:root {
  --fs-bg: #0c0c0f;
  --fs-card: #14141a;
  --fs-card-2: #1b1b24;
  --fs-border: rgba(255,255,255,0.1);
  --fs-text: #f7f7fb;
  --fs-muted: #b5b5c3;
  --fs-pink: #ff2da6;
  --fs-pink-2: #ff5ec0;
  --fs-green: #2ecc71;
  --fs-yellow: #f1c40f;
  --fs-red: #ff6b6b;
  --fs-shadow: 0 18px 50px rgba(0,0,0,0.35);
  --fs-radius: 22px;
}

* { box-sizing: border-box; }

body.fs-demo-body {
  margin: 0;
  font-family: Inter, Arial, Helvetica, sans-serif;
  background:
    radial-gradient(circle at top right, rgba(255,45,166,0.18), transparent 35%),
    linear-gradient(180deg, #050507, #101018 40%, #0b0b10 100%);
  color: var(--fs-text);
}

.freedom-score-wrap {
  width: min(1180px, calc(100% - 32px));
  margin: 40px auto;
}

.freedom-score-section {
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  border: 1px solid var(--fs-border);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: var(--fs-shadow);
}

.freedom-score-hero {
  padding: 42px 26px 26px;
  background:
    radial-gradient(circle at top right, rgba(255,45,166,0.2), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
  border-bottom: 1px solid var(--fs-border);
}

.fs-kicker {
  display: inline-flex;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,45,166,0.12);
  border: 1px solid rgba(255,45,166,0.35);
  color: #ffd5ed;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.freedom-score-hero h2 {
  margin: 16px 0 10px;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 0.98;
}

.freedom-score-hero p {
  margin: 0;
  color: var(--fs-muted);
  max-width: 760px;
  font-size: 1.04rem;
  line-height: 1.65;
}

.fs-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 22px;
  padding: 22px;
}

.fs-card {
  background: linear-gradient(180deg, var(--fs-card), var(--fs-card-2));
  border: 1px solid var(--fs-border);
  border-radius: var(--fs-radius);
  padding: 22px;
}

.fs-card h3 {
  margin: 0 0 16px;
  font-size: 1.18rem;
}

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

.fs-field {
  display: grid;
  gap: 8px;
}

.fs-field.fs-full {
  grid-column: 1 / -1;
}

.fs-label {
  font-size: 0.94rem;
  font-weight: 700;
}

.fs-help {
  color: var(--fs-muted);
  font-size: 0.84rem;
}

.fs-input,
.fs-select {
  width: 100%;
  padding: 14px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: var(--fs-text);
  font: inherit;
  outline: none;
}

.fs-input:focus,
.fs-select:focus {
  border-color: rgba(255,45,166,0.7);
  box-shadow: 0 0 0 4px rgba(255,45,166,0.14);
}

.fs-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.fs-btn {
  appearance: none;
  border: none;
  border-radius: 999px;
  padding: 14px 18px;
  font: inherit;
  font-weight: 800;
  cursor: pointer;
  transition: transform 0.15s ease, opacity 0.15s ease;
}

.fs-btn:hover { transform: translateY(-1px); }
.fs-btn:active { transform: translateY(0); }

.fs-btn-primary {
  background: linear-gradient(135deg, var(--fs-pink), var(--fs-pink-2));
  color: #fff;
}

.fs-btn-secondary {
  background: rgba(255,255,255,0.08);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.12);
}

.fs-score-ring {
  width: 210px;
  height: 210px;
  margin: 0 auto 18px;
  border-radius: 50%;
  background: conic-gradient(var(--fs-pink) 0deg, var(--fs-pink) 0deg, rgba(255,255,255,0.08) 0deg 360deg);
  display: grid;
  place-items: center;
  position: relative;
}

.fs-score-ring::after {
  content: "";
  position: absolute;
  inset: 16px;
  background: linear-gradient(180deg, #0f0f15, #161621);
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.08);
}

.fs-score-inner {
  position: relative;
  z-index: 1;
  text-align: center;
}

.fs-score-number {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1;
}

.fs-score-caption {
  color: var(--fs-muted);
  font-size: 0.9rem;
  margin-top: 8px;
}

.fs-tier {
  display: inline-block;
  margin: 6px 0 16px;
  padding: 8px 14px;
  border-radius: 999px;
  font-weight: 800;
  background: rgba(255,255,255,0.08);
}

.fs-summary {
  color: var(--fs-muted);
  line-height: 1.7;
  margin-bottom: 18px;
}

.fs-breakdown {
  display: grid;
  gap: 12px;
}

.fs-breakdown-item {
  padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(255,255,255,0.08);
}

.fs-breakdown-item strong {
  display: block;
  margin-bottom: 4px;
}

.fs-next-steps {
  margin: 18px 0 0;
  padding-left: 18px;
  color: var(--fs-muted);
  line-height: 1.7;
}

.fs-note {
  margin-top: 16px;
  color: var(--fs-muted);
  font-size: 0.84rem;
}

@media (max-width: 900px) {
  .fs-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .freedom-score-wrap {
    width: min(100% - 18px, 1180px);
    margin: 18px auto;
  }

  .freedom-score-hero,
  .fs-card {
    padding: 18px;
  }

  .fs-form-grid {
    grid-template-columns: 1fr;
  }

  .fs-score-ring {
    width: 180px;
    height: 180px;
  }
}
