:root {
  --bg-1: #ffcfdf;
  --bg-2: #ffd4ac;
  --ink: #2a1a3d;
  --muted: #634b7a;
  --card: #fff8fd;
  --line: #f0d3e9;
  --accent: #f09433;
  --accent-2: #bc1888;
  --accent-3: #405de6;
  --white: #ffffff;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Manrope", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(125% 120% at 10% 0%, rgba(188, 24, 136, 0.25) 0%, transparent 55%),
    radial-gradient(100% 100% at 100% 100%, rgba(240, 148, 51, 0.25) 0%, transparent 60%),
    linear-gradient(165deg, var(--bg-1), var(--bg-2));
}

.page {
  display: grid;
  place-items: center;
  padding: 1.25rem 0.9rem;
}

.phone-wrap {
  width: 100%;
  max-width: 430px;
}

.phone {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 248, 253, 0.96));
  border: 1px solid var(--line);
  border-radius: 1.8rem;
  box-shadow: 0 16px 44px rgba(112, 39, 117, 0.22);
  padding: 1rem;
  animation: rise 550ms ease-out;
}

.ig-head {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.85rem;
}

.ig-dot {
  width: 0.9rem;
  height: 0.9rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), #fd1d1d 50%, var(--accent-2));
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.8);
}

.ig-head p {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 0.86rem;
  letter-spacing: 0.02em;
  color: #8a2d75;
}

