:root{
  /* ── Westmar palette: light, airy, editorial ────────────────────── */
  --paper:#F6F2EA;          /* warm canvas */
  --paper-2:#EFE9DD;        /* deeper paper tone for rails */
  --card:#FFFFFF;
  --ink:#0F1E2C;            /* deep navy ink */
  --ink-2:#2D3F50;          /* secondary ink */
  --ink-3:#67768A;          /* meta / placeholder */
  --ink-4:#A6B0BB;          /* faintest */
  --rule:#E4DDCD;           /* hairline on paper */
  --rule-2:#EEE7D6;         /* even fainter */
  --rule-card:#ECEFF2;      /* hairline on white */
  --dock:#3D6A86;           /* muted dock blue */
  --dock-soft:#E6EDF2;      /* dock tint */
  --brass:#A8783A;          /* warm brass accent */
  --brass-soft:#F2E8D6;     /* brass tint */
  --sea:#4F8474;            /* understated sage/sea */
  --sea-soft:#E4ECE7;
  --rose:#9C4A48;
  --rose-soft:#F4E4E2;
  --amber:#9C7A2B;
  --amber-soft:#F4ECD7;

  --sans:"Barlow", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --display:"Barlow", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --r:6px;
  --r-lg:10px;
  --sh-card:0 1px 0 rgba(15,30,44,.03), 0 0 0 1px var(--rule-card);
  --sh-hover:0 1px 0 rgba(15,30,44,.04), 0 4px 18px -8px rgba(15,30,44,.12), 0 0 0 1px var(--rule-card);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:14px;
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--brass-soft);color:var(--ink)}

#app{display:flex;height:100vh;overflow:hidden}

/* ── Sidebar ────────────────────────────────────────────────────── */
#sidebar{
  width:236px;min-width:236px;
  background:var(--paper);
  display:flex;flex-direction:column;
  border-right:1px solid var(--rule);
}
.brand{padding:32px 24px 26px;border-bottom:1px solid var(--rule);display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.brand-logo{width:172px;height:auto;display:block;margin-left:-2px}
.brand-sub{font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-3);font-weight:500;border-top:1px solid var(--rule);padding-top:14px;width:100%}

.nav{flex:1;padding:22px 0;display:flex;flex-direction:column;gap:1px}
.nav-label{
  font-size:9px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-4);padding:18px 26px 8px;font-weight:500;
}
.nav-btn{
  position:relative;display:flex;align-items:center;gap:12px;
  padding:10px 26px;color:var(--ink-2);cursor:pointer;
  font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  transition:color .12s, background .12s;user-select:none;
}
.nav-btn:hover{color:var(--ink);background:rgba(15,30,44,.025)}
.nav-btn.on{color:var(--ink);font-weight:600;background:rgba(15,30,44,.04)}
.nav-btn.on::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:18px;background:var(--brass);
}
.nav-btn .dot{
  width:5px;height:5px;border-radius:50%;background:var(--ink-4);
  flex-shrink:0;transition:background .12s;
}
.nav-btn:hover .dot{background:var(--ink-2)}
.nav-btn.on .dot{background:var(--brass)}

.sidebar-foot{
  padding:18px 26px 22px;border-top:1px solid var(--rule);
  font-size:10px;color:var(--ink-3);letter-spacing:.05em;line-height:1.5;
}
.sidebar-foot strong{display:block;font-weight:500;color:var(--ink-2);letter-spacing:.18em;text-transform:uppercase;font-size:9px;margin-bottom:4px}

/* ── Main / Topbar ──────────────────────────────────────────────── */
#main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--paper)}
.topbar{
  padding:0 36px;height:68px;display:flex;align-items:flex-end;justify-content:space-between;
  border-bottom:1px solid var(--rule);flex-shrink:0;padding-bottom:14px;padding-top:14px;
  background:var(--paper);
}
.topbar-l{display:flex;flex-direction:column;gap:6px;justify-content:flex-end}
.crumb{font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.page-title{font-family:var(--display);font-size:24px;color:var(--ink);letter-spacing:.16em;text-transform:uppercase;font-weight:300;line-height:1}
.topbar-r{display:flex;gap:10px;align-items:center}
.save-indicator{
  font-size:10.5px;color:var(--ink-3);letter-spacing:.08em;
  display:flex;align-items:center;gap:6px;font-variant-numeric:tabular-nums;
  padding-right:6px;
}
.save-indicator::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--ink-4);display:inline-block}
.save-indicator.saving::before{background:var(--amber);animation:pulse 1s ease-in-out infinite}
.save-indicator.saved::before{background:var(--sea)}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

.content{flex:1;overflow:hidden;padding:0;display:flex;flex-direction:column}

/* Hamburger + drawer backdrop — shown only on narrow screens (see @media). */
.nav-toggle{
  display:none;background:transparent;border:1px solid var(--rule-card);border-radius:var(--r);
  width:38px;height:38px;flex-shrink:0;align-items:center;justify-content:center;
  color:var(--ink-2);cursor:pointer;
}
.nav-toggle:hover{color:var(--ink);background:var(--paper-2)}
#sidebar-backdrop{display:none}

/* ── Buttons ────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px;border-radius:var(--r);
  font-family:var(--sans);font-size:12.5px;font-weight:500;letter-spacing:.005em;
  cursor:pointer;border:1px solid transparent;transition:all .14s;
  user-select:none;white-space:nowrap;line-height:1;
}
.btn-primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-primary:hover{background:#000;border-color:#000}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-soft{background:var(--card);color:var(--ink);border-color:var(--rule-card)}
.btn-soft:hover{border-color:var(--ink-3);background:var(--card)}
.btn-cancel{background:transparent;color:var(--ink-2);border-color:var(--rule-card)}
.btn-cancel:hover{background:var(--paper-2);color:var(--ink)}
.btn-danger{background:var(--rose);color:#fff;border-color:var(--rose)}
.btn-danger:hover{filter:brightness(.92)}
.btn-sm{padding:5px 9px;font-size:11.5px;gap:4px}
.btn-icon{padding:5px 8px;background:transparent;color:var(--ink-3);border-color:transparent}
.btn-icon:hover{color:var(--ink);background:var(--paper-2)}
.btn .plus{font-size:14px;line-height:1;font-weight:400;margin-top:-1px}

/* ── Views & sections ───────────────────────────────────────────── */
.view{display:none}
.view.on{display:flex;flex-direction:column;flex:1;min-height:0;padding:32px 36px}
#view-dash.on{overflow-y:auto;padding-bottom:60px}
#view-clients.on,#view-surveys.on,#view-yachts.on,#view-vessels.on{overflow:hidden;padding-bottom:28px}
#view-clients .tcard,#view-surveys .tcard,#view-yachts .tcard,#view-vessels .tcard{display:flex;flex-direction:column;flex:1;min-height:0;margin-bottom:0}
#view-clients .table-wrap,#view-surveys .table-wrap,#view-yachts .table-wrap,#view-vessels .table-wrap{flex:1;overflow:auto;min-height:0}
#view-clients .tbar,#view-surveys .tbar,#view-yachts .tbar,#view-vessels .tbar,#view-clients .tfoot-bar,#view-surveys .tfoot-bar,#view-yachts .tfoot-bar,#view-vessels .tfoot-bar,#view-clients .filter-row,#view-surveys .filter-row,#view-yachts .filter-row,#view-vessels .filter-row{flex-shrink:0}

