/* MyPatientLeads — Shared Styles */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#F5F4F0;
  --navy:#1B3A6B;
  --blue:#2563EB;
  --ink:#111827;
  --muted:#6B7280;
  --light:#9CA3AF;
  --border:#EEECEA;
  --white:#FFFFFF;
  --green:#10B981;
  --red:#EF4444;
  --amber:#F59E0B;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --radius:12px;
  --shadow:0 4px 24px rgba(0,0,0,0.08);
}

html{scroll-behavior:smooth}
body{
  background:var(--bg);font-family:var(--sans);color:var(--ink);
  -webkit-font-smoothing:antialiased;min-height:100vh;
}

body::before{
  content:'';position:fixed;inset:0;
  background-image:radial-gradient(circle,rgba(27,58,107,0.05) 1px,transparent 1px);
  background-size:28px 28px;pointer-events:none;z-index:0;
}

/* ── Nav ── */
.nav{
  position:sticky;top:0;z-index:100;
  height:64px;display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;background:rgba(245,244,240,0.9);
  backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,0.06);
}
.logo{display:flex;align-items:center;gap:0;text-decoration:none}
.logo-img{height:52px;width:auto;display:block;margin-right:-10px}
.logo-card-img{height:80px;width:auto;display:block;margin:0 auto 20px}
.logo-text{font-weight:700;font-size:20px;color:var(--ink);letter-spacing:-.02em}
.logo-max{color:var(--blue)}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-badge{
  font-size:11px;font-weight:600;color:var(--navy);
  background:rgba(27,58,107,0.08);padding:5px 14px;
  border-radius:100px;letter-spacing:.02em;
}

/* ── Container ── */
.container{
  position:relative;z-index:1;
  max-width:680px;margin:0 auto;padding:40px 24px 80px;
}
.container-wide{max-width:560px;margin:0 auto;padding:40px 24px 80px;position:relative;z-index:1}

/* ── Page Header ── */
.page-header{margin-bottom:36px;text-align:center}
.page-header h1{
  font-family:var(--serif);font-size:clamp(26px,5vw,38px);
  font-weight:900;line-height:1.1;letter-spacing:-.02em;
  margin-bottom:8px;
}
.page-header p{font-size:15px;color:var(--muted);line-height:1.6}
.page-header .practice-name{
  font-family:var(--serif);font-size:clamp(22px,4vw,30px);
  font-weight:900;color:var(--navy);
}

/* ── Cards ── */
.card{
  background:var(--white);border:1px solid var(--border);
  border-radius:16px;padding:28px;margin-bottom:20px;
  box-shadow:0 2px 12px rgba(0,0,0,0.04);
}
.card-title{
  font-family:var(--serif);font-size:18px;font-weight:700;
  margin-bottom:4px;line-height:1.3;
}
.card-desc{font-size:13px;color:var(--muted);margin-bottom:20px}

/* ── Form Elements ── */
.form-group{margin-bottom:16px}
.form-group:last-child{margin-bottom:0}
.form-group label{
  display:block;font-size:13px;font-weight:600;
  color:var(--ink);margin-bottom:6px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="time"],
input[type="date"],
input[type="number"],
select,
textarea{
  width:100%;padding:11px 14px;font-size:14px;font-family:var(--sans);
  color:var(--ink);background:var(--bg);
  border:1.5px solid var(--border);border-radius:10px;
  outline:none;transition:border-color .2s,box-shadow .2s;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(27,58,107,0.08);
}
textarea{resize:vertical;min-height:80px}
.phone-input-wrap{display:flex;gap:8px}
.phone-input-wrap>select{width:auto;min-width:92px;flex-shrink:0;padding-right:28px;background-position:right 8px center}
.phone-input-wrap>input[type="tel"]{width:auto;flex:1}
select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
  padding-right:36px;
}

/* ── Toggle Switch ── */
.toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{
  position:absolute;cursor:pointer;inset:0;
  background:#D1D5DB;border-radius:24px;transition:.25s;
}
.toggle-slider::before{
  content:'';position:absolute;height:18px;width:18px;
  left:3px;bottom:3px;background:white;border-radius:50%;
  transition:.25s;box-shadow:0 1px 3px rgba(0,0,0,0.15);
}
.toggle input:checked+.toggle-slider{background:var(--navy)}
.toggle input:checked+.toggle-slider::before{transform:translateX(20px)}
.toggle.toggle-disabled{opacity:0.38;pointer-events:none}

/* ── Service Row (Admin) ── */
.service-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.service-row:last-child{border-bottom:none}
.service-row .service-input{flex:1}
.service-input-wrap{flex:1;min-width:0}
.service-input-wrap .service-input{width:100%}
.service-row-other .service-input{background:var(--bg-alt,#f5f6f8);color:var(--muted);cursor:default;border-style:dashed}
.service-other-desc{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.5}
.btn-icon-sm-placeholder{width:32px;height:32px;flex-shrink:0;visibility:hidden}

/* ── Buttons ── */
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-size:15px;font-weight:600;color:white;font-family:var(--sans);
  background:linear-gradient(135deg,var(--navy),var(--blue));
  padding:14px 28px;border-radius:var(--radius);border:none;cursor:pointer;
  transition:all .25s;box-shadow:0 4px 20px rgba(27,58,107,0.25);
  text-decoration:none;
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 28px rgba(27,58,107,0.35)}
.btn-primary:active{transform:translateY(0)}
.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn-full{width:100%;margin-bottom:20px}

.btn-secondary{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-size:14px;font-weight:600;color:var(--navy);font-family:var(--sans);
  background:white;padding:12px 24px;border-radius:var(--radius);
  border:1.5px solid rgba(27,58,107,0.2);cursor:pointer;
  transition:all .2s;text-decoration:none;
}
.btn-secondary:hover{background:rgba(27,58,107,0.04);border-color:var(--navy)}
.leads-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.leads-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.leads-status-tabs{
  display:flex;align-items:center;gap:4px;
  background:white;border:1.5px solid var(--border);
  border-radius:10px;padding:3px;
}
.leads-tab{
  font-family:var(--sans);font-size:12px;font-weight:600;
  color:var(--muted);background:transparent;border:none;
  padding:5px 12px;border-radius:7px;cursor:pointer;
  transition:all .15s;white-space:nowrap;
}
.leads-tab:hover{color:var(--ink);background:rgba(27,58,107,0.05)}
.leads-tab.active{background:var(--navy);color:white}
.leads-sort-btn{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--sans);font-size:11px;font-weight:700;
  color:var(--muted);background:white;
  border:1.5px solid var(--border);border-radius:8px;
  padding:5px 10px;cursor:pointer;transition:all .15s;
  letter-spacing:.02em;
}
.leads-sort-btn:hover{color:var(--navy);border-color:var(--navy)}
.leads-sort-btn.active{background:var(--navy);color:white;border-color:var(--navy)}

.btn-outline{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-size:13px;font-weight:600;color:var(--muted);font-family:var(--sans);
  background:transparent;padding:10px 18px;border-radius:10px;
  border:1.5px solid var(--border);cursor:pointer;transition:all .2s;
  text-decoration:none;
}
.btn-outline:hover{border-color:var(--muted);color:var(--ink)}

.btn-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:10px;border:1.5px solid var(--border);
  background:white;cursor:pointer;transition:all .2s;flex-shrink:0;
}
.btn-icon:hover{border-color:var(--navy);background:rgba(27,58,107,0.04)}
.btn-icon svg{width:18px;height:18px;color:var(--muted)}
.btn-icon:hover svg{color:var(--navy)}

.btn-icon-sm{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:8px;border:1.5px solid var(--border);
  background:white;cursor:pointer;transition:all .2s;flex-shrink:0;
}
.btn-icon-sm:hover{border-color:var(--muted)}
.btn-icon-sm svg{width:14px;height:14px;color:var(--muted)}
.btn-icon-sm.btn-danger svg{color:white;fill:white}
.btn-icon-sm.btn-danger:hover svg{color:white;fill:white}

