/* Inter font — the customer.html signature face. Loaded once here so
 * every estimate page picks it up without each one importing
 * separately. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* Estimate system shared design tokens + components.
 *
 * Loaded by estimate-settings.html, estimate-layout-editor.html, and
 * edit-estimate.html so all three pages share the same surface
 * treatment, button styling, hover behaviors, focus halos, modal
 * animations, and save-state pills. Keeps the Phase 1-7 UIs feeling
 * like one coherent product instead of three independently-styled
 * pages.
 *
 * Style direction: a more polished, gradient-accented take on the
 * existing admin palette. Adds depth through subtle shadows + hover
 * lifts, motion through cubic-bezier easing, and personality through
 * gradient primary buttons + animated save-state pulses. Stays
 * compatible with the global dark mode (body.dark).
 */

:root {
  /* Existing palette (mirror what each page already declares so this
     file works even if loaded standalone) */
  --bg:        #f3f6fb;
  --white:     #ffffff;
  --panel:     #ffffff;
  --text:      #1a2e4a;
  --text-2:    #455571;
  --muted:     #7a94b4;
  --border:    rgba(45, 64, 96, .10);
  --border-hi: rgba(45, 64, 96, .18);
  --blue:      #2d7fc6;
  --blue-dk:   #1a5fa0;
  --blue-lt:   #e8f2ff;
  --indigo:    #6366f1;
  --violet:    #8b5cf6;
  --green:     #1b8f5a;
  --green-lt:  #e6f5ef;
  --red:       #c0392b;
  --red-lt:    #fdecea;
  --orange:    #d97706;
  --orange-lt: #fef3e2;

  /* Gradients for accents + primary CTAs */
  --gradient-primary: linear-gradient(135deg, #2d7fc6 0%, #6366f1 100%);
  --gradient-violet:  linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
  --gradient-surface: linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
  --gradient-bg:      linear-gradient(180deg, #f3f6fb 0%, #ecf1f8 100%);

  /* Shadow ladder — used for depth hierarchy. */
  --shadow-xs:    0 1px 2px rgba(15, 32, 64, .06);
  --shadow-sm:    0 2px 6px rgba(15, 32, 64, .06), 0 1px 2px rgba(15, 32, 64, .04);
  --shadow-md:    0 6px 14px -6px rgba(15, 32, 64, .12), 0 2px 4px rgba(15, 32, 64, .06);
  --shadow-lg:    0 18px 36px -16px rgba(15, 32, 64, .25), 0 4px 8px rgba(15, 32, 64, .06);
  --shadow-cta:   0 10px 22px -10px rgba(45, 127, 198, .55);
  --glow-blue:    0 0 0 3px rgba(45, 127, 198, .14);
  --glow-violet:  0 0 0 3px rgba(99, 102, 241, .14);
  --glow-red:     0 0 0 3px rgba(192, 57, 43, .14);

  /* Motion */
  --ease-out-fast:  cubic-bezier(.16, 1, .3, 1);
  --ease-out-bouncy: cubic-bezier(.34, 1.4, .58, 1);
  --t-fast:   .15s;
  --t-med:    .22s;
}
body.dark {
  --gradient-surface: linear-gradient(180deg, #112244 0%, #0e1e3d 100%);
  --gradient-bg:      linear-gradient(180deg, #0c1828 0%, #08111f 100%);
  --shadow-xs: 0 1px 2px rgba(0,0,0,.4);
  --shadow-sm: 0 2px 6px rgba(0,0,0,.45), 0 1px 2px rgba(0,0,0,.4);
  --shadow-md: 0 6px 14px -6px rgba(0,0,0,.5), 0 2px 4px rgba(0,0,0,.4);
  --shadow-lg: 0 18px 36px -16px rgba(0,0,0,.7), 0 4px 8px rgba(0,0,0,.4);
  --shadow-cta: 0 10px 22px -10px rgba(45, 127, 198, .8);
  --border:    rgba(255,255,255,.07);
  --border-hi: rgba(255,255,255,.14);
}

/* ── Body background with subtle gradient ─────────────────── */
body.es-body {
  background: var(--gradient-bg);
  background-attachment: fixed;
}

/* ── Top bar polish ───────────────────────────────────────── */
.es-topbar {
  height: 60px;
  background: rgba(255, 255, 255, .85);
  backdrop-filter: blur(14px) saturate(150%);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center;
  padding: 0 76px 0 22px;
  gap: 14px;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}
body.dark .es-topbar { background: rgba(15, 32, 64, .85); }
.es-tb-back {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: var(--white);
  border: 1px solid var(--border);
  color: var(--text);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: transform var(--t-fast) var(--ease-out-bouncy), background var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
  flex-shrink: 0;
}
.es-tb-back:hover {
  background: var(--blue-lt);
  border-color: var(--border-hi);
  transform: translateX(-2px);
  box-shadow: var(--shadow-sm);
}
.es-tb-back svg { width: 16px; height: 16px; }
.es-tb-title {
  font: 700 17px -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  letter-spacing: -.02em;
}
.es-tb-meta {
  font: 500 13px sans-serif;
  color: var(--muted);
  margin-left: 2px;
}
.es-tb-spacer { flex: 1; }

/* ── Save-state pill (live indicator) ─────────────────────── */
.es-save-state {
  display: none;
  align-items: center;
  gap: 7px;
  padding: 5px 12px 5px 10px;
  border-radius: 999px;
  font: 600 11.5px sans-serif;
  letter-spacing: .02em;
  transition: background var(--t-med), color var(--t-med);
  white-space: nowrap;
}
.es-save-state.show { display: inline-flex; }
.es-save-state::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.es-save-state.saving {
  background: rgba(45, 127, 198, .12);
  color: var(--blue-dk);
}
.es-save-state.saving::before {
  animation: es-pulse 1.2s ease-in-out infinite;
}
.es-save-state.saved {
  background: rgba(27, 143, 90, .12);
  color: var(--green);
}
.es-save-state.error {
  background: rgba(192, 57, 43, .12);
  color: var(--red);
}
@keyframes es-pulse {
  0%, 100% { opacity: .35; }
  50% { opacity: 1; }
}

/* ── Primary CTA (gradient) ───────────────────────────────── */
.es-btn-primary {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 20px;
  border-radius: 10px;
  background: var(--gradient-primary);
  border: none;
  color: #fff;
  font: 600 13.5px sans-serif;
  letter-spacing: -.005em;
  cursor: pointer;
  box-shadow: var(--shadow-cta);
  transition: transform var(--t-med) var(--ease-out-bouncy), box-shadow var(--t-med);
  text-decoration: none;
  white-space: nowrap;
}
.es-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px -10px rgba(45, 127, 198, .65);
}
.es-btn-primary:active { transform: translateY(0); }
.es-btn-primary svg { width: 14px; height: 14px; }

/* ── Generic button (secondary) ───────────────────────────── */
.es-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 16px;
  border-radius: 10px;
  background: var(--white);
  border: 1px solid var(--border);
  color: var(--text);
  font: 600 13px sans-serif;
  cursor: pointer;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy), box-shadow var(--t-fast);
  text-decoration: none;
}
.es-btn:hover {
  background: var(--blue-lt);
  border-color: var(--border-hi);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.es-btn:active { transform: translateY(0); }
.es-btn.icon-only { padding: 8px; }
.es-btn.danger {
  color: var(--red);
  border-color: rgba(192, 57, 43, .3);
}
.es-btn.danger:hover {
  background: var(--red-lt);
  border-color: var(--red);
}
.es-btn svg { width: 14px; height: 14px; }

/* ── Cards (panels with depth) ────────────────────────────── */
.es-card {
  background: var(--gradient-surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 26px 28px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--t-med) var(--ease-out-fast);
}
.es-card-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.es-card-title {
  font: 700 18px sans-serif;
  color: var(--text);
  letter-spacing: -.015em;
}
.es-card-sub {
  font: 500 13px sans-serif;
  color: var(--text-2);
  margin-top: 5px;
}

/* ── Inputs with consistent focus ring ────────────────────── */
.es-input, .es-select, .es-textarea {
  padding: 10px 13px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--text);
  font: 500 14px sans-serif;
  font-family: inherit;
  transition: border-color var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
}
.es-input:hover, .es-select:hover, .es-textarea:hover { background: rgba(232, 242, 255, .35); border-color: var(--border-hi); }
.es-input:focus, .es-select:focus, .es-textarea:focus {
  outline: none;
  border-color: var(--blue);
  background: var(--white);
  box-shadow: var(--glow-blue);
}
.es-textarea { min-height: 80px; resize: vertical; line-height: 1.5; }

.es-search {
  position: relative;
}
.es-search input {
  width: 100%;
  padding: 10px 14px 10px 38px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--white);
  color: var(--text);
  font: 500 13.5px sans-serif;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.es-search input:focus {
  outline: none; border-color: var(--blue);
  box-shadow: var(--glow-blue);
}
.es-search::before {
  content: '';
  position: absolute;
  left: 14px; top: 50%;
  width: 14px; height: 14px;
  margin-top: -7px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%237a94b4' stroke-width='1.7'%3E%3Ccircle cx='7' cy='7' r='5'/%3E%3Cpath d='M14 14l-3.5-3.5'/%3E%3C/svg%3E") center/contain no-repeat;
  pointer-events: none;
}

/* ── Toggle (segmented pill) ─────────────────────────────── */
.es-toggle {
  position: relative;
  width: 38px; height: 22px;
  border-radius: 999px;
  background: var(--border-hi);
  cursor: pointer;
  transition: background var(--t-fast);
  flex-shrink: 0;
}
.es-toggle::after {
  content: '';
  position: absolute;
  top: 2px; left: 2px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 4px rgba(15, 32, 64, .2);
  transition: transform var(--t-fast) var(--ease-out-bouncy);
}
.es-toggle.on { background: var(--gradient-primary); }
.es-toggle.on::after { transform: translateX(16px); }
.es-toggle.small {
  width: 32px; height: 18px;
}
.es-toggle.small::after { width: 14px; height: 14px; }
.es-toggle.small.on::after { transform: translateX(14px); }

/* ── Status pills ─────────────────────────────────────────── */
.es-pill {
  display: inline-block;
  padding: 3px 11px;
  border-radius: 999px;
  font: 700 10.5px sans-serif;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.es-pill.accent { background: var(--blue-lt); color: var(--blue-dk); }
.es-pill.success { background: var(--green-lt); color: var(--green); }
.es-pill.warning { background: var(--orange-lt); color: var(--orange); }

/* ── Empty / stub blocks ──────────────────────────────────── */
.es-empty {
  padding: 50px 26px;
  text-align: center;
  color: var(--muted);
  background: rgba(232, 242, 255, .35);
  border: 1px dashed var(--border-hi);
  border-radius: 14px;
  animation: es-fade-in .4s var(--ease-out-fast);
}
.es-empty strong {
  display: block;
  color: var(--text);
  font: 700 15px sans-serif;
  margin-bottom: 6px;
  letter-spacing: -.01em;
}
.es-empty em { color: var(--blue-dk); font-style: normal; font-weight: 600; }

@keyframes es-fade-in {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── Page rows (sortable list items) ──────────────────────── */
.es-page-row {
  display: flex; align-items: center; gap: 11px;
  padding: 10px 12px;
  margin-bottom: 4px;
  border-radius: 10px;
  cursor: pointer;
  border: 1px solid transparent;
  background: transparent;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy);
}
.es-page-row:hover {
  background: var(--blue-lt);
  border-color: var(--border);
}
.es-page-row.active {
  background: linear-gradient(135deg, rgba(45,127,198,.10), rgba(99,102,241,.10));
  border-color: rgba(45,127,198,.35);
  box-shadow: var(--shadow-xs);
}
.es-page-row.dragging { opacity: .35; transform: scale(.97); }
.es-page-row.drop-target-before { box-shadow: 0 -2px 0 var(--blue); }
.es-page-row.drop-target-after  { box-shadow: 0  2px 0 var(--blue); }
.es-page-handle {
  color: var(--muted); cursor: grab;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  opacity: .55;
  transition: opacity var(--t-fast);
}
.es-page-row:hover .es-page-handle { opacity: 1; }
.es-page-handle svg { width: 14px; height: 14px; }
.es-page-title {
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font: 500 13.5px sans-serif;
  color: var(--text);
  letter-spacing: -.005em;
}
.es-page-row.disabled .es-page-title {
  color: var(--muted);
  text-decoration: line-through;
  text-decoration-color: rgba(122, 148, 180, .55);
}

/* ── Modals (backdrop + animated panel) ───────────────────── */
.es-modal-backdrop {
  position: fixed; inset: 0;
  background: radial-gradient(circle at 50% 30%, rgba(45, 127, 198, .18), rgba(8, 16, 32, .55) 70%);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  display: flex; align-items: center; justify-content: center;
  z-index: 100;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity var(--t-med) var(--ease-out-fast), visibility 0s linear var(--t-med);
}
.es-modal-backdrop.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity var(--t-med) var(--ease-out-fast), visibility 0s;
}
.es-modal {
  width: 100%; max-width: 520px;
  max-height: calc(100vh - 40px);
  background: var(--gradient-surface);
  border: 1px solid rgba(255, 255, 255, .8);
  border-radius: 18px;
  box-shadow:
    var(--shadow-lg),
    inset 0 1px 0 rgba(255, 255, 255, .9);
  display: flex; flex-direction: column;
  overflow: hidden;
  transform: translateY(16px) scale(.96);
  opacity: 0;
  transition: transform .35s var(--ease-out-fast), opacity var(--t-med) var(--ease-out-fast);
}
body.dark .es-modal { border-color: rgba(255,255,255,.06); }
.es-modal-backdrop.open .es-modal {
  transform: translateY(0) scale(1);
  opacity: 1;
}
.es-modal-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border);
  gap: 14px;
}
.es-modal-title {
  font: 700 17px sans-serif;
  color: var(--text);
  letter-spacing: -.015em;
}
.es-modal-sub {
  font: 500 12.5px sans-serif;
  color: var(--muted);
  margin-top: 3px;
}
.es-modal-close {
  width: 34px; height: 34px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, .6);
  color: var(--muted);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: transform var(--t-fast) var(--ease-out-bouncy), background var(--t-fast), color var(--t-fast);
}
.es-modal-close:hover {
  background: var(--white);
  color: var(--text);
  transform: rotate(90deg);
}
.es-modal-body {
  padding: 18px 22px;
  flex: 1;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 14px;
}
.es-modal-foot {
  padding: 16px 22px;
  border-top: 1px solid var(--border);
  display: flex; justify-content: flex-end; gap: 10px;
  background: linear-gradient(180deg, rgba(248, 250, 255, 0) 0%, rgba(241, 245, 252, .8) 100%);
}
body.dark .es-modal-foot { background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.2)); }

