/*
Theme Name: Passage Piétons (Kadence Child)
Template: kadence
Version: 1.0.0
Text Domain: pp-child
Description: Child theme — design News Portal Éditorial (issue #173).
*/

:root {
  /* === tokens COMPLETS du thème news-portal-editorial (échelle typo fluide, filets, couleurs) === */
  --ink: #0a0a0a;
  --ink-soft: #1a1a1a;
  --paper: #fafaf5;
  --paper-raised: #ffffff;
  --paper-tint: #f3f1e8;
  --rule: #0a0a0a;
  --rule-faint: #d4d4cf;
  --muted: #6b6b66;
  --accent: #a8242f;
  --accent-soft: #f5e8ea;
  --highlight: #fff9e6;

  --font-display: 'Playfair Display', 'Crimson Pro', Georgia, serif;
  --font-body: 'Source Sans 3', 'Inter', -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  --step--2: 0.72rem;
  --step--1: 0.82rem;
  --step-0: 1rem;
  --step-1: 1.18rem;
  --step-2: 1.42rem;
  --step-3: 1.75rem;
  --step-4: 2.25rem;
  --step-5: 2.9rem;
  --step-6: 3.8rem;
  --step-7: 5rem;

  --gutter: 2rem;
  --rule-thick: 3px;
  --rule-medium: 2px;
  --rule-thin: 1px;

  --content-width: 1280px;
  --article-width: 680px;
  --article-with-sidebar: 1100px;

  /* alias des var() sémantiques de prose.css -> tokens du :root news-portal */
  --color-text-primary: var(--ink);
  --color-text-secondary: var(--ink-soft);
  --color-text-muted: var(--muted);
  --color-primary: var(--accent);
  --color-primary-dim: #8a1d27;
  --color-primary-light: #c4424d;
  --color-secondary: var(--ink-soft);
  --color-surface: var(--paper);
  --color-surface-raised: var(--paper-raised);
  --color-border: var(--rule-faint);
  --color-border-subtle: #e6e4dc;
  --color-void: var(--ink);
  --radius-card: 4px;
  --text-h3: var(--step-2);
  --text-body-lg: var(--step-1);
  /* override palette Kadence -> accent éditorial */
  --global-palette1: var(--accent);
  --global-palette2: #8a1d27;
  --global-palette3: var(--ink);
  --global-palette4: var(--ink-soft);
  --global-palette9: var(--paper);
}

body { font-family: var(--font-body); background: var(--paper); color: var(--ink); }
h1,h2,h3,h4,h5,h6,.entry-title,.site-title { font-family: var(--font-display); color: var(--ink); }
a { color: var(--accent); text-decoration: none; }
.entry-content a { text-decoration: underline; text-underline-offset: 2px; }
.entry-content { font-family: var(--font-body); }

/* ===== container haute spécificité ===== */
.masthead .container, .footer .container, .pp-home .container, .transition-block .container, .breadcrumb .container, .article-page .container {max-width: var(--content-width);
  margin: 0 auto;
  padding: 0 var(--gutter);}

/* ===== composants éditoriaux portés (prose.css + global.css) ===== */
.entry-content .key-takeaways {margin: 2rem 0 2.5rem;
  padding: 1.75rem 2rem;
  background: var(--paper-tint);
  border-top: var(--rule-thick) solid var(--accent);
  border-bottom: var(--rule-thin) solid var(--rule-faint);}
.entry-content .key-takeaways__label {font-family: var(--font-body);
  font-size: var(--step--2);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.75rem;}
.entry-content .key-takeaways h2 {font-family: var(--font-display);
  font-size: var(--step-2);
  font-weight: 700;
  font-style: italic;
  margin-bottom: 1rem;
  color: var(--ink);
  border: none;
  padding: 0;}
.entry-content .key-takeaways ul {list-style: none;
  padding: 0;
  margin: 0;}
.entry-content .key-takeaways li {padding: 0.5rem 0 0.5rem 1.75rem;
  position: relative;
  font-size: 1.05rem;
  line-height: 1.5;
  color: var(--ink);
  border-bottom: var(--rule-thin) solid var(--rule-faint);}
.entry-content .key-takeaways li:last-child {border-bottom: none;}
.entry-content .key-takeaways li::before {content: '▸';
  position: absolute;
  left: 0;
  top: 0.5rem;
  color: var(--accent);
  font-weight: 700;}
.entry-content .key-takeaways li strong {font-family: var(--font-display);
  font-weight: 700;
  color: var(--ink);}
.entry-content .share-buttons {display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin: 2.5rem 0 1.5rem;
  padding: 1.25rem 0;
  border-top: var(--rule-thin) solid var(--rule-faint);
  border-bottom: var(--rule-thin) solid var(--rule-faint);}