/* ── Cert / due-date pills ──────────────────────────────────────── */
.cert{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 9px 3px 7px;border-radius:99px;
  font-size:11px;font-weight:500;white-space:nowrap;letter-spacing:.02em;
  border:1px solid transparent;font-variant-numeric:tabular-nums;
}
.cert::before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0}
.cert.ok{background:var(--sea-soft);color:#2F5A4B;border-color:#D7E2DB}
.cert.ok::before{background:var(--sea)}
.cert.soon{background:var(--amber-soft);color:#6B5318;border-color:#E8DDB8}
.cert.soon::before{background:var(--amber)}
.cert.over{background:var(--rose-soft);color:#6B2C2A;border-color:#E8D0CE}
.cert.over::before{background:var(--rose)}
.cert.none{background:var(--paper-2);color:var(--ink-4);border-color:var(--rule)}
.cert.none::before{background:var(--ink-4)}

/* Compact strip of multiple cert pills in a table cell */
.cert-strip{display:flex;gap:4px;flex-wrap:wrap;max-width:280px}
.cert-mini{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;font-size:10px;font-weight:600;
  letter-spacing:0;cursor:default;border:1px solid transparent;
}
.cert-mini.ok{background:var(--sea-soft);color:#2F5A4B;border-color:#D7E2DB}
.cert-mini.soon{background:var(--amber-soft);color:#6B5318;border-color:#E8DDB8}
.cert-mini.over{background:var(--rose-soft);color:#6B2C2A;border-color:#E8D0CE}
.cert-mini.none{background:var(--paper-2);color:var(--ink-4);border-color:var(--rule)}

/* Cert grid inside modal */
.cert-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.cert-field{
  display:flex;flex-direction:column;gap:5px;padding:12px 14px;
  border:1px solid var(--rule-card);border-radius:var(--r);background:var(--card);
  position:relative;transition:border-color .14s;
}
.cert-field:focus-within{border-color:var(--ink)}
.cert-field-head{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.cert-field label{
  font-size:10px;font-weight:500;color:var(--ink-2);
  text-transform:uppercase;letter-spacing:.14em;
}
.cert-field input{
  border:none;background:transparent;font-family:var(--sans);
  font-size:13.5px;color:var(--ink);outline:none;padding:0;
  font-variant-numeric:tabular-nums;
}
.cert-field input::-webkit-calendar-picker-indicator{opacity:.4;cursor:pointer}
.cert-field input::-webkit-calendar-picker-indicator:hover{opacity:.8}

/* ── Alerts panel (dashboard) ───────────────────────────────────── */
.alerts-panel{
  background:var(--card);border-radius:var(--r-lg);box-shadow:var(--sh-card);
  margin-bottom:36px;overflow:hidden;
}
.alerts-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding:18px 20px 14px;border-bottom:1px solid var(--rule-card);
}
.alerts-head-l{display:flex;align-items:baseline;gap:14px}
.alerts-title{font-family:var(--display);font-size:15px;color:var(--ink);letter-spacing:.16em;text-transform:uppercase;font-weight:400}
.alerts-count{
  font-size:11px;font-weight:500;color:var(--ink-3);letter-spacing:.04em;
  font-variant-numeric:tabular-nums;
}
.alerts-body{padding:0}
.alert-row{
  display:flex;align-items:center;gap:14px;padding:13px 20px;
  border-bottom:1px solid var(--rule-card);transition:background .12s;
}
.alert-row:last-child{border-bottom:none}
.alert-row:hover{background:var(--paper)}
.alert-icon{flex-shrink:0;width:6px;height:34px;border-radius:2px}
.alert-icon.over{background:var(--rose)}
.alert-icon.soon{background:var(--amber)}
.alert-main{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.alert-title{font-size:13px;color:var(--ink);font-weight:500;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.alert-title em{font-style:italic;font-weight:500;color:var(--ink)}
.alert-sub{font-size:11.5px;color:var(--ink-3);letter-spacing:.02em}
.alert-due{
  font-family:var(--mono);font-size:11.5px;color:var(--ink-2);
  font-variant-numeric:tabular-nums;letter-spacing:0;text-align:right;flex-shrink:0;
}
.alert-due strong{display:block;color:var(--ink);font-weight:600;font-size:12.5px}
.alert-due.over strong{color:var(--rose)}
.alert-due.soon strong{color:var(--amber)}
.alert-empty{padding:36px 20px;text-align:center;color:var(--ink-3);font-size:13px;letter-spacing:.04em}

/* ── Yacht status badge ─────────────────────────────────────────── */
.b-active{background:var(--sea-soft);color:#2F5A4B;border-color:#D7E2DB}
.b-active::before{background:var(--sea)}
.b-paused{background:var(--amber-soft);color:#6B5318;border-color:#E8DDB8}
.b-paused::before{background:var(--amber)}
.b-off{background:var(--paper-2);color:var(--ink-3);border-color:var(--rule)}
.b-off::before{background:var(--ink-4)}
.badge-select.b-active{background:var(--sea-soft);color:#2F5A4B;border-color:#D7E2DB}
.badge-select.b-active::before{background:var(--sea)}
.badge-select.b-paused{background:var(--amber-soft);color:#6B5318;border-color:#E8DDB8}
.badge-select.b-paused::before{background:var(--amber)}
.badge-select.b-off{background:var(--paper-2);color:var(--ink-3);border-color:var(--rule)}
.badge-select.b-off::before{background:var(--ink-4)}

/* ── Modal tabs ─────────────────────────────────────────────────── */
.modal.wide{max-width:880px}
.mtabs{
  display:flex;gap:0;padding:0 32px;border-bottom:1px solid var(--rule-card);
  background:var(--card);position:sticky;top:0;z-index:5;
}
.mtab{
  padding:13px 18px 12px;background:transparent;border:none;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3);cursor:pointer;
  border-bottom:2px solid transparent;transition:all .14s;
  display:inline-flex;align-items:center;gap:7px;
}
.mtab:hover{color:var(--ink-2)}
.mtab.on{color:var(--ink);border-bottom-color:var(--brass);font-weight:600}
.mtab .ct{
  font-size:10px;font-weight:500;color:var(--ink-3);
  padding:1px 6px;border-radius:99px;background:var(--paper-2);letter-spacing:0;
  font-variant-numeric:tabular-nums;
}
.mtab.on .ct{background:var(--brass-soft);color:var(--brass)}
.mtab .alert-dot{
  width:6px;height:6px;border-radius:50%;background:var(--rose);
  flex-shrink:0;display:inline-block;
}
.mpanel{display:none}
.mpanel.on{display:block}

/* ── Sub-section list rows (crew, maintenance, certs) ───────────── */
.subhead{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--rule-card);
}
.subhead-title{font-size:11px;font-weight:500;color:var(--ink-2);letter-spacing:.18em;text-transform:uppercase}
.subhead-meta{font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.04em}

.list-rows{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.list-row{
  background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r);
  padding:12px 14px;display:flex;align-items:center;gap:14px;
  transition:border-color .14s,box-shadow .14s;
}
.list-row:hover{border-color:var(--ink-4)}
.list-row-main{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}
.list-row-title{font-size:13.5px;color:var(--ink);font-weight:500;line-height:1.3;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.list-row-sub{font-size:11.5px;color:var(--ink-3);line-height:1.4;letter-spacing:.02em}
.list-row-aside{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:3px;text-align:right}
.list-row-acts{display:flex;gap:2px;flex-shrink:0}
.list-row-pill{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  font-variant-numeric:tabular-nums;letter-spacing:0;
}
.list-empty{
  padding:32px 20px;text-align:center;color:var(--ink-3);font-size:12.5px;
  border:1px dashed var(--rule);border-radius:var(--r);background:var(--paper);letter-spacing:.04em;
}

/* Inline mini-form */
.mini-form{
  background:var(--paper);border:1px solid var(--rule);border-radius:var(--r);
  padding:16px;margin-bottom:14px;
}
.mini-form-grid{display:grid;gap:10px;margin-bottom:10px}
.mini-form-actions{display:flex;gap:8px;justify-content:flex-end}
.mini-form .field input,.mini-form .field select,.mini-form .field textarea{
  background:var(--card);
}

/* ── Cert row layout (in modal) ──────────────────────────────────── */
.cert-row{
  display:grid;grid-template-columns:1fr 130px 92px auto auto auto;gap:12px;
  align-items:center;padding:10px 12px;background:var(--card);
  border:1px solid var(--rule-card);border-radius:var(--r);transition:border-color .14s;
}
.cert-row:hover{border-color:var(--ink-4)}
.cert-row.builtin .cert-label-input{cursor:default;color:var(--ink)}
.cert-row .cert-label-input{
  border:none;background:transparent;font-family:var(--sans);font-size:13px;font-weight:500;
  color:var(--ink);outline:none;padding:0;width:100%;
}
.cert-row .cert-date-input{
  border:1px solid var(--rule-card);background:var(--card);border-radius:var(--r);
  padding:5px 8px;font-family:var(--sans);font-size:12.5px;color:var(--ink);
  outline:none;font-variant-numeric:tabular-nums;width:100%;
}
.cert-row .cert-int-input{
  border:1px solid var(--rule-card);background:var(--card);border-radius:var(--r);
  padding:5px 8px;font-family:var(--sans);font-size:12.5px;color:var(--ink);outline:none;
  font-variant-numeric:tabular-nums;width:100%;
}
.cert-row .cert-int-wrap{display:flex;align-items:center;gap:5px}
.cert-row .cert-int-wrap .u{font-size:10px;color:var(--ink-3);letter-spacing:.06em}
.cert-row .cert-mark-done{
  background:transparent;border:1px solid var(--rule-card);color:var(--ink-2);
  border-radius:var(--r);padding:5px 9px;font-family:var(--sans);font-size:10.5px;
  font-weight:500;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;
  white-space:nowrap;transition:all .14s;
}
.cert-row .cert-mark-done:hover{background:var(--sea);color:#fff;border-color:var(--sea)}
.cert-row .cert-remove{
  background:transparent;border:none;color:var(--ink-4);cursor:pointer;padding:4px;
  border-radius:var(--r);transition:color .14s;font-size:14px;line-height:1;
}
.cert-row .cert-remove:hover{color:var(--rose)}
.cert-row .cert-reset{
  background:transparent;border:1px solid var(--rule-card);color:var(--ink-3);
  border-radius:var(--r);padding:5px 9px;font-family:var(--sans);font-size:10.5px;
  font-weight:500;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;
  white-space:nowrap;transition:all .14s;
}
.cert-row .cert-reset:hover{background:var(--paper-2);color:var(--ink-2);border-color:var(--ink-4)}
.cert-row .cert-reset:disabled{opacity:.4;cursor:not-allowed}

/* ── Row container wrapping a list-row / cert-row + its docs strip ── */
.row-with-docs{
  display:flex;flex-direction:column;
  background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r);
  transition:border-color .14s;overflow:hidden;
}
.row-with-docs:hover{border-color:var(--ink-4)}
.row-with-docs > .cert-row,
.row-with-docs > .list-row{
  border:none;border-radius:0;background:transparent;
}
.row-with-docs > .cert-row:hover,
.row-with-docs > .list-row:hover{border-color:transparent}
.row-with-docs > .docs-strip{
  margin:0;padding:8px 12px;
  background:var(--paper);border-top:1px solid var(--rule-card);
}

/* ── Document chips / attach ─────────────────────────────────────── */
.docs-strip{
  display:flex;flex-wrap:wrap;gap:6px;align-items:center;
}
.doc-chip{
  display:inline-flex;align-items:stretch;
  background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r);
  overflow:hidden;font-size:11px;
}
.doc-chip-ico{
  background:var(--paper-2);color:var(--ink-2);
  padding:0 7px;display:flex;align-items:center;
  font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.06em;
}
.doc-chip-name{
  background:transparent;border:none;color:var(--ink);font-size:11px;
  padding:4px 8px;cursor:pointer;font-family:var(--sans);max-width:200px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.doc-chip-name:hover{color:var(--brass);text-decoration:underline}
.doc-chip-size{
  font-size:10px;color:var(--ink-4);padding:4px 4px 4px 0;font-variant-numeric:tabular-nums;
}
.doc-chip-x{
  background:transparent;border:none;color:var(--ink-4);
  padding:0 8px;cursor:pointer;font-size:13px;line-height:1;
  border-left:1px solid var(--rule-card);transition:all .14s;
}
.doc-chip-x:hover{color:var(--rose);background:var(--rose-soft)}
.doc-add{
  display:inline-flex;align-items:center;gap:5px;
  background:transparent;border:1px dashed var(--rule);
  border-radius:var(--r);color:var(--ink-3);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  padding:4px 9px;cursor:pointer;transition:all .14s;font-family:var(--sans);
}
.doc-add:hover{border-color:var(--dock);color:var(--dock);background:var(--dock-soft)}
.doc-add svg{flex-shrink:0}

/* Standalone docs panel (in client / survey modals) */
.docs-panel{
  background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r);
  padding:12px 14px;
}
.docs-panel .docs-strip{
  padding:0;margin:0;background:transparent;border:none;
}
.docs-panel-empty{
  color:var(--ink-3);font-size:11.5px;font-style:italic;padding:4px 0;letter-spacing:.02em;
}

/* Clickable yacht name in table */
.vsl-name-link{
  background:none;border:none;padding:0;margin:0;
  font:inherit;color:inherit;text-align:left;cursor:pointer;
  transition:color .12s;
}
.vsl-name-link:hover{color:var(--brass);text-decoration:underline;text-underline-offset:3px}

/* AIS map fallback */
.ais-map-fallback{
  position:relative;width:100%;height:340px;border:1px solid var(--rule-card);
  border-radius:var(--r);overflow:hidden;background:var(--dock-soft);
  display:flex;align-items:center;justify-content:center;
}
.ais-map-fallback iframe{position:absolute;inset:0;width:100%;height:100%;border:none;display:block}
.ais-map-overlay{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%);
  background:rgba(255,255,255,.96);backdrop-filter:blur(8px);
  border:1px solid var(--rule-card);border-radius:var(--r);
  padding:10px 14px;display:flex;flex-direction:column;gap:6px;align-items:center;
  box-shadow:0 4px 12px -4px rgba(15,30,44,.15);max-width:380px;text-align:center;
}
.ais-map-overlay-title{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:600}
.ais-map-overlay-sub{font-size:10.5px;color:var(--ink-3);line-height:1.4;letter-spacing:.02em}
.ais-map-overlay-btns{display:flex;gap:6px;margin-top:4px;flex-wrap:wrap;justify-content:center}
.ais-map-overlay-btn{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--ink);color:#fff;border:none;border-radius:var(--r);
  padding:6px 11px;font-size:11px;letter-spacing:.06em;font-weight:500;
  cursor:pointer;text-decoration:none;transition:background .14s;font-family:var(--sans);
}
.ais-map-overlay-btn:hover{background:var(--dock)}
.ais-map-overlay-btn.secondary{background:transparent;color:var(--ink-2);border:1px solid var(--rule-card)}
.ais-map-overlay-btn.secondary:hover{background:var(--paper);border-color:var(--ink-4)}

/* Mark Done flash */
@keyframes flashDone{0%{background:var(--sea);color:#fff}100%{background:transparent;color:var(--ink-2)}}

/* ── AIS / Tracking panel ───────────────────────────────────────── */
.ais-panel{
  background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r);
  padding:18px 20px;margin-bottom:18px;
}
.ais-empty{
  padding:24px;text-align:center;color:var(--ink-3);font-size:12.5px;
  background:var(--paper);border:1px dashed var(--rule);border-radius:var(--r);letter-spacing:.04em;
}
.ais-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.ais-link{
  display:flex;align-items:center;gap:10px;padding:12px 14px;
  background:var(--paper);border:1px solid var(--rule-card);border-radius:var(--r);
  text-decoration:none;color:var(--ink);transition:all .14s;
}
.ais-link:hover{border-color:var(--ink);background:var(--card);box-shadow:0 2px 8px -2px rgba(15,30,44,.1)}
.ais-link-ico{
  width:34px;height:34px;border-radius:50%;background:var(--dock-soft);color:var(--dock);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600;font-size:11px;letter-spacing:.04em;
}
.ais-link-text{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}
.ais-link-name{font-size:13px;font-weight:500;color:var(--ink)}
.ais-link-sub{font-size:10.5px;color:var(--ink-3);letter-spacing:.02em}
.ais-link-arrow{color:var(--ink-3);flex-shrink:0}
.ais-map{
  width:100%;height:340px;border:1px solid var(--rule-card);border-radius:var(--r);
  overflow:hidden;background:var(--paper);
}
.ais-map iframe{width:100%;height:100%;border:none;display:block}

/* ── Crew badge in yacht row ─────────────────────────────────────── */
.crew-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:2px 8px 2px 6px;border-radius:99px;
  font-size:10.5px;color:var(--ink-3);background:var(--paper);border:1px solid var(--rule-card);
  letter-spacing:.04em;font-variant-numeric:tabular-nums;
}
.crew-pill svg{opacity:.6}

/* ── Custom add row form (cert / crew / maintenance) ─────────────── */
.add-row-btn{
  width:100%;padding:10px;background:transparent;border:1px dashed var(--rule);
  border-radius:var(--r);color:var(--ink-3);font-family:var(--sans);font-size:12px;
  font-weight:500;letter-spacing:.04em;cursor:pointer;transition:all .14s;
}
.add-row-btn:hover{border-color:var(--ink);color:var(--ink);background:var(--paper)}

.section{margin-bottom:36px}
.section-head{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--rule);
}
.eyebrow{font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.section-title{font-family:var(--display);font-size:17px;color:var(--ink);letter-spacing:.18em;text-transform:uppercase;font-weight:400;margin-top:4px}
.section-meta{font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.04em}

/* ── Dashboard (rebuilt) ────────────────────────────────────────── */
.dash{display:flex;flex-direction:column;gap:32px}
.dash-sec{display:flex;flex-direction:column;gap:16px}
.dash-sec-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding-bottom:11px;border-bottom:1px solid var(--rule);
}
.dash-sec-title{
  font-family:var(--display);font-size:15px;color:var(--ink);
  letter-spacing:.18em;text-transform:uppercase;font-weight:400;
}
.dash-sec-meta{
  font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.04em;
}

/* metric grid + tiles */
.metric-grid{display:grid;gap:14px}
.metric-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.metric-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.metric-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.metric-grid.feature{grid-template-columns:1.7fr 1fr 1fr 1fr}
.metric{
  background:var(--card);border-radius:var(--r-lg);box-shadow:var(--sh-card);
  padding:18px 20px 16px;display:flex;flex-direction:column;gap:14px;
  min-height:120px;position:relative;overflow:hidden;
}
.metric::before{content:"";position:absolute;top:0;left:0;width:30px;height:2px;background:var(--ink)}
.metric.a-brass::before{background:var(--brass)}
.metric.a-sea::before{background:var(--sea)}
.metric.a-amber::before{background:var(--amber)}
.metric.a-dock::before{background:var(--dock)}
.metric.a-rose::before{background:var(--rose)}
.metric-lbl{font-size:9.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.metric-note{font-size:10px;color:var(--ink-4);letter-spacing:.02em;margin-top:3px}
.metric-val{
  font-family:var(--display);font-size:32px;font-weight:200;color:var(--ink);
  letter-spacing:.01em;line-height:1;font-variant-numeric:tabular-nums;margin-top:auto;
}
.metric-val .cur{font-size:13px;color:var(--ink-3);vertical-align:top;margin-right:3px;font-weight:300;position:relative;top:2px}
.metric.feat{padding:24px 28px;justify-content:space-between}
.metric.feat .metric-val{font-size:56px;font-weight:100}
.metric.feat .metric-val .cur{font-size:22px;top:6px}

/* account breakdown */
.breakdown{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--sh-card);overflow:hidden}
.breakdown-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding:16px 20px 14px;border-bottom:1px solid var(--rule-card);
}
.breakdown-total{font-family:var(--mono);font-size:12.5px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:0}
.acct-group{border-bottom:1px solid var(--rule-card)}
.acct-group:last-child{border-bottom:none}
.acct-row{display:flex;align-items:center;gap:12px;padding:13px 20px;cursor:pointer;transition:background .12s}
.acct-row:hover{background:var(--paper)}
.acct-caret{flex-shrink:0;width:12px;color:var(--ink-3);font-size:15px;line-height:1;transition:transform .14s;display:inline-block}
.acct-row.open .acct-caret{transform:rotate(90deg);color:var(--ink-2)}
.acct-name{font-size:12.5px;color:var(--ink-2);font-weight:500;letter-spacing:.02em;width:100px;flex-shrink:0}
.acct-bar{flex:1;height:6px;border-radius:3px;background:var(--paper-2);overflow:hidden}
.acct-bar-fill{height:100%;border-radius:3px;background:var(--sea)}
.acct-pct{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);width:40px;text-align:right;flex-shrink:0}
.acct-amt{font-family:var(--mono);font-size:12px;color:var(--ink);font-variant-numeric:tabular-nums;text-align:right;width:96px;flex-shrink:0}

/* expanded job list under an account */
.acct-detail{background:var(--paper);padding:2px 20px 8px 44px}
.acct-job{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--rule-2)}
.acct-job:last-child{border-bottom:none}
.acct-job-main{flex:1;min-width:0}
.acct-job-name{font-size:12.5px;color:var(--ink);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-job-sub{font-size:11px;color:var(--ink-3);letter-spacing:.02em}
.acct-job-date{font-family:var(--mono);font-size:11px;color:var(--ink-3);width:88px;text-align:right;flex-shrink:0}
.acct-job-amt{font-family:var(--mono);font-size:12px;color:var(--ink);font-variant-numeric:tabular-nums;width:88px;text-align:right;flex-shrink:0}
.acct-job-empty{padding:10px 0;font-size:12px;color:var(--ink-3)}

/* fleet count strip */
.fleet-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--rule-card);border:1px solid var(--rule-card);
  border-radius:var(--r-lg);overflow:hidden;
}
.fleet-tile{background:var(--card);padding:16px 18px;display:flex;flex-direction:column;gap:8px}
.fleet-num{font-family:var(--display);font-size:30px;font-weight:200;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.fleet-num.warn{color:var(--amber)}
.fleet-num.bad{color:var(--rose)}
.fleet-lbl{font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500}

/* panels reused on the dashboard sit in a flex column — drop their own margins */
.dash .alerts-panel{margin-bottom:0}

/* google ads roi tiles */
/* Editable metric value (e.g. Google ad spend) styled like a static one. */
.metric-input{
  flex:1;min-width:0;font-family:var(--display);font-size:32px;font-weight:200;color:var(--ink);
  letter-spacing:.01em;line-height:1;font-variant-numeric:tabular-nums;
  border:none;background:transparent;outline:none;padding:0 0 1px;
  border-bottom:1px dashed var(--rule);
}
.metric-input:focus{border-bottom-color:var(--brass)}

@media (max-width:1080px){
  .metric-grid.cols-4,.metric-grid.cols-3,.metric-grid.feature{grid-template-columns:repeat(2,1fr)}
  .fleet-strip{grid-template-columns:repeat(2,1fr)}
}

/* ── Table card ─────────────────────────────────────────────────── */
.tcard{
  background:var(--card);border-radius:var(--r-lg);
  box-shadow:var(--sh-card);overflow:hidden;
}
.tbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--rule-card);gap:14px;flex-wrap:wrap;
}
.tbar-l{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.search{
  display:flex;align-items:center;gap:9px;
  background:var(--paper);border:1px solid var(--rule-card);
  border-radius:var(--r);padding:7px 12px;
  flex:1;min-width:200px;max-width:340px;transition:border-color .14s, background .14s;
}
.search:focus-within{border-color:var(--ink-3);background:var(--card)}
.search svg{flex-shrink:0;color:var(--ink-3)}
.search input{
  border:none;background:transparent;font-family:var(--sans);
  font-size:13px;color:var(--ink);outline:none;width:100%;
}
.search input::placeholder{color:var(--ink-3)}
.tcount{font-size:11.5px;color:var(--ink-3);font-variant-numeric:tabular-nums;letter-spacing:.03em;white-space:nowrap}

.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead th{
  background:var(--card);color:var(--ink-3);
  font-size:9.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  padding:14px 14px 11px;text-align:left;white-space:nowrap;
  border-bottom:1px solid var(--rule-card);
  position:sticky;top:0;
}
tbody tr{border-bottom:1px solid var(--rule-card);transition:background .1s}
tbody tr:hover{background:var(--paper)}
tbody tr:last-child{border-bottom:none}
td{padding:13px 14px;font-size:13px;color:var(--ink);white-space:nowrap;vertical-align:middle}
td.wrap{white-space:normal;max-width:220px;font-size:12px;color:var(--ink-3);line-height:1.45}
td.ref{font-family:var(--mono);font-size:11.5px;color:var(--ink);letter-spacing:0}
td.dim{color:var(--ink-3)}
td.meta{font-size:11.5px;color:var(--ink-3);font-variant-numeric:tabular-nums}
td.fee{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
td.r{text-align:right}
td.c{text-align:center}
td .who{display:flex;flex-direction:column;gap:1px}
td .who-name{font-weight:500;color:var(--ink);line-height:1.2}
td .who-co{font-size:11px;color:var(--ink-3);line-height:1.2}
td a.contact{
  color:var(--ink-3);text-decoration:none;display:inline-flex;align-items:center;gap:5px;
  transition:color .12s;
}
td a.contact:hover{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--brass)}
td a.contact svg{opacity:.5;transition:opacity .12s;flex-shrink:0}
td a.contact:hover svg{opacity:1;color:var(--brass)}
td .vsl{display:flex;flex-direction:column;gap:1px}
td .vsl-name{font-weight:500;color:var(--ink);line-height:1.2;font-style:italic;font-size:13px}
td .vsl-type{font-size:10px;color:var(--ink-3);letter-spacing:.14em;line-height:1.2;text-transform:uppercase;font-weight:500;margin-top:2px}

.tcard table{table-layout:auto;width:100%}
.empty{padding:60px 20px;text-align:center;color:var(--ink-3)}
.empty-ico{
  width:42px;height:42px;border:1px solid var(--rule);border-radius:50%;
  margin:0 auto 12px;display:flex;align-items:center;justify-content:center;
  color:var(--ink-4);
}
.empty-msg{font-size:14px;color:var(--ink-2);font-weight:500;letter-spacing:.04em}
.empty-sub{font-size:11.5px;color:var(--ink-3);margin-top:6px;letter-spacing:.04em}

.acts{display:flex;gap:2px}

.tfoot-bar{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:14px 18px;border-top:1px solid var(--rule-card);background:var(--paper);
}
.tfoot-label{font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.tfoot-conv{font-size:11.5px;color:var(--ink-3);letter-spacing:.02em;font-weight:500}
.tfoot-conv strong{color:var(--ink-2);font-weight:600}
.tfoot-val{font-family:var(--display);font-size:22px;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:.02em;font-weight:200}
.tfoot-val .cur{font-size:11px;color:var(--ink-3);vertical-align:top;margin-right:2px;position:relative;top:1px}

/* ── Badge ─────────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 9px 3px 8px;border-radius:99px;
  font-size:11px;font-weight:500;white-space:nowrap;letter-spacing:.02em;
  border:1px solid transparent;
}
.badge::before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0}
.b-completed{background:var(--sea-soft);color:#2F5A4B;border-color:#D7E2DB}
.b-completed::before{background:var(--sea)}
.b-in-progress{background:var(--amber-soft);color:#6B5318;border-color:#E8DDB8}
.b-in-progress::before{background:var(--amber)}
.b-pending{background:var(--dock-soft);color:#2A4B61;border-color:#D5E0E8}
.b-pending::before{background:var(--dock)}
.b-quoted{background:var(--brass-soft);color:#6B4D1D;border-color:#E5D7B4}
.b-quoted::before{background:var(--brass)}
.b-cancelled{background:var(--rose-soft);color:#6B2C2A;border-color:#E8D0CE}
.b-cancelled::before{background:var(--rose)}
.b-none{background:var(--paper-2);color:var(--ink-3);border-color:var(--rule)}
.b-none::before{background:var(--ink-4)}

.flag{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;font-size:10px;font-weight:600}
.flag.y{background:var(--sea-soft);color:#2F5A4B}
.flag.n{background:var(--paper-2);color:var(--ink-4)}

/* Inline-editable flag toggle (Inv / Paid) */
.flag-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;font-size:11px;font-weight:600;
  border:1px solid transparent;background:transparent;cursor:pointer;
  font-family:inherit;transition:all .14s;color:inherit;
}
.flag-btn.y{background:var(--sea-soft);color:#2F5A4B;border-color:#D7E2DB}
.flag-btn.n{background:var(--paper-2);color:var(--ink-4);border-color:var(--rule)}
.flag-btn:hover{border-color:var(--ink-2);transform:scale(1.06)}
.flag-btn:active{transform:scale(.95)}

/* Inline-editable status badge (acts as a dropdown) */
.badge-select{
  position:relative;display:inline-flex;align-items:center;gap:6px;
  padding:3px 7px 3px 8px;border-radius:99px;
  font-size:11px;font-weight:500;white-space:nowrap;letter-spacing:.02em;
  border:1px solid transparent;cursor:pointer;transition:all .14s;
  user-select:none;
}
.badge-select::before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0}
.badge-select .caret{opacity:.55;flex-shrink:0;transition:opacity .14s,transform .14s}
.badge-select:hover{filter:brightness(.97)}
.badge-select:hover .caret{opacity:.95}
.badge-select select{
  position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;
  border:none;background:transparent;font-size:0;-webkit-appearance:none;
  appearance:none;
}
.badge-select.b-completed{background:var(--sea-soft);color:#2F5A4B;border-color:#D7E2DB}
.badge-select.b-completed::before{background:var(--sea)}
.badge-select.b-in-progress{background:var(--amber-soft);color:#6B5318;border-color:#E8DDB8}
.badge-select.b-in-progress::before{background:var(--amber)}
.badge-select.b-pending{background:var(--dock-soft);color:#2A4B61;border-color:#D5E0E8}
.badge-select.b-pending::before{background:var(--dock)}
.badge-select.b-quoted{background:var(--brass-soft);color:#6B4D1D;border-color:#E5D7B4}
.badge-select.b-quoted::before{background:var(--brass)}
.badge-select.b-cancelled{background:var(--rose-soft);color:#6B2C2A;border-color:#E8D0CE}
.badge-select.b-cancelled::before{background:var(--rose)}
.badge-select.b-none{background:var(--paper-2);color:var(--ink-3);border-color:var(--rule)}
.badge-select.b-none::before{background:var(--ink-4)}

/* ── Modal ─────────────────────────────────────────────────────── */
.overlay{
  display:none;position:fixed;inset:0;background:rgba(15,30,44,.45);
  backdrop-filter:blur(4px);z-index:100;
  align-items:center;justify-content:center;padding:24px;
}
.overlay.on{display:flex}
.modal{
  background:var(--card);border-radius:var(--r-lg);width:100%;max-width:720px;
  max-height:92vh;overflow-y:auto;box-shadow:0 24px 64px -12px rgba(15,30,44,.35);
  animation:mIn .22s cubic-bezier(.2,.8,.2,1);
}
@keyframes mIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.mhead{
  padding:28px 32px 18px;border-bottom:1px solid var(--rule-card);
  display:flex;align-items:center;justify-content:space-between;
}
.mhead-l{display:flex;flex-direction:column;gap:5px}
.mhead-eye{font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.mtitle{font-family:var(--display);font-size:22px;color:var(--ink);letter-spacing:.14em;text-transform:uppercase;font-weight:300}
.mclose{
  background:transparent;border:1px solid var(--rule-card);
  width:30px;height:30px;border-radius:50%;color:var(--ink-2);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .14s;
}
.mclose:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.mbody{padding:28px 32px}
.mfoot{
  display:flex;justify-content:flex-end;gap:10px;
  padding:18px 32px 24px;border-top:1px solid var(--rule-card);background:var(--paper);
  border-radius:0 0 var(--r-lg) var(--r-lg);
}
.fsec{margin-bottom:26px}
.fsec:last-child{margin-bottom:0}
.fsec-title{
  font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3);
  font-weight:500;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--rule-card);
}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fgrid.g3{grid-template-columns:1fr 1fr 1fr}
.fgrid.g1{grid-template-columns:1fr}
.client-address .fgrid + .fgrid{margin-top:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{
  font-size:10px;font-weight:500;color:var(--ink-2);
  text-transform:uppercase;letter-spacing:.16em;
}
.field input,.field select,.field textarea{
  border:1px solid var(--rule-card);border-radius:var(--r);
  padding:9px 12px;font-family:var(--sans);font-size:13.5px;color:var(--ink);
  background:var(--card);transition:border-color .14s, box-shadow .14s;outline:none;
}
.field input::placeholder{color:var(--ink-4)}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--ink);box-shadow:0 0 0 3px rgba(15,30,44,.06);
}
.field input[readonly]{background:var(--paper);color:var(--ink-3);border-color:var(--rule-card);cursor:default}
.field input[readonly]:focus{box-shadow:none;border-color:var(--rule-card)}
.field textarea{resize:vertical;min-height:74px;font-family:var(--sans);line-height:1.5}
.field select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2367768A' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:30px;
}

/* ── Filter chips & sortable headers ────────────────────────────── */
.filter-row{
  display:flex;gap:6px;padding:10px 18px;border-bottom:1px solid var(--rule-card);
  flex-wrap:wrap;background:var(--card);align-items:center;
}
.chip{
  display:inline-flex;align-items:center;gap:7px;
  padding:5px 11px 5px 11px;border:1px solid var(--rule-card);border-radius:99px;
  font-size:11.5px;color:var(--ink-2);background:var(--card);cursor:pointer;
  user-select:none;transition:all .14s;letter-spacing:.02em;font-weight:500;
  font-family:inherit;
}
.chip:hover{border-color:var(--ink-3);color:var(--ink)}
.chip .ct{
  font-variant-numeric:tabular-nums;color:var(--ink-3);font-size:10.5px;font-weight:500;
  padding:1px 6px;border-radius:99px;background:var(--paper-2);
}
.chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip.on .ct{background:rgba(246,242,234,.18);color:var(--paper)}
.chip.on.b-completed{background:var(--sea);color:#fff;border-color:var(--sea)}
.chip.on.b-completed .ct{background:rgba(255,255,255,.2);color:#fff}
.chip.on.b-in-progress{background:var(--amber);color:#fff;border-color:var(--amber)}
.chip.on.b-in-progress .ct{background:rgba(255,255,255,.2);color:#fff}
.chip.on.b-pending{background:var(--dock);color:#fff;border-color:var(--dock)}
.chip.on.b-pending .ct{background:rgba(255,255,255,.2);color:#fff}
.chip.on.b-quoted{background:var(--brass);color:#fff;border-color:var(--brass)}
.chip.on.b-quoted .ct{background:rgba(255,255,255,.2);color:#fff}
.chip.on.b-cancelled{background:var(--rose);color:#fff;border-color:var(--rose)}
.chip.on.b-cancelled .ct{background:rgba(255,255,255,.2);color:#fff}

thead th.sortable{cursor:pointer;user-select:none;transition:color .12s;position:relative}
thead th.sortable:hover{color:var(--ink-2)}
thead th.sortable .sicon{
  display:inline-block;margin-left:4px;opacity:.25;transition:all .14s;
  vertical-align:-1px;color:var(--ink-3);
}
thead th.sortable:hover .sicon{opacity:.6}
thead th.sortable.act{color:var(--ink)}
thead th.sortable.act .sicon{opacity:1;color:var(--brass)}

/* ── Onboarding card (dashboard, when empty) ────────────────────── */
.onboard-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px;min-height:380px}
.onboard{
  background:var(--card);border-radius:var(--r-lg);box-shadow:var(--sh-card);
  padding:42px 40px 36px;display:flex;flex-direction:column;align-items:flex-start;
  gap:18px;max-width:560px;width:100%;position:relative;overflow:hidden;
}
.onboard::before{
  content:"";position:absolute;top:0;left:0;width:64px;height:3px;background:var(--brass);
}
.onboard-eye{font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.onboard h2{
  font-family:var(--display);font-size:26px;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink);line-height:1.15;
}
.onboard p{font-size:13.5px;color:var(--ink-2);line-height:1.6;max-width:460px}
.onboard-steps{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:4px}
.onboard-step{display:flex;align-items:flex-start;gap:14px;padding:10px 0;border-top:1px solid var(--rule-card)}
.onboard-step:last-child{border-bottom:1px solid var(--rule-card)}
.onboard-step-n{
  font-family:var(--display);font-size:18px;font-weight:300;color:var(--brass);
  letter-spacing:.04em;font-variant-numeric:tabular-nums;min-width:22px;
}
.onboard-step-t{display:flex;flex-direction:column;gap:2px;flex:1}
.onboard-step-name{font-size:13px;color:var(--ink);font-weight:500;letter-spacing:.01em}
.onboard-step-sub{font-size:11.5px;color:var(--ink-3);line-height:1.5}
.onboard .row{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}

/* ── Keyboard hint ──────────────────────────────────────────────── */
kbd{
  font-family:var(--mono);font-size:10px;padding:1px 5px;border-radius:3px;
  background:var(--paper);border:1px solid var(--rule-card);color:var(--ink-2);
  box-shadow:0 1px 0 var(--rule-card);line-height:1;display:inline-block;
}
.search-kbd{display:flex;align-items:center;gap:3px;color:var(--ink-4);font-size:10.5px;letter-spacing:.04em;margin-left:6px}
.search-kbd kbd{font-size:10px;padding:1px 4px}

/* ── Confirm dialog ─────────────────────────────────────────────── */
#conf{display:none;position:fixed;inset:0;background:rgba(15,30,44,.45);backdrop-filter:blur(3px);z-index:200;align-items:center;justify-content:center;padding:20px}
#conf.on{display:flex}
.cbox{background:var(--card);border-radius:var(--r-lg);padding:32px 34px;max-width:380px;width:90%;box-shadow:0 24px 64px -12px rgba(15,30,44,.35)}
.cbox h3{font-family:var(--display);font-size:18px;color:var(--ink);margin-bottom:10px;font-weight:400;letter-spacing:.12em;text-transform:uppercase}
.cbox p{font-size:13px;color:var(--ink-3);margin-bottom:22px;line-height:1.5}
.cbtns{display:flex;gap:10px;justify-content:flex-end}

/* ── Toast ──────────────────────────────────────────────────────── */
#toast{
  position:fixed;bottom:28px;right:28px;
  background:var(--ink);color:var(--paper);
  padding:12px 18px 12px 16px;border-radius:var(--r);font-size:13px;
  box-shadow:0 12px 32px -8px rgba(15,30,44,.35);
  transform:translateY(60px);opacity:0;transition:all .26s cubic-bezier(.2,.8,.2,1);
  z-index:300;display:flex;align-items:center;gap:10px;
}
#toast::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--brass)}
#toast.on{transform:none;opacity:1}

::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--rule);border-radius:4px;border:2px solid var(--paper)}
::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}

/* ── Misc ───────────────────────────────────────────────────────── */
/* Menu (export dropdown) */
.menu-wrap{position:relative}
.menu{display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r-lg);box-shadow:0 16px 48px -12px rgba(15,30,44,.25);min-width:268px;padding:10px;z-index:50}
.menu.on{display:block;animation:mIn .16s cubic-bezier(.2,.8,.2,1)}
.menu-label{font-size:9px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3);font-weight:500;padding:6px 10px 10px}
.menu-item{width:100%;background:transparent;border:none;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:2px;padding:9px 10px;border-radius:var(--r);transition:background .12s;font-family:var(--sans)}
.menu-item:hover{background:var(--paper)}
.menu-item-name{font-size:13px;color:var(--ink);font-weight:500;display:flex;align-items:baseline;gap:6px}
.menu-item-ext{color:var(--ink-3);font-family:var(--mono);font-size:11px;font-weight:400}
.menu-item-sub{font-size:11px;color:var(--ink-3);letter-spacing:.02em}
.menu-item-upload{cursor:pointer}
.menu-sep{height:1px;background:var(--rule-card);margin:6px 0}

.fee{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
.fee .cur{color:var(--ink-3);margin-right:1px;font-size:.85em}

/* ── Login overlay ── */
#login-overlay{position:fixed;inset:0;background:var(--paper);display:flex;align-items:center;justify-content:center;z-index:9999;flex-direction:column}
#login-overlay.hide{display:none}
.login-box{background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r-lg);padding:48px 44px;width:100%;max-width:400px;text-align:center;box-shadow:0 2px 24px rgba(15,30,44,.08)}
.login-logo{width:160px;height:auto;margin:0 auto 28px;display:block}
.login-title{font-family:var(--display);font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);margin-bottom:32px;font-weight:500}
.login-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;text-align:left}
.login-field label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.login-field input{border:1px solid var(--rule-card);border-radius:var(--r);padding:10px 13px;font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--paper);outline:none;transition:border-color .14s}
.login-field input:focus{border-color:var(--ink);background:var(--card)}
.login-btn{width:100%;background:var(--ink);color:var(--paper);border:1px solid var(--ink);border-radius:var(--r);padding:11px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.08em;cursor:pointer;transition:all .14s;margin-top:6px}
.login-btn:hover{background:#000}
.login-btn:disabled{opacity:.45;cursor:not-allowed}
.login-err{color:var(--rose);font-size:12px;margin-top:10px;min-height:18px;letter-spacing:.02em}
.login-foot{font-size:10.5px;color:var(--ink-4);margin-top:28px;letter-spacing:.04em}
.login-link{background:none;border:none;color:var(--ink-3);font-family:var(--sans);font-size:12px;letter-spacing:.02em;cursor:pointer;margin-top:14px;padding:2px;text-decoration:underline;text-underline-offset:2px;transition:color .14s}
.login-link:hover{color:var(--ink)}
#reset-overlay{position:fixed;inset:0;background:var(--paper);display:none;align-items:center;justify-content:center;z-index:10000;flex-direction:column}
#reset-overlay.show{display:flex}


/* ── Autocomplete suggest ───────────────────────────────────── */
.ref-suggest{position:absolute;top:calc(100% + 3px);left:0;right:0;background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r);box-shadow:0 6px 24px rgba(15,30,44,.12);z-index:500;max-height:220px;overflow-y:auto}
.ref-sug-row{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:12.5px;color:var(--ink);border-bottom:1px solid var(--rule-card);transition:background .1s}
.ref-sug-row:last-child{border-bottom:none}
.ref-sug-row:hover{background:var(--mist)}
.ref-sug-code{font-family:var(--mono);font-size:11px;color:var(--dock);background:rgba(29,92,122,.08);padding:1px 6px;border-radius:3px;flex-shrink:0}
.ref-sug-name{color:var(--ink);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ref-sug-sub{font-size:10.5px;color:var(--ink-3)}
.field{position:relative}

/* ── Jobs ───────────────────────────────────────────────────── */
.job-type-toggle{display:flex;gap:6px;margin-top:4px}
.jtt-btn{flex:1;padding:7px 10px;border-radius:var(--r);border:1px solid var(--rule-card);background:var(--paper);font-family:var(--sans);font-size:12px;cursor:pointer;color:var(--ink-3);transition:all .14s;text-align:center;font-weight:500}
.jtt-btn.on{background:var(--dock);color:#fff;border-color:var(--dock)}
.recur-section{display:none;margin-top:6px}
.recur-section.show{display:block}
.status-pip{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;flex-shrink:0}
.pip-quoted{background:var(--ink-4)}.pip-pending{background:var(--brass)}.pip-invoiced{background:var(--dock)}
.pip-paid{background:var(--sea)}.pip-overdue{background:var(--rose)}.pip-cancelled{background:var(--ink-4)}
.job-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.jb-quoted{background:#F0F2F5;color:var(--ink-2)}.jb-pending{background:var(--brass-soft);color:var(--brass)}
.jb-invoiced{background:rgba(29,92,122,.1);color:var(--dock)}.jb-paid{background:var(--sea-soft);color:var(--sea)}
.jb-partial{background:var(--amber-soft);color:var(--amber)}
.jb-overdue{background:var(--rose-soft);color:var(--rose)}.jb-cancelled{background:#F0F2F5;color:var(--ink-4)}
.jb-lost{background:var(--rose-soft);color:var(--rose);text-decoration:line-through}
.act-kind{display:inline-block;padding:2px 8px;border-radius:20px;background:#F0F2F5;color:var(--ink-3);font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.recurring-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:10px;font-size:10px;font-weight:600;background:rgba(196,150,58,.12);color:var(--brass);margin-left:4px}
.client-jobs-panel{padding:0}
.cj-row{display:flex;align-items:center;gap:12px;padding:9px 14px;border-bottom:1px solid var(--rule-card);font-size:12.5px}
.cj-row:last-child{border-bottom:none}
.cj-title{flex:1;color:var(--ink)}
.cj-amt{font-family:var(--mono);font-size:12px;color:var(--ink-2);white-space:nowrap}
.cj-total-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--paper);border-top:2px solid var(--rule-card);font-size:12px;font-weight:600}
#view-jobs.on{overflow:hidden;padding-bottom:28px}
#view-jobs .tcard{display:flex;flex-direction:column;flex:1;min-height:0;margin-bottom:0}
#view-jobs .table-wrap{flex:1;overflow:auto;min-height:0}
#view-jobs .tbar,#view-jobs .tfoot-bar,#view-jobs .filter-row{flex-shrink:0}
.mrr-note{font-size:10px;color:var(--ink-4);margin-top:2px;letter-spacing:.02em}


/* ── Country searchable select ────────────────────────────── */
.country-wrap{position:relative;display:flex;flex-direction:column;gap:4px}
.country-input{border:1px solid var(--rule-card);border-radius:6px;padding:7px 11px;font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--card);outline:none;width:100%;transition:border-color .15s}
.country-input:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(29,92,122,.08)}
.country-drop{position:absolute;top:calc(100% + 3px);left:0;right:0;background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r);box-shadow:0 6px 24px rgba(15,30,44,.13);z-index:600;max-height:200px;overflow-y:auto;display:none}
.country-drop.open{display:block}
.country-opt{display:flex;align-items:center;gap:8px;padding:7px 11px;cursor:pointer;font-size:12.5px;color:var(--ink);border-bottom:1px solid var(--rule-card);transition:background .08s}
.country-opt:last-child{border-bottom:none}
.country-opt:hover,.country-opt.focused{background:var(--mist)}
.country-flag{font-size:16px;flex-shrink:0}
.country-name{flex:1}
.country-dial{font-family:var(--mono);font-size:11px;color:var(--ink-3)}

/* ── Phone + dial code combo ──────────────────────────────── */
.phone-combo{display:flex;gap:0;border:1px solid var(--rule-card);border-radius:6px;overflow:hidden;transition:border-color .15s;background:var(--card)}
.phone-combo:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px rgba(29,92,122,.08)}
.phone-dial-btn{display:flex;align-items:center;gap:5px;padding:7px 9px;background:var(--paper);border-right:1px solid var(--rule-card);cursor:pointer;font-size:12px;font-family:var(--mono);color:var(--ink-2);white-space:nowrap;flex-shrink:0;min-width:70px;position:relative;user-select:none}
.phone-dial-btn:hover{background:var(--mist)}
.phone-dial-arrow{font-size:9px;color:var(--ink-4);margin-left:2px}
.phone-dial-drop{position:absolute;top:calc(100% + 2px);left:-1px;width:260px;background:var(--card);border:1px solid var(--rule-card);border-radius:var(--r);box-shadow:0 6px 24px rgba(15,30,44,.13);z-index:600;display:none}
.phone-dial-drop.open{display:block}
.phone-dial-search{width:100%;border:none;border-bottom:1px solid var(--rule-card);padding:8px 12px;font-family:var(--sans);font-size:13px;outline:none;background:var(--paper);color:var(--ink)}
.phone-dial-list{max-height:200px;overflow-y:auto}
.phone-dial-opt{display:flex;align-items:center;gap:8px;padding:7px 12px;cursor:pointer;font-size:12.5px;border-bottom:1px solid var(--rule-card);transition:background .08s}
.phone-dial-opt:last-child{border-bottom:none}
.phone-dial-opt:hover{background:var(--mist)}
.phone-input{border:none;outline:none;padding:7px 10px;font-family:var(--sans);font-size:13px;color:var(--ink);background:transparent;flex:1;min-width:0}

/* ─── Multi-select services (job modal) ─── */
.svc-checks{display:grid;grid-template-columns:repeat(2,1fr);gap:7px 14px}
.svc-check{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2);cursor:pointer;padding:6px 10px;border:1px solid var(--rule-card);border-radius:var(--r);background:var(--card);transition:border-color .12s,background .12s}
.svc-check:hover{border-color:var(--ink-3)}
.svc-check input{accent-color:var(--sea);width:14px;height:14px;cursor:pointer;flex-shrink:0}
.svc-check:has(input:checked){border-color:var(--sea);background:var(--sea-soft);color:var(--ink)}

/* ─── Job costs + profit ─── */
.costs-panel{display:flex;flex-direction:column;gap:7px}
.cost-row{display:flex;align-items:center;gap:8px}
.cost-row .cost-label{flex:1;min-width:0}
.cost-row .cost-cur{color:var(--ink-3);font-family:var(--mono);font-size:12px}
.cost-row .cost-amt{width:120px;flex-shrink:0;font-family:var(--mono)}
.cost-del{flex-shrink:0;width:28px;height:28px;border:1px solid var(--rule-card);border-radius:var(--r);background:transparent;color:var(--ink-3);font-size:16px;line-height:1;cursor:pointer;transition:all .12s}
.cost-del:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-soft)}
.job-profit{margin-top:12px;border-top:1px solid var(--rule-card);padding-top:10px;display:flex;flex-direction:column;gap:4px}
.jp-row{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-3)}
.jp-row strong{font-family:var(--mono);color:var(--ink-2);font-weight:600}
.jp-net{margin-top:4px;padding-top:7px;border-top:1px dashed var(--rule-card);font-size:13px;color:var(--ink-2)}
.jp-net strong{font-size:14px}
.jp-net.pos strong{color:var(--sea)}
.jp-net.neg strong{color:var(--rose)}
.fee-net{font-family:var(--mono);font-size:10px;font-weight:600;margin-top:2px}
.fee-net.pos{color:var(--sea)}
.fee-net.neg{color:var(--rose)}
.fee-due{font-family:var(--mono);font-size:10px;font-weight:600;margin-top:2px;color:var(--brass)}