/* ── Picker rows inside modals ────────────────────────────── */
.es-picker-row {
  display: flex; align-items: center; gap: 13px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--white);
  cursor: pointer;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy), box-shadow var(--t-fast);
}
.es-picker-row:hover {
  background: var(--blue-lt);
  border-color: rgba(45, 127, 198, .35);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.es-picker-row.current {
  background: linear-gradient(135deg, rgba(45,127,198,.12), rgba(99,102,241,.12));
  border-color: var(--blue);
}
.es-picker-icon {
  width: 34px; height: 34px;
  border-radius: 10px;
  background: var(--gradient-primary);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font: 700 13px sans-serif;
  flex-shrink: 0;
  box-shadow: var(--shadow-xs);
}
.es-picker-meta { flex: 1; min-width: 0; }
.es-picker-title {
  font: 600 13.5px sans-serif;
  color: var(--text);
  letter-spacing: -.005em;
}
.es-picker-sub {
  font: 500 12px sans-serif;
  color: var(--muted);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Stub block (placeholder for unfinished editors) ──────── */
.es-stub {
  padding: 44px 30px;
  text-align: center;
  background: linear-gradient(135deg, rgba(45,127,198,.06), rgba(99,102,241,.06));
  border: 1px dashed rgba(45, 127, 198, .25);
  border-radius: 14px;
  color: var(--text-2);
  animation: es-fade-in .4s var(--ease-out-fast);
}
.es-stub strong {
  display: block;
  color: var(--text);
  font: 700 15px sans-serif;
  margin-bottom: 8px;
  letter-spacing: -.015em;
}

/* ── Sub-sidebar (settings nav) ───────────────────────────── */
.es-subnav {
  width: 248px;
  flex-shrink: 0;
  background: var(--gradient-surface);
  border-right: 1px solid var(--border);
  padding: 22px 14px;
  overflow-y: auto;
}
.es-subnav-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 12px;
  border-radius: 10px;
  color: var(--text-2);
  cursor: pointer;
  font: 500 13.5px sans-serif;
  letter-spacing: -.005em;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy);
  margin-bottom: 2px;
}
.es-subnav-item:hover {
  background: var(--blue-lt);
  color: var(--blue-dk);
  transform: translateX(2px);
}
.es-subnav-item.active {
  background: linear-gradient(135deg, rgba(45,127,198,.12), rgba(99,102,241,.12));
  color: var(--blue-dk);
  font-weight: 600;
}
.es-subnav-group { margin-bottom: 4px; }
.es-subnav-children {
  padding-left: 14px;
  margin-top: 2px;
  display: none;
  overflow: hidden;
}
.es-subnav-group.expanded .es-subnav-children { display: block; animation: es-fade-in .3s var(--ease-out-fast); }
.es-subnav-group-chevron {
  transition: transform var(--t-fast);
  width: 11px; height: 11px;
  color: var(--muted);
}
.es-subnav-group.expanded .es-subnav-group-chevron { transform: rotate(180deg); }

/* ── Side pane (vertical nav with sections) ───────────────── */
.es-side-pane {
  width: 320px;
  flex-shrink: 0;
  background: var(--gradient-surface);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 1px 0 0 var(--border), 4px 0 12px -8px rgba(15, 32, 64, .06);
}
.es-side-scroll { flex: 1; overflow-y: auto; }
.es-side-section { border-bottom: 1px solid var(--border); }
.es-side-section-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px;
  cursor: pointer;
  user-select: none;
  transition: background var(--t-fast);
}
.es-side-section-head:hover { background: var(--blue-lt); }
.es-side-section-title {
  font: 700 12px sans-serif;
  color: var(--text);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.es-side-section-chevron {
  width: 12px; height: 12px;
  color: var(--muted);
  transition: transform var(--t-fast);
}
.es-side-section.collapsed .es-side-section-chevron { transform: rotate(-90deg); }
.es-side-section-body { padding: 0 20px 16px; }
.es-side-section.collapsed .es-side-section-body { display: none; }

.es-side-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 0;
  font-size: 13px;
  gap: 12px;
}
.es-side-row + .es-side-row { border-top: 1px dashed var(--border); }
.es-side-row-label {
  font: 500 12.5px sans-serif;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.es-side-row-value {
  font: 600 13.5px sans-serif;
  color: var(--text);
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  text-align: right;
}
.es-side-link {
  color: var(--blue-dk);
  font: 600 12.5px sans-serif;
  cursor: pointer;
  background: none; border: none; padding: 4px 8px;
  border-radius: 6px;
  transition: background var(--t-fast);
}
.es-side-link:hover { background: var(--blue-lt); }

.es-add-page-btn {
  width: calc(100% - 40px);
  margin: 10px 20px 16px;
  padding: 10px 12px;
  border-radius: 11px;
  border: 1px dashed rgba(45, 127, 198, .35);
  background: rgba(45, 127, 198, .04);
  color: var(--blue-dk);
  font: 600 13px sans-serif;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy);
}
.es-add-page-btn:hover {
  background: rgba(45, 127, 198, .10);
  border-color: var(--blue);
  transform: translateY(-1px);
}
.es-add-page-btn svg { width: 14px; height: 14px; }

