/* ============================================================
   Chat Gpt5 Mag — Industrial Vintage custom theme
   Parent: GeneratePress
   Hero style: manifesto | Header: burger-always
   ============================================================ */

/* ---- 1. ROOT VARIABLES ---- */
:root {
  --rp-primary:   #4A4A4A;
  --rp-primary-2: #6B6B6B;
  --rp-accent:    #B7410E;
  --rp-accent-2:  #8E3008;
  --rp-bg:        #C9B895;
  --rp-surface:   #E8D9C4;
  --rp-text:      #2A2A2A;
  --rp-text-soft: #5A4A3A;
  --rp-line:      #8B8070;
  --rp-paper:     #F1E6D2;

  --rp-font-head: "Oswald", "Impact", "Arial Narrow", sans-serif;
  --rp-font-body: "Roboto Slab", Georgia, "Times New Roman", serif;
  --rp-font-mono: "IBM Plex Mono", Menlo, Consolas, monospace;

  --rp-radius-sm: 4px;
  --rp-radius:    8px;
  --rp-radius-lg: 14px;

  --rp-shadow-1: 0 2px 8px rgba(0,0,0,0.10);
  --rp-shadow-2: 0 8px 24px rgba(0,0,0,0.18);
  --rp-shadow-rust: 0 6px 20px rgba(183,65,14,0.28);

  --rp-container: 1240px;
  --rp-gutter: clamp(16px, 3vw, 36px);
}

/* ---- 2. BASE OVERRIDES ---- */
html { scroll-behavior: smooth; }
body.rp-body {
  background: var(--rp-bg);
  color: var(--rp-text);
  font-family: var(--rp-font-body);
  font-size: 17px;
  line-height: 1.65;
  margin: 0;
}
body.rp-body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(rgba(0,0,0,0.04) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,0.03) 1px, transparent 1px);
  background-size: 4px 4px, 9px 9px;
  background-position: 0 0, 2px 2px;
  opacity: .6;
  z-index: 0;
}
.rp-main, .rp-header, .rp-footer { position: relative; z-index: 1; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--rp-font-head);
  font-weight: 700;
  color: var(--rp-text);
  letter-spacing: .01em;
  line-height: 1.15;
  text-transform: uppercase;
  margin: 0 0 .6em;
}
h1 { font-size: clamp(2.4rem, 5.2vw, 4.2rem); letter-spacing: .02em; }
h2 { font-size: clamp(1.8rem, 3.4vw, 2.6rem); }
h3 { font-size: clamp(1.4rem, 2.4vw, 1.8rem); }
h4 { font-size: 1.25rem; }

