/* ============================================================
   S.T.A.B.L.E Framework Tool  ·  Public CSS v4
   Light theme · Inter · Bold · Modern
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ── Root tokens ──────────────────────────────────────────── */
#sft-root {
  --p:      #2563eb;  --p-d: #1d4ed8;  --p-l: #dbeafe;  --p-pl: #eff6ff;
  --white:  #ffffff;
  --bg:     #f8fafc;  --bg2: #f1f5f9;
  --bdr:    #e2e8f0;  --bdr2: #cbd5e1;
  --t:      #0f172a;  --t2: #334155;  --t3: #64748b;  --t4: #94a3b8;
  --ok:     #16a34a;  --ok-l:  #dcfce7;
  --warn:   #d97706;  --warn-l:#fef3c7;
  --danger: #dc2626;  --dan-l: #fee2e2;
  --r: 16px;  --rs: 10px;
  --sh:  0 1px 3px rgba(0,0,0,.06), 0 8px 24px rgba(0,0,0,.07);
  --shs: 0 1px 2px rgba(0,0,0,.05);
  /* ── Appearance-settings-overridable tokens ── */
  --h1-color:        #0f172a;   /* page/section main heading colour */
  --badge-text:      #2563eb;   /* "Step 1 of 3" text colour */
  --badge-bg:        #eff6ff;   /* "Step 1 of 3" background colour */
  --form-sep-color:  #2563eb;   /* "Contact Information" separator text */
  --form-sep-border: #dbeafe;   /* separator underline */
  --label-color:     #334155;   /* field label text */
  --lead-color:      #64748b;   /* sub-heading / lead paragraph text */
  --acc-title-color: #0f172a;   /* S T A B L E accordion title text */
  --acc-subtitle-color: #94a3b8; /* accordion sub-label text */
  --input-color:     #0f172a;   /* input value text */
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--bg);  color: var(--t);
  line-height: 1.6;  -webkit-font-smoothing: antialiased;
  max-width: 1000px;  margin: 0 auto;  padding: 32px 20px 80px;
}

/* ── Type ─────────────────────────────────────────────────── */
.sft-h1 { font-size:clamp(1.8rem,4vw,2.5rem);font-weight:800;color:var(--h1-color,var(--t));margin:0 0 10px;letter-spacing:-.5px;line-height:1.15; }
.sft-lead { font-size:1rem;color:var(--lead-color,var(--t3));font-weight:400;margin:0;max-width:580px; }
.sft-step-badge { display:inline-block;background:var(--badge-bg,var(--p-pl));color:var(--badge-text,var(--p));font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:12px; }

/* ── Card ─────────────────────────────────────────────────── */
.sft-card { background:var(--white);border:1px solid var(--bdr);border-radius:var(--r);padding:36px;box-shadow:var(--sh); }
.sft-card-title { font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin:0 0 18px; }
.sft-step-header { margin-bottom:28px; }
.sft-logo-wrap { margin-bottom:20px; text-align:center; }
.sft-logo-wrap img { max-height:64px; display:inline-block; }