/* ── Internal note (sticky bottom of side pane) ───────────── */
.es-internal-note {
  padding: 14px 20px 18px;
  border-top: 1px solid rgba(217, 119, 6, .22);
  background: linear-gradient(180deg, #fff8e6 0%, #fef0d2 100%);
}
body.dark .es-internal-note { background: linear-gradient(180deg, #2a2410 0%, #1f1a0c 100%); }
.es-internal-note-title {
  font: 700 11px sans-serif;
  color: #b45309;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.es-internal-note textarea {
  width: 100%;
  padding: 9px 12px;
  border-radius: 9px;
  border: 1px solid rgba(217, 119, 6, .3);
  background: #fff;
  color: var(--text);
  font: 500 13px sans-serif;
  font-family: inherit;
  min-height: 70px;
  resize: vertical;
  margin-top: 8px;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.es-internal-note textarea:focus {
  outline: none;
  border-color: #b45309;
  box-shadow: 0 0 0 3px rgba(217, 119, 6, .14);
}

/* ── Editor main area ────────────────────────────────────── */
.es-editor-main {
  flex: 1;
  overflow-y: auto;
  padding: 28px 32px 60px;
  min-width: 0;
  animation: es-fade-in .3s var(--ease-out-fast);
}
.es-editor-card {
  background: var(--gradient-surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 26px 28px;
  margin: 0 auto;
  max-width: 920px;
  box-shadow: var(--shadow-sm);
}
.es-editor-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
.es-editor-page-name input {
  font: 700 19px sans-serif;
  color: var(--text);
  letter-spacing: -.015em;
  background: transparent;
  border: 1px solid transparent;
  padding: 4px 10px;
  border-radius: 8px;
  width: 380px; max-width: 100%;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.es-editor-page-name input:hover {
  border-color: var(--border);
  background: rgba(232, 242, 255, .35);
}
.es-editor-page-name input:focus {
  outline: none;
  border-color: var(--blue);
  background: var(--white);
  box-shadow: var(--glow-blue);
}

/* ── App shell base (works alongside the global app-shell) ─ */
.es-shell {
  display: flex;
  height: 100vh;
}
.es-main {
  flex: 1;
  display: flex; flex-direction: column;
  min-width: 0;
  overflow: hidden;
}
.es-split {
  flex: 1;
  display: flex;
  min-height: 0;
}

/* ── Responsive tightening ────────────────────────────────── */
@media (max-width: 880px) {
  .es-side-pane { width: 280px; }
  .es-subnav { width: 220px; }
  .es-editor-main { padding: 20px 16px 40px; }
}

/* ════════════════════════════════════════════════════════════
 * LEGACY CLASS BRIDGES — visual upgrade for the existing HTML in
 * estimate-settings.html / estimate-layout-editor.html /
 * edit-estimate.html.
 *
 * Style target: customer.html — the project's gold standard. That
 * page achieves a modern, airy feel through restraint:
 *   • Pure white cards (no gradients on surfaces)
 *   • Soft floating shadows (barely visible, lots of depth)
 *   • Subtle colored left accent strips on cards
 *   • Clean tab underline for active nav (no background tints)
 *   • Minimal visible borders — depth comes from shadows
 *   • Generous padding + airy whitespace
 *   • Typography hierarchy (small uppercase labels + bold values)
 *
 * The gradient primary CTA stays (it matches the Add Job button on
 * customer.html). Everything else gets toned down to feel restrained.
 * ════════════════════════════════════════════════════════════ */

/* Surface palette — copied from customer.html literally so cards look
 * identical. The key insight: surfaces are GLASS (translucent white
 * with backdrop blur), not pure white. Combined with the radial-glow
 * body background, this is what gives the page that floating modern
 * feel. */
:root {
  --es-glass-bg:    rgba(255, 255, 255, .82);
  --es-glass-bd:    rgba(255, 255, 255, .55);
  --es-line-soft:   rgba(45, 64, 96, .08);
  --es-shadow-card: 0 16px 48px -20px rgba(14, 27, 48, .16), 0 1px 0 rgba(255, 255, 255, .8) inset;
  --es-shadow-card-hover: 0 24px 60px -20px rgba(14, 27, 48, .22), 0 1px 0 rgba(255, 255, 255, .8) inset;
  --accent-strip:   linear-gradient(180deg, #2d7fc6 0%, #1a5fa0 100%);
}
body.dark {
  --es-glass-bg:    rgba(17, 34, 68, .85);
  --es-glass-bd:    rgba(255, 255, 255, .06);
  --es-line-soft:   rgba(255, 255, 255, .06);
  --es-shadow-card: 0 16px 48px -20px rgba(0, 0, 0, .45);
  --es-shadow-card-hover: 0 24px 60px -20px rgba(0, 0, 0, .55);
}

/* Top bar — glass treatment matching customer.html's chrome. */
.top-bar {
  height: 60px !important;
  background: var(--es-glass-bg) !important;
  backdrop-filter: blur(20px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(140%) !important;
  border-bottom: 1px solid var(--es-line-soft) !important;
  padding: 0 76px 0 22px !important;
  gap: 14px !important;
  font-family: 'Inter', sans-serif !important;
}
body.dark .top-bar { background: var(--es-glass-bg) !important; }
.tb-title {
  font-family: 'Inter', sans-serif !important;
}
.tb-back {
  width: 38px !important; height: 38px !important;
  border-radius: 10px !important;
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
  transition: transform var(--t-fast) var(--ease-out-bouncy), background var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast) !important;
}
.tb-back:hover {
  transform: translateX(-2px) !important;
  background: var(--blue-lt) !important;
  border-color: var(--border-hi) !important;
  box-shadow: var(--shadow-sm);
}
.tb-title {
  font: 700 17px sans-serif !important;
  letter-spacing: -.02em !important;
}

/* Save state pill */
.tb-save-state {
  padding: 5px 12px 5px 10px !important;
  border-radius: 999px !important;
  font: 600 11.5px sans-serif !important;
  letter-spacing: .02em;
  display: inline-flex !important;
  align-items: center;
  gap: 7px;
  transition: background var(--t-med), color var(--t-med);
  white-space: nowrap;
}
.tb-save-state:not(:empty)::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.tb-save-state.saving { background: rgba(45, 127, 198, .12) !important; }
.tb-save-state.saving::before { animation: es-pulse 1.2s ease-in-out infinite; }
.tb-save-state.saved { background: rgba(27, 143, 90, .12) !important; }
.tb-save-state.error { background: rgba(192, 57, 43, .12) !important; }

/* Primary CTA — Review & Share / Estimate Layout buttons */
.btn-review,
.btn.primary,
.tb-btn.primary {
  background: var(--gradient-primary) !important;
  border: none !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 10px 20px !important;
  font: 600 13.5px sans-serif !important;
  letter-spacing: -.005em !important;
  box-shadow: var(--shadow-cta) !important;
  transition: transform var(--t-med) var(--ease-out-bouncy), box-shadow var(--t-med) !important;
}
.btn-review:hover,
.btn.primary:hover,
.tb-btn.primary:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 14px 28px -10px rgba(45, 127, 198, .65) !important;
  background: var(--gradient-primary) !important;
}

/* Generic .btn upgrades — covers .icon-only, .danger */
.btn:not(.primary):not(.tb-btn) {
  border-radius: 10px !important;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy), box-shadow var(--t-fast) !important;
}
.btn:not(.primary):not(.tb-btn):hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

/* Sub-sidebar nav (estimate-settings.html) — glass surface +
 * left-strip active indicator. Mirrors customer.html's nav language. */
.subnav {
  background: var(--es-glass-bg) !important;
  backdrop-filter: blur(20px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(140%) !important;
  border-right: 1px solid var(--es-glass-bd) !important;
  padding: 24px 16px !important;
  font-family: 'Inter', sans-serif !important;
}
.subnav-item {
  position: relative;
  border-radius: 10px !important;
  padding: 10px 14px !important;
  font: 500 14px 'Inter', sans-serif !important;
  letter-spacing: -.005em !important;
  color: var(--text-2) !important;
  transition: color var(--t-fast), background var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy) !important;
}
.subnav-item:hover {
  background: rgba(232, 242, 255, .5) !important;
  color: var(--blue-dk) !important;
  transform: none !important;
}
.subnav-item.active {
  background: rgba(232, 242, 255, .65) !important;
  color: var(--blue-dk) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}
/* Left accent strip for active nav item — the customer.html signature. */
.subnav-item.active::before {
  content: '';
  position: absolute;
  left: 2px; top: 18%; bottom: 18%;
  width: 3px;
  border-radius: 2px;
  background: var(--accent-strip);
  animation: es-strip-in .25s var(--ease-out-fast);
}
@keyframes es-strip-in {
  from { opacity: 0; transform: scaleY(0); }
  to { opacity: 1; transform: scaleY(1); }
}
.subnav-children .subnav-item.active::before {
  left: 2px;
}

/* Settings cards — glass + big soft shadow + inset white highlight.
 * Identical recipe to customer.html's .dash-card. */
.settings-main { padding: 32px 40px 48px !important; }
.settings-card {
  position: relative;
  background: var(--es-glass-bg) !important;
  backdrop-filter: blur(20px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(140%) !important;
  border: 1px solid var(--es-glass-bd) !important;
  border-radius: 18px !important;
  padding: 24px 26px !important;
  box-shadow: var(--es-shadow-card) !important;
  overflow: hidden;
  font-family: 'Inter', sans-serif !important;
  animation: es-card-rise .5s cubic-bezier(.16, 1, .3, 1) both;
  transition: box-shadow .2s ease, transform .15s ease !important;
}
.settings-card:hover {
  box-shadow: var(--es-shadow-card-hover) !important;
  transform: translateY(-2px) !important;
}
.settings-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--accent-strip);
  opacity: .85;
}
.settings-card-head {
  margin-bottom: 22px !important;
}
.settings-card-title {
  font: 700 18px 'Inter', sans-serif !important;
  letter-spacing: -.015em !important;
  color: var(--text);
}
.settings-card-sub {
  font: 500 13.5px 'Inter', sans-serif !important;
  color: var(--text-2);
  margin-top: 5px !important;
  letter-spacing: -.005em;
}
@keyframes es-card-rise {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Layouts table — each row is its own glass card with depth + hover
 * lift, mirroring the customer.html job card pattern. */
.layouts-table {
  border: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
  background: transparent !important;
}
.layouts-row {
  padding: 16px 20px !important;
  background: var(--es-glass-bg);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid var(--es-glass-bd);
  border-radius: 14px;
  margin-bottom: 10px;
  box-shadow: 0 4px 14px -8px rgba(15, 32, 64, .14);
  font-family: 'Inter', sans-serif !important;
  transition: background var(--t-fast), border-color var(--t-fast), box-shadow .2s ease, transform .15s ease !important;
}
.layouts-row:hover:not(.header) {
  border-color: rgba(45,127,198,.25);
  box-shadow: var(--es-shadow-card-hover) !important;
  transform: translateY(-2px) !important;
}
.layouts-row.header {
  background: transparent !important;
  backdrop-filter: none;
  border: none !important;
  border-radius: 0 !important;
  margin-bottom: 6px !important;
  padding: 4px 20px !important;
  box-shadow: none !important;
  transform: none !important;
  font: 700 11px 'Inter', sans-serif !important;
  letter-spacing: .12em !important;
  text-transform: uppercase;
  color: var(--muted) !important;
}
.layouts-row.header:hover {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  transform: none !important;
}
.layouts-name {
  font: 600 15px 'Inter', sans-serif !important;
  letter-spacing: -.01em !important;
}
.layouts-name:hover {
  color: var(--blue-dk) !important;
}

/* Toggles — both .toggle (settings table) and .page-toggle (editor) */
.toggle, .page-toggle {
  border-radius: 999px !important;
  transition: background var(--t-fast) !important;
}
.toggle.on, .page-toggle.on { background: var(--gradient-primary) !important; }
.toggle::after, .page-toggle::after {
  box-shadow: 0 2px 4px rgba(15, 32, 64, .2) !important;
  transition: transform var(--t-fast) var(--ease-out-bouncy) !important;
}

/* Page rows in the editor — calm, clean rows. Active state uses a
 * left accent strip (mirroring the subnav pattern) instead of a
 * tinted background. */
.page-row {
  position: relative;
  border-radius: 9px !important;
  border: 1px solid transparent !important;
  padding-left: 14px !important;
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy) !important;
}
/* Hover state on non-active rows — same light blue family as the
 * active state but lighter, so admin gets a clear affordance that
 * the row is clickable. JobNimbus uses the same pattern. */
.page-row:hover {
  background: rgba(45, 127, 198, .06) !important;
  border-color: transparent !important;
  color: var(--blue-dk) !important;
}
/* Active page — JobNimbus-style light blue tinted background
 * across the whole row, with the brand accent strip on the left
 * edge and bold blue text. Matches the user's reference. */
.page-row.active {
  background: rgba(45, 127, 198, .10) !important;
  border-color: transparent !important;
  box-shadow: none !important;
  color: var(--blue-dk) !important;
}
.page-row.active:hover {
  background: rgba(45, 127, 198, .14) !important;
}
.page-row.active .page-title {
  color: var(--blue-dk) !important;
  font-weight: 600 !important;
}
.page-row.active::before {
  content: '';
  position: absolute;
  left: 2px; top: 18%; bottom: 18%;
  width: 3px;
  border-radius: 2px;
  background: var(--accent-strip);
  animation: es-strip-in .2s var(--ease-out-fast);
}
.page-row.dragging { opacity: .35 !important; transform: scale(.97); }
.page-row.dragging::before { display: none; }
.page-handle {
  opacity: .4;
  transition: opacity var(--t-fast);
}
.page-row:hover .page-handle { opacity: 1; }

/* Modals — overlay glow + scale-in */
.modal-backdrop {
  background: radial-gradient(circle at 50% 30%, rgba(45, 127, 198, .18), rgba(8, 16, 32, .55) 70%) !important;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  display: flex !important;
  transition: opacity var(--t-med) var(--ease-out-fast), visibility 0s linear var(--t-med);
}
.modal-backdrop.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity var(--t-med) var(--ease-out-fast), visibility 0s;
}
.modal {
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, .8) !important;
  background: var(--gradient-surface) !important;
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255, 255, 255, .9) !important;
  transform: translateY(16px) scale(.96);
  opacity: 0;
  transition: transform .35s var(--ease-out-fast), opacity var(--t-med) var(--ease-out-fast);
}
body.dark .modal { border-color: rgba(255,255,255,.06) !important; }
.modal-backdrop.open .modal {
  transform: translateY(0) scale(1);
  opacity: 1;
}
.modal-head {
  padding: 20px 24px 16px !important;
  border-bottom: 1px solid var(--border) !important;
}
.modal-title {
  font: 700 17px sans-serif !important;
  letter-spacing: -.015em !important;
}
.modal-close {
  width: 34px !important; height: 34px !important;
  border-radius: 10px !important;
  background: rgba(255, 255, 255, .6) !important;
  transition: transform var(--t-fast) var(--ease-out-bouncy), background var(--t-fast), color var(--t-fast) !important;
}
.modal-close:hover {
  background: var(--white) !important;
  transform: rotate(90deg);
}
.modal-body { padding: 18px 22px !important; }
.modal-foot {
  padding: 16px 22px !important;
  background: linear-gradient(180deg, rgba(248, 250, 255, 0) 0%, rgba(241, 245, 252, .8) 100%) !important;
  border-top: 1px solid var(--border) !important;
}
body.dark .modal-foot { background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.2)) !important; }