.badge {
  width: fit-content;
  margin: 0 auto 0.9rem;
  background: linear-gradient(90deg, var(--accent), #fd1d1d 48%, var(--accent-2));
  color: var(--white);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding: 0.38rem 0.62rem;
  border-radius: 999px;
}

h1 {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.5rem;
  line-height: 1.2;
}

h1 span {
  display: block;
  margin-top: 0.25rem;
  color: #7e2c76;
  font-size: 1.05rem;
}

.lead {
  margin: 0.9rem 0 1rem;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.45;
}

.insights {
  display: grid;
  gap: 0.62rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.insights li {
  border: 1px solid var(--line);
  border-radius: 0.95rem;
  padding: 0.74rem 0.72rem;
  background: var(--card);
}

.insights h2 {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.3;
}

.insights p {
  margin: 0.34rem 0 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.35;
}

.reveal-box {
  margin-top: 1rem;
  display: grid;
  gap: 0.5rem;
}

.reveal-box label {
  font-size: 0.86rem;
  font-weight: 700;
}

.reveal-box input {
  width: 100%;
  border: 1px solid #e8bfde;
  background: #ffffff;
  border-radius: 0.85rem;
  padding: 0.7rem 0.85rem;
  font-size: 0.95rem;
  outline: none;
}

.reveal-box input:focus {
  border-color: var(--accent-2);
  box-shadow: 0 0 0 3px rgba(188, 24, 136, 0.15);
}

.reveal-box button {
  border: 0;
  border-radius: 0.85rem;
  padding: 0.78rem 0.95rem;
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--white);
  background: linear-gradient(90deg, var(--accent-3), var(--accent-2) 45%, var(--accent));
}

.disclaimer {
  margin-top: 1rem;
  color: #5f6d86;
  font-size: 0.74rem;
  line-height: 1.4;
}

.links {
  margin-top: 0.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem 0.6rem;
}

.links a {
  text-decoration: none;
  color: #8e2f7b;
  font-size: 0.78rem;
}

.hidden {
  display: none;
}

.queue {
  margin: 0;
  color: #8b2a72;
  font-size: 0.92rem;
  font-weight: 700;
}

.loading-title {
  margin: 0.4rem 0 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.4rem;
}

.loading-text {
  margin: 0.55rem 0 0.9rem;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.45;
}

.loader-wrap {
  width: 100%;
  height: 0.72rem;
  border-radius: 999px;
  background: #f4dbea;
  overflow: hidden;
  border: 1px solid #efcae5;
}

.loader-fill {
  width: 0;
  height: 100%;
  background: linear-gradient(90deg, var(--accent-3), var(--accent-2) 48%, var(--accent));
  transition: width 320ms ease;
}

.progress-row {
  margin-top: 0.55rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.progress-row p {
  margin: 0;
  font-size: 0.88rem;
  font-weight: 700;
}

.loading-sub {
  margin: 0.85rem 0 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.scan-card {
  display: grid;
  justify-items: center;
  gap: 0.85rem;
  margin-top: 0.95rem;
  padding: 1rem 0.85rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: linear-gradient(180deg, #fff, #fff7fd);
}

.scan-avatar-wrap {
  position: relative;
  width: 8.5rem;
  height: 8.5rem;
  flex: 0 0 auto;
}

.scan-avatar-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 999px;
  border: 3px solid #ffffff;
  box-shadow: 0 0 0 2px #f2cade;
  animation: scanFloat 1.6s ease-in-out infinite;
}

.scan-ring {
  position: absolute;
  inset: -0.35rem;
  border-radius: 999px;
  border: 2px solid rgba(188, 24, 136, 0.35);
  animation: pulseRing 1.4s ease-in-out infinite;
}

.scan-meta p,
.scan-meta span {
  display: block;
}

.scan-meta {
  text-align: center;
}

.scan-meta p {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 1rem;
  font-weight: 700;
}

.scan-meta span {
  margin-top: 0.25rem;
  color: var(--muted);
  font-size: 0.82rem;
}

.scan-notes {
  margin-top: 0.85rem;
  display: grid;
  gap: 0.55rem;
}

.scan-notes p {
  margin: 0;
  padding: 0.75rem 0.8rem;
  border-radius: 0.85rem;
  border: 1px solid var(--line);
  background: #fffafd;
  color: #5a376f;
  font-size: 0.88rem;
  line-height: 1.4;
}

.scan-notes span {
  font-weight: 800;
  color: #8c2d78;
}

.scan-download {
  margin: 0.55rem 0 0;
  color: #8c2d78;
  font-size: 0.9rem;
  font-weight: 800;
  text-align: center;
}

.badge.success {
  background: linear-gradient(90deg, #34b855, #149f6f);
}

.profile-hero {
  display: grid;
  justify-items: center;
  gap: 0.28rem;
  text-align: center;
  margin-bottom: 0.4rem;
}

.profile-hero img {
  width: 5.3rem;
  height: 5.3rem;
  border-radius: 999px;
  object-fit: cover;
  border: 3px solid #ffffff;
  box-shadow: 0 0 0 2px #f1d3e9;
}

.profile-hero h2 {
  margin: 0.22rem 0 0;
  font-size: 1.2rem;
}

.profile-hero p {
  margin: 0;
  color: #6d4a86;
  font-size: 0.93rem;
  font-weight: 700;
}

.profile-slider {
  margin-top: 0.75rem;
  border: 1px solid var(--line);
  border-radius: 0.9rem;
  background: #fffafd;
  padding: 0.65rem;
}

.profile-slider-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.profile-slider-head h3 {
  margin: 0;
  font-size: 0.86rem;
  color: #713f8b;
}

.profile-slider-controls {
  display: inline-flex;
  gap: 0.35rem;
}

.profile-slider-controls button {
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 999px;
  border: 1px solid #e5bfd8;
  background: #fff;
  color: #8c2d78;
  font-weight: 800;
  line-height: 1;
}

.profile-slider-track {
  margin-top: 0.6rem;
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 0.2rem;
}

.profile-slider-track::-webkit-scrollbar {
  height: 0.38rem;
}

.profile-slider-track::-webkit-scrollbar-thumb {
  background: #e7c5db;
  border-radius: 999px;
}

.profile-slide-card {
  min-width: 7rem;
  scroll-snap-align: start;
  border: 1px solid #f0d3e8;
  border-radius: 0.75rem;
  background: #fff;
  padding: 0.45rem;
  position: relative;
}

.profile-slide-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 0.55rem;
  border: 1px solid #f0d1e5;
  display: block;
}

.profile-slide-card p {
  margin: 0.35rem 0 0;
  font-size: 0.75rem;
  color: #603f77;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-slide-card.locked img {
  filter: blur(7px) brightness(0.7);
  transform: scale(1.05);
}

.profile-slide-card .lock-overlay {
  width: 1.4rem;
  height: 1.4rem;
  font-size: 0.8rem;
}

.api-images {
  margin-top: 0.75rem;
  border: 1px solid #e6d8ef;
  border-radius: 0.9rem;
  background: linear-gradient(180deg, #ffffff, #fffcff);
  box-shadow: 0 6px 18px rgba(73, 42, 94, 0.08);
  padding: 0.78rem;
}

.api-images h3 {
  margin: 0;
  font-size: 0.9rem;
  color: #352049;
}

.api-images-grid {
  margin-top: 0.55rem;
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  gap: 0.45rem;
  padding-bottom: 0;
  scrollbar-width: none;
}

.api-images-grid::-webkit-scrollbar {
  display: none;
}

.api-images-grid::-webkit-scrollbar-thumb {
  background: #e7c5db;
  border-radius: 999px;
}

.api-image-tile {
  position: relative;
  min-width: 82%;
  border-radius: 0.65rem;
  overflow: hidden;
  scroll-snap-align: start;
  border: 1px solid #ebddef;
  background: #fff;
  box-shadow: 0 3px 9px rgba(91, 50, 116, 0.05);
}

.api-images-grid img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 4;
  object-fit: cover;
  border-radius: 0.65rem;
  border: 1px solid #f0d1e5;
}

.api-image-tile.locked img {
  filter: blur(8px) brightness(0.68);
  transform: scale(1.06);
}

.lock-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: 1.55rem;
  height: 1.55rem;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(16, 10, 24, 0.72);
  color: #fff;
  font-size: 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.42);
}

.api-reveal-btn {
  margin-top: 0.65rem;
}

.inline-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
  margin-top: 0.65rem;
}

