.elementor-kit-5{--e-global-color-primary:#0D0D0D;--e-global-color-secondary:#1A1A1A;--e-global-color-text:#FAFAF8;--e-global-color-accent:#F0EDE8;--e-global-color-7b33d13:#8C8577;--e-global-color-020dbb8:#A69872;--e-global-typography-primary-font-family:"Cormorant Garamond";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Cormorant Garamond";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"DM Sans";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Cormorant Garamond";--e-global-typography-accent-font-weight:500;}.elementor-kit-5 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//* =======================================================================
   HYPE MÉDIAS — Design system pour Elementor
   Coller ce fichier dans : Elementor → Site Settings → Custom CSS
   (ou dans un widget "HTML" en tête de page, enveloppé dans <style>…</style>)
   ======================================================================= */

/* --- 1. Fonts (Google Fonts) --------------------------------------------
   Elementor Pro charge déjà certaines fonts. On impose les nôtres via @import
   ou via Elementor → Site Settings → Typography → Custom Fonts.
-------------------------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* --- 2. Design tokens --------------------------------------------------- */
:root {
  --hm-bg:             #0D0D0D;
  --hm-bg-cream:       #EFEBE3;
  --hm-bg-cream-soft:  #F6F3ED;
  --hm-ink:            #0D0D0D;
  --hm-ink-soft:       #2A2824;
  --hm-ink-mute:       #6B6458;
  --hm-cream:          #EFEBE3;
  --hm-cream-mute:     rgba(239,235,227,0.62);
  --hm-gold:           #C8A76B;
  --hm-gold-bright:    #E8D1A0;
  --hm-hairline:       rgba(13,13,13,0.08);
  --hm-hairline-dark:  rgba(239,235,227,0.12);

  --hm-serif:  'Cormorant Garamond', Georgia, serif;
  --hm-sans:   'Inter', system-ui, -apple-system, sans-serif;
  --hm-mono:   'JetBrains Mono', ui-monospace, monospace;
}

/* --- 3. Racine pour scoping -------------------------------------------- */
.hm {
  font-family: var(--hm-sans);
  color: var(--hm-ink);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.hm *, .hm *::before, .hm *::after { box-sizing: border-box; }
.hm p { margin: 0; }
.hm h1, .hm h2, .hm h3, .hm h4 { margin: 0; font-weight: 400; }
.hm a { text-decoration: none; color: inherit; }
.hm img { display: block; max-width: 100%; }
.hm ul { list-style: none; margin: 0; padding: 0; }

/* --- 4. Utilitaires ----------------------------------------------------- */
.hm-serif { font-family: var(--hm-serif); font-weight: 400; letter-spacing: -0.01em; }
.hm-mono  { font-family: var(--hm-mono); }
.hm-eyebrow {
  font-family: var(--hm-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.hm-gold { color: var(--hm-gold); }
.hm-ink  { color: var(--hm-ink); }
.hm ::selection { background: var(--hm-gold); color: var(--hm-ink); }

/* --- 5. Section padding utilities -------------------------------------- */
.hm-section { padding: 120px 80px; }
.hm-section--cream      { background: var(--hm-bg-cream); }
.hm-section--cream-soft { background: var(--hm-bg-cream-soft); }
.hm-section--dark       { background: var(--hm-bg); color: var(--hm-cream); }
.hm-section--dark .hm-serif { color: inherit; }

/* --- 6. Buttons -------------------------------------------------------- */
.hm-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 28px;
  font-family: var(--hm-sans);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: background .2s, color .2s, border-color .2s;
  cursor: pointer;
  border: 0;
}
.hm-btn--gold { background: var(--hm-gold); color: #0D0D0D; }
.hm-btn--gold:hover { background: var(--hm-gold-bright); color: #0D0D0D; }
.hm-btn--ink  { background: var(--hm-ink); color: var(--hm-cream); }
.hm-btn--ghost-dark {
  background: transparent; color: var(--hm-cream);
  border: 1px solid rgba(239,235,227,0.35);
}
.hm-btn--ghost-dark:hover { background: rgba(239,235,227,0.08); }
.hm-btn--ghost-light {
  background: transparent; color: var(--hm-ink);
  border: 1px solid rgba(13,13,13,0.28);
}
.hm-btn--ghost-light:hover { background: rgba(13,13,13,0.05); }
.hm-btn--lg { padding: 20px 40px; font-size: 14px; letter-spacing: 0.06em; }

/* --- 7. Arrow glyph (inline SVG inside buttons) ------------------------ */
.hm-arrow {
  width: 14px; height: 10px;
  display: inline-block; flex-shrink: 0;
}

/* --- 8. HERO ----------------------------------------------------------- */
.hm-hero {
  position: relative;
  min-height: 100vh;
  background: var(--hm-bg);
  color: var(--hm-cream);
  padding: 140px 80px 100px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.hm-hero__grain {
  position: absolute; inset: 0; pointer-events: none; opacity: .06;
  mix-blend-mode: overlay; z-index: 3;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.9'/></svg>");
}
.hm-hero__vignette {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse at 70% 50%, transparent 0%, rgba(13,13,13,0.55) 100%);
}
.hm-hero__lockup { position: relative; z-index: 2; max-width: 720px; }
.hm-hero__eyebrow {
  color: var(--hm-gold); margin-bottom: 32px;
  display: flex; align-items: center; gap: 12px;
}
.hm-hero__eyebrow::before {
  content: ""; width: 28px; height: 1px; background: var(--hm-gold);
  display: inline-block;
}
.hm-hero__title {
  font-family: var(--hm-serif);
  font-size: 96px;
  line-height: 0.96;
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-bottom: 28px;
  text-wrap: balance;
}
.hm-hero__title em {
  font-weight: 400;
  background: linear-gradient(180deg, var(--hm-gold-bright) 0%, var(--hm-gold) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hm-hero__sub {
  font-size: 17px;
  line-height: 1.55;
  color: var(--hm-cream-mute);
  max-width: 520px;
  margin-bottom: 44px;
  text-wrap: pretty;
}
.hm-hero__ctas { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.hm-hero__meta {
  position: absolute; left: 80px; bottom: 40px;
  color: rgba(239,235,227,0.4);
  font-family: var(--hm-mono);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  display: flex; align-items: center; gap: 10px;
  z-index: 2;
}
.hm-hero__meta-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--hm-gold);
  animation: hm-pulse 2.4s ease-in-out infinite;
}
.hm-hero__scroll {
  position: absolute; right: 80px; bottom: 40px;
  color: rgba(239,235,227,0.4);
  font-family: var(--hm-mono);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  z-index: 2;
}
@keyframes hm-pulse {
  0%, 100% { opacity: 0.3; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.3); }
}

/* --- 9. PROOF band ----------------------------------------------------- */
.hm-proof { padding: 100px 80px 80px; background: var(--hm-bg-cream);
  border-top: 1px solid var(--hm-hairline);
  border-bottom: 1px solid var(--hm-hairline);
}
.hm-proof__metrics {
  display: grid; grid-template-columns: repeat(4, 1fr); margin-bottom: 80px;
}
.hm-proof__metric { padding: 8px 24px; border-left: 1px solid var(--hm-hairline); }
.hm-proof__metric:first-child { border-left: 0; }
.hm-proof__value {
  font-family: var(--hm-serif);
  font-size: 72px; line-height: 1; font-weight: 400;
  color: var(--hm-ink); letter-spacing: -0.03em; margin-bottom: 10px;
}
.hm-proof__label { color: var(--hm-ink-mute); }
.hm-proof__divider {
  display: flex; align-items: center; gap: 24px; margin-bottom: 40px;
}
.hm-proof__divider-line { flex: 1; height: 1px; background: var(--hm-hairline); }
.hm-proof__divider-label { color: var(--hm-ink-mute); }
.hm-proof__logos { display: grid; grid-template-columns: repeat(4, 1fr); }
.hm-proof__logo {
  font-family: var(--hm-serif);
  text-align: center;
  padding: 28px 12px;
  font-size: 22px;
  font-style: italic;
  color: var(--hm-ink-soft);
  opacity: 0.55;
  border-right: 1px solid var(--hm-hairline);
  border-bottom: 1px solid var(--hm-hairline);
  transition: opacity .2s;
}
.hm-proof__logo:nth-child(4n) { border-right: 0; }
.hm-proof__logo:nth-child(n+5) { border-bottom: 0; }
.hm-proof__logo:hover { opacity: 1; }

/* --- 10. VERTICALS (3 cartes "pourquoi") ------------------------------- */
.hm-verticals { padding: 120px 80px; background: var(--hm-bg-cream-soft);
  border-top: 1px solid var(--hm-hairline);
}
.hm-verticals__header {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  margin-bottom: 72px; align-items: end;
}
.hm-verticals__title {
  font-family: var(--hm-serif);
  font-size: clamp(44px, 5.5vw, 72px);
  line-height: 0.98; font-weight: 400; letter-spacing: -0.025em;
  text-wrap: balance;
}
.hm-verticals__intro {
  font-size: 16px; line-height: 1.6; color: var(--hm-ink-mute);
  max-width: 460px; justify-self: end; text-wrap: pretty;
}
.hm-verticals__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
.hm-card {
  padding: 36px; background: var(--hm-bg-cream);
  border: 1px solid var(--hm-hairline);
  min-height: 420px;
  display: flex; flex-direction: column;
  position: relative; overflow: hidden;
  transition: background .32s, color .32s;
  cursor: pointer;
}
.hm-card:hover { background: var(--hm-bg); color: var(--hm-cream); }
.hm-card:hover .hm-card__desc { color: rgba(239,235,227,0.68); }
.hm-card:hover .hm-card__tags-wrap { border-top-color: rgba(239,235,227,0.15); }
.hm-card:hover .hm-card__tag { border-color: rgba(239,235,227,0.25); }
.hm-card:hover .hm-card__arrow { opacity: 1; transform: translate(0,0); }
.hm-card__num {
  font-family: var(--hm-mono);
  font-size: 11px; letter-spacing: 0.2em;
  color: var(--hm-gold); margin-bottom: 28px;
}
.hm-card__title {
  font-family: var(--hm-serif);
  font-size: clamp(26px, 2.3vw, 32px);
  line-height: 1.05; font-weight: 400; letter-spacing: -0.015em;
  margin-bottom: 20px; text-wrap: balance;
}
.hm-card__desc {
  font-size: 15px; line-height: 1.55;
  color: var(--hm-ink-mute); margin-bottom: 24px; flex: 1;
  text-wrap: pretty; transition: color .32s;
}
.hm-card__examples {
  font-family: var(--hm-serif);
  font-style: italic;
  font-size: 14px; color: var(--hm-gold); margin-bottom: 20px;
}
.hm-card__tags-wrap {
  padding-top: 20px;
  border-top: 1px solid var(--hm-hairline);
  display: flex; flex-wrap: wrap; gap: 6px;
  transition: border-color .32s;
}
.hm-card__tag {
  font-size: 11px; letter-spacing: 0.04em;
  padding: 4px 10px; border: 1px solid var(--hm-hairline);
  transition: border-color .32s;
}
.hm-card__arrow {
  position: absolute; top: 36px; right: 36px;
  color: var(--hm-gold);
  opacity: 0; transform: translate(-6px, 6px);
  transition: opacity .3s, transform .3s;
}

/* --- 11. PORTFOLIO ----------------------------------------------------- */
.hm-portfolio { padding: 120px 80px; background: var(--hm-bg-cream-soft); }
.hm-portfolio__header {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: 64px; gap: 40px; flex-wrap: wrap;
}
.hm-portfolio__title {
  font-family: var(--hm-serif);
  font-size: clamp(44px, 5.5vw, 72px);
  line-height: 0.98; font-weight: 400; letter-spacing: -0.025em;
  max-width: 720px; text-wrap: balance;
}
.hm-portfolio__link {
  color: var(--hm-ink); font-size: 13px;
  letter-spacing: 0.04em; text-transform: uppercase;
  font-weight: 500;
  display: inline-flex; align-items: center; gap: 10px;
  border-bottom: 1px solid var(--hm-ink); padding-bottom: 4px;
}
.hm-portfolio__grid {
  display: grid; grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: minmax(160px, auto); gap: 20px;
}
.hm-project {
  position: relative; overflow: hidden;
  background: var(--hm-bg); color: var(--hm-cream);
  display: block;
}
.hm-project__img {
  position: absolute; inset: 0;
  transition: transform .9s cubic-bezier(0.2, 0.8, 0.2, 1);
  background:
    linear-gradient(180deg, #2a2822 0%, #151411 70%, #0e0d0b 100%),
    linear-gradient(135deg, #1a1814 0%, #0a0908 100%);
  background-blend-mode: multiply;
}
.hm-project:hover .hm-project__img { transform: scale(1.04); }
.hm-project__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(13,13,13,0.85) 100%);
  opacity: 0.75; transition: opacity .4s;
}
.hm-project:hover .hm-project__overlay { opacity: 1; }
.hm-project__num {
  position: absolute; top: 20px; left: 20px;
  font-family: var(--hm-mono);
  font-size: 11px; letter-spacing: 0.2em; color: var(--hm-gold);
}
.hm-project__year {
  position: absolute; top: 20px; right: 20px;
  font-family: var(--hm-mono);
  font-size: 11px; letter-spacing: 0.2em;
  color: rgba(239,235,227,0.55);
}
.hm-project__meta {
  position: absolute; left: 24px; right: 24px; bottom: 24px;
  transition: transform .4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.hm-project:hover .hm-project__meta { transform: translateY(-4px); }
.hm-project__title {
  font-family: var(--hm-serif);
  font-size: 40px; line-height: 1; font-style: italic;
  letter-spacing: -0.01em; margin-bottom: 8px;
}
.hm-project--compact .hm-project__title { font-size: 28px; }
.hm-project__row {
  display: flex; align-items: center; justify-content: space-between;
}
.hm-project__cat {
  font-family: var(--hm-mono);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(239,235,227,0.7);
}
.hm-project__cta {
  color: var(--hm-gold); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase;
  display: flex; align-items: center; gap: 8px;
  opacity: 0; transform: translateX(-8px);
  transition: opacity .3s, transform .3s;
}
.hm-project:hover .hm-project__cta { opacity: 1; transform: translateX(0); }

/* --- 12. SERVICES (grille 4×2 sur fond noir) --------------------------- */
.hm-services { padding: 120px 80px; background: var(--hm-bg); color: var(--hm-cream); }
.hm-services__header {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  margin-bottom: 72px; align-items: end;
}
.hm-services__title {
  font-family: var(--hm-serif);
  font-size: clamp(44px, 5.5vw, 72px);
  line-height: 0.98; font-weight: 400; letter-spacing: -0.025em;
  text-wrap: balance;
}
.hm-services__intro {
  font-size: 17px; line-height: 1.55;
  color: rgba(239,235,227,0.62);
  max-width: 460px; justify-self: end; text-wrap: pretty;
}
.hm-services__intro em {
  font-family: var(--hm-serif);
  color: var(--hm-gold); font-style: italic;
}
.hm-services__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--hm-hairline-dark);
  border-left: 1px solid var(--hm-hairline-dark);
}
.hm-service {
  padding: 32px 24px;
  border-right: 1px solid var(--hm-hairline-dark);
  border-bottom: 1px solid var(--hm-hairline-dark);
  display: flex; flex-direction: column;
  min-height: 280px;
  transition: background .3s;
}
.hm-service:hover { background: rgba(200,167,107,0.04); }
.hm-service__title {
  font-family: var(--hm-serif);
  font-size: 26px; font-weight: 400; letter-spacing: -0.01em;
  margin-bottom: 18px; text-wrap: balance; line-height: 1.05;
}
.hm-service__list {
  display: flex; flex-direction: column; gap: 6px; flex: 1; margin-bottom: 20px;
}
.hm-service__list li {
  font-size: 13px; color: rgba(239,235,227,0.7);
  display: flex; align-items: center; gap: 10px;
}
.hm-service__list li::before {
  content: ""; width: 3px; height: 3px; border-radius: 50%;
  background: var(--hm-gold); display: inline-block; flex-shrink: 0;
}
.hm-service__kpi-wrap {
  padding-top: 14px; border-top: 1px solid rgba(239,235,227,0.1);
}
.hm-service__kpi {
  font-family: var(--hm-serif);
  font-size: 32px; font-weight: 400; color: var(--hm-gold);
  letter-spacing: -0.02em; line-height: 1; margin-bottom: 4px;
}
.hm-service__kpi-label { color: rgba(239,235,227,0.45); }
.hm-service--custom { background: rgba(200,167,107,0.06); justify-content: center; }
.hm-service--custom .hm-eyebrow { color: var(--hm-gold); margin-bottom: 14px; }
.hm-service--custom p {
  font-size: 14px; line-height: 1.55;
  color: rgba(239,235,227,0.72); margin-bottom: 18px;
}
.hm-service--custom a {
  color: var(--hm-gold); font-size: 13px;
  letter-spacing: 0.04em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 8px;
}

/* --- 13. AI STACK (4 blocs + KPI ligne) -------------------------------- */
.hm-ai {
  padding: 120px 80px;
  background: #0a0a0a; color: var(--hm-cream);
  border-top: 1px solid rgba(239,235,227,0.08);
  position: relative; overflow: hidden;
}
.hm-ai__glow {
  position: absolute; left: -10%; top: 30%;
  width: 700px; height: 700px; border-radius: 50%;
  background: radial-gradient(circle, rgba(200,167,107,0.08) 0%, transparent 70%);
  pointer-events: none;
}
.hm-ai__header {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  margin-bottom: 64px; align-items: end;
  position: relative;
}
.hm-ai__title {
  font-family: var(--hm-serif);
  font-size: clamp(44px, 5.5vw, 72px);
  line-height: 0.98; font-weight: 400; letter-spacing: -0.025em;
  text-wrap: balance;
}
.hm-ai__intro {
  font-size: 16px; line-height: 1.6;
  color: rgba(239,235,227,0.62);
  max-width: 480px; justify-self: end; text-wrap: pretty;
}
.hm-ai__intro em {
  font-family: var(--hm-serif);
  color: var(--hm-gold); font-style: italic;
}
.hm-ai__strip {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 20px;
  border: 1px solid rgba(200,167,107,0.2);
  background: rgba(200,167,107,0.04);
  margin-bottom: 40px;
}
.hm-ai__strip-dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--hm-gold);
  box-shadow: 0 0 12px rgba(200,167,107,0.6);
}
.hm-ai__strip span.hm-eyebrow { color: var(--hm-gold); }
.hm-ai__strip-text { font-size: 13px; color: rgba(239,235,227,0.72); }
.hm-ai__blocks {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  margin-bottom: 80px;
}
.hm-ai-block {
  padding: 28px;
  background: rgba(239,235,227,0.02);
  border: 1px solid rgba(239,235,227,0.08);
  min-height: 280px;
  display: flex; flex-direction: column;
}
.hm-ai-block__num {
  font-family: var(--hm-mono);
  font-size: 11px; letter-spacing: 0.2em;
  color: var(--hm-gold); margin-bottom: 20px;
}
.hm-ai-block__title {
  font-family: var(--hm-serif);
  font-size: 26px; font-weight: 400; letter-spacing: -0.01em;
  margin-bottom: 14px; line-height: 1.05;
}
.hm-ai-block__desc {
  font-size: 13px; line-height: 1.55;
  color: rgba(239,235,227,0.62); flex: 1; margin-bottom: 18px;
  text-wrap: pretty;
}
.hm-ai-block__tools-label {
  color: rgba(239,235,227,0.4); margin-bottom: 8px;
}
.hm-ai-block__tools { display: flex; flex-wrap: wrap; gap: 6px; }
.hm-ai-block__tool {
  font-family: var(--hm-mono);
  font-size: 11px; padding: 4px 10px;
  border: 1px solid rgba(200,167,107,0.35);
  color: var(--hm-gold);
  letter-spacing: 0.04em;
}
.hm-ai__kpis {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid rgba(239,235,227,0.12); padding-top: 40px;
}
.hm-ai__kpi { padding: 0 24px; border-left: 1px solid rgba(239,235,227,0.12); }
.hm-ai__kpi:first-child { border-left: 0; }
.hm-ai__kpi-value {
  font-family: var(--hm-serif);
  font-size: 72px; line-height: 1; color: var(--hm-gold);
  letter-spacing: -0.03em; font-weight: 400; margin-bottom: 10px;
}
.hm-ai__kpi-label { color: rgba(239,235,227,0.55); }

/* --- 14. APPROACH (Manifesto) ------------------------------------------ */
.hm-approach { padding: 140px 80px; background: var(--hm-bg-cream); }
.hm-approach__header {
  display: grid; grid-template-columns: 1fr 1.3fr; gap: 80px;
  margin-bottom: 80px; align-items: start;
}
.hm-approach__meta {
  font-size: 13px; color: var(--hm-ink-mute); line-height: 1.7;
}
.hm-approach__meta-rule {
  height: 1px; background: var(--hm-hairline); margin-bottom: 28px;
}
.hm-approach__title {
  font-family: var(--hm-serif);
  font-size: clamp(44px, 6vw, 88px);
  line-height: 0.98; font-weight: 300; letter-spacing: -0.03em;
  margin-bottom: 40px; text-wrap: balance;
}
.hm-approach__title em { color: var(--hm-gold); }
.hm-approach__body p {
  font-size: 16px; line-height: 1.65; color: var(--hm-ink-soft);
  max-width: 620px; margin-bottom: 20px;
}
.hm-approach__steps {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--hm-hairline);
  margin-bottom: 80px;
}
.hm-step { padding: 32px 24px 32px 24px; border-right: 1px solid var(--hm-hairline); }
.hm-step:first-child { padding-left: 0; }
.hm-step:last-child  { border-right: 0; }
.hm-step__num {
  font-family: var(--hm-mono);
  font-size: 11px; letter-spacing: 0.2em;
  color: var(--hm-gold); margin-bottom: 20px;
}
.hm-step__title {
  font-family: var(--hm-serif);
  font-size: 26px; font-weight: 400; letter-spacing: -0.01em;
  margin-bottom: 14px; line-height: 1.05;
}
.hm-step__desc {
  font-size: 14px; line-height: 1.6; color: var(--hm-ink-mute);
  text-wrap: pretty;
}
.hm-model {
  background: var(--hm-bg); color: var(--hm-cream);
  padding: 48px 40px;
  display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr auto;
  gap: 40px; align-items: center;
  margin-bottom: 60px;
}
.hm-model__lead { font-size: 15px; line-height: 1.55; color: rgba(239,235,227,0.75); }
.hm-model__lead em { font-family: var(--hm-serif); color: var(--hm-gold); font-style: italic; }
.hm-model__lead-eyebrow { color: var(--hm-gold); margin-bottom: 14px; }
.hm-model__kpi-value {
  font-family: var(--hm-serif);
  font-size: 42px; font-weight: 400; color: var(--hm-cream);
  letter-spacing: -0.02em; line-height: 1; margin-bottom: 6px;
}
.hm-model__kpi-label { color: rgba(239,235,227,0.5); }
.hm-testimonial {
  padding: 48px 0 0;
  border-top: 1px solid var(--hm-hairline);
  display: grid; grid-template-columns: 1fr 2fr; gap: 48px;
}
.hm-testimonial__eyebrow { color: var(--hm-gold); margin-bottom: 14px; }
.hm-testimonial__source {
  font-size: 13px; color: var(--hm-ink-mute); line-height: 1.6;
}
.hm-testimonial__source strong { color: var(--hm-ink); font-weight: 500; }
.hm-testimonial__quote {
  font-family: var(--hm-serif);
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.25; font-style: italic; font-weight: 400;
  color: var(--hm-ink); margin: 0; text-wrap: pretty;
  letter-spacing: -0.01em;
}

/* --- 15. CTA final ----------------------------------------------------- */
.hm-cta {
  padding: 140px 80px;
  background: var(--hm-bg); color: var(--hm-cream);
  position: relative; overflow: hidden; text-align: center;
}
.hm-cta__glow {
  position: absolute; left: 50%; bottom: -300px;
  width: 1200px; height: 600px; transform: translateX(-50%);
  background: radial-gradient(ellipse at center top, rgba(200,167,107,0.18) 0%, transparent 60%);
  pointer-events: none;
}
.hm-cta__inner { position: relative; max-width: 960px; margin: 0 auto; }
.hm-cta__eyebrow { color: var(--hm-gold); margin-bottom: 24px; }
.hm-cta__title {
  font-family: var(--hm-serif);
  font-size: clamp(56px, 8.5vw, 112px);
  line-height: 0.98; font-weight: 300; letter-spacing: -0.035em;
  margin-bottom: 40px; text-wrap: balance;
}
.hm-cta__title em { color: var(--hm-gold); }
.hm-cta__sub {
  font-size: 18px; line-height: 1.5;
  color: rgba(239,235,227,0.62);
  max-width: 620px; margin: 0 auto 48px; text-wrap: pretty;
}
.hm-cta__ctas { display: inline-flex; align-items: center; gap: 20px; flex-wrap: wrap; justify-content: center; }

/* --- 16. Responsive ---------------------------------------------------- */
@media (max-width: 1100px) {
  .hm-section, .hm-hero, .hm-proof, .hm-verticals, .hm-portfolio,
  .hm-services, .hm-ai, .hm-approach, .hm-cta { padding-left: 48px; padding-right: 48px; }
  .hm-hero__meta, .hm-hero__scroll { left: 48px; right: 48px; }
  .hm-hero__title { font-size: 72px; }
  .hm-services__grid, .hm-ai__blocks { grid-template-columns: repeat(2, 1fr); }
  .hm-proof__metrics, .hm-proof__logos, .hm-ai__kpis { grid-template-columns: repeat(2, 1fr); }
  .hm-proof__metric:nth-child(3) { border-left: 0; }
  .hm-proof__logo:nth-child(2n) { border-right: 0; }
  .hm-proof__logo:nth-child(n+5) { border-bottom: 1px solid var(--hm-hairline); }
  .hm-proof__logo:nth-last-child(-n+2) { border-bottom: 0; }
  .hm-verticals__grid { grid-template-columns: 1fr; }
  .hm-approach__steps { grid-template-columns: repeat(2, 1fr); }
  .hm-step:nth-child(2) { border-right: 0; }
  .hm-model { grid-template-columns: 1fr 1fr; }
  .hm-portfolio__grid > * { grid-column: span 12 !important; grid-row: span 2 !important; }
}
@media (max-width: 680px) {
  .hm-section, .hm-hero, .hm-proof, .hm-verticals, .hm-portfolio,
  .hm-services, .hm-ai, .hm-approach, .hm-cta { padding: 80px 24px; }
  .hm-hero { padding-top: 120px; padding-bottom: 120px; }
  .hm-hero__meta, .hm-hero__scroll { left: 24px; right: 24px; bottom: 24px; }
  .hm-hero__title { font-size: 52px; }
  .hm-hero__sub { font-size: 15px; }
  .hm-verticals__header, .hm-services__header, .hm-ai__header, .hm-approach__header {
    grid-template-columns: 1fr; gap: 32px;
  }
  .hm-verticals__intro, .hm-services__intro, .hm-ai__intro { justify-self: start; }
  .hm-services__grid, .hm-ai__blocks, .hm-proof__metrics, .hm-proof__logos,
  .hm-approach__steps, .hm-ai__kpis { grid-template-columns: 1fr; }
  .hm-proof__metric, .hm-ai__kpi { border-left: 0; border-top: 1px solid var(--hm-hairline); padding: 24px 0; }
  .hm-ai__kpi { border-top-color: rgba(239,235,227,0.12); }
  .hm-proof__metrics .hm-proof__metric:first-child { border-top: 0; }
  .hm-proof__logo { border-right: 0 !important; }
  .hm-proof__logo:last-child { border-bottom: 0; }
  .hm-step { padding: 24px 0; border-right: 0; border-bottom: 1px solid var(--hm-hairline); }
  .hm-step:last-child { border-bottom: 0; }
  .hm-model { grid-template-columns: 1fr; padding: 32px 24px; }
  .hm-testimonial { grid-template-columns: 1fr; gap: 24px; }
  .hm-cta__title { font-size: 44px; }
}



/* =======================================================================
   HYPE MÉDIAS — Extension CSS pour les 4 nouvelles pages
   Réalisations · Cas client · Blog · Article
   À concaténer APRÈS hype-medias.css (ou dans le même fichier)
   ======================================================================= */

/* --- Primitives partagées supplémentaires ----------------------------- */
.hm em { font-style: italic; font-weight: 400; }
.hm-h1     { font-family: var(--hm-serif); font-size: clamp(48px, 7vw, 96px); line-height: 0.98; letter-spacing: -0.02em; }
.hm-h1-xl  { font-family: var(--hm-serif); font-size: clamp(64px, 9vw, 128px); line-height: 0.94; letter-spacing: -0.025em; }
.hm-h2     { font-family: var(--hm-serif); font-size: clamp(36px, 5vw, 64px); line-height: 1.02; letter-spacing: -0.02em; }
.hm-h3     { font-family: var(--hm-serif); font-size: clamp(28px, 3.4vw, 44px); line-height: 1.1; letter-spacing: -0.015em; }
.hm-lead     { font-size: clamp(17px, 1.5vw, 21px); line-height: 1.55; color: var(--hm-ink-soft); }
.hm-lead-lg  { font-size: clamp(19px, 1.8vw, 24px); line-height: 1.5; color: var(--hm-ink-soft); max-width: 780px; }
.hm-body-lg  { font-size: 19px; line-height: 1.65; color: var(--hm-ink-soft); max-width: 70ch; }
.hm-dim      { color: var(--hm-ink-mute); }
.hm-gold     { color: var(--hm-gold); }
.hm-cream    { color: var(--hm-cream); }
.hm-bg-cream-soft { background: var(--hm-bg-cream-soft); }
.hm-bg-dark       { background: var(--hm-bg); color: var(--hm-cream); }
.hm-bg-dark .hm-eyebrow { color: var(--hm-gold); }

.hm-mb-8  { margin-bottom: 8px; }
.hm-mb-16 { margin-bottom: 16px; }
.hm-mb-20 { margin-bottom: 20px; }
.hm-mb-24 { margin-bottom: 24px; }
.hm-mb-28 { margin-bottom: 28px; }
.hm-mb-32 { margin-bottom: 32px; }
.hm-mb-64 { margin-bottom: 64px; }
.hm-mb-72 { margin-bottom: 72px; }
.hm-mb-80 { margin-bottom: 80px; }

/* Pills / filters */
.hm-pill {
  font-family: var(--hm-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid var(--hm-hairline);
  background: transparent;
  color: var(--hm-ink-soft);
  cursor: pointer;
  transition: all .2s ease;
}
.hm-pill:hover { border-color: var(--hm-ink); }
.hm-pill-active { background: var(--hm-ink); color: var(--hm-cream); border-color: var(--hm-ink); }

/* Back link */
.hm-back {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--hm-mono); font-size: 12px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--hm-ink-mute);
  transition: color .2s;
}
.hm-back:hover { color: var(--hm-ink); }