/* Picker rows inside modals */
.picker-row {
  border-radius: 12px !important;
  padding: 12px 14px !important;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy), box-shadow var(--t-fast) !important;
}
.picker-row:hover {
  background: var(--blue-lt) !important;
  border-color: rgba(45, 127, 198, .35) !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.picker-row.current {
  background: linear-gradient(135deg, rgba(45,127,198,.12), rgba(99,102,241,.12)) !important;
  border-color: var(--blue) !important;
}
.picker-icon {
  width: 34px !important; height: 34px !important;
  border-radius: 10px !important;
  background: var(--gradient-primary) !important;
  color: #fff !important;
  box-shadow: var(--shadow-xs);
}
.picker-title {
  font: 600 13.5px sans-serif !important;
  letter-spacing: -.005em !important;
}

/* Side pane (edit-estimate.html) — glass treatment matching the
 * sub-sidebar. */
.side-pane {
  background: var(--es-glass-bg) !important;
  backdrop-filter: blur(20px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(140%) !important;
  border-right: 1px solid var(--es-glass-bd) !important;
  box-shadow: none !important;
  font-family: 'Inter', sans-serif !important;
}
.side-section {
  border-bottom: 1px solid var(--border-soft) !important;
}
.side-section-head {
  padding: 18px 22px 12px !important;
  transition: background var(--t-fast);
  cursor: pointer;
}
.side-section-head:hover { background: var(--surface-muted); }
.side-section-title {
  font: 700 11px sans-serif !important;
  letter-spacing: .08em !important;
  text-transform: uppercase;
  color: var(--muted) !important;
}
.side-section-body { padding: 0 22px 18px !important; }
.side-row {
  padding: 10px 0 !important;
  border-top: 1px solid var(--border-soft) !important;
}
.side-row:first-child { border-top: none !important; }
.side-row-label {
  font: 500 12.5px sans-serif !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: var(--text-2) !important;
}
.side-row-value {
  font: 600 13.5px sans-serif !important;
  letter-spacing: -.005em;
}
.side-link {
  padding: 3px 9px !important;
  border-radius: 6px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: var(--blue-dk) !important;
  text-decoration: none !important;
  transition: background var(--t-fast), color var(--t-fast) !important;
}
.side-link:hover {
  background: var(--blue-lt);
  color: var(--blue);
}
.side-row-select {
  border-radius: 9px !important;
  padding: 9px 12px !important;
  border-color: var(--border-card) !important;
  background: var(--surface) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  transition: border-color var(--t-fast), box-shadow var(--t-fast) !important;
}
.side-row-select:hover { border-color: var(--border-hi) !important; }
.side-row-select:focus {
  outline: none;
  border-color: var(--blue) !important;
  box-shadow: var(--glow-blue) !important;
}

/* Add Page / Custom Page button */
.add-page-btn {
  border-radius: 11px !important;
  border: 1px dashed rgba(45, 127, 198, .35) !important;
  background: rgba(45, 127, 198, .04) !important;
  transition: background var(--t-fast), border-color var(--t-fast), transform var(--t-fast) var(--ease-out-bouncy) !important;
}
.add-page-btn:hover {
  background: rgba(45, 127, 198, .10) !important;
  border-color: var(--blue) !important;
  transform: translateY(-1px);
}

/* Internal Note */
.internal-note-section {
  padding: 14px 20px 18px !important;
  background: linear-gradient(180deg, #fff8e6 0%, #fef0d2 100%) !important;
  border-top: 1px solid rgba(217, 119, 6, .22) !important;
}
body.dark .internal-note-section { background: linear-gradient(180deg, #2a2410 0%, #1f1a0c 100%) !important; }
.internal-note-textarea {
  border-radius: 9px !important;
  transition: border-color var(--t-fast), box-shadow var(--t-fast) !important;
}
.internal-note-textarea:focus {
  outline: none;
  border-color: #b45309 !important;
  box-shadow: 0 0 0 3px rgba(217, 119, 6, .14) !important;
}

/* Editor card + stub — glass card with the same recipe as the
 * settings card. NO entrance animation here because renderEditor()
 * replaces innerHTML on every page click — playing a 500ms card-rise
 * each time made the UI feel like it was reloading. The card just
 * appears instantly when content swaps. */
.editor-main {
  padding: 32px 40px 60px !important;
  font-family: 'Inter', sans-serif !important;
}
.editor-card {
  position: relative;
  background: var(--es-glass-bg) !important;
  backdrop-filter: blur(20px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(140%) !important;
  border: 1px solid var(--es-glass-bd) !important;
  border-radius: 18px !important;
  box-shadow: var(--es-shadow-card) !important;
  padding: 28px 30px !important;
  overflow: hidden;
  font-family: 'Inter', sans-serif !important;
}
.editor-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--accent-strip);
  opacity: .85;
}
.editor-stub {
  background: rgba(232, 242, 255, .35) !important;
  border: 1px solid var(--es-line-soft) !important;
  border-radius: 14px !important;
  padding: 48px 32px !important;
}
.editor-stub strong {
  font: 700 15px 'Inter', sans-serif !important;
  letter-spacing: -.01em !important;
  color: var(--text) !important;
  margin-bottom: 8px !important;
}
.editor-empty { animation: es-fade-in .4s var(--ease-out-fast); }
.editor-page-name input {
  font: 700 19px sans-serif !important;
  letter-spacing: -.015em !important;
  border-radius: 8px !important;
  padding: 4px 10px !important;
  transition: border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast) !important;
}
.editor-page-name input:focus {
  outline: none;
  border-color: var(--blue) !important;
  background: var(--white) !important;
  box-shadow: var(--glow-blue) !important;
}
.page-type-pill {
  background: linear-gradient(135deg, rgba(45,127,198,.14), rgba(99,102,241,.14)) !important;
  color: var(--blue-dk) !important;
  border-radius: 999px !important;
  padding: 3px 11px !important;
}

/* Pages section in side pane */
.pages-empty {
  padding: 14px 12px !important;
  text-align: center;
  color: var(--muted) !important;
  font-size: 12.5px;
  font-style: italic;
}
.page-title {
  font: 500 13.5px sans-serif !important;
  letter-spacing: -.005em !important;
}

/* Form fields in modals */
.field input, .field textarea {
  border-radius: 10px !important;
  padding: 10px 13px !important;
  transition: border-color var(--t-fast), box-shadow var(--t-fast) !important;
}
.field input:focus, .field textarea:focus {
  outline: none;
  border-color: var(--blue) !important;
  box-shadow: var(--glow-blue) !important;
}
.field label {
  font: 600 11px sans-serif !important;
  letter-spacing: .06em !important;
  text-transform: uppercase;
  color: var(--muted) !important;
}

/* Body — Inter font + radial-gradient background. This is the
 * customer.html recipe verbatim: a calm gray base with two soft
 * glowing radial gradients (purple top-left, blue bottom-right)
 * that give the surface life without being loud. */
body {
  font: 14px/1.45 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  letter-spacing: -.005em !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background:
    radial-gradient(900px 600px at 8% -8%, rgba(124, 58, 237, .06), transparent 60%),
    radial-gradient(720px 480px at 96% 102%, rgba(59, 130, 246, .08), transparent 55%),
    #f0f4fa !important;
  background-attachment: fixed !important;
}
body.dark {
  background:
    radial-gradient(900px 600px at 8% -8%, rgba(124, 58, 237, .08), transparent 60%),
    radial-gradient(720px 480px at 96% 102%, rgba(59, 130, 246, .10), transparent 55%),
    #0c1828 !important;
}

/* Layout search input — clean, calm, generous padding. */
.layouts-search {
  padding: 12px 16px 12px 42px !important;
  border-radius: 11px !important;
  border: 1px solid var(--border-card) !important;
  background: var(--surface) !important;
  font-size: 14px !important;
  transition: border-color var(--t-fast), box-shadow var(--t-fast) !important;
}
.layouts-search:hover { border-color: var(--border-hi) !important; }
.layouts-search:focus {
  outline: none;
  border-color: var(--blue) !important;
  box-shadow: var(--glow-blue) !important;
}
.layouts-search-wrap { margin-bottom: 20px !important; }
.layouts-search-wrap::before {
  left: 16px !important;
}

/* Drop indicators reinforced */
.page-row.drop-target-before { box-shadow: 0 -2px 0 var(--blue) !important; }
.page-row.drop-target-after  { box-shadow: 0  2px 0 var(--blue) !important; }

/* ════════════════════════════════════════════════════════════
 * BUTTON ANIMATION PACKAGE
 *
 * Layered onto every button-like element in the estimate system:
 *  1. Press feedback — every button scales to .96 on :active for
 *     tactile click confirmation
 *  2. Shimmer — primary CTAs sweep a soft highlight on hover so the
 *     button feels alive
 *  3. Icon micro-animations — "+" rotates, trash wiggles, back-arrow
 *     slides, save-icon spins, etc.
 *  4. Spring entrances — newly-added rows / pickers fade-up
 *  5. Reduced-motion respect — all of the above collapse to fades
 *     when the user has prefers-reduced-motion: reduce set
 * ════════════════════════════════════════════════════════════ */

/* 1. Universal press feedback for buttons + interactive rows ONLY.
 *    Toggles excluded — their slide animation is the feedback. Page
 *    rows + subnav also excluded so clicks don't feel "twitchy" when
 *    the active state changes. Only real buttons get the press-scale. */
.es-btn:active,
.es-btn-primary:active,
.btn:active,
.btn-review:active,
.tb-btn:active,
.tb-back:active,
.add-page-btn:active,
.es-add-page-btn:active,
.modal-close:active,
.es-modal-close:active,
.side-link:active,
.es-side-link:active {
  transform: scale(.96) !important;
  transition-duration: 80ms !important;
}
/* Re-apply hover lift after press (translateY composes with scale). */
.es-btn-primary:active,
.btn-review:active,
.tb-btn.primary:active,
.btn.primary:active {
  transform: translateY(0) scale(.96) !important;
}

/* 2. Shimmer/shine sweep on primary CTAs. A diagonal white-to-clear
 *    gradient slides across the button on hover. Implemented with
 *    a pseudo-element that's clipped by the button's rounded corners. */
.btn-review,
.btn.primary,
.tb-btn.primary,
.es-btn-primary {
  position: relative;
  overflow: hidden;
}
.btn-review::before,
.btn.primary::before,
.tb-btn.primary::before,
.es-btn-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.28) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .7s cubic-bezier(.4, 0, .2, 1);
  pointer-events: none;
}
.btn-review:hover::before,
.btn.primary:hover::before,
.tb-btn.primary:hover::before,
.es-btn-primary:hover::before {
  transform: translateX(100%);
}

/* 3. Icon micro-animations.
 *    Targets buttons by their data-action / title attributes so they
 *    apply only where the matching semantic exists. */

/* "Plus" icons (+ Estimate Layout, + Custom Page, + Add Page) rotate
 *    90° on hover so the cross hints at "open a picker / create." */
.add-page-btn:hover svg,
.es-add-page-btn:hover svg,
.tb-btn.primary svg,
.btn.primary svg,
.es-btn-primary svg,
button[onclick*="openJobModal"] svg,
button[onclick*="createNewEstimateV2"] svg {
  transition: transform var(--t-med) var(--ease-out-bouncy);
}
.add-page-btn:hover svg,
.es-add-page-btn:hover svg {
  transform: rotate(90deg) scale(1.05);
}

/* Back arrow slides left further when the back button is hovered. */
.tb-back svg, .es-tb-back svg {
  transition: transform var(--t-med) var(--ease-out-bouncy);
}
.tb-back:hover svg, .es-tb-back:hover svg {
  transform: translateX(-2px);
}

/* Trash icons wiggle on hover. */
.btn.danger svg,
.es-btn.danger svg,
.btn[data-delete] svg,
.btn[data-tmpl-delete] svg,
.btn[title="Delete"] svg {
  transform-origin: 50% 70%;
  transition: transform .3s var(--ease-out-bouncy);
}
.btn.danger:hover svg,
.es-btn.danger:hover svg,
.btn[data-delete]:hover svg,
.btn[data-tmpl-delete]:hover svg,
.btn[title="Delete"]:hover svg {
  animation: es-wiggle .5s var(--ease-out-fast);
}
@keyframes es-wiggle {
  0%, 100% { transform: rotate(0); }
  20% { transform: rotate(-12deg); }
  40% { transform: rotate(10deg); }
  60% { transform: rotate(-7deg); }
  80% { transform: rotate(5deg); }
}

/* Pencil/edit icons tilt slightly on hover. */
.btn[data-edit] svg,
.btn[title="Edit"] svg,
.btn[data-tmpl-edit] svg {
  transform-origin: 25% 75%;
  transition: transform var(--t-med) var(--ease-out-bouncy);
}
.btn[data-edit]:hover svg,
.btn[title="Edit"]:hover svg,
.btn[data-tmpl-edit]:hover svg {
  transform: rotate(-15deg) translateY(-1px);
}

/* Duplicate icons (overlapping rectangles) shift on hover. */
.btn[data-duplicate] svg,
.btn[title="Duplicate"] svg {
  transition: transform var(--t-med) var(--ease-out-bouncy);
}
.btn[data-duplicate]:hover svg,
.btn[title="Duplicate"]:hover svg {
  transform: translate(2px, -2px);
}

/* Refresh icons spin on hover (used in Engage refresh button). */
.tb-btn[title="Refresh inbox"] svg,
.btn[title="Refresh"] svg {
  transition: transform .6s var(--ease-out-fast);
}
.tb-btn[title="Refresh inbox"]:hover svg,
.btn[title="Refresh"]:hover svg {
  transform: rotate(360deg);
}

/* 4. Toggle switch — smooth slide, no bounce. Removed the press-
 * scale that was fighting the slide animation and causing the
 * "stick then jolt" feel the user reported. Now the knob just glides
 * across with an ease-out curve. The background color also transitions
 * smoothly. */
.toggle, .page-toggle, .es-toggle {
  transition: background-color .25s ease-out, background .25s ease-out !important;
}
.toggle::after,
.page-toggle::after,
.es-toggle::after {
  transition: transform .25s ease-out, box-shadow .25s ease-out !important;
}
.toggle.on::after,
.page-toggle.on::after,
.es-toggle.on::after {
  box-shadow: 0 2px 6px rgba(45, 127, 198, .35) !important;
}
/* No press-scale on toggles — it was the source of the jolt. The
 * background color change + knob slide give enough click feedback. */

/* 5. Section chevrons rotate smoothly. */
.side-section-chevron,
.es-side-section-chevron,
.subnav-group-chevron,
.es-subnav-group-chevron {
  transition: transform .25s var(--ease-out-bouncy) !important;
}

/* Page rows: NO entrance animation. The pages list re-renders on every
 * page click (active state swap), so playing an animation each time
 * makes the list feel like it's constantly reloading. */
@keyframes es-row-in {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
.page-row.dragging,
.es-page-row.dragging {
  transition: opacity var(--t-fast), transform var(--t-fast) var(--ease-out-fast) !important;
}

/* 7. Picker rows in modals stagger-fade-in. */
.es-modal-backdrop.open .picker-row,
.modal-backdrop.open .picker-row,
.es-modal-backdrop.open .es-picker-row,
.modal-backdrop.open .es-picker-row {
  animation: es-row-in .35s var(--ease-out-fast) backwards;
}
.es-modal-backdrop.open .picker-row:nth-child(1),
.modal-backdrop.open .picker-row:nth-child(1) { animation-delay: 30ms; }
.es-modal-backdrop.open .picker-row:nth-child(2),
.modal-backdrop.open .picker-row:nth-child(2) { animation-delay: 60ms; }
.es-modal-backdrop.open .picker-row:nth-child(3),
.modal-backdrop.open .picker-row:nth-child(3) { animation-delay: 90ms; }
.es-modal-backdrop.open .picker-row:nth-child(4),
.modal-backdrop.open .picker-row:nth-child(4) { animation-delay: 120ms; }
.es-modal-backdrop.open .picker-row:nth-child(5),
.modal-backdrop.open .picker-row:nth-child(5) { animation-delay: 150ms; }
.es-modal-backdrop.open .picker-row:nth-child(6),
.modal-backdrop.open .picker-row:nth-child(6) { animation-delay: 180ms; }
.es-modal-backdrop.open .picker-row:nth-child(7),
.modal-backdrop.open .picker-row:nth-child(7) { animation-delay: 210ms; }
.es-modal-backdrop.open .picker-row:nth-child(n+8),
.modal-backdrop.open .picker-row:nth-child(n+8) { animation-delay: 240ms; }

/* 8. Focused / keyboard-navigation halo (accessibility + polish). */
.es-btn:focus-visible,
.es-btn-primary:focus-visible,
.btn:focus-visible,
.btn-review:focus-visible,
.tb-btn:focus-visible,
.tb-back:focus-visible,
.subnav-item:focus-visible,
.es-subnav-item:focus-visible,
.side-link:focus-visible,
.es-side-link:focus-visible,
.modal-close:focus-visible,
.es-modal-close:focus-visible {
  outline: none !important;
  box-shadow: var(--glow-blue) !important;
}

/* 9. Loading state — when a button is being clicked-but-waiting,
 *    add class "loading" via JS to spin the inner icon. */
.es-btn.loading svg,
.btn.loading svg,
.es-btn-primary.loading svg,
.btn-review.loading svg,
.tb-btn.loading svg {
  animation: es-spin .8s linear infinite;
}
@keyframes es-spin {
  to { transform: rotate(360deg); }
}

/* 10. Reduced-motion respect. Users who set
 *     prefers-reduced-motion: reduce get just opacity transitions —
 *     no transforms, no shimmer, no shake. Maintains functionality
 *     and feedback without vestibular triggers. */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 60ms !important;
    scroll-behavior: auto !important;
  }
  .btn-review::before, .btn.primary::before,
  .tb-btn.primary::before, .es-btn-primary::before {
    display: none !important;
  }
  .btn:active, .es-btn:active, .btn-review:active,
  .es-btn-primary:active, .tb-back:active {
    transform: none !important;
  }
}