.entry-content .share-buttons__label {font-family: var(--font-body);
  font-size: var(--step--2);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-right: 0.5rem;}
.entry-content .share-btn {display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.45rem 0.85rem;
  border: var(--rule-thin) solid var(--ink);
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--step--1);
  font-weight: 600;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;}
.entry-content .share-btn:hover {background: var(--ink);
  color: var(--paper);}
.entry-content .share-btn svg {width: 14px;
  height: 14px;
  fill: currentColor;}
.entry-content {font-size: 1.15rem; line-height: 1.65; color: var(--ink-soft);}
.entry-content > p:first-of-type::first-letter {font-family: var(--font-display);
  font-size: 4.5rem;
  font-weight: 900;
  float: left;
  line-height: 0.85;
  margin: 0.3rem 0.6rem 0 0;
  color: var(--ink);}
.entry-content h2 {font-size: var(--step-3);
  margin: 2.5rem 0 1rem;
  padding-top: 1rem;
  border-top: var(--rule-thin) solid var(--ink);
  scroll-margin-top: 2rem;}
.entry-content h3 {font-size: var(--step-2); margin: 2rem 0 0.75rem;}
.entry-content p {margin: 0 0 1.25rem;}
.entry-content a {color: var(--ink); border-bottom: var(--rule-thin) solid var(--accent); transition: background 0.15s;}
.entry-content a:hover {background: var(--accent-soft);}
.entry-content blockquote {margin: 2rem 0;
  padding: 1rem 0 1rem 1.5rem;
  border-left: var(--rule-thick) solid var(--accent);
  font-family: var(--font-display);
  font-size: var(--step-3);
  line-height: 1.3;
  font-style: italic;
  color: var(--ink);
  font-weight: 500;}
.entry-content blockquote cite {display: block;
  font-family: var(--font-body);
  font-size: var(--step--1);
  font-style: normal;
  color: var(--muted);
  margin-top: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.04em;}
.entry-content ul, .entry-content ol {padding-left: 1.5rem; margin: 0 0 1.5rem;}
.entry-content li {margin-bottom: 0.4rem;}
.entry-content .inline-tool {margin: 2.5rem 0;
  border: var(--rule-medium) solid var(--ink);
  background: var(--paper-raised);}
.entry-content .inline-tool__header {padding: 0.75rem 1.25rem;
  background: var(--ink);
  color: var(--paper);
  display: flex;
  align-items: baseline;
  gap: 1rem;}
.entry-content .inline-tool__type {font-family: var(--font-body);
  font-size: var(--step--2);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);}
.entry-content .inline-tool__title {font-family: var(--font-display);
  font-style: italic;
  font-weight: 700;
  font-size: var(--step-1);}
.entry-content .inline-tool__body {padding: 1.75rem;}
.entry-content .inline-tool__body .question {font-family: var(--font-display);
  font-size: var(--step-2);
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 1rem;
  color: var(--ink);}
.entry-content .inline-tool__body .options {display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;}
.entry-content .inline-tool__body .option {padding: 1rem;
  border: var(--rule-thin) solid var(--rule-faint);
  background: var(--paper);
  cursor: pointer;
  font-family: var(--font-body);
  font-size: var(--step-0);
  font-weight: 500;
  text-align: left;
  transition: all 0.15s;}
.entry-content .inline-tool__body .option:hover {border-color: var(--accent);
  background: var(--accent-soft);}
.entry-content .inline-tool__footer {padding: 0.75rem 1.25rem;
  border-top: var(--rule-thin) solid var(--rule-faint);
  font-size: var(--step--2);
  color: var(--muted);
  text-align: center;
  font-style: italic;}
.entry-content .faq-block {margin: 3rem 0 0;
  padding-top: 2rem;
  border-top: var(--rule-thick) solid var(--ink);}
.entry-content .faq-block h2 {font-size: var(--step-3);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin-bottom: 2rem;}
.entry-content .faq-block details {border-bottom: var(--rule-thin) solid var(--rule-faint); padding: 1rem 0;}
.entry-content .faq-block summary {font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--step-1);
  cursor: pointer;
  list-style: none;
  position: relative;
  padding-right: 2rem;
  color: var(--ink);}
.entry-content .faq-block summary::-webkit-details-marker {display: none;}
.entry-content .faq-block summary::after {content: '+';
  position: absolute;
  right: 0;
  font-family: var(--font-body);
  font-size: var(--step-3);
  font-weight: 300;
  color: var(--accent);
  line-height: 1;}
