/* ── C2Improve Quiz Overlay ──────────────────────────────────── */
.c2-overlay {
  position: fixed; inset: 0;
  background: rgba(15,26,20,0.72);
  backdrop-filter: blur(4px);
  z-index: 9000;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s;
}
.c2-overlay.open { opacity: 1; pointer-events: all; }

.c2-modal {
  background: #fff;
  border-radius: 16px;
  width: 100%; max-width: 600px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 32px 80px rgba(0,0,0,0.22);
  transform: translateY(20px);
  transition: transform 0.28s cubic-bezier(.22,.68,0,1.2);
  position: relative;
}
.c2-overlay.open .c2-modal { transform: translateY(0); }

.c2-modal-header {
  padding: 28px 32px 20px;
  border-bottom: 1px solid var(--grey-mid, #D9D9D4);
  position: sticky; top: 0; background: #fff; z-index: 1;
  border-radius: 16px 16px 0 0;
}
.c2-modal-label {
  font-size: 0.68rem; font-weight: 700; letter-spacing: 1.8px;
  text-transform: uppercase; color: var(--green, #2D6A4F); display: block; margin-bottom: 6px;
}
.c2-modal-title {
  font-family: Fraunces, Georgia, serif; font-weight: 500;
  font-size: clamp(1.1rem, 3vw, 1.4rem); line-height: 1.3; color: var(--ink, #0F1A14);
}
.c2-modal-close {
  position: absolute; top: 20px; right: 20px;
  background: var(--grey, #F5F5F3); border: none; border-radius: 50%;
  width: 32px; height: 32px; font-size: 1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: #5a6a61; transition: background 0.15s;
}
.c2-modal-close:hover { background: var(--grey-mid, #D9D9D4); }
.c2-modal-body { padding: 28px 32px 32px; }

.c2-progress-bar { height: 3px; background: var(--green-lt, #F0F7F4); border-radius: 2px; margin-bottom: 24px; overflow: hidden; }
.c2-progress-fill { height: 100%; background: var(--green, #2D6A4F); border-radius: 2px; transition: width 0.35s ease; }
.c2-progress-label { font-size: 0.75rem; color: #7a8a82; margin-bottom: 8px; display: block; }

.c2-q-block { display: none; }
.c2-q-block.active { display: block; }
.c2-q-text { font-size: 1.05rem; font-weight: 500; color: var(--ink, #0F1A14); line-height: 1.5; margin-bottom: 20px; }
.c2-q-hint { font-size: 0.82rem; color: #7a8a82; margin-top: -14px; margin-bottom: 20px; }

.c2-options { display: flex; flex-direction: column; gap: 10px; }
.c2-option {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 14px 16px; border: 1.5px solid var(--grey-mid, #D9D9D4);
  border-radius: 10px; cursor: pointer;
  transition: all 0.15s; background: #fff;
}
.c2-option:hover { border-color: var(--green-mid, #B7D5C8); background: var(--green-lt, #F0F7F4); }
.c2-option.selected { border-color: var(--green, #2D6A4F); background: var(--green-lt, #F0F7F4); }
.c2-option-radio {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid var(--grey-mid, #D9D9D4); flex-shrink: 0; margin-top: 1px;
  transition: all 0.15s; background: #fff;
}
.c2-option.selected .c2-option-radio { border-color: var(--green, #2D6A4F); background: var(--green, #2D6A4F); box-shadow: inset 0 0 0 3px #fff; }
.c2-option-text { font-size: 0.9rem; line-height: 1.45; }
.c2-option-text strong { display: block; font-size: 0.92rem; margin-bottom: 2px; }
.c2-option-text span { color: #5a6a61; font-size: 0.83rem; }

.c2-nav-row { display: flex; justify-content: space-between; align-items: center; margin-top: 24px; gap: 12px; }
.c2-btn-ghost { background: transparent; color: #5a6a61; border: none; font-size: 0.85rem; cursor: pointer; font-family: inherit; padding: 8px 4px; }
.c2-btn-ghost:hover { color: var(--ink, #0F1A14); }

.c2-gate-block { display: none; }
.c2-gate-block.active { display: block; }
.c2-gate-intro { background: var(--green-lt, #F0F7F4); border: 1px solid var(--green-mid, #B7D5C8); border-radius: 10px; padding: 16px 20px; margin-bottom: 24px; font-size: 0.88rem; color: var(--green-dk, #1B4332); line-height: 1.6; }
.c2-gate-intro strong { display: block; font-size: 0.92rem; margin-bottom: 4px; }
.c2-form-group { margin-bottom: 16px; }
.c2-form-group label { display: block; font-size: 0.8rem; font-weight: 600; color: var(--ink, #0F1A14); margin-bottom: 6px; letter-spacing: 0.3px; }
.c2-form-group label span { color: var(--green, #2D6A4F); }
.c2-form-group input { width: 100%; padding: 11px 14px; border: 1.5px solid var(--grey-mid, #D9D9D4); border-radius: 8px; font-size: 0.9rem; color: var(--ink, #0F1A14); background: #fff; transition: border-color 0.15s; outline: none; font-family: inherit; }
.c2-form-group input:focus { border-color: var(--green, #2D6A4F); }
.c2-form-consent { display: flex; gap: 10px; align-items: flex-start; font-size: 0.8rem; color: #5a6a61; margin-bottom: 20px; line-height: 1.5; }
.c2-form-consent input[type=checkbox] { margin-top: 2px; flex-shrink: 0; accent-color: var(--green, #2D6A4F); }

.c2-result-block { display: none; }
.c2-result-block.active { display: block; }
.c2-result-score-bar { margin-bottom: 28px; }
.c2-result-score-label { display: flex; justify-content: space-between; font-size: 0.8rem; color: #5a6a61; margin-bottom: 8px; }
.c2-result-score-track { height: 10px; background: var(--green-lt, #F0F7F4); border-radius: 6px; overflow: hidden; }
.c2-result-score-fill { height: 100%; border-radius: 6px; transition: width 0.8s cubic-bezier(.22,.68,0,1.2); background: var(--green, #2D6A4F); }
.c2-result-badge { display: inline-block; padding: 6px 14px; border-radius: 100px; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; margin-bottom: 16px; }
.c2-badge-green { background: #d1fae5; color: #065f46; }
.c2-badge-amber { background: #fef3c7; color: #92400e; }
.c2-badge-blue  { background: #dbeafe; color: #1e40af; }
.c2-badge-red   { background: #fee2e2; color: #991b1b; }
.c2-result-headline { font-family: Fraunces, Georgia, serif; font-size: 1.3rem; font-weight: 500; line-height: 1.35; color: var(--ink, #0F1A14); margin-bottom: 12px; }
.c2-result-body { font-size: 0.9rem; color: #4a5550; line-height: 1.75; margin-bottom: 20px; }
.c2-result-findings { border: 1px solid var(--grey-mid, #D9D9D4); border-radius: 10px; overflow: hidden; margin-bottom: 24px; }
.c2-finding-row { display: flex; align-items: center; gap: 12px; padding: 11px 16px; font-size: 0.86rem; border-bottom: 1px solid var(--grey-mid, #D9D9D4); }
.c2-finding-row:last-child { border-bottom: none; }
.c2-finding-row.good { color: #065f46; background: #f0fdf4; }
.c2-finding-row.warn { color: #92400e; background: #fffbeb; }
.c2-finding-row.gap  { color: #991b1b; background: #fef2f2; }
.c2-finding-icon { font-size: 0.9rem; flex-shrink: 0; }
.c2-result-cta { display: flex; gap: 12px; flex-wrap: wrap; padding-top: 20px; border-top: 1px solid var(--grey-mid, #D9D9D4); }