/* ════════════════════════════════════════════════════════════
 * PER-PAGE EDITORS — styles for components rendered by
 * estimate-page-editors.js. Each component prefixed with .ep-*
 * to avoid collisions.
 * ════════════════════════════════════════════════════════════ */

.ep-form { display: flex; flex-direction: column; gap: 18px; }
.ep-field { display: flex; flex-direction: column; gap: 6px; }
.ep-label {
  font: 700 11px 'Inter', sans-serif;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.ep-input, .ep-textarea {
  font: 500 14px 'Inter', sans-serif;
  letter-spacing: -.005em;
  padding: 10px 13px;
  border-radius: 10px;
  border: 1px solid #c5ccda;
  background: #ffffff;
  color: var(--text);
  transition: border-color .15s, box-shadow .15s;
}
.ep-input:hover, .ep-textarea:hover { border-color: #9aa3b5; }
.ep-input:focus, .ep-textarea:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(45, 127, 198, .15);
}
.ep-textarea { resize: vertical; min-height: 70px; font-family: 'Inter', sans-serif; }
.ep-hint { font: 500 12px 'Inter', sans-serif; color: var(--muted); }
.ep-help {
  font: 500 13px 'Inter', sans-serif;
  color: var(--text-2);
  background: rgba(45, 127, 198, .06);
  padding: 10px 14px;
  border-radius: 10px;
  border-left: 3px solid var(--blue);
  margin: 0 0 16px;
}
.ep-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ep-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
/* Cover-page certifications grid — 4 small upload slots in a row
 * for the top-row certification logos. On narrow viewports the slots
 * wrap to 2 columns. */
.ep-cover-certs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 900px) {
  .ep-cover-certs { grid-template-columns: 1fr 1fr; }
}
.ep-cover-cert-slot { display: flex; flex-direction: column; gap: 6px; }
.ep-cover-cert-label {
  font: 600 11px 'Inter', sans-serif;
  color: var(--muted);
  letter-spacing: .02em;
  text-transform: uppercase;
}
/* Inside a cert slot, shrink the upload zone so 4 fit comfortably. */
.ep-cover-cert-slot .ep-upload-drop { padding: 14px 10px; min-height: 92px; }
.ep-cover-cert-slot .ep-upload-text { font-size: 12px; }
.ep-cover-cert-slot .ep-upload-sub  { font-size: 11px; }
.ep-cover-cert-slot .ep-upload-job  { display: none; }
.ep-cover-cert-slot .ep-upload-grid { grid-template-columns: 1fr; }
.ep-cover-cert-slot .ep-upload-preview img { max-height: 110px; }
.ep-check {
  display: flex; align-items: center; gap: 9px;
  font: 500 13.5px 'Inter', sans-serif;
  color: var(--text);
  cursor: pointer;
  padding: 10px 12px;
  border-radius: 9px;
  border: 1px solid var(--border-card);
  background: #ffffff;
  transition: background .15s, border-color .15s;
}
.ep-check:hover { background: rgba(232, 242, 255, .35); border-color: var(--border-hi); }
.ep-check input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--blue); cursor: pointer; }