.btn-danger{border-color:rgba(239,68,68,0.2)}
.btn-danger:hover{border-color:var(--red);background:rgba(239,68,68,0.04)}
.btn-danger:hover svg{color:var(--red)}

.btn-impersonate{display:inline-flex;align-items:center;gap:5px;font-family:var(--sans);font-size:12px;font-weight:600;padding:6px 13px;border-radius:8px;border:1.5px solid rgba(109,40,217,0.25);background:rgba(109,40,217,0.06);color:#6D28D9;cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-impersonate:hover{background:rgba(109,40,217,0.12);border-color:rgba(109,40,217,0.45)}
.btn-impersonate:disabled{opacity:.5;cursor:not-allowed}
.btn-impersonate svg{flex-shrink:0;stroke:#6D28D9}
.btn-disable{display:inline-flex;align-items:center;font-family:var(--sans);font-size:12px;font-weight:600;padding:6px 13px;border-radius:8px;border:1.5px solid rgba(245,158,11,0.3);background:rgba(245,158,11,0.07);color:#B45309;cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-disable:hover{background:rgba(245,158,11,0.14);border-color:rgba(245,158,11,0.5)}
.btn-disable:disabled{opacity:.5;cursor:not-allowed}

/* ── Link Card ── */
.link-card{background:rgba(27,58,107,0.04);border-color:rgba(27,58,107,0.15)}
.link-row{display:flex;gap:10px}
.link-row input{flex:1;background:white;font-size:12px;font-family:monospace}
.btn-copy{
  padding:11px 20px;font-size:13px;font-weight:700;font-family:var(--sans);
  color:white;background:var(--navy);border:none;border-radius:10px;
  cursor:pointer;transition:background .2s;white-space:nowrap;
}
.btn-copy:hover{background:#0F2548}

/* ── Period Toggle ── */
.period-toggle{display:flex;background:var(--border);border-radius:10px;padding:3px;gap:2px}
.period-btn{
  padding:6px 16px;font-size:13px;font-weight:600;font-family:var(--sans);
  border:none;border-radius:8px;cursor:pointer;background:transparent;
  color:var(--muted);transition:background .15s,color .15s;
}
.period-btn.active{background:white;color:var(--navy);box-shadow:0 1px 3px rgba(0,0,0,.1)}
.period-btn:hover:not(.active){color:var(--ink)}

/* ── Admin Sidebar Layout ── */
.admin-layout{
  position:relative;z-index:1;
  display:flex;min-height:calc(100vh - 64px - 60px);
  max-width:1200px;margin:0 auto;
}
.sidebar{
  width:220px;flex-shrink:0;padding:24px 16px;
  border-right:1px solid var(--border);
  background:rgba(255,255,255,0.5);
  display:flex;flex-direction:column;
  position:sticky;top:64px;height:calc(100vh - 64px);
}
.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:4px;overflow-y:auto}
.sidebar-item{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-radius:10px;
  font-size:14px;font-weight:500;color:var(--ink);
  cursor:pointer;transition:all .2s;border:none;
  background:transparent;font-family:var(--sans);
  text-align:left;width:100%;
}
.sidebar-item:hover{background:rgba(27,58,107,0.06);color:var(--navy)}
.sidebar-item.active{background:rgba(27,58,107,0.08);color:var(--navy);font-weight:600}
.sidebar-item svg{width:18px;height:18px;flex-shrink:0}
.sidebar-divider{height:1px;background:var(--border);margin:12px 0}
.sidebar-bottom{display:flex;flex-direction:column;gap:4px;margin-top:auto}

.admin-content{flex:1;padding:32px;min-width:0}

/* ── Section Header ── */
.section-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;gap:16px;flex-wrap:wrap;
}
.section-header h2{font-family:var(--serif);font-size:22px;font-weight:800}
.section-header p{font-size:13px;color:var(--muted);margin-top:2px}

/* ── Stats Cards ── */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.stat-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:16px;padding:24px;
  box-shadow:0 2px 12px rgba(0,0,0,0.04);
}
.stat-label{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.stat-value{font-family:var(--serif);font-size:36px;font-weight:900;color:var(--navy);line-height:1}
.stat-sub{font-size:12px;color:var(--muted);margin-top:6px}
.stat-green .stat-value{color:var(--green)}
.stat-clickable{cursor:pointer;transition:box-shadow .15s,transform .15s}
.stat-clickable:hover{box-shadow:0 6px 24px rgba(27,58,107,0.13);transform:translateY(-1px)}
.stat-card-hint{font-size:11px;color:var(--blue);margin-top:8px;font-weight:600;min-height:16px}
.stat-card-compact{padding:14px 20px}
.form-perf-row{cursor:pointer;transition:background .12s}
.form-perf-row:hover td{background:rgba(27,58,107,0.04)}

/* ── Leads Table ── */
.table-wrap{
  border:1px solid var(--border);border-radius:16px;
  background:var(--white);overflow:hidden;
}
@media(max-width:768px){.table-wrap{overflow-x:auto}}
.leads-table{width:100%;border-collapse:collapse;font-size:14px}
.leads-table th{
  text-align:left;padding:14px 20px;font-weight:600;
  color:var(--muted);font-size:11px;text-transform:uppercase;
  letter-spacing:.05em;border-bottom:1px solid var(--border);
  background:rgba(245,244,240,0.6);white-space:nowrap;
}
.leads-table td{
  padding:16px 20px;border-bottom:1px solid var(--border);
  color:var(--ink);vertical-align:middle;
}
.leads-table tr:last-child td{border-bottom:none}
.leads-table tr:hover td{background:rgba(27,58,107,0.02)}
.lead-row-clickable{cursor:pointer}
.lead-row-clickable:hover td{background:rgba(27,58,107,0.05)!important}
.lead-row-clickable:active td{background:rgba(27,58,107,0.08)!important}
.lead-urgent td{background:rgba(239,68,68,0.05)!important}
.lead-urgent td:first-child{border-left:3px solid var(--red)}
.lead-urgent.lead-row-clickable:hover td{background:rgba(239,68,68,0.09)!important}
.lead-card.lead-urgent{border-left:4px solid var(--red);background:rgba(239,68,68,0.04)}
.urgent-badge{
  display:inline-flex;align-items:center;gap:3px;
  font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  background:var(--red);color:white;
  padding:2px 7px;border-radius:100px;
  vertical-align:middle;margin-left:4px;
}

.cell-primary{font-weight:600;color:var(--ink);line-height:1.3}
.cell-secondary{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.3}
.cell-pref{font-size:13px;line-height:1.6}
.cell-pref span{font-size:11px;font-weight:700;color:var(--navy);margin-right:3px}

/* ── Lead Cards (mobile) ── */
.lead-cards{display:none;flex-direction:column;gap:12px}
.lead-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:16px;padding:18px 20px;
  box-shadow:0 2px 12px rgba(0,0,0,0.04);
}
.lead-card-head{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;margin-bottom:14px;
}
.lead-card-body{display:flex;flex-direction:column;gap:10px}
.lead-card-row{display:flex;align-items:flex-start;gap:8px;font-size:14px}
.lead-card-label{
  font-size:12px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.04em;
  min-width:70px;flex-shrink:0;padding-top:1px;
}
.lead-card-footer{
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}

@media(max-width:640px){
  .table-wrap{display:none}
  .lead-cards{display:flex}
}

.empty-state{text-align:center;padding:48px 24px;color:var(--muted);font-size:14px}

/* ── Status Badges ── */
.status-badge{
  display:inline-block;padding:4px 10px;border-radius:100px;
  font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
}
/* ── Settings labels ── */
.settings-group-label{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}

/* ── Settings divider ── */
.settings-divider{border:none;border-top:1.5px solid var(--border);margin:28px 0}

/* ── Location inline cards ── */
.location-card-full{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:12px}
.loc-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px}
.loc-card-title{font-family:var(--serif);font-size:17px;font-weight:800;color:var(--ink)}
.loc-field-label{font-size:12px;font-weight:600;color:var(--muted);display:block;margin-bottom:5px}
.loc-hours-section{margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}
.loc-hours-title{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:4px}