a {
  color: var(--rp-accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color .2s, border-color .2s;
}
a:hover { color: var(--rp-accent-2); border-bottom-color: currentColor; }

p { margin: 0 0 1.1em; }
img { max-width: 100%; height: auto; display: block; }

.rp-container { width: 100%; max-width: var(--rp-container); margin: 0 auto; padding: 0 var(--rp-gutter); }

/* ---- 3. BUTTONS ---- */
.rp-btn {
  display: inline-block;
  font-family: var(--rp-font-head);
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .95rem;
  padding: 14px 28px;
  border: 2px solid var(--rp-text);
  background: var(--rp-surface);
  color: var(--rp-text);
  border-radius: var(--rp-radius-sm);
  cursor: pointer;
  transition: transform .2s, background .2s, color .2s, box-shadow .2s;
  text-decoration: none;
  line-height: 1.2;
}
.rp-btn:hover { background: var(--rp-text); color: var(--rp-paper); transform: translateY(-1px); }

.rp-btn--cta {
  background: var(--rp-accent);
  color: #fff;
  border-color: var(--rp-accent-2);
  box-shadow: var(--rp-shadow-rust);
}
.rp-btn--cta:hover { background: var(--rp-accent-2); color: #fff; }
.rp-btn--ghost {
  background: transparent;
  border-color: var(--rp-text);
  color: var(--rp-text);
}
.rp-btn--ghost:hover { background: var(--rp-text); color: var(--rp-paper); }

/* ---- 4. HEADER (burger-always) ---- */
.rp-header {
  background: var(--rp-paper);
  border-bottom: 4px double var(--rp-text);
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: var(--rp-shadow-1);
}
.rp-header__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 78px;
  width: 100%;
  max-width: var(--rp-container);
  margin: 0 auto;
  padding: 0 var(--rp-gutter);
  gap: 16px;
}
.rp-header__brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--rp-text);
  border-bottom: none;
}
.rp-header__brand:hover { color: var(--rp-accent); border-bottom: none; }
.rp-header__logo {
  width: 48px; height: 48px;
  border-radius: var(--rp-radius-sm);
  display: block;
}
.rp-header__title {
  font-family: var(--rp-font-head);
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1;
}
.rp-header__tagline {
  display: block;
  font-family: var(--rp-font-body);
  font-style: italic;
  font-weight: 300;
  font-size: .78rem;
  color: var(--rp-text-soft);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-top: 4px;
}
.rp-header__actions {
  display: flex;
  align-items: center;
  gap: 14px;
}
.rp-header__cta {
  display: none;
}
@media (min-width: 720px) {
  .rp-header__cta { display: inline-block; }
}
.rp-header__burger {
  width: 52px;
  height: 52px;
  background: var(--rp-text);
  border: 2px solid var(--rp-text);
  border-radius: var(--rp-radius-sm);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  padding: 0;
  transition: background .2s;
}
.rp-header__burger:hover { background: var(--rp-accent); border-color: var(--rp-accent); }
.rp-header__burger span {
  display: block;
  width: 26px;
  height: 3px;
  background: var(--rp-paper);
  border-radius: 1px;
}
.rp-header__burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(9px) rotate(45deg); transition: transform .25s; }
.rp-header__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; transition: opacity .15s; }
.rp-header__burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); transition: transform .25s; }
.rp-header__burger span { transition: transform .25s, opacity .15s; }

.rp-nav-drawer {
  position: fixed;
  top: 0; right: 0;
  width: min(420px, 88vw);
  height: 100vh;
  background: var(--rp-paper);
  border-left: 6px double var(--rp-text);
  padding: 96px 32px 48px;
  z-index: 200;
  transform: translateX(100%);
  transition: transform .35s cubic-bezier(.4,0,.2,1);
  overflow-y: auto;
}
.rp-nav-drawer.is-open { transform: translateX(0); }
.rp-nav-drawer__close {
  position: absolute;
  top: 18px; right: 18px;
  width: 44px; height: 44px;
  background: var(--rp-text);
  color: var(--rp-paper);
  border: 0;
  border-radius: var(--rp-radius-sm);
  cursor: pointer;
  font-size: 1.4rem;
  line-height: 1;
}
.rp-nav-drawer .rp-nav-list,
.rp-nav-drawer ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.rp-nav-drawer .rp-nav-list li { border-bottom: 1px solid var(--rp-line); }
.rp-nav-drawer .rp-nav-list a {
  display: block;
  padding: 14px 4px;
  font-family: var(--rp-font-head);
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--rp-text);
  border-bottom: none;
}
.rp-nav-drawer .rp-nav-list a:hover { color: var(--rp-accent); }