/* Boutons */
.hm-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 18px 32px; border-radius: 999px;
  font-family: var(--hm-mono); font-size: 13px; letter-spacing: 0.1em;
  text-transform: uppercase; transition: all .25s ease; cursor: pointer; border: 1px solid transparent;
}
.hm-btn-primary { background: var(--hm-gold); color: var(--hm-ink); }
.hm-btn-primary:hover { background: var(--hm-gold-bright); }
.hm-btn-ghost { background: transparent; color: var(--hm-cream); border-color: rgba(239,235,227,0.3); }
.hm-btn-ghost:hover { border-color: var(--hm-gold); color: var(--hm-gold); }

/* =======================================================================
   PAGE RÉALISATIONS
   ======================================================================= */
.hm-page-realisations { background: var(--hm-bg-cream); padding: 120px 8vw 80px; }

.hm-real-hero { margin-bottom: 80px; }
.hm-real-hero-grid {
  display: grid; grid-template-columns: 1.3fr 1fr; gap: 80px;
  align-items: end; padding-bottom: 60px;
  border-bottom: 1px solid var(--hm-hairline);
}

/* Filtres */
.hm-real-filters {
  display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.hm-filter-group { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.hm-filter-divider { width: 1px; height: 24px; background: var(--hm-hairline); }

/* Grille bento */
.hm-real-grid-wrap { margin-bottom: 120px; }
.hm-real-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 160px;
  gap: 16px;
}
.hm-real-card {
  position: relative; overflow: hidden; border-radius: 4px;
  background: var(--hm-ink); display: block;
  transition: transform .5s cubic-bezier(.2,.8,.2,1);
}
.hm-real-card:hover { transform: translateY(-4px); }
.hm-real-img {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, #3a3530, #1a1815);
  transition: transform .7s cubic-bezier(.2,.8,.2,1);
}
.hm-real-card:hover .hm-real-img { transform: scale(1.06); }
.hm-real-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(0,0,0,0.85) 100%);
}
.hm-real-top {
  position: absolute; top: 20px; left: 24px; right: 24px;
  display: flex; justify-content: space-between;
  color: var(--hm-cream); font-size: 11px; letter-spacing: 0.1em;
}
.hm-real-bottom {
  position: absolute; bottom: 24px; left: 24px; right: 24px;
  color: var(--hm-cream);
}
.hm-real-title { font-size: clamp(22px, 2.2vw, 34px); line-height: 1.05; margin-bottom: 10px; }
.hm-real-tags { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.hm-real-tags span {
  font-family: var(--hm-mono); font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase; padding: 4px 10px;
  border: 1px solid rgba(239,235,227,0.25); border-radius: 999px;
  color: rgba(239,235,227,0.85);
}
.hm-real-kpi-row {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 14px; border-top: 1px solid rgba(239,235,227,0.15);
}
.hm-real-cta {
  font-family: var(--hm-mono); font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--hm-cream);
}

