/* ============================================================
   Palimpseste — Marketing Site
   Design System: Literary / Editorial
   Inspired by publishing houses, bookshops, and fine stationery
   ============================================================ */

/* — Google Fonts — */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Source+Sans+3:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

/* — Reset & Base — */
*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  /* Colors — warm paper & ink palette */
  --color-bg: #faf8f5;
  --color-bg-alt: #f2efe9;
  --color-bg-dark: #2c2620;
  --color-text: #2c2620;
  --color-text-secondary: #6b6256;
  --color-text-tertiary: #9a8f82;
  --color-text-on-dark: #f2efe9;
  --color-accent: #1a365d;
  --color-accent-hover: #234578;
  --color-accent-light: #e8edf4;
  --color-accent-warm: #8b4513;
  --color-border: rgba(44, 38, 32, 0.1);
  --color-card-bg: #ffffff;
  --color-card-shadow: rgba(44, 38, 32, 0.04);
  --color-hero-gradient-start: #faf8f5;
  --color-hero-gradient-end: #f2efe9;
  --color-success: #4a7c59;
  --color-warning: #b8860b;

  /* Typography — serif + humanist sans */
  --font-serif: "Cormorant Garamond", "Georgia", "Times New Roman", serif;
  --font-sans: "Source Sans 3", "Source Sans Pro", -apple-system, BlinkMacSystemFont,
    "Helvetica Neue", sans-serif;
  --font-mono: "SF Mono", SFMono-Regular, ui-monospace, Menlo, Monaco, monospace;

  /* Sizes */
  --size-xs: 0.75rem;
  --size-sm: 0.875rem;
  --size-base: 1rem;
  --size-lg: 1.125rem;
  --size-xl: 1.25rem;
  --size-2xl: 1.5rem;
  --size-3xl: 2rem;
  --size-4xl: 2.5rem;
  --size-5xl: 3rem;
  --size-6xl: 3.5rem;

  /* Layout */
  --max-width: 1100px;
  --max-width-narrow: 780px;
  --nav-height: 56px;
  --section-padding: 100px;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-pill: 980px;

  /* Shadows — warm, subtle */
  --shadow-xs: 0 1px 3px rgba(44, 38, 32, 0.04);
  --shadow-sm: 0 2px 8px rgba(44, 38, 32, 0.06);
  --shadow-md: 0 4px 20px rgba(44, 38, 32, 0.08);
  --shadow-lg: 0 8px 32px rgba(44, 38, 32, 0.1);
  --shadow-xl: 0 16px 48px rgba(44, 38, 32, 0.12);

  /* Transitions */
  --ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --duration-fast: 150ms;
  --duration-normal: 250ms;
  --duration-slow: 400ms;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 120px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: var(--font-sans);
  font-size: var(--size-base);
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-bg);
}

a {
  color: var(--color-accent);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

a:hover {
  color: var(--color-accent-hover);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* — Container — */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
}

.container--narrow {
  max-width: var(--max-width-narrow);
}

/* ============================================================
   Typographic Ornaments
   ============================================================ */
.ornament {
  text-align: center;
  color: var(--color-text-tertiary);
  font-size: var(--size-xl);
  letter-spacing: 0.3em;
  margin: 48px 0;
  -webkit-user-select: none;
  user-select: none;
}

.ornament::before {
  content: "* \2009 * \2009 *";
}

/* Drop cap for first paragraph of a section */
.dropcap::first-letter {
  font-family: var(--font-serif);
  font-size: 3.4em;
  float: left;
  line-height: 0.8;
  margin: 6px 10px 0 0;
  color: var(--color-accent);
  font-weight: 600;
}

/* Section screenshot — full-width image in feature sections */
.section-screenshot {
  margin: 36px 0 12px;
  text-align: center;
}

.section-screenshot img {
  width: 100%;
  max-width: 900px;
  height: auto;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-border);
}

/* ============================================================
   Navigation
   ============================================================ */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: var(--nav-height);
  background: rgba(250, 248, 245, 0.85);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border);
  transition: background var(--duration-normal) var(--ease-out);
}

.nav__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.nav__brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-serif);
  font-size: var(--size-2xl);
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: -0.01em;
}

.nav__brand-icon {
  width: 32px;
  height: 32px;
  background: var(--color-accent);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #f2efe9;
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 700;
  font-style: italic;
}

.nav__links {
  display: flex;
  align-items: center;
  gap: 32px;
  list-style: none;
}

.nav__link {
  font-size: var(--size-sm);
  font-weight: 400;
  color: var(--color-text);
  transition: color var(--duration-fast) var(--ease-out);
}

.nav__link:hover {
  color: var(--color-accent);
}

.nav__cta {
  display: inline-flex;
  align-items: center;
  padding: 8px 20px;
  font-size: var(--size-sm);
  font-weight: 500;
  color: #f2efe9;
  background: var(--color-accent);
  border-radius: var(--radius-md);
  transition: background var(--duration-fast) var(--ease-out);
}

.nav__cta:hover {
  background: var(--color-accent-hover);
  color: #f2efe9;
}

/* Mobile menu toggle */
.nav__toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  color: var(--color-text);
}

.nav__toggle svg {
  width: 22px;
  height: 22px;
}

/* ============================================================
   Hero
   ============================================================ */
.hero {
  padding: calc(var(--nav-height) + 100px) 0 80px;
  background: var(--color-bg);
  text-align: center;
  overflow: hidden;
}

.hero__eyebrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--size-sm);
  font-weight: 400;
  color: var(--color-text-secondary);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 24px;
}

.hero__title {
  font-family: var(--font-serif);
  font-size: clamp(3rem, 6vw, 4.5rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.1;
  color: var(--color-text);
  margin-bottom: 28px;
}

.hero__title em {
  font-style: italic;
  color: var(--color-accent);
}

.hero__subtitle {
  font-family: var(--font-sans);
  font-size: clamp(var(--size-lg), 2vw, var(--size-xl));
  font-weight: 300;
  color: var(--color-text-secondary);
  max-width: 580px;
  margin: 0 auto 48px;
  line-height: 1.7;
}

.hero__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 60px;
}

/* Trust badges strip */
.trust-badges {
  display: flex;
  justify-content: center;
  gap: 32px;
  flex-wrap: wrap;
  margin-bottom: 48px;
}

.trust-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: 'Source Sans 3', sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  letter-spacing: 0.01em;
}

.trust-badge svg {
  flex-shrink: 0;
  color: var(--color-accent);
}

.trust-badges--compact {
  margin-top: 24px;
  margin-bottom: 0;
}

.hero__screenshot {
  max-width: 900px;
  margin: 0 auto;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}

.hero__screenshot img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  display: block;
}

.feature-highlight__image img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  display: block;
}

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 28px;
  font-family: var(--font-sans);
  font-size: var(--size-base);
  font-weight: 500;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
  text-decoration: none;
  line-height: 1.3;
}

.btn--primary {
  color: #f2efe9;
  background: var(--color-accent);
}

.btn--primary:hover {
  background: var(--color-accent-hover);
  color: #f2efe9;
}

.btn--secondary {
  color: var(--color-accent);
  background: transparent;
  border: 1.5px solid var(--color-accent);
}

.btn--secondary:hover {
  background: var(--color-accent-light);
  color: var(--color-accent);
}

.btn--large {
  padding: 16px 36px;
  font-size: var(--size-lg);
}

.btn--dark {
  color: #f2efe9;
  background: var(--color-bg-dark);
}

.btn--dark:hover {
  background: #3d3630;
  color: #f2efe9;
}

/* ============================================================
   Section
   ============================================================ */
.section {
  padding: var(--section-padding) 0;
}

.section--alt {
  background: var(--color-bg-alt);
}

.section--dark {
  background: var(--color-bg-dark);
  color: var(--color-text-on-dark);
}

.section__eyebrow {
  font-family: var(--font-sans);
  font-size: var(--size-sm);
  font-weight: 400;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-align: center;
  margin-bottom: 12px;
}

