:root {
  --brand-red: #d20f39;
  --brand-blue: #0b1f3a;
  --brand-teal: #1f6f8b;
  --surface: #f7f8fb;
  --ink: #18212f;
  --muted: #4f5d75;
  --good: #2e7d32;
  --warn: #d98f00;
  --bad: #b3261e;
  --radius: 16px;
  --shadow: 0 12px 30px rgba(11, 31, 58, 0.12);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  color: var(--ink);
  background: radial-gradient(circle at 15% 10%, #ffffff 0%, #eef2f9 45%, #e9edf7 100%);
  font-family: 'Space Grotesk', 'Segoe UI', sans-serif;
}

a {
  color: var(--brand-red);
}

.topbar {
  padding: 1rem 1.25rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(255, 255, 255, 0.86);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid #e2e7f3;
  position: sticky;
  top: 0;
  z-index: 10;
}

.logo {
  font-family: 'Spectral', serif;
  font-weight: 700;
  letter-spacing: 0.02em;
  font-size: 1.2rem;
  color: var(--brand-blue);
}

.logo span {
  color: var(--brand-red);
}

.layout {
  width: min(960px, 92vw);
  margin: 1.5rem auto 4rem;
}

.card {
  background: #ffffff;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.5rem;
}

.hero {
  display: grid;
  gap: 1rem;
  margin-bottom: 1rem;
}

.hero h1 {
  font-family: 'Spectral', serif;
  margin: 0;
  font-size: clamp(1.6rem, 3vw, 2.6rem);
  color: var(--brand-blue);
}

.hero p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.progress-shell {
  height: 10px;
  background: #ecf0f8;
  border-radius: 999px;
  overflow: hidden;
  margin-top: 0.5rem;
}

.progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--brand-red), #f3576f);
  width: 0;
  transition: width 220ms ease;
}

.question-title {
  font-size: clamp(1.1rem, 2.3vw, 1.4rem);
  font-weight: 700;
  margin: 0 0 0.4rem;
}

.question-help {
  margin: 0 0 1.1rem;
  color: var(--muted);
  line-height: 1.5;
}

.answers {
  display: grid;
  gap: 0.75rem;
}

.answer-btn,
.input,
.textarea {
  border: 1px solid #ced7e8;
  border-radius: 12px;
  padding: 0.95rem 1rem;
  font: inherit;
  background: #fff;
}

.answer-btn {
  cursor: pointer;
  text-align: left;
  transition: border-color 180ms ease, transform 180ms ease, background 180ms ease;
}

.answer-btn:hover {
  border-color: var(--brand-red);
  transform: translateY(-1px);
}

.answer-btn.selected {
  border-color: var(--brand-red);
  background: #fff4f6;
}

.actions {
  margin-top: 1.2rem;
  display: flex;
  justify-content: space-between;
  gap: 0.7rem;
}

button {
  font: inherit;
}

.btn {
  border: 0;
  border-radius: 12px;
  padding: 0.78rem 1.05rem;
  cursor: pointer;
}

.btn-primary {
  background: linear-gradient(135deg, var(--brand-red), #e83e62);
  color: #fff;
  font-weight: 700;
}

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

.btn-ghost {
  background: #edf1f8;
  color: var(--brand-blue);
}

.notice {
  background: #eef6ff;
  border: 1px solid #c0d5f5;
  border-radius: 12px;
  padding: 0.8rem 1rem;
  color: #124179;
}

.muted {
  color: var(--muted);
}

.grid {
  display: grid;
  gap: 1rem;
}

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

.score-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.score-pill {
  border-radius: 999px;
  padding: 0.5rem 0.9rem;
  font-weight: 700;
}

.score-pill.green {
  color: var(--good);
  background: #e8f5ea;
}

.score-pill.yellow {
  color: var(--warn);
  background: #fff7e6;
}

.score-pill.red {
  color: var(--bad);
  background: #fdeced;
}

.kpi {
  font-size: 2.2rem;
  font-weight: 700;
  margin: 0;
}

.category {
  border: 1px solid #e2e8f5;
  border-radius: 12px;
  padding: 1rem;
}

.category h3 {
  margin: 0 0 0.3rem;
}

.category p {
  margin: 0;
  color: var(--muted);
}

.auth-shell {
  width: min(480px, 92vw);
  margin: 5rem auto;
}

.form {
  display: grid;
  gap: 0.75rem;
}

.form label {
  display: grid;
  gap: 0.35rem;
  font-weight: 600;
  color: var(--brand-blue);
}

.footer-note {
  margin-top: 0.75rem;
  font-size: 0.9rem;
}

.module-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.9rem;
  margin-top: 1rem;
}

.module-card {
  border: 1px solid #d9e2f2;
  border-radius: 12px;
  padding: 1rem;
  background: #fff;
}

.module-card h3 {
  margin: 0 0 0.4rem;
}

.partner-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 0.9rem;
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.22rem 0.58rem;
  font-size: 0.82rem;
  line-height: 1.3;
  background: #edf3ff;
  color: #1d3f72;
  border: 1px solid #d4e2fb;
}

.badge-soon {
  display: inline-block;
  margin-top: 0.4rem;
  background: #eef1f7;
  color: #546279;
  border-radius: 999px;
  font-size: 0.8rem;
  padding: 0.22rem 0.55rem;
}

.error-box {
  background: #fdeced;
  color: #8c1d18;
  border: 1px solid #f6c0be;
  border-radius: 12px;
  padding: 0.75rem 0.9rem;
}

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

  .score-hero {
    flex-direction: column;
    align-items: flex-start;
  }
}