.entry-content .faq-block details[open] summary::after {content: '−';}
.entry-content .faq-block details p {margin-top: 1rem; font-size: var(--step-0); line-height: 1.6; color: var(--ink-soft);}
@media (max-width: 640px) {
  .entry-content {font-size: 1.05rem;}
  .entry-content .inline-tool__body .options {grid-template-columns: 1fr;}
}
.entry-content .quiz-cta {position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.25s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.25s ease;
  animation: quiz-cta-entry 0.6s cubic-bezier(0.22, 1, 0.36, 1) both,
             quiz-cta-breathe 4s ease-in-out 1.5s infinite;
  box-shadow: 0 1px 0 rgba(0,0,0,0.02), 0 4px 12px rgba(0,0,0,0.04);}
.entry-content .quiz-cta::before {content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    110deg,
    transparent 0%,
    transparent 40%,
    color-mix(in srgb, var(--accent, #a8242f) 18%, transparent) 50%,
    transparent 60%,
    transparent 100%
  );
  background-size: 250% 100%;
  background-position: -50% 0;
  pointer-events: none;
  animation: quiz-cta-shine 7s cubic-bezier(0.22, 1, 0.36, 1) 2s infinite;
  mix-blend-mode: multiply;}
.entry-content .quiz-cta::after {content: '';
  position: absolute;
  top: -40%; right: -20%;
  width: 180px; height: 180px;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent, #a8242f) 22%, transparent), transparent 70%);
  pointer-events: none;
  animation: quiz-cta-pulse 3s ease-in-out infinite;}
.entry-content .quiz-cta:hover {transform: translateY(-3px);
  box-shadow: 0 1px 0 rgba(0,0,0,0.02), 0 10px 28px rgba(0,0,0,0.08);
  animation-play-state: paused;}
.entry-content .quiz-cta:hover::before {animation-duration: 1.5s;}
.entry-content .quiz-cta__link {display: block;
  color: inherit;
  text-decoration: none;
  position: relative;
  z-index: 1;}
.entry-content .quiz-cta .quiz-cta__title {font-family: var(--font-display, var(--font-body, serif));
  font-size: clamp(1.25rem, 1.8vw, 1.7rem);
  font-weight: 700;
  line-height: 1.15;
  padding: 1.1rem 1.25rem 0.3rem;
  color: var(--ink, #0a0a0a);}
.entry-content .quiz-cta .quiz-cta__title::first-letter {font-weight: 800;}
.entry-content .quiz-cta .quiz-cta__lead {padding: 0 1.25rem 1rem;
  color: var(--muted, #6b6b66);
  font-size: 0.95rem;
  line-height: 1.45;
  margin: 0;}
.entry-content .quiz-cta .inline-tool__footer {display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.95rem 1.25rem;
  border-top: 1px solid var(--rule-faint, #e3e3dd);
  background: var(--paper-tint, var(--paper, #f8f8f8));
  position: relative;}
.entry-content .quiz-cta .inline-tool__footer::after {content: '';
  position: absolute;
  top: 0; left: 0;
  height: 3px;
  width: 0;
  background: var(--accent, currentColor);
  transition: width 0.35s cubic-bezier(0.22, 1, 0.36, 1);}
.entry-content .quiz-cta:hover .inline-tool__footer::after {width: 100%;}
.entry-content .quiz-cta__action {font-family: var(--font-body, sans-serif);
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent, currentColor);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: gap 0.25s ease, letter-spacing 0.25s ease;}
.entry-content .quiz-cta__action::before {content: '⚡';
  font-size: 1.1em;
  animation: quiz-cta-spark 2.4s ease-in-out infinite;}
.entry-content .quiz-cta:hover .quiz-cta__action {letter-spacing: 0.14em;}
.entry-content .quiz-cta__arrow {font-size: 1.35rem;
  color: var(--accent, currentColor);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent, #a8242f) 12%, transparent);
  transition: transform 0.25s ease, background 0.25s ease;
  animation: quiz-cta-bounce 1.6s cubic-bezier(0.4, 0, 0.6, 1) infinite;}
.entry-content .quiz-cta:hover .quiz-cta__arrow {background: var(--accent, #a8242f);
  color: var(--paper, #fff);
  transform: translateY(2px) scale(1.05);}
@media (prefers-reduced-motion: reduce) {
  .entry-content .quiz-cta, .entry-content .quiz-cta::before, .entry-content .quiz-cta::after, .entry-content .quiz-cta__arrow, .entry-content .quiz-cta__action::before {animation: none !important;}
}
.entry-content .quiz-panel {scroll-margin-top: 80px;
  margin: 3rem 0 2rem;
  padding: 0;
  background: var(--paper-tint, var(--paper, #f7f3e9));
  border: var(--rule-medium, 2px) solid var(--ink, #0a0a0a);
  border-radius: 2px;}
.entry-content .quiz-panel__inner {padding: 2rem 1.5rem 1.5rem;
  max-width: 720px;
  margin: 0 auto;}
.entry-content .quiz-panel__header {text-align: center;
  margin-bottom: 1.5rem;}
.entry-content .quiz-panel__label {display: inline-block;
  font-family: var(--font-body, sans-serif);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent, #0a0a0a);
  padding: 0.3rem 0.7rem;
  border: 1px solid var(--accent, #0a0a0a);
  border-radius: 2px;
  margin-bottom: 0.75rem;}
.entry-content .quiz-panel__title {font-family: var(--font-display, serif);
  font-size: clamp(1.5rem, 3vw, 2.3rem);
  font-weight: 800;
  line-height: 1.1;
  margin: 0 0 0.5rem;
  color: var(--ink, #0a0a0a);}
.entry-content .quiz-panel__intro {font-size: 1rem;
  color: var(--muted, #6b6b66);
  margin: 0;
  max-width: 560px;
  margin-inline: auto;}
.entry-content .quiz-panel__form {display: grid;
  gap: 1.25rem;}
.entry-content .quiz-panel__question {border: 1px solid var(--rule-faint, #dcdbd2);
  background: var(--paper-raised, #ffffff);
  padding: 1rem 1.25rem;
  border-radius: 2px;
  margin: 0;}
.entry-content .quiz-panel__legend {font-family: var(--font-display, serif);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--ink, #0a0a0a);
  line-height: 1.3;
  padding: 0 0.25rem;
  display: flex;
  align-items: baseline;
  gap: 0.6rem;}
.entry-content .quiz-panel__num {display: inline-flex;
  min-width: 2.2rem;
  padding: 0.15rem 0.5rem;
  font-family: var(--font-mono, monospace);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--paper, #fff);
  background: var(--accent, #0a0a0a);
  border-radius: 2px;
  align-items: center;
  justify-content: center;}
.entry-content .quiz-panel__answers {display: grid;
  gap: 0.5rem;
  margin-top: 0.85rem;}
.entry-content .quiz-panel__answer {display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.6rem 0.8rem;
  border: 1px solid var(--rule-faint, #dcdbd2);
  border-radius: 2px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  background: var(--paper, #fff);
  font-size: 0.95rem;}
.entry-content .quiz-panel__answer:hover {background: var(--paper-tint, #f7f3e9);
  border-color: var(--accent, #0a0a0a);}
.entry-content .quiz-panel__answer input[type="radio"] {accent-color: var(--accent, #0a0a0a);
  cursor: pointer;}
.entry-content .quiz-panel__answer:has(input:checked) {background: var(--accent-soft, rgba(168, 36, 47, 0.08));
  border-color: var(--accent, #0a0a0a);}
.entry-content .quiz-panel__footer {display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  margin-top: 0.5rem;}
.entry-content .quiz-panel__submit {font-family: var(--font-body, sans-serif);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--paper, #fff);
  background: var(--ink, #0a0a0a);
  border: none;
  padding: 0.95rem 2rem;
  cursor: pointer;
  transition: background 0.15s, transform 0.15s;
  border-radius: 2px;}
.entry-content .quiz-panel__submit:hover {background: var(--accent, #a8242f);
  transform: translateY(-1px);}
.entry-content .quiz-panel__legal {font-size: 0.78rem;
  color: var(--muted, #6b6b66);
  margin: 0;}
@media (max-width: 640px) {
  .entry-content .quiz-panel__inner {padding: 1.5rem 1rem;}
  .entry-content .quiz-panel__title {font-size: 1.4rem;}
  .entry-content .quiz-panel__question {padding: 0.8rem 1rem;}
}
.entry-content .inline-related-box {margin: 2rem 0;
  padding: 1.25rem 1.5rem;
  border-left: 3px solid var(--color-primary);
  background: color-mix(in oklch, var(--color-primary) 5%, var(--color-surface));
  border-radius: 0 0.5rem 0.5rem 0;}
.entry-content .inline-related-heading {font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  margin: 0 0 0.75rem;}
.entry-content .inline-related-links {display: flex;
  flex-direction: column;
  gap: 0.5rem;}
.entry-content .inline-related-link {display: flex;
  align-items: baseline;
  gap: 0.5rem;
  font-size: 0.9rem;
  line-height: 1.4;
  color: var(--color-primary);
  text-decoration: none;
  transition: color 0.15s;}
.entry-content .inline-related-link:hover {color: var(--color-primary-light);
  text-decoration: underline;}
.entry-content .inline-related-arrow {flex-shrink: 0;
  font-size: 0.75rem;
  opacity: 0.6;}
@media print {
  .entry-content .inline-related-box {display: none !important;}
}
