@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Jost:wght@300;400;500&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --sand: #F5EFE0; --sand2: #EDE3CA; --sand3: #D9CBA8;
  --bark: #7A5C3A; --bark2: #5A3E20;
  --moss: #4A6741; --moss2: #2E4229;
  --rust: #9E4A2A; --rust2: #6E2E12;
  --clay: #C4795A; --gold: #B8872A; --gold2: #8A5E10;
  --ink: #1E1A14; --mist: #F9F5EE; --stone: #8A7E6C;
}

body {
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  background: var(--sand);
  color: var(--ink);
  min-height: 100vh;
}
body::before {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 0;
}

.page { position: relative; z-index: 1; max-width: 960px; margin: 0 auto; padding: 48px 24px; }

/* Header */
header { text-align: center; margin-bottom: 48px; }
header .eyebrow { font-family: 'Jost', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--stone); margin-bottom: 12px; }
header h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(36px, 6vw, 56px); font-weight: 300; color: var(--bark2); line-height: 1.1; }
header h1 em { font-style: italic; color: var(--rust); }
header p { margin-top: 14px; font-size: 15px; color: var(--stone); max-width: 520px; margin-left: auto; margin-right: auto; line-height: 1.7; }

/* Tabs */
.tab-bar { display: flex; gap: 0; border-bottom: 2px solid var(--sand3); margin-bottom: 32px; overflow: visible; }
.tab-btn {
  padding: 12px 20px; font-family: 'Jost', sans-serif; font-size: 13px; font-weight: 500;
  letter-spacing: .05em; text-transform: uppercase; color: var(--stone);
  background: none; border: none; border-bottom: 3px solid transparent;
  cursor: pointer; transition: all .2s; white-space: nowrap;
}
.tab-btn:hover { color: var(--bark2); }
.tab-btn.active { color: var(--bark2); border-bottom-color: var(--rust); }
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* Personality assessments — tab bar dropdown */
.tab-dropdown {
  position: relative;
  flex-shrink: 0;
  align-self: flex-end;
}
.tab-dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--stone);
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  cursor: pointer;
  transition: color .2s, border-color .2s;
  white-space: nowrap;
}
.tab-dropdown-toggle:hover { color: var(--bark2); }
.tab-dropdown.is-active .tab-dropdown-toggle,
.tab-dropdown-toggle.active {
  color: var(--bark2);
  border-bottom-color: var(--rust);
}
.tab-dropdown-chevron {
  font-size: 9px;
  opacity: 0.8;
  line-height: 1;
}
.tab-dropdown-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 280px;
  margin: 0;
  padding: 8px 0;
  background: #fff;
  border: 1px solid var(--sand3);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(30, 26, 20, 0.14);
  z-index: 3000;
}
.tab-dropdown-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 11px 20px;
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--ink);
  background: none;
  border: none;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.tab-dropdown-item:hover {
  background: var(--sand2);
  color: var(--bark2);
}
.assessment-active-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 400;
  color: var(--bark2);
  margin-bottom: 20px;
}
.assessment-placeholder {
  font-size: 15px;
  line-height: 1.65;
  color: var(--stone);
  margin: 0;
}