.section__title {
  font-family: var(--font-serif);
  font-size: clamp(var(--size-3xl), 3.5vw, var(--size-4xl));
  font-weight: 400;
  letter-spacing: -0.01em;
  text-align: center;
  margin-bottom: 16px;
}

.section__subtitle {
  font-size: var(--size-lg);
  font-weight: 300;
  color: var(--color-text-secondary);
  text-align: center;
  max-width: 600px;
  margin: 0 auto 60px;
  line-height: 1.7;
}

.section--dark .section__subtitle {
  color: #b0a89e;
}

/* ============================================================
   Pull Quote
   ============================================================ */
.pullquote {
  text-align: center;
  padding: 48px 24px;
  max-width: 700px;
  margin: 0 auto;
}

.pullquote__text {
  font-family: var(--font-serif);
  font-size: clamp(var(--size-xl), 2.5vw, var(--size-2xl));
  font-style: italic;
  font-weight: 400;
  color: var(--color-text);
  line-height: 1.6;
  position: relative;
}

.pullquote__text::before {
  content: "\AB\2009";
  color: var(--color-text-tertiary);
}

.pullquote__text::after {
  content: "\2009\BB";
  color: var(--color-text-tertiary);
}

.pullquote__attribution {
  font-family: var(--font-sans);
  font-size: var(--size-sm);
  color: var(--color-text-tertiary);
  margin-top: 16px;
  font-style: normal;
}

/* ============================================================
   Profile Cards — 3 métiers
   ============================================================ */
.profiles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.profile-card {
  text-align: center;
  padding: 48px 32px;
}

.profile-card__icon {
  font-size: 48px;
  margin-bottom: 20px;
  line-height: 1;
}

.profile-card__title {
  font-family: var(--font-serif);
  font-size: var(--size-2xl);
  font-weight: 500;
  margin-bottom: 16px;
}

.profile-card__description {
  font-size: var(--size-base);
  color: var(--color-text-secondary);
  line-height: 1.7;
}

/* ============================================================
   Feature Grid (cards)
   ============================================================ */
.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.feature-card {
  background: var(--color-card-bg);
  border-radius: var(--radius-lg);
  padding: 36px 32px;
  border: 1px solid var(--color-border);
  transition: box-shadow var(--duration-normal) var(--ease-out);
}

.feature-card:hover {
  box-shadow: var(--shadow-md);
}

.feature-card__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  font-size: 24px;
}

.feature-card__icon--blue { background: var(--color-accent-light); color: var(--color-accent); }
.feature-card__icon--purple { background: #f0ecf5; color: #5d4e8c; }
.feature-card__icon--green { background: #eaf3ec; color: var(--color-success); }
.feature-card__icon--orange { background: #f5f0e5; color: var(--color-warning); }
.feature-card__icon--pink { background: #f5ece8; color: #8b4513; }
.feature-card__icon--teal { background: #e8f0ef; color: #3d7068; }

.feature-card__title {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  font-weight: 600;
  margin-bottom: 8px;
}

.feature-card__description {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.7;
}

/* Feature highlight (large alternating) */
.feature-highlight {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  padding: 60px 0;
}

.feature-highlight--reverse {
  direction: rtl;
}

.feature-highlight--reverse > * {
  direction: ltr;
}

.feature-highlight__content {
  max-width: 480px;
}

.feature-highlight__eyebrow {
  font-size: var(--size-sm);
  font-weight: 400;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 12px;
}

.feature-highlight__title {
  font-family: var(--font-serif);
  font-size: var(--size-3xl);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin-bottom: 20px;
  line-height: 1.2;
}

.feature-highlight__text {
  font-size: var(--size-base);
  color: var(--color-text-secondary);
  line-height: 1.8;
  margin-bottom: 24px;
}

.feature-highlight__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.feature-highlight__list li {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  padding-left: 24px;
  position: relative;
  line-height: 1.6;
}

.feature-highlight__list li::before {
  content: "\2014";
  position: absolute;
  left: 0;
  color: var(--color-text-tertiary);
}

.feature-highlight__image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}


/* ============================================================
   Advantages Section
   ============================================================ */
.advantages-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}

.advantage-card {
  padding: 32px 0;
  border-bottom: 1px solid var(--color-border);
}

.advantage-card__header {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 12px;
}

.advantage-card__icon {
  font-size: 24px;
  line-height: 1;
}

.advantage-card__title {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  font-weight: 600;
}

.advantage-card__text {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.8;
  margin-bottom: 10px;
}

/* Stat card — key numbers display */
.stat-card {
  text-align: center;
  padding: 1.5rem;
  border-bottom: none;
}

.stat-card__number {
  font-family: var(--font-serif);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--color-accent);
  line-height: 1.2;
}

.stat-card__text {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin-top: 0.25rem;
}

/* Profile card feature list */
.profile-card__features {
  list-style: none;
  padding: 0;
  margin: 0.75rem 0 0;
  font-size: var(--size-xs);
  color: var(--color-text-tertiary);
}

.profile-card__features li {
  padding: 0.2rem 0;
}

.profile-card__features li::before {
  content: '\2014\00a0';
  color: var(--color-accent);
}

/* FAQ section */
.faq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 2rem;
}

@media (max-width: 768px) {
  .faq-grid { grid-template-columns: 1fr; }
}

.faq-item {
  padding: 1.5rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-card-bg);
}

.faq-item__question {
  font-family: var(--font-serif);
  font-size: var(--size-base);
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 0.5rem;
}

.faq-item__answer {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.7;
}

/* Subtitle variant — italic with top margin */
.section__subtitle--italic {
  margin-top: 1.5rem;
  font-style: italic;
}

/* Features page sticky navigation */
.features-nav {
  position: sticky;
  top: 60px;
  z-index: 90;
  background: rgba(250, 248, 245, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border);
  padding: 0;
}

[data-theme="dark"] .features-nav {
  background: rgba(44, 38, 32, 0.92);
}

.features-nav__inner {
  display: flex;
  gap: 0.25rem;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 0.5rem 0;
}

.features-nav__inner::-webkit-scrollbar {
  display: none;
}

.features-nav__link {
  flex-shrink: 0;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: var(--size-xs);
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: all 0.15s;
  white-space: nowrap;
}

.features-nav__link:hover {
  color: var(--color-accent);
  background: rgba(26, 54, 93, 0.06);
}

/* Badge — subtle literary style instead of neon pills */
.badge-unique {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  line-height: 1.6;
}

.badge-unique--exclusive {
  background: var(--color-accent-light);
  color: var(--color-accent);
}

.badge-unique--rare {
  background: #f0ecf5;
  color: #5d4e8c;
}

.badge-unique--advantage {
  background: #eaf3ec;
  color: var(--color-success);
}

.badge-pro {
  display: inline-flex;
  align-items: center;
  padding: 1px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.03em;
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: #fff;
  vertical-align: middle;
  margin-left: 6px;
}

/* ============================================================
   Pricing
   ============================================================ */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  max-width: 820px;
  margin: 0 auto;
}

.pricing-card {
  background: var(--color-card-bg);
  border-radius: var(--radius-xl);
  padding: 48px 40px;
  border: 1px solid var(--color-border);
  transition: box-shadow var(--duration-normal) var(--ease-out);
}

.pricing-card:hover {
  box-shadow: var(--shadow-md);
}

.pricing-card--featured {
  border-color: var(--color-accent);
  border-width: 2px;
}

.pricing-card__badge {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-accent);
  color: #f2efe9;
  font-size: var(--size-xs);
  font-weight: 600;
  padding: 4px 16px;
  border-radius: var(--radius-md);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.pricing-card--featured {
  position: relative;
}

.pricing-card__name {
  font-family: var(--font-serif);
  font-size: var(--size-2xl);
  font-weight: 600;
  margin-bottom: 8px;
}

.pricing-card__description {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  margin-bottom: 24px;
}

.pricing-card__price {
  font-family: var(--font-serif);
  font-size: var(--size-5xl);
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}

.pricing-card__price-note {
  font-size: var(--size-sm);
  color: var(--color-text-tertiary);
  margin-bottom: 32px;
  font-style: italic;
}