/* Bande CTA */
.hm-cta-band {
  text-align: center; padding: 100px 0; border-top: 1px solid var(--hm-hairline);
}
.hm-cta-band-h { font-size: clamp(36px, 5vw, 64px); line-height: 1.05; margin-bottom: 40px; }

@media (max-width: 900px) {
  .hm-real-hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .hm-real-grid { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 140px; }
  .hm-real-card { grid-column: span 6 !important; grid-row: span 2 !important; }
}

/* =======================================================================
   CAS CLIENT
   ======================================================================= */
.hm-page-cas { background: var(--hm-bg-cream); }

.hm-cas-hero { padding: 80px 8vw 0; }
.hm-cas-hero-top {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 80px;
}
.hm-cas-hero-grid {
  display: grid; grid-template-columns: 1.3fr 1fr; gap: 60px;
  align-items: end; margin-bottom: 80px;
  padding-bottom: 60px; border-bottom: 1px solid var(--hm-hairline);
}
.hm-tagline { font-size: clamp(22px, 2.5vw, 32px); color: var(--hm-ink-mute); line-height: 1.25; margin-top: 28px; max-width: 40ch; }
.hm-cas-meta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px 40px; }
.hm-meta-v { font-family: var(--hm-serif); font-size: 22px; line-height: 1.2; margin-top: 6px; }

