/* Surgery Savings Calculator - Spark Bariatric - v1.0.3 */

.ssc-calculator {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: #1a1a2e;
    max-width: 900px;
    margin: 0 auto;
    padding: 0 16px;
    box-sizing: border-box;
}
.ssc-calculator *, .ssc-calculator *::before, .ssc-calculator *::after { box-sizing: inherit; }

.ssc-step { animation: sscFade .3s ease; }
@keyframes sscFade { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

/* Step header */
.ssc-step-header { text-align:center; margin-bottom:32px; }
.ssc-step-badge { display:inline-block; background:#eff6ff; color:#2563eb; font-size:12px; font-weight:600; letter-spacing:.5px; text-transform:uppercase; padding:4px 12px; border-radius:20px; margin-bottom:12px; }
.ssc-step-title { font-size:24px; font-weight:700; margin:0 0 10px; color:#1a1a2e; line-height:1.3; }
.ssc-step-subtitle { font-size:15px; color:#666; margin:0; line-height:1.6; }

/* Condition cards */
.ssc-conditions-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:14px; margin-bottom:28px; }
.ssc-condition-card {
    background:#fff; border:2px solid #e8e8e8; border-radius:12px;
    padding:24px 16px; cursor:pointer;
    transition:border-color .2s, box-shadow .2s, transform .15s;
    position:relative; text-align:center;
    display:flex; flex-direction:column; align-items:center; gap:8px;
    user-select:none;
}
.ssc-condition-card:hover { border-color:#93c5fd; box-shadow:0 4px 16px rgba(37,99,235,.1); transform:translateY(-2px); }
.ssc-condition-card.ssc-selected { border-color:#2563eb; background:#eff6ff; box-shadow:0 4px 16px rgba(37,99,235,.15); }
.ssc-condition-card.ssc-selected::after {
    content:'&#10003;'; position:absolute; top:8px; right:10px;
    background:#2563eb; color:#fff; border-radius:50%;
    width:20px; height:20px; font-size:11px; font-weight:700;
    display:flex; align-items:center; justify-content:center;
}
.ssc-condition-icon { font-size:28px; line-height:1; }
.ssc-condition-name { font-weight:700; font-size:14px; color:#1a1a2e; line-height:1.3; }

/* Footer */
.ssc-step-footer { display:flex; align-items:center; justify-content:flex-end; gap:16px; margin-top:24px; flex-wrap:wrap; }
.ssc-selected-summary { color:#2563eb; font-size:14px; font-weight:500; }

/* Buttons */
.ssc-btn { display:inline-flex; align-items:center; justify-content:center; padding:13px 28px; border-radius:8px; font-size:15px; font-weight:600; cursor:pointer; border:none; transition:background .2s, opacity .2s; }
.ssc-btn-primary { background:#2563eb; color:#fff; }
.ssc-btn-primary:hover:not([disabled]) { background:#1d4ed8; }
.ssc-btn-primary[disabled] { opacity:.4; cursor:not-allowed; }
.ssc-btn-secondary { background:transparent; color:#2563eb; border:2px solid #2563eb; }
.ssc-btn-secondary:hover { background:#eff6ff; }

/* Results blocks */
.ssc-results-block { background:#fff; border:1px solid #e8e8e8; border-radius:14px; padding:24px; margin-bottom:20px; }
.ssc-results-block-purple { border-color:#ede9fe; background:#faf5ff; }
.ssc-results-block-title { font-size:15px; font-weight:700; margin:0 0 20px; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.ssc-results-hint { font-size:13px; font-weight:400; color:#888; }
.ssc-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.ssc-dot-blue   { background:#2563eb; }
.ssc-dot-purple { background:#7c3aed; }

/* Summary cards */
.ssc-results-summary { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.ssc-summary-card { background:#f8f9fa; border:1px solid #e8e8e8; border-radius:10px; padding:16px 20px; text-align:center; flex:1; min-width:130px; }
.ssc-summary-current { border-color:#fca5a5; background:#fff5f5; }
.ssc-summary-after   { border-color:#d1fae5; background:#f0fdf4; }
.ssc-summary-savings { border-color:#2563eb; background:linear-gradient(135deg,#eff6ff,#dbeafe); }
.ssc-summary-savings-purple { border-color:#7c3aed; background:linear-gradient(135deg,#faf5ff,#ede9fe); }
.ssc-summary-label { font-size:11px; text-transform:uppercase; letter-spacing:.5px; color:#888; margin-bottom:6px; font-weight:600; }
.ssc-summary-value { font-size:24px; font-weight:800; color:#1a1a2e; }
.ssc-summary-savings .ssc-summary-value { color:#2563eb; font-size:26px; }
.ssc-summary-savings-purple .ssc-summary-value { color:#7c3aed; font-size:26px; }
.ssc-summary-arrow { font-size:18px; color:#ccc; flex-shrink:0; }

/* Chart */
.ssc-chart-section { margin-bottom:32px; }
.ssc-chart-title { font-size:16px; font-weight:700; margin-bottom:16px; }
.ssc-chart-wrap { background:#fff; border:1px solid #e8e8e8; border-radius:12px; padding:24px; height:300px; position:relative; }
.ssc-chart-wrap canvas { max-height:100% !important; }
.ssc-ten-year-callout { text-align:center; margin-top:14px; font-size:14px; color:#555; padding:14px 20px; background:#f8f9fa; border-radius:8px; border:1px solid #e8e8e8; line-height:1.8; }
.ssc-ten-year-callout strong { font-size:17px; }
.ssc-ten-year-callout strong:first-child { color:#2563eb; }
.ssc-ten-year-callout strong:last-child  { color:#7c3aed; }

/* Breakdown table */
.ssc-breakdown-section { margin-bottom:32px; }
.ssc-breakdown-title { font-size:16px; font-weight:700; margin-bottom:14px; }
.ssc-breakdown-table { border:1px solid #e8e8e8; border-radius:12px; overflow:hidden; }
.ssc-breakdown-row { display:grid; grid-template-columns:2fr 1.2fr 1fr 1.2fr; padding:12px 16px; font-size:14px; border-bottom:1px solid #f0f0f0; align-items:center; }
.ssc-breakdown-row:last-child { border-bottom:none; }
.ssc-breakdown-row:nth-child(even):not(.ssc-breakdown-header) { background:#fafafa; }
.ssc-breakdown-header { background:#f8f9fa; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.4px; color:#888; }
.ssc-bd-condition  { font-weight:600; color:#1a1a2e; }
.ssc-bd-resolution { font-size:13px; color:#555; }
.ssc-bd-savings    { color:#2563eb; font-weight:700; }
.ssc-bd-total      { color:#7c3aed; font-weight:700; }

/* Sources */
.ssc-sources-section { margin-bottom:32px; border:1px solid #e8e8e8; border-radius:12px; overflow:hidden; }
.ssc-sources-toggle { width:100%; display:flex; align-items:center; gap:8px; padding:14px 20px; background:#f8f9fa; border:none; cursor:pointer; font-size:14px; font-weight:600; color:#444; text-align:left; }
.ssc-sources-toggle:hover { background:#f0f0f0; }
.ssc-toggle-icon { margin-left:auto; font-size:16px; color:#888; }
.ssc-sources-content { padding:20px 24px; background:#fff; }
.ssc-sources-intro { font-size:13px; color:#666; margin-bottom:14px; line-height:1.6; }
.ssc-sources-list { padding-left:20px; margin:0 0 14px; }
.ssc-sources-list li { font-size:13px; color:#555; line-height:1.7; margin-bottom:6px; }
.ssc-disclaimer { font-size:12px; color:#999; border-top:1px solid #f0f0f0; padding-top:14px; margin-bottom:0; line-height:1.6; }

/* Email */
.ssc-email-section { margin-bottom:28px; }
.ssc-email-card { background:linear-gradient(135deg,#1a1a2e 0%,#2563eb 100%); border-radius:16px; padding:36px 40px; text-align:center; }
.ssc-email-title { font-size:20px; font-weight:700; margin:0 0 8px; color:#fff; }
.ssc-email-subtitle { font-size:14px; color:rgba(255,255,255,.8); margin:0 0 24px; }
.ssc-email-form { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; max-width:560px; margin:0 auto; }
.ssc-input { flex:1; min-width:180px; padding:12px 16px; border-radius:8px; border:none; font-size:14px; outline:none; color:#1a1a2e; background:rgba(255,255,255,.95); }
.ssc-email-form .ssc-btn-primary { background:#fff; color:#2563eb; flex-shrink:0; }
.ssc-email-form .ssc-btn-primary:hover { background:#eff6ff; }
.ssc-email-success { color:#d1fae5; font-size:15px; font-weight:600; padding:12px; }
.ssc-email-error { color:#fca5a5; font-size:14px; margin-top:10px; }
.ssc-privacy-note { font-size:12px; color:rgba(255,255,255,.5); margin:12px 0 0; }

/* Responsive */
@media (max-width:640px) {
    .ssc-step-title { font-size:20px; }
    .ssc-conditions-grid { grid-template-columns:1fr 1fr; }
    .ssc-results-summary { flex-direction:column; }
    .ssc-summary-arrow { transform:rotate(90deg); }
    .ssc-breakdown-row { grid-template-columns:1fr 1fr; gap:4px; }
    .ssc-breakdown-header { display:none; }
    .ssc-email-card { padding:24px 20px; }
}
@media (max-width:380px) {
    .ssc-conditions-grid { grid-template-columns:1fr; }
}