.pricing-card__features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 36px;
}

.pricing-card__features li {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  padding-left: 28px;
  position: relative;
  line-height: 1.6;
}

.pricing-card__features li::before {
  content: "\2014";
  position: absolute;
  left: 0;
  color: var(--color-text-tertiary);
}

.pricing-card__features li.disabled {
  color: var(--color-text-tertiary);
}

.pricing-card__features li.disabled::before {
  content: "";
}

.pricing-card__action {
  width: 100%;
  text-align: center;
}

/* ============================================================
   Stats Bar
   ============================================================ */
.stats-bar {
  display: flex;
  justify-content: center;
  gap: 64px;
  padding: 40px 0;
}

.stat-item {
  text-align: center;
}

.stat-item__number {
  font-family: var(--font-serif);
  font-size: var(--size-4xl);
  font-weight: 600;
  color: var(--color-text);
}

.stat-item__label {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  margin-top: 4px;
}

/* ============================================================
   CTA Section
   ============================================================ */
.cta-section {
  text-align: center;
  padding: 100px 0;
  background: var(--color-bg);
}

.cta-section__title {
  font-family: var(--font-serif);
  font-size: clamp(var(--size-3xl), 3.5vw, var(--size-4xl));
  font-weight: 400;
  margin-bottom: 16px;
}

.cta-section__subtitle {
  font-size: var(--size-lg);
  font-weight: 300;
  color: var(--color-text-secondary);
  margin-bottom: 36px;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

/* ============================================================
   Footer
   ============================================================ */
.footer {
  background: var(--color-bg-dark);
  color: var(--color-text-on-dark);
  padding: 32px 0 20px;
}

.footer__inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
  margin-bottom: 20px;
}

.footer__brand {
  max-width: 320px;
}

.footer__brand-name {
  font-family: var(--font-serif);
  font-size: var(--size-lg);
  font-weight: 600;
  margin-bottom: 4px;
}

.footer__brand-desc {
  font-size: var(--size-sm);
  color: #b0a89e;
  line-height: 1.5;
}

.footer__columns {
  display: flex;
  gap: 48px;
}

.footer__column-title {
  font-size: var(--size-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #b0a89e;
  margin-bottom: 10px;
}

.footer__column-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.footer__column-links a {
  font-size: var(--size-sm);
  color: #d4cdc4;
}

.footer__column-links a:hover {
  color: #f2efe9;
}

.footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.footer__copyright {
  font-size: var(--size-xs);
  color: #8a7f73;
}

.footer__legal-links {
  display: flex;
  gap: 24px;
  list-style: none;
}

.footer__legal-links a {
  font-size: var(--size-xs);
  color: #8a7f73;
}

.footer__legal-links a:hover {
  color: #d4cdc4;
}

.footer__quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--size-xs);
  color: #8a7f73;
  text-align: center;
  margin-top: 12px;
}

/* ============================================================
   Page Header (inner pages)
   ============================================================ */
.page-header {
  padding: calc(var(--nav-height) + 80px) 0 60px;
  background: var(--color-bg);
  text-align: center;
}

.page-header__title {
  font-family: var(--font-serif);
  font-size: clamp(var(--size-3xl), 4vw, var(--size-5xl));
  font-weight: 400;
  margin-bottom: 16px;
}

.page-header__subtitle {
  font-size: var(--size-lg);
  font-weight: 300;
  color: var(--color-text-secondary);
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ============================================================
   Feature Detail Page
   ============================================================ */
.feature-section {
  padding: 80px 0;
  border-bottom: 1px solid var(--color-border);
}

.feature-section:last-child {
  border-bottom: none;
}

.feature-section__category {
  font-size: var(--size-xs);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-tertiary);
  margin-bottom: 16px;
}

.feature-section__title {
  font-family: var(--font-serif);
  font-size: var(--size-3xl);
  font-weight: 400;
  margin-bottom: 24px;
}

.feature-section__intro {
  max-width: 680px;
  color: var(--color-text-secondary);
  line-height: 1.8;
  margin-bottom: 32px;
}

.feature-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.feature-list--spaced {
  margin-top: 40px;
}

.feature-list__item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.feature-list__icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--color-text-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  margin-top: 3px;
}

.feature-list__text {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.7;
}

.feature-list__text strong {
  color: var(--color-text);
  font-weight: 500;
}

/* ============================================================
   Legal Page
   ============================================================ */
.legal-content {
  max-width: 680px;
  margin: 0 auto;
  padding: 60px 24px 100px;
}

.legal-content h2 {
  font-family: var(--font-serif);
  font-size: var(--size-2xl);
  font-weight: 500;
  margin: 48px 0 16px;
}

.legal-content h3 {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  font-weight: 500;
  margin: 32px 0 12px;
}

.legal-content p {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.9;
  margin-bottom: 16px;
}

.legal-content ul,
.legal-content ol {
  margin: 8px 0 16px 24px;
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.9;
}

.legal-content a {
  color: var(--color-accent);
}

/* ============================================================
   Scroll Animations
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-delay-1 { transition-delay: 100ms; }
.reveal-delay-2 { transition-delay: 200ms; }
.reveal-delay-3 { transition-delay: 300ms; }

/* ============================================================
   Competitor Comparison Table (kept, restyled literary)
   ============================================================ */
.table-scroll {
  overflow-x: auto;
}

.competitor-table {
  width: 100%;
  border-collapse: collapse;
  margin: 40px 0;
  font-size: var(--size-sm);
}

.competitor-table th,
.competitor-table td {
  text-align: center;
  padding: 12px 14px;
  border-bottom: 1px solid var(--color-border);
}

.competitor-table th {
  font-weight: 500;
  color: var(--color-text);
  font-size: var(--size-xs);
  letter-spacing: 0.02em;
  padding-bottom: 16px;
}

.competitor-table th:first-child,
.competitor-table td:first-child {
  text-align: left;
  padding-left: 0;
  font-weight: 500;
  min-width: 200px;
}

.competitor-table tr:last-child td {
  border-bottom: none;
}

.competitor-table td {
  color: var(--color-text-secondary);
}

.competitor-table .yes {
  color: var(--color-success);
  font-weight: 600;
}

.competitor-table .partial {
  color: var(--color-warning);
  font-weight: 500;
}

.competitor-table .no {
  color: #ccc5bb;
}

.competitor-table .col-highlight {
  background: rgba(26, 54, 93, 0.04);
}

.competitor-table th.col-highlight {
  background: rgba(26, 54, 93, 0.06);
  color: var(--color-accent);
}

/* ============================================================
   Comparison table (Free vs Pro)
   ============================================================ */
.comparison-table {
  width: 100%;
  border-collapse: collapse;
  margin: 40px 0;
  font-size: var(--size-sm);
}

.comparison-table th,
.comparison-table td {
  text-align: left;
  padding: 14px 20px;
  border-bottom: 1px solid var(--color-border);
}

.comparison-table th {
  font-weight: 500;
  color: var(--color-text);
}

.comparison-table td {
  color: var(--color-text-secondary);
}

.comparison-table .check {
  color: var(--color-success);
  font-weight: 600;
}

.comparison-table .dash {
  color: var(--color-text-tertiary);
}

.comparison-table__section td {
  font-weight: 600;
  color: var(--color-text);
  font-size: var(--size-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding-top: 24px;
  border-bottom: 2px solid var(--color-border);
  background: transparent;
}

.pricing-card__trial {
  font-size: var(--size-sm);
  color: var(--color-accent);
  font-weight: 500;
  margin-top: 12px;
  text-align: center;
}

/* ============================================================
   Feature Deep-Dive Cards
   ============================================================ */
.deep-dive-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
  margin-top: 32px;
}

.deep-dive-card {
  padding: 28px 0;
  border-bottom: 1px solid var(--color-border);
}

.deep-dive-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.deep-dive-card__title {
  font-family: var(--font-serif);
  font-size: var(--size-lg);
  font-weight: 600;
}

