:root {
  --affiliate-banner-height: 0px;
  --page-gutter: 24px;
  --color-charcoal: #2c2825;
  --color-charcoal-light: #3d3835;
  --color-cream: #faf7f2;
  --color-cream-dark: #f0ebe3;
  --color-terracotta: #c4713b;
  --color-terracotta-hover: #d4814b;
  --color-white: #ffffff;
  --color-blue-badge: #1565c0;
  --color-green-badge: #2e7d32;

  --text-primary: rgba(44, 40, 37, 1);
  --text-secondary: rgba(44, 40, 37, 0.7);
  --text-tertiary: rgba(44, 40, 37, 0.5);
  --text-subtle: rgba(44, 40, 37, 0.35);

  --font-sans: "DM Sans", "Avenir Next", "Segoe UI", sans-serif;
  --font-mono: "JetBrains Mono", "SFMono-Regular", Menlo, monospace;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 18px;

  --shadow-sm: 0 2px 10px rgba(44, 40, 37, 0.06);
  --shadow-md: 0 4px 18px rgba(44, 40, 37, 0.1);

  --max-width: 1080px;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html,
body {
  margin: 0;
  padding: 0;
  min-height: 100%;
}

body {
  font-family: var(--font-sans);
  color: var(--text-primary);
  background:
    radial-gradient(circle at 10% 10%, rgba(196, 113, 59, 0.07), transparent 35%),
    radial-gradient(circle at 90% 20%, rgba(61, 56, 53, 0.06), transparent 30%),
    var(--color-cream);
  line-height: 1.5;
}

a {
  color: inherit;
}

.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--page-gutter);
}

.site-affiliate-banner {
  position: sticky;
  top: 0;
  z-index: 30;
  width: 100%;
  padding: calc(env(safe-area-inset-top) + 4px) 0 4px;
  border-bottom: 1px solid rgba(250, 247, 242, 0.24);
  background: linear-gradient(180deg, rgba(44, 40, 37, 0.96), rgba(44, 40, 37, 0.92));
  backdrop-filter: blur(6px);
}

.site-affiliate-track {
  max-width: var(--max-width);
  width: 100%;
  margin: 0 auto;
  padding-left: max(var(--page-gutter), env(safe-area-inset-left));
  padding-right: max(var(--page-gutter), env(safe-area-inset-right));
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  gap: 4px;
}

.site-affiliate-line {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 2px;
  white-space: nowrap;
  text-decoration: none;
  text-align: center;
  line-height: 1.05;
  font-size: 13px;
  font-weight: 700;
  color: rgba(250, 247, 242, 0.98);
}

.site-affiliate-line:hover {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.site-affiliate-copy {
  opacity: 0.98;
}

.site-affiliate-tag {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  padding: 1px 5px;
  border-radius: 999px;
  border: 1px solid rgba(250, 247, 242, 0.2);
  background: rgba(250, 247, 242, 0.08);
  color: rgba(250, 247, 242, 0.58);
  font-size: 6px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.site-affiliate-banner.is-home-jiggle .site-affiliate-track {
  transform-origin: center top;
  animation: affiliate-banner-jiggle 560ms ease-in-out 240ms 1;
}

@keyframes affiliate-banner-jiggle {
  0% {
    transform: translateX(0) rotate(0deg);
  }
  20% {
    transform: translateX(-1.25px) rotate(-0.55deg);
  }
  40% {
    transform: translateX(1.5px) rotate(0.65deg);
  }
  60% {
    transform: translateX(-1px) rotate(-0.45deg);
  }
  80% {
    transform: translateX(0.8px) rotate(0.3deg);
  }
  100% {
    transform: translateX(0) rotate(0deg);
  }
}

.site-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
}

.onboarding-header {
  justify-content: center;
  margin-bottom: 20px;
}

body[data-page="welcome"] .nav-actions {
  display: none !important;
}

.site-logo {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-decoration: none;
}

.site-logo .phi {
  color: var(--color-terracotta);
}

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

.user-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(44, 40, 37, 0.07);
  padding: 6px 10px;
  border-radius: var(--radius-md);
  font-size: 13px;
  color: var(--text-secondary);
}

.user-pill img {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  object-fit: cover;
}