/* ── Payment plan (deposit + balance) in the job form ───────────────── */
.pay-plan{
  margin-top:4px;border:1px solid var(--rule-card);border-radius:var(--r);
  background:var(--paper);overflow:hidden;
}
.pp-row{
  display:flex;align-items:center;gap:12px;padding:11px 14px;
  border-bottom:1px solid var(--rule-card);flex-wrap:wrap;
}
.pp-name{font-size:12.5px;font-weight:600;color:var(--ink-2);min-width:96px}
.pp-pct{font-family:var(--mono);font-size:10.5px;font-weight:500;color:var(--ink-3)}
.pp-amt{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--ink);min-width:70px}
.pp-check{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2);cursor:pointer;white-space:nowrap}
.pp-check input{width:15px;height:15px;cursor:pointer}
.pp-date{flex:0 0 auto;padding:6px 8px;font-family:var(--sans);font-size:12px}
.pp-acct{flex:0 0 auto;padding:6px 8px;font-family:var(--sans);font-size:12px}
.pp-summary{padding:11px 14px;font-size:12.5px;color:var(--ink-3);font-variant-numeric:tabular-nums}
.pp-summary strong{font-family:var(--mono);color:var(--ink);font-weight:600}

/* ─── Row recap card ─── */
.recap{display:flex;flex-direction:column}
.rc-head{padding:16px 18px;border-bottom:1px solid var(--rule-card)}
.rc-title{font-size:17px;font-weight:600;color:var(--ink);letter-spacing:.01em}
.rc-sub{font-size:12.5px;color:var(--ink-3);margin-top:2px}
.rc-ref{margin-top:9px;font-family:var(--mono);font-size:11px;color:var(--ink-3);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rc-sec{padding:12px 18px;border-bottom:1px solid var(--rule-card)}
.rc-sec:last-of-type{border-bottom:none}
.rc-sec-t{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-4);font-weight:600;margin-bottom:8px}
.rc-row{display:flex;justify-content:space-between;gap:16px;padding:3px 0;font-size:12.5px;line-height:1.5}
.rc-k{color:var(--ink-3);flex-shrink:0}
.rc-v{color:var(--ink-2);text-align:right;font-weight:500;min-width:0;word-break:break-word}
.rc-v a{color:var(--sea);text-decoration:none}
.rc-v a:hover{text-decoration:underline}
.rc-net{margin-top:6px;padding-top:8px;border-top:1px dashed var(--rule-card)}
.rc-net .rc-k{color:var(--ink-2)}
.rc-net .rc-v{font-size:14px;font-weight:600}
.rc-tags{display:flex;flex-wrap:wrap;gap:6px}
.rc-tag{font-size:11.5px;background:var(--sea-soft);color:#2F5A4B;border:1px solid #D7E2DB;border-radius:var(--r);padding:3px 9px}
.rc-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid var(--rule-card);background:var(--paper)}