/* Personality suite (Likert + Clifton-style pairs) */
.personality-assessment-card {
  margin-bottom: 0;
}
.personality-assessment-hint,
.personality-assessment-intro,
.personality-assessment-loading {
  font-size: 14px;
  line-height: 1.65;
  color: var(--stone);
  margin: 0 0 16px 0;
}
.personality-assessment-error {
  color: #a33;
  font-size: 14px;
  margin: 0;
}
.personality-quiz-stage {
  margin-top: 8px;
}
.personality-fc-vs {
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  color: var(--bark2);
  margin: 12px 0 16px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.personality-fc-row {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.personality-fc-btn {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  width: 100%;
  padding: 16px 18px;
  font-family: 'Jost', sans-serif;
  text-align: left;
  border: 2px solid var(--sand3);
  border-radius: 12px;
  background: #fff;
  color: var(--bark2);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}
.personality-fc-btn:hover {
  border-color: var(--bark);
  background: var(--sand2);
}
.personality-fc-theme {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--stone);
}
.personality-fc-text {
  font-size: 15px;
  line-height: 1.5;
  font-weight: 400;
}
.personality-scale-labels {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--stone);
  margin: 8px 0 10px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.personality-scale-btns {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.personality-scale-btn {
  flex: 1;
  min-width: 44px;
  padding: 12px 8px;
  font-family: 'Jost', sans-serif;
  font-size: 15px;
  font-weight: 500;
  border: 2px solid var(--sand3);
  border-radius: 10px;
  background: #fff;
  color: var(--bark2);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}
.personality-scale-btn:hover {
  border-color: var(--bark);
  background: var(--sand2);
}
.personality-result-wrap {
  margin-top: 4px;
}
.personality-result-h {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  font-weight: 400;
  color: var(--bark2);
  margin: 0 0 12px 0;
}
.personality-result-list {
  margin: 0;
  padding-left: 1.2em;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.55;
}
.personality-result-list li {
  margin-bottom: 10px;
}
.personality-career-fits {
  font-size: 14px;
  line-height: 1.6;
  color: var(--stone);
  margin-top: 12px;
}
.personality-disclaimer {
  font-size: 12px;
  color: var(--stone);
  margin-top: 12px;
}
.personality-result-actions {
  margin-top: 20px;
}
.personality-retake-btn {
  padding: 12px 24px;
  font-size: 13px;
}
.personality-result-raw {
  font-size: 12px;
  overflow-x: auto;
  background: var(--mist);
  padding: 12px;
  border-radius: 8px;
  border: 1px solid var(--sand3);
}

/* Form */
.form-card { background: var(--mist); border: 1px solid var(--sand3); border-radius: 16px; padding: 36px; margin-bottom: 40px; }
.form-title { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 400; color: var(--bark2); margin-bottom: 24px; display: flex; align-items: center; gap: 10px; }
.form-title::after { content: ''; flex: 1; height: 1px; background: var(--sand3); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.form-grid .span2 { grid-column: span 2; }
.form-grid .span3 { grid-column: span 3; }
.field { display: flex; flex-direction: column; gap: 6px; }
label { font-size: 11px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--stone); }
input, select {
  background: white; border: 1px solid var(--sand3); border-radius: 8px;
  padding: 10px 14px; font-family: 'Jost', sans-serif; font-size: 14px; font-weight: 300;
  color: var(--ink); outline: none; transition: border-color .2s;
}
input:focus, select:focus { border-color: var(--bark); }
.optional { font-size: 10px; font-weight: 400; color: var(--stone); margin-left: 4px; text-transform: none; letter-spacing: 0; }
/* Google Places autocomplete dropdown — ensure it appears above form */
.pac-container {
  z-index: 10000;
  font-family: 'Jost', sans-serif;
  border-radius: 8px;
  border: 1px solid var(--sand3);
  box-shadow: 0 4px 20px rgba(30, 26, 20, 0.12);
  margin-top: 4px;
}
.pac-item { padding: 10px 14px; font-size: 14px; cursor: pointer; }
.pac-item:hover { background: var(--sand2); }
.pac-item-query { font-weight: 400; color: var(--ink); }
.field-hint { font-size: 11px; color: var(--stone); margin-top: 2px; }

.calc-btn {
  width: 100%; margin-top: 24px;
  background: var(--bark2); color: var(--sand);
  border: none; border-radius: 10px; padding: 16px;
  font-family: 'Jost', sans-serif; font-size: 14px; font-weight: 500;
  letter-spacing: .1em; text-transform: uppercase; cursor: pointer;
  transition: background .2s, transform .1s;
}
.calc-btn:hover { background: var(--rust2); }
.calc-btn:active { transform: scale(0.99); }
.calc-btn:disabled { background: var(--stone); cursor: not-allowed; }
.calc-btn-step2 {
  margin-top: 0; margin-bottom: 0;
  background: linear-gradient(135deg, var(--bark2), var(--rust2));
  letter-spacing: .06em;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  text-transform: none;
}
.calc-btn-step2:hover { background: linear-gradient(135deg, var(--rust2), var(--bark2)); }
.calc-btn-step2 .step2-btn-primary {
  font-size: 15px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; line-height: 1.25;
}
.calc-btn-step2 .step2-btn-secondary {
  display: block; font-size: 12px; font-weight: 400; letter-spacing: .03em;
  text-transform: none; opacity: 0.88; line-height: 1.35; max-width: 36rem;
}
.calc-btn-step2--buy {
  background: linear-gradient(135deg, var(--rust), var(--rust2));
}
.calc-btn-step2--buy:hover { background: linear-gradient(135deg, var(--rust2), var(--rust)); }

/* Spinner */
.spinner { display: none; text-align: center; padding: 48px; }
.spinner.active { display: block; }
.spinner::after {
  content: ''; display: inline-block; width: 40px; height: 40px;
  border: 3px solid var(--sand3); border-top-color: var(--rust);
  border-radius: 50%; animation: spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Results */
#results { display: none; }

/* Discourage selecting/copying profile grids (frontend-only; bypassable via devtools, screenshots, etc.) */
.results-discourage-copy {
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}
.results-discourage-copy input,
.results-discourage-copy textarea,
.results-discourage-copy [contenteditable="true"] {
  -webkit-user-select: text;
  user-select: text;
  -webkit-touch-callout: default;
}
.results-discourage-copy ::selection {
  background: transparent;
  color: inherit;
}
.results-discourage-copy ::-moz-selection {
  background: transparent;
  color: inherit;
}
@media print {
  .results-discourage-copy,
  .results-discourage-copy * {
    -webkit-user-select: text !important;
    user-select: text !important;
  }
  .results-discourage-copy ::selection,
  .results-discourage-copy ::-moz-selection {
    background: highlight;
    color: highlighttext;
  }
}
.results-header { font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 300; color: var(--bark2); margin-bottom: 6px; }
.results-sub { font-size: 13px; color: var(--stone); margin-bottom: 32px; }
.results-sub strong { color: var(--rust); font-weight: 500; }

.section-label {
  font-size: 11px; font-weight: 500; letter-spacing: .15em; text-transform: uppercase;
  color: var(--stone); margin: 36px 0 14px; display: flex; align-items: center; gap: 12px;
}
.section-label::after { content: ''; flex: 1; height: 1px; background: var(--sand3); }

.systems-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }

.sys-about {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--sand3);
  font-size: 12px;
  line-height: 1.55;
  color: var(--stone);
}

.sys-card {
  background: var(--mist); border: 1px solid var(--sand3); border-radius: 14px;
  padding: 22px; position: relative; overflow: hidden;
  transition: transform .2s, box-shadow .2s;
}
.sys-card:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(90,62,32,.1); }
.sys-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; }
.sys-card.cat-astro::before { background: linear-gradient(90deg, var(--gold), var(--rust)); }
.sys-card.cat-num::before { background: linear-gradient(90deg, var(--moss), var(--moss2)); }
.sys-card.cat-person::before { background: linear-gradient(90deg, var(--bark), var(--bark2)); }
.sys-card.cat-symbol::before { background: linear-gradient(90deg, var(--clay), var(--rust)); }

.sys-label { font-size: 10px; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: var(--stone); margin-bottom: 8px; }
.sys-name { font-family: 'Cormorant Garamond', serif; font-size: 18px; font-weight: 500; color: var(--bark2); margin-bottom: 12px; }
.primary-result { display: flex; align-items: baseline; gap: 10px; margin-bottom: 10px; }
.primary-value { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 400; color: var(--rust); }
.primary-sub { font-size: 12px; color: var(--stone); }
.secondary-value { font-size: 13px; color: var(--bark); font-weight: 400; }

.detail-rows { margin-top: 10px; border-top: 1px solid var(--sand3); padding-top: 10px; }
.detail-row { display: flex; justify-content: space-between; gap: 8px; padding: 4px 0; font-size: 12px; }
.detail-label { color: var(--stone); flex-shrink: 0; }
.detail-val { color: var(--ink); text-align: right; }