.ep-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  border-radius: 9px;
  font: 600 13px 'Inter', sans-serif;
  letter-spacing: -.005em;
  cursor: pointer;
  border: 1px solid var(--border-card);
  background: #ffffff;
  color: var(--text);
  transition: background .15s, border-color .15s, transform .12s cubic-bezier(.34, 1.4, .58, 1);
}
.ep-btn svg { width: 14px; height: 14px; }
.ep-btn:hover { background: rgba(232, 242, 255, .5); border-color: var(--blue-dk); color: var(--blue-dk); }
.ep-btn:active { transform: scale(.96); }
.ep-btn.primary {
  background: linear-gradient(135deg, #2d7fc6 0%, #1a5fa0 100%);
  color: #ffffff;
  border-color: transparent;
}
.ep-btn.primary:hover { color: #ffffff; box-shadow: 0 6px 16px -6px rgba(45, 127, 198, .55); }
.ep-btn.ghost {
  background: transparent;
  color: var(--text-2);
  border: 1px dashed var(--border-hi);
}
.ep-btn.ghost:hover { color: var(--blue-dk); border-color: var(--blue); }

/* Rich-text editor */
.ep-text-editor {
  display: flex; flex-direction: column;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border-card);
  background: #ffffff;
}
.ep-toolbar {
  display: flex; align-items: center; gap: 4px;
  padding: 8px 10px;
  background: var(--surface-muted);
  border-bottom: 1px solid var(--border-soft);
  flex-wrap: wrap;
}
.ep-tb-btn {
  width: 30px; height: 28px;
  border: none; background: transparent;
  border-radius: 6px;
  font: 600 13px 'Inter', sans-serif;
  color: var(--text-2);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .12s, color .12s, transform .1s cubic-bezier(.34, 1.4, .58, 1);
}
.ep-tb-btn:hover { background: rgba(45, 127, 198, .10); color: var(--blue-dk); }
.ep-tb-btn:active { transform: scale(.92); }
.ep-tb-sep { width: 1px; height: 18px; background: var(--border-soft); margin: 0 4px; }
.ep-content {
  min-height: 220px;
  padding: 18px 22px;
  font: 14.5px/1.6 'Inter', sans-serif;
  color: var(--text);
  letter-spacing: -.005em;
  outline: none;
}
.ep-content:focus { background: rgba(232, 242, 255, .12); }
.ep-content[data-placeholder]:empty::before {
  content: attr(data-placeholder);
  color: var(--muted);
}
.ep-content h2 { font: 700 20px 'Inter', sans-serif; margin: 16px 0 8px; color: #0e1b30; }
.ep-content h3 { font: 700 16px 'Inter', sans-serif; margin: 12px 0 6px; color: #0e1b30; }
.ep-content p  { margin: 0 0 10px; }
.ep-content ul, .ep-content ol { margin: 0 0 10px 22px; }
.ep-content li { margin-bottom: 4px; }

/* Estimate Details (line items) */
.ep-details-editor { font-family: 'Inter', sans-serif; }
.ep-toolbar-row { display: flex; gap: 8px; margin-bottom: 14px; }
.ep-lines-head, .ep-line {
  display: grid;
  grid-template-columns: 28px 1fr 70px 70px 100px 110px 36px;
  align-items: center;
  gap: 10px;
}
.ep-lines-head {
  padding: 10px 6px;
  font: 700 11px 'Inter', sans-serif;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  border-bottom: 1px solid var(--border-soft);
}
.ep-lines { display: flex; flex-direction: column; gap: 6px; padding-top: 6px; }
.ep-line {
  padding: 10px 6px;
  border-radius: 10px;
  background: #ffffff;
  border: 1px solid transparent;
  transition: background .12s, border-color .12s;
}
.ep-line:hover { background: rgba(232, 242, 255, .25); border-color: var(--border-soft); }
.ep-line.ep-dragging { opacity: .4; }
.ep-col-handle {
  display: flex; align-items: center; justify-content: center;
  color: var(--muted);
  cursor: grab;
  font-size: 14px;
  user-select: none;
}
.ep-col-handle:active { cursor: grabbing; }
.ep-col-name { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.ep-line-name, .ep-line-section, .ep-line-qty, .ep-line-unit, .ep-line-price, .ep-line-desc {
  font: 500 13.5px 'Inter', sans-serif;
  padding: 7px 10px;
  border-radius: 7px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text);
  transition: border-color .12s, background .12s;
}
.ep-line-name { font-weight: 600; }
.ep-line-desc { resize: none; min-height: 32px; font-size: 12.5px; color: var(--text-2); }
.ep-line-name:hover, .ep-line-qty:hover, .ep-line-unit:hover, .ep-line-price:hover, .ep-line-desc:hover {
  border-color: var(--border-card); background: #fff;
}
.ep-line-name:focus, .ep-line-qty:focus, .ep-line-unit:focus, .ep-line-price:focus, .ep-line-desc:focus {
  outline: none;
  border-color: var(--blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(45, 127, 198, .12);
}
.ep-col-total {
  text-align: right;
  font: 700 14px 'Inter', sans-serif;
  color: #0e1b30;
  padding-right: 8px;
}
.ep-line-del {
  width: 28px; height: 28px;
  border: none; background: transparent;
  border-radius: 6px;
  color: var(--muted);
  cursor: pointer;
  font: 700 18px 'Inter', sans-serif;
  transition: background .12s, color .12s, transform .12s cubic-bezier(.34, 1.4, .58, 1);
}
.ep-line-del:hover { background: rgba(239, 68, 68, .10); color: #dc2626; }
.ep-line-del:active { transform: scale(.88); }
.ep-line.section {
  grid-template-columns: 28px 1fr 36px;
  padding: 14px 6px 6px;
}
.ep-line-section {
  font: 700 15px 'Inter', sans-serif;
  color: #0e1b30;
  border-bottom: 2px solid var(--border-soft);
  border-radius: 0;
  padding: 8px 4px;
}
.ep-empty-row {
  padding: 28px 16px;
  text-align: center;
  color: var(--muted);
  font: 500 14px 'Inter', sans-serif;
  background: var(--surface-muted);
  border-radius: 10px;
  border: 1px dashed var(--border-card);
}
.ep-empty-row em { color: var(--blue-dk); font-style: normal; font-weight: 600; }

.ep-totals {
  margin-top: 18px;
  padding: 16px 18px;
  border-radius: 12px;
  background: var(--surface-muted);
  border: 1px solid var(--border-soft);
  max-width: 360px;
  margin-left: auto;
}
.ep-totals-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 0;
  font: 500 13.5px 'Inter', sans-serif;
  color: var(--text-2);
}
.ep-totals-row.total {
  border-top: 1px solid var(--border-soft);
  margin-top: 8px;
  padding-top: 14px;
  font: 700 16px 'Inter', sans-serif;
  color: #0e1b30;
}
.ep-tax-input {
  width: 60px;
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid var(--border-card);
  font: 600 13px 'Inter', sans-serif;
  color: var(--text);
  margin: 0 4px;
  text-align: right;
}
.ep-tax-input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 2px rgba(45, 127, 198, .15);
}

/* Signing Upgrades */
.ep-upgrade-head, .ep-upgrade-row {
  display: grid;
  grid-template-columns: 1.2fr 2fr 100px 36px;
  gap: 10px;
  align-items: center;
}
.ep-upgrade-head {
  padding: 10px 6px;
  font: 700 11px 'Inter', sans-serif;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  border-bottom: 1px solid var(--border-soft);
}
.ep-upgrades { display: flex; flex-direction: column; gap: 6px; padding-top: 6px; }
.ep-upgrade-row {
  padding: 10px 6px;
  border-radius: 10px;
  background: #ffffff;
  border: 1px solid transparent;
  transition: background .12s, border-color .12s;
}
.ep-upgrade-row:hover { background: rgba(232, 242, 255, .25); border-color: var(--border-soft); }
.ep-upgrade-name, .ep-upgrade-desc, .ep-upgrade-price {
  font: 500 13.5px 'Inter', sans-serif;
  padding: 7px 10px;
  border-radius: 7px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text);
  transition: border-color .12s, background .12s;
}
.ep-upgrade-name { font-weight: 600; }
.ep-upgrade-name:hover, .ep-upgrade-desc:hover, .ep-upgrade-price:hover {
  border-color: var(--border-card); background: #fff;
}
.ep-upgrade-name:focus, .ep-upgrade-desc:focus, .ep-upgrade-price:focus {
  outline: none;
  border-color: var(--blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(45, 127, 198, .12);
}
.ep-upgrade-del {
  width: 28px; height: 28px;
  border: none; background: transparent;
  border-radius: 6px;
  color: var(--muted);
  cursor: pointer;
  font: 700 18px 'Inter', sans-serif;
  transition: background .12s, color .12s, transform .12s cubic-bezier(.34, 1.4, .58, 1);
}
.ep-upgrade-del:hover { background: rgba(239, 68, 68, .10); color: #dc2626; }
.ep-upgrade-del:active { transform: scale(.88); }

@media (max-width: 900px) {
  .ep-lines-head, .ep-line {
    grid-template-columns: 24px 1fr 60px 90px 36px;
    font-size: 12.5px;
  }
  .ep-col-unit, .ep-line-unit { display: none; }
  .ep-col-total { font-size: 13px; }
  .ep-upgrade-head, .ep-upgrade-row {
    grid-template-columns: 1fr 80px 36px;
  }
  .ep-upgrade-desc { display: none; }
}

/* ════════════════════════════════════════════════════════════
 * EDITOR REWRITE (v333) — sections, floating labels, banner,
 * upload boxes, signers, selections, deposit, token dropdown,
 * inspection items, JobNimbus-style switch toggles, etc.
 * ════════════════════════════════════════════════════════════ */

/* Section blocks within an editor */
.ep-section {
  background: #ffffff;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  padding: 20px 22px;
  margin: 0 0 18px;
}
.ep-section-title {
  display: flex; align-items: center; justify-content: space-between;
  font: 600 13.5px 'Inter', sans-serif;
  color: var(--text-2);
  margin-bottom: 14px;
}
.ep-section-title > span { letter-spacing: -.005em; }
/* Header row that pairs a section title with a small action link
 * on the right (e.g. "Autofill from Job"). Replaces the .ep-section-
 * title block when you need a button alongside the heading. */
.ep-section-title-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
  gap: 12px;
}
.ep-section-title-row .ep-section-title { margin-bottom: 0; flex: 1; }

/* Read-only card used for the Cover page's Customer Details — the
 * fields aren't editable here because the cover is live-linked to
 * the job. Visual: light surface background, rows of label + value
 * stacked, a soft caption at the bottom explaining the bind. */
.ep-readonly-card {
  background: var(--surface-muted);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  padding: 16px 18px;
}
.ep-readonly-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 12px;
  padding: 6px 0;
  font: 500 13px 'Inter', sans-serif;
}
.ep-readonly-row + .ep-readonly-row {
  border-top: 1px solid rgba(45, 64, 96, .06);
}
.ep-readonly-label {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .03em;
  padding-top: 2px;
}
.ep-readonly-value { color: var(--text); }
.ep-readonly-note {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(45, 64, 96, .08);
  font: 500 11.5px 'Inter', sans-serif;
  color: var(--muted);
  letter-spacing: -.005em;
}

/* Floating-label inputs */
.ep-input-group {
  position: relative;
  flex: 1;
}
.ep-input-group.disabled { opacity: .5; }
.ep-floating-label {
  position: absolute;
  top: -7px; left: 12px;
  background: #ffffff;
  padding: 0 6px;
  font: 500 11px 'Inter', sans-serif;
  letter-spacing: .04em;
  color: var(--text-2);
  z-index: 1;
}
.ep-floating-label.small { font-size: 10.5px; }
.ep-input-group .ep-input {
  width: 100%;
  padding: 14px 14px 13px;
  border-radius: 8px;
  border: 1px solid #c5ccda;
  font: 500 14px 'Inter', sans-serif;
  color: var(--text);
  background: #ffffff;
  transition: border-color .15s, box-shadow .15s;
}
.ep-input-group .ep-input:hover { border-color: #9aa3b5; }
.ep-input-group .ep-input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(45, 127, 198, .12);
}
.ep-input-group .ep-input:disabled {
  background: var(--surface-muted);
  color: var(--muted);
  cursor: not-allowed;
}

/* Layout-context banner (T&C, Warranty) */
.ep-banner {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px;
  background: rgba(45, 127, 198, .07);
  border: 1px solid rgba(45, 127, 198, .18);
  border-radius: 10px;
  margin: 0 0 18px;
  font: 500 13px 'Inter', sans-serif;
  color: var(--text-2);
}
.ep-banner svg { width: 18px; height: 18px; color: var(--blue); flex-shrink: 0; }
.ep-banner span { flex: 1; }
.ep-banner-link {
  color: var(--blue-dk);
  text-decoration: none;
  font-weight: 600;
  white-space: nowrap;
}
.ep-banner-link:hover { text-decoration: underline; }

/* Acknowledge / deposit toggle row */
.ep-toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 18px;
  padding: 0 0 14px;
}
.ep-toggle-title {
  font: 600 14px 'Inter', sans-serif;
  color: var(--text);
  letter-spacing: -.005em;
}
.ep-toggle-sub {
  font: 500 12.5px 'Inter', sans-serif;
  color: var(--muted);
  margin-top: 2px;
}
.ep-switch {
  position: relative;
  display: inline-block;
  width: 40px; height: 22px;
  flex-shrink: 0;
}
.ep-switch input { opacity: 0; width: 0; height: 0; }
.ep-switch-track {
  position: absolute; cursor: pointer;
  inset: 0;
  background: #cbd5e1;
  border-radius: 999px;
  transition: background .25s ease-out;
}
.ep-switch-track::after {
  content: '';
  position: absolute;
  top: 3px; left: 3px;
  width: 16px; height: 16px;
  background: #ffffff;
  border-radius: 50%;
  transition: transform .25s ease-out, box-shadow .25s ease-out;
  box-shadow: 0 1px 3px rgba(0,0,0,.15);
}
.ep-switch input:checked + .ep-switch-track { background: var(--blue); }
.ep-switch input:checked + .ep-switch-track::after {
  transform: translateX(18px);
  box-shadow: 0 2px 6px rgba(45, 127, 198, .4);
}

/* Radio buttons (Page Type) */
.ep-radio-group {
  display: flex; flex-direction: column; gap: 8px;
  margin: 0 0 18px;
}
.ep-radio-group .ep-label { margin-bottom: 6px; }
.ep-radio {
  display: flex; align-items: center; gap: 10px;
  cursor: pointer;
  font: 500 14px 'Inter', sans-serif;
  color: var(--text);
}
.ep-radio input[type="radio"] { width: 18px; height: 18px; accent-color: var(--blue); cursor: pointer; }

/* Upload box */
.ep-upload {
  width: 100%;
}
.ep-upload-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 2px dashed var(--border-hi);
  border-radius: 12px;
  overflow: hidden;
  background: #ffffff;
  min-height: 110px;
}
.ep-upload-drop {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 6px;
  padding: 22px 16px;
  cursor: pointer;
  text-align: center;
  border-right: 1px dashed var(--border-hi);
  transition: background .15s;
}
.ep-upload-drop:hover { background: rgba(232, 242, 255, .25); }
.ep-upload-drop svg { width: 26px; height: 26px; color: var(--muted); }
.ep-upload-text {
  font: 500 13.5px 'Inter', sans-serif;
  color: var(--text-2);
}
.ep-upload-text b { color: var(--blue-dk); font-weight: 700; }
.ep-upload-sub {
  font: 500 11.5px 'Inter', sans-serif;
  color: var(--muted);
}
.ep-upload-job {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 6px;
  padding: 22px 16px;
  cursor: pointer;
  background: transparent;
  border: none;
  font: 600 13.5px 'Inter', sans-serif;
  color: var(--blue-dk);
  transition: background .15s, color .15s;
}
.ep-upload-job svg { width: 22px; height: 22px; }
.ep-upload-job:hover { background: rgba(45, 127, 198, .06); color: var(--blue); }
.ep-upload-preview {
  margin-top: 10px;
  padding: 12px;
  background: var(--surface-muted);
  border-radius: 10px;
  display: flex; justify-content: center;
  position: relative;
}
.ep-upload-preview img {
  max-width: 100%;
  max-height: 240px;
  border-radius: 6px;
}
/* Floating pencil-edit button overlay — admin clicks to re-open the
 * crop/zoom modal on an already-saved image. Sits top-right of the
 * preview, lifts on hover. */
