/* ============================================================
   Blocks — visual style per block type
   ============================================================ */

/* ============= Generic block helpers ============= */
.block { padding: 0; position: relative; }
.block.is-spacing-xs { padding-block: var(--sp-xs); }
.block.is-spacing-sm { padding-block: var(--sp-sm); }
.block.is-spacing-md { padding-block: var(--sp-md); }
.block.is-spacing-lg { padding-block: var(--sp-lg); }
.block.is-spacing-xl { padding-block: var(--sp-xl); }

.block.is-align-center { text-align: center; }
.block.is-align-center .container > * { margin-inline: auto; }
.block.is-align-left { text-align: left; }
.block.is-align-right { text-align: right; }

.block.is-background-light { background: var(--color-bg); color: var(--color-text); }
.block.is-background-alt { background: var(--color-bg-alt); color: var(--color-text); }
.block.is-background-mute { background: var(--color-bg-mute); color: var(--color-text); }
.block.is-background-secondary {
  background: var(--gradient-secondary);
  color: var(--color-white);
}
.block.is-background-secondary h1,
.block.is-background-secondary h2,
.block.is-background-secondary h3 { color: var(--color-white); }
.block.is-background-secondary a:not(.btn) { color: var(--color-white); }
.block.is-background-image {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  background-color: var(--color-bg);
}

/* ============= Hero ============= */
.block-hero {
  position: relative;
  padding-block: clamp(56px, 6vw, 96px);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  background-color: var(--color-bg);
  overflow: hidden;
}
.block-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--gradient-hero);
  pointer-events: none;
  z-index: 0;
}
.block-hero::after {
  content: "";
  position: absolute;
  width: 480px; height: 480px;
  top: -120px; right: -160px;
  background: radial-gradient(closest-side, var(--color-primary-glow), transparent 70%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
}
.block-hero > .container { position: relative; z-index: 1; }
.block-hero .hero-inner {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(0, 1fr);
  gap: var(--sp-xl);
  align-items: center;
}
.block-hero .hero-text { max-width: 560px; }
.block-hero .hero-eyebrow,
.block-hero .hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  margin: 0 0 var(--sp-md);
  line-height: 1.2;
}
.block-hero .hero-eyebrow::before {
  content: "";
  width: 6px; height: 6px;
  background: var(--color-primary);
  border-radius: 50%;
  box-shadow: 0 0 0 4px var(--color-primary-soft), 0 0 0 5px var(--color-primary-glow);
  animation: pulseDot 1.8s var(--ease-in-out) infinite;
}
@keyframes pulseDot {
  0%, 100% { box-shadow: 0 0 0 4px var(--color-primary-soft), 0 0 0 5px var(--color-primary-glow); }
  50% { box-shadow: 0 0 0 6px transparent, 0 0 0 8px var(--color-primary-glow); }
}
@media (prefers-reduced-motion: reduce) {
  .block-hero .hero-eyebrow::before { animation: none; }
}
.block-hero .hero-title {
  font-size: var(--fs-hero);
  line-height: 1.08;
  margin: 0 0 var(--sp-md);
  color: var(--color-accent);
  letter-spacing: -0.02em;
}
.block-hero .hero-lead {
  font-size: var(--fs-lead);
  line-height: 1.55;
  color: var(--color-text);
  margin: 0 0 var(--sp-md);
}
.block-hero .hero-cta {
  margin: 0 0 var(--sp-md);
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.block-hero .hero-tagline {
  font-size: var(--fs-base);
  margin: 0;
  color: var(--color-text-muted);
  max-width: 520px;
}
@media (max-width: 991px) {
  .block-hero .hero-inner { grid-template-columns: 1fr; }
  .block-hero .hero-text { max-width: 100%; }
}

/* ============= LeadIntro ============= */
.block-leadIntro { padding-block: var(--sp-md) var(--sp-sm); }
.block-leadIntro .leadIntro-title {
  font-size: var(--fs-h1);
  letter-spacing: -0.015em;
  margin: 0 0 var(--sp-sm);
}
.block-leadIntro .leadIntro-kicker {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  margin: 0 0 var(--sp-sm);
}
.block-leadIntro .leadIntro-lead {
  font-size: var(--fs-lead);
  line-height: 1.6;
  color: var(--color-text);
  margin: 0;
  max-width: 760px;
}

/* ============= SectionTitle ============= */
.block-sectionTitle .sectionTitle-inner {
  max-width: 820px;
  margin-inline: auto;
}
.block-sectionTitle .sectionTitle-kicker {
  display: inline-block;
  text-transform: uppercase;
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  color: var(--color-primary);
  background: var(--color-primary-soft);
  font-weight: 700;
  margin: 0 0 var(--sp-sm);
  padding: 4px 12px;
  border-radius: var(--radius-pill);
}
.block-sectionTitle .sectionTitle-title {
  font-size: var(--fs-h2);
  line-height: 1.15;
  margin: 0 0 var(--sp-sm);
  letter-spacing: -0.015em;
}
.block-sectionTitle .sectionTitle-lead {
  font-size: var(--fs-lead);
  line-height: 1.55;
  margin: 0 auto var(--sp-sm);
  max-width: 720px;
  color: color-mix(in srgb, currentColor 88%, transparent);
}
.block-sectionTitle.is-background-secondary .sectionTitle-kicker {
  color: var(--color-white);
  background: rgba(255, 255, 255, 0.18);
}
.block-sectionTitle .sectionTitle-cta { margin-top: var(--sp-md); }

/* ============= TextBlock ============= */
.block-textBlock .textBlock-inner { max-width: 760px; }
.block-textBlock.is-align-center .textBlock-inner { margin-inline: auto; }
.block-textBlock .textBlock-title {
  font-size: var(--fs-h2);
  line-height: 1.15;
  margin: 0 0 var(--sp-sm);
  letter-spacing: -0.01em;
}
.block-textBlock .textBlock-subtitle {
  font-size: var(--fs-h3);
  margin: 0 0 var(--sp-xs);
  color: var(--color-accent);
  font-weight: 600;
}
.block-textBlock .textBlock-cta { margin-top: var(--sp-md); }

/* ============= BulletList ============= */
.block-bulletList .bulletList-inner { max-width: 760px; }
.block-bulletList.is-align-center .bulletList-inner { margin-inline: auto; }
.block-bulletList .bulletList-items {
  list-style: none;
  padding-left: 0;
  margin: 0;
}
.block-bulletList .bulletList-items li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 12px;
  line-height: 1.55;
}
.block-bulletList .bulletList-items li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.55em;
  width: 16px; height: 16px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'><circle cx='8' cy='8' r='8' fill='%23fde7d6'/><path d='M5 8.2L7.1 10.3L11.2 6' stroke='%23ef7e3c' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.block-bulletList.is-variant-featured .bulletList-items li {
  padding-left: 40px;
  font-size: var(--fs-lead);
  margin-bottom: 18px;
  font-weight: 500;
}
.block-bulletList.is-variant-featured .bulletList-items li::before {
  width: 24px; height: 24px;
  top: 0.4em;
}