.note-badge { font-size: 10px; color: var(--gold2); background: #FFF8E8; border: 1px solid var(--sand3); border-radius: 6px; padding: 4px 8px; margin-top: 10px; line-height: 1.5; }
button.note-badge-expand {
  display: block;
  width: 100%;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: background .15s, border-color .15s;
}
button.note-badge-expand:hover {
  background: #fff3d6;
  border-color: var(--rust);
  color: var(--bark2);
}
button.note-badge-expand:focus-visible {
  outline: 2px solid var(--rust);
  outline-offset: 2px;
}

/* ── Soul Contract AI Reading ── */
.soul-contract-input-preview {
  margin-bottom: 20px;
}
.soul-contract-input-preview[hidden] {
  display: none !important;
}
.soul-contract-input-preview-inner {
  background: var(--mist);
  border: 1px solid var(--sand3);
  border-radius: 14px;
  padding: 18px 20px 20px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}
.sc-preview-lead {
  font-size: 14px;
  font-weight: 500;
  color: var(--bark2);
  margin: 0 0 10px 0;
  line-height: 1.45;
}
.sc-preview-total-line {
  font-size: 15px;
  color: var(--ink);
  margin: 0 0 12px 0;
  line-height: 1.4;
}
.sc-preview-total-num {
  font-weight: 700;
  color: var(--rust);
  font-size: 18px;
  margin-right: 4px;
}
.sc-preview-total-sub {
  font-size: 13px;
  color: var(--stone);
  font-weight: 400;
}
.sc-preview-brief {
  font-size: 14px;
  color: var(--bark2);
  margin: 0 0 16px 0;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--sand3);
  line-height: 1.5;
}
.sc-preview-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 28px;
}
@media (max-width: 720px) {
  .sc-preview-columns {
    grid-template-columns: 1fr;
  }
}
.sc-preview-h {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--stone);
  margin: 0 0 10px 0;
}
.sc-preview-ul {
  margin: 0;
  padding-left: 1.2em;
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink);
}
.sc-preview-ul li {
  margin-bottom: 4px;
}
.sc-preview-w {
  font-size: 11px;
  color: var(--stone);
  font-weight: 500;
}
.sc-preview-col--optional .sc-preview-col-note {
  font-size: 12px;
  color: var(--stone);
  margin: -4px 0 12px 0;
  line-height: 1.45;
}
.sc-preview-addon-ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sc-preview-addon-ul--extra {
  margin-top: 12px;
}
.sc-preview-expand-toggle {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  width: 100%;
  margin-top: 12px;
  padding: 12px 14px;
  text-align: left;
  font: inherit;
  cursor: pointer;
  border: 1px dashed var(--sand3);
  border-radius: 10px;
  background: var(--sand2);
  color: var(--ink);
  transition: background 0.15s ease, border-color 0.15s ease;
}
.sc-preview-expand-toggle:hover {
  background: #e0d9cc;
  border-color: #c4bba8;
}
.sc-preview-expand-toggle:focus-visible {
  outline: 2px solid var(--bark2);
  outline-offset: 2px;
}
.sc-preview-expand-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--bark2);
}
.sc-preview-expand-sub {
  font-size: 11px;
  color: var(--stone);
  line-height: 1.35;
}
.sc-preview-row {
  margin-bottom: 12px;
  padding: 10px 12px;
  background: #fff;
  border: 1px solid var(--sand3);
  border-radius: 10px;
}
.sc-preview-row:last-child {
  margin-bottom: 0;
}
.sc-preview-row--done {
  border-left: 3px solid #5a7d5a;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
}
.sc-preview-row--pending {
  background: linear-gradient(180deg, #ebe6dc 0%, #e4dfd4 100%);
  border: 1px dashed var(--sand3);
  opacity: 0.92;
  border-left: 3px solid #b8b0a4;
}
.sc-preview-row--pending .sc-preview-name {
  color: var(--stone);
}
.sc-preview-row--nav.sc-preview-row--pending {
  cursor: pointer;
}
.sc-preview-row--nav.sc-preview-row--pending:hover {
  border-color: #b8a990;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.sc-preview-row--nav.sc-preview-row--pending:focus-visible {
  outline: 2px solid var(--bark2);
  outline-offset: 2px;
}
.sc-preview-pending-msg {
  display: block;
  font-size: 12px;
  color: var(--stone);
  font-style: italic;
  margin-bottom: 4px;
}
.sc-preview-pending-hint {
  display: block;
  font-size: 11px;
  color: #9a9080;
  letter-spacing: 0.02em;
}
.sc-preview-name {
  display: block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bark2);
  margin-bottom: 4px;
}
.sc-preview-val {
  display: block;
  font-size: 13px;
  color: var(--ink);
}
.sc-preview-blurb {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--sand3);
  font-size: 12px;
  line-height: 1.5;
  color: var(--stone);
}
.sc-preview-none {
  font-size: 13px;
  line-height: 1.55;
  color: var(--stone);
  margin: 0;
  padding: 12px;
  background: var(--sand2);
  border-radius: 10px;
  border: 1px dashed var(--sand3);
}

.soul-contract-card {
  background: var(--mist);
  border: 1px solid var(--sand3);
  border-radius: 18px;
  overflow: hidden;
  position: relative;
  margin-bottom: 8px;
}
.soul-contract-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--rust), var(--gold), var(--clay), var(--moss));
}

.soul-contract-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 72px 32px;
  gap: 24px;
}
.soul-contract-orb {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: radial-gradient(circle at 40% 40%, var(--gold), var(--rust2));
  animation: orb-breathe 2.4s ease-in-out infinite;
  box-shadow: 0 0 30px rgba(184, 135, 42, 0.25);
}
@keyframes orb-breathe {
  0%, 100% { transform: scale(1); opacity: 0.8; }
  50% { transform: scale(1.15); opacity: 1; }
}
.soul-contract-loading-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 400;
  color: var(--bark);
  font-style: italic;
}
.loading-dots::after {
  content: '';
  animation: dots 1.5s steps(4, end) infinite;
}
@keyframes dots {
  0%  { content: ''; }
  25% { content: '.'; }
  50% { content: '..'; }
  75% { content: '...'; }
}

.sc-input-stats {
  margin-bottom: 18px;
  padding: 14px 18px 16px;
  background: linear-gradient(135deg, var(--sand2), var(--sand));
  border: 1px solid var(--sand3);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sc-input-stats-head {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sc-input-stats-total {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--rust);
}
.sc-input-stats-sub {
  font-size: 12px;
  color: var(--stone);
  line-height: 1.45;
  font-weight: 400;
  letter-spacing: 0.02em;
}
.sc-input-stats-brief {
  font-size: 14px;
  color: var(--bark2);
  line-height: 1.5;
  padding-bottom: 4px;
  border-bottom: 1px dashed var(--sand3);
}
.sc-input-stats-section {
  margin-top: 2px;
}
.sc-input-stats-h {
  display: block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--stone);
  margin-bottom: 8px;
}
.sc-input-stats-list {
  margin: 0;
  padding-left: 1.2em;
  font-size: 13px;
  color: var(--ink);
  line-height: 1.55;
}
.sc-input-stats-list li {
  margin-bottom: 4px;
}
.sc-input-stats-w {
  font-size: 11px;
  color: var(--stone);
  font-weight: 500;
}
.sc-input-stats-fallback {
  font-size: 13px;
  color: var(--stone);
  margin: 0;
  line-height: 1.5;
}
.sc-input-stats-breakdown {
  font-size: 13px;
  color: var(--stone);
  line-height: 1.55;
}
.sc-input-stats-cache {
  font-size: 12px;
  color: var(--bark);
  font-weight: 500;
  line-height: 1.45;
  margin-top: 4px;
}
.sc-input-stats-section--addons {
  border-top: 1px solid var(--sand3);
  padding-top: 12px;
  margin-top: 4px;
}
.sc-input-stats-addon-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sc-input-stats-row {
  margin: 0 0 14px 0;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid var(--sand3);
  border-radius: 10px;
}
.sc-input-stats-row:last-child {
  margin-bottom: 0;
}
.sc-input-stats-row--muted {
  background: var(--sand2);
  opacity: 0.95;
}
.sc-input-stats-row-name {
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bark2);
  margin-bottom: 4px;
}
.sc-input-stats-row-val {
  display: block;
  font-size: 13px;
  color: var(--ink);
}
.sc-input-stats-row-blurb {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--sand3);
}
.sc-input-stats-row-detail {
  font-size: 13px;
  line-height: 1.55;
  color: var(--stone);
  font-weight: 400;
}
.sc-input-stats-none {
  font-size: 13px;
  line-height: 1.6;
  color: var(--stone);
  margin: 0;
  padding: 12px 14px;
  background: var(--mist);
  border-radius: 10px;
  border: 1px dashed var(--sand3);
}

