/* ROI calculator — page + ungated industry variant. Uses the site design tokens. */
.roi-hero{padding-bottom:0}
.roi-sec{padding-top:clamp(40px,5vw,64px)}
.roi{max-width:980px;margin:0 auto}

.roi-card{background:var(--paper);border:1px solid var(--line);border-radius:calc(var(--radius) + 4px);
  box-shadow:0 24px 60px -28px rgba(11,27,43,.28),0 2px 8px rgba(11,27,43,.05);padding:clamp(24px,4vw,44px)}

/* ---- email gate ---- */
.roi-gate{max-width:560px;margin:0 auto;text-align:center}
.roi-gate-head{display:flex;flex-direction:column;align-items:center;gap:.7rem;margin-bottom:.4rem}
.roi-lock{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;
  background:rgba(24,194,230,.12);color:var(--brand-600);border:1.5px solid color-mix(in srgb,var(--spark) 40%,var(--line))}
.roi-gate h2{font-size:clamp(24px,3vw,30px);margin:0}
.roi-gate-lede{color:var(--ink-70,#3d4d5b);font-size:1.05rem;line-height:1.6;max-width:46ch;margin:.2rem auto 1.3rem}
.roi-trust{list-style:none;padding:0;margin:0 auto 1.6rem;display:inline-flex;flex-direction:column;gap:.6rem;text-align:left}
.roi-trust li{display:flex;align-items:flex-start;gap:.6rem;font-size:.96rem;color:var(--ink);font-weight:500}
.roi-check{flex:none;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;
  background:rgba(30,158,106,.14);color:var(--success);font-size:.8rem;font-weight:800;margin-top:1px}
.roi-gate-form{display:flex;gap:.6rem;max-width:480px;margin:0 auto;flex-wrap:wrap}
.roi-gate-form .roi-input{flex:1;min-width:200px}
.roi-gate-btn{white-space:nowrap}
.roi-gate-err{color:var(--danger);font-weight:600;font-size:.92rem;margin:.7rem 0 0}
.roi-gate-fine{color:var(--slate);font-size:.82rem;margin:1.1rem auto 0;max-width:44ch}

/* ---- shared input styling ---- */
.roi-input{width:100%;min-height:48px;padding:.7rem .95rem;border:1px solid var(--line);border-radius:12px;
  background:var(--paper);color:var(--ink);font:inherit;font-size:1rem}
.roi-input::placeholder{color:#9aa6b1}
.roi-input:focus{outline:none;border-color:var(--spark);box-shadow:0 0 0 3px rgba(24,194,230,.22)}
select.roi-input{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235B6B7B' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right .9rem center;padding-right:2.4rem}

/* ---- calculator ---- */
.roi-calc-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,360px);gap:clamp(24px,3vw,40px);align-items:start}
.roi-h2{font-size:clamp(22px,2.6vw,28px);margin:0 0 .35rem}
.roi-calc-sub{color:var(--slate);margin:0 0 1.4rem;font-size:.96rem;line-height:1.55}
.roi-field{margin-bottom:1.1rem}
.roi-field label{display:block;font-weight:600;font-size:.95rem;color:var(--ink);margin-bottom:.4rem;line-height:1.4}

/* results panel — dark so the numbers pop */
.roi-results{position:sticky;top:90px;background:linear-gradient(160deg,var(--brand-600),var(--ink) 88%);
  color:#fff;border-radius:18px;padding:26px 24px 24px;box-shadow:0 20px 44px -22px rgba(11,27,43,.5)}
.roi-results-eyebrow{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#9fe9f6;margin:0 0 .7rem}
.roi-stat{display:flex;flex-direction:column;gap:.15rem}
.roi-stat-lead{margin-bottom:1.1rem}
.roi-stat-num{font-family:var(--sans);font-weight:800;letter-spacing:-.02em;line-height:1;font-size:clamp(40px,6vw,52px);color:#7fe3f5}
.roi-stat-num.sm{font-size:clamp(24px,3vw,30px);color:#fff}
.roi-stat-lbl{font-size:.86rem;color:rgba(255,255,255,.78);font-weight:500}
.roi-stat-row{display:flex;gap:22px;flex-wrap:wrap;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.14)}
.roi-results-note{font-size:.8rem;color:rgba(255,255,255,.66);line-height:1.5;margin:1.2rem 0 1.3rem}
.roi-plan-btn{width:100%;justify-content:center}

/* ---- build-cost estimate callout ---- */
.roi-build-est{margin:1.1rem 0 .9rem;padding:.75rem 1rem;border-left:3px solid var(--spark);background:rgba(24,194,230,.07);border-radius:0 10px 10px 0}
.roi-build-est[hidden]{display:none}
.roi-build-est-label{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#9fe9f6;margin:0 0 .25rem}
.roi-build-est-range{font-size:1.15rem;font-weight:700;color:#fff;margin:0 0 .55rem;line-height:1.3}
.roi-build-est-own{font-weight:400;font-size:.9rem;color:rgba(255,255,255,.72)}

/* ---- net / payback stats row ---- */
.roi-net-stats{display:flex;flex-wrap:wrap;gap:.4rem .9rem;align-items:center}
.roi-net-item{font-size:.88rem;color:rgba(255,255,255,.85)}
.roi-net-item strong{color:#7fe3f5;font-weight:700}
.roi-net-sep{color:rgba(255,255,255,.35);font-size:.8rem}

/* ---- large-scope consult nudge ---- */
.roi-large-scope{margin:1rem 0 .9rem;padding:.8rem 1rem;background:rgba(255,255,255,.07);border-radius:10px;border:1px solid rgba(255,255,255,.14)}
.roi-large-scope[hidden]{display:none}
.roi-large-scope p{font-size:.93rem;color:rgba(255,255,255,.88);margin:0 0 .55rem;line-height:1.5}
.roi-large-scope-link{font-size:.9rem;font-weight:600;color:#9fe9f6;text-decoration:none}
.roi-large-scope-link:hover{text-decoration:underline}

/* ---- methodology expandable ---- */
details.roi-methodology{margin:.9rem 0 1rem}
details.roi-methodology summary{font-size:.78rem;font-weight:600;color:rgba(255,255,255,.55);cursor:pointer;list-style:none;user-select:none}
details.roi-methodology summary::-webkit-details-marker{display:none}
details.roi-methodology summary::before{content:'+ ';font-weight:800}
details.roi-methodology[open] summary::before{content:'− '}
.roi-methodology-list{margin:.5rem 0 0 .1rem;padding:0;list-style:none;display:flex;flex-direction:column;gap:.4rem}
.roi-methodology-list li{font-size:.77rem;color:rgba(255,255,255,.55);line-height:1.5;padding-left:1rem;position:relative}
.roi-methodology-list li::before{content:'·';position:absolute;left:0;color:rgba(255,255,255,.3)}
.roi-methodology-list strong{color:rgba(255,255,255,.75)}

/* ---- Ada's generated plan ---- */
.roi-plan{margin-top:clamp(28px,4vw,40px);padding-top:clamp(24px,3vw,32px);border-top:1px solid var(--line)}
.roi-plan[hidden]{display:none}
.roi-plan-status{display:flex;align-items:center;gap:.7rem;color:var(--slate);font-weight:500}
.roi-plan-status[hidden]{display:none}
.roi-spinner{width:20px;height:20px;border-radius:50%;border:2.5px solid rgba(20,89,140,.2);border-top-color:var(--brand-600);
  animation:roi-spin .8s linear infinite;flex:none}
@keyframes roi-spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.roi-spinner{animation:none}}
.roi-plan-body{max-width:70ch}
.roi-plan-body h2{font-size:1.35rem;margin:1.4rem 0 .5rem}
.roi-plan-body h3{font-size:1.08rem;margin:1.1rem 0 .3rem;color:var(--brand-700)}
.roi-plan-body p,.roi-plan-body li{color:var(--ink-soft);line-height:1.7}
.roi-plan-cta{margin-top:1.6rem}
.roi-plan-cta[hidden]{display:none}

/* ---- Ada help section reuses .finder-page-grid (35/65) ---- */
.roi-ada-sec .finder-page-copy .ticks{margin:1.2rem 0 0}

/* ---- ungated industry-page variant: compact, no dark sticky panel ---- */
.roi-ungated .roi-calc-grid{grid-template-columns:1fr}
.roi-ungated .roi-results{position:static;margin-top:1.2rem}
.roi-ungated .roi-card{padding:clamp(20px,3vw,28px)}

/* ---- "Example" preview behind the gate (shows what you're unlocking) ---- */
[data-roi-gatewrap][hidden]{display:none}
.roi-example{position:relative;max-width:980px;margin:26px auto 0}
.roi-example-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);z-index:2;
  background:var(--ink);color:#fff;font-family:var(--sans);font-size:11.5px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;padding:5px 14px;border-radius:99px;box-shadow:0 6px 16px rgba(11,27,43,.22)}
.roi-calc-preview{opacity:.97}
.roi-input-demo{display:flex;align-items:center;color:var(--ink);font-weight:600;
  background:var(--mist);border-style:dashed;border-color:color-mix(in srgb,var(--brand-600) 26%,var(--line))}

@media (max-width:760px){
  .roi-calc-grid{grid-template-columns:1fr}
  .roi-results{position:static}
  .roi-gate-form{flex-direction:column}
  .roi-gate-form .roi-input{min-width:0}
  .roi-gate-btn{width:100%;justify-content:center}
}

/* ---- hidden-until-JS utility ---- */
[data-roi-when-numbers][hidden]{display:none}
[data-roi-locked][hidden]{display:none}

/* ---- v4 block-1 cost lines ---- */
.roi-cost-line--b1{padding:7px 0;border-bottom:1px dashed rgba(255,255,255,.12)}
.roi-b1-total{display:flex;flex-direction:column;gap:.25rem;padding:12px 0 4px;border-top:1px solid rgba(255,255,255,.2);margin-top:8px}
.roi-annual-lbl{font-size:.85rem;color:rgba(255,255,255,.65);display:flex;align-items:baseline;gap:.4rem}
.roi-annual-lbl .roi-stat-num.sm{font-size:clamp(18px,2.5vw,22px)}

/* ---- maintenance toggle ---- */
.roi-maint-toggle{margin-top:10px}
.roi-maint-toggle input:checked ~ .roi-web-sw{background:var(--success,#1e9e6a)}
.roi-suggested-pill{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#06222b;background:#5bf0a5;padding:2px 7px;border-radius:99px;vertical-align:middle;margin-left:5px}

/* ---- locked placeholder (dashed, muted) ---- */
.roi-locked-placeholder{font-size:.85rem;color:rgba(255,255,255,.52);border:1.5px dashed rgba(255,255,255,.22);border-radius:10px;padding:10px 14px;text-align:center;margin-top:4px}

/* ---- build disclaimer ---- */
.roi-build-disclaimer{font-size:11.5px;color:rgba(255,255,255,.48);margin:10px 0 0;line-height:1.5;font-style:italic}

/* ---- v3 results panel: bordered step cards, badges, agent+website cost ---- */
.roi-results-v3{padding:22px 20px 20px}
.roi-rblock{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.16);border-radius:15px;padding:18px 18px 16px;margin-bottom:14px}
.roi-rblock--cost{background:rgba(24,194,230,.07);border-color:rgba(127,227,245,.32)}
.roi-rblock-head{display:flex;align-items:flex-start;gap:13px;margin-bottom:14px}
.roi-rbadge{width:32px;height:32px;border-radius:9px;background:var(--spark);color:#06222b;font-family:var(--sans);font-weight:800;font-size:18px;display:grid;place-items:center;flex:none;margin-top:1px}
.roi-rblock-titles{flex:1;min-width:0}
.roi-rblock-title{display:block;font-family:var(--sans);font-size:16px;font-weight:800;letter-spacing:.02em;color:#fff;line-height:1.18}
.roi-rblock-sub{display:block;font-size:12.5px;color:rgba(255,255,255,.64);font-weight:500;margin-top:3px;line-height:1.4}
.roi-stable-pill{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#06222b;background:#7fe3f5;padding:2px 8px;border-radius:99px;vertical-align:middle;margin-left:4px}
.roi-cost-line{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:9px 0;border-bottom:1px dashed rgba(255,255,255,.14)}
.roi-cost-line[hidden]{display:none}
.roi-cost-name{font-size:14px;font-weight:600;color:#eaf2f8}
.roi-cost-name small{display:block;font-size:11.5px;color:rgba(255,255,255,.56);font-weight:500;margin-top:2px;line-height:1.4}
.roi-cost-amt{font-family:var(--sans);font-weight:800;font-size:16.5px;color:#fff;white-space:nowrap}
.roi-cost-total{display:flex;justify-content:space-between;align-items:baseline;margin-top:10px;padding-top:11px;border-top:1px solid rgba(255,255,255,.2)}
.roi-cost-total-l{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.7)}
.roi-cost-total-v{font-family:var(--sans);font-weight:800;font-size:21px;color:#7fe3f5}
.roi-web-toggle{display:flex;align-items:center;gap:11px;margin:13px 0 2px;padding:11px 12px;border-radius:11px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);cursor:pointer}
.roi-web-toggle input{position:absolute;opacity:0;width:0;height:0}
.roi-web-sw{width:42px;height:24px;border-radius:99px;background:rgba(255,255,255,.22);position:relative;flex:none;transition:background .15s}
.roi-web-sw::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .15s}
.roi-web-toggle input:checked ~ .roi-web-sw{background:var(--spark)}
.roi-web-toggle input:checked ~ .roi-web-sw::after{transform:translateX(18px);background:#06222b}
.roi-web-toggle input:focus-visible ~ .roi-web-sw{outline:none;box-shadow:0 0 0 3px rgba(24,194,230,.4)}
.roi-web-toggle-l{font-size:13.5px;font-weight:700;color:#fff}
.roi-web-toggle-l small{display:block;font-size:11.5px;font-weight:500;color:rgba(255,255,255,.6)}
.roi-build-why{font-size:12.5px;color:rgba(255,255,255,.6);margin:10px 0 0;line-height:1.5}
.roi-pay{display:flex;gap:14px;flex-wrap:wrap}
.roi-pay-item{flex:1 1 0;min-width:120px;background:rgba(255,255,255,.04);border-radius:10px;padding:10px 12px}
.roi-pay-k{display:block;font-size:11.5px;color:rgba(255,255,255,.6);font-weight:600}
.roi-pay-v{display:block;font-family:var(--sans);font-size:18px;font-weight:800;color:#7fe3f5;margin-top:2px}