.rp-nav-overlay {
  position: fixed;
  inset: 0;
  background: rgba(42,42,42,.55);
  z-index: 150;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
.rp-nav-overlay.is-open { opacity: 1; pointer-events: auto; }

/* ---- 5. HERO (manifesto style — no image) ---- */
.rp-hero--manifesto {
  padding: clamp(60px, 9vw, 130px) 0;
  background:
    linear-gradient(180deg, var(--rp-paper) 0%, var(--rp-surface) 100%),
    repeating-linear-gradient(45deg, transparent 0 12px, rgba(0,0,0,0.02) 12px 24px);
  border-bottom: 4px double var(--rp-text);
  position: relative;
}
.rp-hero--manifesto::before {
  content: "";
  position: absolute;
  inset: 24px;
  border: 2px solid var(--rp-text);
  pointer-events: none;
  opacity: .35;
}
.rp-hero__inner {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 var(--rp-gutter);
  text-align: center;
  position: relative;
}
.rp-hero__eyebrow {
  display: inline-block;
  font-family: var(--rp-font-mono);
  font-size: .85rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--rp-accent);
  background: var(--rp-text);
  padding: 8px 18px;
  border-radius: 999px;
  margin-bottom: 28px;
}
.rp-hero__title {
  font-size: clamp(2.6rem, 7.2vw, 5.6rem);
  line-height: 1.02;
  letter-spacing: .015em;
  text-transform: uppercase;
  font-weight: 700;
  margin: 0 0 .35em;
}
.rp-hero__title em {
  font-style: normal;
  color: var(--rp-accent);
  position: relative;
}
.rp-hero__title em::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: 4px;
  height: 8px;
  background: rgba(183,65,14,0.22);
  z-index: -1;
}
.rp-hero__lede {
  font-family: var(--rp-font-body);
  font-size: clamp(1.05rem, 1.8vw, 1.3rem);
  color: var(--rp-text-soft);
  max-width: 760px;
  margin: 1.4em auto 2em;
  line-height: 1.65;
}
.rp-hero__signature {
  font-family: var(--rp-font-mono);
  font-size: .85rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--rp-text);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 16px;
}
.rp-hero__signature::before,
.rp-hero__signature::after {
  content: "";
  display: inline-block;
  width: 40px;
  height: 1px;
  background: var(--rp-text);
}
.rp-hero__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
  margin-top: 14px;
}

/* ---- 6. CATEGORIES GRID ---- */
.rp-section {
  padding: clamp(48px, 7vw, 96px) 0;
}
.rp-section--alt { background: var(--rp-surface); }
.rp-section__head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 36px;
  flex-wrap: wrap;
}
.rp-section__title {
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  margin: 0;
  position: relative;
  padding-bottom: 16px;
}
.rp-section__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 72px;
  height: 4px;
  background: var(--rp-accent);
}
.rp-section__lede {
  color: var(--rp-text-soft);
  max-width: 480px;
  margin: 0;
}

.rp-categories-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: clamp(16px, 2vw, 24px);
}
.rp-cat-card {
  position: relative;
  display: block;
  text-decoration: none;
  color: var(--rp-paper);
  border-radius: var(--rp-radius);
  overflow: hidden;
  aspect-ratio: 4/5;
  background: var(--rp-text);
  box-shadow: var(--rp-shadow-1);
  border: 2px solid var(--rp-text);
  transition: transform .25s, box-shadow .25s, border-color .25s;
}
.rp-cat-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--rp-shadow-2);
  border-color: var(--rp-accent);
}
.rp-cat-card__img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(.35) contrast(1.1) sepia(.18);
  transition: filter .35s, transform .35s;
}
.rp-cat-card:hover .rp-cat-card__img { filter: grayscale(0) contrast(1.05); transform: scale(1.05); }
.rp-cat-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(42,42,42,0.15) 0%, rgba(42,42,42,0.85) 100%);
}
.rp-cat-card__body {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px 22px;
}
.rp-cat-card__label {
  font-family: var(--rp-font-mono);
  font-size: .75rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--rp-accent);
  margin-bottom: 6px;
}
.rp-cat-card__name {
  font-family: var(--rp-font-head);
  font-size: 1.6rem;
  text-transform: uppercase;
  letter-spacing: .03em;
  line-height: 1.1;
  color: var(--rp-paper);
  margin: 0;
}