/* ============= OfferCardGrid + OfferCard ============= */
.block-offerCardGrid {
  background: var(--color-bg-alt);
  padding-block: var(--sp-xl);
}
.block-offerCardGrid .offerCardGrid-inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-lg);
  align-items: stretch;
}
@media (max-width: 991px) {
  .block-offerCardGrid .offerCardGrid-inner { grid-template-columns: 1fr; }
}

.block-offerCard { height: 100%; }
.block-offerCard .pricing {
  position: relative;
  background: var(--color-white);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: 40px 28px 32px;
  text-align: center;
  height: 100%;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-2);
  transition: box-shadow var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
  overflow: hidden;
}
.block-offerCard .pricing::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--gradient-primary);
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
}
.block-offerCard .pricing:hover {
  box-shadow: var(--shadow-4);
  transform: translateY(-6px);
  border-color: transparent;
}
.block-offerCard .pricing:hover::before { opacity: 1; }

.block-offerCard.is-variant-featured .pricing {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-3), 0 0 0 1px var(--color-primary);
}
.block-offerCard.is-variant-featured .pricing::before {
  opacity: 1;
  height: 6px;
}
.block-offerCard.is-variant-featured .pricing::after {
  content: "Populaire";
  position: absolute;
  top: 16px; right: 16px;
  padding: 4px 12px;
  background: var(--color-primary);
  color: var(--color-white);
  font-family: var(--font-heading);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: var(--radius-pill);
  text-transform: uppercase;
  box-shadow: var(--shadow-2);
}

.block-offerCard .offerCard-title {
  font-size: var(--fs-h2);
  margin: 0 0 var(--sp-xs);
  letter-spacing: -0.01em;
}
.block-offerCard .offerCard-subtitle {
  display: inline-block;
  font-size: var(--fs-sm);
  font-weight: 600;
  margin: 0 0 var(--sp-md);
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  background: var(--color-primary-soft);
  padding: 4px 12px;
  border-radius: var(--radius-pill);
}
.block-offerCard .offerCard-image {
  margin: 0 0 var(--sp-md);
}
.block-offerCard .offerCard-image img {
  margin: 0 auto;
  height: 96px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 8px 18px rgba(20, 42, 82, 0.08));
}
.block-offerCard .offerCard-description {
  font-size: var(--fs-base);
  margin: 0 0 var(--sp-md);
  color: var(--color-text-muted);
}
.block-offerCard .offerCard-bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-lg);
  text-align: left;
  flex: 1;
}
.block-offerCard .offerCard-bullets li {
  position: relative;
  padding: 10px 0 10px 28px;
  border-top: 1px solid var(--color-border-soft);
  line-height: 1.4;
  font-size: var(--fs-sm);
}
.block-offerCard .offerCard-bullets li:first-child { border-top: 0; }
.block-offerCard .offerCard-bullets li::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 18px; height: 18px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18' fill='none'><circle cx='9' cy='9' r='9' fill='%23fde7d6'/><path d='M5.5 9.2L7.8 11.5L12.5 6.5' stroke='%23ef7e3c' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
}
.block-offerCard .offerCard-cta { margin: auto 0 0; }