.btn-profile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.profile-btn-avatar {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(44, 40, 37, 0.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}

.profile-btn-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.profile-btn-avatar-fallback {
  background: rgba(44, 40, 37, 0.14);
}

.btn {
  border: 0;
  border-radius: var(--radius-md);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  padding: 10px 18px;
  text-decoration: none;
  transition: 120ms ease;
}

.btn:disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.btn-disabled {
  opacity: 0.45;
  pointer-events: none;
}

.btn-primary {
  background: var(--color-charcoal);
  color: var(--color-cream);
}

.btn-primary:hover {
  background: var(--color-charcoal-light);
}

.btn-accent {
  background: var(--color-terracotta);
  color: var(--color-white);
}

.btn-accent:hover {
  background: var(--color-terracotta-hover);
}

.btn-outline {
  background: transparent;
  border: 1.5px solid rgba(44, 40, 37, 0.18);
  color: var(--text-primary);
}

.btn-danger {
  background: #b8432f;
  color: var(--color-white);
}

.btn-danger:hover {
  background: #963726;
}

.btn-quiet-danger {
  background: transparent;
  border: 1px solid rgba(184, 67, 47, 0.22);
  color: rgba(124, 38, 25, 0.82);
  font-size: 12px;
  font-weight: 600;
  padding: 8px 12px;
}

.btn-quiet-danger:hover {
  background: rgba(184, 67, 47, 0.08);
}

.hero {
  text-align: center;
  margin: 20px auto 28px;
  max-width: 780px;
}

.hero h1 {
  margin: 0 0 8px;
  font-size: clamp(30px, 5vw, 44px);
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.hero p {
  margin: 0;
  color: var(--text-secondary);
  font-size: clamp(15px, 2vw, 18px);
}

.landing-hero {
  margin-bottom: 18px;
}

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

.landing-option-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.landing-option-card:first-child {
  grid-column: 1 / -1;
}

.landing-option-kicker {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  font-weight: 700;
}

.landing-option-card .section-title {
  margin: 0;
  font-size: clamp(21px, 3.7vw, 26px);
}

body[data-page="landing"] .landing-option-card:not(:first-child) .section-title {
  font-size: clamp(16px, 2.6vw, 22px);
  line-height: 1.24;
}

body[data-page="landing"] .landing-option-card.landing-option-no-tagline {
  gap: 6px;
}

body[data-page="landing"] .landing-option-card.landing-option-no-tagline .section-title {
  display: none;
}

.landing-cta {
  width: 100%;
}

body[data-page="landing"] .landing-cta.soft-3d-btn {
  --path-rest-x: 0px;
  --path-rest-y: 0px;
  --path-mid-x: 0px;
  --path-mid-y: 0px;
  --path-back-x: 8px;
  --path-back-y: 8px;
  --landing-press-hover: 2px;
  --landing-press-active: 4px;
  padding: 22px 24px;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  animation-name: landing-choice-unstack;
  animation-fill-mode: backwards;
}

body[data-page="landing"] .landing-cta .soft-3d-title,
body[data-page="landing"] .landing-cta .soft-3d-sub {
  position: relative;
  z-index: 1;
  padding-inline: 8px;
  transition: transform 160ms ease;
}

body[data-page="landing"] .landing-cta.soft-3d-ideas {
  --path-main-bg:
    linear-gradient(160deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.86)),
    linear-gradient(145deg, var(--color-cream), #fff2e5 58%, #f2ddc8);
  --path-back-bg: #deb08a;
  --landing-plate-border: rgba(44, 40, 37, 0.9);
  color: var(--text-primary);
}

body[data-page="landing"] .landing-cta.soft-3d-ideas::after {
  border-color: rgba(44, 40, 37, 0.82);
}

body[data-page="landing"] .landing-cta.soft-3d-submit {
  --path-main-bg:
    linear-gradient(160deg, rgba(61, 56, 53, 0.95), rgba(44, 40, 37, 0.97)),
    linear-gradient(145deg, #3d3835, #2c2825 62%, #201c1a);
  --path-back-bg: #d39a6d;
  --landing-plate-border: rgba(250, 247, 242, 0.9);
  color: rgba(250, 247, 242, 1);
}

body[data-page="landing"] .landing-cta.soft-3d-submit::after {
  border-color: rgba(250, 247, 242, 0.68);
}

body[data-page="landing"] .landing-cta.soft-3d-submit .soft-3d-sub {
  color: rgba(250, 247, 242, 0.84);
}

body[data-page="landing"] .landing-cta.soft-3d-btn::before {
  display: block;
  background: var(--path-main-bg);
  border-color: var(--landing-plate-border, rgba(44, 40, 37, 0.9));
  transform: translate(0, 0);
  z-index: -1;
}

body[data-page="landing"] .landing-cta.soft-3d-btn::after {
  z-index: -2;
}

body[data-page="landing"] .landing-cta.soft-3d-btn:hover {
  transform: translate(var(--path-rest-x), var(--path-rest-y));
}

body[data-page="landing"] .landing-cta.soft-3d-btn:active {
  transform: translate(var(--path-rest-x), var(--path-rest-y));
}

body[data-page="landing"] .landing-cta.soft-3d-btn:hover::before {
  transform: translate(var(--landing-press-hover), var(--landing-press-hover));
}

body[data-page="landing"] .landing-cta.soft-3d-btn:active::before {
  transform: translate(var(--landing-press-active), var(--landing-press-active));
}

body[data-page="landing"] .landing-cta.soft-3d-btn:hover::after {
  transform: translate(var(--path-back-x), var(--path-back-y));
}

body[data-page="landing"] .landing-cta.soft-3d-btn:active::after {
  transform: translate(var(--path-back-x), var(--path-back-y));
}

body[data-page="landing"] .landing-cta.soft-3d-btn:hover .soft-3d-title,
body[data-page="landing"] .landing-cta.soft-3d-btn:hover .soft-3d-sub {
  transform: translate(var(--landing-press-hover), var(--landing-press-hover));
}

body[data-page="landing"] .landing-cta.soft-3d-btn:active .soft-3d-title,
body[data-page="landing"] .landing-cta.soft-3d-btn:active .soft-3d-sub {
  transform: translate(var(--landing-press-active), var(--landing-press-active));
}

body[data-page="landing"] .landing-option-card:nth-child(3) .landing-cta {
  animation-delay: 180ms;
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn {
  --path-rest-x: 0px;
  --path-rest-y: 0px;
  --path-mid-x: 0px;
  --path-mid-y: 0px;
  --path-back-x: 8px;
  --path-back-y: 8px;
  --welcome-press-hover: 2px;
  --welcome-press-active: 4px;
  padding: 22px 24px;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
  animation-name: landing-choice-unstack;
  animation-fill-mode: backwards;
  z-index: 1;
}

body[data-page="welcome"] #welcomeActions .soft-3d-ideas {
  --path-main-bg:
    linear-gradient(160deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.86)),
    linear-gradient(145deg, var(--color-cream), #fff2e5 58%, #f2ddc8);
  --path-back-bg: #deb08a;
  color: var(--text-primary);
  animation-delay: 0s;
}

body[data-page="welcome"] #welcomeActions .soft-3d-ideas::after {
  border-color: rgba(44, 40, 37, 0.82);
}

body[data-page="welcome"] #welcomeActions .soft-3d-submit {
  --path-main-bg:
    linear-gradient(160deg, rgba(61, 56, 53, 0.95), rgba(44, 40, 37, 0.97)),
    linear-gradient(145deg, #3d3835, #2c2825 62%, #201c1a);
  --path-back-bg: #d39a6d;
  color: rgba(250, 247, 242, 1);
  animation-delay: 0s;
}

body[data-page="welcome"] #welcomeActions .soft-3d-submit::after {
  border-color: rgba(250, 247, 242, 0.68);
}

body[data-page="welcome"] #welcomeActions .soft-3d-submit .soft-3d-sub {
  color: rgba(250, 247, 242, 0.84);
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn::before {
  background: var(--path-main-bg);
  border-color: rgba(44, 40, 37, 0.9);
  transform: translate(0, 0);
  z-index: -1;
}

body[data-page="welcome"] #welcomeActions .soft-3d-submit::before {
  border-color: rgba(250, 250, 255, 0.86);
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn::after {
  z-index: -2;
}

body[data-page="welcome"] #welcomeActions .soft-3d-title,
body[data-page="welcome"] #welcomeActions .soft-3d-sub {
  position: relative;
  z-index: 1;
  transition: transform 160ms ease;
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover,
body[data-page="welcome"] #welcomeActions .soft-3d-btn:active {
  transform: translate(var(--path-rest-x), var(--path-rest-y));
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover::before {
  transform: translate(var(--welcome-press-hover), var(--welcome-press-hover));
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn:active::before {
  transform: translate(var(--welcome-press-active), var(--welcome-press-active));
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover::after,
body[data-page="welcome"] #welcomeActions .soft-3d-btn:active::after {
  transform: translate(var(--path-back-x), var(--path-back-y));
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover .soft-3d-title,
body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover .soft-3d-sub {
  transform: translate(var(--welcome-press-hover), var(--welcome-press-hover));
}

body[data-page="welcome"] #welcomeActions .soft-3d-btn:active .soft-3d-title,
body[data-page="welcome"] #welcomeActions .soft-3d-btn:active .soft-3d-sub {
  transform: translate(var(--welcome-press-active), var(--welcome-press-active));
}

.landing-subtext {
  margin: 0;
  color: var(--text-secondary);
  font-size: 14px;
}

.landing-disclosure {
  margin: 0;
  color: var(--text-subtle);
  font-size: 12px;
}

body[data-page="home"] .ideas-live-ticker-panel {
  padding: 14px 16px 16px;
  margin-bottom: 18px;
}

.ideas-live-ticker {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.ideas-live-metric {
  display: grid;
  gap: 6px;
}

.ideas-live-value {
  position: relative;
  min-height: 56px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  border: 1px solid rgba(250, 247, 242, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.03)),
    linear-gradient(180deg, #3d3835 0%, #262220 100%);
  color: rgba(250, 247, 242, 0.98);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 6px 16px rgba(22, 18, 16, 0.22);
  font-family: "JetBrains Mono", monospace;
  font-size: clamp(21px, 3.3vw, 31px);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
  padding: 8px 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ideas-live-value::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
  background: rgba(12, 10, 10, 0.46);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.08);
}

.ideas-live-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-secondary);
  text-align: center;
}

@media (min-width: 900px) {
  body[data-page="landing"] .landing-option-card:first-child .landing-cta {
    width: min(100%, 840px);
  }
}

