/* =========================================================
   IdeaFloat — Homepage Redesign
   Source: redesign/redesign.css from Claude Design bundle
   WordPress adaptation: body rules scoped to .rd-page
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@500;700&family=IBM+Plex+Mono:wght@400;500;700&display=swap');

* { box-sizing: border-box; }

/* =========================================================
   RESET base.css theme overrides inside .rd-page
   base.css forces: span{font-size:16px}, section{flex
   centered column}, main ul bullets, h1/h2 sizes, etc.
   Neutralise all of it so the redesign tokens take over.
   ========================================================= */
.rd-page section {
  display: block;
  flex-direction: initial;
  justify-content: initial;
  align-items: initial;
  overflow: visible;
}
/* spans inherit type from their parent (kills span{font-size:16px}) */
.rd-page .rd-h1 span,
.rd-page .rd-h1 em,
.rd-page .rd-chapter-head h2 span,
.rd-page .rd-dossier-head h2 span,
.rd-page .rd-tpl-head h2 span,
.rd-page .rd-tpl-get-copy h3 span,
.rd-page .rd-trust-head h2 span,
.rd-page .rd-chapter-body h3 span,
.rd-page .rd-film-head h3 em,
.rd-page .rd-cta h2 em,
.rd-page .rd-hero-sub .lead em {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}
/* remove theme list bullets / padding inside redesign lists */
.rd-page ul { padding: 0; margin: 0; list-style: none; }
.rd-page main ul > li:before,
.rd-page ul > li:before { content: none; display: none; }
.rd-page li { padding-left: 0; }
/* re-apply our own price feat bullets (were just cleared) */
.rd-page .rd-price-feats li { padding-left: 20px; }
.rd-page .rd-price-feats li::before {
  content: ""; display: block;
  position: absolute; left: 0; top: 6px; width: 7px; height: 7px;
  background: #3d61df; border-radius: 50%;
}
.rd-page .rd-price-feats li.lead { padding-left: 0; }
.rd-page .rd-price-feats li.lead::before { display: none; }

/* Scoped page background + cursor. Sticky editorial header
   (.rd-top, 64px) takes its own space — no padding hack needed. */