.hm-cas-cover {
  width: 100%; aspect-ratio: 16/7;
  background: linear-gradient(135deg, #3a3530, #1a1815);
  border-radius: 4px;
}

.hm-cas-section { padding: 120px 8vw; }
.hm-cas-section.hm-bg-dark { padding: 140px 8vw; }

.hm-twocol {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px;
  align-items: start;
}

.hm-enjeux-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--hm-hairline);
}
.hm-enjeu {
  padding: 40px 32px 40px 0;
  border-right: 1px solid var(--hm-hairline);
}
.hm-enjeu:last-child { border-right: 0; padding-right: 0; }
.hm-enjeu .hm-mono { display: block; margin-bottom: 16px; font-size: 13px; }
.hm-enjeu h3 { font-size: 24px; line-height: 1.2; margin-bottom: 14px; }
.hm-enjeu p { color: var(--hm-ink-mute); line-height: 1.55; }

.hm-approach-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border-top: 1px solid rgba(239,235,227,0.12);
}
.hm-approach-step {
  padding: 48px 28px 48px 0;
  border-right: 1px solid rgba(239,235,227,0.12);
  color: var(--hm-cream);
}
.hm-approach-step:last-child { border-right: 0; padding-right: 0; }
.hm-approach-step .hm-mono { display: block; margin-bottom: 24px; font-size: 13px; }
.hm-approach-step h3 { font-size: 26px; margin-bottom: 16px; color: var(--hm-cream); }
.hm-approach-step p { color: rgba(239,235,227,0.65); line-height: 1.55; }