.panel {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  padding: 22px;
}

.tabs {
  display: flex;
  align-items: center;
  gap: 6px;
  border-bottom: 1px solid rgba(44, 40, 37, 0.12);
  margin-bottom: 16px;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
  scrollbar-gutter: stable;
}

.tabs::-webkit-scrollbar {
  width: 0;
  height: 0;
}

.pagination-shell {
  margin-top: 16px;
}

.pagination-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.pagination-bar-infinite {
  justify-content: center;
  flex-direction: column;
  gap: 8px;
}

.pagination-label {
  font-size: 13px;
  color: var(--text-secondary);
  min-width: 112px;
  text-align: center;
}

.home-feed-sentinel {
  width: 100%;
  height: 2px;
}

.tab-btn {
  border: 0;
  background: transparent;
  color: var(--text-tertiary);
  font-weight: 500;
  font-size: 14px;
  padding: 10px 12px;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  white-space: nowrap;
}

.tab-btn.is-active {
  color: var(--text-primary);
  border-bottom-color: var(--color-terracotta);
}

.idea-list {
  display: grid;
  gap: 12px;
}

body[data-page="home"] .ideas-filter-row {
  margin-top: 6px;
  margin-bottom: 18px;
}

.idea-card {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  padding: 14px;
}

.vote-rail {
  min-width: 52px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.vote-btn {
  --vote-stack-offset: 3px;
  --vote-press-hover: 1px;
  --vote-press-active: 2px;
  --vote-top-bg: var(--color-white);
  --vote-top-border: rgba(44, 40, 37, 0.18);
  --vote-bottom-bg: #e7ded2;
  --vote-bottom-border: rgba(44, 40, 37, 0.2);
  width: 40px;
  height: 40px;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: var(--radius-md);
  border: 1.5px solid transparent;
  color: var(--text-primary);
  background: transparent;
  font-size: 18px;
  line-height: 1;
  text-align: center;
  isolation: isolate;
  overflow: visible;
}

.vote-btn::before,
.vote-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1.5px solid;
  pointer-events: none;
  transition: transform 120ms ease;
}

.vote-btn::before {
  background: var(--vote-top-bg);
  border-color: var(--vote-top-border);
  transform: translate(0, 0);
  z-index: -1;
}

.vote-btn::after {
  background: var(--vote-bottom-bg);
  border-color: var(--vote-bottom-border);
  transform: translate(var(--vote-stack-offset), var(--vote-stack-offset));
  z-index: -2;
}

.vote-btn:hover::before {
  transform: translate(var(--vote-press-hover), var(--vote-press-hover));
}

.vote-btn:active::before {
  transform: translate(var(--vote-press-active), var(--vote-press-active));
}

.vote-btn:hover::after,
.vote-btn:active::after {
  transform: translate(var(--vote-stack-offset), var(--vote-stack-offset));
}

.vote-btn-glyph {
  position: relative;
  z-index: 1;
  display: block;
  line-height: 1;
  transition: transform 120ms ease;
}

.vote-btn:hover .vote-btn-glyph {
  transform: translate(var(--vote-press-hover), var(--vote-press-hover));
}

.vote-btn:active .vote-btn-glyph {
  transform: translate(var(--vote-press-active), var(--vote-press-active));
}

.vote-btn-up.voted {
  --vote-top-bg: var(--color-terracotta);
  --vote-top-border: var(--color-terracotta);
  --vote-bottom-bg: #a45d34;
  --vote-bottom-border: #a45d34;
  color: var(--color-white);
}

.vote-btn-down.voted {
  --vote-top-bg: var(--color-charcoal);
  --vote-top-border: var(--color-charcoal);
  --vote-bottom-bg: #1f1b19;
  --vote-bottom-border: #1f1b19;
  color: var(--color-white);
}

.vote-count {
  font-weight: 700;
  font-size: 14px;
}

.idea-main {
  flex: 1;
  min-width: 0;
}

.idea-title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.idea-title {
  margin: 0;
  font-size: 16px;
  line-height: 1.35;
}

.idea-desc {
  margin: 6px 0 0;
  color: var(--text-secondary);
  font-size: 14px;
}

.idea-meta {
  margin-top: 8px;
  color: var(--text-tertiary);
  font-size: 12px;
}

.status-pill {
  display: inline-block;
  border-radius: 999px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 4px 9px;
  font-weight: 700;
}

.status-open {
  background: rgba(44, 40, 37, 0.09);
  color: var(--color-charcoal);
}

.status-archived {
  background: rgba(124, 38, 25, 0.12);
  color: rgba(124, 38, 25, 0.95);
}

.status-planned {
  background: rgba(33, 150, 243, 0.14);
  color: var(--color-blue-badge);
}

.status-filmed {
  background: rgba(76, 175, 80, 0.14);
  color: var(--color-green-badge);
}

.status-seen {
  background: rgba(196, 113, 59, 0.16);
  color: #8a4c23;
}

.status-review {
  background: rgba(255, 193, 7, 0.18);
  color: #8a5a00;
}

.status-rejected {
  background: rgba(184, 67, 47, 0.16);
  color: #7c2619;
}

.status-archive-soon {
  cursor: help;
  border: 1px solid rgba(184, 67, 47, 0.28);
}

.status-snark {
  background: rgba(196, 113, 59, 0.18);
  color: #8a4a23;
}

.status-public-visible {
  background: rgba(76, 175, 80, 0.14);
  color: #1f6b27;
}

.status-censored {
  background: rgba(184, 67, 47, 0.2);
  color: #7c2619;
}

.status-easter-egg {
  background: rgba(125, 96, 255, 0.14);
  color: #4b35a8;
}

.status-archive-note {
  background: rgba(124, 38, 25, 0.14);
  color: rgba(124, 38, 25, 0.95);
}

.idea-snark-line {
  margin: 8px 0 0;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  font-weight: 600;
  color: #8a4a23;
}

.idea-snark-line .status-pill {
  text-transform: uppercase;
}

.idea-phi-response {
  margin-top: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(196, 113, 59, 0.1);
  color: var(--text-primary);
}

.idea-phi-response strong {
  color: #8a4a23;
}

.idea-inline-ad {
  width: 100%;
  margin-top: 10px;
  border: 2px solid rgba(196, 113, 59, 0.35);
  border-radius: 20px;
  background: rgba(248, 233, 216, 0.46);
  padding: 12px 14px;
  display: grid;
  gap: 8px;
}

.idea-inline-ad-kicker {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  border-radius: 999px;
  padding: 5px 14px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: #8b4a22;
  background: rgba(196, 113, 59, 0.2);
}

.idea-inline-ad-copy {
  display: block;
  color: rgba(84, 53, 31, 0.95);
  line-height: 1.32;
  font-size: clamp(14px, 2.2vw, 18px);
  overflow-wrap: anywhere;
}

.idea-inline-ad-link {
  color: #8b4a22;
  font-weight: 700;
  text-decoration: underline;
}

.idea-inline-ad-affiliate {
  display: inline-block;
  margin-left: 6px;
  font-size: 14px;
  font-weight: 600;
  color: rgba(101, 64, 38, 0.82);
  vertical-align: baseline;
}

.video-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--color-white);
  text-decoration: none;
  font-weight: 700;
  background: #d93025;
  border: 1px solid #b52a1f;
  border-radius: 999px;
  padding: 4px 10px;
  line-height: 1.1;
}

.video-link:hover {
  background: #c6281f;
}