/* ---- 7. ARTICLE CARDS ---- */
.rp-articles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: clamp(20px, 2.5vw, 32px);
}
.rp-card {
  background: var(--rp-paper);
  border: 2px solid var(--rp-text);
  border-radius: var(--rp-radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .25s, box-shadow .25s;
  box-shadow: var(--rp-shadow-1);
}
.rp-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--rp-shadow-2);
}
.rp-card__media {
  aspect-ratio: 16/9;
  background: var(--rp-text);
  overflow: hidden;
  border-bottom: 2px solid var(--rp-text);
}
.rp-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: contrast(1.05) saturate(.95);
  transition: transform .35s;
}
.rp-card:hover .rp-card__media img { transform: scale(1.04); }
.rp-card__body { padding: 22px; flex-grow: 1; display: flex; flex-direction: column; }
.rp-card__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--rp-font-mono);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--rp-text-soft);
  margin-bottom: 12px;
}
.rp-card__cat {
  background: var(--rp-text);
  color: var(--rp-paper);
  padding: 4px 10px;
  border-radius: 2px;
  text-decoration: none;
}
.rp-card__cat:hover { background: var(--rp-accent); color: #fff; border-bottom: none; }
.rp-card__title {
  font-size: 1.4rem;
  line-height: 1.2;
  margin: 0 0 .5em;
  text-transform: none;
  font-weight: 600;
}
.rp-card__title a { color: var(--rp-text); border-bottom: none; }
.rp-card__title a:hover { color: var(--rp-accent); }
.rp-card__excerpt {
  color: var(--rp-text-soft);
  font-size: .98rem;
  line-height: 1.6;
  flex-grow: 1;
}
.rp-card__more {
  margin-top: 16px;
  font-family: var(--rp-font-head);
  font-size: .85rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--rp-accent);
  text-decoration: none;
  border-bottom: 2px solid var(--rp-accent);
  display: inline-block;
  align-self: flex-start;
  padding-bottom: 2px;
}
.rp-card__more:hover { color: var(--rp-accent-2); border-color: var(--rp-accent-2); }

/* ---- 8. NEWSLETTER STRIP ---- */
.rp-newsletter {
  background: var(--rp-text);
  color: var(--rp-paper);
  padding: clamp(48px, 6vw, 80px) 0;
}
.rp-newsletter__inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 var(--rp-gutter);
  text-align: center;
}
.rp-newsletter__eyebrow {
  font-family: var(--rp-font-mono);
  font-size: .8rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--rp-accent);
  margin-bottom: 12px;
  display: block;
}
.rp-newsletter__title {
  color: var(--rp-paper);
  margin-bottom: 14px;
}
.rp-newsletter__lede { color: rgba(241,230,210,0.8); margin-bottom: 24px; }
.rp-newsletter form {
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}
.rp-newsletter input[type=email] {
  font-family: var(--rp-font-body);
  font-size: 1rem;
  padding: 14px 18px;
  border: 2px solid var(--rp-paper);
  background: var(--rp-paper);
  color: var(--rp-text);
  border-radius: var(--rp-radius-sm);
  min-width: 280px;
}
.rp-newsletter input[type=email]:focus { outline: 3px solid var(--rp-accent); }

/* ---- 9. FOOTER (warehouse_columns) ---- */
.rp-footer {
  background: var(--rp-text);
  color: var(--rp-paper);
  padding: 56px 0 28px;
  margin-top: 80px;
  border-top: 6px double var(--rp-accent);
}
.rp-footer__inner {
  max-width: var(--rp-container);
  margin: 0 auto;
  padding: 0 var(--rp-gutter);
}
.rp-footer__cols {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: clamp(20px, 3vw, 44px);
}
@media (max-width: 900px) { .rp-footer__cols { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .rp-footer__cols { grid-template-columns: 1fr; } }
.rp-footer h4 {
  font-family: var(--rp-font-head);
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--rp-paper);
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--rp-accent);
}
.rp-footer ul { list-style: none; margin: 0; padding: 0; }
.rp-footer li { margin-bottom: 10px; }
.rp-footer a {
  color: rgba(241,230,210,0.78);
  text-decoration: none;
  border-bottom: none;
  font-size: .95rem;
  transition: color .2s;
}
.rp-footer a:hover { color: var(--rp-accent); border-bottom: none; }
.rp-footer__brand-pitch {
  color: rgba(241,230,210,0.7);
  font-size: .95rem;
  line-height: 1.65;
  margin-bottom: 20px;
}
.rp-footer__brand-name {
  font-family: var(--rp-font-head);
  font-size: 1.5rem;
  text-transform: uppercase;
  color: var(--rp-paper);
  margin-bottom: 12px;
  display: block;
}
.rp-footer__cta {
  background: var(--rp-accent);
  color: #fff;
  padding: 12px 20px;
  font-family: var(--rp-font-head);
  font-size: .85rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  border-radius: var(--rp-radius-sm);
  display: inline-block;
}
.rp-footer__cta:hover { background: var(--rp-paper); color: var(--rp-text); }
.rp-footer__social {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}
.rp-footer__social a {
  width: 38px; height: 38px;
  border: 2px solid var(--rp-accent);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--rp-paper);
  font-family: var(--rp-font-mono);
  font-size: .8rem;
  font-weight: 700;
}
.rp-footer__social a:hover { background: var(--rp-accent); color: var(--rp-text); }
.rp-footer__bottom {
  margin-top: 40px;
  padding-top: 22px;
  border-top: 1px solid rgba(241,230,210,0.18);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-family: var(--rp-font-mono);
  font-size: .8rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(241,230,210,0.6);
}