/* ============= PersonaGrid ============= */
.block-personaGrid .personaGrid-row {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--sp-xl);
  align-items: center;
}
@media (max-width: 991px) {
  .block-personaGrid .personaGrid-row { grid-template-columns: 1fr; }
}
.block-personaGrid .personaGrid-text h2 {
  font-size: var(--fs-h2);
  margin: 0 0 var(--sp-sm);
  letter-spacing: -0.015em;
}
.block-personaGrid .personaGrid-text p { margin-bottom: var(--sp-md); }
.block-personaGrid .personaGrid-list {
  list-style: none;
  padding: 0;
  margin: var(--sp-md) 0 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 575px) {
  .block-personaGrid .personaGrid-list { grid-template-columns: 1fr; }
}
.block-personaGrid .personaGrid-list li { margin: 0; }
.block-personaGrid .personaGrid-list a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  background: var(--color-white);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-md);
  color: var(--color-accent);
  text-decoration: none;
  font-weight: 600;
  font-family: var(--font-heading);
  font-size: var(--fs-sm);
  line-height: 1.3;
  box-shadow: var(--shadow-1);
  transition: transform var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              color var(--dur-base) var(--ease-out);
}
.block-personaGrid .personaGrid-list a strong { font-weight: 600; color: inherit; }
.block-personaGrid .personaGrid-list a::after {
  content: "\2192";
  margin-left: auto;
  color: var(--color-primary);
  transition: transform var(--dur-base) var(--ease-out);
}
.block-personaGrid .personaGrid-list a:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-3);
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.block-personaGrid .personaGrid-list a:hover::after { transform: translateX(4px); }
.block-personaGrid .personaGrid-image img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-3);
}

/* ============= StatsGrid ============= */
.block-statsGrid {
  background: var(--color-bg-alt);
  padding-block: var(--sp-xl);
}
.block-statsGrid .statsGrid-inner {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--sp-md);
  align-items: stretch;
}
.block-statsGrid .statsGrid-titleCell {
  grid-column: 1 / -1;
  text-align: center;
  margin-bottom: var(--sp-md);
}
.block-statsGrid .statsGrid-titleCell h2 {
  font-size: var(--fs-h2);
  margin: 0;
  letter-spacing: -0.015em;
}
.block-statsGrid .statsGrid-item { grid-column: span 1; }
.block-statsGrid .pricing {
  background: var(--color-white);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  padding: var(--sp-md) var(--sp-sm);
  text-align: center;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
  box-shadow: var(--shadow-1);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.block-statsGrid .pricing:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-3);
}
.block-statsGrid .pricing h3 {
  font-family: var(--font-heading);
  font-size: var(--fs-stat);
  font-weight: 800;
  line-height: 1;
  margin: 0;
  background: var(--gradient-text-number);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.02em;
}
.block-statsGrid .pricing p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  line-height: 1.35;
}
@media (max-width: 991px) {
  .block-statsGrid .statsGrid-inner { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575px) {
  .block-statsGrid .statsGrid-inner { grid-template-columns: 1fr; }
}

/* ============= TestimonialCard ============= */
.block-testimonialCard { padding-block: var(--sp-xl); }
.block-testimonialCard .testimonialCard-row {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--sp-xl);
  max-width: 960px;
  margin-inline: auto;
  align-items: center;
  background: var(--color-white);
  padding: var(--sp-xl) var(--sp-lg);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-3);
  position: relative;
  overflow: hidden;
}
.block-testimonialCard .testimonialCard-row::before {
  content: "\201C";
  position: absolute;
  top: -40px; right: -10px;
  font-family: Georgia, serif;
  font-size: 280px;
  line-height: 1;
  color: var(--color-primary-soft);
  pointer-events: none;
  font-style: normal;
}
.block-testimonialCard .testimonialCard-avatar {
  position: relative;
  z-index: 1;
}
.block-testimonialCard .testimonialCard-avatar img {
  border-radius: 50%;
  width: 220px;
  height: 220px;
  object-fit: cover;
  box-shadow: 0 0 0 6px var(--color-primary-soft), var(--shadow-3);
}
.block-testimonialCard .testimonialCard-body { position: relative; z-index: 1; }
.block-testimonialCard .testimonialCard-quote {
  font-family: var(--font-heading);
  font-size: clamp(20px, 1.6vw + 14px, 26px);
  font-style: italic;
  font-weight: 500;
  line-height: 1.45;
  color: var(--color-accent);
  margin: 0 0 var(--sp-md);
  padding: 0;
  border-left: 0;
}
.block-testimonialCard .testimonialCard-footer {
  display: flex;
  align-items: center;
  gap: var(--sp-md);
  flex-wrap: wrap;
}
.block-testimonialCard .testimonialCard-author {
  font-weight: 700;
  color: var(--color-accent);
  font-family: var(--font-heading);
  font-size: var(--fs-md);
}
.block-testimonialCard .testimonialCard-role {
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  margin-top: 2px;
}
.block-testimonialCard .testimonialCard-logo img { max-height: 48px; width: auto; }
@media (max-width: 767px) {
  .block-testimonialCard .testimonialCard-row {
    grid-template-columns: 1fr;
    text-align: center;
    padding: var(--sp-lg) var(--sp-md);
  }
  .block-testimonialCard .testimonialCard-avatar { justify-self: center; }
  .block-testimonialCard .testimonialCard-avatar img { width: 140px; height: 140px; }
  .block-testimonialCard .testimonialCard-footer { justify-content: center; }
}

/* ============= LogoStrip ============= */
.block-logoStrip {
  background: var(--color-white);
  padding-block: var(--sp-lg);
}
.block-logoStrip .logoStrip-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--sp-lg);
  align-items: center;
}
.block-logoStrip .logoStrip-item img {
  max-height: 56px;
  width: auto;
  margin-inline: auto;
  filter: grayscale(100%);
  opacity: 0.55;
  transition: filter var(--dur-base) var(--ease-out),
              opacity var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}