.video-link::before {
  content: "\25B6";
  font-size: 10px;
  line-height: 1;
}

.faq-list {
  display: grid;
  gap: 12px;
}

.faq-item {
  background: var(--color-cream);
  border: 1px solid rgba(44, 40, 37, 0.1);
  border-radius: var(--radius-lg);
  padding: 16px;
}

.faq-item h2 {
  margin: 0 0 6px;
  font-size: 20px;
  letter-spacing: -0.01em;
}

.faq-item p {
  margin: 0;
  color: var(--text-secondary);
}

.faq-item a {
  color: var(--color-terracotta);
  font-weight: 700;
}

.empty-state {
  color: var(--text-tertiary);
  background: rgba(44, 40, 37, 0.04);
  border-radius: var(--radius-lg);
  padding: 20px;
  text-align: center;
}

.notice {
  margin-bottom: 16px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  font-size: 14px;
}

.notice-error {
  background: rgba(215, 48, 39, 0.11);
  color: #8a1c14;
}

.notice-ok {
  background: rgba(46, 125, 50, 0.13);
  color: #1f5e24;
}

.form-wrap {
  max-width: 640px;
}

.form-group {
  margin-bottom: 16px;
}

.form-label {
  display: block;
  margin-bottom: 6px;
  font-size: 14px;
  font-weight: 600;
}

.form-input,
.form-textarea,
.form-select {
  width: 100%;
  border: 1.5px solid rgba(44, 40, 37, 0.14);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  font-size: 15px;
  font-family: inherit;
  background: var(--color-white);
  color: var(--text-primary);
}

.form-textarea {
  min-height: 110px;
  resize: vertical;
}

.form-help {
  margin-top: 6px;
  color: var(--text-tertiary);
  font-size: 12px;
}

.submit-processing-state {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  font-size: 13px;
  border: 1px solid transparent;
}

.submit-processing-info {
  background: rgba(44, 40, 37, 0.04);
  color: var(--text-secondary);
  border-color: rgba(44, 40, 37, 0.12);
}

.submit-processing-ok {
  background: rgba(46, 125, 50, 0.11);
  color: #1f5e24;
  border-color: rgba(46, 125, 50, 0.2);
}

.submit-processing-error {
  background: rgba(215, 48, 39, 0.11);
  color: #8a1c14;
  border-color: rgba(215, 48, 39, 0.2);
}

.username-budget-hint {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  background: rgba(44, 40, 37, 0.04);
  border: 1px solid rgba(44, 40, 37, 0.12);
  color: var(--text-secondary);
  font-size: 12px;
}

.username-availability {
  min-height: 18px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
}

.username-availability::before {
  content: "";
  width: 14px;
  text-align: center;
  font-size: 12px;
  line-height: 1;
  opacity: 0.92;
}

.username-availability.is-checking {
  color: var(--text-tertiary);
}

.username-availability.is-checking::before {
  content: "...";
  animation: username-pulse 1s ease-in-out infinite;
}

.username-availability.is-ok {
  color: #2e7d32;
}

.username-availability.is-ok::before {
  content: "\2713";
}

.username-availability.is-error {
  color: #b8432f;
}

.username-availability.is-error::before {
  content: "\2715";
}

@keyframes username-pulse {
  0% {
    opacity: 0.4;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0.4;
  }
}

.section-title {
  margin: 0 0 8px;
  font-size: 28px;
  letter-spacing: -0.02em;
}

.section-subtitle {
  margin: 0 0 18px;
  color: var(--text-secondary);
}

.stack {
  display: grid;
  gap: 22px;
}

.inline-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.profile-danger-zone {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px dashed rgba(44, 40, 37, 0.18);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.profile-danger-copy strong {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 2px;
}

.profile-danger-copy span {
  display: block;
  font-size: 12px;
  color: var(--text-tertiary);
}

.welcome-panel {
  position: relative;
  overflow: hidden;
}

.welcome-panel::before {
  content: "";
  position: absolute;
  inset: -20% auto auto -10%;
  width: 320px;
  height: 320px;
  pointer-events: none;
  background: radial-gradient(circle, rgba(196, 113, 59, 0.12), rgba(196, 113, 59, 0));
}

body[data-page="welcome"] #welcomeActions.welcome-panel::before {
  display: none;
}

.welcome-choice-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
  gap: 16px;
  margin-top: 14px;
}

.welcome-overview {
  margin: 0 auto 12px;
  max-width: 660px;
  font-size: 21px;
  line-height: 1.45;
  letter-spacing: -0.01em;
  color: rgba(44, 40, 37, 0.72);
  text-wrap: pretty;
}

.welcome-branch {
  width: 100%;
  margin: 2px auto 12px;
}

.welcome-branch svg {
  display: block;
  width: 100%;
  height: 172px;
}

.welcome-fork-path {
  fill: none;
  stroke: rgba(44, 40, 37, 0.84);
  stroke-width: 15;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 430;
  stroke-dashoffset: 430;
  animation: welcome-branch-draw 1.6s ease forwards;
}

.welcome-fork-path.left {
  animation-delay: 0.16s;
}

.welcome-fork-path.right {
  animation-delay: 0.24s;
}

.welcome-fork-head {
  fill: rgba(44, 40, 37, 0.88);
  opacity: 0;
  transform-origin: center;
  animation: welcome-fork-head-in 320ms ease forwards;
}

.welcome-fork-head.left {
  animation-delay: 0.92s;
}

.welcome-fork-head.right {
  animation-delay: 1s;
}

.soft-3d-btn {
  position: relative;
  --path-rest-x: 0px;
  --path-rest-y: 0px;
  --path-mid-x: 8px;
  --path-mid-y: 8px;
  --path-back-x: 14px;
  --path-back-y: 14px;
  --path-main-bg: var(--color-white);
  --path-mid-bg: #ead4ff;
  --path-back-bg: #f5b8de;
  display: block;
  text-decoration: none;
  color: var(--text-primary);
  border: 2px solid rgba(44, 40, 37, 0.9);
  border-radius: 18px;
  padding: 24px 20px;
  background: var(--path-main-bg);
  transform: translate(var(--path-rest-x), var(--path-rest-y));
  transition:
    transform 160ms ease,
    filter 160ms ease;
  box-shadow: 0 16px 24px rgba(44, 40, 37, 0.15);
  isolation: isolate;
  overflow: visible;
  will-change: transform;
  animation-duration: 700ms;
  animation-timing-function: cubic-bezier(0.2, 0.8, 0.24, 1);
  animation-fill-mode: both;
}

.soft-3d-btn::before,
.soft-3d-btn::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 2px solid rgba(44, 40, 37, 0.9);
  pointer-events: none;
  transition: transform 160ms ease;
}

.soft-3d-btn::before {
  background: var(--path-mid-bg);
  transform: translate(var(--path-mid-x), var(--path-mid-y));
  z-index: -1;
}

.soft-3d-btn::after {
  background: var(--path-back-bg);
  transform: translate(var(--path-back-x), var(--path-back-y));
  z-index: -2;
}

.soft-3d-btn:hover {
  transform: translate(calc(var(--path-rest-x) - 2px), calc(var(--path-rest-y) - 2px));
  filter: saturate(1.03);
}

.soft-3d-btn:hover::before {
  transform: translate(calc(var(--path-mid-x) + 2px), calc(var(--path-mid-y) + 2px));
}