.deep-dive-card__text {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.8;
}

.deep-dive-card__list {
  list-style: none;
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.deep-dive-card__list li {
  font-size: var(--size-xs);
  color: var(--color-text-secondary);
  padding-left: 20px;
  position: relative;
  line-height: 1.6;
}

.deep-dive-card__list li::before {
  content: "\2014";
  position: absolute;
  left: 0;
  color: var(--color-text-tertiary);
  font-size: var(--size-xs);
}

/* ============================================================
   Pull Quote / Highlight Box
   ============================================================ */
.highlight-box {
  border-left: 3px solid var(--color-accent);
  padding: 32px 40px;
  margin: 48px 0;
  background: rgba(26, 54, 93, 0.03);
}

.highlight-box__text {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  font-style: italic;
  font-weight: 400;
  color: var(--color-text);
  line-height: 1.6;
  max-width: 680px;
}

.highlight-box__subtext {
  font-family: var(--font-sans);
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  margin-top: 12px;
  font-style: normal;
}

/* ============================================================
   Keyboard shortcut badges
   ============================================================ */
.kbd {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-secondary);
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: 4px;
  line-height: 1.5;
}

/* ============================================================
   Bilingual FR/EN toggle
   ============================================================ */
html[lang="fr"] .lang-en { display: none !important; }
html[lang="en"] .lang-fr { display: none !important; }

.lang-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0;
  background: var(--color-bg-alt);
  border-radius: var(--radius-md);
  padding: 2px;
  border: 1px solid var(--color-border);
  font-size: var(--size-xs);
}

.lang-toggle__option {
  padding: 4px 12px;
  border-radius: 6px;
  font-weight: 500;
  color: var(--color-text-secondary);
  transition: all var(--duration-fast) var(--ease-out);
  cursor: pointer;
  border: none;
  background: none;
  font-family: var(--font-sans);
  font-size: var(--size-xs);
}

.lang-toggle__option.active {
  background: white;
  color: var(--color-text);
  box-shadow: var(--shadow-xs);
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px) {
  .features-grid,
  .profiles-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .feature-highlight {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .feature-highlight--reverse {
    direction: ltr;
  }

  .feature-highlight__content {
    max-width: 100%;
  }
}

@media (max-width: 768px) {
  :root {
    --section-padding: 64px;
  }

  .nav__links {
    display: none;
    position: absolute;
    top: var(--nav-height);
    left: 0;
    right: 0;
    background: rgba(250, 248, 245, 0.96);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    flex-direction: column;
    padding: 20px 24px;
    gap: 16px;
    border-bottom: 1px solid var(--color-border);
  }

  .nav__links.open {
    display: flex;
  }

  .nav__toggle {
    display: block;
  }

  .features-grid,
  .profiles-grid {
    grid-template-columns: 1fr;
  }

  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
  }

  .feature-list {
    grid-template-columns: 1fr;
  }

  .stats-bar {
    flex-wrap: wrap;
    gap: 32px;
  }

  .footer__inner {
    flex-direction: column;
  }

  .footer__columns {
    flex-direction: column;
    gap: 20px;
  }

  .footer__bottom {
    flex-direction: column;
    gap: 8px;
    text-align: center;
  }

  .hero {
    padding: calc(var(--nav-height) + 48px) 0 48px;
  }

  .hero__actions {
    flex-direction: column;
    align-items: center;
  }

  .advantages-grid,
  .deep-dive-grid {
    grid-template-columns: 1fr;
  }

  .competitor-table {
    font-size: var(--size-xs);
  }

  .competitor-table th:first-child,
  .competitor-table td:first-child {
    min-width: 120px;
  }

  .competitor-table th,
  .competitor-table td {
    padding: 8px 6px;
  }

  .highlight-box {
    padding: 24px 20px;
  }

  .pullquote {
    padding: 32px 16px;
  }
}

/* ============================================================
   Success Page
   ============================================================ */
.success-page {
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 80px 24px 40px;
}

.success-page__inner {
  max-width: 540px;
  text-align: center;
}

.success-page__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background-color: rgba(74, 124, 89, 0.12);
  margin-bottom: 24px;
}

.success-page__title {
  font-family: var(--font-serif);
  font-size: var(--size-3xl);
  font-weight: 400;
  margin-bottom: 16px;
}

.success-page__text {
  font-size: var(--size-lg);
  color: var(--color-text-secondary);
  line-height: 1.7;
  margin-bottom: 32px;
}

.success-page__steps {
  text-align: left;
  background: var(--color-bg-alt);
  border-radius: var(--radius-lg);
  padding: 28px;
  margin-bottom: 32px;
}

.success-page__steps h3 {
  font-family: var(--font-serif);
  font-size: var(--size-base);
  font-weight: 600;
  margin-bottom: 16px;
}

.success-page__steps ol {
  font-size: var(--size-sm);
  line-height: 1.9;
  color: var(--color-text-secondary);
  padding-left: 20px;
  margin: 0;
}

.success-page__note {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  margin-bottom: 24px;
}

@media (max-width: 480px) {
  .container {
    padding: 0 16px;
  }

  .hero__title {
    font-size: 2.2rem;
  }

  .pricing-card {
    padding: 32px 24px;
  }
}

/* ============================================================
   Download Page
   ============================================================ */

.download-hero {
  text-align: center;
  padding: 100px 0 40px;
  background: var(--color-bg-alt);
}

.download-hero h1 {
  font-family: var(--font-heading);
  font-size: 2.8rem;
  font-weight: 600;
  color: var(--color-accent);
  margin-bottom: 8px;
}

.download-hero__version {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  letter-spacing: 0.05em;
}

/* Download card */
.download-card {
  text-align: center;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 48px 32px;
  margin: 40px 0;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

.download-card__icon {
  margin-bottom: 20px;
}

.download-card h2 {
  font-family: var(--font-heading);
  font-size: 1.8rem;
  font-weight: 600;
  color: var(--color-accent);
  margin-bottom: 8px;
}

.download-card__format {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  margin-bottom: 24px;
}

.download-card__btn {
  display: inline-block;
  margin-bottom: 12px;
}

.download-card__size {
  font-size: 0.8rem;
  color: var(--color-text-tertiary);
}

/* Sections */
.download-section {
  margin: 40px 0;
  padding: 32px 0;
  border-top: 1px solid var(--color-border);
}

.download-section h2 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-accent);
  margin-bottom: 20px;
}

/* Table */
.download-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--size-sm);
}

.download-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}

.download-table td:first-child {
  width: 140px;
  color: var(--color-text-secondary);
}

.download-table a {
  color: var(--color-accent);
  text-decoration: underline;
}

/* Steps */
.download-steps {
  padding-left: 24px;
  line-height: 2;
  font-size: var(--size-sm);
  color: var(--color-text);
}

.download-steps li {
  margin-bottom: 4px;
}

/* Lists */
.download-list {
  list-style: none;
  padding: 0;
  font-size: var(--size-sm);
  line-height: 1.8;
}

.download-list li {
  padding-left: 20px;
  position: relative;
  margin-bottom: 8px;
}

.download-list li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--color-text-tertiary);
}

/* Warning box */
.download-warning {
  background: #fef9e7;
  border: 1px solid #f0dba0;
  border-radius: 8px;
  padding: 24px 28px;
  margin: 40px 0;
}

.download-gatekeeper-msg {
  background: #f5f0e8;
  border-left: 3px solid var(--color-accent);
  padding: 12px 16px;
  margin: 16px 0;
  font-style: italic;
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  border-radius: 0 6px 6px 0;
}

/* Note */
.download-note {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  margin-top: 16px;
  line-height: 1.7;
}

/* Legal section */
.download-legal {
  background: var(--color-bg-alt);
  border-radius: 8px;
  padding: 24px 28px;
  border: none;
}

/* FAQ / Troubleshooting */
.download-faq {
  border-bottom: 1px solid var(--color-border);
  padding: 12px 0;
}

.download-faq summary {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--color-text);
  cursor: pointer;
  padding: 4px 0;
}