.sc-share-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  padding: 12px 36px 18px;
  border-bottom: 1px solid var(--sand3);
  background: var(--mist);
}
.sc-share-btn {
  font-family: 'Jost', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 10px 16px;
  border-radius: 8px;
  border: 1px solid var(--sand3);
  background: #fff;
  color: var(--bark2);
  cursor: pointer;
  transition: background .2s, border-color .2s;
}
.sc-share-btn:hover {
  background: var(--sand2);
  border-color: var(--bark);
}
.sc-share-btn-secondary {
  background: var(--sand2);
}
.sc-share-status {
  font-size: 12px;
  color: var(--stone);
  line-height: 1.4;
  flex: 1 1 220px;
  min-width: 0;
}

.sc-header {
  padding: 32px 36px 24px;
  border-bottom: 1px solid var(--sand3);
}
.sc-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--stone);
  margin-bottom: 8px;
}
.sc-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  font-weight: 400;
  color: var(--bark2);
  line-height: 1.2;
}
.sc-summary {
  font-size: 15px;
  color: var(--bark);
  margin-top: 16px;
  line-height: 1.8;
  font-style: italic;
  border-left: 3px solid var(--gold);
  padding-left: 16px;
}

.sc-sections {
  display: flex;
  flex-direction: column;
}
.sc-section {
  padding: 24px 36px;
  border-bottom: 1px solid var(--sand3);
}
.sc-section:last-child { border-bottom: none; }
.sc-section-title {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--stone);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.sc-icon {
  color: var(--rust);
  font-size: 12px;
}
.sc-section-body {
  font-size: 14px;
  color: var(--ink);
  line-height: 1.85;
}

.sc-closing {
  padding: 24px 36px;
  background: linear-gradient(135deg, #FFF8E8, #FDF6E3);
  border-top: 1px solid var(--sand3);
  font-size: 14px;
  color: var(--gold2);
  line-height: 1.8;
  font-style: italic;
}

/* Soul Contract follow-up chat */
.sc-chat-wrap {
  padding: 20px 36px 24px;
  border-top: 1px solid var(--sand3);
  background: var(--sand);
  border-radius: 0 0 18px 18px;
}
.sc-chat-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--stone);
  margin-bottom: 12px;
}
.sc-chat-meta {
  font-size: 12px;
  color: var(--stone);
  line-height: 1.5;
  margin: -4px 0 12px 0;
}
.sc-chat-log {
  max-height: 280px;
  overflow-y: auto;
  margin-bottom: 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.sc-chat-msg {
  padding: 12px 16px;
  border-radius: 12px;
  font-size: 14px;
  line-height: 1.65;
  max-width: 92%;
  white-space: pre-wrap;
  word-break: break-word;
}
.sc-chat-msg-user {
  align-self: flex-end;
  background: var(--bark2);
  color: var(--sand);
}
.sc-chat-msg-assistant {
  align-self: flex-start;
  background: var(--mist);
  border: 1px solid var(--sand3);
  color: var(--ink);
}
.sc-chat-msg-error {
  color: var(--rust);
}
.sc-chat-form {
  display: flex;
  gap: 10px;
}
.sc-chat-input {
  flex: 1;
  background: white;
  border: 1px solid var(--sand3);
  border-radius: 10px;
  padding: 12px 16px;
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  color: var(--ink);
  outline: none;
  transition: border-color .2s;
}
.sc-chat-input:focus {
  border-color: var(--bark);
}
.sc-chat-btn {
  flex-shrink: 0;
  padding: 12px 20px;
  background: var(--bark2);
  color: var(--sand);
  border: none;
  border-radius: 10px;
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .06em;
  cursor: pointer;
  transition: background .2s;
}
.sc-chat-btn:hover:not(:disabled) {
  background: var(--rust);
}
.sc-chat-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

@media (max-width: 600px) {
  .sc-header, .sc-section, .sc-closing, .sc-share-toolbar { padding-left: 20px; padding-right: 20px; }
  .sc-chat-wrap { padding-left: 20px; padding-right: 20px; }
  .sc-title { font-size: 22px; }
}

/* BaZi pillars */
.pillar-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 8px; }
.bazi-about-wrap {
  grid-column: 1 / -1;
}
.pillar { background: white; border: 1px solid var(--sand3); border-radius: 10px; padding: 14px 12px; text-align: center; }
.pillar-title { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--stone); margin-bottom: 8px; }
.pillar-stem { font-family: 'Cormorant Garamond', serif; font-size: 18px; color: var(--bark2); margin-bottom: 4px; }
.pillar-branch { font-size: 11px; color: var(--rust); }
.pillar-el { font-size: 10px; color: var(--stone); margin-top: 4px; }

/* Natal chart aspects list */
.aspect-list { list-style: none; padding: 0; margin-top: 8px; }
.aspect-list li { font-size: 12px; padding: 3px 0; display: flex; gap: 6px; }
.aspect-symbol { width: 16px; text-align: center; }

/* MBTI Quiz */
.quiz-card { background: var(--mist); border: 1px solid var(--sand3); border-radius: 16px; padding: 32px; }
.quiz-progress { font-size: 11px; color: var(--stone); letter-spacing: .1em; text-transform: uppercase; margin-bottom: 16px; }

/* Shared progress bar (MBTI + personality Likert / Clifton pairs) */
.assessment-quiz-progress-wrap {
  margin-bottom: 20px;
}
.assessment-quiz-progress-label {
  font-size: 11px;
  color: var(--stone);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.assessment-quiz-progress-track {
  height: 10px;
  border-radius: 999px;
  background: var(--sand3);
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.06);
}
.assessment-quiz-progress-fill {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--bark), var(--bark2));
  transition: width 0.28s ease-out;
}
@media (prefers-reduced-motion: reduce) {
  .assessment-quiz-progress-fill {
    transition: none;
  }
}