/* ---- 10. CATEGORY / ARCHIVE PAGES ---- */
.rp-archive-head {
  padding: clamp(40px, 6vw, 72px) 0;
  background: var(--rp-surface);
  border-bottom: 4px double var(--rp-text);
}
.rp-archive-head__eyebrow {
  font-family: var(--rp-font-mono);
  font-size: .75rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--rp-accent);
  display: block;
  margin-bottom: 10px;
}
.rp-archive-head__title {
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  margin: 0 0 .4em;
}
.rp-archive-head__desc {
  max-width: 780px;
  color: var(--rp-text-soft);
  font-size: 1.05rem;
}

/* ---- 11. SINGLE POST ---- */
.rp-single {
  padding: clamp(40px, 6vw, 88px) 0;
  background: var(--rp-paper);
}
.rp-single__inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 var(--rp-gutter);
}
.rp-single h1 { font-size: clamp(2rem, 4vw, 3.2rem); text-transform: none; }
.rp-single p, .rp-single li { font-size: 1.08rem; line-height: 1.75; }
.rp-single blockquote {
  border-left: 4px solid var(--rp-accent);
  margin: 1.5em 0;
  padding: .25em 1.4em;
  font-style: italic;
  color: var(--rp-text-soft);
  background: var(--rp-surface);
}
.rp-single img { border-radius: var(--rp-radius); margin: 1.6em 0; }

