:root {
  --navy: #082b5c;
  --blue: #1578e8;
  --blue-soft: #eaf4ff;
  --ink: #172033;
  --muted: #75819a;
  --line: #e8edf5;
  --canvas: #f6f8fc;
  --white: #fff;
  --green: #16a36a;
  --orange: #ef8a24;
  --red: #e64b55;
  --purple: #7656e8;
  --shadow: 0 10px 30px rgba(28, 56, 101, .08);
}
* { box-sizing: border-box; }
body { margin: 0; font-family: "DM Sans", sans-serif; background: var(--canvas); color: var(--ink); }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
.login-shell { min-height: 100vh; display: grid; place-items: center; padding: 28px; background:
  radial-gradient(circle at 15% 15%, #d9eaff 0, transparent 32%),
  radial-gradient(circle at 90% 80%, #e3f2ff 0, transparent 30%), #f7faff; }
.login-card { width: min(960px, 100%); min-height: 590px; background: white; border-radius: 30px; box-shadow: 0 28px 80px rgba(8,43,92,.14); display: grid; grid-template-columns: 1.05fr .95fr; overflow: hidden; }
.login-art { padding: 54px; background: linear-gradient(145deg,#082b5c,#1263c9); color: white; position: relative; display: flex; flex-direction: column; justify-content: space-between; }
.login-art:after { content:""; position:absolute; width:330px; height:330px; border:1px solid rgba(255,255,255,.15); border-radius:50%; right:-130px; bottom:-120px; box-shadow:0 0 0 48px rgba(255,255,255,.04),0 0 0 96px rgba(255,255,255,.03); }
.brand-lockup { height: 52px; width: 260px; object-fit: contain; object-position: left center; background: white; border-radius: 12px; padding: 7px 10px; }
.login-art h1 { font-size: 42px; line-height: 1.12; margin: 0 0 16px; letter-spacing:-1.5px; }
.login-art p { color: #cfe3ff; line-height: 1.7; max-width: 390px; }
.login-proof { display:flex; gap:12px; align-items:center; font-size:13px; color:#dceaff; }
.avatars { display:flex; }
.avatars span { width:30px; height:30px; border:2px solid #2369b6; border-radius:50%; background:#e8f2ff; margin-left:-7px; display:grid; place-items:center; color:var(--navy); font-size:10px; font-weight:700; }
.login-form { padding: 64px 58px; display:flex; flex-direction:column; justify-content:center; }
.eyebrow { color:var(--blue); font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; }
.login-form h2 { font-size:32px; margin:10px 0 8px; letter-spacing:-1px; }
.login-form > p { color:var(--muted); margin:0 0 32px; }
.field { display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field label { font-size:13px; font-weight:600; }
.field input,.field select,.field textarea,.control { width:100%; border:1px solid var(--line); border-radius:12px; padding:12px 14px; outline:none; background:white; color:var(--ink); }
.field input:focus,.field select:focus,.field textarea:focus,.control:focus { border-color:#87baff; box-shadow:0 0 0 4px #edf5ff; }
.repeatable-group { display:flex; flex-direction:column; gap:14px; }
.repeatable-group .field { margin:0; }
.field-label-row { display:flex; align-items:center; justify-content:space-between; min-height:24px; }
.add-field-btn,.remove-field-btn { width:26px; height:26px; border:0; border-radius:8px; display:grid; place-items:center; font-size:17px; line-height:1; }
.add-field-btn { background:var(--blue-soft); color:var(--blue); }
.add-field-btn:hover { background:#d8ebff; }
.remove-field-btn { background:#fff0f1; color:var(--red); }
.repeatable-added { animation:fieldIn .18s ease-out; }
@keyframes fieldIn { from { opacity:0; transform:translateY(-5px); } }
.label-with-tip { display:flex; align-items:center; gap:7px; }
.help-tip { position:relative; width:18px; height:18px; border-radius:50%; display:inline-grid; place-items:center; background:var(--blue-soft); color:var(--blue); font-size:11px; font-weight:700; cursor:help; }
.help-tip > span { visibility:hidden; opacity:0; position:absolute; left:24px; top:50%; transform:translateY(-50%); width:245px; padding:10px 12px; border-radius:9px; background:#10233f; color:white; font-size:11px; font-weight:500; line-height:1.4; z-index:30; box-shadow:var(--shadow); transition:.15s; }
.help-tip:hover > span,.help-tip:focus > span { visibility:visible; opacity:1; }
.contact-section { border:1px solid var(--line); background:#fafcff; border-radius:16px; padding:18px; }
.contact-section-head { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:14px; }
.contact-section-head h3 { margin:0; font-size:15px; }
.contact-section-head p { margin:4px 0 0; color:var(--muted); font-size:12px; }
.optional-text { margin-left:7px; color:var(--muted); font-size:10px; font-weight:600; text-transform:uppercase; }
.add-contact-card { border:1px solid #cfe2fa; background:var(--blue-soft); color:var(--blue); border-radius:10px; padding:9px 12px; font-weight:700; font-size:12px; white-space:nowrap; }
.contact-card { background:white; border:1px solid var(--line); border-radius:13px; padding:14px; margin-top:10px; animation:fieldIn .18s ease-out; }
.contact-card-title { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; color:var(--navy); font-size:13px; }
.contact-card-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.contact-card-grid .field { margin:0; }
.remove-contact-card { width:27px; height:27px; display:grid; place-items:center; border:0; border-radius:8px; background:#fff0f1; color:var(--red); }
.subscribed-service-card { border:1px solid var(--line); background:#fafcff; border-radius:14px; padding:16px; margin-top:12px; animation:fieldIn .18s ease-out; }
.remove-service-card { width:27px; height:27px; display:grid; place-items:center; border:0; border-radius:8px; background:#fff0f1; color:var(--red); }
.hidden { display:none!important; }
.login-row { display:flex; justify-content:space-between; margin:0 0 22px; font-size:13px; color:var(--muted); }
.link { color:var(--blue); font-weight:600; text-decoration:none; }
.simple-login { background:#fff; padding:32px; }
.simple-login-card { width:min(480px,100%); min-height:0; display:block; overflow:hidden; border:1px solid var(--line); border-radius:24px; box-shadow:0 20px 60px rgba(8,43,92,.10); }
.simple-login-form { padding:48px 48px 36px; display:block; }
.login-logo { display:block; width:250px; max-width:100%; height:62px; object-fit:contain; margin:0 auto 32px; }
.simple-login-form h1 { margin:0 0 34px; text-align:center; color:var(--navy); font-size:27px; letter-spacing:-.7px; }
.simple-login-form .field { margin-bottom:18px; }
.login-submit { width:100%; margin-top:6px; }
.login-footer { padding:18px 24px; border-top:1px solid var(--line); text-align:center; color:var(--muted); background:#fafbfd; font-size:11px; }
.primary { border:0; border-radius:12px; background:linear-gradient(135deg,#0d60c4,#1788ef); color:white; padding:12px 18px; font-weight:700; box-shadow:0 8px 18px rgba(21,120,232,.22); }
.primary:hover { transform:translateY(-1px); }
.app-shell { min-height:100vh; display:grid; grid-template-columns:250px 1fr; }
.sidebar { background:#082956; color:#d8e8fb; padding:24px 16px; position:fixed; inset:0 auto 0 0; width:250px; overflow:auto; z-index:20; }
.sidebar-mobile-head{display:block}.sidebar-mobile-head .side-logo{margin-bottom:25px}.sidebar-close,.sidebar-scrim{display:none}
.side-logo { background:white; border-radius:13px; padding:7px 10px; width:200px; height:47px; object-fit:contain; object-position:left; margin:0 8px 24px; }
.nav-label { font-size:10px; font-weight:700; letter-spacing:1.5px; color:#7fa4cf; padding:16px 13px 8px; }
.nav-item { width:100%; border:0; background:transparent; color:#bcd1e9; display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:11px; margin:3px 0; text-align:left; font-size:14px; transition:.2s; }
.nav-item:hover { background:rgba(255,255,255,.07); color:white; }
.nav-item.active { background:linear-gradient(135deg,#1479e8,#0c61c8); color:white; box-shadow:0 8px 22px rgba(0,0,0,.15); }
.nav-icon { width:20px; text-align:center; font-size:16px; }
.sidebar-foot { margin:32px 8px 0; padding:14px; border:1px solid rgba(255,255,255,.1); border-radius:13px; background:rgba(255,255,255,.04); font-size:12px; line-height:1.5; color:#a9c3df; }
.main { grid-column:2; min-width:0; }
.topbar { height:76px; padding:0 30px; display:flex; align-items:center; justify-content:space-between; background:rgba(255,255,255,.9); border-bottom:1px solid var(--line); position:sticky; top:0; z-index:10; backdrop-filter:blur(12px); }
.topbar h1 { margin:0; font-size:22px; letter-spacing:-.5px; }
.topbar small { color:var(--muted); display:block; margin-top:3px; }
.top-actions { display:flex; align-items:center; gap:12px; }
.search { width:250px; border:1px solid var(--line); background:#f8fafd; border-radius:11px; padding:10px 13px; }
.icon-btn { width:40px; height:40px; border-radius:11px; border:1px solid var(--line); background:white; position:relative; }
.dot { position:absolute; width:7px; height:7px; background:var(--red); border-radius:50%; top:8px; right:8px; border:1px solid white; }
.avatar { width:40px; height:40px; border-radius:12px; background:#e7f2ff; color:var(--navy); display:grid; place-items:center; font-weight:700; }
.top-menu-wrap { position:relative; }
.notification-btn { position:relative; width:45px; height:45px; display:grid; place-items:center; border:1px solid var(--line); border-radius:13px; background:white; color:var(--navy); }
.notification-btn:hover,.notification-btn.active { background:var(--blue-soft); border-color:#b9d7fa; }
.bell-icon { font-size:21px; display:block; animation:bellNudge 4s ease-in-out infinite; transform-origin:top center; }
@keyframes bellNudge { 0%,82%,100%{transform:rotate(0)} 86%{transform:rotate(15deg)} 90%{transform:rotate(-13deg)} 94%{transform:rotate(8deg)} }
.notification-count { position:absolute; right:-5px; top:-6px; min-width:19px; height:19px; padding:0 5px; border-radius:10px; display:grid; place-items:center; background:var(--red); color:white; border:2px solid white; font-size:9px; font-weight:800; }
.avatar-button { border:0; cursor:pointer; }
.avatar-button.active { box-shadow:0 0 0 3px #dbeeff; }
.top-dropdown { position:absolute; right:0; top:calc(100% + 10px); width:340px; background:white; border:1px solid var(--line); border-radius:15px; box-shadow:0 20px 55px rgba(8,43,92,.18); overflow:hidden; z-index:80; }
.dropdown-head { display:flex; justify-content:space-between; align-items:center; padding:14px 16px; border-bottom:1px solid var(--line); }
.dropdown-head span { color:var(--red); font-size:11px; font-weight:700; }
.notification-item { width:100%; border:0; background:white; display:flex; gap:11px; align-items:flex-start; text-align:left; padding:12px 15px; border-bottom:1px solid #f0f3f8; }
.notification-item:hover { background:#f8fbff; }
.notification-item i { width:9px; height:9px; border-radius:50%; margin-top:5px; flex:0 0 auto; }
.notification-item i.red { background:var(--red); }.notification-item i.orange { background:var(--orange); }.notification-item i.blue { background:var(--blue); }
.notification-item strong,.notification-item small { display:block; }
.notification-item strong { color:var(--ink); font-size:12px; }.notification-item small { color:var(--muted); margin-top:3px; font-size:10px; }
.see-all { width:100%; border:0; background:#f7faff; color:var(--blue); padding:12px; font-weight:700; font-size:11px; }
.profile-menu { width:235px; padding:8px; }
.profile-summary { display:flex; gap:10px; align-items:center; padding:8px; border-bottom:1px solid var(--line); margin-bottom:5px; }
.profile-summary strong,.profile-summary small { display:block; }.profile-summary strong{font-size:12px}.profile-summary small{font-size:10px;color:var(--muted);margin-top:2px}
.profile-menu > button { width:100%; border:0; background:white; text-align:left; padding:10px; border-radius:8px; color:#4d5b73; font-weight:600; font-size:12px; }
.profile-menu > button:hover { background:#f4f8fd; }
.profile-menu .signout-button { color:var(--red); }
.content { padding:26px 30px 50px; max-width:1600px; margin:auto; }
.section-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; gap:18px; }
.section-head h2 { margin:0; font-size:20px; }
.section-head p { color:var(--muted); margin:5px 0 0; font-size:13px; }
.section-head .page-summary { margin:0; color:var(--navy); font-size:16px; font-weight:700; letter-spacing:-.2px; }
.cards { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-bottom:22px; }
.prospect-cards { display:grid; grid-template-columns:repeat(7,1fr); gap:12px; margin-bottom:22px; }
.prospect-cards .stat { padding:14px; }
.prospect-cards .stat strong { font-size:20px; }
.stat { background:white; border:1px solid var(--line); padding:17px; border-radius:16px; box-shadow:0 4px 15px rgba(28,56,101,.035); }
.stat-top { display:flex; justify-content:space-between; align-items:center; color:var(--muted); font-size:12px; }
.stat-icon { width:34px; height:34px; display:grid; place-items:center; border-radius:10px; background:var(--blue-soft); color:var(--blue); font-size:17px; }
.stat strong { display:block; font-size:24px; margin:12px 0 5px; letter-spacing:-.6px; }
.trend { font-size:11px; color:var(--green); }
.grid-2 { display:grid; grid-template-columns:1.25fr .75fr; gap:20px; }
.panel { background:white; border:1px solid var(--line); border-radius:17px; box-shadow:0 4px 15px rgba(28,56,101,.035); overflow:hidden; }
.panel-pad { padding:19px; }
.panel-head { display:flex; align-items:center; justify-content:space-between; padding:18px 20px 14px; }
.panel-head h3 { margin:0; font-size:16px; }
.ghost { border:1px solid var(--line); background:white; border-radius:10px; padding:9px 12px; color:#4d5b73; font-weight:600; font-size:12px; }
.ghost:hover { background:#f7f9fc; }
.quick-actions { display:grid; grid-template-columns:repeat(5,1fr); gap:12px; margin-bottom:22px; }
.pipeline-panel { margin-bottom:22px; }
.pipeline { display:grid; grid-template-columns:repeat(6,1fr); gap:1px; background:var(--line); border-top:1px solid var(--line); }
.pipeline-step { border:0; background:white; padding:16px; text-align:left; color:var(--muted); }
.pipeline-step:hover { background:#f5f9ff; }
.pipeline-step span { display:block; font-size:11px; margin-bottom:7px; }
.pipeline-step strong { font-size:23px; color:var(--navy); }
.quick { border:1px solid #dce8f7; background:white; color:var(--navy); border-radius:14px; padding:14px; font-weight:600; display:flex; align-items:center; justify-content:center; gap:8px; transition:.2s; }
.quick:hover { border-color:#9ec9fb; background:#f4f9ff; transform:translateY(-2px); }
.alert-list,.activity-list { padding:0 20px 14px; }
.alert-row,.activity-row { display:flex; gap:12px; align-items:flex-start; padding:13px 0; border-top:1px solid #f0f3f8; }
.alert-mark { width:9px; height:9px; border-radius:50%; margin-top:5px; flex:0 0 auto; }
.alert-mark.red{background:var(--red)}.alert-mark.orange{background:var(--orange)}.alert-mark.blue{background:var(--blue)}
.dashboard-row-button{width:100%;border:0;background:transparent;text-align:left;color:inherit}.dashboard-row-button:hover{background:#f8fbff}.dashboard-row-copy{min-width:0;flex:1}.dashboard-row-copy strong,.dashboard-row-copy span{display:block}.dashboard-activity-icon{width:30px;height:30px;flex:0 0 30px;font-size:12px}.dashboard-empty,.notification-empty{padding:20px;color:var(--muted);font-size:12px;text-align:center}.dashboard-welcome{margin-bottom:20px}
.alert-row strong,.activity-row strong { font-size:13px; display:block; }
.alert-row span,.activity-row span { color:var(--muted); font-size:12px; }
.time { margin-left:auto; white-space:nowrap; font-size:11px!important; }
.toolbar { display:flex; gap:10px; margin-bottom:16px; flex-wrap:wrap; align-items:stretch; }
.toolbar .control,.toolbar > .universal-select { width:auto; min-width:180px; flex:0 1 230px; }
.toolbar > input.control { flex:1 1 240px; }
.toolbar > .reset-filters { flex:0 0 auto; }
.responsive-filter-strip{display:contents}
.clients-toolbar { display:grid; grid-template-columns:minmax(210px,1.25fr) repeat(4,minmax(145px,1fr)) auto; gap:12px; align-items:center; }
.clients-toolbar > .control,.clients-toolbar > .universal-select { width:100%; min-width:0; }
.prospects-toolbar { display:grid; grid-template-columns:minmax(170px,1.15fr) repeat(5,minmax(135px,1fr)) auto; gap:9px; align-items:center; flex-wrap:nowrap; }
.prospects-toolbar > .control,.prospects-toolbar > .universal-select { width:100%; min-width:0; }
.prospects-toolbar > input.control { min-width:0; width:100%; }
.prospects-toolbar .universal-select-input { padding-left:12px; padding-right:43px; font-size:12px; }
.prospects-toolbar .reset-filters { padding:0 12px; }
.quotations-toolbar { display:grid; grid-template-columns:minmax(180px,1.2fr) repeat(3,minmax(145px,1fr)) auto; gap:10px; align-items:center; flex-wrap:nowrap; }
.quotations-toolbar > .control,.quotations-toolbar > .universal-select { width:100%; min-width:0; }
.quotations-toolbar > input.control { width:100%; min-width:0; }
.quotations-toolbar .universal-select-input { padding-left:12px; padding-right:43px; font-size:12px; }
.quotations-toolbar .reset-filters { padding:0 13px; }
.reset-filters { align-self:stretch; min-height:46px; padding:0 14px; border:1px solid #dbe4ef; border-radius:11px; background:white; color:#526078; font-weight:700; font-size:12px; white-space:nowrap; }
.reset-filters:hover { border-color:#a9c9ee; background:var(--blue-soft); color:var(--blue); }
.table-wrap { overflow:auto; }
table { width:100%; border-collapse:collapse; font-size:13px; }
th { color:var(--muted); font-size:11px; text-transform:uppercase; letter-spacing:.65px; text-align:left; background:#fafbfd; padding:12px 16px; border-bottom:1px solid var(--line); white-space:nowrap; }
td { padding:14px 16px; border-bottom:1px solid #eff2f7; white-space:nowrap; }
.service-description { white-space:normal; min-width:320px; max-width:560px; color:#526078; line-height:1.45; }
tbody tr:hover { background:#fbfdff; }
.client-name { font-weight:700; color:#18233a; }
.subtext { color:var(--muted); font-size:11px; display:block; margin-top:3px; }
.badge { display:inline-flex; padding:5px 9px; border-radius:999px; font-size:10px; font-weight:700; }
.green { background:#e8f8f1; color:#118159; }.orange { background:#fff3e4; color:#bd681a; }.red { background:#ffecee; color:#c93946; }.blue { background:#eaf4ff; color:#1769bd; }.grey { background:#f0f2f5; color:#687386; }.purple { background:#f0edff; color:#654ad0; }
.row-actions { display:flex; gap:5px; }
.row-actions button { border:0; background:transparent; color:#64738b; padding:5px; border-radius:6px; }
.row-actions button:hover { color:var(--blue); background:var(--blue-soft); }
.client-record-view { min-width:112px; border:1px solid #b9d7fa; border-radius:9px; padding:8px 12px; background:var(--blue-soft); color:var(--blue); font-size:11px; font-weight:700; white-space:nowrap; }
.client-record-view:hover { border-color:var(--blue); background:var(--blue); color:white; }
.row-actions .convert-invoice-button { padding:7px 10px; border-radius:8px; background:var(--blue); color:white; font-size:10px; font-weight:700; white-space:nowrap; }
.row-actions .convert-invoice-button:hover { background:#176ac0; color:white; }
.quotation-row-actions { align-items:center; flex-wrap:nowrap; }
.row-actions .convert-client-button { padding:7px 10px; border-radius:8px; background:var(--blue); color:white; font-size:10px; font-weight:700; white-space:nowrap; }
.row-actions .convert-client-button:hover { background:#176ac0; color:white; }
.row-actions .mark-lost-button { padding:7px 10px; border-radius:8px; background:var(--red); color:white; font-size:10px; font-weight:700; white-space:nowrap; }
.row-actions .mark-lost-button:hover { background:#c93441; color:white; }
.prospect-row-actions { align-items:center; flex-wrap:nowrap; }
.payments-toolbar { display:grid; grid-template-columns:minmax(240px,1fr) minmax(180px,300px) auto; gap:10px; align-items:center; }
.payments-toolbar > .control,.payments-toolbar > .universal-select { width:100%; min-width:0; }
.record-payment-button { padding:8px 12px!important; border:1px solid #b9d7fa!important; background:var(--blue-soft)!important; color:var(--blue)!important; font-weight:700; white-space:nowrap; }
.record-payment-button:hover { background:var(--blue)!important; color:white!important; }
.reminder-actions{display:flex;gap:7px;align-items:center;white-space:nowrap}.reminder-complete{color:var(--green);border-color:#bfe8d7}.reminder-complete:hover{background:#edf9f4;color:#08724e}
.payment-row-actions { align-items:center; flex-wrap:nowrap; }
.payment-balance-summary { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.payment-balance-summary div { padding:13px; border:1px solid var(--line); border-radius:11px; background:#f8fafd; }
.payment-balance-summary span,.receipt-details span,.receipt-amount span { display:block; color:var(--muted); font-size:10px; text-transform:uppercase; letter-spacing:.5px; margin-bottom:5px; }
.payment-balance-summary strong { font-size:13px; }
.receipt-amount { position:relative; isolation:isolate; overflow:hidden; margin:25px 0; padding:20px; border-radius:14px; background:linear-gradient(135deg,#0c3a78,#267ee2); color:white; }
.receipt-amount-art { position:absolute; inset:0; z-index:-1; width:100%; height:100%; display:block; }
.receipt-amount > span,.receipt-amount > strong { position:relative; z-index:1; }
.receipt-amount span { color:#cfe4ff; }
.receipt-amount strong { display:block; font-size:28px; }
.receipt-details { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.receipt-details > div { padding:13px; border:1px solid var(--line); border-radius:11px; background:#fafbfd; }
.receipt-details strong { font-size:12px; overflow-wrap:anywhere; }
.receipt-footer { margin-top:28px; padding-top:16px; border-top:1px solid var(--line); color:var(--muted); font-size:11px; text-align:center; }
.probability { width:70px; height:5px; background:#edf1f6; border-radius:5px; overflow:hidden; display:inline-block; margin-right:7px; vertical-align:middle; }
.probability span { display:block; height:100%; background:linear-gradient(90deg,var(--blue),var(--green)); border-radius:5px; }
.prospect-hero { background:linear-gradient(135deg,#082b5c,#5946bd); }
.prospect-actions { display:flex; gap:8px; align-items:center; flex-wrap:wrap; padding:14px 20px; border-bottom:1px solid var(--line); }
.prospect-actions .close { margin-left:auto; }
.prospect-action-button { width:170px; min-height:44px; display:inline-flex; align-items:center; justify-content:center; padding:10px 14px!important; font-size:12px!important; line-height:1.2; white-space:nowrap; }
.danger-btn { border:1px solid #ffd4d8; background:#fff4f5; color:#c93946; border-radius:10px; padding:9px 12px; font-weight:700; font-size:12px; }
.delete-modal { width:min(480px,100%); text-align:center; padding-top:25px; }
.delete-symbol { width:48px; height:48px; margin:auto; display:grid; place-items:center; border-radius:50%; background:#ffecee; color:var(--red); font-size:24px; font-weight:800; }
.save-confirm-modal { width:min(480px,100%); text-align:center; padding-top:25px; }
.save-confirm-symbol { width:48px; height:48px; margin:auto; display:grid; place-items:center; border-radius:50%; background:#e8f8f1; color:var(--green); font-size:23px; font-weight:800; }
.delete-copy { padding-top:14px; }
.delete-copy h3 { margin:0 0 10px; font-size:20px; }
.delete-copy p { margin:0; color:var(--muted); line-height:1.55; }
.delete-permanent { border:0; border-radius:10px; padding:10px 15px; background:var(--red); color:white; font-weight:700; }
.delete-permanent:hover { background:#cb3542; }
.profile-columns { display:grid; grid-template-columns:1fr 1fr; gap:20px; padding:20px; }
.profile-columns h3,.timeline h3 { font-size:15px; margin:0 0 12px; }
.detail-grid.compact { grid-template-columns:1fr 1fr; padding:0; }
.timeline { margin:0 20px 22px; padding:18px; border:1px solid var(--line); border-radius:14px; }
.timeline-item { display:grid; grid-template-columns:14px 1fr auto; gap:10px; padding:10px 0; border-top:1px solid #f0f3f8; align-items:start; }
.timeline-item > span { width:9px; height:9px; margin-top:4px; border-radius:50%; background:var(--blue); }
.timeline-item strong { font-size:12px; }.timeline-item p,.timeline-item small { margin:3px 0 0; color:var(--muted); font-size:11px; }
.callout { padding:14px; border-radius:12px; background:#edf6ff; color:#315b87; font-size:13px; line-height:1.5; }
.searchable-select { position:relative; }
.searchable-select > input:first-child { padding-right:52px; }
.picker-toggle { position:absolute; right:6px; top:50%; transform:translateY(-50%); width:38px; height:38px; border:0; border-radius:9px; background:#f4f7fb; display:grid; place-items:center; padding:0; }
.picker-toggle span { width:8px; height:8px; border-right:2px solid var(--navy); border-bottom:2px solid var(--navy); transform:rotate(45deg) translate(-1px,-1px); transform-origin:center; }
.searchable-select.open .picker-toggle span { transform:rotate(225deg) translate(-1px,-1px); }
.picker-menu { display:none; position:absolute; left:0; right:0; top:calc(100% + 6px); max-height:230px; overflow:auto; background:white; border:1px solid var(--line); border-radius:12px; box-shadow:0 16px 35px rgba(8,43,92,.16); padding:6px; z-index:15; }
.searchable-select.open .picker-menu { display:block; }
.picker-option { display:block; width:100%; border:0; background:white; border-radius:9px; padding:10px 11px; text-align:left; color:var(--ink); }
.picker-option:hover { background:var(--blue-soft); }
.picker-option strong { display:block; font-size:13px; padding:2px 0; }
.picker-option span { display:block; color:var(--muted); font-size:11px; margin-top:3px; }
.picker-empty { padding:20px 12px; text-align:center; color:var(--muted); font-size:12px; }
.universal-select { position:relative; width:100%; }
.native-select-hidden { position:absolute!important; width:1px!important; height:1px!important; opacity:0!important; pointer-events:none!important; }
.universal-select-input { width:100%; border:1px solid var(--line); border-radius:12px; padding:12px 52px 12px 14px; outline:none; background:white; color:var(--ink); cursor:pointer; }
.universal-select-input:focus { border-color:#87baff; box-shadow:0 0 0 4px #edf5ff; cursor:text; }
.universal-select-toggle { position:absolute; right:6px; top:50%; transform:translateY(-50%); width:38px; height:38px; border:0; border-radius:9px; background:#f4f7fb; display:grid; place-items:center; padding:0; }
.universal-select-toggle span { width:8px; height:8px; border-right:2px solid var(--navy); border-bottom:2px solid var(--navy); transform:rotate(45deg) translate(-1px,-1px); }
.universal-select.open .universal-select-toggle span { transform:rotate(225deg) translate(-1px,-1px); }
.universal-select-menu { display:none; position:absolute; left:0; right:0; top:calc(100% + 6px); max-height:230px; overflow:auto; background:white; border:1px solid var(--line); border-radius:12px; box-shadow:0 16px 35px rgba(8,43,92,.16); padding:6px; z-index:40; }
.universal-select.open .universal-select-menu { display:block; }
.universal-select-option { display:block; width:100%; border:0; background:white; border-radius:9px; padding:11px; text-align:left; color:var(--ink); font-weight:600; }
.universal-select-option:hover,.universal-select-option.selected { background:var(--blue-soft); color:var(--navy); }
.empty { padding:50px; text-align:center; color:var(--muted); }
.modal-backdrop { position:fixed; inset:0; background:rgba(3,20,45,.55); z-index:100; display:grid; place-items:center; padding:20px; backdrop-filter:blur(4px); }
.modal { width:min(760px,100%); max-height:90vh; overflow:auto; background:white; border-radius:20px; box-shadow:0 30px 90px rgba(0,0,0,.25); }
.modal.wide { width:min(980px,100%); }
.modal-head { display:flex; justify-content:space-between; align-items:center; padding:20px 22px; border-bottom:1px solid var(--line); }
.modal-head h3 { margin:0; }
.close { border:0; background:#f1f4f8; width:34px; height:34px; border-radius:10px; }
.modal-body { padding:22px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:15px; }
.form-grid .field { margin:0; }
.span-2 { grid-column:span 2; }
.prospect-form-shell { min-width:0; }
.prospect-form-tabs { display:flex; gap:7px; padding:5px; margin-bottom:18px; border-radius:12px; background:#f1f5fa; }
.prospect-form-tabs button { flex:1; border:0; border-radius:9px; padding:11px 14px; background:transparent; color:var(--muted); font-weight:700; }
.prospect-form-tabs button.active { background:white; color:var(--blue); box-shadow:0 3px 12px rgba(8,43,92,.08); }
.prospect-form-panel { display:none; }
.prospect-form-panel.active { display:block; }
.field-help { display:block; margin-top:7px; color:var(--muted); font-size:11px; line-height:1.4; }
.prospect-service-selector { min-width:0; }
.prospect-service-multiselect { position:relative; }
.prospect-service-trigger { width:100%; min-height:48px; padding:0 48px 0 14px; border:1px solid var(--line); border-radius:12px; background:white; color:var(--ink); text-align:left; position:relative; }
.prospect-service-trigger i { position:absolute; right:19px; top:50%; width:8px; height:8px; border-right:2px solid var(--navy); border-bottom:2px solid var(--navy); transform:translateY(-70%) rotate(45deg); }
.prospect-service-multiselect.open .prospect-service-trigger i { transform:translateY(-20%) rotate(225deg); }
.prospect-service-menu { display:none; position:absolute; left:0; right:0; top:calc(100% + 6px); padding:8px; border:1px solid var(--line); border-radius:12px; background:white; box-shadow:0 16px 35px rgba(8,43,92,.17); z-index:80; }
.prospect-service-multiselect.open .prospect-service-menu { display:block; }
.prospect-service-search { width:100%; margin-bottom:7px; padding:10px 12px; border:1px solid var(--line); border-radius:9px; }
.prospect-service-options { max-height:230px; overflow:auto; display:flex; flex-direction:column; gap:4px; }
.service-check { position:relative; cursor:pointer; }
.service-check input { position:absolute; opacity:0; pointer-events:none; }
.service-check span { display:flex; flex-direction:row; align-items:center; gap:9px; min-height:40px; padding:9px 11px; border:1px solid transparent; border-radius:9px; color:#526078; background:white; }
.service-check span i { width:17px; height:17px; flex:0 0 17px; border:1.5px solid #b8c5d6; border-radius:5px; background:white; position:relative; }
.service-check span b { font-size:12px; color:var(--ink); }
.service-check:hover span { background:#f4f8fd; }
.service-check input:checked + span { border-color:#82b8f4; color:var(--blue); background:var(--blue-soft); }
.service-check input:checked + span i { border-color:var(--blue); background:var(--blue); }
.service-check input:checked + span i:after { content:""; position:absolute; left:5px; top:2px; width:4px; height:8px; border-right:2px solid white; border-bottom:2px solid white; transform:rotate(45deg); }
.selected-prospect-services { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.selected-service-tag { display:inline-flex; align-items:center; gap:7px; border:1px solid #a8cdf7; border-radius:999px; padding:5px 9px; background:var(--blue-soft); color:var(--blue); font-size:10px; font-weight:700; }
.selected-service-tag span { font-size:13px; line-height:1; }
.custom-service-head { display:flex; align-items:center; justify-content:space-between; gap:10px; margin:11px 0 7px; }
.custom-service-head small { color:var(--muted); font-weight:700; }
.custom-prospect-service { display:flex; gap:7px; margin-top:7px; }
.custom-prospect-service input { min-width:0; }
.remove-custom-prospect-service { flex:0 0 38px; border:0; border-radius:9px; color:var(--red); background:#fff0f1; }
.prospect-services-cell { white-space:normal; min-width:210px; max-width:320px; line-height:1.4; }
.quotation-recipient-type { text-transform:none; font-size:10px; font-weight:600; color:var(--blue); }
.prospect-activity-section { padding:17px; border:1px solid var(--line); border-radius:15px; background:#fafcff; }
.prospect-activity-section-head { display:flex; justify-content:space-between; align-items:flex-start; gap:18px; margin-bottom:12px; }
.prospect-activity-section-head h3 { margin:0 0 5px; font-size:15px; }
.prospect-activity-section-head p { margin:0; color:var(--muted); font-size:11px; line-height:1.45; }
.prospect-activity-entry { display:grid; grid-template-columns:minmax(190px,.42fr) minmax(0,1.58fr); gap:15px; padding:16px; margin-bottom:10px; border:1px solid var(--line); border-radius:14px; background:white; align-items:start; }
.prospect-activity-entry .field { margin:0; }
.prospect-activity-entry-head { grid-column:1/-1; display:flex; justify-content:space-between; align-items:center; font-size:12px; color:var(--navy); }
.remove-prospect-activity { width:27px; height:27px; border:0; border-radius:8px; background:#fff0f1; color:var(--red); }
.saved-prospect-activities { margin:16px 0 12px; }
.saved-prospect-activities h4 { margin:0 0 8px; font-size:13px; }
.saved-activity-row { display:flex; justify-content:space-between; gap:16px; padding:10px 2px; border-top:1px solid var(--line); }
.saved-activity-row strong { display:block; font-size:12px; }
.saved-activity-row p { margin:3px 0 0; color:var(--muted); font-size:11px; line-height:1.4; }
.saved-activity-row span { flex:0 0 auto; color:var(--muted); font-size:10px; }
.conversation-history-panel { border:1px solid var(--line); border-radius:15px; background:#fafcff; overflow:hidden; }
.conversation-history-head { padding:17px 18px; border-bottom:1px solid var(--line); background:white; }
.conversation-history-head h3 { margin:0 0 5px; font-size:15px; }
.conversation-history-head p { margin:0; color:var(--muted); font-size:11px; }
.history-inner-tabs { display:flex; gap:7px; padding:10px; border-bottom:1px solid var(--line); background:#f4f7fb; }
.history-inner-tabs button { flex:1; border:0; border-radius:9px; padding:10px 12px; background:transparent; color:var(--muted); font-weight:700; font-size:11px; }
.history-inner-tabs button.active { background:white; color:var(--blue); box-shadow:0 2px 9px rgba(8,43,92,.09); }
.history-inner-panel { display:none; }
.history-inner-panel.active { display:block; }
.conversation-history-item { display:flex; justify-content:space-between; gap:18px; padding:15px 18px; border-bottom:1px solid var(--line); }
.conversation-history-item:last-child { border-bottom:0; }
.conversation-history-item strong { display:block; font-size:12px; color:var(--ink); }
.conversation-history-item p { margin:5px 0 0; color:#526078; font-size:12px; line-height:1.55; white-space:pre-wrap; overflow-wrap:anywhere; }
.conversation-history-item time { flex:0 0 auto; color:var(--muted); font-size:10px; white-space:nowrap; }
.timeline-item p { white-space:pre-wrap; overflow-wrap:anywhere; }
.modal-foot { display:flex; justify-content:flex-end; gap:10px; padding:16px 22px; border-top:1px solid var(--line); }
.detail-hero { padding:24px; background:linear-gradient(135deg,#092f65,#136bcc); color:white; display:flex; justify-content:space-between; align-items:center; }
.detail-hero h2 { margin:0 0 6px; }.detail-hero p { margin:0; color:#cfe3ff; }
.detail-tabs { display:flex; gap:4px; padding:12px 20px 0; overflow:auto; border-bottom:1px solid var(--line); }
.detail-tabs button { border:0; background:none; padding:10px 12px; color:var(--muted); font-weight:600; font-size:12px; border-bottom:2px solid transparent; white-space:nowrap; }
.detail-tabs button.active { color:var(--blue); border-bottom-color:var(--blue); }
.detail-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; padding:20px; }
.info-box { border:1px solid var(--line); padding:13px; border-radius:12px; }
.info-box label { font-size:10px; color:var(--muted); text-transform:uppercase; display:block; margin-bottom:5px; }
.info-box strong { font-size:13px; }
.invoice-paper { background:white; padding:36px; border:1px solid var(--line); box-shadow:var(--shadow); max-width:800px; margin:auto; }
.doc-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:35px; }
.doc-logo { width:230px; height:52px; object-fit:contain; object-position:left; }
.doc-title { text-align:right; }.doc-title h2 { font-size:32px; color:var(--navy); margin:0; }.doc-title p { color:var(--muted); }
.doc-meta { display:grid; grid-template-columns:1fr 1fr; gap:30px; margin-bottom:25px; }
.doc-total { margin-left:auto; width:280px; margin-top:20px; }
.doc-total div { display:flex; justify-content:space-between; align-items:center; gap:18px; padding:6px 0; font-size:11px; }
.doc-total div strong { font-size:11px; font-weight:600; }
.doc-total .grand { border-top:2px solid var(--navy); margin-top:6px; padding-top:10px; font-size:13px; font-weight:700; color:var(--navy); }
.doc-total .grand span { font-size:13px; }
.quote-builder-backdrop { padding:12px; }
.quote-builder-modal { width:min(1500px,100%); height:min(94vh,980px); background:white; border-radius:20px; box-shadow:0 30px 90px rgba(0,0,0,.28); overflow:hidden; }
.quote-builder-head { height:74px; padding:12px 20px; display:flex; justify-content:space-between; align-items:center; border-bottom:1px solid var(--line); }
.quote-builder-head h2 { margin:3px 0 0; font-size:20px; }
.quote-builder-head > div:last-child { display:flex; align-items:center; gap:8px; }
.quote-builder-layout { display:grid; grid-template-columns:minmax(500px,.9fr) minmax(570px,1.1fr); height:calc(100% - 74px); }
.quote-editor { padding:20px; overflow:auto; background:#fbfcff; border-right:1px solid var(--line); }
.builder-section { background:white; border:1px solid var(--line); border-radius:15px; padding:17px; margin-bottom:15px; min-width:0; overflow:visible; }
.builder-section h3 { margin:0 0 15px; font-size:15px; }
.builder-section-head { display:flex; align-items:center; justify-content:space-between; gap:15px; margin-bottom:12px; }
.builder-section-head h3 { margin:0; }.builder-section-head p { margin:4px 0 0; color:var(--muted); font-size:11px; }
.quote-line-item { border:1px solid var(--line); border-radius:13px; padding:13px; margin-top:10px; background:#fafcff; }
.quote-line-title { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; color:var(--navy); font-size:12px; }
.remove-quote-item,.remove-invoice-item { width:26px; height:26px; border:0; border-radius:8px; background:#fff0f1; color:var(--red); }
.quote-line-service { display:grid; grid-template-columns:minmax(0,.72fr) minmax(0,1.28fr); gap:12px; align-items:start; width:100%; }
.quote-line-service .field,.quote-line-service .rich-field { margin:0; min-width:0; width:100%; }
.quote-line-service .rich-content { min-height:82px; }
.quote-line-numbers { display:grid; grid-template-columns:minmax(0,.62fr) minmax(0,.82fr) minmax(0,1.12fr) minmax(0,.82fr); gap:10px; margin-top:14px; align-items:end; width:100%; }
.quote-line-numbers .field { margin:0; min-width:0; width:100%; }
.quote-line-item { padding:16px; min-width:0; overflow:visible; position:relative; }
.quote-line-item:has(.discount-picker.open) { z-index:60; }
.quote-line-item input,.quote-line-item select,.quote-line-item .universal-select,.quote-line-item .universal-select-input,.quote-line-item .rich-editor { min-height:44px; min-width:0; max-width:100%; width:100%; }
.quote-line-item .universal-select-input { padding-right:46px; }
.discount-picker { position:relative; width:100%; }
.discount-picker-button { width:100%; min-height:44px; padding:0 46px 0 13px; border:1px solid var(--line); border-radius:12px; background:white; color:var(--ink); text-align:left; position:relative; }
.discount-picker-button i { position:absolute; right:18px; top:50%; width:8px; height:8px; border-right:2px solid var(--navy); border-bottom:2px solid var(--navy); transform:translateY(-70%) rotate(45deg); }
.discount-picker.open .discount-picker-button i { transform:translateY(-20%) rotate(225deg); }
.discount-picker-menu { display:none; position:absolute; left:0; right:0; top:calc(100% + 6px); min-width:170px; padding:6px; border:1px solid var(--line); border-radius:11px; background:white; box-shadow:0 14px 30px rgba(8,43,92,.16); z-index:100; }
.discount-picker.open .discount-picker-menu { display:block; }
.discount-picker-menu button { width:100%; border:0; border-radius:8px; background:white; padding:10px; text-align:left; font-weight:600; color:var(--ink); }
.discount-picker-menu button:hover { background:var(--blue-soft); color:var(--blue); }
.line-item-description { margin-top:5px; color:var(--muted); font-size:10px; line-height:1.4; font-weight:400; }
.line-item-description ul,.line-item-description ol { padding-left:16px; margin:3px 0; }
.quote-live-pane { overflow:auto; background:#eef2f8; padding:20px; }
.live-preview-label { display:flex; justify-content:space-between; align-items:center; max-width:800px; margin:0 auto 10px; color:var(--navy); font-size:12px; font-weight:700; }
.live-preview-label small { color:var(--green); font-weight:600; }
.quote-live-pane .invoice-paper { transform-origin:top center; }
.quote-document-dates { display:grid; grid-template-columns:1fr 1fr; gap:12px; padding:13px 0 22px; }
.quote-document-dates div { background:#f7f9fc; border-radius:10px; padding:10px 12px; }
.quote-document-dates span { display:block; color:var(--muted); text-transform:uppercase; font-size:8px; letter-spacing:.5px; margin-bottom:4px; }
.quote-document-dates strong { font-size:11px; }
.quote-doc-head { display:flex; align-items:flex-start; justify-content:space-between; gap:24px; padding-bottom:18px; border-bottom:1px solid var(--line); margin-bottom:24px; }
.quote-doc-head .doc-logo { width:230px; height:50px; }
.quote-title-block { min-width:210px; text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:6px; }
.quote-title-block h2 { margin:0; color:var(--navy); font-size:22px; line-height:1; letter-spacing:.5px; }
.quote-title-meta { display:flex; flex-direction:column; align-items:flex-end; gap:2px; color:var(--muted); }
.quote-title-meta strong { color:var(--navy); font-size:11px; }
.quote-title-meta span { font-size:9px; line-height:1.35; }
.quote-party-grid { display:grid; grid-template-columns:1fr 1fr; gap:42px; margin-bottom:26px; }
.quote-party-grid > div { min-width:0; }
.quote-party-grid .eyebrow { display:block; margin-bottom:7px; }
.quote-party-grid h3 { margin:0 0 7px; font-size:15px; line-height:1.2; }
.quote-party-grid p { margin:0; color:var(--muted); font-size:11px; line-height:1.5; white-space:pre-line; }
.quote-doc-copy { margin-top:25px; border-top:1px solid var(--line); padding-top:14px; color:var(--muted); font-size:11px; line-height:1.5; }
.quote-doc-copy strong { color:var(--ink); }.quote-doc-copy p { margin:5px 0 0; }
.rich-editor-stack { display:flex; flex-direction:column; gap:16px; }
.rich-field > label { display:block; font-size:13px; font-weight:600; margin-bottom:8px; }
.rich-editor { border:1px solid var(--line); border-radius:12px; overflow:hidden; background:white; }
.rich-toolbar { display:flex; gap:4px; padding:7px; border-bottom:1px solid var(--line); background:#f8fafd; }
.rich-toolbar button { border:1px solid transparent; background:white; color:#43516a; min-width:32px; height:30px; border-radius:7px; padding:0 8px; font-size:11px; }
.rich-toolbar button:hover { border-color:#b9d7fa; color:var(--blue); background:var(--blue-soft); }
.rich-content { min-height:105px; padding:12px 14px; outline:none; color:var(--ink); line-height:1.5; font-size:13px; }
.rich-content:empty:before { content:attr(data-placeholder); color:#98a2b5; pointer-events:none; }
.rich-content ul,.rich-content ol,.rich-preview ul,.rich-preview ol { padding-left:20px; margin:6px 0; }
.rich-content p,.rich-preview p { margin:5px 0; }
.rich-preview { margin-top:6px; color:var(--muted); }
.settings-page-head { align-items:center; }
.settings-tabs { display:flex; gap:8px; padding:6px; margin-bottom:20px; width:fit-content; max-width:100%; border:1px solid var(--line); border-radius:14px; background:#edf3fa; }
.settings-tabs button { min-width:180px; border:0; border-radius:10px; padding:12px 18px; background:transparent; color:var(--muted); font-size:12px; font-weight:700; }
.settings-tabs button.active { background:white; color:var(--blue); box-shadow:0 4px 14px rgba(8,43,92,.1); }
.settings-tab-panel { display:none; }
.settings-tab-panel.active { display:block; }
.settings-panel { max-width:1050px; }
.settings-panel-head { display:flex; justify-content:space-between; gap:20px; padding-bottom:18px; margin-bottom:20px; border-bottom:1px solid var(--line); }
.settings-panel-head h3 { margin:5px 0 6px; font-size:20px; }
.settings-panel-head p,.document-default-intro p { margin:0; color:var(--muted); font-size:12px; line-height:1.55; }
.settings-company-grid,.document-default-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px 20px; }
.document-default-grid { padding-bottom:22px; }
.document-settings-tabs { display:flex; gap:6px; padding:5px; margin:3px 0 20px; border-radius:12px; background:#f1f5fa; }
.document-settings-tabs button { flex:1; border:0; border-radius:9px; padding:11px 14px; background:transparent; color:var(--muted); font-weight:700; }
.document-settings-tabs button.active { background:white; color:var(--blue); box-shadow:0 3px 12px rgba(8,43,92,.08); }
.document-settings-content { display:none; padding:20px; border:1px solid var(--line); border-radius:14px; background:#fbfcff; }
.document-settings-content.active { display:block; }
.document-default-intro { margin-bottom:18px; }
.document-default-intro h4 { margin:0 0 5px; color:var(--navy); font-size:15px; }
.document-settings-content .rich-editor { background:white; }
.document-settings-content .rich-content { min-height:120px; }
.demo-data-zone { margin-top:22px; padding:20px; border:1px solid #b9d7fa; background:#f5faff; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.demo-data-zone h3 { margin:0 0 7px; color:var(--navy); font-size:16px; }
.demo-data-zone p { margin:0; color:#526b89; font-size:12px; line-height:1.55; max-width:760px; }
.load-demo-data { flex:0 0 auto; border:0; border-radius:10px; padding:11px 16px; background:var(--blue); color:white; font-weight:700; }
.load-demo-data:hover { background:#176ac0; }
.danger-zone { margin-top:22px; padding:20px; border:1px solid #f3b8be; background:#fff7f8; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.danger-zone h3 { margin:0 0 7px; color:#b72f3c; font-size:16px; }
.danger-zone p { margin:0; color:#7d5960; font-size:12px; line-height:1.55; max-width:760px; }
.delete-all-data { flex:0 0 auto; border:0; border-radius:10px; padding:11px 16px; background:var(--red); color:white; font-weight:700; }
.delete-all-data:hover { background:#c93441; }
.toast { position:fixed; right:24px; bottom:24px; background:#10233f; color:white; padding:12px 18px; border-radius:11px; transform:translateY(90px); opacity:0; transition:.3s; z-index:200; box-shadow:var(--shadow); font-size:13px; }
.toast.show { transform:translateY(0); opacity:1; }
.mobile-menu { display:none; }
@media(max-width:1200px){ .cards{grid-template-columns:repeat(3,1fr)} .prospect-cards{grid-template-columns:repeat(4,1fr)} .quick-actions{grid-template-columns:repeat(3,1fr)} .clients-toolbar{grid-template-columns:repeat(3,minmax(180px,1fr))}.prospects-toolbar{grid-template-columns:repeat(4,minmax(150px,1fr))}.quotations-toolbar{grid-template-columns:repeat(3,minmax(160px,1fr))} }
@media(max-width:850px){
  .login-card{grid-template-columns:1fr}.login-art{display:none}.login-form{padding:45px 30px}
  .simple-login-form{padding:40px 28px 30px}
  .app-shell{display:block}.sidebar{width:min(300px,86vw);transform:translateX(-105%);transition:transform .25s ease;z-index:120;box-shadow:18px 0 45px rgba(3,20,45,.28)}.sidebar.open{transform:translateX(0)}.sidebar-mobile-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-mobile-head .side-logo{margin:0;min-width:0}.sidebar-close{display:grid;place-items:center;flex:0 0 38px;width:38px;height:38px;border:1px solid rgba(255,255,255,.22);border-radius:11px;background:rgba(255,255,255,.1);color:white;font-size:24px;line-height:1}.sidebar-close:hover{background:rgba(255,255,255,.18)}.sidebar-scrim{display:block;position:fixed;inset:0;border:0;background:rgba(3,20,45,.55);opacity:0;visibility:hidden;pointer-events:none;transition:.25s;z-index:110}.sidebar-scrim.open{opacity:1;visibility:visible;pointer-events:auto}
  .main{grid-column:auto}.mobile-menu{display:block}.topbar{padding:0 16px}.content{padding:20px 16px}
  .search{display:none}.cards{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2,1fr)}
  .form-grid,.settings-company-grid,.document-default-grid,.profile-columns{grid-template-columns:1fr}.span-2{grid-column:auto}.pipeline{grid-template-columns:repeat(3,1fr)}.prospect-cards{grid-template-columns:repeat(2,1fr)}.contact-card-grid,.prospect-activity-entry{grid-template-columns:1fr}.contact-section-head,.prospect-activity-section-head{align-items:flex-start;flex-direction:column}
  .toolbar,.clients-toolbar,.prospects-toolbar,.quotations-toolbar,.payments-toolbar{display:block;overflow:visible}
  .toolbar > input.control{display:block;width:100%;min-width:0;margin:0}
  .responsive-filter-strip{display:flex;align-items:stretch;gap:10px;width:100%;margin-top:10px;padding:1px 2px 8px;overflow-x:auto;overflow-y:hidden;overscroll-behavior-inline:contain;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
  .responsive-filter-strip > .control,.responsive-filter-strip > select,.responsive-filter-strip > .universal-select,.responsive-filter-strip > .reset-filters{flex:0 0 210px;width:210px;min-width:210px;scroll-snap-align:start}
  .responsive-filter-strip > .reset-filters{flex-basis:120px;width:120px;min-width:120px}
  .responsive-filter-strip .universal-select-input{width:100%}
  .quote-builder-modal{height:96vh}.quote-builder-layout{grid-template-columns:1fr}.quote-editor{border-right:0}.quote-live-pane{display:none}.quote-line-service{grid-template-columns:1fr}.quote-line-numbers{grid-template-columns:1fr 1fr}
  .settings-tabs{width:100%}.settings-tabs button{min-width:0;flex:1}.danger-zone,.demo-data-zone{align-items:flex-start;flex-direction:column}.delete-all-data,.load-demo-data{width:100%}
  .quotation-row-actions{min-width:250px}.row-actions .convert-invoice-button{padding:7px 9px}
  .prospect-row-actions{min-width:350px}.row-actions .convert-client-button,.row-actions .mark-lost-button{padding:7px 9px}
  .payments-toolbar{grid-template-columns:1fr 1fr}.payment-balance-summary,.receipt-details{grid-template-columns:1fr}
}
@media(max-width:520px){.cards,.prospect-cards{grid-template-columns:1fr}.quick-actions{grid-template-columns:1fr}.top-actions .primary{display:none}.detail-grid,.detail-grid.compact{grid-template-columns:1fr}.doc-meta{grid-template-columns:1fr}.pipeline{grid-template-columns:repeat(2,1fr)}.responsive-filter-strip > .control,.responsive-filter-strip > select,.responsive-filter-strip > .universal-select{flex-basis:185px;width:185px;min-width:185px}}
.hosting-type-row { display:grid; grid-template-columns:1fr 1fr auto; gap:10px; align-items:center; }
.hosting-client-filter { margin-bottom:10px; }
.hosting-client-list { border:1px solid var(--line); border-radius:14px; max-height:220px; overflow:auto; padding:8px; background:#fff; display:grid; gap:6px; }
.hosting-client-option { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:10px; cursor:pointer; color:var(--navy); font-weight:600; }
.hosting-client-option:hover { background:#f4f8fd; }
.hosting-client-option input { width:18px; height:18px; accent-color:var(--blue); }
@media (max-width:700px){ .hosting-type-row { grid-template-columns:1fr; } }
.hosting-client-option.hidden { display:none !important; }
.hosting-client-empty { display:none; padding:10px 12px; color:var(--muted); font-weight:600; }
.hosting-client-empty.show { display:block; }
.domains-toolbar,.web-hostings-toolbar { display:grid; grid-template-columns:minmax(260px,1fr) minmax(180px,300px) auto; gap:10px; align-items:center; }
.domains-toolbar > .control,.domains-toolbar > .universal-select,.web-hostings-toolbar > .control,.web-hostings-toolbar > .universal-select { width:100%; min-width:0; }
.domains-toolbar > input.control,.web-hostings-toolbar > input.control { width:100%; min-width:0; }
.domains-toolbar .reset-filters,.web-hostings-toolbar .reset-filters { white-space:nowrap; }
@media(max-width:850px){ .domains-toolbar,.web-hostings-toolbar{display:block;overflow:visible} }
.notification-list { max-height:420px; overflow:auto; }
.alert-list { max-height:520px; overflow:auto; }
.reminder-bulk-panel { margin-bottom:14px; }
.reminder-bulk-bar { display:flex; gap:12px; align-items:center; justify-content:space-between; padding:14px 16px; flex-wrap:wrap; }
.reminder-check-all { display:flex; align-items:center; gap:8px; font-weight:700; color:var(--navy); }
.reminder-check-all input,.reminder-select { width:18px; height:18px; accent-color:var(--blue); }
.reminder-bulk-actions { display:flex; gap:8px; flex-wrap:wrap; }
.reminder-bulk-actions button:disabled { opacity:.45; cursor:not-allowed; }
.select-col { width:44px; text-align:center; }
@media(max-width:700px){ .reminder-bulk-bar { align-items:flex-start; flex-direction:column; } .reminder-bulk-actions { width:100%; } .reminder-bulk-actions button { flex:1 1 160px; } }
@media(max-width:850px){
  button,.primary,.ghost,.danger-btn,.reset-filters,.record-payment-button,.client-record-view,.prospect-action-button,.delete-permanent,.load-demo-data,.delete-all-data,.add-contact-card,.remove-contact-card,.remove-service-card,.selected-service-tag,.discount-picker-button,.universal-select-option,.picker-option,.notification-item,.dashboard-row-button,.reminder-bulk-actions button {
    white-space:nowrap;
  }
  .section-head { align-items:center; }
  .section-head > .primary,.section-head > .ghost,.section-head > button { flex:0 0 auto; min-width:max-content; }
  .primary { padding:10px 14px; font-size:13px; line-height:1.15; }
  .ghost,.danger-btn,.reset-filters { font-size:11px; line-height:1.15; padding:9px 11px; }
  .modal-foot button,.reminder-bulk-actions button { min-width:max-content; }
}
@media(max-width:520px){
  .primary { padding:9px 12px; font-size:12px; }
  .ghost,.danger-btn,.reset-filters { font-size:10.5px; padding:8px 10px; }
  .section-head { gap:10px; }
  .section-head .page-summary { font-size:14px; }
  .section-head > .primary { max-width:48vw; }
}

/* Mobile-safe top-right dropdowns */
@media(max-width:850px){
  .top-dropdown {
    position:fixed;
    top:84px;
    left:14px;
    right:14px;
    width:auto;
    max-width:calc(100vw - 28px);
    box-sizing:border-box;
    z-index:160;
  }
  .notification-tray,
  .profile-menu {
    width:auto;
    max-width:calc(100vw - 28px);
  }
  .notification-list {
    max-height:min(420px,58vh);
  }
}
@media(max-width:520px){
  .top-dropdown {
    top:80px;
    left:10px;
    right:10px;
    max-width:calc(100vw - 20px);
  }
  .notification-tray,
  .profile-menu {
    max-width:calc(100vw - 20px);
  }
}

/* Keep mobile filter menus above scrollable filter strips and tables */
.universal-select-menu.mobile-floating {
  box-sizing:border-box;
  overscroll-behavior:contain;
}

/* Prospect/client profile cleanup and responsive overflow fixes */
.prospect-preview-history { margin-top:0; }
.prospect-preview-history .conversation-history-panel { background:#fff; }
.prospect-preview-history .empty { padding:34px 18px; }

@media(max-width:850px){
  html,body { max-width:100%; overflow-x:hidden; }
  .app,.main,.page,.content { max-width:100vw; overflow-x:hidden; }
  .table-wrap { max-width:100%; overflow-x:auto; overscroll-behavior-x:contain; }
  .table-wrap table { width:max-content; min-width:100%; }
  table:has(.prospect-row-actions) { min-width:980px; }
  .prospect-row-actions { display:flex; flex-wrap:nowrap; gap:7px; min-width:max-content; max-width:max-content; }
  .prospect-row-actions .convert-client-button,.prospect-row-actions .mark-lost-button { flex:0 0 auto; white-space:nowrap; }
  .prospect-actions { flex-wrap:nowrap; overflow-x:auto; overflow-y:hidden; -webkit-overflow-scrolling:touch; gap:9px; padding:14px 20px; scrollbar-width:thin; }
  .prospect-actions .close { position:sticky; right:0; flex:0 0 38px; margin-left:6px; box-shadow:-10px 0 12px rgba(255,255,255,.92); }
  .prospect-action-button { flex:0 0 auto; width:auto; min-width:168px; }
  .profile-columns { grid-template-columns:1fr; }
  .history-inner-tabs { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .history-inner-tabs button { flex:0 0 auto; min-width:190px; }
  .conversation-history-item { flex-direction:column; gap:6px; }
  .conversation-history-item time { white-space:normal; }
  .modal.wide { width:calc(100vw - 24px); max-width:calc(100vw - 24px); }
  .modal-body,.profile-columns,.detail-grid { padding-left:16px; padding-right:16px; }
  .prospect-form-shell { width:100%; max-width:100%; overflow:hidden; }
  .prospect-form-tabs { overflow-x:auto; flex-wrap:nowrap; -webkit-overflow-scrolling:touch; }
  .prospect-form-tabs button { flex:0 0 auto; min-width:145px; }
  .prospect-activity-entry { grid-template-columns:1fr; }
  .saved-activity-row { flex-direction:column; gap:5px; }
}

@media(max-width:520px){
  .modal-backdrop { padding:8px; align-items:start; overflow:hidden; }
  .modal { max-height:calc(100vh - 16px); border-radius:18px; }
  .detail-hero { padding:22px 24px; align-items:flex-start; gap:12px; }
  .detail-hero h2 { font-size:24px; line-height:1.25; }
  .prospect-actions { padding:14px 20px; }
  .prospect-action-button { min-width:188px; min-height:48px; }
  .detail-tabs { padding-left:16px; padding-right:16px; }
  .conversation-history-head { padding:15px; }
  .history-inner-tabs { padding:8px; }
  .history-inner-tabs button { min-width:165px; font-size:11px; }
  .conversation-history-item { padding:14px 15px; }
  .prospect-form-tabs { margin-left:0; margin-right:0; }
  .prospect-form-tabs button { min-width:132px; }
  .prospect-activity-section { padding:14px; }
}
/* Mobile dropdown arrow alignment normalization */
@media(max-width:850px){
  .responsive-filter-strip .universal-select { position:relative; overflow:hidden; border-radius:12px; }
  .responsive-filter-strip .universal-select-input {
    height:44px;
    min-height:44px;
    padding:0 44px 0 12px!important;
    font-size:12px;
    line-height:44px;
    text-overflow:ellipsis;
  }
  .responsive-filter-strip .universal-select-toggle {
    right:4px;
    top:4px;
    bottom:4px;
    width:36px;
    height:auto;
    min-height:0;
    transform:none;
    border-radius:10px;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .responsive-filter-strip .universal-select-toggle span {
    width:8px;
    height:8px;
    border-right:2px solid var(--navy);
    border-bottom:2px solid var(--navy);
    transform:rotate(45deg);
    margin-top:-4px;
  }
  .responsive-filter-strip .universal-select.open .universal-select-toggle span {
    transform:rotate(225deg);
    margin-top:4px;
  }
}
@media(max-width:520px){
  .responsive-filter-strip .universal-select-input { padding-right:42px!important; }
  .responsive-filter-strip .universal-select-toggle { width:34px; }
}
/* Clean page header title alignment */
.topbar .page-title-block { display:flex; align-items:center; min-height:44px; }
.topbar .page-title-block h1 { line-height:1.1; }
@media(max-width:850px){
  .topbar { min-height:72px; height:auto; padding-top:12px; padding-bottom:12px; }
  .topbar .page-title-block { min-height:38px; }
}
@media(max-width:520px){
  .topbar h1 { font-size:21px; }
}
/* Dropdown option text and mobile menu padding/alignment fix */
.universal-select-menu {
  min-width:max(100%, 220px);
  width:max-content;
  max-width:min(360px, calc(100vw - 28px));
}
.universal-select-option {
  white-space:nowrap;
  line-height:1.2;
  padding:12px 14px;
}
@media(max-width:850px){
  .universal-select-menu.mobile-floating {
    min-width:min(260px, calc(100vw - 24px));
    width:min(300px, calc(100vw - 24px))!important;
    max-width:calc(100vw - 24px)!important;
    padding:8px;
    border-radius:14px;
  }
  .universal-select-menu.mobile-floating .universal-select-option {
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    min-height:42px;
    display:flex;
    align-items:center;
    padding:11px 14px;
    font-size:13px;
  }
  .responsive-filter-strip .universal-select-menu:not(.mobile-floating) {
    min-width:100%;
    width:100%;
  }
}
@media(max-width:520px){
  .universal-select-menu.mobile-floating {
    left:12px!important;
    right:auto!important;
    width:calc(100vw - 24px)!important;
    max-width:calc(100vw - 24px)!important;
  }
  .universal-select-menu.mobile-floating .universal-select-option {
    font-size:12.5px;
    padding:11px 13px;
  }
}