/* Assessment context (popularity / science / description) — below quiz card */
.assessment-panel-context {
  margin-top: 24px;
}
.assessment-context-inner {
  background: var(--mist);
  border: 1px solid var(--sand3);
  border-radius: 14px;
  padding: 20px 22px 18px;
  max-width: 920px;
}
.assessment-context-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 500;
  color: var(--bark2);
  margin: 0 0 12px 0;
  line-height: 1.25;
}
.assessment-context-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}
.assessment-context-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--sand2);
  color: var(--bark2);
  border: 1px solid var(--sand3);
}
.assessment-context-tag--science {
  background: rgba(45, 90, 72, 0.12);
  border-color: rgba(45, 90, 72, 0.25);
  color: #2d5a48;
}
.assessment-context-tag--caution {
  background: rgba(140, 90, 40, 0.12);
  border-color: rgba(140, 90, 40, 0.28);
  color: #6b4a22;
}
.assessment-context-meters {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 24px;
  margin-bottom: 18px;
}
@media (max-width: 520px) {
  .assessment-context-meters {
    grid-template-columns: 1fr;
  }
}
.assessment-context-meter-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 6px;
}
.assessment-context-meter-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--stone);
}
.assessment-context-meter-value {
  font-family: 'Jost', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--bark2);
}
.assessment-context-meter-max {
  font-size: 12px;
  font-weight: 500;
  color: var(--stone);
  margin-left: 2px;
}
.assessment-context-meter-track {
  height: 8px;
  border-radius: 999px;
  background: var(--sand3);
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.05);
}
.assessment-context-meter-fill {
  height: 100%;
  border-radius: 999px;
  transition: width 0.35s ease-out;
}
.assessment-context-meter-fill--pop {
  background: linear-gradient(90deg, #7a6a58, var(--bark));
}
.assessment-context-meter-fill--science {
  background: linear-gradient(90deg, #3d6b5c, #2d5a48);
}
.assessment-context-desc {
  border-top: 1px solid var(--sand3);
  padding-top: 16px;
  margin-top: 2px;
}
.assessment-context-p {
  font-size: 14px;
  line-height: 1.65;
  color: var(--ink);
  margin: 0 0 12px 0;
}
.assessment-context-p:last-child {
  margin-bottom: 0;
}
.assessment-context-note {
  font-size: 11px;
  color: var(--stone);
  font-style: italic;
  margin: 14px 0 0 0;
  line-height: 1.5;
}
@media (prefers-reduced-motion: reduce) {
  .assessment-context-meter-fill {
    transition: none;
  }
}
.quiz-question { font-family: 'Cormorant Garamond', serif; font-size: 22px; color: var(--bark2); margin-bottom: 24px; line-height: 1.4; }
.quiz-option {
  display: block; width: 100%; text-align: left; padding: 16px 20px; margin-bottom: 12px;
  background: white; border: 2px solid var(--sand3); border-radius: 10px;
  font-family: 'Jost', sans-serif; font-size: 14px; color: var(--ink); cursor: pointer;
  transition: border-color .2s, background .2s;
}
.quiz-option:hover { border-color: var(--bark); background: var(--sand); }

.mbti-result-actions {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.palm-result-actions {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--sand3);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.palm-saved-note {
  font-size: 12px;
  color: var(--stone);
  line-height: 1.5;
  margin: 0 0 16px 0;
  padding: 10px 12px;
  background: var(--sand2);
  border: 1px solid var(--sand3);
  border-radius: 10px;
}

/* Palm upload */
.palm-credit-note {
  font-size: 13px; color: var(--stone); line-height: 1.55; margin: 0 0 16px;
}
.palm-credit-note strong { color: var(--bark); font-weight: 600; }
.calc-btn-palm {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  text-transform: none; letter-spacing: .04em;
}
.calc-btn-palm .palm-btn-primary {
  font-size: 14px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
}
.calc-btn-palm .palm-btn-sub {
  font-size: 12px; font-weight: 400; opacity: 0.92; text-transform: none; letter-spacing: .03em;
  line-height: 1.35; max-width: 28rem; text-align: center;
}

.palm-upload-area {
  border: 2px dashed var(--sand3); border-radius: 16px; padding: 48px; text-align: center;
  cursor: pointer; transition: border-color .2s, background .2s;
}
.palm-upload-area:hover { border-color: var(--bark); background: var(--sand); }
.palm-upload-area p { font-size: 14px; color: var(--stone); margin-top: 12px; }
.palm-upload-area .big-icon { font-size: 48px; color: var(--sand3); }
.palm-upload-actions {
  display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: 20px;
}
.palm-upload-action-btn { padding: 10px 20px; font-size: 13px; }
.palm-upload-action-secondary {
  background: var(--mist) !important; color: var(--bark2) !important;
  border: 2px solid var(--sand3);
}
.palm-upload-action-secondary:hover {
  background: var(--sand) !important; border-color: var(--bark);
}

/* Palm camera modal */
.palm-camera-modal {
  position: fixed; inset: 0; z-index: 10050;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .2s, visibility .2s;
}
.palm-camera-modal.active {
  opacity: 1; visibility: visible; pointer-events: auto;
}
.palm-camera-backdrop {
  position: absolute; inset: 0; background: rgba(40, 32, 28, 0.55); cursor: pointer;
}
.palm-camera-panel {
  position: relative; z-index: 1; max-width: 520px; width: 100%;
  background: var(--mist); border: 1px solid var(--sand3); border-radius: 16px;
  padding: 24px; box-shadow: 0 20px 50px rgba(0,0,0,.2);
}
.palm-camera-title {
  font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 500;
  color: var(--bark2); margin: 0 0 8px 0;
}
.palm-camera-hint {
  font-size: 13px; color: var(--stone); line-height: 1.5; margin: 0 0 16px 0;
}
.palm-camera-video-wrap {
  border-radius: 12px; overflow: hidden; background: #1a1a1a;
  aspect-ratio: 4 / 3; max-height: 55vh;
}
.palm-camera-video {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.palm-camera-canvas { display: none; }
.palm-camera-error {
  font-size: 13px; color: #a63d2d; margin: 12px 0 0 0;
}
.palm-camera-actions {
  display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; justify-content: flex-end;
}

.palm-preview { max-width: 300px; border-radius: 12px; margin: 16px auto; display: block; }
.palm-result { margin-top: 24px; }
.palm-error {
  background: #FFF8E8; border: 1px solid var(--sand3); border-radius: 12px;
  padding: 20px; font-size: 14px; line-height: 1.6;
}
.palm-error strong { display: block; margin-bottom: 8px; color: var(--bark2); }
.palm-error p { margin: 0 0 8px 0; color: var(--ink); }
.palm-error-raw { font-size: 12px; color: var(--stone); margin-top: 12px !important; }

/* Palm full result layout */
.palm-full-result { display: flex; flex-direction: column; gap: 0; }
.palm-section {
  padding: 24px; border-bottom: 1px solid var(--sand3);
  background: var(--mist); border-radius: 0;
}
.palm-section:first-child { border-radius: 14px 14px 0 0; }
.palm-section-last { border-bottom: none; border-radius: 0 0 14px 14px; }
.palm-section-title {
  font-size: 10px; font-weight: 500; letter-spacing: .15em; text-transform: uppercase;
  color: var(--stone); margin-bottom: 14px;
}

/* Hand type */
.palm-hand-type { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; }
.palm-hand-badge {
  font-family: 'Cormorant Garamond', serif; font-size: 28px; font-weight: 400; color: var(--rust);
}
.palm-hand-traits { font-size: 13px; color: var(--bark); font-weight: 400; }
.palm-hand-obs { font-size: 12px; color: var(--stone); line-height: 1.6; margin-top: 4px; }

/* Lines grid */
.palm-lines-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.palm-line-block {
  background: white; border: 1px solid var(--sand3); border-radius: 10px; padding: 14px;
}
.palm-line-name {
  font-size: 11px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
  color: var(--stone); margin-bottom: 8px;
}
.palm-line-chars { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
.palm-tag {
  display: inline-block; font-size: 10px; padding: 2px 7px;
  background: var(--sand2); border: 1px solid var(--sand3); border-radius: 20px;
  color: var(--bark2); white-space: nowrap;
}
.palm-line-desc { font-size: 12px; color: var(--stone); line-height: 1.5; margin-bottom: 6px; }
.palm-line-meaning { font-size: 12px; color: var(--ink); line-height: 1.6; }

/* Mounts grid */
.palm-mounts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.palm-mount-item {
  background: white; border: 1px solid var(--sand3); border-radius: 10px;
  padding: 10px 12px;
}
.palm-mount-name {
  font-size: 10px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
  color: var(--stone); margin-bottom: 4px;
}
.palm-mount-val { font-size: 12px; color: var(--ink); line-height: 1.5; }

/* Overall & soul insight */
.palm-overall { font-size: 14px; line-height: 1.7; color: var(--ink); margin-bottom: 14px; }
.palm-soul-insight {
  font-size: 13px; color: var(--gold2); background: #FFF8E8;
  border: 1px solid var(--sand3); border-radius: 8px; padding: 12px 14px; line-height: 1.6;
  font-style: italic;
}

@media (max-width: 600px) {
  .palm-lines-grid { grid-template-columns: 1fr; }
  .palm-mounts-grid { grid-template-columns: 1fr 1fr; }
}

/* Globe button (in Astrocartography card) */
.globe-btn {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 12px; padding: 10px 18px;
  background: var(--bark); color: var(--sand);
  border: none; border-radius: 10px;
  font-family: 'Jost', sans-serif; font-size: 12px; font-weight: 500;
  letter-spacing: .08em; text-transform: uppercase; cursor: pointer;
  transition: background .2s, transform .1s;
}
.globe-btn:hover { background: var(--rust); }
.globe-btn:active { transform: scale(0.98); }
.globe-btn svg { width: 18px; height: 18px; opacity: 0.9; }

/* Globe inline tab */
.globe-inline-header {
  padding: 20px 24px 12px;
  border-bottom: 1px solid var(--sand3);
  background: var(--mist);
  border-radius: 20px 20px 0 0;
}
.globe-inline-title {
  font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 400;
  color: var(--bark2); margin: 0 0 4px 0;
}
.globe-inline-sub {
  font-size: 12px; color: var(--stone); margin: 0;
}
.globe-inline-actions {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: 10px 12px; margin-top: 10px;
}
.globe-birth-city-field {
  display: flex; flex-direction: column; gap: 3px; min-width: 140px; flex: 1 1 160px; max-width: 280px;
}
.globe-birth-city-field label {
  font-size: 10px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: var(--stone);
}
.globe-birth-city-input {
  height: 32px; width: 100%; padding: 0 10px; box-sizing: border-box;
  border-radius: 8px; border: 1px solid var(--sand3);
  background: #fff; color: var(--ink);
  font-family: 'Jost', sans-serif; font-size: 13px;
}
.globe-birth-city-input::placeholder { color: var(--stone); opacity: 0.75; }
.globe-birth-city-input:focus {
  outline: none; border-color: var(--bark); box-shadow: 0 0 0 2px rgba(90, 62, 32, 0.12);
}
.globe-apply-city-btn {
  height: 32px; padding: 0 12px;
  border-radius: 8px; border: 1px solid var(--bark);
  background: var(--bark2); color: var(--sand);
  font-family: 'Jost', sans-serif; font-size: 11px; font-weight: 500;
  letter-spacing: .06em; text-transform: uppercase; cursor: pointer;
  transition: background .2s, border-color .2s;
}
.globe-apply-city-btn:hover { background: var(--bark); border-color: var(--bark2); }
.globe-apply-city-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.globe-container-inline {
  position: relative;
  height: min(65vh, 520px);
  background: #0a0a0f;
  border-radius: 0 0 20px 20px;
  overflow: hidden;
}
.globe-key-btn {
  height: 28px;
  padding: 0 10px;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.12);
  color: #f3f4f7;
  font-family: 'Jost', sans-serif;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s, border-color .2s, color .2s;
  flex-shrink: 0;
}
.globe-key-btn:hover {
  background: rgba(255, 255, 255, 0.22);
  border-color: rgba(255, 255, 255, 0.5);
}
.globe-overlay-legend-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.globe-overlay-legend-head .globe-overlay-title {
  margin-bottom: 0;
}
.globe-container, .globe-container-inline {
  position: relative;
  flex: 1; min-height: 400px; background: #0a0a0f;
}
.globe-stage {
  position: absolute;
  inset: 0;
}
/* Globe.gl hover tooltip for lines/cities */
.globe-container .scene-tooltip, .globe-container-inline .scene-tooltip {
  background: #fff !important;
  color: #111 !important;
  border: 1px solid #d8d8d8 !important;
  border-radius: 8px !important;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18) !important;
  font-family: 'Jost', sans-serif !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  padding: 8px 10px !important;
}
.globe-overlay-legend {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 4;
  max-width: min(92%, 360px);
  background: rgba(9, 12, 20, 0.72);
  color: #f3f4f7;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 10px;
  padding: 10px 12px;
  backdrop-filter: blur(2px);
  font-size: 11px;
  line-height: 1.35;
}
.globe-overlay-title {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 6px;
}
.globe-overlay-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}
.globe-overlay-planets {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  margin-top: 8px;
}
.globe-overlay-planet {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.globe-legend {
  flex-shrink: 0;
  padding: 14px 24px; border-top: 1px solid var(--sand3);
  background: var(--sand); display: flex; flex-direction: column; gap: 10px;
  font-size: 12px; color: var(--ink);
  border-radius: 0 0 20px 20px;
}
.globe-legend-types {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
}
.globe-legend-type {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--bark2);
}
.globe-legend-type-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 18px;
  border-radius: 999px;
  background: var(--bark2);
  color: #fff;
  font-size: 10px;
  letter-spacing: .08em;
  font-weight: 600;
}
.globe-legend-planets {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
}
.globe-legend-item {
  display: flex; align-items: center; gap: 8px;
}
.globe-legend-swatch {
  width: 14px; height: 4px; border-radius: 2px; flex-shrink: 0;
}

/* Print: Soul Contract card only — use Print / Save as PDF */
@media print {
  @page { margin: 14mm; }
  .no-print {
    display: none !important;
  }
  body.print-soul-contract {
    background: #fff !important;
  }
  body.print-soul-contract::before {
    display: none !important;
  }
  body.print-soul-contract .page {
    max-width: 100% !important;
    padding: 12px !important;
  }
  body.print-soul-contract header,
  body.print-soul-contract .tab-bar {
    display: none !important;
  }
  body.print-soul-contract .tab-pane {
    display: none !important;
  }
  body.print-soul-contract #tab-profile.tab-pane {
    display: block !important;
  }
  body.print-soul-contract .form-card,
  body.print-soul-contract #profileSpinner,
  body.print-soul-contract #results > .results-header,
  body.print-soul-contract #results > .results-sub,
  body.print-soul-contract #results > .systems-grid,
  body.print-soul-contract #results > .pillar-grid {
    display: none !important;
  }
  body.print-soul-contract #results > .section-label {
    display: none !important;
  }
  body.print-soul-contract #results > #soul-contract-section > .section-label {
    display: block !important;
    font-size: 11px;
    margin-bottom: 8px;
    page-break-after: avoid;
  }
  body.print-soul-contract .soul-contract-card {
    box-shadow: none;
    border: 1px solid #ccc;
    page-break-inside: avoid;
  }
  body.print-soul-contract .sc-section {
    page-break-inside: avoid;
  }

  /* Print saved reading from My Readings tab */
  body.print-saved-reading header,
  body.print-saved-reading .tab-bar,
  body.print-saved-reading .auth-bar {
    display: none !important;
  }
  body.print-saved-reading .tab-pane {
    display: none !important;
  }
  body.print-saved-reading #tab-readings.tab-pane {
    display: block !important;
  }
  body.print-saved-reading #tab-readings .readings-intro-card,
  body.print-saved-reading #tab-readings .readings-list-wrap,
  body.print-saved-reading #tab-readings .readings-back-btn,
  body.print-saved-reading #tab-readings .readings-auth-hint,
  body.print-saved-reading #tab-readings .readings-load-error {
    display: none !important;
  }
  body.print-saved-reading #tab-readings .readings-detail-wrap {
    display: block !important;
  }
  body.print-saved-reading .readings-detail-card {
    box-shadow: none;
    border: 1px solid #ccc;
    page-break-inside: avoid;
  }
}

