:root{
  --sm-font:#692022;
  --sm-btn:#889063;
  --sm-grey:#efefef;
  --sm-sep:#d6d6d6;
  --sm-overlay: rgba(0,0,0,0.45);
}
body.sm-mmf-lock{ overflow:hidden; }

.sm-mmf-trigger{
  background: var(--sm-btn) !important;
  color: var(--sm-font) !important;
  border:0 !important;
  padding:12px 16px !important;
  font-weight:900 !important;
  border-radius:10px !important;
  cursor:pointer !important;
  text-decoration:none !important;
  display:inline-block !important;
  position:relative !important;
  z-index:99999 !important;
  pointer-events:auto !important;
}

.sm-mmf-modal{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  top: var(--sm-mmf-top, 0px);
  z-index: 2147483647;
  pointer-events: auto;
}
.sm-mmf-overlay{
  position:absolute;
  inset:0;
  background: var(--sm-overlay);
}
.sm-mmf-dialog{
  position: relative;
  width: min(60vw, 1040px);
  margin: 20px auto;
  background:#fff;
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
  overflow:hidden;
  max-height: calc(100vh - var(--sm-mmf-top, 0px) - 40px);
  display:flex;
  flex-direction:column;
}
.sm-mmf-topbar{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--sm-sep);
  background:#fff;
}
.sm-mmf-title{
  flex:1;
  text-align:center;
  font-weight: 900;
  color: var(--sm-font);
}
.sm-mmf-back{
  border:1px solid var(--sm-sep);
  background:#fff;
  color: var(--sm-font);
  border-radius: 8px;
  padding: 4px 8px;
  font-size: 12px;
  cursor:pointer;
}
.sm-mmf-close{
  border:1px solid var(--sm-sep);
  background:#fff;
  color: var(--sm-font);
  border-radius: 10px;
  padding: 6px 10px;
  font-size: 14px;
  cursor:pointer;
}
.sm-mmf-body{
  padding: 14px;
  overflow: auto;
}
.sm-mmf-grid{
  display:flex;
  gap:14px;
}
.sm-mmf-left{
  flex: 1 1 62%;
  border:1px solid var(--sm-sep);
  border-radius: 12px;
  padding: 14px;
  box-sizing:border-box;
}
.sm-mmf-right{
  flex: 0 0 38%;
  background: var(--sm-grey);
  border:1px solid var(--sm-sep);
  border-radius: 12px;
  padding: 14px;
  box-sizing:border-box;
}
.sm-mmf-summary-title{
  font-weight: 900;
  color: var(--sm-font);
  margin-bottom: 10px;
}
.sm-mmf-srow{
  padding: 10px 0;
  border-bottom: 1px solid var(--sm-sep);
}
.sm-mmf-srow .k{
  font-size: 13px;
  font-weight: 900;
  opacity: 0.95;
  color: var(--sm-font);
}
.sm-mmf-srow .v{
  margin-top: 4px;
  font-size: 12px;
  font-weight: 500;
  color: var(--sm-font);
  opacity: 0.9;
}
.sm-mmf-h{
  font-weight: 900;
  color: var(--sm-font);
  margin: 0 0 10px;
}
.sm-mmf-note{
  font-size: 12px;
  color: var(--sm-font);
  opacity: 0.85;
  margin-bottom: 10px;
}
.sm-mmf-btngrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.sm-mmf-btn{
  background: var(--sm-btn);
  color: var(--sm-font);
  border:0;
  border-radius:10px;
  padding:12px 10px;
  font-weight:900;
  cursor:pointer;
  text-align:center;
}
.sm-mmf-btn:hover{ filter: brightness(0.97); }
.sm-mmf-primary{
  width:100%;
  margin-top: 12px;
  background: var(--sm-btn);
  color: var(--sm-font);
  border:0;
  border-radius:10px;
  padding:12px 12px;
  font-weight:900;
  cursor:pointer;
}
.sm-mmf-label{
  display:block;
  font-size: 12px;
  font-weight: 900;
  margin: 10px 0 6px;
  color: var(--sm-font);
}
.sm-mmf-input{
  width:100%;
  padding: 10px;
  border-radius: 10px;
  border: 1px solid var(--sm-sep);
  box-sizing:border-box;
}
.sm-mmf-rateswrap{
  margin-top: 14px;
  border: 1px solid var(--sm-sep);
  border-radius: 12px;
  padding: 12px;
  background:#fff;
}
.sm-mmf-loading, .sm-mmf-error{
  padding: 10px;
  border: 1px solid var(--sm-sep);
  border-radius: 10px;
  background:#fff;
  color: var(--sm-font);
}
.sm-mmf-status{
  margin-top: 10px;
  padding: 10px;
  border-radius: 10px;
  border: 1px solid var(--sm-sep);
  background:#fff;
  color: var(--sm-font);
}
.sm-mmf-status.ok{ border-color: #9bb08a; }
.sm-mmf-status.bad{ border-color: #c28a8a; }

@media (max-width: 980px){
  .sm-mmf-dialog{ width: min(92vw, 1040px); }
}
@media (max-width: 820px){
  .sm-mmf-grid{ flex-direction: column; }
  .sm-mmf-right{ flex: 1 1 auto; }
  .sm-mmf-btngrid{ grid-template-columns: 1fr; }
}


.sm-mmf-trigger-row{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }


/* Start screen (when using [mortgage_finder] without start=) */
.sm-mmf-startbox{ width:100%; }
.sm-mmf-starttitle{ margin:0 0 10px; color: var(--sm-font); font-weight: 900; }
.sm-mmf-trigger-row{ display:flex; gap:10px; flex-wrap:wrap; align-items:stretch; }
.sm-mmf-trigger-row .sm-mmf-root{ flex:1 1 240px; }
.sm-mmf-trigger-row .sm-mmf-trigger{ width:100% !important; text-align:center !important; }

/* Keep modal a constant size (no growing/shrinking per step) */
.sm-mmf-dialog{
  height: calc(100vh - var(--sm-mmf-top, 0px) - 40px);
  max-height: calc(100vh - var(--sm-mmf-top, 0px) - 40px);
}
.sm-mmf-body{ height: 100%; overflow:auto; }

/* Hide CF7 textarea (brief description) but keep it in DOM for submission */
.sm-mmf-step[data-step="lead"] textarea{ display:none !important; }


/* ===== Responsive modal sizing (industry standard) ===== */
.sm-mmf-modal{ position:fixed; inset:0; z-index:999999; }
.sm-mmf-overlay{ position:fixed; inset:0; }

/* Desktop default */
.sm-mmf-dialog{
  width: min(60vw, 980px);
  margin: 0 auto;
  position: relative;
}

/* Tablet */
@media (max-width: 1024px){
  .sm-mmf-dialog{ width: min(86vw, 980px); }
}

/* Mobile full screen + summary drawer */
@media (max-width: 768px){
  .sm-mmf-dialog{
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    max-height: 100vh !important;
    border-radius: 0 !important;
    margin: 0 !important;
  }
  .sm-mmf-grid{ display:block !important; }
  .sm-mmf-right{
    position: fixed;
    left: 0; right: 0; bottom: 0;
    height: 55vh;
    transform: translateY(100%);
    transition: transform .25s ease;
    z-index: 1000001;
    border-top-left-radius: 18px;
    border-top-right-radius: 18px;
    box-shadow: 0 -10px 30px rgba(0,0,0,.18);
  }
  .sm-mmf-modal.sm-mmf-summary-open .sm-mmf-right{ transform: translateY(0); }
  .sm-mmf-summarybtn{ display:inline-flex !important; }
  .sm-mmf-sumoverlay{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.35);
    z-index: 1000000;
  }
}

/* Summary button (hidden on desktop) */
.sm-mmf-summarybtn{
  display:none;
  border:0;
  background: transparent;
  color: #692022;
  font-weight: 700;
  font-size: 13px;
  padding: 6px 10px;
  cursor: pointer;
}

/* ===== Mobile cards for rates table inside modal ===== */
@media (max-width: 768px){
  .sm-mmf-modal .square-mortgage-ltv-rates table,
  .sm-mmf-modal .mortgage-rates table{
    width:100% !important;
    border-collapse: separate !important;
    border-spacing: 0 10px !important;
  }
  .sm-mmf-modal .square-mortgage-ltv-rates thead,
  .sm-mmf-modal .mortgage-rates thead{ display:none !important; }
  .sm-mmf-modal .square-mortgage-ltv-rates tr,
  .sm-mmf-modal .mortgage-rates tr{
    display:block !important;
    background:#fff !important;
    border-radius: 12px !important;
    padding: 10px 12px !important;
    box-shadow: 0 6px 16px rgba(0,0,0,.08) !important;
  }
  .sm-mmf-modal .square-mortgage-ltv-rates td,
  .sm-mmf-modal .mortgage-rates td{
    display:flex !important;
    justify-content: space-between !important;
    gap: 12px !important;
    padding: 6px 0 !important;
    border: 0 !important;
  }
}


/* Mobile usability: keep modal within 80vh and keep action buttons clickable */
@media (max-width: 767px){
  .sm-mmf-modal .sm-mmf-dialog{
    max-height: 80vh !important;
    height: 80vh !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .sm-mmf-modal .sm-mmf-content,
  .sm-mmf-modal .sm-mmf-body{
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  .sm-mmf-modal .sm-mmf-footer,
  .sm-mmf-modal .sm-mmf-actions{
    flex: 0 0 auto !important;
    position: sticky !important;
    bottom: 0 !important;
    background: #fff !important;
    z-index: 5;
    padding-bottom: env(safe-area-inset-bottom);
  }
}