.hm-gallery {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px;
}
.hm-gal-cell {
  position: relative; height: 0;
  background: linear-gradient(135deg, #3a3530, #1a1815);
  border-radius: 4px;
}

.hm-cas-kpi { padding: 120px 8vw; background: var(--hm-bg); color: var(--hm-cream); }
.hm-kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(239,235,227,0.12); }
.hm-kpi {
  padding: 40px 24px 40px 0;
  border-right: 1px solid rgba(239,235,227,0.12);
}
.hm-kpi:last-child { border-right: 0; }
.hm-kpi-v { font-size: clamp(60px, 7vw, 96px); line-height: 1; color: var(--hm-gold); margin-bottom: 16px; letter-spacing: -0.02em; }

.hm-cas-testi { text-align: center; max-width: 1100px; margin: 0 auto; }
.hm-quote {
  font-size: clamp(28px, 3.4vw, 44px); line-height: 1.3;
  font-style: italic; color: var(--hm-ink-soft);
  margin-bottom: 40px; letter-spacing: -0.01em;
}

.hm-stack-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.hm-stack-chips span {
  font-family: var(--hm-mono); font-size: 12px; letter-spacing: 0.1em;
  text-transform: uppercase; padding: 10px 18px;
  border: 1px solid var(--hm-hairline); border-radius: 999px;
  color: var(--hm-ink-soft);
}