.rd-page {
  background: #fbfaf6;
  color: #151515;
  -webkit-font-smoothing: antialiased;
  cursor: none;
}
.rd-page a { color: inherit; text-decoration: none; }
.rd-page ::selection { background: #3d61df; color: #fff; }

/* ---------- Custom cursor ---------- */
.rd-cursor {
  position: fixed; top: 0; left: 0; pointer-events: none; z-index: 200;
  width: 14px; height: 14px; border-radius: 50%;
  background: #151515;
  mix-blend-mode: difference;
  transform: translate(-50%, -50%);
  transition: width .25s, height .25s, background .25s;
}
.rd-cursor.hover { width: 56px; height: 56px; background: #3d61df; mix-blend-mode: normal; }
.rd-cursor-label {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-family: Satoshi; font-weight: 900; font-size: 10px; letter-spacing: .12em;
  text-transform: uppercase; color: #fff; opacity: 0;
}
.rd-cursor.hover .rd-cursor-label { opacity: 1; }

/* ---------- Grid container ---------- */
.rd-shell {
  width: 100%;
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 56px;
  position: relative;
}
.rd-shell::before, .rd-shell::after {
  content: none;
}

/* ---------- Hero ---------- */
.rd-hero { padding: 100px 0 80px; position: relative; background: #fbfaf6; }

.rd-slug {
  display: flex; align-items: center; gap: 14px;
  font-family: Satoshi; font-weight: 700; font-size: 11px;
  letter-spacing: .2em; text-transform: uppercase; color: #6b7280;
  margin-bottom: 64px;
}
.rd-slug .rule { flex: 0 0 60px; height: 1px; background: #151515; }
.rd-slug .pulse { width: 8px; height: 8px; border-radius: 50%; background: #21dd90; animation: pulse 2.4s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.85)} }

.rd-h1 {
  font-family: Satoshi; font-weight: 900;
  font-size: clamp(64px, 11vw, 168px);
  line-height: .92;
  letter-spacing: -.05em;
  margin: 0;
  color: #151515;
}
.rd-h1 .rd-line { display: block; position: relative; }
.rd-h1 .rd-circled { display: inline-block; position: relative; color: #3d61df; }
.rd-h1 .rd-circled::before {
  content: "";
  position: absolute; left: -10%; top: -8%; right: -10%; bottom: -8%;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 80' preserveAspectRatio='none'><path d='M20,42 Q15,18 60,12 Q120,5 180,14 Q210,18 205,40 Q200,68 140,72 Q60,78 25,68 Q12,58 22,42' fill='none' stroke='%233d61df' stroke-width='3' stroke-linecap='round' stroke-dasharray='600' stroke-dashoffset='600'><animate attributeName='stroke-dashoffset' from='600' to='0' dur='1.6s' begin='0.6s' fill='freeze'/></path></svg>") no-repeat center / 100% 100%;
  pointer-events: none;
}

.rd-margin-note {
  position: absolute;
  font-family: 'Caveat', 'Bradley Hand', cursive;
  font-size: 22px; color: #e81c72; line-height: 1.2; max-width: 240px;
  transform: rotate(-4deg);
}
.rd-margin-note::before {
  content: ""; position: absolute;
  border-top: 1.5px solid #e81c72; border-right: 1.5px solid #e81c72;
}

.rd-hero-sub {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  margin-top: 56px; padding-top: 28px;
  border-top: 1px solid rgba(21,21,21,0.12);
}
.rd-hero-sub .lead {
  font-family: Satoshi; font-weight: 500; font-size: 22px; line-height: 1.4;
  color: #1f2937; max-width: 520px; margin: 0; letter-spacing: -.01em;
}
.rd-hero-sub .lead em { font-style: normal; color: #3d61df; font-weight: 700; }
.rd-hero-sub aside { display: flex; flex-direction: column; gap: 24px; align-items: flex-start; }

.rd-meta-row {
  font-family: 'IBM Plex Mono', ui-monospace, monospace;
  font-size: 11px; letter-spacing: .04em; color: #6b7280;
  display: flex; gap: 16px; flex-wrap: wrap;
}
.rd-meta-row span { display: inline-flex; align-items: center; gap: 6px; }
.rd-meta-row span::before { content: "—"; color: #9ca3af; }

.rd-meta-privacy {
  display: inline-flex; align-items: center; gap: 6px;
  color: #2f7a57; text-decoration: none;
  border-bottom: 1px solid rgba(33,221,144,0.45);
  padding-bottom: 1px;
  transition: color .2s var(--ease, ease), border-color .2s var(--ease, ease);
}
.rd-meta-privacy svg { width: 13px; height: 13px; flex: none; color: #10b981; }
.rd-meta-privacy:hover { color: #151515; border-color: #21dd90; }

.rd-hero-cta {
  display: inline-flex; align-items: baseline; gap: 16px;
  font-family: Satoshi; font-weight: 900; font-size: 22px;
  color: #151515; padding: 22px 0; border-top: 1px solid #151515; border-bottom: 1px solid #151515;
  width: 100%; justify-content: space-between; max-width: 420px;
  transition: padding .3s ease; cursor: none; text-decoration: none;
}
.rd-hero-cta:hover { padding-left: 12px; padding-right: 0; color: #3d61df; }
.rd-hero-cta .arrow { font-family: Satoshi; font-weight: 500; font-size: 28px; transition: transform .3s ease; }
.rd-hero-cta:hover .arrow { transform: translateX(8px); color: #3d61df; }

/* ---------- Marquee ---------- */
.rd-marquee {
  margin: 80px 0 0;
  border-top: 1px solid rgba(21,21,21,0.12);
  border-bottom: 1px solid rgba(21,21,21,0.12);
  overflow: hidden; padding: 18px 0;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}
.rd-marquee-track {
  display: flex; gap: 56px; white-space: nowrap;
  animation: marquee 48s linear infinite;
  font-family: Satoshi; font-weight: 500; font-style: italic;
  font-size: 17px; color: #4b5563; letter-spacing: -.01em;
  width: max-content;
}
.rd-marquee-track span { display: inline-flex; align-items: center; gap: 14px; position: relative; }
.rd-marquee-track span::after { content: "·"; color: #c0bdb5; font-size: 24px; line-height: 1; transform: translateY(-2px); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-33.333%); } }

/* ---------- Film section ---------- */
.rd-film { padding: 120px 0 40px; background: #fbfaf6; }
.rd-film-head { display: flex; align-items: baseline; gap: 32px; margin-bottom: 48px; flex-wrap: wrap; }
.rd-film-head .label { font-family: 'IBM Plex Mono', monospace; font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: #6b7280; }
.rd-film-head h3 { font-family: Satoshi; font-weight: 900; font-size: clamp(28px, 3.5vw, 48px); line-height: 1.05; letter-spacing: -.03em; margin: 0; color: #151515; }
.rd-film-head h3 em { color: #3d61df; font-style: italic; font-weight: 500; }
.rd-film-frame {
  position: relative; aspect-ratio: 16 / 9; border-radius: 4px; overflow: hidden;
  background: #151515;
  box-shadow: 0 40px 80px rgba(0,0,0,0.18), 0 8px 24px rgba(0,0,0,0.08);
  transition: transform .4s cubic-bezier(.22,.61,.36,1);
}
.rd-film-frame.on { cursor: auto; }
.rd-film-frame.on, .rd-film-frame.on iframe { cursor: auto !important; }
.rd-film-frame:hover:not(.on) { transform: translateY(-4px); }
.rd-film-thumb-btn {
  position: absolute; inset: 0; width: 100%; height: 100%;
  border: 0; padding: 0; margin: 0; background: transparent; cursor: none; display: block;
}
.rd-film-frame img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  filter: brightness(0.7) saturate(0.85); transition: filter .5s ease, transform 6s ease;
}
.rd-film-frame:hover img { filter: brightness(0.6); transform: scale(1.03); }
.rd-film-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }
.rd-film-close {
  position: absolute; top: 16px; right: 16px;
  background: rgba(21,21,21,0.85); color: #fbfaf6;
  border: 0; padding: 8px 14px; border-radius: 999px;
  font-family: Satoshi; font-weight: 700; font-size: 12px;
  cursor: pointer; z-index: 2; backdrop-filter: blur(8px); transition: background .2s ease;
}
.rd-film-close:hover { background: #e81c72; }
.rd-film-play {
  position: absolute; left: 48px; bottom: 48px;
  display: inline-flex; align-items: center; gap: 14px;
  background: #fbfaf6; color: #151515;
  padding: 18px 26px 18px 22px; border-radius: 999px;
  font-family: Satoshi; font-weight: 700; font-size: 15px;
  transition: gap .3s ease, padding .3s ease, background .3s ease;
  pointer-events: none;
}
.rd-film-frame:hover .rd-film-play { gap: 18px; background: #3d61df; color: #fbfaf6; }
.rd-film-play-icon { font-size: 11px; }
.rd-film-meta {
  position: absolute; right: 32px; top: 32px;
  display: flex; flex-direction: column; gap: 6px; align-items: flex-end;
  font-family: 'IBM Plex Mono', monospace; font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; color: rgba(255,255,255,0.8); pointer-events: none;
}
.rd-film-meta span { padding: 4px 10px; background: rgba(0,0,0,0.35); border-radius: 2px; backdrop-filter: blur(6px); }
@media (max-width: 920px) {
  .rd-film-play { left: 16px; bottom: 16px; padding: 14px 18px; font-size: 13px; }
  .rd-film-meta { right: 12px; top: 12px; }
}

/* ---------- Chapters ---------- */
.rd-chapters { padding: 100px 0 60px; background: #fbfaf6; }
.rd-chapter-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: end; margin-bottom: 80px;
  padding-bottom: 40px; border-bottom: 1px solid rgba(21,21,21,0.12);
}
.rd-chapter-head .label { font-family: 'IBM Plex Mono', monospace; font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: #6b7280; }
.rd-chapter-head h2 { font-family: Satoshi; font-weight: 900; font-size: clamp(40px, 5.5vw, 72px); line-height: 1.02; letter-spacing: -.04em; margin: 14px 0 0; color: #151515; max-width: 600px; }
.rd-chapter-head .blue { color: #3d61df; }
.rd-chapter-head p { font-family: Satoshi; font-weight: 500; font-size: 18px; line-height: 1.55; color: #4b5563; max-width: 440px; margin: 0; }

.rd-chapter {
  display: grid; grid-template-columns: 0.5fr 1.5fr; gap: 56px;
  padding: 44px 0; border-bottom: 1px solid rgba(21,21,21,0.12);
  position: relative;
  transition: background .4s ease, grid-template-columns .5s cubic-bezier(.22,.61,.36,1);
  align-items: start;
}
.rd-chapter.is-open { grid-template-columns: 0.5fr 1.1fr 1fr; }
.rd-chapter:hover { background: rgba(21,21,21,0.015); }
.rd-chapter:last-child { border-bottom: 0; }

.rd-chapter-preview {
  position: sticky; top: 96px;
  display: flex; flex-direction: column; gap: 16px;
  animation: previewSlideIn .45s cubic-bezier(.22,.61,.36,1);
  overflow: hidden;
}
.rd-chapter:not(.is-open) .rd-chapter-preview { display: none; }
@keyframes previewSlideIn { from { opacity: 0; transform: translateX(16px); } to { opacity: 1; transform: translateX(0); } }

.rd-chapter-preview-close {
  position: absolute; top: 10px; right: 12px;
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(251,250,246,0.92); color: #151515;
  border: 0; border-radius: 50%;
  font-family: Satoshi; font-weight: 900; font-size: 18px;
  backdrop-filter: blur(6px); cursor: none;
  transition: background .2s ease, transform .2s ease;
}
.rd-chapter-preview-close:hover { background: #e81c72; color: #fff; transform: rotate(90deg); }
.rd-chapter-preview-meta { display: flex; flex-direction: column; gap: 4px; }
.rd-chapter-preview-meta .k { font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: #9ca3af; }
.rd-chapter-preview-meta strong { font-family: Satoshi; font-weight: 900; font-size: 18px; color: var(--phase, #3d61df); letter-spacing: -.01em; transition: color .3s ease; }
.rd-chapter-preview-meta .b { font-family: Satoshi; font-weight: 500; font-size: 14px; line-height: 1.5; color: #4b5563; margin-top: 2px; }
.rd-chapter-preview-frame {
  position: relative; aspect-ratio: 16 / 10;
  background: #151515; border-radius: 6px; overflow: hidden;
  box-shadow: 0 20px 40px rgba(0,0,0,0.10), 0 4px 12px rgba(0,0,0,0.05);
  transition: box-shadow .35s ease;
}
.rd-chapter:hover .rd-chapter-preview-frame { box-shadow: 0 24px 48px rgba(0,0,0,0.14), 0 6px 16px rgba(0,0,0,0.06); }
.rd-chapter-preview-frame video {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block;
  animation: previewIn .45s cubic-bezier(.22,.61,.36,1);
}
@keyframes previewIn { from { opacity: 0; transform: scale(1.02); } to { opacity: 1; transform: scale(1); } }

.rd-chapter-preview-corner {
  position: absolute; top: 10px; right: 12px;
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(251,250,246,0.92); color: #151515;
  border-radius: 50%; font-family: Satoshi; font-weight: 900; font-size: 14px;
  backdrop-filter: blur(6px);
}

/* Tool chips */
.rd-chapter-tools { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 24px; }
.rd-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 12px 7px 14px;
  border: 1px solid rgba(21,21,21,0.16); background: transparent; border-radius: 999px;
  font-family: Satoshi; font-weight: 500; font-size: 13px; color: #1f2937;
  cursor: none; transition: all .2s ease;
}
.rd-chip:hover { border-color: var(--phase, #3d61df); color: var(--phase, #3d61df); transform: translateY(-1px); }
.rd-chip.on { background: var(--phase, #3d61df); color: #fbfaf6; border-color: var(--phase, #3d61df); }
.rd-chip:focus-visible { outline: 2px solid var(--phase, #3d61df); outline-offset: 2px; }
.rd-chip-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--phase, #3d61df); transition: background .2s ease; }
.rd-chip.on .rd-chip-dot { background: #fbfaf6; }
.rd-chip-affordance { font-family: Satoshi; font-weight: 700; font-size: 13px; opacity: .55; margin-left: 2px; transition: opacity .2s ease, transform .2s ease; }
.rd-chip:hover .rd-chip-affordance { opacity: 1; transform: translateX(2px); }
.rd-chip.on .rd-chip-affordance { opacity: 1; }

.rd-chapter-see {
  align-self: flex-start; margin-top: 22px;
  background: transparent; border: 0; padding: 0;
  font-family: Satoshi; font-weight: 700; font-size: 14px;
  color: var(--phase, #3d61df);
  display: inline-flex; align-items: center; gap: 8px;
  cursor: none; border-bottom: 1px solid currentColor; padding-bottom: 2px;
  transition: gap .2s ease;
}
.rd-chapter-see:hover { gap: 14px; }

@media (max-width: 1100px) {
  .rd-chapter, .rd-chapter.is-open { grid-template-columns: 0.6fr 1.2fr; }
  .rd-chapter-preview { grid-column: 1 / -1; margin-top: 24px; position: static; }
  .rd-chapter-preview-frame { max-width: 560px; }
}

.rd-chapter-num {
  font-family: Satoshi; font-weight: 900;
  font-size: clamp(80px, 10vw, 152px);
  line-height: .85; letter-spacing: -.06em;
  color: var(--phase, #3d61df);
}
.rd-chapter-num small { display: block; font-size: 11px; font-family: 'IBM Plex Mono', monospace; font-weight: 500; letter-spacing: .25em; text-transform: uppercase; color: #6b7280; margin-top: 12px; }

.rd-chapter-body h3 { font-family: Satoshi; font-weight: 900; font-size: clamp(28px, 3vw, 44px); line-height: 1.05; letter-spacing: -.03em; margin: 0 0 18px; max-width: 520px; color: #151515; }
.rd-chapter-body h3 .q { color: var(--phase, #3d61df); }
.rd-chapter-body p { font-family: Satoshi; font-weight: 500; font-size: 17px; line-height: 1.6; color: #4b5563; max-width: 540px; margin: 0; }
.rd-chapter-tools span { display: inline-flex; align-items: center; gap: 6px; padding: 7px 14px; border: 1px solid rgba(21,21,21,0.16); border-radius: 999px; font-family: Satoshi; font-weight: 500; font-size: 13px; color: #1f2937; transition: all .2s ease; cursor: none; }
.rd-chapter-tools span:hover { border-color: var(--phase, #3d61df); color: var(--phase, #3d61df); transform: translateY(-2px); }
.rd-chapter-tools span::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--phase, #3d61df); }

/* Phase color binding */
.rd-c1 { --phase: #3d61df; }
.rd-c2 { --phase: #f3b900; }
.rd-c3 { --phase: #e81c72; }
.rd-c4 { --phase: #21dd90; }

/* ---------- Dossier / Beyond section ---------- */
.rd-dossier { padding: 140px 0; background: #151515; color: #fbfaf6; position: relative; overflow: hidden; }
.rd-dossier .rd-shell::before, .rd-dossier .rd-shell::after { background: rgba(255,255,255,0.08); }
.rd-dossier-head { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; margin-bottom: 80px; align-items: end; }
.rd-dossier-head .label { color: rgba(255,255,255,0.5); }
.rd-dossier-head h2 { font-family: Satoshi; font-weight: 900; font-size: clamp(40px, 5.5vw, 72px); line-height: 1.02; letter-spacing: -.04em; margin: 14px 0 0; max-width: 600px; color: #fbfaf6; }
.rd-dossier-head .accent { color: #21dd90; }
.rd-dossier-head p { font-family: Satoshi; font-weight: 500; font-size: 18px; line-height: 1.55; color: rgba(255,255,255,0.65); max-width: 440px; margin: 0; }

.rd-dossier-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: start; }
.rd-doc {
  background: #fbfaf6; color: #151515; border-radius: 4px; padding: 48px 56px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.4), 0 4px 12px rgba(0,0,0,0.2);
  font-family: Satoshi; position: relative; transform: rotate(-0.6deg);
}
.rd-doc::before { content: ""; position: absolute; top: 16px; right: -12px; width: 36px; height: 64px; background: rgba(243,185,0,0.85); transform: rotate(8deg); box-shadow: 0 4px 8px rgba(0,0,0,0.15); }
.rd-doc-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 28px; padding-bottom: 16px; border-bottom: 1px solid rgba(21,21,21,0.12); }
.rd-doc-head .meta { font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: #6b7280; }
.rd-doc-head h4 { font-family: Satoshi; font-weight: 900; font-size: 28px; letter-spacing: -.02em; margin: 6px 0 0; color: #151515; }
.rd-doc-head .stamp { font-family: Satoshi; font-weight: 900; font-size: 12px; letter-spacing: .2em; color: #21dd90; border: 2px solid #21dd90; padding: 6px 10px; border-radius: 4px; transform: rotate(6deg); display: inline-block; }
.rd-doc-row { padding: 12px 0; border-bottom: 1px dashed rgba(21,21,21,0.16); display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: baseline; }
.rd-doc-row:last-child { border-bottom: 0; }
.rd-doc-row .k { font-family: Satoshi; font-weight: 500; font-size: 14px; color: #4b5563; }
.rd-doc-row .v { font-family: Satoshi; font-weight: 900; font-size: 16px; color: #151515; }
.rd-doc-row .src { display: block; font-family: 'IBM Plex Mono', monospace; font-size: 10px; color: #9ca3af; margin-top: 2px; font-weight: 500; }

.rd-dossier-points { display: flex; flex-direction: column; gap: 32px; margin-top: 12px; }
.rd-dossier-points .item { border-left: 2px solid rgba(255,255,255,0.2); padding-left: 24px; transition: border-color .3s ease, padding-left .3s ease; }
.rd-dossier-points .item:hover { border-color: #21dd90; padding-left: 32px; }
.rd-dossier-points h5 { font-family: Satoshi; font-weight: 900; font-size: 22px; letter-spacing: -.02em; margin: 0 0 8px; color: #fbfaf6; }
.rd-dossier-points p { font-family: Satoshi; font-weight: 500; font-size: 15px; line-height: 1.6; color: rgba(255,255,255,0.65); margin: 0; }

/* ---------- Receipts / Testimonials ---------- */
.rd-receipts { padding: 80px 0 100px; background: #fbfaf6; border-top: 1px solid rgba(21,21,21,0.06); border-bottom: 1px solid rgba(21,21,21,0.06); }
.rd-quotes-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; border-top: 1px solid rgba(21,21,21,0.12); border-left: 1px solid rgba(21,21,21,0.12); }
.rd-quote { margin: 0; padding: 36px 40px 32px; border-right: 1px solid rgba(21,21,21,0.12); border-bottom: 1px solid rgba(21,21,21,0.12); background: #fbfaf6; transition: background .3s ease; }
.rd-quote:hover { background: #fff; }
.rd-quote blockquote { font-family: Satoshi; font-weight: 500; font-size: 20px; line-height: 1.45; color: #151515; margin: 0 0 18px; letter-spacing: -.01em; }
.rd-quote figcaption { font-family: 'IBM Plex Mono', monospace; font-size: 12px; display: flex; gap: 14px; align-items: baseline; letter-spacing: .02em; color: #6b7280; }
.rd-quote figcaption strong { font-family: Satoshi; font-weight: 900; font-size: 15px; color: #151515; letter-spacing: -.01em; }
@media (max-width: 920px) { .rd-quotes-grid { grid-template-columns: 1fr; } }

/* ---------- Trust / data security ---------- */
.rd-trust {
  padding: 120px 0;
  background: #fbfaf6;
  border-top: 1px solid rgba(21,21,21,0.06);
  border-bottom: 1px solid rgba(21,21,21,0.06);
}
.rd-trust-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: end; margin-bottom: 52px;
}
.rd-trust-head .label {
  font-family: 'IBM Plex Mono', monospace; font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
  color: #6b7280;
}
.rd-trust-head h2 {
  font-family: Satoshi; font-weight: 900; font-size: clamp(40px, 5.5vw, 72px);
  line-height: 1.02; letter-spacing: -.04em; margin: 14px 0 0; color: #151515; max-width: 600px;
}
.rd-trust-head .blue { color: #3d61df; }
.rd-trust-head p {
  font-family: Satoshi; font-weight: 500; font-size: 18px; line-height: 1.55;
  color: #4b5563; max-width: 470px; margin: 0;
}
.rd-trust-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid #151515;
  border-left: 1px solid rgba(21,21,21,0.12);
}
.rd-trust-cell {
  padding: 30px 28px 36px;
  border-right: 1px solid rgba(21,21,21,0.12);
  border-bottom: 1px solid rgba(21,21,21,0.12);
  display: flex; flex-direction: column; gap: 14px;
  background: #fbfaf6; transition: background .3s ease;
}
.rd-trust-cell:hover { background: #fff; }
.rd-trust-cell-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.rd-trust-k { font-family: 'IBM Plex Mono', monospace; font-size: 11px; letter-spacing: .22em; color: #9ca3af; }
.rd-trust-check {
  width: 24px; height: 24px; flex: none;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%; background: rgba(33,221,144,0.14); color: #10b981;
  font-size: 13px; font-weight: 700; line-height: 1;
  transition: background .3s ease, color .3s ease, transform .3s ease;
}
.rd-trust-cell:hover .rd-trust-check { background: #21dd90; color: #151515; transform: scale(1.08); }
.rd-trust-cell h3 {
  font-family: Satoshi; font-weight: 900; font-size: 20px; line-height: 1.15;
  letter-spacing: -.02em; margin: 0; color: #151515; text-wrap: balance;
}
.rd-trust-cell p {
  font-family: Satoshi; font-weight: 500; font-size: 14px; line-height: 1.6;
  color: #4b5563; margin: 0; text-wrap: pretty;
}
.rd-trust-seal {
  margin-top: 40px;
  display: grid; grid-template-columns: 1fr 1.2fr; gap: 0;
  border: 1px solid #151515; border-radius: 4px; overflow: hidden;
  background: #fff;
}
.rd-trust-seal-mark {
  display: flex; align-items: center; gap: 18px;
  padding: 28px 32px;
  background: #151515; color: #f3f1ea;
}
.rd-trust-seal-mark svg { width: 34px; height: 34px; flex: none; color: #21dd90; }
.rd-trust-seal-mark span {
  font-family: Satoshi; font-weight: 700; font-size: 16px; line-height: 1.35; letter-spacing: -.01em;
}
.rd-trust-specs {
  display: grid; grid-template-columns: 1fr 1fr; margin: 0;
}
.rd-trust-specs > div {
  padding: 18px 26px;
  border-left: 1px solid rgba(21,21,21,0.12);
  border-bottom: 1px solid rgba(21,21,21,0.12);
  display: flex; flex-direction: column; gap: 5px;
}
.rd-trust-specs > div:nth-child(odd) { border-left: none; }
.rd-trust-specs > div:nth-child(n+3) { border-bottom: none; }
.rd-trust-specs dt {
  font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: .2em; text-transform: uppercase;
  color: #9ca3af;
}
.rd-trust-specs dd {
  margin: 0; font-family: 'IBM Plex Mono', monospace; font-size: 14px; color: #151515; letter-spacing: -.01em;
}
@media (max-width: 1100px) {
  .rd-trust-grid { grid-template-columns: 1fr 1fr; }
  .rd-trust-seal { grid-template-columns: 1fr; }
  .rd-trust-seal-mark { border-bottom: 1px solid rgba(243,241,234,0.15); }
}
@media (max-width: 920px) {
  .rd-trust { padding: 80px 0; }
  .rd-trust-head { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 600px) {
  .rd-trust-grid { grid-template-columns: 1fr; }
}

/* ---------- Pricing ---------- */
.rd-pricing { padding: 140px 0; background: #fbfaf6; }
.rd-price-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid #151515; border-bottom: 1px solid #151515; margin-top: 64px; }
.rd-price-cell { padding: 36px 28px; border-right: 1px solid rgba(21,21,21,0.12); display: flex; flex-direction: column; gap: 16px; transition: background .3s ease; position: relative; cursor: none; text-decoration: none; color: #151515; }
.rd-price-cell:last-child { border-right: 0; }
.rd-price-cell:hover { background: #151515; color: #fbfaf6; }
.rd-price-cell:hover .rd-price-name { color: #fbfaf6; }
.rd-price-cell:hover .rd-price-link { color: #fbfaf6; }
.rd-price-cell:hover .rd-price-blurb { color: rgba(255,255,255,0.7); }
.rd-price-cell:hover .rd-price-num { color: #21dd90; }
.rd-price-cell:hover .rd-price-feats li { color: #fbfaf6; }
.rd-price-cell:hover .rd-price-feats li.lead { color: rgba(255,255,255,0.55); }
.rd-price-cell:hover .rd-price-feats li::before { background: #21dd90; }
/* Pro — persistently emphasised so it reads as the default choice */
.rd-price-cell.popular { background: #151515; color: #fbfaf6; }
.rd-price-cell.popular .rd-price-tier { color: #21dd90; }
.rd-price-cell.popular .rd-price-num { color: #21dd90; }
.rd-price-cell.popular .rd-price-name { color: #fbfaf6; }
.rd-price-cell.popular .rd-price-link { color: #fbfaf6; }
.rd-price-cell.popular .rd-price-blurb { color: rgba(255,255,255,0.72); }
.rd-price-cell.popular .rd-price-feats li { color: #fbfaf6; }
.rd-price-cell.popular .rd-price-feats li::before { background: #21dd90; }
.rd-price-cell.popular .rd-price-feats li.lead { color: rgba(255,255,255,0.55); }
.rd-price-badge { position: absolute; top: 0; right: 0; font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: #151515; background: #21dd90; padding: 6px 12px; }
.rd-price-tier { font-family: 'IBM Plex Mono', monospace; font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: #6b7280; }
.rd-price-name { font-family: Satoshi; font-weight: 900; font-size: 36px; letter-spacing: -.03em; margin: 0; }
.rd-price-num { font-family: Satoshi; font-weight: 900; font-size: 28px; letter-spacing: -.02em; color: #3d61df; transition: color .3s ease; }
.rd-price-num small { font-family: Satoshi; font-weight: 500; font-size: 13px; color: #6b7280; letter-spacing: 0; margin-left: 4px; }
.rd-price-blurb { font-family: Satoshi; font-weight: 500; font-size: 14px; line-height: 1.55; color: #4b5563; transition: color .3s ease; }
.rd-price-feats { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.rd-price-feats li { font-family: Satoshi; font-weight: 600; font-size: 13px; line-height: 1.35; color: #1f2937; padding-left: 20px; position: relative; transition: color .3s ease; }
.rd-price-feats li::before { content: ""; position: absolute; left: 0; top: 6px; width: 7px; height: 7px; background: #3d61df; border-radius: 50%; transition: background .3s ease; }
.rd-price-feats li.lead { font-family: 'IBM Plex Mono', monospace; font-weight: 500; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: #6b7280; padding-left: 0; margin-bottom: 2px; }
.rd-price-feats li.lead::before { display: none; }
.rd-price-link { font-family: Satoshi; font-weight: 700; font-size: 13px; display: inline-flex; align-items: baseline; gap: 8px; transition: color .3s ease; }

/* ---------- Final CTA ---------- */
.rd-cta { padding: 160px 0; background: #3d61df; color: #fbfaf6; position: relative; overflow: hidden; text-align: center; }
.rd-cta-meta { margin-top: 32px; font-family: 'IBM Plex Mono', monospace; font-size: 12px; letter-spacing: .04em; color: rgba(255,255,255,0.7); display: inline-flex; gap: 24px; flex-wrap: wrap; justify-content: center; }
.rd-cta-meta span { display: inline-flex; align-items: center; gap: 8px; }
.rd-cta-meta span::before { content: "✓"; color: #21dd90; font-weight: 700; }
.rd-cta::before { content: ""; position: absolute; inset: 0; background: url("/wp-content/themes/plb/img/brand/pattern.webp") repeat; opacity: .35; mix-blend-mode: soft-light; pointer-events: none; }
.rd-cta .rd-shell::before, .rd-cta .rd-shell::after { background: rgba(255,255,255,0.12); }
.rd-cta h2 { font-family: Satoshi; font-weight: 900; font-size: clamp(48px, 7vw, 96px); line-height: .98; letter-spacing: -.04em; margin: 0 auto; max-width: 1100px; position: relative; color: #fbfaf6; }
.rd-cta h2 em { font-style: italic; font-weight: 500; color: #fbfaf6; opacity: .75; }
.rd-cta-link { display: inline-flex; align-items: baseline; gap: 14px; margin-top: 48px; padding: 22px 0; border-top: 1px solid rgba(255,255,255,0.4); border-bottom: 1px solid rgba(255,255,255,0.4); font-family: Satoshi; font-weight: 900; font-size: 22px; color: #fbfaf6; text-decoration: none; width: min(420px, 80vw); justify-content: space-between; transition: padding .3s ease; cursor: none; position: relative; }
.rd-cta-link:hover { padding-left: 12px; }
.rd-cta-link .arrow { font-weight: 500; font-size: 28px; transition: transform .3s ease; }
.rd-cta-link:hover .arrow { transform: translateX(8px); }

/* ---------- Reveal-on-scroll ---------- */
.rd-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s cubic-bezier(.22,.61,.36,1); }
.rd-reveal.in { opacity: 1; transform: translateY(0); }

/* ---------- Footer ---------- */
footer { margin-top: 0 !important; }

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
  .rd-shell { padding: 0 24px; }
  .rd-hero-sub, .rd-chapter, .rd-chapter-head, .rd-dossier-grid, .rd-dossier-head { grid-template-columns: 1fr; gap: 32px; }
  .rd-price-grid { grid-template-columns: 1fr 1fr; }
  .rd-page { cursor: auto; }
  .rd-cursor { display: none; }
  .rd-chapter, .rd-chapter.is-open { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 600px) {
  .rd-price-grid { grid-template-columns: 1fr; }
  .rd-hero { padding: 60px 0 48px; }
  .rd-film { padding: 64px 0 24px; }
  .rd-dossier { padding: 80px 0; }
  .rd-chapters { padding: 64px 0 40px; }
  .rd-receipts { padding: 64px 0 80px; }
  .rd-pricing { padding: 80px 0; }
  .rd-cta { padding: 100px 0; }
  .rd-marquee { margin: 40px 0 0; }
}

/* ════════════════════════════════════════════════════
   TEMPLATES — Business-plan designs gallery
   ════════════════════════════════════════════════════ */
.rd-tpl {
  padding: 120px 0 130px;
  background: #fbfaf6;
  border-top: 1px solid rgba(21,21,21,0.06);
  overflow: hidden;
}
.rd-tpl-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: end; margin-bottom: 12px;
}
.rd-tpl-head .label {
  font-family: 'IBM Plex Mono', monospace; font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
  color: #6b7280;
}
.rd-tpl-head h2 {
  font-family: Satoshi; font-weight: 900; font-size: clamp(40px, 5.5vw, 72px);
  line-height: 1.02; letter-spacing: -.04em; margin: 14px 0 0; color: #151515; max-width: 640px;
}
.rd-tpl-head .blue { color: #3d61df; }
.rd-tpl-head p {
  font-family: Satoshi; font-weight: 500; font-size: 18px; line-height: 1.55;
  color: #4b5563; max-width: 470px; margin: 0;
}

/* Scroll-rail of live cover previews */
.rd-tpl-railwrap { position: relative; margin-top: 52px; }
.rd-tpl-rail {
  display: flex; gap: 28px;
  overflow-x: auto; overflow-y: hidden;
  padding: 8px 0 30px;
  /* let cards bleed to the viewport edge so the rail reads as a shelf.
     content half-width = (max-width 1480 / 2) - 56px padding = 684px */
  margin: 0 calc(50% - 50vw);
  padding-left: max(56px, calc(50vw - 684px));
  padding-right: max(56px, calc(50vw - 684px));
  scrollbar-width: thin;
  scrollbar-color: rgba(21,21,21,0.2) transparent;
}
.rd-tpl-rail::-webkit-scrollbar { height: 6px; }
.rd-tpl-rail::-webkit-scrollbar-thumb { background: rgba(21,21,21,0.18); border-radius: 99px; }
.rd-tpl-rail::-webkit-scrollbar-track { background: transparent; }

.rd-tpl-card {
  flex: 0 0 auto; width: 300px;
  color: inherit;
  display: flex; flex-direction: column;
}
.rd-tpl-frame {
  width: 300px; height: 424px; position: relative;
  overflow: hidden; background: #fff;
  border: 1px solid rgba(21,21,21,0.12);
  box-shadow: 0 1px 0 rgba(21,21,21,0.04);
  transition: transform .4s cubic-bezier(.22,.61,.36,1), box-shadow .4s ease, border-color .4s ease;
}
.rd-tpl-frame iframe {
  width: 794px; height: 1123px; border: 0;
  transform: scale(0.37783); transform-origin: top left;
  pointer-events: none; display: block;
}
.rd-tpl-frame::after {
  /* hairline inner edge + subtle paper depth */
  content: ""; position: absolute; inset: 0;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.4);
  pointer-events: none;
}
.rd-tpl-card:hover .rd-tpl-frame { transform: translateY(-8px); box-shadow: 0 26px 50px -28px rgba(21,21,21,0.5); border-color: rgba(21,21,21,0.28); }
.rd-tpl-cap {
  display: flex; align-items: baseline; gap: 10px;
  padding: 16px 2px 0;
}
.rd-tpl-cap .n {
  font-family: 'IBM Plex Mono', monospace; font-size: 11px; letter-spacing: .14em;
  color: #9ca3af; flex: none;
}
.rd-tpl-cap strong {
  font-family: Satoshi; font-weight: 900; font-size: 16px; letter-spacing: -.02em; color: #151515;
}
.rd-tpl-cap .aes {
  font-family: 'IBM Plex Mono', monospace; font-size: 11px; letter-spacing: .02em;
  color: #6b7280; margin-left: auto; text-align: right;
}

/* "See it for real" CTA band — split light copy + dark action */
.rd-tpl-get {
  display: grid; grid-template-columns: 1.3fr 1fr; align-items: stretch;
  margin-top: 56px;
  border: 1px solid #151515; border-radius: 6px; overflow: hidden;
  background: #fff;
}
.rd-tpl-get-copy { padding: 40px 44px; }
.rd-tpl-get-copy .eyebrow {
  font-family: 'IBM Plex Mono', monospace; font-size: 11px; letter-spacing: .2em; text-transform: uppercase;
  color: #3d61df; margin: 0 0 14px;
}
.rd-tpl-get-copy h3 {
  font-family: Satoshi; font-weight: 900; font-size: clamp(26px, 3vw, 36px);
  line-height: 1.06; letter-spacing: -.03em; margin: 0; color: #151515; max-width: 16ch; text-wrap: balance;
}
.rd-tpl-get-copy p {
  font-family: Satoshi; font-weight: 500; font-size: 15px; line-height: 1.6;
  color: #4b5563; margin: 16px 0 0; max-width: 44ch;
}
.rd-tpl-get-side {
  background: #151515; color: #fbfaf6;
  padding: 40px 44px;
  display: flex; flex-direction: column; justify-content: center; gap: 22px;
}
.rd-tpl-get-stats { display: flex; gap: 36px; }
.rd-tpl-get-stats div { display: flex; flex-direction: column; gap: 4px; }
.rd-tpl-get-stats .num {
  font-family: Satoshi; font-weight: 900; font-size: 34px; letter-spacing: -.03em; color: #fff; line-height: 1;
}
.rd-tpl-get-stats .lbl {
  font-family: 'IBM Plex Mono', monospace; font-size: 10px; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.rd-tpl-actions { display: flex; flex-direction: column; gap: 12px; }
.rd-tpl-dl {
  display: inline-flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 16px 22px; border-radius: 4px;
  background: #21dd90; color: #0c1a12;
  font-family: Satoshi; font-weight: 900; font-size: 16px; letter-spacing: -.01em;
  text-decoration: none; cursor: none;
  transition: transform .3s ease, background .3s ease;
}
.rd-tpl-dl:hover { transform: translateY(-2px); background: #2bf09e; }
.rd-tpl-dl .arrow { font-size: 18px; transition: transform .3s ease; }
.rd-tpl-dl:hover .arrow { transform: translateX(4px); }
.rd-tpl-sample {
  display: inline-flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 14px 22px; border-radius: 4px;
  border: 1px solid rgba(255,255,255,0.25); color: #fbfaf6;
  font-family: Satoshi; font-weight: 700; font-size: 15px; letter-spacing: -.01em;
  text-decoration: none; cursor: none;
  transition: border-color .3s ease, background .3s ease;
}
.rd-tpl-sample:hover { border-color: rgba(255,255,255,0.6); background: rgba(255,255,255,0.06); }
.rd-tpl-dl:focus-visible, .rd-tpl-sample:focus-visible { outline: 2px solid #21dd90; outline-offset: 3px; }
.rd-tpl-get-fine {
  font-family: 'IBM Plex Mono', monospace; font-size: 11px; letter-spacing: .06em;
  color: rgba(255,255,255,0.55); margin: 0;
  display: flex; align-items: center; gap: 8px;
}
.rd-tpl-get-fine svg { width: 14px; height: 14px; color: #21dd90; flex: none; }

@media (max-width: 1100px) {
  .rd-tpl-head { grid-template-columns: 1fr; gap: 24px; }
  .rd-tpl-get { grid-template-columns: 1fr; }
}
@media (max-width: 920px) {
  .rd-tpl { padding: 80px 0 90px; }
  .rd-tpl-rail { padding-left: 24px; padding-right: 24px; }
  .rd-tpl-get-copy, .rd-tpl-get-side { padding: 32px 24px; }
  .rd-tpl-card, .rd-tpl-dl, .rd-tpl-sample { cursor: auto; }
}

/* Reduced-motion: no card-lift transitions */
@media (prefers-reduced-motion: reduce) {
  .rd-tpl-frame, .rd-tpl-open, .rd-tpl-dl, .rd-tpl-dl .arrow, .rd-tpl-sample { transition: none; }
}