.inline-stats article {
  border: 1px solid #e6d8ef;
  border-radius: 0.8rem;
  background: linear-gradient(180deg, #ffffff, #fffcff);
  box-shadow: 0 4px 12px rgba(73, 42, 94, 0.06);
  padding: 0.55rem 0.4rem;
  text-align: center;
}

.inline-stats p {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
}

.inline-stats span {
  display: block;
  margin-top: 0.2rem;
  color: var(--muted);
  font-size: 0.76rem;
}

.locked-list {
  margin-top: 0.72rem;
  display: grid;
  gap: 0.45rem;
}

.locked-list p {
  margin: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: 1px solid #e6d8ef;
  border-radius: 0.72rem;
  padding: 0.55rem 0.65rem;
  font-size: 0.86rem;
  background: linear-gradient(180deg, #ffffff, #fffcff);
  box-shadow: 0 3px 9px rgba(73, 42, 94, 0.06);
}

.user-row-left {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.user-avatar {
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 999px;
  object-fit: cover;
  border: 1px solid #f0d1e5;
  background: #fff;
}

.report-card {
  margin-top: 0.75rem;
  border: 1px solid #e6d8ef;
  border-radius: 0.95rem;
  background: linear-gradient(180deg, #ffffff, #fffcff);
  box-shadow: 0 6px 18px rgba(73, 42, 94, 0.08);
  padding: 0.85rem;
}

.report-card h3 {
  margin: 0;
  font-size: 0.97rem;
  color: #352049;
  letter-spacing: 0.01em;
  position: relative;
  padding-left: 0.72rem;
}

.report-card h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.25rem;
  width: 0.34rem;
  height: 0.34rem;
  border-radius: 999px;
  background: #1aa164;
  box-shadow: 0 0 0 3px rgba(26, 161, 100, 0.14);
}

.report-sub {
  margin: 0.42rem 0 0;
  color: #5a4b73;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.report-warn {
  margin: 0.35rem 0 0;
  color: #815a18;
  background: #fff8e8;
  border: 1px solid #f3dfb2;
  border-radius: 0.6rem;
  padding: 0.38rem 0.5rem;
  font-size: 0.83rem;
  font-weight: 700;
}

.report-period {
  margin: 0.45rem 0 0;
  color: #66577d;
  font-size: 0.8rem;
  font-weight: 700;
}

.report-line {
  margin: 0.45rem 0 0;
  color: #48335d;
  font-size: 0.85rem;
  line-height: 1.45;
  border: 1px solid #efe2f5;
  background: #fff;
  border-radius: 0.68rem;
  padding: 0.5rem 0.58rem;
}

.visited-section {
  margin-top: 0.8rem;
}

.visited-section h3 {
  margin: 0;
  font-size: 0.9rem;
}

.visit-row {
  margin-top: 0.5rem;
  border: 1px solid #ead9f1;
  border-radius: 0.85rem;
  background: #fff;
  box-shadow: 0 2px 7px rgba(91, 50, 116, 0.05);
  padding: 0.62rem;
}

.visit-row p {
  margin: 0;
  color: #5b3c70;
  font-size: 0.8rem;
  line-height: 1.35;
}

.visit-avatars {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  margin-bottom: 0.4rem;
}

.visit-avatars .user-avatar {
  width: 1.5rem;
  height: 1.5rem;
}

.visit-row span {
  display: block;
  margin-top: 0.35rem;
  color: #6d4e88;
  font-size: 0.79rem;
  font-weight: 700;
}

.stalker-card {
  margin-top: 0.75rem;
  border: 1px solid #dfcee9;
  border-radius: 0.95rem;
  padding: 0.86rem;
  background: linear-gradient(180deg, #ffffff, #fff9fe);
  box-shadow: 0 8px 20px rgba(82, 46, 108, 0.09);
}

.stalker-card h3 {
  margin: 0;
  font-size: 0.98rem;
  color: #332145;
}

.stalker-card p {
  margin: 0.5rem 0 0;
  font-size: 0.84rem;
  line-height: 1.4;
  color: #5c3e71;
}

.pill-row {
  margin-top: 0.55rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.34rem;
}

.pill-row span {
  border: 1px solid #e7bed7;
  border-radius: 999px;
  padding: 0.23rem 0.5rem;
  font-size: 0.73rem;
  color: #8a2d75;
  background: #fff;
}

.chat-preview {
  margin-top: 0.65rem;
  border: 1px dashed #dca7cb;
  border-radius: 0.75rem;
  padding: 0.55rem;
  background: rgba(255, 255, 255, 0.78);
}

.chat-preview p {
  margin: 0.22rem 0;
  font-size: 0.78rem;
  color: #613f77;
}

.primary-btn {
  margin-top: 0.68rem;
  width: 100%;
  border: 0;
  border-radius: 0.85rem;
  padding: 0.78rem 0.95rem;
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  color: var(--white);
  background: linear-gradient(90deg, #ff512f, #dd2476);
}

.primary-btn.full {
  margin-top: 0.88rem;
  font-size: 0.94rem;
}

.limited-time {
  margin: 0.5rem 0 0;
  text-align: center;
  color: #8f2f7b;
  font-size: 0.8rem;
  font-weight: 700;
}

.report-page {
  min-height: 100vh;
  margin: 0;
  font-family: "Manrope", sans-serif;
  color: #2a1a3d;
  background:
    radial-gradient(120% 120% at 10% 0%, rgba(188, 24, 136, 0.18) 0%, transparent 55%),
    radial-gradient(100% 100% at 100% 100%, rgba(240, 148, 51, 0.16) 0%, transparent 60%),
    linear-gradient(180deg, #fff4fb, #fffdfd);
}

.report-shell {
  max-width: 430px;
  margin: 0 auto;
  padding: 1.1rem 0.95rem 1.4rem;
}

.report-hero {
  text-align: center;
  margin-bottom: 0.85rem;
}

.report-profile {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  margin-top: 0.75rem;
}

.report-profile img {
  width: 4.4rem;
  height: 4.4rem;
  border-radius: 999px;
  object-fit: cover;
  border: 3px solid #ffffff;
  box-shadow: 0 0 0 2px #f1d3e9;
  flex: 0 0 auto;
}

.report-profile-label {
  margin: 0;
  color: #8c2d78;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.report-profile h2 {
  margin: 0.2rem 0 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.18rem;
}

.report-profile p:last-child {
  margin: 0.18rem 0 0;
  color: #66577d;
  font-size: 0.9rem;
  font-weight: 700;
}

.report-badge {
  margin: 0 auto 0.55rem;
  width: fit-content;
  border-radius: 999px;
  padding: 0.3rem 0.7rem;
  background: #ffffff;
  border: 1px solid #e8d6f0;
  box-shadow: 0 4px 12px rgba(73, 42, 94, 0.08);
  color: #8c2d78;
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.report-hero h1 {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.6rem;
  line-height: 1.15;
}

.report-intro {
  margin: 0.55rem 0 0;
  color: #59406d;
  font-size: 0.92rem;
}

.card-soft {
  border: 1px solid #e6d8ef;
  border-radius: 1rem;
  background: linear-gradient(180deg, #ffffff, #fffcff);
  box-shadow: 0 8px 22px rgba(73, 42, 94, 0.08);
  padding: 0.9rem;
}

.report-benefits {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.55rem;
}

.report-benefits article {
  border: 1px solid #e6d8ef;
  border-radius: 0.9rem;
  background: #fff;
  box-shadow: 0 4px 12px rgba(73, 42, 94, 0.05);
  padding: 0.75rem 0.8rem;
}

.report-benefits h2 {
  margin: 0;
  font-size: 0.92rem;
  color: #352049;
}

.report-benefits p {
  margin: 0.28rem 0 0;
  color: #5a4b73;
  font-size: 0.84rem;
  line-height: 1.4;
}

.report-countdown,
.pricing-card,
.report-footer {
  margin-top: 0.75rem;
}

.report-label {
  margin: 0;
  color: #5a4b73;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 800;
}

.countdown-box {
  margin-top: 0.5rem;
  padding: 0.7rem 0.9rem;
  border-radius: 0.85rem;
  background: #fff8e8;
  border: 1px solid #f3dfb2;
  text-align: center;
}

.countdown-box span {
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: #815a18;
}

.report-warning {
  margin: 0.6rem 0 0;
  color: #ab2959;
  font-weight: 800;
  font-size: 0.95rem;
  text-align: center;
}

.report-note {
  margin: 0.35rem 0 0;
  color: #59406d;
  font-size: 0.84rem;
  text-align: center;
}

.pricing-card {
  text-align: center;
}

.pricing-ribbon {
  display: inline-block;
  margin: 0 auto 0.6rem;
  padding: 0.32rem 0.68rem;
  border-radius: 999px;
  background: linear-gradient(90deg, #ff512f, #dd2476);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.05em;
}

.price-header {
  display: grid;
  gap: 0.18rem;
}

.price-tag {
  color: #352049;
  font-size: 1rem;
  font-weight: 800;
}

.price-from,
.price-meta {
  margin: 0;
  color: #66577d;
  font-size: 0.86rem;
}

.price-now {
  margin: 0.2rem 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 2.2rem;
  color: #1aa164;
  font-weight: 700;
}

.price-points {
  margin-top: 0.85rem;
  display: grid;
  gap: 0.4rem;
}

.price-points p {
  margin: 0;
  padding: 0.58rem 0.7rem;
  border: 1px solid #ece0f3;
  border-radius: 0.75rem;
  background: #fff;
  color: #48335d;
  font-size: 0.84rem;
  line-height: 1.35;
}

.purchase-btn {
  margin-top: 0.9rem;
}

.email-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.email-modal[hidden] {
  display: none;
}

.email-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17, 10, 24, 0.58);
  backdrop-filter: blur(6px);
}

.email-modal-card {
  position: relative;
  width: 100%;
  max-width: 360px;
  z-index: 1;
  border: 1px solid #e6d8ef;
  border-radius: 1rem;
  background: linear-gradient(180deg, #ffffff, #fffcff);
  box-shadow: 0 24px 70px rgba(22, 14, 34, 0.3);
  padding: 1rem;
}

.email-modal-close {
  position: absolute;
  top: 0.65rem;
  right: 0.7rem;
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 999px;
  background: #f4e7f0;
  color: #6b305f;
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1;
}

.email-modal-badge {
  margin-left: 0;
}

.email-modal-card h2 {
  margin: 0.6rem 0 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.3rem;
}

.email-modal-text {
  margin: 0.5rem 0 0;
  color: #5a4b73;
  font-size: 0.92rem;
  line-height: 1.5;
}

.email-form {
  margin-top: 0.85rem;
  display: grid;
  gap: 0.55rem;
}

.email-form label {
  font-size: 0.86rem;
  font-weight: 700;
  color: #352049;
}

.email-form input {
  width: 100%;
  border: 1px solid #e8bfde;
  background: #ffffff;
  border-radius: 0.85rem;
  padding: 0.78rem 0.9rem;
  font-size: 0.95rem;
  outline: none;
}

.email-form input:focus {
  border-color: #bc1888;
  box-shadow: 0 0 0 3px rgba(188, 24, 136, 0.15);
}

.report-footer p {
  margin: 0;
  color: #66577d;
  font-size: 0.76rem;
  line-height: 1.45;
  text-align: center;
}

.report-footer a {
  color: #8e2f7b;
  text-decoration: none;
  margin: 0 0.2rem;
}

.footer-domain {
  margin: 0.75rem 0 0;
  text-align: center;
  color: #66577d;
  font-size: 0.8rem;
  font-weight: 700;
}

.footer-domain a,
.legal-domain a {
  color: #8e2f7b;
  text-decoration: none;
  font-weight: 800;
}

.legal-domain {
  margin-top: 0.75rem;
  text-align: center;
}

.legal-domain p {
  margin: 0;
}

.legal-card h1 {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  font-size: 1.4rem;
}

.legal-card p {
  margin: 0.6rem 0 0;
  color: #5a4b73;
  font-size: 0.9rem;
  line-height: 1.5;
}

.legal-nav {
  margin-top: 0.75rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.45rem 0.65rem;
}

.legal-nav a {
  text-decoration: none;
  color: #8e2f7b;
  font-size: 0.83rem;
  font-weight: 700;
}

@media (min-width: 600px) {
  .report-shell {
    padding-top: 1.5rem;
  }
}

.profile-card {
  display: flex;
  gap: 0.78rem;
  align-items: center;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 1rem;
  padding: 0.7rem;
}

.profile-card img {
  width: 4rem;
  height: 4rem;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid #ffffff;
  box-shadow: 0 0 0 2px #f1d3e9;
}

.profile-card h2 {
  margin: 0;
  font-size: 1rem;
}

.profile-card p {
  margin: 0.2rem 0 0;
  color: var(--muted);
  font-size: 0.83rem;
}

.stats-grid {
  margin-top: 0.75rem;
  display: grid;
  gap: 0.55rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.stats-grid article {
  border: 1px solid var(--line);
  border-radius: 0.85rem;
  padding: 0.62rem;
  background: #fffafd;
}

.stats-grid h3 {
  margin: 0;
  font-size: 0.78rem;
  color: var(--muted);
}

.stats-grid p {
  margin: 0.33rem 0 0;
  font-size: 1rem;
  font-weight: 800;
}

.bio-block {
  margin-top: 0.75rem;
  border: 1px solid var(--line);
  border-radius: 0.9rem;
  background: #fffafd;
  padding: 0.65rem;
}

.bio-block h3 {
  margin: 0;
  font-size: 0.8rem;
  color: var(--muted);
}

.bio-block p {
  margin: 0.38rem 0 0;
  font-size: 0.86rem;
  line-height: 1.4;
}

.ghost-btn {
  margin-top: 0.8rem;
  border: 1px solid #deafd1;
  border-radius: 0.85rem;
  padding: 0.75rem 0.95rem;
  background: #fff4fb;
  color: #8c2d78;
  font-size: 0.9rem;
  font-weight: 700;
  width: 100%;
}

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

@keyframes pulseRing {
  0% {
    transform: scale(0.94);
    opacity: 0.85;
  }
  70% {
    transform: scale(1.04);
    opacity: 0.15;
  }
  100% {
    transform: scale(0.94);
    opacity: 0.85;
  }
}

@keyframes scanFloat {
  0% {
    transform: scale(0.97) translateY(0);
  }
  50% {
    transform: scale(1.03) translateY(-4px);
  }
  100% {
    transform: scale(0.97) translateY(0);
  }
}

@media (min-width: 600px) {
  .page {
    padding: 2rem;
  }

  .phone {
    padding: 1.2rem;
  }
}