/* ════════════════════════════════════════════════════════════════════
   Mobile / portrait — phones and narrow windows
   ════════════════════════════════════════════════════════════════════ */
@media (max-width:760px){
  #app{height:100dvh;overflow-x:hidden}
  #main,.content{min-width:0;max-width:100vw}

  /* ── Off-canvas sidebar drawer ── */
  #sidebar{
    position:fixed;top:0;left:0;bottom:0;z-index:200;width:82%;max-width:300px;
    transform:translateX(-100%);transition:transform .24s cubic-bezier(.2,.8,.2,1);
    box-shadow:0 0 48px rgba(15,30,44,.28);
  }
  body.nav-open #sidebar{transform:none}
  #sidebar-backdrop{
    display:block;position:fixed;inset:0;z-index:150;background:rgba(15,30,44,.42);
    opacity:0;pointer-events:none;transition:opacity .24s;
  }
  body.nav-open #sidebar-backdrop{opacity:1;pointer-events:auto}
  .nav-toggle{display:inline-flex}

  /* ── Topbar: hamburger + title on row 1, actions on row 2 ── */
  .topbar{height:auto;padding:9px 13px;gap:8px 10px;align-items:center;flex-wrap:wrap}
  .nav-toggle{order:1}
  .topbar-l{order:2;flex:1 1 auto;min-width:0;gap:2px}
  .crumb{display:none}
  .page-title{font-size:18px;letter-spacing:.1em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .topbar-r{order:3;flex:1 1 100%;display:flex;justify-content:flex-end;align-items:center;gap:6px}
  .topbar .btn{padding:8px 12px;font-size:12px}
  .save-indicator{display:none}
  .menu{right:0;min-width:0;width:max-content;max-width:calc(100vw - 26px)}

  /* ── View padding + let pages scroll vertically ── */
  .view.on{padding:16px 13px}
  #view-dash.on{padding-bottom:44px}
  #view-clients.on,#view-vessels.on,#view-yachts.on,#view-jobs.on{overflow-y:auto;padding-bottom:24px}
  #view-clients .tcard,#view-vessels .tcard,#view-yachts .tcard,#view-jobs .tcard{flex:none}
  #view-clients .table-wrap,#view-vessels .table-wrap,#view-yachts .table-wrap,#view-jobs .table-wrap{flex:none;overflow:visible}

  /* ── Table toolbar + filters ── */
  .tbar{flex-direction:column;align-items:stretch;padding:12px}
  .tbar-l{flex-direction:column;align-items:stretch;gap:10px}
  .search{width:100%}
  .search-kbd{display:none}
  .filter-row{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
  .filter-row::-webkit-scrollbar{display:none}

  /* ── Tables become stacked cards (label above value) ── */
  table,tbody,tr,td{display:block;width:100%;max-width:100%}
  thead{display:none}
  tbody tr{
    border:1px solid var(--rule-card);border-radius:var(--r-lg);background:var(--card);
    margin-bottom:12px;padding:6px 0;
  }
  tbody tr:hover{background:var(--card)}
  td{
    white-space:normal;overflow-wrap:anywhere;
    display:flex;flex-direction:column;align-items:flex-start;gap:3px;
    padding:7px 16px;text-align:left;
  }
  td::before{
    content:attr(data-label);
    font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
  }
  td:not([data-label])::before{display:none}
  td:has(.empty){display:block;text-align:center;padding:0}
  td.wrap{max-width:none;color:var(--ink-2)}
  td.r,td.c{text-align:left}
  td .who,td .vsl{align-items:flex-start}
  td .cert-strip{max-width:none}
  td.cell-acts{flex-direction:row;justify-content:flex-end;gap:6px;border-top:1px solid var(--rule-2);margin-top:4px;padding-top:11px}
  td.cell-acts .btn-icon{padding:9px 11px}
  .empty{display:block}
  .tfoot-bar{flex-direction:column;align-items:flex-start;gap:8px}

  /* ── Modals: bottom sheet, full width ── */
  .overlay{padding:0;align-items:flex-end}
  .modal,.modal.wide{max-width:100%;width:100%;max-height:94dvh;border-radius:var(--r-lg) var(--r-lg) 0 0}
  .mhead{padding:20px 18px 14px}
  .mtitle{font-size:18px;letter-spacing:.1em}
  .mtabs{padding:0 14px;overflow-x:auto}
  .mbody{padding:18px}
  .mfoot{padding:14px 18px 18px}
  .mfoot .btn{flex:1;justify-content:center}

  /* ── Forms single column ── */
  .fgrid,.fgrid.g3{grid-template-columns:1fr}
  .cert-grid{grid-template-columns:1fr}
  .pp-row{align-items:flex-start}

  /* ── Dashboard one column ── */
  .metric-grid.cols-4,.metric-grid.cols-3,.metric-grid.cols-2,.metric-grid.feature{grid-template-columns:1fr}
  .metric.feat .metric-val{font-size:46px}
  .fleet-strip{grid-template-columns:1fr 1fr}
  .alerts-head{flex-direction:column;align-items:flex-start;gap:10px}
  .alert-row{flex-wrap:wrap}

  /* ── Login / reset ── */
  .login-box{padding:36px 22px;max-width:none;margin:14px}
}
