:root {
  --surface: rgba(255, 255, 255, 0.92);
  --surface-strong: #f8f9fa;
  --text: #1f2a36;
  --muted: #5b6774;
  --line: rgba(31, 42, 54, 0.12);
  --blue: #1a6bb5;
  --blue-transition: #0097b2;
  --orange: #ff7a00;
  --yellow: #ffb800;
  --gold-soft: #f4c46b;
  --blue-deep: #163d73;
  --success: #27ae60;
  --shadow: 0 24px 60px rgba(26, 107, 181, 0.12);
  --radius-lg: 24px;
  --radius-md: 20px;
  --radius-sm: 16px;
  --container: min(1120px, calc(100vw - 40px));
  --container-wide: min(1760px, calc(100vw - 24px));

  /* ── Bodygraph tamanho padrão aprovado ───────────────────
     Altere apenas aqui para propagar em todo o site.      */
  --bg-max-w:    980px;                    /* largura máxima do SVG            */
  --bg-max-h:    calc(100vh - 155px);      /* altura máxima do SVG             */
  --bg-rail-w:   90px;                     /* largura de cada coluna Design/Personalidade */
  --bg-rail-gap: 8px;                      /* gap entre colunas e bodygraph    */
  --bg-bg-scale: 0.9;                      /* escala do círculo de fundo       */
  --bg-chart-scale: 1.1053;                /* escala visual aplicada ao bodygraph de charts */
  --bg-chart-background-scale: 1.1;        /* aumento visual aplicado ao background de charts */
  --bg-chart-transform-scale: 1.2534;      /* escala visual efetiva do bodygraph no charts */
  --bg-chart-transform-scale-public: 1.1583; /* escala visual efetiva do bodygraph publico */

  /* ── Spacing system ──────────────────────────────────── */
  --space-xs:  8px;
  --space-sm:  16px;
  --space-md:  24px;
  --space-lg:  32px;
  --space-xl:  48px;
  --space-2xl: 64px;

  --section-gap:     var(--space-xl);
  --panel-padding-v: 28px;
  --panel-padding-h: 28px;
  --site-max-width:  var(--container);
  --site-padding-h:  var(--space-lg);
}

@media (max-width: 768px) {
  :root {
    --section-gap:     var(--space-lg);
    --panel-padding-v: 20px;
    --panel-padding-h: 20px;
    --site-padding-h:  var(--space-md);
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "Manrope", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(0, 151, 178, 0.12), transparent 24%),
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 22%),
    linear-gradient(180deg, #ffffff 0%, #f8f9fa 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(26, 107, 181, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26, 107, 181, 0.04) 1px, transparent 1px);
  background-size: 96px 96px;
  opacity: 0.45;
  pointer-events: none;
}

a {
  color: inherit;
  text-decoration: none;
}

.skip-link {
  position: absolute;
  top: -100%;
  left: 16px;
  z-index: 9999;
  padding: 8px 16px;
  background: var(--blue-deep, #163d73);
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 600;
  border-radius: 0 0 8px 8px;
  text-decoration: none;
  transition: top 0.15s;
}

.skip-link:focus {
  top: 0;
}

.site-shell {
  width: min(1648px, calc(100vw - 80px));
  margin: 0 auto;
  padding-bottom: 72px;
}

@media (max-width: 600px) {
  .site-shell {
    width: min(100%, calc(100vw - 32px));
  }
}

@media (max-width: 380px) {
  .site-shell {
    width: min(100%, calc(100vw - 16px));
  }
}

.site-shell-wide {
  width: min(1648px, calc(100vw - 80px));
  margin-inline: auto;
}

.site-shell-wide .site-header {
  top: 8px;
  margin: 8px auto 10px;
  padding: var(--space-sm) var(--space-md);
}

.site-header {
  position: sticky;
  top: 16px;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin: 16px auto 16px;
  padding: var(--space-md);
  background: linear-gradient(90deg, var(--blue), var(--blue-deep));
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 22px;
  backdrop-filter: blur(18px);
  box-shadow: var(--shadow);
  transition: transform 220ms ease, opacity 220ms ease, box-shadow 220ms ease;
  transform: translateY(0);
  opacity: 1;
}

@media (min-width: 1024px) {
  body.is-header-auto-hidden .site-header,
  .site-header.is-auto-hidden {
    transform: translateY(calc(-100% + 14px));
    opacity: 0.38;
  }

  body.is-header-auto-hidden .site-header:hover,
  .site-header.is-auto-hidden:hover {
    transform: translateY(0);
    opacity: 1;
  }
}

/* ===========================
   MOBILE NAV
   =========================== */

.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  padding: 6px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 8px;
  cursor: pointer;
  flex-shrink: 0;
}

.nav-toggle-bar {
  display: block;
  width: 100%;
  height: 2px;
  background: #ffffff;
  border-radius: 2px;
  transition: transform 0.2s, opacity 0.2s;
}

.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2) {
  opacity: 0;
}

.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.nav-drawer {
  display: contents;
}

@media (max-width: 980px) {
  .nav-toggle {
    display: flex;
  }

  .site-header {
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
    position: relative;
    gap: 12px;
  }

  .nav-drawer {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    flex-direction: column;
    gap: 0;
    background: linear-gradient(160deg, var(--blue) 0%, var(--blue-deep) 100%);
    border-radius: 16px;
    padding: 12px;
    border: 1px solid rgba(255,255,255,0.16);
    box-shadow: 0 8px 32px rgba(0,0,0,0.2);
    z-index: 100;
  }

  .nav-drawer.is-open {
    display: flex;
  }

  .site-nav {
    flex-direction: column;
    gap: 2px;
    width: 100%;
  }

  .site-nav a {
    padding: 10px 12px;
    border-radius: 8px;
    display: block;
    font-size: 0.875rem;
    text-align: left;
  }

  .site-nav a:hover {
    background: rgba(255,255,255,0.1);
  }

  .header-actions {
    flex-direction: column;
    gap: 8px;
    padding-top: 12px;
    margin-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.12);
    width: 100%;
  }

  .header-actions .button {
    width: 100%;
    justify-content: center;
    min-height: 44px;
    text-align: center;
  }
}

.flash-stack {
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
}

.flash {
  margin: 0;
  padding: 14px 18px;
  border-radius: var(--radius-sm);
  font-weight: 700;
  transition: opacity 220ms ease, transform 220ms ease, max-height 220ms ease, margin 220ms ease, padding 220ms ease;
}

.flash.is-dismissing {
  opacity: 0;
  transform: translateY(-6px);
}

.flash-notice {
  background: rgba(39, 174, 96, 0.12);
  color: var(--success);
}

.flash-alert {
  background: rgba(255, 122, 0, 0.12);
  color: var(--orange);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  color: var(--yellow);
  font-size: 1.6rem;
  font-weight: 700;
}

.brand-copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.brand-copy strong {
  font-size: 0.98rem;
  color: #ffffff;
}

.brand-copy small,
.site-nav a,
.eyebrow,
.card-label,
.pill {
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.brand-copy small,
.site-nav a {
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.74rem;
}

.site-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 22px;
  flex: 1;
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.header-actions .button {
  min-height: 36px;
  padding: 0 16px;
  font-size: 0.82rem;
  text-align: center;
  white-space: nowrap;
}

.header-actions form,
.row-actions form {
  margin: 0;
}

.header-actions .button-ghost {
  color: rgba(255, 255, 255, 0.75);
}

.header-actions .button-ghost:hover {
  color: #ffffff;
}

.user-chip {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  font-size: 0.85rem;
  font-weight: 700;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 700;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.button:hover {
  transform: translateY(-1px);
}

.button,
.button:hover,
.button:focus,
.button:focus-visible,
button.button,
button.button:hover,
button.button:focus,
button.button:focus-visible,
input.button,
input.button:hover,
input.button:focus,
input.button:focus-visible {
  box-shadow: none !important;
}

.button-primary {
  background: linear-gradient(135deg, #ff7a00, #ffb800);
  color: #fff;
}

.button-primary:hover {
  box-shadow: 0 6px 28px rgba(255, 122, 0, 0.45) !important;
}

.button-secondary {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.24);
  color: #ffffff;
}

.content-panel .button-secondary,
.library-card .button-secondary,
.report-offer-card .button-secondary,
.workspace-page .button-secondary {
  background: rgba(26, 107, 181, 0.1);
  border-color: rgba(26, 107, 181, 0.18);
  color: var(--blue);
}

.button-outline {
  background: transparent;
  border-color: rgba(26, 107, 181, 0.22);
  color: var(--blue);
}

.button-danger {
  border-color: rgba(192, 57, 43, 0.22);
  color: #c0392b;
}

.hero,
.split-section {
  display: grid;
  grid-template-columns: 1.25fr 0.9fr;
  gap: 32px;
}

.hero {
  position: relative;
  padding: 64px 42px 52px;
  align-items: center;
  border-radius: 0 0 28px 28px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, #f4c46b 0%, #ff7a00 18%, #0097b2 55%, #0b2147 100%);
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(20deg, rgba(255, 255, 255, 0.14) 0 24%, transparent 24% 100%),
    linear-gradient(200deg, rgba(255, 255, 255, 0.1) 0 32%, transparent 32% 100%);
  pointer-events: none;
}

.hero > * {
  position: relative;
  z-index: 1;
}

.eyebrow,
.card-label,
.pill {
  color: var(--yellow);
  font-size: 0.76rem;
  font-weight: 700;
}

h1,
h2,
h3 {
  margin: 0;
  font-family: "Manrope", sans-serif;
  font-weight: 800;
  line-height: 1.02;
}

h1 {
  margin-top: 14px;
  font-size: clamp(3.4rem, 6vw, 5.8rem);
}

.hero h1 {
  max-width: 13ch;
}

h2 {
  font-size: clamp(2.4rem, 4vw, 4rem);
}

h3 {
  font-size: 1.55rem;
}

p,
dd,
li {
  margin: 0;
  color: var(--muted);
  line-height: 1.72;
  font-size: 1.02rem;
}

.lead {
  max-width: 58ch;
  margin-top: 18px;
  font-size: 1.12rem;
}

.hero h1,
.hero .lead,
.hero dd,
.hero dt {
  color: #ffffff;
}

.hero-actions,
.contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}

.hero-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin: 36px 0 0;
}

.hero-metrics div,
.hero-card,
.service-card,
.material-card,
.about-grid article,
.course-list article,
.manifesto-panel,
.content-panel {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(26, 107, 181, 0.08);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}

.hero-metrics div::before,
.content-panel::before,
.service-card::before,
.material-card::before,
.hero-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  border-radius: 24px 24px 0 0;
  background: linear-gradient(90deg, #ff7a00, #ffb800);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.38s ease;
  z-index: 1;
}

.hero-metrics div:hover::before,
.content-panel:hover::before,
.service-card:hover::before,
.material-card:hover::before,
.hero-card:hover::before {
  transform: scaleX(1);
}

.hero-metrics div {
  padding: 22px;
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.18);
}

.hero-metrics dt {
  margin-bottom: 6px;
  color: #ffffff;
  font-size: 1.8rem;
  font-weight: 800;
}

.hero-card {
  min-height: 100%;
  padding: 34px;
  background:
    linear-gradient(180deg, rgba(26, 107, 181, 0.3), rgba(22, 61, 115, 0.36)),
    rgba(255, 255, 255, 0.12);
  color: #f8f9fa;
  border-color: rgba(255, 255, 255, 0.16);
}

.hero-card h2,
.hero-card p {
  color: inherit;
}

.hero-card h2 {
  margin-top: 18px;
  max-width: 12ch;
}

.hero-card p {
  margin-top: 18px;
}

.card-glow {
  position: absolute;
  inset: auto -72px -72px auto;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 184, 0, 0.42), transparent 70%);
}

.credibility-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 16px;
}

.credibility-stat {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 22px 20px;
  border-radius: 20px;
  border: 1px solid rgba(26, 107, 181, 0.1);
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(8px);
}

.credibility-stat strong {
  display: flex;
  align-items: baseline;
  gap: 4px;
  font-size: 2.4rem;
  font-weight: 800;
  line-height: 1;
  color: var(--blue-deep);
}

.credibility-stat strong span {
  font-size: 1rem;
  font-weight: 700;
  color: var(--orange);
}

.credibility-stat p {
  margin: 0;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.4;
}

.credibility-stat-badge strong {
  font-size: 1.9rem;
  letter-spacing: -0.02em;
  color: var(--blue-deep);
}

.credibility-strip p {
  padding: 16px 18px;
  border-top: 2px solid rgba(26, 107, 181, 0.12);
  color: var(--text);
  font-size: 0.92rem;
}

.home-live-hero {
  padding: 44px 0 26px;
}

.home-live-copy {
  max-width: 960px;
}

.home-live-copy h1 {
  max-width: 14ch;
  color: var(--brand-blue);
}

.home-live-copy .lead {
  max-width: 66ch;
}

.home-live-metrics dt,
.home-live-metrics dd {
  color: var(--text);
}

.home-transit-context-strip {
  background: #f4f7fb;
  border-top: 2px solid #163d73;
  border-bottom: 1px solid rgba(22, 61, 115, 0.1);
  padding: 0 1.5rem;
}

.home-transit-context-inner {
  max-width: var(--container);
  margin: 0 auto;
  min-height: 68px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 12px 0;
}

.home-transit-context-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: #163d73;
  white-space: nowrap;
  padding-right: 28px;
}

.home-transit-context-hint {
  font-size: 0.84rem;
  color: var(--muted);
  line-height: 1.5;
  max-width: 58ch;
  margin: 0;
  padding-left: 28px;
  border-left: 1px solid rgba(22, 61, 115, 0.2);
}

.home-transit-preview {
  margin-bottom: 28px;
}

.home-transit-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 22px;
  padding: 26px 28px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(26, 107, 181, 0.96), rgba(0, 151, 178, 0.9));
  box-shadow: var(--shadow);
}

.home-transit-banner h2 {
  margin-top: 8px;
  color: #ffffff;
  font-size: clamp(2rem, 3vw, 3rem);
}

.home-transit-banner p:not(.eyebrow) {
  margin-top: 12px;
  max-width: 68ch;
  color: rgba(255, 255, 255, 0.86);
}

.hero-bridge {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.6;
  margin: 6px 0 0;
  max-width: 420px;
}

.hero-pain-hook {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.5);
  line-height: 1.8;
  margin: 4px 0 10px;
  max-width: 440px;
  font-style: italic;
}

/* ── Home reincident hook ─────────────────────────────────────── */
.home-reincident-hook {
  background: rgba(26,107,181,0.04);
  border-top: 1px solid rgba(26,107,181,0.08);
  border-bottom: 1px solid rgba(26,107,181,0.08);
  padding: 48px 24px;
}

.home-reincident-inner {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}

.home-reincident-inner h2 {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 8px 0 16px;
  line-height: 1.3;
  letter-spacing: -0.02em;
}

.home-reincident-inner p {
  font-size: 0.92rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.65);
  margin: 0 0 24px;
}
/* ── End Home reincident hook ─────────────────────────────────── */

.home-transit-banner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
  flex-shrink: 0;
}

.home-transit-banner .button-outline,
.home-transit-banner .button-secondary {
  background: rgba(11, 33, 71, 0.72);
  border-color: rgba(255, 255, 255, 0.22);
  color: #ffffff;
}

.home-transit-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 210px;
  gap: 18px;
  align-items: stretch;
}


.home-transit-stage {
  min-height: auto;
  margin-top: 0;
}

/* ── Home Hero — split layout premium ──────────────────────────── */
.home-hero {
  background: linear-gradient(135deg, #163d73 0%, #1a4a8a 100%);
  padding: 5rem 1.5rem 4.5rem;
  position: relative;
  overflow: hidden;
}

.home-hero-inner {
  max-width: var(--container);
  margin: 0 auto;
  text-align: center;
}

.home-hero-badge {
  display: inline-block;
  background: #ff7a00;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.35rem 1.1rem;
  border-radius: 100px;
  margin-bottom: 0.75rem;
}

.home-hero-eyebrow {
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 0.5rem;
}

.home-hero h1 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: clamp(2.4rem, 4.5vw, 3.6rem);
  color: #ffffff;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0 auto 1.5rem;
}

.home-hero-pain {
  color: rgba(255, 255, 255, 0.65);
  font-size: 1rem;
  line-height: 1.75;
  max-width: 72ch;
  margin: 0 auto 0.75rem;
  font-style: italic;
}

.home-hero-bridge {
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.9rem;
  line-height: 1.65;
  max-width: 76ch;
  margin: 0 auto 2rem;
}

.home-hero-actions {
  display: flex;
  gap: 1.25rem;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-bottom: 2.5rem;
}

.home-hero-cta {
  font-size: 1rem;
  padding: 0 28px;
  min-height: 52px;
}

.home-hero-secondary-cta {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.95rem;
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.22);
  padding-bottom: 2px;
  transition: color 0.18s, border-color 0.18s;
}

.home-hero-secondary-cta:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.6);
}

.home-hero-stats {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  justify-content: center;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 1.5rem;
}

.home-hero-stat strong {
  display: block;
  font-size: 1.15rem;
  font-weight: 800;
  color: #ffffff;
  letter-spacing: -0.01em;
}

.home-hero-stat span {
  font-size: 0.7rem;
  color: rgba(255, 255, 255, 0.48);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.home-transit-preview {
  padding-top: 2rem;
}

@media (max-width: 540px) {
  .home-hero {
    padding: 3.5rem 1.25rem 3rem;
  }
  .home-hero h1 {
    max-width: none;
  }
  .home-hero-actions {
    flex-direction: column;
    align-items: flex-start;
  }
  .home-hero-stats {
    gap: 1.5rem;
  }
}

.home-transit-stage .workspace-map-app {
  display: flex !important;
  justify-content: flex-start !important;
  align-items: flex-start !important;
  grid-template-columns: none !important;
  gap: 0 !important;
}

.home-transit-stage .workspace-bodygraph {
  flex: 0 1 580px !important;
  width: auto !important;
  min-width: 0;
}

.home-transit-explain {
  flex: 0 0 440px;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 1.25rem 1.5rem 1.25rem 0.75rem;
  border-right: 1px solid rgba(22, 61, 115, 0.1);
  max-height: calc(100vh - 200px);
  overflow: hidden;
}

.home-transit-explain-eyebrow {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #163d73;
  margin-bottom: 0.4rem;
}

.home-transit-explain-title {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--heading);
  margin-bottom: 0.9rem;
}

.home-transit-explain-body {
  font-size: 0.75rem;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 0.6rem;
}

.home-transit-explain-body em {
  font-style: normal;
  font-weight: 600;
  color: var(--heading);
}

.home-transit-explain-cta {
  font-size: 0.72rem;
  color: #163d73;
  font-weight: 600;
  margin-top: 0.4rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(22, 61, 115, 0.1);
}

.home-transit-stage .workspace-rail.personality-tone {
  flex: 0 0 104px !important;
  width: 104px !important;
  transform: none !important;
}

.home-transit-panel .workspace-panel-tabs {
  grid-template-columns: 1fr;
  justify-items: center;
  padding: 10px 16px 0;
}

.home-transit-panel .workspace-tab {
  width: 100%;
  min-height: 36px;
  font-size: 0.82rem;
  white-space: nowrap;
}

.home-transit-gate-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.home-transit-panel .home-transit-gate-row {
  padding: 7px 4px !important;
}

.home-transit-panel .home-transit-gate-row strong {
  font-size: 0.76rem !important;
}

.home-transit-panel .home-transit-gate-row--sun {
  border: 1.5px solid var(--orange);
  border-radius: 8px;
  padding: 7px 10px !important;
  background: rgba(245, 158, 11, 0.06);
  justify-content: center;
  gap: 4px;
}

.home-transit-panel .home-transit-gate-row--sun strong,
.home-transit-panel .home-transit-gate-row--sun .home-transit-gate-planet,
.home-transit-panel .home-transit-gate-row--sun .home-transit-gate-planet span,
.home-transit-panel .home-transit-gate-row--sun .home-transit-gate-planet .planet-symbol {
  color: var(--orange) !important;
  font-weight: 700 !important;
}

.home-transit-panel .home-transit-gate-row--sun .home-transit-gate-planet .planet-symbol {
  font-size: 1.3rem !important;
}


.home-transit-panel .home-transit-gate-row--sun strong {
  font-weight: 700;
  font-size: 0.82rem !important;
  white-space: nowrap;
}

.sun-gate-meta {
  font-size: 0.78rem;
  color: var(--muted);
  margin-bottom: 16px;
}

.sun-gate-footer {
  border-top: 1px solid rgba(15, 33, 58, 0.08);
  padding-top: 16px;
  font-size: 0.9rem;
  color: var(--muted);
}

.home-transit-gate-planet {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 0.72rem;
}

.home-transit-panel .home-transit-gate-planet {
  font-size: 0.72rem !important;
}

.home-transit-gate-planet .planet-symbol {
  font-size: 0.82rem;
}

.home-transit-stage .app-bodygraph .bodygraph-svg {
  width: min(100%, 778px);
  max-width: 778px;
  max-height: calc((100vh - 155px) * 0.8735);
  transform: translateY(5%) scale(1);
  transform-origin: center top;
}

.home-transit-stage .app-bodygraph .bodygraph-background {
  top: 52%;
  width: min(80.2%, calc((100vh - 155px) * 0.8821));
  max-width: calc((100vh - 155px) * 0.8821);
}

.home-transit-stage .app-bodygraph .bodygraph-canvas.is-mandala-visible {
  padding: 38px 0;
}

.home-transit-stage .app-bodygraph .bodygraph-canvas.is-mandala-visible .bodygraph-svg {
  width: min(100%, 1056px);
  max-width: min(calc(100vh - 130px), 1056px);
  height: auto;
  aspect-ratio: 1 / 1;
  max-height: none;
  transform: scale(1.15);
  transform-origin: center;
}

.home-transit-stage .app-bodygraph:has(.bodygraph-canvas.is-mandala-visible) {
  align-self: center;
}

.home-transit-head {
  align-items: end;
  gap: 16px;
}

.home-transit-head h1,
.home-transit-head h2 {
  max-width: none;
  font-size: clamp(1.4rem, 2vw, 1.8rem);
  font-weight: 700;
  line-height: 1.25;
  text-wrap: balance;
  color: var(--heading);
}

.home-transit-head-note {
  max-width: 34ch;
  font-size: 0.98rem;
  color: var(--muted);
}

.home-transit-panel {
  width: 100%;
  max-width: none;
  height: calc(100vh - 96px);
  min-height: calc(100vh - 96px);
  align-self: start;
  justify-self: stretch;
}

.home-transit-shell.workspace-shell-app > aside.workspace-panel.content-panel.workspace-panel-app.home-transit-panel {
  margin-top: 0 !important;
  position: sticky !important;
  top: 88px !important;
  width: 100% !important;
  max-width: none !important;
}

.section {
  padding: 48px 0;
}

.section-heading {
  margin-bottom: 28px;
}

.section-heading h2 {
  margin-top: 12px;
}

.about-grid,
.cards-grid,
.course-list {
  display: grid;
  gap: 22px;
}

.about-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.about-grid.four-col {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.manifesto-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.cards-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.about-grid article,
.service-card,
.material-card,
.course-list article,
.content-panel {
  padding: var(--panel-padding-v) var(--panel-padding-h);
}

.featured {
  background:
    linear-gradient(180deg, rgba(255, 184, 0, 0.14), rgba(244, 196, 107, 0.18));
}

.pill {
  display: inline-flex;
  margin-bottom: 14px;
}

.split-copy p:not(.eyebrow) {
  margin-top: 18px;
}

.materials-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card-actions {
  margin-top: 20px;
}

.manifesto-panel {
  padding: 44px;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(0, 151, 178, 0.96), rgba(255, 122, 0, 0.92), rgba(244, 196, 107, 0.9));
}

.manifesto-panel h2,
.manifesto-panel p {
  color: #f4efe7;
}

.manifesto-panel p:not(.eyebrow) {
  margin-top: 16px;
}

/* Section background rhythm */
.section.home-proof {
  background: rgba(26, 107, 181, 0.03);
  border-radius: 24px;
  padding-left: 32px;
  padding-right: 32px;
}

.section.about,
.section.materials,
.section.pricing {
  background: rgba(26, 107, 181, 0.03);
  border-radius: 24px;
  padding-left: 32px;
  padding-right: 32px;
  margin-top: 48px;
}

/* Pilot section */
.pilot .split-section {
  grid-template-columns: 1.05fr 0.95fr;
}

.pilot-split {
  grid-template-columns: 0.72fr 1.28fr !important;
  align-items: start;
  gap: 48px;
}

.pilot-photo-area {
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(160deg, rgba(26, 107, 181, 0.08), rgba(0, 151, 178, 0.12));
  display: flex;
  align-items: center;
  justify-content: center;
}

.pilot-portrait {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
  border-radius: 16px;
  opacity: 0.9;
}

.pilot-content {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.pilot-traits article {
  padding: 18px 22px;
}

/* Pill badge on light card backgrounds */
.material-card .pill,
.service-card .pill,
.content-panel .pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(255, 122, 0, 0.12), rgba(255, 184, 0, 0.18));
  border: 1px solid rgba(255, 122, 0, 0.22);
  color: #c45f00;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 8px;
}

/* Pricing tiers */
.tier-price-area {
  margin: 20px 0 4px;
  border-top: 1px solid rgba(26, 107, 181, 0.1);
  padding-top: 16px;
}

.tier-price-value {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--blue-deep);
  line-height: 1;
}

.tier-price-label {
  font-size: 0.78rem;
  color: var(--text-muted, #8492a6);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.tier-entry {
  border-top: 4px solid rgba(26, 107, 181, 0.58);
}

.tier-business {
  border-top: 4px solid rgba(0, 151, 178, 0.62);
  background: linear-gradient(180deg, rgba(26, 107, 181, 0.08), rgba(255, 255, 255, 0.92));
}

.tier-first {
  border-top: 4px solid var(--orange);
  background: linear-gradient(180deg, rgba(255, 122, 0, 0.08), rgba(244, 196, 107, 0.16));
}

.page-section {
  display: flex;
  flex-direction: column;
  gap: var(--section-gap);
  padding: 8px 0 var(--section-gap);
}

.page-hero {
  padding: 12px 18px;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, rgba(26, 107, 181, 0.96), rgba(0, 151, 178, 0.9));
  color: #ffffff;
}

.page-hero h1,
.page-hero p {
  max-width: none;
  color: #ffffff;
}

.page-hero h1 {
  max-width: none;
  font-size: clamp(1.3rem, 2.1vw, 2rem);
}

.passenger-hero h1 {
  max-width: 100%;
  font-size: clamp(1.1rem, 2vw, 1.8rem);
  line-height: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
}

.report-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(260px, 0.72fr);
  gap: 28px;
  align-items: stretch;
  padding: 26px 30px;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.3), transparent 22%),
    linear-gradient(135deg, rgba(18, 79, 145, 0.98), rgba(0, 151, 178, 0.94));
  box-shadow: 0 24px 50px rgba(10, 63, 118, 0.24);
}

.report-hero-copy {
  display: grid;
  align-content: center;
  gap: 10px;
}

.report-hero-copy h1 {
  font-size: clamp(2rem, 3.7vw, 3.25rem);
  line-height: 0.96;
  letter-spacing: -0.045em;
  white-space: normal;
  text-wrap: balance;
}

.report-hero-copy p:not(.eyebrow) {
  max-width: 40ch;
  margin: 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: 1.02rem;
  line-height: 1.6;
}

.report-hero-meta {
  display: grid;
  gap: 12px;
  align-content: center;
}

.report-hero-chip {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(16px);
}

.report-hero-chip strong {
  color: #ffffff;
  font-size: 1rem;
  line-height: 1.2;
}

.page-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 24px;
  margin-top: 24px;
}

.free-map-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.72fr);
  gap: 24px;
  align-items: center;
  padding: 0 32px;
}

.free-map-hero h1 {
  max-width: none;
  white-space: normal;
  line-height: 1;
  font-size: clamp(1.6rem, 2.6vw, 2.6rem);
  text-wrap: balance;
  letter-spacing: -0.04em;
  margin-bottom: 10px;
}

.free-map-hero > div {
  max-width: 760px;
}

.free-map-hero > div > p:not(.eyebrow) {
  max-width: 58ch;
  margin-top: 8px;
  font-size: 0.95rem;
}

.free-map-check-list {
  margin-top: 10px;
}

.free-map-check-list.check-list li + li {
  margin-top: 6px;
}

.free-map-check-list li,
.free-map-hero p,
.free-map-promise p {
  color: rgba(255, 255, 255, 0.9);
}

.free-map-promise {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.18);
  padding: 24px 22px;
}

.free-map-promise h2,
.free-map-promise p {
  color: #ffffff;
}

.free-map-promise h2 {
  max-width: 14ch;
  font-size: clamp(1.2rem, 2vw, 1.75rem);
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin-bottom: 8px;
}

.free-map-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(290px, 0.9fr);
  gap: 24px;
  margin-top: 24px;
}

.free-map-sidebar {
  display: grid;
  gap: 24px;
}

.free-map-panel-header {
  align-items: flex-start;
  margin-bottom: 24px;
}

.free-map-panel-header h2 {
  font-size: clamp(0.8rem, 1.3vw, 1.05rem);
}

.free-map-preview,
.free-map-upgrade {
  padding: 24px;
}

.free-map-consent-note {
  margin: 18px auto 0;
  max-width: 52ch;
  font-size: 0.84rem;
  line-height: 1.45;
  color: var(--muted);
  text-align: center;
}

.free-map-form-actions {
  justify-content: center;
  margin-top: 18px;
  margin-bottom: 0;
}

.free-map-form-actions .form-submit {
  box-shadow: none;
}

.free-map-image {
  width: 100%;
  margin-top: 18px;
  border-radius: 18px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  background: rgba(255, 255, 255, 0.92);
}

.free-map-bodygraph-preview {
  margin-top: 18px;
  padding: 12px;
  width: 100%;
  box-sizing: border-box;
  border-radius: 18px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  background: rgba(255, 255, 255, 0.92);
}

.free-map-bodygraph-preview .bodygraph-canvas {
  padding: 0;
  width: 100%;
  min-height: auto;
}

.free-map-bodygraph-preview .bodygraph-background {
  width: min(100%, 620px);
  max-width: 620px;
  top: 50%;
}

.free-map-bodygraph-preview .bodygraph-svg {
  width: min(100%, 460px) !important;
  max-width: 460px !important;
  max-height: none;
  transform: scale(0.97);
  transform-origin: center center;
}

.panel-header,
.list-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.row-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.row-actions form {
  display: flex;
  align-items: center;
}

.stack-list {
  display: grid;
  gap: 0;
  margin-top: 10px;
  padding-top: 0;
}

.library-panel-header {
  position: relative;
  justify-content: center;
}

.library-panel-header > div {
  text-align: center;
}

.library-panel-header > .button {
  position: absolute;
  right: 0;
}

.list-card {
  padding: 18px 0;
  border-top: 1px solid rgba(26, 107, 181, 0.12);
}

.list-card:first-child {
  border-top: 0;
  padding-top: 0;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 10px;
}

.map-dst-block {
  margin: 16px 0;
  padding: 14px 16px;
  border: 1px solid #f9a825;
  border-radius: 8px;
  background: #fff8e1;
}

.map-dst-description {
  font-size: 0.9rem;
  color: #bf360c;
  margin-bottom: 12px;
  line-height: 1.5;
}

.map-dst-choices {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.map-dst-option {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text);
}

.map-dst-radio {
  width: 18px;
  height: 18px;
  margin: 0;
  flex-shrink: 0;
}

.map-dst-note { font-size: 0.82rem; color: #e65100; font-style: italic; }

.auth-switch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 18px;
  padding: 6px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  border-radius: 18px;
  background: rgba(239, 246, 255, 0.78);
}

.auth-switch-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 132px;
  padding: 12px 18px;
  border-radius: 14px;
  color: var(--text);
  font-weight: 700;
  text-decoration: none;
  transition: background-color 180ms ease, color 180ms ease;
}

.auth-switch-link:hover {
  background: rgba(26, 107, 181, 0.08);
}

.auth-switch-link.is-active {
  background: #ffffff;
  color: var(--brand);
}

.checkbox-inline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--text);
  font-weight: 600;
  cursor: pointer;
}

.profile-form .checkbox-inline {
  margin-top: 10px;
}

.checkbox-inline input {
  width: 18px;
  height: 18px;
  margin: 0;
}

.form-helper-link {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.form-helper-link a {
  color: var(--brand);
  text-decoration: none;
  font-weight: 700;
}

.form-helper-link a:hover {
  text-decoration: underline;
}

.form-error-summary {
  margin-bottom: 18px;
  padding: 16px 18px;
  border: 1px solid rgba(201, 73, 73, 0.24);
  border-radius: 16px;
  background: rgba(255, 244, 244, 0.96);
  color: #8a2d2d;
}

.form-error-summary h2 {
  margin: 0 0 10px;
  font-size: 1rem;
}

.form-error-summary ul {
  margin: 0;
  padding-left: 18px;
}

.aside-action {
  margin-top: 18px;
}

.form-submit {
  appearance: none;
  cursor: pointer;
}

.mb-3 {
  margin-bottom: 0;
}

.form-label {
  display: inline-block;
  margin-bottom: 8px;
  color: var(--text);
  font-weight: 700;
}

.form-control,
.form-select {
  width: 100%;
  min-height: 48px;
  padding: 0 14px;
  border: 1px solid rgba(26, 107, 181, 0.16);
  border-radius: 14px;
  background: #ffffff;
  color: var(--text);
  font: inherit;
}

.form-control:focus,
.form-select:focus {
  outline: 2px solid var(--blue, #1a6bb5);
  outline-offset: 2px;
  border-color: rgba(26, 107, 181, 0.42);
  box-shadow: 0 0 0 4px rgba(26, 107, 181, 0.08);
}

input:focus:not(.form-control):not(.form-select),
textarea:focus,
select:focus:not(.form-select) {
  outline: 2px solid var(--blue, #1a6bb5);
  outline-offset: 2px;
}

.place-field {
  position: relative;
}

.place-field-input {
  position: relative;
  z-index: 2;
}

.place-field-feedback {
  margin-top: 8px;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.35;
}

.place-field-hint {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.4;
  font-style: italic;
}

.place-field-results {
  position: absolute;
  top: calc(100% - 6px);
  left: 0;
  right: 0;
  z-index: 15;
  display: grid;
  gap: 0;
  padding: 8px;
  border: 1px solid rgba(26, 107, 181, 0.16);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 36px rgba(26, 107, 181, 0.12);
}

.place-field-option {
  appearance: none;
  width: 100%;
  padding: 10px 12px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.place-field-option:hover {
  background: rgba(26, 107, 181, 0.06);
}

.place-field-option strong,
.place-field-option span {
  display: block;
}

.place-field-option strong {
  font-size: 0.96rem;
  font-weight: 700;
}

.place-field-option span,
.place-field-empty {
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.35;
}

.place-field-empty {
  padding: 10px 12px;
}

.invalid-feedback,
.error_notification {
  color: #c0392b;
  font-size: 0.92rem;
}

.error-text {
  margin-top: 16px;
  color: #c0392b;
  font-weight: 700;
}

.result-panel {
  margin-top: 18px;
  padding: 18px;
  border-radius: 18px;
  background: rgba(26, 107, 181, 0.05);
  border: 1px solid rgba(26, 107, 181, 0.12);
}

.result-panel p + p {
  margin-top: 8px;
}

.activation-table {
  margin-top: 24px;
  border-top: 1px solid rgba(26, 107, 181, 0.12);
}

.activation-heading {
  margin-top: 28px;
  margin-bottom: 10px;
}

.activation-row {
  display: grid;
  grid-template-columns: 1.2fr 1fr 0.6fr 0.6fr;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(26, 107, 181, 0.08);
}

.activation-head {
  color: var(--blue-deep);
  font-weight: 800;
}

.check-list {
  padding-left: 20px;
}

.check-list li + li {
  margin-top: 10px;
}

.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(39, 174, 96, 0.12);
  color: var(--success);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.chart-stage {
  margin-top: 14px;
}

.public-chart-grid {
  align-items: start;
}

.public-chart-note {
  margin-top: 18px;
}

.public-chart-offers {
  display: grid;
  gap: 18px;
}

.public-offer-card {
  padding: 22px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(26, 107, 181, 0.08), rgba(255, 255, 255, 0.96));
  border: 1px solid rgba(26, 107, 181, 0.12);
}

.public-offer-card h3 {
  margin-top: 10px;
}

.public-offer-card p {
  margin: 12px 0 18px;
}

.public-offer-card-secondary {
  background: linear-gradient(180deg, rgba(255, 122, 0, 0.08), rgba(255, 255, 255, 0.96));
}

.chart-layout {
  display: grid;
  grid-template-columns: minmax(180px, 240px) minmax(320px, 1fr) minmax(180px, 240px);
  gap: 28px;
  align-items: center;
  margin-top: 0;
}

.chart-column {
  display: grid;
  gap: 8px;
  align-content: center;
}

.chart-column .section-heading {
  margin-bottom: 0;
  text-align: center;
}

.activation-heading-bottom {
  margin-top: 6px;
}

.compact-table {
  margin-top: 0;
  border: 1px solid rgba(26, 107, 181, 0.18);
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.94);
}

.compact-table .activation-head {
  background: rgba(26, 107, 181, 0.06);
}

.compact-table .activation-row {
  grid-template-columns: 1fr auto;
  gap: 16px;
  padding: 11px 14px;
}

.compact-table .activation-row[data-activation-row] {
  transition: background 180ms ease, box-shadow 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.activation-row-button {
  width: 100%;
  border: 0;
  background: transparent;
  text-align: inherit;
  cursor: pointer;
}

.compact-table .activation-row:last-child {
  border-bottom: 0;
}

.compact-row span:last-child,
.compact-table .activation-head span:last-child {
  text-align: right;
  font-weight: 800;
}

.planet-cell {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.planet-symbol {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.2em;
  font-size: 1.45rem;
  line-height: 1;
}

.table-top-label {
  margin-bottom: 4px;
  text-align: center;
}

.chart-map-placeholder {
  position: relative;
  min-height: 0;
  display: grid;
  place-items: center;
  padding: 0;
  text-align: center;
}

.chart-map-placeholder .eyebrow {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
}

.bodygraph-reference {
  position: relative;
  width: min(100%, 470px);
  display: grid;
  place-items: center;
  transform: none;
  margin-top: 34px;
}

.bodygraph-reference-image {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 14px 28px rgba(26, 107, 181, 0.12));
}

.chart-insights {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 24px;
}

.insight-card {
  padding: 18px 20px;
  border-radius: 18px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  background: rgba(255, 255, 255, 0.9);
}

.insight-card h3 {
  margin-top: 8px;
  font-size: 1.2rem;
  line-height: 1.2;
}

.chart-details {
  margin-top: 24px;
}

.design-tone .eyebrow,
.design-tone h3 {
  color: #d44a43;
}

.personality-tone .eyebrow,
.personality-tone h3 {
  color: var(--text);
}

.design-table .activation-head,
.design-table .activation-row {
  color: #d44a43;
}

.personality-table .activation-head,
.personality-table .activation-row {
  color: var(--text);
}

.design-table .activation-head {
  background: rgba(212, 74, 67, 0.08);
}

.personality-table .activation-head {
  background: rgba(31, 42, 54, 0.05);
}

.design-table .activation-row span,
.personality-table .activation-row span {
  font-weight: 700;
}

.design-table .activation-row.is-center-linked,
.personality-table .activation-row.is-center-linked,
.home-transit-gate-row.is-center-linked {
  position: relative;
  background: rgba(0, 194, 255, 0.12);
  box-shadow: inset 4px 0 0 #00c2ff;
}

.design-table .activation-row.is-activation-hovered,
.personality-table .activation-row.is-activation-hovered,
.home-transit-gate-row.is-activation-hovered {
  position: relative;
  background: rgba(0, 194, 255, 0.18);
  box-shadow:
    inset 5px 0 0 #00c2ff,
    0 0 0 1px rgba(0, 194, 255, 0.14);
  transform: translateX(1px);
}

.library-card {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.65fr) auto;
  align-items: center;
  gap: 24px;
  padding: 18px 24px;
  border: 0;
  border-top: 1px solid rgba(26, 107, 181, 0.12);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.list-card.library-card {
  padding: 18px 24px;
}

.library-search-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;
  margin-bottom: 12px;
}

.library-search-shell {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: 60px;
  padding: 0 18px;
  border-radius: 22px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  background:
    radial-gradient(circle at top left, rgba(244, 196, 107, 0.1), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 249, 250, 0.98));
  box-shadow: 0 18px 36px rgba(26, 107, 181, 0.06);
}

.library-search-shell:focus-within {
  border-color: rgba(26, 107, 181, 0.28);
  box-shadow: 0 22px 42px rgba(26, 107, 181, 0.1);
}

.library-search-icon {
  color: var(--blue);
  font-size: 1.25rem;
  line-height: 1;
}

.library-search-input {
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text);
  font-size: 1rem;
  font-weight: 500;
  outline: none;
}

.library-search-input::placeholder {
  color: rgba(31, 42, 54, 0.48);
}

.library-search-status {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 600;
  white-space: nowrap;
}

.library-search-status strong {
  color: var(--blue-deep);
}

.library-card-copy {
  display: flex;
  min-width: 0;
  flex-direction: column;
  justify-content: center;
  align-self: center;
  gap: 0;
  padding-top: 0;
}

.library-card-copy h3,
.library-card-copy p {
  margin: 0;
}

.library-card-copy h3 {
  font-size: clamp(1.05rem, 1.6vw, 1.26rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--text);
}

.library-card-name-link {
  color: inherit;
  text-decoration: none;
}

.library-card-name-link:hover {
  color: var(--blue);
}

.library-card-side {
  display: flex;
  min-width: 0;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
}

.library-card-type {
  margin: 0;
  color: var(--text);
  font-size: 0.98rem;
  font-weight: 500;
  line-height: 1.3;
}

.library-actions {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-self: center;
  margin: 0;
  gap: 0;
  max-width: none;
}

.library-actions .button,
.library-actions form {
  flex-shrink: 0;
  margin: 0;
}

.library-action-button {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  line-height: inherit;
}

.library-action-delete-form {
  display: flex;
  align-items: center;
}

.library-action-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: rgba(31, 42, 54, 0.54);
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
}

.library-action-icon:hover {
  color: #d04948;
  background: transparent;
}

.library-delete-icon {
  width: 24px;
  height: 24px;
  display: block;
}

.library-card-primary {
  background: rgba(26, 107, 181, 0.02);
  box-shadow: none;
}

.stack-list .library-card:first-child {
  border-top: 1px solid rgba(26, 107, 181, 0.12);
}

.library-chip {
  color: var(--blue);
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

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

.report-offers-grid {
  margin-top: 24px;
}

.report-offer-card {
  display: grid;
  gap: 16px;
}

.report-offer-card h2 {
  font-size: clamp(1.7rem, 2.4vw, 2.2rem);
}

.report-offer-price {
  color: var(--blue-deep);
  font-size: 1.5rem;
  font-weight: 800;
}


.sales-chart-context {
  margin-top: 10px;
  color: var(--blue);
  font-weight: 600;
}

.sales-callout {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(280px, 0.9fr);
  gap: 24px;
  align-items: center;
  margin-top: 24px;
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.2), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 249, 255, 0.94));
}

.sales-callout h2 {
  margin-bottom: 10px;
}

.sales-callout-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.sales-ownership-panel {
  display: grid;
  gap: 10px;
  margin-top: 24px;
}

.sales-ownership-panel h2 {
  margin: 0;
}

.sales-offers-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 28px;
  align-items: stretch;
}

.sales-offer-card {
  position: relative;
  min-height: 100%;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
}

.sales-offer-card.is-featured {
  border-color: rgba(255, 122, 0, 0.18);
  background:
    radial-gradient(circle at top right, rgba(255, 122, 0, 0.16), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(255, 248, 242, 0.98));
}

.sales-offer-card.is-selected {
  border-color: rgba(26, 107, 181, 0.26);
  background:
    radial-gradient(circle at top right, rgba(26, 107, 181, 0.12), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(244, 249, 255, 0.98));
}

.sales-offer-card.is-premium {
  border-color: rgba(11, 33, 71, 0.14);
  background:
    radial-gradient(circle at top right, rgba(11, 33, 71, 0.12), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(245, 247, 252, 0.98));
}

.sales-offer-head {
  display: grid;
  gap: 10px;
}

.sales-offer-head h2 {
  font-size: clamp(1.45rem, 2vw, 1.9rem);
}

.sales-offer-subtitle {
  margin: 0;
  color: var(--blue-deep);
  font-size: 0.98rem;
  font-weight: 700;
  line-height: 1.45;
}

.sales-offer-description {
  font-size: 0.98rem;
  line-height: 1.5;
}

.sales-offer-section {
  display: grid;
  gap: 8px;
}

.sales-offer-section > strong {
  color: var(--blue-deep);
  font-size: 0.88rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.sales-offer-list {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.5;
}

.sales-offer-audience,
.sales-offer-close p {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.55;
}

.sales-offer-ownership {
  color: var(--blue);
  font-weight: 700;
}

.sales-offer-card .button,
.sales-offer-card form {
  align-self: end;
}

.sales-compare-panel {
  display: grid;
  gap: 18px;
  margin-top: 28px;
}

.sales-compare-head h2 {
  margin-bottom: 0;
}

.sales-compare-table {
  display: grid;
  border: 1px solid rgba(26, 107, 181, 0.12);
  border-radius: 24px;
  overflow: hidden;
}

.sales-compare-row {
  display: grid;
  grid-template-columns: minmax(220px, 1.25fr) repeat(3, minmax(140px, 1fr));
}

.sales-compare-row > div {
  padding: 16px 18px;
  border-top: 1px solid rgba(26, 107, 181, 0.1);
  background: rgba(255, 255, 255, 0.94);
}

.sales-compare-row-head > div {
  border-top: 0;
  background: rgba(244, 248, 255, 0.96);
  color: var(--blue);
  font-weight: 800;
}

.sales-compare-row > div[role="rowheader"] {
  color: var(--text);
  font-weight: 700;
}

.subscriptions-hero {
  display: grid;
  gap: 8px;
  padding-block: 8px;
}


.subscriptions-hero-tagline {
  margin: -4px 0 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 1.05rem;
  font-style: italic;
  line-height: 1.3;
}

.subscriptions-hero .hero-sub {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.55;
}

.subscriptions-hero-detail {
  margin: 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.88rem;
  line-height: 1.5;
}

.subscriptions-hero .hero-proof {
  margin: 0;
  color: rgba(31, 43, 63, 0.72);
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.35;
}

.subscriptions-hero-highlight {
  max-width: 52ch;
  margin: 0;
  color: var(--blue-deep);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.35;
}

.subscriptions-hero-actions {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 12px;
  margin-top: 0;
}

.subscriptions-difference {
  display: grid;
  gap: 18px;
  margin-top: 28px;
}

.subscriptions-emotional {
  display: grid;
  gap: 12px;
  margin-top: 28px;
  background:
    radial-gradient(circle at top right, rgba(255, 122, 0, 0.12), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(255, 249, 243, 0.96));
}

.subscriptions-emotional h2 {
  margin: 0;
}

.subscriptions-emotional p {
  margin: 0;
  line-height: 1.6;
}

.subscriptions-compare-table .sales-compare-row {
  grid-template-columns: minmax(220px, 1.15fr) repeat(2, minmax(170px, 1fr));
}

.subscriptions-clarity-note {
  margin: 0;
  padding: 18px 20px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  border-radius: 18px;
  background: rgba(244, 248, 255, 0.72);
  color: var(--blue-deep);
  font-weight: 700;
}

.subscriptions-usage-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  margin-top: 28px;
}

.subscriptions-usage-card {
  display: grid;
  gap: 14px;
}

.subscriptions-usage-card h2 {
  margin: 0;
}

.subscriptions-example {
  display: grid;
  gap: 18px;
  margin-top: 28px;
}

.subscriptions-segments {
  display: grid;
  gap: 18px;
  margin-top: 28px;
}

.subscriptions-segments-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.subscriptions-example-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.subscriptions-example-grid .sales-choice-card {
  min-height: 100%;
}

.subscriptions-example-grid .sales-choice-card p {
  margin: 0;
  line-height: 1.5;
}

.subscriptions-plans-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 28px;
  align-items: stretch;
}

.subscriptions-plan-card {
  gap: 18px;
}

.subscriptions-plan-price {
  display: flex;
  align-items: baseline;
  gap: 6px;
}

.subscriptions-plan-price small {
  color: rgba(31, 43, 63, 0.72);
  font-size: 0.94rem;
  font-weight: 700;
}

.subscriptions-plan-savings {
  margin: -6px 0 0;
  color: #ff7a00;
  font-size: 0.92rem;
  font-weight: 800;
}

.subscriptions-plan-anchor {
  margin: -10px 0 0;
  color: var(--blue-deep);
  font-size: 0.92rem;
  font-weight: 800;
}

.subscriptions-plan-anchor-sub {
  margin: 4px 0 0;
  color: var(--text-muted);
  font-size: 0.82rem;
  font-style: italic;
}

.subscriptions-hero-proof-pill {
  cursor: default;
  pointer-events: none;
  white-space: nowrap;
  color: rgba(31, 43, 63, 0.82);
  font-size: 0.92rem;
  font-weight: 700;
}

/* ── Reports page ─────────────────────────────────────── */

.reports-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  margin-top: 8px;
}

.reports-hero-proof-pill {
  cursor: default;
  pointer-events: none;
  color: rgba(31, 43, 63, 0.82);
  font-size: 0.88rem;
  font-weight: 600;
}

.reports-guide {
  display: grid;
  gap: 24px;
}

.reports-guide-head {
  display: grid;
  gap: 10px;
}

.reports-guide-head h2 {
  margin: 0;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.reports-guide-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.reports-guide-card {
  display: grid;
  gap: 10px;
  padding: 20px;
  background: var(--surface-strong);
  border-radius: var(--radius-sm);
  border: 1px solid rgba(31, 42, 54, 0.08);
}

.reports-guide-card strong {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text);
}

.reports-guide-card p {
  margin: 0;
  font-size: 0.875rem;
  color: var(--muted);
  line-height: 1.5;
}

.reports-guide-card-featured {
  border-color: rgba(26, 107, 181, 0.2);
  background: linear-gradient(160deg, rgba(26, 107, 181, 0.04), rgba(255, 255, 255, 0.6));
}

.reports-guide-link {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--blue);
  text-decoration: none;
  align-self: end;
}

.reports-guide-link:hover {
  text-decoration: underline;
}

@media (max-width: 720px) {
  .reports-guide-grid {
    grid-template-columns: 1fr;
  }
}

.subscriptions-hero-secondary-button {
  border-color: rgba(255, 255, 255, 0.78);
  background: rgba(255, 255, 255, 0.96);
  color: var(--blue-deep);
}

.subscriptions-hero-secondary-button:hover {
  border-color: #ffffff;
  background: #ffffff;
  color: var(--blue-deep);
}

.subscriptions-callout {
  grid-template-columns: 1fr;
  margin-top: 28px;
}

@media (max-width: 980px) {
  .subscriptions-usage-grid,
  .subscriptions-plans-grid,
  .subscriptions-example-grid {
    grid-template-columns: 1fr;
  }

  .subscriptions-compare-table .sales-compare-row {
    grid-template-columns: minmax(180px, 1fr) repeat(2, minmax(120px, 1fr));
  }
}

@media (max-width: 720px) {
  .subscriptions-hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .subscriptions-hero-actions .button {
    width: 100%;
    justify-content: center;
  }

  .subscriptions-compare-table {
    overflow-x: auto;
  }

  .subscriptions-compare-table .sales-compare-row {
    min-width: 640px;
  }
}

.flight-testimonials {
  display: grid;
  gap: 24px;
  margin-top: 28px;
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 28%),
    linear-gradient(180deg, rgba(16, 33, 58, 0.98), rgba(22, 46, 77, 0.96));
  color: #f5f7fb;
}

.flight-testimonials .eyebrow,
.flight-testimonials h2,
.flight-testimonials p,
.flight-testimonials strong,
.flight-testimonials span {
  color: inherit;
}

.flight-testimonials-head {
  display: grid;
  gap: 8px;
  max-width: none;
}

.flight-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
}

.flight-testimonial-card {
  display: grid;
  gap: 16px;
  align-content: start;
  min-height: 100%;
  padding: 22px 20px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.04));
  box-shadow: 0 18px 40px rgba(10, 21, 38, 0.22);
  transform: translateY(0);
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
  animation: flightTestimonialLift 520ms ease both;
}

.flight-testimonial-card:nth-child(2) { animation-delay: 70ms; }
.flight-testimonial-card:nth-child(3) { animation-delay: 140ms; }
.flight-testimonial-card:nth-child(4) { animation-delay: 210ms; }
.flight-testimonial-card:nth-child(5) { animation-delay: 280ms; }

.flight-testimonial-card:hover,
.flight-testimonial-card:focus-within {
  transform: translateY(-4px);
  border-color: rgba(244, 196, 107, 0.5);
  box-shadow: 0 24px 48px rgba(10, 21, 38, 0.3);
}

.flight-testimonial-media {
  position: relative;
  display: block;
  padding: 0;
  border: 0;
  border-radius: 18px;
  overflow: hidden;
  background: #0f2034;
  cursor: pointer;
}

.flight-testimonial-media img {
  display: block;
  width: 100%;
  aspect-ratio: 9 / 16;
  object-fit: cover;
  opacity: 0.92;
  transition: transform 240ms ease, opacity 240ms ease;
}

.flight-testimonial-media:hover img,
.flight-testimonial-media:focus-visible img {
  transform: scale(1.03);
  opacity: 1;
}

.flight-testimonial-play {
  position: absolute;
  left: 50%;
  top: 50%;
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(244, 196, 107, 0.9);
  color: #11233a;
  font-size: 1.3rem;
  font-weight: 900;
  transform: translate(-50%, -50%);
  box-shadow: 0 14px 28px rgba(10, 21, 38, 0.28);
}

.flight-testimonial-initial {
  display: inline-grid;
  place-items: center;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(244, 196, 107, 0.95), rgba(218, 162, 49, 0.92));
  color: #11233a;
  font-size: 1.25rem;
  font-weight: 900;
}

.flight-testimonial-copy {
  display: grid;
  gap: 6px;
}

.flight-testimonial-identity {
  display: flex;
  align-items: center;
  gap: 12px;
}

.flight-testimonial-copy h3 {
  margin: 0;
  font-size: 1.16rem;
  line-height: 1.2;
}

.flight-testimonial-city {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.92rem;
}

.flight-testimonial-quote {
  margin: 0;
  color: rgba(255, 255, 255, 0.94);
  font-size: 0.98rem;
  line-height: 1.72;
}

.flight-testimonial-button {
  align-self: end;
  justify-self: start;
  min-width: 100%;
  border-color: rgba(244, 196, 107, 0.8);
  background: linear-gradient(135deg, #f4c46b, #dca136);
  color: #11233a;
  font-weight: 900;
  box-shadow: 0 10px 24px rgba(244, 196, 107, 0.24);
}

.flight-testimonial-button:hover,
.flight-testimonial-button:focus-visible {
  border-color: rgba(255, 255, 255, 0.92);
  background: linear-gradient(135deg, #ffd685, #e8b34a);
  color: #11233a;
}

.flight-testimonials-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.flight-testimonials-stat {
  display: grid;
  gap: 4px;
  min-width: 160px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
}

.flight-testimonials-stat strong {
  font-size: 1.35rem;
  color: #f4c46b;
}

.flight-testimonials-stat span {
  color: rgba(255, 255, 255, 0.76);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.76rem;
}

.flight-testimonial-modal {
  width: min(860px, calc(100vw - 32px));
}

.flight-testimonial-modal-card {
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.98));
}

.flight-testimonial-modal-city {
  margin: 6px 0 0;
  color: var(--muted);
  font-weight: 600;
}

.flight-testimonial-modal-video iframe,
.flight-testimonial-video-placeholder {
  width: 100%;
  aspect-ratio: 9 / 16;
  border: 0;
  border-radius: 20px;
}

.flight-testimonial-video-placeholder {
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.16), transparent 30%),
    linear-gradient(180deg, rgba(16, 33, 58, 0.96), rgba(22, 46, 77, 0.96));
  color: #f5f7fb;
  font-size: 1rem;
  font-weight: 700;
}

.flight-testimonial-modal-quote {
  margin: 0;
  color: var(--blue-deep);
  font-size: 1.05rem;
  line-height: 1.8;
}

.flight-testimonial-modal-note {
  margin: 0;
  color: var(--muted);
}

.booking-confirmed-page {
  display: grid;
  gap: 24px;
}

.booking-confirmed-hero,
.booking-confirmed-panel {
  max-width: 920px;
  margin-inline: auto;
}

.booking-confirmed-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.booking-confirmed-chip {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(26, 107, 181, 0.08);
  border: 1px solid rgba(26, 107, 181, 0.12);
  color: var(--blue-deep);
  font-weight: 700;
}

.booking-confirmed-list {
  margin-top: 16px;
}

.booking-confirmed-modal-card {
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.98));
}

.booking-confirmed-modal-highlight {
  color: var(--blue-deep);
  font-size: 1.04rem;
}

@keyframes flightTestimonialLift {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.report-page-grid {
  grid-template-columns: 1fr;
  align-items: start;
}

.report-content-panel {
  display: grid;
  gap: 20px;
}

.my-reports-search-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 18px;
  border-radius: var(--radius-lg);
  background: #ffffff;
  border: 1.5px solid rgba(26, 107, 181, 0.18);
  box-shadow: 0 2px 8px rgba(10, 40, 80, 0.06);
  margin-bottom: 24px;
}

.my-reports-search-label {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--blue);
  font-size: 0.82rem;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}

.my-reports-search-input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-size: 0.96rem;
  color: var(--text);
  font-family: inherit;
}

.my-reports-search-input::placeholder {
  color: rgba(15, 33, 58, 0.35);
}

.my-reports-search-empty {
  display: block;
  padding: 24px 0;
  color: var(--muted);
  font-size: 0.9rem;
  text-align: center;
}

.my-reports-list {
  display: grid;
  gap: 24px;
}

.my-reports-chart-group {
  display: grid;
  gap: 16px;
}

.my-reports-chart-name {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0;
}

.my-reports-cards {
  display: grid;
  gap: 12px;
}

.my-reports-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  border-radius: 14px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  background: rgba(248, 251, 255, 0.7);
}

.my-reports-card-info {
  display: grid;
  gap: 4px;
}

.my-reports-card-kind {
  font-weight: 700;
  font-size: 0.95rem;
  margin: 0;
}

.my-reports-card-deck {
  font-size: 0.875rem;
  color: var(--text-muted, #666);
  margin: 0;
}

.my-reports-card-date {
  font-size: 0.8rem;
  color: var(--text-muted, #888);
  margin: 0;
}

.my-reports-card-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.my-reports-empty {
  text-align: center;
  display: grid;
  gap: 16px;
  justify-items: center;
}

.report-jump-nav {
  position: sticky;
  top: 16px;
  z-index: 5;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 16px 18px;
  border-radius: 22px;
  border: 1px solid rgba(26, 107, 181, 0.1);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(246, 250, 255, 0.94));
  box-shadow: 0 16px 30px rgba(26, 107, 181, 0.06);
  backdrop-filter: blur(12px);
}

.report-jump-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(26, 107, 181, 0.16);
  background: rgba(255, 255, 255, 0.88);
  color: var(--blue);
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  text-decoration: none;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.report-jump-link:hover,
.report-jump-link:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(26, 107, 181, 0.28);
  background: rgba(255, 255, 255, 1);
  box-shadow: 0 10px 18px rgba(26, 107, 181, 0.08);
}

.report-jump-link.is-active,
.report-jump-link[aria-current="true"] {
  border-color: rgba(26, 107, 181, 0.32);
  background: linear-gradient(135deg, rgba(26, 107, 181, 0.12), rgba(244, 196, 107, 0.18));
  color: var(--blue-deep);
  box-shadow: 0 12px 20px rgba(26, 107, 181, 0.1);
}

.report-panel-header {
  align-items: flex-start;
  padding: 22px 24px;
  border-radius: 24px;
  border: 1px solid rgba(26, 107, 181, 0.08);
  background:
    radial-gradient(circle at top left, rgba(244, 196, 107, 0.12), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(246, 250, 255, 0.92));
  box-shadow: 0 14px 30px rgba(26, 107, 181, 0.06);
}

.report-head-copy {
  display: grid;
  gap: 8px;
}

.report-head-copy h2 {
  font-size: clamp(1.5rem, 2vw, 2.1rem);
  line-height: 1.08;
}

.report-head-deck {
  max-width: 54ch;
  margin: 0;
  color: rgba(21, 34, 56, 0.76);
  font-size: 0.98rem;
  line-height: 1.6;
}

.report-ownership-badge,
.print-report-ownership {
  margin: 6px 0 0;
  font-size: 0.82rem;
  line-height: 1.45;
  color: rgba(21, 34, 56, 0.62);
}

.report-ownership-badge strong,
.print-report-ownership strong {
  color: #15325f;
}

.report-bodygraph-anchor {
  max-width: 340px;
  margin: 0 auto 2rem;
}

.report-bodygraph-anchor svg {
  width: 100%;
  height: auto;
  display: block;
}

/* Cruz mandala in report — wider container + breathing room */
.report-bodygraph-anchor:has(.bodygraph-canvas-cross) {
  max-width: 520px;
}

.report-bodygraph-anchor .bodygraph-canvas-cross.is-mandala-visible {
  padding: 48px 24px;
}

.report-bodygraph-anchor .bodygraph-canvas-cross .bodygraph-svg {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  max-height: none;
}

/* ── Report: Cruz de Encarnação two-column header ───────────────────────── */
.report-cross-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 8px;
  align-items: start;
  margin: 0 0 2rem;
  border-radius: 20px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.08), transparent 40%),
    linear-gradient(160deg, rgba(248, 251, 255, 0.98), rgba(255, 255, 255, 0.98));
  overflow: hidden;
}

.report-cross-info {
  padding: 6px 8px 8px;
}

.report-cross-info-name {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-text, #1a1a2e);
  margin: 0 0 1rem;
  padding: 8px 4px 0;
}

.report-cross-info-list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.report-cross-info-row {
  display: flex;
  gap: 0.5rem;
  font-size: 0.875rem;
  align-items: baseline;
}

.report-cross-info-row dt {
  color: var(--color-text-muted, #6b7280);
  min-width: 6.5rem;
  flex-shrink: 0;
}

.report-cross-info-row dd {
  margin: 0;
  font-weight: 500;
  color: var(--color-text, #1a1a2e);
}

.report-cross-info-row--highlight dd {
  font-weight: 600;
  color: var(--color-primary, #1a6bb5);
}

.report-cross-mandala {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 91px 9px 8px;
}

.report-cross-mandala .bodygraph-canvas-cross {
  width: 100%;
  max-width: 260px;
}

.report-cross-mandala .bodygraph-canvas-cross.is-mandala-visible {
  padding: 25px 0;
}

.report-cross-mandala .bodygraph-canvas-cross .bodygraph-svg {
  width: min(100%, 260px);
  max-width: 260px;
  height: auto;
  aspect-ratio: 1 / 1;
  max-height: none;
  transform: scale(1.15);
  transform-origin: center;
}

.report-content {
  margin: 0;
  padding: 32px;
  border-radius: 28px;
  border: 1px solid rgba(26, 107, 181, 0.1);
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.12), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.98));
  color: var(--text);
  font-family: "Manrope", sans-serif;
  font-size: 1.02rem;
  line-height: 1.78;
  box-shadow: 0 22px 44px rgba(26, 107, 181, 0.08);
}

.report-protected-surface {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.report-watermark-layer {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 48px 36px;
  align-content: space-between;
  justify-items: center;
  padding: 28px 18px;
  pointer-events: none;
  z-index: 0;
}

.report-watermark-stamp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(21, 50, 95, 0.18);
  transform: rotate(-24deg);
  user-select: none;
}

.report-protected-surface .report-rich-content,
.report-protected-surface > *:not(.report-watermark-layer) {
  position: relative;
  z-index: 1;
}

.report-rich-content {
  display: grid;
  gap: 28px;
}

.report-section {
  display: grid;
  gap: 14px;
  padding: 24px 24px 22px;
  border-radius: 24px;
  border: 1px solid rgba(26, 107, 181, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(245, 249, 255, 0.82));
  box-shadow: 0 12px 28px rgba(26, 107, 181, 0.04);
}

.report-section[id] {
  scroll-margin-top: 110px;
}

.report-section:last-child {
  margin-bottom: 0;
}

.report-section h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.52rem;
  line-height: 1.1;
  color: var(--blue-deep);
  letter-spacing: -0.02em;
}

.report-activation-group-design h3,
.report-activation-group-design > p {
  color: #b3261e;
}

.report-activation-group-design li > p:first-child strong,
.report-activation-group-design li > p:nth-child(2) strong,
.report-activation-group-design li > p:nth-child(4) strong,
.report-activation-group-design li > p:nth-child(7) strong,
.report-activation-group-design li > p:nth-child(10) strong {
  color: #b3261e;
}

.report-section p {
  margin: 0;
  max-width: 72ch;
}

.report-section > p:first-of-type {
  font-size: 1.07rem;
  line-height: 1.82;
}

.report-section > p + p {
  color: rgba(21, 34, 56, 0.88);
}

.report-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.report-summary-item {
  display: grid;
  gap: 4px;
  padding: 15px 16px;
  border-radius: 20px;
  background: rgba(26, 107, 181, 0.045);
  border: 1px solid rgba(26, 107, 181, 0.09);
}

.report-summary-label {
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.report-list {
  display: grid;
  gap: 14px;
  margin: 0;
  padding-left: 0;
  list-style: none;
}

.report-list li {
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(26, 107, 181, 0.08);
  line-height: 1.72;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

.report-channel-card {
  display: grid;
  gap: 10px;
}

.report-channel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.report-channel-title {
  color: var(--blue-deep);
  font-size: 1.05rem;
  line-height: 1.45;
}

.report-channel-connection,
.report-channel-meta,
.report-channel-copy {
  margin: 0;
}

.report-channel-connection {
  color: rgba(21, 34, 56, 0.82);
  font-weight: 600;
}

.report-channel-meta {
  font-size: 0.92rem;
  color: rgba(26, 107, 181, 0.9);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.report-channel-copy {
  max-width: 68ch;
}

.report-channel-more {
  flex-shrink: 0;
  min-width: 140px;
}

.report-channel-modal-content[hidden] {
  display: none;
}

.report-channel-modal-section {
  display: grid;
  gap: 8px;
}

.report-channel-modal-section-title {
  margin: 0;
  color: var(--gold);
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.report-side-panel {
  display: grid;
  gap: 16px;
}

.report-side-actions {
  display: grid;
  gap: 12px;
}

.report-side-actions-inline {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
}

.report-side-actions-inline form,
.report-side-actions-inline a {
  width: 100%;
  min-width: 0;
}

.report-side-actions-inline .button,
.report-side-actions-inline form .button {
  width: 100%;
}

.report-section:nth-child(1),
.report-section:nth-child(4),
.report-section:nth-child(7),
.report-section:nth-child(10) {
  background:
    radial-gradient(circle at top left, rgba(244, 196, 107, 0.1), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(246, 250, 255, 0.88));
}

.workspace-page {
  padding: 0 0 18px;
}

.workspace-upgrade-banner-shell {
  background: #ffffff;
  border-bottom: 0.5px solid #e5e7eb;
}

.workspace-shell {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) 250px;
  gap: 16px;
  align-items: start;
  width: min(100%, 1648px);
  margin-inline: auto;
}

.workspace-sidebar,
.workspace-main,
.workspace-panel {
  min-height: calc(100vh - 132px);
}

.workspace-panel {
  position: sticky;
  top: 88px;
}

.workspace-sidebar,
.workspace-panel,
.workspace-main {
  display: grid;
  gap: 18px;
}

.workspace-sidebar {
  grid-template-rows: auto auto;
  align-content: start;
  align-self: start;
  justify-items: center;
  position: static;
  height: auto;
  min-height: 0;
  max-height: none;
  padding: 20px 10px;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at top left, rgba(244, 196, 107, 0.22), transparent 22%),
    linear-gradient(180deg, rgba(22, 61, 115, 0.98), rgba(26, 107, 181, 0.96));
  box-shadow: var(--shadow);
  text-align: center;
}

.workspace-sidebar-chart {
  position: static !important;
  top: auto !important;
  align-self: start !important;
  max-height: none !important;
  height: calc(100vh - 96px) !important;
  min-height: calc(100vh - 96px);
  margin-top: 0;
  transform: translateY(-1%);
  padding: 8px 4px;
  overflow-y: auto;
  overflow-x: hidden;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: space-evenly !important;
  background:
    radial-gradient(circle at top left, rgba(244, 196, 107, 0.22), transparent 22%),
    linear-gradient(180deg, rgba(22, 61, 115, 0.98), rgba(26, 107, 181, 0.96));
  box-shadow: var(--shadow);
  border-radius: var(--radius-lg);
}

.workspace-page .workspace-shell.workspace-shell-app > .workspace-sidebar.workspace-sidebar-chart {
  position: static !important;
  top: auto !important;
  align-self: auto !important;
  max-height: none !important;
  margin-top: 0 !important;
  transform: translateY(-1%) !important;
}

.workspace-sidebar-head {
  display: grid;
  justify-items: center;
  gap: 6px;
}

.workspace-sidebar-head h2,
.workspace-sidebar-head p,
.workspace-sidebar-section p,
.workspace-sidebar strong,
.workspace-sidebar span {
  color: #ffffff;
}

.workspace-sidebar-head h2 {
  margin: 6px 0 0;
  font-size: 1.28rem;
  line-height: 1.05;
  max-width: 8ch;
}

.workspace-sidebar-head p:not(.eyebrow) {
  margin: 8px 0 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.76rem;
  line-height: 1.4;
  max-width: 16ch;
}

.workspace-sidebar-actions {
  display: grid;
  gap: 12px;
  width: 100%;
  align-content: start;
  justify-items: center;
  margin-top: 8px;
}

.workspace-button {
  width: 100%;
}

.workspace-sidebar .workspace-button {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  margin-inline: auto;
  padding-inline: 12px;
  font-size: 0.82rem;
  border-radius: 10px;
}

.workspace-sidebar .button-primary.workspace-button {
  box-shadow: 0 10px 24px rgba(255, 122, 0, 0.2);
}

.workspace-sidebar .button-secondary,
.workspace-sidebar .button-outline {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.24);
  color: #ffffff;
}

.workspace-sidebar-next-step {
  display: grid;
  gap: 10px;
  width: 100%;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.workspace-sidebar-next-step .eyebrow {
  margin: 0;
  opacity: 0.86;
}

.workspace-sidebar-onboarding {
  display: grid;
  gap: 10px;
  width: 100%;
  margin-top: 14px;
  padding: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.06);
}

.workspace-sidebar-onboarding[hidden] {
  display: none;
}

.workspace-sidebar-onboarding-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.workspace-sidebar-onboarding-head .eyebrow {
  margin: 0;
  opacity: 0.86;
}

.workspace-sidebar-onboarding-dismiss {
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.5);
  font-size: 1.1rem;
  cursor: pointer;
  line-height: 1;
  padding: 0 2px;
}

.workspace-sidebar-onboarding-dismiss:hover {
  color: rgba(255, 255, 255, 0.9);
}

.workspace-sidebar-onboarding-steps {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.workspace-sidebar-onboarding-steps li {
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.4;
}

.workspace-sidebar-next-step-title {
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.3;
}

.workspace-sidebar-next-step-body {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.8rem;
  line-height: 1.4;
}

.workspace-sidebar-next-step-actions {
  display: grid;
  gap: 10px;
  width: 100%;
}

.workspace-sidebar-next-step-actions .button {
  width: 100%;
  min-width: 0;
}

.workspace-sidebar-chart::-webkit-scrollbar {
  width: 6px;
}

.workspace-sidebar-chart::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.24);
  border-radius: 999px;
}

.workspace-sidebar-next-step-actions .button-outline {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.24);
  color: #ffffff;
}

.workspace-library {
  display: grid;
  gap: 10px;
}

.workspace-library-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 15px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  transition: transform 180ms ease, background 180ms ease, border-color 180ms ease;
}

.workspace-library-card:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.12);
}

.workspace-library-card.is-active {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 184, 0, 0.42);
}

.workspace-library-card.is-primary {
  box-shadow: inset 0 0 0 1px rgba(255, 184, 0, 0.3);
}

.workspace-library-copy {
  display: grid;
  gap: 4px;
}

.workspace-library-copy strong {
  font-size: 0.84rem;
  line-height: 1.2;
}

.workspace-library-copy span {
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.72rem;
}

.workspace-library-badge {
  color: var(--yellow);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.workspace-main {
  min-width: 0;
}

.workspace-stage {
  display: grid;
  gap: 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 249, 250, 0.98));
}

.workspace-shell-app {
  grid-template-columns: 52px minmax(0, 1fr) 400px;
  gap: 8px;
}

.home-transit-shell.workspace-shell-app {
  --bg-max-h: calc(100vh - 155px);
  --bg-rail-w: 104px;
  --bg-rail-gap: 14px;
  width: min(100%, 1648px);
  grid-template-columns: minmax(0, 1fr) 210px;
  gap: 8px;
  align-items: start;
}

.home-transit-shell.workspace-shell-app > .workspace-panel {
  max-width: none;
}

.workspace-shell-app > aside.workspace-panel.content-panel.workspace-panel-app {
  width: min(100%, 300px);
  margin-top: -96px !important;
  transform: none;
}

.workspace-page:not(.workspace-page-demo) .workspace-shell-app > aside.workspace-panel.content-panel.workspace-panel-app {
  width: 100%;
  max-width: none;
  margin-top: -96px !important;
  justify-self: stretch;
}

.workspace-stage-app {
  position: relative;
  height: calc(100vh - 96px);
  min-height: calc(100vh - 96px);
  margin-top: -1%;
  align-content: start;
  padding: 12px 14px 14px;
  overflow: visible;
}

.home-transit-stage.workspace-stage-app {
  margin-top: -1%;
  height: calc(100vh - 96px);
  min-height: calc(100vh - 96px);
  overflow: hidden;
}

.workspace-wide-row {
  grid-column: 2 / 4;
  min-width: 0;
}

.workspace-split-row {
  grid-column: 1 / -1;
  width: 100vw;
  margin-left: calc(50% - 50vw);
}

.workspace-split-row .split-bodygraph-section {
  width: 100%;
}

.mc-chart-reports-wrapper {
  grid-column: 1 / -1;
}

.workspace-app-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.workspace-app-head.home-transit-head {
  justify-content: center;
  text-align: center;
}

.workspace-mandala-name {
  display: block;
  position: absolute;
  bottom: 18px;
  right: 18px;
  font-size: 0.58rem;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.45;
  text-align: right;
  margin-top: 0;
  pointer-events: none;
}

.workspace-stage-app:has(.bodygraph-canvas.is-mandala-visible) {
  align-content: start;
}

.workspace-stage-app:has(.bodygraph-canvas.is-mandala-visible) .workspace-map-app {
  height: auto;
}

.workspace-page:not(.workspace-page-demo) .workspace-stage-app:not(:has(.bodygraph-canvas.is-mandala-visible)) .workspace-map-app {
  transform: translateY(10%);
}

.workspace-stage:has(.bodygraph-canvas.is-mandala-visible) .workspace-app-head > div:first-child {
  display: none;
}

.workspace-stage:has(.bodygraph-canvas.is-mandala-visible) .workspace-app-head {
  justify-content: flex-end;
  margin-bottom: 0;
}

.workspace-stage:has(.bodygraph-canvas.is-mandala-visible) .workspace-mandala-name {
  display: block;
  position: absolute;
  bottom: 18px;
  right: 18px;
  font-size: 0.58rem;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.45;
  text-align: right;
  margin-top: 0;
  pointer-events: none;
}

.workspace-stage:has(.bodygraph-canvas.is-mandala-visible) .workspace-bodygraph-download,
.workspace-stage:has(.bodygraph-canvas.is-mandala-visible) .workspace-report-cta {
  display: none;
}

.workspace-app-head-actions {
  display: flex;
  justify-content: flex-end;
  flex: 0 0 auto;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.workspace-app-head-actions .button {
  min-height: 22px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 0.61rem;
  line-height: 1;
  letter-spacing: 0.01em;
}

.workspace-mandala-toggle {
  min-width: 72px;
  padding-inline: 8px;
  white-space: nowrap;
  border-color: rgba(15, 33, 58, 0.14);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(238, 243, 247, 0.92)),
    radial-gradient(circle at top left, rgba(198, 154, 74, 0.18), transparent 52%);
  box-shadow: 0 12px 28px rgba(15, 33, 58, 0.1);
}

.workspace-mandala-toggle.is-active,
.workspace-mandala-toggle[aria-pressed="true"] {
  color: #0f1f31;
  border-color: rgba(167, 121, 39, 0.42);
  background:
    linear-gradient(135deg, rgba(253, 248, 237, 0.98), rgba(244, 232, 206, 0.96)),
    radial-gradient(circle at top left, rgba(193, 135, 34, 0.24), transparent 56%);
  box-shadow: 0 16px 32px rgba(143, 106, 42, 0.18);
}

.workspace-mandala-layer-controls {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 180ms ease, transform 180ms ease;
}

.workspace-mandala-layer-controls[hidden] {
  display: none;
}

.workspace-mandala-layer-controls.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.workspace-mandala-layer-toggle {
  min-width: 90px;
  color: rgba(15, 31, 49, 0.76);
  border-color: rgba(15, 33, 58, 0.12);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 8px 20px rgba(15, 33, 58, 0.06);
}

.workspace-mandala-layer-toggle.is-active,
.workspace-mandala-layer-toggle[aria-pressed="true"] {
  color: #0f1f31;
  border-color: rgba(102, 138, 154, 0.32);
  background:
    linear-gradient(135deg, rgba(242, 248, 250, 0.96), rgba(228, 238, 242, 0.94)),
    radial-gradient(circle at top left, rgba(102, 138, 154, 0.16), transparent 58%);
  box-shadow: 0 12px 24px rgba(64, 94, 116, 0.12);
}

.workspace-report-cta {
  min-width: 72px;
  padding-inline: 8px;
  white-space: nowrap;
  box-shadow: 0 10px 24px rgba(255, 122, 0, 0.2);
}

.workspace-visualize-wrapper {
  position: relative;
  display: none;
}

.workspace-stage:has(.bodygraph-canvas.is-mandala-visible) .workspace-visualize-wrapper {
  display: inline-flex;
}

.workspace-stage:has(.workspace-bodygraph.is-cross-visible) .workspace-visualize-wrapper {
  display: inline-flex;
}

.workspace-visualize-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(15, 33, 58, 0.12);
  padding: 6px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 180px;
  z-index: 50;
}

.workspace-visualize-dropdown[hidden] {
  display: none;
}

.workspace-visualize-dropdown .button {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  text-align: left;
  border-radius: 8px;
  white-space: nowrap;
}

.dropdown-divider {
  height: 1px;
  background: var(--line);
  margin: 2px 0;
}

.workspace-visualize-dropdown [data-mandala-layer-controls] {
  display: flex !important;
  flex-direction: column;
  gap: 4px;
  opacity: 1 !important;
  transform: none !important;
}

.workspace-visualize-dropdown [data-mandala-layer-controls][hidden] {
  display: none;
}

.workspace-app-head h1 {
  margin-top: 4px;
  font-size: 1.32rem;
  line-height: 1.05;
  white-space: nowrap;
  color: var(--blue-deep);
}

.workspace-map-app {
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr) 190px;
  align-items: start;
  justify-content: center;
  gap: 18px;
  min-height: 0;
  height: calc(100% - 44px);
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}

.workspace-map-app.is-planets-hidden {
  grid-template-columns: minmax(0, 1fr);
}

.workspace-map-app.is-planets-hidden .workspace-rail {
  display: none;
}

.workspace-rail {
  display: grid;
  grid-template-rows: 1fr auto;
  align-content: stretch;
  gap: 0;
  align-self: stretch;
  padding-top: 0;
  margin-top: -22px;
  min-width: 0;
}

.workspace-rail .table-top-label {
  text-align: center;
  margin-bottom: 0;
  font-size: 0.68rem;
}

.workspace-rail-main {
  display: grid;
  align-content: start;
  gap: 6px;
  padding-top: 0;
}

.app-rail-table {
  margin-top: 0;
  width: 100%;
  border-radius: 14px;
}

.app-rail-table .activation-row {
  grid-template-columns: 1fr;
  gap: 0;
  padding: 4px 6px;
}

.app-rail-table .planet-cell {
  justify-content: center;
  gap: 4px;
  font-size: 0.72rem;
  line-height: 1.1;
}

.app-rail-table .planet-symbol {
  font-size: 1.3rem;
}

.workspace-rail .table-top-label {
  font-size: 0.52rem;
  letter-spacing: 0.04em;
}

.workspace-rail-footer {
  margin: 6px 0 0;
  text-align: center;
  font-size: 0.48rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.25;
  padding-bottom: 6px;
}

.workspace-rail-footer-design {
  color: #e14b40;
}

.workspace-rail-footer-personality {
  color: #2a3445;
}

.workspace-bodygraph {
  display: grid;
  place-items: center;
  text-align: center;
  min-width: 0;
  width: 100%;
}

.workspace-bodygraph-download {
  justify-content: center;
}

.app-bodygraph {
  min-height: 0;
  align-self: start;
}

.app-bodygraph .bodygraph-canvas {
  overflow: visible;
}

.app-bodygraph .bodygraph-svg {
  width: min(100%, 1120px);
  max-width: 1120px;
  transform: translateY(-8px) scale(1.02);
  transform-origin: center top;
}

.workspace-page:not(.workspace-page-demo) .workspace-map-app {
  grid-template-columns: var(--bg-rail-w) minmax(0, 1fr) var(--bg-rail-w);
  gap: var(--bg-rail-gap);
}

.workspace-page:not(.workspace-page-demo) .workspace-map-app.is-planets-hidden {
  grid-template-columns: minmax(0, 1fr);
}

.workspace-page:not(.workspace-page-demo) .app-bodygraph .bodygraph-svg {
  width: min(100%, calc(var(--bg-max-w) * var(--bg-chart-scale)));
  max-width: calc(var(--bg-max-w) * var(--bg-chart-scale));
  max-height: calc(var(--bg-max-h) * var(--bg-chart-scale));
  transform: translateY(-9%) scale(var(--bg-chart-transform-scale));
}

.workspace-page:not(.workspace-page-demo):not(.workspace-page-public) .app-bodygraph .bodygraph-svg {
  transform: translateY(-14%) scale(var(--bg-chart-transform-scale));
}

.workspace-page:not(.workspace-page-demo) .app-bodygraph .bodygraph-background {
  width: min(calc(108% * var(--bg-chart-background-scale)), calc(var(--bg-max-h) * 1.08 * var(--bg-chart-background-scale)));
  max-width: calc(var(--bg-max-h) * 1.08 * var(--bg-chart-background-scale));
  transform: translate(-50%, -50%) scale(1.1246);
}

@keyframes bodygraphFloatA {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, 14px, 0); }
}

@keyframes bodygraphFloatB {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, -16px, 0); }
}

@keyframes bodygraphGridDrift {
  0% { background-position: 0 0, 0 0; }
  100% { background-position: 0 48px, 48px 0; }
}

@keyframes bodygraphWavePulse {
  0%, 100% { opacity: 0.18; transform: translate3d(0, 0, 0); }
  50% { opacity: 0.34; transform: translate3d(0, -8px, 0); }
}

@keyframes bodygraphReveal {
  0% {
    opacity: 0;
    transform: translate3d(0, 16px, 0) scale(0.985);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

.bodygraph-canvas {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 0;
  margin-top: 0;
  padding: 8px 0 14px;
  border-radius: 28px;
  background: transparent;
  border: 0;
  overflow: visible;
}

.workspace-page:not(.workspace-page-demo) .app-bodygraph .bodygraph-canvas.is-mandala-visible {
  padding: 38px 0 38px;
}

.workspace-page:not(.workspace-page-demo) .app-bodygraph .bodygraph-canvas.is-mandala-visible .bodygraph-svg {
  width: min(100%, 1056px);
  max-width: min(calc(100vh - 130px), 1056px);
  height: auto;
  aspect-ratio: 1 / 1;
  max-height: none;
  transform: scale(1.15);
  transform-origin: center;
}

.workspace-page:not(.workspace-page-demo) .app-bodygraph:has(.bodygraph-canvas.is-mandala-visible) {
  align-self: center;
}

.bodygraph-canvas[data-mandala-available="true"] .bodygraph-mandala {
  opacity: 0;
  visibility: hidden;
  transition: opacity 220ms ease, visibility 220ms ease;
}

.bodygraph-canvas .is-mandala-layer-hidden {
  display: none;
}

.bodygraph-canvas[data-mandala-available].is-mandala-visible .bodygraph-mandala {
  opacity: 1 !important;
  visibility: visible !important;
}

.bodygraph-background {
  position: absolute;
  left: 50%;
  top: 47%;
  width: min(155.94%, 1622px);
  height: auto;
  transform: translate(-50%, -50%);
  opacity: 0.17;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  filter: grayscale(1) contrast(1.05);
}

.bodygraph-canvas.is-mandala-visible .bodygraph-background {
  opacity: 0;
  visibility: hidden;
}

.bodygraph-svg {
  position: relative;
  width: min(100%, 1396px);
  max-width: 1396px;
  height: auto;
  max-height: calc(100vh - 110px);
  display: block;
  animation: bodygraphReveal 720ms cubic-bezier(0.22, 1, 0.36, 1);
  overflow: visible;
  z-index: 1;
  shape-rendering: geometricPrecision;
  text-rendering: geometricPrecision;
}

.bodygraph-graph {
  transform-origin: 1000px 1000px;
  transition: transform 320ms ease, opacity 220ms ease;
}

.bodygraph-stage {
  transform-box: fill-box;
  transform-origin: center;
  transition: transform 320ms ease;
}

.bodygraph-canvas.is-mandala-visible .bodygraph-stage {
  transform: translateY(4%) scale(1.43);
}

.bodygraph-canvas.is-mandala-visible .bodygraph-graph {
  transform: scale(var(--bodygraph-mandala-graph-scale, 0.67));
}

.workspace-stage:has(.bodygraph-canvas.is-mandala-visible) .workspace-rail {
  transform: translateY(5%);
}

.bodygraph-graph-silhouette {
  display: none;
  opacity: 1;
  pointer-events: none;
  filter: brightness(0.95);
}

.bodygraph-canvas.is-mandala-visible .bodygraph-graph-silhouette {
  display: block;
}

.bodygraph-mandala-backdrop {
  fill: transparent;
  opacity: 0;
}

.bodygraph-mandala-outer-tick {
  stroke: rgba(18, 24, 32, 0.72);
  stroke-width: 0.76;
  opacity: 0.52;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
  fill: none;
}

.bodygraph-mandala-outer-tick.is-major {
  stroke-width: 1.25;
  opacity: 0.66;
}

.bodygraph-mandala-hexagram {
  pointer-events: none;
}

.bodygraph-mandala-hexagram-line {
  fill: rgba(9, 15, 22, 0.84);
  opacity: 0.74;
}

.bodygraph-mandala-hexagram-hitbox {
  fill: transparent;
  opacity: 0;
}

.bodygraph-mandala-ring {
  fill: none;
  stroke-linecap: round;
  pointer-events: none;
}

.bodygraph-mandala-ring-outer {
  stroke: rgba(18, 25, 35, 0.22);
  stroke-width: 1;
}

.bodygraph-mandala-ring-middle {
  stroke: rgba(18, 26, 38, 0.14);
  stroke-width: 2.4;
}

.bodygraph-mandala-ring-inner {
  stroke: rgba(36, 47, 60, 0.18);
  stroke-width: 1.2;
}

.bodygraph-mandala-ring-core {
  stroke: rgba(46, 58, 72, 0.14);
  stroke-width: 1.1;
}

.bodygraph-mandala-radial,
.bodygraph-mandala-tick {
  stroke: rgba(40, 53, 70, 0.14);
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
}

.bodygraph-mandala-radial {
  stroke-width: 0.9;
  opacity: 0.32;
}

.bodygraph-mandala-zodiac-band-ring {
  fill: none;
  stroke: rgba(18, 26, 38, 0.16);
  stroke-width: 2.4;
  opacity: 0.82;
  pointer-events: none;
}

.bodygraph-mandala-zodiac-segment {
  fill: #f2f2f2;
  stroke: none;
  stroke-width: 0;
  stroke-linecap: round;
  opacity: 1;
  pointer-events: none;
}

.bodygraph-mandala-zodiac-divider {
  stroke: none;
  stroke-width: 0;
  opacity: 0;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
}

.bodygraph-mandala-zodiac-symbol {
  fill: #000000;
  font-family: "Noto Sans Symbols 2", "Segoe UI Symbol", serif;
  font-size: 48px;
  font-weight: 700;
  opacity: 0.9;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.12));
  pointer-events: none;
}

.bodygraph-mandala-zodiac-tick {
  stroke: rgba(19, 25, 32, 0.78);
  stroke-width: 1.05;
  fill: none;
  opacity: 0.58;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
}

.bodygraph-mandala-quarter {
  opacity: 0.52;
  pointer-events: none;
  transition: opacity 180ms ease, filter 180ms ease;
}

.bodygraph-mandala-quarter.is-quarter-hovered {
  opacity: 0.85;
  filter: brightness(1.15) saturate(1.1);
}

.bodygraph-mandala-quarter.quarter-2.is-quarter-hovered,
.bodygraph-mandala-quarter.quarter-3.is-quarter-hovered,
.bodygraph-mandala-quarter.quarter-4.is-quarter-hovered {
  opacity: 0.96;
  filter: brightness(1.28) saturate(1.4);
}

.bodygraph-mandala-quarter.quarter-1 {
  opacity: 0.55;
}

.bodygraph-mandala-quarter.quarter-1.is-quarter-hovered {
  opacity: 0.90;
  filter: brightness(1.22) saturate(1.18);
}

.bodygraph-mandala-quarter-label {
  fill: rgba(15, 22, 35, 0.92);
  font-family: "Manrope", sans-serif;
  font-size: 64px;
  font-weight: 800;
  letter-spacing: 0.12em;
  pointer-events: none;
  text-transform: uppercase;
}

.bodygraph-mandala-gates use[data-bodygraph-item="true"] {
  pointer-events: auto;
  cursor: pointer;
}

.bodygraph-mandala-segment {
  opacity: 0.92;
  stroke: rgba(255, 255, 255, 0.74);
  stroke-width: 0.85;
  vector-effect: non-scaling-stroke;
  transition: opacity 180ms ease, stroke 180ms ease, stroke-width 180ms ease, filter 180ms ease;
}

.bodygraph-mandala-gate.defined {
  opacity: 1;
  stroke: var(--gate-stroke, rgba(28, 40, 56, 0.28));
  stroke-width: 0.55;
  fill: var(--gate-fill);
}

.bodygraph-mandala-gate {
  fill: var(--gate-fill, #ffffff);
  pointer-events: none;
  transition: opacity 180ms ease, stroke 180ms ease, stroke-width 180ms ease, fill 180ms ease, filter 180ms ease;
}

.bodygraph-mandala-gate-beam {
  opacity: 0.55;
  pointer-events: none;
  transition: opacity 220ms ease;
}

.bodygraph-mandala-gate.is-hovered + .bodygraph-mandala-gate-beam,
.bodygraph-mandala-gate.is-activation-linked + .bodygraph-mandala-gate-beam,
.bodygraph-mandala-gates use:focus + .bodygraph-mandala-gate-beam {
  opacity: 0.85;
}

.bodygraph-mandala-gate.is-design {
  fill: var(--gate-fill);
}

.bodygraph-mandala-gate.is-personality {
  fill: var(--gate-fill);
}

.bodygraph-mandala-gate.is-mixed {
  fill: var(--gate-fill);
  stroke: var(--gate-stroke, #111111);
  stroke-width: 0.9;
}

.bodygraph-mandala-label {
  fill: rgba(31, 40, 51, 0.88);
  font-family: "Manrope", sans-serif;
  font-size: 31px;
  font-weight: 900;
  opacity: 0.96;
  transition: fill 180ms ease, transform 180ms ease;
  pointer-events: none;
}


.bodygraph-mandala-planets .bodygraph-mandala-planet-symbol {
  fill: #000000;
  font-family: "Noto Sans Symbols 2", "Segoe UI Symbol", serif;
  font-size: 34px;
  opacity: 0.96;
  filter: drop-shadow(0 2px 3px rgba(255, 255, 255, 0.18));
  pointer-events: none;
}

.bodygraph-mandala-planet.is-design .bodygraph-mandala-planet-symbol {
  fill: #d04948;
}

.bodygraph-mandala-gate.is-hovered,
.bodygraph-mandala-gates use:focus {
  opacity: 1;
  stroke: #00c2ff;
  stroke-width: 2.4;
  fill: var(--gate-fill-hover, var(--gate-fill));
  filter: drop-shadow(0 0 7px rgba(0, 194, 255, 0.28));
}

.bodygraph-mandala-gate.is-activation-linked {
  opacity: 1;
  stroke: #00c2ff;
  stroke-width: 3.2;
  fill: var(--gate-fill-hover, var(--gate-fill));
  filter: drop-shadow(0 0 10px rgba(0, 194, 255, 0.36));
}

.bodygraph-mandala-label.is-hovered,
.bodygraph-mandala-label.is-activation-linked {
  fill: #0f3b78;
}

.bodygraph-channel-track {
  display: block;
  pointer-events: none;
  opacity: 0.86;
}

.bodygraph-channel-highlight {
  display: block;
  pointer-events: none;
}

#gateSegments,
#gateSegments path,
#gateSegments circle {
  pointer-events: none;
}

.bodygraph-gate text {
  font-family: "Manrope", sans-serif;
  font-size: 30px;
  font-weight: 700;
  fill: #111111;
}

.bodygraph-gate circle {
  fill: #6c2ed9;
  stroke: none;
  stroke-width: 0;
  opacity: 0.96;
}

.bodygraph-gate:not(.is-inactive) text {
  fill: #ffffff;
}

.bodygraph-center,
.bodygraph-channel,
.bodygraph-gate {
  cursor: pointer;
}

.bodygraph-gate circle,
.bodygraph-gate text {
  transition: stroke 180ms ease, stroke-width 180ms ease, fill 180ms ease, filter 180ms ease, transform 180ms ease;
}

.bodygraph-center polygon,
.bodygraph-center rect,
.bodygraph-center path,
.bodygraph-center use,
.bodygraph-channel {
  transition: transform 180ms ease, filter 180ms ease, stroke 180ms ease, stroke-width 180ms ease, opacity 180ms ease;
  transform-box: fill-box;
  transform-origin: center;
}

.bodygraph-center.is-hovered polygon,
.bodygraph-center.is-hovered rect,
.bodygraph-center.is-hovered path,
.bodygraph-center.is-hovered use,
.bodygraph-center:focus polygon,
.bodygraph-center:focus rect,
.bodygraph-center:focus path,
.bodygraph-center:focus use {
  filter: drop-shadow(0 6px 14px rgba(26, 107, 181, 0.18));
  transform: scale(1.02);
  stroke: #00c2ff;
  stroke-width: 6;
}

.bodygraph-center.is-activation-linked polygon,
.bodygraph-center.is-activation-linked rect,
.bodygraph-center.is-activation-linked path,
.bodygraph-center.is-activation-linked use {
  filter: drop-shadow(0 10px 20px rgba(26, 107, 181, 0.24));
  transform: scale(1.03);
  stroke: #00c2ff;
  stroke-width: 8;
}

/* ── Hover de porta nas colunas — dimming dos outros centros ── */
.bodygraph-center.is-dimmed {
  opacity: 0.12;
  transition: opacity 0.15s ease;
}

.bodygraph-center.is-activation-linked {
  transition: opacity 0.15s ease;
}

/* ── Hover de porta nas colunas ───────────────────────────────────── */

/* Canais ficam brancos — exceto o canal da porta em hover */
.bodygraph-graph.is-gate-hovered #channels {
  filter: brightness(100) saturate(0);
}
.bodygraph-graph.is-gate-hovered #channelHighlights [data-channel-id]:not(.is-gate-channel-highlighted) {
  filter: brightness(100) saturate(0);
}

/* Silhueta fica branca */
.bodygraph-graph.is-gate-hovered .bodygraph-graph-silhouette {
  filter: brightness(100) saturate(0);
}

/* Centros inativos ficam brancos com contorno cinza via drop-shadow */
.bodygraph-graph.is-gate-hovered .bodygraph-center:not(.is-gate-center-active) {
  filter: brightness(100) saturate(0) drop-shadow(0 0 3px rgba(120, 120, 120, 0.7));
  transition: filter 0.15s ease;
}

/* Centro ativo — sem filter, mostra cor original */
.bodygraph-graph.is-gate-hovered .bodygraph-center.is-gate-center-active {
  filter: none;
  opacity: 1 !important;
}

/* Gates inativos somem */
.bodygraph-graph.is-gate-hovered .bodygraph-gate {
  opacity: 0.06;
  filter: brightness(100) saturate(0);
  transition: opacity 0.15s ease;
}

/* Gate ativo fica visível */
.bodygraph-graph.is-gate-hovered .bodygraph-gate.is-gate-active {
  opacity: 1 !important;
  filter: none;
}

/* ── End hover porta ──────────────────────────────────────────────── */

.bodygraph-center.is-selected polygon,
.bodygraph-center.is-selected rect,
.bodygraph-center.is-selected path,
.bodygraph-center.is-selected use {
  filter: drop-shadow(0 12px 24px rgba(26, 107, 181, 0.28));
  transform: scale(1.03);
  stroke: #00c2ff;
}

.bodygraph-channel-track {
  fill: #f8f8f8;
  stroke: #d5d9df;
  stroke-width: 2.2;
  pointer-events: none;
  opacity: 0.72;
}

.bodygraph-channel-highlight {
  pointer-events: none;
}

.bodygraph-channel-color {
  filter: none;
  pointer-events: none;
}

.bodygraph-channel-mixed-overlay {
  stroke-width: 1.6;
  opacity: 0.92;
}

.bodygraph-graph.is-channel-hovered .bodygraph-gate-segment {
  opacity: 0;
}

.bodygraph-channel {
  cursor: pointer;
  transform-box: fill-box;
  transform-origin: center;
  stroke-width: 3.2;
}

.bodygraph-channel.is-inactive {
  stroke: #ffffff;
}

.bodygraph-channel.is-design {
  stroke: #d8312a;
}

.bodygraph-channel.is-personality {
  stroke: #111111;
}

.bodygraph-channel.is-mixed {
  stroke: #111111;
}

.bodygraph-channel.defined:hover,
.bodygraph-channel.defined.is-hovered,
.bodygraph-channel.defined:focus,
.bodygraph-channel.is-partial:hover,
.bodygraph-channel.is-partial.is-hovered,
.bodygraph-channel.is-partial:focus {
  stroke-width: 6.4;
  filter: drop-shadow(0 0 10px rgba(0, 194, 255, 0.42));
}

.bodygraph-channel.defined:hover + .bodygraph-channel-color,
.bodygraph-channel.defined.is-hovered + .bodygraph-channel-color,
.bodygraph-channel.defined:focus + .bodygraph-channel-color,
.bodygraph-channel.is-partial:hover + .bodygraph-channel-color,
.bodygraph-channel.is-partial.is-hovered + .bodygraph-channel-color,
.bodygraph-channel.is-partial:focus + .bodygraph-channel-color {
  stroke: #00c2ff;
  stroke-width: 5.2;
  filter: drop-shadow(0 0 12px rgba(0, 194, 255, 0.48));
}

.bodygraph-channel.is-selected {
  stroke-width: 6.4;
  filter: drop-shadow(0 0 10px rgba(0, 194, 255, 0.42));
  stroke: #00c2ff;
}

.bodygraph-channel.is-activation-linked {
  stroke-width: 6.4;
  filter: drop-shadow(0 0 10px rgba(0, 194, 255, 0.42));
}

.bodygraph-channel.is-selected + .bodygraph-channel-color,
.bodygraph-channel.is-activation-linked + .bodygraph-channel-color {
  stroke: #00c2ff;
  stroke-width: 5.2;
  filter: drop-shadow(0 0 12px rgba(0, 194, 255, 0.5));
}

.bodygraph-channel:not(.is-active) {
  opacity: 1;
}

.bodygraph-center:focus,
.bodygraph-channel:focus {
  outline: none;
}

.bodygraph-center:focus-visible polygon,
.bodygraph-center:focus-visible rect,
.bodygraph-center:focus-visible path,
.bodygraph-center:focus-visible use,
.bodygraph-channel:focus-visible {
  stroke: #1a6bb5;
  stroke-width: 3.4;
}

.bodygraph-gate.is-hovered circle,
.bodygraph-gate.is-activation-linked circle,
.bodygraph-gate:focus circle {
  stroke: #00c2ff;
  stroke-width: 6;
  filter: drop-shadow(0 0 10px rgba(0, 194, 255, 0.42));
}

.bodygraph-gate.is-hovered text,
.bodygraph-gate:focus text {
  fill: #00c2ff;
}

.workspace-panel-head h2 {
  margin-top: 6px;
  font-size: 1.28rem;
}

.workspace-panel {
  min-height: calc(100vh - 96px);
  max-height: calc(100vh - 96px);
  overflow: hidden;
}

.workspace-panel-app {
  display: flex;
  flex-direction: column;
  position: relative;
  width: 100%;
  min-width: 0;
  min-height: calc(100vh - 96px);
  height: calc(100vh - 96px);
  padding: 0;
  overflow: hidden;
}

.workspace-panel-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2px;
  padding: 6px 8px 0;
  flex-shrink: 0;
}

.workspace-tab {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: 30px;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  color: #6b7b8d;
  font-size: 0.7rem;
  font-weight: 700;
  cursor: pointer;
}

.workspace-tab.is-active {
  border: 1px solid rgba(26, 107, 181, 0.14);
  background: rgba(26, 107, 181, 0.06);
  color: var(--blue-deep);
}

.workspace-tab-phs {
  text-decoration: none;
  opacity: 0.7;
  padding: 0 8px;
}

.workspace-tab-phs:hover {
  opacity: 1;
  color: var(--blue-deep);
}

.workspace-tab-phs--owned {
  opacity: 1;
  color: var(--blue-deep);
}

.workspace-panel-scroll {
  display: grid;
  flex: 1 1 auto;
  gap: 2px;
  min-height: 0;
  padding: 0 10px 4px;
  overflow-y: auto;
}

.workspace-panel-detail[hidden] {
  display: none;
}

.workspace-panel-detail {
  display: grid;
  gap: 4px;
  padding: 0 0 16px;
  border-radius: 0;
  border: 0;
  border-bottom: 1px solid rgba(15, 33, 58, 0.08);
  background: transparent;
}

.workspace-panel-detail h3:empty {
  display: none;
}

.workspace-panel-detail h3 {
  margin: 0;
  color: var(--text);
  font-size: 0.98rem;
}

.workspace-panel-detail-description {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.55;
}

#home-bodygraph-detail-panel .eyebrow:empty,
#home-bodygraph-detail-panel .workspace-panel-detail-description:empty {
  display: none;
}

#home-bodygraph-detail-panel:not(:has(.eyebrow:not(:empty))):not(:has(h3:not(:empty))):not(:has(.workspace-panel-detail-description:not(:empty))):not(:has(.workspace-panel-detail-meta:not([hidden]))) {
  display: none;
}

.workspace-panel-detail-meta {
  display: grid;
  gap: 8px;
}

.workspace-panel-detail-row {
  display: grid;
  gap: 3px;
  padding-top: 8px;
  border-top: 1px solid rgba(26, 107, 181, 0.08);
}

.workspace-panel-detail-row span {
  color: var(--muted);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.workspace-panel-detail-row strong {
  color: var(--text);
  font-size: 0.82rem;
  line-height: 1.35;
}

.workspace-panel-section {
  display: none;
}

.workspace-panel-section.is-active {
  display: block !important;
}

.workspace-panel-group {
  display: grid;
  gap: 8px;
}

.workspace-panel-group + .workspace-panel-group {
  margin-top: 18px;
}

.workspace-panel-block {
  padding: 14px 4px 0;
  border-top: 1px solid rgba(15, 33, 58, 0.08);
}

.workspace-panel-block-trigger {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
}

.workspace-panel-block p {
  margin: 0;
  color: var(--text);
  font-size: 0.98rem;
  line-height: 1.45;
  word-break: break-word;
}

.workspace-gate-panel[hidden] {
  display: none;
}

.workspace-gate-panel {
  position: absolute;
  inset: 12px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 16px;
  padding: 22px 20px;
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(0, 194, 255, 0.12), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 249, 250, 0.98));
  border: 1px solid rgba(26, 107, 181, 0.12);
  box-shadow: 0 24px 60px rgba(14, 33, 58, 0.18);
  z-index: 6;
  overflow: hidden;
}

.workspace-gate-panel-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.workspace-gate-panel-head h3 {
  margin: 4px 0 0;
  font-size: 1.2rem;
  color: var(--blue-deep);
}

.workspace-gate-panel-body {
  color: var(--text);
  font-size: 0.94rem;
  line-height: 1.7;
  min-height: 0;
  padding-right: 8px;
  overflow-y: auto;
}

.workspace-gate-panel-body p {
  margin: 0;
}

.workspace-gate-panel-body p + p {
  margin-top: 12px;
}

.workspace-center-panel-section + .workspace-center-panel-section {
  margin-top: 18px;
}

.workspace-panel-lead {
  display: grid;
  gap: 10px;
  padding: 14px 14px 16px;
  border-radius: 18px;
  background: rgba(26, 107, 181, 0.05);
  border: 1px solid rgba(26, 107, 181, 0.1);
}

.workspace-panel-lead-eyebrow {
  margin: 0;
  color: var(--gold);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.workspace-panel-lead h4 {
  margin: 0;
  color: var(--blue-deep);
  font-size: 1.05rem;
}

.workspace-panel-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.workspace-panel-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(0, 194, 255, 0.1);
  border: 1px solid rgba(0, 194, 255, 0.22);
  color: var(--blue-deep);
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1;
}

.workspace-center-panel-section h4 {
  margin: 0 0 8px;
  color: var(--blue-deep);
  font-size: 0.95rem;
}

.workspace-panel-link-list {
  display: grid;
  gap: 10px;
}

.workspace-panel-link-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  padding: 10px 0;
  border-bottom: 1px solid rgba(15, 33, 58, 0.08);
}

.workspace-panel-link-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.workspace-panel-link-row-stacked {
  grid-template-columns: 1fr;
  gap: 6px;
}

.workspace-panel-link-row-stacked .workspace-panel-link-value {
  justify-content: flex-start;
  text-align: left;
}

.workspace-panel-link-row > span {
  color: rgba(48, 56, 70, 0.78);
  font-size: 0.95rem;
  line-height: 1.4;
}

.workspace-panel-link-value {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  text-align: right;
}

.workspace-panel-inline-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border: 1px solid rgba(26, 107, 181, 0.18);
  border-radius: 999px;
  background: rgba(26, 107, 181, 0.06);
  color: var(--blue-deep);
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.workspace-panel-inline-button:hover {
  background: rgba(0, 194, 255, 0.12);
  border-color: rgba(0, 194, 255, 0.4);
  transform: translateY(-1px);
}

.workspace-gate-panel-actions {
  display: flex;
  justify-content: flex-start;
}

.workspace-token-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
}

.workspace-token {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid rgba(15, 33, 58, 0.12);
  background: rgba(26, 107, 181, 0.04);
  color: var(--text);
  font-size: 0.94rem;
  font-weight: 700;
  line-height: 1;
}

.workspace-token-button {
  cursor: pointer;
}

.workspace-technical-list {
  border-top: 1px solid rgba(15, 33, 58, 0.08);
}

.workspace-technical-row {
  display: grid;
  grid-template-columns: minmax(110px, 132px) minmax(0, 1fr);
  align-items: start;
  gap: 16px;
  width: 100%;
  padding: 16px 4px;
  border-radius: 0;
  border: 0;
  border-bottom: 1px solid rgba(15, 33, 58, 0.08);
  background: transparent;
  text-align: left;
}

.workspace-technical-row span {
  min-width: 0;
  color: var(--text);
  font-size: 0.98rem;
  text-transform: none;
  letter-spacing: normal;
  font-weight: 500;
}

.workspace-technical-row strong {
  min-width: 0;
  color: var(--text);
  font-size: 0.98rem;
  line-height: 1.25;
  font-weight: 700;
  text-align: right;
  white-space: normal;
  overflow-wrap: anywhere;
}

.workspace-technical-row strong span {
  color: inherit;
  font: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
}

.birth-dst-note {
  font-size: 0.8em;
  font-weight: normal;
  color: var(--color-text-muted, #6b7280);
  margin-top: 2px;
  line-height: 1.3;
}

/* ── Banner DST dismissível no workspace ─────────────────── */
.dst-notice-banner {
  background: #f5f5f7;
  border: 2px solid #f97316;
  border-radius: 8px;
  padding: 16px 20px;
  margin: 12px 16px 4px;
}

.dst-notice-content {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dst-notice-header {
  display: flex;
  align-items: center;
  gap: 8px;
}

.dst-notice-icon { font-size: 1.1em; line-height: 1; }

.dst-notice-title {
  font-size: 0.95rem;
  color: #1a1a1a;
  font-weight: 600;
}

.dst-notice-body p {
  font-size: 0.88rem;
  color: #444;
  margin: 0 0 6px;
  line-height: 1.5;
}

.dst-notice-body p:last-child { margin-bottom: 0; }

.dst-notice-dismiss-btn {
  align-self: flex-start;
  background: #fff;
  border: 1px solid #d0d0d3;
  color: #1a1a1a;
  padding: 6px 14px;
  border-radius: 6px;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  margin-top: 8px;
  line-height: 1.4;
}

.dst-notice-dismiss-btn:hover {
  background: #f0f0f3;
  border-color: #b0b0b3;
}

.workspace-technical-row-single {
  grid-template-columns: 1fr;
}

.workspace-technical-row-single strong {
  text-align: left;
}

.workspace-technical-trigger {
  cursor: pointer;
  transition: background-color 180ms ease;
}

.workspace-technical-trigger:hover {
  background: rgba(26, 107, 181, 0.03);
}

.workspace-gate-list-row {
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
}

.workspace-gate-list-row span {
  line-height: 1.45;
}

.term-modal {
  width: min(720px, calc(100vw - 32px));
  padding: 0;
  border: 0;
  background: transparent;
}

.term-modal::backdrop {
  background: rgba(14, 33, 58, 0.42);
  backdrop-filter: blur(4px);
}

.term-modal-backdrop {
  position: fixed;
  inset: 0;
}

.term-modal-card {
  position: relative;
  display: grid;
  gap: 18px;
  padding: 28px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.16), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 249, 250, 0.98));
  border: 1px solid rgba(26, 107, 181, 0.12);
  box-shadow: 0 30px 90px rgba(14, 33, 58, 0.2);
  max-height: min(88vh, 900px);
  overflow-y: auto;
}

.term-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  position: sticky;
  top: 0;
  background: inherit;
  z-index: 1;
  padding-bottom: 4px;
}

.term-modal-card h2 {
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  color: var(--blue-deep);
}

.term-modal-body {
  display: grid;
  gap: 18px;
}

.term-modal-card p:not(.eyebrow) {
  color: var(--text);
  font-size: 1.04rem;
  line-height: 1.75;
}

.term-modal-summary {
  margin: 0;
  font-weight: 600;
  color: var(--blue-deep);
}

.term-modal-section {
  display: grid;
  gap: 8px;
  padding-top: 14px;
  border-top: 1px solid rgba(15, 33, 58, 0.08);
}

.term-modal-section:first-child {
  padding-top: 0;
  border-top: 0;
}

.term-modal-section-title {
  margin: 0;
  color: var(--gold);
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.term-modal-section-body {
  margin: 0;
}

.term-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.term-modal-section--product-cta {
  margin-top: 8px;
  padding-top: 18px;
  border-top: 2px solid rgba(15, 33, 58, 0.1);
}

.term-modal-planet-copy {
  margin: 0 0 12px;
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 1.55;
}

.term-modal-cta-map {
  display: block;
  margin-top: 10px;
  font-size: 0.8rem;
  color: var(--muted);
  text-decoration: none;
  opacity: 0.7;
}

.term-modal-cta-map:hover {
  opacity: 1;
  text-decoration: underline;
}

.term-modal-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(26, 107, 181, 0.14);
  border-radius: 50%;
  background: rgba(26, 107, 181, 0.06);
  color: var(--blue-deep);
  font-size: 1.4rem;
  cursor: pointer;
}

.birth-profile-modal {
  width: min(860px, calc(100vw - 24px));
}

.birth-profile-modal-card {
  gap: 22px;
}

.birth-profile-modal-copy {
  margin: 0;
}

.birth-profile-modal .profile-form {
  display: grid;
  gap: 18px;
}

.term-modal-close-corner {
  position: fixed;
  top: 18px;
  right: 18px;
  opacity: 0;
  pointer-events: none;
}

@media (max-width: 1280px) {
  .workspace-shell,
  .workspace-shell-app {
    grid-template-columns: 72px minmax(0, 1fr) 400px;
  }

  .workspace-map-app {
    grid-template-columns: 120px max-content 120px;
    gap: 18px;
  }

  .workspace-rail-footer {
    font-size: 0.56rem;
    letter-spacing: 0.05em;
  }

  .bodygraph-canvas {
    width: 100%;
    min-height: auto;
  }

  .bodygraph-svg {
    width: min(100%, 567px);
    max-width: 567px;
    height: auto;
    max-height: calc(100vh - 250px);
  }

  .bodygraph-aura-left {
    left: 10%;
  }

  .bodygraph-aura-right {
    right: 8%;
  }
}

@media (max-width: 980px) {
  .site-header,
  .hero,
  .split-section,
  .about-grid,
  .cards-grid,
  .materials-grid,
  .credibility-strip,
  .hero-metrics,
  .page-grid,
  .free-map-hero,
  .free-map-grid,
  .pilot-split {
    grid-template-columns: 1fr;
  }

  .pilot-photo-area {
    max-height: 420px;
  }

  .site-header {
    border-radius: 28px;
    padding: 18px;
  }

  .site-header,
  .site-nav {
    flex-direction: column;
  }

  .header-actions,
  .panel-header,
  .list-card,
  .form-grid {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: stretch;
  }

  .row-actions {
    flex-direction: column;
  }

  .library-card-copy {
    gap: 6px;
  }

  .library-card {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .library-card-side {
    align-items: flex-start;
  }

  .library-search-bar {
    grid-template-columns: 1fr;
  }

  .library-search-status {
    white-space: normal;
  }

  .library-actions {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .library-actions .button,
  .library-actions form,
  .library-actions form .button {
    width: auto;
  }

  .activation-row {
    grid-template-columns: 1fr 1fr;
  }

  .chart-layout {
    grid-template-columns: 1fr;
  }

  .workspace-shell,
  .workspace-shell-app {
    grid-template-columns: 1fr;
  }

  .workspace-wide-row {
    grid-column: 1 / -1;
  }

  .workspace-sidebar,
  .workspace-panel {
    position: static;
    min-height: auto;
    max-height: none;
    overflow: visible;
  }

  .workspace-app-head {
    flex-direction: column;
  }

  .workspace-app-head-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .workspace-mandala-toggle {
    min-width: 0;
  }

  .workspace-mandala-layer-controls {
    width: 100%;
  }

  .workspace-mandala-layer-toggle {
    min-width: 0;
  }

  .workspace-app-head h1 {
    white-space: normal;
  }

  .chart-insights {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .chart-map-placeholder {
    min-height: 420px;
    order: 2;
  }

  .chart-column:first-child {
    order: 1;
  }

  .chart-column:last-child {
    order: 3;
  }

  .site-nav {
    width: 100%;
    align-items: flex-start;
    gap: 12px;
  }

  .home-transit-banner {
    flex-direction: column;
    align-items: flex-start;
  }

  .home-transit-shell {
    grid-template-columns: 1fr;
  }

  .home-transit-banner-actions {
    justify-content: flex-start;
  }

  .home-transit-panel {
    min-height: auto;
    max-height: none;
  }

  .flight-testimonials-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero {
    padding: 36px 22px;
  }

  .free-map-hero {
    padding: 0 24px;
    gap: 20px;
  }

  .free-map-hero h1 {
    font-size: clamp(1.75rem, 4.8vw, 2.35rem);
  }

  .free-map-hero h1 br {
    display: none;
  }

  .free-map-promise h2 {
    max-width: none;
    font-size: clamp(1.45rem, 3.8vw, 1.95rem);
  }

  .free-map-preview,
  .free-map-upgrade {
    padding: 22px;
  }

  .report-hero {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 24px;
  }

  .report-hero-copy h1 {
    font-size: clamp(1.8rem, 4.8vw, 2.6rem);
  }

  .report-panel-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .report-jump-nav {
    position: static;
    padding: 14px;
  }

  .report-head-copy h2 {
    white-space: normal;
  }
}

@media (max-width: 640px) {
  .site-shell {
    width: min(100vw - 24px, 100%);
  }

  h1 {
    font-size: 3.2rem;
  }

  h2 {
    font-size: 2.4rem;
  }

  .hero-card,
  .about-grid article,
  .service-card,
  .material-card,
  .course-list article,
  .manifesto-panel,
  .content-panel,
  .page-hero {
    padding: 22px;
    border-radius: 24px;
  }

  .report-hero-chip {
    padding: 14px 16px;
    border-radius: 18px;
  }

  .report-head-deck {
    font-size: 0.94rem;
  }

  .report-jump-nav {
    gap: 8px;
  }

  .report-jump-link {
    width: 100%;
    justify-content: flex-start;
    padding: 0 16px;
  }

  .home-live-copy h1,
  .home-transit-head h1 {
    font-size: clamp(2rem, 7vw, 2.8rem);
  }

  .home-transit-banner {
    padding: 22px;
  }

  .compact-table .activation-row {
    grid-template-columns: 1fr auto;
  }

  .chart-insights {
    grid-template-columns: 1fr;
  }

  .chart-map-placeholder {
    min-height: 320px;
  }

  .workspace-sidebar,
  .workspace-panel {
    padding: 22px;
  }

  .report-summary-grid {
    grid-template-columns: 1fr;
  }

  .flight-testimonials-grid {
    grid-template-columns: 1fr;
  }

  .flight-testimonial-button {
    width: 100%;
  }

  .workspace-map-app {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .bodygraph-canvas {
    width: 100%;
    min-height: auto;
    padding: 10px 0 12px;
  }

  .bodygraph-svg {
    width: min(100%, 611px);
    max-width: 611px;
    height: auto;
  }

  .bodygraph-mandala-quarter-label {
    font-size: 64px;
  }

  .bodygraph-mandala-label {
    font-size: 30px;
  }

  .bodygraph-grid,
  .bodygraph-wave {
    opacity: 0.12;
  }

  .free-map-hero {
    padding: 0 20px;
  }

  .free-map-hero h1 {
    font-size: clamp(1.55rem, 8.2vw, 2rem);
    line-height: 1.02;
  }

  .free-map-panel-header h2 {
    font-size: 1.6rem;
  }

  .free-map-promise h2 {
    font-size: 1.5rem;
  }

  .free-map-preview,
  .free-map-upgrade {
    padding: 18px;
  }

  .sales-callout {
    grid-template-columns: 1fr;
  }

  .sales-offers-grid {
    grid-template-columns: 1fr;
  }

  .sales-compare-table {
    overflow-x: auto;
  }

  .sales-compare-row {
    min-width: 720px;
  }

  .report-cross-header {
    grid-template-columns: 1fr;
  }

  .report-cross-mandala {
    max-width: 240px;
    margin: 0 auto;
  }
}

.analysis-page {
  display: grid;
  gap: 24px;
}

.analysis-hero,
.analysis-catalog,
.analysis-proof {
  display: grid;
  gap: 24px;
}

.analysis-hero {
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.65fr);
  align-items: stretch;
}

.analysis-hero-copy {
  display: grid;
  gap: 8px;
}

.analysis-hero-copy h1 {
  max-width: 24ch;
  font-size: clamp(1.7rem, 3.1vw, 2.9rem);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.analysis-hero-title {
  max-width: none;
  white-space: normal;
  text-wrap: balance;
}

.analysis-hero-lead {
  max-width: 64ch;
  font-size: 1.12rem;
  color: rgba(31, 43, 63, 0.82);
  margin: 0;
}

.analysis-hero-copy p:last-child {
  margin: 0;
  color: rgba(31, 43, 63, 0.76);
}

.analysis-hero-aside {
  display: flex;
}

.analysis-hero-card {
  display: grid;
  gap: 14px;
  width: 100%;
  padding: 24px;
  border: 1px solid rgba(28, 82, 154, 0.12);
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255, 170, 0, 0.18), transparent 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(246, 250, 255, 0.98));
}

.analysis-hero-card h2 {
  font-size: 1.9rem;
  line-height: 1;
}

.analysis-hero-card p {
  color: rgba(31, 43, 63, 0.78);
}

.analysis-section-head {
  display: grid;
  gap: 8px;
  padding-bottom: 4px;
}

.analysis-section-head h2::after {
  content: "";
  display: block;
  width: 80px;
  height: 3px;
  margin-top: 12px;
  border-radius: 2px;
  background: linear-gradient(90deg, #0097b2, #f4c46b);
}

.analysis-section-head h2 {
  max-width: none;
  font-size: clamp(0.95rem, 1.55vw, 1.45rem);
  line-height: 1.14;
  letter-spacing: -0.05em;
}

.analysis-proof-title {
  max-width: none;
  white-space: nowrap;
}

.analysis-catalog-title {
  max-width: none;
  white-space: nowrap;
}

.analysis-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.analysis-card {
  display: grid;
  grid-template-rows: 160px 1fr auto;
  border: 1px solid rgba(28, 82, 154, 0.1);
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.94);
}

.analysis-card-media {
  position: relative;
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 249, 210, 0.96), rgba(255, 249, 210, 0.18) 28%, transparent 29%),
    radial-gradient(circle at center, rgba(28, 82, 154, 0.15), rgba(28, 82, 154, 0.02) 58%, transparent 60%),
    linear-gradient(135deg, rgba(18, 67, 129, 0.96), rgba(10, 28, 58, 0.94));
}

.analysis-card-media-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.analysis-card.is-connectivity .analysis-card-media {
  background:
    radial-gradient(circle at 34% 42%, rgba(255, 223, 231, 0.96), rgba(255, 223, 231, 0.14) 20%, transparent 21%),
    radial-gradient(circle at 66% 58%, rgba(255, 244, 214, 0.96), rgba(255, 244, 214, 0.14) 22%, transparent 23%),
    linear-gradient(135deg, rgba(69, 113, 178, 0.92), rgba(31, 52, 94, 0.96));
}

.analysis-card.is-family .analysis-card-media {
  background:
    radial-gradient(circle at 32% 60%, rgba(255, 204, 84, 0.88), transparent 18%),
    radial-gradient(circle at 52% 38%, rgba(124, 210, 108, 0.82), transparent 16%),
    radial-gradient(circle at 68% 62%, rgba(255, 255, 255, 0.88), transparent 17%),
    linear-gradient(135deg, rgba(98, 162, 140, 0.96), rgba(33, 74, 70, 0.96));
}

.analysis-card.is-solar .analysis-card-media {
  background:
    radial-gradient(circle at center, rgba(255, 205, 96, 0.95), rgba(255, 205, 96, 0.22) 22%, transparent 23%),
    linear-gradient(135deg, rgba(255, 150, 54, 0.96), rgba(118, 29, 10, 0.96));
}

.analysis-card.is-chiron .analysis-card-media {
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.9), rgba(158, 211, 255, 0.18) 18%, transparent 19%),
    linear-gradient(135deg, rgba(68, 112, 152, 0.96), rgba(17, 31, 54, 0.96));
}

.analysis-card.is-uranus .analysis-card-media {
  background:
    radial-gradient(circle at center, rgba(140, 207, 255, 0.95), rgba(140, 207, 255, 0.16) 20%, transparent 21%),
    linear-gradient(135deg, rgba(39, 63, 110, 0.96), rgba(6, 13, 29, 0.98));
}

.analysis-card.is-saturn .analysis-card-media {
  background:
    radial-gradient(circle at 52% 50%, rgba(240, 199, 109, 0.92), rgba(240, 199, 109, 0.18) 18%, transparent 19%),
    linear-gradient(135deg, rgba(58, 91, 126, 0.96), rgba(18, 31, 48, 0.98));
}

.analysis-card.is-incarnation .analysis-card-media {
  background:
    radial-gradient(circle at center, rgba(255, 245, 191, 0.96), rgba(255, 245, 191, 0.18) 21%, transparent 22%),
    linear-gradient(135deg, rgba(245, 170, 54, 0.96), rgba(79, 20, 8, 0.98));
}

.analysis-card-body {
  display: grid;
  gap: 10px;
  padding: 18px 18px 10px;
}

.analysis-card-body h3 {
  font-size: 1.35rem;
  line-height: 1.04;
}

.analysis-card-subtitle {
  color: #5f7393;
  font-size: 0.95rem;
  font-weight: 700;
}

.analysis-card-body p:last-child {
  color: rgba(31, 43, 63, 0.76);
}

.analysis-card-actions {
  padding: 0 18px 18px;
}

.analysis-card-actions .button {
  width: 100%;
  justify-content: center;
}

.analysis-reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.analysis-reviews-widget-shell {
  display: grid;
}

.analysis-reviews-widget {
  display: grid;
  gap: 22px;
  padding: 22px;
  border: 1px solid rgba(28, 82, 154, 0.1);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.92);
}

.analysis-reviews-widget.is-embed {
  padding: 12px;
}

.analysis-reviews-widget-copy {
  display: grid;
  gap: 8px;
  max-width: 780px;
}

.analysis-reviews-widget-copy strong {
  color: #1f2b3f;
  font-size: 1.08rem;
}

.analysis-reviews-widget-copy p {
  color: rgba(31, 43, 63, 0.72);
  margin: 0;
}

.analysis-review-card {
  display: grid;
  gap: 12px;
  padding: 22px;
  border: 1px solid rgba(28, 82, 154, 0.1);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.94);
}

.analysis-review-head {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 12px;
}

.analysis-review-head > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.review-author-avatar {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  min-width: 42px;
  border-radius: 50%;
  color: #fff;
  font-size: 1.1rem;
  font-weight: 800;
}

.analysis-review-head span {
  color: #6e809d;
  font-size: 0.92rem;
}

.analysis-review-card p {
  color: rgba(31, 43, 63, 0.8);
  font-style: italic;
  line-height: 1.65;
}

.review-stars {
  color: #ff9a00;
  font-size: 0.95rem;
  letter-spacing: 1px;
}

.home-proof-cta {
  display: flex;
  justify-content: center;
  margin-top: 8px;
}

.analysis-reviews-section {
  display: grid;
  gap: 24px;
}

.google-reviews-cta {
  display: flex;
  justify-content: center;
  margin-top: 8px;
}

.google-reviews-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.google-reviews-button-icon {
  display: inline-flex;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
}

.google-reviews-button-icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.fundamental-analysis-page {
  display: grid;
  gap: 24px;
}

.analysis-sales-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.55fr);
  gap: 24px;
  align-items: stretch;
}

.analysis-sales-copy {
  display: grid;
  gap: 14px;
}

.analysis-sales-copy h1 {
  max-width: 24ch;
  font-size: clamp(1.7rem, 3.1vw, 2.9rem);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.analysis-sales-lead {
  max-width: 60ch;
  font-size: 1.14rem;
  color: rgba(31, 43, 63, 0.86);
  margin: 0;
}

.analysis-sales-supporting {
  max-width: 64ch;
  color: rgba(31, 43, 63, 0.76);
  margin: 0;
}

.analysis-sales-fit {
  display: grid;
  gap: 12px;
  margin-top: 2px;
}

.analysis-sales-bonus {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  margin-top: 4px;
  border: 1px solid rgba(245, 164, 0, 0.2);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255, 243, 214, 0.78), rgba(255, 248, 234, 0.96));
}

.analysis-sales-bonus strong {
  color: #1f2b3f;
  font-size: 1rem;
}

.analysis-sales-bonus p {
  margin: 0;
  color: rgba(31, 43, 63, 0.76);
}

.analysis-sales-fit strong {
  font-size: 1.05rem;
  color: #1f2b3f;
}

.analysis-sales-bullets {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.analysis-sales-bullets li {
  padding-left: 18px;
  position: relative;
  color: rgba(31, 43, 63, 0.82);
}

.analysis-sales-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #f5a400;
  transform: translateY(-50%);
}

.analysis-sales-proofbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 6px;
}

.analysis-sales-proofbar span,
.analysis-sales-panel-points span {
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(28, 82, 154, 0.08);
  color: #1c529a;
  font-size: 0.92rem;
  font-weight: 700;
}

.analysis-sales-offer-card {
  align-content: start;
}

.analysis-sales-journey {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 10px;
}

.analysis-sales-journey-card,
.analysis-sales-reassurance,
.order-journey-step,
.order-journey-note,
.workspace-upgrade-banner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 64px;
  align-items: center;
  max-width: 960px;
  margin: 0 auto;
  padding: 40px 48px;
  border-radius: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.analysis-sales-journey-card::before,
.analysis-sales-reassurance::before,
.order-journey-step::before,
.order-journey-note::before,
.workspace-upgrade-banner::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, rgba(26, 107, 181, 0.92), rgba(0, 151, 178, 0.72));
}

.analysis-sales-journey-card strong,
.analysis-sales-reassurance strong,
.order-journey-step strong,
.order-journey-note strong,
.workspace-upgrade-banner h2 {
  margin: 0;
  color: #14233d;
}

.analysis-sales-journey-card p,
.analysis-sales-reassurance p,
.order-journey-step p,
.order-journey-note p,
.workspace-upgrade-banner p {
  margin: 0;
  color: rgba(31, 43, 63, 0.76);
  line-height: 1.6;
}

.analysis-sales-panel-points {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
}

.analysis-sales-reassurance {
  margin-top: 4px;
}

/* Hero context: cards are in a narrow column, not full-width */
.analysis-sales-journey .analysis-sales-journey-card,
.analysis-sales-hero .analysis-sales-reassurance {
  grid-template-columns: 1fr;
  gap: 8px;
  max-width: none;
  margin: 0;
  padding: 18px 20px;
}

.fundamental-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 24px;
  align-items: stretch;
}

.fundamental-hero-copy {
  display: grid;
  gap: 14px;
}

.fundamental-hero-copy h1 {
  max-width: 11ch;
  font-size: clamp(2.8rem, 6vw, 5.8rem);
  line-height: 0.92;
  letter-spacing: -0.05em;
}

.fundamental-hero-lead {
  max-width: 62ch;
  font-size: 1.12rem;
  color: rgba(31, 43, 63, 0.82);
}

.fundamental-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
}

.fundamental-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 6px;
}

.fundamental-hero-chips span {
  padding: 10px 14px;
  border: 1px solid rgba(28, 82, 154, 0.12);
  border-radius: 999px;
  font-size: 0.92rem;
  color: #5f7393;
  background: rgba(255, 255, 255, 0.82);
}

.fundamental-hero-panel {
  display: flex;
}

.fundamental-price-card {
  display: grid;
  gap: 14px;
  width: 100%;
  padding: 24px;
  border: 1px solid rgba(28, 82, 154, 0.12);
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255, 170, 0, 0.18), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(246, 250, 255, 0.98));
}

.fundamental-price-block {
  display: grid;
  gap: 4px;
  padding: 14px 0;
  border-top: 1px solid rgba(28, 82, 154, 0.08);
}

.fundamental-price-block:first-of-type {
  border-top: 0;
  padding-top: 4px;
}

.fundamental-price-block strong {
  font-size: 2rem;
  line-height: 1;
  color: #1c529a;
}

.fundamental-price-block span,
.fundamental-price-note,
.fundamental-footnote {
  color: rgba(31, 43, 63, 0.72);
}

.order-journey-panel {
  display: grid;
  gap: 20px;
}

.order-journey-head {
  display: grid;
  gap: 10px;
}

.order-journey-head h2 {
  margin: 0;
  font-size: clamp(1.55rem, 2.3vw, 2.2rem);
  line-height: 1.04;
  letter-spacing: -0.035em;
}

.order-journey-head p:not(.eyebrow) {
  margin: 0;
  max-width: 62ch;
  color: rgba(31, 43, 63, 0.74);
}

.order-journey-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}

.order-crosssell-panel {
  display: grid;
  gap: 20px;
}

.order-crosssell-head {
  display: grid;
  gap: 10px;
}

.order-crosssell-head h2 {
  margin: 0;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.order-crosssell-head p {
  margin: 0;
  color: var(--muted);
  max-width: 60ch;
}

.order-journey-step.is-complete {
  border-color: rgba(28, 82, 154, 0.18);
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.16), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(246, 250, 255, 0.98));
}

.order-journey-step.is-active {
  box-shadow: 0 20px 42px rgba(28, 82, 154, 0.11);
}


.workspace-upgrade-banner-copy h2 {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 10px;
  color: #111827;
}

.workspace-upgrade-banner-copy p {
  font-size: 15px;
  color: #6b7280;
  line-height: 1.6;
  margin: 0;
}

.workspace-upgrade-banner-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-start;
}

.workspace-upgrade-banner-reassurance {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.75);
  margin: 0 0 4px;
  line-height: 1.5;
}

.workspace-bodygraph-gap-note {
  padding: 14px 16px;
  background: rgba(26, 107, 181, 0.06);
  border-left: 3px solid var(--blue);
  border-radius: 0 8px 8px 0;
  margin-top: 12px;
}

.workspace-bodygraph-gap-note p {
  margin: 0 0 4px;
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--muted);
}

.workspace-bodygraph-gap-note p:last-child {
  margin-bottom: 0;
}

.checkout-trust-anchor {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.65);
  text-align: center;
  margin: 0 0 12px;
  line-height: 1.45;
}

.checkout-confirm-access-note {
  text-align: center;
  font-size: 0.8rem;
  color: var(--muted);
  margin: 0;
}

.checkout-postconsent-note {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.5);
  text-align: center;
  margin: -8px 0 12px;
  line-height: 1.5;
}

.checkout-faq-link {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.5);
  margin-top: 12px;
  text-align: center;
}

.checkout-faq-anchor {
  color: var(--blue);
  text-decoration: underline;
}

/* ── Checkout FAQ inline accordion ───────────────────────────────── */
.checkout-faq-inline {
  margin-top: 16px;
  border-top: 1px solid rgba(21,34,56,0.08);
  padding-top: 12px;
}

.checkout-faq-inline-toggle {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--blue);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 6px;
}

.checkout-faq-inline-toggle::-webkit-details-marker { display: none; }

.checkout-faq-inline-toggle::after { content: '▾'; font-size: 0.7rem; }
details[open] .checkout-faq-inline-toggle::after { content: '▴'; }

.checkout-faq-inline-body {
  margin-top: 12px;
  font-size: 0.78rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.65);
}

.checkout-faq-inline-body p { margin: 0 0 10px; }

.checkout-faq-full-link {
  margin-top: 8px;
  font-size: 0.75rem;
}
/* ── End Checkout FAQ inline ─────────────────────────────────────── */

.checkout-testimonial-author-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
}

.checkout-testimonial-avatar {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  min-width: 38px;
  border-radius: 50%;
  color: #fff;
  font-size: 1rem;
  font-weight: 800;
}

.checkout-testimonial-author-row strong {
  font-size: 0.85rem;
  color: var(--blue-deep);
  display: block;
}

.checkout-testimonial-author-row span {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.5);
}

.checkout-testimonial--secondary {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(21,34,56,0.06);
}

.checkout-confirm-guarantee {
  text-align: center;
  font-size: 0.82rem;
  color: var(--muted);
  margin: 2px 0 0;
}

/* ── Checkout layout ──────────────────────────────────────────────── */
.checkout-body {
  background: #f8f9fb;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.checkout-header {
  background: white;
  border-bottom: 1px solid rgba(21,34,56,0.08);
  padding: 0 24px;
  height: 60px;
  display: flex;
  align-items: center;
}

.checkout-header-inner {
  max-width: 960px;
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.checkout-logo img {
  height: 36px;
  width: auto;
}

.checkout-header-support {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
}

.checkout-support-label {
  color: rgba(21,34,56,0.5);
}

.checkout-support-link {
  color: var(--blue);
  text-decoration: none;
  font-weight: 600;
}

.checkout-support-link:hover {
  text-decoration: underline;
}

.checkout-footer {
  margin-top: auto;
  padding: 20px 24px;
  text-align: center;
  font-size: 0.78rem;
  color: rgba(21,34,56,0.4);
  border-top: 1px solid rgba(21,34,56,0.06);
  background: white;
}
/* ── End Checkout layout ──────────────────────────────────────────── */

/* ── Checkout trust seals ─────────────────────────────────────────── */
.checkout-trust-seals {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 0 16px;
}

.checkout-seal {
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(21,34,56,0.6);
  background: rgba(21,34,56,0.04);
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 20px;
  padding: 5px 12px;
  white-space: nowrap;
}
/* ── End Checkout trust seals ─────────────────────────────────────── */

/* ── Entrega imediata note ────────────────────────────────────────── */
.entrega-imediata-note {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.45);
  margin: 6px 0 0;
  text-align: center;
}
/* ── End Entrega imediata note ────────────────────────────────────── */

.workspace-type-identification {
  margin: 16px 0 0;
  padding: 16px 18px;
  background: rgba(26, 107, 181, 0.05);
  border-left: 3px solid var(--blue);
  border-radius: 0 10px 10px 0;
}

.workspace-type-identification-phrase {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--text);
  margin: 0 0 10px;
  font-weight: 500;
}

.workspace-type-identification-hook {
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--muted);
  margin: 0;
}

.order-upsell-primer {
  font-size: 0.95rem;
  color: var(--muted);
  text-align: center;
  margin: 0 0 12px;
  font-style: italic;
}

.analysis-exit-modal-root[hidden] {
  display: none;
}

.analysis-exit-modal-root {
  position: fixed;
  inset: 0;
  z-index: 80;
}

.analysis-exit-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17, 29, 46, 0.56);
  backdrop-filter: blur(3px);
}

.analysis-exit-modal {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(100% - 32px, 540px);
  padding: 24px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 28px 90px rgba(17, 29, 46, 0.24);
  transform: translate(-50%, -48%) scale(0.96);
  opacity: 0;
  transition: opacity 180ms ease, transform 180ms ease;
}

.analysis-exit-modal-root.is-visible .analysis-exit-modal {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
}

.analysis-exit-modal h2 {
  margin: 8px 0 10px;
  font-size: clamp(1.8rem, 4vw, 2.2rem);
  line-height: 1;
}

.analysis-exit-modal p:last-of-type {
  color: rgba(31, 43, 63, 0.78);
}

.analysis-exit-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}

.analysis-exit-close {
  position: absolute;
  top: 14px;
  right: 16px;
  border: 0;
  background: transparent;
  color: #d44d79;
  font-size: 1.8rem;
  line-height: 1;
  cursor: pointer;
}

.fundamental-points,
.fundamental-deliverables,
.fundamental-mentor,
.fundamental-investment,
.fundamental-faq {
  display: grid;
  gap: 24px;
}

.fundamental-analysis-page .analysis-section-head h2 {
  max-width: none;
  text-wrap: balance;
  overflow-wrap: break-word;
}

.fundamental-points-grid,
.fundamental-deliverables-grid,
.fundamental-payment-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.fundamental-point-card,
.fundamental-deliverable-card,
.fundamental-payment-card,
.fundamental-faq-item {
  padding: 22px;
  border: 1px solid rgba(28, 82, 154, 0.1);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.94);
}

.fundamental-point-card p,
.fundamental-payment-card p,
.fundamental-faq-item p {
  color: rgba(31, 43, 63, 0.78);
}

.fundamental-deliverable-card strong,
.fundamental-faq-item h3,
.fundamental-payment-card strong {
  font-size: 1.2rem;
  line-height: 1.08;
}

.fundamental-mentor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.9fr);
  gap: 20px;
}

.fundamental-mentor-copy {
  display: grid;
  gap: 14px;
}

.fundamental-mentor-copy p {
  color: rgba(31, 43, 63, 0.8);
}

.fundamental-mentor-badges {
  display: grid;
  gap: 14px;
}

.fundamental-mentor-badges article {
  padding: 18px;
  border: 1px solid rgba(28, 82, 154, 0.1);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.94);
}

.fundamental-mentor-badges article strong {
  display: block;
  margin-bottom: 6px;
}

.fundamental-mentor-badges article p {
  color: rgba(31, 43, 63, 0.76);
}

.fundamental-payment-card {
  display: grid;
  gap: 10px;
}

.fundamental-payment-card strong {
  font-size: 2rem;
  color: #1c529a;
}

.fundamental-payment-card .button {
  margin-top: 6px;
}

.fundamental-faq-list {
  display: grid;
  gap: 16px;
}

@media (max-width: 1100px) {
  .fundamental-hero,
  .fundamental-mentor-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1100px) {
  .analysis-hero {
    grid-template-columns: 1fr;
  }

  .analysis-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .analysis-reviews-grid {
    grid-template-columns: 1fr;
  }

  .analysis-sales-hero,
  .fundamental-points-grid,
  .fundamental-deliverables-grid,
  .fundamental-payment-grid {
    grid-template-columns: 1fr;
  }

  .analysis-sales-journey,
  .order-journey-grid,
  .workspace-upgrade-banner {
    grid-template-columns: 1fr;
  }
}

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

  .analysis-card {
    grid-template-rows: 140px 1fr auto;
  }

  .analysis-hero-copy h1,
  .analysis-section-head h2,
  .analysis-sales-copy h1 {
    max-width: none;
  }

  .fundamental-analysis-page .analysis-section-head h2,
  .analysis-hero-title,
  .analysis-catalog-title,
  .analysis-proof-title {
    white-space: normal;
  }

  .analysis-exit-actions .button {
    width: 100%;
    justify-content: center;
  }

  .fundamental-hero-actions .button,
  .workspace-upgrade-banner-actions .button,
  .sales-callout-actions .button {
    width: 100%;
    justify-content: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .bodygraph-aura-left,
  .bodygraph-aura-right,
  .bodygraph-grid,
  .bodygraph-wave,
  .bodygraph-svg {
    animation: none;
  }
}

@media print {
  @page {
    size: A4 portrait;
    margin: 20mm;

    @top-left   { content: ""; }
    @top-right  { content: ""; }
    @top-center {
      content: "Relatório | Desenho Humano - Human Design - Mapa Humano - www.desenhohumano.com.br";
      font-family: Georgia, "Times New Roman", serif;
      font-size: 8pt;
      color: #555;
    }
  }

  body.print-layout {
    font-size: 10pt;
    line-height: 1.6;
    color: #000;
    background: #fff;
  }

  /* Remove bordas e separadores */
  .print-report-body *,
  .report-section,
  .report-channel-card,
  .report-summary-item,
  .report-summary-grid,
  .chart-print-details,
  .chart-print-detail-row {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    background: transparent !important;
  }

  /* Permite quebra livre — texto flui naturalmente */
  * {
    break-inside: auto !important;
    page-break-inside: auto !important;
  }

  /* Headings: orphans/widows mas sem break-after (causa overlap no Chrome) */
  h2, h3, h4 {
    orphans: 3;
    widows: 3;
  }

  /* Elemento seguinte ao heading não separa — mais confiável que break-after sozinho */
  h2 + p, h3 + p, h4 + p,
  h2 + ul, h3 + ul, h4 + ul,
  h2 + div, h3 + div {
    break-before: avoid !important;
    page-break-before: avoid !important;
  }

  /* Oculta elementos de navegação */
  .site-header,
  .flash-stack,
  .report-side-panel,
  .report-actions,
  .print-report-footer-fixed,
  nav, footer, button, .no-print {
    display: none !important;
  }

  /* Tipografia uniforme */
  .print-report-body *,
  .chart-print-page * {
    color: #000 !important;
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 10pt !important;
    line-height: 1.7 !important;
  }

  .print-report-body h2, .chart-print-page h2 {
    font-size: 13pt !important;
    font-weight: 700 !important;
    padding-top: 18pt !important;
    margin-top: 0 !important;
    margin-bottom: 6pt !important;
  }

  .print-report-body h3, .chart-print-page h3 {
    font-size: 11pt !important;
    font-weight: 700 !important;
    padding-top: 12pt !important;
    margin-top: 0 !important;
    margin-bottom: 4pt !important;
  }

  .print-report-body strong {
    font-weight: 700 !important;
    font-size: 10pt !important;
  }

  .print-report-body p {
    margin: 0 0 8pt 0 !important;
  }

  /* Fix: grid → block para evitar overlap de conteúdo de canais na quebra de página */
  .print-report-body .report-channel-modal-content[hidden] {
    display: block !important;
  }

  .print-report-body .report-channel-card,
  .print-report-body .report-channel-modal-section {
    display: block !important;
  }

  .print-report-body .report-channel-modal-section {
    margin-bottom: 12px;
  }

  /* Título de subseção: não ficar órfão + manter com o parágrafo seguinte */
  .print-report-body .report-channel-modal-section-title {
    break-after: avoid !important;
    page-break-after: avoid !important;
    padding-top: 10pt !important;
    margin-bottom: 4pt !important;
  }

  .print-report-body .report-channel-modal-section-title + p {
    break-before: avoid !important;
    page-break-before: avoid !important;
  }

  .print-report-body .report-section {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  .print-report-body .report-summary-grid {
    margin-top: 0 !important;
    gap: 4pt !important;
  }
}

.print-layout {
  background: #ffffff;
}

.print-layout::before,
.print-layout .site-header,
.print-layout .flash-stack {
  display: none !important;
}

.print-page {
  width: min(210mm, 100%);
  margin: 0 auto;
  padding: 14mm 12mm 16mm;
  background: #ffffff;
}

.print-report-header {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 2px solid rgba(0, 0, 0, 0.12);
}

.print-report-header h1 {
  max-width: none;
  font-size: 2rem;
  line-height: 0.98;
  color: #000000;
}

.print-report-header p,
.print-report-header .eyebrow {
  color: #000000;
}

.print-report-ownership {
  color: rgba(0, 0, 0, 0.6);
}

.print-report-body .report-rich-content {
  display: block;
}

.report-protected-surface-print {
  position: relative;
  overflow: hidden;
}

.report-watermark-layer-print {
  inset: 12mm 0 0;
  grid-template-columns: 1fr;
  gap: 34px;
  justify-items: center;
  align-content: start;
  padding: 0;
}

.report-watermark-stamp-print {
  font-size: 10pt;
  letter-spacing: 0.12em;
  color: rgba(0, 0, 0, 0.14);
  transform: rotate(-28deg);
}

.print-page--chart {
  position: relative;
  overflow: hidden;
}

.print-report-body .report-section {
  display: block;
  margin: 0 0 14px;
  padding: 0 0 12px;
  border: 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 0;
  background: #ffffff;
  box-shadow: none;
  break-inside: auto;
  page-break-inside: auto;
}

.print-report-body .report-section h2 {
  margin: 0 0 8px;
  color: #000000;
  font-size: 16pt;
}

.print-report-body .report-section p {
  max-width: none;
  color: #000000;
}

.print-report-body .report-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.print-report-body .report-summary-item,
.print-report-body .report-list li {
  padding: 10px 12px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 10px;
  background: #ffffff;
  box-shadow: none;
  break-inside: avoid;
  page-break-inside: avoid;
}

.print-report-body .report-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.print-report-body .report-channel-more {
  display: none;
}

.print-report-body .report-channel-modal-content[hidden] {
  display: grid;
  gap: 14px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(0, 0, 0, 0.12);
}


.chart-print-page {
  width: 100%;
  height: calc(297mm - 40mm);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 3mm;
  color: #000000;
}

.chart-print-top {
  display: grid;
  grid-template-rows: auto auto;
  gap: 2mm;
  min-height: 0;
}

.chart-print-header h1 {
  margin: 0;
  font-size: 18pt;
  line-height: 1.05;
  font-weight: 800;
  text-transform: none;
}

.chart-print-bodygraph {
  display: grid;
  grid-template-columns: 38mm minmax(0, 1fr) 38mm;
  gap: 3mm;
  align-items: start;
  min-height: 0;
}

.chart-print-bodygraph--mandala {
  display: block;
  overflow: visible;
}

.chart-print-bodygraph--mandala .chart-print-map {
  width: 101mm;
  margin: 0 auto;
  overflow: visible;
}

.chart-print-bodygraph--mandala .chart-print-map .bodygraph-canvas {
  overflow: visible;
  width: 101mm;
}

.chart-print-bodygraph--mandala .chart-print-map .bodygraph-svg {
  width: 101mm;
  max-width: 101mm;
  height: auto;
  aspect-ratio: 1 / 1;
  display: block;
  margin: 0;
}

.chart-print-column {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 2mm;
  min-width: 0;
}

.chart-print-column-label {
  margin: 0;
  font-size: 8pt;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-align: center;
}

.chart-print-column-design .chart-print-column-label {
  color: #d8312a;
}

.chart-print-column-personality .chart-print-column-label {
  color: #2a3445;
}

.chart-print-activation-table {
  width: 100%;
  border-radius: 0;
  border: 1px solid rgba(0, 0, 0, 0.16);
  background: #ffffff;
  box-shadow: none;
}

.chart-print-activation-table .activation-row {
  grid-template-columns: 1fr;
  gap: 0;
  padding: 1.2mm 1.6mm;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.chart-print-activation-table .activation-row:last-child {
  border-bottom: 0;
}

.chart-print-activation-table .planet-cell {
  justify-content: center;
  gap: 1.4mm;
  font-size: 8.2pt;
  line-height: 1.15;
}

.chart-print-activation-table .planet-symbol {
  font-size: 13pt;
}

.chart-print-map {
  display: grid;
  place-items: center;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}

.chart-print-map .bodygraph-canvas {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.chart-print-map .bodygraph-background {
  width: min(92%, 98mm);
  max-width: 98mm;
  top: 48%;
  opacity: 0.16;
}

.chart-print-map .bodygraph-svg {
  width: 100%;
  max-width: 92mm;
  height: auto;
  transform: none;
  max-height: none;
}

.chart-print-bottom {
  min-height: 0;
}

.chart-print-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 8mm;
  row-gap: 0;
  padding-top: 1.5mm;
  border-top: 1px solid rgba(0, 0, 0, 0.18);
}

.chart-print-detail-row {
  display: grid;
  grid-template-columns: 27mm minmax(0, 1fr);
  align-items: start;
  gap: 3mm;
  padding: 2.2mm 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  break-inside: avoid;
  page-break-inside: avoid;
}

.chart-print-detail-row span {
  font-size: 9pt;
  line-height: 1.25;
  font-weight: 600;
}

.chart-print-detail-row strong {
  font-size: 9pt;
  line-height: 1.25;
  font-weight: 700;
}

.chart-print-footer {
  margin-top: 0;
  padding-top: 1.5mm;
  border-top: 1px solid rgba(0, 0, 0, 0.12);
  text-align: center;
  font-size: 8pt;
  line-height: 1.2;
  color: rgba(0, 0, 0, 0.7);
}

/* ═══════════════════════════════════════════════════════════════
   DH GUIDE PAGE — /o-que-e-desenho-humano
   ═══════════════════════════════════════════════════════════════ */

/* ── Container & base ──────────────────────────────────────── */
.dh-guide-page {
  --dh-section-gap: 80px;
  --dh-card-radius: 20px;
  color: var(--text);
}

.dh-container {
  max-width: var(--container);
  width: 100%;
  margin-inline: auto;
  padding-inline: 24px;
}

/* ── Scroll-reveal ─────────────────────────────────────────── */
.dh-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.dh-reveal.dh-reveal-delay {
  transition-delay: 0.18s;
}
.dh-reveal.dh-revealed {
  opacity: 1;
  transform: translateY(0);
}

/* ── Zoom images ────────────────────────────────────────────── */
.dh-zoom-img {
  cursor: zoom-in;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  border-radius: 14px;
  display: block;
  width: 100%;
  height: auto;
}
.dh-zoom-img:hover {
  transform: scale(1.025);
  box-shadow: 0 12px 40px rgba(26, 107, 181, 0.18);
}

/* ── Gradient text ─────────────────────────────────────────── */
.dh-gradient-text {
  background: linear-gradient(90deg, var(--blue), var(--blue-deep));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Lead paragraph ────────────────────────────────────────── */
.dh-lead {
  font-size: 1.15rem;
  line-height: 1.65;
  color: var(--muted);
  margin-bottom: 24px;
}

/* ── HERO ───────────────────────────────────────────────────── */
.dh-hero {
  padding-block: 72px 56px;
  background: linear-gradient(160deg, rgba(26,107,181,0.04) 0%, transparent 60%);
  border-radius: 24px;
}

.dh-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

.dh-hero-copy h1 {
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 800;
  line-height: 1.15;
  margin-bottom: 16px;
}

.dh-hero-figure {
  margin: 0;
}

.dh-hero-figure figcaption {
  font-size: 0.8rem;
  color: var(--muted);
  margin-top: 8px;
  text-align: center;
}

.dh-hero-img {
  border-radius: 20px;
  box-shadow: var(--shadow);
}

/* ── TOC ────────────────────────────────────────────────────── */
.dh-toc {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 28px;
}

.dh-toc-link {
  display: inline-block;
  padding: 6px 14px;
  border-radius: 99px;
  border: 1px solid rgba(26,107,181,0.25);
  color: var(--blue);
  font-size: 0.82rem;
  font-weight: 500;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.dh-toc-link:hover {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
}

/* ── Sections ───────────────────────────────────────────────── */
.dh-section {
  padding-block: var(--dh-section-gap);
}

.dh-section-alt {
  background: rgba(26,107,181,0.025);
  border-radius: 24px;
}

.dh-cta-section {
  background: linear-gradient(135deg, rgba(26,107,181,0.07) 0%, rgba(22,61,115,0.05) 100%);
  border-radius: 24px;
  border: 1px solid rgba(26,107,181,0.1);
}

.dh-section-head {
  margin-bottom: 40px;
  max-width: 720px;
}

.dh-section-head h2 {
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--blue-deep);
}

.dh-section-sub {
  font-size: 1.05rem;
  color: var(--muted);
  line-height: 1.6;
  margin-top: 8px;
}

/* ── Split (2-col) ──────────────────────────────────────────── */
.dh-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
}

.dh-split-reverse > *:first-child { order: 2; }
.dh-split-reverse > *:last-child  { order: 1; }

/* ── Card (text block) ──────────────────────────────────────── */
.dh-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.dh-card p {
  line-height: 1.7;
  margin: 0;
}

/* ── Three-col grid ─────────────────────────────────────────── */
.dh-three-col {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* ── Feature card ───────────────────────────────────────────── */
.dh-feature-card {
  background: #fff;
  border-radius: var(--dh-card-radius);
  box-shadow: 0 4px 20px rgba(26,107,181,0.08);
  overflow: hidden;
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}
.dh-feature-card:hover {
  box-shadow: 0 12px 36px rgba(26,107,181,0.14);
  transform: translateY(-4px);
}

.dh-feature-img-wrap {
  overflow: hidden;
  background: rgba(26,107,181,0.04);
}
.dh-feature-img-wrap img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0;
  transition: transform 0.4s ease;
}
.dh-feature-card:hover .dh-feature-img-wrap img {
  transform: scale(1.03);
}

.dh-feature-body {
  padding: 20px;
}
.dh-feature-body h3 {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--blue-deep);
}
.dh-feature-body p {
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.65;
  margin: 0;
}

/* ── Types grid ─────────────────────────────────────────────── */
.dh-types-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 32px;
}

.dh-type-card {
  background: #fff;
  border-radius: var(--dh-card-radius);
  box-shadow: 0 4px 20px rgba(26,107,181,0.08);
  overflow: hidden;
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}
.dh-type-card:hover {
  box-shadow: 0 12px 36px rgba(26,107,181,0.16);
  transform: translateY(-5px);
}

.dh-type-img-wrap {
  overflow: hidden;
  background: rgba(26,107,181,0.04);
}
.dh-type-img-wrap img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0;
  transition: transform 0.4s ease;
}
.dh-type-card:hover .dh-type-img-wrap img {
  transform: scale(1.04);
}

.dh-type-body {
  padding: 16px;
}
.dh-type-label {
  display: inline-block;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--blue);
  font-weight: 600;
  margin-bottom: 6px;
}
.dh-type-body h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin-bottom: 8px;
}
.dh-type-body p {
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

/* ── Media card (figure) ────────────────────────────────────── */
.dh-media-card {
  margin: 0;
  border-radius: var(--dh-card-radius);
  overflow: hidden;
  background: rgba(26,107,181,0.03);
}
.dh-media-card img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--dh-card-radius);
}
.dh-media-card figcaption {
  font-size: 0.78rem;
  color: var(--muted);
  padding: 10px 4px 0;
  text-align: center;
}

.dh-wide {
  width: 100%;
}

/* ── Inline CTAs ────────────────────────────────────────────── */
.dh-cta-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
}

/* ── CTA section / panel ────────────────────────────────────── */
.dh-cta-panel {
  max-width: 600px;
  margin-inline: auto;
  text-align: center;
}
.dh-cta-panel h2 {
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 700;
  color: var(--blue-deep);
  margin-bottom: 12px;
}
.dh-cta-panel p {
  color: var(--muted);
  margin-bottom: 28px;
}

.dh-cta-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

/* ── FAQ ────────────────────────────────────────────────────── */
.dh-faq {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-radius: var(--dh-card-radius);
  overflow: hidden;
  border: 1px solid rgba(26,107,181,0.12);
}

.dh-faq-item {
  border-bottom: 1px solid rgba(26,107,181,0.1);
  background: #fff;
  transition: background 0.2s;
}
.dh-faq-item:last-child {
  border-bottom: none;
}
.dh-faq-item[open] {
  background: rgba(26,107,181,0.02);
}

.dh-faq-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  font-size: 1rem;
  font-weight: 600;
  color: var(--blue-deep);
  cursor: pointer;
  list-style: none;
  gap: 16px;
}
.dh-faq-q::-webkit-details-marker { display: none; }
.dh-faq-q::marker { content: none; }

.dh-faq-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: rgba(26,107,181,0.1);
  color: var(--blue);
  font-size: 1.1rem;
  font-weight: 400;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, transform 0.25s;
}
.dh-faq-item[open] .dh-faq-icon {
  background: var(--blue);
  color: #fff;
  transform: rotate(45deg);
}

.dh-faq-a {
  padding: 0 24px 20px;
}
.dh-faq-a p {
  font-size: 0.95rem;
  color: var(--muted);
  line-height: 1.7;
  margin: 0;
}

/* ── Lightbox ───────────────────────────────────────────────── */
.dh-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(15, 20, 30, 0.92);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}
.dh-lightbox.is-open {
  opacity: 1;
  pointer-events: auto;
}

.dh-lightbox-inner {
  max-width: min(90vw, 960px);
  max-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.dh-lightbox-inner img {
  max-width: 100%;
  max-height: 90vh;
  border-radius: 16px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6);
  object-fit: contain;
}

.dh-lightbox-close {
  position: absolute;
  top: 20px;
  right: 24px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  border: none;
  color: #fff;
  font-size: 1.4rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
  line-height: 1;
}
.dh-lightbox-close:hover {
  background: rgba(255,255,255,0.28);
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 980px) {
  .dh-hero-grid {
    grid-template-columns: 1fr;
  }
  .dh-hero-figure {
    order: -1;
  }
  .dh-split,
  .dh-split-reverse {
    grid-template-columns: 1fr;
  }
  .dh-split-reverse > *:first-child { order: unset; }
  .dh-split-reverse > *:last-child  { order: unset; }
  .dh-three-col {
    grid-template-columns: 1fr 1fr;
  }
  .dh-types-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 600px) {
  .dh-hero {
    padding-block: 48px 40px;
  }
  .dh-three-col {
    grid-template-columns: 1fr;
  }
  .dh-types-grid {
    grid-template-columns: 1fr 1fr;
  }
  .dh-section {
    --dh-section-gap: 56px;
  }
  .dh-faq-q {
    padding: 16px 18px;
    font-size: 0.93rem;
  }
  .dh-faq-a {
    padding: 0 18px 16px;
  }
}

/* ===== Analysis pages: new elements ===== */

/* FAQ accordion (details/summary) */
.fundamental-faq-item {
  cursor: pointer;
}

.fundamental-faq-item summary {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  font-size: 1.05rem;
  font-weight: 700;
  color: #1f2b3f;
  cursor: pointer;
}

.fundamental-faq-item summary::-webkit-details-marker { display: none; }

.fundamental-faq-item summary::after {
  content: "+";
  font-size: 1.4rem;
  font-weight: 400;
  flex-shrink: 0;
  color: #1c529a;
  transition: transform 0.2s ease;
}

.fundamental-faq-item[open] summary::after {
  transform: rotate(45deg);
}

.fundamental-faq-item p {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(28, 82, 154, 0.08);
}

/* Hero panel CTA button */
.analysis-sales-panel-cta {
  width: 100%;
  justify-content: center;
  margin-top: 16px;
}

.analysis-sales-panel-guarantee {
  margin-top: 10px;
  font-size: 0.82rem;
  color: rgba(31, 43, 63, 0.56);
  text-align: center;
  line-height: 1.5;
}

/* Catalog card: price badge */
.analysis-card-media {
  position: relative;
}

.analysis-card-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 5px 12px;
  border-radius: 999px;
  background: #f5a400;
  color: #1f2b3f;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.analysis-card-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.analysis-card-price {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  font-size: 0.93rem;
  font-weight: 800;
  color: #1c529a;
  white-space: nowrap;
}

.analysis-card-price-prefix,
.analysis-card-price-amount {
  display: block;
}

/* Cross-sell section */
.analysis-crosssell {
  border-top: 1px solid rgba(28, 82, 154, 0.08);
}

.analysis-crosssell-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 4px;
}

.analysis-crosssell-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 22px;
  border: 1px solid rgba(28, 82, 154, 0.1);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.94);
}

.analysis-crosssell-card h3 {
  font-size: 1.08rem;
  line-height: 1.2;
  margin: 0;
}

.analysis-crosssell-card p {
  color: rgba(31, 43, 63, 0.76);
  flex: 1;
  margin: 0;
}

.analysis-crosssell-card .button {
  align-self: flex-start;
  margin-top: auto;
}

@media (max-width: 900px) {
  .analysis-crosssell-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 600px) {
  .analysis-crosssell-grid {
    grid-template-columns: 1fr;
  }
  .analysis-card-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .analysis-card-actions .button {
    width: 100%;
    justify-content: center;
  }
}

/* ===================================================
   Melhorias de conversão — pagamento e bundle
   =================================================== */

/* Single-card payment layout */
.fundamental-payment-solo {
  display: flex;
  justify-content: center;
}

.fundamental-payment-solo .fundamental-payment-card {
  max-width: 520px;
  width: 100%;
}

/* Secondary price line (installment note) */
.analysis-price-alt {
  color: rgba(31, 43, 63, 0.7);
  font-size: 0.9rem;
  margin: 0;
}

.analysis-price-anchor {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.55);
  line-height: 1.55;
  margin: 0 0 8px;
  font-style: italic;
}

/* Bundle promotional section */
.analysis-bundle {
  border-top: 1px solid rgba(28, 82, 154, 0.08);
}

.analysis-bundle-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 28px;
  align-items: center;
  padding: 28px;
  border: 2px solid rgba(28, 82, 154, 0.15);
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255, 170, 0, 0.12), transparent 40%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(246, 250, 255, 0.97));
  margin-top: 4px;
}

.analysis-bundle-copy {
  display: grid;
  gap: 12px;
}

.analysis-bundle-copy p {
  color: rgba(31, 43, 63, 0.8);
  margin: 0;
}

.analysis-bundle-copy ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 6px;
}

.analysis-bundle-copy li {
  color: rgba(31, 43, 63, 0.8);
  font-size: 0.94rem;
  padding-left: 18px;
  position: relative;
}

.analysis-bundle-copy li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: rgba(28, 82, 154, 0.45);
}

.analysis-bundle-copy .analysis-price-alt {
  font-size: 0.86rem;
}

.analysis-bundle-action {
  display: grid;
  gap: 10px;
  min-width: 230px;
  text-align: center;
}

.analysis-bundle-action .button {
  width: 100%;
  justify-content: center;
}

.analysis-bundle-action p {
  font-size: 0.82rem;
  color: rgba(31, 43, 63, 0.6);
  line-height: 1.5;
  margin: 0;
}

@media (max-width: 780px) {
  .analysis-bundle-card {
    grid-template-columns: 1fr;
  }

  .analysis-bundle-action {
    min-width: 0;
  }
}

/* Checkout context banner on auth pages */
.auth-checkout-context {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border: 1px solid rgba(28, 82, 154, 0.14);
  border-radius: 18px;
  background: rgba(246, 250, 255, 0.92);
  margin-bottom: 20px;
}

.auth-checkout-context strong {
  display: block;
  font-size: 0.9rem;
  color: #1c529a;
}

.auth-checkout-context p {
  font-size: 0.84rem;
  color: rgba(31, 43, 63, 0.7);
  margin: 0;
  line-height: 1.5;
}

.auth-context-note {
  font-size: 0.875rem;
  color: rgba(31, 43, 63, 0.65);
  line-height: 1.5;
  margin-bottom: 18px;
}

/* ============================================
   ABOUT PAGE
   ============================================ */

.about-page {
  display: grid;
  gap: 24px;
}


.about-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.about-hero-chips span {
  padding: 5px 12px;
  border-radius: 999px;
  border: 1px solid rgba(26, 107, 181, 0.18);
  background: rgba(26, 107, 181, 0.06);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--blue);
  letter-spacing: 0.02em;
}

.about-photo-area {
  margin: 0;
  max-height: 360px;
}

.about-bio,
.about-approach,
.about-cta {
  display: grid;
  gap: 28px;
}

.about-bio-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 32px;
  align-items: start;
}

.about-bio-text {
  display: grid;
  gap: 16px;
}

/* Bio layout: foto + credencial à esquerda, texto à direita */
.about-bio-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 36px;
  align-items: start;
  margin-top: 24px;
}

.about-bio-photo-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.about-bio-photo {
  width: 100%;
  height: auto;
  border-radius: 20px;
  box-shadow: 0 20px 48px -16px rgba(11, 33, 71, 0.28);
  display: block;
}

.about-bio-text-col {
  display: grid;
  gap: 16px;
}

.about-bio-text p {
  font-size: 1rem;
  line-height: 1.75;
}

.about-credentials {
  display: grid;
  gap: 12px;
}

.about-credential-card {
  padding: 18px 20px;
  border-radius: 16px;
  border: 1px solid rgba(26, 107, 181, 0.1);
  background: rgba(246, 250, 255, 0.8);
  display: grid;
  gap: 6px;
}

.about-credential-card strong {
  font-size: 0.92rem;
  color: var(--text);
}

.about-credential-card p {
  font-size: 0.84rem;
  margin: 0;
  line-height: 1.55;
}

.about-approach-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.about-approach-grid article {
  padding: 22px;
  border-radius: 18px;
  border: 1px solid rgba(26, 107, 181, 0.08);
  background: rgba(255, 255, 255, 0.7);
  display: grid;
  gap: 8px;
}

.about-approach-grid h3 {
  font-size: 1rem;
  color: var(--text);
}

.about-cta {
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 249, 255, 0.95));
  padding: 44px;
  border-radius: 24px;
}

.about-cta h2 {
  font-size: clamp(1.4rem, 2.4vw, 2rem);
}

@media (max-width: 860px) {
  .about-bio-grid {
    grid-template-columns: 1fr;
  }

  .about-bio-layout {
    grid-template-columns: 1fr;
  }

  .about-bio-photo {
    max-width: 280px;
    margin: 0 auto;
  }

  .about-approach-grid {
    grid-template-columns: 1fr;
  }

  .about-cta {
    padding: 28px 24px;
  }
}

/* ============================================
   CONTACT PAGE
   ============================================ */

.contact-page {
  display: grid;
  gap: 24px;
}

.contact-channels,
.contact-faq {
  display: grid;
  gap: 28px;
}

.contact-channels-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.contact-channel-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 22px;
  border-radius: 18px;
  border: 1px solid rgba(26, 107, 181, 0.1);
  background: rgba(246, 250, 255, 0.8);
}

.contact-channel-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(37, 211, 102, 0.12);
  color: #1a9c45;
  flex-shrink: 0;
}

.contact-channel-icon-email {
  background: rgba(26, 107, 181, 0.1);
  color: var(--blue);
}

.contact-channel-icon-instagram {
  background: rgba(225, 48, 108, 0.1);
  color: #e1306c;
}

.contact-channel-card strong {
  display: block;
  font-size: 0.96rem;
  color: var(--text);
  margin-bottom: 2px;
}

.contact-channel-card p {
  font-size: 0.88rem;
  margin: 0 0 8px;
  color: var(--muted);
}

.contact-channel-link {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--blue);
  text-decoration: none;
}

.contact-channel-link:hover {
  color: var(--orange);
}

@media (max-width: 860px) {
  .contact-channels-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   HOW IT WORKS / PARA INICIANTES PAGE
   ============================================ */

.how-it-works-page {
  display: grid;
  gap: 24px;
}

.how-it-works-page .analysis-hero-title,
.about-hero-title {
  font-size: clamp(1.5rem, 2.6vw, 2.4rem);
}

.hiw-steps-grid {
  display: grid;
  gap: 0;
}

.hiw-step {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 20px;
  padding: 28px 0;
  border-bottom: 1px solid rgba(26, 107, 181, 0.08);
}

.hiw-step:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.hiw-step-number {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(255, 122, 0, 0.12), rgba(255, 184, 0, 0.2));
  border: 1px solid rgba(255, 122, 0, 0.22);
  color: #c45f00;
  font-weight: 800;
  font-size: 1rem;
  line-height: 40px;
  flex-shrink: 0;
}

.hiw-step-body {
  display: grid;
  gap: 10px;
}

.hiw-step-body h3 {
  font-size: 1.1rem;
  line-height: 1.2;
  color: var(--text);
}

.hiw-step-body p {
  font-size: 0.96rem;
  color: var(--muted);
  line-height: 1.7;
}

.hiw-step-note {
  font-size: 0.82rem !important;
  color: rgba(91, 103, 116, 0.8) !important;
  padding: 8px 12px;
  border-left: 3px solid rgba(0, 151, 178, 0.3);
  border-radius: 0 8px 8px 0;
  background: rgba(0, 151, 178, 0.04);
}

.hiw-step-link {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--blue);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.hiw-step-link:hover {
  color: var(--orange);
}

/* Timeline */
.hiw-timeline {
  display: grid;
  gap: 0;
}

.hiw-timeline-item {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 16px;
  padding: 20px 0;
  border-bottom: 1px solid rgba(26, 107, 181, 0.07);
}

.hiw-timeline-item:last-child {
  border-bottom: none;
}

.hiw-timeline-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ff7a00, #ffb800);
  margin-top: 5px;
  flex-shrink: 0;
}

.hiw-timeline-item strong {
  display: block;
  font-size: 0.98rem;
  color: var(--text);
  margin-bottom: 4px;
}

.hiw-timeline-item p {
  font-size: 0.9rem;
  margin: 0;
}

/* FAQ */
.hiw-steps,
.hiw-session,
.hiw-faq {
  display: grid;
  gap: 28px;
}

/* CTA */
.hiw-cta {
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 249, 255, 0.95));
  padding: 44px;
  border-radius: 24px;
  display: grid;
  gap: 12px;
}

.hiw-cta h2 {
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  max-width: 32ch;
}

.hiw-cta p {
  max-width: 56ch;
}

.hiw-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
}

@media (max-width: 640px) {
  .hiw-step {
    grid-template-columns: 1fr;
  }

  .hiw-cta {
    padding: 28px 24px;
  }
}

/* ============================================
   SITE FOOTER
   ============================================ */

.site-footer {
  margin-top: 72px;
  background: #0b1629;
  color: rgba(255, 255, 255, 0.72);
  border-radius: 28px 28px 0 0;
}

.site-footer-inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 56px 40px 40px;
}

.site-footer-brand {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.footer-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #ffffff;
  font-weight: 700;
  font-size: 1rem;
  text-decoration: none;
}

.footer-brand .brand-mark {
  font-size: 1.5rem;
}

.footer-brand strong {
  color: #ffffff;
}

.site-footer-brand > p {
  max-width: 38ch;
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.52);
  line-height: 1.65;
  margin: 0;
}

.footer-social {
  display: flex;
  gap: 10px;
  margin-top: 4px;
}

.footer-social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.6);
  transition: background 180ms ease, color 180ms ease, border-color 180ms ease;
}

.footer-social-link:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.22);
}

.footer-social-whatsapp:hover {
  background: rgba(37, 211, 102, 0.15);
  color: #25d366;
  border-color: rgba(37, 211, 102, 0.3);
}

.footer-social-instagram:hover {
  background: rgba(225, 48, 108, 0.15);
  color: #e1306c;
  border-color: rgba(225, 48, 108, 0.3);
}

.footer-social-youtube:hover {
  background: rgba(255, 0, 0, 0.15);
  color: #ff0000;
  border-color: rgba(255, 0, 0, 0.3);
}

.footer-social-facebook:hover {
  background: rgba(24, 119, 242, 0.15);
  color: #1877f2;
  border-color: rgba(24, 119, 242, 0.3);
}

.site-footer-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
}

.footer-nav-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-nav-label {
  margin: 0 0 4px;
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.38);
}

.footer-nav-group a {
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.62);
  text-decoration: none;
  transition: color 150ms ease;
}

.footer-nav-group a:hover {
  color: #ffffff;
}

.site-footer-bottom {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 16px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 20px 40px 28px;
  border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.site-footer-bottom p {
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.3);
}

@media (max-width: 860px) {
  .site-footer-inner {
    grid-template-columns: 1fr;
    gap: 40px;
    padding: 40px 24px 32px;
  }

  .site-footer-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .site-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    padding: 20px 24px 28px;
  }
}

/* ============================================================
   ABOUT SECTION — /sobre multi-page layout
   ============================================================ */

.about-section-page {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 40px;
  align-items: start;
  padding-top: 40px;
  padding-bottom: 80px;
}

.about-sidenav-col {
  position: sticky;
  top: 88px;
}

.about-sidenav {
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 14px;
  padding: 12px 10px;
}

.about-sidenav-link {
  display: block;
  padding: 9px 14px;
  border-radius: 8px;
  font-size: 0.88rem;
  font-weight: 500;
  color: #444;
  text-decoration: none;
  transition: background 150ms ease, color 150ms ease;
}

.about-sidenav-link:hover {
  background: rgba(0, 151, 178, 0.06);
  color: #0097b2;
}

.about-sidenav-photo {
  width: 100%;
  height: auto;
  border-radius: 16px;
  box-shadow: 0 16px 40px -12px rgba(11, 33, 71, 0.24);
  display: block;
  margin-top: 16px;
}

.about-ihds-verify {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  padding: 12px 14px;
  background: linear-gradient(135deg, rgba(26,107,181,0.06), rgba(0,151,178,0.08));
  border: 1px solid rgba(0, 151, 178, 0.25);
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
  transition: border-color 150ms, background 150ms;
}

.about-ihds-verify:hover {
  border-color: rgba(0, 151, 178, 0.5);
  background: linear-gradient(135deg, rgba(26,107,181,0.1), rgba(0,151,178,0.13));
}

.about-ihds-verify-badge {
  flex-shrink: 0;
  background: #0097b2;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 4px 8px;
  border-radius: 6px;
  letter-spacing: 0.03em;
}

.about-ihds-verify-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
}

.about-ihds-verify-text strong {
  font-size: 0.82rem;
  color: var(--blue-deep);
  line-height: 1.2;
}

.about-ihds-verify-text small {
  font-size: 0.72rem;
  color: var(--muted);
}

.about-ihds-verify-arrow {
  font-size: 0.85rem;
  color: #0097b2;
  flex-shrink: 0;
}

.about-sidenav-link.is-active {
  background: #0097b2;
  color: #fff;
  font-weight: 600;
}

.about-section-content {
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-width: 0;
}

.about-section-card {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 16px;
  padding: 36px 40px;
}

.about-section-card h1 {
  margin: 8px 0 16px;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  line-height: 1.15;
}

.about-section-card h2 {
  margin: 0 0 14px;
  font-size: 1.15rem;
  font-weight: 700;
  color: #0b2147;
}

.about-section-card h3,
.about-section-sub {
  margin: 18px 0 8px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-deep);
}

.about-section-card p {
  margin: 0 0 14px;
  line-height: 1.7;
  color: #444;
}

.about-section-card p:last-child {
  margin-bottom: 0;
}

.about-section-lead {
  font-size: 1.05rem;
  color: #333;
  line-height: 1.7;
  margin-bottom: 24px !important;
}

.about-highlight {
  color: #ff7a00;
  font-weight: 700;
}

.about-highlight-blue {
  color: #0097b2;
  font-weight: 600;
}

/* Profile grid */
.about-profile-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin: 24px 0;
}

.about-profile-card {
  background: rgba(0, 151, 178, 0.04);
  border: 1px solid rgba(0, 151, 178, 0.15);
  border-radius: 12px;
  padding: 18px 20px;
}

.about-profile-card > strong {
  display: block;
  margin-bottom: 8px;
  font-size: 0.9rem;
  color: #0b2147;
}

.about-profile-card p {
  margin: 0;
  font-size: 0.88rem;
  color: #555;
  line-height: 1.6;
}

/* CTA buttons inside about */
.about-section-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}

/* Contact card */
.about-contact-card p {
  margin: 0 0 6px;
}

.about-contact-link {
  color: #0097b2;
  font-weight: 500;
  text-decoration: none;
}

.about-contact-link:hover {
  text-decoration: underline;
}

.about-contact-offices {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(0, 0, 0, 0.07);
}

.about-contact-offices strong {
  display: block;
  margin-bottom: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #0097b2;
}

/* Certificates grid */
.about-certs-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-top: 24px;
}

.about-cert {
  margin: 0;
  text-align: center;
}

.about-cert img {
  width: 100%;
  height: auto;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.08);
}

.about-cert figcaption {
  margin-top: 8px;
  font-size: 0.8rem;
  color: #666;
}

/* FAQ grid */
.about-faq-grid {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ── FAQ sections ─────────────────────────────────────────────── */
.faq-section {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.faq-section-title {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0 0 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(26,107,181,0.15);
}

.faq-item {
  border-bottom: 1px solid rgba(21,34,56,0.08);
  padding: 4px 0;
}

.faq-question {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--blue-deep);
  cursor: pointer;
  padding: 14px 0;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.faq-question::-webkit-details-marker { display: none; }

.faq-question::after {
  content: '+';
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--blue);
  min-width: 20px;
  text-align: center;
  flex-shrink: 0;
}

details[open] .faq-question::after {
  content: '−';
}

.faq-answer {
  padding: 0 0 16px;
  font-size: 0.88rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.7);
}

.faq-answer p { margin: 0 0 10px; }
.faq-answer p:last-child { margin-bottom: 0; }

.faq-answer ul {
  margin: 8px 0 12px 16px;
}

.faq-answer li {
  margin-bottom: 8px;
}

.faq-answer a {
  color: var(--blue);
  text-decoration: underline;
}
/* ── End FAQ sections ─────────────────────────────────────────── */

/* Legal grid (privacy + terms) */
.about-legal-grid {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.about-legal-toc {
  background: rgba(0, 151, 178, 0.04);
  border: 1px solid rgba(0, 151, 178, 0.15);
  border-radius: 12px;
  padding: 18px 22px;
  margin-top: 4px;
}

.about-legal-toc strong {
  display: block;
  margin-bottom: 10px;
  font-size: 0.88rem;
  color: #0b2147;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.about-legal-toc ol {
  margin: 0;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.about-legal-toc li {
  font-size: 0.88rem;
  color: #555;
}

.about-legal-list {
  margin: 0 0 14px;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.about-legal-list li {
  font-size: 0.92rem;
  color: #444;
  line-height: 1.6;
}

.about-legal-list:last-child {
  margin-bottom: 0;
}

/* Ra Uru Hu */
.about-ra-hero-img {
  width: 100%;
  height: auto;
  border-radius: 12px;
  margin-top: 20px;
  display: block;
}

.about-timeline-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin: 24px 0;
}

.about-timeline-card {
  background: rgba(0, 151, 178, 0.04);
  border: 1px solid rgba(0, 151, 178, 0.15);
  border-radius: 12px;
  padding: 18px 20px;
}

.about-timeline-date {
  display: block;
  margin-bottom: 10px;
  font-size: 0.85rem;
  font-weight: 700;
  color: #ff7a00;
  letter-spacing: 0.02em;
}

.about-timeline-card p {
  margin: 0;
  font-size: 0.88rem;
  color: #555;
  line-height: 1.65;
}

.about-timeline-legacy {
  background: rgba(255, 122, 0, 0.06);
  border-left: 3px solid #ff7a00;
  border-radius: 0 10px 10px 0;
  padding: 16px 20px;
  margin-top: 4px;
}

.about-timeline-legacy p {
  margin: 0;
  font-size: 0.95rem;
  color: #444;
  line-height: 1.65;
}

/* Responsive */
@media (max-width: 860px) {
  .about-section-page {
    grid-template-columns: 1fr;
    gap: 24px;
    padding-top: 24px;
  }

  .about-sidenav-col {
    position: static;
  }

  .about-sidenav {
    flex-direction: row;
    flex-wrap: wrap;
    border-radius: 12px;
  }

  .about-sidenav-link {
    font-size: 0.82rem;
    padding: 7px 12px;
  }

  .about-section-card {
    padding: 24px 20px;
  }

  .about-section-card h1 {
    white-space: normal;
    font-size: clamp(1.5rem, 6vw, 2rem);
  }

  .about-profile-grid,
  .about-timeline-grid,
  .about-contact-offices {
    grid-template-columns: 1fr;
  }

  .about-certs-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 540px) {
  .about-certs-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   CERT LIGHTBOX
   ============================================================ */

.cert-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(0, 0, 0, 0.88);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 16px;
  padding: 24px;
}

.cert-lightbox.is-open {
  display: flex;
}

.cert-lightbox-img {
  max-width: min(900px, 92vw);
  max-height: 82vh;
  width: auto;
  height: auto;
  border-radius: 10px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6);
  object-fit: contain;
}

.cert-lightbox-caption {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.7);
}

.cert-lightbox-close {
  position: fixed;
  top: 20px;
  right: 24px;
  background: rgba(255, 255, 255, 0.12);
  border: none;
  border-radius: 50%;
  width: 44px;
  height: 44px;
  font-size: 1.5rem;
  line-height: 1;
  color: #fff;
  cursor: pointer;
  transition: background 150ms ease;
}

.cert-lightbox-close:hover {
  background: rgba(255, 255, 255, 0.22);
}

/* ============================================================
   COURSES — Landing page & player
   ============================================================ */

/* ── Course Hero ─────────────────────────────────────── */
.course-hero {
  background: linear-gradient(135deg, #0b2147 0%, #0097b2 60%, #0b2147 100%);
  color: #fff;
  padding: 64px 0 72px;
  border-radius: 24px;
  overflow: hidden;
}

.course-hero-inner {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 56px;
  align-items: center;
  max-width: var(--container, 1200px);
  margin: 0 auto;
  padding: 0 40px;
}

.course-hero-content .eyebrow {
  color: rgba(255, 255, 255, 0.65);
}

.course-hero-title {
  margin: 12px 0 18px;
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  line-height: 1.1;
  color: #fff;
}

.course-hero-highlight {
  color: #ffb800;
}

.course-hero-lead {
  font-size: 1.08rem;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.65;
  margin-bottom: 24px;
}

.course-hero-pills {
  list-style: none;
  margin: 0 0 28px;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.course-hero-pills li {
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  padding: 5px 14px;
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.9);
}

.course-hero-price {
  margin: 14px 0 0;
  display: flex;
  align-items: center;
  gap: 12px;
}

.course-price-original {
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.45);
  text-decoration: line-through;
}

.course-price-sale {
  font-size: 1.6rem;
  font-weight: 800;
  color: #ffb800;
}

.course-hero-media {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.4);
}

.course-hero-img {
  width: 100%;
  height: auto;
  display: block;
}

/* ── Shared section styles ────────────────────────────── */
.course-section-head {
  text-align: center;
  margin-bottom: 40px;
}

.course-section-head h2 {
  font-size: clamp(1.5rem, 3vw, 2rem);
  color: #0b2147;
  margin: 8px 0 0;
}

.course-section-lead {
  margin: 12px auto 0;
  max-width: 560px;
  color: #555;
  line-height: 1.65;
}

.course-learn,
.course-curriculum,
.course-materials,
.course-why,
.course-instructor,
.course-cta-final {
  padding: 72px 0;
}

.course-learn { background: #f7f8fa; border-radius: 24px; }
.course-curriculum { background: #fff; border-radius: 24px; }
.course-materials { background: #f7f8fa; border-radius: 24px; }
.course-why { background: #fff; border-radius: 24px; }
.course-instructor { background: #f7f8fa; border-radius: 24px; }
.course-cta-final {
  background: linear-gradient(135deg, #0b2147 0%, #0097b2 100%);
  color: #fff;
  text-align: center;
  border-radius: 24px;
  overflow: hidden;
}

/* ── What you'll learn ────────────────────────────────── */
.course-learn-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  max-width: 820px;
  margin: 0 auto;
}

.course-learn-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 12px;
  padding: 14px 16px;
}

.course-learn-check {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  background: rgba(0, 151, 178, 0.12);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  color: #0097b2;
  font-weight: 700;
  margin-top: 2px;
}

.course-learn-item strong {
  display: block;
  font-size: 0.9rem;
  color: #0b2147;
  margin-bottom: 3px;
}

.course-learn-item span {
  font-size: 0.82rem;
  color: #666;
  line-height: 1.4;
}

/* ── Curriculum ───────────────────────────────────────── */
.course-curriculum-list {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.course-lesson-row {
  border: 1px solid rgba(0, 0, 0, 0.09);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}

.course-lesson-summary {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.course-lesson-summary::-webkit-details-marker { display: none; }

.course-lesson-row[open] .course-lesson-summary {
  border-bottom: 1px solid rgba(0, 0, 0, 0.07);
}

.course-lesson-number {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  background: rgba(0, 151, 178, 0.1);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  font-weight: 700;
  color: #0097b2;
}

.course-lesson-title {
  flex: 1;
  font-size: 0.95rem;
  font-weight: 600;
  color: #0b2147;
}

.course-lesson-duration {
  font-size: 0.8rem;
  color: #888;
  flex-shrink: 0;
}

.course-lesson-arrow {
  font-size: 0.8rem;
  color: #aaa;
  flex-shrink: 0;
  transition: transform 200ms ease;
}

.course-lesson-row[open] .course-lesson-arrow {
  transform: rotate(180deg);
}

.course-lesson-desc {
  padding: 16px 20px 18px 66px;
  font-size: 0.88rem;
  color: #555;
  line-height: 1.65;
}

/* ── Materials ────────────────────────────────────────── */
.course-materials-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  max-width: 880px;
  margin: 0 auto;
}

.course-material-card {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 16px;
  padding: 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}

.course-material-card img {
  width: 100%;
  max-height: 200px;
  object-fit: contain;
  border-radius: 8px;
}

.course-material-card strong {
  display: block;
  font-size: 0.95rem;
  color: #0b2147;
}

.course-material-card p {
  font-size: 0.85rem;
  color: #666;
  line-height: 1.55;
  margin: 0;
}

.course-materials-note {
  text-align: center;
  margin-top: 20px;
  font-size: 0.82rem;
  color: #888;
}

/* ── Why us ───────────────────────────────────────────── */
.course-why-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.course-why-card {
  background: rgba(0, 151, 178, 0.04);
  border: 1px solid rgba(0, 151, 178, 0.14);
  border-radius: 14px;
  padding: 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.course-why-icon {
  font-size: 1.5rem;
  line-height: 1;
}

.course-why-card strong {
  font-size: 0.95rem;
  color: #0b2147;
}

.course-why-card p {
  font-size: 0.85rem;
  color: #555;
  line-height: 1.6;
  margin: 0;
}

/* ── Instructor ───────────────────────────────────────── */
.course-instructor-inner {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 48px;
  align-items: start;
  max-width: 880px;
  margin: 0 auto;
}

.course-instructor-photo img {
  width: 100%;
  height: auto;
  border-radius: 16px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
}

.course-instructor-bio h2 {
  margin: 10px 0 4px;
  font-size: 1.6rem;
  color: #0b2147;
}

.course-instructor-cert {
  font-size: 0.85rem;
  color: #0097b2;
  font-weight: 600;
  margin-bottom: 16px !important;
}

.course-instructor-bio p {
  font-size: 0.92rem;
  color: #444;
  line-height: 1.7;
  margin-bottom: 14px;
}

.course-instructor-stats {
  display: flex;
  gap: 24px;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.course-instructor-stats div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.course-instructor-stats strong {
  font-size: 1.4rem;
  color: #ff7a00;
}

.course-instructor-stats span {
  font-size: 0.78rem;
  color: #888;
}

/* ── CTA Final ────────────────────────────────────────── */
.course-cta-final-inner {
  max-width: 640px;
  margin: 0 auto;
}

.course-cta-final .eyebrow {
  color: rgba(255, 255, 255, 0.6);
}

.course-cta-final h2 {
  margin: 10px 0 16px;
  font-size: clamp(1.5rem, 3vw, 2rem);
  color: #fff;
}

.course-cta-final p {
  color: rgba(255, 255, 255, 0.75);
  margin-bottom: 32px;
  line-height: 1.65;
}

.course-cta-price-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.course-cta-price {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.course-price-note {
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.55);
}

.course-guarantee {
  margin-top: 20px;
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.5);
}

/* ── Course Index ─────────────────────────────────────── */
.courses-index {
  padding-top: 56px;
  padding-bottom: 80px;
}

.courses-index-head {
  text-align: center;
  margin-bottom: 48px;
}

.courses-index-head h1 {
  display: block;
  font-size: clamp(1.35rem, 4vw, 2.8rem);
  color: #0b2147;
  margin: 8px 0 12px;
  max-width: none;
  text-align: center;
}

.courses-index-lead {
  font-size: 1.05rem;
  color: #555;
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.65;
}

.courses-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
}

.course-card {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.course-card-img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
}

.course-card-body {
  padding: 20px 22px 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 6px;
}

.course-card-instructor {
  font-size: 0.78rem;
  color: #0097b2;
  font-weight: 600;
  margin: 0;
}

.course-card-title {
  font-size: 1.15rem;
  color: #0b2147;
  margin: 0;
}

.course-card-meta {
  font-size: 0.82rem;
  color: #888;
  margin: 0;
}

.course-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 16px;
}

.course-card-price strong {
  font-size: 1.3rem;
  color: #0b2147;
}

/* ── Lesson Player ────────────────────────────────────── */
.lesson-player-page .site-header,
.lesson-player-page .site-footer {
  /* keep header visible, hide footer in player */
}

.lesson-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  min-height: calc(100vh - 64px);
}

.lesson-sidebar {
  background: #0b2147;
  color: #fff;
  overflow-y: auto;
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
}

.lesson-sidebar-header {
  padding: 20px 20px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.lesson-course-back {
  display: block;
  font-size: 0.85rem;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  margin-bottom: 4px;
}

.lesson-course-back:hover { color: #ffb800; }

.lesson-sidebar-subtitle {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.4);
  margin: 0;
}

.lesson-nav {
  flex: 1;
  overflow-y: auto;
  padding: 12px 0;
}

.lesson-nav-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 20px;
  text-decoration: none;
  transition: background 150ms ease;
}

.lesson-nav-item:hover {
  background: rgba(255, 255, 255, 0.06);
}

.lesson-nav-item.is-active {
  background: rgba(0, 151, 178, 0.25);
  border-left: 3px solid #0097b2;
}

.lesson-nav-num {
  flex-shrink: 0;
  font-size: 0.75rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.35);
  margin-top: 2px;
  min-width: 20px;
}

.lesson-nav-title {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.4;
}

.lesson-nav-item.is-active .lesson-nav-title {
  color: #fff;
  font-weight: 600;
}

.lesson-main {
  background: #f7f8fa;
  overflow-y: auto;
  padding-bottom: 60px;
}

.lesson-video-wrap {
  background: #000;
  aspect-ratio: 16/9;
  width: 100%;
}

.lesson-video {
  width: 100%;
  height: 100%;
  display: block;
}

.lesson-video-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.4);
  font-size: 0.9rem;
}

.lesson-info {
  padding: 32px 40px 20px;
  max-width: 860px;
}

.lesson-info-eyebrow {
  font-size: 0.78rem;
  color: #0097b2;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 8px;
}

.lesson-info-title {
  font-size: 1.5rem;
  color: #0b2147;
  margin: 0 0 16px;
}

.lesson-info-desc {
  font-size: 0.92rem;
  color: #555;
  line-height: 1.7;
}

.lesson-info-desc p { margin: 0 0 12px; }

.lesson-pagination {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 40px 0;
  max-width: 860px;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  margin-top: 24px;
}

.lesson-pag-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  font-size: 0.85rem;
  color: #0b2147;
  text-decoration: none;
  font-weight: 600;
  transition: background 150ms ease, border-color 150ms ease;
  max-width: 300px;
}

.lesson-pag-btn:hover {
  background: #f0f9fb;
  border-color: #0097b2;
  color: #0097b2;
}

.lesson-pag-btn span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Responsive ───────────────────────────────────────── */
@media (max-width: 1024px) {
  .course-hero-inner {
    grid-template-columns: 1fr;
  }
  .course-hero-media {
    max-width: 480px;
  }
  .course-why-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .course-instructor-inner {
    grid-template-columns: 1fr;
  }
  .course-instructor-photo img {
    max-width: 260px;
  }
}

@media (max-width: 768px) {
  .course-learn-grid {
    grid-template-columns: 1fr;
  }
  .course-materials-grid {
    grid-template-columns: 1fr;
  }
  .course-why-grid {
    grid-template-columns: 1fr;
  }
  .lesson-layout {
    grid-template-columns: 1fr;
  }
  .lesson-sidebar {
    position: static;
    height: auto;
  }
  .lesson-info,
  .lesson-pagination {
    padding-left: 20px;
    padding-right: 20px;
  }
  .course-curriculum-list {
    padding: 0 8px;
  }
}

.course-enrolled-bar {
  background: #0097b2;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  padding: 14px 24px;
  font-size: 0.95rem;
  font-weight: 600;
  border-radius: 16px;
}

.course-enrolled-bar .button {
  background: #fff;
  color: #0097b2;
  font-weight: 700;
  min-height: 36px;
  padding: 0 20px;
  font-size: 0.85rem;
}

.course-enrolled-bar .button:hover {
  background: #f0f9fb;
}

.course-not-enrolled-bar {
  background: #0b2147;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  padding: 14px 24px;
  font-size: 0.95rem;
  font-weight: 600;
  border-radius: 16px;
}

.course-not-enrolled-bar .button {
  background: linear-gradient(135deg, #ff7a00, #ffb800);
  color: #fff;
  font-weight: 700;
  min-height: 36px;
  padding: 0 20px;
  font-size: 0.85rem;
}

/* ── Lesson video shields (block YouTube logo / title link) ── */
.lesson-video-wrap {
  position: relative;
}

.lesson-video-shield {
  position: absolute;
  z-index: 2;
  pointer-events: all;
  left: 0;
  right: 0;
  background: #000;
  height: 52px;
}

/* Barra preta no topo — cobre título e link clicável */
.lesson-video-shield-top {
  top: 0;
}

/* Barra preta embaixo — cobre controles e logo do YouTube */
.lesson-video-shield-br {
  bottom: 0;
  height: 60px;
}

/* ── Course card featured (Workshop) ─────────────────── */
.course-card-featured {
  border: 2px solid #ff7a00;
  box-shadow: 0 8px 32px rgba(255, 122, 0, 0.18);
  position: relative;
}

.course-card-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  background: linear-gradient(135deg, #ff7a00, #ffb800);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 5px 12px;
  border-radius: 999px;
  box-shadow: 0 2px 10px rgba(255, 122, 0, 0.4);
}

/* ============================================================
   FREE MAP PAGE — enhancements
   ============================================================ */

.free-map-highlight {
  color: #ff7a00;
}

.free-map-hero-lead {
  font-size: 0.98rem;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.55;
  margin-bottom: 0;
  max-width: 54ch;
  overflow-wrap: break-word;
}

.free-map-hero-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  margin-top: 14px;
}

.free-map-hero-cta-button {
  font-size: 1rem;
  font-weight: 700;
  border: 1.5px solid rgba(255, 255, 255, 0.6) !important;
}

.free-map-hero-cta-note {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.7);
  margin: 0;
}

.free-map-tension-block {
  padding: 14px 16px;
  background: rgba(255, 80, 80, 0.05);
  border-left: 3px solid #ff4d4f;
  border-radius: 0 8px 8px 0;
  margin-bottom: 20px;
  font-size: 0.9rem;
  width: min(1240px, 100%);
  margin-inline: auto;
  box-sizing: border-box;
}

.free-map-tension-block p {
  margin: 0 0 8px;
  color: var(--text);
  line-height: 1.5;
  font-weight: 600;
}

.free-map-tension-block p:last-child {
  margin-bottom: 0;
}

.free-map-tension-sub {
  font-weight: 400 !important;
  color: rgba(31,43,63,0.7) !important;
  font-size: 0.88rem !important;
}

.free-map-progress {
  font-size: 0.8rem;
  color: var(--muted);
  margin: 0 0 6px;
}

.free-map-preview-intro {
  font-size: 0.9rem;
  color: var(--muted);
  margin: 0 0 10px;
  font-style: italic;
}

/* Fundo escuro no hero da página de mapa gratuito */
.free-map-hero {
  background: radial-gradient(circle at top left, #f4c46b 0%, #ff7a00 18%, #0097b2 55%, #0b2147 100%);
  border-radius: 16px;
  padding: 32px 48px !important;
  margin-bottom: 24px;
}

.free-map-hero h1 {
  color: #fff;
}

.free-map-hero .eyebrow {
  color: rgba(255, 255, 255, 0.65);
}

/* Trust strip */
.free-map-trust {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 14px;
  padding: 12px 32px;
  margin-bottom: 0;
  flex-wrap: wrap;
}

.free-map-trust-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 0 28px;
}

.free-map-trust-item strong {
  font-size: 1.3rem;
  font-weight: 800;
  color: #ff7a00;
}

.free-map-trust-item span {
  font-size: 0.78rem;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.free-map-trust-sep {
  width: 1px;
  height: 32px;
  background: rgba(0, 0, 0, 0.1);
  flex-shrink: 0;
}

/* Discover pillars */
.free-map-discover {
  padding: 56px 0 48px;
}

.free-map-section-head {
  text-align: center;
  margin-bottom: 36px;
}

.free-map-section-head h2 {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  color: #0b2147;
  margin: 8px 0 12px;
}

.free-map-section-head p {
  color: #666;
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.65;
  font-size: 0.95rem;
}

.free-map-pillars {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.free-map-pillar {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 14px;
  padding: 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: box-shadow 180ms ease, transform 180ms ease;
}

.free-map-pillar:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  transform: translateY(-2px);
}

.free-map-pillar-icon {
  font-size: 1.6rem;
  line-height: 1;
}

.free-map-pillar strong {
  font-size: 0.95rem;
  font-weight: 700;
  color: #0b2147;
}

.free-map-pillar p {
  font-size: 0.85rem;
  color: #555;
  line-height: 1.6;
  margin: 0;
}

/* Birth time tip box */
.free-map-time-tip {
  background: rgba(0, 151, 178, 0.05);
  border: 1px solid rgba(0, 151, 178, 0.2);
  border-left: 3px solid #0097b2;
  border-radius: 0 10px 10px 0;
  padding: 14px 18px;
  margin-bottom: 24px;
}

.free-map-time-tip strong {
  display: block;
  margin-bottom: 6px;
  font-size: 0.9rem;
  color: #0b2147;
}

.free-map-time-tip p {
  margin: 0;
  font-size: 0.85rem;
  color: #555;
  line-height: 1.6;
}

/* Sidebar upgrade actions */
.generate-next-hook {
  font-size: 0.84rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.6);
  margin: 8px 0 14px;
}
.generate-next-link {
  color: var(--blue);
  text-decoration: underline;
  white-space: nowrap;
}
.free-map-upgrade-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 16px;
}

.free-map-upgrade-actions .button {
  flex: 1;
  min-width: 120px;
  justify-content: center;
  font-size: 0.82rem;
}

/* FAQ tip card */
.free-map-faq-tip p {
  font-size: 0.88rem;
  color: #555;
  line-height: 1.65;
  margin: 10px 0 14px;
}

.free-map-whatsapp-link {
  display: inline-block;
  font-size: 0.85rem;
  font-weight: 600;
  color: #0097b2;
  text-decoration: none;
}

.free-map-whatsapp-link:hover {
  text-decoration: underline;
}

@media (max-width: 860px) {
  .free-map-pillars {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .free-map-trust {
    gap: 16px;
    padding: 16px 20px;
  }

  .free-map-trust-sep {
    display: none;
  }

  .free-map-trust-item {
    padding: 0 12px;
  }
}

@media (max-width: 540px) {
  .free-map-pillars {
    grid-template-columns: 1fr;
  }
}

.free-map-highlight {
  -webkit-text-stroke: 0.6px #fff;
  paint-order: stroke fill;
}

.free-map-preview h3,
.free-map-upgrade h3,
.free-map-faq-tip h3 {
  font-size: clamp(0.8rem, 1.3vw, 1.05rem);
}

.free-map-faq-inline {
  grid-column: 1;
}

.free-map-left-col {
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-width: 0;
}

.free-map-faq-inline {
  grid-column: unset;
}

.report-upgrade-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 20px;
}

.report-upgrade-card {
  padding: 20px;
  border-radius: 20px;
  border: 1px solid rgba(11, 33, 71, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 233, 0.9));
  box-shadow: 0 14px 34px rgba(11, 33, 71, 0.08);
}

.report-upgrade-card h3 {
  margin: 6px 0 10px;
  color: #0b2147;
}

.report-upgrade-eyebrow {
  margin: 0;
  color: #88643a;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.report-upgrade-price,
.report-upgrade-note {
  margin-bottom: 0;
}

.report-upgrade-note {
  color: #55606f;
  font-size: 0.9rem;
}

.report-upgrade-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.report-upgrade-actions .button {
  width: 100%;
  justify-content: center;
}

@media (max-width: 720px) {
  .report-upgrade-grid {
    grid-template-columns: 1fr;
  }
}

/* ── Split Bodygraph (Design / Personalidade) ─────────────────── */

.split-bodygraph-section {
  padding: 32px 28px 36px;
}

.split-bodygraph-header {
  margin-bottom: 28px;
}

.split-bodygraph-title {
  margin: 6px 0 8px;
  color: #0b2147;
  font-size: 1.28rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.05;
}

.split-bodygraph-lead {
  color: var(--muted);
  font-size: 0.9rem;
  max-width: none;
  margin: 0;
  white-space: nowrap;
}

.split-bodygraph-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px 120px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.split-bg-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  min-width: 0;
  justify-content: start;
}

.split-bg-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0 3% 0;
}

.split-bg-label-design {
  color: #d04948;
}

.split-bg-label-personality {
  color: #1f1f1f;
}

.split-bg-subtitle {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
}

.split-bg-subtitle-design {
  color: #d04948;
}

.split-bg-subtitle-personality {
  color: #1f1f1f;
}

.split-bg-wrap {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex: 1 1 auto;
}

.split-bg-wrap .bodygraph-canvas {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: visible;
}

.split-bg-wrap .bodygraph-svg {
  width: 100%;
  max-width: calc(var(--bg-max-w) * 1.15);
  max-height: calc(var(--bg-max-h) * 0.828);
  transform: none;
}

.split-bg-wrap .bodygraph-background {
  width: min(103.5%, calc(var(--bg-max-h) * 0.828 * 0.9));
  max-width: calc(var(--bg-max-h) * 0.828 * 0.9);
}

.split-bg-middle-table {
  width: 100%;
  min-width: 0;
}

.split-bg-col-middle {
  gap: 12px;
}

.split-bg-col-middle .app-rail-table {
  border-radius: 14px;
}

.split-bg-col-middle .app-rail-table .activation-row {
  grid-template-columns: 1fr;
  gap: 0;
  padding: 4px 6px;
}

.split-bg-col-middle .app-rail-table .planet-cell {
  justify-content: center;
  gap: 4px;
  font-size: 0.72rem;
  line-height: 1.1;
}

.split-bg-col-middle .app-rail-table .planet-symbol {
  font-size: 1.3rem;
}

@media (max-width: 860px) {
  .split-bodygraph-grid {
    grid-template-columns: 1fr;
  }
}

.conversion-paths,
.sales-choice-panel,
.course-path-guide {
  display: grid;
  gap: 24px;
}

.conversion-paths-head,
.sales-choice-head,
.course-path-guide-head,
.analysis-decision-guide {
  display: grid;
  gap: 10px;
}

.conversion-paths-head h2,
.sales-choice-head h2,
.course-path-guide-head h2,
.analysis-decision-guide h2 {
  margin: 0;
  font-size: clamp(1.7rem, 2.6vw, 2.5rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  text-wrap: balance;
}

.conversion-paths-head p:not(.eyebrow),
.sales-choice-head p:not(.eyebrow),
.course-path-guide-head p:not(.eyebrow),
.analysis-decision-guide p:not(.eyebrow) {
  margin: 0;
  color: rgba(31, 43, 63, 0.74);
  font-size: 1rem;
  line-height: 1.65;
}

.conversion-paths-grid,
.sales-choice-grid,
.analysis-decision-grid,
.course-path-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.conversion-path-card,
.sales-choice-card,
.analysis-decision-card,
.course-path-card,
.free-map-next-step-card,
.workspace-sidebar-upsell,
.workspace-sidebar-upsell-list > div {
  display: grid;
  gap: 12px;
  position: relative;
  padding: 22px 22px 20px;
  border-radius: 24px;
  border: 1px solid rgba(26, 107, 181, 0.1);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.96));
  box-shadow: 0 18px 40px rgba(14, 45, 88, 0.06);
  overflow: hidden;
}

.conversion-path-card::before,
.sales-choice-card::before,
.analysis-decision-card::before,
.course-path-card::before,
.free-map-next-step-card::before,
.workspace-sidebar-upsell-list > div::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, rgba(26, 107, 181, 0.92), rgba(0, 151, 178, 0.72));
  opacity: 0.92;
}

.conversion-path-card h3,
.sales-choice-card strong,
.analysis-decision-card strong,
.course-path-card strong,
.free-map-next-step-card strong,
.workspace-sidebar-upsell h3,
.workspace-sidebar-upsell-list strong {
  margin: 0;
  color: #14233d;
  line-height: 1.12;
}

.conversion-path-card h3 {
  font-size: 1.35rem;
  letter-spacing: -0.03em;
}

.sales-choice-card strong,
.analysis-decision-card strong,
.course-path-card strong,
.free-map-next-step-card strong,
.workspace-sidebar-upsell-list strong {
  font-size: 1.05rem;
}

.conversion-path-card p,
.sales-choice-card p,
.analysis-decision-card p,
.course-path-card p,
.free-map-next-step-card p,
.workspace-sidebar-upsell p,
.workspace-sidebar-upsell-list p {
  margin: 0;
  color: rgba(31, 43, 63, 0.76);
  line-height: 1.6;
}

.course-path-card-link {
  align-self: end;
  margin-top: 4px;
  color: var(--blue);
  font-size: 0.88rem;
  font-weight: 600;
  text-decoration: none;
}

.course-path-card-link:hover {
  text-decoration: underline;
}

.conversion-path-card.is-featured,
.sales-choice-card.is-highlighted {
  border-color: rgba(28, 82, 154, 0.24);
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(244, 248, 255, 0.98));
  box-shadow: 0 24px 54px rgba(28, 82, 154, 0.12);
}

.conversion-path-list {
  margin: 0;
}

.conversion-path-list li,
.sales-offer-list li,
.check-list li {
  line-height: 1.5;
}

.sales-choice-actions,
.analysis-decision-actions,
.workspace-sidebar-upsell-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.analysis-decision-guide,
.course-path-guide {
  margin-bottom: 32px;
}


.sales-choice-panel,
.analysis-decision-guide,
.course-path-guide,
.workspace-sidebar-upsell {
  border-radius: 30px;
}

.sales-choice-grid,
.analysis-decision-grid,
.course-path-grid {
  align-items: stretch;
}

.sales-choice-card,
.analysis-decision-card,
.course-path-card {
  min-height: 100%;
}

.sales-choice-actions .button,
.analysis-decision-actions .button,
.workspace-sidebar-upsell-actions .button {
  min-width: 210px;
}

.free-map-decision-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.free-map-decision-strip a {
  padding: 10px 14px;
  border-radius: 999px;
  background: #ff7a00;
  color: #ffffff;
  font-size: 0.92rem;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.15s;
}

.free-map-decision-strip a:hover {
  background: #e06a00;
  color: #ffffff;
}

.free-map-next-step-guide {
  display: grid;
  gap: 16px;
  margin-top: 18px;
  margin-bottom: 18px;
}

.free-map-next-step-card {
  padding: 18px 18px 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.94);
}

.free-map-upgrade-actions .button {
  min-width: 210px;
}

.workspace-sidebar-upsell {
  margin-top: 16px;
  padding: 22px;
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(245, 249, 255, 0.98));
}

.workspace-sidebar-upsell-list {
  display: grid;
  gap: 12px;
}

.sales-offer-card {
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.sales-offer-card:hover,
.conversion-path-card:hover,
.sales-choice-card:hover,
.analysis-decision-card:hover,
.course-path-card:hover,
.course-card:hover,
.analysis-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 52px rgba(14, 45, 88, 0.1);
}

.sales-offer-head h2,
.analysis-card-body h3,
.course-card-title {
  text-wrap: balance;
}

.analysis-card,
.course-card,
.sales-offer-card {
  border-radius: 26px;
}

.analysis-card-actions .button,
.course-card .button,
.sales-offer-card .button {
  min-height: 46px;
}

@media (max-width: 960px) {
  .conversion-paths-grid,
  .sales-choice-grid,
  .analysis-decision-grid,
  .course-path-grid {
    grid-template-columns: 1fr;
  }

  .sales-choice-actions .button,
  .analysis-decision-actions .button,
  .workspace-sidebar-upsell-actions .button,
  .free-map-upgrade-actions .button {
    width: 100%;
    min-width: 0;
  }
}

/* ── Checkout confirm page ──────────────────────────────── */

.checkout-confirm-page {
  padding-top: 4px;
  padding-bottom: 24px;
  padding-inline: 24px;
}

.checkout-confirm-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 24px;
  align-items: start;
  width: min(1240px, 100%);
  margin: 0 auto;
}

/* ── Painel principal ────────────────────────────────────────────── */
.checkout-confirm-product {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 28px 32px;
}

.checkout-confirm-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.checkout-confirm-title {
  font-size: clamp(1.2rem, 2.2vw, 1.65rem);
  font-weight: 800;
  line-height: 1.1;
  color: var(--blue-deep);
  margin: 0;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .checkout-confirm-title-row {
    flex-wrap: wrap;
    gap: 8px;
  }

  .checkout-confirm-title {
    white-space: normal;
    font-size: clamp(1.2rem, 5vw, 1.5rem);
  }
}

.checkout-confirm-description {
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--muted);
  margin: 0;
}
.checkout-emotional-hook {
  font-size: 0.88rem;
  color: rgba(21,34,56,0.65);
  line-height: 1.65;
  margin: 12px 0 0;
  font-style: italic;
  border-left: 3px solid rgba(26,107,181,0.3);
  padding-left: 12px;
}

/* ── Preço ───────────────────────────────────────────────────────── */
.checkout-confirm-price {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 12px 18px;
  background: var(--surface-strong);
  border-radius: var(--radius-sm);
  border-left: 4px solid var(--blue);
  flex-shrink: 0;
}

.checkout-confirm-price strong {
  font-size: clamp(1.7rem, 4vw, 2.2rem);
  font-weight: 900;
  color: var(--blue-deep);
  letter-spacing: -0.02em;
}

.checkout-confirm-cadence {
  font-size: 0.95rem;
  color: var(--muted);
}

/* ── Checkout coupon block ─────────────────────────────── */

.checkout-coupon-block {
  margin-top: 4px;
}

.checkout-coupon-applied {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: 12px;
  background: rgba(39, 174, 96, 0.08);
  border: 1px solid rgba(39, 174, 96, 0.22);
  color: var(--success);
  font-size: 0.88rem;
  margin: 0;
}

.checkout-coupon-applied strong {
  color: var(--success);
}

.checkout-coupon-details summary {
  font-size: 0.85rem;
  color: rgba(31, 43, 63, 0.5);
  cursor: pointer;
  list-style: none;
  padding: 4px 0;
}

.checkout-coupon-details summary::-webkit-details-marker {
  display: none;
}

.checkout-coupon-details summary:hover {
  color: var(--blue);
}

.checkout-coupon-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  margin-top: 10px;
  align-items: start;
}

.checkout-coupon-input {
  width: 100%;
  min-height: 42px;
  padding: 0 12px;
  border: 1px solid rgba(26, 107, 181, 0.18);
  border-radius: 10px;
  background: #ffffff;
  color: var(--text);
  font: inherit;
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.checkout-coupon-input:focus {
  outline: 0;
  border-color: rgba(26, 107, 181, 0.4);
  box-shadow: 0 0 0 3px rgba(26, 107, 181, 0.08);
}

.checkout-coupon-input--error {
  border-color: rgba(192, 57, 43, 0.4);
}

.checkout-coupon-input--error:focus {
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.08);
}

.checkout-coupon-apply {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 10px;
  border: 1px solid rgba(26, 107, 181, 0.22);
  background: rgba(26, 107, 181, 0.08);
  color: var(--blue);
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background 180ms ease;
}

.checkout-coupon-apply:hover {
  background: rgba(26, 107, 181, 0.14);
}

.checkout-coupon-error {
  grid-column: 1 / -1;
  font-size: 0.82rem;
  color: #c0392b;
  margin: 0;
}

.checkout-confirm-price-original {
  font-size: 0.9rem;
  color: rgba(31, 43, 63, 0.4);
  text-decoration: line-through;
  align-self: center;
}

.checkout-confirm-price-discount {
  font-size: 0.8rem;
  color: var(--success);
  font-weight: 700;
  align-self: center;
}

/* ── Lista de benefícios ─────────────────────────────────────────── */
.checkout-confirm-features {
  margin: 0;
  padding-left: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.checkout-confirm-features li {
  font-size: 0.9rem;
  line-height: 1.45;
  color: var(--text);
  padding-left: 1.6em;
  position: relative;
}

.checkout-confirm-features li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--success);
  font-weight: 800;
}

/* ── Métodos de pagamento ────────────────────────────────────────── */
.checkout-confirm-methods {
  font-size: 0.85rem;
  color: var(--muted);
  padding: 10px 14px;
  background: var(--surface-strong);
  border-radius: 12px;
  border: 1px solid rgba(26, 107, 181, 0.08);
}

.checkout-confirm-methods p {
  margin: 0;
}

/* ── Form / CTA ──────────────────────────────────────────────────── */
.checkout-confirm-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.checkout-confirm-cta {
  width: 100%;
  text-align: center;
  padding-block: 14px;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.checkout-confirm-back {
  text-align: center;
  font-size: 0.875rem;
  color: var(--muted);
  text-decoration: none;
}

.checkout-confirm-back:hover {
  color: var(--blue);
}

/* ── Painel lateral de confiança ─────────────────────────────────── */
.checkout-confirm-trust {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 22px 22px;
}

.checkout-confirm-trust-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.checkout-confirm-trust-list li {
  font-size: 0.88rem;
  line-height: 1.4;
  color: var(--muted);
  padding-left: 1.5em;
  position: relative;
}

.checkout-confirm-trust-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--success);
  font-weight: 800;
}

/* ── Responsividade ──────────────────────────────────────────────── */
@media (max-width: 960px) {
  .checkout-confirm-shell {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .checkout-confirm-page {
    padding-block: 16px;
    padding-inline: 16px;
  }

  .checkout-confirm-product {
    padding: 22px 20px;
    gap: 14px;
  }

  .checkout-confirm-trust {
    padding: 18px 18px;
  }
}

/* ===========================
   EMAIL VERIFICATION PAGE
   =========================== */

.verification-page {
  display: flex;
  justify-content: center;
  padding-block: 48px;
}

.verification-panel {
  width: 100%;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
}

.verification-icon {
  font-size: 2.5rem;
  margin-bottom: 12px;
}

.verification-panel .eyebrow {
  margin-bottom: 8px;
}

.verification-panel h1 {
  font-size: clamp(1.3rem, 3vw, 1.7rem);
  line-height: 1.25;
  margin-bottom: 16px;
}

.verification-anticipation {
  font-size: 0.88rem;
  line-height: 1.65;
  color: rgba(31,43,63,0.55);
  margin: 0 0 16px;
  text-align: center;
  font-style: italic;
}
.verification-lead {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(31, 43, 63, 0.7);
  margin-bottom: 28px;
}

.verification-alert {
  width: 100%;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 0.9rem;
  color: #b91c1c;
  margin-bottom: 20px;
}

.verification-notice {
  width: 100%;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 0.9rem;
  color: #15803d;
  margin-bottom: 20px;
}

.verification-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
}

.verification-code-field {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.verification-code-input {
  width: 200px;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.25em;
  padding: 14px 12px;
  border: 2px solid rgba(28, 82, 154, 0.25);
  border-radius: 12px;
  outline: none;
  transition: border-color 0.2s;
}

.verification-code-input:focus {
  border-color: #1c529a;
}

.verification-submit {
  width: 100%;
  max-width: 320px;
}

.verification-resend {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin-bottom: 20px;
}

.verification-resend-label {
  font-size: 0.88rem;
  color: rgba(31, 43, 63, 0.55);
  margin: 0;
}

.verification-resend-form {
  margin: 0;
}

.verification-resend-button {
  background: none;
  border: none;
  padding: 0;
  color: #1c529a;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: underline;
}

.verification-hint {
  font-size: 0.82rem;
  color: rgba(31, 43, 63, 0.4);
  margin: 0;
}

.verification-expiry {
  font-size: 0.82rem;
  color: rgba(31, 43, 63, 0.45);
  margin-bottom: 24px;
}

.verification-back {
  font-size: 0.88rem;
  color: rgba(31, 43, 63, 0.5);
  text-decoration: none;
}

.verification-back:hover {
  color: #1c529a;
}

@media (max-width: 600px) {
  .verification-page {
    padding-block: 24px;
  }

  .verification-code-input {
    width: 160px;
    font-size: 1.6rem;
  }
}

.verification-delivery-hint {
  font-size: 0.85rem;
  color: rgba(31, 43, 63, 0.55);
  margin: 0 0 14px;
}

.verification-open-email {
  margin-bottom: 28px;
  font-size: 0.9rem;
  padding: 10px 20px;
}

/* ===========================
   MAP LOADING PAGE
   =========================== */

.map-loading-page {
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
  background: #f4f7fb;
}

.map-loading-card {
  background: #ffffff;
  border-radius: 20px;
  border: 1px solid rgba(28, 82, 154, 0.1);
  padding: 48px 40px;
  max-width: 440px;
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.map-loading-spinner {
  width: 72px;
  height: 72px;
}

.map-loading-arc {
  transform-origin: 40px 40px;
  animation: map-loading-spin 1s linear infinite;
}

@keyframes map-loading-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

.map-loading-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: #1f2b3f;
  margin: 0;
}

.map-loading-sub {
  font-size: 0.9rem;
  color: rgba(31, 43, 63, 0.6);
  line-height: 1.6;
  margin: 0;
}

.map-loading-steps {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.map-loading-step {
  font-size: 0.88rem;
  color: rgba(31, 43, 63, 0.35);
  margin: 0;
  padding: 10px 16px;
  border-radius: 8px;
  transition: background 0.3s, color 0.3s;
}

.map-loading-step.is-active {
  background: rgba(28, 82, 154, 0.07);
  color: #1c529a;
  font-weight: 600;
}

/* ===========================
   WORKSPACE EMOTIONAL HOOK
   =========================== */

.workspace-emotional-hook {
  background: #1a2e50;
  padding: 28px 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.workspace-emotional-hook-intro {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
}

.workspace-emotional-hook-eyebrow {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.75);
  margin: 0;
  white-space: nowrap;
}

.workspace-emotional-hook-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #f59e0b;
  color: #1a1a00;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  min-height: 48px;
  padding: 0 28px;
  border-radius: 999px;
  margin: 0;
  flex-shrink: 0;
}

.workspace-emotional-hook-subtitle {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.75);
  margin: 0;
  white-space: nowrap;
}

.workspace-emotional-hook-type-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #1a2e50;
  opacity: 0.5;
  display: inline-block;
}

.workspace-emotional-hook-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 0 48px;
  width: 100%;
  max-width: 960px;
  align-items: center;
}

.workspace-emotional-hook-headline {
  grid-column: 1;
  grid-row: 1 / 3;
  font-size: 24px;
  font-weight: 500;
  color: #e2eaf8;
  line-height: 1.4;
  text-align: left;
  margin: 0;
  align-self: center;
}

.workspace-emotional-hook-divider {
  display: none;
}

.workspace-emotional-hook-pain {
  grid-column: 2;
  grid-row: 1;
  font-size: 15px;
  color: #93b5d4;
  line-height: 1.7;
  margin-bottom: 16px;
  border-left: 2px solid #2e4a6e;
  padding-left: 16px;
  text-align: left;
  border-radius: 0;
}

.workspace-emotional-hook-bridge {
  grid-column: 2;
  grid-row: 2;
  font-size: 14px;
  color: #c8dff0;
  line-height: 1.6;
  font-style: italic;
  padding: 14px 20px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 8px;
  text-align: left;
}

.workspace-emotional-hook-bridge strong {
  color: #f59e0b;
  font-style: normal;
  font-weight: 500;
}

@media (max-width: 768px) {
  .workspace-emotional-hook {
    padding: 28px 20px;
  }

  .workspace-emotional-hook-body {
    grid-template-columns: 1fr;
    gap: 20px 0;
  }

  .workspace-emotional-hook-headline {
    grid-column: 1;
    grid-row: 1;
    font-size: 20px;
    text-align: center;
  }

  .workspace-emotional-hook-pain {
    grid-column: 1;
    grid-row: 2;
  }

  .workspace-emotional-hook-bridge {
    grid-column: 1;
    grid-row: 3;
  }
}

.workspace-upgrade-banner-cost {
  font-size: 0.88rem;
  line-height: 1.6;
  color: rgba(31, 43, 63, 0.7);
  margin: 0 0 10px;
  font-style: italic;
}

.workspace-upgrade-banner-social-proof {
  font-size: 13px;
  color: #6b7280;
  margin: 0;
}

.workspace-upgrade-banner-urgency {
  font-size: 13px;
  color: #9ca3af;
  margin: 0;
}

/* ===========================
   NEXT STEP BLOCK
   =========================== */

.next-step-block {
  background: var(--color-background-primary);
  border-bottom: 0.5px solid var(--color-border-tertiary);
  padding: 28px 48px;
}

.next-step-inner {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 0 48px;
  align-items: center;
  max-width: 960px;
  margin: 0 auto;
}

.next-step-eyebrow {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #f59e0b;
  margin-bottom: 8px;
}

.next-step-headline {
  font-size: 22px;
  font-weight: 500;
  color: var(--color-text-primary);
  line-height: 1.35;
  margin-bottom: 10px;
}

.next-step-body {
  font-size: 15px;
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin: 0;
}

.next-step-action {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
}

.next-step-social {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: 0;
}

.next-step-cta {
  width: 100%;
  text-align: center;
}

.next-step-micro {
  font-size: 12px;
  color: var(--color-text-tertiary);
  margin: 0;
  text-align: center;
  width: 100%;
}

@media (max-width: 768px) {
  .next-step-block {
    padding: 24px 20px;
  }

  .next-step-inner {
    grid-template-columns: 1fr;
    gap: 20px 0;
  }
}

/* ===========================
   PROGRESS MAP
   =========================== */

.progress-map {
  background: var(--color-background-secondary);
  border-bottom: 0.5px solid var(--color-border-tertiary);
  padding: 24px 48px;
}

.progress-map-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  max-width: 960px;
  margin: 0 auto;
}

.progress-map-title {
  font-size: 16px;
  font-weight: 500;
  color: var(--color-text-primary);
  margin: 0 0 4px;
}

.progress-map-subtitle {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: 0;
}

.progress-map-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 0.5px solid var(--color-border-secondary);
  color: var(--color-text-secondary);
  font-size: 13px;
  padding: 6px 14px;
  border-radius: 999px;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}

.progress-map-toggle:hover {
  border-color: var(--color-border-primary);
  color: var(--color-text-primary);
}

.progress-map-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 960px;
  margin: 20px auto 0;
}

.progress-card {
  background: #ffffff;
  border: 1.5px solid var(--color-border, rgba(0,0,0,0.10));
  border-radius: 12px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color 0.15s;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.progress-card--locked {
  background: var(--color-surface-muted, #f8f9fb);
  border-color: rgba(0,0,0,0.06);
}

.progress-card--available {
  border-color: var(--color-border-secondary);
}

.progress-card--available:hover {
  border-color: var(--color-border-primary);
}

.progress-card--completed {
  border-color: var(--color-border-success);
}

.progress-card--recommended {
  border-color: var(--blue, #1a6bb5);
  box-shadow: 0 2px 12px rgba(26,107,181,0.12);
}

.progress-card-badge {
  font-size: 10px;
  font-weight: 500;
  color: #92400e;
  background: #fef3c7;
  padding: 3px 8px;
  border-radius: 4px;
  display: inline-block;
  margin: 0;
  align-self: flex-start;
}

.progress-card-status-icon {
  font-size: 16px;
}

.progress-status-completed {
  color: var(--color-text-success);
}

.progress-status-available {
  color: #f59e0b;
}

.progress-status-locked {
  color: var(--color-text-tertiary);
}

.progress-card-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-primary);
  margin: 0;
  line-height: 1.3;
}

.progress-card-description {
  font-size: 13px;
  color: var(--color-text-secondary);
  line-height: 1.5;
  margin: 0;
  flex: 1;
}

.progress-card-footer {
  margin-top: 4px;
}

.progress-card-cta {
  font-size: 13px;
  color: #f59e0b;
  text-decoration: none;
  font-weight: 500;
}

.progress-card-cta:hover {
  text-decoration: underline;
}

.progress-card-done {
  font-size: 12px;
  color: var(--color-text-success);
  font-weight: 500;
}

.progress-card-locked-label {
  font-size: 12px;
  color: var(--color-text-tertiary);
}

@media (max-width: 1024px) {
  .progress-map-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .progress-map {
    padding: 20px 16px;
  }

  .progress-map-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .progress-map-grid {
    grid-template-columns: 1fr;
  }
}

/* ===========================
   JORNADA MAP (public page)
   =========================== */

.jornada-map-page {
  padding-bottom: 64px;
}

.jornada-map-hero {
  text-align: center;
  padding: 56px 24px 40px;
  max-width: 800px;
  margin: 0 auto;
}

.jornada-map-hero h1 {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  line-height: 1.15;
  white-space: balance;
  max-width: 100%;
}

.jornada-map-intro {
  font-size: 15px;
  color: var(--color-text-secondary);
  line-height: 1.65;
  margin: 16px 0 0;
}

.progress-map--public {
  background: transparent;
  border-bottom: none;
  padding: 0 48px 48px;
  margin-top: 16px;
}

.progress-map-grid--visible {
  display: grid;
  margin-top: 0;
}

.progress-card {
  position: relative;
}

.progress-card-completion {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid #1a1a1a;
  background: transparent;
  flex-shrink: 0;
}

.progress-card-completion--filled {
  background: var(--orange, #ff7a00);
  border-color: var(--orange, #ff7a00);
}

.progress-map--public .progress-card {
  border: 1.5px solid var(--color-border, rgba(0,0,0,0.10));
  border-radius: 12px;
  padding: 20px;
  background: #ffffff;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.progress-map--public .progress-card--recommended {
  border-color: var(--blue, #1a6bb5);
  box-shadow: 0 2px 12px rgba(26,107,181,0.12);
}

.progress-map--public .progress-card--locked {
  background: var(--color-surface-muted, #f8f9fb);
  border-color: rgba(0,0,0,0.06);
}

.progress-map--public .progress-map-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

@media (max-width: 768px) {
  .progress-map--public {
    padding: 0 16px 40px;
  }

  .progress-map--public .progress-map-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ===========================
   CONNECTIVITY
   =========================== */

.connectivity-form {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 24px 48px;
}

.connectivity-selector-form {
  max-width: 980px;
}

.connectivity-selector-shell {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.connectivity-selector-intro {
  text-align: center;
}

.connectivity-selector-title {
  font-size: 28px;
  line-height: 1.15;
  margin: 0 0 10px;
  color: var(--color-text-primary);
}

.connectivity-selector-copy {
  max-width: 680px;
  margin: 0 auto;
  color: var(--color-text-secondary);
  line-height: 1.6;
}

.connectivity-library-selectors {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}

.connectivity-chart-select-card {
  margin-bottom: 0;
}

.connectivity-empty-state {
  max-width: 760px;
  margin: 0 auto 48px;
  text-align: center;
}

.connectivity-empty-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.connectivity-person-section {
  background: var(--color-background-primary);
  border: 0.5px solid var(--color-border-secondary);
  border-radius: var(--border-radius-lg);
  padding: 24px;
  margin-bottom: 0;
}

.connectivity-person-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}

.connectivity-person-badge {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--color-accent-primary);
  color: white;
  padding: 3px 10px;
  border-radius: 999px;
}

.connectivity-person-badge--b {
  background: #7c3aed;
}

.connectivity-person-title {
  font-size: 16px;
  font-weight: 500;
  color: var(--color-text-primary);
  margin: 0;
}

.connectivity-primary-confirm {
  background: var(--color-background-secondary);
  border-radius: var(--border-radius-md);
  padding: 16px;
}

.connectivity-primary-name {
  font-size: 16px;
  font-weight: 500;
  color: var(--color-text-primary);
  margin: 0 0 4px;
}

.connectivity-primary-meta {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: 0;
}

.connectivity-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 0;
}

.connectivity-divider-icon {
  font-size: 20px;
  color: var(--color-text-tertiary);
}

.connectivity-birth-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.connectivity-submit {
  text-align: center;
  padding-top: 32px;
}

.connectivity-submit-btn {
  width: 100%;
  max-width: 360px;
  font-size: 16px;
  padding: 14px 24px;
}

.connectivity-submit-micro {
  font-size: 12px;
  color: var(--color-text-tertiary);
  margin-top: 8px;
}

/* Result page */

.connectivity-result-page {
  max-width: 1380px;
  margin: 0 auto;
  padding: 0 24px 64px;
}

.connectivity-result-page .bodygraph-background,
.connectivity-result-page .bodygraph-silhouette {
  display: none !important;
}

.connectivity-result-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 1400px;
  margin: 0 auto;
  padding: 56px 0 28px;
}

.connectivity-result-header .eyebrow {
  font-size: clamp(28px, 3vw, 48px);
  line-height: 1.1;
}

.connectivity-legend {
  position: static;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px 14px;
  margin-top: 20px;
}

.connectivity-result-header h1 {
  font-size: 18px;
  line-height: 1.02;
  letter-spacing: -0.03em;
  margin-bottom: 12px;
}

.connectivity-result-header .connectivity-title {
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  font-size: 18px;
  line-height: 1.02;
  letter-spacing: -0.03em;
  text-align: center;
  width: 100%;
  max-width: none;
  margin-left: auto;
  margin-right: auto;
}

.connectivity-plus {
  color: var(--color-text-tertiary);
  font-weight: 300;
  display: inline-block;
  margin: 0 6px;
}

.connectivity-theme {
  font-size: 14px;
  letter-spacing: 0.01em;
  color: var(--color-text-secondary);
  margin: 0;
}

.connectivity-summary {
  margin: 12px auto 0;
  max-width: 640px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--color-text-secondary);
}

.connectivity-result-people {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 32px;
}

.connectivity-person-card {
  border-radius: 0;
  padding: 12px 14px 10px;
  border: 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.14);
  min-height: 0;
  height: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
}

.connectivity-person-card--a {
  background: linear-gradient(180deg, rgba(37,99,235,0.09), rgba(37,99,235,0.03));
}

.connectivity-person-card--a .connectivity-person-card-name {
  color: #2563eb;
}

.connectivity-person-card--b {
  background: linear-gradient(180deg, rgba(22,163,74,0.09), rgba(22,163,74,0.03));
}

.connectivity-person-card--b .connectivity-person-card-name {
  color: #16a34a;
}

.connectivity-person-card-name {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 14px;
  line-height: 1.25;
  font-weight: 500;
  color: var(--color-text-primary);
  margin: 0;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  justify-content: center;
}

.connectivity-person-card-name .connectivity-person-swatch {
  margin-top: 3px;
  flex: 0 0 12px;
  align-self: flex-start;
}

.connectivity-person-card-name-lines,
.connectivity-person-card-meta-lines {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  align-items: center;
  text-align: center;
}

.connectivity-person-card-name-line,
.connectivity-person-card-meta-line {
  display: block;
}

.connectivity-person-card-kicker {
  margin: 0 0 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
}

.connectivity-person-card-meta {
  font-size: 11px;
  line-height: 1.4;
  color: var(--color-text-secondary);
  margin: 0;
  text-align: center;
}

.connectivity-person-card-note {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 12px 0 0;
  font-size: 11px;
  line-height: 1.4;
  color: var(--color-text-secondary);
}

.connectivity-channel-section {
  padding: 24px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.05);
}

.connectivity-channel-title {
  font-size: 16px;
  font-weight: 500;
  margin: 0 0 8px;
}

.connectivity-channel-title--electromagnetic { color: #059669; }
.connectivity-channel-title--companionship   { color: #2563eb; }
.connectivity-channel-title--dominance       { color: #d97706; }
.connectivity-channel-title--dominance-a    { color: #d97706; }
.connectivity-channel-title--dominance-b    { color: #7c3aed; }
.connectivity-channel-title--compromise      { color: #dc2626; }

.connectivity-channel-description {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: 0 0 16px;
  line-height: 1.5;
}

.connectivity-dominance-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--color-text-secondary);
  margin: 12px 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.connectivity-channel-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.connectivity-channel-item {
  font-size: 13px;
  font-weight: 500;
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px solid;
}

.connectivity-channel-item--electromagnetic { color: #059669; border-color: #059669; background: rgba(5,150,105,0.06); }
.connectivity-channel-item--companionship   { color: #2563eb; border-color: #2563eb; background: rgba(37,99,235,0.06); }
.connectivity-channel-item--dominance-a     { color: #d97706; border-color: #d97706; background: rgba(217,119,6,0.06); }
.connectivity-channel-item--dominance-b     { color: #7c3aed; border-color: #7c3aed; background: rgba(124,58,237,0.06); }
.connectivity-channel-item--compromise      { color: #dc2626; border-color: #dc2626; background: rgba(220,38,38,0.06); }

.connectivity-result-cta {
  text-align: center;
  padding: 36px 28px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.05);
  margin-top: 40px;
}

.connectivity-result-cta-eyebrow {
  margin: 0 0 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
}

.connectivity-result-cta-text {
  max-width: 620px;
  margin: 0 auto 20px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--color-text-secondary);
}

.connectivity-result-cta-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.connectivity-result-cta-micro {
  font-size: 12px;
  color: var(--color-text-tertiary);
  margin: 0;
}

.connectivity-bodygraph-section {
  margin: 10px 0 40px;
}

.connectivity-layout {
  display: grid;
  grid-template-columns: 196px minmax(0, 1fr) 196px 214px;
  gap: 20px;
  align-items: stretch;
  width: 100%;
}

.person-column {
  display: flex;
  flex-direction: column;
  align-self: stretch;
}

.connectivity-bodygraph-center {
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  min-height: 100%;
  min-width: 0;
}

.connectivity-summary-column {
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-height: 100%;
}

.connectivity-person-panel {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: 112px auto;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
  box-shadow: 0 20px 42px rgba(15, 23, 42, 0.05);
  overflow: hidden;
}

.connectivity-summary-panel {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(148, 163, 184, 0.14);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.92));
  box-shadow: 0 20px 42px rgba(15, 23, 42, 0.05);
}

.connectivity-summary-block {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.connectivity-summary-block + .connectivity-summary-block {
  padding-top: 14px;
  border-top: 1px solid rgba(148, 163, 184, 0.14);
}

.connectivity-summary-label {
  margin: 0;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
}

.connectivity-summary-people-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.connectivity-summary-people-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 12px;
  line-height: 1.45;
  color: var(--color-text-secondary);
}

.connectivity-summary-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.connectivity-summary-panel .connectivity-legend-item {
  width: fit-content;
}

.connectivity-summary-theme,
.connectivity-summary-copy {
  margin: 0;
  font-size: 13px;
  line-height: 1.6;
  color: var(--color-text-secondary);
}

.connectivity-summary-theme {
  font-weight: 600;
  color: var(--color-text-primary);
}

.person-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 4px;
  align-items: start;
  padding: 12px 14px;
}

.design-column,
.personality-column {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.planet-column {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.connectivity-grid-heading {
  margin: 0 0 2px;
  position: relative;
  white-space: nowrap;
  display: block;
  width: 100%;
  text-align: center;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
}

.personality-column .connectivity-grid-heading {
  left: 0;
}

.connectivity-grid-heading--planets {
  opacity: 0;
  pointer-events: none;
}

.connectivity-planet-row {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
}

.connectivity-side-row {
  display: flex;
  align-items: center;
  min-height: 24px;
  font-size: 12px;
}

.connectivity-layout .design-column .connectivity-side-row {
  justify-content: center;
  color: #d84a4a !important;
  font-weight: 500;
}

.connectivity-layout .personality-column .connectivity-side-row {
  justify-content: center;
  color: #111111 !important;
  font-weight: 500;
}

.connectivity-layout .planet-column .planet-symbol {
  color: #9ca3af !important;
  opacity: 0.9;
  font-size: 19.8px;
  line-height: 1.1;
}

.connectivity-layout .gate-value {
  font-size: 1em;
  font-weight: 600;
}

.connectivity-layout .gate-line {
  font-size: 0.68em;
  font-weight: 500;
  vertical-align: baseline;
}

.design-column .connectivity-side-row span {
  text-align: right;
  display: block;
  width: 100%;
}

.personality-column .connectivity-side-row span {
  text-align: left;
  display: block;
  width: 100%;
}

.connectivity-layout .connectivity-side-row .gate-value,
.connectivity-layout .connectivity-side-row .gate-line {
  display: inline;
  width: auto;
}

.connectivity-bodygraph-stage {
  padding: 22px 22px 28px;
  border: none !important;
  border-radius: 32px;
  background: transparent !important;
  box-shadow: none !important;
}

.connectivity-people-legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: 0;
}

.connectivity-people-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(255,255,255,0.84);
  color: var(--color-text-secondary);
  font-size: 12px;
  line-height: 1.35;
}

.connectivity-person-swatch {
  width: 12px;
  height: 12px;
  margin-top: 4px;
  flex: 0 0 12px;
  border-radius: 999px;
  box-shadow: 0 0 0 4px rgba(255,255,255,0.82), 0 0 0 1px rgba(15, 23, 42, 0.08);
}

.connectivity-person-swatch--a { background: #2563eb; }
.connectivity-person-swatch--b { background: #16a34a; }
.connectivity-person-swatch--shared { background: #4b5563; }

.connectivity-bodygraph-legend {
  position: static;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 14px;
  margin: 0;
}

.connectivity-bodygraph-wrap {
  max-width: 806px;
  margin: 32px auto 0;
  transform: scale(1.404);
  transform-origin: center center;
  overflow: visible;
}

.connectivity-bodygraph-wrap .bodygraph-background {
  transform: scale(0.65);
  transform-origin: center center;
  opacity: 0.35;
}

.connectivity-legend-item {
  position: static;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid;
}

.connectivity-legend-item--electromagnetic { color: #059669; border-color: #059669; background: rgba(5,150,105,0.08); }
.connectivity-legend-item--companionship   { color: #2563eb; border-color: #2563eb; background: rgba(37,99,235,0.08); }
.connectivity-legend-item--dominance-a     { color: #d97706; border-color: #d97706; background: rgba(217,119,6,0.08); }
.connectivity-legend-item--dominance-b     { color: #7c3aed; border-color: #7c3aed; background: rgba(124,58,237,0.08); }
.connectivity-legend-item--compromise      { color: #dc2626; border-color: #dc2626; background: rgba(220,38,38,0.08); }

.connectivity-layout .compact-table,
.connectivity-layout .design-table,
.connectivity-layout .personality-table {
  border: none;
  background: transparent;
  box-shadow: none;
}

.connectivity-layout .activation-row {
  border-bottom: 1px solid rgba(148,163,184,0.15);
  padding: 6px 0;
  color: inherit;
}

.connectivity-layout .connectivity-side-row span {
  color: inherit !important;
}

.connectivity-layout .activation-row,
.connectivity-layout .compact-row,
.connectivity-layout .planet-cell {
  color: inherit !important;
}

.connectivity-insights {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 8px;
}

.connectivity-bodygraph-wrap .bodygraph-canvas {
  width: 100%;
}

/* Composite channel colors in SVG */
.connectivity-bodygraph-wrap .bodygraph-channel.is-electromagnetic { opacity: 1; }
.connectivity-bodygraph-wrap .bodygraph-channel.is-companionship   { opacity: 1; }
.connectivity-bodygraph-wrap .bodygraph-channel.is-dominance-a     { opacity: 1; }
.connectivity-bodygraph-wrap .bodygraph-channel.is-dominance-b     { opacity: 1; }
.connectivity-bodygraph-wrap .bodygraph-channel.is-compromise      { opacity: 1; }

/* ── Connectivity Report landing (.cr-*) ─────────────────────────────────── */
.cr-page .page-hero { max-width: none; width: 100%; }

.cr-hero-actions .button.button-outline,
.cr-cta-buttons .button.button-outline {
  background: rgba(255, 255, 255, 0.96);
  color: #0f3b78;
  border-color: rgba(15, 59, 120, 0.18);
}
.cr-hero-actions .button.button-outline:hover,
.cr-cta-buttons .button.button-outline:hover {
  background: #ffffff;
  color: #0f3b78;
  border-color: rgba(15, 59, 120, 0.28);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.cr-hero-context {
  margin: 22px auto 0;
  text-align: center;
}
.cr-hero-context-label {
  margin: 0 0 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  opacity: 0.85;
}
.cr-hero-context-names {
  display: block;
  font-size: 1.6rem;
  font-weight: 600;
  color: white;
  margin-top: 8px;
  margin-bottom: 6px;
  white-space: normal;
  text-align: center;
  line-height: 1.2;
}
.cr-hero-context-note {
  margin: 0;
  font-size: 13px;
  text-align: center;
  opacity: 0.9;
}

.cr-hero-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 28px;
}
.cr-hero-micro {
  margin: 12px 0 0;
  font-size: 12px;
  text-align: center;
}
.cr-page .cr-hero .cr-hero-micro {
  color: rgba(255,255,255,0.65);
}

.cr-hero-scroll-hint {
  display: block;
  margin-top: 16px;
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  letter-spacing: 0.02em;
  text-align: center;
}
.cr-hero-scroll-hint:hover { color: #ffffff; }

.cr-pain-section {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 32px;
  align-items: center;
  padding: 36px 40px;
}

.cr-pain-section .analysis-section-head h2 {
  font-size: clamp(1.4rem, 2.2vw, 2rem);
}

.cr-pain-proof {
  display: grid;
  gap: 12px;
  padding: 20px 22px;
  border-radius: 16px;
  background: rgba(26, 107, 181, 0.05);
  border: 1px solid rgba(26, 107, 181, 0.1);
}

.cr-pain-proof-item {
  font-size: 0.92rem;
  color: rgba(31, 43, 63, 0.78);
  line-height: 1.55;
  padding-left: 16px;
  position: relative;
  margin: 0;
}

.cr-pain-proof-item::before {
  content: "—";
  position: absolute;
  left: 0;
  color: rgba(26, 107, 181, 0.4);
}

@media (max-width: 720px) {
  .cr-pain-section {
    grid-template-columns: 1fr;
  }
}

.cr-pain-body {
  max-width: 680px;
  font-size: 1.05rem;
  line-height: 1.75;
  color: rgba(31, 43, 63, 0.78);
  margin: 0;
}

.cr-deliverables-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 10px;
}
.cr-deliverables-closing {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid rgba(26, 107, 181, 0.08);
  font-size: 0.95rem;
  color: rgba(31, 43, 63, 0.7);
  font-style: italic;
  line-height: 1.6;
  max-width: 560px;
}

.cr-connection-section { margin-top: 0; }

.cr-connection-card {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: center;
  padding: 28px 32px;
  background: rgba(26, 107, 181, 0.04);
  border: 1px solid rgba(26, 107, 181, 0.12);
  border-radius: 24px;
  margin-top: 10px;
}
.cr-connection-card-names { flex: 1 1 200px; }
.cr-connection-card-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  margin-bottom: 4px;
}
.cr-connection-card-pair {
  font-size: 1.4rem;
  color: var(--color-text-primary);
  white-space: normal;
  overflow: visible;
  word-break: break-word;
}
.cr-connection-card-meta {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1 1 160px;
}
.cr-connection-card-meta-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
}
.cr-connection-card-meta-value {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
}

.cr-steps {
  display: grid;
  gap: 14px;
  counter-reset: cr-step;
}

.cr-steps article {
  counter-increment: cr-step;
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 0 16px;
  padding: 20px 22px;
  border-radius: 16px;
  border: 1px solid rgba(26, 107, 181, 0.08);
  background: rgba(255, 255, 255, 0.7);
  align-items: start;
}

.cr-steps article::before {
  content: counter(cr-step);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(26, 107, 181, 0.12), rgba(0, 151, 178, 0.18));
  border: 1px solid rgba(26, 107, 181, 0.18);
  color: #1a6bb5;
  font-size: 0.9rem;
  font-weight: 800;
  grid-row: 1 / 3;
}

.cr-steps article strong {
  display: block;
  margin-bottom: 6px;
  color: #14233d;
  font-size: 1rem;
  grid-column: 2;
  grid-row: 1;
}

.cr-steps article p {
  color: rgba(31, 43, 63, 0.76);
  line-height: 1.6;
  margin: 0;
  grid-column: 2;
  grid-row: 2;
}

.cr-cta-eyebrow {
  margin: 0 0 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
}
.cr-cta-title {
  margin: 0 auto 24px;
  max-width: 520px;
  font-size: clamp(1.3rem, 2.6vw, 1.75rem);
  line-height: 1.2;
}
.cr-cta-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.cr-cta-micro {
  font-size: 12px;
  color: var(--color-text-tertiary);
  margin: 0;
}

/* Report view */
/* Report sections — each is an independent content-panel card */
.cr-report-section {
  margin-bottom: 28px;
  border-left-width: 4px;
}
.cr-report-section:last-of-type {
  margin-bottom: 0;
}

/* Remove orange hover bar from report page panels */
.cr-page .content-panel::before {
  display: none;
}

/* Section accent colors — system palette */
.cr-report-section--eletromagnetico { border-left-color: #059669; }
.cr-report-section--companheirismo  { border-left-color: #2563eb; }
.cr-report-section--dominancia_a    { border-left-color: #d97706; }
.cr-report-section--dominancia_b    { border-left-color: #7c3aed; }
.cr-report-section--compromisso     { border-left-color: #dc2626; }
.cr-report-section--abertura,
.cr-report-section--essencia,
.cr-report-section--padroes,
.cr-report-section--riscos,
.cr-report-section--potencial,
.cr-report-section--orientacao      { border-left-color: rgba(26, 107, 181, 0.35); }

.cr-report-body {
  color: var(--color-text-secondary);
  line-height: 1.7;
  max-width: 720px;
  margin: 0 0 20px;
}
.cr-report-items {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cr-report-item {
  padding: 16px 20px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 10px;
  line-height: 1.6;
  color: var(--color-text-primary);
  font-size: 0.95rem;
}

/* Item accent colors — match section */
.cr-report-section--eletromagnetico .cr-report-item { border-left: 3px solid #059669; }
.cr-report-section--companheirismo  .cr-report-item { border-left: 3px solid #2563eb; }
.cr-report-section--dominancia_a    .cr-report-item { border-left: 3px solid #d97706; }
.cr-report-section--dominancia_b    .cr-report-item { border-left: 3px solid #7c3aed; }
.cr-report-section--compromisso     .cr-report-item { border-left: 3px solid #dc2626; }

.cr-report-item--channel { gap: 14px; display: flex; flex-direction: column; }
.cr-report-item-title { font-size: 1rem; font-weight: 700; color: var(--color-text-primary); }
.cr-report-item-body { font-size: 0.875rem; color: var(--color-text-secondary); line-height: 1.65; margin: 0; }
.cr-channel-field { display: flex; flex-direction: column; gap: 4px; }
.cr-channel-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
}
.cr-channel-field--tension  .cr-channel-label { color: #b45309; }
.cr-channel-field--potential .cr-channel-label { color: #059669; }
.cr-channel-body { font-size: 0.875rem; color: var(--color-text-secondary); line-height: 1.7; margin: 0; }
.cr-report-theme {
  font-size: 1rem;
  color: rgba(255,255,255,0.8);
  margin: 8px 0 0;
}

/* ─── Micro-interações do relatório de conectividade ─────────────────────── */

@keyframes cr-fade-up {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.cr-page .cr-hero {
  animation: cr-fade-up 480ms ease-out both;
}

.cr-page .cr-report-section {
  animation: cr-fade-up 480ms ease-out both;
  animation-delay: var(--anim-delay, 0ms);
}

.cr-page .cr-cta {
  animation: cr-fade-up 480ms ease-out both;
}

.cr-page .cr-conversion-block {
  display: grid;
  gap: 10px;
  margin-top: 22px;
  padding: 28px 30px;
  border-radius: 28px;
  border: 1px solid rgba(28, 82, 154, 0.14);
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.18), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(244, 248, 255, 0.98));
  box-shadow: 0 24px 54px rgba(28, 82, 154, 0.1);
}

.cr-page .cr-conversion-block--impact,
.cr-page .cr-cta {
  margin-top: 28px;
}

.cr-page .cr-conversion-block--impact {
  text-align: center;
}

.cr-page .cr-conversion-block--impact .cr-conversion-lead,
.cr-page .cr-conversion-block--impact .cr-conversion-support,
.cr-page .cr-conversion-block--impact .cr-conversion-cta {
  margin-left: auto;
  margin-right: auto;
}

.cr-page .cr-conversion-block--impact .cr-conversion-actions {
  justify-content: center;
}

.cr-page .cr-conversion-intro,
.cr-page .cr-conversion-lead,
.cr-page .cr-conversion-support,
.cr-page .cr-cta-closing,
.cr-page .cr-cta-title,
.cr-page .cr-cta-micro,
.cr-page .cr-cta-eyebrow {
  margin: 0;
  color: #25344d;
  line-height: 1.55;
}

.cr-page .cr-conversion-intro,
.cr-page .cr-conversion-lead,
.cr-page .cr-cta-closing {
  font-size: clamp(1.1rem, 1.8vw, 1.35rem);
  font-weight: 600;
}

.cr-page .cr-conversion-support {
  color: rgba(31, 43, 63, 0.76);
  font-size: 1.02rem;
}

.cr-page .cr-conversion-cta {
  margin: 0;
  color: #14233d;
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.03em;
  text-wrap: balance;
}

.cr-page .cr-conversion-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 2px;
}

.cr-page .cr-conversion-button {
  min-height: 52px;
  padding-inline: 24px;
  font-size: 0.98rem;
}

.cr-conversion-button-secondary {
  font-size: 0.88rem;
  min-height: 44px;
  padding: 0 20px;
  color: rgba(31, 43, 63, 0.72);
  border-color: rgba(31, 43, 63, 0.18);
}

.cr-conversion-button-secondary:hover {
  border-color: rgba(31, 43, 63, 0.32);
  color: #14233d;
}

.cr-conversion-secondary-link {
  margin: 4px 0 0;
  font-size: 0.85rem;
  color: rgba(31, 43, 63, 0.55);
  text-align: center;
}
.cr-conversion-secondary-link a {
  color: rgba(31, 43, 63, 0.65);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cr-conversion-secondary-link a:hover { color: #14233d; }
.cr-page .cr-hero .cr-conversion-secondary-link a {
  color: rgba(180, 210, 255, 0.9) !important;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cr-page .cr-hero .cr-conversion-secondary-link a:hover {
  color: #ffffff !important;
}

.cr-page .cr-hero .cr-conversion-block {
  text-align: center;
}
.cr-page .cr-hero .cr-conversion-actions {
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.cr-page .cr-hero-actions,
.cr-page .cr-conversion-actions,
.cr-page .cr-cta-buttons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

@media (min-width: 640px) {
  .cr-page .cr-hero-actions,
  .cr-page .cr-conversion-actions,
  .cr-page .cr-cta-buttons {
    flex-direction: row;
    justify-content: center;
  }
}

.cr-page .cr-cta {
  display: grid;
  gap: 10px;
  text-align: center;
  padding: 34px 36px;
  border-radius: 30px;
  border: 2px solid rgba(28, 82, 154, 0.18);
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.22), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.998), rgba(243, 248, 255, 0.99));
  box-shadow: 0 32px 70px rgba(28, 82, 154, 0.14);
}

.cr-page .cr-cta-micro {
  color: rgba(31, 43, 63, 0.74);
}

.cr-page .cr-cta-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 2px;
}

/* Hover sutil nos itens internos */
.cr-page .cr-report-item {
  transition: box-shadow 220ms ease, transform 220ms ease;
}
.cr-page .cr-report-item:hover {
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.07);
  transform: translateY(-1px);
}

/* Acessibilidade — sem animações quando preferido pelo sistema */
@media (prefers-reduced-motion: reduce) {
  .cr-page .cr-hero,
  .cr-page .cr-report-section,
  .cr-page .cr-cta {
    animation: none;
  }
  .cr-page .cr-report-item {
    transition: none;
  }
}

@media (max-width: 640px) {
  .cr-deliverables-grid { grid-template-columns: 1fr; }
  .cr-connection-card { flex-direction: column; align-items: flex-start; }
  .cr-hero-actions { flex-direction: column; align-items: center; }
  .cr-page .cr-conversion-block,
  .cr-page .cr-cta {
    padding: 22px 18px;
  }
  .cr-page .cr-conversion-actions,
  .cr-page .cr-cta-buttons {
    flex-direction: column;
  }
  .cr-page .cr-conversion-button,
  .cr-page .cr-cta-buttons .button {
    width: 100%;
  }
}

@media (max-width: 640px) {
  .form-row {
    grid-template-columns: 1fr;
  }
  .connectivity-library-selectors,
  .connectivity-layout,
  .connectivity-insights {
    grid-template-columns: 1fr;
  }
  .person-column {
    justify-content: center;
  }
  .connectivity-bodygraph-stage {
    padding: 18px 14px 22px;
  }
  .connectivity-result-header h1 {
    line-height: 1.08;
  }
}

@media (min-width: 641px) and (max-width: 1200px) {
  .connectivity-layout {
    grid-template-columns: 161px minmax(0, 1fr) 161px;
  }

  .connectivity-summary-column {
    grid-column: 1 / -1;
  }

  .connectivity-summary-panel {
    gap: 14px;
  }
}

/* ===========================
   BUYER CONTEXT SELECTOR
   =========================== */

.buyer-context-selector {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 16px;
}

.buyer-context-selector-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: rgba(255, 255, 255, 0.6);
  font-size: 13px;
  padding: 6px 16px;
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.2s;
}

.buyer-context-selector-trigger:hover {
  border-color: rgba(255, 255, 255, 0.4);
  color: rgba(255, 255, 255, 0.9);
}

.buyer-context-selector-panel {
  margin-top: 12px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  padding: 20px 24px;
  width: 100%;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.buyer-context-selector-hint {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.6);
  text-align: center;
  line-height: 1.5;
  margin: 0;
}

.buyer-context-selector-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.buyer-context-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.buyer-context-field label {
  font-size: 11px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.buyer-context-field select {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #ffffff;
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 13px;
}

.buyer-context-field select option {
  background: #1a2e50;
  color: #ffffff;
}

.buyer-context-selector-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: center;
}

.buyer-context-cancel {
  background: transparent;
  border: none;
  color: rgba(255, 255, 255, 0.4);
  font-size: 13px;
  cursor: pointer;
  padding: 4px 8px;
}

.buyer-context-cancel:hover {
  color: rgba(255, 255, 255, 0.7);
}

.buyer-context-selector-success {
  font-size: 13px;
  color: #4ade80;
  text-align: center;
  margin: 0;
}

/* ===========================
   GIFT UPSELL CHECKOUT
   =========================== */

.checkout-gift-upsell {
  margin-top: 20px;
  padding: 16px;
  background: #fefce8;
  border: 1px solid #fde68a;
  border-radius: 12px;
}

.checkout-gift-upsell-trigger {
  display: flex;
  align-items: center;
  gap: 12px;
}

.checkout-gift-icon {
  font-size: 20px;
  flex-shrink: 0;
}

.checkout-gift-trigger-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.checkout-gift-trigger-text strong {
  font-size: 14px;
  color: #92400e;
}

.checkout-gift-trigger-text span {
  font-size: 13px;
  color: #b45309;
}

.checkout-gift-hint {
  font-size: 13px;
  color: #6b7280;
  margin-bottom: 16px;
  line-height: 1.5;
  margin-top: 16px;
}

.checkout-gift-fields {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
}

.checkout-gift-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.checkout-gift-field label {
  font-size: 12px;
  font-weight: 500;
  color: #374151;
}

.checkout-gift-field input[type="text"] {
  padding: 8px 12px;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  color: #111827;
  background: #ffffff;
}

.checkout-gift-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.checkout-gift-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
}

.checkout-gift-cancel {
  background: transparent;
  border: none;
  font-size: 13px;
  color: #9ca3af;
  cursor: pointer;
  padding: 4px;
  text-align: center;
}

.checkout-gift-cancel:hover {
  color: #6b7280;
}

.checkout-gift-error {
  font-size: 13px;
  color: #dc2626;
  margin-top: 8px;
  text-align: center;
}

/* ===========================
   JORNADA PAGE
   =========================== */

.jornada-page {
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-width: 820px;
  margin-inline: auto;
}

.jornada-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
}

.jornada-hero h1 {
  font-size: clamp(1.5rem, 3.5vw, 2.1rem);
  line-height: 1.2;
  margin-bottom: 16px;
}

.jornada-hero-sub {
  font-size: 0.97rem;
  line-height: 1.7;
  color: rgba(31, 43, 63, 0.72);
}

.jornada-hero-offer {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.jornada-price-block {
  display: flex;
  align-items: baseline;
  gap: 12px;
}

.jornada-price-old {
  font-size: 0.9rem;
  color: rgba(31, 43, 63, 0.45);
  text-decoration: line-through;
}

.jornada-price-current {
  font-size: 2.2rem;
  font-weight: 700;
  color: #1f2b3f;
}

.jornada-benefits {
  margin: 0;
}

.jornada-social-proof {
  font-size: 0.85rem;
  font-weight: 600;
  color: #1c529a;
  margin: 0;
}

.jornada-no-chart-alert {
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 0.88rem;
  color: #b91c1c;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.jornada-no-chart-link {
  color: #1c529a;
  font-weight: 600;
  font-size: 0.88rem;
}

.jornada-cta {
  width: 100%;
  text-align: center;
  font-size: 1rem;
  padding: 16px 24px;
}

.jornada-cta-disabled {
  opacity: 0.45;
  pointer-events: none;
}

.jornada-cta-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.jornada-cta-meta p {
  font-size: 0.8rem;
  color: rgba(31, 43, 63, 0.5);
  margin: 0;
  text-align: center;
}

.jornada-guarantee {
  font-size: 0.82rem;
  color: rgba(31, 43, 63, 0.6);
  text-align: center;
  padding: 10px 12px;
  background: rgba(28, 82, 154, 0.04);
  border-radius: 8px;
}

/* How it works */

.jornada-how {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.jornada-how h2 {
  font-size: clamp(1.1rem, 2.5vw, 1.4rem);
  margin: 0;
}

.jornada-days {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}

.jornada-day {
  background: #f4f7fb;
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.jornada-day strong {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #1c529a;
}

.jornada-day p {
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(31, 43, 63, 0.78);
  margin: 0;
}

/* Final CTA */

.jornada-final-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
}

.jornada-final-cta h2 {
  font-size: clamp(1.2rem, 2.8vw, 1.6rem);
  max-width: 560px;
  margin: 0;
}

.jornada-final-cta p {
  font-size: 0.95rem;
  color: rgba(31, 43, 63, 0.7);
  max-width: 480px;
  line-height: 1.6;
  margin: 0;
}

.jornada-final-cta .jornada-cta {
  max-width: 360px;
}

.jornada-fallback {
  font-size: 0.85rem;
  color: rgba(31, 43, 63, 0.5);
  margin: 4px 0 0;
}

.jornada-fallback a {
  color: #1c529a;
  font-weight: 600;
}

@media (max-width: 720px) {
  .jornada-hero {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .jornada-days {
    grid-template-columns: 1fr;
  }

  .jornada-final-cta .jornada-cta {
    max-width: 100%;
  }
}

.jornada-cta-disabled,
.jornada-cta-disabled:hover,
.jornada-cta-disabled:focus {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
  pointer-events: none;
  box-shadow: none !important;
  transform: none !important;
}

.jornada-no-chart-alert {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  background: #fef9ec;
  border: 1px solid #f5c842;
  border-radius: 12px;
  padding: 16px;
  text-align: center;
}

.jornada-no-chart-alert p {
  font-size: 0.88rem;
  color: #92400e;
  margin: 0;
}

.jornada-cta-generate {
  width: 100%;
  text-align: center;
}

/* jornada-cta-disabled — visualmente desabilitado mas clicável */
.jornada-cta-disabled {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
  transform: none !important;
}

/* sobrescreve regra anterior que tinha pointer-events:none */
.jornada-cta-disabled {
  pointer-events: auto;
}

@keyframes jornada-pulse {
  0%   { transform: scale(1);    box-shadow: 0 0 0 0   rgba(255, 165, 0, 0.45); }
  50%  { transform: scale(1.05); box-shadow: 0 0 0 10px rgba(255, 165, 0, 0);   }
  100% { transform: scale(1);    box-shadow: 0 0 0 0   rgba(255, 165, 0, 0);    }
}

.is-pulsing {
  animation: jornada-pulse 0.9s ease-in-out 3;
  opacity: 1 !important;
  outline: 2px solid #f5a623;
  outline-offset: 2px;
}

/* ── jornada-cta-disabled: OVERRIDE FINAL ─────────────────────────────────
   Garante pointer-events:auto para o click do JS funcionar.
   Usa !important para sobrescrever qualquer regra anterior.             */
.jornada-cta-disabled {
  opacity: 0.5 !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  box-shadow: none !important;
  transform: none !important;
  filter: grayscale(0.2);
}

/* ── Animações de feedback ────────────────────────────────────────────── */
@keyframes jornada-pulse-v2 {
  0%   { transform: scale(1);    box-shadow: 0 0 0 0    rgba(245, 158, 11, 0.35); }
  50%  { transform: scale(1.04); box-shadow: 0 0 0 12px rgba(245, 158, 11, 0);   }
  100% { transform: scale(1);    box-shadow: 0 0 0 0    rgba(245, 158, 11, 0);   }
}

@keyframes highlightFlash {
  0%   { background-color: rgba(245, 158, 11, 0.06); border-color: rgba(245, 158, 11, 0.5); }
  50%  { background-color: rgba(245, 158, 11, 0.18); border-color: rgba(245, 158, 11, 0.9); }
  100% { background-color: rgba(245, 158, 11, 0.06); border-color: rgba(245, 158, 11, 0.5); }
}

.is-pulsing {
  animation: jornada-pulse-v2 0.9s ease-in-out 3 !important;
  outline: 2px solid rgba(245, 158, 11, 0.6);
  outline-offset: 3px;
}

.is-highlighted {
  animation: highlightFlash 1.2s ease-in-out 2;
}

/* ── Jornada: no-chart-group wrapper ──────────────────────────────────── */
[data-no-chart-group] {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
}

/* ── Jornada: disabled CTA — interativo mas orientador ───────────────── */
.jornada-cta-disabled {
  opacity: 0.6 !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  box-shadow: none !important;
  transform: none !important;
  filter: none !important;
  transition: opacity 0.2s, filter 0.2s !important;
}

.jornada-cta-disabled:hover {
  opacity: 0.75 !important;
  filter: brightness(1.06) !important;
  transform: none !important;
  box-shadow: none !important;
}

/* ── CORREÇÃO DEFINITIVA: cursor no botão orientador da jornada ────────
   Sobrescreve todas as regras anteriores com cursor:not-allowed          */
button.jornada-cta-disabled,
button.jornada-cta-disabled:hover,
button.jornada-cta-disabled:focus,
button.jornada-cta-disabled:active,
a.jornada-cta-disabled,
a.jornada-cta-disabled:hover,
a.jornada-cta-disabled:focus {
  cursor: pointer !important;
}

.jornada-cta-generate {
  background: #1c529a !important;
  color: #ffffff !important;
  border-color: #1c529a !important;
}

.jornada-cta-generate:hover {
  background: #174a8a !important;
  border-color: #174a8a !important;
  color: #ffffff !important;
}

/* ── Workspace Engagement Bar ─────────────────────────────────────────────── */
.workspace-engagement-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 200;
  background: #1f2b3f;
  border-top: 2px solid rgba(245,200,66,0.3);
  padding: 16px 24px;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.workspace-engagement-bar.is-visible {
  transform: translateY(0);
}

.workspace-engagement-bar-inner {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.workspace-engagement-bar-copy {
  flex: 1;
  min-width: 200px;
}

.workspace-engagement-bar-hook {
  margin: 0 0 4px;
  font-size: 15px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.3;
}

.workspace-engagement-bar-sub {
  margin: 0;
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  line-height: 1.4;
}

.workspace-engagement-bar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.workspace-engagement-bar-close {
  background: none;
  border: none;
  color: rgba(255,255,255,0.4);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  padding: 4px 6px;
  flex-shrink: 0;
}

.workspace-engagement-bar-close:hover {
  color: rgba(255,255,255,0.8);
}

@media (max-width: 600px) {
  .workspace-engagement-bar {
    padding: 14px 16px;
  }
  .workspace-engagement-bar-inner {
    gap: 12px;
  }
  .workspace-engagement-bar-cta {
    width: 100%;
    text-align: center;
  }
}

/* ── Public chart: bodygraph tamanho ajustado (0.84 × 1.1 = 0.924) ──────── */
.workspace-page-public {
  --bg-max-w:    905px;                          /* 980px × 0.924 */
  --bg-max-h:    calc((100vh - 155px) * 0.924);
  --bg-rail-w:   74px;                           /* 80px × 0.924  */
  --bg-rail-gap: 9px;                            /* 10px × 0.924  */
}

.workspace-page-public .app-bodygraph .bodygraph-svg {
  transform: translateY(-9%) scale(var(--bg-chart-transform-scale-public)) !important;
}

.workspace-page-public .app-bodygraph .bodygraph-background {
  width: min(calc(108% * var(--bg-chart-background-scale)), calc(var(--bg-max-h) * 1.08 * var(--bg-chart-background-scale))) !important;
  max-width: calc(var(--bg-max-h) * 1.08 * var(--bg-chart-background-scale)) !important;
  transform: translate(-50%, -50%) scale(1.039) !important;
}

@media (min-width: 1200px) {
  .workspace-page-public {
    --bg-rail-w:   96px;   /* 104px × 0.924 */
    --bg-rail-gap: 13px;   /* 14px × 0.924  */
  }
}

/* ── Identificação por tipo: acima do bodygraph ───────────────────────────── */
.workspace-stage-app > .workspace-type-identification {
  margin: 0 0 12px;
  padding: 14px 18px;
  background: rgba(28, 82, 154, 0.06);
  border-left: 3px solid var(--blue);
  border-radius: 0 10px 10px 0;
}

/* ── Coupon popup ─────────────────────────────────────────── */

.coupon-popup-backdrop {
  position: fixed;
  inset: 0;
  z-index: 900;
  background: rgba(14, 33, 58, 0.52);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 320ms ease;
}

.coupon-popup-backdrop.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.coupon-popup {
  position: relative;
  width: min(540px, calc(100vw - 32px));
  display: grid;
  gap: 16px;
  padding: 36px 32px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(244, 196, 107, 0.22), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.99), rgba(245,249,255,0.98));
  border: 1px solid rgba(28, 82, 154, 0.14);
  box-shadow: 0 32px 80px rgba(14, 33, 58, 0.28);
  transform: translateY(16px) scale(0.97);
  transition: transform 320ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

.coupon-popup-backdrop.is-visible .coupon-popup {
  transform: translateY(0) scale(1);
}

.coupon-popup-close {
  position: absolute;
  top: 16px;
  right: 18px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid rgba(26, 107, 181, 0.14);
  background: rgba(26, 107, 181, 0.06);
  color: var(--muted);
  font-size: 1.2rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.coupon-popup-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0;
}

.coupon-popup-title {
  font-size: clamp(1.3rem, 2.4vw, 1.65rem);
  line-height: 1.2;
  color: #14233d;
  margin: 0;
}

.coupon-popup-body {
  font-size: 0.95rem;
  line-height: 1.65;
  color: rgba(31, 43, 63, 0.76);
  margin: 0;
}

.coupon-popup-offer {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}

.coupon-popup-price-old {
  font-size: 1rem;
  color: rgba(31, 43, 63, 0.4);
  text-decoration: line-through;
}

.coupon-popup-price-new {
  font-size: 2rem;
  font-weight: 800;
  color: #14233d;
  line-height: 1;
}

.coupon-popup-price-label {
  font-size: 0.85rem;
  color: rgba(31, 43, 63, 0.6);
}

.coupon-popup-code-block {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-radius: 14px;
  background: rgba(26, 107, 181, 0.06);
  border: 1px dashed rgba(26, 107, 181, 0.28);
}

.coupon-popup-code-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(31, 43, 63, 0.5);
  flex-shrink: 0;
}

.coupon-popup-code {
  flex: 1;
  font-size: 1rem;
  font-weight: 800;
  color: #14233d;
  letter-spacing: 0.04em;
}

.coupon-popup-copy {
  flex-shrink: 0;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid rgba(26, 107, 181, 0.22);
  background: rgba(26, 107, 181, 0.08);
  color: var(--blue);
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 180ms ease;
}

.coupon-popup-copy:hover {
  background: rgba(26, 107, 181, 0.14);
}

.coupon-popup-expiry {
  font-size: 0.82rem;
  color: rgba(31, 43, 63, 0.5);
  margin: 0;
}

.coupon-popup-actions {
  display: grid;
  gap: 10px;
}

.coupon-popup-cta {
  width: 100%;
  justify-content: center;
}

.coupon-popup-dismiss {
  width: 100%;
  background: transparent;
  border: none;
  color: rgba(31, 43, 63, 0.45);
  font-size: 0.85rem;
  cursor: pointer;
  padding: 8px;
  transition: color 180ms ease;
}

.coupon-popup-dismiss:hover {
  color: rgba(31, 43, 63, 0.7);
}

@media (max-width: 540px) {
  .coupon-popup {
    padding: 28px 22px;
  }
}

/* ── Mecânicas da Sua Sexualidade — landing page ─────────────────────────── */

.mecanicas-sexualidade-page {
  display: grid;
  gap: 20px;
}

.mec-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.mec-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.mec-hero-sub {
  max-width: 58ch;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  margin: 16px 0 0;
}

.mec-hero-actions {
  align-items: center;
  margin-top: 28px;
}

.mec-hero-badge {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.55);
  white-space: nowrap;
}

.mec-hero-social {
  margin: 18px 0 0;
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
}

.mec-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 0;
}

.mec-card {
  display: grid;
  gap: 10px;
  padding: 24px 22px;
}

.mec-card-icon {
  font-size: 1.2rem;
  margin-right: 6px;
}

.mec-card h2 {
  font-size: 1.05rem;
  margin: 0;
  color: var(--blue-deep);
}

.mec-card p {
  margin: 0;
  font-size: 0.93rem;
  color: rgba(21, 34, 56, 0.72);
  line-height: 1.6;
}

.mec-preview {
  border-left: 4px solid var(--orange);
  padding-left: 24px;
}

.mec-preview-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--orange);
  margin: 0 0 14px;
}

.mec-recognition-list { display: flex; flex-direction: column; gap: 24px; margin: 20px 0 0; }
.mec-recognition-item { border-left: 3px solid var(--orange); padding-left: 16px; }
.mec-recognition-q { font-weight: 600; color: var(--blue-deep); margin: 0 0 6px; font-size: 1rem; line-height: 1.4; }
.mec-recognition-a { color: rgba(21, 34, 56, 0.72); font-size: 0.93rem; line-height: 1.65; margin: 0; }
.mec-preview-footer { margin: 24px 0 0; font-size: 0.88rem; color: rgba(21, 34, 56, 0.5); }
.mec-preview-context { font-size: 0.9rem; color: rgba(21, 34, 56, 0.55); margin: 0 0 10px; font-style: italic; }

.mec-buy-block {
  text-align: center;
  padding: 44px 32px;
}

.mec-buy-sub-intro {
  font-size: 0.95rem;
  color: rgba(21, 34, 56, 0.58);
  margin: 4px 0 0;
}

.mec-price {
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.04em;
  margin: 12px 0 0;
}

.mec-buy-actions {
  justify-content: center;
  margin-top: 20px;
}

.mec-buy-note {
  font-size: 0.88rem;
  color: rgba(21, 34, 56, 0.5);
  margin: 14px 0 0;
}

.mec-buy-sub {
  font-size: 0.82rem;
  color: rgba(21, 34, 56, 0.4);
  margin: 6px 0 0;
}

@media (max-width: 720px) {
  .mec-cards-grid {
    grid-template-columns: 1fr;
  }

  .mec-hero {
    padding: 32px 20px 36px;
  }

  .mec-buy-block {
    padding: 32px 20px;
  }
}

/* ─── Cruz de Encarnação — landing page ────────────────────────────────────── */

.cruz-page {
  display: grid;
  gap: 20px;
}

.cruz-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.cruz-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.cruz-hero-sub {
  max-width: 58ch;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  margin: 16px 0 0;
}

.cruz-hero-actions {
  align-items: center;
  margin-top: 28px;
}

.cruz-hero-social {
  margin: 18px 0 0;
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
}

.cruz-recognition {
  border-left: 4px solid var(--orange);
  padding-left: 24px;
}

.cruz-recognition-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--orange);
  margin: 0 0 14px;
}

.cruz-recognition-list { display: flex; flex-direction: column; gap: 24px; margin: 20px 0 0; }
.cruz-recognition-item { border-left: 3px solid var(--orange); padding-left: 16px; }
.cruz-recognition-q { font-weight: 600; color: var(--blue-deep); margin: 0 0 6px; font-size: 1rem; line-height: 1.4; }
.cruz-recognition-a { color: rgba(21, 34, 56, 0.72); font-size: 0.93rem; line-height: 1.65; margin: 0; }

.cruz-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 0;
}

.cruz-card {
  display: grid;
  gap: 10px;
  padding: 24px 22px;
}

.cruz-card-icon {
  font-size: 1.2rem;
  margin-right: 6px;
}

.cruz-card h2 {
  font-size: 1.05rem;
  margin: 0;
  color: var(--blue-deep);
}

.cruz-card p {
  margin: 0;
  font-size: 0.93rem;
  color: rgba(21, 34, 56, 0.72);
  line-height: 1.6;
}

.cruz-buy-block {
  text-align: center;
  padding: 44px 32px;
}

.cruz-buy-sub-intro {
  font-size: 0.95rem;
  color: rgba(21, 34, 56, 0.58);
  margin: 4px 0 0;
}

.cruz-buy-promise {
  font-size: 1.05rem;
  color: var(--blue-deep);
  font-weight: 500;
  max-width: 42ch;
  margin: 12px auto 0;
  line-height: 1.5;
}

.cruz-price {
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.04em;
  margin: 12px 0 0;
}

.cruz-buy-actions {
  justify-content: center;
  margin-top: 20px;
}

.cruz-buy-note {
  font-size: 0.88rem;
  color: rgba(21, 34, 56, 0.5);
  margin: 14px 0 0;
}

.cruz-buy-sub {
  font-size: 0.82rem;
  color: rgba(21, 34, 56, 0.4);
  margin: 6px 0 0;
}

@media (max-width: 720px) {
  .cruz-cards-grid {
    grid-template-columns: 1fr;
  }

  .cruz-hero {
    padding: 32px 20px 36px;
  }

  .cruz-buy-block {
    padding: 32px 20px;
  }
}


/* ─── Nodos page ─────────────────────────────────────────────────────────── */

.nodos-page {
  display: grid;
  gap: 20px;
}

.nodos-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.nodos-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.nodos-hero-sub {
  max-width: 58ch;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  margin: 16px 0 0;
}

.nodos-hero-actions {
  align-items: center;
  margin-top: 28px;
}

.nodos-hero-social {
  margin: 18px 0 0;
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
}

.nodos-hero-symbols {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 20px 0 0;
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.nodos-symbol-north {
  color: #ffffff;
  opacity: 0.9;
}

.nodos-symbol-south {
  color: #ffffff;
  opacity: 0.9;
}

.nodos-symbol-divider {
  color: rgba(255,255,255,0.4);
  font-weight: 300;
}

.nodos-recognition {
  border-left: 4px solid var(--orange);
  padding-left: 24px;
}

.nodos-recognition-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--orange);
  margin: 0 0 14px;
}

.nodos-recognition-list { display: flex; flex-direction: column; gap: 24px; margin: 20px 0 0; }
.nodos-recognition-item { border-left: 3px solid var(--orange); padding-left: 16px; }
.nodos-recognition-q { font-weight: 600; color: var(--blue-deep); margin: 0 0 6px; font-size: 1rem; line-height: 1.4; }
.nodos-recognition-a { color: rgba(21, 34, 56, 0.72); font-size: 0.93rem; line-height: 1.65; margin: 0; }
.nodos-label-design { color: #d04948; font-weight: 700; }
.nodos-label-personality { color: #1a1a1a; font-weight: 700; }

.nodos-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 0;
}

.nodos-card {
  display: grid;
  gap: 10px;
  padding: 24px 22px;
}

.nodos-card-icon {
  font-size: 1.2rem;
  margin-right: 6px;
}

.nodos-card h2 {
  font-size: 1.05rem;
  margin: 0;
  color: var(--blue-deep);
}

.nodos-card p {
  margin: 0;
  font-size: 0.93rem;
  color: rgba(21, 34, 56, 0.72);
  line-height: 1.6;
}

.nodos-buy-block {
  text-align: center;
  padding: 44px 32px;
}

.nodos-buy-sub-intro {
  font-size: 0.95rem;
  color: rgba(21, 34, 56, 0.58);
  margin: 4px 0 0;
}

.nodos-buy-promise {
  font-size: 1.05rem;
  color: var(--blue-deep);
  font-weight: 500;
  max-width: 42ch;
  margin: 12px auto 0;
  line-height: 1.5;
}

.nodos-price {
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.04em;
  margin: 12px 0 0;
}

.nodos-buy-actions {
  justify-content: center;
  margin-top: 20px;
}

.nodos-buy-note {
  font-size: 0.88rem;
  color: rgba(21, 34, 56, 0.5);
  margin: 14px 0 0;
}

.nodos-buy-sub {
  font-size: 0.82rem;
  color: rgba(21, 34, 56, 0.4);
  margin: 6px 0 0;
}

@media (max-width: 720px) {
  .nodos-cards-grid {
    grid-template-columns: 1fr;
  }

  .nodos-hero {
    padding: 32px 20px 36px;
  }

  .nodos-buy-block {
    padding: 32px 20px;
  }
}

/* ── PHS / Variáveis ──────────────────────────────────────────────────── */

.phs-page { gap: 32px; }

/* ── Decisões page ──────────────────────────────────────────── */
.decisoes-page { gap: 24px; }

.decisoes-hero-social {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.78);
  margin: 0 0 16px;
}

.decisoes-recognition-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue-deep);
  opacity: 0.7;
  margin: 0 0 20px;
}

.decisoes-recognition-list { display: flex; flex-direction: column; gap: 24px; }
.decisoes-recognition-item { display: flex; flex-direction: column; gap: 8px; }

.decisoes-recognition-q {
  font-weight: 600;
  font-size: 1rem;
  color: #1a1a1a;
  font-style: italic;
  margin: 0;
}

.decisoes-recognition-a {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(21, 34, 56, 0.75);
  margin: 0;
}

.decisoes-auth-intro {
  font-size: 1rem;
  line-height: 1.65;
  color: rgba(21, 34, 56, 0.75);
  margin: 0 0 24px;
}

.decisoes-auth-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.decisoes-auth-item {
  background: var(--surface-strong);
  border-radius: 12px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.decisoes-auth-name {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0;
}

.decisoes-auth-desc {
  font-size: 0.88rem;
  line-height: 1.55;
  color: rgba(21, 34, 56, 0.72);
  margin: 0;
}

.decisoes-cta-block {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.decisoes-cta-block h2 {
  font-size: 1.4rem;
  margin: 0;
}

.decisoes-cta-block p {
  max-width: 520px;
  color: rgba(21, 34, 56, 0.7);
  margin: 0;
}

.decisoes-cta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 8px;
}

@media (max-width: 768px) {
  .decisoes-auth-grid { grid-template-columns: 1fr; }
  .decisoes-cta-actions { flex-direction: column; align-items: center; }
}

.phs-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.phs-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.phs-hero-sub {
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  max-width: 58ch;
  margin: 16px 0 0;
}

.phs-hero-sub--secondary {
  margin-top: 12px;
}

.phs-hero-actions { margin-top: 28px; }

.phs-hero-social {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
  margin: 18px 0 0;
}

.phs-recognition { display: flex; flex-direction: column; gap: 20px; }

.phs-recognition-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue-deep);
  opacity: 0.7;
  margin: 0 0 4px;
}

.phs-recognition-list { display: flex; flex-direction: column; gap: 24px; }

.phs-recognition-item { display: flex; flex-direction: column; gap: 8px; }

.phs-recognition-q {
  font-weight: 600;
  font-size: 1rem;
  color: #1a1a1a;
  margin: 0;
  font-style: italic;
}

.phs-recognition-a {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(21,34,56,0.75);
  margin: 0;
}

.phs-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.phs-card { display: flex; flex-direction: column; gap: 10px; }
.phs-card h2 { font-size: 1.05rem; display: flex; align-items: center; gap: 8px; margin: 0; }
.phs-card p { font-size: 0.9rem; line-height: 1.6; color: rgba(21,34,56,0.75); margin: 0; }
.phs-card-icon { font-size: 1.2rem; }

.phs-buy-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  padding: 48px 40px;
  background: #fafbfc;
}

.phs-buy-sub-intro { font-size: 0.9rem; color: rgba(21,34,56,0.6); margin: 0; }
.phs-buy-promise { font-size: 1.05rem; font-weight: 500; color: #1a1a1a; margin: 0; max-width: 480px; }
.phs-anchor-value {
  font-size: 0.92rem;
  line-height: 1.6;
  color: rgba(21,34,56,0.6);
  max-width: 420px;
  margin: 8px 0 0;
  font-style: italic;
}
.phs-price { font-size: 2.2rem; font-weight: 800; color: var(--blue-deep); margin: 4px 0 0; letter-spacing: -0.02em; }
.phs-buy-actions { margin: 4px 0 0; }
.phs-buy-note { font-size: 0.8rem; color: rgba(21,34,56,0.45); margin: 4px 0 0; }
.phs-buy-sub { font-size: 0.82rem; color: rgba(21,34,56,0.4); margin: 6px 0 0; }

/* PHS report header */
.report-phs-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: center;
  padding: 24px 0 32px;
  border-bottom: 1px solid rgba(21,34,56,0.08);
  margin-bottom: 8px;
}

.report-phs-visual {
  text-align: right;
}

.report-phs-visual-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(21,34,56,0.45);
  margin: 0 0 12px;
}

.report-phs-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-end;
}

.report-phs-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
  align-items: flex-end;
}

.report-phs-item-meta {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.report-phs-item-data { font-size: 0.95rem; }

.phs-label-body { color: #c06020; }
.phs-label-mind { color: #1c529a; }

@media (max-width: 720px) {
  .phs-cards-grid { grid-template-columns: 1fr; }
  .phs-hero { padding: 32px 20px 36px; }
  .phs-buy-block { padding: 32px 20px; }
  .report-phs-header { grid-template-columns: 1fr; }
}


/* ─── Report nodes header ────────────────────────────────────────────────── */

.report-nodes-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 8px;
  align-items: start;
  margin: 0 0 2rem;
  border-radius: 20px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  background:
    radial-gradient(circle at top right, rgba(107, 180, 244, 0.08), transparent 40%),
    linear-gradient(160deg, rgba(248, 251, 255, 0.98), rgba(255, 255, 255, 0.98));
  overflow: hidden;
}

.report-nodes-visual {
  padding: 28px 24px 28px;
  border-left: 1px solid rgba(26, 107, 181, 0.08);
}

.report-nodes-visual-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-muted, #6b7280);
  margin: 0 0 16px;
}

.report-nodes-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.report-nodes-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.report-nodes-item-meta {
  font-size: 0.75rem;
  color: var(--color-text-muted, #6b7280);
}

.report-nodes-item-meta-sub {
  opacity: 0.7;
}

.report-nodes-item-data {
  display: flex;
  align-items: baseline;
  gap: 6px;
  font-size: 0.92rem;
}

.report-nodes-symbol {
  font-size: 1.1rem;
  color: #1a6bb5;
  flex-shrink: 0;
}

.report-nodes-symbol--south {
  color: #b56a1a;
}

.report-nodes-gate-name {
  color: var(--color-text-muted, #6b7280);
  font-size: 0.85rem;
}

.nodes-label-design {
  color: #d04948;
  font-weight: 700;
}

.nodes-label-personality {
  color: #1a1a1a;
  font-weight: 700;
}

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

  .report-nodes-visual {
    border-left: none;
    border-top: 1px solid rgba(26, 107, 181, 0.08);
  }
}

/* ── Report type header ───────────────────────────────────────── */

.report-type-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 8px;
  align-items: start;
  margin: 0 0 2rem;
  border-radius: 20px;
  border: 1px solid rgba(26, 107, 181, 0.12);
  background:
    radial-gradient(circle at top right, rgba(107, 180, 244, 0.06), transparent 40%),
    linear-gradient(160deg, rgba(248, 251, 255, 0.98), rgba(255, 255, 255, 0.98));
  overflow: hidden;
}

.report-type-visual {
  padding: 28px 24px 28px;
  border-left: 1px solid rgba(26, 107, 181, 0.08);
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: rgba(255,255,255,0.6);
}

.report-type-badge {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 18px;
  border-radius: 12px;
  background: var(--tipo-color, #1c529a);
  color: #fff;
}

.report-type-badge-label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.75;
}

.report-type-badge-name {
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.report-type-theme-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.report-type-theme-label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(21,34,56,0.45);
}

.report-type-theme-value {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--tipo-color, #1c529a);
}

.report-type-theme-row--notself .report-type-theme-value {
  color: rgba(21,34,56,0.65);
}

@media (max-width: 720px) {
  .report-type-header {
    grid-template-columns: 1fr;
  }
  .report-type-visual {
    border-left: none;
    border-top: 1px solid rgba(26, 107, 181, 0.08);
  }
}

/* ── Report upsell ────────────────────────────────────────────── */
.report-upsell {
  margin: 48px 0 0;
  padding: 32px;
  background: linear-gradient(160deg, rgba(248, 251, 255, 0.98), rgba(255, 255, 255, 0.98));
  border: 1px solid rgba(26, 107, 181, 0.12);
  border-radius: 20px;
}

.report-upsell-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--blue-deep);
  opacity: 0.6;
  margin: 0 0 6px;
}

.report-upsell-sub {
  font-size: 0.95rem;
  color: rgba(21, 34, 56, 0.65);
  margin: 0 0 24px;
  line-height: 1.5;
}

.report-upsell-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.report-upsell-card {
  background: #ffffff;
  border: 1px solid rgba(21, 34, 56, 0.08);
  border-radius: 14px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.report-upsell-card-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: #1a1a2e;
  margin: 0;
}

.report-upsell-card-desc {
  font-size: 0.85rem;
  line-height: 1.55;
  color: rgba(21, 34, 56, 0.65);
  margin: 0;
  flex: 1;
}

.report-upsell-card-price {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 4px 0 0;
  letter-spacing: -0.02em;
}

.report-upsell-card-cta {
  margin-top: 4px;
  font-size: 0.85rem;
  padding: 10px 16px;
  text-align: center;
}

@media (max-width: 640px) {
  .report-upsell { padding: 20px; }
  .report-upsell-grid { grid-template-columns: 1fr; }
}

/* ─── Report bodygraph view toggle ──────────────────────────────────────── */

.report-view-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}

.report-view-tab {
  font-size: 0.82rem;
  padding: 6px 14px;
  opacity: 0.45;
  transition: opacity 150ms ease;
}

/* ─── Landing page: Seu Tipo em Profundidade ────────────────────────────── */

.tipo-page { gap: 32px; }

.tipo-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.tipo-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.tipo-hero-sub {
  max-width: 58ch;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  margin: 16px 0 0;
}

.tipo-hero-sub--secondary { margin-top: 12px; }

.tipo-hero-actions { margin-top: 28px; }

.tipo-hero-social {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
  margin: 18px 0 0;
}

.tipo-recognition { display: flex; flex-direction: column; gap: 20px; }

.tipo-recognition-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0;
}

.tipo-recognition-list { display: flex; flex-direction: column; gap: 24px; }

.tipo-recognition-item { display: flex; flex-direction: column; gap: 8px; }

.tipo-recognition-q {
  font-size: 0.95rem;
  font-weight: 600;
  color: #1a1a1a;
  margin: 0;
  line-height: 1.5;
}

.tipo-recognition-a {
  font-size: 0.9rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.72);
  margin: 0;
}

.tipo-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.tipo-card { display: flex; flex-direction: column; gap: 10px; }
.tipo-card h2 { font-size: 1.05rem; display: flex; align-items: center; gap: 8px; margin: 0; }
.tipo-card p { font-size: 0.9rem; line-height: 1.6; color: rgba(21,34,56,0.75); margin: 0; }

.tipo-buy-block {
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: linear-gradient(145deg, #f8fbff 0%, #eef4fd 100%);
  border: 1px solid rgba(26,107,181,0.15);
}

.tipo-buy-sub-intro { font-size: 0.9rem; color: rgba(21,34,56,0.6); margin: 0; }
.tipo-buy-promise { font-size: 1.05rem; font-weight: 500; color: #1a1a1a; margin: 0; max-width: 480px; }

.tipo-anchor-value {
  font-size: 0.92rem;
  font-style: italic;
  color: rgba(21,34,56,0.6);
  margin: 4px 0 0;
  max-width: 540px;
}

.tipo-price { font-size: 2.2rem; font-weight: 800; color: var(--blue-deep); margin: 4px 0 0; letter-spacing: -0.02em; }
.tipo-buy-actions { margin: 4px 0 0; }
.tipo-buy-note { font-size: 0.8rem; color: rgba(21,34,56,0.45); margin: 4px 0 0; }
.tipo-buy-sub { font-size: 0.82rem; color: rgba(21,34,56,0.4); margin: 6px 0 0; }

@media (max-width: 720px) {
  .tipo-cards-grid { grid-template-columns: 1fr; }
  .tipo-hero { padding: 32px 20px 36px; }
  .tipo-buy-block { padding: 32px 20px; }
}

/* ─── End landing page: Seu Tipo em Profundidade ─────────────────────────── */

/* ─── Report header: Autoridade em Profundidade ──────────────────────────── */

.report-authority-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 8px;
  align-items: start;
  margin: 0 0 2rem;
  border-radius: 20px;
  border: 1px solid rgba(90, 60, 160, 0.12);
  background:
    radial-gradient(circle at top right, rgba(160, 130, 240, 0.06), transparent 40%),
    linear-gradient(160deg, rgba(250, 248, 255, 0.98), rgba(255, 255, 255, 0.98));
  overflow: hidden;
}

.report-authority-visual {
  padding: 28px 24px;
  border-left: 1px solid rgba(90, 60, 160, 0.08);
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: rgba(255,255,255,0.6);
}

.report-authority-badge {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 18px;
  border-radius: 12px;
  background: #5a3ca0;
  color: #fff;
}

.report-authority-badge-label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.75;
}

.report-authority-badge-name {
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.report-authority-type-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.report-authority-type-label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(21,34,56,0.45);
}

.report-authority-type-value {
  font-size: 0.95rem;
  font-weight: 600;
  color: #5a3ca0;
}

@media (max-width: 720px) {
  .report-authority-header {
    grid-template-columns: 1fr;
  }
  .report-authority-visual {
    border-left: none;
    border-top: 1px solid rgba(90, 60, 160, 0.08);
  }
}

/* ─── Landing page: Sua Autoridade em Profundidade ───────────────────────── */

.autoridade-page { gap: 32px; }

.autoridade-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.autoridade-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.autoridade-hero-sub {
  max-width: 58ch;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  margin: 16px 0 0;
}

.autoridade-hero-sub--secondary { margin-top: 12px; }

.autoridade-hero-actions { margin-top: 28px; }

.autoridade-hero-social {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
  margin: 18px 0 0;
}

.autoridade-recognition {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.autoridade-recognition-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #5a3ca0;
  margin: 0 0 24px;
}

.autoridade-recognition-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.autoridade-recognition-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 20px 0;
  border-top: 1px solid rgba(21,34,56,0.07);
}

.autoridade-recognition-q {
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.55;
  color: rgba(21,34,56,0.65);
  font-style: italic;
  margin: 0;
}

.autoridade-recognition-a {
  font-size: 0.9rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.75);
  margin: 0;
}

.autoridade-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.autoridade-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 3px solid #5a3ca0;
}

.autoridade-card h2 { font-size: 1.05rem; display: flex; align-items: center; gap: 8px; margin: 0; }
.autoridade-card p { font-size: 0.9rem; line-height: 1.6; color: rgba(21,34,56,0.75); margin: 0; }

.autoridade-buy-block {
  background:
    radial-gradient(ellipse at 80% 20%, rgba(140, 100, 220, 0.07), transparent 50%),
    linear-gradient(160deg, rgba(250, 248, 255, 0.97), #fff);
  border: 1px solid rgba(90, 60, 160, 0.12);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 48px 40px;
}

.autoridade-buy-sub-intro { font-size: 0.88rem; color: rgba(21,34,56,0.55); margin: 0; }
.autoridade-buy-promise { font-size: 1.1rem; font-weight: 700; color: #15222e; margin: 0; max-width: 540px; line-height: 1.45; }
.autoridade-anchor-value { font-size: 0.92rem; color: rgba(21,34,56,0.65); max-width: 540px; line-height: 1.6; margin: 0; }
.autoridade-price { font-size: 2rem; font-weight: 800; color: #5a3ca0; margin: 4px 0; letter-spacing: -0.03em; }
.autoridade-buy-actions { margin: 4px 0; }
.autoridade-buy-note { font-size: 0.82rem; color: rgba(21,34,56,0.45); margin: 0; }
.autoridade-buy-sub { font-size: 0.82rem; color: rgba(21,34,56,0.45); margin: 0; }

@media (max-width: 720px) {
  .autoridade-cards-grid { grid-template-columns: 1fr; }
  .autoridade-hero { padding: 32px 20px 36px; }
  .autoridade-buy-block { padding: 32px 20px; }
  .autoridade-recognition-item { grid-template-columns: 1fr; gap: 12px; }
}

/* ─── End landing page: Sua Autoridade em Profundidade ───────────────────── */

/* ─── Landing page: Suas Linhas em Profundidade ─────────────────────────── */
.linhas-page { gap: 32px; }

.linhas-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.linhas-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.linhas-hero-sub {
  max-width: 58ch;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  margin: 16px 0 0;
}

.linhas-hero-sub--secondary { margin-top: 12px; }

.linhas-hero-actions { margin-top: 28px; }

.linhas-hero-social {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
  margin: 18px 0 0;
}

.linhas-recognition {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.linhas-recognition-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0 0 24px;
}

.linhas-recognition-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.linhas-recognition-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 20px 0;
  border-top: 1px solid rgba(21,34,56,0.07);
}

.linhas-recognition-q {
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.55;
  color: rgba(21,34,56,0.65);
  font-style: italic;
  margin: 0;
}

.linhas-recognition-a {
  font-size: 0.9rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.75);
  margin: 0;
}

.linhas-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.linhas-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 3px solid var(--blue);
}

.linhas-card h2 { font-size: 1.05rem; font-weight: 700; margin: 0; }
.linhas-card p { font-size: 0.9rem; line-height: 1.6; color: rgba(21,34,56,0.75); margin: 0; }

.linhas-buy-block {
  background:
    radial-gradient(ellipse at 80% 20%, rgba(26, 107, 181, 0.07), transparent 50%),
    linear-gradient(160deg, rgba(248, 251, 255, 0.97), #fff);
  border: 1px solid rgba(26, 107, 181, 0.15);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 48px 40px;
}

.linhas-buy-sub-intro { font-size: 0.88rem; color: rgba(21,34,56,0.55); margin: 0; }
.linhas-buy-promise { font-size: 1.1rem; font-weight: 700; color: #15222e; margin: 0; max-width: 540px; line-height: 1.45; }
.linhas-anchor-value { font-size: 0.92rem; color: rgba(21,34,56,0.65); max-width: 540px; line-height: 1.6; margin: 0; }
.linhas-price { font-size: 2rem; font-weight: 800; color: var(--blue-deep); margin: 4px 0; letter-spacing: -0.03em; }
.linhas-buy-actions { margin: 4px 0; }
.linhas-buy-note { font-size: 0.82rem; color: rgba(21,34,56,0.45); margin: 0; }
.linhas-buy-sub { font-size: 0.82rem; color: rgba(21,34,56,0.45); margin: 0; }

@media (max-width: 720px) {
  .linhas-hero { padding: 32px 20px 36px; }
  .linhas-cards-grid { grid-template-columns: 1fr; }
  .linhas-buy-block { padding: 32px 20px; }
  .linhas-recognition-item { grid-template-columns: 1fr; gap: 12px; }
}
/* ─── End landing page: Suas Linhas em Profundidade ─────────────────────── */

/* ─── Landing page: Sua Definição em Profundidade ───────────────────────── */
.definicao-page { gap: 32px; }

.definicao-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.definicao-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.definicao-hero-sub {
  max-width: 58ch;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  margin: 16px 0 0;
}

.definicao-hero-sub--secondary { margin-top: 12px; }

.definicao-hero-actions { margin-top: 28px; }

.definicao-hero-social {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
  margin: 18px 0 0;
}

.definicao-recognition {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.definicao-recognition-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0 0 24px;
}

.definicao-recognition-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.definicao-recognition-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 20px 0;
  border-top: 1px solid rgba(21,34,56,0.07);
}

.definicao-recognition-q {
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.55;
  color: rgba(21,34,56,0.65);
  font-style: italic;
  margin: 0;
}

.definicao-recognition-a {
  font-size: 0.9rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.75);
  margin: 0;
}

.definicao-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.definicao-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 3px solid var(--blue);
}

.definicao-card h2 { font-size: 1.05rem; font-weight: 700; margin: 0; }
.definicao-card p { font-size: 0.9rem; line-height: 1.6; color: rgba(21,34,56,0.75); margin: 0; }

.definicao-buy-block {
  background:
    radial-gradient(ellipse at 80% 20%, rgba(26, 107, 181, 0.07), transparent 50%),
    linear-gradient(160deg, rgba(248, 251, 255, 0.97), #fff);
  border: 1px solid rgba(26, 107, 181, 0.15);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 48px 40px;
}

.definicao-buy-sub-intro { font-size: 0.88rem; color: rgba(21,34,56,0.55); margin: 0; }
.definicao-buy-promise { font-size: 1.1rem; font-weight: 700; color: #15222e; margin: 0; max-width: 540px; line-height: 1.45; }
.definicao-anchor-value { font-size: 0.92rem; color: rgba(21,34,56,0.65); max-width: 540px; line-height: 1.6; margin: 0; }
.definicao-price { font-size: 2rem; font-weight: 800; color: var(--blue-deep); margin: 4px 0; letter-spacing: -0.03em; }
.definicao-buy-actions { margin: 4px 0; }
.definicao-buy-note { font-size: 0.82rem; color: rgba(21,34,56,0.45); margin: 0; }
.definicao-buy-sub { font-size: 0.82rem; color: rgba(21,34,56,0.45); margin: 0; }

@media (max-width: 720px) {
  .definicao-hero { padding: 32px 20px 36px; }
  .definicao-cards-grid { grid-template-columns: 1fr; }
  .definicao-buy-block { padding: 32px 20px; }
  .definicao-recognition-item { grid-template-columns: 1fr; gap: 12px; }
}
/* ─── End landing page: Sua Definição em Profundidade ───────────────────── */

/* ─── Landing page: Seus Canais em Profundidade ─────────────────────────── */
.canais-page { gap: 32px; }

.canais-hero {
  background: var(--blue-deep);
  padding: 44px 36px 48px;
}

.canais-hero h1 {
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: none;
}

.canais-hero-sub {
  max-width: 58ch;
  font-size: 1.1rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.8);
  margin: 16px 0 0;
}

.canais-hero-sub--secondary { margin-top: 12px; }

.canais-hero-actions { margin-top: 28px; }

.canais-hero-social {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.48);
  margin: 18px 0 0;
}

.canais-recognition {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.canais-recognition-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0 0 24px;
}

.canais-recognition-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.canais-recognition-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 20px 0;
  border-top: 1px solid rgba(21,34,56,0.07);
}

.canais-recognition-q {
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.55;
  color: rgba(21,34,56,0.65);
  font-style: italic;
  margin: 0;
}

.canais-recognition-a {
  font-size: 0.9rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.75);
  margin: 0;
}

.canais-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.canais-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 3px solid var(--blue);
}

.canais-card h2 { font-size: 1.05rem; font-weight: 700; margin: 0; }
.canais-card p { font-size: 0.9rem; line-height: 1.6; color: rgba(21,34,56,0.75); margin: 0; }

.canais-buy-block {
  background:
    radial-gradient(ellipse at 80% 20%, rgba(26, 107, 181, 0.07), transparent 50%),
    linear-gradient(160deg, rgba(248, 251, 255, 0.97), #fff);
  border: 1px solid rgba(26, 107, 181, 0.15);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 48px 40px;
}

.canais-buy-sub-intro { font-size: 0.88rem; color: rgba(21,34,56,0.55); margin: 0; }
.canais-buy-promise { font-size: 1.1rem; font-weight: 700; color: #15222e; margin: 0; max-width: 540px; line-height: 1.45; }
.canais-anchor-value { font-size: 0.92rem; color: rgba(21,34,56,0.65); max-width: 540px; line-height: 1.6; margin: 0; }
.canais-price { font-size: 2rem; font-weight: 800; color: var(--blue-deep); margin: 4px 0; letter-spacing: -0.03em; }
.canais-buy-actions { margin: 4px 0; }
.canais-buy-note { font-size: 0.82rem; color: rgba(21,34,56,0.45); margin: 0; }
.canais-buy-sub { font-size: 0.82rem; color: rgba(21,34,56,0.45); margin: 0; }

@media (max-width: 720px) {
  .canais-hero { padding: 32px 20px 36px; }
  .canais-cards-grid { grid-template-columns: 1fr; }
  .canais-buy-block { padding: 32px 20px; }
  .canais-recognition-item { grid-template-columns: 1fr; gap: 12px; }
}
/* ─── End landing page: Seus Canais em Profundidade ─────────────────────── */

/* ─── CTAs contextuais: /o-que-e-desenho-humano ─────────────────────────── */
.oque-section-cta {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid rgba(21,34,56,0.08);
}

.oque-section-cta p {
  font-size: 0.95rem;
  color: rgba(21,34,56,0.7);
  margin: 0;
  line-height: 1.5;
}

.oque-cta-link {
  color: var(--blue);
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
}

.oque-cta-link:hover {
  text-decoration: underline;
}
/* ─── End CTAs contextuais: /o-que-e-desenho-humano ─────────────────────── */

/* ─── Educational pages: conceitos base e tipos ─────────────────────────── */
.edu-hero {
  padding: 60px 40px 48px;
}

.edu-hero h1 {
  font-size: 2rem;
  font-weight: 800;
  color: #15222e;
  line-height: 1.25;
  max-width: 680px;
  margin: 12px 0 16px;
  letter-spacing: -0.03em;
}

.edu-hero-sub {
  font-size: 1.05rem;
  color: rgba(21,34,56,0.7);
  max-width: 580px;
  line-height: 1.65;
  margin: 0 0 28px;
}

.edu-intro {
  font-size: 1rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.8);
  max-width: 680px;
  margin: 0 auto;
}

.edu-section-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: #15222e;
  margin: 0 0 20px;
}

.edu-variations-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.edu-variation-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-top: 3px solid var(--blue);
  padding-top: 14px;
}

.edu-variation-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: #15222e;
  margin: 0;
}

.edu-variation-card p {
  font-size: 0.9rem;
  line-height: 1.6;
  color: rgba(21,34,56,0.72);
  margin: 0;
}

.edu-variation-label {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 4px;
}

.edu-explanation-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.edu-explanation-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(21,34,56,0.07);
}

.edu-explanation-item h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: #15222e;
  margin: 0;
}

.edu-explanation-item p {
  font-size: 0.88rem;
  line-height: 1.6;
  color: rgba(21,34,56,0.7);
  margin: 0;
}

.edu-cta-block {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 48px 40px;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(26,107,181,0.07), transparent 50%),
    linear-gradient(160deg, rgba(248,251,255,0.97), #fff);
  border: 1px solid rgba(26,107,181,0.15);
}

.edu-cta-eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0;
}

.edu-cta-block h2 {
  font-size: 1.3rem;
  font-weight: 800;
  color: #15222e;
  margin: 0;
  max-width: 520px;
  line-height: 1.35;
}

.edu-cta-block p {
  font-size: 0.95rem;
  color: rgba(21,34,56,0.65);
  max-width: 480px;
  line-height: 1.6;
  margin: 0;
}

.edu-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.edu-related-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 20px;
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 8px;
  text-decoration: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.edu-related-card:hover {
  border-color: var(--blue);
  box-shadow: 0 2px 12px rgba(26,107,181,0.1);
}

.edu-related-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue);
}

.edu-related-card h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: #15222e;
  margin: 0;
  line-height: 1.35;
}

.edu-related-card p {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.65);
  margin: 0;
  line-height: 1.5;
}

.edu-highlight-box {
  background: rgba(26,107,181,0.05);
  border-left: 3px solid var(--blue);
  padding: 16px 20px;
  border-radius: 0 6px 6px 0;
}

.edu-highlight-box p {
  font-size: 0.95rem;
  color: rgba(21,34,56,0.8);
  margin: 0;
  line-height: 1.65;
}

.edu-types-list {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 12px;
}

.edu-type-row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 16px;
  align-items: start;
  padding: 14px 0;
  border-top: 1px solid rgba(21,34,56,0.07);
}

.edu-type-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: #15222e;
}

.edu-type-desc {
  font-size: 0.9rem;
  color: rgba(21,34,56,0.7);
  line-height: 1.55;
}

@media (max-width: 720px) {
  .edu-hero { padding: 32px 20px 36px; }
  .edu-hero h1 { font-size: 1.5rem; }
  .edu-variations-grid { grid-template-columns: 1fr; }
  .edu-explanation-grid { grid-template-columns: 1fr; }
  .edu-related-grid { grid-template-columns: 1fr; }
  .edu-cta-block { padding: 32px 20px; }
  .edu-type-row { grid-template-columns: 1fr; gap: 4px; }
}
/* ─── Tipo pages — personalized banner ──────────────────────────────────── */
.tipo-self-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: linear-gradient(135deg, rgba(28,82,154,0.08), rgba(28,82,154,0.04));
  border: 1px solid rgba(28,82,154,0.18);
  border-radius: 12px;
  padding: 14px 20px;
  margin-bottom: 8px;
}

.tipo-self-banner p {
  margin: 0;
  font-size: 0.95rem;
  color: #1c529a;
  line-height: 1.4;
}

.tipo-self-banner-link {
  flex-shrink: 0;
  font-size: 0.85rem;
  font-weight: 600;
  color: #1c529a;
  text-decoration: none;
  white-space: nowrap;
  padding: 6px 12px;
  border: 1px solid rgba(28,82,154,0.3);
  border-radius: 8px;
  transition: background 0.15s, color 0.15s;
}

.tipo-self-banner-link:hover {
  background: #1c529a;
  color: #fff;
}

/* Workspace tipo page inline link */
.tipo-page-inline-link {
  display: block;
  padding: 6px 16px 8px;
  font-size: 0.75rem;
  font-weight: 600;
  color: #1c529a;
  text-decoration: none;
  letter-spacing: 0.02em;
}

.tipo-page-inline-link:hover {
  text-decoration: underline;
}
/* ─── End educational pages ──────────────────────────────────────────────── */

.report-view-tab.is-active {
  opacity: 1;
}

.workspace-sidebar-help-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  margin: 8px 12px 0;
  border-radius: 8px;
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.75);
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}

.workspace-sidebar-help-btn:hover {
  background: rgba(255,255,255,0.15);
  color: #fff;
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: space-evenly;
  width: 100%;
  height: 100%;
}

.sidebar-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 12px 6px;
  width: 100%;
  border-radius: 8px;
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  font-family: inherit;
  transition: background 0.15s, color 0.15s;
  line-height: 1;
  position: relative;
}

.sidebar-nav-item:hover {
  background: rgba(255,255,255,0.1);
  color: #fff;
}

.sidebar-nav-item span:not(.sidebar-nav-label) {
  display: none;
}

.sidebar-nav-label {
  display: block;
  font-size: 8px;
  font-weight: 500;
  text-align: center;
  line-height: 1.2;
  color: inherit;
  letter-spacing: 0;
  word-break: break-word;
  width: 100%;
}

.sidebar-nav-item[data-tooltip]:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  background: #1f2b3f;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 5px 9px;
  border-radius: 6px;
  white-space: nowrap;
  pointer-events: none;
  z-index: 200;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
}

/* ── Ciclos Planetários ──────────────────────── */
.cycles-intro {
  font-size: 0.88rem;
  color: rgba(21, 34, 56, 0.65);
  line-height: 1.6;
  margin: 0 0 16px;
}

.cycle-item {
  padding: 14px 0;
  border-top: 1px solid rgba(21, 34, 56, 0.07);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.cycle-item-header {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}

.cycle-item-label {
  font-size: 0.9rem;
  font-weight: 700;
  color: #15222e;
  flex: 1;
}

.cycle-item-date {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--blue);
}

.cycle-item-status {
  font-size: 0.78rem;
  color: rgba(21, 34, 56, 0.5);
}

.cycle-item--past .cycle-item-date {
  color: rgba(21, 34, 56, 0.4);
}

.cycle-item--past .cycle-item-label {
  color: rgba(21, 34, 56, 0.5);
}

.cycle-cta-link {
  font-size: 0.82rem;
  color: var(--blue);
  font-weight: 600;
  text-decoration: none;
}

.cycle-cta-link:hover {
  text-decoration: underline;
}

.cycles-unavailable {
  font-size: 0.88rem;
  color: rgba(21, 34, 56, 0.5);
  font-style: italic;
}

/* ── Bodygraph stage — sem borda, fundo transparente ─── */
.workspace-stage-app {
  border: none;
  box-shadow: none;
  backdrop-filter: none;
  background: transparent;
}

.workspace-stage-app::before {
  display: none;
}
/* ═══════════════════════════════════════════════════════════════════
   LEGACY landing selectors (mantidos para compatibilidade)
   ═══════════════════════════════════════════════════════════════════ */

.oraculo-page.oraculo-landing-page .oraculo-hero {
  text-align: center;
  padding: 3rem 1.5rem 2.5rem;
}

.oraculo-hero-sub {
  max-width: 640px;
  margin: 1rem auto;
  font-size: 1.05rem;
  opacity: 0.85;
  line-height: 1.7;
}

.oraculo-hero-actions {
  margin-top: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}

.oraculo-hero-price {
  font-size: 0.88rem;
  opacity: 0.6;
  margin-top: 0.5rem;
}

.oraculo-section-panel,
.oraculo-features-panel,
.oraculo-recognition-panel,
.oraculo-how-it-works-panel {
  margin-top: 2rem;
}

.oraculo-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem;
  margin-top: 1.5rem;
}

.oraculo-feature-item {
  background: rgba(26, 107, 181, 0.05);
  border: 1px solid rgba(26, 107, 181, 0.12);
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
}

.oraculo-feature-icon {
  font-size: 1.5rem;
  display: block;
  margin-bottom: 0.5rem;
}

.oraculo-feature-item h3 {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: var(--text);
}

.oraculo-feature-item p {
  font-size: 0.9rem;
  color: var(--text);
  opacity: 0.8;
  line-height: 1.6;
  margin: 0;
}

.oraculo-recognition-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-top: 1.5rem;
}

.oraculo-recognition-item {
  border-left: 3px solid var(--blue);
  padding-left: 1.25rem;
}

.oraculo-recognition-q {
  font-weight: 600;
  margin-bottom: 0.4rem;
  font-size: 0.97rem;
}

.oraculo-recognition-a {
  opacity: 0.8;
  font-size: 0.9rem;
  line-height: 1.6;
  margin: 0;
}

.oraculo-steps-list {
  margin: 1.25rem 0 2rem;
  padding-left: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.oraculo-steps-list li {
  font-size: 1rem;
  line-height: 1.6;
}

.oraculo-cta-center {
  text-align: center;
}

.oraculo-included-list {
  list-style: none;
  padding: 0;
  margin: 1rem 0 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.oraculo-included-list li {
  font-size: 0.95rem;
  color: var(--text);
  opacity: 0.85;
  padding-left: 0.25rem;
}

.oraculo-included-list li::before {
  content: "✓ ";
  color: #2e8b57;
  font-weight: 700;
  margin-right: 0.4rem;
}

.oraculo-price-comparison {
  font-size: 1.05rem;
  font-style: italic;
  color: var(--text);
  opacity: 0.85;
  margin: 1rem auto 1.5rem;
  max-width: 480px;
  line-height: 1.5;
  text-align: center;
}

.oraculo-hero-eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

@media (max-width: 600px) {
  .oraculo-hero-eyebrow {
    font-size: 0.7rem;
    padding: 0 1rem;
  }
}

.oraculo-guarantee {
  list-style: none;
  padding: 0;
  margin-top: 1.25rem;
  display: inline-flex;
  flex-direction: column;
  gap: 0.4rem;
  text-align: left;
}

.oraculo-guarantee li {
  font-size: 0.9rem;
  color: var(--text);
  opacity: 0.75;
}

.oraculo-guarantee li::before {
  content: "✓ ";
  color: #2e8b57;
  font-weight: 700;
}

/* ── Content page (daily oracle) ── */

.oraculo-page.oraculo-content-page {
  padding: 1.5rem 1rem 3rem;
}

.oraculo-content-wrapper {
  max-width: 720px;
  margin: 0 auto;
}

.oraculo-back-nav {
  margin-bottom: 1.5rem;
}

.oraculo-back-link {
  font-size: 0.88rem;
  color: var(--blue);
  text-decoration: none;
  font-weight: 600;
}

.oraculo-back-link:hover {
  text-decoration: underline;
}

.oraculo-content-body {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 2rem 2.5rem;
}

/* Day header */
.oraculo-day-header {
  text-align: center;
  margin-bottom: 2.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.oraculo-day-header h2 {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 0.5rem;
}

.oraculo-date {
  font-size: 0.9rem;
  opacity: 0.55;
  font-style: italic;
  margin: 0;
}

/* Sections */
.oraculo-section {
  margin-bottom: 2rem;
}

.oraculo-section h3 {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.oraculo-section p {
  font-size: 0.97rem;
  line-height: 1.75;
  opacity: 0.9;
  margin-bottom: 0.75rem;
}

.oraculo-section ul {
  padding-left: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.oraculo-section ul li {
  font-size: 0.95rem;
  line-height: 1.65;
  opacity: 0.9;
}

/* Mantra */
.oraculo-mantra {
  background: rgba(var(--blue-rgb, 30, 100, 220), 0.08);
  border: 1px solid rgba(var(--blue-rgb, 30, 100, 220), 0.2);
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
  text-align: center;
}

.oraculo-mantra h3 {
  justify-content: center;
}

.oraculo-mantra p {
  font-size: 1.1rem;
  font-weight: 600;
  opacity: 1;
}

/* Footer */
.oraculo-footer {
  margin-top: 2rem;
  text-align: center;
  opacity: 0.5;
}

.oraculo-footer-note {
  font-size: 0.8rem;
  margin-bottom: 0.25rem;
}

/* FAQ */

.oraculo-faq-item {
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  padding: 0;
}

.oraculo-faq-item summary {
  font-weight: 600;
  font-size: 0.975rem;
  color: var(--text);
  cursor: pointer;
  list-style: none;
  padding: 1rem 0.25rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  user-select: none;
}

.oraculo-faq-item summary::-webkit-details-marker { display: none; }

.oraculo-faq-item summary::before {
  content: "+";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  height: 1.4rem;
  border-radius: 50%;
  background: rgba(255, 122, 0, 0.12);
  color: var(--orange);
  font-size: 1rem;
  font-weight: 700;
  flex-shrink: 0;
}

.oraculo-faq-item[open] summary::before {
  content: "−";
  background: rgba(255, 122, 0, 0.2);
}

.oraculo-faq-item p {
  margin: 0 0 1rem 2rem;
  color: var(--text);
  opacity: 0.72;
  font-size: 0.95rem;
  line-height: 1.7;
}

/* Revelação callout */

.oraculo-revelation-callout {
  margin: 1.5rem 0 0.5rem;
  padding: 1rem 1.25rem;
  background: rgba(255, 122, 0, 0.07);
  border-left: 3px solid var(--orange);
  border-radius: 0 8px 8px 0;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.4;
}

/* Sticky CTA mobile */

.oraculo-sticky-cta {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0.75rem 1.25rem calc(0.75rem + env(safe-area-inset-bottom));
  background: rgba(22, 61, 115, 0.97);
  backdrop-filter: blur(6px);
  z-index: 50;
  text-align: center;
  box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.25);
}

.oraculo-sticky-cta .button {
  width: 100%;
  max-width: 400px;
}

/* Responsive — content page only */
@media (max-width: 600px) {
  .oraculo-content-body {
    padding: 1.25rem 1.25rem;
  }

  .oraculo-day-header h2 {
    font-size: 1.3rem;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   RELATORIOS PAGE — /relatorios
   ═══════════════════════════════════════════════════════════════════════════ */

.relatorios-hero-context {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.85);
  margin-top: 8px;
}

.relatorio-group {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 48px;
}

.relatorio-group-header {
  margin-bottom: 8px;
}

.relatorio-group-header h2 {
  font-size: 1.45rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 6px 0 10px;
  letter-spacing: -0.02em;
}

.relatorio-group-desc {
  font-size: 0.95rem;
  color: rgba(21,34,56,0.65);
  line-height: 1.65;
  max-width: 640px;
  margin: 0;
}

.relatorio-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}

.relatorio-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px;
  background: #ffffff;
  border: 1px solid rgba(21,34,56,0.08);
  border-radius: 12px;
  border-top: 3px solid var(--blue);
  box-shadow: 0 2px 12px rgba(21,34,56,0.04);
  transition: box-shadow 0.15s, transform 0.15s;
}

.relatorio-card--analise {
  border-top-color: #4a7fc1;
}

.relatorio-card:hover {
  box-shadow: 0 4px 24px rgba(21,34,56,0.10);
  transform: translateY(-2px);
}

.relatorio-card-header {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.relatorio-card h3 {
  font-size: 1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0;
  line-height: 1.3;
}

.relatorio-card-price {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--blue);
  margin: 0;
}

.relatorio-card-cadence {
  font-size: 0.75rem;
  font-weight: 500;
  opacity: 0.7;
}

.relatorio-card-desc {
  font-size: 0.88rem;
  line-height: 1.6;
  color: rgba(21,34,56,0.65);
  flex: 1;
  margin: 0;
}

.relatorio-card-footer {
  margin-top: auto;
  padding-top: 4px;
}

.relatorios-cta-final {
  text-align: center;
  padding: 40px;
  margin-top: 8px;
}

.relatorios-cta-final h2 {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 6px 0 12px;
  letter-spacing: -0.02em;
}

.relatorios-cta-final p {
  color: rgba(21,34,56,0.65);
  max-width: 480px;
  margin: 0 auto 24px;
  line-height: 1.65;
}

@media (max-width: 720px) {
  .relatorio-cards-grid {
    grid-template-columns: 1fr;
  }
}

/* ── Baralho na página de relatórios ─────────────────────────── */
.relatorios-baralho-section {
  border: 2px solid rgba(26,107,181,0.15);
  background: linear-gradient(135deg,
    rgba(26,107,181,0.03) 0%,
    rgba(15,32,68,0.02) 100%);
}

.relatorios-baralho-content h2 {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 4px 0 10px;
  letter-spacing: -0.02em;
}

.relatorios-baralho-content p {
  font-size: 0.88rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.65);
  margin: 0 0 20px;
}

.relatorios-baralho-opcoes {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

.relatorios-baralho-opcao {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 16px 20px;
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 10px;
  min-width: 140px;
  text-align: center;
}

.relatorios-baralho-destaque {
  border-color: var(--blue);
  background: rgba(26,107,181,0.04);
}

.relatorios-baralho-badge {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  background: rgba(26,107,181,0.1);
  padding: 2px 8px;
  border-radius: 10px;
}

.relatorios-baralho-preco {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.03em;
}

.relatorios-baralho-label {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.5);
  margin-bottom: 6px;
}
/* ── End Baralho na página de relatórios ──────────────────────── */

/* ═══════════════════════════════════════════════════════════════════════════
   NEW CHART BANNER — pós-geração do mapa grátis
   ═══════════════════════════════════════════════════════════════════════════ */

.new-chart-banner {
  background: linear-gradient(135deg, var(--blue-deep) 0%, #1a4a8a 100%);
  color: white;
  padding: 40px;
  margin-bottom: 0;
  border-radius: 0;
}

.new-chart-banner .eyebrow {
  color: rgba(255,255,255,0.7);
}

.new-chart-banner h2 {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 8px 0 12px;
  letter-spacing: -0.03em;
  color: white;
}

.new-chart-banner > p {
  color: rgba(255,255,255,0.8);
  font-size: 0.95rem;
  line-height: 1.6;
  max-width: 560px;
  margin: 0 0 24px;
}

.new-chart-products {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

.new-chart-product-card {
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 8px;
  padding: 20px;
}

.new-chart-product-card h3 {
  font-size: 0.9rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: white;
}

.new-chart-product-card p {
  font-size: 0.82rem;
  margin: 0 0 16px;
  color: rgba(255,255,255,0.75);
}

.new-chart-banner-close {
  display: block;
  background: none;
  border: none;
  color: rgba(255,255,255,0.55);
  font-size: 0.85rem;
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
  margin-top: 4px;
}

.new-chart-banner-close:hover {
  color: rgba(255,255,255,0.85);
}

/* ═══════════════════════════════════════════════════════════════════════════
   POR ONDE COMEÇAR — /por-onde-comecar
   ═══════════════════════════════════════════════════════════════════════════ */

.poc-hero-context {
  font-size: 0.9rem;
  color: rgba(255,255,255,0.8);
  margin-top: 6px;
}

.poc-recommendations {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 32px;
}

.poc-recommendation {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding: 28px;
  border: 1px solid rgba(21,34,56,0.08);
  border-radius: 12px;
  margin-bottom: 12px;
  background: white;
}

.poc-recommendation--featured {
  background: rgba(26,107,181,0.04);
  border-color: var(--blue);
  border-left: 4px solid var(--blue);
}

.poc-rec-number {
  width: 36px;
  height: 36px;
  background: var(--blue-deep);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.9rem;
  flex-shrink: 0;
  margin-top: 2px;
}

.poc-rec-content h3 {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 4px 0 8px;
}

.poc-rec-content p {
  font-size: 0.9rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.7);
  margin: 0 0 16px;
}

.poc-more-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
  margin-bottom: 40px;
}

.poc-more-card {
  padding: 20px;
  border: 1px solid rgba(21,34,56,0.08);
  border-radius: 10px;
  background: white;
}

.poc-more-card h4 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 6px;
}

.poc-more-card p {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.65);
  line-height: 1.55;
  margin: 0 0 14px;
}

.poc-analise-cta {
  margin-top: 16px;
  padding: 36px 40px;
  text-align: center;
}

.poc-analise-cta h2 {
  font-size: 1.3rem;
  font-weight: 800;
  margin: 6px 0 10px;
  letter-spacing: -0.02em;
}

.poc-analise-cta p {
  color: rgba(21,34,56,0.65);
  font-size: 0.9rem;
  max-width: 440px;
  margin: 0 auto 20px;
  line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LANDING PAGES NOVAS — mapa básico, biblioteca, leitura guiada, jornada, workshop
   ═══════════════════════════════════════════════════════════════════════════ */

.lp-benefit-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: 20px 0 0;
}

.lp-benefit-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.lp-benefit-icon {
  font-size: 1.3rem;
  flex-shrink: 0;
  margin-top: 1px;
}

.lp-benefit-item h4 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 4px;
}

.lp-benefit-item p {
  font-size: 0.875rem;
  color: rgba(21,34,56,0.65);
  line-height: 1.6;
  margin: 0;
}

.lp-profiles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 20px;
}

.lp-profile-card {
  padding: 20px;
  border: 1px solid rgba(21,34,56,0.08);
  border-radius: 10px;
  background: rgba(26,107,181,0.03);
}

.lp-profile-card p {
  font-size: 0.875rem;
  color: rgba(21,34,56,0.7);
  line-height: 1.55;
  margin: 0;
}

.lp-buy-block {
  text-align: center;
  padding: 44px 40px;
  margin-top: 8px;
}

.lp-buy-block h2 {
  font-size: 1.3rem;
  font-weight: 800;
  margin: 0 0 10px;
  letter-spacing: -0.02em;
}

.lp-buy-block p {
  color: rgba(21,34,56,0.65);
  font-size: 0.9rem;
  max-width: 440px;
  margin: 0 auto;
  line-height: 1.6;
}

.lp-price {
  font-size: 2rem;
  font-weight: 900;
  color: var(--blue);
  margin: 16px 0 8px;
  letter-spacing: -0.03em;
}

.lp-price-note {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.5);
  margin: 0 0 24px;
}

.lp-badge {
  display: inline-block;
  background: #f59e0b;
  color: white;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 20px;
  margin-bottom: 12px;
  letter-spacing: 0.03em;
}

@media (max-width: 600px) {
  .new-chart-products { grid-template-columns: 1fr; }
  .poc-more-grid { grid-template-columns: 1fr; }
  .lp-profiles-grid { grid-template-columns: 1fr; }
}

/* ── Ciclo Reports ─────────────────────────────────────────── */
.ciclo-report-header {
  background: linear-gradient(135deg, #0f2044 0%, #1a3a6e 100%);
  color: white;
  border-radius: 16px;
  padding: 40px 48px;
  margin-bottom: 40px;
}

.ciclo-report-header h1 {
  font-size: 2rem;
  font-weight: 900;
  color: white;
  margin: 0 0 12px;
  letter-spacing: -0.03em;
}

.ciclo-report-header .ciclo-subtitle {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.75);
  margin: 0 0 28px;
  line-height: 1.5;
}

.ciclo-date-row {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
}

.ciclo-date-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ciclo-date-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.ciclo-date-value {
  font-size: 1.1rem;
  font-weight: 700;
  color: white;
}

.ciclo-section {
  background: white;
  border: 1px solid rgba(21,34,56,0.08);
  border-radius: 12px;
  padding: 32px 36px;
  margin-bottom: 20px;
}

.ciclo-section h2 {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--blue);
  margin: 0 0 16px;
  letter-spacing: -0.02em;
}

.ciclo-section p,
.ciclo-section li {
  font-size: 0.95rem;
  color: rgba(21,34,56,0.82);
  line-height: 1.7;
  margin: 0 0 12px;
}

.ciclo-section ul {
  padding-left: 20px;
  margin: 0;
}

.ciclo-mantra {
  background: linear-gradient(135deg, #f0f4ff 0%, #e8f0fe 100%);
  border-left: 4px solid var(--blue);
  border-radius: 0 12px 12px 0;
  padding: 28px 36px;
  margin-top: 32px;
}

.ciclo-mantra p {
  font-size: 1.15rem;
  font-style: italic;
  color: var(--blue);
  font-weight: 600;
  line-height: 1.6;
  margin: 0;
}

/* ── Ciclo Landing Pages ───────────────────────────────────── */
.ciclo-landing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 28px;
}

.ciclo-landing-card {
  background: rgba(21,34,56,0.03);
  border: 1px solid rgba(21,34,56,0.08);
  border-radius: 12px;
  padding: 24px 28px;
}

.ciclo-landing-card h3 {
  font-size: 1rem;
  font-weight: 800;
  color: var(--blue);
  margin: 0 0 10px;
  letter-spacing: -0.01em;
}

.ciclo-landing-card p {
  font-size: 0.9rem;
  color: rgba(21,34,56,0.7);
  line-height: 1.65;
  margin: 0;
}

.ciclo-pain-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 24px 0 28px;
}

.ciclo-pain-list p {
  padding: 14px 18px;
  background: rgba(21,34,56,0.03);
  border-left: 3px solid var(--blue);
  border-radius: 0 8px 8px 0;
  font-size: 0.93rem;
  color: rgba(21,34,56,0.8);
  line-height: 1.55;
  margin: 0;
}

.ciclo-pain-close {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue);
  margin: 8px 0 0 !important;
}

.ciclo-cta-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  text-align: center;
  background: linear-gradient(135deg, #f8f9ff 0%, #f0f4ff 100%);
  border: 1px solid rgba(21,34,56,0.08);
}

.ciclo-cta-block h2 {
  max-width: 560px;
  margin: 0;
}

.ciclo-cta-note {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.5);
  margin: 0 !important;
}

@media (max-width: 768px) {
  .ciclo-landing-grid { grid-template-columns: 1fr; }
  .ciclo-report-header { padding: 28px 24px; }
  .ciclo-section { padding: 24px 20px; }
  .ciclo-date-row { gap: 20px; }
}

/* ── Página Minha Conta ───────────────────────────────────────────── */
.conta-page { gap: 24px; }

.conta-identity {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}

.conta-identity-info {
  display: flex;
  align-items: center;
  gap: 20px;
}

.conta-avatar {
  width: 56px;
  height: 56px;
  background: var(--blue-deep);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  font-weight: 800;
  flex-shrink: 0;
}

.conta-name {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0 0 4px;
}

.conta-email {
  font-size: 0.88rem;
  color: rgba(21,34,56,0.6);
  margin: 0 0 2px;
}

.conta-since {
  font-size: 0.8rem;
  color: rgba(21,34,56,0.4);
  margin: 0;
}

.conta-identity-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.conta-signout { color: rgba(21,34,56,0.5) !important; }

.conta-section { display: flex; flex-direction: column; gap: 16px; }

.conta-section-header { display: flex; flex-direction: column; gap: 4px; }

.conta-section-header h2 {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0;
}

.conta-section-desc {
  font-size: 0.88rem;
  color: rgba(21,34,56,0.55);
  margin: 0;
}

.conta-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 700;
}

.status-active       { background: rgba(34,197,94,0.12); color: #15803d; }
.status-warning      { background: rgba(234,179,8,0.12);  color: #854d0e; }
.status-expired      { background: rgba(239,68,68,0.1);   color: #b91c1c; }

.conta-subscription-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  background: rgba(26,107,181,0.04);
  border: 1px solid rgba(26,107,181,0.12);
  border-radius: 10px;
  flex-wrap: wrap;
}

.conta-sub-info {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.conta-sub-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0;
}

.conta-sub-detail {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.6);
  margin: 0;
}

.conta-cycles-list { display: flex; flex-direction: column; gap: 8px; }

.conta-cycle-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid rgba(21,34,56,0.07);
  border-radius: 8px;
  flex-wrap: wrap;
}

.conta-cycle-item.is-past { opacity: 0.6; }

.conta-cycle-info {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.conta-cycle-label {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--blue-deep);
}

.conta-cycle-date {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--blue);
}

.conta-cycle-status {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.45);
}

.conta-cycle-cta {
  font-size: 0.82rem;
  color: var(--blue);
  font-weight: 600;
  text-decoration: none;
}

.conta-cycle-cta:hover { text-decoration: underline; }

.conta-products-list { display: flex; flex-direction: column; gap: 8px; }

.conta-product-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border: 1px solid rgba(21,34,56,0.07);
  border-radius: 8px;
  transition: border-color 0.15s;
  flex-wrap: wrap;
}

.conta-product-item:hover { border-color: rgba(26,107,181,0.2); }

.conta-product-info {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.conta-product-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--blue-deep);
  text-decoration: none;
}

a.conta-product-name:hover { color: var(--blue); text-decoration: underline; }

.conta-product-badge {
  display: inline-flex;
  padding: 2px 8px;
  background: rgba(26,107,181,0.08);
  color: var(--blue);
  border-radius: 20px;
  font-size: 0.72rem;
  font-weight: 700;
}

.conta-product-badge-live {
  background: rgba(234,179,8,0.1);
  color: #854d0e;
}

.conta-product-date {
  font-size: 0.8rem;
  color: rgba(21,34,56,0.4);
}

.conta-product-actions { display: flex; gap: 8px; }

.conta-product-generating {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.4);
  font-style: italic;
}

.conta-charts-list { display: flex; flex-direction: column; gap: 8px; }

.conta-chart-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border: 1px solid rgba(21,34,56,0.07);
  border-radius: 8px;
  flex-wrap: wrap;
}

.conta-chart-info { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

.conta-chart-name { font-size: 0.95rem; font-weight: 700; color: var(--blue-deep); }

.conta-chart-type { font-size: 0.8rem; color: var(--blue); font-weight: 600; }

.conta-chart-date { font-size: 0.8rem; color: rgba(21,34,56,0.4); }

.conta-charts-footer { padding-top: 8px; }

.conta-add-chart {
  font-size: 0.88rem;
  color: var(--blue);
  font-weight: 600;
  text-decoration: none;
}

.conta-add-chart:hover { text-decoration: underline; }

.conta-empty-state {
  padding: 24px;
  background: rgba(21,34,56,0.02);
  border-radius: 8px;
  border: 1px dashed rgba(21,34,56,0.12);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.conta-empty-state p { font-size: 0.9rem; color: rgba(21,34,56,0.6); margin: 0; }

.conta-empty-sub { font-size: 0.85rem !important; color: rgba(21,34,56,0.45) !important; }

@media (max-width: 720px) {
  .conta-identity        { flex-direction: column; align-items: flex-start; }
  .conta-subscription-card { flex-direction: column; align-items: flex-start; }
  .conta-cycle-item      { flex-direction: column; align-items: flex-start; }
  .conta-product-item    { flex-direction: column; align-items: flex-start; }
  .conta-chart-item      { flex-direction: column; align-items: flex-start; }
}
/* ── Editar Dados ────────────────────────────────────────────────── */
.conta-back-link {
  font-size: 0.85rem;
  color: var(--blue);
  text-decoration: none;
  display: inline-block;
  margin-bottom: 12px;
}
.conta-back-link:hover { text-decoration: underline; }

.conta-edit-header { gap: 4px; display: flex; flex-direction: column; padding-bottom: 0; }

.conta-edit-title {
  font-size: 1.4rem;
  font-weight: 900;
  color: var(--blue-deep);
  margin: 0;
  letter-spacing: -0.02em;
}

.conta-edit-form { display: flex; flex-direction: column; gap: 32px; }

.conta-fieldset {
  border: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.conta-fieldset-legend {
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(21,34,56,0.5);
  margin-bottom: 4px;
}

.conta-fieldset-optional {
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: rgba(21,34,56,0.35);
}

.conta-fieldset-desc {
  font-size: 0.88rem;
  color: rgba(21,34,56,0.55);
  margin: -8px 0 4px;
  line-height: 1.5;
}

.conta-field { display: flex; flex-direction: column; gap: 6px; }

.conta-label {
  font-size: 0.88rem;
  font-weight: 700;
  color: rgba(21,34,56,0.75);
}

.conta-input {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid rgba(21,34,56,0.15);
  border-radius: 8px;
  font-size: 0.95rem;
  color: var(--blue-deep);
  background: white;
  transition: border-color 0.15s;
  box-sizing: border-box;
  font-family: inherit;
}

.conta-input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(26,107,181,0.1);
}

.conta-textarea { resize: vertical; min-height: 96px; line-height: 1.6; }

.conta-field-hint {
  font-size: 0.8rem;
  color: rgba(21,34,56,0.45);
  margin: 0;
  line-height: 1.5;
}

.conta-form-actions { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }

.conta-form-errors {
  background: rgba(239,68,68,0.06);
  border: 1px solid rgba(239,68,68,0.2);
  border-radius: 8px;
  padding: 14px 18px;
}

.conta-form-errors p {
  font-size: 0.88rem;
  color: #b91c1c;
  margin: 0 0 4px;
}

.conta-form-errors p:last-child { margin: 0; }

.conta-edit-divider {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(21,34,56,0.08);
}

.conta-edit-divider p {
  font-size: 0.88rem;
  color: rgba(21,34,56,0.55);
  margin: 0;
}
/* ── End Minha Conta ──────────────────────────────────────────────── */

/* ── Popup de escolha de ciclo ──────────────────────────────────────── */
.ciclo-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.ciclo-modal[hidden] { display: none; }

.ciclo-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10,18,32,0.6);
  backdrop-filter: blur(4px);
  cursor: pointer;
}

.ciclo-modal-box {
  position: relative;
  background: #ffffff;
  border-radius: 16px;
  padding: 40px;
  max-width: 680px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 24px 80px rgba(10,18,32,0.3);
  z-index: 1;
}

.ciclo-modal-close {
  position: absolute;
  top: 16px;
  right: 20px;
  background: none;
  border: none;
  font-size: 1.5rem;
  color: rgba(21,34,56,0.4);
  cursor: pointer;
  line-height: 1;
  padding: 4px 8px;
}

.ciclo-modal-close:hover { color: rgba(21,34,56,0.8); }

.ciclo-modal-eyebrow { margin: 0 0 8px; }

.ciclo-modal-heading {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.03em;
  margin: 0 0 8px;
}

.ciclo-modal-sub {
  font-size: 0.9rem;
  color: rgba(21,34,56,0.6);
  margin: 0 0 28px;
}

.ciclo-modal-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 20px;
}

.ciclo-modal-option {
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 12px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ciclo-modal-option--featured {
  border-color: var(--blue);
  border-width: 2px;
  background: rgba(26,107,181,0.03);
}

.ciclo-modal-badge {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue);
  background: rgba(26,107,181,0.1);
  padding: 3px 8px;
  border-radius: 20px;
  margin-bottom: 6px;
}

.ciclo-modal-badge--alt {
  color: rgba(21,34,56,0.6);
  background: rgba(21,34,56,0.06);
}

.ciclo-modal-option h3 {
  font-size: 1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0 0 4px;
}

.ciclo-modal-price {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--blue);
  margin: 0;
}

.ciclo-modal-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}

.ciclo-modal-list li {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.7);
  padding-left: 16px;
  position: relative;
  line-height: 1.5;
}

.ciclo-modal-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--blue);
  font-weight: 700;
  font-size: 0.8rem;
}

.ciclo-modal-btn { width: 100%; text-align: center; }

.ciclo-modal-note {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.4);
  text-align: center;
  margin: 0;
}

.ciclo-modal-dismiss {
  display: block;
  width: 100%;
  background: none;
  border: none;
  font-size: 0.82rem;
  color: rgba(21,34,56,0.35);
  cursor: pointer;
  text-align: center;
  padding: 8px;
  text-decoration: underline;
}

.ciclo-modal-dismiss:hover { color: rgba(21,34,56,0.6); }

.cycle-cta-btn {
  background: none;
  border: none;
  padding: 0;
  font-size: inherit;
  color: var(--blue);
  cursor: pointer;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.cycle-cta-btn:hover { color: var(--blue-deep); }

@media (max-width: 600px) {
  .ciclo-modal-box { padding: 28px 20px; }
  .ciclo-modal-options { grid-template-columns: 1fr; }
}
/* ── End popup ciclo ────────────────────────────────────────────────── */

/* ── Jornada ──────────────────────────────────────────────────────────── */
.jornada-page { max-width: 900px; margin: 0 auto; }

.jornada-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px;
  padding: 0 20px 60px;
}

.jornada-card {
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 12px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: #fff;
  transition: box-shadow 0.2s;
}

.jornada-card:hover { box-shadow: 0 4px 20px rgba(21,34,56,0.08); }

.jornada-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
}

.jornada-card-week {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue);
  background: rgba(26,107,181,0.1);
  padding: 3px 8px;
  border-radius: 20px;
}

.jornada-card-theme {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.5);
}

.jornada-card-title {
  font-size: 1rem;
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.02em;
  line-height: 1.3;
  margin: 0;
}

.jornada-card-preview {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.6);
  line-height: 1.6;
  flex: 1;
}

.jornada-card-cta {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--blue);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.jornada-card-cta:hover { text-decoration: underline; }

/* Post view */
.jornada-post-page { max-width: 720px; margin: 0 auto; padding: 0 20px 80px; }

.jornada-post-nav { padding: 20px 0; }

.jornada-back-link {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.5);
  text-decoration: none;
}

.jornada-back-link:hover { color: var(--blue); }

.jornada-post-header {
  margin-bottom: 40px;
}

.jornada-post-header h1 {
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.03em;
  line-height: 1.2;
  margin: 8px 0 0;
}

.jornada-post-body { margin-bottom: 40px; }

.journey-post-free { line-height: 1.8; }

.journey-post-free h2 {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.02em;
  margin: 32px 0 12px;
}

.journey-post-free p {
  font-size: 1rem;
  color: rgba(21,34,56,0.8);
  margin-bottom: 16px;
}

.journey-post-locked-wrapper { margin-top: 40px; }

.journey-post-locked {
  position: relative;
  min-height: 200px;
  border-radius: 12px;
  overflow: hidden;
}

.journey-lock-overlay {
  background: rgba(250,251,255,0.95);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(26,107,181,0.15);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 40px;
  text-align: center;
}

.journey-lock-title {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.02em;
  margin: 0;
}

.journey-lock-sub {
  font-size: 0.9rem;
  color: rgba(21,34,56,0.65);
  max-width: 400px;
  line-height: 1.6;
  margin: 0;
}

.journey-lock-price {
  font-size: 0.8rem;
  color: rgba(21,34,56,0.45);
  margin: 0;
}

.journey-locked-preview {
  background: rgba(26,107,181,0.04);
  border: 1px solid rgba(26,107,181,0.12);
  border-radius: 10px;
  padding: 24px;
  margin-top: 32px;
}

.journey-locked-preview .journey-locked-title {
  font-size: 1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0 0 8px;
}

.journey-locked-preview .journey-locked-sub {
  font-size: 0.88rem;
  color: rgba(21,34,56,0.6);
  line-height: 1.6;
  margin: 0;
}

.journey-unlocked-banner {
  background: rgba(26,107,181,0.06);
  border: 1px solid rgba(26,107,181,0.2);
  border-radius: 10px;
  padding: 24px;
  display: flex;
  align-items: center;
  gap: 20px;
}

.journey-unlocked-banner p {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(21,34,56,0.7);
  flex: 1;
}

.jornada-post-pagination {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-top: 40px;
  border-top: 1px solid rgba(21,34,56,0.08);
}

.jornada-pagination-link {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.5);
  text-decoration: none;
  max-width: 48%;
  line-height: 1.4;
}

.jornada-pagination-link:hover { color: var(--blue); }

.jornada-pagination-next { text-align: right; margin-left: auto; }

@media (max-width: 600px) {
  .jornada-grid { grid-template-columns: 1fr; }
  .jornada-post-header h1 { font-size: 1.4rem; }
  .journey-lock-overlay { padding: 28px 20px; }
  .journey-unlocked-banner { flex-direction: column; }
  .jornada-post-pagination { flex-direction: column; }
  .jornada-pagination-link { max-width: 100%; }
}
.jornada-note {
  margin-top: 8px;
}

.jornada-note-inner {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 640px;
}

.jornada-note-inner h2 {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0;
  letter-spacing: -0.02em;
}

.jornada-note-inner p {
  font-size: 0.92rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.7);
  margin: 0;
}

.jornada-note-emphasis {
  font-size: 0.92rem !important;
  font-weight: 600;
  color: var(--blue-deep) !important;
  padding: 14px 18px;
  background: rgba(26,107,181,0.06);
  border-left: 3px solid var(--blue);
  border-radius: 0 8px 8px 0;
}
/* ── End Jornada ──────────────────────────────────────────────────────── */

/* ── Welcome page ─────────────────────────────────────────────────────── */
.welcome-hero {
  text-align: center;
  padding: 56px 24px 48px;
}

.welcome-hero h1 {
  font-size: 2.4rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  color: #1f2b3f;
  margin: 0 0 16px;
}

.welcome-hero-sub {
  font-size: 1.05rem;
  line-height: 1.65;
  color: rgba(31,43,63,0.7);
  max-width: 520px;
  margin: 0 auto;
}

.welcome-steps {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.welcome-step {
  display: flex;
  gap: 20px;
  align-items: flex-start;
}

.welcome-step-num {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #1c529a;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
}

.welcome-step-body h3 {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: 700;
  color: #1f2b3f;
}

.welcome-step-body p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(31,43,63,0.65);
}

.welcome-cta {
  text-align: center;
  padding: 40px 24px;
}

.welcome-cta-note {
  margin: 12px 0 0;
  font-size: 0.82rem;
  color: rgba(31,43,63,0.45);
}

.welcome-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 16px;
}

.welcome-preview-item {
  background: rgba(28,82,154,0.04);
  border: 1px solid rgba(28,82,154,0.1);
  border-radius: 10px;
  padding: 16px 18px;
}

.welcome-preview-item h4 {
  margin: 0 0 6px;
  font-size: 0.9rem;
  font-weight: 700;
  color: #1f2b3f;
}

.welcome-preview-item p {
  margin: 0;
  font-size: 0.85rem;
  line-height: 1.5;
  color: rgba(31,43,63,0.6);
}

@media (max-width: 600px) {
  .welcome-hero h1 { font-size: 1.7rem; }
  .welcome-preview-grid { grid-template-columns: 1fr; }
}
/* ── End Welcome page ─────────────────────────────────────────────────── */

/* ── Painel de Porta ──────────────────────────────────────────────── */
.gate-panel-loading {
  color: rgba(21,34,56,0.4);
  font-size: 0.88rem;
  font-style: italic;
}

.gate-panel-meta {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(21,34,56,0.4);
  margin: 0 0 14px;
}

.gate-panel-desc,
.gate-panel-body-content {
  font-size: 0.9rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.75);
  margin: 0 0 16px;
}

.gate-panel-desc p,
.gate-panel-body-content p { margin: 0 0 10px; }

.gate-panel-line {
  margin: 16px 0;
  padding: 16px;
  border: 1px solid rgba(21,34,56,0.08);
  border-radius: 8px;
  background: rgba(26,107,181,0.02);
}

.gate-panel-line-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  margin: 0 0 6px;
}

.gate-panel-line-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 10px;
}

.gate-panel-line-intro,
.gate-panel-line-meaning {
  font-size: 0.88rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.75);
}

.gate-panel-line-intro p,
.gate-panel-line-meaning p { margin: 0 0 8px; }

.gate-panel-related-channel {
  margin: 16px 0;
  padding: 14px;
  background: rgba(21,34,56,0.03);
  border-radius: 8px;
  font-size: 0.87rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.65);
}

.gate-panel-related-channel p { margin: 0 0 6px; }

.gate-panel-channel-ref {
  font-size: 0.8rem;
  color: rgba(21,34,56,0.4);
  margin: 12px 0 0;
}

.gate-panel-action-link {
  font-size: 0.82rem;
  color: var(--blue);
  font-weight: 600;
  text-decoration: none;
}

.gate-panel-action-link:hover { text-decoration: underline; }
/* ── End Painel de Porta ──────────────────────────────────────────── */

/* ── Sequência de reconhecimento ─────────────────────────────────── */
.recognition-sequence {
  background: linear-gradient(135deg, #0f2044 0%, #1a3a6e 100%);
  color: white;
  padding: 48px 40px;
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.recognition-phrase {
  font-size: clamp(1.2rem, 2.5vw, 1.6rem);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.02em;
  color: white;
  margin: 0;
  max-width: 640px;
}

.recognition-questions-intro {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin: 0 0 16px;
}

.recognition-questions {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.recognition-question {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px;
  padding: 16px 20px;
  color: rgba(255,255,255,0.8);
  font-size: 0.95rem;
  line-height: 1.55;
  text-align: left;
  cursor: pointer;
  transition: all 0.15s;
  font-family: inherit;
}

.recognition-question:hover {
  background: rgba(255,255,255,0.12);
  color: white;
}

.recognition-question.is-selected {
  background: rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.4);
  color: white;
}

.recognition-question.is-selected::before {
  content: "✓ ";
  color: rgba(255,255,255,0.6);
}

.recognition-reveal {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 12px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 8px;
}

.recognition-reveal p {
  font-size: 0.95rem;
  line-height: 1.65;
  color: rgba(255,255,255,0.85);
  margin: 0;
}

.recognition-reveal p:first-child {
  font-size: 1.1rem;
  font-weight: 700;
  color: white;
}

.recognition-skip {
  background: none;
  border: none;
  color: rgba(255,255,255,0.3);
  font-size: 0.82rem;
  cursor: pointer;
  text-decoration: underline;
  font-family: inherit;
  text-align: left;
  padding: 0;
  margin-top: 8px;
  align-self: flex-start;
}

.recognition-secondary-cta {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.35);
  margin: 8px 0 0;
  text-align: center;
}
.recognition-secondary-link {
  color: rgba(255,255,255,0.35);
  text-decoration: underline;
}

@media (max-width: 720px) {
  .recognition-sequence { padding: 32px 20px; }
}

.recognition-context-intro {
  border-bottom: 1px solid rgba(255,255,255,0.12);
  padding-bottom: 20px;
}
.recognition-context-text {
  font-size: 0.9rem;
  color: rgba(255,255,255,0.55);
  margin: 0;
  line-height: 1.55;
}
.recognition-context-text strong {
  color: rgba(255,255,255,0.9);
  font-weight: 600;
}
/* ── End sequência de reconhecimento ─────────────────────────────── */

/* ── Today insights ───────────────────────────────────────────────── */
.today-insight {
  padding: 14px 16px;
  border-radius: 10px;
  margin-bottom: 10px;
  border: 1px solid rgba(21,34,56,0.08);
}

.today-insight--natal {
  background: rgba(26,107,181,0.05);
  border-color: rgba(26,107,181,0.15);
}

.today-insight--electromagnetic {
  background: rgba(180,100,20,0.05);
  border-color: rgba(180,100,20,0.2);
}

.today-insight-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.today-insight-planet {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--blue);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.today-insight-gate {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--blue-deep);
}

.today-insight-badge {
  font-size: 0.72rem;
  padding: 2px 8px;
  border-radius: 20px;
  background: rgba(26,107,181,0.1);
  color: var(--blue);
  font-weight: 600;
}

.today-insight--electromagnetic .today-insight-badge {
  background: rgba(180,100,20,0.1);
  color: #8b4513;
}

.today-insight-message {
  font-size: 0.88rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.75);
  margin: 0;
}

.today-insight-cta {
  margin-top: 16px;
  padding: 16px;
  background: rgba(26,107,181,0.04);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.today-insight-cta p {
  font-size: 0.88rem;
  color: rgba(21,34,56,0.7);
  margin: 0;
}

.today-insight-price {
  font-size: 0.75rem !important;
  color: rgba(21,34,56,0.4) !important;
}
/* ── End Today insights ───────────────────────────────────────────── */

/* ── Diário de Experimentos ───────────────────────────────────────── */
.experiment-page { gap: 24px; max-width: 680px; margin: 0 auto; }
.experiment-hero { text-align: center; padding: 48px 24px 40px; }
.experiment-hero h1 { font-size: 1.6rem; font-weight: 800; letter-spacing: -0.03em; line-height: 1.2; }
.experiment-hero-sub { font-size: 0.95rem; color: rgba(21,34,56,0.65); line-height: 1.6; max-width: 480px; margin: 12px auto 0; }

.experiment-form { display: flex; flex-direction: column; gap: 20px; }
.experiment-field { display: flex; flex-direction: column; gap: 8px; }
.experiment-label { font-size: 0.82rem; font-weight: 700; color: var(--blue-deep); text-transform: uppercase; letter-spacing: 0.06em; }
.experiment-textarea { padding: 12px 16px; border: 1px solid rgba(21,34,56,0.15); border-radius: 8px; font-size: 0.92rem; font-family: inherit; line-height: 1.6; resize: vertical; color: var(--blue-deep); background: white; }
.experiment-textarea:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px rgba(26,107,181,0.1); }
.experiment-date { padding: 10px 14px; border: 1px solid rgba(21,34,56,0.15); border-radius: 8px; font-size: 0.9rem; font-family: inherit; color: var(--blue-deep); }

.experiment-toggle-group { display: flex; gap: 12px; }
.experiment-toggle { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.experiment-radio { accent-color: var(--blue); }
.experiment-toggle-label { font-size: 0.9rem; font-weight: 600; padding: 8px 16px; border-radius: 8px; border: 1px solid rgba(21,34,56,0.15); cursor: pointer; }
.experiment-toggle-yes { color: #15803d; border-color: rgba(34,197,94,0.3); }
.experiment-toggle-no { color: #b91c1c; border-color: rgba(239,68,68,0.3); }
.experiment-authority-hint { font-size: 0.8rem; color: rgba(21,34,56,0.5); margin: 0; }

.experiment-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-bottom: 16px; }
.experiment-stat { text-align: center; padding: 16px; border-radius: 10px; background: rgba(21,34,56,0.03); border: 1px solid rgba(21,34,56,0.07); }
.experiment-stat--yes { background: rgba(34,197,94,0.06); border-color: rgba(34,197,94,0.2); }
.experiment-stat--no { background: rgba(239,68,68,0.05); border-color: rgba(239,68,68,0.15); }
.experiment-stat-num { display: block; font-size: 1.8rem; font-weight: 800; color: var(--blue-deep); }
.experiment-stat-label { font-size: 0.75rem; color: rgba(21,34,56,0.5); }
.experiment-pattern-note { font-size: 0.88rem; line-height: 1.7; color: rgba(21,34,56,0.65); margin: 0; }

.experiment-entries { display: flex; flex-direction: column; gap: 12px; }
.experiment-entry { padding: 16px; border-radius: 10px; border: 1px solid rgba(21,34,56,0.08); position: relative; }
.experiment-entry--yes { border-left: 3px solid #22c55e; }
.experiment-entry--no { border-left: 3px solid #ef4444; }
.experiment-entry-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.experiment-entry-date { font-size: 0.75rem; color: rgba(21,34,56,0.4); }
.experiment-entry-authority { font-size: 0.75rem; font-weight: 700; }
.experiment-entry--yes .experiment-entry-authority { color: #15803d; }
.experiment-entry--no .experiment-entry-authority { color: #b91c1c; }
.experiment-entry-decision { font-size: 0.9rem; color: var(--blue-deep); font-weight: 600; margin: 0 0 6px; line-height: 1.5; }
.experiment-entry-outcome { font-size: 0.85rem; color: rgba(21,34,56,0.65); margin: 0; line-height: 1.55; }
.experiment-entry-delete { position: absolute; top: 12px; right: 12px; background: none; border: none; color: rgba(21,34,56,0.25); cursor: pointer; font-size: 1.1rem; padding: 0 4px; }
.experiment-entry-delete:hover { color: rgba(21,34,56,0.6); }

@media (max-width: 600px) {
  .experiment-stats { grid-template-columns: repeat(2,1fr); }
  .experiment-hero { padding: 32px 16px 28px; }
}
/* ── End Diário de Experimentos ───────────────────────────────────── */

/* ── WhatsApp flutuante ───────────────────────────────────────────── */
.whatsapp-float {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 56px;
  height: 56px;
  background: #25d366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(37,211,102,0.4);
  z-index: 9000;
  transition: transform 0.2s, box-shadow 0.2s;
  text-decoration: none;
}
.whatsapp-float:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(37,211,102,0.5);
}
@media (max-width: 720px) {
  .whatsapp-float { bottom: 16px; right: 16px; width: 48px; height: 48px; }
}
/* ── End WhatsApp flutuante ───────────────────────────────────────── */

/* ── Urgência de vaga (análises ao vivo) ─────────────────────────── */
.analise-urgencia {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.55);
  margin: 10px 0 8px;
  line-height: 1.5;
  text-align: center;
}
.analise-urgencia strong { color: var(--blue-deep); }
.analysis-inline-guarantee {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.45);
  text-align: center;
  margin: 8px 0 0;
  line-height: 1.55;
}
/* ── End Urgência de vaga ─────────────────────────────────────────── */

/* ── Garantia de cancelamento inline (landings de análise) ─────────── */
.analysis-guarantee-details {
  margin: 12px 0 8px;
  border: 1px solid rgba(21,34,56,0.12);
  border-radius: 8px;
  padding: 0;
  background: rgba(21,34,56,0.02);
}
.analysis-guarantee-toggle {
  cursor: pointer;
  padding: 10px 14px;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--blue-deep);
  list-style: none;
  display: flex;
  align-items: center;
  gap: 6px;
  user-select: none;
}
.analysis-guarantee-toggle::before { content: "▶"; font-size: 0.6rem; transition: transform 0.15s; }
details[open] .analysis-guarantee-toggle::before { transform: rotate(90deg); }
.analysis-guarantee-body {
  padding: 0 14px 12px;
  font-size: 0.82rem;
  color: rgba(21,34,56,0.7);
  line-height: 1.55;
}
.analysis-guarantee-body p { margin: 0 0 6px; }
.analysis-guarantee-body p:last-child { margin-bottom: 0; }
/* ── End Garantia de cancelamento ────────────────────────────────── */

/* ── Depoimento no checkout ───────────────────────────────────────── */
.checkout-testimonial {
  padding: 16px;
  background: rgba(26,107,181,0.04);
  border-radius: 8px;
  border-left: 3px solid var(--blue);
  margin-top: 20px;
}
.checkout-testimonial-stars {
  color: #f59e0b;
  font-size: 0.9rem;
  margin-bottom: 8px;
  letter-spacing: 2px;
}
.checkout-testimonial-text {
  font-size: 0.85rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.75);
  font-style: italic;
  margin: 0 0 8px;
}
.checkout-testimonial-author {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.45);
  font-weight: 600;
  margin: 0;
}
/* ── End Depoimento no checkout ───────────────────────────────────── */

/* ── Bestseller card na página de relatórios ─────────────────────── */
.relatorio-featured-card {
  background: linear-gradient(135deg, rgba(26,107,181,0.08), rgba(26,107,181,0.03));
  border: 2px solid var(--blue);
  border-radius: 14px;
  padding: 22px 26px;
  margin-bottom: 20px;
}
.relatorio-featured-badge {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 14px;
}
.relatorio-featured-content {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.relatorio-featured-content h3 {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0 0 6px;
  letter-spacing: -0.02em;
}
.relatorio-featured-content p {
  font-size: 0.88rem;
  line-height: 1.6;
  color: rgba(21,34,56,0.65);
  margin: 0;
  max-width: 420px;
}
.relatorio-featured-cta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}
.relatorio-featured-price {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--blue);
  margin: 0 !important;
}
@media (max-width: 600px) {
  .relatorio-featured-content { flex-direction: column; align-items: flex-start; }
  .relatorio-featured-cta { align-items: flex-start; }
}
/* ── End Bestseller relatórios ────────────────────────────────────── */

/* ── Progresso na jornada — badge "Você tem este" ────────────────── */
.progress-card--owned { opacity: 0.78; }
.progress-card-badge--owned {
  background: rgba(34,197,94,0.12);
  color: #15803d;
  border-radius: 20px;
  font-size: 0.7rem;
  font-weight: 700;
  padding: 2px 10px;
  display: inline-block;
  margin-bottom: 6px;
}
/* ── End Progresso na jornada ─────────────────────────────────────── */

/* ── Rodapé centralizado ──────────────────────────────────────────── */
.site-footer-brand {
  align-items: center;
  text-align: center;
}

.site-footer-brand > p {
  text-align: center;
  max-width: none;
}

.footer-brand {
  justify-content: center;
}

.footer-social {
  justify-content: center;
}

.site-footer-bottom {
  justify-content: center;
  text-align: center;
}
/* ── End Rodapé centralizado ──────────────────────────────────────── */

/* ── Page transition ──────────────────────────────────────────────── */
#page-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: linear-gradient(90deg, #1a6bb5 0%, #0f2044 50%, #1a6bb5 100%);
  background-size: 200% 100%;
  z-index: 99999;
  transition: width 0.3s ease;
  animation: progress-shimmer 1.5s infinite linear;
  opacity: 0;
  pointer-events: none;
}

#page-progress.is-loading {
  opacity: 1;
  width: 85%;
  transition: width 8s cubic-bezier(0.1, 0.05, 0, 1);
}

#page-progress.is-complete {
  width: 100% !important;
  opacity: 0;
  transition: width 0.2s ease, opacity 0.3s ease 0.2s;
}

@keyframes progress-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Fade suave do conteúdo ao navegar */
.page-fade-out {
  opacity: 0.6;
  transition: opacity 0.15s ease;
  pointer-events: none;
}
/* ── End Page transition ──────────────────────────────────────────── */

/* ── DH Loading Overlay ───────────────────────────────────────────── */
.dh-loading-overlay[hidden] {
  display: none;
}

.dh-loading-overlay {
  position: fixed;
  inset: 0;
  background: #ffffff;
  z-index: 99990;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.dh-loading-overlay:not([hidden]) {
  opacity: 1;
  pointer-events: auto;
}

.dh-loading-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 32px 24px;
  max-width: 340px;
  text-align: center;
}

.dh-loading-title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: #1a3a6e;
}

.dh-loading-inline-dots {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  vertical-align: middle;
  margin-left: 5px;
}

.dh-loading-inline-dots span {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(26, 58, 110, 0.3);
  animation: dot-pulse 1.4s ease-in-out infinite;
}

.dh-loading-inline-dots span:nth-child(2) { animation-delay: 0.2s; }
.dh-loading-inline-dots span:nth-child(3) { animation-delay: 0.4s; }

.dh-loading-video {
  width: 248px !important;
  height: 248px !important;
  max-width: 248px;
  max-height: 248px;
  object-fit: contain;
  border: none;
  outline: none;
  box-shadow: none;
  clip-path: inset(3px round 25px);
  flex-shrink: 0;
  display: block;
  user-select: none;
  pointer-events: none;
}

.dh-loading-phrase {
  font-size: 0.95rem;
  line-height: 1.65;
  color: rgba(26, 58, 110, 0.8);
  font-weight: 400;
  letter-spacing: 0.01em;
  min-height: 3em;
  transition: opacity 0.4s ease;
}

.dh-loading-phrase.is-fading {
  opacity: 0;
}

.dh-loading-dots {
  display: flex;
  gap: 8px;
  align-items: center;
}

.dh-loading-dots span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(26, 58, 110, 0.3);
  animation: dot-pulse 1.4s ease-in-out infinite;
}

.dh-loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.dh-loading-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes dot-pulse {
  0%, 80%, 100% {
    transform: scale(0.8);
    background: rgba(26, 58, 110, 0.3);
  }
  40% {
    transform: scale(1.2);
    background: rgba(26, 58, 110, 0.9);
  }
}
/* ── End DH Loading Overlay ───────────────────────────────────────── */

/* ── Preview desbloqueável ────────────────────────────────────────── */
.preview-page { gap: 24px; }

.preview-report-header .preview-status {
  color: rgba(21,34,56,0.4);
  font-style: italic;
}

/* === PHS Transformation Cards === */
.phs-transformation-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 24px 0 0;
}

.phs-transformation-card {
  border-radius: 12px;
  padding: 18px 16px 16px;
  display: flex;
  flex-direction: column;
  background: #ffffff;
  border: 5px solid transparent;
  color: var(--blue-deep);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  position: relative;
  overflow: hidden;
}

.phs-transformation-card::after {
  content: "";
  position: absolute;
  bottom: 10px;
  right: 10px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--card-accent);
  opacity: 0.85;
}

.phs-transformation-card--1 { border-color: #EA580C; --card-accent: #EA580C; }
.phs-transformation-card--2 { border-color: #16A34A; --card-accent: #16A34A; }
.phs-transformation-card--3 { border-color: #2563EB; --card-accent: #2563EB; }
.phs-transformation-card--4 { border-color: #7C3AED; --card-accent: #7C3AED; }

.phs-tc-number {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: rgba(21, 34, 56, 0.45);
  margin-bottom: 4px;
}

.phs-tc-name {
  display: block;
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: 4px;
}

.phs-transformation-card--1 .phs-tc-name { color: #EA580C; }
.phs-transformation-card--2 .phs-tc-name { color: #16A34A; }
.phs-transformation-card--3 .phs-tc-name { color: #2563EB; }
.phs-transformation-card--4 .phs-tc-name { color: #7C3AED; }


.phs-tc-subtitle {
  display: block;
  font-size: 0.8rem;
  line-height: 1.4;
  color: rgba(21, 34, 56, 0.55);
  margin-bottom: 0;
}

.phs-tc-sep {
  border: none;
  border-top: 1px solid rgba(21, 34, 56, 0.12);
  margin: 12px 0;
}

.phs-tc-variables {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.phs-tc-variables li {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--blue-deep);
}

.phs-tc-var-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(21, 34, 56, 0.45);
  line-height: 1.2;
  margin-bottom: 1px;
}

.phs-tc-var-value {
  display: block;
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--blue-deep);
  line-height: 1.3;
}

/* Mobile: grid 2×2 */
@media (max-width: 767px) {
  .phs-transformation-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile: grid 2×2 */
@media (max-width: 767px) {
  .phs-transformation-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

.preview-variables-hook {
  font-size: 0.9rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.65);
  margin: 16px 0 0;
  font-style: italic;
}

.preview-locked-sections {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.preview-locked-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid rgba(21,34,56,0.07);
}

.preview-locked-item:last-child { border-bottom: none; }

.preview-locked-content h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: rgba(21,34,56,0.5);
  margin: 0 0 4px;
}

.preview-locked-content p {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.35);
  margin: 0;
  line-height: 1.5;
}

.preview-locked-icon {
  font-size: 1rem;
  opacity: 0.4;
  flex-shrink: 0;
  margin-top: 2px;
}

.preview-cta {
  text-align: center;
  background: linear-gradient(135deg,
    rgba(26,107,181,0.06) 0%,
    rgba(15,32,68,0.04) 100%);
  border: 2px solid rgba(26,107,181,0.2);
}

.preview-cta h2 {
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
}

.preview-cta p {
  font-size: 0.9rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.65);
  max-width: 480px;
  margin: 0 auto 24px;
}

.preview-cta-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.preview-cta-price {
  font-size: 1.8rem !important;
  font-weight: 800 !important;
  color: var(--blue) !important;
  margin: 0 !important;
  letter-spacing: -0.03em;
}

.button-lg {
  padding: 16px 36px;
  font-size: 1rem;
}

.preview-cta-note {
  font-size: 0.78rem !important;
  color: rgba(21,34,56,0.4) !important;
  margin: 0 !important;
}

.preview-centers-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 16px 0;
}

.preview-center-item {
  padding: 14px 16px;
  background: rgba(26,107,181,0.04);
  border: 1px solid rgba(26,107,181,0.12);
  border-left: 3px solid var(--blue);
  border-radius: 8px;
}

.preview-center-name {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 4px;
}

.preview-center-hook {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.6);
  margin: 0;
  line-height: 1.5;
}
/* ── End Preview desbloqueável ────────────────────────────────────── */

/* ── Admin panel ──────────────────────────────────────────────────── */
.admin-generate-panel {
  background: rgba(239,68,68,0.04);
  border: 1px dashed rgba(239,68,68,0.3);
  border-radius: 8px;
  padding: 16px;
  margin-top: 16px;
}

.admin-eyebrow {
  color: #dc2626 !important;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 12px;
}

.admin-generate-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}

.admin-generate-btn {
  background: white;
  border: 1px solid rgba(239,68,68,0.2);
  border-radius: 6px;
  padding: 6px 4px;
  font-size: 0.72rem;
  font-weight: 600;
  color: #dc2626;
  cursor: pointer;
  text-align: center;
  transition: background 0.15s;
  width: 100%;
}

.admin-generate-btn:hover {
  background: rgba(239,68,68,0.08);
}
/* ── End Admin panel ──────────────────────────────────────────────── */

/* ── Baralho 64 Portas ────────────────────────────────────────────── */
.baralho-page {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px 48px;
}

.baralho-hero {
  text-align: center;
  padding: 48px 24px 32px;
}

.baralho-hero h1 {
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--blue-deep);
  max-width: none;
  width: 100%;
  margin: 0 auto 12px;
  text-align: center;
  white-space: nowrap;
}

@media (max-width: 600px) {
  .baralho-hero h1 {
    white-space: normal;
    font-size: 1.2rem;
  }
}

.baralho-hero-sub {
  font-size: 0.95rem;
  color: rgba(21,34,56,0.6);
  line-height: 1.65;
  max-width: 480px;
  margin: 0 auto;
}

.baralho-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 900px;
  margin: 0 auto;
}

.baralho-grid .carta-wrapper:last-child:nth-child(3n + 1) {
  grid-column: 2 / 3;
}

@media (max-width: 600px) {
  .baralho-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}

@media (max-width: 380px) {
  .baralho-grid { grid-template-columns: repeat(1, 1fr); gap: 12px; }
}

.carta-wrapper {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.carta-flip {
  position: relative;
  width: 100%;
  aspect-ratio: 2 / 3;
  cursor: pointer;
  transform-style: preserve-3d;
  transition: transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 6px;
}

.carta-flip.is-flipped {
  transform: rotateY(180deg);
}

.carta-face {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  transition: box-shadow 0.2s;
}

.carta-face:hover {
  box-shadow: 0 4px 16px rgba(26,107,181,0.25);
}

.carta-frente {
  border: 2px solid var(--blue, #1a6bb5);
}

.carta-verso {
  transform: rotateY(180deg);
  border: 2px solid var(--orange, #ff7a00);
}

.carta-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  user-select: none;
  pointer-events: none;
}

.carta-label { text-align: center; }

.carta-label-btn {
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 4px;
  border-radius: 6px;
  width: 100%;
  transition: background 0.15s;
}

.carta-label-btn:hover { background: rgba(26,107,181,0.07); }

.carta-num {
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--blue);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.carta-iching {
  font-size: 0.6rem;
  color: rgba(21,34,56,0.4);
  font-style: italic;
  line-height: 1.3;
}

.carta-name {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--blue-deep);
  line-height: 1.3;
}

.carta-hexagram {
  font-size: 1.4rem;
  line-height: 1;
  color: var(--blue);
  margin-bottom: 2px;
  display: block;
}

.baralho-popup {
  position: fixed;
  inset: 0;
  z-index: 9100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.baralho-popup-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10,22,40,0.7);
  backdrop-filter: blur(4px);
}

.baralho-popup-box {
  position: relative;
  background: white;
  border-radius: 16px;
  max-width: 560px;
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  padding: 32px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.25);
}

.baralho-popup-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: none;
  border: none;
  font-size: 1.4rem;
  color: rgba(21,34,56,0.4);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  line-height: 1;
}

.baralho-popup-close:hover { color: var(--blue-deep); }

.baralho-popup-header { margin-bottom: 20px; }

.baralho-popup-header h2 {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.02em;
  margin: 4px 0 6px;
}

.baralho-popup-iching {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.5);
  font-style: italic;
  margin: 0;
}

.baralho-popup-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.baralho-popup-img {
  width: 100%;
  border-radius: 8px;
  cursor: zoom-in;
  box-shadow: 0 2px 10px rgba(0,0,0,0.15);
}

.baralho-popup-tip {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.35);
  text-align: center;
  margin: 0;
}
/* ── End Baralho 64 Portas ────────────────────────────────────────── */

/* ── Baralho Landing ──────────────────────────────────────────────── */
.baralho-landing { gap: 24px; }

.baralho-landing-hero { text-align: center; }

.baralho-landing-hero h1 {
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
  color: var(--blue-deep);
  margin-bottom: 16px;
  max-width: none;
  white-space: normal;
}

.baralho-hero-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-top: 24px;
}

.baralho-hero-note {
  font-size: 0.8rem;
  color: rgba(21,34,56,0.45);
  margin: 0;
}

.baralho-card-anatomy {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 24px;
}

@media (max-width: 640px) {
  .baralho-card-anatomy { grid-template-columns: 1fr; }
}

.baralho-anatomy-side {
  border: 1px solid rgba(21,34,56,0.08);
  border-radius: 12px;
  overflow: hidden;
}

.baralho-anatomy-header {
  padding: 12px 16px;
  font-weight: 700;
  font-size: 0.82rem;
}

.baralho-anatomy-frente {
  background: rgba(26,107,181,0.08);
  color: var(--blue);
  border-bottom: 2px solid var(--blue);
}

.baralho-anatomy-verso {
  background: rgba(249,115,22,0.08);
  color: #f97316;
  border-bottom: 2px solid #f97316;
}

.baralho-anatomy-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.baralho-anatomy-list li {
  padding: 12px 16px;
  border-bottom: 1px solid rgba(21,34,56,0.06);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.baralho-anatomy-list li:last-child { border-bottom: none; }
.baralho-anatomy-list li[hidden] { display: none; }

.baralho-anatomy-list strong {
  font-size: 0.88rem;
  color: var(--blue-deep);
}

.baralho-anatomy-list span {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.55);
  line-height: 1.5;
}

.baralho-uses-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 20px;
}

@media (max-width: 640px) {
  .baralho-uses-grid { grid-template-columns: 1fr; }
}

.baralho-use-item {
  padding: 20px;
  background: rgba(26,107,181,0.04);
  border: 1px solid rgba(26,107,181,0.12);
  border-radius: 12px;
}

.baralho-use-icon {
  font-size: 1.4rem;
  display: block;
  margin-bottom: 10px;
}

.baralho-use-item h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 8px;
}

.baralho-use-item p {
  font-size: 0.85rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.65);
  margin: 0;
}

.baralho-digital-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 20px;
}

@media (max-width: 640px) {
  .baralho-digital-grid { grid-template-columns: 1fr; }
}

.baralho-digital-item {
  padding: 24px;
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 12px;
}

.baralho-digital-highlight {
  border: 2px solid var(--blue);
  background: rgba(26,107,181,0.03);
}

.baralho-digital-item h3 {
  font-size: 1rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 0 0 16px;
}

.baralho-digital-item ul {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.baralho-digital-item ul li {
  font-size: 0.85rem;
  color: rgba(21,34,56,0.7);
  line-height: 1.4;
}

.baralho-digital-price {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--blue);
  letter-spacing: -0.03em;
  margin: 0 0 12px;
}

.baralho-cta-final {
  text-align: center;
  background: linear-gradient(135deg,
    rgba(26,107,181,0.06) 0%,
    rgba(15,32,68,0.04) 100%);
  border: 2px solid rgba(26,107,181,0.2);
}

.baralho-cta-final h2 {
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
}

.baralho-cta-final > p {
  font-size: 0.9rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.65);
  max-width: 480px;
  margin: 0 auto 24px;
}

.baralho-cta-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.baralho-cta-price {
  font-size: 2rem !important;
  font-weight: 800 !important;
  color: var(--blue) !important;
  margin: 0 !important;
  letter-spacing: -0.03em;
}

.baralho-cta-note {
  font-size: 0.78rem !important;
  color: rgba(21,34,56,0.4) !important;
  margin: 0 !important;
}

.baralho-author-section p {
  font-size: 0.92rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.72);
}

.baralho-pain-section p {
  font-size: 0.92rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.72);
}
/* ── End Baralho Landing ──────────────────────────────────────────── */

/* ── Baralho Landing — imagens ────────────────────────────────────── */
.baralho-landing-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
  padding: 48px 0 32px;
}

.baralho-hero-content {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.baralho-hero-content h1 {
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
  color: var(--blue-deep);
  margin: 0;
  max-width: none;
  white-space: normal;
}

.baralho-hero-image {
  display: flex;
  align-items: center;
  justify-content: center;
}

.baralho-mockup-img {
  width: 100%;
  max-width: 480px;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.12);
}

@media (max-width: 720px) {
  .baralho-landing-hero {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .baralho-hero-image { order: -1; }
  .baralho-mockup-img { max-width: 280px; }
  .baralho-hero-cta { align-items: center; }
}

.baralho-anatomy-with-image {
  display: flex;
  flex-direction: column;
}

.baralho-anatomy-image {
  padding: 16px;
  background: rgba(21,34,56,0.02);
  border-bottom: 1px solid rgba(21,34,56,0.06);
  display: flex;
  align-items: center;
  justify-content: center;
}

.baralho-anatomy-img {
  width: 100%;
  max-width: 320px;
  height: auto;
  border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.1);
}
.baralho-anatomy-intro {
  padding: 14px 16px;
  background: rgba(21,34,56,0.02);
  border-bottom: 1px solid rgba(21,34,56,0.06);
}

.baralho-anatomy-intro p {
  font-size: 0.85rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.65);
  margin: 0;
  font-style: italic;
}

.baralho-lightbox-btn {
  position: relative;
  display: block;
  background: none;
  border: none;
  padding: 0;
  cursor: zoom-in;
  border-radius: 8px;
  overflow: hidden;
}
.baralho-lightbox-btn:hover .baralho-zoom-hint {
  opacity: 1;
}
.baralho-zoom-hint {
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(15,20,30,0.72);
  color: #fff;
  font-size: 0.75rem;
  padding: 4px 10px;
  border-radius: 20px;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
}
@media (hover: none) {
  .baralho-zoom-hint { opacity: 0.85; }
}
/* ── End Baralho Landing — imagens ───────────────────────────────── */

/* ── Amostra de cartas na landing ────────────────────────────────── */
.baralho-sample-section { text-align: center; }

.baralho-sample-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 680px;
  margin: 0 auto;
}

@media (max-width: 560px) {
  .baralho-sample-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    max-width: 380px;
  }
  .baralho-sample-grid .baralho-sample-wrapper:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    max-width: 46%;
    margin: 0 auto;
  }
}

.baralho-sample-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  perspective: 800px;
}

.baralho-sample-flip {
  position: relative;
  width: 100%;
  aspect-ratio: 2 / 3;
  cursor: pointer;
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
  transition: transform 0.55s cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 8px;
}

.baralho-sample-flip.is-flipped {
  transform: rotateY(180deg);
}

.baralho-sample-face {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
}

.baralho-sample-frente {
  border: 2px solid var(--blue, #1a6bb5);
}

.baralho-sample-verso {
  transform: rotateY(180deg);
  border: 2px solid #f97316;
}

.baralho-sample-face:hover {
  box-shadow: 0 6px 24px rgba(26,107,181,0.25);
}

.baralho-sample-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
  user-select: none;
}

.baralho-sample-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.baralho-sample-hex {
  font-size: 1.6rem;
  color: var(--blue);
  line-height: 1;
}

.baralho-sample-num {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--blue);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.baralho-sample-name {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--blue-deep);
}

/* Expandir verso */
.baralho-expand-wrapper {
  padding: 12px 16px;
  border-top: 1px solid rgba(21,34,56,0.06);
}

.baralho-expand-btn {
  background: none;
  border: none;
  color: var(--blue);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  padding: 8px 0;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.baralho-expand-btn:hover {
  color: var(--blue-deep);
}
/* ── End Amostra de cartas na landing ────────────────────────────── */

/* ── Combo pricing ────────────────────────────────────────────────── */
.baralho-digital-grid-3 {
  grid-template-columns: 1fr 1.15fr 1fr;
}

@media (max-width: 860px) {
  .baralho-digital-grid-3 {
    grid-template-columns: 1fr;
  }
}

.baralho-digital-combo {
  position: relative;
  border: 2px solid var(--blue);
  transform: scale(1.02);
}

.baralho-combo-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--blue);
  color: white;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 20px;
  white-space: nowrap;
}

.baralho-combo-pricing {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.baralho-combo-original {
  font-size: 0.95rem;
  color: rgba(21,34,56,0.35);
  text-decoration: line-through;
}

.baralho-combo-note {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.45);
  margin: 8px 0 0;
  text-align: center;
}

/* Checkout shipping */
.checkout-shipping-section {
  margin: 24px 0;
  padding: 20px;
  background: rgba(26,107,181,0.04);
  border: 1px solid rgba(26,107,181,0.15);
  border-radius: 12px;
}

.checkout-shipping-header h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 8px;
}

.checkout-shipping-note {
  font-size: 0.84rem;
  color: rgba(21,34,56,0.6);
  line-height: 1.6;
  margin: 0 0 20px;
}

.checkout-shipping-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 560px) {
  .checkout-shipping-fields { grid-template-columns: 1fr; }
}

.checkout-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.checkout-field-full { grid-column: 1 / -1; }
.checkout-field-zip  { grid-column: span 1; max-width: 160px; }

.checkout-field label {
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(21,34,56,0.6);
  letter-spacing: 0.02em;
}

.checkout-input {
  padding: 10px 12px;
  border: 1px solid rgba(21,34,56,0.15);
  border-radius: 8px;
  font-size: 0.9rem;
  color: var(--blue-deep);
  background: white;
  width: 100%;
  font-family: inherit;
  transition: border-color 0.15s;
}

.checkout-input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(26,107,181,0.1);
}

.checkout-guest-email-block {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 20px;
  padding: 16px;
  background: rgba(26,107,181,0.04);
  border: 1px solid rgba(26,107,181,0.12);
  border-radius: 10px;
}

.checkout-guest-email-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--blue-deep);
}

.checkout-guest-email-input {
  font-size: 1rem !important;
}

.checkout-guest-email-note {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.55);
  margin: 0;
}

/* ── Checkout legal consent ───────────────────────────────────── */
.checkout-legal-consent {
  margin: 16px 0;
  padding: 14px 16px;
  background: rgba(21,34,56,0.03);
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 8px;
}

.checkout-consent-label {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  cursor: pointer;
  font-size: 0.82rem;
  line-height: 1.55;
  color: rgba(21,34,56,0.7);
}

.checkout-consent-checkbox {
  margin-top: 2px;
  min-width: 16px;
  height: 16px;
  accent-color: var(--blue);
  cursor: pointer;
}

.checkout-consent-link {
  color: var(--blue);
  text-decoration: underline;
  font-size: 0.8rem;
}

.checkout-consent-policy-link {
  margin: 4px 0 0 26px;
  font-size: 0.78rem;
}

.checkout-consent--error {
  border-color: #dc2626;
  background: rgba(220,38,38,0.04);
}

.checkout-consent--error .checkout-consent-label {
  color: #dc2626;
}

/* ── Checkout policy dialog ───────────────────────────────────── */
.checkout-policy-dialog {
  max-width: 540px;
  width: 90vw;
  border: none;
  border-radius: 12px;
  padding: 0;
  box-shadow: 0 8px 40px rgba(0,0,0,0.15);
}

.checkout-policy-dialog::backdrop {
  background: rgba(0,0,0,0.5);
}

.checkout-policy-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid rgba(21,34,56,0.08);
}

.checkout-policy-header h2 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0;
}

.checkout-policy-close {
  background: none;
  border: none;
  font-size: 1.1rem;
  cursor: pointer;
  color: rgba(21,34,56,0.4);
  padding: 4px 8px;
  border-radius: 4px;
}

.checkout-policy-close:hover {
  background: rgba(21,34,56,0.06);
  color: var(--blue-deep);
}

.checkout-policy-body {
  padding: 20px 24px 24px;
  font-size: 0.88rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.75);
}

.checkout-policy-body p {
  margin: 0 0 12px;
}

.checkout-policy-body ul {
  margin: 8px 0 12px 16px;
}

.checkout-policy-body li {
  margin-bottom: 8px;
}
/* ── End Checkout legal consent ───────────────────────────────── */

.checkout-shipping-disclaimer {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.5);
  margin: 16px 0 0;
  padding: 10px 12px;
  background: rgba(249,115,22,0.06);
  border-left: 3px solid #f97316;
  border-radius: 0 6px 6px 0;
  line-height: 1.5;
}

/* Aviso combo na conta */
.combo-shipping-notice {
  padding: 20px;
  background: rgba(249,115,22,0.05);
  border: 1px solid rgba(249,115,22,0.2);
  border-left: 4px solid #f97316;
  border-radius: 10px;
  margin-bottom: 16px;
}

.combo-shipping-notice h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 4px 0 8px;
}

.combo-shipping-notice p {
  font-size: 0.88rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.7);
  margin: 0 0 6px;
}
/* ── End Combo pricing ────────────────────────────────────────────── */

/* ── Admin Painel ─────────────────────────────────────────────────── */
.admin-painel {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 24px 80px;
}

.admin-alert {
  padding: 14px 18px;
  border-radius: 8px;
  font-size: 0.85rem;
  line-height: 1.6;
  margin-bottom: 24px;
}

.admin-alert-warning {
  background: rgba(220, 150, 0, 0.1);
  border: 1px solid rgba(220, 150, 0, 0.35);
  color: #7a4f00;
}

.admin-alert-vars {
  font-family: monospace;
  font-size: 0.78rem;
  opacity: 0.85;
}

.admin-painel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}

.admin-painel-header h1 {
  font-size: 1.8rem;
  color: var(--blue-deep);
  margin: 4px 0 0;
}

.admin-painel-date {
  font-size: 0.82rem;
  color: rgba(21,34,56,0.45);
  margin: 4px 0 0;
}

.admin-painel-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.admin-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 32px;
}

.admin-kpi {
  background: white;
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 12px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.admin-kpi-revenue {
  border-color: rgba(26,107,181,0.3);
  background: rgba(26,107,181,0.04);
}

.admin-kpi-alert {
  border-color: rgba(220,38,38,0.3);
  background: rgba(220,38,38,0.04);
}

.admin-kpi-warning {
  border-color: rgba(234,179,8,0.4);
  background: rgba(234,179,8,0.04);
}

.admin-kpi-birthday {
  border-color: rgba(249,115,22,0.3);
  background: rgba(249,115,22,0.04);
}

.admin-kpi-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(21,34,56,0.45);
}

.admin-kpi-value {
  font-size: 2rem;
  font-weight: 800;
  color: var(--blue-deep);
  line-height: 1.1;
}

.admin-kpi-sub {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.5);
  line-height: 1.4;
}

.admin-section {
  background: white;
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 12px;
  margin-bottom: 24px;
  overflow: hidden;
}

.admin-section-alert {
  border-color: rgba(220,38,38,0.3);
}

.admin-section-birthday {
  border-color: rgba(249,115,22,0.3);
}

.admin-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(21,34,56,0.08);
  flex-wrap: wrap;
}

.admin-section-header h2 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0;
}

.admin-table-wrapper {
  overflow-x: auto;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.admin-table th {
  text-align: left;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(21,34,56,0.45);
  padding: 10px 16px;
  border-bottom: 1px solid rgba(21,34,56,0.08);
  white-space: nowrap;
}

.admin-table td {
  padding: 12px 16px;
  border-bottom: 1px solid rgba(21,34,56,0.05);
  vertical-align: middle;
}

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

.admin-table tbody tr:hover {
  background: rgba(21,34,56,0.02);
}

.admin-td-muted {
  color: rgba(21,34,56,0.5);
}

.admin-td-mono {
  font-family: monospace;
  font-size: 0.88rem;
  letter-spacing: 0.04em;
}

.admin-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 100px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.admin-badge-paid      { background: rgba(16,185,129,0.12); color: #065f46; }
.admin-badge-delivered { background: rgba(26,107,181,0.12); color: #1a6bb5; }
.admin-badge-pending   { background: rgba(234,179,8,0.15);  color: #854d0e; }
.admin-badge-email     { background: rgba(139,92,246,0.12); color: #5b21b6; }
.admin-badge-ok        { background: rgba(16,185,129,0.12); color: #065f46; }
.admin-badge-expired   { background: rgba(220,38,38,0.1);   color: #dc2626; }
.admin-badge-admin     { background: rgba(249,115,22,0.12); color: #9a3412; }

.admin-ship-form {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-tracking-input {
  border: 1px solid rgba(21,34,56,0.2);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 0.82rem;
  font-family: monospace;
  color: var(--blue-deep);
  background: white;
  width: 140px;
}

.admin-tracking-input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 2px rgba(26,107,181,0.1);
}

.admin-search-form {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-search-input {
  border: 1px solid rgba(21,34,56,0.2);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 0.88rem;
  color: var(--blue-deep);
  background: white;
  width: 280px;
  font-family: inherit;
}

.admin-search-input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(26,107,181,0.1);
}

.admin-coupon-form {
  padding: 0 20px 20px;
}

.admin-coupon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
}

.admin-coupon-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.admin-coupon-field label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(21,34,56,0.5);
}

.admin-coupon-field .admin-tracking-input {
  width: 100%;
  box-sizing: border-box;
  font-family: inherit;
}

.admin-link {
  color: var(--blue);
  text-decoration: none;
  font-weight: 500;
}

.admin-link:hover {
  text-decoration: underline;
}

.admin-empty {
  padding: 24px 20px;
  color: rgba(21,34,56,0.4);
  font-size: 0.88rem;
  margin: 0;
}
/* ── End Admin Painel ─────────────────────────────────────────────── */

/* ── Admin API costs ──────────────────────────────────────────────── */
.admin-section-api {
  border-color: rgba(139,92,246,0.2);
}

.admin-api-kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  border-bottom: 1px solid rgba(21,34,56,0.06);
}

@media (max-width: 900px) {
  .admin-api-kpi-grid { grid-template-columns: repeat(2, 1fr); }
}

.admin-api-kpi {
  padding: 16px 20px;
  border-right: 1px solid rgba(21,34,56,0.06);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.admin-api-kpi:last-child { border-right: none; }

.admin-api-kpi-total { background: rgba(139,92,246,0.03); }
.admin-api-kpi-margin { background: rgba(16,185,129,0.03); }

.admin-api-cost {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--blue-deep);
  letter-spacing: -0.02em;
  font-family: monospace;
}
/* ── End Admin API costs ──────────────────────────────────────────── */

/* ── Report image pages (template visual) ────────────────────────── */
.report-image-page {
  width: 210mm;
  height: 297mm;
  margin: 0 auto;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  page-break-before: always;
  break-before: page;
}

.report-image-page img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

@media screen {
  .report-image-page {
    margin: 24px auto;
    box-shadow: 0 2px 12px rgba(0,0,0,0.1);
  }
}

@media print {
  .report-image-page {
    width: 210mm;
    height: 297mm;
    margin: 0;
    page-break-before: always;
    break-before: page;
    page-break-after: always;
    break-after: page;
    page-break-inside: avoid;
    break-inside: avoid;
  }

  .report-image-page img {
    width: 210mm;
    height: 297mm;
    object-fit: cover;
  }
}
/* ── End Report image pages ───────────────────────────────────────── */

/* ── PHS Arrows no bodygraph ──────────────────────────────────────── */
.phs-arrow--design path {
  fill: #d44a43;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,0.5));
}

.phs-arrow--personality path {
  fill: #1a1a1a;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,0.5));
}

/* ── Botão Variáveis PHS no workspace ─────────────────────────────── */
.workspace-phs-btn {
  font-size: 0.75rem;
  padding: 6px 12px;
  opacity: 0.8;
  white-space: nowrap;
}

.workspace-phs-btn--owned {
  opacity: 1;
}
/* ── End PHS ──────────────────────────────────────────────────────── */

/* ── Sobre — origem da viagem ─────────────────────────────────── */
.sobre-origem {
  margin-top: 40px;
  padding-top: 32px;
  border-top: 1px solid rgba(21,34,56,0.08);
}

.sobre-origem .eyebrow {
  margin-bottom: 16px;
}

.sobre-origem p {
  font-size: 0.95rem;
  line-height: 1.8;
  color: rgba(21,34,56,0.75);
  margin-bottom: 18px;
}

.sobre-origem p:last-child {
  margin-bottom: 0;
}
/* ── End Sobre — origem da viagem ─────────────────────────────── */

/* ── First time guide extras ─────────────────────────────────── */
.button-ghost {
  background: none;
  border: none;
  color: rgba(21,34,56,0.45);
  font-size: 0.78rem;
  cursor: pointer;
  padding: 4px 0;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.button-ghost:hover {
  color: rgba(21,34,56,0.7);
}

.first-time-step-footnote {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.45);
  margin: 8px 0 0;
  line-height: 1.5;
}
/* ── End First time guide extras ─────────────────────────────── */

/* ── Analysis type hook ───────────────────────────────────────── */
.analysis-type-hook {
  background: rgba(26,107,181,0.05);
  border: 1px solid rgba(26,107,181,0.15);
  border-radius: 12px;
  padding: 20px 24px;
  margin: 24px 0;
}

.analysis-type-hook .eyebrow {
  margin-bottom: 8px;
}

.analysis-type-hook-text {
  font-size: 0.9rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.7);
  margin: 0;
  font-style: italic;
}
.analysis-type-hook--hero {
  margin-top: 0;
  border-color: rgba(26,107,181,0.25);
  background: rgba(26,107,181,0.07);
}
/* ── End Analysis type hook ───────────────────────────────────── */

/* ── First time recognition hook ─────────────────────────────── */
.first-time-recognition-hook {
  text-align: center;
  margin-bottom: 20px;
  padding: 14px 20px;
  background: rgba(26,107,181,0.06);
  border-radius: 10px;
  font-size: 0.9rem;
  font-style: italic;
  color: rgba(21,34,56,0.65);
  line-height: 1.6;
}

.first-time-recognition-hook p { margin: 0; }
/* ── End First time recognition hook ─────────────────────────── */

/* ── First time guide — micro-jornada pós-mapa ───────────────── */
.first-time-guide {
  background: linear-gradient(135deg,
    rgba(26,107,181,0.06) 0%,
    rgba(15,32,68,0.04) 100%);
  border: 1px solid rgba(26,107,181,0.15);
  border-radius: 16px;
  margin: 0 0 24px;
  overflow: hidden;
}

.first-time-guide-inner {
  padding: 32px 28px;
  max-width: 620px;
  margin: 0 auto;
}

.first-time-guide-header {
  text-align: center;
  margin-bottom: 28px;
}

.first-time-guide-header h2 {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--blue-deep);
  margin: 6px 0 10px;
  letter-spacing: -0.02em;
  line-height: 1.3;
}

.first-time-guide-sub {
  font-size: 0.9rem;
  color: rgba(21,34,56,0.6);
  line-height: 1.65;
  margin: 0;
}

.first-time-step {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.first-time-step[hidden] { display: none !important; }

.first-time-step--active {
  animation: stepFadeIn 0.3s ease;
}

@keyframes stepFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.first-time-step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  min-width: 36px;
  border-radius: 50%;
  background: var(--blue);
  color: white;
  font-size: 0.9rem;
  font-weight: 800;
  margin-top: 4px;
}

.first-time-step-content {
  flex: 1;
}

.first-time-step-content h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 10px;
}

.first-time-step-text {
  font-size: 0.88rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.7);
  margin: 0 0 20px;
}

.first-time-step-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.first-time-guide-progress {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 24px;
}

.first-time-progress-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(26,107,181,0.2);
  transition: background 0.2s;
}

.first-time-progress-dot--active {
  background: var(--blue);
}

@media (max-width: 600px) {
  .first-time-guide-inner { padding: 24px 20px; }
  .first-time-guide-header h2 { font-size: 1.2rem; }
  .first-time-step { flex-direction: column; gap: 10px; }
  .first-time-step-number { width: 28px; height: 28px; min-width: 28px; }
}
/* ── End First time guide ─────────────────────────────────────── */

/* ── Roberto voice ────────────────────────────────────────────── */
.roberto-voice {
  max-width: 720px;
  margin: 0 auto;
}

.roberto-voice-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}

.roberto-voice-avatar {
  width: 48px;
  height: 48px;
  min-width: 48px;
  border-radius: 50%;
  background: var(--blue-deep);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  display: flex;
  align-items: center;
  justify-content: center;
}

.roberto-voice-name {
  font-weight: 700;
  font-size: 0.95rem;
  margin: 0 0 2px;
}

.roberto-voice-role {
  font-size: 0.8rem;
  color: var(--muted);
  margin: 0;
}

.roberto-voice-quote {
  font-size: 1.15rem;
  line-height: 1.65;
  font-style: italic;
  color: var(--blue-deep);
  border-left: 3px solid var(--blue);
  padding-left: 18px;
  margin: 12px 0 0;
}

/* ── Session fragment ─────────────────────────────────────────── */
.session-fragment {
  max-width: 720px;
  margin: 0 auto;
}

.session-fragment-title {
  font-size: 1.3rem;
  margin: 0 0 24px;
}

.session-fragment-cases {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.session-fragment-case {
  background: var(--surface);
  border-radius: 10px;
  padding: 20px 22px;
  border-left: 3px solid var(--blue);
}

.session-fragment-case--second {
  border-left-color: var(--blue-deep);
}

.session-fragment-type {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--blue);
  margin: 0 0 10px;
}

.session-fragment-case--second .session-fragment-type {
  color: var(--blue-deep);
}

.session-fragment-text {
  font-size: 1rem;
  line-height: 1.65;
  font-style: italic;
  margin: 0 0 10px;
}

.session-fragment-note {
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0;
}

@media (max-width: 600px) {
  .roberto-voice-quote { font-size: 1rem; }
  .session-fragment-case { padding: 16px; }
}

/* Detail panel — type consequence + authority instruction + micro-CTA */
.tipo-page-inline-link {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--blue);
  text-decoration: none;
  margin: 4px 0 2px;
}
.tipo-page-inline-link:hover { text-decoration: underline; }

.detail-type-consequence {
  font-size: 0.84rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.65);
  margin: 6px 0 0;
  font-style: italic;
}

.detail-authority-instruction {
  font-size: 0.82rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.6);
  margin: 6px 0 0;
  padding: 8px 10px;
  background: rgba(26,107,181,0.05);
  border-radius: 6px;
  border-left: 2px solid rgba(26,107,181,0.25);
}

.detail-next-step {
  margin: 14px 0 0;
  padding: 12px 14px;
  background: rgba(21,34,56,0.03);
  border-radius: 8px;
  border: 1px solid rgba(21,34,56,0.08);
}

.detail-next-step-text {
  font-size: 0.8rem;
  color: rgba(21,34,56,0.55);
  margin: 0 0 6px;
  line-height: 1.5;
}

.detail-next-step-link {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--blue);
  text-decoration: none;
}

.detail-next-step-link:hover { text-decoration: underline; }

/* Block 4 — guest nudge banner (30s delay, sessionStorage dismiss) */
.guest-nudge-banner {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 201;
  background: #fff;
  border-top: 3px solid var(--orange);
  box-shadow: 0 -4px 20px rgba(21,34,56,0.12);
  padding: 14px 20px;
  animation: nudgeSlideUp 0.3s ease;
}

.guest-nudge-content {
  max-width: 640px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.guest-nudge-text {
  flex: 1;
  min-width: 200px;
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(21,34,56,0.75);
  margin: 0;
}

.guest-nudge-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.guest-nudge-cta {
  font-size: 0.85rem;
  font-weight: 600;
  color: #fff;
  background: var(--orange);
  border: none;
  border-radius: 6px;
  padding: 8px 16px;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
}

.guest-nudge-cta:hover { opacity: 0.9; }

.guest-nudge-dismiss {
  font-size: 0.78rem;
  color: rgba(21,34,56,0.4);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  white-space: nowrap;
}

.guest-nudge-dismiss:hover { color: rgba(21,34,56,0.7); }

@keyframes nudgeSlideUp {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
/* ── End Roberto voice / Session fragment ─────────────────────── */

/* orders#show — análise gravada */
.recorded-pending-meta {
  font-size: 0.85rem;
  line-height: 1.8;
}
.recorded-pending-meta p { margin: 0 0 4px; }

.recorded-qa-upsell {
  margin-top: 0;
  text-align: center;
}
.recorded-qa-text {
  font-size: 0.88rem;
  color: rgba(21,34,56,0.6);
  margin: 0 0 14px;
  line-height: 1.6;
}

/* landings — opção gravada */
.recorded-option-block { margin: 24px 0 0; }

.recorded-option-divider {
  text-align: center;
  position: relative;
  margin: 20px 0;
}
.recorded-option-divider::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 1px;
  background: rgba(21,34,56,0.1);
}
.recorded-option-divider span {
  background: #fff;
  position: relative;
  padding: 0 12px;
  font-size: 0.8rem;
  color: rgba(21,34,56,0.4);
}
.recorded-option-card {
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 12px;
  padding: 20px 24px;
  background: rgba(21,34,56,0.02);
}
.recorded-option-eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--blue);
  margin: 0 0 6px;
}
.recorded-option-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 10px;
}
.recorded-option-desc {
  font-size: 0.85rem;
  line-height: 1.6;
  color: rgba(21,34,56,0.65);
  margin: 0 0 12px;
}
.recorded-option-bullets {
  font-size: 0.82rem;
  line-height: 1.8;
  color: rgba(21,34,56,0.6);
  margin: 0 0 16px;
}
.recorded-option-ctas {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.recorded-option-btn { width: 100%; text-align: center; }
.recorded-option-live-link {
  font-size: 0.8rem;
  text-align: center;
  color: rgba(21,34,56,0.45);
  text-decoration: underline;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}
@media (max-width: 600px) {
  .recorded-option-card { padding: 16px; }
}

/* ============================================================
   WORKSHOP VIVER SEU DESENHO — Landing de conversão
   ============================================================ */

/* ── Hero com headline de dor ────────────────────────────── */
.workshop-hero-pain {
  font-size: clamp(1.6rem, 3.8vw, 2.8rem);
  line-height: 1.2;
  color: #fff;
  margin: 12px 0 20px;
  font-weight: 800;
}

/* ── Seção 2 — Problema ──────────────────────────────────── */
.workshop-problem {
  background: #fff;
  border-radius: 24px;
}

.workshop-problem-blocks {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
}

.workshop-problem-block {
  background: #f7f8fa;
  border-left: 4px solid #0097b2;
  border-radius: 0 12px 12px 0;
  padding: 24px 20px;
}

.workshop-problem-block p {
  font-size: 0.97rem;
  line-height: 1.7;
  color: rgba(21, 34, 56, 0.8);
  margin: 0;
}

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

/* ── Seção 3 — Solução ───────────────────────────────────── */
.workshop-solution {
  background: linear-gradient(135deg, #0b2147 0%, #0097b2 100%);
  border-radius: 24px;
  color: #fff;
}

.workshop-solution .course-section-head h2 {
  color: #fff;
}

.workshop-solution .eyebrow {
  color: rgba(255, 255, 255, 0.65);
}

.workshop-solution-copy {
  max-width: 720px;
  margin: 0 auto;
}

.workshop-solution-copy p {
  font-size: 1.05rem;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.88);
  margin: 0 0 16px;
}

.workshop-solution-copy p:last-child { margin-bottom: 0; }

/* ── Urgência do kit físico ──────────────────────────────── */
.workshop-materials-urgency {
  background: #fff8e6;
  border: 1px solid #f0c040;
  border-radius: 12px;
  padding: 18px 24px;
  margin: 24px 0 8px;
}

.workshop-materials-urgency p {
  font-size: 0.92rem;
  line-height: 1.6;
  color: #7a5c00;
  margin: 0;
  font-weight: 500;
}

/* ── Tabela de comparação ────────────────────────────────── */
.workshop-comparison-table-wrap {
  overflow-x: auto;
  margin-top: 32px;
  border-radius: 12px;
}

.workshop-comparison-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

.workshop-comparison-table thead th {
  padding: 16px 20px;
  text-align: left;
  font-weight: 700;
  font-size: 0.9rem;
  color: rgba(21, 34, 56, 0.6);
  background: #f7f8fa;
  border-bottom: 2px solid rgba(21, 34, 56, 0.08);
}

.workshop-comparison-table tbody td {
  padding: 14px 20px;
  border-bottom: 1px solid rgba(21, 34, 56, 0.06);
  color: rgba(21, 34, 56, 0.75);
  vertical-align: middle;
}

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

.workshop-comparison-table tbody td:first-child {
  font-weight: 600;
  color: rgba(21, 34, 56, 0.55);
  white-space: nowrap;
}

.workshop-col-highlight {
  background: rgba(0, 151, 178, 0.06);
  color: #0b2147 !important;
}

.workshop-col-highlight strong {
  color: #0b2147;
}

.workshop-comparison-note {
  margin-top: 20px;
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(21, 34, 56, 0.7);
  text-align: center;
  font-style: italic;
}

@media (max-width: 600px) {
  .workshop-comparison-table thead th,
  .workshop-comparison-table tbody td { padding: 10px 12px; font-size: 0.85rem; }
}

/* ── Depoimentos ─────────────────────────────────────────── */
.workshop-testimonials {
  background: #f7f8fa;
  border-radius: 24px;
}

.workshop-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 32px;
}

@media (max-width: 900px) {
  .workshop-testimonials-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
  .workshop-testimonials-grid { grid-template-columns: 1fr; }
}

.workshop-testimonial-card {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.07);
  display: flex;
  flex-direction: column;
}

.workshop-testimonial-media {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16/9;
  background: #0b2147;
  border: none;
  cursor: pointer;
  padding: 0;
  overflow: hidden;
}

.workshop-testimonial-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity 0.2s;
}

.workshop-testimonial-media:hover img { opacity: 0.85; }

.workshop-testimonial-play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.2rem;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
  pointer-events: none;
}

.workshop-testimonial-copy {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 16px 0;
}

.workshop-testimonial-initial {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #0097b2;
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.workshop-testimonial-copy strong {
  font-size: 0.9rem;
  color: #0b2147;
  display: block;
}

.workshop-testimonial-city {
  font-size: 0.78rem;
  color: rgba(21, 34, 56, 0.5);
  margin: 0;
}

.workshop-testimonial-quote {
  font-size: 0.85rem;
  line-height: 1.6;
  color: rgba(21, 34, 56, 0.7);
  padding: 12px 16px 16px;
  margin: 0;
  font-style: italic;
  flex: 1;
}

.workshop-testimonials-reach {
  margin-top: 32px;
  text-align: center;
  font-size: 0.95rem;
  color: rgba(21, 34, 56, 0.6);
  line-height: 1.6;
}

/* ── Instructor intro ────────────────────────────────────── */
.workshop-instructor-intro {
  font-size: 0.97rem;
  line-height: 1.7;
  color: rgba(21, 34, 56, 0.75);
  border-left: 3px solid #0097b2;
  padding-left: 16px;
  margin-bottom: 16px;
}

/* ── Seção de investimento ───────────────────────────────── */
.workshop-investment-section {
  background: #fff;
  border-radius: 24px;
}

.workshop-investment-card {
  max-width: 600px;
  margin: 0 auto;
  background: #f7f8fa;
  border: 2px solid rgba(0, 151, 178, 0.2);
  border-radius: 20px;
  padding: 40px 36px;
  text-align: center;
}

.workshop-investment-price-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin-bottom: 28px;
}

.workshop-investment-from {
  font-size: 0.9rem;
  color: rgba(21, 34, 56, 0.45);
}

.workshop-investment-from s {
  text-decoration: line-through;
}

.workshop-investment-price {
  font-size: clamp(2.4rem, 5vw, 3.2rem);
  font-weight: 800;
  color: #0b2147;
  line-height: 1;
}

.workshop-investment-installment {
  font-size: 0.88rem;
  color: rgba(21, 34, 56, 0.55);
  margin-top: 4px;
}

.workshop-investment-pix {
  font-size: 0.9rem;
  font-weight: 600;
  color: #059669;
}

.workshop-investment-includes {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.workshop-investment-includes li {
  font-size: 0.95rem;
  color: rgba(21, 34, 56, 0.8);
  line-height: 1.4;
  padding-left: 4px;
}

.workshop-invest-note {
  font-size: 0.82rem;
  color: rgba(21, 34, 56, 0.45);
}

.workshop-invest-cta {
  width: 100%;
  font-size: 1.05rem;
  padding: 16px 24px;
  display: block;
}

.workshop-invest-delivery-note {
  font-size: 0.82rem;
  color: rgba(21, 34, 56, 0.5);
  margin: 12px 0 0;
  line-height: 1.5;
}

.workshop-invest-whatsapp {
  display: block;
  margin-top: 16px;
  font-size: 0.88rem;
  color: rgba(21, 34, 56, 0.5);
  text-decoration: underline;
}

.workshop-invest-whatsapp:hover {
  color: rgba(21, 34, 56, 0.75);
}

@media (max-width: 600px) {
  .workshop-investment-card { padding: 28px 20px; }
}

/* ── FAQ ─────────────────────────────────────────────────── */
.workshop-faq {
  background: #f7f8fa;
  border-radius: 24px;
}

.workshop-faq-list {
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid rgba(21, 34, 56, 0.1);
  border-radius: 16px;
  overflow: hidden;
}

.workshop-faq-item {
  border-bottom: 1px solid rgba(21, 34, 56, 0.08);
  background: #fff;
}

.workshop-faq-item:last-child { border-bottom: none; }

.workshop-faq-item summary {
  padding: 18px 24px;
  font-size: 0.97rem;
  font-weight: 600;
  color: #0b2147;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  user-select: none;
}

.workshop-faq-item summary::-webkit-details-marker { display: none; }

.workshop-faq-item summary::after {
  content: '+';
  font-size: 1.3rem;
  font-weight: 300;
  color: #0097b2;
  flex-shrink: 0;
  margin-left: 12px;
}

.workshop-faq-item[open] summary::after { content: '−'; }

.workshop-faq-item p {
  padding: 0 24px 18px;
  font-size: 0.92rem;
  line-height: 1.7;
  color: rgba(21, 34, 56, 0.7);
  margin: 0;
}

@media (max-width: 600px) {
  .workshop-faq-item summary { padding: 14px 16px; }
  .workshop-faq-item p { padding: 0 16px 14px; }
}


/* ── Gate Panel: conteúdo premium ─────────────────────────────────── */
.gate-premium-content {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid rgba(21,34,56,0.10);
}

.gate-premium-content h2 {
  font-size: 1rem;
  font-weight: 700;
  color: #152238;
  margin: 0 0 8px;
}

.gate-premium-content p.lead {
  font-size: 0.9rem;
  line-height: 1.7;
  color: rgba(21,34,56,0.8);
  margin: 0 0 10px;
  font-style: italic;
}

.gate-premium-content p.meta {
  font-size: 0.72rem;
  color: rgba(21,34,56,0.4);
  margin: 0 0 16px;
  line-height: 1.5;
}

.gate-premium-content .paragrafos p {
  font-size: 0.9rem;
  line-height: 1.75;
  color: rgba(21,34,56,0.75);
  margin: 0 0 12px;
}

.gate-premium-content hr {
  border: none;
  border-top: 1px solid rgba(21,34,56,0.08);
  margin: 20px 0;
}

.gate-premium-content h3 {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #163d73;
  margin: 16px 0 8px;
}

.gate-premium-content ul {
  margin: 0 0 16px;
  padding-left: 1.2em;
}

.gate-premium-content li {
  font-size: 0.87rem;
  line-height: 1.65;
  color: rgba(21,34,56,0.75);
  margin-bottom: 6px;
}

/* ── Gate Panel: CTA de upgrade ───────────────────────────────────── */
.gate-upgrade-cta {
  margin-top: 24px;
  padding: 20px;
  background: #fef6f0;
  border: 1.5px solid #163d73;
  border-radius: 10px;
}

.gate-upgrade-teaser {
  font-size: 0.9rem;
  line-height: 1.6;
  color: #152238;
  margin: 0 0 14px;
}

.gate-upgrade-button {
  display: block;
  width: 100%;
  padding: 11px 16px;
  background: #ff7a00;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  text-align: center;
  border-radius: 7px;
  text-decoration: none;
  transition: background 0.18s;
}

.gate-upgrade-button:hover {
  background: #e06b00;
  color: #fff;
}

/* ── Banner pós-geração de mapa (mr-banner) ──────────────────── */

.mr-banner {
  position: relative;
  background: linear-gradient(160deg, #0f2044 0%, #1a3a6e 60%, #0f2044 100%);
  padding: 56px 24px 48px;
  text-align: center;
  border-radius: 0 0 20px 20px;
  margin-bottom: 24px;
}

.mr-banner-dismiss {
  position: absolute;
  top: 16px;
  right: 20px;
  background: transparent;
  border: none;
  color: rgba(255, 255, 255, 0.45);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  padding: 4px 8px;
  transition: color 0.15s;
}

.mr-banner-dismiss:hover {
  color: rgba(255, 255, 255, 0.9);
}

.mr-banner-content {
  max-width: 560px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.mr-ready-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 100px;
  padding: 8px 18px;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.75);
}

.mr-ready-icon {
  width: 18px;
  height: 18px;
  color: #4ade80;
  flex-shrink: 0;
}

.mr-eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.45);
  margin: 0;
}

.mr-headline {
  font-family: "Fraunces", Georgia, serif;
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  line-height: 1.15;
  color: #fff;
  margin: 0;
}

.mr-type-name {
  color: #f5c842;
  display: block;
}

.mr-traits {
  font-size: 0.92rem;
  color: rgba(255, 255, 255, 0.6);
  margin: 0;
}

.mr-traits strong {
  color: rgba(255, 255, 255, 0.9);
  font-weight: 600;
}

.mr-traits-sep {
  margin: 0 8px;
  color: rgba(255, 255, 255, 0.3);
}

.mr-offer-block {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  padding: 28px 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
}

.mr-bridge {
  font-size: 1rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.82);
  margin: 0;
}

.mr-cta-primary {
  font-size: 1rem;
  padding: 14px 28px;
  width: 100%;
  justify-content: center;
}

.mr-dismiss-secondary {
  background: transparent;
  border: none;
  color: #ff7a00;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  padding: 4px 8px;
  transition: color 0.15s;
  font-family: inherit;
}

.mr-dismiss-secondary:hover {
  color: #e06b00;
}

.mr-ferida {
  font-size: 1.02rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.9);
  margin: 0;
  text-align: left;
}

.mr-vergonha {
  font-size: 0.93rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.62);
  margin: 0;
  text-align: left;
}

@media (max-width: 480px) {
  .mr-banner { padding: 40px 20px; }
  .mr-offer-block { padding: 22px 20px; }
}

/* ── Checkout Air Canada — sumário sticky à direita ─────────────── */
.checkout-summary-panel {
  position: sticky;
  top: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px;
}

.checkout-summary-heading {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(26,26,26,0.45);
  margin: 0 0 4px;
}

.checkout-summary-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.checkout-summary-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.88rem;
  line-height: 1.4;
}

.checkout-summary-item--main .checkout-summary-item-name {
  font-weight: 600;
  color: var(--blue-deep);
}

.checkout-summary-item--addon {
  color: rgba(26,26,26,0.7);
}

.checkout-summary-item-price {
  white-space: nowrap;
  font-weight: 600;
  flex-shrink: 0;
}

.checkout-summary-divider {
  height: 1px;
  background: rgba(26,26,26,0.1);
  margin: 4px 0;
}

.checkout-summary-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.checkout-summary-total-label {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--blue-deep);
}

.checkout-summary-total {
  font-size: 1.35rem;
  font-weight: 800;
  font-family: 'Fraunces', Georgia, serif;
  color: var(--blue-deep);
}

.checkout-summary-seals {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.8rem;
  color: rgba(26,26,26,0.55);
  margin-top: 4px;
}

/* ── Vitrine de adicionais ───────────────────────────────────────── */
/* ── Container externo da seção de adicionais ────────────────── */
.checkout-vitrine-wrapper {
  background: #fdf8f4;
  border: 1px solid rgba(180,110,70,0.15);
  border-radius: 14px;
  box-shadow: 0 2px 14px rgba(160,90,50,0.07);
  padding: 22px 20px 20px;
  margin: 20px 0;
}

/* ── Badge de entrada ─────────────────────────────────────────── */
.checkout-vitrine-badge {
  display: inline-block;
  background: #fef3c7;
  color: #92400e;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  border-radius: 20px;
  padding: 5px 14px;
  margin: 0 0 16px;
  line-height: 1.4;
}

.checkout-vitrine {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.checkout-vitrine-heading {
  font-size: 0.95rem;
  color: var(--blue-deep);
  margin: 0;
}

.checkout-vitrine-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.checkout-vitrine-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border: 1px solid rgba(26,26,26,0.1);
  border-radius: 8px;
  background: #fafafa;
  transition: border-color 0.15s, background 0.15s;
}

.checkout-vitrine-item:has([data-vitrine-qty]:not([value="0"])) {
  border-color: var(--blue-mid, #1a6bb5);
  background: rgba(26,107,181,0.04);
}

.checkout-vitrine-item-info {
  flex: 1;
  min-width: 0;
}

.checkout-vitrine-item-name {
  display: block;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--blue-deep);
  line-height: 1.3;
}

.checkout-vitrine-item-prices {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 2px;
}

.checkout-vitrine-full-price {
  font-size: 0.78rem;
  color: rgba(26,26,26,0.4);
}

.checkout-vitrine-half-price {
  font-size: 0.9rem;
  font-weight: 700;
  color: #c0392b;
}

.checkout-vitrine-qty-controls {
  display: flex;
  align-items: center;
  gap: 0;
  border: 1px solid rgba(26,26,26,0.18);
  border-radius: 6px;
  overflow: hidden;
  flex-shrink: 0;
}

.checkout-vitrine-btn {
  width: 30px;
  height: 30px;
  border: none;
  background: #fff;
  cursor: pointer;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--blue-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.1s;
}

.checkout-vitrine-btn:hover { background: rgba(26,107,181,0.08); }
.checkout-vitrine-btn:active { background: rgba(26,107,181,0.15); }

.checkout-vitrine-qty {
  width: 34px;
  height: 30px;
  border: none;
  border-left: 1px solid rgba(26,26,26,0.12);
  border-right: 1px solid rgba(26,26,26,0.12);
  text-align: center;
  font-size: 0.88rem;
  font-weight: 600;
  background: #fff;
  -moz-appearance: textfield;
}

.checkout-vitrine-qty::-webkit-inner-spin-button,
.checkout-vitrine-qty::-webkit-outer-spin-button { -webkit-appearance: none; }

/* ── Gancho emocional ────────────────────────────────────────────── */
.checkout-gancho {
  padding: 0;
}

.checkout-gancho-short {
  font-size: 1.1rem;
  line-height: 1.5;
  color: #1f2b3f;
  margin: 0;
  font-style: normal;
  font-weight: 500;
}

.checkout-gancho-details {
  margin-top: 6px;
}

.checkout-gancho-toggle {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--blue-mid, #1a6bb5);
  cursor: pointer;
  list-style: none;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.checkout-gancho-toggle::-webkit-details-marker { display: none; }

.checkout-gancho-full {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.checkout-gancho-full p {
  font-size: 0.88rem;
  line-height: 1.6;
  color: rgba(26,26,26,0.75);
  margin: 0;
}

/* ── "Ver todos" toggle ──────────────────────────────────────────── */
.checkout-vitrine-more {
  margin-top: 10px;
}

.checkout-vitrine-more-toggle {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--blue-mid, #1a6bb5);
  cursor: pointer;
  list-style: none;
  text-decoration: underline;
  text-underline-offset: 2px;
  padding: 4px 0;
  display: inline-block;
}

.checkout-vitrine-more-toggle::-webkit-details-marker { display: none; }

.checkout-vitrine-grid--rest {
  margin-top: 10px;
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .checkout-summary-panel {
    position: static;
    order: -1;
  }
  .checkout-vitrine-item {
    flex-wrap: wrap;
  }
  .checkout-vitrine-wrapper {
    padding: 18px 16px 16px;
    margin: 16px 0;
  }
  .checkout-gancho-short {
    font-size: 1rem;
  }
}

/* ── Página de resgate de presente ───────────────────────────── */
.gift-page { max-width: 640px; margin: 0 auto; }
.gift-card { padding: 2.5rem 2rem; }
.gift-card h1 { font-size: 1.6rem; line-height: 1.3; margin: 0.5rem 0 1.25rem; }
.gift-card h1 em { font-style: italic; color: #1c529a; }

.gift-bilhete {
  background: #fdf8f4;
  border-left: 3px solid #f59e0b;
  border-radius: 0 8px 8px 0;
  padding: 16px 18px;
  margin: 0 0 1.25rem;
}
.gift-bilhete-text {
  font-size: 1rem;
  line-height: 1.7;
  color: #1f2b3f;
  font-style: italic;
  margin: 0 0 0.4rem;
}
.gift-bilhete-autor {
  font-size: 0.85rem;
  color: rgba(31,43,63,0.55);
  font-weight: 600;
  margin: 0;
}

.gift-descricao {
  font-size: 0.95rem;
  line-height: 1.65;
  color: rgba(31,43,63,0.72);
  margin: 0 0 1.5rem;
}

.gift-alert {
  background: #fef3c7;
  color: #92400e;
  border-radius: 8px;
  padding: 12px 16px;
  font-size: 0.88rem;
  margin-bottom: 1.25rem;
}

.gift-action-box {
  background: #f4f7fb;
  border-radius: 12px;
  padding: 1.5rem;
  margin-bottom: 1.25rem;
}
.gift-action-box p {
  font-size: 0.95rem;
  line-height: 1.6;
  color: #1f2b3f;
  margin: 0 0 1rem;
}
.gift-auth-actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.gift-cta { width: 100%; justify-content: center; }
.gift-chart-form { display: flex; flex-direction: column; gap: 0; }
.gift-prazo {
  font-size: 0.82rem;
  color: rgba(31,43,63,0.45);
  text-align: center;
  margin-top: 1rem;
}

/* ── Admin Inbox ──────────────────────────────────────────────────────── */

.inbox-shell { padding-bottom: 0; }

/* Abas */
.inbox-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 2px solid rgba(21,34,56,0.1);
  margin-bottom: 0;
  flex-wrap: wrap;
}
.inbox-tab {
  padding: 10px 18px;
  font-size: 0.83rem;
  font-weight: 600;
  color: rgba(21,34,56,0.55);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.inbox-tab:hover { color: var(--blue-deep); }
.inbox-tab--active { color: var(--blue); border-bottom-color: var(--blue); }

/* Corpo duas colunas */
.inbox-body {
  display: flex;
  min-height: calc(100vh - 200px);
  border: 1px solid rgba(21,34,56,0.1);
  border-radius: 0 0 12px 12px;
  background: #fff;
  overflow: hidden;
}

/* Lista (esquerda) */
.inbox-list {
  width: 300px;
  flex-shrink: 0;
  border-right: 1px solid rgba(21,34,56,0.08);
  overflow-y: auto;
  background: #fafbfc;
}
.inbox-empty {
  padding: 24px 16px;
  font-size: 0.85rem;
  color: rgba(21,34,56,0.45);
  text-align: center;
}
.inbox-item {
  display: block;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(21,34,56,0.06);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.1s;
}
.inbox-item:hover { background: rgba(28,82,154,0.04); }
.inbox-item--selected { background: rgba(28,82,154,0.07); border-left: 3px solid var(--blue); }
.inbox-item-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
}
.inbox-item-time {
  font-size: 0.7rem;
  color: rgba(21,34,56,0.4);
  white-space: nowrap;
}
.inbox-item-title {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--blue-deep);
  line-height: 1.3;
}
.inbox-item-sub {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.5);
  margin-top: 2px;
}
.inbox-item-error {
  font-family: monospace;
  font-size: 0.72rem;
  color: #dc2626;
}

/* Painel de detalhe (direita) */
.inbox-detail {
  flex: 1;
  padding: 28px 32px;
  overflow-y: auto;
  display: block;
}
.inbox-detail-empty {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(21,34,56,0.35);
  font-size: 0.88rem;
}
.inbox-detail-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.inbox-detail-time {
  font-size: 0.75rem;
  color: rgba(21,34,56,0.45);
}
.inbox-detail-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin: 0 0 20px;
  line-height: 1.3;
}

/* Bloco de DH */
.inbox-dh-card {
  background: linear-gradient(135deg, #f0f4f8 0%, #e8f0f8 100%);
  border: 1px solid rgba(28,82,154,0.12);
  border-radius: 12px;
  padding: 16px 20px;
  margin-bottom: 16px;
}
.inbox-dh-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--blue-deep);
  margin-bottom: 4px;
}
.inbox-dh-type {
  font-size: 0.88rem;
  color: var(--blue);
  font-weight: 600;
  margin-bottom: 6px;
}
.inbox-dh-cross {
  font-size: 0.8rem;
  color: rgba(21,34,56,0.6);
  display: flex;
  gap: 8px;
  align-items: center;
}

.inbox-analysis-meta {
  display: flex;
  gap: 16px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.inbox-meta-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.inbox-meta-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(21,34,56,0.45);
}
.inbox-meta-value {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--blue-deep);
}
.inbox-meta-alert { color: #92400e; }

.inbox-no-chart {
  background: #fffbeb;
  border: 1px solid #f59e0b;
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 16px;
  font-size: 0.85rem;
  color: #92400e;
}
.inbox-no-chart p { margin: 0 0 4px; }
.inbox-no-chart p:last-child { margin: 0; }

/* Definição list */
.inbox-dl {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 6px 12px;
  font-size: 0.85rem;
  margin-bottom: 16px;
}
.inbox-dl dt {
  font-weight: 600;
  color: rgba(21,34,56,0.5);
  align-self: start;
}
.inbox-dl dd {
  color: var(--blue-deep);
  word-break: break-word;
}
.inbox-message {
  font-style: italic;
  background: rgba(28,82,154,0.04);
  border-left: 3px solid rgba(28,82,154,0.2);
  padding: 6px 10px;
  border-radius: 0 6px 6px 0;
}

/* Ações */
.inbox-detail-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.inbox-detail-form { border-top: 1px solid rgba(21,34,56,0.08); padding-top: 20px; }

/* Bloco de erro */
.inbox-error-body {
  font-size: 0.78rem;
  font-family: monospace;
  background: #fef2f2;
  border: 1px solid rgba(220,38,38,0.15);
  border-radius: 8px;
  padding: 12px 14px;
  white-space: pre-wrap;
  word-break: break-all;
  color: #991b1b;
  margin-bottom: 16px;
  max-height: 200px;
  overflow-y: auto;
}

/* Responsivo: mobile */
@media (max-width: 640px) {
  .inbox-body { flex-direction: column; min-height: unset; }
  .inbox-list { width: 100%; border-right: none; border-bottom: 1px solid rgba(21,34,56,0.08); max-height: 300px; }
  .inbox-detail { padding: 16px; }
  .inbox-dl { grid-template-columns: 90px 1fr; }
}
