
/* ── Assessment Form ──────────────────────────────────────────────────────── */
:root{--navy-dark:#174e72;--bg:#f0f4f8;--surf:#ffffff;--green:#5cb85c;--red:#dc3545;--yellow:#d4a017}
body{background:var(--bg);min-height:100dvh}
.site-main{padding:0}
.calm-form{max-width:660px;margin:0 auto;padding:24px 16px 48px}
.progress-wrap{margin-bottom:28px}
.progress-steps{display:flex;align-items:center;gap:0;justify-content:space-between;position:relative}
.progress-steps::before{content:'';position:absolute;top:14px;left:14px;right:14px;height:2px;background:#c5d4e0;z-index:0}
.progress-track{position:absolute;top:14px;left:14px;height:2px;background:var(--navy);z-index:1;transition:width .35s ease}
.step-dot-wrap{display:flex;flex-direction:column;align-items:center;gap:6px;z-index:2}
.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:var(--surf);border:2px solid #c5d4e0;color:var(--muted);transition:all .25s}
.step-dot.done{background:var(--navy);border-color:var(--navy);color:#fff}
.step-dot.active{background:var(--navy);border-color:var(--navy);color:#fff;box-shadow:0 0 0 4px rgba(31,98,142,.18)}
.step-label{font-size:10px;color:var(--muted);text-align:center;max-width:56px;line-height:1.2}
.step-label.active{color:var(--navy);font-weight:600}
.progress-pct{text-align:right;font-size:12px;color:var(--muted);margin-top:10px}
.card{background:var(--surf);border-radius:14px;box-shadow:0 2px 16px rgba(31,98,142,.08);overflow:hidden}
.card-header{background:linear-gradient(135deg,var(--navy) 0%,#2a7ab8 100%);padding:22px 24px}
.card-header .dim-num{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:4px}
.card-header h2{font-size:19px;font-weight:700;color:#fff;line-height:1.3;margin-bottom:4px}
.card-header .dim-desc{font-size:13px;color:rgba(255,255,255,.75)}
.card-body{padding:24px}
.question-item{padding:16px 0;border-bottom:1px solid #c5d4e0}
.question-item:last-child{border-bottom:none}
.question-text{font-size:15px;color:var(--text);line-height:1.5;margin-bottom:14px;font-weight:500}
.likert{display:flex;flex-direction:column;gap:8px}
.likert-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);padding:0 2px}
.likert-options{display:flex;gap:6px}
.likert-opt{flex:1;position:relative}
.likert-opt input[type=radio]{position:absolute;opacity:0;width:0;height:0}
.likert-btn{display:flex;align-items:center;justify-content:center;height:48px;border-radius:8px;cursor:pointer;border:2px solid #c5d4e0;background:var(--bg);font-size:13px;font-weight:600;color:var(--muted);transition:all .15s;user-select:none}
.likert-btn:hover{border-color:var(--navy);color:var(--navy);background:rgba(31,98,142,.06)}
.likert-opt input:checked+.likert-btn{background:var(--navy);border-color:var(--navy);color:#fff}
.likert-opt input:focus-visible+.likert-btn{outline:2px solid var(--accent);outline-offset:2px}
.likert-val-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);padding:2px 4px 0}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input{width:100%;background:var(--bg);border:2px solid #c5d4e0;border-radius:8px;padding:12px 14px;color:var(--text);font-size:15px;font-family:inherit;outline:none;transition:border-color .2s}
.field input:focus{border-color:var(--navy)}
.optin-row{display:flex;gap:10px;align-items:flex-start;padding:14px;background:rgba(31,98,142,.05);border-radius:8px;border:1px solid rgba(31,98,142,.15)}
.optin-row input[type=checkbox]{flex-shrink:0;margin-top:3px;accent-color:var(--navy);width:18px;height:18px}
.optin-row label{font-size:13px;color:var(--muted);line-height:1.5}
.optin-row a{color:var(--navy)}
.card-footer{padding:16px 24px;border-top:1px solid #c5d4e0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.btn{padding:12px 22px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;border:none;font-family:inherit;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-dark)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid #c5d4e0;font-size:14px;padding:10px 18px}
.btn-ghost:hover{background:var(--bg);color:var(--text)}
.btn-magic{background:transparent;color:var(--muted);border:none;font-size:12px;padding:8px 0;text-decoration:underline;cursor:pointer;font-family:inherit}
.btn-magic:hover{color:var(--navy)}
.spacer{flex:1}
.midpoint-banner{background:linear-gradient(135deg,#e8f4ed 0%,#ddf0e8 100%);border:1px solid #b3d9c4;border-radius:10px;padding:14px 18px;margin-bottom:20px;font-size:14px;color:#2d6a4a;display:none}
.midpoint-banner.show{display:block}
.err-msg{font-size:13px;color:var(--red);margin-top:6px;display:none}
.err-msg.show{display:block}
.question-item.unanswered .question-text{color:var(--red)}
.question-item.unanswered .likert-btn{border-color:rgba(220,53,69,.4)}
.confirm-screen{display:none;text-align:center;padding:48px 24px}
.confirm-screen.show{display:block}
.confirm-icon{font-size:56px;margin-bottom:16px}
.confirm-screen h2{font-size:22px;font-weight:700;color:var(--navy);margin-bottom:12px}
.confirm-screen p{font-size:15px;color:var(--muted);line-height:1.65;max-width:380px;margin:0 auto 20px}
.confirm-highlight{background:rgba(31,98,142,.08);border-radius:10px;padding:16px 20px;margin:0 auto 20px;max-width:380px;font-size:14px;color:var(--navy);font-weight:600}
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* ── Confirm & Result Pages ───────────────────────────────────────────────── */
.cd-center{max-width:480px;margin:48px auto;padding:0 16px;text-align:center}
.cd-card{background:#fff;border-radius:14px;padding:36px 28px;box-shadow:0 2px 16px rgba(31,98,142,.08)}
.cd-icon{font-size:48px;margin-bottom:16px}
.cd-card h1{font-size:21px;font-weight:700;color:#152030;margin:0 0 10px}
.cd-card p{font-size:14px;color:#4a6580;line-height:1.6;margin:0 0 16px}
.cd-spinner{width:32px;height:32px;border:3px solid #c5d4e0;border-top-color:#1f628e;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}
.cd-card a{color:#1f628e}
.result-hero{background:var(--navy);padding:28px 24px 24px;text-align:center}
.result-hero .eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin:0 0 8px}
.result-hero h1{font-family:var(--fb,Georgia,serif);font-size:24px;font-weight:600;color:#fff;margin:0;line-height:1.3}
.result-body{max-width:660px;margin:0 auto;padding:28px 16px 48px}
.r-card{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(31,98,142,.08);margin-bottom:20px;overflow:hidden}
.r-card-header{padding:18px 24px 14px;border-bottom:1px solid #e8f0f7}
.r-card-header h2{font-size:15px;font-weight:700;color:#152030;margin:0}
.r-card-body{padding:20px 24px}
.overall-pill{display:inline-flex;align-items:center;gap:10px;background:#f0f4f8;border-radius:50px;padding:10px 20px;margin-bottom:20px}
.overall-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.overall-label{font-size:14px;font-weight:700;color:#152030}
.overall-sub{font-size:12px;color:#4a6580}
.chart-wrap{display:flex;justify-content:center;align-items:center;padding:12px 0}
.dim-list{display:flex;flex-direction:column;gap:12px}
.dim-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.dim-info{min-width:0}
.dim-name{font-size:14px;font-weight:600;color:#152030;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dim-bar-wrap{height:8px;background:#e8f0f7;border-radius:4px;overflow:hidden;margin-top:5px}
.dim-bar{height:100%;border-radius:4px}
.dim-score{text-align:right;white-space:nowrap}
.dim-pct{font-size:14px;font-weight:700}
.dim-range-label{font-size:11px;font-weight:600;display:block;text-transform:uppercase;letter-spacing:.04em;margin-top:1px}
.cta-box{background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(31,98,142,.08);padding:28px 24px;text-align:center}
.cta-icon{font-size:36px;margin-bottom:12px}
.cta-box h3{font-size:18px;font-weight:700;color:#152030;margin:0 0 10px}
.cta-box p{font-size:14px;color:#4a6580;line-height:1.6;margin:0 0 20px}
.btn-cta{display:inline-block;background:var(--accent);color:#fff;font-size:15px;font-weight:700;padding:14px 32px;border-radius:50px;text-decoration:none;letter-spacing:.01em}
.btn-cta:hover{background:#c8854d;text-decoration:none}
.cta-hint{font-size:12px;color:#9ca3af;margin-top:14px}
.r-legend{display:flex;flex-wrap:wrap;gap:10px 20px;padding:14px 24px;background:#f9f5f0;border-top:1px solid #e4d9ce}
.r-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#4a6580}
.r-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.r-loading{text-align:center;padding:60px 20px;color:#4a6580}
.r-loading-spinner{width:36px;height:36px;border:3px solid #c5d4e0;border-top-color:#1f628e;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}
@media print{.cta-box{display:none}}
