:root {
    --sidebar-width-expanded: 280px;
    --sidebar-width-collapsed: 84px;
    --topbar-height: 72px;
    --bg-base: #f4f7fb;
    --bg-panel: #ffffff;
    --bg-soft: #f8fbff;
    --bg-active: #294a78;
    --text-primary: #0f2d57;
    --text-secondary: #476887;
    --text-muted: #8ea3bd;
    --brand-navy: #143763;
    --brand-navy-hover: #1d4a82;
    --brand-green: #0d9b44;
    --brand-red: #c62828;
    --border: #d7e1eb;
    --shadow: 0 14px 32px rgba(20, 55, 99, 0.08);
}

body.app-auth-locked {
    overflow: hidden;
}

body:not(.app-auth-ready) .app-shell {
    visibility: hidden;
    pointer-events: none;
    user-select: none;
}

body.app-auth-locked .app-shell {
    visibility: hidden;
    filter: none;
    pointer-events: none;
    user-select: none;
}

.office-auth-overlay {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: grid;
    place-items: center;
    padding: 24px;
}

.office-auth-overlay__backdrop {
    position: absolute;
    inset: 0;
    background: var(--bg-base);
}

.office-auth-card {
    position: relative;
    width: min(100%, 440px);
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 30px 80px rgba(15, 23, 42, 0.26);
    overflow: hidden;
}

.office-auth-card__brand {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    padding: 20px 22px;
    background: linear-gradient(135deg, #173a63, #2b5f91);
    color: #f8fbff;
}

.office-auth-card__brand p,
.office-auth-card__body h1,
.office-auth-card__body p {
    margin: 0;
}

.office-auth-card__logo {
    width: 64px;
    height: 64px;
    border-radius: 14px;
    object-fit: contain;
    padding: 4px;
    background: #ffffff;
}

.office-auth-card__body {
    display: grid;
    gap: 16px;
    padding: 24px 22px 22px;
}

.office-auth-copy {
    color: #50667f;
}

.office-auth-field {
    display: grid;
    gap: 8px;
    color: #173a63;
    font-size: 14px;
    font-weight: 600;
}

.office-auth-field input {
    width: 100%;
    border: 1px solid #d6e2ee;
    border-radius: 14px;
    padding: 13px 14px;
    font: inherit;
    color: #10273f;
    background: #f8fbff;
}

.office-auth-message {
    color: #325c86;
    font-size: 14px;
    line-height: 1.5;
}

.office-auth-actions,
.settings-personal-mfa-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.office-auth-footer {
    margin-top: 4px;
    color: #5f7b99;
    font-size: 13px;
    line-height: 1.6;
    text-align: center;
}

.office-auth-footer a {
    color: #173a63;
    font-weight: 700;
    text-decoration: underline;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; overflow: hidden; }
[hidden] { display: none !important; }
body {
    font-family: 'Inter', sans-serif;
    background: var(--bg-base);
    color: var(--text-primary);
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
i[data-lucide] {
    display: inline-block;
    width: 1em;
    height: 1em;
    visibility: hidden;
    flex-shrink: 0;
}
svg.lucide {
    display: block;
    flex-shrink: 0;
}

.app-shell { display: flex; min-height: 100vh; height: 100vh; overflow: hidden; }
.sidebar-spacer { width: var(--sidebar-width-collapsed); flex-shrink: 0; transition: width .3s ease; }
.sidebar-spacer.locked { width: var(--sidebar-width-expanded); }
html[data-sidebar-locked="true"] .sidebar-spacer { width: var(--sidebar-width-expanded); }

.sidebar {
    position: fixed; top: 0; left: 0; bottom: 0;
    width: var(--sidebar-width-collapsed);
    background: var(--brand-navy);
    color: #fff;
    transition: width .3s ease;
    overflow-x: hidden;
    overflow-y: auto;
    z-index: 100;
    box-shadow: 10px 0 30px rgba(20, 55, 99, 0.14);
    display: flex;
    flex-direction: column;
}
html[data-sidebar-locked="true"] .sidebar { width: var(--sidebar-width-expanded); }
.sidebar:hover, .sidebar.locked { width: var(--sidebar-width-expanded); }
.sidebar-header {
    min-height: var(--topbar-height);
    display: flex;
    align-items: center;
    padding: 0 16px;
    border-bottom: 1px solid rgba(255,255,255,.14);
}
.sidebar-logo { max-width: 150px; max-height: 42px; object-fit: contain; }
.sidebar-logo-fallback {
    font-size: 0.92rem;
    line-height: 1.2;
    font-weight: 700;
    color: rgba(255,255,255,.96);
    word-break: break-word;
}
.sidebar-nav { flex: 1; display: flex; flex-direction: column; gap: 8px; padding: 20px 12px; }
.nav-category { border-radius: 10px; overflow: hidden; }
.category-btn {
    width: 100%; border: none; background: transparent; color: rgba(255,255,255,.94);
    padding: 13px 14px; display: flex; align-items: center; gap: 14px;
    border-radius: 10px; cursor: pointer; text-align: left;
}
.category-btn:hover, .nav-category.active .category-btn { background: rgba(255,255,255,.1); color: #fff; }
.nav-icon { width: 22px; height: 22px; min-width: 22px; margin-left: 4px; }
.nav-text, .chevron { opacity: 0; transition: opacity .15s ease; }
.nav-text { flex: 1; white-space: nowrap; font-weight: 600; }
.sidebar:hover .nav-text, .sidebar:hover .chevron, .sidebar.locked .nav-text, .sidebar.locked .chevron, html[data-sidebar-locked="true"] .sidebar .nav-text, html[data-sidebar-locked="true"] .sidebar .chevron { opacity: 1; }
.chevron { width: 18px; height: 18px; }
.nav-category.active .chevron { transform: rotate(180deg); }
.sub-nav {
    max-height: 0; overflow: hidden; display: flex; flex-direction: column; gap: 4px;
    margin-left: 22px; padding: 0 12px 0 28px; border-left: 1px solid rgba(255,255,255,.16);
    transition: max-height .25s ease, margin .25s ease, padding .25s ease;
}
.sidebar:hover .nav-category.active .sub-nav,
.sidebar.locked .nav-category.active .sub-nav,
html[data-sidebar-locked="true"] .sidebar .nav-category.active .sub-nav {
    max-height: 320px; margin-top: 8px; padding-bottom: 8px;
}
.sub-nav-link {
    font-size: .92rem; color: rgba(255,255,255,.82); padding: 8px 10px; border-radius: 8px;
}
.sub-nav-link.active, .sub-nav-link:hover { color: #fff; background: rgba(255,255,255,.08); }
.upgrade-card {
    background: linear-gradient(135deg, rgba(29, 33, 97, 0.05), rgba(26, 113, 59, 0.05));
    border: 1px solid rgba(29, 33, 97, 0.15);
    border-radius: 12px;
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 16px;
    overflow: hidden;
    opacity: 0;
}
.sidebar:hover .upgrade-card, .sidebar.locked .upgrade-card { opacity: 1; }
.zap-icon {
    width: 24px;
    height: 24px;
    min-width: 24px;
    color: #2d6cdf;
}
.upgrade-text h4 { font-size: .95rem; margin-bottom: 4px; }
.upgrade-text p { font-size: .82rem; color: rgba(255,255,255,.82); line-height: 1.45; }

.main-content { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow: hidden; }
.topbar {
    height: var(--topbar-height);
    background: var(--bg-panel);
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: space-between; gap: 14px;
    padding: 0 24px;
    position: sticky;
    top: 0;
    z-index: 140;
}
.topbar-left, .topbar-right { display: flex; align-items: center; gap: 14px; }
.topbar-right { margin-left: auto; }
.icon-btn {
    width: 40px; height: 40px; border-radius: 50%; border: none; background: transparent;
    color: var(--brand-navy); display: inline-flex; align-items: center; justify-content: center; cursor: pointer;
}
.icon-btn:hover { background: #edf3fa; }
.search-bar {
    min-width: min(360px, 100%); height: 42px; border-radius: 999px; border: 1px solid var(--border);
    display: flex; align-items: center; gap: 8px; padding: 0 14px; background: #f4f7fb;
}
.search-icon {
    width: 18px;
    height: 18px;
    color: var(--text-muted);
}
.search-bar input { width: 100%; border: none; outline: none; background: transparent; color: var(--text-primary); }
.topbar-title { display: flex; flex-direction: column; gap: 2px; }
.topbar-title strong { font-size: 1rem; }
.topbar-title span { font-size: .82rem; color: var(--text-muted); }
.topbar-user-actions {
    display: inline-flex;
    align-items: center;
    gap: 12px;
}
.topbar-user-chip,
.topbar-notifications-trigger,
.topbar-personal-settings,
.topbar-user-trigger {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.topbar-notifications-trigger svg,
.topbar-personal-settings svg,
.topbar-user-trigger svg {
    width: 24px;
    height: 24px;
    stroke-width: 1.9;
}
.topbar-notifications-trigger,
.topbar-personal-settings {
    color: #173a63;
    text-decoration: none;
}
.topbar-notifications-trigger,
.topbar-user-trigger {
    border: none;
    background: transparent;
    color: #173a63;
    cursor: pointer;
    padding: 0;
}
.topbar-notifications-trigger:hover,
.topbar-personal-settings:hover {
    color: #0f2745;
}
.topbar-user-trigger:hover {
    color: #0f2745;
}
.topbar-user-menu-wrap {
    position: relative;
}
.topbar-notifications-wrap {
    position: relative;
}
.topbar-notifications-badge {
    position: absolute;
    top: -2px;
    right: -4px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border-radius: 999px;
    background: #dc2626;
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    line-height: 16px;
    text-align: center;
}
.topbar-notifications-menu {
    position: absolute;
    top: calc(100% + 12px);
    right: 0;
    width: min(360px, calc(100vw - 32px));
    max-height: min(70vh, 420px);
    display: flex;
    flex-direction: column;
    border-radius: 14px;
    border: 1px solid #d7e4ef;
    background: #fff;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
    overflow: hidden;
    z-index: 220;
}
.topbar-notifications-head {
    padding: 14px 16px;
    border-bottom: 1px solid #e6edf5;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: #173a63;
}
.topbar-notifications-clear-btn {
    border: none;
    background: transparent;
    color: #1d4ed8;
    font-size: 0.82rem;
    font-weight: 700;
    cursor: pointer;
    padding: 0;
}
.topbar-notifications-clear-btn:hover {
    color: #173a63;
}
.topbar-notifications-list {
    display: grid;
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}
.topbar-notification-item {
    width: 100%;
    border: none;
    border-bottom: 1px solid #eef3f8;
    background: #fff;
    text-align: left;
    padding: 14px 16px;
    display: grid;
    gap: 4px;
    cursor: pointer;
}
.topbar-notification-item strong {
    color: #173a63;
    font-size: 0.95rem;
}
.topbar-notification-item small {
    color: #5f7288;
    white-space: pre-line;
}
.topbar-notification-item.is-unread {
    background: #f7fbff;
    border-left: 4px solid #2563eb;
    padding-left: 12px;
}
.topbar-notification-item.is-unread strong,
.topbar-notification-item.is-unread small {
    font-weight: 700;
    color: #173a63;
}
.topbar-notification-item:hover {
    background: #eef5fc;
}
.topbar-notification-empty {
    padding: 16px;
    color: #5f7288;
}
.topbar-user-menu {
    position: absolute;
    top: calc(100% + 12px);
    right: 0;
    min-width: 200px;
    border-radius: 14px;
    border: 1px solid #d7e4ef;
    background: #fff;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
    overflow: hidden;
    z-index: 220;
}
.topbar-user-menu-head {
    padding: 16px 18px;
    border-bottom: 1px solid #e6edf5;
}
.topbar-user-menu-head strong {
    font-size: 1.05rem;
    color: #173a63;
}
.topbar-user-menu-action {
    width: 100%;
    border: none;
    background: #fff;
    color: #ef4444;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 15px 18px;
    cursor: pointer;
    font-size: .98rem;
}
.topbar-user-menu-action:hover {
    background: #fff5f5;
}
.icon-badge-container { position: relative; }
.icon-badge {
    position: absolute;
    top: -2px;
    right: -2px;
    background-color: var(--brand-green);
    color: white;
    font-size: 0.65rem;
    font-weight: 700;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #fff;
}

.page-content { flex: 1; overflow: auto; padding: 28px 30px 34px; position: relative; }
body[data-page="tracking"] .page-content {
    overflow: auto;
}
body[data-page="tracking"] #tracking-shell {
    display: block;
}
body[data-page="personal-settings"] .page-content {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    padding-bottom: 34px;
    scroll-padding-bottom: 0;
}
body[data-page="personal-settings"] #personal-settings-shell {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: visible;
}
body[data-page="settings"] .page-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 0 0 18px;
    min-height: 0;
    overflow: hidden;
    background: #f4f5f7;
    box-sizing: border-box;
}
body[data-page="settings"] #settings-shell {
    flex: 1;
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 20px 30px 30px;
    box-sizing: border-box;
    scroll-padding-bottom: 30px;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
    background: #f4f5f7;
    background-clip: padding-box;
}
body[data-page="settings"] .settings-customers-shell {
    flex: 1 1 auto;
    width: 100%;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: visible;
}
body[data-page="settings"] .settings-customers-fixed-shell {
    flex-shrink: 0;
    padding: 18px 30px 0;
    background: #f4f5f7;
}
body[data-page="settings"] .settings-customers-scroll-area {
    flex: 1;
    min-height: 0;
    overflow: visible;
    padding: 0;
}
body[data-page="settings"] .settings-customers-scroll-area .settings-card {
    width: 100%;
    min-height: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-content: flex-start;
}
body[data-page="personal-settings"] .settings-grid {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding-right: 6px;
    padding-bottom: 120px;
    scroll-padding-bottom: 120px;
}

.form-detail-page-content {
    padding: 0;
    background: #f4f5f7;
    display: flex;
    flex-direction: column;
    overflow: auto;
    min-height: 0;
    flex: 1;
}
#form-detail-shell {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    gap: 0;
    overflow: hidden;
}
.forms-page-content {
    padding: 0;
    background: #f4f5f7;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0;
    flex: 1;
}
#forms-shell {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    gap: 0;
    overflow: hidden;
}
#quotes-shell {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    gap: 0;
    overflow: hidden;
}
.page-header, .card-head, .toolbar-actions, .row-actions, .tab-row, .selection-actions { display: flex; gap: 12px; }
.page-header, .card-head { align-items: flex-end; justify-content: space-between; margin-bottom: 22px; }
.page-header h1 { font-size: 2rem; margin-bottom: 6px; }
#settings-page-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
}
.settings-page-header {
    display: block;
    gap: 12px;
    align-items: stretch;
}
.settings-page-header-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 16px;
    width: 100%;
}
.settings-page-header-main h1 {
    margin: 0;
    min-width: 0;
}
.settings-page-header #settings-page-actions {
    margin-left: 0;
    justify-self: end;
}
.settings-page-header-copy {
    display: grid;
    gap: 0;
    margin-top: 12px;
}
.settings-page-header-copy .subtitle {
    margin: 0;
}
#settings-page-back {
    margin-top: 18px;
}
#settings-page-back:empty {
    display: none;
}
.emails-filter-bar {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) 180px 180px;
    gap: 12px;
    align-items: end;
    margin-bottom: 18px;
}
.emails-filter-search,
.emails-filter-select-wrap {
    display: grid;
    gap: 6px;
}
.emails-filter-select-wrap span {
    color: var(--text-secondary);
    font-size: 0.86rem;
    font-weight: 700;
}
.office-search-input,
.emails-filter-select {
    width: 100%;
    border: 1px solid #dce8f4;
    border-radius: 14px;
    background: #ffffff;
    color: #173a63;
    padding: 12px 14px;
    font-size: 0.95rem;
    font-weight: 700;
    outline: none;
}
.office-search-input:focus,
.emails-filter-select:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
}
.subtitle, .muted { color: var(--text-secondary); }