.soft-3d-btn:hover::after {
  transform: translate(calc(var(--path-back-x) + 4px), calc(var(--path-back-y) + 4px));
}

.soft-3d-btn:active {
  transform: translate(calc(var(--path-rest-x) + 4px), calc(var(--path-rest-y) + 4px)) scale(0.99);
  box-shadow: 0 9px 14px rgba(44, 40, 37, 0.16);
}

.soft-3d-title {
  display: block;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.soft-3d-sub {
  display: block;
  margin-top: 8px;
  font-size: 14px;
  color: rgba(44, 40, 37, 0.74);
}

.soft-3d-ideas {
  --path-rest-x: 9px;
  --path-rest-y: 8px;
  --path-main-bg:
    linear-gradient(160deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.7)),
    linear-gradient(145deg, #ffefe0, #ffe2c8 56%, #ffd5b0);
  --path-mid-bg: #f0d8ff;
  --path-back-bg: #f4b4dc;
  animation-name: welcome-choice-unstack-left;
  z-index: 3;
}

.soft-3d-submit {
  --path-rest-x: -9px;
  --path-rest-y: -8px;
  --path-main-bg:
    linear-gradient(160deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.04)),
    linear-gradient(145deg, #1c1f59, #2a2f7c 56%, #3644ad);
  --path-mid-bg: #8d9cff;
  --path-back-bg: #d2b5ff;
  color: rgba(250, 250, 255, 0.98);
  animation-name: welcome-choice-unstack-right;
  animation-delay: 100ms;
  z-index: 2;
}

.soft-3d-submit .soft-3d-sub {
  color: rgba(250, 250, 255, 0.8);
}

@keyframes welcome-choice-unstack-left {
  0% {
    transform: translate(58px, 20px) rotate(-4deg) scale(0.96);
  }
  65% {
    transform: translate(6px, 10px) rotate(-0.9deg);
  }
  100% {
    transform: translate(9px, 8px) rotate(0deg) scale(1);
  }
}

@keyframes welcome-choice-unstack-right {
  0% {
    transform: translate(-58px, -24px) rotate(4deg) scale(0.96);
  }
  65% {
    transform: translate(-8px, -10px) rotate(0.9deg);
  }
  100% {
    transform: translate(-9px, -8px) rotate(0deg) scale(1);
  }
}

@keyframes landing-choice-unstack {
  0% {
    transform: translate(40px, 14px) rotate(-2.6deg) scale(0.97);
  }
  65% {
    transform: translate(4px, 2px) rotate(-0.4deg);
  }
  100% {
    transform: translate(0, 0) rotate(0deg) scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .soft-3d-btn,
  .soft-3d-btn::before,
  .soft-3d-btn::after {
    animation: none !important;
    transition: none !important;
  }

  .soft-3d-ideas,
  .soft-3d-submit {
    transform: translate(0, 0);
  }

  body[data-page="landing"] .landing-cta.soft-3d-btn:hover,
  body[data-page="landing"] .landing-cta.soft-3d-btn:active {
    transform: translate(0, 0);
  }

  body[data-page="landing"] .landing-cta .soft-3d-title,
  body[data-page="landing"] .landing-cta .soft-3d-sub {
    transition: none !important;
  }

  body[data-page="landing"] .landing-cta.soft-3d-btn:hover::before,
  body[data-page="landing"] .landing-cta.soft-3d-btn:active::before {
    transform: translate(0, 0);
  }

  body[data-page="landing"] .landing-cta.soft-3d-btn:hover::after,
  body[data-page="landing"] .landing-cta.soft-3d-btn:active::after {
    transform: translate(var(--path-back-x), var(--path-back-y));
  }

  body[data-page="landing"] .landing-cta.soft-3d-btn:hover .soft-3d-title,
  body[data-page="landing"] .landing-cta.soft-3d-btn:hover .soft-3d-sub,
  body[data-page="landing"] .landing-cta.soft-3d-btn:active .soft-3d-title,
  body[data-page="landing"] .landing-cta.soft-3d-btn:active .soft-3d-sub {
    transform: translate(0, 0);
  }

  body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover,
  body[data-page="welcome"] #welcomeActions .soft-3d-btn:active {
    transform: translate(var(--path-rest-x), var(--path-rest-y));
  }

  body[data-page="welcome"] #welcomeActions .soft-3d-title,
  body[data-page="welcome"] #welcomeActions .soft-3d-sub,
  .vote-btn-glyph {
    transition: none !important;
  }

  body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover::before,
  body[data-page="welcome"] #welcomeActions .soft-3d-btn:active::before {
    transform: translate(0, 0);
  }

  body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover::after,
  body[data-page="welcome"] #welcomeActions .soft-3d-btn:active::after {
    transform: translate(var(--path-back-x), var(--path-back-y));
  }

  body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover .soft-3d-title,
  body[data-page="welcome"] #welcomeActions .soft-3d-btn:hover .soft-3d-sub,
  body[data-page="welcome"] #welcomeActions .soft-3d-btn:active .soft-3d-title,
  body[data-page="welcome"] #welcomeActions .soft-3d-btn:active .soft-3d-sub {
    transform: translate(0, 0);
  }

  .vote-btn,
  .vote-btn::before,
  .vote-btn::after {
    transition: none !important;
  }

  .vote-btn:hover::before,
  .vote-btn:active::before {
    transform: translate(0, 0);
  }

  .vote-btn:hover::after,
  .vote-btn:active::after {
    transform: translate(var(--vote-stack-offset), var(--vote-stack-offset));
  }

  .vote-btn:hover .vote-btn-glyph,
  .vote-btn:active .vote-btn-glyph {
    transform: translate(0, 0);
  }
}

@keyframes welcome-branch-draw {
  to {
    stroke-dashoffset: 0;
  }
}