.block-logoStrip .logoStrip-item:hover img {
  filter: none;
  opacity: 1;
  transform: scale(1.05);
}

/* ============= ImageTextBlock ============= */
.block-imageTextBlock .imageTextBlock-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-xl);
  align-items: center;
}
.block-imageTextBlock .imageTextBlock-text { max-width: 540px; }
.block-imageTextBlock .imageTextBlock-image img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-3);
}
.block-imageTextBlock.is-align-right .imageTextBlock-row { direction: rtl; }
.block-imageTextBlock.is-align-right .imageTextBlock-text,
.block-imageTextBlock.is-align-right .imageTextBlock-image { direction: ltr; }
@media (max-width: 991px) {
  .block-imageTextBlock .imageTextBlock-row { grid-template-columns: 1fr; direction: ltr; }
}

/* ============= Image ============= */
.block-image figcaption {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  margin-top: var(--sp-xs);
  text-align: center;
}
.block-image img { border-radius: var(--radius-md); }

/* ============= DownloadCta ============= */
.block-downloadCta .downloadCta-row {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--sp-lg);
  align-items: center;
  padding: var(--sp-lg);
  background: linear-gradient(135deg, var(--color-bg-alt), var(--color-white));
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-2);
  position: relative;
  overflow: hidden;
}
.block-downloadCta .downloadCta-row::before {
  content: "";
  position: absolute;
  top: -80px; left: -80px;
  width: 240px; height: 240px;
  background: radial-gradient(closest-side, var(--color-primary-glow), transparent 70%);
  pointer-events: none;
}
.block-downloadCta .downloadCta-text { position: relative; z-index: 1; }
.block-downloadCta .downloadCta-image {
  display: block;
  position: relative;
  z-index: 1;
}
.block-downloadCta .downloadCta-image img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-3);
}
@media (max-width: 767px) {
  .block-downloadCta .downloadCta-row { grid-template-columns: 1fr; }
}

/* ============= ArticleHeader ============= */
.block-articleHeader {
  padding-top: var(--sp-md);
  padding-bottom: var(--sp-md);
}
.block-articleHeader .container { max-width: 820px; }
.block-articleHeader .articleHeader-cover {
  position: relative;
  margin: 0 0 var(--sp-md);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.block-articleHeader .articleHeader-cover img {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
}
.block-articleHeader .articleHeader-cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(20, 42, 82, 0.2));
  pointer-events: none;
}
.block-articleHeader .articleHeader-category {
  display: inline-block;
  margin: 0 0 var(--sp-sm);
  padding: 6px 14px;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-primary);
  background: var(--color-primary-soft);
  text-decoration: none;
  font-weight: 700;
  border-radius: var(--radius-pill);
}
.block-articleHeader .articleHeader-category:hover {
  background: var(--color-primary);
  color: var(--color-white);
}
.block-articleHeader .articleHeader-title {
  font-size: var(--fs-h1);
  line-height: 1.12;
  margin: 0 0 var(--sp-md);
  letter-spacing: -0.02em;
}
.block-articleHeader .articleHeader-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-md);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: 14px 0;
}
.block-articleHeader .articleHeader-date::before {
  content: "";
  display: inline-block;
  width: 14px; height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%236b7c85' stroke-width='1.4'><rect x='2' y='3.5' width='12' height='11' rx='1.5'/><path d='M5 2v3M11 2v3M2 7h12'/></svg>");
  background-repeat: no-repeat;
  margin-right: 6px;
  vertical-align: -2px;
}
.block-articleHeader .articleHeader-reading::before {
  content: "";
  display: inline-block;
  width: 14px; height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%236b7c85' stroke-width='1.4'><circle cx='8' cy='8' r='6.5'/><path d='M8 4v4l3 2'/></svg>");
  background-repeat: no-repeat;
  margin-right: 6px;
  vertical-align: -2px;
}
.block-articleHeader .articleHeader-share-label {
  font-weight: 700;
  color: var(--color-accent);
  margin-left: auto;
}
.block-articleHeader .articleHeader-share {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 6px;
}
.block-articleHeader .articleHeader-share a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px; height: 34px;
  color: var(--color-text-muted);
  text-decoration: none;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border-soft);
  border-radius: 50%;
  font-size: var(--fs-xs);
  font-weight: 600;
  transition: color var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}
.block-articleHeader .articleHeader-share a:hover {
  color: var(--color-white);
  background: var(--color-primary);
  border-color: var(--color-primary);
  transform: translateY(-2px);
}