/* ---- 12. TOOLS (forms, quizzes, calculators) ---- */
.rp-tool-quiz, .rp-tool-calc, .rp-tool-gen {
  background: var(--rp-paper);
  border: 2px solid var(--rp-text);
  border-radius: var(--rp-radius);
  padding: clamp(20px, 3vw, 40px);
  margin: 24px 0;
  box-shadow: var(--rp-shadow-1);
}
.rp-tool-quiz fieldset {
  border: 1px solid var(--rp-line);
  border-radius: var(--rp-radius-sm);
  padding: 16px 18px;
  margin-bottom: 18px;
  background: var(--rp-surface);
}
.rp-tool-quiz legend {
  font-family: var(--rp-font-head);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 1rem;
  padding: 0 8px;
  color: var(--rp-accent);
}
.rp-tool-quiz fieldset label,
.rp-tool-calc label,
.rp-tool-gen label {
  display: block;
  font-family: var(--rp-font-body);
  font-size: .98rem;
  margin: 8px 0;
  color: var(--rp-text);
  cursor: pointer;
}
.rp-tool-calc label,
.rp-tool-gen label {
  font-family: var(--rp-font-head);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: .85rem;
  color: var(--rp-text-soft);
  margin-top: 14px;
}
.rp-tool-calc input[type=number],
.rp-tool-calc select,
.rp-tool-gen input[type=text],
.rp-tool-gen select {
  display: block;
  width: 100%;
  margin-top: 6px;
  padding: 10px 14px;
  font-family: var(--rp-font-body);
  font-size: 1rem;
  border: 2px solid var(--rp-line);
  border-radius: var(--rp-radius-sm);
  background: #fff;
  color: var(--rp-text);
}
.rp-tool-calc input:focus,
.rp-tool-gen input:focus,
.rp-tool-calc select:focus,
.rp-tool-gen select:focus {
  outline: 3px solid var(--rp-accent);
  border-color: var(--rp-accent);
}
.rp-quiz-result, .rp-calc-result, .rp-gen-result {
  margin-top: 24px;
  padding: 22px 24px;
  background: var(--rp-text);
  color: var(--rp-paper);
  border-radius: var(--rp-radius-sm);
  border-left: 6px solid var(--rp-accent);
}
.rp-quiz-result h4, .rp-calc-result h4, .rp-gen-result h4 {
  color: var(--rp-accent);
  margin-bottom: 12px;
}
.rp-quiz-result ol, .rp-quiz-result ul,
.rp-calc-result ul, .rp-gen-list {
  list-style: square;
  padding-left: 22px;
  color: rgba(241,230,210,.92);
}
.rp-calc-total {
  font-family: var(--rp-font-head);
  font-size: 2.2rem;
  color: var(--rp-accent);
  margin-bottom: 12px;
}
.rp-gen-list a { color: var(--rp-paper); border-bottom: 1px dotted rgba(241,230,210,.4); }
.rp-gen-list a:hover { color: var(--rp-accent); }
.rp-calc-disclaimer, .rp-gen-tip {
  margin-top: 14px;
  font-size: .85rem;
  font-style: italic;
  color: rgba(241,230,210,.65);
}
.rp-quiz-err, .rp-gen-err {
  background: var(--rp-accent);
  color: #fff;
  padding: 12px 16px;
  border-radius: var(--rp-radius-sm);
  margin: 0;
}

/* ---- 13. ANIMATIONS — CTA shine_sweep ---- */
@keyframes rp-shine-sweep {
  0%   { transform: translateX(-120%) skewX(-20deg); opacity: 0; }
  20%  { opacity: 1; }
  60%  { opacity: 1; }
  100% { transform: translateX(220%) skewX(-20deg); opacity: 0; }
}
.rp-btn--cta {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.rp-btn--cta::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.45), transparent);
  pointer-events: none;
  animation: rp-shine-sweep 3.4s cubic-bezier(.4,0,.2,1) infinite;
  z-index: 2;
}
.rp-btn--cta:hover::after { animation-duration: 1.6s; }

/* ---- 14. ANIMATIONS — CTR testimonial_slider ---- */
@keyframes rp-slide-in-right {
  0%   { opacity: 0; transform: translateX(40px); }
  100% { opacity: 1; transform: translateX(0); }
}
@keyframes rp-slide-out-left {
  0%   { opacity: 1; transform: translateX(0); }
  100% { opacity: 0; transform: translateX(-40px); }
}
.rp-testimonial-slider {
  position: relative;
  min-height: 240px;
  background: var(--rp-surface);
  border: 2px solid var(--rp-text);
  border-radius: var(--rp-radius);
  padding: 32px 32px 56px;
  margin: 24px 0;
}
.rp-testimonial-slider .rp-testimonial {
  position: absolute;
  inset: 32px 32px 56px;
  opacity: 0;
  pointer-events: none;
  animation: rp-slide-out-left .5s ease forwards;
}
.rp-testimonial-slider .rp-testimonial.is-active {
  opacity: 1;
  pointer-events: auto;
  animation: rp-slide-in-right .55s cubic-bezier(.4,0,.2,1) forwards;
}
.rp-testimonial blockquote {
  font-family: var(--rp-font-body);
  font-size: 1.15rem;
  font-style: italic;
  margin: 0 0 16px;
  border-left: 0;
  padding: 0;
}
.rp-testimonial cite {
  font-family: var(--rp-font-mono);
  font-style: normal;
  font-size: .85rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--rp-accent);
}
.rp-testimonial-dots {
  position: absolute;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 10px;
}
.rp-testimonial-dots button {
  width: 12px; height: 12px;
  border-radius: 50%;
  border: 1px solid var(--rp-text);
  background: var(--rp-paper);
  cursor: pointer;
  padding: 0;
}
.rp-testimonial-dots button.is-active { background: var(--rp-accent); border-color: var(--rp-accent); }