@keyframes welcome-fork-head-in {
  from {
    opacity: 0;
    transform: scale(0.86);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.modal-shell {
  position: fixed;
  inset: 0;
  background: rgba(44, 40, 37, 0.45);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 40;
  padding: 14px;
}

.modal-shell.open {
  display: flex;
}

.modal {
  width: 100%;
  max-width: 430px;
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: 24px;
  box-shadow: var(--shadow-md);
}

.modal h2 {
  margin: 0 0 6px;
  font-size: 24px;
  letter-spacing: -0.01em;
  text-align: center;
}

.modal p {
  margin: 0 0 16px;
  color: var(--text-secondary);
  font-size: 14px;
  text-align: center;
}

.google-btn {
  width: 100%;
  margin: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--radius-md);
  border: 1.5px solid rgba(44, 40, 37, 0.16);
  background: var(--color-white);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
}

.auth-action-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.google-btn-secondary {
  background: var(--color-cream);
}

.auth-signup-panel {
  margin-top: 4px;
}

.auth-signup-panel .checkbox-card {
  margin-top: 12px;
}

.auth-signup-actions {
  margin-top: 0;
}

.auth-signup-actions-secondary {
  margin-top: 10px;
}

.auth-signup-actions .btn {
  width: 100%;
}

.checkbox-card {
  margin-top: 16px;
  background: var(--color-cream);
  border-radius: var(--radius-md);
  padding: 12px;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.checkbox-card input {
  margin-top: 3px;
}

.checkbox-card strong {
  display: block;
  font-size: 14px;
}

.checkbox-card span {
  display: block;
  color: var(--text-tertiary);
  font-size: 12px;
}

.admin-user-search-form {
  margin-bottom: 10px;
}

.admin-ops-links {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.admin-ops-status {
  margin-bottom: 16px;
}

.admin-ops-status-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.admin-user-search-controls {
  display: flex;
  gap: 10px;
  align-items: center;
}

.admin-user-search-controls .form-input {
  max-width: 300px;
}

.admin-sort-row {
  display: flex;
  justify-content: flex-end;
}

.admin-filter-row {
  display: flex;
}

.admin-sort-control {
  display: grid;
  gap: 6px;
  width: min(360px, 100%);
}

.admin-sort-control span {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.admin-data-view {
  margin-top: 6px;
}

.admin-data-view[hidden] {
  display: none !important;
}

.admin-table-wrap {
  overflow-x: auto;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.admin-table th,
.admin-table td {
  text-align: left;
  padding: 10px;
  border-bottom: 1px solid rgba(44, 40, 37, 0.1);
  vertical-align: top;
}

.admin-table th {
  font-size: 11px;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.admin-table .form-input,
.admin-table .form-textarea,
.admin-table .form-select {
  font-size: 13px;
  padding: 9px 10px;
}

.admin-table .form-textarea {
  min-height: 78px;
}

.admin-table .vote-rail-inline {
  min-width: 0;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
}

.admin-action-stack {
  display: grid;
  gap: 8px;
  min-width: 122px;
}

.admin-feedback-row td {
  padding-top: 0;
  border-bottom: 1px solid rgba(44, 40, 37, 0.1);
}

.admin-row-feedback {
  margin: 2px 0 10px;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  font-size: 13px;
}

.admin-row-feedback-ok {
  background: rgba(46, 125, 50, 0.12);
  color: #1f5e24;
}

.admin-row-feedback-error {
  background: rgba(215, 48, 39, 0.11);
  color: #8a1c14;
}

.metrics-toolbar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.metric-card {
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  padding: 14px;
}

.metric-card-highlight {
  background: linear-gradient(135deg, rgba(196, 113, 59, 0.18), rgba(196, 113, 59, 0.06));
}

.metric-label {
  color: var(--text-tertiary);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 6px;
}

.metric-value {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.1;
}

.metric-subtle {
  margin-top: 8px;
  font-size: 12px;
  color: var(--text-secondary);
}

.metrics-chart-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}

.metrics-chart-card {
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  padding: 12px;
}

.metrics-chart-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.metrics-chart-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
}

.metrics-chart-value {
  font-size: 18px;
  font-weight: 700;
}

.metrics-chart-svg {
  width: 100%;
  height: auto;
  display: block;
}

.metrics-chart-footer {
  margin-top: 6px;
  font-size: 11px;
  color: var(--text-tertiary);
  display: flex;
  justify-content: space-between;
}

.conversion-funnel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
}

.conversion-funnel-card {
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(44, 40, 37, 0.12);
  padding: 12px;
}

.conversion-funnel-title {
  margin: 0 0 10px;
  font-size: 14px;
  color: var(--text-secondary);
  font-weight: 700;
}

.conversion-funnel-step {
  position: relative;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(44, 40, 37, 0.14);
  border-radius: 10px;
  padding: 10px 12px;
}

.conversion-funnel-step + .conversion-funnel-step {
  margin-top: 10px;
}

.conversion-funnel-step + .conversion-funnel-step::before {
  content: "";
  position: absolute;
  top: -8px;
  left: 50%;
  width: 2px;
  height: 8px;
  background: rgba(44, 40, 37, 0.22);
  transform: translateX(-50%);
}

.conversion-funnel-step-label {
  font-size: 11px;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 4px;
}

.conversion-funnel-step-value {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.1;
}

.conversion-funnel-step-meta {
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-secondary);
}

.footer {
  margin-top: 34px;
  color: var(--text-tertiary);
  text-align: center;
  font-size: 12px;
}

.mobile-bottom-nav {
  display: none;
}

.mobile-menu-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 42px;
  height: 42px;
  border-radius: 10px;
  border: 1.5px solid rgba(44, 40, 37, 0.18);
  background: var(--color-white);
  padding: 0;
  gap: 4px;
  flex-direction: column;
}

.mobile-menu-toggle-bar {
  display: block;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: var(--color-charcoal);
  transition: transform 140ms ease, opacity 140ms ease;
}

.mobile-menu-toggle.is-open .mobile-menu-toggle-bar:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

.mobile-menu-toggle.is-open .mobile-menu-toggle-bar:nth-child(2) {
  opacity: 0;
}

.mobile-menu-toggle.is-open .mobile-menu-toggle-bar:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

.mobile-nav-btn {
  border: 0;
  background: transparent;
  color: var(--text-tertiary);
  font-family: inherit;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  padding: 8px 6px;
  border-radius: 10px;
}

.mobile-nav-btn.has-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}

.mobile-nav-btn.is-active {
  background: rgba(196, 113, 59, 0.14);
  color: var(--color-charcoal);
}