.btn {
    border: 1px solid var(--border); border-radius: 10px; padding: 11px 18px;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer; font-weight: 600;
}
.btn.primary { background: var(--brand-green); border-color: var(--brand-green); color: #fff; }
.btn.secondary { background: #fff; color: var(--brand-navy); }
.btn.danger { background: #fbe9e9; color: var(--brand-red); border-color: #efc6c6; }

.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 18px; margin-bottom: 20px; }
.card {
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 18px;
    box-shadow: var(--shadow);
    padding: 22px;
}
.stat-card-header, .item-row, .audit-row, .form-row, .summary-bar, .detail-header {
    display: flex; justify-content: space-between; align-items: center; gap: 14px;
}
.stat-card-header { margin-bottom: 14px; color: var(--text-secondary); }
.stat-card-value { font-size: 2rem; font-weight: 700; margin-bottom: 10px; }
.mini-pill, .status-pill {
    display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; border-radius: 999px; font-size: .76rem; font-weight: 700;
}
.mini-pill { background: #e8f3ff; color: #1d4ed8; }
.status-pill.complete { background: #e7f7ec; color: var(--brand-green); }
.status-pill.incomplete, .status-pill.pending { background: #fde8e8; color: var(--brand-red); }
.status-pill.progress { background: #e8f3ff; color: #1d4ed8; }

.two-col, .detail-two-col { display: grid; grid-template-columns: 1.1fr .9fr; gap: 18px; }
.stack { display: grid; gap: 14px; }
.item-row, .audit-row, .summary-bar {
    padding: 14px 16px; border: 1px solid #e2ebf3; background: var(--bg-soft); border-radius: 14px;
}
.item-row small, .audit-row small, .form-row small, .summary-bar small { display: block; margin-top: 4px; color: var(--text-secondary); }

.field-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.form-row {
    display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(0, 2fr) minmax(160px, .9fr) auto;
    gap: 16px; align-items: center; padding: 18px 20px; border: 1px solid var(--border); border-radius: 18px; background: #fff;
}
.form-row.complete { background: linear-gradient(90deg, rgba(13,155,68,.11), #fff 38%); }
.form-row.incomplete { background: linear-gradient(90deg, rgba(198,40,40,.11), #fff 38%); }

.job-header { margin-bottom: 18px; }
.job-header h1 { font-size: 1.8rem; margin-bottom: 4px; }
.job-meta { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-top: 16px; }
.job-meta-card { background: var(--bg-soft); border: 1px solid #e3ebf3; border-radius: 14px; padding: 14px 16px; }
.job-meta-card span { display: block; font-size: .8rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; }

.job-topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    padding: 10px 32px;
    background: #f4f5f7;
    border-bottom: 1px solid #d1d5db;
}
.job-topbar-left,
.job-topbar-right {
    display: flex;
    align-items: center;
    gap: 32px;
}
.job-topbar-right {
    justify-content: flex-end;
    margin-left: auto;
    gap: 20px;
}
.job-tab-content.engineer-form-page {
    display: flex;
    flex-direction: column;
    padding: 0;
    background: transparent;
    flex: 1;
    overflow: hidden;
    min-height: 0;
}
.form-detail-scroll-body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    padding: 12px 32px 24px;
}
.form-detail-action-bar {
    position: relative;
    z-index: 8;
    margin-top: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 14px 32px;
    background: #f4f7fb;
    border-top: 1px solid #d7e1eb;
}
.form-detail-action-left {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.form-detail-cancel-btn {
    min-width: 140px;
}
.form-detail-undo-btn,
.form-detail-redo-btn {
    min-width: 120px;
}
.form-detail-save-btn {
    min-width: 160px;
}
.form-detail-save-btn.secondary {
    background: #fff;
    border-color: var(--border);
    color: var(--brand-navy);
}
.form-detail-add-btn {
    min-width: 190px;
}
.engineer-layout {
    display: grid;
    grid-template-columns: 320px minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}
.engineer-sidebar-card,
.engineer-main-card {
    padding: 24px;
}
.detail-card {
    overflow: hidden;
}
.section-setup-row {
    padding: 28px;
}
.section-setup-card {
    min-height: 340px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 14px;
}
.section-setup-card h3 {
    margin: 0;
    font-size: 1.7rem;
}
.excel-group-title-button {
    border: none;
    background: transparent;
    padding: 0;
    color: inherit;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    text-align: left;
}
.section-setup-card p {
    max-width: 520px;
    margin: 0;
    color: var(--text-secondary);
    font-size: 1rem;
    line-height: 1.5;
}
.section-location-input {
    width: min(560px, 100%);
}
.section-location-keyboard {
    width: min(720px, 100%);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
}
.section-location-chip {
    border: 1px solid #d7e1eb;
    border-radius: 12px;
    background: #fff;
    color: var(--brand-navy);
    padding: 10px 14px;
    font-weight: 600;
    cursor: pointer;
}
.section-location-chip:hover {
    background: #eef5fc;
    border-color: #9fc2ef;
}
.engineer-sidebar-card {
    position: sticky;
    top: 24px;
    padding: 0;
}
.engineer-sidebar-head,
.engineer-form-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}
.engineer-sidebar-head {
    padding: 20px 22px 16px;
}
.engineer-sidebar-head h3,
.engineer-form-head h3 {
    margin: 0;
}
.engineer-sidebar-head p,
.engineer-form-head p {
    margin: 6px 0 0;
    color: var(--text-secondary);
    font-size: 0.9rem;
}
.empty-work-items-panel {
    border-top: 1px solid var(--border);
    padding: 24px 22px 28px;
    display: flex;
    justify-content: center;
}
.empty-detail-state {
    min-height: 520px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 12px;
}
.empty-detail-state h2 {
    margin: 0;
    font-size: 2rem;
}
.empty-detail-state p {
    max-width: 360px;
    margin: 0;
    color: var(--text-secondary);
    font-size: 1.15rem;
    line-height: 1.45;
}
.form-detail-inline-chooser {
    width: min(780px, 100%);
    margin-top: 18px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.form-detail-inline-chooser .office-action-option {
    min-height: 58px;
    box-shadow: 0 12px 24px rgba(15, 39, 78, 0.08);
}
.empty-add-work-btn {
    min-height: 44px;
    min-width: 320px;
    padding: 0 26px;
    border-radius: 12px;
    box-shadow: 0 14px 24px rgba(13, 155, 68, 0.18);
    justify-content: center;
}
.empty-work-items-panel .empty-add-work-btn {
    min-width: 220px;
    width: auto;
    border-radius: 14px;
    box-shadow: 0 12px 20px rgba(13, 155, 68, 0.14);
}
.form-detail-interaction-error {
    margin: 10px 16px;
    padding: 10px 14px;
    border: 1px solid #fecaca;
    border-radius: 12px;
    background: #fff1f2;
    color: #991b1b;
    font-weight: 700;
    position: relative;
    z-index: 20;
}
.work-item-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-top: 0;
    border-top: 1px solid var(--border);
}
.excel-empty-section {
    padding: 28px 22px 32px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.excel-empty-section-copy {
    color: var(--text-secondary);
    font-size: 0.95rem;
    text-align: center;
}
.excel-empty-add-btn {
    min-width: 220px;
    justify-content: center;
}
.record-topbar {
    padding: 0;
    background: #f4f5f7;
    border-bottom: 1px solid #d1d5db;
}
.record-topbar-main {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 28px;
    padding: 18px 32px 14px;
}
.record-topbar-left {
    display: flex;
    align-items: center;
    gap: 18px;
}
.record-topbar-left h1 {
    font-size: 1.6rem;
    font-weight: 300;
    color: #333;
    margin: 0;
}
.record-title-block {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.record-title-button {
    border: none;
    background: transparent;
    padding: 0;
    color: inherit;
    font: inherit;
    text-align: left;
    cursor: pointer;
}
.record-title-row {
    display: flex;
    align-items: center;
    gap: 30px;
    margin-bottom: 4px;
}
.record-back-btn {
    width: 40px;
    height: 40px;
    border: 1px solid #d7e1eb;
    border-radius: 999px;
    background: #fff;
    color: var(--brand-navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.record-back-btn:hover {
    background: #eef5fc;
}
.record-topbar-left p {
    color: #6b7280;
    margin: 0;
}
.record-topbar-right {
    display: flex;
    align-items: center;
    gap: 16px;
}
.record-map-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.mini-gps-map {
    position: relative;
    width: 118px;
    height: 70px;
    padding: 0;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid #d9e6f2;
    background: linear-gradient(135deg, #ddecfb, #f6fbff);
    flex-shrink: 0;
    cursor: pointer;
}
.quote-static-map {
    cursor: default;
}
.google-static-map-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.mini-google-static-map-image,
.modal-google-static-map-image,
.mini-google-map-embed,
.modal-google-map-embed {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.mini-google-map-embed,
.modal-google-map-embed {
    width: 100%;
    height: 100%;
    border: 0;
    background: #eef5fb;
}
.mini-google-map-embed {
    pointer-events: none;
}
.modal-google-map-embed {
    pointer-events: none;
}
.mini-live-map-host {
    position: absolute;
    inset: 0;
    z-index: 0;
    background: #eef5fb;
    pointer-events: none;
}
.mini-google-static-map-image {
    object-fit: contain;
    background: #eef5fb;
}
.form-map-stage {
    position: absolute;
    inset: 0;
    z-index: 0;
    transform-origin: center center;
    will-change: transform;
    pointer-events: none;
}
.mini-gps-map .map-grid,
.mini-gps-map .site-pin,
.mini-gps-map .gps-pin,
.mini-gps-map .gps-radius {
    z-index: 1;
}
.map-engineer-name {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--brand-navy);
    text-align: center;
    line-height: 1.1;
}
.record-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 14px;
    margin-left: 4px;
    border-radius: 999px;
    background: #fde68a;
    color: #92400e;
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1;
}
.map-modal-overlay.hidden {
    display: none;
}
.map-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 90;
}
.map-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(11, 18, 32, 0.42);
    backdrop-filter: blur(2px);
}
.map-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(760px, calc(100vw - 48px));
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 24px 80px rgba(15, 23, 42, 0.22);
    overflow: hidden;
}
.map-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 24px 14px;
    border-bottom: 1px solid #e4edf6;
}
.map-modal-head h2 {
    margin: 0 0 4px;
}
.map-modal-head p {
    margin: 0;
    color: #64748b;
}
.map-modal-body {
    padding: 20px 24px 24px;
    display: grid;
    gap: 16px;
}
.map-modal-canvas {
    position: relative;
    min-height: 360px;
    border: 1px solid #d7e1eb;
    border-radius: 20px;
    overflow: hidden;
    background: linear-gradient(135deg, #ddecfb, #f8fbff);
    cursor: grab;
    user-select: none;
    touch-action: none;
}
.map-modal-canvas.is-live-map {
    cursor: default;
    user-select: auto;
    touch-action: auto;
    background: #edf4fb;
}
.map-modal-canvas.is-dragging {
    cursor: grabbing;
}
.map-modal-live-host {
    position: absolute;
    inset: 0;
}
.google-static-map-card {
    overflow: hidden;
    border-radius: 18px;
    border: 1px solid #d9e6f2;
    min-height: 260px;
    background: #edf4fb;
}
.map-modal-toolbar {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.map-modal-engineer {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--brand-navy);
}
.map-modal-canvas .map-grid {
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(rgba(103, 146, 198, 0.17) 1px, transparent 1px),
      linear-gradient(90deg, rgba(103, 146, 198, 0.17) 1px, transparent 1px);
    background-size: 34px 34px;
}
.map-modal-canvas.map-layers-on {
    background:
      radial-gradient(circle at 20% 20%, rgba(84, 183, 113, 0.18), transparent 32%),
      radial-gradient(circle at 72% 28%, rgba(251, 191, 36, 0.14), transparent 26%),
      linear-gradient(135deg, #d6ead7, #eef7ef);
}
.map-modal-canvas .site-pin {
    width: 20px;
    height: 20px;
}
.map-modal-canvas .gps-pin {
    width: 18px;
    height: 18px;
}
.map-modal-canvas .gps-radius {
    width: 86px;
    height: 86px;
}
.detail-fixed-shell {
    position: relative;
    z-index: 2;
    background: #f4f5f7;
    flex-shrink: 0;
}
.forms-fixed-shell {
    padding: 18px 30px 0;
}
.forms-page-header {
    margin-bottom: 0;
}
.forms-page-header.quote-detail-page-header {
    display: block;
    width: 100%;
}
.forms-page-header h1 {
    margin-bottom: 4px;
}
.jobs-controls {
    display: flex;
    align-items: center;
    gap: 12px;
}
.jobs-search {
    flex: 1;
    max-width: 500px;
    background: var(--bg-panel);
    border: 1px solid var(--border);
}
.forms-controls {
    margin-top: 18px;
}
.forms-page-search {
    width: 100%;
}
.forms-tabs-container {
    margin: 14px 0 0;
}
.forms-scroll-area {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding: 20px 30px 34px;
    overscroll-behavior: contain;
}
.forms-scroll-area.quote-detail-scroll-shell {
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.forms-list-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}
.forms-list-toolbar-head {
    margin-bottom: 0;
    justify-content: flex-end;
}
.forms-list-toolbar-meta,
.forms-list-pagination,
.forms-list-pagination-summary,
.forms-list-pagination-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}
.forms-list-pagination {
    justify-content: space-between;
    margin-top: 22px;
    padding-top: 18px;
    border-top: 1px solid #e8eff7;
}
.forms-list-rows-label,
.forms-list-page-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #5a7b9d;
    font-size: 0.9rem;
    font-weight: 700;
}
.forms-list-rows-select,
.forms-list-page-input {
    border: 1px solid #dce8f4;
    border-radius: 12px;
    background: #ffffff;
    color: #173a63;
    padding: 8px 12px;
    font-size: 0.95rem;
    font-weight: 700;
    outline: none;
}
.forms-list-rows-select {
    min-width: 88px;
}
.forms-list-page-input {
    width: 76px;
}
.forms-list-rows-select:focus,
.forms-list-page-input:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
}
.record-tabs-container,
.job-tabs-container {
    display: flex;
    flex-wrap: nowrap;
    gap: 0;
    padding: 6px 0 0 0;
    margin: 0 32px;
    background: transparent;
    border-bottom: 2px solid #e5e7eb;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
}
.record-tab {
    padding: 12px 28px;
    border: none;
    background: transparent;
    color: #6b7280;
    font-size: 0.95rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    border-radius: 6px 6px 0 0;
    margin-bottom: -2px;
    position: relative;
}
.record-tab.active {
    background: white;
    color: #111827;
    border: 2px solid #e5e7eb;
    border-bottom: 2px solid white;
    font-weight: 500;
}
.record-tab.active::after,
.job-tab.active::after {
    content: "";
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 4px;
    height: 3px;
    border-radius: 999px;
    background: var(--brand-navy);
}
.job-tab {
    padding: 12px 28px;
    border: none;
    background: transparent;
    color: #6b7280;
    font-size: 0.95rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    border-radius: 6px 6px 0 0;
    margin-bottom: -2px;
    position: relative;
    flex: 0 0 auto;
}
.job-tab.active {
    background: white;
    color: #111827;
    border: 2px solid #e5e7eb;
    border-bottom: 2px solid white;
    font-weight: 500;
}
.admin-job-topbar {
    align-items: center;
}
.admin-job-topbar-left {
    align-items: center;
    min-height: 78px;
}
.admin-job-topbar-right {
    align-items: flex-start;
}
.admin-job-topbar-left h1 {
    font-size: 1.6rem;
    font-weight: 300;
    color: #333;
    margin: 0;
    line-height: 1;
}
.admin-job-topbar-left p {
    color: #6b7280;
    margin: 0;
    line-height: 1.1;
}
.admin-job-tabs {
    margin-bottom: 0;
}
.admin-form-detail-page {
    padding-top: 8px;
}
.admin-engineer-layout {
    min-height: calc(100vh - 260px);
    align-items: start;
}
.admin-engineer-sidebar-card,
.admin-engineer-main-card {
    background: #fff;
}
.admin-engineer-sidebar-card {
    position: sticky;
    top: 0;
    align-self: start;
}
.quote-detail-page {
    flex: 1;
    min-height: 0;
}
.quote-detail-scroll-body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding-bottom: 12px;
}
.quote-detail-toolbar {
    margin-bottom: 20px;
}
.quote-detail-action-bar {
    position: relative;
    z-index: 15;
    flex-shrink: 0;
    margin-bottom: 8px;
    box-shadow: 0 -6px 18px rgba(15, 23, 42, 0.06);
}
.quote-detail-action-right {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.detail-section-search-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 14px 16px 0;
    padding: 10px 14px;
    border: 1px solid #dbe6f0;
    border-radius: 16px;
    background: #f8fbfe;
}
.detail-section-search-icon {
    color: #5f7b99;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}
.detail-section-search-input {
    width: 100%;
    border: none;
    outline: none;
    background: transparent;
    color: #173a63;
    font-size: 0.95rem;
}
.detail-section-search-input::placeholder {
    color: #8aa0b6;
}
.detail-section-search-clear {
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 999px;
    background: #edf3f8;
    color: #5f7b99;
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
}
.detail-section-search-clear:hover {
    background: #dfe9f3;
    color: #173a63;
}
.admin-work-item-list {
    gap: 0;
    margin-top: 14px;
}
.admin-sidebar-empty-search {
    padding: 18px 16px 20px;
    color: #5f7b99;
    font-size: 0.95rem;
    font-weight: 600;
}
.admin-work-item-row {
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr) 52px;
    align-items: stretch;
    border-top: 1px solid #d7e1eb;
}
.admin-work-item-row:first-child {
    border-top: 0;
}
.admin-work-item-row.incomplete {
    background: #b91c1c;
}
.admin-work-item-row.complete {
    background: #15803d;
}
.admin-work-item-row.active {
    box-shadow: inset 0 0 0 2px #2563eb;
}
.admin-work-item-row.dragging {
    opacity: 0.55;
}
.admin-work-item-row.drag-target {
    box-shadow: inset 0 0 0 2px #93c5fd;
}
.admin-work-item-placeholder {
    border-top: 1px solid #d7e1eb;
    background: transparent;
}
.admin-work-item-leading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-right: 1px solid #d7e1eb;
    background: rgba(255,255,255,0.08);
}
.admin-sidebar-handle {
    width: 24px;
    height: 24px;
    color: #ffffff;
    cursor: grab;
    touch-action: none;
    user-select: none;
}
.admin-work-item-row.dragging .admin-sidebar-handle {
    cursor: grabbing;
}
.admin-sidebar-check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.admin-sidebar-check input {
    accent-color: #ffffff;
}
.admin-work-item-main {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 16px 18px;
    border: 0;
    background: transparent;
    color: #ffffff;
    text-align: left;
    cursor: pointer;
    min-width: 0;
}
.admin-work-item-copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}
.section-count-lines {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    gap: 6px;
    white-space: nowrap;
}
.section-count-lines span {
    color: var(--text-secondary);
    font-size: 0.92rem;
    line-height: 1.2;
}
.section-count-dot {
    margin-right: 6px;
}
.section-count-lines:empty {
    display: none;
}
.sidebar-section-counts {
    display: grid;
    gap: 2px;
}
.sidebar-section-counts span {
    color: rgba(255,255,255,0.88);
    font-size: 0.92rem;
    line-height: 1.2;
}
.sidebar-section-counts:empty {
    display: none;
}
.admin-work-item-copy strong {
    font-size: 0.98rem;
    color: #ffffff;
}
.admin-work-item-trash {
    border: 0;
    border-left: 1px solid #d7e1eb;
    background: rgba(255,255,255,0.08);
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.admin-work-item-row .status-pill {
    color: #ffffff;
    border: 1px solid rgba(255,255,255,0.28);
    background: rgba(255,255,255,0.16);
}
.admin-work-item-row .status-pill.complete,
.admin-work-item-row .status-pill.incomplete {
    color: #ffffff;
}
.admin-work-item-trash:hover {
    background: rgba(255,255,255,0.16);
}
.forms-grid {
    display: grid;
    gap: 0;
    border: 1px solid var(--border);
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
}
.forms-grid-head,
.forms-grid-main {
    display: grid;
    grid-template-columns: minmax(160px, 1.1fr) minmax(340px, 2.5fr) minmax(180px, 1.1fr) 90px 90px 110px 140px;
    gap: 14px;
    align-items: center;
}
.forms-grid-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 56px;
    padding: 14px 18px;
    background: #f4f7fb;
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 1px solid var(--border);
}
.forms-grid-head-main {
    display: grid;
    grid-template-columns: minmax(160px, 1.1fr) minmax(340px, 2.5fr) minmax(180px, 1.1fr) 90px 90px 110px 140px;
    gap: 14px;
    align-items: center;
}
.forms-grid-head > div:last-child {
    min-height: 1px;
}
.forms-grid-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 56px;
    border-top: 1px solid #e6edf5;
    background: #fff;
}
.forms-grid-row:first-of-type {
    border-top: 0;
}
.forms-grid-row.complete {
    background: linear-gradient(90deg, rgba(13,155,68,.11), #fff 38%);
}
.forms-grid-row.incomplete {
    background: linear-gradient(90deg, rgba(198,40,40,.11), #fff 38%);
}
.forms-grid-main {
    padding: 18px;
    color: inherit;
    text-decoration: none;
}
.forms-grid-main strong {
    font-size: 0.98rem;
}
.forms-grid-bin {
    border: 0;
    border-left: 1px solid #e6edf5;
    background: #f8fbff;
    color: #5b7592;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.forms-grid-bin:hover {
    background: #eef5fc;
    color: var(--brand-red);
}
.admin-detail-stack {
    display: grid;
    gap: 18px;
    padding: 22px;
}
.admin-engineer-main-card .detail-box,
.admin-engineer-main-card .selection-bar,
.admin-engineer-main-card .card {
    border-radius: 16px;
}
.admin-engineer-main-card .detail-box {
    box-shadow: none;
    border: 1px solid #d7e1eb;
}
.admin-engineer-main-card .detail-header h3 {
    font-size: 1.5rem;
}
.excel-selection-bar {
    margin-bottom: 18px;
}
.excel-group-list {
    display: grid;
    gap: 18px;
}
.excel-group-card {
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    overflow: hidden;
    scroll-margin-top: 12px;
    container-type: inline-size;
}
.excel-group-card.highlighted {
    border-color: #93c5fd;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}
.excel-group-card.dragging,
.excel-row.dragging {
    opacity: 0.55;
}
.excel-group-header {
    display: grid;
    grid-template-areas: "title meta actions";
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 16px;
    align-items: center;
    padding: 12px 16px;
    background: #f4f7fb;
    border-bottom: 1px solid #d7e1eb;
}
.excel-group-leading,
.excel-row-leading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}
.excel-handle {
    width: 28px;
    height: 28px;
    border: 1px solid #d7e1eb;
    border-radius: 8px;
    background: #fff;
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: grab;
}
.excel-group-title {
    grid-area: title;
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    min-width: 0;
    justify-self: start;
}
.excel-group-meta {
    grid-area: meta;
    display: flex;
    justify-content: center;
    align-items: center;
    min-width: 0;
    justify-self: center;
}
.section-header-counts {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    justify-items: center;
    text-align: center;
}
.section-header-counts span {
    display: inline-flex;
    align-items: center;
}
.excel-group-add {
    grid-area: actions;
    min-width: 108px;
    height: 32px;
    border: 1px solid var(--brand-green);
    border-radius: 10px;
    background: var(--brand-green);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 10px 18px rgba(13, 155, 68, 0.14);
    gap: 8px;
    padding: 0 12px;
    font-weight: 700;
    justify-self: end;
    white-space: nowrap;
}
.excel-group-add:hover {
    background: #0c8d3e;
    border-color: #0c8d3e;
}
.excel-group-add span {
    line-height: 1;
}
.excel-group-add-placeholder {
    width: 32px;
    height: 32px;
}
.excel-rows {
    display: grid;
}
.excel-row {
    display: grid;
    grid-template-columns: 90px minmax(180px, 260px) minmax(0, 1fr) 56px;
    gap: 16px;
    align-items: center;
    padding: 16px;
    border-top: 1px solid #e6edf5;
    background: #fff;
}
.excel-row:first-child {
    border-top: 0;
}
.excel-row-title {
    display: grid;
    gap: 8px;
    align-content: start;
}
.excel-row-title-copy {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}
.excel-row-title strong {
    font-size: 1rem;
}
.row-qty-badge {
    border: 1px solid #d7e1eb;
    border-radius: 999px;
    background: #f8fafc;
    color: #173a63;
    padding: 4px 10px;
    font-size: 0.86rem;
    font-weight: 700;
    line-height: 1.1;
    cursor: pointer;
}
.row-qty-badge:hover {
    background: #eef5fc;
}
.excel-row-fields {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
}
.excel-row-actions {
    display: flex;
    justify-content: center;
    align-items: center;
}
.excel-row-actions.has-action-stack {
    display: grid;
    grid-auto-rows: min-content;
    justify-items: center;
    align-content: center;
    gap: 8px;
    padding: 8px 0;
}
.excel-action-btn {
    width: 34px;
    height: 34px;
    border: 1px solid #d7e1eb;
    border-radius: 10px;
    background: #f8fafc;
    color: var(--brand-navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.excel-action-label {
    display: none;
}
.excel-action-btn:hover {
    background: #eef5fc;
}
.excel-action-btn.is-disabled,
.excel-action-btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.excel-row-window-measure {
    grid-template-areas: "leading title layout actions";
    grid-template-columns: 74px 96px minmax(0, 1fr) 48px;
    align-items: stretch;
    gap: 12px;
}
.excel-row-window-measure .excel-row-leading {
    grid-area: leading;
}
.window-measure-title-cell {
    grid-area: title;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 14px 10px;
    font-weight: 700;
    text-align: center;
    color: var(--brand-navy);
}
.window-measure-layout {
    grid-area: layout;
    display: grid;
    align-items: stretch;
    gap: 14px;
    grid-template-columns: 220px minmax(320px, 1.45fr) minmax(260px, 1.3fr);
    grid-template-areas:
        "sketch main side"
        "photo addon status";
}
.window-measure-layout > * {
    min-width: 0;
}
.window-measure-media-card {
    display: grid;
    grid-template-rows: auto 1fr;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    overflow: hidden;
}
.window-measure-media-label {
    padding: 10px 12px 0;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.window-measure-media-card .excel-cell-input {
    margin: 6px 8px 8px;
}
.window-measure-sketch-card { grid-area: sketch; }
.window-measure-photo-card { grid-area: photo; }
.window-measure-photo-card,
.window-measure-addon-stack,
.window-measure-status-row {
    min-height: 188px;
}
.bay-measure-photo-top-card { grid-area: sketch; }
.bay-measure-photo-top-card .media-trigger-shell {
    display: flex;
    flex: 1 1 auto;
    min-height: 0;
}
.bay-measure-photo-top-card .sketch-trigger {
    height: 180px;
    min-height: 180px;
}
.bay-measure-left-stack {
    display: grid;
    gap: 14px;
    align-content: start;
    min-width: 0;
    width: auto;
    max-width: none;
}
.bay-measure-status-card .status-choice-stack {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 8px 12px 12px;
    align-content: stretch;
    flex: 1 1 auto;
}
.bay-measure-status-card .status-choice-btn {
    min-height: 70px;
    height: 100%;
    width: 100%;
}
.bay-measure-status-card {
    min-height: 180px;
}
.bay-measure-segment-tail-status .status-choice-stack {
    grid-template-columns: 1fr;
    align-content: stretch;
    gap: 8px;
    padding: 8px 12px 12px;
}
.bay-measure-segment-tail-status .status-choice-btn {
    min-height: 70px;
    width: 100%;
}
.bay-measure-drawing-card .sketch-trigger,
.bay-measure-drawing-card .sketch-trigger-preview {
    min-height: 180px;
}
.door-measure-layout {
    grid-area: layout;
    display: grid;
    gap: 14px;
    grid-template-columns: 220px minmax(320px, 1.45fr) minmax(260px, 1.3fr);
    grid-template-areas:
        "sketch main side"
        "photo addon status"
        "flag addontail opening";
    align-items: stretch;
    min-width: 0;
}
.door-measure-layout > * {
    min-width: 0;
}
.door-measure-desktop-shell {
    display: contents;
}
.door-measure-mobile-sequence {
    display: none;
}
.door-measure-side-grid {
    grid-area: side;
}
.door-measure-flag-column {
    grid-area: flag;
    display: grid;
    gap: 8px;
    min-width: 0;
    grid-column: 1 / span 2;
    grid-template-columns: 220px minmax(320px, 1.45fr);
    align-items: start;
}
.door-measure-flag-card {
    min-width: 0;
}
.door-measure-flag-empty {
    min-width: 0;
    min-height: 88px;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
}
.door-measure-toplight-measure-card {
    grid-column: 1 / span 2;
}
.door-measure-addon-tail {
    grid-area: addontail;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    min-width: 0;
}
.door-measure-opening-stack {
    grid-area: opening;
    display: grid;
    gap: 8px;
    min-width: 0;
    align-content: start;
}
.door-measure-opening-card {
    min-width: 0;
}
.door-measure-toplight-card,
.door-measure-letterbox-card,
.door-measure-opening-card,
.door-measure-toplight-measure-card {
    min-width: 0;
}
.door-measure-opening-empty {
    width: 100%;
    min-height: 68px;
    height: 68px;
    align-self: start;
}
.door-measure-flag-card .window-measure-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
}
.door-measure-toplight-card .window-measure-cell,
.door-measure-letterbox-card .window-measure-cell,
.door-measure-opening-card .window-measure-cell,
.door-measure-toplight-measure-card .window-measure-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
    min-height: 88px;
    height: auto;
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.door-measure-toplight-card .window-measure-cell .window-measure-cell-label,
.door-measure-letterbox-card .window-measure-cell .window-measure-cell-label,
.door-measure-opening-card .window-measure-cell .window-measure-cell-label,
.door-measure-toplight-measure-card .window-measure-cell .window-measure-cell-label {
    padding-top: 10px;
    padding-bottom: 6px;
    margin-bottom: 0;
    min-height: 24px;
    line-height: 1.1;
    white-space: nowrap;
}
.door-measure-toplight-card .status-choice-stack,
.door-measure-letterbox-card .status-choice-stack,
.door-measure-opening-card .status-choice-stack,
.door-measure-toplight-measure-card .status-choice-stack {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 2px 10px 10px;
    min-height: 0;
    align-content: start;
    margin-top: auto;
    width: 100%;
}
.door-measure-toplight-card .status-choice-btn,
.door-measure-letterbox-card .status-choice-btn,
.door-measure-opening-card .status-choice-btn,
.door-measure-toplight-measure-card .status-choice-btn {
    min-height: 0;
    height: 48px;
    padding: 0 14px;
    font-size: 1rem;
    width: 100%;
    min-width: 0;
}
.door-measure-toplight-measure-card .window-measure-cell {
    display: grid;
    grid-template-columns: minmax(180px, 1.2fr) minmax(220px, 1fr);
    align-items: center;
    min-height: 64px;
    padding: 4px 12px 0;
}
.door-measure-toplight-measure-card .window-measure-cell .window-measure-cell-label {
    padding: 0 14px 0 0;
    min-height: 0;
    margin: 0;
    display: flex;
    align-items: center;
}
.door-measure-toplight-measure-card .status-choice-stack {
    padding: 4px 0;
    margin-top: 0;
}
.door-measure-photo-card,
.door-measure-drawing-card {
    min-height: 188px;
}
.door-measure-drawing-card {
    grid-area: photo;
}
.door-measure-photo-card {
    grid-area: sketch;
}
.door-measure-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    grid-column: 1 / -1;
    min-width: 0;
}
.door-measure-grid .window-measure-inline-cell,
.door-measure-grid .window-measure-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
}
.door-measure-grid .window-measure-inline-cell {
    min-height: 82px;
}
.door-measure-grid .window-measure-inline-cell .excel-cell-input,
.door-measure-grid .window-measure-inline-cell .cell-select,
.door-measure-grid .window-measure-inline-cell .cell-input {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
.door-measure-grid .window-measure-inline-cell:first-child,
.door-measure-grid .window-measure-cell:first-child {
    border-top: 1px solid #d7e1eb;
}
.door-measure-grid .window-measure-cell {
    min-height: 88px;
}
.door-measure-section-divider {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    margin-bottom: 8px;
}
.door-measure-section-divider::before,
.door-measure-section-divider::after {
    content: "";
    flex: 1 1 auto;
    min-width: 0;
    height: 1px;
    background: #d7e1eb;
}
.door-measure-section-divider span {
    flex: 0 0 auto;
    padding: 0 12px;
    background: #fff;
    color: #3d628b;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.2;
    white-space: nowrap;
}
.door-measure-branch-layout {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 220px minmax(320px, 1.45fr) minmax(260px, 1.3fr);
    gap: 14px;
    margin-top: 0;
    min-width: 0;
    padding-top: 6px;
    box-sizing: border-box;
    align-items: stretch;
}
.door-measure-branch-size {
    grid-column: 1;
    display: grid;
    grid-template-rows: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 6px;
    min-width: 0;
}
.door-measure-branch-size .window-measure-inline-cell,
.door-measure-branch-side .window-measure-inline-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
    overflow: hidden;
    min-height: 82px;
}
.door-measure-branch-addon {
    grid-area: auto;
    grid-column: 2;
    display: grid;
    margin-top: 6px;
    min-width: 0;
    width: 100%;
    max-width: none;
}
.door-measure-branch-addon-card {
    display: grid;
    grid-template-rows: auto 1fr;
    min-height: 178px;
    height: 100%;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    overflow: hidden;
    background: #f8fafc;
    box-sizing: border-box;
}
.door-measure-branch-addon-head {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border-bottom: 1px solid #e6edf5;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.door-measure-branch-addon-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-width: 0;
    height: 100%;
}
.door-measure-branch-addon-item {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 72px;
    padding: 0 14px;
    border-top: 1px solid #e6edf5;
    box-sizing: border-box;
}
.door-measure-branch-addon-item:nth-child(-n + 2) {
    border-top: 0;
}
.door-measure-branch-addon-item:nth-child(2n) {
    border-left: 1px solid #e6edf5;
}
.door-measure-branch-addon-label {
    flex: 0 0 auto;
    min-width: 30px;
    font-weight: 700;
    color: var(--brand-navy);
}
.door-measure-branch-addon-input {
    flex: 1 1 auto;
    min-width: 0;
}
.door-measure-branch-addon-input .excel-cell-input,
.door-measure-branch-addon-input .cell-input,
.door-measure-branch-addon-input .cell-select {
    width: 100%;
    max-width: 100%;
}
.admin-form-detail-page .door-measure-branch-addon.window-measure-addon-stack {
    width: 100%;
    max-width: none;
}
.door-measure-branch-side {
    grid-column: 3;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
    margin-top: 6px;
    min-width: 0;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    overflow: hidden;
    background: #f8fafc;
}
.door-measure-branch-side .window-measure-inline-cell {
    border: 0;
    border-top: 1px solid #e6edf5;
    border-radius: 0;
    min-height: 88px;
}
.door-measure-branch-side .window-measure-inline-cell:nth-child(-n + 2) {
    border-top: 0;
}
.door-measure-branch-side .window-measure-inline-cell:nth-child(2n) {
    border-left: 1px solid #e6edf5;
}
.door-measure-section-heading {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    min-height: 42px;
    padding: 0 12px;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #eef4fa;
}
.door-measure-section-heading .window-measure-cell-label {
    margin: 0;
    padding: 0;
    font-size: 0.8rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.admin-form-detail-page .excel-row-door-measure {
    grid-template-areas: "leading title layout actions";
    grid-template-columns: 74px 96px minmax(0, 1fr) 48px;
    align-items: stretch;
    gap: 12px;
}
.admin-form-detail-page .excel-row-door-measure .excel-row-leading {
    grid-area: leading;
}
.admin-form-detail-page .excel-row-door-measure .door-measure-layout {
    grid-area: layout;
    display: grid;
    gap: 14px;
    min-width: 0;
    width: 100%;
    max-width: none;
    justify-self: stretch;
}
.admin-form-detail-page .excel-row-door-measure .door-measure-layout > * {
    width: 100%;
    max-width: none;
    min-width: 0;
}
.admin-form-detail-page .excel-row-door-measure .door-measure-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    min-width: 0;
}
.admin-form-detail-page .excel-row-door-measure .door-measure-grid .window-measure-inline-cell,
.admin-form-detail-page .excel-row-door-measure .door-measure-grid .window-measure-cell,
.admin-form-detail-page .excel-row-door-measure .door-measure-section-heading,
.admin-form-detail-page .excel-row-door-measure .window-measure-media-card {
    width: 100%;
    max-width: none;
    min-width: 0;
}
.admin-form-detail-page .excel-row-door-measure .excel-row-actions,
.admin-form-detail-page .excel-row-door-measure .excel-row-actions.has-action-stack {
    grid-area: actions;
    justify-content: center;
    align-items: center;
    width: auto;
    max-width: none;
    padding-top: 0;
}
.admin-form-detail-page .excel-row-door-measure .excel-row-actions.has-action-stack {
    display: grid;
    grid-auto-rows: min-content;
    justify-items: center;
    align-content: center;
    gap: 8px;
    padding: 8px 0;
}
.admin-form-detail-page .excel-row-door-measure .excel-delete-btn,
.admin-form-detail-page .excel-row-door-measure .excel-action-btn {
    width: 34px;
    height: 34px;
    min-height: 34px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0;
}
.admin-form-detail-page .excel-row-door-measure .excel-delete-label,
.admin-form-detail-page .excel-row-door-measure .excel-action-label {
    display: none;
}
.door-measure-status-empty {
    background: #f8fafc;
}
.door-measure-status-spacer {
    min-height: 100%;
}
.excel-row-window-handle {
    grid-template-areas: "leading title layout actions";
    grid-template-columns: 74px 96px minmax(0, 1fr) 48px;
    align-items: stretch;
    gap: 12px;
}
.excel-row-window-handle .excel-row-leading {
    grid-area: leading;
}
.excel-row-window-handle .excel-row-actions {
    grid-area: actions;
}
.excel-row-detail {
    grid-template-areas: "leading title layout actions";
    grid-template-columns: 74px 96px minmax(0, 1fr) 48px;
    align-items: stretch;
    gap: 12px;
}
.excel-row-detail .excel-row-leading {
    grid-area: leading;
}
.excel-row-detail .excel-row-actions {
    grid-area: actions;
}
.detail-row-title-cell {
    grid-area: title;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 14px 0;
    font-weight: 700;
    text-align: left;
    color: var(--brand-navy);
}
.detail-row-layout {
    grid-area: layout;
    display: grid;
    gap: 14px;
    align-items: stretch;
    min-width: 0;
}
.excel-row-detail-media .detail-row-layout {
    grid-template-columns: minmax(240px, 0.85fr) minmax(320px, 1fr);
}
@media (max-width: 1100px) {
    .excel-row-detail-media .detail-row-layout {
        grid-template-columns: 1fr;
    }
}
.detail-field-card {
    display: grid;
    grid-template-rows: auto 1fr;
    gap: 10px;
    padding: 14px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
    min-width: 0;
}
.detail-field-card > span,
.detail-note-recorder > .detail-recorder-label {
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    color: #516786;
    letter-spacing: 0.04em;
}
.detail-media-card .excel-cell-input,
.detail-description-card .excel-cell-input,
.detail-transcript-card .excel-cell-input,
.detail-note-text .excel-cell-input {
    margin: 0;
}
.detail-description-card .cell-textarea,
.detail-transcript-card .cell-textarea {
    min-height: 142px;
}
.detail-note-layout {
    display: grid;
    grid-template-columns: minmax(320px, 1.35fr) minmax(240px, 0.9fr);
    gap: 18px;
    width: 100%;
    align-items: stretch;
}
.detail-note-text {
    min-width: 0;
}
.detail-note-text-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.detail-note-text .cell-textarea {
    min-height: 142px;
}
.window-handle-title-cell {
    grid-area: title;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 14px 10px;
    font-weight: 700;
    text-align: center;
    color: var(--brand-navy);
}
.window-handle-layout {
    --handle-row-height: 101px;
    --handle-stack-gap: 14px;
    --handle-column-height: calc((var(--handle-row-height) * 2) + var(--handle-stack-gap));
    grid-area: layout;
    display: grid;
    grid-template-columns: 220px minmax(320px, 1.45fr) minmax(260px, 1.3fr);
    grid-template-areas: "photo main side";
    gap: 16px;
    align-items: stretch;
    min-width: 0;
}
.window-handle-media-card {
    display: grid;
    grid-template-rows: auto 1fr;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    min-width: 0;
    overflow: hidden;
}
.window-handle-photo-card {
    grid-area: photo;
    min-height: var(--handle-column-height);
    height: var(--handle-column-height);
}
.window-handle-fitted-photo-card {
    grid-area: fitted;
    min-height: var(--handle-column-height);
    height: var(--handle-column-height);
}
.excel-row-window-handle.is-fit .window-handle-layout {
    grid-template-areas: "fitted main side";
}
.excel-row-window-handle.is-fit .window-handle-photo-card.is-fit-hidden {
    display: none;
}
.window-handle-media-label {
    padding: 10px 12px 0;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.no-image-required-btn {
    border: 0;
    background: transparent;
    color: #d92d20;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    margin: 0;
}
.no-image-required-btn:hover,
.no-image-required-btn:focus-visible {
    color: #b42318;
    outline: none;
}
.no-image-required-btn.is-active {
    color: #b42318;
}
.window-handle-media-card .excel-cell-input {
    margin: 10px 12px 12px;
}
.window-handle-main-column,
.window-handle-side-column {
    display: grid;
    gap: var(--handle-stack-gap);
    min-width: 0;
    align-content: stretch;
    min-height: var(--handle-column-height);
    height: var(--handle-column-height);
}
.window-handle-main-column {
    grid-area: main;
    grid-template-rows: repeat(2, var(--handle-row-height));
}
.window-lock-main-column {
    grid-area: main;
    display: grid;
    grid-template-rows: repeat(2, var(--handle-row-height));
    gap: var(--handle-stack-gap);
    min-width: 0;
    min-height: var(--handle-column-height);
    height: var(--handle-column-height);
}
.window-lock-main-column .window-measure-inline-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
    box-sizing: border-box;
    padding-top: 10px;
    padding-bottom: 10px;
}
.window-lock-main-column .window-measure-inline-cell:first-child {
    border-top: 1px solid #d7e1eb;
}
.window-lock-spacer {
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
    background: #f8fafc;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
}
.window-toe-main-card {
    grid-area: main;
    display: grid;
    grid-template-rows: auto auto 1fr;
    gap: 10px;
    min-width: 0;
    min-height: var(--handle-column-height);
    height: var(--handle-column-height);
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    padding: 10px 12px 12px;
    box-sizing: border-box;
}
.window-toe-main-label {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.window-toe-main-card .excel-cell-input {
    margin: 0;
}
.window-toe-keyboard {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-content: start;
}
.window-toe-chip {
    border: 1px solid #d7e1eb;
    border-radius: 999px;
    background: #fff;
    color: var(--brand-navy);
    padding: 8px 12px;
    font-size: 0.9rem;
    font-weight: 600;
}
.window-toe-chip:hover {
    background: #eef5fc;
}
.window-handle-type-row,
.window-handle-colour-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--handle-stack-gap);
    min-width: 0;
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
}
.window-handle-type-row.has-other,
.window-handle-colour-row.has-other {
    grid-template-columns: 1fr 1fr;
}
.window-handle-type-row .window-measure-inline-cell,
.window-handle-colour-row .window-measure-inline-cell,
.window-handle-other-type-card,
.window-handle-other-colour-card {
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
}
.window-handle-other-type-card.is-hidden {
    display: none;
}
.window-handle-other-colour-card.is-hidden {
    display: none;
}
.window-handle-other-type-card .window-measure-inline-cell,
.window-handle-other-colour-card .window-measure-inline-cell {
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
}
.window-handle-side-column {
    grid-area: side;
    grid-template-rows: repeat(2, var(--handle-row-height));
}
.window-handle-main-column .window-measure-inline-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
    box-sizing: border-box;
}
.window-handle-side-column .window-measure-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
}
.window-handle-main-column .window-measure-inline-cell {
    padding-top: 10px;
    padding-bottom: 10px;
}
.window-handle-main-column .window-measure-inline-cell:first-child {
    border-top: 1px solid #d7e1eb;
}
.window-handle-side-column .window-measure-cell-label {
    padding-top: 10px;
    padding-bottom: 6px;
    margin-bottom: 0;
}
.window-handle-main-column .window-measure-inline-label,
.window-handle-side-column .window-measure-cell-label {
    min-height: 24px;
}
.window-handle-side-column .window-measure-cell .excel-cell-input {
    min-height: 48px;
    margin-top: 4px;
}
.window-handle-side-column .window-measure-cell .cell-select,
.window-handle-side-column .window-measure-cell .cell-input {
    height: 48px;
}
.window-handle-side-column .status-choice-stack {
    padding-top: 2px;
    min-height: 0;
    align-content: start;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    height: auto;
    margin-top: auto;
}
.window-handle-side-column .status-choice-btn {
    min-height: 0;
    height: 44px;
}
.window-glass-layout {
    --handle-row-height: 101px;
    --handle-stack-gap: 14px;
    --glass-column-height: calc((var(--handle-row-height) * 2) + var(--handle-stack-gap));
    grid-area: layout;
    display: grid;
    grid-template-columns: 220px minmax(320px, 1.45fr) minmax(260px, 1.3fr);
    grid-template-areas:
        "photo main side"
        "photo-bottom main side";
    gap: 16px;
    align-items: stretch;
    min-width: 0;
}
.excel-row-window-glass.is-fit .window-glass-layout {
    grid-template-areas:
        "fitted main side"
        "photo-bottom main side";
}
.window-glass-main-column {
    grid-area: main;
    display: grid;
    grid-template-rows: auto auto;
    gap: var(--handle-stack-gap);
    min-width: 0;
    min-height: var(--glass-column-height);
    height: auto;
}
.excel-row-window-glass .window-handle-photo-card,
.excel-row-window-glass .window-handle-fitted-photo-card {
    min-height: var(--glass-column-height);
    height: var(--glass-column-height);
}
.window-glass-photo-bottom-row {
    grid-area: photo-bottom;
    min-width: 0;
    width: 100%;
    align-self: stretch;
}
.window-glass-photo-bottom-row .window-measure-inline-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 6px;
    padding-right: 6px;
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 100%;
}
.window-glass-photo-bottom-row .window-measure-inline-cell:first-child {
    border-top: 1px solid #d7e1eb;
}
.window-glass-photo-bottom-row .window-measure-inline-label {
    min-height: 24px;
    padding: 10px 8px 6px;
    margin-bottom: 0;
}
.window-glass-side-column {
    grid-area: side;
    display: grid;
    grid-template-rows: repeat(3, var(--handle-row-height));
    gap: var(--handle-stack-gap);
    min-width: 0;
    min-height: var(--glass-column-height);
    height: var(--glass-column-height);
}
.window-glass-dimensions-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--handle-stack-gap);
    min-width: 0;
    align-items: stretch;
}
.window-panel-main-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--handle-stack-gap);
    min-width: 0;
    align-items: stretch;
}
.window-panel-main-grid .window-measure-inline-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
    overflow: hidden;
}
.window-panel-main-grid .window-measure-inline-cell:nth-child(1) { order: 1; }
.window-panel-main-grid .window-measure-inline-cell:nth-child(3) { order: 2; }
.window-panel-main-grid .window-measure-inline-cell:nth-child(2) { order: 3; }
.window-panel-main-grid .window-measure-inline-cell:nth-child(4) { order: 4; }
.window-glass-extra-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--handle-stack-gap);
    min-width: 0;
}
.window-glass-extra-row.no-other-glass-type {
    grid-template-columns: 1fr;
}
.window-glass-extra-row.has-other-glass-type {
    grid-template-columns: 1fr 1fr;
}
.window-glass-extra-row .window-measure-inline-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
    padding-top: 10px;
    padding-bottom: 10px;
}
.window-glass-extra-row .window-measure-inline-cell:first-child {
    border-top: 1px solid #d7e1eb;
}
.window-glass-other-type-card.is-hidden {
    display: none;
}
.window-glass-photo-bottom-row .status-choice-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding: 2px 6px 10px;
    margin-top: auto;
    width: 100%;
}
.window-glass-photo-bottom-row .status-choice-btn {
    min-height: 0;
    height: 44px;
    padding: 0 6px;
    font-size: 0.96rem;
    width: 100%;
    min-width: 0;
}
.window-glass-dimensions-grid .window-measure-inline-cell,
.window-glass-side-column .window-measure-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    box-sizing: border-box;
}
.window-glass-dimensions-grid .window-measure-inline-cell {
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
    padding-top: 10px;
    padding-bottom: 10px;
}
.window-glass-dimensions-grid .window-measure-inline-cell:first-child,
.window-glass-side-column .window-measure-cell:first-child {
    border-top: 1px solid #d7e1eb;
}
.window-glass-photo-bottom-row .window-measure-inline-label {
    min-height: 24px;
    padding-top: 10px;
    padding-bottom: 6px;
    margin-bottom: 0;
}
.window-glass-side-column .window-measure-cell {
    min-height: var(--handle-row-height);
    height: var(--handle-row-height);
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.window-glass-side-column .window-measure-cell .window-measure-cell-label {
    padding-top: 10px;
    padding-bottom: 6px;
    margin-bottom: 0;
    min-height: 24px;
    line-height: 1.1;
    white-space: nowrap;
}
.window-glass-side-column .status-choice-stack {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding-top: 2px;
    min-height: 0;
    align-content: start;
    margin-top: auto;
    width: 100%;
}
.window-glass-side-column .status-choice-btn {
    min-height: 0;
    height: 48px;
    padding: 0 14px;
    font-size: 1rem;
    width: 100%;
    min-width: 0;
}

@container (max-width: 1100px) {
    .excel-group-card .window-measure-cell:has(.status-choice-stack),
    .excel-group-card .window-measure-inline-cell:has(.status-choice-stack) {
        min-height: 132px;
        height: auto;
        padding-top: 0;
        padding-bottom: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }
    .excel-group-card .window-measure-cell {
        padding-bottom: 0;
        display: flex;
        flex-direction: column;
    }
    .excel-group-card .window-measure-cell-label {
        min-height: 24px;
        padding-top: 10px;
        padding-bottom: 6px;
        margin-bottom: 0;
    }
    .excel-group-card .status-choice-stack {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 2px 12px 10px;
        margin-top: auto;
        width: 100%;
    }
    .window-measure-status-row .status-choice-stack,
    .window-measure-status-column .status-choice-stack {
        margin-top: 0;
        gap: 8px;
        padding: 4px 14px 6px;
    }
    .window-measure-status-row .window-measure-cell,
    .window-measure-status-column .window-measure-cell {
        min-height: 82px;
    }
    .window-measure-status-row .status-choice-btn,
    .window-measure-status-column .status-choice-btn {
        height: 44px;
        padding: 0 12px;
    }
    .excel-group-card .status-choice-btn {
        height: 44px;
        width: 100%;
        padding: 0 12px;
    }
    .window-handle-layout {
        width: min(100%, 460px);
        justify-self: start;
        grid-template-columns: 1fr;
        grid-template-areas:
            "photo"
            "main"
            "side";
    }
    .door-measure-layout {
        width: min(100%, 460px);
        justify-self: start;
        grid-template-columns: 1fr 1fr;
    }
    .door-measure-grid {
        grid-template-columns: 1fr 1fr;
        grid-column: 1 / -1;
    }
    .window-handle-main-column,
    .window-handle-side-column,
    .window-lock-main-column,
    .window-toe-main-card {
        min-height: 0;
        height: auto;
    }
    .window-handle-main-column {
        grid-template-rows: auto auto;
    }
    .window-handle-side-column {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto;
    }
    .window-handle-side-column .window-measure-cell {
        min-height: 0;
        height: auto;
        padding-bottom: 10px;
    }
    .window-handle-side-column .status-choice-stack {
        grid-template-columns: 1fr;
        margin-top: 4px;
    }
    .window-lock-spacer {
        display: none;
    }
    .window-lock-main-column {
        grid-template-rows: auto;
    }
    .window-glass-layout {
        width: min(100%, 460px);
        justify-self: start;
        grid-template-columns: repeat(2, minmax(0, calc((100% - 16px) / 2)));
        grid-template-areas: none;
        align-items: start;
        justify-content: start;
        justify-items: start;
        column-gap: 16px;
    }
    .window-glass-main-column,
    .window-glass-side-column,
    .window-glass-photo-bottom-row,
    .excel-row-window-glass .window-handle-photo-card,
    .excel-row-window-glass .window-handle-fitted-photo-card {
        min-height: 0;
        height: auto;
    }
    .window-glass-photo-bottom-row .window-measure-inline-cell,
    .window-glass-side-column .window-measure-cell {
        min-height: 132px;
        height: auto;
        overflow: visible;
        padding-bottom: 0;
    }
    .window-glass-main-column,
    .window-glass-side-column,
    .window-glass-photo-bottom-row {
        display: contents;
    }
    .window-glass-dimensions-grid,
    .window-glass-extra-row {
        display: contents;
    }
    .window-glass-extra-row {
        grid-template-columns: initial;
    }
    .excel-row-window-glass .window-handle-photo-card {
        grid-column: 1;
        grid-row: span 2;
        width: 100%;
        max-width: 100%;
        justify-self: start;
        min-height: calc((var(--handle-row-height) * 2) + var(--handle-stack-gap));
        height: auto;
    }
    .window-glass-dimensions-grid .glass-width-cell {
        grid-column: 2;
        order: 1;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-dimensions-grid .glass-height-cell {
        grid-column: 2;
        order: 2;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-extra-row.no-other-glass-type .glass-type-cell {
        grid-column: 1 / 3;
        order: 3;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-extra-row.has-other-glass-type .glass-type-cell {
        grid-column: 1;
        order: 3;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-other-type-card {
        display: contents;
    }
    .window-glass-extra-row.has-other-glass-type .glass-other-type-cell {
        grid-column: 2;
        order: 3;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-dimensions-grid .glass-spacer-depth-cell {
        grid-column: 1;
        order: 4;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-dimensions-grid .glass-spacer-colour-cell {
        grid-column: 2;
        order: 4;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-photo-bottom-row .window-measure-inline-cell {
        grid-column: 1;
        order: 5;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-side-column > :nth-child(2) {
        grid-column: 2;
        order: 5;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-side-column > :nth-child(1) {
        grid-column: 1;
        order: 6;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-side-column > :nth-child(3) {
        grid-column: 2;
        order: 6;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-photo-bottom-row .status-choice-stack,
    .window-glass-side-column .status-choice-stack {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 2px 8px 10px;
        margin-top: auto;
        width: 100%;
    }
    .window-glass-photo-bottom-row .status-choice-btn,
    .window-glass-side-column .status-choice-btn {
        height: 44px;
        width: 100%;
        padding: 0 8px;
    }
    .excel-row-window-handle.is-fit .window-handle-layout {
        grid-template-areas:
            "photo"
            "main"
            "side"
            "fitted";
    }
    .excel-row-window-handle.is-fit .window-handle-photo-card.is-fit-hidden {
        display: grid;
    }
    .excel-row-window-glass.is-fit .window-glass-layout {
        grid-template-areas: none;
    }
    .excel-row-window-glass .window-handle-fitted-photo-card {
        grid-column: 1;
        order: 7;
        width: 100%;
        max-width: 100%;
        justify-self: start;
        min-height: var(--handle-row-height);
        height: auto;
    }
}

@container (max-width: 700px) {
    .excel-row-window-handle {
        grid-template-areas:
            "leading title spacer"
            "layout layout spacer"
            ". actions spacer";
        grid-template-columns: 74px minmax(0, 460px) minmax(0, 1fr);
        gap: 14px;
    }
    .admin-form-detail-page .window-handle-title-cell {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 460px;
        justify-self: start;
        display: block;
        text-align: right;
        padding: 14px 0 14px 74px;
        box-sizing: border-box;
    }
    .window-handle-layout {
        width: min(100%, 460px);
        justify-self: start;
        grid-template-columns: 1fr;
        grid-template-areas:
            "photo"
            "main"
            "side";
    }
    .window-handle-main-column,
    .window-handle-side-column,
    .window-lock-main-column,
    .window-toe-main-card {
        min-height: 0;
        height: auto;
    }
    .window-handle-main-column {
        grid-template-rows: auto auto;
    }
    .window-handle-side-column {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto;
    }
    .window-handle-side-column .window-measure-cell {
        min-height: 0;
        height: auto;
        padding-bottom: 10px;
    }
    .window-handle-side-column .status-choice-stack {
        grid-template-columns: 1fr;
        margin-top: 4px;
    }
    .window-lock-spacer {
        display: none;
    }
    .excel-row-window-handle.is-fit .window-handle-layout {
        grid-template-areas:
            "photo"
            "main"
            "side"
            "fitted";
    }
    .excel-row-window-handle.is-fit .window-handle-photo-card.is-fit-hidden {
        display: grid;
    }
    .admin-form-detail-page .excel-row-window-handle .excel-row-actions {
        grid-area: actions;
        grid-column: 1 / 3;
        justify-content: stretch;
        align-self: start;
        width: 100%;
        max-width: 460px;
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-window-handle .excel-delete-btn {
        width: 100%;
        max-width: 460px;
        min-width: 0;
        min-height: 36px;
        height: auto;
        padding: 8px 12px;
        gap: 8px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
    }
    .admin-form-detail-page .excel-row-window-handle .excel-delete-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
}

@container (max-width: 440px) {
    .excel-group-card .window-measure-cell:has(.status-choice-stack),
    .excel-group-card .window-measure-inline-cell:has(.status-choice-stack) {
        min-height: 132px;
        height: auto;
        padding-top: 0;
        padding-bottom: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }
    .excel-group-card .window-measure-cell {
        padding-bottom: 0;
        display: flex;
        flex-direction: column;
    }
    .excel-group-card .window-measure-cell-label {
        min-height: 24px;
        padding-top: 10px;
        padding-bottom: 6px;
        margin-bottom: 0;
    }
    .excel-group-card .status-choice-stack {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 2px 12px 10px;
        margin-top: auto;
        width: 100%;
    }
    .excel-group-card .status-choice-btn {
        height: 44px;
        width: 100%;
        padding: 0 12px;
    }
    .window-glass-photo-bottom-row .status-choice-stack,
    .window-glass-side-column .status-choice-stack {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 2px 8px 10px;
        margin-top: auto;
        width: 100%;
    }
    .window-glass-photo-bottom-row .status-choice-btn,
    .window-glass-side-column .status-choice-btn {
        height: 44px;
        width: 100%;
        padding: 0 8px;
    }
    .excel-row-window-handle {
        grid-template-areas:
            "leading title spacer"
            "layout layout"
            ". actions spacer";
        grid-template-columns: 56px minmax(0, 200px) minmax(0, 1fr);
    }
    .admin-form-detail-page .window-handle-title-cell {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 200px;
        justify-self: start;
        display: block;
        text-align: right;
        padding: 14px 0 14px 56px;
        box-sizing: border-box;
    }
    .window-handle-layout {
        width: min(100%, 200px);
        justify-self: start;
        grid-template-columns: 1fr;
        grid-template-areas:
            "photo"
            "main"
            "side";
    }
    .door-measure-layout {
        width: min(100%, 200px);
        justify-self: start;
        grid-template-columns: 1fr;
    }
    .door-measure-grid {
        grid-template-columns: 1fr;
        grid-column: 1;
    }
    .window-handle-main-column {
        grid-template-rows: auto var(--handle-row-height);
        min-height: 0;
        height: auto;
    }
    .window-lock-main-column .window-measure-inline-cell {
        min-height: var(--handle-row-height);
        height: auto;
    }
    .window-lock-main-column {
        grid-template-rows: auto;
    }
    .window-lock-spacer {
        display: none;
    }
    .window-glass-layout {
        width: min(100%, 200px);
        justify-self: start;
        grid-template-columns: 1fr;
        grid-template-areas: none;
    }
    .window-glass-main-column,
    .window-glass-side-column,
    .window-glass-photo-bottom-row,
    .excel-row-window-glass .window-handle-photo-card,
    .excel-row-window-glass .window-handle-fitted-photo-card {
        min-height: 0;
        height: auto;
    }
    .window-glass-dimensions-grid .window-measure-inline-cell,
    .window-glass-extra-row .window-measure-inline-cell,
    .window-glass-photo-bottom-row .window-measure-inline-cell,
    .window-glass-side-column .window-measure-cell,
    .window-glass-other-type-card {
        width: 100%;
        max-width: 196px;
        justify-self: start;
        box-sizing: border-box;
    }
    .window-glass-photo-bottom-row .window-measure-inline-cell,
    .window-glass-side-column .window-measure-cell {
        min-height: 132px;
        height: auto;
        overflow: visible;
        padding-bottom: 0;
    }
    .window-glass-main-column,
    .window-glass-side-column {
        display: contents;
    }
    .window-glass-photo-bottom-row {
        display: block;
    }
    .window-glass-dimensions-grid {
        display: contents;
    }
    .window-glass-extra-row {
        display: grid;
        grid-column: 1;
        order: 4 !important;
        grid-template-columns: 1fr;
        gap: 14px;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .excel-row-window-glass .window-handle-photo-card {
        grid-area: auto;
        grid-column: 1;
        order: 1;
    }
    .window-glass-dimensions-grid .glass-width-cell {
        grid-column: 1;
        order: 2;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-dimensions-grid .glass-height-cell {
        grid-column: 1;
        order: 3;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-extra-row .glass-type-cell {
        grid-column: 1;
        order: 1 !important;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-extra-row.no-other-glass-type .glass-type-cell {
        grid-column: 1;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-other-type-card {
        display: block;
        grid-column: 1;
        order: 2 !important;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-other-type-card .glass-other-type-cell,
    .window-glass-extra-row .glass-other-type-cell {
        grid-column: 1;
        order: 2 !important;
        width: 100%;
        max-width: 100%;
        justify-self: start;
    }
    .window-glass-dimensions-grid .glass-spacer-depth-cell {
        grid-column: 1;
        order: 5 !important;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-dimensions-grid .glass-spacer-colour-cell {
        grid-column: 1;
        order: 6 !important;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-photo-bottom-row {
        grid-area: auto;
        grid-column: 1;
        order: 7 !important;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-side-column > :nth-child(1) {
        grid-column: 1;
        order: 8 !important;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-side-column > :nth-child(2) {
        grid-column: 1;
        order: 9 !important;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-glass-side-column > :nth-child(3) {
        grid-column: 1;
        order: 10 !important;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .excel-row-window-glass .window-handle-fitted-photo-card {
        grid-area: auto;
        grid-column: 1;
        order: 11;
        width: 196px;
        max-width: 196px;
        justify-self: start;
    }
    .window-toe-main-card {
        min-height: 0;
        height: auto;
    }
    .window-handle-side-column {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto;
    }
    .window-handle-side-column .window-measure-cell {
        min-height: 0;
        height: auto;
        padding-bottom: 10px;
    }
    .window-handle-side-column .status-choice-stack {
        grid-template-columns: 1fr;
        margin-top: 4px;
    }
    .excel-row-window-handle.is-fit .window-handle-layout {
        grid-template-areas:
            "photo"
            "main"
            "side"
            "fitted";
    }
    .window-handle-type-row.has-other,
    .window-handle-colour-row.has-other {
        grid-template-columns: 1fr;
        height: auto;
    }
    .window-handle-other-type-card,
    .window-handle-other-colour-card {
        height: auto;
    }
    .excel-row-window-handle.is-fit .window-handle-fitted-photo-card {
        grid-area: fitted;
    }
    .excel-row-window-handle.is-fit .window-handle-photo-card.is-fit-hidden {
        display: grid;
    }
    .excel-row-window-glass.is-fit .window-glass-layout {
        grid-template-areas: none;
    }
    .admin-form-detail-page .excel-row-window-handle .excel-row-actions {
        grid-area: actions;
        grid-column: 1 / 3;
        justify-content: stretch;
        width: 100%;
        max-width: 200px;
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-window-handle .excel-delete-btn {
        width: 100%;
        max-width: 200px;
        min-width: 0;
        min-height: 36px;
        height: auto;
        padding: 8px 12px;
        gap: 8px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
    }
    .admin-form-detail-page .excel-row-window-handle .excel-delete-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
    .admin-form-detail-page .excel-row-window-handle .excel-delete-btn {
        width: 100%;
        max-width: 200px;
    }
}
.media-trigger-shell {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    margin: 6px 8px 8px;
    min-height: 0;
}
.sketch-trigger {
    width: 100%;
    margin: 0;
    height: 180px;
    min-height: 180px;
    max-height: 180px;
    border: 1px solid #ccd8e4;
    border-radius: 12px;
    background: #fff;
    padding: 0;
    overflow: hidden;
    cursor: pointer;
}
.sketch-trigger.drag-hover {
    border-style: dashed;
    border-color: #1d4ed8;
    background: #eef5fc;
}
.media-validation-toast {
    position: fixed;
    right: 24px;
    bottom: 24px;
    z-index: 220;
    max-width: min(420px, calc(100vw - 32px));
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid #efc6c6;
    background: #fff5f5;
    color: var(--brand-red);
    font-weight: 600;
    box-shadow: 0 16px 32px rgba(15, 23, 42, 0.18);
    opacity: 0;
    transform: translateY(10px);
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease;
}
.media-validation-toast.show {
    opacity: 1;
    transform: translateY(0);
}
.office-status-toast {
    position: fixed;
    right: 24px;
    bottom: 24px;
    z-index: 3800;
    max-width: min(340px, calc(100vw - 32px));
    padding: 12px 16px;
    border-radius: 14px;
    border: 1px solid #cddced;
    background: #f7fbff;
    color: #173a63;
    font-weight: 700;
    box-shadow: 0 16px 32px rgba(15, 23, 42, 0.18);
    opacity: 0;
    transform: translateY(10px);
    pointer-events: none;
    transition: opacity .18s ease, transform .18s ease;
}
.office-status-toast.is-success {
    border-color: #b7e0c0;
    background: #f1fbf4;
    color: #166534;
}
.office-status-toast.is-error {
    border-color: #efc6c6;
    background: #fff5f5;
    color: var(--brand-red);
}
.office-status-toast.show {
    opacity: 1;
    transform: translateY(0);
}
.sketch-trigger-preview {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    overflow: hidden;
}
.sketch-trigger-preview canvas {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    image-rendering: auto;
}
.sketch-trigger-preview img {
    display: block;
    flex: 0 0 auto;
    max-width: 100% !important;
    max-height: 100% !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain;
    object-position: center;
    background: #fff;
}
.office-media-trigger-preview,
.office-media-preview,
.photo-thumb {
    position: relative;
}
.office-media-trigger-preview {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    min-width: 0;
    min-height: 0;
}
.office-media-preview,
.photo-thumb {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    min-width: 0;
    min-height: 0;
}
.office-media-image-frame {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    aspect-ratio: auto !important;
    overflow: hidden;
    background: #fff;
}
.office-media-image-frame img {
    display: block;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;
    object-position: center;
}
.office-media-trigger-preview img,
.office-media-preview img,
.photo-thumb img {
    position: relative;
    z-index: 1;
}
.office-media-image-frame .office-media-markup {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
    pointer-events: none;
}
.sketch-trigger-preview canvas {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;
}
.sketch-trigger-preview .sketch-trigger-video,
.sketch-trigger-preview video {
    flex: 0 0 auto;
    display: block;
    max-width: 100% !important;
    max-height: 100% !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain;
    object-position: center;
    background: linear-gradient(180deg, #eef5ff 0%, #dfeafb 100%);
}

.inline-video-preview-shell {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 180px;
    background: linear-gradient(180deg, #eef5ff 0%, #dfeafb 100%);
}

.inline-video-preview-badge {
    position: absolute;
    left: 12px;
    bottom: 12px;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(22, 59, 114, 0.88);
    color: #fff;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    pointer-events: none;
}
.sketch-trigger {
    width: 100%;
}
.sketch-trigger-preview {
    width: 100%;
    height: 100%;
}
.sketch-trigger-preview.is-sketch-preview img {
    object-fit: contain;
}
.office-sketch-preview svg {
    width: 100%;
    height: 100%;
    display: block;
    overflow: visible;
}
.sketch-preview-empty {
    padding: 18px;
    color: var(--text-secondary);
    text-align: center;
    line-height: 1.5;
}
.window-measure-column,
.window-measure-status-column {
    display: grid;
    grid-auto-rows: minmax(72px, auto);
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    overflow: hidden;
    background: #f8fafc;
}
.window-measure-side-column {
    display: grid;
    grid-template-rows: auto auto;
    gap: 14px;
}
.window-measure-status-row {
    grid-area: status;
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 188px;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    overflow: hidden;
    background: #f8fafc;
}
.window-measure-status-stack {
    display: grid;
    grid-template-rows: minmax(0, 1fr);
    min-width: 0;
}
.window-measure-status-row .status-choice-stack,
.window-measure-status-column .status-choice-stack {
    gap: 8px;
    padding: 4px 14px 6px;
}
.window-measure-status-stack.has-other-glass-type {
    grid-template-rows: auto auto;
}
.window-measure-other-glass-type.is-hidden {
    display: none;
}
.window-measure-status-row .window-measure-cell {
    border-top: 0;
    min-height: 82px;
    height: 100%;
}
.window-measure-status-row .window-measure-cell:has(.status-choice-stack),
.window-measure-status-column .window-measure-cell:has(.status-choice-stack) {
    display: flex;
    flex-direction: column;
}
.window-measure-status-row .status-choice-btn,
.window-measure-status-column .status-choice-btn {
    min-height: 0;
    height: 44px;
    width: 100%;
    padding: 0 12px;
    font-size: 1rem;
}
.window-measure-status-row .window-measure-cell + .window-measure-cell {
    border-left: 1px solid #e6edf5;
}
.window-measure-status-stack.no-other-glass-type .window-measure-cell:first-child {
    display: grid;
    grid-template-rows: auto 1fr;
}
.window-measure-status-stack.no-other-glass-type .window-measure-cell:first-child .excel-cell-input {
    min-height: 0;
    height: calc(100% - 10px);
    margin: 4px 12px 6px;
}
.window-measure-status-row .window-measure-cell:has(.status-choice-stack) .status-choice-stack,
.window-measure-status-column .window-measure-cell:has(.status-choice-stack) .status-choice-stack {
    flex: 1;
    align-content: stretch;
}
.window-measure-status-row .window-measure-cell:has(.status-choice-stack) .status-choice-btn,
.window-measure-status-column .window-measure-cell:has(.status-choice-stack) .status-choice-btn {
    height: auto;
    min-height: 44px;
}
.window-measure-status-stack .window-measure-cell + .window-measure-cell {
    border-top: 1px solid #e6edf5;
    border-left: 0;
}
.window-measure-side-grid {
    grid-area: side;
    display: grid;
    grid-template-columns: 1fr 1fr;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    overflow: hidden;
    background: #f8fafc;
}
.window-measure-side-grid .window-measure-cell {
    border-top: 1px solid #e6edf5;
    min-height: 88px;
}
.window-measure-side-grid .window-measure-cell:nth-child(-n + 2) {
    border-top: 0;
}
.window-measure-side-grid .window-measure-cell:nth-child(2n) {
    border-left: 1px solid #e6edf5;
}
.door-threshold-combined {
    grid-column: 2;
    grid-row: 1 / span 2;
    display: grid;
    grid-template-rows: minmax(0, 1fr);
    min-width: 0;
    border-left: 1px solid #e6edf5;
}
.door-threshold-combined.has-other-threshold {
    grid-template-rows: 1fr 1fr;
}
.door-threshold-combined > * {
    min-width: 0;
}
.door-threshold-combined .window-measure-cell {
    border-top: 1px solid #e6edf5;
    min-height: 88px;
    height: 100%;
}
.door-threshold-combined > *:first-child .window-measure-cell,
.door-threshold-combined > .window-measure-cell:first-child {
    border-top: 0;
}
.door-threshold-combined.no-other-threshold .door-threshold-primary .window-measure-cell {
    display: grid;
    grid-template-rows: auto 1fr;
    height: 100%;
}
.door-threshold-combined.no-other-threshold .door-threshold-primary .window-measure-cell .excel-cell-input,
.door-threshold-combined.no-other-threshold .door-threshold-primary .window-measure-cell .cell-select,
.door-threshold-combined.no-other-threshold .door-threshold-primary .window-measure-cell .cell-input {
    min-height: 0;
    height: calc(100% - 16px);
    margin: 4px 12px 12px;
}
.door-threshold-combined.no-other-threshold .door-threshold-empty {
    display: none;
}
.bay-measure-main-grid {
    --bay-single-row-height: 88px;
    align-items: stretch;
    grid-template-rows: minmax(var(--bay-single-row-height), auto) minmax(var(--bay-single-row-height), auto);
}
.bay-measure-main-grid .window-measure-inline-cell {
    min-height: var(--bay-single-row-height);
    padding: 0;
    gap: 0;
    grid-template-rows: auto 1fr;
    align-items: stretch;
    box-sizing: border-box;
}
.bay-measure-main-grid .window-measure-inline-label {
    min-height: 44px;
    padding: 10px 12px 4px;
    display: flex;
    align-items: flex-start;
    box-sizing: border-box;
}
.bay-measure-main-grid .window-measure-inline-cell .excel-cell-input,
.bay-measure-main-grid .window-measure-inline-cell .cell-select,
.bay-measure-main-grid .window-measure-inline-cell .cell-input {
    min-height: 48px;
    height: 48px;
    margin: 6px 12px 12px;
    width: calc(100% - 24px);
}
.bay-measure-colour-combined {
    grid-column: 2;
    grid-row: 1 / span 2;
    display: grid;
    grid-template-rows: 1fr 1fr;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    overflow: hidden;
    min-height: calc((var(--bay-single-row-height, 88px) * 2) + 12px);
}
.bay-measure-colour-combined.no-other-bay-colour {
    grid-template-rows: 1fr;
}
.bay-measure-colour-combined > .bay-measure-colour-primary,
.bay-measure-colour-combined > [data-other-window-colour],
.bay-measure-colour-combined > .bay-measure-main-empty {
    min-height: 0;
    border-top: 0;
    background: transparent;
}
.bay-measure-colour-primary {
    display: grid;
    grid-template-rows: auto 1fr;
    min-height: 0;
    background: transparent;
    box-sizing: border-box;
    height: 100%;
    align-self: stretch;
    border: 0;
    border-radius: 0;
}
.bay-measure-colour-primary .window-measure-cell-label,
.bay-measure-colour-combined .window-measure-inline-label,
.bay-measure-glass-combined .window-measure-inline-label {
    min-height: 44px;
    box-sizing: border-box;
}
.bay-measure-colour-primary .excel-cell-input,
.bay-measure-colour-primary .cell-select,
.bay-measure-colour-primary .cell-input {
    margin: 6px 12px 12px;
    min-height: 48px;
    height: 48px;
    width: calc(100% - 24px);
}
.bay-measure-colour-combined.no-other-bay-colour .bay-measure-colour-primary {
    height: 100%;
}
.bay-measure-colour-combined.no-other-bay-colour .bay-measure-colour-primary .excel-cell-input,
.bay-measure-colour-combined.no-other-bay-colour .bay-measure-colour-primary .cell-select,
.bay-measure-colour-combined.no-other-bay-colour .bay-measure-colour-primary .cell-input {
    flex: 1 1 auto;
    align-self: stretch;
    height: auto;
    min-height: 0;
}
.bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary {
    border-bottom: 1px solid #e6edf5;
}
.bay-measure-colour-combined > [data-other-window-colour] {
    display: grid;
    min-height: 0;
    height: 100%;
    background: transparent;
    align-self: stretch;
}
.bay-measure-colour-secondary {
    display: grid;
    grid-template-rows: auto 1fr;
    min-height: var(--bay-single-row-height, 88px);
    height: 100%;
    padding: 0;
    gap: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-sizing: border-box;
}
.bay-measure-colour-combined.has-other-bay-colour .bay-measure-colour-secondary .window-measure-inline-label {
    padding: 15px 12px 1px;
}
.bay-measure-colour-combined .window-measure-inline-label {
    min-height: 44px;
    padding: 10px 12px 4px;
    box-sizing: border-box;
    display: flex;
    align-items: flex-start;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.15;
}
.bay-measure-colour-secondary .excel-cell-input,
.bay-measure-colour-secondary .cell-select,
.bay-measure-colour-secondary .cell-input {
    margin: 6px 12px 12px;
    min-height: 48px;
    height: 48px;
    width: calc(100% - 24px);
    box-sizing: border-box;
    align-self: stretch;
}
.bay-measure-colour-combined.has-other-bay-colour .bay-measure-colour-secondary .excel-cell-input,
.bay-measure-colour-combined.has-other-bay-colour .bay-measure-colour-secondary .cell-select,
.bay-measure-colour-combined.has-other-bay-colour .bay-measure-colour-secondary .cell-input {
    margin: 10px 12px 8px;
}
.bay-measure-colour-combined.no-other-bay-colour .bay-measure-main-empty {
    display: none;
}
.bay-measure-side-grid {
    --bay-double-row-height: calc((var(--bay-single-row-height, 88px) * 2) + 12px);
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: minmax(var(--bay-single-row-height, 88px), auto) minmax(var(--bay-single-row-height, 88px), auto);
    gap: 12px;
    border: 0;
    border-radius: 0;
    background: transparent;
    overflow: visible;
}
.bay-measure-side-grid .window-measure-cell:nth-child(1) {
    grid-column: 1;
    grid-row: 1;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    min-height: var(--bay-single-row-height, 88px);
}
.bay-measure-side-grid .window-measure-cell:nth-child(2) {
    grid-column: 2;
    grid-row: 1;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    min-height: var(--bay-single-row-height, 88px);
}
.bay-measure-side-grid .window-measure-cell:nth-child(3) {
    grid-column: 1;
    grid-row: 2;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    min-height: var(--bay-single-row-height, 88px);
}
.bay-measure-glass-combined {
    grid-column: 2;
    grid-row: 1 / span 2;
    display: grid;
    grid-template-rows: 1fr 1fr;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    overflow: hidden;
    min-height: calc((var(--bay-single-row-height, 88px) * 2) + 12px);
}
.bay-measure-glass-combined.no-other-glass-type {
    grid-template-rows: 1fr;
}
.bay-measure-glass-combined > .bay-measure-glass-primary,
.bay-measure-glass-combined > [data-other-glass-type],
.bay-measure-glass-combined > .bay-measure-side-empty {
    min-height: 0;
    border-top: 0;
    background: transparent;
}
.bay-measure-glass-combined .bay-measure-glass-primary,
.bay-measure-glass-combined .window-measure-inline-cell {
    border: 0;
    border-radius: 0;
    background: transparent;
    min-height: 0;
}
.bay-measure-glass-primary {
    display: grid;
    grid-template-rows: auto 1fr;
    min-height: 0;
    height: 100%;
    box-sizing: border-box;
}
.bay-measure-glass-combined.no-other-glass-type .bay-measure-glass-primary {
    height: 100%;
}
.bay-measure-glass-combined .window-measure-cell-label {
    padding: 10px 12px 4px;
    min-height: 44px;
    box-sizing: border-box;
}
.bay-measure-glass-primary .excel-cell-input,
.bay-measure-glass-primary .cell-select,
.bay-measure-glass-primary .cell-input {
    margin: 6px 12px 12px;
    min-height: 48px;
    height: 48px;
    width: calc(100% - 24px);
}
.bay-measure-glass-combined.no-other-glass-type .bay-measure-glass-primary .excel-cell-input,
.bay-measure-glass-combined.no-other-glass-type .bay-measure-glass-primary .cell-select,
.bay-measure-glass-combined.no-other-glass-type .bay-measure-glass-primary .cell-input {
    align-self: stretch;
    min-height: 0;
    height: auto;
    flex: 1 1 auto;
}
.bay-measure-glass-combined > [data-other-glass-type] {
    display: grid;
    min-height: 0;
    height: 100%;
    background: #f8fafc;
    align-self: stretch;
}
.bay-measure-glass-combined.has-other-glass-type > [data-other-glass-type] .window-measure-inline-cell {
    min-height: var(--bay-single-row-height, 88px);
    grid-template-rows: auto auto;
}
.bay-measure-glass-combined.has-other-glass-type > [data-other-glass-type] .window-measure-inline-label {
    padding: 12px 12px 2px;
}
.bay-measure-glass-combined .window-measure-inline-cell {
    padding: 0;
    gap: 0;
    grid-template-rows: auto 1fr;
    height: 100%;
}
.bay-measure-glass-combined .window-measure-inline-label {
    min-height: 44px;
    padding: 10px 12px 4px;
    box-sizing: border-box;
    display: flex;
    align-items: flex-start;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.15;
}
.bay-measure-glass-combined .window-measure-inline-cell .excel-cell-input {
    margin: 6px 12px 12px;
    min-height: 48px;
    height: 48px;
    width: calc(100% - 24px);
    box-sizing: border-box;
    align-self: stretch;
}
.bay-measure-glass-combined.has-other-glass-type > [data-other-glass-type] .window-measure-inline-cell .excel-cell-input {
    margin: 8px 12px 10px;
}
.bay-measure-glass-combined.has-other-glass-type > *:first-child {
    border-bottom: 1px solid #e6edf5;
}
.bay-measure-glass-combined.no-other-glass-type .bay-measure-side-empty {
    display: none;
}
.bay-measure-side-empty {
    visibility: hidden;
}
.bay-measure-mobile-angle-list,
.bay-measure-mobile-tail,
.bay-measure-mobile-status-card,
.bay-measure-mobile-fit-photo,
.bay-measure-mobile-tail-v2,
.bay-measure-mobile-status-card-v2,
.bay-measure-mobile-fit-photo-v2 {
    display: none;
}
.window-measure-cell {
    display: grid;
    grid-template-rows: auto 1fr;
    min-height: 82px;
    border-top: 1px solid #e6edf5;
}
.window-measure-column .window-measure-cell:first-child,
.window-measure-status-column .window-measure-cell:first-child {
    border-top: 0;
}
.window-measure-cell.empty {
    background: #f8fafc;
}
.window-measure-cell-label {
    padding: 10px 12px 4px;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    min-height: 34px;
    display: flex;
    align-items: flex-start;
    line-height: 1.15;
    box-sizing: border-box;
}
.window-measure-side-grid .window-measure-cell-label {
    min-height: 44px;
}
.window-measure-cell .excel-cell-input {
    min-height: 40px;
    margin: 6px 12px 12px;
    width: calc(100% - 24px);
}
.window-measure-side-grid .window-measure-cell .excel-cell-input {
    min-height: 48px;
}
.window-measure-side-grid .window-measure-cell .cell-select,
.window-measure-side-grid .window-measure-cell .cell-input {
    height: 48px;
}
.bay-measure-side-grid .bay-measure-glass-type-stack.no-other-glass-type .excel-cell-input,
.bay-measure-side-grid .bay-measure-glass-type-stack.no-other-glass-type .cell-select,
.bay-measure-side-grid .bay-measure-glass-type-stack.no-other-glass-type .cell-input {
    flex: 1 1 auto;
    align-self: stretch;
    height: auto;
    min-height: 0;
}
.window-measure-cell .cell-select,
.window-measure-inline-cell .cell-select,
.window-measure-addon-item .cell-select {
    color: var(--brand-navy);
}
.window-measure-cell .cell-select.is-placeholder,
.window-measure-inline-cell .cell-select.is-placeholder,
.window-measure-addon-item .cell-select.is-placeholder,
.window-measure-media-card .cell-select.is-placeholder {
    color: #94a3b8;
}
.status-choice-stack {
    display: grid;
    gap: 8px;
    padding: 6px 16px 12px;
    align-content: start;
}
.status-choice-btn {
    min-height: 42px;
    border-radius: 14px;
    border: 1px solid #d7e1eb;
    font-weight: 700;
    cursor: pointer;
    background: #fff;
    width: 100%;
    padding: 0 12px;
}
.status-choice-btn {
    position: relative;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.window-glass-type-grid .status-choice-btn,
.window-glass-answer-grid .status-choice-btn {
    font-size: 0;
}
.window-glass-type-grid .status-choice-btn::after,
.window-glass-answer-grid .status-choice-btn::after {
    content: attr(data-short-label);
    font-size: 0.9rem;
}
.status-choice-btn.required {
    color: #c62828;
    border-color: rgba(198, 40, 40, 0.24);
    background: rgba(198, 40, 40, 0.05);
}
.status-choice-btn.required.active {
    background: #c62828;
    color: #fff;
    border-color: #c62828;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
}
.status-choice-btn.fit {
    color: #12813a;
    border-color: rgba(18, 129, 58, 0.24);
    background: rgba(18, 129, 58, 0.05);
}
.status-choice-btn.fit.active {
    background: #12813a;
    color: #fff;
    border-color: #12813a;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
}
.flag-choice-stack {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    padding: 6px 12px 12px;
    align-content: start;
}
.flag-choice-btn {
    min-height: 42px;
    border-radius: 12px;
    border: 1px solid #c7d5e6;
    background: #fff;
    color: var(--brand-navy);
    font-weight: 700;
    cursor: pointer;
    width: 100%;
    padding: 0 8px;
    transition: background-color 120ms ease, border-color 120ms ease, box-shadow 120ms ease;
}
.flag-choice-btn.active {
    background: #e8f3ff;
    border: 2px solid #1d4ed8;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.5);
}
.window-measure-cell textarea.excel-cell-input {
    min-height: 88px;
}
.window-measure-main-column {
    display: grid;
    grid-template-rows: auto 1fr;
    gap: 14px;
}
.window-measure-main-grid {
    grid-area: main;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.window-measure-addon-column {
    display: grid;
    grid-template-rows: auto 1fr;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    overflow: hidden;
    background: #f8fafc;
}
.window-measure-addon-stack {
    grid-area: addon;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 8px;
    align-content: start;
    height: 100%;
    min-height: 0;
}
.window-measure-addon-stack.no-other-colour {
    grid-template-rows: minmax(0, 1fr);
    min-height: 180px;
}
.window-measure-addon-stack.no-other-colour .window-measure-addon-column {
    height: 100%;
    min-height: 180px;
}
.window-measure-other-colour-card {
    grid-template-rows: 1fr;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    overflow: hidden;
    background: #f8fafc;
}
.window-measure-other-colour-card.is-hidden {
    display: none;
}
.window-measure-other-colour-card .window-measure-inline-cell {
    min-height: 58px;
    border: 0;
    background: #f8fafc;
    padding: 8px 12px 8px;
}
.window-measure-other-colour-card .window-measure-inline-cell:first-child {
    border-top: 0;
}
.window-measure-other-colour-card .window-measure-inline-label {
    margin-bottom: 0;
}
.window-measure-other-colour-card .window-measure-inline-cell .excel-cell-input {
    min-height: 34px;
}
.window-measure-addon-head {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border-bottom: 1px solid #e6edf5;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.window-measure-addon-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
    min-width: 0;
    height: 100%;
}
.window-measure-addon-item {
    display: flex;
    flex-direction: row;
    gap: 10px;
    align-items: center;
    min-height: 48px;
    min-width: 0;
    padding: 8px 12px;
    border-top: 1px solid #e6edf5;
    background: #f8fafc;
}
.window-measure-addon-item:nth-child(-n + 2) {
    border-top: 0;
}
.window-measure-addon-item:nth-child(2n) {
    border-left: 1px solid #e6edf5;
}
.window-measure-addon-item.empty {
    background: #f8fafc;
}
.window-measure-addon-label {
    flex: 0 0 52px;
    display: block;
    min-width: 0;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--brand-navy);
    line-height: 1.2;
}
.window-measure-addon-item .excel-cell-input {
    flex: 1 1 auto;
    display: block;
    min-height: 34px;
    min-width: 0;
    width: 100%;
    margin: 0;
}
.compact-addon-card {
    width: 100%;
    max-width: 200px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    overflow: hidden;
    background: #f8fafc;
    box-sizing: border-box;
}
.compact-addon-head {
    min-height: 34px;
    padding: 7px 12px 6px;
    border-bottom: 1px solid #e6edf5;
    text-align: center;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.1;
}
.compact-addon-body {
    display: flex;
    flex-direction: column;
}
.compact-addon-row {
    display: grid;
    grid-template-columns: 56px 112px;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-height: 56px;
    height: 56px;
    padding: 0 12px;
    background: #f8fafc;
    box-sizing: border-box;
}
.compact-addon-row + .compact-addon-row {
    border-top: 1px solid #e6edf5;
}
.compact-addon-label {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--brand-navy);
    line-height: 1;
}
.compact-addon-input .excel-cell-input,
.compact-addon-input .cell-input,
.compact-addon-input .cell-select {
    height: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
    width: 112px !important;
    min-width: 112px !important;
    margin: 0 !important;
    border-radius: 10px;
}
.bay-measure-angle-column {
    display: contents;
}
.bay-measure-angle-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
    min-width: 0;
    height: auto;
    align-items: stretch;
}
.bay-measure-angle-grid .window-measure-addon-item {
    border-top: 1px solid #e6edf5;
    border-left: 0;
    border-radius: 0;
    background: #f8fafc;
    min-height: 48px;
    width: auto;
    padding: 8px 12px;
}
.bay-measure-angle-grid .window-measure-addon-item:nth-child(-n + 2),
.bay-measure-angle-grid .window-measure-addon-item:nth-child(2n) {
    border-top: 0;
}
.bay-measure-angle-grid .window-measure-addon-item:nth-child(2n) {
    border-left: 1px solid #e6edf5;
}
.bay-measure-angle-grid .window-measure-addon-item:nth-child(3),
.bay-measure-angle-grid .window-measure-addon-item:nth-child(4) {
    border-top: 1px solid #e6edf5;
}
.bay-measure-angle-grid .window-measure-addon-item:first-child {
    border-top: 0;
}
.bay-measure-angle-grid .window-measure-addon-label {
    flex: 0 0 52px;
    white-space: nowrap;
    flex-basis: 52px;
}
.bay-measure-left-stack,
.bay-measure-angle-card {
    width: auto;
    min-width: 0;
    display: grid;
    grid-template-columns:
        220px
        minmax(153px, 1fr)
        minmax(153px, 1fr)
        minmax(124px, 1fr)
        minmax(124px, 1fr);
    gap: 14px;
    align-items: start;
}
.bay-measure-segment-sketch-card {
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: stretch;
    height: 100%;
}
.bay-measure-segment-right {
    display: contents;
}
.bay-measure-segment-right > .window-measure-cell,
.bay-measure-segment-right > .window-measure-inline-cell,
.bay-measure-segment-right > .window-measure-addon-column,
.bay-measure-segment-right > .window-measure-media-card {
    width: 100%;
    min-width: 0;
}
.bay-measure-segment-right > .bay-measure-segment-width-card {
    grid-column: 2;
    grid-row: 1;
}
.bay-measure-segment-right > .bay-measure-angle-top-card,
.bay-measure-segment-right > .bay-measure-segment-status-card {
    grid-column: 2;
    grid-row: 2;
}
.bay-measure-segment-right > .bay-measure-segment-top-spacer {
    grid-column: 2;
    grid-row: 2;
    display: block;
    width: 100%;
    min-width: 0;
    min-height: 82px;
    height: 100%;
    box-sizing: border-box;
    align-self: stretch;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
}
.bay-measure-segment-right > .bay-measure-segment-extras-combined {
    grid-column: 3 / span 2;
    grid-row: 1 / span 2;
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto 1fr;
    column-gap: 0;
    row-gap: 0;
    padding: 0;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    overflow: hidden;
    align-self: stretch;
    height: 100%;
}
.bay-measure-segment-right > .bay-measure-segment-extras-combined::before {
    content: "";
    position: absolute;
    top: 0;
    height: 82px;
    left: 50%;
    width: 1px;
    background: #e6edf5;
    transform: translateX(-0.5px);
    pointer-events: none;
}
.bay-measure-segment-extras-combined > .window-measure-cell:nth-child(1) {
    grid-column: 1;
    grid-row: 1;
}
.bay-measure-segment-extras-combined > .window-measure-cell:nth-child(2) {
    grid-column: 2;
    grid-row: 1;
}
.bay-measure-segment-extras-combined > .bay-measure-addon-column {
    grid-column: 1 / span 2;
    grid-row: 2;
    border: 0;
    border-radius: 0;
    background: transparent;
    height: 100%;
    min-height: 100%;
}
.bay-measure-segment-extras-combined > .window-measure-cell {
    min-width: 0;
    min-height: 82px;
    border: 0;
    border-radius: 0;
    background: transparent;
}
.bay-measure-segment-extras-combined > .window-measure-cell .window-measure-cell-label {
    min-width: 0;
    padding-top: 6px;
    padding-bottom: 0;
    min-height: 30px;
}
.bay-measure-segment-extras-combined > .window-measure-cell .excel-cell-input,
.bay-measure-segment-extras-combined > .window-measure-cell .cell-select,
.bay-measure-segment-extras-combined > .window-measure-cell .cell-input {
    min-width: 0;
    margin: 2px 12px 4px;
}
.bay-measure-segment-extras-combined > .bay-measure-addon-column .window-measure-addon-head {
    min-height: 32px;
}
.bay-measure-segment-extras-combined > .bay-measure-addon-column .window-measure-addon-item {
    min-height: 52px;
    padding-top: 6px;
    padding-bottom: 6px;
}
.bay-measure-segment-extras-combined > .bay-measure-addon-column .window-measure-addon-item .excel-cell-input {
    min-height: 32px;
}
.bay-measure-segment-extras-combined > .bay-measure-addon-column {
    border-top: 1px solid #e6edf5;
}
.bay-measure-segment-right > .bay-measure-segment-spacer {
    grid-column: 5;
    grid-row: 1 / span 2;
    display: block;
    width: 100%;
    min-width: 0;
    min-height: 100%;
    height: 100%;
    align-self: stretch;
    justify-self: stretch;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
}
.bay-measure-segment-right > .bay-measure-segment-tail-stack {
    grid-column: 5;
    grid-row: 1 / span 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
    align-self: stretch;
    height: 100%;
    min-height: 100%;
}
.bay-measure-segment-tail-stack > .bay-measure-segment-tail-status {
    min-height: 100%;
}
.bay-measure-segment-tail-photo {
    display: none;
}
.bay-measure-segment-right > .window-measure-cell {
    min-height: 82px;
    height: 100%;
    align-self: stretch;
    border: 1px solid #d7e1eb;
    border-top: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
}
.bay-measure-segment-right > .window-measure-cell .excel-cell-input,
.bay-measure-segment-right > .window-measure-cell .cell-select,
.bay-measure-segment-right > .window-measure-cell .cell-input {
    min-height: 40px;
    margin: 6px 12px 12px;
    width: calc(100% - 24px);
}
.bay-measure-angle-width-cell {
    border-top: 1px solid #d7e1eb;
}
.bay-measure-addon-stack {
    grid-column: 1 / -1;
    grid-row: 2;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
    justify-content: stretch;
    align-content: start;
}
.bay-measure-addon-stack > .bay-measure-left-stack:not(:last-child),
.bay-measure-addon-stack > .bay-measure-angle-card:not(:last-child) {
    padding-bottom: 14px;
    border-bottom: 1px solid #d7e1eb;
}
.window-measure-inline-cell {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
    align-items: stretch;
    min-height: 82px;
    padding: 8px 12px;
    border-top: 1px solid #e6edf5;
}
.window-measure-inline-cell:first-child {
    border-top: 0;
}
.window-measure-main-grid .window-measure-inline-cell {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    min-height: 82px;
}
.window-measure-main-grid .window-measure-inline-cell:first-child {
    border-top: 1px solid #d7e1eb;
}
.window-measure-inline-cell.empty {
    background: #f8fafc;
}
.window-measure-inline-label {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.window-measure-inline-cell .excel-cell-input {
    min-height: 40px;
    width: 100%;
    margin: 0;
}
.excel-row-actions {
    min-width: 0;
}
.excel-delete-btn {
    width: 34px;
    height: 34px;
}
.excel-row-actions.has-action-stack .excel-delete-btn {
    width: 34px;
    min-width: 34px;
    height: 34px;
    padding: 0;
}
.audit-layout {
    grid-template-columns: 1fr;
}
.sketch-editor-overlay.hidden {
    display: none;
}
.sketch-editor-overlay {
    position: fixed;
    inset: 0;
    z-index: 50;
}
.sketch-editor-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 24, 45, 0.45);
}
.sketch-editor-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(920px, calc(100vw - 64px));
    max-height: calc(100vh - 64px);
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.28);
    padding: 18px;
    display: grid;
    grid-template-rows: auto auto 1fr auto;
    gap: 12px;
}
.sketch-editor-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}
.sketch-editor-head h3 {
    margin: 0;
}
.sketch-editor-head p {
    margin: 4px 0 0;
    color: var(--text-secondary);
}
.sketch-editor-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    padding-right: 4px;
}
.sketch-editor-shape-tools {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.sketch-editor-shape-tools.hidden {
    display: none;
}
.sketch-editor-arch-variant {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    border: 1px solid #ccd8e4;
    border-radius: 10px;
    background: #fff;
    color: var(--text-secondary);
    font-weight: 600;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
    z-index: 2;
    pointer-events: auto;
}
.sketch-editor-arch-variant.hidden {
    display: none;
}
.sketch-editor-arch-variant span {
    font-size: 0.85rem;
}
.sketch-editor-arch-variant select {
    min-height: 30px;
    border: 1px solid #ccd8e4;
    border-radius: 8px;
    background: #fff;
    color: var(--text-primary);
    padding: 4px 28px 4px 8px;
}
.sketch-editor-stage {
    border: 1px solid #d7e1eb;
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
    position: relative;
}
.sketch-editor-toolbar .text-btn {
    min-height: 34px;
    padding: 6px 12px;
    border: 1px solid #ccd8e4;
    border-radius: 10px;
    background: #fff;
    color: var(--text-secondary);
    font-weight: 600;
}
.sketch-editor-toolbar .text-btn.is-active {
    border-color: #1d4ed8;
    color: #1d4ed8;
    background: #eef5fc;
}
.sketch-editor-toolbar .text-btn:hover {
    background: #f7fafc;
}
.sketch-editor-toolbar .text-btn.danger {
    border-color: #f4b4b4;
    color: #b42318;
}
.sketch-editor-canvas {
    width: 100%;
    display: block;
    touch-action: none;
    background: #fff;
}
.sketch-editor-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}
body.sketch-editor-open {
    overflow: hidden;
}
body.voice-note-open {
    overflow: hidden;
}
body.media-video-preview-open {
    overflow: hidden;
}
.hidden-upload-input {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}
.voice-transcript-editor {
    display: grid;
    gap: 10px;
}

.detail-note-recorder {
    display: grid;
    grid-template-columns: 56px minmax(0, 1fr);
    grid-template-areas:
        "label label"
        "button status"
        "transcript transcript"
        "audio audio";
    gap: 8px;
    align-content: start;
    align-items: start;
    padding: 12px;
    border: 1px solid #d9e3ef;
    border-radius: 14px;
    background: #fcfdff;
}

.detail-recorder-head {
    grid-area: label;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.detail-recorder-head-left {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.detail-recorder-label {
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #5f728c;
    font-weight: 800;
}

.detail-recorder-icon-btn {
    width: 26px;
    height: 26px;
    border: 1px solid #cfe0f5;
    border-radius: 999px;
    background: #eef5ff;
    color: #204a87;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex: 0 0 auto;
}

.detail-recorder-text-btn {
    width: auto;
    height: 30px;
    gap: 6px;
    padding: 0 10px;
    border-radius: 12px;
    font-size: 0.76rem;
    font-weight: 800;
}

.detail-recorder-text-btn svg {
    width: 14px;
    height: 14px;
}

.detail-recorder-icon-btn.is-loading {
    opacity: 0.6;
    cursor: wait;
}

.detail-record-btn {
    grid-area: button;
    width: 56px;
    height: 56px;
    border: none;
    border-radius: 999px;
    background: #17b26a;
    color: #fff;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 0 10px 20px rgba(23, 178, 106, 0.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.detail-record-btn.active {
    box-shadow: 0 0 0 4px rgba(23, 178, 106, 0.24);
    transform: scale(0.985);
}

.detail-recorder-status {
    grid-area: status;
    display: grid;
    gap: 4px;
    align-content: center;
    min-width: 0;
    padding-top: 2px;
}

.detail-recorder-wave {
    display: flex;
    align-items: end;
    gap: 5px;
    min-height: 16px;
}

.detail-recorder-wave span {
    width: 6px;
    height: 9px;
    border-radius: 999px;
    background: #9bc6ff;
    transition: transform 0.18s ease, height 0.18s ease, background 0.18s ease;
}

.detail-note-recorder.recording .detail-recorder-wave span {
    background: #17b26a;
    animation: detail-wave 0.9s ease-in-out infinite;
}

.detail-note-recorder.recording .detail-recorder-wave span:nth-child(2) {
    animation-delay: 0.1s;
}

.detail-note-recorder.recording .detail-recorder-wave span:nth-child(3) {
    animation-delay: 0.2s;
}

.detail-note-recorder.recording .detail-recorder-wave span:nth-child(4) {
    animation-delay: 0.3s;
}

.detail-note-recorder.recording .detail-recorder-wave span:nth-child(5) {
    animation-delay: 0.4s;
}

.detail-recorder-copy {
    margin: 0;
    color: #667892;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.2;
}

.detail-record-timer {
    font-size: 0.88rem;
    font-weight: 800;
    color: #163b72;
    line-height: 1.1;
}

.detail-recorder-transcript-status {
    grid-area: transcript;
    margin-top: 0;
    color: #5f728c;
    font-size: 0.78rem;
    line-height: 1.4;
    display: none !important;
}

.detail-audio-empty {
    min-height: 34px;
    display: flex;
    align-items: center;
    padding: 0 10px;
    border: 1px dashed #cfd9e7;
    border-radius: 10px;
    color: #78879b;
    background: #fff;
    grid-area: audio;
    font-size: 0.78rem;
}

.detail-audio-player {
    grid-area: audio;
    display: grid;
    gap: 6px;
    padding: 10px;
    border: 1px solid #d9e3ef;
    border-radius: 10px;
    background: #fff;
}

.detail-audio-player-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.detail-audio-top-right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

.detail-audio-play-btn {
    border: none;
    border-radius: 999px;
    padding: 6px 14px;
    background: #163b72;
    color: #fff;
    font-weight: 700;
    cursor: pointer;
    font-size: 0.78rem;
}

.detail-audio-times {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #5f728c;
    font-size: 0.8rem;
    font-weight: 700;
}

.detail-audio-slider {
    width: 100%;
    margin: 0;
}

.detail-audio-speed-btn {
    border: 1px solid #cfe0f5;
    border-radius: 999px;
    padding: 4px 10px;
    background: #eef5ff;
    color: #204a87;
    font-size: 0.74rem;
    font-weight: 800;
    cursor: pointer;
}

.detail-audio-element {
    display: none;
}

@media (max-width: 980px) {
    .admin-form-detail-page .excel-row-detail {
        grid-template-areas:
            "leading title actions"
            "layout layout layout";
        grid-template-columns: 74px minmax(0, 1fr) 48px;
    }
    .admin-form-detail-page .detail-row-title-cell {
        justify-content: flex-start;
        text-align: left;
    }
    .admin-form-detail-page .detail-note-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .admin-form-detail-page .excel-row-detail {
        grid-template-areas:
            "title"
            "leading"
            "layout"
            "actions";
        grid-template-columns: 1fr;
    }
    .admin-form-detail-page .detail-row-title-cell,
    .admin-form-detail-page .excel-row-detail .excel-row-actions {
        justify-content: center;
        text-align: center;
    }
}

@container (max-width: 980px) {
    .admin-form-detail-page .detail-note-layout {
        grid-template-columns: 1fr;
    }
}

@container (max-width: 700px) {
    .admin-form-detail-page .excel-row-detail {
        grid-template-areas:
            "leading title spacer"
            "layout layout spacer"
            ". actions spacer";
        grid-template-columns: 74px minmax(0, 460px) minmax(0, 1fr);
        gap: 14px;
    }
    .admin-form-detail-page .detail-row-title-cell {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 460px;
        justify-self: start;
        display: block;
        text-align: right;
        padding: 14px 0 14px 74px;
        box-sizing: border-box;
    }
    .admin-form-detail-page .detail-row-layout {
        width: min(100%, 460px);
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-detail .excel-row-actions {
        grid-area: actions;
        grid-column: 1 / 3;
        justify-content: stretch;
        align-self: start;
        width: 100%;
        max-width: 460px;
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-detail .excel-delete-btn {
        width: 100%;
        max-width: 460px;
        min-width: 0;
        min-height: 40px;
        height: auto;
        padding: 8px 14px;
        gap: 8px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
    }
    .admin-form-detail-page .excel-row-detail .excel-delete-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
}

@container (max-width: 440px) {
    .admin-form-detail-page .excel-row-detail {
        grid-template-areas:
            "leading title spacer"
            "layout layout"
            ". actions spacer";
        grid-template-columns: 56px minmax(0, 200px) minmax(0, 1fr);
    }
    .admin-form-detail-page .detail-row-title-cell {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 200px;
        justify-self: start;
        display: block;
        text-align: right;
        padding: 14px 0 14px 56px;
        box-sizing: border-box;
    }
    .admin-form-detail-page .detail-row-layout {
        width: min(100%, 200px);
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-detail .excel-row-actions {
        width: 100%;
        max-width: 200px;
    }
    .admin-form-detail-page .excel-row-detail .excel-delete-btn {
        width: 100%;
        max-width: 200px;
        height: auto;
        padding: 8px 12px;
        gap: 8px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
    }
    .admin-form-detail-page .excel-row-detail .excel-delete-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
}

@keyframes detail-wave {
    0%, 100% { height: 10px; }
    50% { height: 24px; }
}

.voice-note-inline-btn {
    justify-self: start;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 10px;
    border: 1px solid #cdd9e8;
    background: #f8fbff;
    color: #163b72;
    font-weight: 700;
    cursor: pointer;
}

.sketch-trigger-video {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    border-radius: 12px;
    background: #fff;
}

.voice-note-overlay.hidden {
    display: none;
}

.media-video-preview-overlay.hidden {
    display: none;
}

.media-video-preview-overlay {
    position: fixed;
    inset: 0;
    z-index: 260;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: calc(var(--topbar-height) + 18px) 16px 24px;
    box-sizing: border-box;
}

.media-video-preview-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(12, 24, 40, 0.64);
}

.media-video-preview-modal {
    position: relative;
    width: min(860px, calc(100vw - 32px));
    margin: 0;
    padding: 18px;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.28);
    display: grid;
    gap: 14px;
}

.media-video-preview-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.media-video-preview-head h3 {
    margin: 0;
    color: #173a63;
}

.media-video-preview-head p {
    margin: 4px 0 0;
    color: #5f728c;
    font-size: 0.9rem;
}

.media-video-preview-player {
    width: 100%;
    max-height: min(52vh, 420px);
    border-radius: 14px;
    background: #0f172a;
}

.media-video-preview-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.voice-note-overlay {
    position: fixed;
    inset: 0;
    z-index: 90;
}

.voice-note-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.36);
}

.voice-note-modal {
    position: relative;
    z-index: 1;
    width: min(680px, calc(100vw - 32px));
    margin: 48px auto;
    padding: 20px;
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.24);
    display: grid;
    gap: 16px;
}

.voice-note-head {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: start;
}

.voice-note-head h3 {
    margin: 0 0 6px;
    font-size: 1.8rem;
}

.voice-note-head p {
    margin: 0;
    color: #667892;
}

.voice-note-status-card {
    display: flex;
    gap: 16px;
    align-items: center;
    padding: 16px;
    border-radius: 18px;
    background: #eef6ff;
    border: 1px solid #d4e4fb;
}

.voice-note-wave {
    display: flex;
    align-items: end;
    gap: 6px;
}

.voice-note-wave span {
    width: 8px;
    border-radius: 999px;
    background: #7fb5ff;
}

.voice-note-wave span:nth-child(1) { height: 14px; }
.voice-note-wave span:nth-child(2) { height: 18px; }
.voice-note-wave span:nth-child(3) { height: 22px; }
.voice-note-wave span:nth-child(4) { height: 18px; }
.voice-note-wave span:nth-child(5) { height: 14px; }

.voice-note-recorder-main {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 18px;
    border-radius: 22px;
    background: #12182a;
    color: #fff;
}

.voice-note-record-btn {
    width: 84px;
    height: 84px;
    border-radius: 999px;
    border: none;
    background: #f03636;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 16px 36px rgba(240, 54, 54, 0.28);
}

.voice-note-record-btn.active {
    transform: scale(0.97);
    box-shadow: 0 0 0 4px rgba(240, 54, 54, 0.26);
}

.voice-note-recorder-meta p {
    margin: 6px 0 0;
    color: rgba(255, 255, 255, 0.78);
}

.voice-note-timer {
    font-size: 2.5rem;
    font-weight: 800;
    line-height: 1;
}

.voice-note-field {
    display: grid;
    gap: 8px;
}

.voice-note-field > span {
    font-weight: 700;
    color: #54657f;
}

.voice-note-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}
.new-form-overlay.hidden {
    display: none;
}
.new-form-overlay {
    position: absolute;
    inset: 0;
    z-index: 160;
    display: grid;
    place-items: center;
    padding: 24px;
    overflow: auto;
    background: #f6faff;
}
.new-form-backdrop {
    position: absolute;
    inset: 0;
    background: #f6faff;
}
.new-form-modal {
    position: relative;
    width: min(760px, calc(100vw - 40px));
    max-height: min(86vh, 860px);
    overflow: auto;
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 24px 50px rgba(15, 23, 42, 0.24);
    padding: 24px;
}
.unfinished-leave-overlay.hidden {
    display: none;
}
.unfinished-leave-overlay {
    position: fixed;
    inset: 0;
    z-index: 3300;
}
.unfinished-leave-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 24, 45, 0.34);
    backdrop-filter: blur(3px);
}
.unfinished-leave-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(360px, calc(100vw - 32px));
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 24px 50px rgba(15, 23, 42, 0.24);
    padding: 28px 24px 22px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    align-items: center;
    text-align: center;
}
.unfinished-leave-modal h2 {
    margin: 0;
    font-size: 1.9rem;
    line-height: 1.15;
    color: #123b74;
}
.row-qty-overlay.hidden {
    display: none;
}
.row-qty-overlay {
    position: fixed;
    inset: 0;
    z-index: 3350;
}
.row-qty-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 24, 45, 0.34);
    backdrop-filter: blur(3px);
}
.row-qty-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(320px, calc(100vw - 32px));
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 24px 50px rgba(15, 23, 42, 0.24);
    padding: 26px 22px 22px;
    display: grid;
    gap: 14px;
    text-align: center;
}
.row-qty-close {
    position: absolute;
    top: 12px;
    right: 14px;
    border: 0;
    background: transparent;
    color: #5f7b99;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}
.row-qty-modal h2 {
    margin: 0;
    color: #123b74;
    font-size: 1.5rem;
    line-height: 1.15;
}
.row-qty-copy {
    color: #516786;
    font-size: 0.84rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.row-qty-stepper {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) 52px;
    gap: 12px;
    align-items: center;
}
.row-qty-step-btn {
    width: 52px;
    height: 52px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
    color: #173a63;
    font-size: 1.8rem;
    line-height: 1;
    cursor: pointer;
}
.row-qty-step-input {
    min-height: 52px;
    border: 1px solid #c6d6e6;
    border-radius: 16px;
    padding: 10px 12px;
    text-align: center;
    font-size: 1.15rem;
    font-weight: 700;
    color: #173a63;
    background: #fff;
}
.row-copy-overlay.hidden {
    display: none;
}
.row-copy-overlay {
    position: fixed;
    inset: 0;
    z-index: 3355;
}
.row-copy-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 24, 45, 0.34);
    backdrop-filter: blur(3px);
}
.row-copy-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(520px, calc(100vw - 32px));
    max-height: calc(100vh - 40px);
    overflow: auto;
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 24px 50px rgba(15, 23, 42, 0.24);
    padding: 26px 22px 22px;
    display: grid;
    gap: 14px;
}
.row-copy-close {
    position: absolute;
    top: 12px;
    right: 14px;
    border: 0;
    background: transparent;
    color: #5f7b99;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}
.row-copy-modal h2 {
    margin: 0;
    color: #123b74;
    font-size: 1.5rem;
    line-height: 1.15;
}
.row-copy-subtitle {
    margin: -4px 0 0;
    color: #516786;
}
.row-copy-body {
    display: grid;
    gap: 16px;
}
.row-copy-option-grid,
.row-copy-target-list,
.row-copy-keyboard {
    display: grid;
    gap: 12px;
}
.row-copy-option,
.row-copy-target-option {
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
    color: #173a63;
    padding: 14px 16px;
    text-align: left;
    font-weight: 700;
    cursor: pointer;
}
.row-copy-option:hover,
.row-copy-target-option:hover,
.row-copy-chip:hover {
    background: #eef5fc;
}
.row-copy-field {
    display: grid;
    gap: 8px;
    font-weight: 700;
    color: #173a63;
}
.row-copy-target-list {
    max-height: 280px;
    overflow: auto;
}
.row-copy-empty {
    border: 1px dashed #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
    color: #516786;
    padding: 14px;
}
.row-copy-keyboard {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}
.row-copy-chip {
    border: 1px solid #ccdbe8;
    border-radius: 14px;
    background: #fff;
    color: #173a63;
    padding: 10px 12px;
    font-size: 0.92rem;
    font-weight: 700;
    line-height: 1.1;
    cursor: pointer;
}
.row-copy-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}
.unfinished-leave-actions {
    display: flex;
    justify-content: center;
    gap: 14px;
    width: 100%;
}
.unfinished-leave-btn {
    border: 0;
    border-radius: 999px;
    min-width: 120px;
    padding: 14px 24px;
    font-size: 1rem;
    font-weight: 800;
    color: #fff;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.unfinished-leave-btn:hover {
    transform: translateY(-1px);
}
.unfinished-leave-btn-no {
    background: #cf2e2e;
    box-shadow: 0 14px 30px rgba(207, 46, 46, 0.22);
}
.unfinished-leave-btn-yes {
    background: #159947;
    box-shadow: 0 14px 30px rgba(21, 153, 71, 0.22);
}
.new-form-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 20px;
}
.new-form-head h2 {
    margin: 0 0 6px;
    font-size: 1.5rem;
}
.new-form-body {
    display: grid;
    gap: 20px;
}
.new-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.new-form-job-field {
    grid-column: 1 / -1;
}
.new-form-address-lookup {
    display: grid;
    gap: 12px;
}
.new-form-lookup-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: end;
}
.new-form-search-field {
    margin: 0;
}
.new-form-address-results {
    display: grid;
    gap: 10px;
}
.new-quote-customer-field {
    position: relative;
    z-index: 4;
}
.new-quote-customer-results-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    z-index: 20;
    max-height: 280px;
    overflow: auto;
    padding: 10px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.14);
}
.new-quote-customer-results-list {
    display: grid;
    gap: 10px;
}
.new-quote-customer-manual-option {
    margin-top: 10px;
    border-style: dashed;
}
.new-form-result {
    width: 100%;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fbff;
    padding: 12px 14px;
    text-align: left;
    cursor: pointer;
    color: var(--text-primary);
}
.new-form-result strong,
.new-form-result span {
    display: block;
}
.new-form-result span {
    margin-top: 4px;
    color: var(--text-secondary);
    font-size: 0.92rem;
}
.new-form-result:hover {
    border-color: #9fc2ef;
    background: #eef5fc;
}
.new-form-address-error {
    color: var(--brand-red);
    font-weight: 600;
    font-size: 0.92rem;
}
.new-form-manual-toggle {
    justify-self: start;
}
.new-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}
.postcode-location-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 44px;
    gap: 8px;
    align-items: center;
}
.postcode-location-btn {
    width: 44px;
    height: 42px;
    border: 1px solid #cfe0f0;
    border-radius: 12px;
    background: #fff;
    color: #123b74;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}
.postcode-location-btn:hover,
.postcode-location-btn:focus-visible {
    border-color: #7db2ee;
    box-shadow: 0 10px 22px rgba(18, 59, 116, 0.15);
    transform: translateY(-1px);
    outline: none;
}
.postcode-location-btn svg {
    width: 19px;
    height: 19px;
}
.location-pin-editor-overlay.hidden {
    display: none;
}
.location-pin-editor-overlay {
    position: fixed;
    inset: 0;
    z-index: 3800;
    display: grid;
    place-items: center;
    padding: 24px;
}
.location-pin-editor-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 24, 45, 0.36);
    backdrop-filter: blur(3px);
}
.location-pin-editor-modal {
    position: relative;
    width: min(900px, calc(100vw - 36px));
    max-height: min(92vh, 820px);
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 26px 60px rgba(15, 23, 42, 0.28);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.location-pin-editor-head,
.location-pin-editor-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 22px;
}
.location-pin-editor-head {
    border-bottom: 1px solid #dbe7f2;
}
.location-pin-editor-head h2 {
    margin: 0;
    color: #082d5e;
    font-size: 1.5rem;
}
.location-pin-editor-head p,
.location-pin-editor-message {
    margin: 4px 0 0;
    color: #315a89;
}
.location-pin-editor-body {
    padding: 18px 22px;
    display: grid;
    gap: 12px;
}
.location-pin-editor-map {
    min-height: 440px;
    border: 1px solid #cfe0f0;
    border-radius: 18px;
    background: #eef5fc;
    overflow: hidden;
}
.location-pin-editor-actions {
    border-top: 1px solid #dbe7f2;
    justify-content: flex-end;
}
.office-action-overlay.hidden {
    display: none;
}
.office-action-overlay {
    position: fixed;
    top: var(--topbar-height);
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 3200;
    overflow-y: auto;
    padding: 24px;
}
.print-preview-overlay.hidden {
    display: none;
}
.print-preview-overlay {
    position: fixed;
    inset: 0;
    z-index: 3600;
}
.print-preview-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 24, 45, 0.44);
}
.print-preview-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    width: min(1220px, calc(100vw - 120px));
    height: min(840px, calc(100vh - 96px));
    transform: translate(-50%, -50%);
    background: #f7fbff;
    border: 1px solid #cddced;
    border-radius: 22px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.28);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    overflow: hidden;
}
.print-preview-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    padding: 18px 20px;
    border-bottom: 1px solid #d7e1eb;
    background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
    text-align: center;
}
.print-preview-head > div:first-child {
    flex: 1 1 auto;
}
.print-preview-head h2 {
    margin: 0;
    font-size: 1.05rem;
}
.print-preview-head p {
    margin: 6px 0 0;
    color: var(--text-secondary);
    font-size: 0.92rem;
}
.print-preview-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}
.print-preview-close-btn {
    min-width: 48px;
    padding-inline: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.print-preview-frame-wrap {
    min-height: 0;
    padding: 14px;
    background: #e8f0f8;
}
.print-preview-frame {
    width: 100%;
    height: 100%;
    border: 1px solid #c9d8e8;
    border-radius: 18px;
    background: #fff;
}
.settings-company-grid {
    min-height: 0;
}
.settings-company-card {
    width: 100%;
    min-height: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-content: flex-start;
}
.settings-company-toolbar {
    display: flex;
    align-items: center;
    gap: 10px;
}
.settings-card .card-actions {
    display: flex;
    justify-content: flex-end;
    padding-top: 18px;
}
.settings-company-action {
    min-width: 138px;
    min-height: 44px;
    padding: 11px 20px;
    border-radius: 12px;
    border: 1px solid #d7e1eb;
    background: #fff;
    color: var(--brand-navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    box-shadow: none;
    transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}
.settings-company-action:hover {
    background: #f7fafc;
    border-color: #c6d7e8;
}
.settings-company-action:active {
    transform: translateY(1px);
}
.settings-company-action i {
    width: 16px;
    height: 16px;
}
.settings-company-toolbar .settings-company-action {
    min-width: 120px;
}
.card-actions .settings-company-action {
    min-width: 164px;
}
.settings-company-toolbar .button-secondary {
    background: #fff;
    color: var(--brand-navy);
}
.settings-card .card-actions .button-primary {
    background: #fff;
    color: var(--brand-navy);
}
.settings-company-table {
    display: grid;
    grid-template-columns: 180px minmax(280px, 1.5fr) repeat(5, minmax(108px, 0.8fr));
    border: 1px solid #d7e1eb;
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
}
.settings-company-cell {
    padding: 12px 14px;
    border-right: 1px solid #d7e1eb;
    border-bottom: 1px solid #d7e1eb;
    background: #fff;
}
.settings-company-cell:nth-child(7n) {
    border-right: 0;
}
.settings-company-header {
    background: #f6f9fc;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--brand-navy);
}
.settings-company-cell.field strong {
    color: var(--brand-navy);
    font-size: 0.95rem;
}
.settings-company-cell.value small {
    display: block;
    color: var(--text-secondary);
    font-size: 0.9rem;
    line-height: 1.45;
}
.settings-company-input {
    width: 100%;
}
.settings-company-logo-field {
    display: grid;
    gap: 10px;
}
.settings-company-logo-hidden-input {
    display: none;
}
.settings-company-logo-preview {
    position: relative;
    min-height: 180px;
    border: 1px dashed #c8d8e8;
    border-radius: 16px;
    background: #f7fafc;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.settings-company-logo-preview img {
    width: 100%;
    height: 100%;
    max-height: 180px;
    object-fit: contain;
    display: block;
    padding: 12px;
}
.settings-company-logo-preview img[hidden] {
    display: none !important;
}
.settings-company-logo-fallback {
    padding: 16px;
    color: var(--brand-navy);
    font-size: 1.05rem;
    font-weight: 700;
    text-align: center;
    line-height: 1.3;
}
.settings-company-logo-add {
    min-width: 40px;
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.settings-company-logo-add i {
    width: 18px;
    height: 18px;
}
.settings-company-logo-add.is-empty {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 52px;
    height: 52px;
    min-width: 52px;
    background: #fff;
}
.settings-company-logo-add.is-corner {
    position: absolute;
    right: 10px;
    top: 10px;
    background: #fff3f3;
    border-color: #efc6c6;
    color: #b42318;
}
.settings-company-cell.value .cell-input,
.settings-company-cell.value .cell-textarea {
    min-height: 44px;
    border-radius: 12px;
}
.settings-company-cell.value .cell-textarea {
    resize: vertical;
    min-height: 96px;
}
.settings-company-cell.value .cell-input:disabled,
.settings-company-cell.value .cell-textarea:disabled {
    background: #f7fafc;
    color: #31577f;
    border-color: #e0e9f2;
    cursor: default;
}
.settings-company-cell.tick {
    display: flex;
    align-items: center;
    justify-content: center;
}
.settings-company-check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.settings-company-check.is-locked {
    opacity: 0.58;
}
.settings-company-check-readonly {
    pointer-events: none;
    opacity: 0.56;
}
.settings-company-check-readonly.is-disabled {
    opacity: 0.34;
}
.settings-company-check input {
    position: absolute;
    opacity: 0;
}
.settings-company-check span {
    width: 18px;
    height: 18px;
    border: 1px solid #b8cadc;
    border-radius: 5px;
    background: #fff;
    display: inline-block;
    position: relative;
}
.settings-company-check input:checked + span {
    background: #173a63;
    border-color: #173a63;
}
.settings-company-check-readonly.is-checked span {
    background: #173a63;
    border-color: #173a63;
}
.settings-company-check-readonly span {
    background: #f3f7fb;
    border-color: #c7d6e5;
}
.settings-company-check input:checked + span::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 1px;
    width: 5px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.settings-company-check-readonly.is-checked span::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 1px;
    width: 5px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
@media (max-width: 960px) {
    .print-preview-modal {
        width: calc(100vw - 32px);
        height: calc(100vh - 32px);
    }
    .print-preview-head {
        flex-wrap: wrap;
    }
}
.office-action-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 24, 45, 0.32);
}
.office-action-card {
    position: absolute;
    width: min(420px, calc(100vw - 48px));
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 18px;
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.22);
    padding: 16px;
}
.office-action-card.floating {
    right: 28px;
    bottom: 96px;
}
.office-action-card.centered {
    top: 24px;
    left: 50%;
    right: auto;
    bottom: auto;
    transform: translateX(-50%);
    max-height: calc(100vh - var(--topbar-height) - 48px);
    overflow-y: auto;
    overscroll-behavior: contain;
}
.office-action-card-wide {
    width: min(560px, calc(100vw - 48px));
}
.office-action-card.anchored {
    right: auto;
    bottom: auto;
}
.office-action-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 14px;
}
.office-action-head h3 {
    margin: 0;
    font-size: 1.05rem;
}
.office-action-head p {
    margin: 4px 0 0;
    color: var(--text-secondary);
    font-size: 0.92rem;
}
.office-action-issue-list {
    display: grid;
    gap: 12px;
    max-height: min(48vh, 420px);
    overflow: auto;
    margin-bottom: 14px;
}
.office-action-issue-card {
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fbfe;
    padding: 12px 14px;
}
.office-action-issue-card strong {
    display: block;
    color: var(--brand-navy);
    margin-bottom: 8px;
}
.office-action-issue-copy {
    font-size: 0.88rem;
    color: var(--text-secondary);
    margin-bottom: 6px;
}
.office-action-issue-card ul {
    margin: 0;
    padding-left: 18px;
    color: var(--brand-navy);
}
.office-action-issue-card li + li {
    margin-top: 4px;
}
.office-action-input-wrap {
    display: grid;
    gap: 8px;
    margin-bottom: 14px;
}
.office-action-input-label {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--brand-navy);
}
.office-action-input {
    width: 100%;
    border: 1px solid #d7e1eb;
    border-radius: 12px;
    padding: 12px 14px;
    font: inherit;
    color: var(--brand-navy);
    background: #fff;
}
.office-action-customer-search {
    position: relative;
}
.office-action-customer-suggestions {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    z-index: 12;
    display: grid;
    gap: 6px;
    padding: 8px;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.14);
    max-height: 220px;
    overflow-y: auto;
}
.office-action-customer-suggestions.hidden {
    display: none;
}
.office-action-customer-email-list {
    display: grid;
    gap: 10px;
    margin-top: 10px;
    padding: 12px;
    border: 1px solid #d7e1eb;
    border-radius: 12px;
    background: #f8fbfe;
}
.office-action-customer-email-list.hidden {
    display: none;
}
.office-action-customer-suggestion {
    width: 100%;
    border: 1px solid transparent;
    border-radius: 10px;
    background: #f8fbfe;
    color: var(--brand-navy);
    padding: 10px 12px;
    text-align: left;
    cursor: pointer;
    font: inherit;
}
.office-action-customer-suggestion:hover {
    background: #eef5ff;
    border-color: #bfdbfe;
}
.office-action-customer-suggestion strong {
    display: block;
}
.office-action-customer-suggestion small,
.office-action-email-choice span {
    color: var(--text-secondary);
}
.office-action-email-choice-list {
    display: grid;
    gap: 10px;
}
.office-action-email-choice {
    padding: 8px 4px;
}
.office-action-textarea {
    min-height: 220px;
    resize: vertical;
    line-height: 1.5;
}
.office-action-html-editor {
    min-height: 260px;
    line-height: 1.55;
    overflow-y: auto;
}
.office-action-html-editor:focus {
    outline: 2px solid rgba(37, 99, 235, 0.18);
    border-color: #93c5fd;
}
.office-action-html-editor a {
    color: inherit;
    text-decoration-color: currentColor;
}
.office-action-html-editor img {
    max-width: 100%;
    height: auto;
}
.office-action-card-email-compose {
    width: min(760px, calc(100vw - 48px));
}
.office-action-saved-email-list.hidden {
    display: none;
}
.office-action-checkbox-list {
    display: grid;
    gap: 10px;
    padding: 12px;
    border: 1px solid #d7e1eb;
    border-radius: 12px;
    background: #f8fbfe;
}
.office-action-signature-preview {
    border: 1px solid #d7e1eb;
    border-radius: 12px;
    background: #f8fbfe;
    padding: 14px;
    color: var(--brand-navy);
    line-height: 1.5;
}
.office-action-signature-preview:empty::before {
    content: "No signature set in personal settings yet.";
    color: var(--text-secondary);
}
.office-action-signature-preview img {
    max-width: 100%;
    height: auto;
}
.office-action-close {
    width: 32px;
    height: 32px;
    border: 1px solid #d7e1eb;
    border-radius: 10px;
    background: #fff;
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.office-action-options {
    display: grid;
    gap: 10px;
}
.office-action-empty {
    margin: 0;
    padding: 12px 14px;
    border: 1px dashed #bfd0e3;
    border-radius: 10px;
    background: #f8fbff;
    color: var(--text-secondary);
    font-weight: 600;
}
.office-action-options-compact-right {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 10px;
}
.office-action-options-inline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.office-action-option {
    min-height: 46px;
    border: 1px solid #d7e1eb;
    border-radius: 12px;
    background: #fff;
    color: var(--brand-navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
}
.office-action-option-compact {
    min-height: 38px;
    padding: 0 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: auto;
    min-width: 112px;
    font-size: 0.92rem;
}
.office-action-option-compact svg {
    width: 16px;
    height: 16px;
}
.office-action-option.primary {
    background: #1d4ed8;
    border-color: #1d4ed8;
    color: #fff;
}
.office-action-option.is-loading {
    opacity: 0.92;
    cursor: wait;
}
.office-action-option.is-loading svg {
    animation: office-spin 0.9s linear infinite;
}
.office-action-option:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.office-action-option[aria-disabled="true"] {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}
.office-action-option:not(:disabled):hover {
    background: #eef5fc;
}
.office-action-option.primary:not(:disabled):hover {
    background: #1b44bc;
}
@keyframes office-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}
.photo-workspace .photo-workspace-group-list {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-auto-flow: row;
    grid-auto-rows: auto;
    gap: 20px;
    align-items: start;
}
.photo-workspace .photo-workspace-group-list > .excel-group-card {
    height: auto;
    align-self: start;
}
.photo-workspace .photo-group-rows {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
}
.photo-workspace .photo-excel-row {
    grid-template-columns: 56px minmax(0, 1fr);
    grid-template-areas:
        "leading preview"
        ". fields";
    border: 0;
    border-radius: 0;
    padding: 18px 16px;
    background: #fff;
    align-items: start;
    gap: 12px 14px;
}
.photo-workspace .photo-excel-row:nth-child(odd) {
    border-right: 1px solid #d9e6f2;
}
.photo-workspace .photo-excel-row:nth-child(n+3) {
    border-top: 1px solid #d9e6f2;
}
.photo-workspace .photo-excel-row .excel-row-leading {
    grid-area: leading;
    align-self: center;
}
.photo-workspace .photo-row-preview {
    grid-area: preview;
    padding: 0;
    display: flex;
    justify-content: center;
}
.photo-workspace .photo-row-fields {
    grid-area: fields;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 12px;
}
.photo-workspace .photo-cell-value {
    min-height: 40px;
    border: 1px solid #ccd8e4;
    border-radius: 8px;
    padding: 9px 10px;
    background: #fff;
    width: 100%;
    box-sizing: border-box;
    font: inherit;
    color: var(--brand-navy);
}
.quotes-workspace-shell {
    display: grid;
    gap: 18px;
}
.quotes-top-strip {
    display: grid;
    grid-template-columns: minmax(320px, 0.95fr) minmax(420px, 1.05fr);
    gap: 18px;
}
.quotes-control-card,
.quotes-history-card {
    min-height: 100%;
}
.quote-form-picker {
    margin-bottom: 14px;
}
.quote-control-summary {
    display: grid;
    gap: 12px;
}
.quote-workspace-layout {
    align-items: start;
}
.quote-sidebar-card,
.quote-main-card {
    min-height: 0;
}
.quote-section-list {
    display: grid;
    gap: 10px;
}
.quote-workspace-group-list {
    display: grid;
    gap: 20px;
}
.quote-workspace-group .excel-group-header {
    align-items: center;
}
.quote-workspace-rows {
    display: grid;
    gap: 14px;
    padding: 18px;
    background: #f8fbff;
}
.quote-row-card {
    border: 1px solid #d9e6f2;
    border-radius: 18px;
    background: #fff;
    padding: 16px 18px;
    display: grid;
    gap: 14px;
}
.quote-row-head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
}
.quote-row-head-copy {
    min-width: 0;
}
.quote-row-head-copy strong,
.quote-row-head-copy small {
    display: block;
}
.quote-row-head-copy small {
    margin-top: 4px;
    color: var(--text-secondary);
}
.quote-row-body {
    display: grid;
    gap: 16px;
    align-items: start;
}
.quote-row-body-part {
    grid-template-columns: minmax(200px, 240px) minmax(0, 1fr);
}
.quote-row-body-measure {
    grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
}
.quote-row-media-column {
    display: grid;
    gap: 12px;
}
.quote-row-media-column.is-measure {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.quote-row-media-stack {
    display: grid;
    gap: 10px;
    grid-column: 1 / -1;
}
.quote-media-card {
    border: 1px solid #d9e6f2;
    border-radius: 14px;
    padding: 10px;
    background: #fbfdff;
    display: grid;
    gap: 8px;
}
.quote-media-card span {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #6a7f97;
}
.quote-media-card img,
.quote-media-card video {
    width: 100%;
    height: 180px;
    border-radius: 10px;
    object-fit: contain;
    background: #fff;
    display: block;
}
.quote-media-card.is-primary img,
.quote-media-card.is-primary video {
    height: 210px;
}
.quote-media-empty,
.quote-answer-empty {
    display: grid;
    place-items: center;
    min-height: 120px;
    border-radius: 10px;
    background: #fff;
    color: #73869b;
    font-weight: 600;
}
.quote-answer-list {
    display: grid;
    gap: 10px;
}
.quote-answer-row {
    display: grid;
    grid-template-columns: minmax(160px, 220px) minmax(0, 1fr);
    gap: 14px;
    align-items: start;
    padding: 10px 12px;
    border: 1px solid #dfe8f1;
    border-radius: 12px;
    background: #fbfdff;
}
.quote-answer-label {
    font-weight: 700;
    color: #173a63;
}
.quote-answer-value {
    color: #45617f;
    word-break: break-word;
}
.quote-row-preview-overlay.hidden {
    display: none;
}
.quote-row-preview-overlay {
    position: fixed;
    inset: 0;
    z-index: 60;
}
.quote-row-preview-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(11, 23, 40, 0.56);
}
.quote-row-preview-modal {
    position: relative;
    width: min(1220px, calc(100vw - 40px));
    max-height: calc(100vh - 40px);
    margin: 20px auto;
    border-radius: 20px;
    background: #f6faff;
    border: 1px solid #d4e0ec;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    overflow: hidden;
    box-shadow: 0 32px 80px rgba(17, 41, 68, 0.22);
}
.quote-row-preview-head,
.quote-row-preview-actions {
    padding: 18px 22px;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}