.hm-cas-next {
  display: block; position: relative; overflow: hidden;
  background: var(--hm-bg); color: var(--hm-cream);
}
.hm-cas-next-img {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, #3a3530, #1a1815);
  opacity: 0.35; transition: opacity .5s, transform .7s cubic-bezier(.2,.8,.2,1);
}
.hm-cas-next:hover .hm-cas-next-img { opacity: 0.55; transform: scale(1.04); }
.hm-cas-next-content {
  position: relative; padding: 120px 8vw;
  display: flex; justify-content: space-between; align-items: end; gap: 40px;
}
.hm-next-title { font-size: clamp(48px, 7vw, 96px); line-height: 1; }

@media (max-width: 900px) {
  .hm-cas-hero-grid, .hm-twocol { grid-template-columns: 1fr; gap: 32px; }
  .hm-cas-meta-grid { grid-template-columns: 1fr 1fr; }
  .hm-enjeux-grid, .hm-approach-grid, .hm-kpi-row { grid-template-columns: 1fr; }
  .hm-enjeu, .hm-approach-step, .hm-kpi { border-right: 0; border-bottom: 1px solid var(--hm-hairline); padding: 32px 0; }
  .hm-approach-step { border-bottom-color: rgba(239,235,227,0.12); }
  .hm-cas-section { padding: 80px 6vw; }
  .hm-cas-next-content { flex-direction: column; align-items: start; padding: 80px 6vw; }
}