/* ============= ArticleBody ============= */
.block-articleBody .container { max-width: 820px; }
.block-articleBody .articleBody-inner {
  font-size: var(--fs-md);
  line-height: 1.75;
  color: var(--color-text);
}
.block-articleBody .articleBody-inner h2 {
  font-size: var(--fs-h2);
  margin-top: var(--sp-xl);
  margin-bottom: var(--sp-sm);
  letter-spacing: -0.015em;
  position: relative;
  padding-bottom: 12px;
}
.block-articleBody .articleBody-inner h2::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 48px; height: 3px;
  background: var(--gradient-primary);
  border-radius: var(--radius-pill);
}
.block-articleBody .articleBody-inner h3 {
  font-size: var(--fs-h3);
  margin-top: var(--sp-lg);
  margin-bottom: var(--sp-sm);
}
.block-articleBody .articleBody-inner p { margin: 0 0 var(--sp-sm); }
.block-articleBody .articleBody-inner ul,
.block-articleBody .articleBody-inner ol {
  margin: 0 0 var(--sp-sm);
  padding-left: 0;
  list-style: none;
}
.block-articleBody .articleBody-inner ul li,
.block-articleBody .articleBody-inner ol li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 10px;
}
.block-articleBody .articleBody-inner ul li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.6em;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--gradient-primary);
}
.block-articleBody .articleBody-inner ol { counter-reset: ol-counter; }
.block-articleBody .articleBody-inner ol li { counter-increment: ol-counter; }
.block-articleBody .articleBody-inner ol li::before {
  content: counter(ol-counter);
  position: absolute;
  left: 0; top: 0.05em;
  width: 22px; height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-radius: 50%;
}
.block-articleBody .articleBody-inner a {
  color: var(--color-primary);
  text-decoration: none;
  background-image: linear-gradient(var(--color-primary), var(--color-primary));
  background-position: 0 100%;
  background-repeat: no-repeat;
  background-size: 100% 1px;
  padding-bottom: 1px;
  transition: background-size var(--dur-base) var(--ease-out),
              color var(--dur-base) var(--ease-out);
}
.block-articleBody .articleBody-inner a:hover {
  background-size: 100% 2px;
  color: var(--color-primary-hover);
}
.block-articleBody .articleBody-inner img {
  border-radius: var(--radius-md);
  margin: var(--sp-md) auto;
  box-shadow: var(--shadow-2);
}
.block-articleBody .articleBody-inner blockquote {
  margin: var(--sp-md) 0;
  padding: var(--sp-md) var(--sp-lg);
  border-left: 4px solid var(--color-primary);
  background: var(--color-bg-alt);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-style: italic;
  font-size: var(--fs-lead);
}

/* ============= ArticleMeta ============= */
.block-articleMeta .container { max-width: 820px; }
.block-articleMeta .articleMeta-inner {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-md);
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-md) 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.block-articleMeta .articleMeta-share,
.block-articleMeta .articleMeta-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  font-size: var(--fs-sm);
}
.block-articleMeta .articleMeta-share-list,
.block-articleMeta .articleMeta-tag-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.block-articleMeta .articleMeta-share-list a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border-soft);
  border-radius: 50%;
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}
.block-articleMeta .articleMeta-share-list a:hover {
  color: var(--color-white);
  background: var(--color-primary);
  border-color: var(--color-primary);
  transform: translateY(-2px);
}
.block-articleMeta .articleMeta-tag-list a {
  display: inline-block;
  padding: 5px 12px;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-pill);
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
}
.block-articleMeta .articleMeta-tag-list a:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.block-articleMeta .articleMeta-share-label,
.block-articleMeta .articleMeta-tag-label {
  font-weight: 700;
  color: var(--color-accent);
}

/* ============= RelatedArticles + ArticleCard ============= */
.block-relatedArticles { padding-block: var(--sp-xl); }
.block-relatedArticles .relatedArticles-title {
  text-align: center;
  font-size: var(--fs-h2);
  margin-bottom: var(--sp-lg);
  letter-spacing: -0.015em;
}
.block-relatedArticles .relatedArticles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-lg);
}
.block-relatedArticles .relatedArticles-empty {
  grid-column: 1 / -1;
  text-align: center;
  font-size: var(--fs-md);
  color: var(--color-text-soft);
  padding: var(--sp-lg);
  background: var(--color-bg-alt);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
}
@media (max-width: 991px) {
  .block-relatedArticles .relatedArticles-grid { grid-template-columns: 1fr; }
}

.block-articleCard {
  background: var(--color-white);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-1);
  transition: box-shadow var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
}
.block-articleCard:hover {
  box-shadow: var(--shadow-4);
  transform: translateY(-4px);
  border-color: transparent;
}
.block-articleCard .articleCard-image {
  display: block;
  overflow: hidden;
  background: var(--color-bg-mute);
}
.block-articleCard .articleCard-image img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
}
.block-articleCard:hover .articleCard-image img { transform: scale(1.06); }

.block-articleCard .articleCard-category {
  margin: 18px 18px 0;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}
.block-articleCard .articleCard-category a {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: 700;
}
.block-articleCard .articleCard-title {
  margin: 8px 18px 12px;
  font-size: var(--fs-h3);
  line-height: 1.3;
}
.block-articleCard .articleCard-title a {
  color: var(--color-accent);
  text-decoration: none;
}
.block-articleCard .articleCard-title a:hover { color: var(--color-primary); }
.block-articleCard .articleCard-excerpt {
  margin: 0 18px 18px;
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  flex: 1;
  line-height: 1.55;
}
.block-articleCard .articleCard-excerpt a {
  color: var(--color-primary);
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}
.block-articleCard .articleCard-excerpt a:hover { text-decoration: underline; }

/* ============= CategoryLabel ============= */
.block-categoryLabel {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}
.block-categoryLabel a {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: 700;
}