.quote-row-preview-head {
    border-bottom: 1px solid #d9e6f2;
}
.quote-row-preview-actions {
    border-top: 1px solid #d9e6f2;
    justify-content: flex-end;
}
.quote-row-preview-body {
    overflow: auto;
    padding: 22px;
}
.quote-popup-row {
    background: #fff;
}
.quote-popup-row .excel-row-title,
.quote-popup-row .window-handle-title-cell,
.quote-popup-row .window-measure-title-cell,
.quote-popup-row .detail-row-title-cell {
    min-width: 0;
}
@media (max-width: 1180px) {
    .quotes-top-strip {
        grid-template-columns: minmax(0, 1fr);
    }
    .quote-row-body-part,
    .quote-row-body-measure {
        grid-template-columns: minmax(0, 1fr);
    }
}
@media (max-width: 1200px) {
    .photo-workspace .photo-group-rows {
        grid-template-columns: minmax(0, 1fr);
    }
    .photo-workspace .photo-excel-row:nth-child(odd) {
        border-right: 0;
    }
    .photo-workspace .photo-excel-row:nth-child(n+2) {
        border-top: 1px solid #d9e6f2;
    }
    .photo-workspace .photo-excel-row:nth-child(n+3) {
        border-top: 1px solid #d9e6f2;
    }
}