/* =======================================================================
   BLOG (INDEX)
   ======================================================================= */
.hm-page-blog { background: var(--hm-bg-cream); }

.hm-blog-hero { padding: 100px 8vw 60px; }
.hm-blog-hero-top {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 60px; padding-bottom: 32px;
  border-bottom: 1px solid var(--hm-hairline);
}

.hm-featured {
  display: block; margin-top: 80px; padding-top: 60px;
  border-top: 1px solid var(--hm-hairline);
  transition: opacity .3s;
}
.hm-featured:hover { opacity: 0.85; }
.hm-featured-grid {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 60px;
  align-items: center;
}
.hm-featured-meta { display: flex; gap: 20px; align-items: center; margin-bottom: 32px; flex-wrap: wrap; }
.hm-featured-title { font-size: clamp(36px, 4.5vw, 56px); line-height: 1.05; letter-spacing: -0.02em; margin-bottom: 28px; }
.hm-featured-excerpt { font-size: 19px; line-height: 1.55; color: var(--hm-ink-soft); max-width: 58ch; margin-bottom: 40px; }
.hm-featured-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px; border-top: 1px solid var(--hm-hairline);
}
.hm-read-link { font-family: var(--hm-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--hm-gold); }
.hm-featured-img {
  aspect-ratio: 4/5;
  background: linear-gradient(135deg, #3a3530, #1a1815);
  border-radius: 4px;
}

.hm-blog-body { padding: 80px 8vw 120px; }
.hm-blog-filters {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  margin-bottom: 64px; padding-bottom: 32px;
  border-bottom: 1px solid var(--hm-hairline);
}

.hm-blog-grid {
  display: grid; grid-template-columns: repeat(6, 1fr);
  gap: 48px 32px;
}
.hm-article-card { display: block; transition: opacity .3s; }
.hm-article-card:hover { opacity: 0.78; }
.hm-article-card .hm-article-img {
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, #3a3530, #1a1815);
  border-radius: 4px; margin-bottom: 24px;
}
.hm-article-title { font-size: 24px; line-height: 1.15; margin: 14px 0; letter-spacing: -0.01em; }
.hm-article-title-lg { font-size: clamp(30px, 3vw, 40px); line-height: 1.1; margin: 14px 0 20px; letter-spacing: -0.015em; }
.hm-article-card p { color: var(--hm-ink-mute); line-height: 1.55; margin-bottom: 16px; font-size: 15px; }
.hm-article-card .hm-mono { font-size: 11px; }

.hm-article-wide { display: grid !important; grid-template-columns: 1.1fr 1fr; gap: 40px; align-items: center; padding: 40px 0; border-top: 1px solid var(--hm-hairline); border-bottom: 1px solid var(--hm-hairline); }
.hm-article-wide .hm-article-img { margin-bottom: 0; aspect-ratio: 4/3; }

/* Newsletter */
.hm-newsletter { padding: 120px 8vw; background: var(--hm-bg); color: var(--hm-cream); }
.hm-newsletter-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.hm-newsletter h2 { color: var(--hm-cream); }
.hm-newsletter-form { display: flex; flex-direction: column; gap: 20px; }
.hm-newsletter-input {
  display: flex; background: rgba(239,235,227,0.06);
  border: 1px solid rgba(239,235,227,0.15); border-radius: 999px;
  overflow: hidden;
}
.hm-newsletter-input input {
  flex: 1; background: transparent; border: 0; outline: none;
  padding: 22px 32px; font-family: var(--hm-sans); font-size: 15px;
  color: var(--hm-cream);
}
.hm-newsletter-input input::placeholder { color: rgba(239,235,227,0.4); }
.hm-newsletter-input button {
  background: var(--hm-gold); color: var(--hm-ink); border: 0;
  padding: 0 32px; font-family: var(--hm-mono); font-size: 12px;
  letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer;
  transition: background .2s;
}
.hm-newsletter-input button:hover { background: var(--hm-gold-bright); }

@media (max-width: 900px) {
  .hm-featured-grid, .hm-article-wide, .hm-newsletter-grid { grid-template-columns: 1fr !important; gap: 32px; }
  .hm-blog-grid { grid-template-columns: 1fr; }
  .hm-article-card { grid-column: span 1 !important; }
}

/* =======================================================================
   ARTICLE (LECTURE LONGUE)
   ======================================================================= */
.hm-page-article { background: var(--hm-bg-cream); }

.hm-progress-bar {
  position: fixed; top: 0; left: 0; right: 0; height: 2px;
  background: rgba(13,13,13,0.08); z-index: 100;
}
.hm-progress-fill { height: 100%; background: var(--hm-gold); width: 0%; transition: width .1s; }

.hm-article-hero { padding: 80px 8vw 60px; }
.hm-article-hero-inner { max-width: 900px; }
.hm-article-hero .hm-back { margin-bottom: 60px; display: inline-flex; }
.hm-article-h1 { font-size: clamp(44px, 6vw, 80px); line-height: 1.02; letter-spacing: -0.02em; margin-bottom: 32px; }
.hm-article-deck { font-size: clamp(22px, 2.2vw, 28px); color: var(--hm-ink-mute); line-height: 1.35; margin-bottom: 60px; max-width: 44ch; }

.hm-article-meta {
  display: grid; grid-template-columns: repeat(4, auto);
  gap: 48px; align-items: center; justify-content: start;
  padding: 32px 0; border-top: 1px solid var(--hm-hairline); border-bottom: 1px solid var(--hm-hairline);
}
.hm-share-h { display: flex; gap: 12px; }
.hm-share-h a, .hm-share-buttons a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid var(--hm-hairline);
  font-family: var(--hm-mono); font-size: 12px; color: var(--hm-ink-soft);
  transition: all .2s;
}
.hm-share-h a:hover, .hm-share-buttons a:hover { background: var(--hm-ink); color: var(--hm-cream); border-color: var(--hm-ink); }