.mobile-nav-avatar {
  width: 16px;
  height: 16px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(44, 40, 37, 0.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  font-size: 9px;
  font-weight: 700;
  line-height: 1;
  flex: 0 0 auto;
}

.mobile-nav-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.mobile-nav-avatar-fallback {
  background: rgba(44, 40, 37, 0.14);
}

.mobile-nav-label {
  display: block;
  max-width: 84px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0 auto;
}

@media (max-width: 860px) {
  :root {
    --page-gutter: 14px;
  }

  body:not([data-page="welcome"]) {
    padding-bottom: calc(86px + env(safe-area-inset-bottom));
  }

  body:not([data-page="welcome"]) .site-header {
    position: sticky;
    top: calc(env(safe-area-inset-top) + var(--affiliate-banner-height) + 8px);
    align-items: center;
    justify-content: space-between;
    flex-direction: row;
    z-index: 95;
    margin-bottom: 16px;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid rgba(44, 40, 37, 0.12);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 8px 20px rgba(44, 40, 37, 0.12);
    backdrop-filter: blur(8px);
  }

  body:not([data-page="welcome"]) .mobile-menu-toggle {
    display: inline-flex;
  }

  body:not([data-page="welcome"]) .site-header .nav-actions {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    left: auto;
    width: min(320px, calc(100vw - 28px));
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 12px;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(44, 40, 37, 0.12);
    border-radius: 14px;
    box-shadow: 0 10px 24px rgba(44, 40, 37, 0.14);
    z-index: 90;
  }

  body:not([data-page="welcome"]) .site-header .nav-actions.is-mobile-open {
    display: flex;
  }

  body:not([data-page="welcome"]) .site-header .nav-actions .btn,
  body:not([data-page="welcome"]) .site-header .nav-actions .user-pill {
    width: 100%;
  }

  body:not([data-page="welcome"]) .site-header .nav-actions .user-pill {
    justify-content: center;
  }

  .idea-card {
    flex-direction: column;
  }

  .vote-rail {
    min-width: 0;
    flex-direction: row;
    align-items: center;
  }

  .inline-row {
    grid-template-columns: 1fr;
  }

  .profile-danger-zone {
    flex-direction: column;
    align-items: flex-start;
  }

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

  .admin-user-search-controls {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-user-search-controls .form-input {
    max-width: none;
  }

  .admin-sort-row {
    justify-content: stretch;
  }

  .admin-sort-control {
    width: 100%;
    max-width: none;
  }

  #adminContent .panel > div:first-child .nav-actions {
    width: 100%;
    justify-content: flex-start;
  }

  #adminContent .panel > div:first-child .nav-actions .btn,
  #adminContent .panel > div:first-child .nav-actions a.btn {
    flex: 1 1 calc(50% - 10px);
    min-width: 140px;
    text-align: center;
  }

  body[data-page="admin"] #adminContent .panel {
    padding: 16px;
  }

  body[data-page="admin"] #adminDataViewTabs .tab-btn,
  body[data-page="admin"] #adminIdeasTabs .tab-btn,
  body[data-page="admin"] #adminPublicIdeasTabs .tab-btn {
    font-size: 15px;
    padding: 12px 14px;
  }

  body[data-page="admin"] .admin-table-wrap {
    overflow: visible;
  }

  body[data-page="admin"] #adminUsersTable,
  body[data-page="admin"] #adminModerationTable,
  body[data-page="admin"] #adminPublicIdeasTable {
    width: 100%;
    min-width: 0;
    border-collapse: separate;
    border-spacing: 0 10px;
    font-size: 14px;
  }

  body[data-page="admin"] #adminUsersTable thead,
  body[data-page="admin"] #adminModerationTable thead,
  body[data-page="admin"] #adminPublicIdeasTable thead {
    display: none;
  }

  body[data-page="admin"] #adminUsersTable tbody,
  body[data-page="admin"] #adminModerationTable tbody,
  body[data-page="admin"] #adminPublicIdeasTable tbody {
    display: block;
  }

  body[data-page="admin"] #adminUsersTable tr,
  body[data-page="admin"] #adminModerationTable tr,
  body[data-page="admin"] #adminPublicIdeasTable tr {
    display: block;
    border: 1px solid rgba(44, 40, 37, 0.12);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 2px 10px rgba(44, 40, 37, 0.06);
    overflow: hidden;
  }

  body[data-page="admin"] #adminModerationTable tr.admin-feedback-row {
    margin-top: -4px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  body[data-page="admin"] #adminUsersTable td,
  body[data-page="admin"] #adminModerationTable td,
  body[data-page="admin"] #adminPublicIdeasTable td {
    display: grid;
    grid-template-columns: minmax(92px, 36%) minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    padding: 10px 8px;
    border-bottom: 1px dashed rgba(44, 40, 37, 0.12);
    text-align: left;
    word-break: break-word;
  }

  body[data-page="admin"] #adminUsersTable td::before,
  body[data-page="admin"] #adminModerationTable td::before,
  body[data-page="admin"] #adminPublicIdeasTable td::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 700;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.35;
  }

  body[data-page="admin"] #adminUsersTable td:last-child,
  body[data-page="admin"] #adminModerationTable td:last-child,
  body[data-page="admin"] #adminPublicIdeasTable td:last-child {
    border-bottom: 0;
  }

  body[data-page="admin"] #adminUsersTable td[colspan],
  body[data-page="admin"] #adminModerationTable td[colspan],
  body[data-page="admin"] #adminPublicIdeasTable td[colspan] {
    display: block;
    padding: 10px;
    border-bottom: 0;
  }

  body[data-page="admin"] #adminUsersTable td[colspan]::before,
  body[data-page="admin"] #adminModerationTable td[colspan]::before,
  body[data-page="admin"] #adminPublicIdeasTable td[colspan]::before {
    content: none;
  }

  body[data-page="admin"] #adminUsersTable .btn,
  body[data-page="admin"] #adminModerationTable .btn,
  body[data-page="admin"] #adminPublicIdeasTable .btn {
    width: 100%;
  }

  body[data-page="admin"] #adminUsersTable .form-input,
  body[data-page="admin"] #adminModerationTable .form-input,
  body[data-page="admin"] #adminModerationTable .form-select,
  body[data-page="admin"] #adminPublicIdeasTable .form-input,
  body[data-page="admin"] #adminPublicIdeasTable .form-select {
    font-size: 16px;
  }

  body[data-page="admin-metrics"] #adminMetricsContent .panel > div:first-child .nav-actions,
  body[data-page="admin-experiments"] #adminExperimentsContent .panel > div:first-child .nav-actions,
  body[data-page="admin-traffic"] #adminTrafficContent .panel > div:first-child .nav-actions,
  body[data-page="admin-uptime"] #adminUptimeContent .panel > div:first-child .nav-actions {
    width: 100%;
    justify-content: flex-start;
  }

  body[data-page="admin-metrics"] #adminMetricsContent .panel > div:first-child .nav-actions .btn,
  body[data-page="admin-metrics"] #adminMetricsContent .panel > div:first-child .nav-actions a.btn,
  body[data-page="admin-experiments"] #adminExperimentsContent .panel > div:first-child .nav-actions .btn,
  body[data-page="admin-experiments"] #adminExperimentsContent .panel > div:first-child .nav-actions a.btn,
  body[data-page="admin-traffic"] #adminTrafficContent .panel > div:first-child .nav-actions .btn,
  body[data-page="admin-traffic"] #adminTrafficContent .panel > div:first-child .nav-actions a.btn,
  body[data-page="admin-uptime"] #adminUptimeContent .panel > div:first-child .nav-actions .btn,
  body[data-page="admin-uptime"] #adminUptimeContent .panel > div:first-child .nav-actions a.btn {
    flex: 1 1 calc(50% - 10px);
    min-width: 140px;
    text-align: center;
  }

  body[data-page="admin-metrics"] .metrics-toolbar,
  body[data-page="admin-experiments"] .metrics-toolbar,
  body[data-page="admin-traffic"] .metrics-toolbar {
    grid-template-columns: 1fr;
  }

  body[data-page="admin-metrics"] .metrics-grid,
  body[data-page="admin-experiments"] .metrics-grid,
  body[data-page="admin-traffic"] .metrics-grid,
  body[data-page="admin-uptime"] .metrics-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="admin-metrics"] .metrics-chart-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="admin-metrics"] .metrics-chart-card {
    padding: 10px;
  }

  body[data-page="admin-metrics"] .metrics-chart-title {
    font-size: 12px;
  }

  body[data-page="admin-metrics"] .metrics-chart-value {
    font-size: 16px;
  }

  body[data-page="admin-metrics"] .admin-table-wrap,
  body[data-page="admin-traffic"] .admin-table-wrap,
  body[data-page="admin-uptime"] .admin-table-wrap {
    overflow: visible;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top,
  body[data-page="admin-metrics"] .admin-table-metrics-daily,
  body[data-page="admin-traffic"] .admin-table-traffic-top,
  body[data-page="admin-traffic"] .admin-table-traffic-daily {
    width: 100%;
    min-width: 0;
    border-collapse: separate;
    border-spacing: 0 10px;
    font-size: 14px;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top thead,
  body[data-page="admin-metrics"] .admin-table-metrics-daily thead,
  body[data-page="admin-traffic"] .admin-table-traffic-top thead,
  body[data-page="admin-traffic"] .admin-table-traffic-daily thead {
    display: none;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top tbody,
  body[data-page="admin-metrics"] .admin-table-metrics-daily tbody,
  body[data-page="admin-traffic"] .admin-table-traffic-top tbody,
  body[data-page="admin-traffic"] .admin-table-traffic-daily tbody {
    display: block;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top tr,
  body[data-page="admin-metrics"] .admin-table-metrics-daily tr,
  body[data-page="admin-traffic"] .admin-table-traffic-top tr,
  body[data-page="admin-traffic"] .admin-table-traffic-daily tr {
    display: block;
    border: 1px solid rgba(44, 40, 37, 0.12);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 2px 10px rgba(44, 40, 37, 0.06);
    overflow: hidden;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top td,
  body[data-page="admin-metrics"] .admin-table-metrics-daily td,
  body[data-page="admin-traffic"] .admin-table-traffic-top td,
  body[data-page="admin-traffic"] .admin-table-traffic-daily td {
    display: grid;
    grid-template-columns: minmax(112px, 42%) minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    padding: 10px 8px;
    border-bottom: 1px dashed rgba(44, 40, 37, 0.12);
    text-align: left;
    word-break: break-word;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top td::before,
  body[data-page="admin-metrics"] .admin-table-metrics-daily td::before,
  body[data-page="admin-traffic"] .admin-table-traffic-top td::before,
  body[data-page="admin-traffic"] .admin-table-traffic-daily td::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 700;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.35;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top td:last-child,
  body[data-page="admin-metrics"] .admin-table-metrics-daily td:last-child,
  body[data-page="admin-traffic"] .admin-table-traffic-top td:last-child,
  body[data-page="admin-traffic"] .admin-table-traffic-daily td:last-child {
    border-bottom: 0;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top td[colspan],
  body[data-page="admin-metrics"] .admin-table-metrics-daily td[colspan],
  body[data-page="admin-traffic"] .admin-table-traffic-top td[colspan],
  body[data-page="admin-traffic"] .admin-table-traffic-daily td[colspan] {
    display: block;
    padding: 10px;
    border-bottom: 0;
  }

  body[data-page="admin-metrics"] .admin-table-metrics-top td[colspan]::before,
  body[data-page="admin-metrics"] .admin-table-metrics-daily td[colspan]::before,
  body[data-page="admin-traffic"] .admin-table-traffic-top td[colspan]::before,
  body[data-page="admin-traffic"] .admin-table-traffic-daily td[colspan]::before {
    content: none;
  }

  body[data-page="admin-uptime"] .admin-table-uptime-kv {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 10px;
  }

  body[data-page="admin-uptime"] .admin-table-uptime-kv tbody {
    display: block;
  }

  body[data-page="admin-uptime"] .admin-table-uptime-kv tr {
    display: block;
    border: 1px solid rgba(44, 40, 37, 0.12);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 2px 10px rgba(44, 40, 37, 0.06);
    overflow: hidden;
    margin-bottom: 10px;
  }

  body[data-page="admin-uptime"] .admin-table-uptime-kv th,
  body[data-page="admin-uptime"] .admin-table-uptime-kv td {
    display: block;
    width: 100%;
    padding: 8px 10px;
    border-bottom: 1px dashed rgba(44, 40, 37, 0.12);
  }

  body[data-page="admin-uptime"] .admin-table-uptime-kv th {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  body[data-page="admin-uptime"] .admin-table-uptime-kv td {
    border-bottom: 0;
    font-size: 14px;
    color: var(--text-primary);
    word-break: break-word;
  }

  body[data-page="admin-uptime"] #uptimeCommit {
    word-break: break-all;
  }

  .site-affiliate-track {
    gap: 3px;
  }

  .mobile-bottom-nav {
    position: fixed;
    left: 8px;
    right: 8px;
    bottom: 8px;
    z-index: 100;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
    padding: 8px;
    padding-bottom: calc(8px + env(safe-area-inset-bottom));
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(44, 40, 37, 0.12);
    border-radius: 16px;
    box-shadow: 0 10px 28px rgba(44, 40, 37, 0.14);
    backdrop-filter: blur(10px);
  }

  .mobile-bottom-nav.mobile-bottom-nav-3up {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body[data-page="home"] .ideas-live-ticker-panel {
    margin-bottom: 20px;
  }

  body[data-page="home"] .ideas-filter-row {
    margin-bottom: 20px;
  }
}

@media (max-width: 620px) {
  body[data-page="landing"] .landing-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  body[data-page="landing"] .landing-option-card:first-child {
    grid-column: 1 / -1;
  }

  body[data-page="landing"] .landing-option-card {
    padding: 16px;
    gap: 8px;
  }

  body[data-page="landing"] .landing-option-card:not(:first-child) .section-title {
    font-size: clamp(14px, 3.8vw, 17px);
    line-height: 1.28;
  }

  body[data-page="landing"] .landing-option-card:not(:first-child) .landing-subtext,
  body[data-page="landing"] .landing-option-card:not(:first-child) .landing-disclosure {
    font-size: 11px;
  }

  body[data-page="landing"] .landing-option-card:not(:first-child) .soft-3d-title {
    font-size: 17px;
    line-height: 1.2;
  }

  body[data-page="landing"] .landing-option-card:not(:first-child) .soft-3d-sub {
    font-size: 12px;
  }

  .ideas-live-ticker {
    grid-template-columns: 1fr;
  }

  body[data-page="admin-metrics"] .metrics-grid,
  body[data-page="admin-experiments"] .metrics-grid,
  body[data-page="admin-traffic"] .metrics-grid,
  body[data-page="admin-uptime"] .metrics-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="admin-metrics"] .metric-value,
  body[data-page="admin-experiments"] .metric-value,
  body[data-page="admin-traffic"] .metric-value,
  body[data-page="admin-uptime"] .metric-value {
    font-size: 24px;
  }

  body[data-page="welcome"] .container {
    min-height: calc(100vh - env(safe-area-inset-top));
    display: flex;
    flex-direction: column;
    padding-bottom: calc(22px + env(safe-area-inset-bottom));
  }

  body[data-page="welcome"] #welcomeActions.welcome-panel {
    min-height: calc(100vh - 180px);
    display: flex;
    flex-direction: column;
  }

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

  body[data-page="welcome"] #welcomeActions .section-title {
    font-size: 30px;
    line-height: 1.15;
  }

  body[data-page="welcome"] #welcomeActions .welcome-overview {
    font-size: 16px;
    max-width: 100%;
  }

  body[data-page="welcome"] #welcomeActions .welcome-branch {
    margin-bottom: 16px;
  }

  body[data-page="welcome"] #welcomeActions .welcome-branch svg {
    height: 128px;
  }

  body[data-page="welcome"] #welcomeActions .welcome-choice-grid {
    margin-top: auto;
    padding-bottom: 8px;
    gap: 12px;
  }

  body[data-page="welcome"] #welcomeActions .soft-3d-btn {
    --path-rest-x: 0px;
    --path-rest-y: 0px;
    --path-mid-x: 6px;
    --path-mid-y: 6px;
    --path-back-x: 10px;
    --path-back-y: 10px;
    padding: 18px 14px;
    border-radius: 16px;
    transform: translate(0, 0);
    animation: none;
  }

  body[data-page="landing"] .landing-options .soft-3d-btn {
    --path-rest-x: 0px;
    --path-rest-y: 0px;
    --path-mid-x: 6px;
    --path-mid-y: 6px;
    --path-back-x: 10px;
    --path-back-y: 10px;
    padding: 18px 14px;
    border-radius: 16px;
  }

  body[data-page="welcome"] #welcomeActions .soft-3d-title,
  body[data-page="landing"] .landing-options .soft-3d-title {
    font-size: 24px;
  }

  body[data-page="welcome"] #welcomeActions .soft-3d-sub,
  body[data-page="landing"] .landing-options .soft-3d-sub {
    font-size: 13px;
  }
}