/* ============= NewsletterBlock ============= */
.block-newsletterBlock {
  padding: var(--sp-lg) 0;
  border-top: 1px solid var(--color-border-soft);
}
.block-newsletterBlock .container { max-width: 820px; }
.block-newsletterBlock .newsletterBlock-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-sm);
  padding: var(--sp-lg);
  background: linear-gradient(135deg, var(--color-primary-soft) 0%, var(--color-bg-alt) 100%);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-soft);
}
.block-newsletterBlock .newsletterBlock-title {
  font-size: var(--fs-h3);
  margin: 0 0 var(--sp-xs);
  letter-spacing: -0.01em;
}
.block-newsletterBlock .newsletterBlock-description {
  margin: 0 0 var(--sp-sm);
  color: var(--color-text-muted);
}
.block-newsletterBlock .newsletterBlock-form {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.block-newsletterBlock .newsletterBlock-form input[type=email] {
  flex: 1;
  min-width: 240px;
  padding: 13px 18px;
  font: inherit;
  font-size: var(--fs-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: var(--color-white);
  color: var(--color-text);
  transition: border-color var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
}
.block-newsletterBlock .newsletterBlock-form input[type=email]:focus-visible {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px var(--color-primary-glow);
}
.block-newsletterBlock .newsletterBlock-form button {
  background: var(--color-primary);
  color: var(--color-white);
  border: 0;
  padding: 13px 24px;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--fs-sm);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-2);
  cursor: pointer;
  transition: background var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.block-newsletterBlock .newsletterBlock-form button:hover {
  background: var(--color-primary-hover);
  box-shadow: var(--shadow-glow);
}

/* ============= SocialLinks ============= */
.block-socialLinks { padding: var(--sp-md) 0; }
.block-socialLinks .container { max-width: 820px; }
.block-socialLinks .socialLinks-title {
  font-size: var(--fs-h3);
  margin: 0 0 var(--sp-sm);
}
.block-socialLinks .socialLinks-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.block-socialLinks .socialLinks-list a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  padding: 10px 18px;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-pill);
  color: var(--color-accent);
  font-weight: 600;
  font-size: var(--fs-sm);
  transition: color var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}
.block-socialLinks .socialLinks-list a:hover {
  color: var(--color-white);
  background: var(--color-primary);
  border-color: var(--color-primary);
  transform: translateY(-2px);
}

/* ============= MustReadList ============= */
.block-mustReadList {
  padding: var(--sp-lg) 0;
  border-top: 1px solid var(--color-border-soft);
}
.block-mustReadList .container { max-width: 820px; }
.block-mustReadList .mustReadList-title {
  font-size: var(--fs-h3);
  margin: 0 0 var(--sp-md);
  letter-spacing: -0.01em;
  position: relative;
  padding-bottom: 10px;
}
.block-mustReadList .mustReadList-title::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 42px; height: 3px;
  background: var(--gradient-primary);
  border-radius: var(--radius-pill);
}
.block-mustReadList .mustReadList-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 24px;
}
.block-mustReadList .mustReadList-list li { margin: 0; }
.block-mustReadList .mustReadList-list a {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 14px;
  background: var(--color-bg-alt);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  color: var(--color-accent);
  text-decoration: none;
  font-weight: 600;
  font-size: var(--fs-sm);
  line-height: 1.35;
  transition: color var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              transform var(--dur-base) var(--ease-out);
}
.block-mustReadList .mustReadList-list a::before {
  content: "\2192";
  color: var(--color-primary);
  font-weight: 700;
  flex-shrink: 0;
  transition: transform var(--dur-base) var(--ease-out);
}
.block-mustReadList .mustReadList-list a:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
  transform: translateX(2px);
}
.block-mustReadList .mustReadList-list a:hover::before { transform: translateX(2px); }
@media (max-width: 767px) {
  .block-mustReadList .mustReadList-list { grid-template-columns: 1fr; }
}

/* ============= CaseStudyEnjeux / Results ============= */
.block-caseStudyEnjeux, .block-caseStudyResults {
  padding-block: var(--sp-lg);
}
.block-caseStudyEnjeux .container,
.block-caseStudyResults .container { max-width: 900px; }
.block-caseStudyEnjeux .caseStudyEnjeux-title,
.block-caseStudyResults .caseStudyResults-title {
  font-size: var(--fs-h2);
  margin: 0 0 var(--sp-md);
  letter-spacing: -0.015em;
  position: relative;
  padding-bottom: 12px;
}
.block-caseStudyEnjeux .caseStudyEnjeux-title::after,
.block-caseStudyResults .caseStudyResults-title::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 48px; height: 3px;
  background: var(--gradient-primary);
  border-radius: var(--radius-pill);
}
.block-caseStudyEnjeux .caseStudyEnjeux-list,
.block-caseStudyResults .caseStudyResults-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
}
.block-caseStudyEnjeux .caseStudyEnjeux-list li,
.block-caseStudyResults .caseStudyResults-list li {
  position: relative;
  padding: 18px 18px 18px 64px;
  margin: 0;
  font-size: var(--fs-lead);
  line-height: 1.45;
  background: var(--color-white);
  border: 1px solid var(--color-border-soft);
  border-left: 4px solid var(--color-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  box-shadow: var(--shadow-1);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.block-caseStudyEnjeux .caseStudyEnjeux-list li:hover,
.block-caseStudyResults .caseStudyResults-list li:hover {
  transform: translateX(4px);
  box-shadow: var(--shadow-2);
}
.block-caseStudyEnjeux .caseStudyEnjeux-list li::before,
.block-caseStudyResults .caseStudyResults-list li::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px; height: 32px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' fill='none'><circle cx='16' cy='16' r='16' fill='%23fde7d6'/><path d='M10 16.5L14 20.5L22 12.5' stroke='%23ef7e3c' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
}
.block-caseStudyEnjeux .caseStudyEnjeux-list li::after,
.block-caseStudyResults .caseStudyResults-list li::after { content: none; }

/* ============= CTA Banner ============= */
.block-ctaBanner {
  padding-block: var(--sp-xl);
  background-color: var(--color-bg-alt);
}
.block-ctaBanner.is-variant-dark {
  color: var(--color-white);
  background-color: var(--color-bg-darker);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  position: relative;
  overflow: hidden;
}
.block-ctaBanner.is-variant-dark::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--color-overlay-dark) 0%, rgba(20, 42, 82, 0.85) 100%);
  pointer-events: none;
}
.block-ctaBanner.is-variant-dark > .container { position: relative; }
.block-ctaBanner.is-variant-dark h2 { color: var(--color-white); }
.block-ctaBanner.is-variant-dark p { color: rgba(255, 255, 255, 0.88); }
.block-ctaBanner.is-variant-dark a:not(.btn) { color: var(--color-white); }