.download-faq summary:hover {
  color: var(--color-accent);
}

.download-faq p {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  padding: 8px 0 4px 0;
  line-height: 1.7;
}

.download-faq code {
  background: var(--color-bg-alt);
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 0.85em;
}

kbd {
  display: inline-block;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: 4px;
  padding: 1px 6px;
  font-family: var(--font-body);
  font-size: 0.85em;
  box-shadow: 0 1px 0 rgba(0,0,0,0.08);
}

/* ── Download Form (email gate) ── */

.download-form {
  text-align: left;
  margin-top: 24px;
}

.download-form__label {
  display: block;
  font-size: var(--size-sm);
  color: var(--color-text);
  margin-bottom: 12px;
  line-height: 1.6;
}

.download-form__row {
  display: flex;
  gap: 10px;
  margin-bottom: 12px;
}

.download-form__input {
  flex: 1;
  padding: 12px 14px;
  font-family: var(--font-body);
  font-size: 1rem;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  background: var(--color-bg);
  color: var(--color-text);
  transition: border-color 0.2s;
}

.download-form__input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(26, 54, 93, 0.1);
}

.download-form__btn {
  white-space: nowrap;
  padding: 12px 24px;
}

.download-form__btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.download-form__consent {
  font-size: 0.8rem;
  color: var(--color-text-secondary);
  line-height: 1.6;
}

.download-form__consent input[type="checkbox"] {
  margin-right: 6px;
  vertical-align: middle;
}

.download-form__consent a {
  color: var(--color-accent);
  text-decoration: underline;
}

.download-form__message {
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: 6px;
  font-size: var(--size-sm);
  line-height: 1.5;
}

.download-form__message--success {
  background: #e8f5e9;
  color: #2e7d32;
  border: 1px solid #a5d6a7;
}

.download-form__message--error {
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fca5a5;
}

.download-form__success {
  text-align: center;
  padding: 24px 0;
}

.download-form__success svg {
  margin-bottom: 12px;
}

.download-form__success p {
  font-size: var(--size-sm);
  color: #2e7d32;
  line-height: 1.6;
}

@media (max-width: 480px) {
  .download-form__row {
    flex-direction: column;
  }
}

/* ============================================================
   Pricing v2 — 5 tiers (subscription)
   ============================================================ */
.pricing-grid--5 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  max-width: 1280px;
  margin: 0 auto;
  align-items: stretch;
}

.pricing-grid--5 .pricing-card {
  display: flex;
  flex-direction: column;
  padding: 28px 22px;
  position: relative;
}

.pricing-grid--5 .pricing-card__features {
  flex-grow: 1;
  margin-bottom: 24px;
}

.pricing-grid--5 .pricing-card__price {
  font-size: var(--size-3xl);
}

.pricing-grid--5 .pricing-card__name {
  font-size: var(--size-xl);
}

.pricing-card__cta {
  display: inline-block;
  width: 100%;
  text-align: center;
  padding: 12px 16px;
  border-radius: var(--radius-md);
  font-size: var(--size-sm);
  font-weight: 600;
  background: var(--color-accent);
  color: #f2efe9;
  border: 1px solid var(--color-accent);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);
  text-decoration: none;
}

.pricing-card__cta:hover {
  background: var(--color-accent-hover, var(--color-accent));
  transform: translateY(-1px);
}

.pricing-card__cta--secondary {
  background: transparent;
  color: var(--color-text-primary);
  border: 1px solid var(--color-border);
}

.pricing-card__cta--secondary:hover {
  background: var(--color-card-bg-hover, var(--color-card-bg));
}

.pricing-card__cta--featured {
  box-shadow: var(--shadow-md);
}