/* ── Form location badge ── */
.form-loc-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:100px;font-size:11px;font-weight:600;background:rgba(27,58,107,0.08);color:var(--navy)}
.form-loc-missing{background:rgba(234,179,8,0.12);color:#92400E}

/* ── No-location warning banner ── */
.loc-missing-banner{background:rgba(234,179,8,0.1);border:1.5px solid rgba(234,179,8,0.4);border-radius:10px;padding:12px 16px;font-size:13px;color:#78350F}

/* ── Location modal delete btn ── */
.btn-danger{padding:9px 18px;font-size:13px;font-weight:700;font-family:var(--sans);color:white;background:#DC2626;border:none;border-radius:10px;cursor:pointer;transition:background .15s}
.btn-danger:hover{background:#B91C1C}

/* ── Office Hours Grid ── */
.hours-grid{display:flex;flex-direction:column;gap:0}
.hours-row{
  display:flex;align-items:center;gap:16px;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.hours-row:last-child{border-bottom:none}
.hours-day{font-size:14px;font-weight:600;width:100px;flex-shrink:0}
.hours-inputs{display:flex;align-items:center;gap:10px;flex:1}
.hours-inputs input[type="time"]{width:130px;flex-shrink:0}
.hours-sep{font-size:13px;color:var(--muted);flex-shrink:0}
.hours-closed{font-size:13px;color:var(--light);font-style:italic}
.hours-open-label{font-size:13px;color:var(--green);font-weight:600}

/* ── Office Hours — Schedule Grid ── */
/* ── Time Window Editors ── */
.slot-defs-title{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:4px}
.slot-def-row{
  display:flex;align-items:center;gap:14px;
  padding:10px 0;border-bottom:1px solid var(--border);
}
.slot-def-row:last-child{border-bottom:none}
.slot-def-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0;color:var(--navy)}
.slot-def-name{font-size:14px;font-weight:600;width:90px;flex-shrink:0;color:var(--ink)}
.sch-slot-times{display:flex;align-items:center;gap:8px}
.sch-slot-times input[type="time"]{
  font-size:13px;padding:7px 10px;border:1.5px solid var(--border);
  border-radius:8px;background:white;outline:none;width:120px;
  font-family:var(--sans);color:var(--ink);
}
.sch-slot-times input[type="time"]:focus{border-color:var(--navy)}
.sch-slot-times span{font-size:13px;color:var(--muted);font-weight:600}

/* ── Per-day office hours rows ── */
.day-hours-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 0;border-bottom:1px solid var(--border);gap:12px;
}
.day-hours-row:last-child{border-bottom:none}
.day-hours-label{display:flex;align-items:center;gap:10px;min-width:140px;flex-shrink:0}
.day-hours-name{font-size:14px;font-weight:600;color:var(--ink)}
.day-hours-name.muted{color:var(--light);font-weight:500}
.day-hours-closed{font-size:13px;color:var(--light);font-style:italic}
@media(max-width:520px){
  .day-hours-row{flex-wrap:wrap;gap:6px}
  .day-hours-label{min-width:0;flex:1}
  .day-hours-row .sch-slot-times{width:100%;padding-left:46px}
}

/* ── Schedule Grid (legacy, kept for reference) ── */
.card-flush{padding:0;overflow:hidden}

/* ── Slot disabled state ── */
.slot-def-row.slot-disabled{opacity:.4}

/* ── Days grid ── */
.days-grid{
  display:flex;gap:10px;flex-wrap:wrap;
}
.day-card{
  flex:1 1 calc(14.28% - 10px);min-width:72px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  border:1.5px solid var(--border);border-radius:12px;
  padding:14px 8px;transition:border-color .15s,background .15s;
}
.day-card.day-open{border-color:var(--navy);background:#f0f4ff}
.day-card.day-closed{background:#fafafa}
.day-card-label{font-size:13px;font-weight:700;color:var(--ink)}
.day-card-status{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.day-card.day-open .day-card-status{color:var(--green)}
.day-card.day-closed .day-card-status{color:var(--light)}
@media(max-width:520px){
  .day-card{flex:1 1 calc(33% - 10px)}
}

/* ── Modal ── */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,0.35);
  z-index:500;display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;transition:opacity .2s;pointer-events:none;
}
.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal-box{
  background:var(--white);border-radius:16px;padding:28px;width:100%;
  max-width:480px;box-shadow:0 16px 48px rgba(0,0,0,0.18);
  transform:translateY(12px);transition:transform .25s cubic-bezier(.32,.72,0,1);
}
.modal-backdrop.open .modal-box{transform:translateY(0)}
.modal-handle{display:none}
.modal-title{font-family:var(--serif);font-size:18px;font-weight:700;margin-bottom:4px}
.modal-desc{font-size:13px;color:var(--muted);margin-bottom:18px}
.modal-actions{display:flex;gap:10px;margin-top:20px;justify-content:flex-end}

@media(max-width:640px){
  .modal-backdrop{
    align-items:flex-end;
    padding:0;
  }
  .modal-box{
    max-width:100%;
    border-radius:20px 20px 0 0;
    padding:12px 20px 36px;
    max-height:88vh;
    overflow-y:auto;
    transform:translateY(100%);
    box-shadow:0 -8px 40px rgba(0,0,0,0.15);
  }
  .modal-backdrop.open .modal-box{transform:translateY(0)}
  .modal-handle{
    display:block;width:36px;height:4px;border-radius:2px;
    background:var(--border);margin:0 auto 16px;
  }
  .modal-title{font-size:17px}
  .modal-actions{margin-top:16px}
}

/* ── Stepper ── */
.stepper{
  display:flex;align-items:center;justify-content:center;
  margin-bottom:36px;
}
.step-item{display:flex;align-items:center}
.step-dot{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;
  background:var(--border);color:var(--light);
  transition:all .3s;flex-shrink:0;
}
.step-label{
  font-size:11px;font-weight:600;color:var(--light);
  margin-left:8px;transition:color .3s;display:none;
}
.step-line{width:32px;height:2px;background:var(--border);margin:0 6px;transition:background .3s;flex-shrink:0}
.step-item.active .step-dot{background:var(--navy);color:white}
.step-item.active .step-label{color:var(--ink);display:block}
.step-item.done .step-dot{background:var(--green);color:white}
.step-item.done+.step-line,.step-line.done{background:var(--green)}

/* ── Step Content ── */
.step-content{display:none}
.step-content.active{display:block}

/* ── Step Card: title/desc ── */
.step-heading{font-family:var(--serif);font-size:22px;font-weight:800;margin-bottom:6px;line-height:1.2}
.step-sub{font-size:14px;color:var(--muted);margin-bottom:24px;line-height:1.5}

/* ── Service Cards (lead form step 1) ── */
.service-grid{display:grid;grid-template-columns:1fr;gap:10px}
.service-card{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;background:white;border:2px solid var(--border);
  border-radius:var(--radius);cursor:pointer;transition:all .2s;
  text-align:left;font-family:var(--sans);width:100%;
}
.service-card:hover{border-color:rgba(27,58,107,0.3);background:#FAFAF9}
.service-card.selected{border-color:var(--navy);background:rgba(27,58,107,0.04)}
.service-card .svc-icon{
  width:40px;height:40px;border-radius:10px;
  background:rgba(27,58,107,0.08);display:flex;
  align-items:center;justify-content:center;flex-shrink:0;
  color:var(--navy);transition:color .2s;
}
.service-card.selected .svc-icon{background:var(--navy);color:white}
.service-card .svc-name{font-size:15px;font-weight:600;color:var(--ink)}
.other-explain{
  margin-top:14px;
  animation:fadeIn .2s ease;
}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* ── Patient Type Cards ── */
.patient-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:4px}
.patient-type-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  padding:24px 16px;background:white;border:2px solid var(--border);border-radius:14px;
  cursor:pointer;font-family:var(--sans);width:100%;text-align:center;position:relative;
  transition:border-color .15s,background .15s;
}
.patient-type-card:hover{border-color:rgba(27,58,107,0.3);background:#FAFAF9}
.patient-type-card.selected{border-color:var(--navy);background:rgba(27,58,107,0.04)}
.patient-type-icon{width:52px;height:52px;border-radius:14px;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--navy);transition:background .15s,color .15s}
.patient-type-card.selected .patient-type-icon{background:var(--navy);color:white}
.patient-type-label{font-size:15px;font-weight:700;color:var(--ink)}
.patient-type-hint{font-size:12px;color:var(--muted)}
.patient-type-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);transition:border-color .15s,background .15s;margin-top:4px}
.patient-type-card.selected .patient-type-radio{border-color:var(--navy);background:var(--navy)}
.patient-type-card.selected .patient-type-radio::after{content:'';display:block;width:8px;height:8px;border-radius:50%;background:white;margin:3px auto}

/* Single-view patient type option */
.sv-patient-opt{display:flex;align-items:stretch;cursor:pointer}
.sv-patient-opt input[type="radio"]{display:none}
.sv-patient-opt-inner{
  display:flex;flex-direction:column;gap:2px;padding:12px 14px;width:100%;
  border:2px solid var(--border);border-radius:10px;transition:border-color .15s,background .15s;
}
.sv-patient-opt input:checked ~ .sv-patient-opt-inner{border-color:var(--navy);background:rgba(27,58,107,0.04)}
.sv-patient-opt-inner strong{font-size:13px;font-weight:700;color:var(--ink)}
.sv-patient-opt-inner span{font-size:11px;color:var(--muted)}

/* ── Urgency Cards (step 3) ── */
.urgency-grid{display:grid;grid-template-columns:1fr;gap:10px}
.urgency-card{
  display:flex;align-items:center;gap:16px;
  padding:18px 20px;background:white;border:2px solid var(--border);
  border-radius:var(--radius);cursor:pointer;transition:all .2s;
  font-family:var(--sans);width:100%;text-align:left;
}
.urgency-card:hover{border-color:rgba(27,58,107,0.3);background:#FAFAF9}
.urgency-card.selected{border-color:var(--navy);background:rgba(27,58,107,0.04)}
.urgency-icon{
  width:44px;height:44px;border-radius:12px;
  background:rgba(27,58,107,0.08);display:flex;
  align-items:center;justify-content:center;
  flex-shrink:0;transition:background .2s,color .2s;
  color:var(--navy);
}
.urgency-card.selected .urgency-icon{background:var(--navy);color:white}
.urgency-info{flex:1}
.urgency-label{font-size:15px;font-weight:600;color:var(--ink)}
.urgency-hint{font-size:12px;color:var(--muted);margin-top:2px}
.urgency-radio{
  width:20px;height:20px;border-radius:50%;
  border:2px solid var(--border);display:flex;
  align-items:center;justify-content:center;flex-shrink:0;
  transition:all .2s;
}
.urgency-card.selected .urgency-radio{
  border-color:var(--navy);background:var(--navy);
}
.urgency-card.selected .urgency-radio::after{
  content:'';width:8px;height:8px;border-radius:50%;background:white;
}

/* ── Preference Cards — ranked days/times (steps 4 & 5) ── */
.pref-hint{
  font-size:13px;color:var(--muted);margin-bottom:20px;
  background:rgba(27,58,107,0.04);padding:10px 14px;border-radius:10px;
}
.pref-hint b{color:var(--navy)}
.pref-grid-days{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
.pref-grid-times{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pref-card{
  position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;padding:16px 12px;background:white;
  border:2px solid var(--border);border-radius:var(--radius);
  cursor:pointer;transition:all .2s;font-family:var(--sans);
  text-align:center;min-height:60px;
}
.pref-card:hover{border-color:rgba(27,58,107,0.3);background:#FAFAF9}
.pref-card.ranked{border-color:var(--navy);background:rgba(27,58,107,0.04)}
.pref-card.full{opacity:.5;cursor:not-allowed}
.pref-card.full:hover{border-color:var(--border);background:white}
.pref-card-disabled{opacity:.35;cursor:not-allowed;pointer-events:none}
.pref-card-disabled:hover{border-color:var(--border);background:white}
.pref-icon{font-size:24px;color:var(--navy)}
.pref-label{font-size:14px;font-weight:600;color:var(--ink)}
.pref-badge{
  position:absolute;top:-10px;right:-10px;
  width:26px;height:26px;border-radius:50%;
  background:var(--navy);color:white;
  font-size:13px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(27,58,107,0.4);
  animation:popIn .15s ease;
}
@keyframes popIn{from{transform:scale(0.6)}to{transform:scale(1)}}
.pref-badge-2{background:var(--blue)}

/* ── Step Actions ── */
.step-actions{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:28px;gap:12px;
}
.step-actions .btn-primary{flex:1;max-width:220px}

/* ── Lead Confirmation (step 6) ── */
.lead-confirm{text-align:center;padding:10px 0}
.confirm-check{
  width:72px;height:72px;border-radius:50%;
  background:rgba(16,185,129,0.1);margin:0 auto 24px;
  display:flex;align-items:center;justify-content:center;
}
.confirm-title{font-family:var(--serif);font-size:28px;font-weight:900;margin-bottom:8px;line-height:1.2}
.confirm-sub{font-size:15px;color:var(--muted);margin-bottom:28px;line-height:1.6}

.what-next-card{
  background:white;border:1px solid var(--border);border-radius:16px;
  padding:24px;margin-bottom:20px;text-align:left;
}
.what-next-title{
  font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);margin-bottom:16px;
}
.what-next-step{
  display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;
}
.what-next-step:last-child{margin-bottom:0}
.what-next-num{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:white;font-size:13px;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.what-next-text{font-size:14px;color:var(--ink);line-height:1.5;padding-top:4px}

.hours-summary{margin-top:4px}
.hours-summary-row{
  display:flex;flex-direction:column;gap:3px;
  padding:10px 0;border-bottom:1px solid var(--border);
  font-size:14px;
}
.hours-summary-row:last-child{border-bottom:none}
.hours-summary-day{font-weight:700;color:var(--ink)}
.hours-summary-time{color:var(--muted);font-size:13px;line-height:1.6}
.hours-summary-closed{color:var(--light);font-style:italic;font-size:13px}

/* ── Error State ── */
.error-state{text-align:center;padding:80px 24px}
.error-state h2{font-family:var(--serif);font-size:24px;margin-bottom:8px}
.error-state p{color:var(--muted);font-size:15px}

/* ── Footer ── */
.footer{
  position:relative;z-index:1;text-align:center;
  padding:24px;font-size:12px;color:var(--light);
}

/* ── Unsaved Modal ── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.45);
  display:flex;align-items:center;justify-content:center;
  z-index:2000;padding:20px;backdrop-filter:blur(2px);
}
.modal-dialog{
  background:white;border-radius:20px;padding:36px 32px 28px;
  max-width:420px;width:100%;box-shadow:0 24px 64px rgba(0,0,0,0.18);
  text-align:center;
}
.modal-icon{
  width:56px;height:56px;border-radius:16px;
  background:rgba(239,68,68,0.1);display:flex;
  align-items:center;justify-content:center;
  margin:0 auto 20px;color:var(--red);
}
.modal-title{font-family:var(--serif);font-size:22px;font-weight:800;color:var(--ink);margin-bottom:10px}
.modal-body{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:28px}
.modal-actions{display:flex;flex-direction:column;gap:10px}
.btn-modal-leave{
  padding:13px 20px;border-radius:var(--radius);border:none;cursor:pointer;
  background:var(--red);color:white;font-family:var(--sans);
  font-size:14px;font-weight:700;transition:opacity .15s;
}
.btn-modal-leave:hover{opacity:.88}

/* ── Toast ── */
.toast{
  position:fixed;top:24px;right:24px;
  color:white;padding:16px 22px;border-radius:12px;
  font-size:15px;font-weight:700;line-height:1.4;
  max-width:320px;
  transform:translateY(-120%);opacity:0;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
  z-index:1000;pointer-events:none;
}
.toast.error{background:var(--red);box-shadow:0 8px 32px rgba(239,68,68,0.35)}
.toast.success{background:var(--blue);box-shadow:0 8px 32px rgba(37,99,235,0.3)}
.toast.show{transform:translateY(0);opacity:1}

/* ── Logout Button ── */
.btn-logout{
  font-size:12px;font-weight:600;color:var(--muted);font-family:var(--sans);
  background:transparent;padding:6px 14px;border-radius:8px;
  border:1.5px solid var(--border);cursor:pointer;transition:all .2s;
}
.btn-logout:hover{border-color:var(--red);color:var(--red)}

/* ── Login Page ── */
.login-container{
  position:relative;z-index:1;
  max-width:420px;margin:0 auto;padding:60px 24px 80px;
  display:flex;align-items:center;justify-content:center;
  min-height:calc(100vh - 64px - 60px);
}
.login-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:16px;padding:36px;width:100%;
  box-shadow:0 2px 12px rgba(0,0,0,0.04);
}
.login-header{text-align:center;margin-bottom:28px}
.login-header h1{
  font-family:var(--serif);font-size:28px;font-weight:900;
  line-height:1.2;margin-bottom:6px;
}
.login-header p{font-size:14px;color:var(--muted)}

.auth-error{
  background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.2);
  color:var(--red);font-size:13px;font-weight:500;
  padding:10px 14px;border-radius:10px;margin-bottom:20px;
  text-align:center;
}
.auth-toggle{text-align:center;margin-top:20px;font-size:13px;color:var(--muted)}
.auth-toggle-btn{
  background:none;border:none;color:var(--navy);font-weight:700;
  font-size:13px;font-family:var(--sans);cursor:pointer;
  margin-left:4px;text-decoration:underline;
}
.auth-toggle-btn:hover{color:var(--blue)}

input[type="password"]{
  width:100%;padding:11px 44px 11px 14px;font-size:14px;font-family:var(--sans);
  color:var(--ink);background:var(--bg);
  border:1.5px solid var(--border);border-radius:10px;
  outline:none;transition:border-color .2s,box-shadow .2s;
}
input[type="password"]:focus{
  border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(27,58,107,0.08);
}
.pw-wrap{position:relative}
.pw-wrap input[type="text"]{padding-right:44px}
.pw-eye{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;padding:4px;
  color:var(--muted);display:flex;align-items:center;transition:color .2s;
}
.pw-eye:hover{color:var(--navy)}
.pw-eye svg{width:18px;height:18px;display:block}

/* ── Hamburger ── */
.nav-left{display:flex;align-items:center;gap:10px}
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;background:none;border:none;cursor:pointer;
  padding:6px;border-radius:8px;transition:background .2s;flex-shrink:0;
}
.hamburger:hover{background:rgba(27,58,107,0.06)}
.hamburger span{
  display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;
  transition:all .3s ease;transform-origin:center;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Responsive ── */
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-badge{display:none}
  .admin-layout{display:block !important}
  .stats-row{grid-template-columns:1fr 1fr}

  .sidebar{
    position:fixed;top:64px;left:-220px;width:200px;height:calc(100vh - 64px);
    display:flex !important;flex-direction:column;z-index:200;padding:12px;
    background:#fff;border-right:1px solid var(--border);box-shadow:none;
    transition:left .25s ease,box-shadow .25s ease;overflow-y:auto;
  }
  .sidebar.open{left:0;box-shadow:6px 0 24px rgba(0,0,0,0.1)}
  #sidebarBackdrop{
    display:none;position:fixed;inset:0;z-index:199;
    background:rgba(0,0,0,0.25);
  }
  #sidebarBackdrop.open{display:block}
  .sidebar-nav{flex-direction:column;gap:2px;flex:0 0 auto}
  .sidebar-bottom{display:flex;flex-direction:column;margin-top:0}
  .sidebar-divider{display:block}
  .sidebar-item{padding:12px 14px;font-size:15px;touch-action:manipulation}

  .admin-content{padding:20px 16px}
  .hours-row{flex-wrap:wrap}
  .hours-day{width:80px}
}

@media(max-width:640px){
  body{overflow-x:hidden}
  .nav{padding:0 16px}
  .container,.container-wide{padding:24px 16px 60px}
  .form-row{grid-template-columns:1fr}
  .form-row-2{grid-template-columns:1fr}
  .card{padding:20px}
  .step-label{display:none !important}
  .step-line{width:20px;margin:0 3px}
  .link-row{flex-direction:column}
  .link-row .btn-copy{width:100%;padding:12px}
  .section-header{flex-direction:column;align-items:flex-start}
  .section-header .btn-secondary{width:100%;justify-content:center}
  .stats-row{grid-template-columns:1fr}
  .pref-grid-times{grid-template-columns:1fr}
  .pref-grid-days{grid-template-columns:repeat(2,1fr)}
  .hours-inputs{flex-wrap:wrap}

  /* Time slot rows: wrap times onto a second line */
  .slot-def-row{flex-wrap:wrap;gap:8px 12px;align-items:center}
  .slot-def-name{flex:1;width:auto}
  .sch-slot-times{
    width:100%;order:4;
    display:flex;align-items:center;gap:8px;
  }
  .sch-slot-times input[type="time"]{flex:1;width:auto;min-width:0}

}

/* ── Form Builder (Admin) ── */
.fb-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:10px}
.fb-list{display:flex;flex-direction:column;gap:8px}
.fb-empty{font-size:14px;color:var(--muted);padding:16px 0}
.fb-row{background:white;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;transition:border-color .15s}
.fb-row:hover{border-color:rgba(27,58,107,.2)}
.fb-row-main{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.fb-row-drag{display:flex;flex-direction:column;gap:2px;flex-shrink:0}
.fb-move-btn{background:none;border:none;cursor:pointer;padding:2px 4px;color:var(--muted);font-size:14px;line-height:1;border-radius:4px}
.fb-move-btn:hover:not(:disabled){background:var(--border);color:var(--ink)}
.fb-move-btn:disabled{opacity:.3;cursor:not-allowed}
.fb-drag-handle{cursor:grab;color:var(--muted);font-size:18px;user-select:none;padding:0 2px}
.fb-drag-handle:active{cursor:grabbing}
.fb-row[draggable=true]:hover .fb-drag-handle{color:var(--navy)}
.fb-row.fb-dragging{opacity:0.35}
.fb-row.fb-drag-over{border-color:var(--navy);box-shadow:0 0 0 2px rgba(27,58,107,.15)}
.fb-contact-group.fb-dragging-group,.fb-custom-group.fb-dragging-group{opacity:0.35}
.fb-contact-group.fb-drag-over-group,.fb-custom-group.fb-drag-over-group{outline:2px solid var(--navy);outline-offset:2px;border-radius:10px}
.fb-type-badge{flex-shrink:0;font-size:11px;font-weight:700;padding:3px 8px;border-radius:100px;background:var(--navy);color:#fff;white-space:nowrap}
.fb-type-badge-wrap{display:flex;flex-direction:column;align-items:center;gap:3px;flex-shrink:0}
.fb-type-badge-sub{font-size:11px;font-weight:600;color:var(--muted);white-space:nowrap}
/* Custom field type colours — shared by badge and type picker */
.fb-type-text    {background:#0D9488; color:#fff}
.fb-type-textarea{background:#7C3AED; color:#fff}
.fb-type-select  {background:#D97706; color:#fff}
.fb-type-radio   {background:#DB2777; color:#fff}
.fb-type-checkbox{background:#4F46E5; color:#fff}
.fb-type-file    {background:#059669; color:#fff}
.fb-row-fields{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}
.fb-subfield{display:flex;flex-direction:column;gap:3px}
.fb-subfield-label{font-size:11px;font-weight:600;color:var(--ink);letter-spacing:.02em}
.fb-subfield-fixed{font-size:13px;color:var(--muted);padding:6px 10px;background:rgba(27,58,107,0.03);border:1px solid var(--border);border-radius:6px;user-select:none}
.fb-label-input,.fb-placeholder-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:var(--sans);color:var(--ink);background:white;box-sizing:border-box}
.fb-label-input:focus,.fb-placeholder-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,58,107,.08)}
input[type=number].fb-placeholder-input{-moz-appearance:textfield;-webkit-appearance:none;appearance:none;background:white;color:var(--muted);font-size:13px;line-height:normal}
input[type=number].fb-placeholder-input::-webkit-outer-spin-button,
input[type=number].fb-placeholder-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;display:none}
.fb-placeholder-input{font-size:13px;color:var(--muted)}
.fb-row-controls{display:flex;align-items:center;gap:16px;flex-shrink:0;flex-wrap:wrap}
.fb-control-group{display:flex;flex-direction:column;align-items:center;gap:4px}
.fb-control-label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.fb-lock-badge{font-size:11px;font-weight:600;color:var(--muted);padding:2px 7px;background:var(--border);border-radius:100px;white-space:nowrap}
.fb-delete-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:var(--muted);transition:all .15s;flex-shrink:0;display:flex}
.fb-delete-btn:hover{background:#FEE2E2;color:#DC2626}
.fb-add-row{display:flex;align-items:center;gap:10px;margin-top:4px}
.fb-add-row{flex-wrap:nowrap!important}
.fb-add-field-btn{padding:0 14px!important;height:36px;font-size:13px!important;white-space:nowrap;flex-shrink:0}
.fb-new-type-select{padding:0 32px 0 10px;height:36px;border:1px solid var(--border);border-radius:10px;font-size:13px;font-family:var(--sans);background:white url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E") no-repeat right 10px center;color:var(--ink);appearance:none;-webkit-appearance:none;cursor:pointer;min-width:0;flex:1}
.fb-new-type-select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,58,107,.08)}
.fb-options-wrap{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.fb-options-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:8px}
.fb-option-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.fb-option-input{flex:1;padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--sans)}
.fb-option-del{background:none;border:none;cursor:pointer;padding:6px 8px;border-radius:6px;color:var(--muted);font-size:16px;line-height:1}
.fb-option-del:hover{background:#FEE2E2;color:#DC2626}
.fb-add-option-btn{font-size:13px;font-weight:500;color:var(--navy);background:none;border:none;cursor:pointer;padding:4px 0}
.fb-add-option-btn:hover{text-decoration:underline}

/* ── Custom field inputs (lead form) ── */
.radio-option,.checkbox-option{display:flex;align-items:center;gap:10px;padding:12px 14px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:8px;font-size:15px;font-weight:500;color:var(--ink);transition:border-color .15s,background .15s}
.radio-option:hover,.checkbox-option:hover{border-color:rgba(27,58,107,.3);background:#FAFAF9}
.radio-option input,.checkbox-option input{width:18px;height:18px;accent-color:var(--navy);flex-shrink:0;cursor:pointer}
.radio-option:has(input:checked),.checkbox-option:has(input:checked){border-color:var(--navy);background:rgba(27,58,107,.04)}

/* ── Forms list (multi-form management) ── */
.form-card{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 24px;background:white;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;transition:box-shadow .15s}
.form-card:hover{box-shadow:0 2px 12px rgba(0,0,0,.07)}
.form-card-left{flex:1;min-width:0}
.form-card-name{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:6px}
.form-card-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.form-type-badge{font-size:11px;font-weight:700;letter-spacing:.03em;padding:3px 9px;border-radius:100px;white-space:nowrap}
.form-type-appt{background:#E8F0FE;color:#1a73e8}
.form-type-contact{background:#E6F4EA;color:#188038}
.form-type-custom{background:#F3F4F6;color:#374151}
.form-card-slug{font-size:12px;color:var(--muted);font-family:monospace}
.form-card-link{display:flex;align-items:center;gap:8px;max-width:520px}
.form-link-input{flex:1;padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:12px;font-family:monospace;background:var(--bg);color:var(--ink);min-width:0}
.form-copy-btn{flex-shrink:0;padding:7px 14px;font-size:12px}
.form-card-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;padding-top:2px}
.form-edit-btn{font-size:13px;padding:8px 14px;display:flex;align-items:center;gap:5px}
.back-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;padding:8px 14px}

/* ── Driver.js tour theme ── */
.driver-popover.lm-tour{
  /* Override Driver.js CSS custom properties so its internal styles use our theme */
  --driver-popover-bg:#ffffff;
  --driver-popover-title-color:#ffffff;
  --driver-popover-description-color:#6B7280;
  --driver-popover-btn-primary-bg:#1B3A6B;
  --driver-popover-btn-primary-color:#ffffff;
  --driver-popover-btn-secondary-bg:#ffffff;
  --driver-popover-btn-secondary-color:#1B3A6B;
  --driver-popover-progress-color:#9CA3AF;
  font-family:var(--sans)!important;
  border-radius:16px!important;
  box-shadow:0 16px 48px rgba(27,58,107,.28)!important;
  padding:0!important;
  max-width:360px!important;
  overflow:hidden!important;
  border:none!important;
  background:#fff!important;
}
/* Navy header strip */
.driver-popover.lm-tour .driver-popover-title{
  display:block;
  background:var(--navy)!important;
  color:#fff!important;
  font-family:var(--serif)!important;
  font-size:16px!important;
  font-weight:800!important;
  padding:16px 42px 14px 20px!important;
  margin:0!important;
  line-height:1.3!important;
  letter-spacing:-.01em!important;
}
/* Close button sits in the header */
.driver-popover.lm-tour .driver-popover-close-btn{
  position:absolute!important;
  top:14px!important;right:14px!important;
  color:rgba(255,255,255,.7)!important;
  font-size:20px!important;line-height:1!important;
  background:none!important;border:none!important;padding:0!important;cursor:pointer!important;
}
.driver-popover.lm-tour .driver-popover-close-btn:hover{color:#fff!important;}
/* Description */
.driver-popover.lm-tour .driver-popover-description{
  padding:16px 20px 4px!important;
  font-size:13.5px!important;
  color:var(--muted)!important;
  line-height:1.65!important;
  margin:0!important;
}
.driver-popover.lm-tour .driver-popover-description b{color:var(--ink)!important;font-weight:700!important;}
/* Footer */
.driver-popover.lm-tour .driver-popover-footer{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  padding:14px 20px 18px!important;
  margin:0!important;
  gap:10px!important;
}
.driver-popover.lm-tour .driver-popover-progress-text{
  font-size:11px!important;font-weight:700!important;
  color:var(--light)!important;
  font-family:var(--sans)!important;
  letter-spacing:.04em!important;
  text-transform:uppercase!important;
  white-space:nowrap!important;
}
.driver-popover.lm-tour .driver-popover-navigation-btns{display:flex!important;gap:8px!important;}
/* Prev button */
.driver-popover.lm-tour .driver-popover-prev-btn{
  background:#fff!important;
  color:var(--navy)!important;
  border:1.5px solid rgba(27,58,107,.25)!important;
  border-radius:9px!important;
  padding:7px 15px!important;
  font-size:13px!important;font-weight:600!important;
  font-family:var(--sans)!important;
  cursor:pointer!important;
  transition:background .15s!important;
}
.driver-popover.lm-tour .driver-popover-prev-btn:hover{background:var(--bg)!important;}
/* Next / Done button */
.driver-popover.lm-tour .driver-popover-next-btn{
  background:var(--navy)!important;
  color:#ffffff!important;
  border:none!important;
  border-radius:9px!important;
  padding:7px 18px!important;
  font-size:13px!important;font-weight:600!important;
  font-family:var(--sans)!important;
  cursor:pointer!important;
  transition:background .15s!important;
  -webkit-font-smoothing:antialiased!important;
  -moz-osx-font-smoothing:grayscale!important;
  transform:translateZ(0)!important;
  text-shadow:none!important;
}
.driver-popover.lm-tour .driver-popover-next-btn:hover{background:#142d55!important;}
/* Arrow */
.driver-popover.lm-tour .driver-popover-arrow-side-left.driver-popover-arrow{border-right-color:#1B3A6B!important;}
.driver-popover.lm-tour .driver-popover-arrow-side-right.driver-popover-arrow{border-left-color:#1B3A6B!important;}
.driver-popover.lm-tour .driver-popover-arrow-side-top.driver-popover-arrow{border-bottom-color:#1B3A6B!important;}
.driver-popover.lm-tour .driver-popover-arrow-side-bottom.driver-popover-arrow{border-top-color:#1B3A6B!important;}

/* ── Embed mode (form loaded inside iframe on client website) ── */
.embed-mode .nav,.embed-mode .footer{display:none!important}
body.embed-mode{background:transparent;min-height:0!important;height:auto}
.embed-mode .container{padding:20px 20px 24px}

/* Narrow embed: 420px and below */
@media(max-width:420px){
  .embed-mode .container{padding:16px 14px 20px}
  .embed-mode .card{padding:16px}
  .embed-mode .step-dot{width:26px;height:26px;font-size:11px}
  .embed-mode .step-line{width:16px;margin:0 3px}
  .embed-mode .urgency-card{padding:12px 14px;gap:10px}
  .embed-mode .urgency-icon{width:36px;height:36px;font-size:18px}
  .embed-mode .urgency-label{font-size:13px}
  .embed-mode .urgency-hint{font-size:11px}
  .embed-mode .service-card{padding:10px 14px;gap:10px}
  .embed-mode .svc-name{font-size:13px}
  .embed-mode .step-heading{font-size:20px}
  .embed-mode .page-header{margin-bottom:16px}
  .embed-mode .practice-name{font-size:18px}
}

/* Very narrow embed: 320px and below */
@media(max-width:320px){
  .embed-mode .container{padding:12px 10px 16px}
  .embed-mode .card{padding:12px}
  .embed-mode .step-label{display:none!important}
  .embed-mode .step-dot{width:22px;height:22px;font-size:10px}
  .embed-mode .pref-grid-days{grid-template-columns:repeat(2,1fr);gap:8px}
  .embed-mode .pref-card{padding:10px 8px;font-size:12px}
}

/* ── Form cards — embed snippet row ── */
.form-link-block{margin-bottom:12px;max-width:620px}
.form-link-block-head{margin-bottom:4px}
.form-card-link-row{display:flex;align-items:center;gap:8px}
.form-link-label{font-size:11px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;margin-right:4px}
.form-link-desc{font-size:11px;color:var(--muted);line-height:1.4}
.form-embed-input{flex:1;padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:11px;font-family:monospace;background:var(--bg);color:var(--ink);min-width:0;resize:none;height:46px;overflow:hidden;line-height:1.4}
.form-css-badge{font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 7px;border-radius:100px;background:#E6F4EA;color:#188038;vertical-align:middle;margin-left:6px}

/* ── Form builder — Thank You section ── */
.fb-thankyou-wrap{background:white;border:1.5px solid var(--border);border-radius:12px;padding:20px;margin-top:8px}
.fb-ty-mode-row{display:flex;flex-direction:column;gap:8px}
.fb-ty-opt{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s}
.fb-ty-opt input[type=radio]{margin-top:2px;flex-shrink:0;accent-color:var(--navy)}
.fb-ty-opt.active{border-color:var(--navy);background:rgba(27,58,107,.04)}
.fb-ty-opt-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:2px}
.fb-ty-opt-desc{font-size:12px;color:var(--muted);line-height:1.4}
.fb-field-label{display:block;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px}
.fb-ty-divider{border:none;border-top:1px solid var(--border);margin:16px 0}
.fb-ty-block{margin-bottom:14px}
.fb-ty-block-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}

/* ── Form builder — CSS editor section ── */
.fb-file-section{display:flex;flex-direction:column;gap:4px;width:100%}
.fb-file-presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.fb-file-preset-btn{font-size:11px;font-weight:600;padding:3px 10px;border:1.5px solid var(--border);border-radius:100px;background:white;color:var(--ink);cursor:pointer;transition:all .15s}
.fb-file-preset-btn:hover{border-color:var(--navy);color:var(--navy)}
.fb-file-preset-clear{color:var(--muted)}
.fb-file-hipaa-note{font-size:11px;color:#92400E;background:#FEF3C7;border:1px solid #FCD34D;border-radius:6px;padding:6px 10px;margin-top:8px;line-height:1.5}
.fb-stepper{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:8px;overflow:hidden;width:fit-content}
.fb-stepper-btn{width:32px;height:32px;background:var(--bg);border:none;font-size:18px;font-weight:500;color:var(--ink);cursor:pointer;transition:background .15s;display:flex;align-items:center;justify-content:center}
.fb-stepper-btn:hover{background:rgba(27,58,107,0.08)}
.fb-stepper-val{min-width:52px;text-align:center;font-size:13px;font-weight:600;color:var(--ink);padding:0 6px;border-left:1.5px solid var(--border);border-right:1.5px solid var(--border);height:32px;display:flex;align-items:center;justify-content:center}
.fb-css-wrap{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:16px;margin-top:8px}
.fb-css-hint{font-size:13px;color:var(--muted);margin-bottom:10px;line-height:1.5}
.fb-css-hint code{font-family:monospace;background:white;border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-size:12px;color:var(--ink)}
.fb-css-editor{width:100%;min-height:180px;padding:12px;border:1px solid var(--border);border-radius:8px;font-family:monospace;font-size:13px;line-height:1.6;color:var(--ink);background:white;resize:vertical;box-sizing:border-box}
.fb-css-editor:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,58,107,.1)}

/* ── Form display type badges (forms list) ── */
.form-display-wizard{background:#F3F4F6;color:#374151}
.form-display-single{background:#FFF7ED;color:#C2410C}

/* ── Form builder — display type selector ── */
.fb-display-options{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.fb-display-opt{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s;position:relative}
.fb-display-opt input[type=radio]{position:absolute;opacity:0;pointer-events:none}
.fb-display-opt.active{border-color:var(--navy);background:rgba(27,58,107,.04)}
.fb-display-opt:hover:not(.active){border-color:rgba(27,58,107,.3)}
.fb-display-body{flex:1}
.fb-display-name{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:700;color:var(--ink);margin-bottom:4px}
.fb-display-desc{font-size:12px;color:var(--muted);line-height:1.5}
@media(max-width:560px){.fb-display-options{grid-template-columns:1fr}}

/* ── Single-view form ── */
.sv-form{display:flex;flex-direction:column;gap:20px}
.sv-field{display:flex;flex-direction:column;gap:6px}
.sv-label{font-size:14px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:6px}
.sv-opt{font-size:12px;font-weight:400;color:var(--muted)}
.sv-hint{font-size:12px;color:var(--muted);margin:0}
.sv-input,.sv-select,.sv-textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;font-family:var(--sans);color:var(--ink);background:white;box-sizing:border-box;transition:border-color .15s}
.sv-input:focus,.sv-select:focus,.sv-textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,58,107,.08)}
.sv-textarea{resize:vertical;min-height:80px}
.sv-other-text{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;font-family:var(--sans);color:var(--ink);background:white;box-sizing:border-box;resize:vertical;min-height:70px;margin-top:8px}
.sv-choice{display:flex;align-items:center;gap:8px;padding:9px 12px;border:1.5px solid var(--border);border-radius:9px;cursor:pointer;font-size:14px;font-weight:500;color:var(--ink);transition:border-color .15s,background .15s;margin-bottom:6px}
.sv-choice:hover{border-color:rgba(27,58,107,.3);background:rgba(27,58,107,.02)}
.sv-choice input{width:16px;height:16px;accent-color:var(--navy);flex-shrink:0;cursor:pointer}
.sv-choice:has(input:checked){border-color:var(--navy);background:rgba(27,58,107,.04)}
.sv-pills{display:flex;flex-wrap:wrap;gap:8px}
.sv-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1.5px solid var(--border);border-radius:100px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink);transition:all .15s;white-space:nowrap;user-select:none}
.sv-pill:hover{border-color:rgba(27,58,107,.4);background:rgba(27,58,107,.03)}
.sv-pill input{position:absolute;opacity:0;pointer-events:none}
.sv-pill:has(input:checked){border-color:var(--navy);background:var(--navy);color:white}
.sv-pill-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.sv-pill-hint{font-size:11px;font-weight:400;color:inherit;opacity:.75}
.sv-submit-row{margin-top:8px}
.sv-submit-btn{width:100%;padding:16px;font-size:16px}
.sv-file-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-family:var(--sans);color:var(--ink);background:white;box-sizing:border-box;cursor:pointer}
.sv-file-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,58,107,.08)}
.sv-file-hint{font-size:12px;color:var(--muted);margin:4px 0 0}
.sv-file-input-hidden{display:none}
.sv-file-label{display:flex;align-items:center;gap:10px;cursor:pointer;width:100%}
.sv-file-btn{display:inline-flex;align-items:center;padding:8px 16px;border-radius:8px;border:1.5px solid var(--navy);background:white;color:var(--navy);font-size:13px;font-weight:600;font-family:var(--sans);white-space:nowrap;transition:background .15s,color .15s}
.sv-file-label:hover .sv-file-btn{background:var(--navy);color:white}
.sv-file-name{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── Privacy Policy consent widget ── */
.privacy-policy-wrap{padding:4px 0}
.privacy-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;user-select:none}
.privacy-label input[type="checkbox"]{width:20px;height:20px;flex-shrink:0;margin-top:1px;accent-color:var(--navy);cursor:pointer}
.privacy-text{font-size:14px;color:var(--ink);line-height:1.5}
.privacy-link{color:var(--navy);text-decoration:underline;font-weight:500}
.sv-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius,16px);padding:20px 24px;margin-top:0}

/* ── Form builder — name/label field ── */
.fb-name-field{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.fb-name-input{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:16px;font-weight:600;font-family:var(--sans);color:var(--ink);background:white;box-sizing:border-box;transition:border-color .15s}
.fb-name-input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(27,58,107,.08)}
.fb-name-hint{font-size:12px;color:var(--muted);margin:6px 0 0}

/* ── Inline field error ── */
.field-error{font-size:12.5px;color:#dc2626;margin-top:5px;display:none}

/* ── Lead form badge (shows which form a lead came from) ── */
.lead-form-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.03em;padding:2px 8px;border-radius:100px;background:#F0F4FF;color:#3B5BDB;margin-top:3px;white-space:nowrap}

/* ── Leads toolbar form filter ── */
.leads-toolbar-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
/* Search bar */
.leads-search-wrap{position:relative}
.leads-search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
input.leads-search{
  padding:6px 10px 6px 34px;width:220px;
  border:1.5px solid var(--border);border-radius:8px;
  font-size:13px;font-family:var(--sans);color:var(--ink);background:white;
  transition:border-color .15s,width .2s;
}
input.leads-search::placeholder{color:var(--muted)}
input.leads-search:focus{outline:none;border-color:var(--navy);width:280px}
/* Form filter dropdown */
.leads-form-filter-wrap{position:relative}
.leads-filter-chevron{position:absolute;right:9px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.leads-form-filter{
  padding:6px 28px 6px 10px;max-width:160px;
  border:1.5px solid var(--border);border-radius:8px;
  font-size:13px;font-family:var(--sans);color:var(--ink);background:white;
  cursor:pointer;-webkit-appearance:none;appearance:none;
}
.leads-form-filter:focus{outline:none;border-color:var(--navy)}

/* ── Email Notifications (Form Builder) ── */
.fb-email-sidebyside{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}
@media(max-width:900px){.fb-email-sidebyside{grid-template-columns:1fr}}
.fb-email-wrap{background:white;border:1.5px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:16px;height:100%}
.fb-email-toggle-row{display:flex;align-items:center;justify-content:space-between}
.fb-email-toggle-label{font-size:14px;font-weight:600;color:var(--ink)}
.fb-email-fields{display:flex;flex-direction:column;gap:16px;transition:opacity .2s}
.fb-email-fields-locked{opacity:0.45;pointer-events:none;user-select:none}
.fb-email-err{font-size:12px;color:#DC2626;margin-top:4px;min-height:16px}
.fb-email-input-err{border-color:#DC2626 !important;box-shadow:0 0 0 3px rgba(220,38,38,.1) !important}
.fb-email-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.fb-email-label-row .fb-email-label{margin-bottom:0}
.fb-refresh-body-btn{font-size:11px;color:var(--navy);background:none;border:1px solid var(--navy);border-radius:4px;padding:2px 8px;cursor:pointer;white-space:nowrap;opacity:0.75;transition:opacity .15s,background .15s}
.fb-refresh-body-btn:hover:not(:disabled){opacity:1;background:rgba(27,58,107,0.07)}
.fb-refresh-body-btn:disabled{opacity:0.35;cursor:default}
.fb-token-hint{font-size:12px;color:var(--muted)}
.fb-token-chips{display:flex;flex-wrap:wrap;gap:6px}
.fb-token-chip{font-size:11px;font-family:var(--sans);padding:3px 9px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg);color:var(--navy);cursor:grab;transition:all .15s;user-select:none}
.fb-token-chip:hover{border-color:var(--navy);background:#EEF2FF}
.fb-token-chip:active{cursor:grabbing}
.fb-email-body[ondragover],.fb-email-input[ondragover]{transition:border-color .15s}
.fb-email-body.drag-over,.fb-email-input.drag-over{border-color:var(--navy);background:#F0F4FF}
.fb-email-field{display:flex;flex-direction:column;gap:5px}
.fb-email-label{font-size:13px;font-weight:600;color:var(--ink)}
.fb-email-sublabel{font-size:12px;font-weight:400;color:var(--muted);margin-left:4px}
.fb-email-input{border:1.5px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;font-family:var(--sans);color:var(--ink);background:white}
.fb-email-input:focus{outline:none;border-color:var(--navy)}
.fb-email-body{border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;font-family:monospace;color:var(--ink);background:white;resize:vertical;line-height:1.6}
.fb-email-body:focus,.fb-email-sig:focus{outline:none;border-color:var(--navy)}
.fb-email-sig{border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;font-family:var(--sans);color:var(--ink);background:white;resize:vertical}