.block-ctaBanner h2 {
  font-size: var(--fs-h2);
  letter-spacing: -0.015em;
  margin: 0 0 var(--sp-sm);
}
.block-ctaBanner .row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-lg);
  align-items: center;
}
.block-ctaBanner.is-align-center .row {
  grid-template-columns: 1fr;
  max-width: 760px;
  margin-inline: auto;
  text-align: center;
}
.block-ctaBanner .cta-image img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-3);
}
.block-ctaBanner .cta-actions { margin-top: var(--sp-md); }

@media (max-width: 991px) {
  .block-ctaBanner .row { grid-template-columns: 1fr; }
  .block-ctaBanner { padding-block: var(--sp-lg); }
}

/* ============= articleList ============= */
.block-articleList { padding-block: var(--sp-lg); }
.block-articleList .articleList-title {
  font-size: var(--fs-h1);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 var(--sp-sm);
}
.block-articleList .articleList-lead {
  font-size: var(--fs-lead);
  color: var(--color-text-mute);
  margin: 0 0 var(--sp-lg);
}
.block-articleList .articleList-grid {
  display: flex;
  flex-direction: column;
  gap: var(--sp-lg);
}
.block-articleList .block-articleCard {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--sp-md);
  align-items: start;
  background: var(--color-white);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-1);
  overflow: hidden;
  transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.block-articleList .block-articleCard:hover {
  box-shadow: var(--shadow-2);
  transform: translateY(-2px);
}
.block-articleList .block-articleCard .articleCard-image {
  display: block;
  height: 200px;
  overflow: hidden;
}
.block-articleList .block-articleCard .articleCard-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.block-articleList .block-articleCard .articleCard-category,
.block-articleList .block-articleCard .articleCard-title,
.block-articleList .block-articleCard .articleCard-excerpt {
  padding-inline: var(--sp-md);
}
.block-articleList .block-articleCard .articleCard-category { padding-top: var(--sp-md); }
.block-articleList .block-articleCard .articleCard-excerpt { padding-bottom: var(--sp-md); }
@media (max-width: 767px) {
  .block-articleList .block-articleCard { grid-template-columns: 1fr; }
  .block-articleList .block-articleCard .articleCard-image { height: 180px; }
}

/* Variant: grid — articleList cards laid out in a 3-column grid with
   the standard image-on-top articleCard layout (used by /magazine hub). */
.block-articleList.is-variant-grid .articleList-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-lg);
}
.block-articleList.is-variant-grid .block-articleCard {
  display: flex;
  flex-direction: column;
  grid-template-columns: none;
  padding: 0;
}
.block-articleList.is-variant-grid .block-articleCard .articleCard-image {
  height: 200px;
}
.block-articleList.is-variant-grid .block-articleCard .articleCard-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.block-articleList.is-variant-grid .block-articleCard .articleCard-category,
.block-articleList.is-variant-grid .block-articleCard .articleCard-title,
.block-articleList.is-variant-grid .block-articleCard .articleCard-excerpt {
  padding-inline: 18px;
}
.block-articleList.is-variant-grid .block-articleCard .articleCard-category {
  margin: 18px 0 0;
  padding-top: 0;
}
.block-articleList.is-variant-grid .block-articleCard .articleCard-title {
  margin: 8px 0 12px;
  font-size: var(--fs-h4, var(--fs-h3));
  line-height: 1.3;
}
.block-articleList.is-variant-grid .block-articleCard .articleCard-excerpt {
  padding-bottom: 18px;
}
@media (max-width: 991px) {
  .block-articleList.is-variant-grid .articleList-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 600px) {
  .block-articleList.is-variant-grid .articleList-grid {
    grid-template-columns: 1fr;
  }
  .block-articleList.is-variant-grid .block-articleCard .articleCard-image {
    height: 180px;
  }
}

/* Variant: featured — single hero card spanning the full grid row,
   image on the left, larger title and lead on the right. */