.hm-article-cover {
  margin: 60px 8vw 0;
  aspect-ratio: 16/8;
  background: linear-gradient(135deg, #3a3530, #1a1815);
  border-radius: 4px;
}

.hm-article-body-wrap { padding: 120px 8vw; }
.hm-article-body-grid {
  display: grid;
  grid-template-columns: 220px 1fr 60px;
  gap: 80px;
  max-width: 1400px; margin: 0 auto;
}

.hm-toc { position: sticky; top: 120px; align-self: start; }
.hm-toc-list { display: flex; flex-direction: column; gap: 16px; }
.hm-toc-link {
  display: flex; gap: 16px; align-items: baseline;
  padding: 8px 0; font-size: 14px; color: var(--hm-ink-mute);
  border-left: 2px solid transparent; padding-left: 16px; margin-left: -18px;
  transition: all .25s;
}
.hm-toc-link .hm-mono { font-size: 11px; }
.hm-toc-link.hm-toc-active { color: var(--hm-ink); border-left-color: var(--hm-gold); }

.hm-article-body { max-width: 68ch; font-size: 19px; line-height: 1.75; color: var(--hm-ink-soft); }
.hm-article-body p { margin-bottom: 28px; }
.hm-h2-art { font-size: clamp(32px, 3.6vw, 44px); line-height: 1.1; color: var(--hm-ink); margin: 60px 0 28px; letter-spacing: -0.015em; }
.hm-h2-art:first-child { margin-top: 0; }

.hm-pull {
  font-family: var(--hm-serif); font-style: italic;
  font-size: clamp(26px, 2.8vw, 34px); line-height: 1.3;
  color: var(--hm-ink); margin: 40px 0 40px -32px;
  padding-left: 28px; border-left: 3px solid var(--hm-gold);
  max-width: 60ch;
}

.hm-list-num { display: flex; flex-direction: column; gap: 20px; margin: 0 0 32px; }
.hm-list-num li {
  display: grid; grid-template-columns: 40px 1fr; gap: 16px;
  padding-bottom: 20px; border-bottom: 1px solid var(--hm-hairline);
}
.hm-list-num .hm-mono { font-size: 13px; padding-top: 4px; }

.hm-cta-inline {
  background: var(--hm-ink); color: var(--hm-cream);
  padding: 48px; border-radius: 4px; margin: 60px 0;
}
.hm-cta-inline .hm-eyebrow { color: var(--hm-gold); }
.hm-cta-inline-h { font-size: 32px; line-height: 1.1; margin-bottom: 16px; color: var(--hm-cream); }
.hm-cta-inline p { font-size: 16px; color: rgba(239,235,227,0.7); margin-bottom: 28px; }
.hm-cta-inline-form { display: flex; gap: 12px; background: rgba(239,235,227,0.06); border: 1px solid rgba(239,235,227,0.15); border-radius: 999px; overflow: hidden; }
.hm-cta-inline-form input { flex: 1; background: transparent; border: 0; outline: none; padding: 18px 24px; color: var(--hm-cream); font-size: 15px; }
.hm-cta-inline-form input::placeholder { color: rgba(239,235,227,0.4); }
.hm-cta-inline-form button { background: var(--hm-gold); color: var(--hm-ink); border: 0; padding: 0 28px; font-family: var(--hm-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer; }

.hm-author-card {
  display: grid; grid-template-columns: 80px 1fr; gap: 28px;
  padding: 40px 0 0; margin-top: 60px;
  border-top: 1px solid var(--hm-hairline);
}
.hm-author-avatar {
  width: 80px; height: 80px; border-radius: 50%;
  background: var(--hm-ink); color: var(--hm-gold);
  font-family: var(--hm-serif); font-size: 28px;
  display: flex; align-items: center; justify-content: center;
}
.hm-author-name { font-size: 22px; line-height: 1.2; margin-bottom: 8px; }

.hm-share-v { position: sticky; top: 120px; align-self: start; }
.hm-share-buttons { display: flex; flex-direction: column; gap: 10px; }

.hm-related { padding: 120px 8vw; border-top: 1px solid var(--hm-hairline); }
.hm-related-head {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: 64px;
}
.hm-related-all {
  font-family: var(--hm-mono); font-size: 12px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--hm-gold);
}
.hm-related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.hm-related-card { transition: opacity .3s; }
.hm-related-card:hover { opacity: 0.8; }
.hm-related-img {
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, #3a3530, #1a1815);
  border-radius: 4px; margin-bottom: 20px;
}
.hm-related-card h3 { font-size: 22px; line-height: 1.2; margin: 12px 0; }

@media (max-width: 1100px) {
  .hm-article-body-grid { grid-template-columns: 1fr; gap: 40px; }
  .hm-toc, .hm-share-v { position: static; }
  .hm-share-v { display: none; }
}
@media (max-width: 900px) {
  .hm-article-meta { grid-template-columns: 1fr; gap: 20px; }
  .hm-pull { margin-left: 0; }
  .hm-related-grid { grid-template-columns: 1fr; }
  .hm-cta-inline { padding: 32px 24px; }
  .hm-cta-inline-form { flex-direction: column; background: transparent; border: 0; gap: 10px; }
  .hm-cta-inline-form input { background: rgba(239,235,227,0.06); border: 1px solid rgba(239,235,227,0.15); border-radius: 999px; }
  .hm-cta-inline-form button { border-radius: 999px; padding: 16px; }
}/* End custom CSS */