.ep-upload-edit {
  position: absolute;
  top: 8px; right: 8px;
  width: 32px; height: 32px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, .95);
  color: var(--text);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 12px -4px rgba(8, 18, 36, .25);
  transition: background var(--t-fast), transform var(--t-fast);
}
.ep-upload-edit:hover {
  background: var(--blue-dk);
  color: #ffffff;
  transform: scale(1.05);
}
.ep-upload-edit svg { width: 15px; height: 15px; }
/* While the upload POST is in flight, show a subtle pulsing overlay
 * + cursor wait. Once it returns, the persistent URL replaces the
 * object URL and this state clears. */
.ep-upload-uploading .ep-upload-grid { opacity: .6; pointer-events: none; }
.ep-upload-uploading .ep-upload-preview img { opacity: .7; }
.ep-upload-uploading .ep-upload-preview::after {
  content: 'Uploading…';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(15, 32, 64, .85);
  color: #ffffff;
  font: 600 12.5px 'Inter', sans-serif;
  letter-spacing: .04em;
  padding: 7px 14px;
  border-radius: 999px;
  box-shadow: 0 4px 12px -4px rgba(0,0,0,.3);
  animation: ep-upload-pulse 1.2s ease-in-out infinite;
}
@keyframes ep-upload-pulse {
  0%, 100% { transform: translate(-50%, -50%) scale(1); }
  50%      { transform: translate(-50%, -50%) scale(1.05); }
}