/* ── My Readings tab ───────────────────────────────────────── */
.readings-intro-card .readings-intro {
  font-size: 14px; color: var(--stone); line-height: 1.65; margin-top: 8px;
}
.readings-auth-hint {
  text-align: center; padding: 32px 20px; color: var(--stone);
}
.readings-auth-hint .calc-btn { max-width: 280px; margin: 16px auto 0; }
.readings-list {
  display: flex; flex-direction: column; gap: 10px; margin-top: 16px;
}
.readings-list-row {
  display: flex; flex-direction: row; align-items: stretch; gap: 12px;
}
.readings-list-item {
  display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
  text-align: left; flex: 1; min-width: 0; padding: 16px 18px;
  background: var(--mist); border: 1px solid var(--sand3); border-radius: 14px;
  cursor: pointer; font-family: 'Jost', sans-serif;
  transition: border-color .2s, background .2s;
}
.readings-list-side {
  display: flex; flex-direction: column; justify-content: center; align-items: stretch;
  gap: 6px; flex-shrink: 0; padding: 8px 0; min-width: 100px;
}
.readings-list-side-btns {
  display: flex; flex-direction: column; gap: 8px;
}
.readings-list-delete-btn {
  font-family: 'Jost', sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 10px 14px; border-radius: 12px; cursor: pointer; white-space: nowrap;
  border: 1px solid rgba(163, 51, 51, 0.35); background: #fff; color: #8b2a2a;
  transition: border-color .2s, background .2s, color .2s;
}
.readings-list-delete-btn:hover:not(:disabled) {
  border-color: #a33; background: #fff5f5; color: #721c1c;
}
.readings-list-delete-btn:disabled {
  opacity: 0.65; cursor: wait;
}
.readings-list-share-btn {
  font-family: 'Jost', sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 10px 14px; border-radius: 12px; cursor: pointer; white-space: nowrap;
  border: 1px solid var(--sand3); background: #fff; color: var(--bark);
  transition: border-color .2s, background .2s, color .2s;
}
.readings-list-share-btn:hover:not(:disabled) {
  border-color: var(--bark); background: var(--mist); color: var(--bark2);
}
.readings-list-share-btn:disabled {
  opacity: 0.65; cursor: wait;
}
.readings-list-share-hint {
  font-size: 11px; line-height: 1.35; color: var(--stone); text-align: center;
  min-height: 1.35em;
}
.readings-list-share-hint--error {
  color: #a33; font-weight: 500;
}
@media (max-width: 540px) {
  .readings-list-row { flex-direction: column; align-items: stretch; gap: 8px; }
  .readings-list-side {
    flex-direction: row; align-items: flex-start; justify-content: space-between;
    flex-wrap: wrap; min-width: 0; width: 100%; padding: 0 4px 4px; gap: 8px;
  }
  .readings-list-side-btns {
    flex-direction: row; flex-wrap: wrap; gap: 8px;
  }
  .readings-list-share-btn, .readings-list-delete-btn { flex: 1 1 auto; min-width: 88px; }
  .readings-list-share-hint { text-align: left; flex: 1 1 100%; min-width: 0; order: 3; }
}
.readings-list-item:hover {
  border-color: var(--bark); background: #fff;
}
.readings-list-date {
  font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--stone);
}
.readings-list-name {
  font-family: 'Cormorant Garamond', serif; font-size: 20px; color: var(--bark2);
}
.readings-list-chats {
  font-size: 12px; font-weight: 500; color: var(--bark); letter-spacing: .02em;
}
.readings-list-preview {
  font-size: 13px; color: var(--stone); line-height: 1.45;
}
.readings-loading, .readings-empty {
  color: var(--stone); padding: 24px; text-align: center;
}
.readings-back-btn {
  margin-bottom: 16px; padding: 8px 0; background: none; border: none;
  font-family: 'Jost', sans-serif; font-size: 13px; font-weight: 500;
  color: var(--bark); cursor: pointer; letter-spacing: .04em;
}
.readings-back-btn:hover { color: var(--bark2); text-decoration: underline; }
.readings-load-error { color: #a33; padding: 12px; font-size: 14px; }
.readings-detail-card { margin-top: 0; }

/* ── Auth bar (top of page) ─────────────────────────────────── */
.auth-bar {
  display: flex; justify-content: flex-end; padding: 0 0 12px;
}
.auth-bar-btn {
  background: none; border: 1px solid var(--sand3); border-radius: 8px;
  padding: 6px 14px; font-family: 'Jost', sans-serif; font-size: 12px;
  font-weight: 500; color: var(--bark2); cursor: pointer;
  letter-spacing: .04em; transition: background .2s, border-color .2s;
  max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.auth-bar-btn:hover { background: var(--sand2); border-color: var(--sand3); }

/* ── Auth modal ───────────────────────────────────────────── */
.auth-modal {
  position: fixed; inset: 0; z-index: 1100;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; visibility: hidden; transition: opacity .25s, visibility .25s;
}
.auth-modal.active { opacity: 1; visibility: visible; }
.auth-modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(30, 26, 20, 0.6);
  cursor: pointer;
}
.auth-modal-panel {
  position: relative; z-index: 1;
  width: 100%; max-width: 420px;
  background: var(--mist); border: 1px solid var(--sand3);
  border-radius: 20px; padding: 36px 32px 28px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
}
.auth-modal-close {
  position: absolute; top: 12px; right: 16px;
  width: 36px; height: 36px;
  background: transparent; border: none;
  font-size: 26px; line-height: 1; color: var(--stone);
  cursor: pointer; border-radius: 8px;
  transition: color .2s, background .2s;
}
.auth-modal-close:hover { color: var(--bark2); background: var(--sand2); }
.auth-modal-title {
  font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 400;
  color: var(--bark2); margin: 0 0 6px;
}
.auth-modal-sub {
  font-size: 13px; color: var(--stone); margin: 0 0 20px; line-height: 1.5;
}
.auth-input {
  width: 100%; padding: 12px 14px; border: 1px solid var(--sand3);
  border-radius: 10px; font-family: 'Jost', sans-serif; font-size: 15px;
  background: #fff; color: var(--ink); margin-bottom: 12px;
  transition: border-color .2s;
}
.auth-input:focus { outline: none; border-color: var(--bark); }
.auth-send-btn { margin-top: 0; }
.auth-toggle-btn {
  display: block; width: 100%; margin-top: 12px; padding: 0;
  background: none; border: none; font-family: 'Jost', sans-serif;
  font-size: 13px; color: var(--stone); cursor: pointer;
  text-align: center; transition: color .2s;
}
.auth-toggle-btn:hover { color: var(--bark2); }
.auth-toggle-btn strong { color: var(--bark); }
.auth-status {
  font-size: 13px; color: var(--bark2); margin-top: 14px; min-height: 20px;
  line-height: 1.5;
}
.auth-signed-in { text-align: center; }
.auth-user-email {
  font-size: 14px; color: var(--ink); margin-bottom: 12px;
}
.auth-signout-btn {
  background: none; border: 1px solid var(--sand3); border-radius: 8px;
  padding: 8px 18px; font-family: 'Jost', sans-serif; font-size: 12px;
  font-weight: 500; color: var(--stone); cursor: pointer;
  letter-spacing: .04em; transition: background .2s, color .2s;
}
.auth-signout-btn:hover { background: var(--sand2); color: var(--bark2); }

/* ── Step 2 Soul Contract CTA ───────────────────────────── */
.step2-panel {
  margin-bottom: 16px;
}
.step2-credit-packs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}
@media (max-width: 640px) {
  .step2-credit-packs {
    grid-template-columns: 1fr;
  }
}
.step2-credit-pack-btn {
  font-family: 'Jost', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: none;
  padding: 12px 10px;
  border-radius: 10px;
  border: 1px solid var(--sand3);
  background: #fff;
  color: var(--bark2);
  cursor: pointer;
  transition: background .2s, border-color .2s, color .2s;
}
.step2-credit-pack-btn:hover:not(:disabled) {
  background: var(--sand2);
  border-color: var(--bark2);
}
.step2-credit-pack-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.step2-panel .calc-btn-step2:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  background: var(--stone);
  filter: grayscale(0.25);
}
.step2-panel .calc-btn-step2:disabled:hover {
  transform: none;
}
.step2-banner {
  font-family: 'Jost', sans-serif;
  font-size: 14px;
  line-height: 1.45;
  color: var(--bark2);
  margin-bottom: 12px;
  padding: 12px 14px;
  background: var(--mist);
  border: 1px solid var(--sand3);
  border-radius: 12px;
}
.step2-banner strong {
  font-size: 18px; font-weight: 600; color: var(--bark);
  font-variant-numeric: tabular-nums;
}
.step2-banner-credits { color: var(--bark2); }
.step2-banner-none {
  color: var(--rust); font-weight: 600;
}
.step2-banner-loading { color: var(--stone); font-size: 13px; }
.step2-banner-error { color: #a33; font-size: 13px; }

/* ── Payment toast ───────────────────────────────────────── */
.payment-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--moss2); color: #fff; padding: 14px 24px;
  border-radius: 12px; font-family: 'Jost', sans-serif; font-size: 14px;
  font-weight: 500; box-shadow: 0 8px 28px rgba(0,0,0,.25);
  opacity: 0; transition: opacity .3s, transform .3s; z-index: 2000;
  pointer-events: none;
}
.payment-toast.visible { opacity: 1; transform: translateX(-50%) translateY(0); }

/* Responsive */
@media (max-width: 600px) {
  .form-grid { grid-template-columns: 1fr 1fr; }
  .form-grid .span3 { grid-column: span 2; }
  .pillar-grid { grid-template-columns: repeat(2, 1fr); }
  .bazi-about-wrap { grid-column: 1 / -1; }
  .tab-btn { padding: 10px 14px; font-size: 11px; }
  .tab-dropdown-toggle { padding: 10px 14px; font-size: 11px; }
  .tab-dropdown-menu { min-width: min(100vw - 32px, 280px); left: 0; right: auto; }
  .auth-modal-panel { padding: 28px 20px 20px; }
}
