/* Mortgage Qualification calculator — Maple Groove Financial brand styling.
   All selectors scoped under .mwx so nothing leaks into the shared sheet
   (and the shared sheet's bare selectors can't reach in). Brand tokens
   (--ink, --accent, --blue, --green, --amber, --rule…) come from
   styles.css :root, loaded on the page. Mirrors the IPP (.ippx) build. */

.mwx{
  max-width:1180px;
  margin:0 auto;
  font-family:'Space Mono', ui-monospace, monospace;
  color:var(--ink);
  font-size:15px;
}

/* ── intro ─────────────────────────────────────────────────── */
.mwx .page-header{margin:6px 0 22px}
.mwx .page-header h1{
  font-family:'Bebas Neue', sans-serif;
  font-size:38px;font-weight:400;letter-spacing:0.04em;
  color:var(--ink);margin-bottom:8px;
}
.mwx .page-header p{font-size:13px;color:var(--ink-dim);max-width:64ch;line-height:1.6}

/* ── command deck: chart beside headline + verdict ─────────── */
.mwx .deck{
  display:grid;grid-template-columns:1.5fr 1fr;gap:20px;
  align-items:stretch;margin-bottom:20px;
}
.mwx .card{background:#0c0c0c;border:1px solid var(--rule-2);border-radius:12px;overflow:hidden}
.mwx .card-hd{
  padding:9px 16px;border-bottom:1px solid var(--rule-2);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.mwx .hd-title{font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:0.05em;color:var(--ink)}
.mwx .card-body{padding:18px 20px}

.mwx .chart-card{display:flex;flex-direction:column}
.mwx .chart-wrap{position:relative;flex:1;min-height:178px;padding:8px 12px}
.mwx .legend{display:flex;gap:14px;flex-wrap:wrap;padding:0 16px 8px}
.mwx .leg{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--ink-dim)}
.mwx .leg-line{width:18px;height:0;border-top:3px solid;border-radius:2px;flex-shrink:0}
.mwx .leg.dashed .leg-line{border-top-style:dashed}

/* ── headline panel (right of chart) ───────────────────────── */
.mwx .headline{display:flex;flex-direction:column;gap:10px}
.mwx .hl-pay{
  background:#07131f;border:1px solid #14344e;border-radius:10px;padding:9px 14px;
}
.mwx .hl-pay .lbl{font-size:10px;color:#9ec3df;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:2px}
.mwx .hl-pay .val{font-family:'Bebas Neue',sans-serif;font-size:26px;line-height:0.95;color:var(--blue)}
.mwx .hl-pay .sub{font-size:10px;color:var(--ink-dim);margin-top:2px}
.mwx .hl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.mwx .hl-stat{background:#0c0c0c;border:1px solid var(--rule-2);border-radius:10px;padding:8px 10px}
.mwx .hl-stat .lbl{font-size:10px;color:var(--ink-dim);letter-spacing:0.04em;margin-bottom:3px}
.mwx .hl-stat .val{font-family:'Bebas Neue',sans-serif;font-size:19px;line-height:1;color:var(--ink)}
.mwx .hl-stat .val.amber{color:var(--amber)}
.mwx .hl-stat .val.green{color:var(--green)}

/* ── qualification verdict ─────────────────────────────────── */
.mwx .verdict{border-radius:10px;padding:8px 13px;border:2px solid;display:flex;flex-direction:column;gap:6px}
.mwx .verdict.pass{background:#06140c;border-color:var(--green);box-shadow:0 0 18px rgba(74,222,128,0.18)}
.mwx .verdict.tight{background:#1a1400;border-color:var(--amber);box-shadow:0 0 18px rgba(232,166,52,0.18)}
.mwx .verdict.fail{background:#1a0707;border-color:var(--accent);box-shadow:0 0 18px rgba(214,40,40,0.2)}
.mwx .verdict-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.mwx .verdict-title{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:0.04em}
.mwx .verdict.pass .verdict-title{color:var(--green)}
.mwx .verdict.tight .verdict-title{color:var(--amber)}
.mwx .verdict.fail .verdict-title{color:var(--accent-glow)}
.mwx .verdict-sub{font-size:10.5px;color:var(--ink-dim);line-height:1.4}
.mwx .ratio-row{display:flex;flex-direction:column;gap:5px}
.mwx .ratio-line{display:flex;justify-content:space-between;align-items:baseline;font-size:12px}
.mwx .ratio-line .rk{color:var(--ink-dim)}
.mwx .ratio-line .rv{font-weight:700;font-variant-numeric:tabular-nums}
.mwx .bar{height:7px;background:var(--rule-2);border-radius:4px;overflow:hidden;position:relative}
.mwx .bar-fill{height:100%;border-radius:4px;transition:width .3s}
.mwx .bar-fill.ok{background:var(--green)}
.mwx .bar-fill.warn{background:var(--amber)}
.mwx .bar-fill.over{background:var(--accent)}
.mwx .bar-limit{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--ink);opacity:0.55}

/* ── controls strip ────────────────────────────────────────── */
.mwx .controls{
  display:grid;grid-template-columns:repeat(2,1fr);gap:22px 30px;
  background:#0c0c0c;border:1px solid var(--rule-2);border-radius:12px;
  padding:22px 24px;margin-bottom:20px;
}
.mwx .ctrl-group{min-width:0}
.mwx .ctrl-group__title{
  font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:0.07em;
  margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--rule);
}
.mwx .ctrl-group__title.blue{color:var(--blue)}
.mwx .ctrl-group__title.green{color:var(--green)}
.mwx .ctrl-group__title.amber{color:var(--amber)}
.mwx .ctrl-group__title.red{color:var(--accent)}

/* sliders */
.mwx .sl{margin-bottom:15px}
.mwx .sl:last-child{margin-bottom:0}
.mwx .sl label{font-size:12px;color:var(--ink-dim);display:block;margin-bottom:7px;letter-spacing:0.03em}
.mwx .sl-row{display:flex;align-items:center;gap:12px}
.mwx .sl-row input[type=range]{flex:1;height:5px;accent-color:var(--blue);cursor:pointer;min-width:0}
.mwx .sl-val{font-size:14px;font-weight:700;color:var(--ink);min-width:92px;text-align:right;font-variant-numeric:tabular-nums}
.mwx .sl-val.editable{cursor:text;border-bottom:1px dashed var(--rule-2)}

/* number / select fields */
.mwx .fld{margin-bottom:15px}
.mwx .fld:last-child{margin-bottom:0}
.mwx .fld label{font-size:12px;color:var(--ink-dim);display:block;margin-bottom:7px;letter-spacing:0.03em}
.mwx .fld input[type=number],
.mwx .fld select{
  width:100%;background:#070707;border:1px solid var(--rule-2);border-radius:8px;
  color:var(--ink);font-family:inherit;font-size:14px;padding:9px 11px;
}
.mwx .fld input[type=number]:focus,.mwx .fld select:focus{outline:none;border-color:var(--blue)}

/* segmented toggle (amortization, rate type, frequency-ish) */
.mwx .seg{display:flex;gap:6px;flex-wrap:wrap}
.mwx .seg button{
  flex:1;min-width:fit-content;background:#070707;border:1px solid var(--rule-2);
  color:var(--ink-dim);font-family:inherit;font-size:12px;padding:8px 10px;border-radius:8px;cursor:pointer;
  transition:all .15s;white-space:nowrap;
}
.mwx .seg button:hover{border-color:var(--ink-dim)}
.mwx .seg button.active{background:#07131f;border-color:var(--blue);color:var(--blue);font-weight:700}

/* inline checkbox row */
.mwx .chk{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--ink-dim);margin-bottom:12px;cursor:pointer}
.mwx .chk input{width:15px;height:15px;accent-color:var(--blue);cursor:pointer}
.mwx .chk:last-child{margin-bottom:0}
.mwx .hint{font-size:10.5px;color:var(--ink-faint);line-height:1.5;margin-top:6px}

/* per-renewal rate rows */
.mwx .rate-blocks{display:flex;flex-direction:column;gap:9px}
.mwx .rate-block{display:flex;align-items:center;gap:10px}
.mwx .rate-block .rb-label{font-size:11px;color:var(--ink-dim);min-width:96px;font-variant-numeric:tabular-nums}
.mwx .rate-block input[type=range]{flex:1;height:5px;accent-color:var(--amber);cursor:pointer;min-width:0}
.mwx .rate-block .rb-val{font-size:13px;font-weight:700;color:var(--amber);min-width:58px;text-align:right;font-variant-numeric:tabular-nums}

/* ── results breakdown ─────────────────────────────────────── */
.mwx .results{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.mwx .panel{background:#0c0c0c;border:1px solid var(--rule-2);border-radius:12px;padding:20px 22px}
.mwx .panel-title{font-family:'Bebas Neue',sans-serif;font-size:19px;letter-spacing:0.04em;color:var(--ink);margin-bottom:14px}
.mwx .line{display:flex;justify-content:space-between;align-items:center;padding:6px 0;gap:14px;border-bottom:1px solid var(--rule)}
.mwx .line:last-child{border-bottom:0}
.mwx .line span{font-size:13px;color:var(--ink-dim)}
.mwx .line strong{font-size:13px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.mwx .line.deduct strong{color:var(--accent-glow)}
.mwx .line.tot{padding-top:9px}
.mwx .line.tot span{color:var(--ink);font-weight:700;font-size:14px}
.mwx .line.tot strong{font-size:16px;color:var(--blue)}
.mwx .line.tot.green strong{color:var(--green)}

/* ── snapshot actions + disclaimer ─────────────────────────── */
.mwx .actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.mwx .actions button{
  background:#07131f;border:1px solid #14344e;color:var(--blue);font-family:inherit;
  font-size:13px;font-weight:700;padding:11px 20px;border-radius:8px;cursor:pointer;transition:all .15s;
}
.mwx .actions button:hover{background:#0a1c2b;transform:translateY(-1px)}
.mwx .disclaimer{
  font-size:11px;color:var(--ink-faint);line-height:1.7;
  border:1px dashed var(--rule-2);border-radius:10px;padding:16px 18px;
}
.mwx .disclaimer strong{color:var(--ink-dim);font-weight:700}

/* ── responsive ────────────────────────────────────────────── */
@media(max-width:920px){
  .mwx .deck{grid-template-columns:1fr}
  .mwx .controls{grid-template-columns:1fr 1fr}
  .mwx .results{grid-template-columns:1fr}
}
@media(max-width:680px){
  .mwx .controls{grid-template-columns:1fr}
  .mwx .hl-grid{grid-template-columns:1fr 1fr}
  .mwx .page-header h1{font-size:30px}
  .mwx .closing-deck{grid-template-columns:1fr}
}

/* ── editable value inputs (price / down — exact entry) ── */
.mwx .sl-input{
  background:transparent;border:none;border-bottom:1px dashed var(--rule-2);
  color:var(--ink);font-family:inherit;font-weight:700;font-size:14px;
  text-align:right;min-width:96px;width:120px;padding:2px 0;
  font-variant-numeric:tabular-nums;
}
.mwx .sl-input:focus{outline:none;border-bottom-color:var(--blue);color:var(--blue)}

/* ── province closing-cost deck ── */
.mwx .closing-deck{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start;margin-bottom:20px}
.mwx .map-panel{background:#0c0c0c;border:1px solid var(--rule-2);border-radius:12px;padding:20px;text-align:center}
.mwx .map-prompt{font-size:11px;color:var(--ink-dim);margin-bottom:14px;letter-spacing:0.25em;text-transform:uppercase}
.mwx .map-inner{max-width:560px;margin:0 auto}
.mwx #canada-map path{fill:#1c2433}
.mwx .prov-map-group{transition:filter .15s, transform .2s;cursor:pointer;transform-box:fill-box;transform-origin:center bottom}
.mwx .prov-map-group:hover{filter:brightness(1.5);transform:translateY(-7px)}
.mwx .prov-map-group.selected{transform:translateY(-10px)}
.mwx .prov-map-group.selected path,.mwx path.prov-map-group.selected{fill:var(--blue) !important}
.mwx .selected-bar{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:14px;padding:12px 18px;background:#07131f;border:1px solid #14344e;border-radius:8px;min-height:48px}
.mwx .prov-name{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:0.06em;color:var(--blue)}
.mwx .rate-chip{font-size:12px;color:#bae6fd;background:#0a1c2b;border:1px solid #14344e;border-radius:5px;padding:4px 12px}
.mwx .closing-deck .chk{margin-bottom:14px}

/* The shared sheet sets `overflow-x:hidden` on html/body, which makes body a
   scroll container and breaks position:sticky. `clip` prevents the same
   horizontal scroll WITHOUT creating a scroll container, so the deck can pin to
   the viewport. Scoped here (mortgage.css only loads on this page). */
html, body { overflow-x: clip; }

/* ── sticky command deck (desktop) ──
   Pin the chart + headline + verdict just under the fixed nav so you can
   scroll through the controls and watch them react. Desktop + tall-enough
   windows only — on phones / short screens it stays in normal flow so it
   doesn't swallow the viewport. Black background covers content scrolling
   under the inter-card gap. */
@media (min-width: 921px) and (min-height: 760px) {
  .mwx .deck {
    position: sticky;
    top: calc(var(--bar-h) + 8px);
    z-index: 5;
    background: var(--bg);
    padding-bottom: 14px;
  }
}

/* ── lender text input ── */
.mwx .fld input[type=text]{
  width:100%;background:#070707;border:1px solid var(--rule-2);border-radius:8px;
  color:var(--ink);font-family:inherit;font-size:14px;padding:9px 11px;
}
.mwx .fld input[type=text]:focus{outline:none;border-color:var(--blue)}
.mwx .fld input[type=text]::placeholder{color:var(--ink-faint)}

/* ── scenario save bar ── */
.mwx .scenarios-bar{background:#0c0c0c;border:1px solid var(--rule-2);border-radius:12px;padding:16px 18px;margin-bottom:18px}
.mwx .scen-label{display:block;font-size:12px;color:var(--ink-dim);margin-bottom:12px}
.mwx .scen-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.mwx .scen-btn{background:#07131f;border:1px solid #14344e;color:var(--blue);font-family:inherit;font-size:12.5px;font-weight:700;padding:9px 14px;border-radius:8px;cursor:pointer;transition:all .15s}
.mwx .scen-btn:hover{background:#0a1c2b;transform:translateY(-1px)}
.mwx .scen-compare{display:inline-block;color:var(--amber);font-weight:700;font-size:13px;text-decoration:none;border-bottom:1px dashed var(--amber)}
.mwx .scen-compare:hover{color:var(--amber-glow)}
.mwx #scen-status{margin-top:10px;color:var(--green)}