/* Rich-text editor */
.ep-rt {
  border: 1px solid var(--border-card);
  border-radius: 10px;
  overflow: hidden;
  background: #ffffff;
}
.ep-rt.compact .ep-rt-body { min-height: 110px; padding: 12px 14px; }
.ep-rt-bar {
  display: flex; align-items: center;
  gap: 2px;
  padding: 6px 10px;
  background: var(--surface-muted);
  border-bottom: 1px solid var(--border-soft);
}
.ep-rt-bar-right { margin-left: auto; }
.ep-rt .ep-tb-btn {
  width: 30px; height: 28px;
  border: none; background: transparent;
  border-radius: 6px;
  font: 600 13px 'Inter', sans-serif;
  color: var(--text-2);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .12s, color .12s;
}
.ep-rt .ep-tb-btn svg { width: 15px; height: 15px; }
.ep-rt .ep-tb-btn:hover { background: rgba(45, 127, 198, .10); color: var(--blue-dk); }
.ep-rt-body {
  min-height: 220px;
  padding: 16px 18px;
  font: 14px/1.6 'Inter', sans-serif;
  color: var(--text);
  letter-spacing: -.005em;
  outline: none;
}
.ep-rt-body:focus { background: rgba(232, 242, 255, .08); }
.ep-rt-body[data-placeholder]:empty::before {
  content: attr(data-placeholder);
  color: var(--muted);
  pointer-events: none;
}
.ep-rt-body p { margin: 0 0 12px; }
.ep-rt-body ul, .ep-rt-body ol { margin: 0 0 12px 22px; }
.ep-rt-body li { margin-bottom: 6px; }

/* Insert token dropdown */
.ep-token-wrap { position: relative; }
.ep-token-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px;
  background: transparent;
  border: none;
  font: 600 12.5px 'Inter', sans-serif;
  color: var(--text-2);
  cursor: pointer;
  border-radius: 6px;
  transition: background .12s, color .12s;
}
.ep-token-btn svg { width: 11px; height: 11px; }
.ep-token-btn:hover { background: rgba(45, 127, 198, .10); color: var(--blue-dk); }
.ep-token-menu {
  position: absolute;
  top: 100%; right: 0;
  margin-top: 4px;
  min-width: 230px;
  background: #ffffff;
  border: 1px solid var(--border-card);
  border-radius: 10px;
  box-shadow: 0 12px 32px -8px rgba(15, 32, 64, .18);
  z-index: 30;
  padding: 8px 0;
  max-height: 320px;
  overflow-y: auto;
}
.ep-token-menu[hidden] { display: none; }
.ep-token-group {
  padding: 4px 0;
  border-bottom: 1px solid var(--border-soft);
}
.ep-token-group:last-child { border-bottom: none; }
.ep-token-group-label {
  padding: 6px 14px 4px;
  font: 700 10.5px 'Inter', sans-serif;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.ep-token-item {
  display: block; width: 100%;
  padding: 8px 14px;
  background: transparent;
  border: none;
  text-align: left;
  font: 500 13px 'Inter', sans-serif;
  color: var(--text);
  cursor: pointer;
  transition: background .12s, color .12s;
}
.ep-token-item:hover { background: rgba(45, 127, 198, .08); color: var(--blue-dk); }

/* Inspection sections + items */
.ep-insp-section-head {
  display: flex; align-items: flex-start; gap: 14px;
  margin-bottom: 12px;
}
.ep-insp-style {
  display: flex; align-items: center; gap: 6px;
  margin: 0 0 16px;
  font: 500 13px 'Inter', sans-serif;
  color: var(--text-2);
}
.ep-insp-style-label { font-weight: 600; color: var(--muted); }
.ep-text-link {
  background: transparent;
  border: none;
  color: var(--blue-dk);
  font: 600 13px 'Inter', sans-serif;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
}
.ep-text-link:hover { background: rgba(45, 127, 198, .06); text-decoration: underline; }
.ep-insp-items { display: flex; flex-direction: column; gap: 14px; }
.ep-insp-item {
  display: grid;
  grid-template-columns: 24px 280px 1fr 28px;
  gap: 14px;
  align-items: start;
}
.ep-insp-handle {
  color: var(--muted);
  cursor: grab;
  font-size: 14px;
  user-select: none;
  padding-top: 16px;
}
.ep-insp-handle:active { cursor: grabbing; }
.ep-insp-item-rt { min-width: 0; }
.ep-insp-del {
  background: transparent; border: none;
  width: 28px; height: 28px;
  border-radius: 6px;
  color: var(--muted);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .12s, color .12s;
}
.ep-insp-del:hover { background: rgba(239, 68, 68, .10); color: #dc2626; }
.ep-insp-del svg { width: 16px; height: 16px; }

/* Add Photo / Add Section buttons (dark navy) */
.ep-row-left { display: flex; align-items: center; }
.ep-row-right { display: flex; align-items: center; justify-content: flex-end; }
.ep-row-between { display: flex; align-items: center; justify-content: space-between; }
.ep-btn.primary.dark {
  background: #112244;
  color: #ffffff;
  border: none;
}
.ep-btn.primary.dark:hover {
  background: #1a3265;
  box-shadow: 0 6px 16px -6px rgba(17, 34, 68, .55);
}

/* Signing & Upgrades — Upgrades table */
.ep-upg-head, .ep-upg-row {
  display: grid;
  grid-template-columns: 1.4fr 80px 90px 100px 100px 32px;
  gap: 10px;
  align-items: center;
  padding: 6px 8px;
}
.ep-upg-head {
  font: 700 11px 'Inter', sans-serif;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--muted);
  border-bottom: 1px solid var(--border-soft);
}
.ep-upg-rows { display: flex; flex-direction: column; gap: 4px; }
.ep-upg-row {
  background: #ffffff;
  border-radius: 8px;
  border: 1px solid transparent;
  transition: background .12s, border-color .12s;
}
.ep-upg-row:hover { background: rgba(232, 242, 255, .25); border-color: var(--border-soft); }
.ep-upg-row input {
  padding: 7px 9px;
  border-radius: 6px;
  border: 1px solid transparent;
  font: 500 13px 'Inter', sans-serif;
  color: var(--text);
  background: transparent;
  width: 100%;
  transition: border-color .12s, background .12s;
}
.ep-upg-row input:hover { border-color: var(--border-card); background: #fff; }
.ep-upg-row input:focus {
  outline: none;
  border-color: var(--blue);
  background: #fff;
  box-shadow: 0 0 0 2px rgba(45, 127, 198, .12);
}
.ep-upg-line-total {
  text-align: right;
  font: 700 13px 'Inter', sans-serif;
  color: #0e1b30;
  padding-right: 6px;
}
.ep-upg-row [data-role="del-upg"] {
  background: transparent; border: none;
  width: 26px; height: 26px;
  border-radius: 6px;
  color: var(--muted);
  font: 700 16px 'Inter', sans-serif;
  cursor: pointer;
  transition: background .12s, color .12s;
}
.ep-upg-row [data-role="del-upg"]:hover { background: rgba(239, 68, 68, .10); color: #dc2626; }
.ep-upg-section-total {
  font: 500 13px 'Inter', sans-serif;
  color: var(--text-2);
}
.ep-upg-section-total strong { color: #0e1b30; font-weight: 700; margin-left: 6px; }
.ep-add-split { display: flex; align-items: stretch; }
.ep-add-split .ep-btn:first-child { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.ep-add-split-chev {
  border-left: none;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  padding: 8px 10px;
}

/* Deposit */
.ep-deposit-amt {
  display: flex; align-items: center; gap: 14px;
}
.ep-deposit-or {
  font: 500 13px 'Inter', sans-serif;
  color: var(--muted);
}

/* Signers */
.ep-signer {
  position: relative;
  padding: 14px;
  background: var(--surface-muted);
  border-radius: 10px;
  margin-bottom: 10px;
}
.ep-signer-del {
  position: absolute;
  top: 8px; right: 8px;
  width: 26px; height: 26px;
  border: none; background: transparent;
  border-radius: 6px;
  color: var(--muted);
  font: 700 18px 'Inter', sans-serif;
  cursor: pointer;
}
.ep-signer-del:hover { background: rgba(239, 68, 68, .10); color: #dc2626; }

/* Selections */
.ep-selection {
  padding: 14px;
  background: var(--surface-muted);
  border-radius: 10px;
  margin-bottom: 12px;
}
.ep-selection-head {
  display: flex; align-items: center; gap: 8px;
  font: 600 13px 'Inter', sans-serif;
  color: var(--text-2);
  margin-bottom: 12px;
}
.ep-help-inline {
  font: 500 12.5px 'Inter', sans-serif;
  color: var(--muted);
  margin: -6px 0 12px;
}

/* Embedded legacy Estimate Builder iframe inside Estimate Details.
 *
 * Goal: the iframe + editor card visually disappear. Only the editor
 * head (page title + Revert/Delete) and the legacy builder content
 * are visible — no padding, no border, no shadow, no rounded corners
 * around the embedded page. The embedded builder takes the full
 * width of the editor pane. */
.ep-details-fullbleed {
  margin: 0;
}
.ep-iframe-wrap {
  position: relative;
  width: 100%;
  margin: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  transition: height .12s ease-out;
  /* iframe is inline-block by default with a baseline-aligned space
   * underneath. Setting display:block on .ep-builder-iframe handles
   * that, but the wrap also gets line-height:0 as a belt-and-
   * suspenders against any whitespace that might sneak between the
   * editor-head bottom border and the iframe's top edge. */
  line-height: 0;
  font-size: 0;
}
.ep-iframe-wrap > * { font-size: 14px; line-height: 1.5; }
.ep-builder-iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
  background: transparent;
}

/* When Estimate Details is active, strip the editor-card chrome
 * entirely — no border, no shadow, no padding, no left accent strip,
 * no rounded corners. Editor head keeps its own padding so the page
 * title + Revert/Delete buttons stay readable. */
.editor-main:has(.ep-details-fullbleed) {
  padding: 0 !important;
}
.editor-card:has(.ep-details-fullbleed) {
  max-width: none !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
}
.editor-card:has(.ep-details-fullbleed)::before {
  display: none !important;
}
.editor-card:has(.ep-details-fullbleed) .editor-head {
  padding: 24px 32px 18px;
  background: #ffffff;
  border-bottom: 1px solid var(--border-soft);
}

/* "Open in Estimate Builder" link bar on Estimate Details */
.ep-legacy-link {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px;
  margin: 0 0 18px;
  background: linear-gradient(135deg, rgba(45,127,198,.08), rgba(99,102,241,.08));
  border: 1px solid rgba(45,127,198,.20);
  border-radius: 10px;
  font: 500 13px 'Inter', sans-serif;
  color: var(--text-2);
}
.ep-legacy-link svg { width: 16px; height: 16px; color: var(--blue); flex-shrink: 0; }
.ep-legacy-link span { flex: 1; letter-spacing: -.005em; }
.ep-legacy-link a {
  color: var(--blue-dk);
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
  padding: 4px 10px;
  border-radius: 6px;
  transition: background .12s, color .12s;
}
.ep-legacy-link a:hover {
  background: rgba(45,127,198,.10);
  color: var(--blue);
}

/* Icon edit pencil button */
.ep-icon-btn {
  width: 26px; height: 26px;
  border: none; background: transparent;
  border-radius: 6px;
  color: var(--muted);
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .12s, color .12s;
}
.ep-icon-btn svg { width: 14px; height: 14px; }
.ep-icon-btn:hover { background: rgba(45, 127, 198, .08); color: var(--blue-dk); }