@media (max-width: 1100px) {
  .pricing-grid--5 {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 720px) {
  .pricing-grid--5 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .pricing-grid--5 {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   Modal (Checkout)
   ============================================================ */
.modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modal[hidden] {
  display: none;
}

.modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
}

.modal__panel {
  position: relative;
  background: var(--color-card-bg, #fff);
  border-radius: var(--radius-xl);
  padding: 32px 32px 28px;
  max-width: 460px;
  width: calc(100% - 32px);
  box-shadow: var(--shadow-lg, 0 12px 48px rgba(0, 0, 0, 0.2));
  border: 1px solid var(--color-border);
}

.modal__close {
  position: absolute;
  top: 12px;
  right: 14px;
  width: 32px;
  height: 32px;
  background: transparent;
  border: none;
  font-size: 24px;
  line-height: 1;
  color: var(--color-text-tertiary);
  cursor: pointer;
  border-radius: var(--radius-sm);
}

.modal__close:hover {
  background: var(--color-card-bg-hover, rgba(0, 0, 0, 0.05));
}

.modal__title {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  margin: 0 0 4px;
}

.modal__subtitle {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  margin: 0 0 20px;
}

.modal__label {
  display: block;
  font-size: var(--size-xs);
  font-weight: 600;
  color: var(--color-text-secondary);
  margin: 14px 0 6px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.modal__input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--size-base);
  font-family: inherit;
  background: var(--color-bg, #fff);
  color: var(--color-text-primary);
  box-sizing: border-box;
}

.modal__input:focus {
  outline: 2px solid var(--color-accent);
  outline-offset: -1px;
}

.modal__hint {
  font-size: var(--size-xs);
  color: var(--color-text-tertiary);
  margin: 6px 0 0;
}

.modal__error {
  font-size: var(--size-sm);
  color: #c1452f;
  background: rgba(193, 69, 47, 0.08);
  border: 1px solid rgba(193, 69, 47, 0.25);
  border-radius: var(--radius-md);
  padding: 10px 12px;
  margin: 16px 0 0;
}

.modal__submit {
  width: 100%;
  margin-top: 20px;
  padding: 12px 16px;
}

.modal__finepoint {
  font-size: var(--size-xs);
  color: var(--color-text-tertiary);
  text-align: center;
  margin: 12px 0 0;
}

/* ============================================================
   Format Tags — "Formats ouverts" section
   ============================================================ */

.format-tags {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 28px;
}

.format-tag {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
}

.format-tag code {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-accent);
  background: var(--color-accent-light);
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  flex-shrink: 0;
}

@media (max-width: 480px) {
  .format-tags {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   Stat Card — variant highlight (0 format propriétaire)
   ============================================================ */

.stat-card--highlight {
  border: 1.5px solid var(--color-accent-light);
}

.stat-card__number--zero {
  color: var(--color-accent);
}

/* ============================================================
   Profile Cards — couleurs par profil
   ============================================================ */

.profile-card__label {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--size-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  margin-bottom: 12px;
}

.profile-card--researcher .profile-card__label {
  color: #1a4a6d;
  background: #e8f0f8;
}

.profile-card--novelist .profile-card__label {
  color: #5a3020;
  background: #f5ede8;
}

.profile-card--journalist .profile-card__label {
  color: #2d4a2d;
  background: #e8f0e8;
}

/* ============================================================
   Inline Feature — spellcheck mention
   ============================================================ */

.inline-feature {
  display: flex;
  align-items: flex-start;
  gap: 24px;
  padding: 32px 40px;
  background: var(--color-card-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.inline-feature__icon {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-accent-light);
  border-radius: var(--radius-md);
  color: var(--color-accent);
}

.inline-feature__title {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 8px;
}

.inline-feature__text {
  font-size: var(--size-base);
  color: var(--color-text-secondary);
  line-height: 1.65;
}

@media (max-width: 768px) {
  .inline-feature {
    flex-direction: column;
    padding: 24px;
  }
}

/* ============================================================
   CTA section — note below buttons
   ============================================================ */

.cta-section__note {
  margin-top: 20px;
  font-size: var(--size-sm);
  color: rgba(242, 239, 233, 0.55);
  letter-spacing: 0.04em;
}

/* ============================================================
   Visually hidden (accessibility)
   ============================================================ */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================
   Dark section CTA block
   ============================================================ */

.cta-dark {
  text-align: center;
  padding: 80px 0;
}

.cta-dark__title {
  font-family: var(--font-serif);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 500;
  color: var(--color-text-on-dark);
  margin-bottom: 16px;
}

.cta-dark__subtitle {
  font-size: var(--size-lg);
  color: rgba(242, 239, 233, 0.75);
  margin-bottom: 36px;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

.cta-dark__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Ghost button — for use on dark backgrounds */
.btn--ghost {
  border-color: rgba(242, 239, 233, 0.3);
  color: var(--color-text-on-dark);
  background: transparent;
}

.btn--ghost:hover {
  border-color: rgba(242, 239, 233, 0.6);
  background: rgba(242, 239, 233, 0.08);
  color: var(--color-text-on-dark);
}

/* ============================================================
   Sprint L Website Refonte (2026-05-15)
   Components for: story-engine.html, personas.html, comparison.html
   Plus: nav__dropdown (Solutions menu added to all pages)
   ============================================================ */

/* ── Nav dropdown ────────────────────────────────────────── */
.nav__dropdown {
  position: relative;
}

.nav__dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: none;
  cursor: pointer;
  font: inherit;
  color: inherit;
  padding: 0;
  text-decoration: none;
}

.nav__dropdown-arrow {
  transition: transform 0.2s ease;
}

.nav__dropdown[aria-expanded="true"] .nav__dropdown-arrow,
.nav__dropdown:hover .nav__dropdown-arrow,
.nav__dropdown:focus-within .nav__dropdown-arrow {
  transform: rotate(180deg);
}

.nav__dropdown-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 280px;
  background: var(--color-bg);
  border: 1px solid rgba(44, 38, 32, 0.12);
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(44, 38, 32, 0.12), 0 4px 8px rgba(44, 38, 32, 0.06);
  padding: 8px;
  margin: 0;
  list-style: none;
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(-4px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s;
  z-index: 1000;
}

.nav__dropdown:hover .nav__dropdown-menu,
.nav__dropdown:focus-within .nav__dropdown-menu,
.nav__dropdown[aria-expanded="true"] .nav__dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.nav__dropdown-menu li {
  list-style: none;
}

.nav__dropdown-link {
  display: block;
  padding: 10px 14px;
  border-radius: 8px;
  text-decoration: none;
  color: var(--color-text);
  transition: background 0.15s ease;
}

.nav__dropdown-link:hover,
.nav__dropdown-link:focus {
  background: var(--color-accent-light);
  text-decoration: none;
}

.nav__dropdown-link strong {
  display: block;
  font-family: var(--font-serif);
  font-size: var(--size-lg);
  color: var(--color-accent);
  font-weight: 600;
  margin-bottom: 2px;
}

.nav__dropdown-link small {
  display: block;
  font-size: var(--size-xs);
  color: var(--color-text-secondary);
}

/* Mobile dropdown — open in-flow under Solutions trigger */
@media (max-width: 768px) {
  .nav__dropdown-menu {
    position: static;
    transform: none;
    opacity: 1;
    visibility: visible;
    box-shadow: none;
    border: none;
    background: transparent;
    padding-left: 16px;
    min-width: 0;
  }

  .nav__dropdown:hover .nav__dropdown-menu,
  .nav__dropdown:focus-within .nav__dropdown-menu {
    transform: none;
  }

  .nav__dropdown-arrow {
    display: none;
  }
}

/* ── Hero variant for feature pages ──────────────────────── */
.hero--feature {
  padding: 80px 0 60px;
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);
}

.hero__badge {
  display: inline-block;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--color-accent-light);
  color: var(--color-accent);
  font-size: var(--size-sm);
  font-weight: 600;
  margin-bottom: 24px;
}

.hero__cta {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 32px;
}

/* ── Generic section variants ────────────────────────────── */
.section {
  padding: 80px 0;
}

.section--alt {
  background: var(--color-bg-alt);
}

.section--accent {
  background: var(--color-accent);
  color: var(--color-text-on-dark);
}

.section--accent .section__title {
  color: var(--color-text-on-dark);
}

.section--accent .section__lead,
.section--accent .section__note {
  color: rgba(242, 239, 233, 0.88);
}

.section--accent strong {
  color: var(--color-text-on-dark);
}

.section__lead {
  max-width: 720px;
  margin: 0 auto 48px;
  text-align: center;
  font-size: var(--size-lg);
  color: var(--color-text-secondary);
  line-height: 1.6;
}

.section__note {
  max-width: 720px;
  margin: 32px auto 0;
  text-align: center;
  font-size: var(--size-base);
  color: var(--color-text-secondary);
  font-style: italic;
}

/* ── Comparison tables (story-engine + comparison) ───────── */
.compare-table {
  max-width: 800px;
  margin: 0 auto;
  overflow-x: auto;
}

.compare-table--wide {
  max-width: 1100px;
}

.compare-table table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(44, 38, 32, 0.06);
}

.compare-table th,
.compare-table td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid rgba(44, 38, 32, 0.08);
}

.compare-table th {
  background: var(--color-accent);
  color: var(--color-text-on-dark);
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: var(--size-lg);
  text-align: center;
}

.compare-table th:first-child {
  text-align: left;
}

.compare-table td {
  font-size: var(--size-base);
}

.compare-table td:not(:first-child) {
  text-align: center;
}

.compare-table tbody tr:hover {
  background: var(--color-bg-alt);
}

.compare-table tbody tr:last-child td {
  border-bottom: none;
}

.compare-table__price-row td {
  background: var(--color-accent-light);
  font-size: var(--size-lg);
  border-top: 2px solid var(--color-accent);
}

.compare-table small {
  display: block;
  color: var(--color-text-tertiary);
  font-size: var(--size-xs);
}

/* ── Pipeline grid (Story Engine 2-passes) ───────────────── */
.pipeline-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}

.pipeline-card {
  background: var(--color-bg);
  padding: 28px;
  border-radius: 12px;
  border: 1px solid rgba(44, 38, 32, 0.08);
  position: relative;
}

.pipeline-card__step {
  position: absolute;
  top: -16px;
  left: 24px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-accent);
  color: var(--color-text-on-dark);
  border-radius: 50%;
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: var(--size-base);
}

.pipeline-card h3 {
  font-family: var(--font-serif);
  font-size: var(--size-2xl);
  color: var(--color-accent);
  margin: 8px 0 12px;
}

.pipeline-card p {
  color: var(--color-text-secondary);
  line-height: 1.6;
  font-size: var(--size-base);
}

.pipeline-card__link {
  display: inline-block;
  margin-top: 14px;
  font-size: var(--size-sm);
  font-weight: 600;
  color: var(--color-accent);
}

/* ── Profile cards (3 profiles) ──────────────────────────── */
.profile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}

.profile-card {
  background: var(--color-bg);
  padding: 32px 28px;
  border-radius: 12px;
  border: 1px solid rgba(44, 38, 32, 0.08);
  text-align: center;
}

.profile-card__icon {
  font-size: 2.5rem;
  margin-bottom: 16px;
  line-height: 1;
}

.profile-card h3 {
  font-family: var(--font-serif);
  font-size: var(--size-2xl);
  color: var(--color-accent);
  margin-bottom: 12px;
}

.profile-card p {
  color: var(--color-text-secondary);
  line-height: 1.6;
}

/* ── Specs grid (Story Engine + personas anatomy) ────────── */
.specs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}

.spec-card {
  background: var(--color-bg);
  padding: 24px;
  border-radius: 12px;
  border: 1px solid rgba(44, 38, 32, 0.08);
}

.spec-card__icon {
  font-size: 1.8rem;
  margin-bottom: 10px;
  line-height: 1;
}

.spec-card h3 {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  color: var(--color-accent);
  margin-bottom: 10px;
}

.spec-card p {
  color: var(--color-text-secondary);
  line-height: 1.55;
  font-size: var(--size-base);
}

/* ── CTA section ─────────────────────────────────────────── */
.cta-section {
  padding: 80px 0;
  background: var(--color-bg-dark);
  color: var(--color-text-on-dark);
}