.block-articleCard.is-variant-featured {
  display: grid;
  grid-template-columns: minmax(280px, 1.2fr) minmax(0, 1fr);
  gap: 0;
  background: linear-gradient(135deg, var(--color-bg-alt), var(--color-white));
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-2);
  align-items: stretch;
}
.block-articleCard.is-variant-featured .articleCard-image {
  height: 100%;
  min-height: 320px;
}
.block-articleCard.is-variant-featured .articleCard-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
}
.block-articleCard.is-variant-featured:hover .articleCard-image img {
  transform: scale(1.04);
}
.block-articleCard.is-variant-featured .articleCard-category {
  margin: var(--sp-lg) var(--sp-lg) 0;
  padding: 0;
}
.block-articleCard.is-variant-featured .articleCard-title {
  margin: var(--sp-sm) var(--sp-lg) var(--sp-sm);
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  line-height: 1.2;
  letter-spacing: -0.015em;
}
.block-articleCard.is-variant-featured .articleCard-excerpt {
  margin: 0 var(--sp-lg) var(--sp-lg);
  font-size: var(--fs-base);
  line-height: 1.6;
}
.block-articleList .block-articleCard.is-variant-featured {
  display: grid;
  grid-template-columns: minmax(280px, 1.2fr) minmax(0, 1fr);
  padding: 0;
}
.block-articleList .block-articleCard.is-variant-featured .articleCard-image {
  height: 100%;
  min-height: 320px;
}
@media (max-width: 767px) {
  .block-articleCard.is-variant-featured,
  .block-articleList .block-articleCard.is-variant-featured {
    grid-template-columns: 1fr;
  }
  .block-articleCard.is-variant-featured .articleCard-image,
  .block-articleList .block-articleCard.is-variant-featured .articleCard-image {
    min-height: 220px;
    height: 220px;
  }
}

/* ============= featureGrid ============= */
.block-featureGrid { padding-block: var(--sp-xl); }
.block-featureGrid .featureGrid-title {
  font-size: var(--fs-h2);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 var(--sp-sm);
}
.block-featureGrid .featureGrid-lead {
  font-size: var(--fs-lead);
  color: var(--color-text-mute);
  max-width: 640px;
  margin: 0 0 var(--sp-xl);
}
.block-featureGrid .featureGrid-inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-md);
}
.block-featureGrid .featureGrid-item {
  padding: var(--sp-md) var(--sp-md) var(--sp-md) calc(var(--sp-md) + 4px);
  border-left: 4px solid var(--color-primary);
  background: var(--color-white);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  box-shadow: var(--shadow-1);
  transition: box-shadow var(--dur-base) var(--ease-out);
}
.block-featureGrid .featureGrid-item:hover { box-shadow: var(--shadow-2); }
.block-featureGrid .featureGrid-item-title {
  font-size: var(--fs-md);
  font-weight: 700;
  color: var(--color-heading);
  margin: 0 0 8px;
}
.block-featureGrid .featureGrid-item-desc {
  font-size: var(--fs-sm);
  color: var(--color-text-mute);
  margin: 0;
  line-height: 1.6;
}
@media (max-width: 767px) {
  .block-featureGrid .featureGrid-inner { grid-template-columns: 1fr; }
}

/* ============= manifestoStack ============= */
.block-manifestoStack { padding-block: var(--sp-xl); }
.block-manifestoStack .manifestoStack-heading {
  font-size: var(--fs-h2);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 var(--sp-xl);
}
.block-manifestoStack .manifestoStack-inner {
  display: flex;
  flex-direction: column;
  gap: var(--sp-lg);
  max-width: 800px;
}
.block-manifestoStack .manifestoStack-item {
  font-size: clamp(1.2rem, 2.5vw, 1.55rem);
  font-weight: 600;
  font-style: italic;
  line-height: 1.45;
  color: var(--color-heading);
  position: relative;
  padding-left: var(--sp-lg);
  margin: 0;
}
.block-manifestoStack .manifestoStack-item::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-style: normal;
}
.block-manifestoStack .manifestoStack-item strong { color: var(--color-primary); font-style: normal; }

/* ============= pillarsGrid ============= */
.block-pillarsGrid { padding-block: var(--sp-xl); }
.block-pillarsGrid .pillarsGrid-title {
  font-size: var(--fs-h2);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 var(--sp-sm);
}
.block-pillarsGrid .pillarsGrid-lead {
  font-size: var(--fs-lead);
  color: var(--color-text-mute);
  max-width: 640px;
  margin: 0 0 var(--sp-xl);
}
.block-pillarsGrid .pillarsGrid-inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-md);
}
.block-pillarsGrid .pillarsGrid-item {
  background: var(--color-white);
  border: 1px solid var(--color-border-soft);
  border-top: 4px solid var(--color-primary);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  padding: var(--sp-md);
  box-shadow: var(--shadow-1);
  transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.block-pillarsGrid .pillarsGrid-item:hover {
  box-shadow: var(--shadow-2);
  transform: translateY(-2px);
}
.block-pillarsGrid .pillarsGrid-item-title {
  font-size: var(--fs-md);
  font-weight: 700;
  color: var(--color-primary);
  margin: 0 0 var(--sp-sm);
}
.block-pillarsGrid .pillarsGrid-item-desc {
  font-size: var(--fs-sm);
  color: var(--color-text-mute);
  margin: 0;
  line-height: 1.6;
}
@media (max-width: 767px) {
  .block-pillarsGrid .pillarsGrid-inner { grid-template-columns: 1fr; }
}