@media (max-width: 980px) {
    .quote-row-head {
        grid-template-columns: minmax(0, 1fr);
    }
    .quote-row-head .quote-row-open-btn {
        width: 100%;
    }
    .quote-row-media-column.is-measure {
        grid-template-columns: minmax(0, 1fr);
    }
    .quote-answer-row {
        grid-template-columns: minmax(0, 1fr);
    }
    .quote-row-preview-modal {
        width: min(100vw - 20px, 1220px);
        max-height: calc(100vh - 20px);
        margin: 10px auto;
    }
    .forms-list-toolbar {
        flex-direction: column;
        align-items: stretch;
    }
    .forms-list-toolbar-meta,
    .forms-list-pagination {
        flex-wrap: wrap;
    }
}
.excel-delete-btn {
    width: 36px;
    height: 36px;
    border: 1px solid #efc6c6;
    border-radius: 10px;
    background: #fff5f5;
    color: var(--brand-red);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.excel-delete-btn:hover {
    background: #fde8e8;
}
.excel-delete-label {
    display: none;
}

@container (max-width: 1100px) {
    .bay-measure-mobile-status-card,
    .bay-measure-mobile-fit-photo {
        display: none !important;
    }
    .window-measure-layout {
        width: min(100%, 460px);
        justify-self: start;
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
            "sketch photo"
            "main main"
            "addon addon"
            "side side"
            "status status";
        min-width: 0;
    }
    .window-measure-addon-stack {
        width: 100%;
        justify-self: start;
    }
    .bay-measure-layout {
        width: min(100%, 460px);
        justify-self: start;
        grid-template-columns: 1fr 1fr;
        grid-template-areas: none;
        min-width: 0;
        align-items: start;
    }
    .bay-measure-left-stack,
    .bay-measure-angle-card {
        width: 100%;
        max-width: none;
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 14px;
        align-items: start;
    }
    .bay-measure-segment-sketch-card {
        grid-column: 1;
        grid-row: 1 / span 2;
    }
    .bay-measure-segment-right > .bay-measure-segment-width-card {
        grid-column: 2;
        grid-row: 1;
    }
    .bay-measure-segment-right > .bay-measure-angle-top-card,
    .bay-measure-segment-right > .bay-measure-segment-status-card,
    .bay-measure-segment-right > .bay-measure-segment-top-spacer {
        grid-column: 2;
        grid-row: 2;
    }
    .bay-measure-segment-right > .bay-measure-segment-extras-combined {
        grid-column: 1 / -1;
        grid-row: 3;
    }
    .bay-measure-segment-right > .bay-measure-segment-spacer,
    .bay-measure-segment-right > .bay-measure-segment-tail-stack {
        grid-column: 1 / -1;
        grid-row: 4;
    }
    .bay-measure-segment-right > .bay-measure-segment-spacer {
        display: none;
    }
    .bay-measure-segment-tail-stack.has-completed-photo {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        align-items: stretch;
    }
    .bay-measure-segment-tail-stack:not(.has-completed-photo) {
        grid-template-columns: minmax(0, 1fr);
        width: calc((100% - 14px) / 2);
        max-width: none;
        justify-self: start;
    }
    .bay-measure-segment-tail-stack:not(.has-completed-photo) .bay-measure-segment-tail-status {
        min-height: auto;
        height: auto;
    }
    .bay-measure-segment-tail-stack:not(.has-completed-photo) .status-choice-stack {
        gap: 8px;
        padding: 8px 12px 8px;
    }
    .bay-measure-segment-tail-stack:not(.has-completed-photo) .status-choice-btn {
        min-height: 58px;
    }
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-photo {
        display: grid;
    }
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-status,
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-photo {
        min-height: 180px;
        height: 100%;
        align-self: stretch;
    }
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-status .status-choice-stack {
        grid-template-columns: 1fr;
        grid-template-rows: 1fr 1fr;
        height: 100%;
        gap: 8px;
        padding: 8px 12px 8px;
        box-sizing: border-box;
    }
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-status .status-choice-btn {
        min-height: 0;
        height: 100%;
    }
    .bay-measure-photo-top-card {
        grid-column: 1;
        grid-row: 2 / span 2;
    }
    .bay-measure-main-grid {
        display: contents;
    }
    .bay-measure-main-grid > .window-measure-inline-cell,
    .bay-measure-side-grid > .window-measure-cell {
        display: grid !important;
        grid-template-rows: auto auto;
        gap: 6px;
        min-height: 0;
        padding: 8px 12px;
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        box-sizing: border-box;
        overflow: hidden;
    }
    .bay-measure-main-grid > .window-measure-inline-cell .window-measure-inline-label,
    .bay-measure-side-grid > .window-measure-cell .window-measure-cell-label {
        min-height: 24px;
        padding: 6px 0 0;
        margin: 0 0 6px;
        display: block;
    }
    .bay-measure-main-grid > .window-measure-inline-cell .excel-cell-input,
    .bay-measure-main-grid > .window-measure-inline-cell .cell-select,
    .bay-measure-main-grid > .window-measure-inline-cell .cell-input,
    .bay-measure-side-grid > .window-measure-cell .excel-cell-input,
    .bay-measure-side-grid > .window-measure-cell .cell-select,
    .bay-measure-side-grid > .window-measure-cell .cell-input {
        margin: 0;
        min-height: 40px;
        height: 40px;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box;
    }
    .bay-measure-main-grid > .window-measure-inline-cell:nth-child(1) {
        grid-column: 2;
        grid-row: 2;
    }
    .bay-measure-main-grid > .window-measure-inline-cell:nth-child(2) {
        grid-column: 2;
        grid-row: 3;
    }
    .bay-measure-main-grid > .bay-measure-colour-combined.no-other-bay-colour {
        display: grid;
        grid-template-rows: 1fr;
        grid-column: 1 / -1;
        grid-row: 4;
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        overflow: hidden;
        min-height: var(--bay-single-row-height);
    }
    .bay-measure-main-grid > .bay-measure-colour-combined.has-other-bay-colour {
        display: contents;
    }
    .bay-measure-side-grid {
        display: contents;
    }
    .bay-measure-side-grid .window-measure-cell:nth-child(1) {
        grid-column: 1;
        grid-row: 5;
    }
    .bay-measure-side-grid .window-measure-cell:nth-child(3) {
        grid-column: 2;
        grid-row: 5;
    }
    .bay-measure-glass-combined.no-other-glass-type {
        display: grid;
        grid-template-rows: 1fr;
        grid-column: 1 / -1;
        grid-row: 6;
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        overflow: hidden;
        min-height: var(--bay-single-row-height);
    }
    .bay-measure-glass-combined.has-other-glass-type {
        display: contents;
    }
    .bay-measure-colour-combined.no-other-bay-colour > .bay-measure-colour-primary,
    .bay-measure-glass-combined.no-other-glass-type > .bay-measure-glass-primary {
        grid-column: auto;
        min-height: 100%;
        height: 100%;
        border: 0;
        border-radius: 0;
        background: transparent;
        box-sizing: border-box;
        overflow: hidden;
    }
    .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary {
        grid-column: 1;
        grid-row: 4;
    }
    .bay-measure-colour-combined > [data-other-window-colour] {
        grid-column: 2;
        grid-row: 4;
        display: grid;
        align-content: stretch;
    }
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary {
        grid-column: 1;
        grid-row: 6;
    }
    .bay-measure-glass-combined > [data-other-glass-type] {
        grid-column: 2;
        grid-row: 6;
        display: grid;
        align-content: stretch;
    }
    .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary,
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary,
    .bay-measure-colour-combined > [data-other-window-colour],
    .bay-measure-glass-combined > [data-other-glass-type],
    .bay-measure-colour-combined > [data-other-window-colour] .bay-measure-colour-secondary,
    .bay-measure-glass-combined > [data-other-glass-type] .window-measure-inline-cell {
        min-height: var(--bay-single-row-height);
        height: var(--bay-single-row-height);
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        box-sizing: border-box;
        overflow: hidden;
    }
    .bay-measure-colour-combined.no-other-bay-colour > .bay-measure-colour-primary .window-measure-cell-label,
    .bay-measure-glass-combined.no-other-glass-type > .bay-measure-glass-primary .window-measure-cell-label,
    .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary .window-measure-cell-label,
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary .window-measure-cell-label,
    .bay-measure-colour-combined > [data-other-window-colour] .window-measure-inline-label,
    .bay-measure-glass-combined > [data-other-glass-type] .window-measure-inline-label {
        min-height: 24px;
        padding-top: 11px;
        padding-bottom: 5px;
        margin-bottom: 0;
    }
    .bay-measure-colour-combined.no-other-bay-colour > .bay-measure-colour-primary .excel-cell-input,
    .bay-measure-colour-combined.no-other-bay-colour > .bay-measure-colour-primary .cell-select,
    .bay-measure-colour-combined.no-other-bay-colour > .bay-measure-colour-primary .cell-input,
    .bay-measure-glass-combined.no-other-glass-type > .bay-measure-glass-primary .excel-cell-input,
    .bay-measure-glass-combined.no-other-glass-type > .bay-measure-glass-primary .cell-select,
    .bay-measure-glass-combined.no-other-glass-type > .bay-measure-glass-primary .cell-input,
    .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary .excel-cell-input,
    .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary .cell-select,
    .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary .cell-input,
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary .excel-cell-input,
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary .cell-select,
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary .cell-input,
    .bay-measure-colour-combined > [data-other-window-colour] .excel-cell-input,
    .bay-measure-colour-combined > [data-other-window-colour] .cell-select,
    .bay-measure-colour-combined > [data-other-window-colour] .cell-input,
    .bay-measure-glass-combined > [data-other-glass-type] .excel-cell-input,
    .bay-measure-glass-combined > [data-other-glass-type] .cell-select,
    .bay-measure-glass-combined > [data-other-glass-type] .cell-input {
        min-height: 48px;
        height: 48px;
        margin: 4px 12px 10px;
        width: calc(100% - 24px);
    }
    .bay-measure-colour-combined.no-other-bay-colour .bay-measure-main-empty,
    .bay-measure-glass-combined.no-other-glass-type .bay-measure-side-empty {
        display: none;
    }
    .bay-measure-addon-stack {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        grid-column: 1 / -1;
        grid-row: 7;
        justify-content: stretch;
        align-content: start;
    }
    .bay-measure-segment-right > .bay-measure-segment-extras-combined {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        grid-template-rows: auto 1fr;
        row-gap: 14px;
        column-gap: 14px;
        padding: 0;
        border: 0;
        border-radius: 0;
        background: transparent;
        overflow: visible;
        align-self: start;
        height: auto;
    }
    .bay-measure-segment-right > .bay-measure-segment-extras-combined::before {
        display: none;
    }
    .bay-measure-segment-right > .bay-measure-segment-extras-combined > .window-measure-cell:nth-child(1) {
        grid-column: 1;
        grid-row: 1;
    }
    .bay-measure-segment-right > .bay-measure-segment-extras-combined > .window-measure-cell:nth-child(2) {
        grid-column: 2;
        grid-row: 1;
    }
    .bay-measure-segment-right > .bay-measure-segment-extras-combined > .bay-measure-addon-column {
        grid-column: 1 / span 2;
        grid-row: 2;
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        overflow: hidden;
        height: auto;
        min-height: 0;
    }
    .bay-measure-segment-extras-combined > .window-measure-cell {
        min-height: 82px;
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
    }
    .bay-measure-segment-extras-combined > .window-measure-cell:nth-child(2) {
        border-left: 1px solid #d7e1eb;
    }
    .bay-measure-segment-extras-combined > .window-measure-cell .window-measure-cell-label {
        padding-top: 10px;
        padding-bottom: 4px;
        min-height: 34px;
    }
    .bay-measure-segment-extras-combined > .window-measure-cell .excel-cell-input,
    .bay-measure-segment-extras-combined > .window-measure-cell .cell-select,
    .bay-measure-segment-extras-combined > .window-measure-cell .cell-input {
        margin: 6px 12px 12px;
    }
    .bay-measure-addon-stack > .bay-measure-angle-card.is-first-bay-angle .bay-measure-angle-top-card {
        min-height: 138px;
    }
    .window-measure-media-card .sketch-trigger {
        min-height: 180px;
    }
    .excel-row-window-measure .window-measure-title-cell {
        width: min(100%, 460px);
        justify-self: start;
        justify-content: flex-end;
        text-align: right;
    }
}

@container (max-width: 700px) {
    .excel-row-window-measure {
        grid-template-areas:
            "leading title spacer"
            "layout layout spacer"
            ". actions spacer";
        grid-template-columns: 74px minmax(0, 460px) minmax(0, 1fr);
        gap: 14px;
    }
    .admin-form-detail-page .excel-row-door-measure {
        grid-template-areas:
            "leading title spacer"
            "layout layout spacer";
        grid-template-columns: 74px minmax(0, 460px) minmax(0, 1fr);
        gap: 14px;
        align-items: start;
    }
    .admin-form-detail-page .excel-row-window-measure .window-measure-title-cell {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 460px;
        justify-self: start;
        display: block;
        justify-content: initial;
        text-align: right;
        padding: 14px 0 14px 74px;
        box-sizing: border-box;
    }
    .admin-form-detail-page .excel-row-door-measure .window-measure-title-cell {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 460px;
        justify-self: start;
        display: block;
        justify-content: initial;
        text-align: right;
        padding: 14px 0 14px 74px;
        box-sizing: border-box;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-layout {
        width: min(100%, 460px);
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-desktop-shell {
        display: none;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence {
        display: flex;
        flex-direction: column;
        gap: 14px;
        width: min(100%, 200px);
        justify-self: start;
        align-items: stretch;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence > * {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .door-measure-grid {
        grid-template-columns: 1fr;
        width: 100%;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .window-measure-inline-cell,
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .window-measure-cell,
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .window-measure-media-card {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .window-measure-inline-cell {
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        box-sizing: border-box;
        overflow: hidden;
        min-height: 82px;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .window-measure-inline-cell:first-child {
        border-top: 1px solid #d7e1eb;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .window-measure-cell:not(.door-measure-section-heading) {
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        box-sizing: border-box;
        overflow: hidden;
        min-height: 82px;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .door-measure-section-heading {
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 42px;
        padding: 0 12px;
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #eef4fa;
        box-sizing: border-box;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .door-measure-section-heading .window-measure-cell-label {
        margin: 0;
        padding: 0;
        min-height: 0;
        justify-content: center;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .door-measure-section-divider {
        margin: 2px 0;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .door-measure-section-divider span {
        padding: 0 10px;
    }
    .admin-form-detail-page .excel-row-door-measure > .excel-row-actions,
    .admin-form-detail-page .excel-row-door-measure > .excel-row-actions.has-action-stack {
        display: none !important;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .excel-row-actions {
        display: block;
        width: 100%;
        max-width: 200px;
        padding: 0;
        margin: 0;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .excel-row-actions.has-action-stack {
        display: grid;
        grid-auto-rows: min-content;
        width: 100%;
        max-width: 200px;
        justify-items: stretch;
        align-content: start;
        gap: 8px;
        padding: 0;
        margin: 0 0 -16px;
    }
    .admin-form-detail-page .excel-row-window-measure .excel-row-actions {
        grid-area: actions;
        grid-column: 1 / 3;
        justify-content: stretch;
        align-self: start;
        width: 100%;
        max-width: 200px;
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-door-measure .excel-row-actions {
        grid-area: actions;
        grid-column: 1 / 3;
        justify-content: stretch;
        align-self: start;
        width: 100%;
        max-width: 200px;
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-door-measure .excel-row-actions.has-action-stack {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 200px;
        justify-self: start;
        justify-items: stretch;
        align-content: start;
        gap: 8px;
        padding: 0;
        margin-top: 0;
    }
    .admin-form-detail-page .excel-row-window-measure .excel-delete-btn {
        width: 100%;
        max-width: 200px;
        min-width: 0;
        min-height: 40px;
        height: auto;
        padding: 8px 14px;
        gap: 8px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
    }
    .admin-form-detail-page .excel-row-door-measure .excel-delete-btn {
        width: 100%;
        max-width: 200px;
        min-width: 0;
        min-height: 40px;
        height: auto;
        padding: 8px 14px;
        gap: 8px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
    }
    .admin-form-detail-page .excel-row-door-measure .excel-row-actions.has-action-stack .excel-action-btn {
        width: 100%;
        min-width: 0;
        height: auto;
        min-height: 40px;
        padding: 8px 12px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
        gap: 8px;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .excel-delete-btn,
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .excel-action-btn {
        width: 100%;
        min-width: 0;
        height: auto;
        min-height: 40px;
        padding: 8px 12px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
        gap: 8px;
    }
    .admin-form-detail-page .excel-row-window-measure .excel-delete-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
    .admin-form-detail-page .excel-row-door-measure .excel-delete-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
    .admin-form-detail-page .excel-row-door-measure .excel-action-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .excel-delete-label,
    .admin-form-detail-page .excel-row-door-measure .door-measure-mobile-sequence .excel-action-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
}

@container (max-width: 520px) {
    .excel-group-header {
        grid-template-areas:
            "title"
            "meta"
            "actions";
        grid-template-columns: minmax(0, 1fr);
        gap: 10px 12px;
    }
    .excel-group-title {
        justify-self: center;
        text-align: center;
    }
    .excel-group-meta {
        justify-self: center;
        text-align: center;
    }
    .excel-group-actions {
        justify-self: center;
    }
    .excel-group-add {
        justify-self: center;
        margin: 0 auto;
    }
}

@container (max-width: 440px) {
    .excel-group-card {
        width: min(100%, 256px);
        max-width: 256px;
    }
    .window-measure-layout {
        width: min(100%, 200px);
        justify-self: start;
        grid-template-columns: 1fr;
        grid-template-areas:
            "sketch"
            "photo"
            "main"
            "addon"
            "side"
            "status";
    }
    .window-measure-addon-stack {
        width: min(100%, 200px);
        justify-self: start;
    }
    .bay-measure-addon-stack {
        grid-template-columns: minmax(0, 1fr);
        width: min(100%, 200px);
        justify-content: start;
        display: flex;
        flex-direction: column;
        gap: 14px;
    }
    .bay-measure-layout {
        width: min(100%, 200px);
        display: flex;
        flex-direction: column;
        gap: 14px;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-layout > * {
        flex: 0 0 auto;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-photo-top-card,
    .bay-measure-addon-stack,
    .bay-measure-main-grid > .window-measure-inline-cell,
    .bay-measure-main-grid > .bay-measure-colour-combined,
    .bay-measure-main-grid > .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary,
    .bay-measure-main-grid > .bay-measure-colour-combined > [data-other-window-colour],
    .bay-measure-side-grid .window-measure-cell:nth-child(1),
    .bay-measure-side-grid .window-measure-cell:nth-child(3),
    .bay-measure-glass-combined,
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary,
    .bay-measure-glass-combined > [data-other-glass-type] {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-photo-top-card { order: 1; }
    .bay-measure-mobile-angle-list {
        order: 2;
        display: flex;
        flex-direction: column;
        gap: 14px;
        width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-mobile-angle-list .window-measure-cell {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-main-grid {
        order: 3;
        display: flex;
        flex-direction: column;
        gap: 14px;
        width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-main-grid > .window-measure-inline-cell:nth-child(2) { order: 1; }
    .bay-measure-main-grid > .window-measure-inline-cell:nth-child(1) { order: 2; }
    .bay-measure-main-grid > .bay-measure-colour-combined.no-other-bay-colour {
        order: 3;
        display: block;
    }
    .bay-measure-main-grid > .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary {
        order: 3;
    }
    .bay-measure-main-grid > .bay-measure-colour-combined > [data-other-window-colour] {
        order: 4;
    }
    .bay-measure-side-grid {
        order: 4;
        display: flex;
        flex-direction: column;
        gap: 14px;
        width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-side-grid .window-measure-cell:nth-child(3) { order: 1; }
    .bay-measure-side-grid .window-measure-cell:nth-child(1) { order: 2; }
    .bay-measure-addon-stack { order: 5; }
    .bay-measure-glass-combined.no-other-glass-type {
        order: 6;
        display: block;
    }
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary {
        order: 6;
    }
    .bay-measure-glass-combined > [data-other-glass-type] {
        order: 7;
    }
    .bay-measure-segment-tail-stack.has-completed-photo {
        grid-template-columns: minmax(0, 1fr);
    }
    .bay-measure-left-stack,
    .bay-measure-angle-card {
        width: 100%;
        display: flex;
        flex-direction: column;
        gap: 14px;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-segment-sketch-card {
        order: 6;
        width: 100%;
        min-height: 180px;
    }
    .bay-measure-segment-right {
        display: contents;
    }
    .bay-measure-segment-right > .bay-measure-segment-width-card {
        order: 1;
    }
    .bay-measure-segment-right > .bay-measure-angle-top-card,
    .bay-measure-segment-right > .bay-measure-segment-status-card,
    .bay-measure-segment-right > .bay-measure-segment-top-spacer {
        order: 2;
    }
    .bay-measure-segment-right > .bay-measure-angle-top-card {
        display: none;
        width: 100%;
    }
    .bay-measure-segment-right > .bay-measure-segment-top-spacer,
    .bay-measure-segment-right > .bay-measure-segment-spacer {
        display: none !important;
    }
    .bay-measure-segment-right > .bay-measure-segment-extras-combined {
        order: 2;
        display: flex;
        flex-direction: column;
        gap: 14px;
        width: 100%;
        min-width: 0;
        box-sizing: border-box;
        padding: 0;
        border: 0;
        border-radius: 0;
        background: transparent;
        overflow: visible;
    }
    .bay-measure-segment-extras-combined > .window-measure-cell:nth-child(1) {
        order: 1;
    }
    .bay-measure-segment-extras-combined > .window-measure-cell:nth-child(2) {
        order: 2;
    }
    .bay-measure-segment-extras-combined > .bay-measure-addon-column {
        order: 3;
    }
    .bay-measure-segment-sketch-card { order: 3; }
    .bay-measure-segment-right > .bay-measure-segment-tail-stack,
    .bay-measure-segment-right > .bay-measure-segment-spacer {
        order: 4;
    }
    .bay-measure-segment-right > .bay-measure-segment-tail-stack {
        display: flex;
        flex-direction: column;
        gap: 14px;
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }
    .bay-measure-segment-tail-stack:not(.has-completed-photo) {
        width: 100% !important;
        max-width: 100%;
        justify-self: stretch;
    }
    .bay-measure-segment-tail-stack > .bay-measure-segment-tail-status {
        width: 100%;
        max-width: 100%;
    }
    .bay-measure-segment-tail-stack.has-completed-photo {
        grid-template-columns: 1fr;
        align-items: start;
    }
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-status,
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-photo {
        min-height: 0;
        height: auto;
        align-self: stretch;
    }
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-status .status-choice-stack {
        grid-template-columns: 1fr;
        grid-template-rows: none;
        height: auto;
        gap: 10px;
        padding: 8px 12px 12px;
        box-sizing: border-box;
    }
    .bay-measure-segment-tail-stack.has-completed-photo .bay-measure-segment-tail-status .status-choice-btn {
        min-height: 44px;
        height: auto;
    }
    .bay-measure-layout .window-measure-cell,
    .bay-measure-layout .window-measure-inline-cell,
    .bay-measure-layout .window-measure-media-card,
    .bay-measure-layout .window-measure-addon-column,
    .bay-measure-layout .bay-measure-colour-secondary,
    .bay-measure-layout [data-other-glass-type] .window-measure-inline-cell {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
        align-self: stretch;
        overflow: hidden;
    }
    .bay-measure-layout .window-measure-inline-cell,
    .bay-measure-layout .window-measure-cell {
        min-height: 0;
        padding: 8px 12px;
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
    }
    .bay-measure-layout .window-measure-inline-label,
    .bay-measure-layout .window-measure-cell-label {
        min-height: 24px;
        padding: 6px 8px 0;
        margin-bottom: 6px;
    }
    .bay-measure-layout .window-measure-media-label {
        padding: 10px 8px 0;
        margin: 0;
        text-align: left;
        box-sizing: border-box;
    }
    .bay-measure-side-grid > .window-measure-cell,
    .bay-measure-segment-right > .bay-measure-segment-width-card,
    .bay-measure-mobile-angle-list .window-measure-cell,
    .bay-measure-segment-extras-combined > .window-measure-cell {
        grid-template-rows: auto auto;
        min-height: 0;
    }
    .bay-measure-side-grid > .window-measure-cell .window-measure-cell-label,
    .bay-measure-segment-right > .bay-measure-segment-width-card .window-measure-cell-label,
    .bay-measure-mobile-angle-list .window-measure-cell .window-measure-cell-label,
    .bay-measure-segment-extras-combined > .window-measure-cell .window-measure-cell-label {
        min-height: 24px;
        padding: 6px 8px 0;
        margin-bottom: 6px;
    }
    .bay-measure-side-grid > .window-measure-cell .excel-cell-input,
    .bay-measure-side-grid > .window-measure-cell .cell-select,
    .bay-measure-side-grid > .window-measure-cell .cell-input,
    .bay-measure-segment-right > .bay-measure-segment-width-card .excel-cell-input,
    .bay-measure-segment-right > .bay-measure-segment-width-card .cell-select,
    .bay-measure-segment-right > .bay-measure-segment-width-card .cell-input,
    .bay-measure-mobile-angle-list .window-measure-cell .excel-cell-input,
    .bay-measure-mobile-angle-list .window-measure-cell .cell-select,
    .bay-measure-mobile-angle-list .window-measure-cell .cell-input,
    .bay-measure-segment-extras-combined > .window-measure-cell .excel-cell-input,
    .bay-measure-segment-extras-combined > .window-measure-cell .cell-select,
    .bay-measure-segment-extras-combined > .window-measure-cell .cell-input {
        min-height: 40px;
        height: 40px;
        margin: 0;
        width: 100% !important;
        max-width: 100% !important;
    }
    .bay-measure-segment-right > .bay-measure-segment-width-card,
    .bay-measure-segment-right > .bay-measure-angle-top-card,
    .bay-measure-segment-right > .bay-measure-segment-status-card,
    .bay-measure-segment-extras-combined > .window-measure-cell {
        min-height: 0;
        padding: 8px 12px;
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        box-sizing: border-box;
        overflow: hidden;
    }
    .bay-measure-segment-right > .bay-measure-segment-width-card .window-measure-cell-label,
    .bay-measure-segment-right > .bay-measure-angle-top-card .window-measure-cell-label,
    .bay-measure-segment-right > .bay-measure-segment-status-card .window-measure-cell-label,
    .bay-measure-segment-extras-combined > .window-measure-cell .window-measure-cell-label {
        min-height: 24px;
        padding-top: 6px;
        padding-bottom: 0;
        margin-bottom: 6px;
    }
    .bay-measure-segment-right > .bay-measure-segment-width-card .excel-cell-input,
    .bay-measure-segment-right > .bay-measure-segment-width-card .cell-select,
    .bay-measure-segment-right > .bay-measure-segment-width-card .cell-input,
    .bay-measure-segment-right > .bay-measure-angle-top-card .excel-cell-input,
    .bay-measure-segment-right > .bay-measure-angle-top-card .cell-select,
    .bay-measure-segment-right > .bay-measure-angle-top-card .cell-input,
    .bay-measure-segment-right > .bay-measure-segment-status-card .excel-cell-input,
    .bay-measure-segment-right > .bay-measure-segment-status-card .cell-select,
    .bay-measure-segment-right > .bay-measure-segment-status-card .cell-input,
    .bay-measure-segment-extras-combined > .window-measure-cell .excel-cell-input,
    .bay-measure-segment-extras-combined > .window-measure-cell .cell-select,
    .bay-measure-segment-extras-combined > .window-measure-cell .cell-input {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0;
        box-sizing: border-box;
        margin: 0 !important;
    }
    .bay-measure-segment-extras-combined > .window-measure-cell,
    .bay-measure-segment-extras-combined > .bay-measure-addon-column {
        border: 1px solid #d7e1eb;
        border-radius: 14px;
        background: #f8fafc;
        overflow: hidden;
    }
    .bay-measure-segment-extras-combined > .bay-measure-addon-column .window-measure-addon-head {
        min-height: 32px;
    }
    .bay-measure-segment-extras-combined > .bay-measure-addon-column .window-measure-addon-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }
    .bay-measure-segment-extras-combined > .bay-measure-addon-column .window-measure-addon-item {
        min-height: 48px;
        padding: 8px 12px;
    }
    .bay-measure-segment-extras-combined > .bay-measure-addon-column .window-measure-addon-item:nth-child(2n) {
        border-left: 0;
    }
    .bay-measure-segment-extras-combined > .bay-measure-addon-column .window-measure-addon-item:nth-child(n + 2) {
        border-top: 1px solid #e6edf5;
    }
    .bay-measure-layout .window-measure-cell .excel-cell-input,
    .bay-measure-layout .window-measure-cell .cell-select,
    .bay-measure-layout .window-measure-cell .cell-input,
    .bay-measure-layout .window-measure-inline-cell .excel-cell-input,
    .bay-measure-layout .window-measure-inline-cell .cell-select,
    .bay-measure-layout .window-measure-inline-cell .cell-input {
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .bay-measure-layout .window-measure-inline-cell .excel-cell-input,
    .bay-measure-layout .window-measure-inline-cell .cell-select,
    .bay-measure-layout .window-measure-inline-cell .cell-input {
        width: 100% !important;
        margin: 0 !important;
        min-height: 40px;
    }
    .bay-measure-layout .window-measure-cell .excel-cell-input,
    .bay-measure-layout .window-measure-cell .cell-select,
    .bay-measure-layout .window-measure-cell .cell-input {
        width: calc(100% - 24px) !important;
        max-width: calc(100% - 24px) !important;
        min-height: 40px;
    }
    .bay-measure-side-grid > .window-measure-cell .excel-cell-input,
    .bay-measure-side-grid > .window-measure-cell .cell-select,
    .bay-measure-side-grid > .window-measure-cell .cell-input,
    .bay-measure-segment-right > .bay-measure-segment-width-card .excel-cell-input,
    .bay-measure-segment-right > .bay-measure-segment-width-card .cell-select,
    .bay-measure-segment-right > .bay-measure-segment-width-card .cell-input,
    .bay-measure-mobile-angle-list .window-measure-cell .excel-cell-input,
    .bay-measure-mobile-angle-list .window-measure-cell .cell-select,
    .bay-measure-mobile-angle-list .window-measure-cell .cell-input,
    .bay-measure-segment-extras-combined > .window-measure-cell .excel-cell-input,
    .bay-measure-segment-extras-combined > .window-measure-cell .cell-select,
    .bay-measure-segment-extras-combined > .window-measure-cell .cell-input {
        width: 100% !important;
        max-width: 100% !important;
    }
    .bay-measure-main-empty,
    .bay-measure-side-empty {
        display: none !important;
    }
    .excel-row-window-measure {
        grid-template-areas:
            "leading title spacer"
            "layout layout spacer"
            ". actions spacer";
        grid-template-columns: 56px minmax(0, 200px) minmax(0, 1fr);
    }
    .admin-form-detail-page .excel-row-door-measure {
        grid-template-areas:
            "leading title spacer"
            "layout layout spacer";
        grid-template-columns: 56px minmax(0, 200px) minmax(0, 1fr);
        align-items: start;
    }
    .admin-form-detail-page .excel-row-window-measure .window-measure-title-cell {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 200px;
        justify-self: start;
        display: block;
        justify-content: initial;
        text-align: right;
        padding: 14px 0 14px 56px;
        box-sizing: border-box;
    }
    .admin-form-detail-page .excel-row-door-measure .window-measure-title-cell {
        grid-column: 1 / 3;
        width: 100%;
        max-width: 200px;
        justify-self: start;
        display: block;
        justify-content: initial;
        text-align: right;
        padding: 14px 0 14px 56px;
        box-sizing: border-box;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-layout {
        width: min(100%, 200px);
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-window-measure .excel-row-actions {
        grid-area: actions;
        grid-column: 1 / 3;
        justify-content: stretch;
        width: 100%;
        max-width: 200px;
        justify-self: start;
    }
    .admin-form-detail-page .excel-row-door-measure .excel-row-actions {
        grid-area: actions;
        grid-column: 1 / 3;
        justify-content: stretch;
        width: 100%;
        max-width: 200px;
        justify-self: start;
    }
    .window-measure-main-grid,
    .window-measure-addon-grid,
    .window-measure-side-grid,
    .window-measure-status-row {
        grid-template-columns: 1fr;
    }
    .window-measure-main-grid .window-measure-inline-cell:nth-child(1) { order: 1; }
    .window-measure-main-grid .window-measure-inline-cell:nth-child(3) { order: 2; }
    .window-measure-main-grid .window-measure-inline-cell:nth-child(2) { order: 3; }
    .window-measure-main-grid .window-measure-inline-cell:nth-child(4) { order: 4; }
    .window-measure-main-grid .window-measure-inline-cell.full-span { order: 5; }
    .window-measure-side-grid .window-measure-cell:nth-child(1) { order: 1; }
    .window-measure-side-grid .window-measure-cell:nth-child(3) { order: 2; }
    .window-measure-side-grid .window-measure-cell:nth-child(2) { order: 3; }
    .window-measure-side-grid .window-measure-cell:nth-child(4) { order: 4; }

    .bay-measure-main-grid > .window-measure-inline-cell {
        display: grid !important;
    }
    .bay-measure-main-grid > .window-measure-inline-cell:nth-child(2) { order: 3; }
    .bay-measure-main-grid > .window-measure-inline-cell:nth-child(1) { order: 4; }
    .bay-measure-main-grid > .bay-measure-colour-combined.no-other-bay-colour { order: 5; }
    .bay-measure-main-grid > .bay-measure-colour-combined.has-other-bay-colour > .bay-measure-colour-primary { order: 5; }
    .bay-measure-main-grid > .bay-measure-colour-combined > [data-other-window-colour] { order: 6; }
    .bay-measure-side-grid > .window-measure-cell:nth-child(3) { order: 6; }
    .bay-measure-side-grid > .window-measure-cell:nth-child(1) { order: 7; }
    .bay-measure-addon-stack { order: 8; }
    .bay-measure-glass-combined.no-other-glass-type { order: 9; }
    .bay-measure-glass-combined.has-other-glass-type > .bay-measure-glass-primary { order: 9; }
    .bay-measure-glass-combined > [data-other-glass-type] { order: 10; }
    .bay-measure-mobile-tail-v2,
    .bay-measure-mobile-status-card-v2,
    .bay-measure-mobile-fit-photo-v2 {
        display: none !important;
    }
    .bay-measure-final-segment-card .bay-measure-segment-tail-stack {
        display: flex !important;
        flex-direction: column;
        gap: 14px;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        height: auto;
        min-height: 0;
        order: 4;
    }
    .bay-measure-final-segment-card .bay-measure-segment-tail-status,
    .bay-measure-final-segment-card .bay-measure-segment-tail-photo {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        min-height: 0;
        height: auto;
        align-self: stretch;
    }
    .bay-measure-final-segment-card .bay-measure-segment-tail-status .status-choice-stack {
        display: grid !important;
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 8px 12px 12px;
        width: 100%;
        height: auto;
        box-sizing: border-box;
    }
    .bay-measure-final-segment-card .bay-measure-segment-tail-status .status-choice-btn {
        min-height: 44px;
        height: auto;
        width: 100%;
    }
    .bay-measure-final-segment-card .bay-measure-segment-tail-photo .media-trigger-shell {
        display: flex;
        flex: 0 0 auto;
        min-height: 0;
    }
    .bay-measure-final-segment-card .bay-measure-segment-tail-photo {
        min-height: 0;
        height: auto;
        align-self: auto;
        grid-template-rows: auto auto;
        align-content: start;
    }
    .bay-measure-final-segment-card .bay-measure-segment-tail-photo .sketch-trigger,
    .bay-measure-final-segment-card .bay-measure-segment-tail-photo .sketch-trigger-preview {
        width: 100%;
        margin: 0;
        min-height: 180px;
        height: 180px;
        max-height: 180px;
    }
    .bay-measure-final-segment-card .bay-measure-segment-sketch-card {
        min-height: 0;
        height: auto;
        align-self: auto;
    }
    .bay-measure-final-segment-card .bay-measure-segment-sketch-card .media-trigger-shell {
        margin: 6px 8px 8px;
    }
    .bay-measure-final-segment-card .bay-measure-segment-sketch-card .sketch-trigger,
    .bay-measure-final-segment-card .bay-measure-segment-sketch-card .sketch-trigger-preview {
        min-height: 180px;
        height: 180px;
        max-height: 180px;
    }
    .bay-measure-final-segment-card,
    .bay-measure-status-segment-card {
        height: auto;
        min-height: 0;
        align-items: stretch;
        align-content: start;
    }
    .bay-measure-segment-right > .bay-measure-segment-width-card {
        min-height: 82px;
        height: auto;
        align-self: auto;
    }
}
.excel-field {
    display: grid;
    gap: 6px;
}
.excel-field > span {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.excel-row .cell-input,
.excel-row .cell-select,
.excel-row .cell-textarea {
    min-height: 40px;
}
.excel-row .cell-textarea {
    min-height: 92px;
}
.tab-row { flex-wrap: wrap; margin-bottom: 18px; }
.tab-btn {
    border: 1px solid var(--border); background: #fff; color: var(--brand-navy);
    padding: 10px 14px; border-radius: 999px; font-weight: 600;
}
.tab-btn.active { background: var(--brand-navy); border-color: var(--brand-navy); color: #fff; }

.detail-box { padding: 18px; }
.detail-type, .chip {
    display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; border-radius: 999px;
    background: #edf3fa; color: var(--brand-navy); font-size: .8rem; font-weight: 700;
}
.detail-table { width: 100%; border-collapse: collapse; }
.detail-table th, .detail-table td { padding: 10px 12px; border-bottom: 1px solid #e6edf5; vertical-align: top; }
.detail-table th { width: 220px; color: var(--text-secondary); text-align: left; font-size: .86rem; font-weight: 700; }

.cell-input, .cell-select, .cell-textarea {
    width: 100%; border: 1px solid #ccd8e4; border-radius: 8px; padding: 9px 10px; background: #fff; color: var(--text-primary); box-sizing: border-box;
}
.cell-input:focus,
.cell-select:focus,
.cell-textarea:focus {
    outline: none;
    border-color: #ccd8e4;
    box-shadow: none;
}
.cell-input:not(:placeholder-shown),
.cell-textarea:not(:placeholder-shown),
.cell-select:not(.is-placeholder) {
    color: #000;
}
.cell-input::placeholder,
.cell-textarea::placeholder {
    color: #94a3b8;
}
.cell-textarea { min-height: 86px; resize: vertical; }

.gallery-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
.photo-card { border: 1px solid #dde7f1; border-radius: 16px; background: #f9fbfe; padding: 14px; display: grid; gap: 10px; }
.photo-thumb {
    aspect-ratio: 4 / 3; border-radius: 12px; border: 1px dashed #b8cae0;
    background: linear-gradient(135deg, #d9e6f7, #f4f8fc); display: flex; align-items: center; justify-content: center;
    color: var(--brand-navy); font-weight: 700;
}
.photo-thumb.is-image,
.photo-thumb.is-video {
    overflow: hidden;
    background: #eef4fb;
}
.photo-thumb img,
.photo-thumb video {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.selection-bar {
    display: flex; justify-content: space-between; align-items: center; gap: 14px;
    padding: 16px 18px; border-radius: 16px; background: var(--bg-soft); border: 1px solid #d9e6f2;
}
.checkbox-label { display: inline-flex; align-items: center; gap: 10px; font-weight: 600; }
.checkbox-label input { width: 18px; height: 18px; }

.editor-grid { display: grid; gap: 12px; }
.editor-row {
    display: grid; grid-template-columns: 140px minmax(0, 1.15fr) minmax(0, 1.2fr) minmax(120px, .8fr) minmax(120px, 1fr) 76px;
    gap: 10px; align-items: center;
}
.settings-receipts-grid,
.editor-row {
    min-width: max-content;
}
.editor-row.header { font-size: .84rem; color: var(--text-secondary); font-weight: 700; }
.settings-field-row {
    align-items: start;
}
.settings-scope-pill {
    min-height: 42px;
    padding: 10px 12px;
    border: 1px solid #d7e1eb;
    border-radius: 12px;
    background: #f8fafc;
    color: var(--brand-navy);
    font-size: 0.85rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.settings-page-shell {
    display: grid;
    gap: 20px;
}
.personal-settings-shell {
    display: flex;
    flex-direction: column;
    gap: 20px;
    flex: 1;
    min-height: 0;
    padding-bottom: 0;
    overflow: visible;
}
.settings-landing-shell,
.settings-detail-shell {
    display: grid;
    gap: 20px;
    align-content: start;
}
.settings-landing-shell {
    flex: 0 0 auto;
    height: auto;
    min-height: 0;
    overflow: visible;
}
.settings-landing-scroll-area {
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}
.settings-detail-shell {
    flex: 0 0 auto;
    height: auto;
    min-height: 0;
    overflow: visible;
    gap: 0;
}
.settings-customers-list-topbar {
    display: grid;
    gap: 20px;
    padding: 0 0 12px;
    background: #f4f5f7;
    border-bottom: 1px solid #dce8f4;
}
.settings-customers-list-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.settings-customers-list-title-row h1 {
    margin: 0;
}
.settings-customers-add-btn {
    flex-shrink: 0;
}
.settings-customers-list-topbar .forms-list-toolbar {
    width: 100%;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0;
}
.settings-customers-list-topbar .forms-list-toolbar-meta {
    display: flex;
    margin-left: auto;
    justify-content: flex-end;
    width: auto;
}
.settings-card .forms-list-toolbar-head {
    justify-content: space-between;
}
body[data-page="settings"][data-settings-view="landing"] .page-header,
body[data-page="settings"][data-settings-view="customers-list"] .page-header,
body[data-page="settings"][data-settings-view="suppliers-list"] .page-header,
body[data-page="settings"][data-settings-view="detail"] .page-header {
    padding: 28px 30px 0;
    margin-bottom: 0;
}
body[data-page="settings"] #settings-shell .settings-back-link {
    display: none;
}
body[data-page="settings"][data-settings-view="detail"] .settings-detail-shell > * {
    min-height: 0;
    overflow: visible;
}
.settings-landing-grid {
    display: grid;
    width: 100%;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 20px;
}
.settings-nav-card {
    min-height: 180px;
    border: 1px solid #d7e6f4;
    border-radius: 22px;
    background: linear-gradient(180deg, #fbfdff, #f3f8fe);
    padding: 22px;
    display: grid;
    gap: 20px;
    align-content: start;
    box-shadow: 0 12px 24px rgba(20, 55, 99, 0.06);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.settings-nav-card:hover {
    transform: translateY(-2px);
    border-color: #b8d0eb;
    box-shadow: 0 18px 30px rgba(20, 55, 99, 0.1);
}
.settings-nav-card-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.settings-nav-icon {
    width: 52px;
    height: 52px;
    border-radius: 16px;
    border: 1px solid #d7e1eb;
    background: #ffffff;
    color: var(--brand-navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.settings-nav-card-copy {
    display: grid;
    gap: 10px;
}
.settings-nav-card-copy strong {
    font-size: 1.2rem;
    line-height: 1.2;
}
.settings-nav-card-copy p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.5;
}
.settings-back-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    min-height: 40px;
    padding: 0 14px;
    margin-bottom: 12px;
    border: 1px solid #d7e1eb;
    border-radius: 999px;
    background: #fff;
    color: var(--brand-navy);
    font-weight: 700;
}
.settings-back-link:hover {
    background: #eef5fc;
}
.settings-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.9fr);
    gap: 18px;
    align-items: stretch;
    background:
        radial-gradient(circle at top left, rgba(41, 74, 120, 0.12), transparent 42%),
        linear-gradient(135deg, #ffffff, #f7fbff 55%, #eef5fd);
}
.settings-hero-copy {
    display: grid;
    gap: 12px;
    align-content: start;
}
.settings-hero-copy h2 {
    margin: 0;
    font-size: 1.9rem;
    line-height: 1.15;
}
.settings-hero-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.settings-metric-card {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.92);
    padding: 18px 16px;
    display: grid;
    gap: 6px;
    align-content: center;
    box-shadow: 0 10px 24px rgba(20, 55, 99, 0.06);
}
.settings-metric-card strong {
    font-size: 1.9rem;
    line-height: 1;
}
.settings-metric-card span {
    color: var(--text-secondary);
    font-size: 0.92rem;
}
.settings-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}
.settings-card {
    display: grid;
    gap: 18px;
}
body[data-page="settings"][data-settings-view="detail"] .settings-detail-shell > .settings-card {
    margin: 0;
    width: 100%;
    box-sizing: border-box;
    min-height: 0;
    overflow: visible;
}
.settings-part-grid,
.settings-family-grid,
.settings-policy-grid {
    display: grid;
    gap: 14px;
}
.settings-detail-body-card {
    border: 1px solid #dce8f4;
    border-radius: 20px;
    background: #f8fbff;
    padding: 16px;
    display: grid;
    gap: 16px;
}
.settings-connections-stack {
    display: grid;
    gap: 18px;
    margin-bottom: 18px;
}
.settings-connection-card,
.settings-folder-routing-card {
    border: 1px solid #d7e1eb;
    border-radius: 18px;
    background: #f8fafc;
    padding: 18px;
    display: grid;
    gap: 16px;
}
.settings-connection-card-head,
.settings-folder-routing-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}
.settings-connection-card-head h3,
.settings-folder-routing-head h3 {
    margin: 0;
    font-size: 1.05rem;
    color: var(--brand-navy);
}
.settings-connection-card-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.settings-connection-main-copy {
    display: grid;
    gap: 4px;
}
.settings-connection-main-copy small {
    color: var(--text-secondary);
}
.settings-connection-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 8px 14px;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.settings-connection-status.is-connected {
    background: #e7f7ed;
    color: #166534;
}
.settings-connection-status.is-disconnected {
    background: #fceaea;
    color: #991b1b;
}
.settings-folder-routing-grid {
    gap: 10px;
}
.settings-folder-routing-row {
    grid-template-columns: minmax(180px, 1.1fr) minmax(220px, 1.2fr) 110px;
}
.settings-folder-routing-header {
    color: var(--text-secondary);
    font-size: 0.84rem;
    font-weight: 700;
}
.settings-folder-route-label,
.settings-folder-route-folder {
    min-height: 42px;
    padding: 10px 12px;
    border: 1px solid #d7e1eb;
    border-radius: 12px;
    background: #ffffff;
    display: flex;
    align-items: center;
    color: var(--brand-navy);
    font-weight: 700;
}
.settings-folder-route-folder {
    font-weight: 600;
}
.settings-folder-route-actions {
    display: flex;
    justify-content: flex-end;
}
.settings-connections-message {
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid #d7e1eb;
    background: #ffffff;
    color: var(--brand-navy);
    font-weight: 600;
}
.settings-connection-modal {
    position: fixed;
    inset: 0;
    z-index: 1400;
    display: grid;
    place-items: center;
    padding: 24px;
}
.settings-connection-modal.hidden {
    display: none;
}
.settings-connection-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.42);
}
.settings-connection-modal-card {
    position: relative;
    z-index: 1;
    width: min(520px, calc(100vw - 32px));
    border-radius: 22px;
    border: 1px solid #d7e1eb;
    background: #ffffff;
    box-shadow: 0 24px 60px rgba(20, 55, 99, 0.18);
    padding: 22px;
    display: grid;
    gap: 18px;
}
.settings-connection-modal-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}
.settings-connection-modal-head h3 {
    margin: 0 0 4px;
    color: var(--brand-navy);
}
.settings-connection-modal-head p {
    margin: 0;
    color: var(--text-secondary);
}
.settings-connection-modal-body {
    display: grid;
    gap: 14px;
}
.settings-connection-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}
.settings-list-group-grid {
    display: grid;
    gap: 14px;
}
.settings-list-sidebar-layout {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}
.settings-list-sidebar {
    min-width: 0;
}
.settings-list-sidebar-card {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    padding: 18px 14px;
    display: grid;
    gap: 18px;
}
.settings-list-sidebar-section {
    display: grid;
    gap: 8px;
}
.settings-list-sidebar-heading {
    padding: 0 10px;
    color: #5f7894;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.settings-list-sidebar-children {
    display: grid;
    gap: 4px;
}
.settings-list-sidebar-link {
    display: block;
    padding: 10px 14px 10px 22px;
    border: 0;
    border-radius: 12px;
    background: transparent;
    color: var(--brand-navy);
    font-weight: 700;
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}
.settings-list-sidebar-link:hover {
    background: #eef6ff;
}
.settings-list-sidebar-link.active {
    background: #e8f2ff;
    box-shadow: inset 0 0 0 1px #9fc5f3;
}
.settings-list-sidebar-panel {
    min-width: 0;
}
.settings-part-grid,
.settings-family-grid,
.settings-policy-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.settings-list-group-card {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    padding: 16px;
    display: grid;
    gap: 14px;
}
.settings-list-group-head h3 {
    margin: 0;
    font-size: 1rem;
}
.settings-list-group-head-with-action {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.settings-dropdown-table-add-btn {
    flex-shrink: 0;
}
.settings-dropdown-table-wrap {
    min-width: 0;
}
.settings-dropdown-table {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
}
.settings-dropdown-table-head,
.settings-dropdown-table-row {
    display: grid;
    grid-template-columns: minmax(180px, 1.1fr) minmax(280px, 1.8fr) minmax(110px, 0.7fr) 56px 56px;
    align-items: center;
}
.settings-keyboard-table .settings-dropdown-table-head,
.settings-keyboard-table .settings-dropdown-table-row {
    grid-template-columns: minmax(240px, 1fr) 56px 56px;
}
.settings-keyboard-table .settings-dropdown-table-head > div:first-child,
.settings-keyboard-table .settings-dropdown-table-name-cell {
    justify-self: stretch;
}
.settings-keyboard-table .settings-dropdown-table-head > div:nth-child(2),
.settings-keyboard-table .settings-dropdown-table-head > div:nth-child(3) {
    justify-self: center;
}
.settings-dropdown-table-head {
    background: #edf4fb;
    color: #5f7894;
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}
.settings-dropdown-table-head > div,
.settings-dropdown-table-cell {
    padding: 14px 16px;
}
.settings-dropdown-table-body {
    display: grid;
}
.settings-dropdown-table-row + .settings-dropdown-table-row {
    border-top: 1px solid #e3edf7;
}
.settings-dropdown-table-row.is-locked {
    background: #fbfdff;
}
.settings-dropdown-table-row.is-saved {
    opacity: 0.84;
}
.settings-dropdown-table-row.is-saved .settings-dropdown-table-cell {
    color: #5b7592;
}
.settings-dropdown-table-row.is-editing {
    background: #f8fbff;
}
.settings-dropdown-table-cell {
    min-width: 0;
    color: var(--brand-navy);
}
.settings-dropdown-table-name-cell strong {
    font-size: 0.96rem;
}
.settings-dropdown-table-cell .cell-input {
    width: 100%;
}
.settings-dropdown-table-icon-cell {
    display: flex;
    align-items: center;
    justify-content: center;
}
.settings-dropdown-table-icon-btn {
    width: 36px;
    height: 36px;
}
.settings-dropdown-table-delete-btn {
    color: var(--brand-red);
}
.settings-dropdown-table-lock-note {
    color: #7a8ea5;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.settings-part-card,
.settings-family-card,
.settings-policy-card {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    padding: 16px;
    display: grid;
    gap: 12px;
}
.settings-part-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}
.settings-part-head h3 {
    margin: 0;
    font-size: 1rem;
}
.settings-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.settings-chip {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid #d6e4f1;
    background: #fff;
    color: var(--brand-navy);
    font-size: 0.86rem;
    font-weight: 700;
}
.settings-repair-part-list {
    display: grid;
    gap: 10px;
}
.settings-repair-part-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 52px;
    gap: 10px;
    align-items: center;
}
.settings-repair-part-name {
    min-height: 46px;
    padding: 0 18px;
    border: 1px solid #d6e4f1;
    border-radius: 16px;
    background: #fff;
    color: var(--brand-navy);
    font-size: 0.98rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.settings-repair-part-delete {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    justify-self: center;
    background: #f8fbff;
    color: #d92d20;
}
.settings-repair-part-delete.is-disabled,
.settings-repair-part-delete:disabled {
    opacity: 0.38;
    cursor: not-allowed;
    background: #f8fbff;
    color: #d92d20;
    border-color: #dce8f4;
}
.settings-field-card {
    overflow: visible;
}
.settings-repair-list-layout {
    display: grid;
    gap: 20px;
    align-content: start;
}
.settings-repair-list-section {
    display: grid;
    align-content: start;
}
.settings-repair-list-title {
    padding: 14px 18px;
    border-bottom: 1px solid #dce8f4;
    background: linear-gradient(180deg, #f8fbff 0%, #f3f8fd 100%);
    color: var(--brand-navy);
    font-size: 1rem;
    font-weight: 800;
}
.settings-repair-list-box {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #fff;
    overflow-x: auto;
    overflow-y: hidden;
    align-self: start;
}
.settings-repair-list-header,
.settings-repair-list-row {
    min-width: 1380px;
}
.settings-repair-list-row {
    display: grid;
    grid-template-columns: minmax(120px, 0.9fr) minmax(140px, 0.95fr) 120px minmax(155px, 1fr) minmax(130px, 0.8fr) 118px 86px 86px 120px;
    align-items: center;
    gap: 0;
}
.settings-repair-list-row + .settings-repair-list-row {
    border-top: 1px solid #e3edf7;
}
.settings-repair-preview-row {
    padding: 0 14px 14px;
    border-top: 1px solid #e3edf7;
    background: #fff;
}
.settings-repair-preview-row.is-hidden {
    display: none;
}
.settings-repair-preview-panel {
    margin-top: 14px;
}
.custom-dropdown-stack {
    display: grid;
    gap: 10px;
    align-content: start;
}
.custom-dropdown-other-field {
    display: grid;
    gap: 8px;
}
.settings-repair-list-header {
    background: #f8fbff;
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.01em;
}
.settings-repair-list-header > div {
    padding: 12px 14px;
}
.settings-repair-list-header > div:nth-child(6),
.settings-repair-list-header > div:nth-child(7) {
    text-align: center;
}
.settings-repair-list-header-action {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-right: 10px;
}
.settings-repair-list-cell {
    padding: 10px 12px;
    min-width: 0;
}
.settings-repair-list-cell .cell-input,
.settings-repair-list-cell .cell-select,
.settings-repair-list-cell select {
    width: 100%;
}
.settings-price-input-wrap {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 8px;
    width: 100%;
    min-height: 44px;
    padding: 0 12px;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #fff;
    box-sizing: border-box;
}
.settings-price-input-prefix {
    color: var(--brand-navy);
    font-weight: 700;
    line-height: 1;
}
.settings-price-input-wrap .settings-price-input.cell-input {
    border: 0;
    box-shadow: none;
    background: transparent;
    padding-left: 0;
    padding-right: 0;
}
.settings-price-input-wrap .settings-price-input.cell-input:focus {
    box-shadow: none;
}
.settings-repair-list-row.is-saved .settings-price-input-wrap {
    background: #f3f7fb;
    opacity: 0.78;
}
.settings-repair-list-row.is-saved .settings-repair-list-cell .cell-input:disabled,
.settings-repair-list-row.is-saved .settings-repair-list-cell .cell-select:disabled,
.settings-repair-list-row.is-saved .settings-repair-list-cell select:disabled {
    opacity: 0.6;
    background: #f8fbff;
    color: #5b7592;
}
.settings-repair-list-row.is-saved {
    opacity: 0.82;
}
.settings-repair-list-row.is-saved .settings-repair-list-locked-name,
.settings-repair-list-row.is-saved .settings-repair-list-cell {
    color: #5b7592;
}
.settings-repair-list-row.is-saved .settings-qty-toggle {
    opacity: 0.6;
}
.settings-repair-list-locked-name {
    min-height: 42px;
    padding: 10px 12px;
    border: 1px solid #d6e3f0;
    border-radius: 12px;
    background: #f8fbff;
    color: var(--brand-navy);
    font-weight: 700;
    display: flex;
    align-items: center;
}
.settings-repair-list-locked-name-continuation {
    background: transparent;
    border-color: transparent;
}
.settings-repair-list-cell-action,
.settings-repair-list-cell-other,
.settings-repair-list-cell-qty {
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border-left: 0;
}
.settings-repair-list-cell-action {
    gap: 8px;
    justify-content: flex-end;
    padding-right: 14px;
}
.settings-repair-list-save {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    padding: 0;
    background: transparent;
    border: 1px solid transparent;
    color: var(--brand-green) !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.settings-repair-list-save:hover,
.settings-repair-list-save:focus-visible,
.forms-grid-bin.settings-repair-list-save:hover,
.forms-grid-bin.settings-repair-list-save:focus-visible {
    background: transparent;
    border-color: transparent;
    color: var(--brand-green) !important;
}
.settings-repair-list-bin,
.settings-repair-list-bin.settings-customer-bin {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    padding: 0;
    background: transparent;
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.settings-repair-list-save i,
.settings-repair-list-bin i {
    width: 18px;
    height: 18px;
    stroke-width: 2;
}
.settings-repair-list-bin.is-disabled,
.settings-repair-list-bin:disabled,
.settings-repair-list-add-btn.is-disabled,
.settings-repair-list-add-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
    box-shadow: none;
}
.settings-repair-list-bin:hover,
.settings-repair-list-bin:focus-visible,
.forms-grid-bin.settings-repair-list-bin:hover,
.forms-grid-bin.settings-repair-list-bin:focus-visible,
.settings-customer-bin.settings-repair-list-bin:hover,
.settings-customer-bin.settings-repair-list-bin:focus-visible {
    background: transparent;
    border-color: transparent;
    color: var(--brand-red);
}
.settings-repair-list-add-btn {
    min-height: 38px;
    min-width: 96px;
    max-width: 100%;
    padding: 0 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    white-space: nowrap;
}
.settings-repair-list-cell-other .settings-qty-toggle,
.settings-repair-list-cell-qty .settings-qty-toggle {
    width: 56px;
    min-height: 42px;
    min-width: 56px;
    padding: 0;
    justify-content: center;
    border: 1px solid #d6e3f0;
    border-radius: 14px;
    background: #f8fbff;
}
.settings-repair-list-cell-other .settings-qty-toggle.is-disabled {
    opacity: 0.4;
    cursor: not-allowed;
}
.settings-repair-list-cell-other .settings-qty-toggle input,
.settings-repair-list-cell-qty .settings-qty-toggle input {
    width: 18px;
    height: 18px;
    margin: 0;
}
.settings-people-list {
    display: grid;
    gap: 12px;
}
.settings-person-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #f8fbff;
}
.settings-person-row small {
    display: block;
    margin-top: 4px;
    color: var(--text-secondary);
}
.settings-person-row span {
    color: var(--brand-navy);
    font-weight: 700;
}
.settings-policy-card p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.5;
}
.settings-quote-grid {
    display: grid;
    gap: 14px;
}
.settings-receipt-row {
    align-items: center;
}
.settings-receipts-grid {
    display: grid;
    grid-template-columns: minmax(220px, 1.5fr) repeat(4, minmax(92px, 0.55fr)) auto 52px;
    gap: 12px 10px;
    align-items: center;
}
.settings-receipt-row,
.settings-receipt-header {
    display: contents;
}
.settings-receipt-header > div {
    font-size: .84rem;
    color: var(--text-secondary);
    font-weight: 700;
    text-align: center;
}
.settings-receipt-header > div:first-child {
    text-align: left;
}
.settings-receipt-remove-btn {
    justify-self: center;
    width: 42px;
    height: 42px;
    border: 0;
    border-radius: 12px;
    background: #d92d20;
    color: #ffffff;
    box-shadow: none;
}
.settings-receipt-remove-btn:hover {
    background: #b42318;
}
.settings-receipt-remove-btn svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
}
.settings-receipt-save-btn {
    min-width: 84px;
}
.settings-receipt-save-btn.is-hidden {
    visibility: hidden;
    pointer-events: none;
}
.settings-receipt-tick {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #f8fbff;
}
.settings-receipt-tick input {
    width: 18px;
    height: 18px;
}
.tracking-page-shell {
    display: grid;
    gap: 20px;
}
.tracking-toolbar-card,
.tracking-map-card,
.tracking-engineers-card {
    display: grid;
    gap: 12px;
}
.tracking-toolbar-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.tracking-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(390px, 410px);
    gap: 16px;
    align-items: start;
}
.tracking-map-card {
    min-height: 760px;
}
.tracking-map-card .card-head {
    margin-bottom: -2px;
}
.tracking-map-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    color: var(--text-secondary);
    font-weight: 600;
}
.tracking-legend-item {
    display: inline-flex;
    align-items: center;
}
.tracking-legend-icon {
    width: 14px;
    height: 14px;
    margin-right: 8px;
    stroke-width: 2.2;
}
.tracking-map-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}
.tracking-map-motion-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid #d7e1eb;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
    color: #5f7288;
    font-size: 0.92rem;
    line-height: 1.2;
}
.tracking-map-motion-pill strong {
    color: #173a63;
    font-size: 0.92rem;
}
.tracking-map-controls {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.tracking-map-corner-controls {
    position: absolute;
    bottom: 18px;
    z-index: 7;
    display: flex;
    gap: 10px;
    pointer-events: none;
}
.tracking-map-corner-controls-left {
    left: 18px;
}
.tracking-map-corner-controls-right {
    right: 18px;
    flex-direction: column;
}
.tracking-map-corner-btn {
    min-width: 74px;
    justify-content: center;
    pointer-events: auto;
}
.tracking-map-corner-icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid #d7e1eb;
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.14);
    pointer-events: auto;
}
.tracking-map-corner-icon:hover,
.tracking-map-corner-icon:focus-visible {
    background: #ffffff;
    border-color: #9eb6d1;
}
.tracking-map-hint {
    color: var(--text-secondary);
    font-size: 0.9rem;
    font-weight: 600;
}
.tracking-legend-dot {
    width: 12px;
    height: 12px;
    border-radius: 999px;
    display: inline-block;
    margin-right: 8px;
}
.tracking-legend-business {
    color: var(--brand-navy);
}
.tracking-legend-job-site {
    background: #111111;
}
.tracking-legend-live {
    background: var(--brand-green);
}
.tracking-legend-stop {
    background: #f59e0b;
}
.tracking-legend-home {
    color: #3b82f6;
}
.tracking-map-canvas {
    position: relative;
    min-height: 640px;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    overflow: hidden;
    cursor: grab;
    background:
        radial-gradient(circle at 20% 20%, rgba(84, 183, 113, 0.16), transparent 28%),
        radial-gradient(circle at 80% 18%, rgba(20, 55, 99, 0.12), transparent 25%),
        linear-gradient(135deg, #ddecfb, #f7fbff);
}
.tracking-map-canvas-live {
    cursor: default;
}
.tracking-map-live-host {
    position: absolute;
    inset: 0;
}
.tracking-map-canvas.map-layers-on {
    background:
        radial-gradient(circle at 22% 24%, rgba(82, 151, 71, 0.2), transparent 26%),
        radial-gradient(circle at 76% 20%, rgba(234, 179, 8, 0.18), transparent 22%),
        linear-gradient(135deg, #d9ead7, #edf6ee);
}
.tracking-map-canvas.is-dragging {
    cursor: grabbing;
}
.tracking-map-stage {
    position: absolute;
    inset: 0;
    transition: transform 0.18s ease;
    will-change: transform;
    transform-origin: center center;
}
.tracking-map-overlay {
    position: absolute;
    inset: 0;
    z-index: 3;
    pointer-events: none;
}
.tracking-map-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
    pointer-events: none;
}
.tracking-route-layer {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
}
.tracking-route-path {
    fill: none;
    stroke: rgba(13, 155, 68, 0.48);
    stroke-width: 0.45;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 1.6 1.1;
}
.tracking-map-pin,
.tracking-map-marker,
.tracking-map-radius,
.tracking-map-label {
    position: absolute;
    transform: translate(-50%, -50%);
}
.tracking-map-pin {
    z-index: 4;
    pointer-events: auto;
}
.tracking-map-marker {
    width: 16px;
    height: 16px;
    border-radius: 999px;
    box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.92);
    transform: scale(calc(1 / var(--tracking-zoom, 1)));
    transform-origin: center center;
}
.tracking-map-marker-site {
    background: var(--brand-navy);
}
.tracking-map-marker-engineer {
    background: var(--engineer-color, var(--brand-green));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.42rem;
    font-weight: 800;
    overflow: hidden;
}
.tracking-map-marker-engineer.has-face {
    background: #fff;
    box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.92), inset 0 0 0 2px var(--engineer-color, var(--brand-green));
}
.tracking-map-marker-engineer.has-face img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.tracking-map-radius {
    width: var(--tracking-radius);
    height: var(--tracking-radius);
    border-radius: 999px;
    background: rgba(13, 155, 68, 0.12);
    border: 2px solid rgba(13, 155, 68, 0.28);
    z-index: 1;
}
.tracking-map-tooltip {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 12px);
    transform: translateX(-50%) scale(calc(1 / var(--tracking-zoom, 1)));
    min-width: 180px;
    max-width: 220px;
    padding: 10px 12px;
    border-radius: 14px;
    background: rgba(14, 31, 55, 0.94);
    color: #fff;
    box-shadow: 0 16px 34px rgba(13, 31, 53, 0.22);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.18s ease, visibility 0.18s ease, transform 0.18s ease;
    transform-origin: center center;
}
.tracking-map-tooltip.tooltip-below {
    top: calc(100% + 12px);
    bottom: auto;
}
.tracking-map-tooltip.tooltip-left {
    left: auto;
    right: 0;
    transform: scale(calc(1 / var(--tracking-zoom, 1)));
}
.tracking-map-tooltip.tooltip-right {
    left: 0;
    transform: scale(calc(1 / var(--tracking-zoom, 1)));
}
.tracking-map-tooltip.tooltip-center.tooltip-above {
    transform: translateX(-50%) scale(calc(1 / var(--tracking-zoom, 1)));
}
.tracking-map-tooltip.tooltip-center.tooltip-below {
    transform: translateX(-50%) scale(calc(1 / var(--tracking-zoom, 1)));
}
.tracking-map-tooltip strong,
.tracking-map-tooltip small {
    display: block;
}
.tracking-map-tooltip small {
    margin-top: 4px;
    color: rgba(255, 255, 255, 0.82);
    line-height: 1.35;
}
.tracking-map-pin:hover .tracking-map-tooltip,
.tracking-map-pin:focus-within .tracking-map-tooltip,
.tracking-map-label:hover .tracking-map-tooltip,
.tracking-map-label:focus-visible .tracking-map-tooltip,
.tracking-map-label-static:hover .tracking-map-tooltip,
.tracking-map-label-static:focus-within .tracking-map-tooltip {
    opacity: 1;
    visibility: visible;
}
.tracking-map-pin:hover .tracking-map-tooltip.tooltip-center.tooltip-above,
.tracking-map-pin:focus-within .tracking-map-tooltip.tooltip-center.tooltip-above,
.tracking-map-label:hover .tracking-map-tooltip.tooltip-center.tooltip-above,
.tracking-map-label:focus-visible .tracking-map-tooltip.tooltip-center.tooltip-above,
.tracking-map-label-static:hover .tracking-map-tooltip.tooltip-center.tooltip-above,
.tracking-map-label-static:focus-within .tracking-map-tooltip.tooltip-center.tooltip-above {
    transform: translateX(-50%) translateY(-2px) scale(calc(1 / var(--tracking-zoom, 1)));
}
.tracking-map-pin:hover .tracking-map-tooltip.tooltip-center.tooltip-below,
.tracking-map-pin:focus-within .tracking-map-tooltip.tooltip-center.tooltip-below,
.tracking-map-label:hover .tracking-map-tooltip.tooltip-center.tooltip-below,
.tracking-map-label:focus-visible .tracking-map-tooltip.tooltip-center.tooltip-below,
.tracking-map-label-static:hover .tracking-map-tooltip.tooltip-center.tooltip-below,
.tracking-map-label-static:focus-within .tracking-map-tooltip.tooltip-center.tooltip-below {
    transform: translateX(-50%) translateY(2px) scale(calc(1 / var(--tracking-zoom, 1)));
}
.tracking-map-pin:hover .tracking-map-tooltip.tooltip-left.tooltip-above,
.tracking-map-pin:focus-within .tracking-map-tooltip.tooltip-left.tooltip-above,
.tracking-map-label:hover .tracking-map-tooltip.tooltip-left.tooltip-above,
.tracking-map-label:focus-visible .tracking-map-tooltip.tooltip-left.tooltip-above,
.tracking-map-label-static:hover .tracking-map-tooltip.tooltip-left.tooltip-above,
.tracking-map-label-static:focus-within .tracking-map-tooltip.tooltip-left.tooltip-above,
.tracking-map-pin:hover .tracking-map-tooltip.tooltip-right.tooltip-above,
.tracking-map-pin:focus-within .tracking-map-tooltip.tooltip-right.tooltip-above,
.tracking-map-label:hover .tracking-map-tooltip.tooltip-right.tooltip-above,
.tracking-map-label:focus-visible .tracking-map-tooltip.tooltip-right.tooltip-above,
.tracking-map-label-static:hover .tracking-map-tooltip.tooltip-right.tooltip-above,
.tracking-map-label-static:focus-within .tracking-map-tooltip.tooltip-right.tooltip-above {
    transform: translateY(-2px) scale(calc(1 / var(--tracking-zoom, 1)));
}
.tracking-map-pin:hover .tracking-map-tooltip.tooltip-left.tooltip-below,
.tracking-map-pin:focus-within .tracking-map-tooltip.tooltip-left.tooltip-below,
.tracking-map-label:hover .tracking-map-tooltip.tooltip-left.tooltip-below,
.tracking-map-label:focus-visible .tracking-map-tooltip.tooltip-left.tooltip-below,
.tracking-map-label-static:hover .tracking-map-tooltip.tooltip-left.tooltip-below,
.tracking-map-label-static:focus-within .tracking-map-tooltip.tooltip-left.tooltip-below,
.tracking-map-pin:hover .tracking-map-tooltip.tooltip-right.tooltip-below,
.tracking-map-pin:focus-within .tracking-map-tooltip.tooltip-right.tooltip-below,
.tracking-map-label:hover .tracking-map-tooltip.tooltip-right.tooltip-below,
.tracking-map-label:focus-visible .tracking-map-tooltip.tooltip-right.tooltip-below,
.tracking-map-label-static:hover .tracking-map-tooltip.tooltip-right.tooltip-below,
.tracking-map-label-static:focus-within .tracking-map-tooltip.tooltip-right.tooltip-below {
    transform: translateY(2px) scale(calc(1 / var(--tracking-zoom, 1)));
}
.tracking-map-label {
    margin-top: -18px;
    z-index: 4;
    text-decoration: none;
    pointer-events: auto;
}
.tracking-map-label-static {
    cursor: default;
}
.tracking-map-label span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid #d7e1eb;
    color: var(--brand-navy);
    font-size: 0.76rem;
    font-weight: 700;
    transform: scale(calc(1 / var(--tracking-zoom, 1)));
    transform-origin: center center;
}
.tracking-map-label:hover span,
.tracking-map-label:focus-visible span {
    border-color: #9eb6d1;
    background: #ffffff;
}
.tracking-map-empty,
.tracking-empty-state {
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--text-secondary);
    border: 1px dashed #c7d6e6;
    border-radius: 20px;
    background: #f8fbff;
    padding: 24px;
}
.tracking-record-list,
.tracking-engineer-list {
    display: grid;
    gap: 12px;
}
.tracking-engineer-list {
    padding-right: 4px;
}
.tracking-map-info-window {
    display: grid;
    gap: 4px;
    min-width: 180px;
    color: #173a63;
}
.tracking-map-info-window strong {
    font-size: 0.95rem;
}
.tracking-map-info-window small {
    color: #5f7288;
    line-height: 1.35;
}
body[data-page="tracking"] .gm-style .gm-style-iw-c {
    padding: 8px 10px 10px !important;
    border-radius: 16px !important;
}
body[data-page="tracking"] .gm-style .gm-style-iw-d {
    overflow: auto !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
}
body[data-page="tracking"] .gm-style .gm-ui-hover-effect {
    top: 2px !important;
    right: 2px !important;
    width: 28px !important;
    height: 28px !important;
}
body[data-page="tracking"] .gm-style .gm-ui-hover-effect > span {
    margin: 6px !important;
}
body[data-page="tracking"] .tracking-map-info-window {
    padding-top: 18px;
    min-width: 180px;
}

@media (min-height: 820px) {
    body[data-page="tracking"] .page-content {
        overflow: hidden;
        display: flex;
        flex-direction: column;
        min-height: 0;
    }
    body[data-page="tracking"] #tracking-shell {
        flex: 1;
        min-height: 0;
        display: flex;
        flex-direction: column;
    }
    .tracking-page-shell {
        display: flex;
        flex-direction: column;
        flex: 1;
        min-height: 0;
    }
    .tracking-layout {
        flex: 1;
        height: 100%;
        min-height: 0;
        align-items: stretch;
    }
    .tracking-map-card {
        min-height: 0;
        height: 100%;
        grid-template-rows: auto auto minmax(0, 1fr);
    }
    .tracking-map-canvas {
        min-height: 0;
        height: 100%;
    }
    .tracking-engineers-card {
        min-height: 0;
        height: 100%;
        grid-template-rows: auto auto auto auto minmax(0, 1fr);
    }
.tracking-engineer-list {
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
}
}
.tracking-form-link {
    color: var(--brand-navy);
    text-decoration: none;
}
.tracking-form-link:hover,
.tracking-form-link:focus-visible {
    text-decoration: underline;
}
.tracking-record-card {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    padding: 16px;
    display: grid;
    gap: 12px;
}
.tracking-record-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}
.tracking-record-head small {
    display: block;
    margin-top: 4px;
    color: var(--text-secondary);
}
.tracking-record-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.tracking-record-note {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.5;
}
.tracking-engineer-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.tracking-date-wrap {
    display: grid;
    gap: 10px;
}
.tracking-date-input-row {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 8px;
    align-items: end;
}
.tracking-date-step-btn {
    width: 40px;
    height: 42px;
    border-radius: 12px;
    border: 1px solid #dce8f4;
    background: #f8fbff;
}
.tracking-date-actions {
    display: flex;
    justify-content: flex-start;
    gap: 10px;
    margin-top: -4px;
    flex-wrap: wrap;
}
.tracking-engineer-option {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 6px;
    padding: 10px 8px;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #f8fbff;
    min-width: 0;
    width: 100%;
    overflow: hidden;
}
.tracking-engineer-option.is-focusable {
    cursor: pointer;
}
.tracking-engineer-option.is-focusable:hover,
.tracking-engineer-option.is-focusable:focus-visible {
    border-color: #b7d2ec;
    background: #f2f8ff;
}
.tracking-engineer-toggle {
    flex: 1 1 auto;
    display: grid;
    gap: 3px;
    min-width: 0;
    max-width: none;
    width: auto;
}
.tracking-engineer-time {
    color: var(--text-secondary);
    font-size: 0.78rem;
    min-width: 0;
    display: grid;
    gap: 1px;
    margin-left: 28px;
}
.tracking-engineer-time-label {
    white-space: nowrap;
}
.tracking-engineer-time-value {
    display: block;
}
.tracking-engineer-option-end {
    display: flex;
    align-items: center;
    gap: 3px;
    flex: 0 0 auto;
    margin-left: auto;
}
.tracking-engineer-focus {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    border: 1px solid #cfdceb;
    background: #fff;
    color: var(--brand-navy);
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    display: grid;
    place-items: center;
    padding: 0;
    line-height: 1;
}
.tracking-engineer-focus:hover,
.tracking-engineer-focus:focus-visible {
    border-color: #8aa9ca;
    background: #f4f9ff;
}
.tracking-engineer-focus.is-disabled,
.tracking-engineer-focus:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.tracking-engineer-home {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    border: 1px solid #cfdceb;
    background: #fff;
    color: var(--brand-navy);
    font-size: 1rem;
    cursor: pointer;
    display: grid;
    place-items: center;
    padding: 0;
    line-height: 1;
}
.tracking-engineer-home svg {
    width: 18px;
    height: 18px;
    display: block;
    stroke-width: 2;
}
.tracking-engineer-home:hover,
.tracking-engineer-home:focus-visible {
    border-color: #8aa9ca;
    background: #f4f9ff;
}
.tracking-engineer-home.is-disabled,
.tracking-engineer-home:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.tracking-engineer-live-request {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    border: 1px solid #bad7ff;
    background: #eff6ff;
    color: #1d4ed8;
    display: grid;
    place-items: center;
    padding: 0;
    line-height: 1;
    cursor: pointer;
}
.tracking-engineer-live-request svg {
    width: 18px;
    height: 18px;
    display: block;
    stroke-width: 2;
}
.tracking-engineer-live-request:hover,
.tracking-engineer-live-request:focus-visible {
    background: #dbeafe;
    border-color: #93c5fd;
}
.tracking-engineer-live-request:disabled {
    opacity: 0.55;
    cursor: wait;
}
.tracking-engineer-emergency {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    border: 1px solid #f2b8bf;
    background: #fff4f5;
    color: #9f1239;
    display: grid;
    place-items: center;
    padding: 0;
    line-height: 1;
}
.tracking-engineer-emergency svg {
    width: 18px;
    height: 18px;
    display: block;
    stroke-width: 2;
}
.tracking-engineer-emergency:hover,
.tracking-engineer-emergency:focus-visible {
    background: #ffe8ec;
    border-color: #e58f9d;
}
.tracking-engineer-emergency.is-disabled,
.tracking-engineer-emergency:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.tracking-engineer-toggle .checkbox-label {
    min-width: 0;
    width: auto;
    align-items: center;
    display: grid;
    grid-template-columns: 26px minmax(0, 1fr);
    column-gap: 8px;
}
.tracking-engineer-toggle .checkbox-label input[type="checkbox"] {
    justify-self: center;
    margin: 0;
}
.tracking-engineer-toggle .engineer-badge {
    min-width: 0;
    width: auto;
}
.tracking-engineer-toggle .engineer-badge-label {
    font-size: 0.88rem;
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
    line-height: 1.2;
}
.tracking-engineer-option:has(.tracking-engineer-time) .tracking-engineer-toggle {
    grid-template-columns: 26px minmax(0, 1fr);
    column-gap: 8px;
    align-items: center;
}
.tracking-engineer-option:has(.tracking-engineer-time) .tracking-engineer-toggle .checkbox-label {
    display: contents;
}
.tracking-engineer-option:has(.tracking-engineer-time) .tracking-engineer-toggle input[type="checkbox"] {
    grid-column: 1;
    grid-row: 1 / span 2;
    align-self: center;
    justify-self: center;
}
.tracking-engineer-option:has(.tracking-engineer-time) .tracking-engineer-toggle .engineer-badge {
    grid-column: 2;
    grid-row: 1;
}
.tracking-engineer-option:has(.tracking-engineer-time) .tracking-engineer-time {
    grid-column: 2;
    grid-row: 2;
    margin-left: 0;
}
.tracking-emergency-overlay {
    position: fixed;
    inset: 0;
    z-index: 70;
}
.tracking-emergency-backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(10, 24, 45, 0.45);
}
.tracking-emergency-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(420px, calc(100vw - 32px));
    background: #fff;
    border: 1px solid #f2b8bf;
    border-radius: 22px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.28);
    padding: 18px;
    display: grid;
    gap: 14px;
}
.tracking-emergency-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}
.tracking-emergency-head h3 {
    margin: 0;
    color: #9f1239;
}
.tracking-emergency-head p {
    margin: 4px 0 0;
    color: var(--text-secondary);
}
.tracking-emergency-card {
    border: 1px solid #f2b8bf;
    border-radius: 16px;
    background: #fff4f5;
    padding: 14px;
    display: grid;
    gap: 12px;
}
.tracking-emergency-card strong {
    display: block;
    color: #9f1239;
    margin-bottom: 4px;
}
.tracking-emergency-card small {
    color: var(--brand-navy);
    font-size: 0.875rem;
}
.tracking-emergency-call {
    color: var(--brand-navy);
    font-weight: 500;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.875rem;
    line-height: 1.4;
}
.tracking-emergency-call-icon {
    width: 24px;
    height: 24px;
    background: #16a34a;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}
.tracking-emergency-call-icon svg {
    width: 14px;
    height: 14px;
    stroke: #ffffff;
}
.tracking-emergency-call:hover,
.tracking-emergency-call:focus-visible {
    text-decoration: none;
}
.settings-user-grid {
    display: grid;
    gap: 16px;
}
.settings-user-editor-layout {
    display: grid;
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}
.settings-user-list-card,
.settings-user-preview-card {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    padding: 16px;
    display: grid;
    gap: 14px;
}
.settings-user-empty-card {
    border: 1px dashed #c7d6e6;
    border-radius: 18px;
    background: #f8fbff;
    min-height: 240px;
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 8px;
    text-align: center;
    color: var(--text-secondary);
    padding: 24px;
}
.settings-user-empty-card strong {
    color: var(--brand-navy);
    font-size: 1.05rem;
}
.settings-user-empty-card p {
    margin: 0;
}
.settings-user-list-head {
    display: grid;
    gap: 4px;
}
.settings-user-list-head small,
.settings-user-inline-meta small {
    color: var(--text-secondary);
}
.settings-user-list {
    display: grid;
    gap: 10px;
}
.settings-user-new-btn {
    margin-top: 6px;
    width: 100%;
}
.settings-user-list-item {
    width: 100%;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    text-align: left;
    color: var(--brand-navy);
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}
.settings-user-list-item small,
.settings-user-list-item span {
    color: var(--text-secondary);
}
.settings-user-list-item.is-active,
.settings-user-list-item:hover,
.settings-user-list-item:focus-visible {
    border-color: #8fb3d9;
    background: #eef6ff;
    box-shadow: 0 10px 24px rgba(20, 55, 99, 0.08);
}
.settings-user-list-select {
    flex: 1 1 auto;
    min-width: 0;
    padding: 14px 16px;
    border: 0;
    background: transparent;
    color: inherit;
    text-align: left;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 12px;
}
.settings-user-list-copy {
    display: grid;
    gap: 2px;
    min-width: 0;
}
.settings-user-list-select .engineer-badge {
    flex: 0 0 auto;
}
.settings-user-list-select .engineer-badge-avatar {
    width: 42px;
    height: 42px;
    font-size: 1rem;
}
.settings-user-list-copy strong,
.settings-user-list-copy small {
    white-space: normal;
}
.settings-user-list-actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding-right: 14px;
}
.settings-user-active-toggle {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--brand-navy);
    font-weight: 700;
    white-space: nowrap;
}
.settings-user-active-toggle > span:first-child {
    color: var(--brand-navy);
}
.settings-switch {
    position: relative;
    display: inline-flex;
    width: 42px;
    height: 24px;
    flex: 0 0 auto;
}
.settings-switch input {
    position: absolute;
    inset: 0;
    opacity: 0;
    margin: 0;
    cursor: pointer;
}
.settings-switch-slider {
    position: absolute;
    inset: 0;
    border-radius: 999px;
    background: #d7e3ef;
    border: 1px solid #c4d4e4;
    transition: background 0.18s ease, border-color 0.18s ease;
}
.settings-switch-slider::after {
    content: "";
    position: absolute;
    top: 2px;
    left: 2px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.18);
    transition: transform 0.18s ease;
}
.settings-switch input:checked + .settings-switch-slider {
    background: #1d4ed8;
    border-color: #1d4ed8;
}
.settings-switch input:checked + .settings-switch-slider::after {
    transform: translateX(18px);
}
.settings-switch input:disabled {
    cursor: not-allowed;
}
.settings-switch input:disabled + .settings-switch-slider {
    background: #e5edf5;
    border-color: #cbd8e6;
    opacity: 0.62;
}
.settings-switch input:disabled + .settings-switch-slider::after {
    background: #f8fafc;
}
.settings-switch input:checked:disabled + .settings-switch-slider {
    background: #9bb7e5;
    border-color: #9bb7e5;
}
.settings-user-delete-btn {
    width: 34px;
    height: 34px;
    padding: 0;
    border-radius: 999px;
    border: 1px solid #f1c5c5;
    background: #fff5f5;
    color: #b42318;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.settings-user-delete-btn i {
    width: 16px;
    height: 16px;
}
.settings-user-editor-stack {
    display: grid;
    gap: 16px;
}
.settings-user-card {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    padding: 16px;
    display: grid;
    gap: 12px;
}
.settings-user-inline-meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 12px;
}
.settings-user-header-row {
    align-items: flex-start;
}
.settings-user-header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.settings-user-section-head {
    display: grid;
    gap: 4px;
    margin-top: 4px;
}
.settings-user-section-head h3 {
    margin: 0;
    font-size: 1rem;
}
.settings-user-address-shell,
.settings-user-notification-card,
.settings-user-licence-card {
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #fff;
    padding: 14px;
    display: grid;
    gap: 12px;
}
.settings-user-emergency-card {
    border: 1px solid #f2b8bf;
    border-radius: 16px;
    background: #fff4f5;
    padding: 14px;
    display: grid;
    gap: 12px;
}
.settings-user-emergency-head {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #9f1239;
}
.settings-user-emergency-head i {
    width: 16px;
    height: 16px;
}
.settings-user-emergency-card .excel-field span {
    color: var(--brand-navy);
}
.settings-user-address-search-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: end;
}
.settings-address-search-field > span {
    font-weight: 800;
    color: var(--brand-navy);
}
.settings-user-address-results {
    display: grid;
    gap: 10px;
}
.settings-user-field-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.settings-user-policy-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
    align-items: start;
}
.settings-user-field-full {
    grid-column: 1 / -1;
}
.settings-password-reset-stack {
    display: grid;
    gap: 10px;
}
.settings-password-reset-btn {
    width: 100%;
}
.settings-user-save-stack {
    display: grid;
    gap: 6px;
    justify-items: end;
}
.settings-personal-email-top-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: end;
}
.settings-personal-email-top-row > .excel-field {
    min-width: 0;
}
.settings-personal-email-save-stack {
    align-self: end;
    min-width: 140px;
}
.settings-personal-card {
    display: grid;
    grid-template-rows: auto;
    align-items: stretch;
    align-content: start;
    gap: 18px;
    grid-column: 1 / -1;
    height: auto;
    min-width: 0;
    min-height: 0;
    overflow: visible;
}
.settings-personal-card-compact {
    grid-column: 1 / span 1;
    grid-template-rows: auto;
    height: auto;
    min-height: auto;
    overflow: visible;
    align-self: start;
}
.settings-personal-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.settings-personal-user-row {
    display: flex;
    align-items: center;
    gap: 14px;
}
.settings-personal-user-copy {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.settings-personal-user-copy strong {
    font-size: 1rem;
    color: #173a63;
}
.settings-personal-user-copy small {
    color: var(--text-muted);
}
.settings-personal-connector-grid {
    display: grid;
    grid-template-rows: auto auto;
    gap: 16px;
    align-items: stretch;
    align-content: start;
    height: auto;
    min-width: 0;
    min-height: 0;
    overflow: visible;
}
.settings-signature-editor {
    display: grid;
    grid-template-rows: auto auto;
    gap: 12px;
    align-items: stretch;
    height: auto;
    min-width: 0;
    min-height: auto;
    overflow: visible;
}
.settings-signature-editor.is-readonly .settings-signature-canvas {
    background: #f7fafc;
    color: #31577f;
    cursor: default;
}
.settings-signature-editor.is-readonly .settings-signature-toolbar-fieldset {
    display: none;
}
.settings-personal-card .cell-input:disabled {
    background: #f7fafc;
    border-color: #e0e9f2;
    color: #31577f;
}
.settings-signature-toolbar-fieldset {
    margin: 0;
    padding: 0;
    border: 0;
    min-width: 0;
}
.settings-signature-toolbar-fieldset:disabled .settings-signature-ribbon {
    background: #f7fafc;
}
.settings-signature-toolbar-fieldset:disabled .settings-signature-toolbar {
    background: #f7fafc;
}
.settings-signature-ribbon {
    position: relative;
    border-radius: 18px;
    background: #ffffff;
    overflow: visible;
    min-width: 0;
    isolation: isolate;
    z-index: 5;
}
.settings-signature-ribbon::before {
    content: "";
    position: absolute;
    inset: 0;
    border: 1px solid #dce8f4;
    border-radius: inherit;
    pointer-events: none;
    z-index: 0;
}
.settings-signature-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: stretch;
    padding: 14px;
    background: #ffffff;
    min-width: 0;
    overflow: visible;
}
body[data-page="personal-settings"] .settings-signature-toolbar {
    align-items: flex-start;
    gap: 14px;
}
body[data-page="personal-settings"] .settings-signature-editor {
    display: block;
    height: auto;
}
body[data-page="personal-settings"] .settings-signature-group {
    align-content: start;
}
.settings-signature-toolbar-select {
    min-width: 176px;
    width: 176px;
    max-width: 100%;
}
.settings-signature-font-row {
    display: inline-grid;
    grid-template-columns: 176px 110px auto;
    align-items: center;
    gap: 8px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}
.settings-signature-font-block {
    display: grid;
    gap: 8px;
    min-width: 0;
}
.settings-signature-font-style-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-width: 0;
}
.settings-signature-font-style-row-inline {
    flex-wrap: nowrap;
    align-items: center;
}
.settings-signature-size-control {
    display: inline-grid;
    grid-template-columns: 110px;
    align-items: center;
    gap: 0;
}
.settings-signature-size-input {
    width: 110px;
    max-width: 110px;
    text-align: center;
    min-height: 44px;
    box-sizing: border-box;
}
.settings-signature-size-input::-webkit-outer-spin-button,
.settings-signature-size-input::-webkit-inner-spin-button {
    opacity: 1;
}
.settings-signature-align-row {
    display: flex;
    gap: 8px;
    align-items: center;
}
.settings-signature-paragraph-row,
.settings-signature-insert-row {
    flex-wrap: nowrap;
}
.settings-signature-group {
    display: grid;
    gap: 8px;
    padding: 0 14px 0 0;
    border-right: 1px solid #e3ebf4;
    min-width: 0;
}
.settings-signature-group:last-child {
    border-right: 0;
    padding-right: 0;
}
.settings-signature-group-tools {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    min-width: 0;
}
.settings-signature-group-label {
    color: #69819c;
    font-size: 0.74rem;
    font-weight: 800;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.settings-signature-tool-btn {
    min-width: 48px;
    min-height: 44px;
    padding: 10px 14px;
}
.settings-signature-tool-btn.is-active {
    border-color: #3b82f6;
    background: #eef5ff;
    color: #173a63;
}
.settings-signature-tool-btn:disabled {
    opacity: 0.45;
    background: #f3f6fa;
    color: #8ca0b6;
    border-color: #d7e1eb;
    cursor: not-allowed;
}
.settings-signature-tool-btn-wide {
    min-width: 84px;
}
.settings-signature-colour-picker {
    position: relative;
}
.settings-signature-colour-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    position: relative;
    width: 54px;
    min-height: 44px;
    padding: 0 7px 8px;
    border: 1px solid #dce8f4;
    border-radius: 14px;
    background: #ffffff;
    color: #173a63;
    font-size: 0.92rem;
    font-weight: 700;
    cursor: pointer;
}
.settings-signature-last-used-colour-line {
    position: absolute;
    left: 10px;
    right: 10px;
    bottom: 5px;
    height: 3px;
    border-radius: 999px;
    background: var(--last-used-colour, #173a63);
    box-shadow: inset 0 0 0 1px rgba(23, 58, 99, 0.08);
    pointer-events: none;
}
.settings-signature-last-used-colour-line.is-clear {
    background:
        repeating-linear-gradient(
            135deg,
            #ffffff 0 6px,
            #e2e8f0 6px 12px
        );
    box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.7);
}
.settings-signature-colour-panel {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    z-index: 20;
    width: 320px;
    max-width: min(420px, calc(100vw - 32px));
    padding: 12px;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 20px 35px rgba(15, 23, 42, 0.14);
    display: grid;
    gap: 12px;
}
.settings-signature-colour-panel[hidden] {
    display: none !important;
}
.settings-signature-colour-section {
    display: grid;
    gap: 8px;
}
.settings-signature-colour-section strong {
    color: #69819c;
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.settings-signature-colour-palette-frame[hidden],
.settings-signature-custom-colour-editor[hidden] {
    display: none !important;
}
.settings-signature-swatch-grid,
.settings-signature-swatch-row {
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 6px;
}
.settings-signature-swatch {
    width: 24px;
    height: 24px;
    border: 1px solid #d0dbe7;
    border-radius: 4px;
    background: var(--swatch);
    cursor: pointer;
}
.settings-signature-swatch-clear {
    position: relative;
    background:
        linear-gradient(45deg, #f8fafc 25%, #e2e8f0 25%, #e2e8f0 50%, #f8fafc 50%, #f8fafc 75%, #e2e8f0 75%);
    background-size: 10px 10px;
}
.settings-signature-swatch-clear::after {
    content: "";
    position: absolute;
    inset: 3px;
    border-top: 2px solid #dc2626;
    transform: rotate(-45deg);
}
.settings-signature-more-colours {
    border: 0;
    background: transparent;
    color: #2563eb;
    font-size: 0.92rem;
    font-weight: 700;
    text-align: left;
    cursor: pointer;
}
.settings-signature-custom-colour-editor {
    display: grid;
    gap: 12px;
}
.settings-signature-custom-colour-head {
    display: flex;
    align-items: center;
    gap: 10px;
}
.settings-signature-custom-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: 1px solid #d0dbe7;
    border-radius: 50%;
    background: #ffffff;
    color: #173a63;
    cursor: pointer;
    flex: 0 0 auto;
}
.settings-signature-custom-action:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.settings-signature-native-colour-input {
    position: absolute;
    left: -9999px;
    width: 16px;
    height: 16px;
    opacity: 0;
}
.settings-signature-native-picker-fallback {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border: 1px solid #dce8f4;
    border-radius: 12px;
    background: #f8fbff;
}
.settings-signature-native-picker-fallback span {
    color: #69819c;
    font-size: 0.82rem;
    font-weight: 700;
}
.settings-signature-native-picker-fallback input[type="color"] {
    width: 42px;
    height: 32px;
    padding: 0;
    border: 1px solid #d0dbe7;
    border-radius: 8px;
    background: #ffffff;
    cursor: pointer;
}
.settings-signature-custom-colour-preview {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 1px solid #d0dbe7;
    background: var(--swatch, #173a63);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.45);
    flex: 0 0 auto;
}
.settings-signature-custom-colour-code {
    color: #173a63;
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}
.settings-signature-custom-surface {
    position: relative;
    width: 100%;
    min-height: 170px;
    border: 1px solid #dce8f4;
    border-radius: 12px;
    cursor: crosshair;
    overflow: hidden;
    touch-action: none;
    background:
        linear-gradient(to top, #000000 0%, rgba(0, 0, 0, 0) 100%),
        linear-gradient(to right, #ffffff 0%, var(--picker-hue, #2563eb) 100%);
}
.settings-signature-custom-surface-handle {
    position: absolute;
    left: var(--picker-x, 50%);
    top: var(--picker-y, 50%);
    width: 14px;
    height: 14px;
    border: 2px solid #ffffff;
    border-radius: 50%;
    box-shadow: 0 0 0 2px rgba(23, 58, 99, 0.7);
    transform: translate(-50%, -50%);
    pointer-events: none;
}
.settings-signature-custom-hue {
    width: 100%;
    height: 12px;
    margin: 0;
    border: 1px solid #dce8f4;
    border-radius: 999px;
    appearance: none;
    -webkit-appearance: none;
    background: linear-gradient(90deg, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0040 100%);
    cursor: pointer;
}
.settings-signature-custom-hue::-webkit-slider-runnable-track {
    height: 12px;
    border-radius: 999px;
    background: transparent;
}
.settings-signature-custom-hue::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    margin-top: -3px;
    border: 2px solid #ffffff;
    border-radius: 50%;
    background: #2563eb;
    box-shadow: 0 0 0 2px rgba(23, 58, 99, 0.2);
}
.settings-signature-custom-hue::-moz-range-track {
    height: 12px;
    border-radius: 999px;
    background: transparent;
}
.settings-signature-custom-hue::-moz-range-thumb {
    width: 16px;
    height: 16px;
    border: 2px solid #ffffff;
    border-radius: 50%;
    background: #2563eb;
    box-shadow: 0 0 0 2px rgba(23, 58, 99, 0.2);
}
.settings-signature-custom-colour-rgb {
    display: grid;
    grid-template-columns: repeat(3, minmax(72px, 1fr));
    gap: 10px;
    align-items: start;
}
.settings-signature-custom-colour-rgb label {
    display: grid;
    gap: 6px;
    min-width: 0;
}
.settings-signature-custom-colour-rgb span {
    color: #69819c;
    font-size: 0.8rem;
    font-weight: 700;
    text-align: center;
}
.settings-signature-custom-colour-rgb .cell-input {
    text-align: center;
}
.settings-signature-canvas {
    display: flow-root;
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 100%;
    min-height: 220px;
    height: auto !important;
    max-height: 430px !important;
    padding: 18px;
    border: 1px solid #cfe0ef;
    border-radius: 18px;
    background: #ffffff;
    color: #173a63;
    line-height: 1.5;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    min-width: 0;
    white-space: normal !important;
    overflow-wrap: anywhere;
    word-break: normal;
    box-sizing: border-box;
    contain: none;
}
body[data-page="personal-settings"] .settings-signature-canvas {
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    height: auto !important;
    max-height: min(430px, calc(100vh - 390px)) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .page-content {
    height: 100%;
    max-height: 100%;
    overflow: hidden !important;
    box-sizing: border-box;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .page-header,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-back-link {
    flex: 0 0 auto;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] #personal-settings-shell,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .personal-settings-shell,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-grid,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-card,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-connector-grid,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-signature-editor {
    max-height: 100%;
    min-height: 0;
    overflow: hidden !important;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-grid {
    flex: 1 1 auto;
    display: flex;
    padding-right: 0;
    padding-bottom: 0;
    scroll-padding-bottom: 0;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-card {
    flex: 1 1 auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-self: stretch;
    box-sizing: border-box;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-connector-grid {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-signature-editor {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-signature-canvas {
    flex: 1 1 auto;
    height: auto !important;
    min-height: 0;
    max-height: none !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
}
.settings-signature-canvas *,
.settings-signature-canvas *::before,
.settings-signature-canvas *::after {
    max-width: 100%;
    box-sizing: border-box;
    overflow-wrap: anywhere;
}
.settings-signature-canvas::after {
    content: "";
    display: block;
    clear: both;
}
.settings-signature-canvas.is-table-col-resize,
.settings-signature-canvas.is-table-col-resize * {
    cursor: col-resize !important;
}
.settings-signature-canvas.is-table-row-resize,
.settings-signature-canvas.is-table-row-resize * {
    cursor: row-resize !important;
}
.settings-signature-canvas table {
    width: auto !important;
    max-width: 100% !important;
    table-layout: fixed;
    border-collapse: collapse;
    position: relative;
}
.settings-signature-canvas td,
.settings-signature-canvas th {
    word-break: break-word;
    position: relative;
}
.settings-signature-canvas table.is-selected {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}
.settings-signature-canvas table.is-selected::before {
    content: "";
    position: absolute;
    top: -8px;
    left: -8px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background:
      radial-gradient(circle at 50% 35%, #ffffff 0 2px, transparent 2px),
      linear-gradient(#3b82f6, #3b82f6);
    box-shadow: 0 0 0 2px #ffffff, 0 0 0 3px #3b82f6;
    cursor: grab;
}
.settings-signature-selection-preview-layer {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
}
.settings-signature-selection-preview-rect {
    position: absolute;
    background: #3b73d9;
    border-radius: 0;
    box-shadow: inset 0 0 0 1px rgba(59, 115, 217, 0.96);
}
.settings-signature-selection-preview-text {
    position: absolute;
    z-index: 2;
    color: #ffffff;
    -webkit-text-fill-color: #ffffff;
    pointer-events: none;
    white-space: normal;
    word-break: break-word;
}
.settings-signature-selection-preview-text,
.settings-signature-selection-preview-text * {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-shadow: none !important;
    background: transparent !important;
    border-color: transparent !important;
    fill: currentColor;
}
.settings-signature-table-overlay.hidden {
    display: none;
}
.settings-signature-table-overlay {
    position: fixed;
    inset: 0;
    z-index: 260;
}
.settings-signature-table-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.34);
}
.settings-signature-table-modal {
    position: relative;
    width: min(360px, calc(100vw - 32px));
    margin: 120px auto 0;
    padding: 18px;
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 24px 46px rgba(15, 23, 42, 0.16);
    display: grid;
    gap: 16px;
}
.settings-signature-table-head h3 {
    margin: 0;
    color: #173a63;
    font-size: 1.1rem;
}
.settings-signature-table-grid {
    display: grid;
    gap: 14px;
}
.settings-signature-table-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

@media (max-width: 1180px) {
    .settings-signature-toolbar {
        display: grid;
        grid-template-columns: 1fr;
    }
    .settings-signature-group {
        padding-right: 0;
        border-right: 0;
        border-bottom: 1px solid #e3ebf4;
        padding-bottom: 14px;
    }
    .settings-signature-group:last-child {
        border-bottom: 0;
        padding-bottom: 0;
    }
    .settings-signature-font-row {
        grid-template-columns: minmax(0, 1fr) 110px;
        width: 100%;
    }
    .settings-signature-font-style-row-inline {
        flex-wrap: wrap;
    }
    .settings-signature-paragraph-row,
    .settings-signature-insert-row {
        flex-wrap: wrap;
    }
}

@media (max-height: 900px), (max-width: 1200px) {
    body[data-page="personal-settings"] .page-content {
        overflow-x: hidden;
        overflow-y: auto;
    }
    body[data-page="personal-settings"] #personal-settings-shell {
        overflow: visible;
    }
    body[data-page="personal-settings"] .settings-grid {
        flex: 1;
        min-height: 0;
        overflow: visible;
    }
    .personal-settings-shell {
        flex: 1;
        min-height: 0;
        overflow: visible;
    }
    .settings-personal-card {
        height: auto;
        min-height: auto;
        overflow: visible;
    }
    .settings-personal-connector-grid,
    .settings-signature-editor {
        height: auto;
        min-height: auto;
        overflow: visible;
    }
    .settings-signature-canvas {
        min-height: 360px;
        height: auto;
    }
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .page-content {
    overflow: hidden;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] #personal-settings-shell,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .personal-settings-shell,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-grid,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-card,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-connector-grid,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-signature-editor {
    max-height: 100%;
    min-height: 0;
    overflow: hidden !important;
}
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-signature-canvas {
    min-height: 0;
    height: auto !important;
    max-height: none !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] .page-content {
    height: 100%;
    max-height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden !important;
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] #personal-settings-shell,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .personal-settings-shell,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-grid,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-card,
body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-connector-grid {
    flex: 1 1 auto;
    min-height: 0;
    max-height: 100%;
    overflow: hidden !important;
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-grid {
    display: flex;
    padding-bottom: 0 !important;
    scroll-padding-bottom: 0 !important;
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-card {
    display: flex;
    flex-direction: column;
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-connector-grid {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-personal-connector-grid > .excel-field {
    min-height: 0;
    display: flex;
    flex-direction: column;
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-signature-editor {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden !important;
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-signature-toolbar-fieldset {
    flex: 0 0 auto;
}

body[data-page="personal-settings"][data-personal-settings-panel="email"] .settings-signature-canvas {
    flex: 1 1 auto;
    min-height: 0 !important;
    max-height: none !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: contain;
}
.settings-signature-canvas:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
}
.settings-signature-canvas:empty::before {
    content: attr(data-placeholder);
    color: #8ea7c0;
}
.settings-signature-canvas img {
    max-width: 100%;
    height: auto;
}
.settings-signature-table-marker {
    display: inline-block;
    width: 0;
    height: 0;
    overflow: hidden;
    line-height: 0;
    vertical-align: top;
}
.settings-signature-link-marker {
    display: inline-block;
    width: 0;
    height: 0;
    overflow: hidden;
    line-height: 0;
    vertical-align: top;
}
.settings-signature-canvas > div,
.settings-signature-canvas > p,
.settings-signature-canvas > blockquote,
.settings-signature-canvas > ul,
.settings-signature-canvas > ol {
    display: block;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    float: none !important;
    overflow: visible !important;
    white-space: normal !important;
}
.settings-signature-canvas > div,
.settings-signature-canvas > p,
.settings-signature-canvas > blockquote {
    margin: 0 0 0.35em;
}
.settings-signature-canvas > *:last-child {
    margin-bottom: 0;
}
.settings-signature-image-wrap {
    position: relative;
    display: inline-flex;
    width: fit-content;
    height: fit-content;
    margin: 6px 0;
    vertical-align: top;
    line-height: 0;
    overflow: visible;
}
.settings-signature-image-wrap img {
    display: block;
    width: auto;
    max-width: 100%;
    height: auto;
    border-radius: 6px;
}
.settings-signature-image-wrap.is-selected {
    outline: 2px solid #3b82f6;
    outline-offset: 0;
    border-radius: 6px;
}
.settings-signature-image-handle {
    position: absolute;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid #ffffff;
    background: #3b82f6;
    box-shadow: 0 2px 6px rgba(15, 23, 42, 0.18);
    cursor: nwse-resize;
    opacity: 0;
    pointer-events: none;
}
.settings-signature-image-handle.handle-nw {
    left: 0;
    top: 0;
    transform: translate(-50%, -50%);
    cursor: nwse-resize;
}
.settings-signature-image-handle.handle-ne {
    right: 0;
    top: 0;
    transform: translate(50%, -50%);
    cursor: nesw-resize;
}
.settings-signature-image-handle.handle-sw {
    left: 0;
    bottom: 0;
    transform: translate(-50%, 50%);
    cursor: nesw-resize;
}
.settings-signature-image-handle.handle-se {
    right: 0;
    bottom: 0;
    transform: translate(50%, 50%);
    cursor: nwse-resize;
}
.settings-signature-image-rotate {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -150%);
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid #ffffff;
    background: #16a34a;
    box-shadow: 0 2px 6px rgba(15, 23, 42, 0.18);
    cursor: grab;
    opacity: 0;
    pointer-events: none;
}
.settings-signature-image-rotate::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 18px;
    width: 2px;
    height: 12px;
    background: #16a34a;
    transform: translateX(-50%);
}
.settings-signature-image-wrap.is-selected .settings-signature-image-handle,
.settings-signature-image-wrap.is-selected .settings-signature-image-rotate {
    opacity: 1;
    pointer-events: auto;
}
.settings-signature-canvas a {
    color: inherit;
    text-decoration-color: currentColor;
}
.settings-personal-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.settings-personal-summary-grid .summary-bar {
    min-height: 88px;
}
.settings-personal-provider-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.settings-personal-api-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.settings-email-config-grid {
    margin-bottom: 14px;
}
.settings-user-save-note {
    max-width: 280px;
    color: #9a3412;
    text-align: right;
    line-height: 1.35;
}
.settings-phone-input {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: stretch;
    border: 1px solid #ccd8e4;
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
}
.settings-phone-input:focus-within {
    border-color: #ccd8e4;
}
.settings-phone-input.is-readonly {
    border-color: #e0e9f2;
    background: #f7fafc;
}
.settings-phone-prefix {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 12px;
    border-right: 1px solid #dbe5ef;
    color: var(--brand-navy);
    background: #f7fafc;
    font-weight: 700;
    white-space: nowrap;
}
.settings-phone-flag {
    width: 18px;
    height: 12px;
    border-radius: 2px;
    border: 1px solid rgba(15, 23, 42, 0.12);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
    background-color: #012169;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 30'%3E%3CclipPath id='t'%3E%3Cpath d='M0,0 v30 h60 v-30 z'/%3E%3C/clipPath%3E%3Cpath d='M0,0 v30 h60 v-30 z' fill='%23012169'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23fff' stroke-width='6' clip-path='url(%23t)'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23C8102E' stroke-width='4' clip-path='url(%23t)'/%3E%3Cpath d='M30,0 v30 M0,15 h60' stroke='%23fff' stroke-width='10'/%3E%3Cpath d='M30,0 v30 M0,15 h60' stroke='%23C8102E' stroke-width='6'/%3E%3C/svg%3E");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    flex: 0 0 auto;
}
.settings-phone-number-input.cell-input {
    border: 0;
    border-radius: 0;
    padding-left: 12px;
}
.settings-phone-number-input.cell-input:focus {
    box-shadow: none;
}
.settings-required-star {
    margin-left: 2px;
    color: var(--brand-navy);
    font-weight: 800;
}
.settings-field-error,
.settings-user-avatar-error {
    color: #c81e1e;
    font-size: 0.78rem;
    font-weight: 700;
}
.settings-user-avatar-error {
    margin-top: 8px;
}
.settings-user-card .excel-field.is-invalid > .cell-input,
.settings-user-card .excel-field.is-invalid > .cell-select,
.settings-user-card .excel-field.is-invalid > .cell-textarea,
.settings-user-card .cell-input.is-invalid,
.settings-user-card .cell-select.is-invalid,
.settings-user-card .cell-textarea.is-invalid,
.settings-user-card .settings-phone-input.is-invalid,
.settings-user-card .settings-user-avatar-panel .cell-select.is-invalid {
    border-color: #ef4444 !important;
}
.settings-user-card .settings-phone-input.is-invalid .settings-phone-prefix {
    border-right-color: #ef4444;
}
.settings-user-avatar-action-btn.is-invalid {
    border-color: #ef4444;
    background: #fff5f5;
    color: #b42318;
}
.settings-user-card .cell-input[readonly],
.settings-user-card .cell-textarea[readonly],
.settings-user-card .cell-select:disabled {
    border-color: #e0e9f2;
    background: #f7fafc;
    color: #31577f;
    cursor: default;
}
.settings-user-card .cell-input[readonly]::placeholder,
.settings-user-card .cell-textarea[readonly]::placeholder {
    color: #7f96af;
}
.settings-user-card .cell-input[readonly]:focus,
.settings-user-card .cell-textarea[readonly]:focus,
.settings-user-card .cell-select:disabled:focus {
    border-color: #e0e9f2;
    box-shadow: none;
}
.settings-user-card .cell-select:disabled {
    appearance: none;
    -webkit-appearance: none;
    background-image:
        linear-gradient(45deg, transparent 50%, #8ca3ba 50%),
        linear-gradient(135deg, #8ca3ba 50%, transparent 50%);
    background-position:
        calc(100% - 18px) calc(50% - 2px),
        calc(100% - 12px) calc(50% - 2px);
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
    padding-right: 34px;
}
.settings-user-card button.btn:disabled,
.settings-user-card .btn.secondary:disabled {
    border-color: #e0e9f2;
    background: #f7fafc;
    color: #7f96af;
    cursor: default;
    opacity: 1;
    box-shadow: none;
}
.settings-user-card .settings-phone-input.is-readonly .settings-phone-prefix {
    border-right-color: #e0e9f2;
    background: #f7fafc;
    color: #31577f;
}
.settings-user-card .settings-phone-input.is-readonly .settings-phone-number-input.cell-input {
    background: transparent;
    color: #31577f;
}
.settings-user-field-grid-tight {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.settings-user-meta-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(260px, 340px);
    gap: 14px;
    align-items: start;
}
.settings-user-face-card {
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #fff;
    padding: 14px;
    display: grid;
    gap: 12px;
}
.settings-user-face-preview {
    min-height: 180px;
    border-radius: 14px;
    border: 1px dashed #c8d9ea;
    background: linear-gradient(180deg, #fbfdff, #f2f7fd);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.settings-user-avatar-card {
    display: grid;
    gap: 12px;
}
.settings-user-avatar-hero {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #fff;
    padding: 16px 18px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 18px;
}
.settings-user-avatar-stage {
    position: relative;
    width: 96px;
    min-height: 96px;
}
.settings-user-avatar-stage-label {
    margin-bottom: 8px;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--brand-navy);
}
.settings-user-avatar-inline-error {
    display: block;
    margin-top: 8px;
}
.settings-user-avatar-preview {
    width: 96px;
    height: 96px;
    border-radius: 999px;
    background: var(--engineer-color, #3b82f6);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: 800;
    box-shadow: inset 0 0 0 4px rgba(255,255,255,0.18);
    overflow: hidden;
}
.settings-user-avatar-preview.has-face {
    background: #fff;
    border: 4px solid var(--engineer-color, #3b82f6);
    box-sizing: border-box;
    box-shadow: none;
}
.settings-user-avatar-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 999px;
}
.settings-user-avatar-edit-btn {
    position: absolute;
    right: -2px;
    bottom: -2px;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid #cfdceb;
    background: #f3efe8;
    color: #4a5565;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}
.settings-user-avatar-edit-btn:hover,
.settings-user-avatar-edit-btn:focus-visible {
    background: #ece6dc;
}
.settings-user-avatar-copy {
    display: grid;
    gap: 4px;
}
.settings-user-avatar-copy strong {
    font-size: 1.2rem;
}
.settings-user-avatar-contact {
    display: grid;
    gap: 10px;
    justify-items: end;
    text-align: right;
}
.settings-user-header-action-row {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.settings-user-delete-header-btn {
    border-color: #f1c5c5;
    background: #fff5f5;
    color: #b42318;
}
.settings-user-avatar-status {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 14px;
}
.settings-user-avatar-copy small,
.settings-user-avatar-current-label {
    color: var(--text-secondary);
}
.settings-user-delete-overlay {
    position: fixed;
    inset: 0;
    z-index: 3600;
}
.settings-user-delete-backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(10, 24, 45, 0.34);
    backdrop-filter: blur(3px);
}
.settings-user-delete-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(420px, calc(100vw - 32px));
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 24px 50px rgba(15, 23, 42, 0.24);
    padding: 28px 24px 22px;
    display: grid;
    gap: 16px;
    text-align: center;
}
.settings-user-delete-icon {
    width: 52px;
    height: 52px;
    margin: 0 auto;
    border-radius: 999px;
    background: #fff5f5;
    color: #b42318;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.settings-user-delete-icon i {
    width: 24px;
    height: 24px;
}
.settings-user-delete-modal h3 {
    margin: 0;
    font-size: 1.4rem;
    color: #123b74;
}
.settings-user-delete-modal p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.5;
}
.settings-user-delete-actions {
    display: flex;
    justify-content: center;
    gap: 12px;
}
.btn.danger {
    border-color: #b42318;
    background: #b42318;
    color: #fff;
}
.settings-user-avatar-panel {
    display: grid;
    gap: 14px;
    padding-top: 6px;
    border-top: 1px solid #e4edf6;
}
.settings-user-avatar-actions {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
    align-items: stretch;
}
.settings-user-avatar-action {
    min-height: 52px;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #fff;
}
.settings-user-avatar-text-action {
    padding: 10px 12px;
    display: grid;
    gap: 8px;
}
.settings-user-avatar-text-action span {
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-secondary);
}
.settings-user-avatar-text-action .cell-input {
    min-height: 34px;
}
.settings-user-avatar-colour-action {
    padding: 10px 12px;
    display: grid;
    gap: 8px;
}
.settings-user-avatar-colour-action span {
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-secondary);
}
.settings-user-avatar-colour-action input[type="color"] {
    width: 100%;
    min-height: 34px;
    border: 0;
    padding: 0;
    background: transparent;
    cursor: pointer;
}
.settings-user-avatar-action-btn {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-align: center;
}
.settings-user-avatar-action-btn i {
    width: 16px;
    height: 16px;
}
.settings-user-avatar-checkbox {
    padding: 0 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-weight: 700;
    color: var(--brand-navy);
    width: 100%;
}
.settings-user-avatar-checkbox input {
    width: 18px;
    height: 18px;
}
.settings-avatar-crop-overlay {
    position: fixed;
    inset: 0;
    z-index: 70;
}
.settings-avatar-crop-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 24, 45, 0.45);
}
.settings-avatar-crop-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(560px, calc(100vw - 40px));
    background: #fff;
    border: 1px solid #d7e1eb;
    border-radius: 22px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.28);
    padding: 18px;
    display: grid;
    gap: 16px;
}
.settings-avatar-crop-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}
.settings-avatar-crop-head h3 {
    margin: 0;
}
.settings-avatar-crop-head p {
    margin: 4px 0 0;
    color: var(--text-secondary);
}
.settings-avatar-crop-body {
    display: grid;
    gap: 8px;
}
.settings-avatar-crop-stage {
    display: flex;
    justify-content: center;
}
.settings-avatar-crop-frame {
    --frame-size: min(280px, 70vw);
    width: var(--frame-size);
    height: var(--frame-size);
    padding: 10px;
    border-radius: 999px;
    background: #f4f8ff;
    box-shadow: inset 0 0 0 4px var(--engineer-color, #3b82f6);
}
.settings-avatar-crop-image-wrap {
    width: 100%;
    height: 100%;
    border-radius: 999px;
    overflow: hidden;
    cursor: grab;
    background: #eef4fb;
    touch-action: none;
}
.settings-avatar-crop-image-wrap:active {
    cursor: grabbing;
}
.settings-avatar-crop-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform-origin: center;
    user-select: none;
    -webkit-user-drag: none;
}
.settings-avatar-crop-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}
.settings-avatar-crop-actions .btn {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.settings-avatar-crop-actions .btn i {
    width: 16px;
    height: 16px;
}
.settings-user-avatar-panel-preview {
    display: flex;
    align-items: center;
    gap: 12px;
}
.settings-user-avatar-current-label {
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.settings-user-section-copy {
    display: grid;
    gap: 4px;
}
.settings-user-section-copy small {
    color: var(--text-secondary);
}
.settings-user-toggle-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.settings-user-toggle-grid-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.settings-toggle-card {
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #fff;
    padding: 14px;
    display: grid;
    gap: 8px;
}
.settings-toggle-card-inline {
    align-content: end;
}
.settings-toggle-card small {
    color: var(--text-secondary);
    line-height: 1.45;
}
.settings-customer-grid {
    display: grid;
    gap: 18px;
}
.settings-customer-list {
    display: grid;
    gap: 0;
    overflow-x: auto;
}
.settings-customer-list-head,
.settings-customer-list-row {
    display: grid;
    grid-template-columns: minmax(200px, 1fr) minmax(240px, 1.3fr) minmax(240px, 1.2fr);
    gap: 16px;
    align-items: center;
}
.settings-customer-list-head {
    grid-template-columns: minmax(200px, 1fr) minmax(240px, 1.3fr) minmax(240px, 1.2fr) 56px;
    min-width: 980px;
    padding: 14px 18px;
    background: #f4f7fb;
    color: var(--text-secondary);
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border: 1px solid #dce8f4;
    border-bottom: 0;
    border-radius: 18px 18px 0 0;
}
.settings-customer-list-item {
    border: 1px solid #dce8f4;
    border-radius: 0;
    background: #ffffff;
    overflow: hidden;
}
.settings-customer-list-item + .settings-customer-list-item {
    border-top: 0;
}
.settings-customer-list-item:nth-child(even) .settings-customer-list-row-shell {
    background: #f8fbff;
}
.settings-customer-list-item:last-child {
    border-radius: 0 0 18px 18px;
}
.settings-customer-list-row-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 56px;
    min-width: 980px;
    background: #fff;
    min-height: 76px;
}
.settings-customer-list-row {
    padding: 16px 18px;
    color: inherit;
    text-decoration: none;
}
.settings-customer-list-row:hover {
    background: #eef5fc;
}
.settings-customer-list-row.is-editing {
    background: #f8fbff;
    border-bottom: 1px solid #dce8f4;
}
.settings-customer-list-cell {
    min-width: 0;
}
.settings-customer-list-cell strong,
.settings-customer-list-cell span {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.settings-customer-list-actions {
    display: inline-flex;
    justify-content: flex-end;
}
.settings-customer-bin {
    width: 100%;
    height: 100%;
    border-radius: 0;
    color: #c0392b;
}
.settings-customer-bin:hover {
    background: #fdeceb;
    color: #c0392b;
}
.settings-customer-editor {
    display: grid;
    gap: 16px;
    padding: 18px;
    background: #f8fbff;
}
.settings-customer-editor-head-row {
    display: grid;
    grid-template-columns: minmax(320px, 620px) auto;
    gap: 12px;
    align-items: end;
}
.settings-customer-editor-top-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}
.settings-customer-action-btn {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    border: 1px solid #d5e2ef;
    background: #fff;
}
.settings-customer-action-btn:hover {
    background: #edf3fa;
}
.settings-customer-save-icon-btn {
    color: #0f766e;
}
.settings-customer-save-icon-btn:hover {
    background: #e7f8f4;
}
.settings-customer-delete-icon-btn {
    color: #c0392b;
}
.settings-customer-delete-icon-btn:hover {
    background: #fdeceb;
}
.settings-customer-detail-grid {
    display: grid;
    gap: 16px;
}
.settings-customer-summary-groups {
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(280px, 0.9fr) minmax(420px, 1.1fr);
    align-items: start;
}
.settings-supplier-summary-groups {
    grid-template-columns: minmax(0, 1fr);
}
.settings-supplier-summary-groups .settings-customer-summary-card {
    padding-top: 0;
}
.settings-customer-summary-card {
    padding: 14px 16px;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #f8fbff;
}
.settings-customer-summary-inline-grid {
    display: grid;
    gap: 12px;
}
.settings-customer-summary-inline-grid-jobref {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.settings-customer-summary-inline-grid-markup {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.settings-customer-summary-card .summary-bar {
    margin: 0;
}
.settings-supplier-tab-visibility-card {
    display: grid;
    grid-template-columns: minmax(150px, 180px) repeat(6, minmax(0, 1fr));
    column-gap: 10px;
    row-gap: 12px;
    align-items: start;
    width: 100%;
    min-width: 0;
    overflow: hidden;
}
.settings-supplier-tab-visibility-title {
    font-size: 0.95rem;
    color: var(--brand-navy);
    font-weight: 700;
    display: flex;
    align-items: flex-end;
    min-height: 56px;
    padding-bottom: 2px;
}
.settings-supplier-tab-visibility-item {
    display: grid;
    justify-items: center;
    grid-template-rows: 1fr auto;
    align-items: end;
    gap: 6px;
    text-align: center;
    color: var(--brand-navy);
    font-weight: 700;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    min-height: 56px;
    min-width: 0;
}
.settings-supplier-tab-visibility-item span {
    white-space: normal;
    line-height: 1.15;
    min-height: 0;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    width: 100%;
    overflow-wrap: anywhere;
}
.settings-supplier-tab-visibility-item input {
    max-width: 100%;
}
.settings-supplier-tab-visibility-item input {
    margin: 0;
}
.settings-supplier-tab-visibility-item.is-readonly {
    opacity: 0.8;
}
.settings-customer-card {
    display: grid;
    gap: 16px;
}
.settings-customer-head-actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.settings-customer-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.settings-customer-rule-groups {
    display: grid;
    gap: 12px;
    grid-template-columns: minmax(280px, 0.9fr) minmax(420px, 1.1fr);
    align-items: start;
}
.settings-customer-rule-card {
    padding: 14px 16px;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #f8fbff;
}
.settings-customer-rule-inline-grid {
    display: grid;
    gap: 12px;
    align-items: end;
}
.settings-customer-rule-inline-grid-jobref {
    grid-template-columns: minmax(220px, 0.9fr) minmax(0, 1.1fr);
}
.settings-customer-inline-field {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 10px;
}
.settings-customer-inline-field span {
    margin: 0;
    white-space: nowrap;
}
.settings-customer-inline-field.is-disabled {
    opacity: 0.48;
}
.settings-customer-inline-field.is-disabled .cell-input,
.settings-customer-inline-field.is-disabled .cell-select {
    background: #f3f6fa;
    border-color: #d9e3ef;
    color: #8aa0b8;
}
.settings-customer-rule-inline-grid-markup {
    grid-template-columns: minmax(180px, 0.85fr) minmax(0, 1fr) minmax(150px, 0.7fr) minmax(150px, 0.75fr);
}
.settings-customer-rule-toggle {
    min-height: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    align-content: center;
    gap: 10px;
    border: 0;
    background: transparent;
    padding: 0;
    border-radius: 0;
}
.settings-customer-rule-toggle span {
    font-weight: 600;
}
.settings-customer-rule-toggle input[type="checkbox"] {
    margin: 0;
    flex: 0 0 auto;
}
.settings-customer-email-block {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #f8fbff;
}
.settings-customer-email-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.settings-customer-email-list {
    display: grid;
    gap: 10px;
}
.settings-customer-email-columns {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr) 40px 78px;
    gap: 10px;
    align-items: center;
}
.settings-customer-email-columns span {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.settings-customer-email-columns span:last-child {
    text-align: center;
}
.settings-customer-email-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr) 40px 78px;
    gap: 10px;
    align-items: center;
}
.settings-customer-email-row.is-readonly {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr) 40px 78px;
}
.settings-customer-email-row.is-readonly .cell-input {
    background: #f3f6fa;
    border-color: #d9e3ef;
    color: #0f2747;
}
.settings-customer-email-row.is-readonly .settings-customer-default-email {
    opacity: 0.55;
}
.settings-customer-default-email {
    white-space: nowrap;
    justify-content: center;
    display: inline-flex;
    align-items: center;
    width: 100%;
}
.settings-customer-default-email span {
    display: none;
}
.settings-customer-email-delete-btn {
    color: #c0392b;
}
.settings-customer-email-delete-btn:hover {
    background: #fdeceb;
}
.settings-user-policy-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 10px;
}
.settings-user-policy-row small {
    color: var(--text-secondary);
}
.settings-schedule-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 10px;
}
.settings-schedule-editor {
    border-radius: 16px;
    border: 1px solid #dce8f4;
    padding: 12px;
    background: #fff;
    display: grid;
    gap: 10px;
}
.settings-schedule-editor.is-enabled {
    border-color: #b9d8c5;
    background: #eff8f2;
}
.settings-schedule-editor.is-disabled {
    border-color: #e2e8f0;
    background: #f8fafc;
}
.settings-schedule-editor .cell-input:disabled,
.settings-schedule-editor .cell-select:disabled,
.settings-schedule-editor input[type="time"]:disabled {
    border-color: #e0e9f2;
    background: #f7fafc;
    color: #31577f;
    cursor: default;
}
.settings-schedule-editor.is-disabled .cell-input:disabled,
.settings-schedule-editor.is-disabled .cell-select:disabled,
.settings-schedule-editor.is-disabled input[type="time"]:disabled {
    background: #f1f5f9;
}
.settings-schedule-editor input[type="checkbox"]:disabled {
    cursor: default;
    opacity: 0.7;
}
.settings-schedule-title {
    justify-content: space-between;
    align-items: center;
}
.settings-schedule-time-grid {
    display: grid;
    gap: 10px;
}
.settings-schedule-chip {
    border-radius: 14px;
    border: 1px solid #dce8f4;
    padding: 12px 10px;
    background: #ffffff;
    display: grid;
    gap: 4px;
    text-align: center;
}
.settings-schedule-chip.is-enabled {
    border-color: #b9d8c5;
    background: #eff8f2;
}
.settings-schedule-chip.is-disabled {
    border-color: #e2e8f0;
    background: #f8fafc;
}
.settings-schedule-chip small {
    color: var(--text-secondary);
}
.settings-user-licence-preview {
    position: relative;
    min-height: 180px;
    border-radius: 14px;
    border: 1px dashed #c8d9ea;
    background: linear-gradient(180deg, #fbfdff, #f2f7fd);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.settings-user-licence-preview.has-image {
    border-style: solid;
    background: #fff;
}
.settings-user-licence-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.settings-user-licence-side {
    display: grid;
    gap: 10px;
}
.settings-user-licence-side-head {
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--brand-navy);
}
.settings-user-licence-upload-field {
    display: grid;
    gap: 10px;
}
.settings-user-licence-image {
    display: block;
    width: 100%;
    height: 100%;
    max-height: 260px;
    object-fit: contain;
    background: #fff;
    padding: 12px;
}
.settings-user-licence-empty {
    color: var(--brand-navy);
    font-size: 1rem;
    font-weight: 700;
    text-align: center;
    padding: 24px;
}
.settings-user-licence-image[hidden],
.settings-user-licence-empty[hidden] {
    display: none !important;
}
.settings-user-licence-add {
    min-width: 40px;
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.settings-user-licence-add i {
    width: 18px;
    height: 18px;
}
.settings-user-licence-add.is-empty {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 52px;
    height: 52px;
    min-width: 52px;
    background: #fff;
}
.settings-user-licence-add.is-corner {
    position: absolute;
    right: 10px;
    top: 10px;
    background: #eff6ff;
    border-color: #bfd3ea;
    color: var(--brand-navy);
}
.settings-user-notification-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}
@media (max-width: 900px) {
    .settings-user-licence-grid {
        grid-template-columns: 1fr;
    }
}
.settings-colour-input {
    min-height: 48px;
    padding: 6px;
}
.engineer-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}
.engineer-badge-avatar {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: var(--engineer-color, #3b82f6);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1;
    flex: 0 0 auto;
    overflow: hidden;
    box-shadow: inset 0 0 0 2px rgba(255,255,255,0.26);
}
.engineer-badge-avatar.has-face {
    background: #fff;
    border: 2px solid var(--engineer-color, #3b82f6);
    box-sizing: border-box;
    box-shadow: none;
}
.engineer-badge-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 999px;
}
.engineer-badge-label {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.settings-sync-preview {
    margin: 0;
    border-radius: 16px;
    border: 1px solid #dce8f4;
    background: #0f1d30;
    color: #e3eefc;
    padding: 16px;
    font-size: 0.88rem;
    line-height: 1.55;
    overflow: auto;
}
.settings-audit-filter-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 16px;
}
.settings-audit-list {
    display: grid;
    gap: 12px;
}
.settings-audit-row {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding: 16px;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #f8fbff;
}
.settings-audit-meta {
    display: grid;
    justify-items: end;
    gap: 4px;
    min-width: 180px;
}
.settings-audit-meta small {
    color: var(--text-secondary);
}
@media (max-width: 1200px) {
    .settings-user-editor-layout {
        grid-template-columns: 1fr;
    }
    .settings-user-avatar-hero {
        grid-template-columns: auto minmax(0, 1fr);
    }
    .settings-user-avatar-contact {
        grid-column: 1 / -1;
        justify-items: start;
        text-align: left;
    }
    .settings-user-meta-grid,
    .settings-user-toggle-grid,
    .settings-user-field-grid-tight {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .settings-user-notification-list {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 760px) {
    .settings-user-address-search-row,
    .settings-user-avatar-hero,
    .settings-user-avatar-actions,
    .settings-user-meta-grid,
    .settings-user-field-grid,
    .settings-user-field-grid-tight,
    .settings-user-toggle-grid,
    .settings-schedule-grid {
        grid-template-columns: 1fr;
    }
}
.settings-entity-grid,
.settings-email-list {
    display: grid;
    gap: 16px;
}
.settings-email-monitor-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}
.settings-email-sidebar {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid #dce8f4;
    border-radius: 20px;
    background: #f8fbff;
}
.settings-email-sidebar-title {
    color: #173a63;
    font-size: 1.15rem;
    font-weight: 800;
}
.settings-email-sidebar-list {
    display: grid;
    gap: 10px;
}
.settings-email-category-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    border: 1px solid #dce8f4;
    border-radius: 16px;
    background: #ffffff;
    color: #173a63;
    padding: 14px 16px;
    text-align: left;
    font-size: 0.98rem;
    font-weight: 700;
    cursor: pointer;
}
.settings-email-category-btn small {
    color: #5a7b9d;
    font-size: 0.8rem;
    font-weight: 700;
}
.settings-email-category-btn:hover,
.settings-email-category-btn.is-active {
    border-color: #3b82f6;
    background: #eef5ff;
}
.settings-email-monitor-main {
    display: grid;
    gap: 22px;
}
.settings-email-monitor-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}
.settings-email-monitor-head h3 {
    margin: 0 0 6px;
    color: #173a63;
    font-size: 1.2rem;
    font-weight: 800;
}
.settings-email-monitor-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.settings-email-rows-label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #5a7b9d;
    font-size: 0.9rem;
    font-weight: 700;
}
.settings-email-rows-select {
    min-width: 88px;
    border: 1px solid #dce8f4;
    border-radius: 12px;
    background: #ffffff;
    color: #173a63;
    padding: 8px 12px;
    font-size: 0.95rem;
    font-weight: 700;
    outline: none;
    cursor: pointer;
}
.settings-email-rows-select:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
}
.settings-email-log {
    display: grid;
    gap: 10px;
}
.settings-email-log-empty {
    border: 1px dashed #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    color: #5a7b9d;
    padding: 18px;
    text-align: center;
    font-weight: 700;
}
.settings-email-log-row {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, 1.2fr) 120px 150px 124px;
    align-items: center;
    gap: 12px;
    width: 100%;
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    padding: 14px 16px;
    color: #173a63;
    text-align: left;
}
.settings-email-log-row.is-admin-view {
    grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.95fr) minmax(180px, 1fr) minmax(0, 1.1fr) 120px 150px 124px;
}
.settings-email-log-head {
    background: transparent;
    border: none;
    padding: 0 16px;
    color: #3f6f9f;
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.settings-email-log-head > div:last-child {
    text-align: center;
}
.settings-email-sort-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: none;
    background: transparent;
    color: inherit;
    font: inherit;
    font-weight: inherit;
    text-transform: inherit;
    letter-spacing: inherit;
    cursor: pointer;
    padding: 0;
}
.settings-email-sort-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 12px;
    font-size: 0.85em;
}
.settings-email-sort-arrow.is-idle {
    opacity: 0.5;
}
.settings-email-log-entry {
    cursor: pointer;
}
.settings-email-log-entry:hover,
.settings-email-log-entry:focus-visible {
    border-color: #bdd4ea;
    background: #f3f8fe;
    outline: none;
}
.settings-email-log-row > div {
    min-width: 0;
}
.settings-email-log-subject {
    font-weight: 700;
}
.settings-email-log-row div:not(.settings-email-log-actions) {
    overflow-wrap: anywhere;
}
.settings-email-log-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}
.settings-email-log-entry .settings-email-log-actions {
    align-self: flex-start;
    padding-top: 2px;
}
.settings-email-actions-placeholder {
    display: block;
    width: 100%;
    min-height: 40px;
}
.settings-email-user-cell {
    min-width: 0;
}
.settings-email-user-cell .engineer-badge {
    max-width: 100%;
}
.settings-email-actions-dropdown-wrap {
    display: block;
    width: 100%;
}
.settings-email-actions-dropdown {
    width: 100%;
    min-width: 120px;
    border: 1px solid #dce8f4;
    border-radius: 14px;
    background: #ffffff;
    color: #173a63;
    padding: 10px 12px;
    font-size: 0.95rem;
    font-weight: 700;
    outline: none;
    cursor: pointer;
}
.settings-email-actions-dropdown:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
}
.settings-email-retry-icon-btn {
    min-width: 0;
    height: 42px;
    padding: 0 12px;
    border-radius: 12px;
}
.settings-email-retry-icon-btn i {
    width: 18px;
    height: 18px;
}
.settings-email-modal .cell-input.is-invalid,
.settings-email-modal .cell-select.is-invalid,
.settings-email-modal .cell-textarea.is-invalid {
    border-color: #ef4444 !important;
}
.settings-email-field-error {
    display: block;
    margin-top: 8px;
}
.settings-email-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.settings-email-pagination-summary {
    display: flex;
    align-items: center;
    gap: 10px;
}
.settings-email-page-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.settings-email-page-input {
    width: 76px;
    border: 1px solid #dce8f4;
    border-radius: 12px;
    background: #ffffff;
    color: #173a63;
    padding: 8px 10px;
    font-size: 0.95rem;
    font-weight: 700;
    outline: none;
}
.settings-email-page-input:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
}
.settings-email-pagination-actions {
    display: flex;
    gap: 10px;
}
.settings-email-status-chip {
    justify-content: center;
    min-width: 78px;
}
.settings-email-status-chip.status-sent {
    background: #e8f7ee;
    color: #1b7f43;
}
.settings-email-status-chip.status-failed {
    background: #fdebec;
    color: #c53446;
}
.settings-email-status-chip.status-queued {
    background: #eef4fb;
    color: #325c86;
}
.settings-email-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(12, 25, 43, 0.32);
    z-index: 80;
}
.settings-email-modal {
    position: fixed;
    top: 84px;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    width: min(880px, calc(100vw - 48px));
    max-height: none;
    overflow: auto;
    z-index: 81;
    border: 1px solid #dce8f4;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 30px 60px rgba(12, 25, 43, 0.18);
    padding: 22px;
    display: grid;
    gap: 18px;
}
.settings-email-modal-head,
.settings-email-modal-actions {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}
.settings-email-modal-head h3 {
    margin: 0 0 6px;
    color: #173a63;
    font-size: 1.25rem;
    font-weight: 800;
}
.settings-email-modal-body {
    display: grid;
    gap: 16px;
}
.settings-email-modal-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.settings-email-edit-body {
    width: 100%;
    min-height: 180px;
    resize: vertical;
}
.settings-email-html-preview {
    border: 1px solid #dce8f4;
    border-radius: 14px;
    background: #ffffff;
    padding: 14px;
    line-height: 1.25;
    color: #173a63;
}
.settings-email-html-preview p,
.settings-email-html-preview div {
    margin-top: 0;
}
.settings-email-html-preview a,
.settings-email-html-preview a:visited {
    color: inherit !important;
    text-decoration: none !important;
}
.settings-email-html-preview img {
    max-width: 100%;
    height: auto;
}
.settings-email-attachments {
    display: grid;
    gap: 10px;
}
.settings-email-attachment-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.settings-email-attachment-chip {
    border: 1px solid #d6e4f2;
    cursor: pointer;
}
.settings-email-attachment-chip span {
    color: #6d87a5;
    font-size: 0.78rem;
}
.settings-email-attachment-chip:hover {
    border-color: #8fb5df;
    background: #f1f7ff;
}
.settings-email-attachment-preview-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(12, 25, 43, 0.42);
    z-index: 90;
}
.settings-email-attachment-preview {
    position: fixed;
    top: 72px;
    left: 50%;
    width: min(1120px, calc(100vw - 120px));
    height: min(760px, calc(100vh - 120px));
    transform: translateX(-50%);
    z-index: 91;
    border: 1px solid #dce8f4;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 30px 70px rgba(12, 25, 43, 0.24);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    overflow: hidden;
}
.settings-email-attachment-preview-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    padding: 18px 20px;
    border-bottom: 1px solid #dce8f4;
}
.settings-email-attachment-preview-head h3 {
    margin: 0 0 4px;
    color: #173a63;
    font-size: 1.1rem;
    font-weight: 800;
}
.settings-email-attachment-preview-body {
    min-height: 0;
    overflow: auto;
    background: #f4f8fc;
    padding: 14px;
}
.settings-email-attachment-preview-body iframe {
    width: 100%;
    height: 100%;
    min-height: 0;
    border: 0;
    border-radius: 14px;
    background: #ffffff;
}
.settings-email-attachment-preview-body img {
    display: block;
    max-width: 100%;
    max-height: 76vh;
    margin: 0 auto;
    border-radius: 14px;
    background: #ffffff;
    object-fit: contain;
}
.summary-bar-danger {
    border-color: #f3c3cb;
    background: #fff6f7;
}
.settings-entity-card,
.settings-email-card {
    border: 1px solid #dce8f4;
    border-radius: 18px;
    background: #f8fbff;
    padding: 16px;
    display: grid;
    gap: 12px;
}
.settings-entity-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}
.settings-email-body {
    display: grid;
    gap: 8px;
}
.settings-email-body pre {
    margin: 0;
    white-space: pre-wrap;
    font-family: inherit;
    color: var(--text-secondary);
    line-height: 1.55;
    background: #ffffff;
    border: 1px solid #dce8f4;
    border-radius: 14px;
    padding: 14px;
}
@media (max-width: 1100px) {
    .emails-filter-bar {
        grid-template-columns: 1fr;
    }
    .settings-email-log-row {
        grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) minmax(0, 1fr) 110px 130px 124px;
    }
    .settings-email-log-row.is-admin-view {
        grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr) minmax(160px, 1fr) minmax(0, 1fr) 110px 130px 124px;
    }
}
@media (max-width: 920px) {
    .settings-email-attachment-preview {
        top: 64px;
        width: calc(100vw - 28px);
        height: calc(100vh - 92px);
    }
    .settings-signature-toolbar {
        align-items: stretch;
    }
    .settings-signature-group {
        width: 100%;
        padding-right: 0;
        padding-bottom: 12px;
        border-right: 0;
        border-bottom: 1px solid #e3ebf4;
    }
    .settings-signature-group:last-child {
        padding-bottom: 0;
        border-bottom: 0;
    }
    .settings-email-monitor-layout,
    .settings-email-modal-grid {
        grid-template-columns: 1fr;
    }
    .settings-email-log-head {
        display: none;
    }
    .settings-email-log-row {
        grid-template-columns: 1fr;
        align-items: start;
    }
    .settings-email-log-actions,
    .settings-email-monitor-head,
    .settings-email-modal-head,
    .settings-email-modal-actions {
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}
.settings-qty-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
}
.settings-qty-toggle input {
    width: 18px;
    height: 18px;
}
.settings-keyboard-preview {
    display: grid;
    gap: 12px;
    padding: 12px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
}
.settings-keyboard-preview .cell-input {
    width: 100%;
}
.settings-keyboard-preview-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.settings-keyboard-chip {
    border: 1px solid #ccdbe8;
    border-radius: 14px;
    background: #ffffff;
    color: #173a63;
    padding: 10px 12px;
    font-size: 0.92rem;
    font-weight: 700;
    line-height: 1.1;
    cursor: pointer;
}
.settings-keyboard-chip:hover {
    background: #eef5fc;
}
.settings-input-preview {
    display: grid;
    gap: 12px;
    padding: 12px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
}
.settings-input-preview .cell-input {
    width: 100%;
}
.settings-input-preview-fill {
    min-height: 76px;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
}
.settings-option-preview {
    display: grid;
    gap: 12px;
    padding: 12px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
}
.settings-option-preview .cell-select,
.settings-option-preview .cell-input {
    width: 100%;
}
.settings-option-preview-fill {
    min-height: 76px;
    border: 1px solid #d7e1eb;
    border-radius: 14px;
    background: #f8fafc;
    padding: 12px;
    display: grid;
    align-items: start;
}
.settings-option-preview-fill.is-hidden {
    display: none;
}
.settings-repair-single-field-preview {
    display: grid;
    grid-template-columns: minmax(220px, 420px) minmax(40px, 1fr);
    gap: 16px;
    padding: 12px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
}
.settings-repair-single-field-card {
    display: grid;
    gap: 8px;
}
.settings-repair-single-field-label {
    color: var(--brand-navy);
    font-size: 0.9rem;
    font-weight: 700;
}
.settings-repair-single-field-input {
    width: 100%;
}
.settings-repair-single-field-spacer {
    min-height: 76px;
}
.settings-repair-keyboard-preview {
    display: grid;
    padding: 12px;
    border: 1px solid #d7e1eb;
    border-radius: 16px;
    background: #f8fafc;
}
.settings-repair-keyboard-card {
    display: grid;
    gap: 10px;
    max-width: 420px;
}
.map-preview {
    min-height: 220px; border-radius: 18px; background: linear-gradient(135deg, #ddecfb, #f6fbff);
    border: 1px solid #d9e6f2; padding: 20px; color: var(--brand-navy); display: grid; gap: 14px;
}
.map-preview-graphic {
    position: relative;
    overflow: hidden;
    min-height: 260px;
}
.map-preview-fallback {
    display: none;
    min-height: 260px;
    align-items: center;
    justify-content: center;
    color: #5f7b99;
    font-weight: 700;
}
.map-preview-graphic.is-map-unavailable .map-preview-fallback {
    display: flex;
}
.map-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(20,55,99,.08) 1px, transparent 1px),
        linear-gradient(90deg, rgba(20,55,99,.08) 1px, transparent 1px);
    background-size: 34px 34px;
}
.site-pin,
.gps-pin {
    position: absolute;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    box-shadow: 0 0 0 4px rgba(255,255,255,.9);
}
.site-pin {
    top: 42%;
    left: 44%;
    background: var(--brand-navy);
}
.gps-pin {
    top: 48%;
    left: 52%;
    background: var(--brand-green);
}
.gps-radius {
    position: absolute;
    top: calc(48% - 52px);
    left: calc(52% - 52px);
    width: 104px;
    height: 104px;
    border-radius: 50%;
    background: rgba(13, 155, 68, 0.14);
    border: 2px solid rgba(13, 155, 68, 0.38);
}
.mini-site-pin,
.mini-gps-pin {
    width: 12px;
    height: 12px;
    box-shadow: 0 0 0 3px rgba(255,255,255,.9);
}
.mini-site-pin {
    top: 40%;
    left: 38%;
}
.mini-gps-pin {
    top: 46%;
    left: 54%;
}
.mini-gps-radius {
    top: calc(46% - 24px);
    left: calc(54% - 24px);
    width: 48px;
    height: 48px;
    border-width: 1.5px;
}