.cta-section__inner {
  text-align: center;
  max-width: 720px;
}

.cta-section__title {
  font-family: var(--font-serif);
  font-size: var(--size-4xl);
  color: var(--color-text-on-dark);
  margin-bottom: 20px;
}

.cta-section__subtitle {
  font-size: var(--size-lg);
  color: rgba(242, 239, 233, 0.8);
  margin-bottom: 36px;
  line-height: 1.6;
}

.cta-section__buttons {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ── Personas page ───────────────────────────────────────── */
.problem-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .problem-grid {
    grid-template-columns: 1fr;
  }
}

.problem-card {
  padding: 32px 28px;
  border-radius: 12px;
  border: 1px solid rgba(44, 38, 32, 0.08);
}

.problem-card--bad {
  background: rgba(139, 69, 19, 0.05);
  border-color: rgba(139, 69, 19, 0.15);
}

.problem-card--good {
  background: var(--color-accent-light);
  border-color: rgba(26, 54, 93, 0.15);
}

.problem-card h3 {
  font-family: var(--font-serif);
  font-size: var(--size-2xl);
  margin-bottom: 14px;
}

.problem-card--bad h3 {
  color: var(--color-accent-warm);
}

.problem-card--good h3 {
  color: var(--color-accent);
}

.problem-card p {
  color: var(--color-text-secondary);
  line-height: 1.65;
}

/* Feature grid (Mon Studio) */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}

.feature-item {
  background: var(--color-bg);
  padding: 24px;
  border-radius: 12px;
  border: 1px solid rgba(44, 38, 32, 0.08);
}

.feature-item h3 {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  color: var(--color-accent);
  margin-bottom: 8px;
}

.feature-item p {
  color: var(--color-text-secondary);
  line-height: 1.6;
  font-size: var(--size-base);
}

/* Library features */
.library-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}

.library-feature {
  background: var(--color-bg-alt);
  padding: 22px;
  border-radius: 10px;
}

.library-feature h3 {
  font-family: var(--font-serif);
  font-size: var(--size-lg);
  color: var(--color-accent);
  margin-bottom: 8px;
}

.library-feature p {
  color: var(--color-text-secondary);
  font-size: var(--size-base);
  line-height: 1.55;
}

/* ── Comparison page — per-tool blocks ───────────────────── */
.compete-block {
  background: var(--color-bg);
  border: 1px solid rgba(44, 38, 32, 0.08);
  border-radius: 16px;
  padding: 36px;
  margin-bottom: 32px;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}

.compete-block__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(44, 38, 32, 0.08);
}

.compete-block__header h3 {
  font-family: var(--font-serif);
  font-size: var(--size-3xl);
  color: var(--color-accent);
  margin: 0;
}

.compete-block__price {
  font-size: var(--size-base);
  color: var(--color-text-tertiary);
  font-style: italic;
}

.compete-block__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-bottom: 20px;
}

@media (max-width: 768px) {
  .compete-block__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

.compete-block__grid h4 {
  font-family: var(--font-serif);
  font-size: var(--size-lg);
  color: var(--color-text);
  margin-bottom: 12px;
}

.compete-block__grid ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.compete-block__grid li {
  padding: 8px 0;
  padding-left: 20px;
  position: relative;
  color: var(--color-text-secondary);
  line-height: 1.55;
  font-size: var(--size-base);
}

.compete-block__grid li::before {
  position: absolute;
  left: 0;
  top: 8px;
  color: var(--color-accent);
  font-weight: 700;
}

.compete-block__grid > div:first-child li::before {
  content: "○";
  color: var(--color-text-tertiary);
}

.compete-block__grid > div:last-child li::before {
  content: "✓";
}

.compete-block__verdict {
  background: var(--color-accent-light);
  padding: 18px 22px;
  border-radius: 8px;
  border-left: 4px solid var(--color-accent);
  color: var(--color-text);
  line-height: 1.6;
  font-size: var(--size-base);
}

/* Moat grid */
.moat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}

.moat-card {
  background: var(--color-bg-alt);
  padding: 28px 24px;
  border-radius: 12px;
  border: 1px solid rgba(44, 38, 32, 0.08);
}

.moat-card__icon {
  font-size: 2rem;
  margin-bottom: 12px;
  line-height: 1;
}

.moat-card h3 {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  color: var(--color-accent);
  margin-bottom: 10px;
}

.moat-card p {
  color: var(--color-text-secondary);
  line-height: 1.6;
  font-size: var(--size-base);
}

/* Use case selector */
.usecase-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .usecase-grid {
    grid-template-columns: 1fr;
  }
}

.usecase-card {
  background: var(--color-bg);
  padding: 28px 24px;
  border-radius: 12px;
  border: 1px solid rgba(44, 38, 32, 0.08);
}

.usecase-card h3 {
  font-family: var(--font-serif);
  font-size: var(--size-xl);
  color: var(--color-accent);
  margin-bottom: 12px;
  line-height: 1.3;
}

.usecase-card p {
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin-bottom: 14px;
}

.usecase-card__link {
  font-size: var(--size-sm);
  font-weight: 600;
  color: var(--color-accent);
}

/* ── Deep-dive card variants (Sprint L features.html) ────── */
.deep-dive-card--featured {
  background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-bg) 100%);
  border: 1px solid rgba(26, 54, 93, 0.18);
  box-shadow: 0 4px 14px rgba(26, 54, 93, 0.08);
}

.deep-dive-card__cta {
  display: inline-block;
  margin-top: 8px;
  font-weight: 600;
  color: var(--color-accent);
  text-decoration: none;
}

.deep-dive-card__cta:hover {
  text-decoration: underline;
}

.badge-unique--new {
  background: var(--color-accent);
  color: var(--color-text-on-dark);
}

/* ── Hero release pill (index.html) ──────────────────────── */
.hero__release-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  margin-bottom: 24px;
  background: var(--color-accent-light);
  border: 1px solid rgba(26, 54, 93, 0.18);
  border-radius: 999px;
  text-decoration: none;
  color: var(--color-accent);
  font-size: var(--size-sm);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.hero__release-pill:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(26, 54, 93, 0.14);
  text-decoration: none;
}

.hero__release-pill strong {
  background: var(--color-accent);
  color: var(--color-text-on-dark);
  padding: 2px 8px;
  border-radius: 999px;
  font-size: var(--size-xs);
  font-weight: 700;
  letter-spacing: 0.02em;
}

/* ============================================================
   Sprint L.11 — Story Engine screenshots integration
   ============================================================ */

/* Hero screenshot — story-engine.html */
.hero__screenshot.story-engine-shot {
  margin-top: 48px;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.hero__screenshot.story-engine-shot img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 16px 40px rgba(44, 38, 32, 0.16), 0 4px 12px rgba(44, 38, 32, 0.08);
  border: 1px solid rgba(44, 38, 32, 0.08);
}

.hero__screenshot.story-engine-shot figcaption {
  margin-top: 14px;
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  font-style: italic;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.55;
}

/* Pipeline preflight visual intro */
.pipeline-screenshot {
  margin: 0 auto 48px;
  max-width: 880px;
  text-align: center;
}

.pipeline-screenshot img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(44, 38, 32, 0.10), 0 2px 6px rgba(44, 38, 32, 0.06);
  border: 1px solid rgba(44, 38, 32, 0.08);
}