/* ── Form ─────────────────────────────────────────────────── */
.sft-form-section-title { font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--form-sep-color,var(--p));padding-bottom:10px;border-bottom:2px solid var(--form-sep-border,var(--p-l));margin:24px 0 18px; }
.sft-grid-2 { display:grid;grid-template-columns:1fr 1fr;gap:16px 22px; }
@media(max-width:600px){ .sft-grid-2 { grid-template-columns:1fr; } }
.sft-field { display:flex;flex-direction:column;gap:5px; }
.sft-label { font-size:13px;font-weight:600;color:var(--label-color,var(--t2)); }
.sft-req { color:var(--danger); }
.sft-optional { font-weight:400;color:var(--t4);font-size:12px; }
.sft-input { background:var(--white);border:1.5px solid var(--bdr);border-radius:var(--rs);padding:11px 14px;font-family:'Inter',sans-serif;font-size:14px;font-weight:500;color:var(--input-color,var(--t));transition:border-color .18s,box-shadow .18s;outline:none;width:100%;box-sizing:border-box; }
.sft-input:focus { border-color:var(--p);box-shadow:0 0 0 3px rgba(37,99,235,.12); }
.sft-input.sft-err-field { border-color:var(--danger); }
.sft-input::placeholder { color:var(--t4);font-weight:400; }
select.sft-input option { background:#fff; }
.sft-textarea { resize:vertical;min-height:80px; }
.sft-err { font-size:12px;color:var(--danger);font-weight:600;min-height:14px; }
.sft-form-actions { margin-top:28px;padding-top:20px;border-top:1px solid var(--bdr);display:flex;justify-content:flex-end; }

/* ── Buttons ──────────────────────────────────────────────── */
.sft-btn { display:inline-flex;align-items:center;gap:7px;padding:11px 22px;border-radius:var(--rs);font-family:'Inter',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .18s;text-decoration:none;border:none;white-space:nowrap; }
.sft-btn-lg { padding:14px 30px;font-size:15px;font-weight:700;border-radius:12px; }
.sft-btn-sm { padding:7px 14px;font-size:12px; }
.sft-btn-primary { background:var(--p);color:#fff; }
.sft-btn-primary:hover { background:var(--p-d);transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,99,235,.35); }
.sft-btn-primary:disabled { background:var(--t4);cursor:not-allowed;transform:none;box-shadow:none; }
.sft-btn-outline { background:transparent;border:2px solid var(--bdr2);color:var(--t2); }
.sft-btn-outline:hover { border-color:var(--p);color:var(--p);background:var(--p-pl); }
.sft-btn-ghost { background:var(--bg2);color:var(--t3);border:1px solid var(--bdr); }
.sft-btn-ghost:hover { background:var(--p-pl);color:var(--p); }
.sft-spinner { width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:sftSpin .7s linear infinite;display:inline-block; }
@keyframes sftSpin { to { transform:rotate(360deg); } }

/* ── Assessment header ────────────────────────────────────── */
.sft-assess-header { display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px;padding:16px 20px;background:var(--white);border:1px solid var(--bdr);border-radius:12px;box-shadow:var(--shs); }
.sft-assess-meta { font-size:14px;font-weight:600;color:var(--t2); }
.sft-assess-meta strong { color:var(--t);font-weight:800; }
.sft-assess-controls { display:flex;gap:8px; }
.sft-progress-bar-wrap { position:relative;height:8px;background:var(--bg2);border-radius:4px;margin-bottom:6px;overflow:hidden; }
.sft-progress-bar { height:100%;background:linear-gradient(90deg,var(--p),#7c3aed);border-radius:4px;transition:width .4s ease; }
.sft-progress-label { font-size:12px;color:var(--t4);font-weight:500;display:block;text-align:right;margin-bottom:20px; }

/* ── Accordion ────────────────────────────────────────────── */
.sft-accordion { border:2px solid var(--bdr);border-radius:14px;margin-bottom:12px;overflow:hidden;transition:border-color .2s; }
.sft-accordion.sft-acc-open { border-color:var(--acc-color,var(--p)); }
.sft-acc-head { display:flex;align-items:center;gap:14px;padding:16px 20px;cursor:pointer;background:var(--white);user-select:none;transition:background .18s; }
.sft-acc-head:hover { background:var(--bg2); }
.sft-accordion.sft-acc-open .sft-acc-head { background:color-mix(in srgb,var(--acc-color,var(--p)) 6%,white); }
.sft-acc-letter { width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:900;color:#fff;flex-shrink:0;background:var(--acc-color,var(--p)); }
.sft-acc-info { flex:1;min-width:0; }
.sft-acc-title { font-size:15px;font-weight:800;color:var(--acc-title-color,var(--t));margin:0 0 2px; }
.sft-acc-subtitle { font-size:12px;color:var(--acc-subtitle-color,var(--t4)); }
.sft-acc-meta { display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0; }
.sft-acc-score { font-size:16px;font-weight:800;color:var(--acc-color,var(--p)); }
.sft-acc-diag { font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px; }
.sft-acc-chevron { font-size:12px;color:var(--t4);transition:transform .25s; }
.sft-accordion.sft-acc-open .sft-acc-chevron { transform:rotate(180deg); }
.sft-acc-body { display:none;padding:0 20px 20px; }
.sft-accordion.sft-acc-open .sft-acc-body { display:block; }
.sft-acc-locked-msg { display:none;padding:14px 20px 18px;font-size:13px;color:var(--t4);font-style:italic; }
.sft-accordion.sft-acc-locked .sft-acc-locked-msg { display:block; }
.sft-accordion.sft-acc-locked .sft-acc-body { display:none !important; }

/* ── Section subtotal bar ─────────────────────────────────── */
/* Shows at the bottom of each accordion: score + diagnosis badge + priority badge */
.sft-subtotal {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
  padding: 12px 16px;
  background: var(--bg2);
  border-radius: 10px;
  border-left: 4px solid var(--acc-color, var(--p));
}
.sft-subtotal-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .8px;
  flex-shrink: 0;
}
.sft-subtotal-score {
  font-size: 15px;
  font-weight: 800;
  color: var(--acc-color, var(--p));
  flex-shrink: 0;
}
.sft-subtotal-sep {
  color: var(--bdr2);
  font-size: 14px;
  flex-shrink: 0;
}
.sft-subtotal-pills {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* ══════════════════════════════════════════════════════════
   QUESTION ROW
   Two columns:
     LEFT  (flex:1):        number + question text + tags (left-aligned, under text)
     RIGHT (flex-shrink:0): rating buttons ONLY — nothing else, never pushed

   Tags are in the LEFT column so they appear under the question
   text, aligned left — matching the text they describe.
   The RIGHT column is buttons only so it NEVER changes size.
   ══════════════════════════════════════════════════════════ */
.sft-q-row {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 14px 0;
  border-top: 1px solid var(--bdr);
}
.sft-q-row:first-child { border-top: none; padding-top: 0; }

/* LEFT: grows to fill available space, stacks text then tags */
.sft-q-left {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Top line: number + question text side by side */
.sft-q-text-line {
  display: flex;
  align-items: flex-start;
  gap: 6px;
}
.sft-q-num {
  font-size: 12px;
  font-weight: 700;
  color: var(--t4);
  flex-shrink: 0;
  padding-top: 2px;
}
.sft-q-text {
  font-size: 13px;
  font-weight: 500;
  color: var(--t2);
  line-height: 1.65;
}

/* Tags: LEFT-ALIGNED under the question text */
.sft-q-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-start;   /* LEFT aligned */
  min-height: 22px;              /* reserved — no layout shift */
  padding-left: 18px;            /* indent to align under text (past the number) */
}

/* RIGHT: buttons ONLY — fixed width, never changes */
.sft-q-right {
  flex-shrink: 0;
  flex-grow: 0;
  padding-top: 2px;  /* align with first text line */
}

/* Rating buttons */
.sft-rating {
  display: flex;
  gap: 5px;
}
.sft-rating-btn {
  box-sizing: border-box;
  width: 36px; height: 36px; border-radius: 8px;
  border: 2px solid var(--bdr); background: var(--white);
  font-size: 13px; font-weight: 700; color: var(--t3);
  cursor: pointer;
  transition: background .12s, border-color .12s, color .12s;
  font-family: 'Inter', sans-serif; flex-shrink: 0;
}
.sft-rating-btn:hover {
  border-color: var(--acc-color, var(--p));
  color: var(--acc-color, var(--p));
  background: var(--bg2);
}
.sft-rating-btn.active {
  border-color: var(--acc-color, var(--p));
  background: var(--acc-color, var(--p));
  color: #fff;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--acc-color, var(--p));
}
.sft-q-tag {
  display: inline-block;
  font-size: 10px; font-weight: 700;
  padding: 2px 9px; border-radius: 20px; white-space: nowrap;
}
.sft-tag-strong   { background: var(--ok-l);   color: var(--ok); }
.sft-tag-moderate { background: var(--warn-l);  color: var(--warn); }
.sft-tag-weak     { background: var(--dan-l);   color: var(--danger); }
.sft-tag-maintain { background: #dbeafe;         color: #1d4ed8; }
.sft-tag-improve  { background: var(--warn-l);  color: var(--warn); }
.sft-tag-urgent   { background: var(--dan-l);   color: var(--danger); }

/* ══════════════════════════════════════════════════════════
   RESULTS
   ══════════════════════════════════════════════════════════ */
.sft-results-header { text-align:center;margin-bottom:28px; }
.sft-score-hero { display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px; }
@media(max-width:560px){ .sft-score-hero { grid-template-columns:1fr; } }
.sft-hero-card { background:var(--white);border:1.5px solid var(--bdr);border-radius:var(--r);padding:24px 16px;text-align:center;box-shadow:var(--sh); }
.sft-hero-label { font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--t4);margin-bottom:8px; }
.sft-hero-val { font-size:clamp(2rem,5vw,2.8rem);font-weight:900;color:var(--t);line-height:1; }
.sft-hero-val .sft-hero-max { font-size:1rem;font-weight:400;color:var(--t4); }
.sft-diag-banner { border-radius:12px;padding:18px 22px;margin-bottom:22px; }
.sft-diag-banner-title { font-size:1.1rem;font-weight:800;margin-bottom:5px; }
.sft-diag-banner p { font-size:14px;margin:0;line-height:1.65; }
.sft-results-grid { display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px; }
@media(max-width:700px){ .sft-results-grid { grid-template-columns:1fr; } }
.sft-chart-card { padding:24px; }
.sft-chart-wrap { position:relative;height:280px; }
.sft-chart-bar-wrap { position:relative;height:240px; }
.sft-table-card { padding:20px;overflow-x:auto; }
.sft-rtable { width:100%;border-collapse:collapse;font-size:13px; }
.sft-rtable th { padding:10px 12px;text-align:left;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--t4);border-bottom:2px solid var(--bdr); }
.sft-rtable td { padding:12px 12px;border-bottom:1px solid var(--bdr);vertical-align:middle; }
.sft-rtable tr:last-child td { border-bottom:none; }
.sft-sec-cell { display:flex;align-items:center;gap:8px; }
.sft-sec-dot { width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0; }

/* ── Badges ───────────────────────────────────────────────── */
.sft-badge { display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap; }
.sft-badge-ok     { background:var(--ok-l);  color:var(--ok); }
.sft-badge-warn   { background:var(--warn-l);color:var(--warn); }
.sft-badge-danger { background:var(--dan-l); color:var(--danger); }
.sft-badge-blue   { background:var(--p-l);   color:var(--p); }
.sft-badge-gray   { background:var(--bg2);   color:var(--t3); }

/* ── Report link card ─────────────────────────────────────── */
.sft-report-link-card { display:flex;align-items:center;gap:16px;padding:18px 22px;background:var(--p-pl);border:2px solid var(--p-l);border-radius:12px;margin-bottom:20px;flex-wrap:wrap; }
.sft-report-link-icon { font-size:2rem; }
.sft-report-link-title { font-size:15px;font-weight:700;color:var(--t);margin-bottom:3px; }
.sft-report-link-sub { font-size:12px;color:var(--t3); }
.sft-report-link-url { font-size:12px;color:var(--p);font-weight:600;word-break:break-all;margin-top:4px; }
.sft-report-link-card .sft-btn { margin-left:auto;flex-shrink:0; }
.sft-results-actions { display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:28px; }
.sft-email-notice { text-align:center;margin-top:16px;padding:12px;background:var(--ok-l);border:1px solid #bbf7d0;border-radius:10px;font-size:13px;color:var(--ok);font-weight:600; }

/* ══════════════════════════════════════════════════════════
   PRINT — visibility approach (no blank pages on any theme)

   Using visibility:hidden / visibility:visible instead of
   display:none means elements remain in the layout flow but
   are invisible. #sft-root is then pulled to the top with
   position:fixed so it fills the printed page cleanly.
   ══════════════════════════════════════════════════════════ */
@media print {
  @page { margin: 1.2cm; }

  /* Hide everything */
  body * { visibility: hidden !important; }

  /* Show only the assessment root and everything inside it */
  #sft-root,
  #sft-root * { visibility: visible !important; }

  /* Position root at the top — absolute (not fixed) so content
     flows across multiple pages without overlapping */
  #sft-root {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
    padding: 12px !important;
    margin: 0 !important;
    max-width: none !important;
    background: #fff !important;
  }

  /* Hide UI elements that should not appear in print */
  #sft-root .sft-assess-controls,
  #sft-root .sft-assess-header,
  #sft-root .sft-assess-footer,
  #sft-root .sft-results-actions,
  #sft-root .sft-report-link-card,
  #sft-root .sft-email-notice,
  #sft-root .sft-btn,
  #sft-root #sft-step-1,
  #sft-root #sft-step-2,
  #sft-root .sft-step-badge {
    display: none !important;
    visibility: hidden !important;
  }

  /* Clean up card styling for paper */
  .sft-card, .sft-hero-card, .sft-chart-card, .sft-table-card {
    box-shadow: none !important;
    border: 1px solid #ccc !important;
  }
  .sft-results-grid { grid-template-columns: 1fr !important; }
}


/* ── Responsive ───────────────────────────────────────────── */
@media(max-width:700px) {
  #sft-root { padding:16px 12px 60px; }
  .sft-card { padding:20px; }
  /* Stack question rows vertically on mobile */
  .sft-q-row { flex-direction:column; gap:10px; }
  .sft-q-right { width:auto; }
  .sft-assess-footer { flex-direction:column;gap:10px; }
  .sft-results-actions { flex-direction:column;align-items:stretch; }
  .sft-results-actions .sft-btn { justify-content:center; }
}