@media (max-width: 1100px) {
    .two-col, .detail-two-col { grid-template-columns: 1fr; }
}

@media (max-width: 1900px) {
    .admin-form-detail-page .job-tabs-container {
        min-width: 0;
        width: 100%;
    }
    .admin-form-detail-page .admin-engineer-layout {
        grid-template-columns: 320px minmax(0, 1fr);
        width: 100%;
        min-width: 0;
    }
    .admin-form-detail-page .admin-engineer-main-card {
        min-width: 0;
        overflow-x: auto;
        overflow-y: visible;
    }
    .admin-form-detail-page .excel-group-list {
        min-width: 0;
    }
    .admin-form-detail-page .excel-group-card {
        min-width: 0;
    }
}

@media (max-width: 900px) {
    .search-bar { display: none; }
    .form-row, .editor-row { grid-template-columns: 1fr; }
    .settings-repair-list-row { grid-template-columns: 1fr; }
    .settings-repair-list-header { display: none; }
    .settings-repair-list-cell,
    .settings-repair-list-cell-action,
    .settings-repair-list-cell-qty {
        padding: 8px 12px;
    }
    .settings-repair-list-cell-action,
    .settings-repair-list-cell-qty {
        justify-content: flex-start;
    }
    .page-header, .card-head, .selection-bar { flex-direction: column; align-items: stretch; }
    .page-content { padding: 20px; }
    .settings-landing-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .settings-hero,
    .settings-grid,
    .settings-part-grid,
    .settings-family-grid,
    .settings-policy-grid,
    .settings-customer-form-grid,
    .settings-customer-rule-groups,
    .settings-customer-summary-groups,
    .settings-customer-summary-inline-grid-jobref,
    .settings-customer-summary-inline-grid-markup,
    .settings-customer-rule-inline-grid-jobref,
    .settings-customer-rule-inline-grid-markup,
    .tracking-layout,
    .tracking-record-grid {
        grid-template-columns: 1fr;
    }
    .settings-customer-editor-head-row {
        grid-template-columns: 1fr;
    }
    .settings-customer-editor-top-actions {
        justify-content: flex-start;
    }
    .settings-customer-inline-field {
        grid-template-columns: 1fr;
    }
    .settings-supplier-tab-visibility-card {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .settings-supplier-tab-visibility-title {
        grid-column: 1 / -1;
    }
    .settings-customer-list-head,
    .settings-customer-list-row {
        grid-template-columns: 1fr;
    }
    .settings-customer-list-head {
        display: none;
    }
    .settings-customer-list-row-shell {
        grid-template-columns: 1fr;
    }
    .settings-customer-list-actions {
        justify-content: flex-start;
    }
    .tracking-toolbar-summary {
        grid-template-columns: 1fr;
    }
    .tracking-map-card {
        min-height: auto;
    }
    .tracking-map-canvas {
        min-height: 460px;
    }
    .settings-schedule-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .settings-audit-filter-row,
    .settings-audit-row {
        grid-template-columns: 1fr;
        display: grid;
    }
    .settings-audit-meta {
        justify-items: start;
        min-width: 0;
    }
    .settings-entity-head {
        flex-direction: column;
        align-items: flex-start;
    }
    .settings-hero-metrics {
        grid-template-columns: 1fr;
    }
    .settings-person-row {
        flex-direction: column;
        align-items: flex-start;
    }
    body[data-page="settings"] #settings-shell {
        overflow-x: auto;
        overflow-y: auto;
    }
    body[data-page="settings"] .settings-customers-scroll-area,
    body[data-page="settings"] .settings-detail-shell {
        overflow-x: auto;
        overflow-y: visible;
    }
    body[data-page="settings"] .settings-customers-scroll-area .settings-card,
    body[data-page="settings"] .settings-detail-shell > .settings-card {
        width: max-content;
        min-width: 100%;
    }
    body[data-page="settings"] .settings-customers-scroll-area > *,
    body[data-page="settings"] .settings-detail-shell > *:not(.settings-back-link) {
        width: max-content;
        min-width: 100%;
    }
    body[data-page="settings"] .settings-landing-grid {
        grid-template-columns: repeat(4, minmax(260px, 1fr));
        min-width: 1120px;
    }
    body[data-page="settings"] .settings-grid,
    body[data-page="settings"] .settings-part-grid,
    body[data-page="settings"] .settings-family-grid,
    body[data-page="settings"] .settings-policy-grid,
    body[data-page="settings"] .settings-customer-form-grid,
    body[data-page="settings"] .settings-customer-rule-groups,
    body[data-page="settings"] .settings-customer-summary-groups,
    body[data-page="settings"] .settings-customer-summary-inline-grid-jobref,
    body[data-page="settings"] .settings-customer-summary-inline-grid-markup,
    body[data-page="settings"] .settings-customer-rule-inline-grid-jobref,
    body[data-page="settings"] .settings-customer-rule-inline-grid-markup,
    body[data-page="settings"] .settings-user-editor-layout,
    body[data-page="settings"] .settings-list-group-grid {
        grid-template-columns: repeat(2, minmax(320px, 1fr));
        min-width: 920px;
    }
    body[data-page="settings"] .settings-list-sidebar-layout {
        grid-template-columns: 1fr;
        min-width: 920px;
    }
    body[data-page="settings"] .settings-list-sidebar {
        min-width: 0;
    }
    body[data-page="settings"] .settings-dropdown-table {
        min-width: 920px;
    }
    body[data-page="settings"] .editor-row {
        grid-template-columns: 140px minmax(0, 1.15fr) minmax(0, 1.2fr) minmax(120px, .8fr) minmax(120px, 1fr) 76px;
        min-width: 920px;
    }
    body[data-page="settings"] .settings-repair-list-header {
        display: grid;
        min-width: 1380px;
    }
    body[data-page="settings"] .settings-repair-list-layout,
    body[data-page="settings"] .settings-repair-list-section {
        min-width: max-content;
    }
    body[data-page="settings"] .settings-repair-list-box {
        overflow-x: auto;
        overflow-y: hidden;
    }
    body[data-page="settings"] .settings-repair-list-row {
        grid-template-columns: minmax(120px, 0.9fr) minmax(140px, 0.95fr) 120px minmax(155px, 1fr) minmax(130px, 0.8fr) 118px 86px 86px 120px;
        min-width: 1380px;
    }
    body[data-page="settings"] .settings-customer-list-head {
        display: grid;
        grid-template-columns: minmax(200px, 1fr) minmax(240px, 1.3fr) minmax(240px, 1.2fr) 56px;
        min-width: 980px;
    }
    body[data-page="settings"] .settings-customer-list-row {
        grid-template-columns: minmax(200px, 1fr) minmax(240px, 1.3fr) minmax(240px, 1.2fr);
        min-width: 924px;
    }
    body[data-page="settings"] .settings-customer-list-row-shell {
        grid-template-columns: minmax(0, 1fr) 56px;
        min-width: 980px;
    }
    body[data-page="settings"] .settings-customer-list-actions {
        justify-content: center;
    }
    body[data-page="settings"] .settings-receipts-grid {
        grid-template-columns: minmax(220px, 1.5fr) repeat(4, minmax(92px, 0.55fr)) auto 52px;
        min-width: 1080px;
    }
    .tracking-record-head,
    .tracking-engineer-option {
        flex-direction: column;
        align-items: flex-start;
    }
    .job-topbar,
    .job-tab-content.engineer-form-page {
        padding-left: 20px;
        padding-right: 20px;
    }
    .job-topbar {
        padding-top: 10px;
        padding-bottom: 10px;
    }
    .form-detail-scroll-body {
        overflow: auto;
    }
    .admin-engineer-layout {
        grid-template-columns: 280px minmax(0, 1fr);
        width: 100%;
        min-width: 0;
    }
    .admin-form-detail-page .admin-engineer-main-card {
        min-width: 0;
        overflow-x: auto;
        overflow-y: visible;
    }
    .admin-form-detail-page .excel-group-list {
        min-width: 0;
    }
    .admin-form-detail-page .excel-group-card {
        min-width: 0;
    }
    .admin-form-detail-page .excel-group-header,
    .admin-form-detail-page .excel-row {
        min-width: 0;
    }
    .admin-form-detail-page .window-measure-grid {
        grid-template-columns: 1fr;
    }
    .admin-form-detail-page .window-measure-layout {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
            "sketch photo"
            "main main"
            "addon addon"
            "side side"
            "status status";
        min-width: 0;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-layout {
        display: flex !important;
        flex-direction: column !important;
        gap: 14px;
        min-width: 0;
        width: 100%;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-layout > * {
        width: 100%;
        max-width: none;
        min-width: 0;
        grid-area: auto !important;
        grid-column: auto !important;
    }
    .admin-form-detail-page .excel-row-door-measure .window-measure-main-grid,
    .admin-form-detail-page .excel-row-door-measure .window-measure-addon-stack,
    .admin-form-detail-page .excel-row-door-measure .window-measure-side-grid,
    .admin-form-detail-page .excel-row-door-measure .window-measure-status-row {
        width: 100%;
        max-width: none;
        min-width: 0;
    }
    .admin-form-detail-page .excel-row-door-measure .window-measure-main-grid,
    .admin-form-detail-page .excel-row-door-measure .window-measure-addon-grid,
    .admin-form-detail-page .excel-row-door-measure .window-measure-side-grid,
    .admin-form-detail-page .excel-row-door-measure .window-measure-status-row {
        grid-template-columns: 1fr !important;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-grid {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }
    .admin-form-detail-page .excel-row-door-measure .door-measure-grid .window-measure-inline-cell,
    .admin-form-detail-page .excel-row-door-measure .door-measure-grid .window-measure-cell,
    .admin-form-detail-page .excel-row-door-measure .door-measure-section-heading,
    .admin-form-detail-page .excel-row-door-measure .window-measure-media-card {
        width: 100%;
        max-width: none;
    }
    .admin-form-detail-page .window-measure-main-grid {
        grid-template-columns: 1fr 1fr;
    }
    .admin-form-detail-page .window-measure-addon-grid,
    .admin-form-detail-page .window-measure-side-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    }
    .admin-form-detail-page .window-measure-addon-stack {
        width: 100%;
        max-width: 220px;
    }
    .admin-form-detail-page .compact-addon-card {
        width: 100%;
        max-width: 200px;
        border: 1px solid #d7e1eb;
        border-radius: 16px;
        overflow: hidden;
        background: #f8fafc;
        box-sizing: border-box;
    }
    .admin-form-detail-page .compact-addon-head {
        min-height: 34px;
        padding: 7px 12px 6px;
        border-bottom: 1px solid #e6edf5;
        text-align: center;
        font-size: 0.78rem;
        font-weight: 700;
        color: var(--text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        line-height: 1.1;
    }
    .admin-form-detail-page .compact-addon-body {
        display: flex;
        flex-direction: column;
    }
    .admin-form-detail-page .compact-addon-row {
        display: grid;
        grid-template-columns: 56px 112px;
        align-items: center;
        justify-content: space-between;
        gap: 8px;
        min-height: 56px;
        height: 56px;
        padding: 0 12px;
        background: #f8fafc;
        box-sizing: border-box;
    }
    .admin-form-detail-page .compact-addon-row + .compact-addon-row {
        border-top: 1px solid #e6edf5;
    }
    .admin-form-detail-page .compact-addon-label {
        font-size: 0.95rem;
        font-weight: 700;
        color: var(--brand-navy);
        line-height: 1;
    }
    .admin-form-detail-page .compact-addon-input .excel-cell-input,
    .admin-form-detail-page .compact-addon-input .cell-input,
    .admin-form-detail-page .compact-addon-input .cell-select {
        height: 38px !important;
        min-height: 38px !important;
        max-height: 38px !important;
        width: 112px !important;
        min-width: 112px !important;
        margin: 0 !important;
        border-radius: 10px;
    }
    .admin-form-detail-page .window-measure-addon-item:nth-child(-n + 2) {
        border-top: 1px solid #e6edf5;
    }
    .admin-form-detail-page .window-measure-addon-item:first-child {
        border-top: 0;
    }
    .admin-form-detail-page .window-measure-addon-item:nth-child(2n) {
        border-left: 0;
    }
    .admin-form-detail-page .window-measure-addon-label {
        flex: 0 0 auto;
        min-width: 0;
    }
    .admin-form-detail-page .window-measure-addon-item .excel-cell-input {
        flex: 0 0 112px;
        width: 112px;
        min-width: 112px;
    }
    .admin-form-detail-page .window-measure-addon-stack.window-measure-addon-stack-mobile .window-measure-addon-item .excel-cell-input,
    .admin-form-detail-page .window-measure-addon-stack.window-measure-addon-stack-mobile .window-measure-addon-item .cell-input,
    .admin-form-detail-page .window-measure-addon-stack.window-measure-addon-stack-mobile .window-measure-addon-item .cell-select,
    .admin-form-detail-page .window-measure-addon-item-mobile-card .excel-cell-input,
    .admin-form-detail-page .window-measure-addon-item-mobile-card .cell-input,
    .admin-form-detail-page .window-measure-addon-item-mobile-card .cell-select {
        height: 38px !important;
        min-height: 38px !important;
        max-height: 38px !important;
        margin: 0 !important;
        border-radius: 10px;
        width: 112px !important;
        min-width: 112px !important;
    }
    .excel-group-leading,
    .excel-row-leading {
        justify-content: flex-start;
    }
    .forms-fixed-shell {
        padding: 18px 20px 0;
    }
    .jobs-controls {
        flex-direction: column;
        align-items: stretch;
    }
    .forms-scroll-area {
        padding: 20px;
    }
    .forms-grid-head {
        display: none;
    }
    .forms-grid-row {
        grid-template-columns: 1fr;
    }
    .forms-grid-main {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .forms-grid-bin {
        min-height: 48px;
        border-left: 0;
        border-top: 1px solid #e6edf5;
    }
    .record-topbar {
        padding: 0;
    }
    .record-topbar-main {
        flex-direction: column;
        align-items: stretch;
        gap: 14px;
        padding: 16px 20px 14px;
    }
    .record-topbar-left {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    .record-title-row {
        flex-wrap: wrap;
        gap: 12px;
    }
    .record-topbar-right { justify-content: flex-start; flex-wrap: wrap; }
    .record-tabs-container,
    .job-tabs-container {
        margin: 0 20px;
        min-width: 0;
        width: 100%;
    }
    .mini-gps-map { width: 112px; height: 68px; }
    .sidebar-spacer,
    .sidebar-spacer.locked { width: var(--sidebar-width-collapsed) !important; }
    .sidebar,
    .sidebar:hover,
    .sidebar.locked {
        width: var(--sidebar-width-collapsed);
    }
    .nav-text,
    .chevron,
    .upgrade-card,
    .sidebar:hover .nav-text,
    .sidebar:hover .chevron,
    .sidebar.locked .nav-text,
    .sidebar.locked .chevron,
    .sidebar:hover .upgrade-card,
    .sidebar.locked .upgrade-card {
        opacity: 0;
    }
    .sidebar .sub-nav,
    .sidebar:hover .nav-category.active .sub-nav,
    .sidebar.locked .nav-category.active .sub-nav {
        max-height: 0;
        margin-top: 0;
        padding-bottom: 0;
    }
}

@media (max-width: 1300px) {
    .settings-landing-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .settings-landing-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .sidebar-spacer { display: none; }
    .sidebar { width: var(--sidebar-width-expanded); transform: translateX(-100%); }
    .sidebar.show-mobile { transform: translateX(0); }
    .nav-text, .chevron { opacity: 1; }
    .sidebar.show-mobile .nav-text,
    .sidebar.show-mobile .chevron,
    .sidebar.show-mobile .upgrade-card {
        opacity: 1 !important;
    }
    .sub-nav { max-height: 320px; margin-top: 8px; padding-bottom: 8px; }
    .sidebar.show-mobile .sub-nav,
    .sidebar.show-mobile .nav-category.active .sub-nav {
        max-height: 320px;
        margin-top: 8px;
        padding-bottom: 8px;
    }
    .icon-btn { display: inline-flex; }
    .new-form-modal {
        width: calc(100vw - 24px);
        padding: 18px;
    }
    .new-form-grid {
        grid-template-columns: 1fr;
    }
.empty-add-work-btn {
        min-width: 0;
        width: 100%;
    }
}

.admin-form-detail-page .excel-row-actions.has-action-stack .excel-delete-label {
    display: none;
}
.admin-form-detail-page .excel-row-actions.has-action-stack .excel-action-label {
    display: none;
}

@container (max-width: 700px) {
    .admin-form-detail-page .excel-row-window-handle .excel-row-actions.has-action-stack .excel-delete-btn,
    .admin-form-detail-page .excel-row-window-handle .excel-row-actions.has-action-stack .excel-action-btn,
    .admin-form-detail-page .excel-row-detail .excel-row-actions.has-action-stack .excel-delete-btn,
    .admin-form-detail-page .excel-row-detail .excel-row-actions.has-action-stack .excel-action-btn,
    .admin-form-detail-page .excel-row-window-measure .excel-row-actions.has-action-stack .excel-delete-btn {
        width: 100%;
        min-width: 0;
        height: auto;
        min-height: 40px;
        padding: 8px 12px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
        gap: 8px;
    }
    .admin-form-detail-page .excel-row-window-measure .excel-row-actions.has-action-stack .excel-action-btn {
        width: 100%;
        min-width: 0;
        height: auto;
        min-height: 40px;
        padding: 8px 12px;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        justify-content: center;
        gap: 8px;
    }
    .admin-form-detail-page .excel-row-window-handle .excel-row-actions.has-action-stack .excel-delete-label,
    .admin-form-detail-page .excel-row-window-handle .excel-row-actions.has-action-stack .excel-action-label,
    .admin-form-detail-page .excel-row-detail .excel-row-actions.has-action-stack .excel-delete-label,
    .admin-form-detail-page .excel-row-detail .excel-row-actions.has-action-stack .excel-action-label,
    .admin-form-detail-page .excel-row-window-measure .excel-row-actions.has-action-stack .excel-delete-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
    .admin-form-detail-page .excel-row-window-measure .excel-row-actions.has-action-stack .excel-action-label {
        display: inline;
        white-space: normal;
        overflow-wrap: break-word;
        word-break: normal;
        min-width: 0;
        text-align: center;
        line-height: 1.15;
    }
}