/* ---- 15. ANIMATIONS — CTO floating_contact_card ---- */
@keyframes rp-float-pop {
  0%   { transform: translateY(20px) scale(.95); opacity: 0; }
  100% { transform: translateY(0)    scale(1);   opacity: 1; }
}
@keyframes rp-float-pulse {
  0%, 100% { box-shadow: 0 8px 24px rgba(0,0,0,0.18); }
  50%      { box-shadow: 0 12px 32px rgba(183,65,14,0.35); }
}
.rp-floating-contact {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 999;
  background: var(--rp-surface);
  color: var(--rp-text);
  border: 2px solid var(--rp-accent);
  border-radius: var(--rp-radius-lg);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  font-family: var(--rp-font-head);
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  animation: rp-float-pop .5s ease-out, rp-float-pulse 2.8s ease-in-out infinite;
  transition: transform .25s ease;
  border-bottom: 2px solid var(--rp-accent);
}
.rp-floating-contact:hover {
  transform: translateY(-3px) scale(1.03);
  color: var(--rp-text);
  border-bottom: 2px solid var(--rp-accent);
}
.rp-floating-contact-icon {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--rp-accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-family: var(--rp-font-mono);
}
@media (max-width: 600px) {
  .rp-floating-contact { right: 12px; bottom: 12px; padding: 10px 14px; font-size: .85rem; }
  .rp-floating-contact-icon { width: 26px; height: 26px; }
}

/* ---- 16. UTILITY ---- */
.rp-visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

/* ---- 17. RESPONSIVE ---- */
@media (max-width: 720px) {
  .rp-header__tagline { display: none; }
  .rp-header__title { font-size: 1.2rem; }
  .rp-section__head { flex-direction: column; align-items: flex-start; }
  .rp-hero--manifesto::before { inset: 12px; }
}
@media (max-width: 480px) {
  body.rp-body { font-size: 16px; }
  .rp-newsletter input[type=email] { min-width: 0; width: 100%; }
}


/* Validator: cap hauteur hero cat (override 240px max) */
.cat-hero, .rp-cat-hero { max-height: 240px !important; min-height: 180px !important; padding: 30px 0 !important; }
.cat-hero img, .rp-cat-hero img { max-width: 200px !important; max-height: 200px !important; object-fit: cover; }
.cat-hero[style*='background-image'], .rp-cat-hero[style*='background-image'] { background-size: cover !important; background-position: center !important; }


/* === RANKOPRESS v9 fixes (overrides finaux) === */

/* Cap hauteur hero categorie : trop grand par defaut quand pas d'image */
.rp-cat-hero {
    max-height: 280px !important;
    min-height: 180px !important;
    padding: 50px 0 !important;
    overflow: hidden;
}
.rp-cat-hero .rp-cat-hero-bg { display: none !important; }
/* Quand pas d'image, fond accent du design (cohesion visuelle) */
.rp-cat-hero:not(:has(img)) {
    background: linear-gradient(135deg, var(--rp-primary, #4A4A4A) 0%, var(--rp-accent, #B7410E) 100%) !important;
    color: #fff !important;
    text-align: center;
}
.rp-cat-hero:not(:has(img)) h1 { color: #fff !important; }
.rp-cat-hero:not(:has(img)) .rp-cat-tagline { color: rgba(255,255,255,0.85) !important; }
.rp-cat-hero:not(:has(img)) .rp-breadcrumb { color: rgba(255,255,255,0.7) !important; }
.rp-cat-hero:not(:has(img)) .rp-breadcrumb a { color: rgba(255,255,255,0.9) !important; }

/* Footer adaptatif : 4 cols par defaut, 5+ si Customizer remplit Liens utiles */
.rp-footer-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    gap: 32px !important;
}