.pipeline-screenshot figcaption {
  margin-top: 12px;
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.5;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.pipeline-screenshot code {
  background: var(--color-accent-light);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 0.85em;
}

/* Pipeline card with screenshot — replaces text-only variant */
.pipeline-card--with-shot {
  margin: 0;
  padding: 0 0 24px 0;
  overflow: hidden;
}

.pipeline-card--with-shot .pipeline-card__step {
  position: relative;
  top: 0;
  left: 0;
  margin: 24px 24px 12px;
  display: inline-block;
  padding: 4px 14px;
  background: var(--color-accent);
  color: var(--color-text-on-dark);
  border-radius: 999px;
  font-size: var(--size-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  width: auto;
  height: auto;
}

.pipeline-card--with-shot .pipeline-card__title {
  margin: 0 24px 12px;
}

.pipeline-card--with-shot > img {
  display: block;
  width: 100%;
  height: auto;
  border-top: 1px solid rgba(44, 38, 32, 0.08);
  border-bottom: 1px solid rgba(44, 38, 32, 0.08);
  margin-bottom: 18px;
}

.pipeline-card--with-shot .pipeline-card__body {
  margin: 0 24px;
}

/* Specs section screenshot (Plan tab) */
.specs-screenshot {
  margin: 56px auto 0;
  max-width: 1000px;
  text-align: center;
}

.specs-screenshot img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(44, 38, 32, 0.14), 0 3px 10px rgba(44, 38, 32, 0.06);
  border: 1px solid rgba(44, 38, 32, 0.08);
}

.specs-screenshot figcaption {
  margin-top: 16px;
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  line-height: 1.55;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  font-style: italic;
}

.specs-screenshot strong {
  color: var(--color-text);
  font-style: normal;
}

/* Deep-dive card with thumbnail (features.html) */
.deep-dive-card--with-thumb {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 0;
  overflow: hidden;
  padding: 0;
}

@media (max-width: 768px) {
  .deep-dive-card--with-thumb {
    grid-template-columns: 1fr;
  }
}

.deep-dive-card__thumb {
  display: block;
  overflow: hidden;
  background: var(--color-bg-alt);
}

.deep-dive-card__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.25s ease;
}

.deep-dive-card__thumb:hover img {
  transform: scale(1.03);
}

.deep-dive-card__body {
  padding: 24px;
}

/* Use-case card with screenshot (comparison.html) */
.usecase-card--with-shot {
  overflow: hidden;
  padding: 0;
}

.usecase-card__thumb {
  display: block;
  overflow: hidden;
  background: var(--color-bg-alt);
  border-bottom: 1px solid rgba(44, 38, 32, 0.08);
}

.usecase-card__thumb img {
  display: block;
  width: 100%;
  height: auto;
  transition: transform 0.25s ease;
}

.usecase-card__thumb:hover img {
  transform: scale(1.03);
}

.usecase-card--with-shot h3,
.usecase-card--with-shot p,
.usecase-card--with-shot .usecase-card__link {
  padding-left: 28px;
  padding-right: 28px;
}

.usecase-card--with-shot h3 { padding-top: 24px; }

.usecase-card--with-shot .usecase-card__link { padding-bottom: 24px; display: inline-block; }

/* ============================================================
   Sprint L.12 — Tonal refonte (audit dénigrement)
   Capability list (replaces head-to-head comparison tables)
   ============================================================ */
.capabilities-list {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 760px;
  display: grid;
  gap: 14px;
}

.capabilities-list li {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 14px;
  align-items: baseline;
  background: var(--color-bg);
  padding: 16px 20px;
  border-radius: 10px;
  border: 1px solid rgba(44, 38, 32, 0.06);
  line-height: 1.55;
  color: var(--color-text-secondary);
  font-size: var(--size-base);
}

.capabilities-list li strong {
  color: var(--color-text);
  font-weight: 600;
}

.capabilities-list__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--color-accent);
  color: var(--color-text-on-dark);
  font-weight: 700;
  font-size: 14px;
}

/* ============================================================
   setup.html — page Configuration locale complète
   ============================================================ */
.setup-card {
  background: var(--color-bg);
  border: 1px solid rgba(44, 38, 32, 0.08);
  border-radius: 12px;
  padding: 28px 32px;
  margin: 0 auto 24px;
  max-width: 880px;
  box-shadow: 0 2px 8px rgba(44, 38, 32, 0.04);
}

.setup-card--recommended {
  border-color: var(--color-accent);
  background: linear-gradient(180deg, var(--color-accent-light) 0%, var(--color-bg) 70%);
}

.setup-card__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(44, 38, 32, 0.08);
}

.setup-card__title {
  margin: 0;
  font-family: var(--font-serif);
  font-size: var(--size-2xl);
  color: var(--color-accent);
  font-weight: 600;
}

.setup-card__badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--color-accent-light);
  color: var(--color-accent);
  font-size: var(--size-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.setup-card__badge--cloud {
  background: rgba(139, 69, 19, 0.10);
  color: var(--color-accent-warm);
}

.setup-card p {
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin: 0 0 14px 0;
  font-size: var(--size-base);
}

.setup-card code {
  background: var(--color-bg-alt);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 0.88em;
  color: var(--color-text);
}

.setup-card pre {
  background: var(--color-text);
  color: var(--color-bg);
  padding: 10px 14px;
  border-radius: 6px;
  font-family: var(--font-mono);
  font-size: 0.9em;
  margin: 8px 0;
  overflow-x: auto;
}

.setup-card pre code {
  background: transparent;
  color: inherit;
  padding: 0;
}

.setup-card__steps {
  margin: 14px 0 14px 0;
  padding-left: 22px;
  color: var(--color-text-secondary);
  line-height: 1.55;
}

.setup-card__steps li {
  margin-bottom: 10px;
  font-size: var(--size-base);
}

.setup-card__steps li::marker {
  color: var(--color-accent);
  font-weight: 700;
}

.setup-card__note {
  margin: 16px 0 0 0 !important;
  padding: 12px 14px;
  background: rgba(59,130,246,0.07);
  border-left: 3px solid var(--color-accent);
  border-radius: 0 6px 6px 0;
  font-size: var(--size-sm);
  line-height: 1.55;
}

/* Hardware table — § 4 */
.hardware-table {
  max-width: 1000px;
  margin: 0 auto;
  overflow-x: auto;
}

.hardware-table table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(44, 38, 32, 0.06);
}

.hardware-table th,
.hardware-table td {
  padding: 14px 18px;
  text-align: left;
  border-bottom: 1px solid rgba(44, 38, 32, 0.08);
  vertical-align: top;
}

.hardware-table th {
  background: var(--color-accent);
  color: var(--color-text-on-dark);
  font-family: var(--font-serif);
  font-weight: 600;
}

.hardware-table tbody tr:last-child td {
  border-bottom: none;
}

.hardware-table__sweet {
  background: var(--color-accent-light);
}

.hardware-table__sweet td {
  font-weight: 500;
}

.hardware-table__star {
  display: inline-block;
  margin-left: 4px;
  color: var(--color-accent);
  font-size: 1.1em;
}

/* Recap table — § 5 */
.recap-table {
  max-width: 1000px;
  margin: 0 auto;
  overflow-x: auto;
}

.recap-table table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(44, 38, 32, 0.06);
}

.recap-table th,
.recap-table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid rgba(44, 38, 32, 0.08);
  font-size: var(--size-base);
}

.recap-table th {
  background: var(--color-accent);
  color: var(--color-text-on-dark);
  font-family: var(--font-serif);
  font-weight: 600;
}

.recap-table tbody tr:last-child td {
  border-bottom: none;
}

.recap-table tbody tr:hover {
  background: var(--color-bg-alt);
}

.recap-table__yes {
  color: var(--color-accent);
  font-weight: 700;
  text-align: center;
  white-space: nowrap;
}

.recap-table__yes small {
  color: var(--color-text-tertiary);
  font-weight: 400;
  display: block;
  margin-top: 2px;
}

.recap-table__no {
  color: var(--color-text-tertiary);
  text-align: center;
}

.specs-card__see-more {
  margin-top: 12px;
  font-size: var(--size-sm);
}

/* ============================================================
   Utility classes for inline-styles cleanup (review remediation)
   ============================================================ */
.legal-meta {
  margin-top: 48px;
  color: var(--color-text-tertiary);
  font-size: var(--size-xs);
}

.download-fineprint {
  font-size: var(--size-sm);
  color: var(--color-text-secondary);
  margin-top: 0.75rem;
}

.download-fineprint--tight {
  margin-top: 0.5rem;
}

.download-center {
  text-align: center;
  margin-top: 1.5rem;
}

.download-section--centered {
  text-align: center;
  padding-bottom: 3rem;
}
