/* ===================================
   CSS Custom Properties
   =================================== */
:root {
    --color-primary: #0078d4;
    --color-primary-dark: #005a9e;
    --color-primary-light: #106ebe;
    --color-success: #107c10;
    --color-warning: #ffb900;
    --color-danger: #d13438;
    --color-error: #a80000;
    --color-text: #323130;
    --color-text-secondary: #605e5c;
    --color-border: #8a8886;
    --color-border-light: #edebe9;
    --color-bg: #ffffff;
    --color-bg-secondary: #faf9f8;
    --color-bg-tertiary: #f3f2f1;

    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;

    --border-radius: 4px;
    --border-radius-lg: 8px;

    --font-size-sm: 14px;
    --font-size-base: 16px;
    --font-size-lg: 18px;
    --font-size-xl: 20px;
    --font-size-xxl: 24px;
    --font-size-xxxl: 28px;

    --touch-target-min: 44px;
    --input-height: 48px;
}

/* ===================================
   Base Styles
   =================================== */
* {
    box-sizing: border-box;
}

body {
    margin: 0;
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;
    font-size: var(--font-size-base);
    line-height: 1.5;
    color: var(--color-text);
    background-color: var(--color-bg-secondary);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    min-width: 320px;
}

/* ===================================
   Layout
   =================================== */
.container {
    padding: var(--spacing-md);
    max-width: 480px;
    margin: 0 auto;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* Login page - fill screen, no scroll */
.login-container {
    height: 100dvh;
    max-width: 480px;
    margin: 0 auto;
    padding: var(--spacing-sm);
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
}

.login-container .login-form {
    gap: var(--spacing-sm);
}

.login-container .login-logo {
    max-width: 120px;
    margin-bottom: 4px;
}

.login-container .app-title {
    margin-bottom: 4px;
    font-size: var(--font-size-lg);
}

.change-pin-subtitle {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-md);
    text-align: center;
}

.login-container .pin-display {
    min-height: 44px;
    padding: var(--spacing-sm);
}

.login-container .numpad {
    margin-top: 0;
    gap: 6px;
}

.login-container .numpad-btn {
    min-height: 44px;
    height: 44px;
}

.login-container .remember-group {
    margin-top: 0;
}

/* List page container - not centered */
.app-header + .container {
    justify-content: flex-start;
    min-height: auto;
    padding-top: var(--spacing-lg);
    padding-bottom: var(--spacing-xl);
}

.login-card {
    background: var(--color-bg);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-md);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.login-logo {
    display: block;
    max-width: 160px;
    height: auto;
    margin: 0 auto var(--spacing-sm);
}

.app-title {
    font-size: var(--font-size-xl);
    font-weight: 600;
    margin: 0 0 var(--spacing-sm) 0;
    text-align: center;
    color: var(--color-primary);
}

/* ===================================
   Form Elements
   =================================== */
.login-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.form-label {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-text);
}

.input-field {
    width: 100%;
    height: var(--input-height);
    padding: 12px var(--spacing-md);
    font-size: var(--font-size-lg);
    border: 2px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background-color: var(--color-bg);
    transition: border-color 0.2s ease;
}

.input-field:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 1px var(--color-primary);
}

.input-field::placeholder {
    color: var(--color-text-secondary);
}

/* ===================================
   PIN Display
   =================================== */
.pin-display {
    min-height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-bg-tertiary);
    border: 2px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-xxxl);
    letter-spacing: 12px;
    padding: var(--spacing-md);
    font-family: monospace;
    color: var(--color-text);
}

.pin-display.shake {
    animation: shake 0.5s cubic-bezier(.36,.07,.19,.97) both;
}

@keyframes shake {
    10%, 90% {
        transform: translateX(-2px);
    }
    20%, 80% {
        transform: translateX(4px);
    }
    30%, 50%, 70% {
        transform: translateX(-6px);
    }
    40%, 60% {
        transform: translateX(6px);
    }
}

/* ===================================
   Number Pad
   =================================== */
.numpad {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
    margin-top: var(--spacing-sm);
}

.numpad-btn {
    min-height: 52px;
    height: 52px;
    font-size: var(--font-size-xxl);
    font-weight: 600;
    border: 2px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background-color: var(--color-bg);
    color: var(--color-text);
    cursor: pointer;
    transition: all 0.15s ease;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

.numpad-btn:active {
    transform: scale(0.95);
    background-color: var(--color-bg-tertiary);
}

.numpad-btn:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.numpad-btn-empty {
    background-color: transparent;
    border-color: transparent;
    cursor: default;
}

.numpad-btn-backspace {
    background-color: var(--color-bg-tertiary);
}

.backspace-icon {
    font-size: var(--font-size-xxxl);
}

/* ===================================
   Checkbox (Remember Username)
   =================================== */
.remember-group {
    margin-top: var(--spacing-sm);
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    cursor: pointer;
    user-select: none;
}

.checkbox-label input[type="checkbox"] {
    width: 20px;
    height: 20px;
    cursor: pointer;
}

/* ===================================
   Primary Button
   =================================== */
.btn-primary {
    width: 100%;
    min-height: 52px;
    padding: var(--spacing-md);
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: #ffffff;
    background-color: var(--color-primary);
    border: none;
    border-radius: var(--border-radius);
    cursor: pointer;
    transition: background-color 0.2s ease;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
}

.btn-primary:hover:not(:disabled) {
    background-color: var(--color-primary-light);
}

.btn-primary:active:not(:disabled) {
    background-color: var(--color-primary-dark);
    transform: scale(0.98);
}

.btn-primary:disabled {
    background-color: var(--color-border-light);
    color: var(--color-text-secondary);
    cursor: not-allowed;
}

.btn-primary:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* ===================================
   Sticky Submit Footer
   =================================== */
.submit-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #ffffff;
    padding: var(--spacing-md);
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    z-index: 100;
}

.btn-submit-footer {
    max-width: 600px;
    margin: 0 auto;
    display: block;
}

.btn-submit-success {
    background-color: var(--color-success) !important;
    color: #ffffff !important;
}

/* Pseudo-disabled look for the submit button before required fields are filled.
   Stays clickable so HTML5 invalid handler still flashes red + scrolls. */
.btn-submit-footer.btn-pending {
    background-color: #d1d5db !important;
    color: #6b7280 !important;
    box-shadow: none !important;
}
.btn-submit-footer.btn-pending:hover {
    background-color: #d1d5db !important;
}

/* Submit button flashes red when validation fails so techs scrolled
   near the top of the form get a clear cue alongside the error banner. */
.btn-error-flash {
    background-color: #dc2626 !important;
    color: #fff !important;
    animation: btn-error-shake 0.5s ease-in-out;
}
@keyframes btn-error-shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-6px); }
    40% { transform: translateX(6px); }
    60% { transform: translateX(-4px); }
    80% { transform: translateX(4px); }
}

/* Add padding to container when sticky footer is present */
body:has(.submit-footer) .container {
    padding-bottom: 90px;
}

/* ===================================
   Error Message
   =================================== */
.error-message {
    display: none;
    padding: var(--spacing-md);
    background-color: #fef0f0;
    border: 1px solid var(--color-error);
    border-radius: var(--border-radius);
    color: var(--color-error);
    font-size: var(--font-size-base);
    text-align: center;
}

.error-message.visible {
    display: block;
}

/* ===================================
   App Shell (for app.html)
   =================================== */
.app-header {
    background-color: #92400E;
    color: #ffffff;
    padding: var(--spacing-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    position: sticky;
    top: 0;
    z-index: 10000;
}

.app-header-title {
    font-size: var(--font-size-xl);
    font-weight: 600;
    margin: 0;
}

/* ===================================
   Offline Indicator
   =================================== */
.offline-bar {
    display: none;
    background-color: #d97706;
    color: #ffffff;
    text-align: center;
    padding: 4px var(--spacing-md);
    font-size: var(--font-size-sm);
    font-weight: 600;
}

.offline-bar.visible {
    display: block;
}

.pending-badge {
    display: none;
    background-color: #d97706;
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    min-width: 18px;
    height: 18px;
    line-height: 18px;
    text-align: center;
    border-radius: 9px;
    padding: 0 4px;
    position: absolute;
    top: -4px;
    right: -4px;
}

.pending-badge.visible {
    display: block;
}

/* ===================================
   Header Right (icon group)
   =================================== */
.header-right {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.header-icon-btn {
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    text-decoration: none;
}

.header-icon-btn:active {
    background: rgba(255, 255, 255, 0.2);
}

/* ===================================
   Profile Menu
   =================================== */
.profile-menu {
    position: relative;
}

.profile-icon-btn {
    background: rgba(255, 255, 255, 0.15);
    border: 2px solid rgba(255, 255, 255, 0.6);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #ffffff;
    padding: 0;
    font-size: 14px;
    font-weight: 700;
    font-family: inherit;
    letter-spacing: 0.5px;
}

.profile-icon-btn:active {
    background: rgba(255, 255, 255, 0.3);
}

.profile-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: #ffffff;
    border-radius: var(--border-radius);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    min-width: 160px;
    z-index: 10000;
    overflow: hidden;
}

.profile-dropdown.open {
    display: flex;
    flex-direction: column;
}

.profile-dropdown-item {
    display: block;
    width: 100%;
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
    color: var(--color-text);
    background: none;
    border: none;
    text-align: left;
    cursor: pointer;
    text-decoration: none;
    font-family: inherit;
}

.profile-dropdown-name {
    padding: var(--spacing-md) var(--spacing-lg);
    font-weight: 600;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border-light);
}

.profile-dropdown-item:hover {
    background-color: var(--color-bg-secondary);
}

.profile-dropdown-item:last-child {
    border-top: 1px solid var(--color-border-light);
    color: var(--color-danger);
}

/* ===================================
   Issue Form
   =================================== */
.issue-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    padding-bottom: var(--spacing-xl);
}

.issue-form .form-section {
    background: var(--color-bg);
    padding: var(--spacing-lg);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.issue-form .section-title {
    font-size: var(--font-size-lg);
    font-weight: 600;
    margin: 0 0 var(--spacing-md) 0;
    color: var(--color-text);
}

.issue-form select {
    width: 100%;
    height: var(--input-height);
    padding: 12px var(--spacing-md);
    font-size: var(--font-size-lg);
    border: 2px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background-color: var(--color-bg);
    cursor: pointer;
}

.issue-form textarea {
    width: 100%;
    min-height: 100px;
    padding: 12px var(--spacing-md);
    font-size: var(--font-size-lg);
    border: 2px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background-color: var(--color-bg);
    font-family: inherit;
    resize: vertical;
}

.issue-form textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 1px var(--color-primary);
}

/* ===================================
   Photo Upload
   =================================== */
.photo-input-hidden {
    display: none;
}

.photo-thumbnails {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
}

.photo-thumbnail {
    position: relative;
    aspect-ratio: 1;
    border-radius: var(--border-radius);
    overflow: hidden;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.photo-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.photo-remove {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 28px;
    height: 28px;
    background-color: var(--color-danger);
    color: #ffffff;
    border: none;
    border-radius: 50%;
    font-size: var(--font-size-lg);
    font-weight: bold;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.photo-remove:active {
    transform: scale(0.9);
}

/* ===================================
   Success Toast
   =================================== */
.success-toast {
    position: fixed;
    top: var(--spacing-lg);
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--color-success);
    color: #ffffff;
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--border-radius);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    font-size: var(--font-size-base);
    z-index: 10001;
    display: none;
    max-width: 90%;
}

.success-toast.visible {
    display: block;
    animation: slideDown 0.3s ease;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translate(-50%, -20px);
    }
    to {
        opacity: 1;
        transform: translate(-50%, 0);
    }
}

/* ===================================
   Loading Indicator
   =================================== */
.loading-indicator {
    display: none;
    text-align: center;
    padding: var(--spacing-md);
    color: var(--color-text-secondary);
    font-size: var(--font-size-base);
}

.loading-indicator.visible {
    display: block;
}

.spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid var(--color-border-light);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* ===================================
   Utility Classes
   =================================== */
.hidden {
    display: none !important;
}

.text-center {
    text-align: center;
}

.text-muted {
    color: var(--color-text-secondary);
}

.mt-md {
    margin-top: var(--spacing-md);
}

.mb-md {
    margin-bottom: var(--spacing-md);
}

/* ===================================
   Responsive Adjustments
   =================================== */
@media (min-width: 768px) {
    .container {
        padding: var(--spacing-xl);
    }

    .login-container {
        padding: var(--spacing-xl);
    }

    .login-container .login-form {
        gap: var(--spacing-md);
    }

    .login-container .login-logo {
        max-width: 160px;
    }

    .login-container .app-title {
        font-size: var(--font-size-xl);
    }

    .login-card {
        padding: var(--spacing-xl) 48px;
    }

    .numpad {
        gap: var(--spacing-lg);
    }

    .numpad-btn {
        min-height: 70px;
        height: 70px;
    }
}

/* ===================================
   Issue Checkbox Grid
   =================================== */
.section-hint {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin: 0 0 var(--spacing-md) 0;
}

.checkbox-grid {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.checkbox-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background-color: var(--color-bg-tertiary);
    border-radius: var(--border-radius);
    cursor: pointer;
    user-select: none;
    min-height: var(--touch-target-min);
    transition: background-color 0.15s ease;
}

.checkbox-item:active {
    background-color: var(--color-border-light);
}

.checkbox-item input[type="checkbox"] {
    width: 24px;
    height: 24px;
    cursor: pointer;
    flex-shrink: 0;
    accent-color: var(--color-primary);
}

.checkbox-label-text {
    font-size: var(--font-size-base);
    color: var(--color-text);
    line-height: 1.3;
}

.checkbox-item-wide {
    /* For longer text items */
}

.other-issue-container {
    margin-top: var(--spacing-md);
}

/* Radio button grid (service line survey) */
.radio-grid {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.radio-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background-color: var(--color-bg-tertiary);
    border-radius: var(--border-radius);
    cursor: pointer;
    user-select: none;
    min-height: var(--touch-target-min);
    transition: background-color 0.15s ease;
}

.radio-item:active {
    background-color: var(--color-border-light);
}

.radio-item input[type="radio"] {
    width: 24px;
    height: 24px;
    cursor: pointer;
    flex-shrink: 0;
    accent-color: var(--color-primary);
}

.radio-label-text {
    font-size: var(--font-size-base);
    color: var(--color-text);
    line-height: 1.3;
}

/* ===================================
   Photo Category Buttons
   =================================== */
.photo-category-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.photo-cat-btn {
    min-height: var(--input-height);
    padding: var(--spacing-md);
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-primary);
    background-color: var(--color-bg);
    border: 2px solid var(--color-primary);
    border-radius: var(--border-radius);
    cursor: pointer;
    transition: all 0.15s ease;
    touch-action: manipulation;
}

.photo-cat-btn:active {
    transform: scale(0.97);
    background-color: var(--color-primary);
    color: #ffffff;
}

.photo-cat-btn:disabled {
    color: var(--color-text-secondary);
    border-color: var(--color-border-light);
    cursor: not-allowed;
}

.photo-count-display {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-top: var(--spacing-sm);
}

/* ===================================
   Photo Category Badge
   =================================== */
.photo-category-badge {
    position: absolute;
    bottom: 4px;
    left: 4px;
    right: 4px;
    background-color: rgba(0, 0, 0, 0.7);
    color: #ffffff;
    font-size: 10px;
    padding: 2px 4px;
    border-radius: 2px;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ===================================
   Issues List Page
   =================================== */
.loading-state,
.empty-state,
.error-state {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--color-text-secondary);
}

.loading-state .spinner {
    margin-right: var(--spacing-sm);
}

.empty-state p,
.error-state p {
    margin: 0 0 var(--spacing-lg) 0;
    font-size: var(--font-size-lg);
}

.btn-secondary {
    min-height: var(--touch-target-min);
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-primary);
    background-color: var(--color-bg);
    border: 2px solid var(--color-primary);
    border-radius: var(--border-radius);
    cursor: pointer;
    transition: all 0.15s ease;
}

.btn-secondary:active {
    background-color: var(--color-primary);
    color: #ffffff;
}

/* ===================================
   Status & Issue Badges
   =================================== */
.issue-card-status {
    font-size: var(--font-size-sm);
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 12px;
    text-transform: capitalize;
    flex-shrink: 0;
}

.status-open {
    background-color: #fff3cd;
    color: #856404;
}

.status-resolved {
    background-color: #d4edda;
    color: #155724;
}

.issue-badge {
    font-size: 12px;
    font-weight: 500;
    padding: 2px 8px;
    background-color: var(--color-bg-tertiary);
    border-radius: 12px;
    color: var(--color-text);
}

/* Next Action pills (list table) */
.na-pill {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    white-space: nowrap;
}

.na-pill-overdue {
    background: #fde8e8;
    color: #dc2626;
}

.na-pill-soon {
    background: #fef9e7;
    color: #92400e;
}

.na-pill-future {
    background: #e8f5e9;
    color: #166534;
}

.na-pill-complete {
    background: #e8f5e9;
    color: #166534;
}

/* ===================================
   Wide Container (for tables)
   =================================== */
.container-wide {
    max-width: 100%;
    min-height: calc(100vh - 56px);
}

/* Lock the page so only the table area scrolls */
body:has(.table-scroll-area) {
    height: 100dvh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

body:has(.table-scroll-area) .app-header,
body:has(.table-scroll-area) .offline-bar {
    flex-shrink: 0;
}

body:has(.table-scroll-area) .container.container-wide {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

/* css.html wraps the table inside #panel-selfid / #panel-telemetry; those
   wrappers need to participate in the flex chain so the .datatable-bottom
   doesn't flow below the viewport. */
body:has(.table-scroll-area) #panel-selfid,
body:has(.table-scroll-area) #panel-telemetry {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}
/* Inline `style="display:none"` on the inactive panel beats the rule above;
   the rule still applies once the tab switcher clears the inline style. */

.container-wide .issues-table-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.table-scroll-area {
    flex: 1;
    overflow: auto;
    min-height: 0;
}

.issues-table thead th {
    position: sticky;
    top: 0;
    z-index: 10;
    background-color: var(--color-bg-tertiary);
}

/* ===================================
   Pagination
   =================================== */
.pagination-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    border-top: 1px solid var(--color-border-light);
    background: var(--color-bg);
    flex-shrink: 0;
}

.page-info {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    min-width: 100px;
    text-align: center;
}

.btn-page {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-primary);
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    cursor: pointer;
    min-height: 36px;
    transition: all 0.15s ease;
}

.btn-page:hover:not(:disabled) {
    background-color: var(--color-bg-secondary);
    border-color: var(--color-primary);
}

.btn-page:disabled {
    color: var(--color-text-secondary);
    opacity: 0.5;
    cursor: not-allowed;
}

/* ===================================
   Issues Table
   =================================== */
.issues-table-container {
    background: var(--color-bg);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow-x: auto;
}

/* Filter Bar */
.filter-bar {
    display: flex;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--color-border-light);
    flex-wrap: wrap;
    align-items: center;
}

.filter-group {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.filter-input {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    min-width: 200px;
}

.filter-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(0, 120, 212, 0.2);
}

.filter-select {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    background: var(--color-bg);
    cursor: pointer;
}

.filter-select:focus {
    outline: none;
    border-color: var(--color-primary);
}

.filter-dates {
    gap: var(--spacing-xs);
}

.filter-date {
    padding: var(--spacing-sm);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    font-family: inherit;
    background: var(--color-bg);
    color: var(--color-text);
}

.filter-date:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(0, 120, 212, 0.2);
}

.filter-date-sep {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
}

.results-count {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
}

/* Sortable Headers */
.issues-table th.sortable {
    cursor: pointer;
    user-select: none;
    transition: background-color 0.15s ease;
}

.issues-table th.sortable:hover {
    background-color: var(--color-border-light);
}

.sort-icon {
    margin-left: var(--spacing-xs);
    font-size: 10px;
    color: var(--color-text-secondary);
    opacity: 0.5;
}

.sort-icon.sort-active {
    opacity: 1;
    color: var(--color-primary);
}

.issues-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-sm);
}

.issues-table th,
.issues-table td {
    padding: var(--spacing-sm) var(--spacing-md);
    text-align: left;
    border-bottom: 1px solid var(--color-border-light);
}

.issues-table th {
    background-color: var(--color-bg-tertiary);
    font-weight: 600;
    color: var(--color-text);
    white-space: nowrap;
}

.issues-table tbody tr {
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.issues-table tbody tr:hover {
    background-color: var(--color-bg-secondary);
}

.issues-table tbody tr:active {
    background-color: var(--color-bg-tertiary);
}

.cell-work-order {
    font-weight: 500;
    min-width: 80px;
}

.cell-address {
    min-width: 150px;
}

.cell-serial {
    color: var(--color-text-secondary);
    min-width: 80px;
}

.cell-issues {
    min-width: 150px;
}

.cell-issues .issue-badge {
    margin-right: 4px;
    margin-bottom: 4px;
    display: inline-block;
}

.cell-status {
    min-width: 80px;
}

.cell-photos {
    text-align: center;
    min-width: 60px;
    color: var(--color-primary);
}

.cell-date {
    color: var(--color-text-secondary);
    white-space: nowrap;
    min-width: 100px;
}

.cell-submitted-by {
    color: var(--color-text-secondary);
    min-width: 80px;
}

.col-actions,
.cell-actions {
    width: 60px;
    text-align: center;
}

.btn-delete-row {
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-secondary);
    width: 28px;
    height: 28px;
    border-radius: var(--border-radius);
    cursor: pointer;
    font-size: 0.875rem;
    line-height: 1;
    transition: all 0.15s ease;
}

.btn-delete-row:hover {
    background-color: #C62828;
    border-color: #C62828;
    color: #ffffff;
}

/* Responsive table - hide some columns on mobile */
@media (max-width: 600px) {
    /* Hide Serial (3), Photos (6), Submitted By (7) on mobile */
    .issues-table th:nth-child(3),
    .issues-table td:nth-child(3),
    .issues-table th:nth-child(6),
    .issues-table td:nth-child(6),
    .issues-table th:nth-child(7),
    .issues-table td:nth-child(7) {
        display: none;
    }

    .issues-table th,
    .issues-table td {
        padding: var(--spacing-sm);
    }

    .filter-bar {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-input {
        min-width: 100%;
    }
}

/* ===================================
   Metadata Grid (Detail Page)
   =================================== */
.metadata-grid {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.metadata-item {
    display: flex;
    gap: var(--spacing-sm);
}

.metadata-label {
    font-weight: 600;
    color: var(--color-text);
    min-width: 100px;
}

.metadata-value {
    color: var(--color-text-secondary);
}

/* Textarea styling for detail form */
textarea.input-field {
    min-height: 80px;
    resize: vertical;
}

/* ===================================
   Photo Lightbox
   =================================== */
.photo-lightbox {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.9);
    z-index: 2000;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: var(--spacing-md);
}

.photo-lightbox.visible {
    display: flex;
}

.photo-lightbox img {
    max-width: 100%;
    max-height: calc(100vh - 120px);
    object-fit: contain;
    border-radius: var(--border-radius);
    transition: transform 0.3s ease;
}

.lightbox-rotate {
    position: absolute;
    top: var(--spacing-md);
    right: calc(var(--spacing-md) + 56px);
    width: 48px;
    height: 48px;
    background-color: rgba(255, 255, 255, 0.2);
    color: #ffffff;
    border: none;
    border-radius: 50%;
    font-size: 28px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
}

.lightbox-rotate:hover,
.lightbox-rotate:active {
    background-color: rgba(255, 255, 255, 0.3);
}

.lightbox-close {
    position: absolute;
    top: var(--spacing-md);
    right: var(--spacing-md);
    width: 48px;
    height: 48px;
    background-color: rgba(255, 255, 255, 0.2);
    color: #ffffff;
    border: none;
    border-radius: 50%;
    font-size: 32px;
    font-weight: 300;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
}

.lightbox-close:hover,
.lightbox-close:active {
    background-color: rgba(255, 255, 255, 0.3);
}

.lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 48px;
    height: 48px;
    background-color: rgba(255, 255, 255, 0.2);
    color: #ffffff;
    border: none;
    border-radius: 50%;
    font-size: 36px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
}

.lightbox-nav:hover,
.lightbox-nav:active {
    background-color: rgba(255, 255, 255, 0.3);
}

.lightbox-prev {
    left: var(--spacing-md);
}

.lightbox-next {
    right: var(--spacing-md);
}

.lightbox-caption {
    color: #ffffff;
    font-size: var(--font-size-base);
    margin-top: var(--spacing-md);
    text-align: center;
}

/* Make thumbnails clickable */
.photo-thumbnail {
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.photo-thumbnail:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.photo-thumbnail:active {
    transform: scale(0.98);
}

/* Photo delete button (detail page) */
.photo-delete-btn {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 24px;
    height: 24px;
    background-color: rgba(0, 0, 0, 0.6);
    color: #ffffff;
    border: none;
    border-radius: 50%;
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.15s ease, background-color 0.15s ease;
}

.photo-thumbnail:hover .photo-delete-btn {
    opacity: 1;
}

.photo-delete-btn:hover {
    background-color: #C62828;
}

/* ===================================
   Modal Styles
   =================================== */
.modal-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 1000;
    justify-content: center;
    align-items: center;
    padding: var(--spacing-md);
}

.modal-overlay.visible {
    display: flex;
}

.modal-content {
    background-color: #ffffff;
    border-radius: var(--border-radius-lg);
    width: 100%;
    max-width: 480px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}

.modal-content.modal-small {
    max-width: 360px;
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--color-border);
}

.modal-header h2 {
    margin: 0;
    font-size: var(--font-size-lg);
}

.modal-close {
    width: 32px;
    height: 32px;
    background: none;
    border: none;
    font-size: 24px;
    color: var(--color-text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--border-radius);
}

.modal-close:hover {
    background-color: var(--color-bg-secondary);
}

.modal-content form {
    padding: var(--spacing-md);
}

.modal-content p {
    padding: var(--spacing-md);
    margin: 0;
}

.modal-actions {
    display: flex;
    gap: var(--spacing-sm);
    justify-content: flex-end;
    padding-top: var(--spacing-md);
}

/* ===================================
   User Management Styles
   =================================== */
.btn-add-inline {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: #ffffff;
    background-color: var(--color-primary);
    border: none;
    border-radius: var(--border-radius);
    cursor: pointer;
    min-height: 36px;
}

.btn-add-inline:hover {
    background-color: var(--color-primary-light);
}

.page-actions {
    margin-bottom: var(--spacing-md);
}

.role-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: var(--font-size-sm);
    font-weight: 500;
}

.role-badge.role-admin {
    background-color: #E3F2FD;
    color: #1565C0;
}

.role-badge.role-tech {
    background-color: #E8F5E9;
    color: #2E7D32;
}

.role-badge.role-power_user {
    background-color: #FFF3E0;
    color: #E65100;
}

.status-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: var(--font-size-sm);
    font-weight: 500;
}

.status-badge.status-active {
    background-color: #E8F5E9;
    color: #2E7D32;
}

.status-badge.status-inactive {
    background-color: #FFEBEE;
    color: #C62828;
}

.status-badge.temp-pin-badge {
    background-color: #FFF3E0;
    color: #E65100;
}

.actions-cell {
    white-space: nowrap;
}

.btn-icon {
    width: 36px;
    height: 36px;
    padding: 0;
    border: none;
    background: none;
    color: var(--color-text-secondary);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--border-radius);
    transition: background-color 0.2s ease, color 0.2s ease;
}

.btn-icon:hover {
    background-color: var(--color-bg-secondary);
}

.btn-icon.btn-edit:hover {
    color: var(--color-primary);
}

.btn-icon.btn-delete:hover {
    color: #C62828;
}

.btn-danger {
    background-color: #C62828;
    color: #ffffff;
    padding: var(--spacing-sm) var(--spacing-md);
    border: none;
    border-radius: var(--border-radius);
    font-size: var(--font-size-base);
    font-weight: 500;
    cursor: pointer;
}

.btn-danger:hover {
    background-color: #B71C1C;
}

.btn-danger:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.button-row {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

.button-row .btn-primary,
.button-row .btn-danger {
    flex: 1;
    min-width: 140px;
}

.form-hint {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-top: 4px;
}

/* ===================================
   Dashboard Styles
   =================================== */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.stats-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.stat-card {
    background: var(--color-bg);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-md);
    text-align: center;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    border-top: 3px solid var(--color-border-light);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.stat-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.12);
}

.stat-card.stat-open { border-top-color: #d97706; }
.stat-card.stat-inprogress { border-top-color: #2563eb; }
.stat-card.stat-completed { border-top-color: #059669; }
.stat-card.stat-total { border-top-color: var(--color-primary); }

.stat-value {
    font-size: var(--font-size-xxxl);
    font-weight: 700;
    line-height: 1;
    margin-bottom: var(--spacing-xs);
}

.stat-card.stat-open .stat-value { color: #d97706; }
.stat-card.stat-inprogress .stat-value { color: #2563eb; }
.stat-card.stat-completed .stat-value { color: #059669; }
.stat-card.stat-total .stat-value { color: var(--color-primary); }

.stat-label {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    font-weight: 500;
}

.dashboard-nav {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.nav-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--spacing-lg);
    background: var(--color-bg);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06);
    border: 1px solid var(--color-border-light);
    text-decoration: none;
    color: var(--color-text);
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.nav-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.1);
    border-color: var(--color-primary);
}

.nav-card:active {
    transform: scale(0.98);
}

.nav-card-icon {
    width: 64px;
    height: 64px;
    background-color: #e8f1fb;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    margin-bottom: var(--spacing-md);
    transition: background-color 0.15s ease;
}

.nav-card:hover .nav-card-icon {
    background-color: #d4e6f9;
}

.nav-card-title {
    font-size: var(--font-size-lg);
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
}

.nav-card-desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    text-align: center;
}

/* Nav card text wrapper (for desktop horizontal layout) */
.nav-card-text {
    display: contents;
}

@media (max-width: 400px) {
    .dashboard-nav {
        grid-template-columns: 1fr;
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ===================================
   Home Dashboard — Responsive Layout
   =================================== */

/* Home container overrides the base .container max-width */
.home-container {
    justify-content: flex-start;
}

.home-layout {
    width: 100%;
}

/* Stats row: 4 columns on mobile wraps to 2x2 */
.home-container .stats-row {
    grid-template-columns: repeat(2, 1fr);
}

/* Dashboard Report panel */
.dash-report {
    background: var(--color-bg);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-lg);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    border: 1px solid var(--color-border-light);
}

/* 5-day weather card on the home dashboard */
.dash-weather {
    background: var(--color-bg);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-lg);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    border: 1px solid var(--color-border-light);
}
.dash-weather-title {
    font-size: 1rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 12px;
}
.dash-weather-body {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
}
.dash-weather-day {
    background: #f8fafc;
    border: 1px solid var(--color-border-light);
    border-radius: 10px;
    padding: 10px 6px;
    text-align: center;
}
.dash-weather-dow {
    font-size: 0.8rem;
    font-weight: 700;
    color: #0f172a;
}
.dash-weather-date {
    font-size: 0.72rem;
    color: #64748b;
    margin-bottom: 4px;
}
.dash-weather-icon {
    font-size: 28px;
    line-height: 1;
    margin: 4px 0;
}
.dash-weather-hi {
    font-size: 0.95rem;
    font-weight: 700;
    color: #0f172a;
}
.dash-weather-lo {
    font-size: 0.8rem;
    color: #64748b;
}
.dash-weather-empty {
    color: #64748b;
    font-size: 0.9rem;
    padding: 10px 0;
}

.dash-report-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--color-border-light);
}

.dash-report-title {
    font-size: var(--font-size-xl);
    font-weight: 700;
    margin: 0;
    color: var(--color-text);
}

.dash-report-viewall {
    font-size: var(--font-size-sm);
    color: var(--color-bg);
    background: var(--color-primary);
    text-decoration: none;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: var(--border-radius);
    transition: background 0.15s ease;
}

.dash-report-viewall:hover {
    background: var(--color-primary-dark);
    text-decoration: none;
}

.dash-report-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-lg);
}

.dash-report-table:last-child {
    margin-bottom: 0;
}

.dash-report-table th {
    text-align: right;
    font-weight: 600;
    color: var(--color-text-secondary);
    padding: var(--spacing-sm) var(--spacing-sm);
    border-bottom: 2px solid var(--color-border-light);
    white-space: nowrap;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.dash-report-table th:first-child {
    text-align: left;
}

.dash-report-table td {
    padding: var(--spacing-sm);
    border-bottom: 1px solid var(--color-border-light);
    color: var(--color-text);
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.dash-report-table td:first-child {
    text-align: left;
    font-weight: 600;
    color: var(--color-text);
}

.dash-report-table tbody tr {
    transition: background-color 0.1s;
}

.dash-report-table tbody tr:hover {
    background-color: var(--color-bg-secondary);
}

.dash-report-table tr:last-child td {
    border-bottom: none;
}

/* Highlight the "Day" column */
.dash-report-table td:last-child {
    font-weight: 700;
    color: var(--color-primary);
}

.dash-report-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-sm);
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.dash-report-label + .dash-report-table {
    margin-top: 0;
}

/* Divider between summary + tech sections */
.dash-report-divider {
    border: none;
    border-top: 1px solid var(--color-border-light);
    margin: var(--spacing-lg) 0;
}

/* ── Tech Home Nav (3 equal boxes) ── */
.tech-nav {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 1rem 0;
}
.tech-nav.hidden { display: none; }

.tech-nav-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: #fff;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    padding: 1.5rem 1rem;
    text-decoration: none;
    color: var(--color-text);
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
    transition: box-shadow 0.15s, border-color 0.15s;
}
.tech-nav-box:hover {
    border-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}
.tech-nav-box svg {
    stroke: var(--color-primary);
}
.tech-nav-title {
    font-size: 1.15rem;
    font-weight: 700;
}
.tech-nav-desc {
    font-size: 0.85rem;
    color: var(--color-text-muted);
}

/* ── My WOs Summary Card (Home Page) ── */
.my-wos-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-md) var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
    text-decoration: none;
    color: inherit;
    transition: box-shadow 0.15s, border-color 0.15s;
}

.my-wos-card:hover {
    border-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(0,120,212,0.15);
    text-decoration: none;
    color: inherit;
}

.my-wos-card-icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #e8f4fd;
    border-radius: var(--border-radius-lg);
    color: var(--color-primary);
}

.my-wos-card-body {
    flex: 1;
    min-width: 0;
}

.my-wos-card-title {
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--color-text);
}

.my-wos-card-subtitle {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}

.my-wos-card-chevron {
    flex-shrink: 0;
    color: var(--color-text-secondary);
}

/* ── My WOs List Page ─────────────────── */
.wo-filter-chips {
    display: flex;
    gap: 6px;
    margin: var(--spacing-md) 0 0;
}
.wo-filter-chip {
    flex: 1;
    padding: 5px 16px;
    font-size: var(--font-size-sm);
    font-weight: 600;
    border: 1px solid var(--color-border-light);
    border-radius: 20px;
    background: var(--color-bg);
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: all 0.15s;
}
.wo-filter-chip:hover { border-color: var(--color-primary); color: var(--color-primary); }
.wo-filter-chip.active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

.toggle-map-btn {
    padding: 4px 12px;
    font-size: 0.8rem;
    font-weight: 600;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: #fff;
    color: var(--color-text-muted);
    cursor: pointer;
    margin-left: auto;
}
.toggle-map-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }

.mywos-toolbar {
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.select-toggle-btn {
    width: 100%;
    padding: 8px 12px;
    font-size: var(--font-size-sm);
    font-weight: 600;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    color: var(--color-text-secondary);
    cursor: pointer;
}
.select-toggle-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
.select-toggle-btn.active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

.bulk-edit-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: var(--spacing-md) 0;
    flex-wrap: wrap;
}

.bulk-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--font-size-sm);
}
.bulk-bar.hidden { display: none; }

#bulk-count {
    font-weight: 600;
    color: var(--color-text-secondary);
}

.bulk-utc-btn {
    padding: 4px 14px;
    background: #fee2e2;
    color: #b91c1c;
    border: 1px solid #fecaca;
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
}
.bulk-utc-btn:hover { background: #fecaca; }
.bulk-utc-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.bulk-cancel-btn {
    padding: 4px 12px;
    background: none;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    cursor: pointer;
    color: var(--color-text-secondary);
}
.bulk-cancel-btn:hover { border-color: var(--color-text-secondary); }

.my-wo-card.selectable { cursor: pointer; }
.my-wo-card.wo-selected { border-color: #b91c1c; background: #fef2f2; }

/* Route Controls */
.route-controls {
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.route-input-row {
    display: flex;
    gap: var(--spacing-sm);
    align-items: center;
}

.route-gps-btn {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    color: var(--color-primary);
    cursor: pointer;
}

.route-gps-btn:hover {
    background: var(--color-bg-secondary);
}

.route-input {
    flex: 1 1 0;
    min-width: 0;
    height: 40px;
    padding: 0 var(--spacing-sm);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
}

.route-btn {
    flex-shrink: 0;
    height: 40px;
    padding: 0 var(--spacing-lg);
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    font-weight: 600;
    cursor: pointer;
}

.route-btn:hover {
    background: var(--color-primary-dark);
}

.route-clear-btn {
    flex-shrink: 0;
    height: 40px;
    padding: 0 var(--spacing-md);
    background: var(--color-bg-tertiary);
    color: var(--color-text);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    cursor: pointer;
}

.route-action-row {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-sm);
    align-items: center;
}

.route-limit-select {
    height: 40px;
    padding: 0 var(--spacing-sm);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    background: var(--color-bg);
    color: var(--color-text);
}

.route-note {
    font-size: 12px;
    color: var(--color-text-tertiary);
    margin-top: var(--spacing-sm);
    line-height: 1.4;
}

.route-status {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-top: var(--spacing-sm);
    min-height: 1.2em;
}

.route-status:empty {
    display: none;
}

.route-navigate-btn {
    display: inline-block;
    margin-top: var(--spacing-sm);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
}

.route-navigate-btn:hover {
    text-decoration: underline;
}

/* Route numbered markers on map */
.route-number-icon {
    background: none !important;
    border: none !important;
}

.route-number-marker {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

.route-start-marker {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #107c10;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}

.map-dot-icon {
    background: none !important;
    border: none !important;
}
.map-dot {
    border-radius: 50%;
    border: 2px solid #fff;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
    line-height: 1;
}
.map-dot.selected {
    border-color: #dd6b20;
    border-width: 3px;
}

.user-location-marker {
    position: relative;
    width: 18px;
    height: 18px;
    pointer-events: none;
}
.user-location-marker .dot {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 14px;
    height: 14px;
    margin: -7px 0 0 -7px;
    background: #1a73e8;
    border: 2px solid #fff;
    border-radius: 50%;
    box-shadow: 0 1px 4px rgba(0,0,0,0.35);
}
.user-location-marker .pulse {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 14px;
    height: 14px;
    margin: -7px 0 0 -7px;
    background: rgba(26,115,232,0.6);
    border-radius: 50%;
    animation: user-loc-pulse 2s ease-out infinite;
}
@keyframes user-loc-pulse {
    0%   { transform: scale(1);   opacity: 0.55; }
    100% { transform: scale(3.2); opacity: 0;    }
}

.locate-control {
    margin-top: 8px !important;
}
.locate-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    color: #444;
    background: #fff;
}
.locate-btn:hover {
    background: #f4f4f4;
    color: #1a73e8;
}
.locate-btn.locating {
    color: #1a73e8;
}
.locate-btn.locating svg {
    animation: locate-spin 1s linear infinite;
}
@keyframes locate-spin {
    to { transform: rotate(360deg); }
}

.fit-bounds-control {
    margin-top: 6px !important;
}
.fit-bounds-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    color: #444;
    background: #fff;
}
.fit-bounds-btn:hover {
    background: #f4f4f4;
    color: #1a73e8;
}

/* Route number badge on cards */
.wo-route-num {
    display: inline-block;
    background: var(--color-primary);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 3px;
    margin-right: 6px;
    vertical-align: middle;
}

.mywos-map {
    height: 350px;
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--color-border-light);
    margin-bottom: var(--spacing-lg);
}

.my-wos-list {
    display: grid;
    gap: var(--spacing-md);
    grid-template-columns: 1fr;
}

.my-wo-card {
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-md);
    display: flex;
    flex-direction: column;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.my-wo-card-done {
    opacity: 0.6;
}

.my-wo-card-appt {
    border-left: 4px solid #059669;
    background: #f0fdf4;
}

.my-wo-appt-badge {
    background: #059669;
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: var(--border-radius);
    margin-bottom: 8px;
    display: inline-block;
}

.my-wo-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-xs);
}

.my-wo-type {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--color-text-secondary);
}

.my-wo-status {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 4px;
    text-transform: capitalize;
}

.wo-status-open {
    background: #e8f4fd;
    color: #0078d4;
}

.wo-status-in-progress {
    background: #fff4ce;
    color: #8a6d00;
}

.wo-status-completed {
    background: #dff6dd;
    color: #107c10;
}

.wo-status-enroute {
    background: #fef3c7;
    color: #92400e;
}

/* ── WO Status Chips (Premises Table) ── */
.wo-chip {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 12px;
    white-space: nowrap;
}
.wo-chip-open {
    background: #dbeafe;
    color: #1d4ed8;
}
.wo-chip-enroute {
    background: #fef3c7;
    color: #92400e;
}
.wo-chip-inprogress {
    background: #fff4ce;
    color: #8a6d00;
}
.wo-chip-inreview {
    background: #ede9fe;
    color: #6d28d9;
}
.wo-chip-completed {
    background: #d1fae5;
    color: #065f46;
}
.wo-chip-closed {
    background: #e5e7eb;
    color: #6b7280;
}
.wo-chip-appt {
    background: #d1fae5;
    color: #065f46;
}

/* ── Bulk Select Checkbox Column ── */
.col-checkbox {
    width: 36px;
    min-width: 36px;
    max-width: 36px;
    text-align: center;
    padding: 4px !important;
}
.col-checkbox input[type="checkbox"] {
    cursor: pointer;
    width: 16px;
    height: 16px;
}

/* ── Bulk Action Toolbar ── */
.bulk-action-toolbar {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%) translateY(100%);
    background: #2d3748;
    color: #fff;
    padding: 10px 16px;
    border-radius: 8px 8px 0 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    z-index: 900;
    box-shadow: 0 -2px 10px rgba(0,0,0,.25);
    transition: transform .25s ease;
    max-width: calc(100vw - 32px);
}
.bulk-action-toolbar.visible {
    transform: translateX(-50%) translateY(0);
}
.bulk-row {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.bulk-header-row {
    padding-bottom: 2px;
    border-bottom: 1px solid rgba(255,255,255,.15);
    width: 100%;
}
.bulk-count {
    font-weight: 600;
    font-size: 0.9rem;
    margin-right: 4px;
}
.bulk-group-label {
    font-size: 0.7rem;
    color: rgba(255,255,255,.5);
    text-transform: uppercase;
    letter-spacing: .5px;
    min-width: 72px;
}
.bulk-btn {
    padding: 5px 10px;
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 4px;
    background: rgba(255,255,255,.1);
    color: #fff;
    font-size: 0.8rem;
    cursor: pointer;
    transition: opacity .15s;
}
.bulk-btn:hover {
    opacity: .8;
}
/* ── Multi-Select Filter ── */
.multi-filter-wrap { position: relative; }
.multi-filter-btn {
    width: 100%;
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: 3px;
    padding: 4px 6px;
    font-size: 0.75rem;
    cursor: pointer;
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: border-color 0.1s;
}
.multi-filter-btn:hover { border-color: var(--color-primary); }
.multi-filter-btn.active {
    border-color: var(--color-primary);
    color: var(--color-primary);
    font-weight: 600;
}
.multi-filter-panel {
    display: none;
    position: absolute;
    top: calc(100% + 2px);
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid var(--color-border-light);
    border-radius: 3px;
    min-width: 140px;
    max-height: 300px;
    overflow-y: auto;
    z-index: 500;
    padding: 4px 0;
    box-shadow: 0 2px 8px rgba(0,0,0,.1);
}
.multi-filter-panel.show { display: block; }
.multi-filter-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    font-size: 0.75rem;
    color: var(--color-text);
    white-space: nowrap;
    user-select: none;
    cursor: pointer;
}
.multi-filter-item:hover { background: #f7fafc; }
.multi-filter-item input[type="checkbox"] { accent-color: var(--color-primary); cursor: pointer; }

/* ── Date Range Filter ── */
.date-filter-wrap { position: relative; }
.date-filter-trigger {
    width: 100%;
    box-sizing: border-box;
    padding: 4px 6px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: 12px;
    font-family: inherit;
    background: var(--color-bg);
    color: var(--color-text-muted);
    cursor: pointer;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    outline: none;
}
.date-filter-trigger:hover { border-color: var(--color-primary); }
.date-filter-trigger.has-filter {
    color: var(--color-primary);
    border-color: var(--color-primary);
    background: #e8f4fd;
    font-weight: 600;
}
.date-filter-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    z-index: 9999;
    min-width: 240px;
    background: #fff;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 4px 12px rgba(0,0,0,0.12);
    padding: 10px;
}
.date-filter-preset-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 8px;
}
.date-filter-preset {
    padding: 4px 10px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    font-size: 12px;
    cursor: pointer;
    color: var(--color-text-muted);
    transition: all 0.15s;
}
.date-filter-preset:hover { background: #f0f0f0; border-color: var(--color-primary); }
.date-filter-preset.active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.date-filter-divider {
    font-size: 11px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 8px 0 6px;
    border-top: 1px solid var(--color-border-light);
    padding-top: 8px;
}
.date-filter-custom { display: flex; gap: 8px; margin-bottom: 10px; }
.date-filter-field { flex: 1; }
.date-filter-field label { display: block; font-size: 11px; color: var(--color-text-muted); margin-bottom: 2px; }
.date-filter-field input[type="date"] {
    width: 100%;
    box-sizing: border-box;
    padding: 4px 6px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: 12px;
    color: var(--color-text);
    background: var(--color-bg);
}
.date-filter-field input[type="date"]:focus { border-color: var(--color-primary); outline: none; }
.date-filter-btn-row { display: flex; gap: 6px; }
.date-filter-clear-btn, .date-filter-apply-btn {
    flex: 1;
    padding: 5px 0;
    border: none;
    border-radius: var(--border-radius);
    font-size: 12px;
    cursor: pointer;
}
.date-filter-clear-btn { background: #e5e7eb; color: var(--color-text-muted); }
.date-filter-clear-btn:hover { background: #d1d5db; }
.date-filter-apply-btn { background: var(--color-primary); color: #fff; }
.date-filter-apply-btn:hover { opacity: 0.9; }

.bulk-assign-select {
    padding: 5px 8px;
    border-radius: 4px;
    border: 1px solid rgba(255,255,255,.3);
    background: rgba(255,255,255,.15);
    color: #fff;
    font-size: 0.8rem;
    cursor: pointer;
}
.bulk-assign-select option {
    background: #2d3748;
    color: #fff;
}

.wo-status-closed {
    background: var(--color-bg-tertiary);
    color: var(--color-text-secondary);
}

.my-wo-enroute-time, .my-wo-onsite-time {
    display: block;
    font-size: 11px;
    color: #92400e;
    font-weight: 500;
}

.my-wo-onsite-time {
    color: #0078d4;
}

.my-wo-address {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--spacing-sm);
    line-height: 1.3;
}

.my-wo-meta {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-md);
}

.my-wo-visits {
    font-size: 12px;
}

.my-wo-actions-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 8px;
    margin-top: auto;
}

.my-wo-grid-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    font-weight: 600;
    padding: 12px 8px;
    border-radius: var(--border-radius);
    border: none;
    cursor: pointer;
    text-decoration: none;
    text-align: center;
    transition: background 0.15s;
}
.my-wo-grid-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.my-wo-tall-btn {
    grid-column: 2;
    grid-row: 1 / 3;
    font-size: 1.1rem;
}

.my-wo-utc-btn {
    background: #fee2e2;
    color: #b91c1c;
    border: 1px solid #fecaca;
}
.my-wo-utc-btn:hover { background: #fecaca; }

.my-wo-enroute-btn {
    background: #f59e0b;
    color: #fff;
}
.my-wo-enroute-btn:hover { background: #d97706; }

.my-wo-onsite-btn {
    background: #059669;
    color: #fff;
}
.my-wo-onsite-btn:hover { background: #047857; }

.my-wo-open-btn {
    background: #059669;
    color: #fff;
}
.my-wo-open-btn:hover { background: #047857; color: #fff; }

.my-wo-claim-btn {
    background: #7c3aed;
    color: #fff;
}
.my-wo-claim-btn:hover { background: #6d28d9; }
.my-wo-claimed-btn {
    background: #a78bfa;
    opacity: 0.7;
}

.my-wo-route-here-btn {
    background: var(--color-primary);
    color: #fff;
}
.my-wo-route-here-btn:hover { background: var(--color-primary-dark); }

@media (min-width: 600px) {
    .my-wos-list {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Hide reports on phone — users can tap the nav card instead */
@media (max-width: 599px) {
    .dash-report {
        display: none !important;
    }
}

/* Tablet: widen container */
@media (min-width: 600px) {
    .home-container {
        max-width: 720px;
    }

    .home-container .stats-row {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Desktop: two-panel layout */
@media (min-width: 1024px) {
    .home-container {
        max-width: 1200px;
    }

    .home-layout {
        display: grid;
        grid-template-columns: 300px 1fr;
        grid-template-rows: auto 1fr;
        gap: var(--spacing-xl);
        align-items: start;
    }

    .home-layout > .my-wos-card {
        grid-column: 2;
        grid-row: 1;
    }

    .home-sidebar {
        grid-column: 1;
        grid-row: 1 / -1;
    }

    .home-main {
        grid-column: 2;
        grid-row: 2;
    }

    /* Sidebar nav: single column, horizontal cards. Descriptions are hidden
       here — the menu is long enough that icon + title reads cleaner. */
    .home-sidebar .dashboard-nav {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .home-sidebar .nav-card {
        flex-direction: row;
        align-items: center;
        padding: 8px 12px;
        gap: var(--spacing-md);
    }

    .home-sidebar .nav-card-icon {
        width: 32px;
        height: 32px;
        margin-bottom: 0;
        flex-shrink: 0;
    }

    .home-sidebar .nav-card-icon svg {
        width: 18px;
        height: 18px;
    }

    .home-sidebar .nav-card-text {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
    }

    .home-sidebar .nav-card-title {
        font-size: var(--font-size-base);
    }

    .home-sidebar .nav-card-desc {
        display: none;
    }

    /* Stats: 4 columns on desktop */
    .home-container .stats-row {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ===================================
   Stats Page Styles
   =================================== */
.stats-section {
    background: var(--color-bg);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.stats-section .section-title {
    font-size: var(--font-size-lg);
    font-weight: 600;
    margin: 0 0 var(--spacing-md) 0;
    color: var(--color-text);
}

.stats-section .stats-row {
    margin-bottom: 0;
}

.stat-value.stat-warning {
    color: #d97706;
}

.stat-value.stat-success {
    color: var(--color-success);
}

.stats-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.stats-list-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--color-border-light);
}

.stats-list-item:last-child {
    border-bottom: none;
}

.stats-list-label {
    font-size: var(--font-size-base);
    color: var(--color-text);
}

.stats-list-value {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-primary);
}

.recent-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.recent-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm);
    background-color: var(--color-bg-secondary);
    border-radius: var(--border-radius);
    text-decoration: none;
    color: var(--color-text);
    transition: background-color 0.15s ease;
}

.recent-item:hover {
    background-color: var(--color-bg-tertiary);
}

.recent-item-main {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.recent-item-title {
    font-weight: 500;
}

.recent-item-date {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}

/* ===================================
   Map Page
   =================================== */
.map-page {
    height: 100dvh;
    overflow: hidden;
    display: grid;
    grid-template-rows: auto 1fr 22px; /* header, body, footer */
}

.map-page .app-header {
    grid-row: 1;
    position: relative; /* override sticky — no scrolling in grid */
}

/* Map Body: sidebar + map side by side */
.map-body {
    grid-row: 2;
    display: flex;
    min-height: 0;
    min-width: 0;
    position: relative;
    overflow: hidden;
}

/* Left Sidebar */
.map-sidebar {
    width: 280px;
    min-width: 280px;
    background: white;
    border-right: 1px solid #e2e8f0;
    overflow-y: auto;
    overflow-x: hidden;
    flex-shrink: 0;
    z-index: 20;
    transition: margin-left 0.25s ease, opacity 0.25s ease;
}

.map-sidebar.collapsed {
    margin-left: -280px;
    opacity: 0;
    pointer-events: none;
}

.map-sidebar-content {
    padding: 12px;
}

.map-sidebar-section {
    margin-bottom: 16px;
}

.map-sidebar-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.map-sidebar-section-title {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #4a5568;
}

.map-sidebar-link-btn {
    background: none;
    border: none;
    font-size: 0.75rem;
    color: #4299e1;
    cursor: pointer;
    padding: 0;
}

.map-sidebar-link-btn:hover {
    text-decoration: underline;
}

/* Filter Groups */
.map-filter-group {
    margin-bottom: 12px;
}

.map-filter-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    color: #718096;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 4px;
}

.map-filter-checks {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.map-check {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 6px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
    color: #2d3748;
    transition: background 0.1s;
}

.map-check:hover {
    background: #edf2f7;
}

.map-check input[type="checkbox"] {
    margin: 0;
    cursor: pointer;
    accent-color: #4299e1;
}

.map-filter-checks-row {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px 6px;
}
.map-check-inline {
    padding: 2px 6px;
    min-width: 36px;
    justify-content: center;
}

/* --- Layers floating panel & toggle button --- */
.map-layers-ctrl.active {
    background: #e2e8f0;
    color: #0078d4;
}

.map-layers-panel {
    position: absolute;
    top: 10px;
    right: 50px;
    z-index: 1000;
    width: 240px;
    max-height: 70vh;
    overflow-y: auto;
    background: white;
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
    border: 1px solid #e2e8f0;
}
.map-layers-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px 8px;
    border-bottom: 1px solid #edf2f7;
}
.map-layers-panel-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: #2d3748;
}
.map-layers-panel-close {
    background: none;
    border: none;
    font-size: 1.2rem;
    color: #a0aec0;
    cursor: pointer;
    padding: 0 2px;
    line-height: 1;
}
.map-layers-panel-close:hover {
    color: #4a5568;
}
.map-layers-panel-body {
    padding: 8px 12px 12px;
}
.map-layers-panel-body .map-filter-group {
    margin-bottom: 10px;
}
.map-layers-panel-body .map-filter-group:last-child {
    margin-bottom: 0;
}

/* --- Layer controls (radio buttons, color swatches, sliders) --- */
.map-layer-radios {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.map-radio {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 6px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
    color: #2d3748;
    transition: background 0.1s;
}
.map-radio:hover {
    background: #edf2f7;
}
.map-radio input[type="radio"] {
    margin: 0;
    cursor: pointer;
    accent-color: #4299e1;
}

.map-color-swatches {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.map-color-swatch-row {
    display: flex;
    align-items: center;
    gap: 3px;
    cursor: pointer;
    padding: 3px 4px;
    border-radius: 4px;
    border: 2px solid transparent;
    transition: border-color 0.15s, background 0.1s;
}
.map-color-swatch-row:hover {
    background: #f0f4f8;
}
.map-color-swatch-row.active {
    border-color: #0078d4;
}
.map-color-dot {
    width: 14px;
    height: 14px;
    border-radius: 3px;
    flex-shrink: 0;
}
.map-color-swatch-label {
    font-size: 0.78rem;
    color: #4a5568;
    margin-left: 4px;
}

.map-slider {
    width: 100%;
    accent-color: #0078d4;
    cursor: pointer;
    margin-top: 2px;
}

.map-legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 1.5px solid #fff;
    box-shadow: 0 0 0 1px rgba(0,0,0,0.15);
    flex-shrink: 0;
}

.map-filter-select {
    width: 100%;
    padding: 6px 8px;
    border: 1px solid #cbd5e0;
    border-radius: 4px;
    font-size: 0.85rem;
    color: #2d3748;
    background: white;
    cursor: pointer;
}

.map-filter-select:focus {
    border-color: #4299e1;
    box-shadow: 0 0 0 2px rgba(66, 153, 225, 0.15);
    outline: none;
}

/* Counts */
.map-footer {
    grid-row: 3;
    padding: 0 12px;
    background: #f7fafc;
    border-top: 1px solid #e2e8f0;
    display: flex;
    align-items: center;
    height: 22px;
    overflow: hidden;
    white-space: nowrap;
}
.map-footer .map-count-text {
    font-size: 0.72rem;
    line-height: 1;
}
.map-sidebar-counts {
    padding: 8px 0;
    border-top: 1px solid #edf2f7;
    border-bottom: 1px solid #edf2f7;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
/* Drawer buttons (City / Postal Code) */
.map-drawer-btn {
    width: 100%;
    padding: 6px 10px;
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.85rem;
    color: var(--color-text);
    font-family: inherit;
}
.map-drawer-btn:hover {
    background: var(--color-bg-tertiary);
}

/* Filter Drawer Panel (secondary sidebar) */
.map-zip-panel {
    width: 160px;
    min-width: 160px;
    background: white;
    border-right: 1px solid #e2e8f0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 0;
}
.map-zip-panel.hidden {
    display: none;
}
.map-zip-panel-header {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 10px 6px;
    border-bottom: 1px solid #edf2f7;
    flex-shrink: 0;
}
.map-zip-panel-title {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #4a5568;
}
.map-zip-picker-list {
    flex: 1 1 0;
    height: 0;
    overflow-y: auto;
    padding: 4px 0;
}
.map-zip-pick-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 3px 10px;
    font-size: 0.8rem;
    cursor: pointer;
    border-radius: 0;
}
.map-zip-pick-item:hover {
    background: var(--color-bg-tertiary);
}
.map-zip-pick-item input[type="checkbox"] {
    margin: 0;
    flex-shrink: 0;
}
.map-zip-pick-code {
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}
.map-zip-pick-count {
    margin-left: auto;
    color: var(--color-text-secondary);
    font-size: 0.75rem;
    font-variant-numeric: tabular-nums;
}

.map-count-text {
    font-size: 0.8rem;
    color: #718096;
    line-height: 1.4;
}

/* Zip code labels on map (detail view) */
.map-zip-label {
    background: rgba(255, 255, 255, 0.85) !important;
    border: 1px solid rgba(0, 0, 0, 0.15) !important;
    color: #2d3748;
    font-size: 11px;
    font-weight: 700;
    padding: 1px 5px;
    border-radius: 3px;
    white-space: nowrap;
    pointer-events: none;
    text-align: center;
    text-align: center;
}

/* Bulk Action Toolbar (fixed bottom bar) */
.map-bulk-toolbar {
    position: fixed;
    bottom: 0;
    left: 50%;
    width: 90%;
    max-width: 900px;
    background: #2d3748;
    color: white;
    padding: 10px 16px;
    border-radius: 8px 8px 0 0;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 1100;
    transform: translateX(-50%) translateY(100%);
    transition: transform 0.25s ease;
}
.map-bulk-row { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.map-bulk-label { font-size:0.75rem; font-weight:600; text-transform:uppercase; letter-spacing:0.04em; color:rgba(255,255,255,0.6); white-space:nowrap; }
.map-sched-btn { padding:4px 10px; border:none; border-radius:4px; font-size:0.78rem; font-weight:600; cursor:pointer; transition:opacity 0.15s; }
.map-sched-btn:hover { opacity:0.85; }
.map-sector-btn { padding:4px 10px; border:none; border-radius:4px; font-size:0.78rem; font-weight:600; cursor:pointer; transition:opacity 0.15s; }
.map-sector-btn:hover { opacity:0.85; }
.map-bulk-toolbar.visible {
    transform: translateX(-50%) translateY(0);
}
.map-bulk-count {
    font-weight: 600;
    font-size: 0.85rem;
    white-space: nowrap;
}
.map-bulk-sep {
    color: rgba(255, 255, 255, 0.3);
    font-weight: 300;
}
.map-bulk-select {
    padding: 5px 8px;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.1);
    color: white;
    font-size: 0.82rem;
    cursor: pointer;
    min-width: 120px;
}
.map-bulk-select option {
    background: #2d3748;
    color: white;
}
.map-bulk-assign-btn {
    padding: 6px 12px;
    border: none;
    border-radius: 4px;
    background: rgba(72, 187, 120, 0.4);
    border: 1px solid rgba(72, 187, 120, 0.6);
    color: white;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s;
}
.map-bulk-assign-btn:hover:not(:disabled) {
    background: rgba(72, 187, 120, 0.6);
}
.map-bulk-assign-btn:disabled {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
    color: rgba(255, 255, 255, 0.4);
    cursor: not-allowed;
}
.map-bulk-status {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.7);
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.map-bulk-status.success {
    color: #68d391;
}
.map-bulk-status.error {
    color: #fc8181;
}
.map-bulk-deselect {
    padding: 5px 10px;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.05);
    color: white;
    font-size: 0.82rem;
    cursor: pointer;
    white-space: nowrap;
    margin-left: auto;
    transition: background 0.15s;
}
.map-bulk-deselect:hover {
    background: rgba(255, 255, 255, 0.15);
}

/* Sidebar Toggle Button */
.map-sidebar-toggle {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 1000;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.12);
    cursor: pointer;
    color: #4a5568;
}

.map-sidebar-toggle:hover {
    background: #edf2f7;
}


/* Map Main Area */
.map-main {
    flex: 1;
    min-width: 0;
    position: relative;
    overflow: hidden;
}

.status-none {
    background: var(--color-bg-tertiary);
    color: var(--color-text-secondary);
}

.map-container {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.map-loading,
.map-main > .error-state,
.map-main > .empty-state {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: white;
    z-index: 5;
}

/* Rectangle Select Hint */
.map-rect-hint {
    position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 15;
    background: rgba(0, 0, 0, 0.7);
    color: white;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 0.8rem;
    pointer-events: none;
}

/* --- Collapsible Section Toggles --- */
.map-section-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: none;
    border: none;
    border-bottom: 1px solid #edf2f7;
    padding: 10px 0 8px;
    cursor: pointer;
    color: #4a5568;
}

.map-section-toggle-text {
    display: flex;
    align-items: center;
    gap: 6px;
}

.map-section-chevron {
    transition: transform 0.2s ease;
    flex-shrink: 0;
}

.map-section-toggle[aria-expanded="true"] .map-section-chevron {
    transform: rotate(90deg);
}

.map-section-body {
    overflow: hidden;
    transition: max-height 0.25s ease, opacity 0.2s ease;
    max-height: 800px;
    opacity: 1;
    padding-top: 8px;
}

.map-section-body.collapsed {
    max-height: 0;
    opacity: 0;
    padding-top: 0;
}

/* --- Active Filter Badge --- */
.map-filter-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: #4299e1;
    color: white;
    font-size: 0.7rem;
    font-weight: 600;
}

/* --- Active Filter Pills --- */
.map-filter-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 6px 0;
}

.map-filter-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    background: #ebf8ff;
    border: 1px solid #bee3f8;
    border-radius: 12px;
    font-size: 0.72rem;
    color: #2b6cb0;
    white-space: nowrap;
}

.map-filter-pill-x {
    cursor: pointer;
    background: none;
    border: none;
    padding: 0;
    font-size: 0.85rem;
    color: #4299e1;
    line-height: 1;
}

.map-filter-pill-x:hover {
    color: #e53e3e;
}

/* --- Address Search Input --- */
.map-filter-input {
    width: 100%;
    padding: 6px 8px;
    border: 1px solid #cbd5e0;
    border-radius: 4px;
    font-size: 0.85rem;
    color: #2d3748;
    background: white;
    box-sizing: border-box;
}

.map-filter-input:focus {
    border-color: #4299e1;
    box-shadow: 0 0 0 2px rgba(66, 153, 225, 0.15);
    outline: none;
}

.map-filter-input::placeholder {
    color: #a0aec0;
}

/* --- Select Area Button --- */


/* --- Leaflet control buttons — uniform size (top-right) --- */
.leaflet-control-zoom .leaflet-control-zoom-in,
.leaflet-control-zoom .leaflet-control-zoom-out,
.map-zoom-selected-btn,
.map-poly-draw-ctrl,
.map-layers-ctrl {
    width: 34px !important;
    height: 34px !important;
    line-height: 34px !important;
    font-size: 18px !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    background: white;
    cursor: pointer;
    color: #333;
    border: none;
    padding: 0;
}
.leaflet-control-zoom .leaflet-control-zoom-in:hover,
.leaflet-control-zoom .leaflet-control-zoom-out:hover,
.map-zoom-selected-btn:hover,
.map-poly-draw-ctrl:hover,
.map-layers-ctrl:hover {
    background: #f4f4f4;
}
.leaflet-control-zoom {
    width: 34px !important;
    overflow: hidden;
}
.leaflet-control-zoom .leaflet-control-zoom-in,
.leaflet-control-zoom .leaflet-control-zoom-out {
    width: 100% !important;
    border: none !important;
    border-bottom: 1px solid #ccc !important;
}
.leaflet-control-zoom .leaflet-control-zoom-out {
    border-bottom: none !important;
}
.map-poly-draw-ctrl.active {
    background: #4299e1;
    color: white;
}

/* --- Drawing Mode Cursor --- */
.map-drawing-mode {
    cursor: crosshair !important;
}

.map-drawing-mode .leaflet-container {
    cursor: crosshair !important;
}
.map-drawing-mode .leaflet-overlay-pane svg path,
.map-drawing-mode .leaflet-overlay-pane canvas {
    pointer-events: none !important;
}

/* --- Confirmation Dialog --- */
.map-confirm-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.map-confirm-dialog {
    background: white;
    border-radius: 8px;
    padding: 24px;
    max-width: 420px;
    width: 90%;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.map-confirm-dialog h3 {
    margin: 0 0 8px;
    font-size: 1rem;
}

.map-confirm-dialog p {
    margin: 0 0 16px;
    font-size: 0.9rem;
    color: #4a5568;
}

.map-confirm-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}

.map-confirm-actions button {
    padding: 8px 16px;
    border-radius: 4px;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    border: 1px solid #cbd5e0;
    background: white;
    color: #4a5568;
}

.map-confirm-actions .confirm-primary,
.map-confirm-dialog .confirm-primary {
    background: #4299e1;
    color: white;
    border-color: #3182ce;
    padding: 8px 16px;
    border-radius: 4px;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    border: 1px solid #3182ce;
}

.assign-progress-bar-wrap {
    width: 100%;
    height: 8px;
    background: #e2e8f0;
    border-radius: 4px;
    overflow: hidden;
    margin-top: 12px;
}

.assign-progress-bar {
    height: 100%;
    width: 0%;
    background: #4299e1;
    border-radius: 4px;
    transition: width 0.2s ease;
}

.assign-progress-list {
    max-height: 260px;
    overflow-y: auto;
    margin: 8px 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.assign-progress-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.82rem;
    font-family: monospace;
}

.assign-progress-row .assign-row-icon {
    width: 16px;
    text-align: center;
    flex-shrink: 0;
}

.assign-progress-row .assign-row-label {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.assign-progress-row .assign-row-status {
    font-size: 0.75rem;
    flex-shrink: 0;
}

.assign-progress-row.pending {
    color: #a0aec0;
}

.assign-progress-row.in-progress {
    background: #ebf8ff;
    color: #2b6cb0;
    font-weight: 600;
}

.assign-progress-row.success {
    color: #276749;
}

.assign-progress-row.success .assign-row-icon {
    color: #48bb78;
}

.assign-progress-row.error {
    color: #9b2c2c;
}

.assign-progress-row.error .assign-row-icon {
    color: #fc8181;
}

.assign-dialog-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    margin-top: 16px;
}

.assign-dialog-actions button {
    padding: 8px 16px;
    border-radius: 4px;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
}

.assign-dialog-actions .assign-done-btn {
    width: 100%;
}

.assign-summary {
    font-size: 0.9rem;
    color: #4a5568;
    margin: 0 0 8px;
}

/* Mobile: sidebar overlays as drawer */
@media (max-width: 600px) {
    .map-sidebar {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        width: 280px;
        box-shadow: 4px 0 16px rgba(0, 0, 0, 0.15);
    }

    .map-sidebar.collapsed {
        margin-left: -280px;
    }

    .map-zip-panel {
        display: none !important;
    }

    .map-filter-pills {
        max-height: 60px;
        overflow-y: auto;
    }

    .map-confirm-dialog {
        margin: 16px;
        max-width: none;
    }
}

/* Map popup styles */
.map-popup-container .leaflet-popup-content-wrapper {
    border-radius: var(--border-radius-lg);
    padding: 0;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

.map-popup-container .leaflet-popup-content {
    margin: 0;
    min-width: 200px;
}

.map-popup {
    padding: var(--spacing-md);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    font-size: var(--font-size-sm);
    line-height: 1.4;
}

.map-popup-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.map-popup-header strong {
    font-size: var(--font-size-base);
}

.map-popup-address {
    color: var(--color-text);
    margin-bottom: var(--spacing-xs);
}

.map-popup-serial {
    color: var(--color-text-secondary);
    font-size: 12px;
    margin-bottom: var(--spacing-sm);
}

.map-popup-issues {
    margin-bottom: var(--spacing-sm);
}

.map-popup-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 500;
    padding: 1px 6px;
    background-color: var(--color-bg-tertiary);
    border-radius: 10px;
    color: var(--color-text);
    margin-right: 3px;
    margin-bottom: 3px;
}

.map-popup-meta {
    font-size: 12px;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-sm);
}

.map-popup-link {
    display: inline-block;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
}

.map-popup-link:hover {
    text-decoration: underline;
}

.map-address-tooltip {
    font-size: var(--font-size-sm);
    padding: 4px 8px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
    border-radius: var(--border-radius);
    color: var(--color-text);
    white-space: nowrap;
}

/* Detail page mini-map */
.detail-map {
    height: 200px;
    border-radius: var(--border-radius);
    border: 1px solid var(--color-border-light);
}

/* Detail page layout */
.detail-container {
    max-width: 480px;
}

.form-fields-row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* ── Read-Only Detail View ── */
.detail-view {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    padding-bottom: var(--spacing-xl);
}

/* Top row: info + map */
.dv-top-row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

/* Next Action Banner */
.next-action-banner {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    border-radius: var(--border-radius);
    font-size: 14px;
    font-weight: 500;
}

.next-action-banner .na-label {
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.next-action-banner .na-step {
    font-weight: 600;
}

.next-action-banner .na-timing {
    margin-left: auto;
    font-size: 13px;
    font-weight: 600;
}

.next-action-banner.na-overdue {
    background: #fde8e8;
    border: 1px solid #f87171;
    color: #991b1b;
}

.next-action-banner.na-soon {
    background: #fef9e7;
    border: 1px solid #facc15;
    color: #92400e;
}

.next-action-banner.na-future {
    background: #e8f5e9;
    border: 1px solid #4ade80;
    color: #166534;
}

.next-action-banner.na-complete {
    background: #e8f5e9;
    border: 1px solid #4ade80;
    color: #166534;
}

/* Header: WO# + status badge */
.dv-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.dv-wo-num {
    font-size: 22px;
    font-weight: 700;
    color: var(--color-text);
    letter-spacing: -0.3px;
}

.dv-status {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 13px;
    font-weight: 600;
    text-transform: capitalize;
}

.dv-status.open { background: #fff4ce; color: #8a6d00; }
.dv-status.resolved { background: #dff6dd; color: #107c10; }
.dv-status.in_progress { background: #d6e8ff; color: #005a9e; }

/* Fields row */
.dv-fields {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md) var(--spacing-xl);
    margin-bottom: var(--spacing-md);
}

.dv-field {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dv-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dv-value {
    font-size: 15px;
    color: var(--color-text);
}

/* Issue pills */
.dv-issues {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: var(--spacing-md);
}

.dv-issue-pill {
    display: inline-block;
    padding: 5px 14px;
    border-radius: 16px;
    font-size: 13px;
    font-weight: 500;
    background: var(--color-primary);
    color: #fff;
}

/* Notes */
.dv-notes {
    margin-bottom: var(--spacing-sm);
}

.dv-notes-text {
    margin: 4px 0 0 0;
    font-size: 14px;
    color: var(--color-text);
    line-height: 1.5;
    white-space: pre-wrap;
}

/* Inline metadata row */
.dv-meta-inline {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md) var(--spacing-xl);
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border-light);
}

.dv-meta-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 13px;
    color: var(--color-text);
}

/* Map section */
.dv-map-section {
    min-height: 200px;
}

.dv-map-section .detail-map {
    height: 100%;
    min-height: 200px;
}

/* Action buttons */
.dv-actions {
    justify-content: flex-start;
    gap: var(--spacing-md);
}

/* Bigger photo thumbnails in read-only view */
.dv-photos-section .photo-thumbnails {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
}

/* Desktop: info + map side by side, photos full width */
@media (min-width: 1200px) {
    .dv-top-row {
        flex-direction: row;
        align-items: stretch;
    }

    .dv-info {
        flex: 1;
    }

    .dv-map-section {
        flex: 0 0 360px;
        min-height: 280px;
    }

    .dv-map-section .detail-map {
        height: 100%;
        min-height: 280px;
    }

    .dv-photos-section .photo-thumbnails {
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    }
}

/* ── Map Visit Number Labels ── */
.map-visit-label {
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    pointer-events: none;
}

/* ── Visit Carousel ── */
.visit-carousel {
    display: flex;
    gap: 12px;
    padding: 4px 2px var(--spacing-lg) 2px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}

.visit-carousel::-webkit-scrollbar {
    height: 4px;
}

.visit-carousel::-webkit-scrollbar-thumb {
    background: var(--color-border-light);
    border-radius: 2px;
}

.visit-card {
    flex: 0 0 190px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px 14px;
    border: 2px solid var(--color-border-light);
    border-radius: 10px;
    background: var(--color-surface);
    cursor: pointer;
    scroll-snap-align: start;
    transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.visit-card:hover {
    border-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(0, 90, 158, 0.12);
}

.visit-card.active {
    border-color: var(--color-primary);
    background: #f0f6ff;
    box-shadow: 0 2px 8px rgba(0, 90, 158, 0.18);
    cursor: default;
}

.visit-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.visit-card-num {
    font-weight: 700;
    font-size: 14px;
    color: var(--color-text);
}

.visit-card-date {
    font-size: 12px;
    color: var(--color-text-secondary);
}

.visit-card-issues {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.visit-card-tag {
    display: block;
    width: fit-content;
    padding: 2px 10px;
    border-radius: 10px;
    background: #e8ecf0;
    font-size: 11px;
    font-weight: 500;
    color: #333;
}

.visit-card.active .visit-card-tag {
    background: #d6e4f5;
}

.visit-card-footer {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--color-text-secondary);
    margin-top: auto;
}

.visit-card-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.visit-card-dot.open { background: #d4a017; }
.visit-card-dot.resolved { background: #107c10; }
.visit-card-dot.in_progress { background: #005a9e; }

.visit-card-status {
    font-weight: 600;
    text-transform: capitalize;
}

.visit-card-photos {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    opacity: 0.7;
}

.visit-card-tech {
    font-size: 11px;
    color: var(--color-text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.visit-gap-chip {
    display: flex;
    align-items: center;
    align-self: center;
    flex-shrink: 0;
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-secondary);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border-light);
    border-radius: 12px;
    padding: 2px 8px;
    white-space: nowrap;
}

.visit-gap-red {
    background: #fde8e8;
    border-color: #f87171;
    color: #dc2626;
}

.visit-gap-yellow {
    background: #fef9e7;
    border-color: #facc15;
    color: #a16207;
}

.visit-gap-green {
    background: #e8f5e9;
    border-color: #4ade80;
    color: #16a34a;
}

/* Tablet: widen detail */
@media (min-width: 600px) {
    .detail-container {
        max-width: 640px;
    }

    .visit-card {
        flex: 0 0 210px;
    }
}

/* Desktop */
@media (min-width: 768px) {
    .detail-container {
        max-width: 960px;
    }

    .visit-card {
        flex: 0 0 220px;
        scroll-snap-align: center;
    }

    .detail-container .form-fields-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-md);
    }

    .detail-container .checkbox-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
    }

    .detail-container .checkbox-item-wide {
        grid-column: 1 / -1;
    }

    .detail-container .metadata-grid {
        flex-direction: row;
        gap: var(--spacing-lg);
    }

    .detail-container .button-row {
        justify-content: flex-end;
        gap: var(--spacing-md);
    }
}

/* Large desktop: two-column form sections */
@media (min-width: 1200px) {
    .detail-container {
        max-width: 1400px;
        padding-left: var(--spacing-xl);
        padding-right: var(--spacing-xl);
    }

    .detail-container .issue-form {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-lg);
    }

    /* WO Details section spans full width */
    .detail-container .issue-form > .form-section:first-child {
        grid-column: 1 / -1;
    }

    /* Button row spans full width */
    .detail-container .issue-form > .button-row {
        grid-column: 1 / -1;
    }

    /* Error message spans full width */
    .detail-container .issue-form > .error-message {
        grid-column: 1 / -1;
    }

    .detail-container .checkbox-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Full HD+ */
@media (min-width: 1600px) {
    .detail-container {
        max-width: 1600px;
    }

    /* WO Details: 3 fields in a row */
    .detail-container .form-fields-row {
        grid-template-columns: 1fr 1fr 1fr;
    }

    .detail-container .checkbox-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ===================================
   Manage Data Page
   =================================== */

/* Feedback banner */
.manage-feedback {
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-md);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    font-weight: 500;
}

.manage-feedback-success {
    background: #dff6dd;
    color: #107c10;
    border: 1px solid #a7e3a5;
}

.manage-feedback-danger {
    background: #fde7e9;
    color: #a80000;
    border: 1px solid #f1bbbc;
}

.manage-feedback-error {
    background: #fde7e9;
    color: #a80000;
    border: 1px solid #f1bbbc;
}

/* Table layout */
.manage-table-wrap {
    background: white;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow-x: auto;
}

.manage-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.manage-table thead th {
    background: #f7fafc;
    padding: 10px 12px;
    text-align: left;
    font-weight: 600;
    font-size: 0.8rem;
    color: #4a5568;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 2px solid #e2e8f0;
    white-space: nowrap;
}

.manage-table tbody td {
    padding: 10px 12px;
    border-bottom: 1px solid #f0f0f0;
    vertical-align: middle;
    font-size: 0.85rem;
    color: #2d3748;
}

.manage-table tbody tr:last-child td {
    border-bottom: none;
}

.manage-table tbody tr:hover {
    background: #ebf8ff;
}

.manage-data-label {
    font-weight: 600;
    color: var(--color-text);
}

.manage-count {
    font-weight: 400;
    color: var(--color-text-secondary);
    font-size: 13px;
}

.manage-cell-empty {
    color: var(--color-border);
    text-align: center;
}

/* Buttons */
.manage-btn {
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--border-radius);
    border: 1px solid;
    cursor: pointer;
    background: transparent;
    white-space: nowrap;
}

.manage-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.manage-btn-default {
    color: var(--color-primary);
    border-color: #c7dff7;
}

.manage-btn-default:hover:not(:disabled) {
    background: #f0f6ff;
}

.manage-btn-danger {
    color: var(--color-danger);
    border-color: #f1bbbc;
}

.manage-btn-danger:hover:not(:disabled) {
    background: #fde7e9;
}

.manage-btn-cancel {
    color: var(--color-text-secondary);
    border-color: var(--color-border-light);
}

.manage-btn-cancel:hover:not(:disabled) {
    background: var(--color-bg-tertiary);
}

/* Hidden file inputs */
.manage-file-hidden {
    display: none;
}

/* Import preview panel */
.manage-preview {
    margin-top: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--color-bg-tertiary);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    font-size: var(--font-size-sm);
    color: var(--color-text);
}

.manage-preview-actions {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
}

/* Column Mapping Panel */
.mapping-panel {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius);
    padding: var(--spacing-lg);
    margin-top: var(--spacing-lg);
}

.mapping-title {
    font-size: var(--font-size-lg);
    font-weight: 600;
    margin: 0 0 var(--spacing-xs) 0;
}

.mapping-hint {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin: 0 0 var(--spacing-md) 0;
}

.mapping-fields {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.mapping-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.mapping-label {
    min-width: 100px;
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text);
}

.mapping-select {
    flex: 1;
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-sm);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    color: var(--color-text);
}

.mapping-sample {
    margin-top: var(--spacing-md);
}

.mapping-sample-title {
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-xs);
}

.mapping-sample-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-sm);
}

.mapping-sample-table th,
.mapping-sample-table td {
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 1px solid var(--color-border-light);
    text-align: left;
}

.mapping-sample-table th {
    background: var(--color-bg-secondary);
    font-weight: 500;
}

.mapping-empty {
    color: var(--color-text-tertiary);
}

/* ===================================
   Autocomplete Dropdown
   =================================== */
.autocomplete-dropdown {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    z-index: 100;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-top: none;
    border-radius: 0 0 var(--border-radius) var(--border-radius);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    max-height: 200px;
    overflow-y: auto;
}

.autocomplete-item {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
    cursor: pointer;
    border-bottom: 1px solid var(--color-border-light);
}

.autocomplete-item:last-child {
    border-bottom: none;
}

.autocomplete-item:hover,
.autocomplete-item.active {
    background: var(--color-bg-tertiary);
}

.autocomplete-dropdown.hidden {
    display: none;
}

/* ===================================
   Meters Data Table
   =================================== */

.datatable-wrapper {
    background: white;
    border-radius: 8px;
    padding: 16px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.datatable-container {
    /* Scrolling handled by parent .table-scroll-area */
}

.datatable-table {
    border-collapse: separate;
    border-spacing: 0;
    table-layout: fixed;
    width: 100%;
}

/* Header row (first row in thead) */
.datatable-table thead tr:first-child th {
    background: #f7fafc;
    position: sticky;
    top: 0;
    z-index: 10;
    color: #4a5568;
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 10px 12px;
    border-bottom: 2px solid #e2e8f0;
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
    text-align: left;
}

.datatable-table thead tr:first-child th:hover {
    background: #edf2f7;
}

.datatable-table td {
    padding: 10px 12px;
    border-bottom: 1px solid #f0f0f0;
    font-size: 0.85rem;
    color: #2d3748;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: left;
}

.datatable-table tbody tr {
    cursor: pointer;
    transition: background 0.1s;
}

.datatable-table tbody tr:hover {
    background: #ebf8ff;
}

/* Column Resize Handle */
.datatable-table th {
    position: relative;
}

.col-resize {
    position: absolute;
    top: 0;
    right: -3px;
    width: 6px;
    height: 100%;
    cursor: col-resize;
    z-index: 11;
}

.col-resize:hover,
.col-resize.active {
    background: var(--color-primary);
    opacity: 0.4;
}

/* Filter Row (second row in thead — below headers) */
.filter-row th {
    background: #edf2f7;
    padding: 6px 8px;
    border-bottom: 1px solid #e2e8f0;
    position: sticky;
    top: 37px;
    z-index: 9;
    cursor: default;
    height: 36px;
}

.filter-row th:hover {
    background: #edf2f7;
}

/* Per-Column Filter Inputs & Selects */
.col-filter-input,
.col-filter-select {
    width: 100%;
    box-sizing: border-box;
    padding: 4px 6px;
    border: 1px solid #cbd5e0;
    border-radius: 4px;
    font-size: 0.8rem;
    color: #2d3748;
    background: white;
    outline: none;
    font-family: inherit;
    transition: border-color 0.15s;
}

.col-filter-input:focus,
.col-filter-select:focus {
    border-color: #4299e1;
    box-shadow: 0 0 0 2px rgba(66, 153, 225, 0.15);
}

.col-filter-input::placeholder {
    color: var(--color-border);
}

.col-filter-select {
    cursor: pointer;
}

/* Address filter: text input + blank/not-blank toggle side by side */
.address-filter-wrap {
    display: flex;
    gap: 4px;
    align-items: stretch;
    width: 100%;
}
.address-filter-wrap .address-filter-text {
    flex: 1 1 auto;
    min-width: 0;
}
.address-filter-wrap .address-filter-text:disabled {
    background: #f3f4f6;
    color: #9ca3af;
}
.address-filter-toggle {
    flex: 0 0 auto;
    width: 78px;
    padding: 4px 4px;
    border: 1px solid #cbd5e0;
    border-radius: 4px;
    font-size: 0.72rem;
    color: #2d3748;
    background: white;
    cursor: pointer;
    font-family: inherit;
}
.address-filter-toggle:focus {
    outline: none;
    border-color: #4299e1;
}

/* DNC filter button + chip */
.dnc-filter-btn {
    flex: 0 0 auto;
    padding: 4px 10px;
    border: 1px solid #cbd5e0;
    border-radius: 4px;
    font-size: 0.72rem;
    font-weight: 700;
    color: #4a5568;
    background: white;
    cursor: pointer;
    font-family: inherit;
    letter-spacing: 0.03em;
}
.dnc-filter-btn:hover { border-color: #dc2626; color: #dc2626; }
.dnc-filter-btn.active {
    background: #fee2e2;
    color: #991b1b;
    border-color: #dc2626;
}
.dnc-chip {
    display: inline-block;
    padding: 1px 6px;
    margin-left: 4px;
    border-radius: 3px;
    background: #fee2e2;
    color: #991b1b;
    font-size: 10px;
    font-weight: 700;
    vertical-align: middle;
}

/* Filter Pills */
.filter-pills-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    padding: var(--spacing-sm) var(--spacing-md);
    border-bottom: 1px solid var(--color-border-light);
}

.filter-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 10px;
    font-size: 12px;
    font-weight: 500;
    background: #e8f4fd;
    color: var(--color-primary-dark);
    border: 1px solid #b3d9f2;
    border-radius: 9999px;
    white-space: nowrap;
}

.filter-pill-label {
    color: var(--color-primary);
}

.filter-pill-x {
    background: none;
    border: none;
    cursor: pointer;
    color: #93c5fd;
    padding: 0;
    margin-left: 2px;
    line-height: 1;
}

.filter-pill-x:hover {
    color: var(--color-primary-dark);
}

.filter-clear-all {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-secondary);
    background: none;
    border: 1px solid var(--color-border-light);
    border-radius: 9999px;
    padding: 2px 10px;
    cursor: pointer;
}

.filter-clear-all:hover {
    background: var(--color-bg-tertiary);
    color: var(--color-text);
}

/* Column Picker (Gear Icon) */
.col-picker-wrap {
    position: relative;
}

.col-picker-btn {
    background: none;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    padding: 6px 10px;
    font-size: 1.1rem;
    cursor: pointer;
    color: var(--color-text-secondary);
}

.col-picker-btn:hover {
    background: var(--color-bg-tertiary);
    color: var(--color-text);
}

.col-picker-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    min-width: 180px;
    max-height: 60vh;
    overflow-y: auto;
    z-index: 200;
    padding: 6px 0;
}

.col-picker-dropdown.show {
    display: block;
}

.col-picker-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: 6px 14px;
    cursor: pointer;
    font-size: var(--font-size-sm);
    color: var(--color-text);
    user-select: none;
}

.col-picker-item:hover {
    background: var(--color-bg-secondary);
}

.col-picker-item.disabled {
    opacity: 0.45;
    cursor: default;
}

.col-picker-item input[type="checkbox"] {
    accent-color: var(--color-primary);
}

/* Export CSV Button */
.export-csv-btn {
    background: none;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    padding: 6px 10px;
    cursor: pointer;
    color: var(--color-text-secondary);
    display: flex;
    align-items: center;
    margin-left: auto;
}

.export-csv-btn:hover {
    background: var(--color-bg-tertiary);
    color: var(--color-text);
}

/* Data Table Toolbars */
.meters-toolbar,
.issues-toolbar,
.users-toolbar,
.premises-toolbar,
.feedback-toolbar {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    border-bottom: 1px solid var(--color-border-light);
    background: var(--color-bg);
    flex-shrink: 0;
}

/* Pagination (sits outside .table-scroll-area, fixed at bottom) */
.datatable-bottom {
    padding: 12px 0 0 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.8rem;
    color: #718096;
    flex-wrap: wrap;
    gap: 8px;
    border-top: 1px solid #e2e8f0;
    background: white;
    flex-shrink: 0;
    border-radius: 0 0 8px 8px;
}

.datatable-bottom .datatable-info { order: 1; }
.datatable-bottom .datatable-pagination { order: 2; }
.datatable-bottom .datatable-dropdown { order: 3; margin-left: auto; }

.datatable-pagination .datatable-pagination-list {
    display: flex;
    gap: 4px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.datatable-pagination .datatable-pagination-list li button {
    padding: 4px 10px;
    border-radius: 4px;
    border: 1px solid #e2e8f0;
    background: white;
    color: #4a5568;
    cursor: pointer;
    font-size: 0.8rem;
    text-decoration: none;
}

.datatable-pagination .datatable-pagination-list li.datatable-active button {
    background: #4299e1;
    color: white;
    border-color: #4299e1;
}

.datatable-bottom select {
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    background: var(--color-bg);
}

/* ===================================
   Multi-Select Checkbox Filter
   =================================== */
.col-filter-multi {
    position: relative;
    width: 100%;
}

.col-filter-multi-btn {
    width: 100%;
    box-sizing: border-box;
    padding: 4px 6px;
    border: 1px solid #cbd5e0;
    border-radius: 4px;
    font-size: 0.75rem;
    color: #2d3748;
    background: white;
    cursor: pointer;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: border-color 0.15s;
}

.col-filter-multi-btn:hover {
    border-color: #a0aec0;
}

.col-filter-multi-btn.active {
    border-color: #4299e1;
    color: #2b6cb0;
    background: #ebf8ff;
}

.col-filter-multi-dd {
    display: none;
    position: absolute;
    top: calc(100% + 2px);
    left: 0;
    min-width: 100%;
    max-height: 250px;
    overflow-y: auto;
    background: white;
    border: 1px solid #cbd5e0;
    border-radius: 4px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    z-index: 50;
    padding: 4px 0;
}

.col-filter-multi-dd.show {
    display: block;
}

.col-filter-multi-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    font-size: 0.75rem;
    cursor: pointer;
    white-space: nowrap;
}

.col-filter-multi-item:hover {
    background: #edf2f7;
}

.col-filter-multi-item input[type="checkbox"] {
    margin: 0;
    cursor: pointer;
}

.col-filter-multi-all {
    border-bottom: 1px solid #e2e8f0;
    margin-bottom: 2px;
    padding-bottom: 4px;
}

/* ===================================
   Column Picker Handle & Drag
   =================================== */
.col-picker-handle {
    cursor: grab;
    color: var(--color-text-secondary);
    font-size: 1.1rem;
    line-height: 1;
    padding: 0 2px;
}

.col-picker-item.dragging {
    opacity: 0.4;
}

.col-picker-item.drag-over {
    border-top: 2px solid var(--color-primary);
}

/* ===================================
   Row Actions Button
   =================================== */
.col-actions {
    width: 40px;
    text-align: center;
}

.row-actions-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1.1rem;
    color: var(--color-text-secondary);
    padding: 2px 6px;
    border-radius: var(--border-radius);
    line-height: 1;
    letter-spacing: 1px;
}

.row-actions-btn:hover {
    background: var(--color-bg-tertiary);
    color: var(--color-text);
}

/* ===================================
   Feedback Badge Styles
   =================================== */
.feedback-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
    text-transform: capitalize;
}

.feedback-type-bug { background: #fed7d7; color: #c53030; }
.feedback-type-feature { background: #bee3f8; color: #2b6cb0; }
.feedback-type-question { background: #e2e8f0; color: #4a5568; }
.feedback-priority-critical { background: #fed7d7; color: #c53030; }
.feedback-priority-high { background: #feb2b2; color: #9b2c2c; }
.feedback-priority-medium { background: #fefcbf; color: #975a16; }
.feedback-priority-low { background: #e2e8f0; color: #4a5568; }
.feedback-status-open { background: #bee3f8; color: #2b6cb0; }
.feedback-status-in-progress,
.feedback-status-in_progress { background: #fefcbf; color: #975a16; }
.feedback-status-resolved { background: #c6f6d5; color: #276749; }
.feedback-status-closed { background: #e2e8f0; color: #4a5568; }

/* ===================================
   Feedback Page Layout
   =================================== */
.feedback-page {
    max-width: 100%;
    padding: var(--spacing-md);
}

@media (min-width: 768px) {
    .feedback-page {
        max-width: 100%;
    }
}

/* ===================================
   Feedback Dialog / Modal
   =================================== */
.feedback-dialog {
    border: none;
    border-radius: 0;
    box-shadow: -4px 0 24px rgba(0, 0, 0, 0.15);
    padding: 0;
    margin: 0;
    width: clamp(480px, 55vw, 900px);
    max-width: 100vw;
    height: 100vh;
    max-height: 100vh;
    position: fixed;
    top: 0;
    right: 0;
    left: auto;
    transform: translateX(0);
}

.feedback-dialog::backdrop {
    background: rgba(0, 0, 0, 0.4);
}

.feedback-modal-content {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.feedback-dialog form {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* Keep the smaller confirm-delete dialog centered like a regular modal */
#confirm-delete-dialog.feedback-dialog {
    width: 90%;
    max-width: 360px;
    height: auto;
    max-height: 90vh;
    top: 50%;
    right: auto;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}

.feedback-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--color-border-light);
}

.feedback-modal-header h3 {
    margin: 0;
    font-size: var(--font-size-lg);
    color: var(--color-text);
}

.feedback-modal-close-btn {
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--color-text-secondary);
    padding: 0 4px;
    line-height: 1;
}

.feedback-modal-close-btn:hover {
    color: var(--color-text);
}

.feedback-modal-body {
    padding: var(--spacing-md);
    overflow-y: auto;
    flex: 1;
    min-height: 0;
}

.feedback-modal-body .form-group {
    margin-bottom: var(--spacing-md);
}

.feedback-modal-footer {
    display: flex;
    align-items: center;
    padding: var(--spacing-md);
    border-top: 1px solid var(--color-border-light);
    gap: var(--spacing-sm);
}

.btn-secondary {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    color: var(--color-text);
    cursor: pointer;
    font-size: var(--font-size-sm);
}

.btn-secondary:hover {
    background: var(--color-bg-tertiary);
}

/* Feedback Attachment */
.fb-attachment-label {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    border: 1px dashed var(--color-border);
    border-radius: var(--border-radius);
    cursor: pointer;
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    transition: border-color .15s, color .15s;
}
.fb-attachment-label:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}
.fb-preview-wrap {
    position: relative;
    display: inline-block;
    margin-top: 8px;
}
.fb-preview-wrap img {
    max-height: 200px;
    border-radius: var(--border-radius);
    border: 1px solid var(--color-border-light);
}
.fb-preview-remove {
    position: absolute;
    top: -6px;
    right: -6px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: none;
    background: #333;
    color: #fff;
    font-size: 14px;
    line-height: 22px;
    text-align: center;
    cursor: pointer;
    padding: 0;
}

/* ===================================
   Toast Notifications
   =================================== */
.toast-container {
    position: fixed;
    bottom: var(--spacing-lg);
    right: var(--spacing-lg);
    z-index: 10000;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.toast {
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--border-radius);
    color: white;
    font-size: var(--font-size-sm);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    animation: toast-in 0.3s ease;
}

.toast-success { background: var(--color-success); }
.toast-error { background: var(--color-danger); }
.toast-info { background: var(--color-primary); }

.toast-fade {
    opacity: 0;
    transition: opacity 0.3s ease;
}

@keyframes toast-in {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ===================================
   Date Range Filter (Issues Log)
   =================================== */

.date-filter-wrap {
    position: relative;
}

.date-filter-trigger {
    width: 100%;
    box-sizing: border-box;
    padding: 4px 6px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: 12px;
    font-family: inherit;
    background: var(--color-bg);
    color: var(--color-text-secondary);
    cursor: pointer;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    outline: none;
}

.date-filter-trigger:hover {
    border-color: var(--color-border);
}

.date-filter-trigger.has-filter {
    color: var(--color-primary-dark);
    border-color: var(--color-primary);
    background: #e8f4fd;
}

.date-filter-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    z-index: 9999;
    min-width: 240px;
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
    padding: 10px;
}

.date-filter-preset-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 8px;
}

.date-filter-preset {
    padding: 4px 10px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg-secondary);
    font-size: 12px;
    font-family: inherit;
    cursor: pointer;
    color: var(--color-text-secondary);
    transition: all 0.15s;
}

.date-filter-preset:hover {
    background: var(--color-bg-tertiary);
    border-color: var(--color-border);
}

.date-filter-preset.active {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.date-filter-divider {
    font-size: 11px;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 8px 0 6px;
    border-top: 1px solid var(--color-border-light);
    padding-top: 8px;
}

.date-filter-custom {
    display: flex;
    gap: 8px;
    margin-bottom: 10px;
}

.date-filter-field {
    flex: 1;
}

.date-filter-field label {
    display: block;
    font-size: 11px;
    color: var(--color-text-secondary);
    margin-bottom: 2px;
}

.date-filter-field input[type="date"] {
    width: 100%;
    box-sizing: border-box;
    padding: 4px 6px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    font-size: 12px;
    font-family: inherit;
    color: var(--color-text);
    background: var(--color-bg);
}

.date-filter-field input[type="date"]:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(0, 120, 212, 0.15);
    outline: none;
}

.date-filter-btn-row {
    display: flex;
    gap: 6px;
}

.date-filter-clear-btn,
.date-filter-apply-btn {
    flex: 1;
    padding: 5px 0;
    border: none;
    border-radius: var(--border-radius);
    font-size: 12px;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.15s;
}

.date-filter-clear-btn {
    background: var(--color-bg-tertiary);
    color: var(--color-text-secondary);
}

.date-filter-clear-btn:hover {
    background: var(--color-border-light);
}

.date-filter-apply-btn {
    background: var(--color-primary);
    color: #fff;
}

.date-filter-apply-btn:hover {
    background: var(--color-primary-dark);
}

/* ===================================
   Duplicate WO# Highlight
   =================================== */

.wo-duplicate {
    color: var(--color-warning);
    font-weight: 600;
}

.wo-dup-badge {
    display: inline-block;
    background: var(--color-warning);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    line-height: 1;
    padding: 2px 5px;
    border-radius: 9999px;
    vertical-align: middle;
}

.col-dup_count {
    text-align: center;
}

.dups-toggle-btn {
    padding: 4px 10px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    font-size: 12px;
    font-family: inherit;
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: all 0.15s;
    margin-right: 4px;
}

.dups-toggle-btn:hover {
    background: var(--color-bg-tertiary);
    border-color: var(--color-border);
}

.dups-toggle-btn.active {
    background: var(--color-warning);
    color: #fff;
    border-color: var(--color-warning);
}

/* ===================================
   Multiselect Filter Dropdown
   =================================== */

.multiselect-filter-wrap {
    position: relative;
}

.multiselect-filter-trigger {
    width: 100%;
    box-sizing: border-box;
    padding: 4px 8px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    font-size: 12px;
    font-family: inherit;
    color: var(--color-text-secondary);
    cursor: pointer;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.multiselect-filter-trigger:hover {
    border-color: var(--color-border);
}

.multiselect-filter-trigger.has-filter {
    color: var(--color-primary-dark);
    border-color: var(--color-primary);
    background: var(--color-primary-bg, rgba(0, 120, 212, 0.06));
}

.multiselect-filter-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    min-width: 180px;
    max-width: 260px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
    z-index: 200;
    padding: 4px 0;
}

.multiselect-action-row {
    display: flex;
    gap: 4px;
    padding: 4px 8px 6px;
    border-bottom: 1px solid var(--color-border-light);
}

.multiselect-action-row button {
    flex: 1;
    padding: 3px 6px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    font-size: 11px;
    font-family: inherit;
    color: var(--color-text-secondary);
    cursor: pointer;
}

.multiselect-action-row button:hover {
    background: var(--color-bg-tertiary);
    border-color: var(--color-border);
}

.multiselect-list {
    max-height: 220px;
    overflow-y: auto;
    padding: 4px 0;
}

.multiselect-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    font-size: 12px;
    color: var(--color-text);
    cursor: pointer;
    white-space: nowrap;
}

.multiselect-item:hover {
    background: var(--color-bg-tertiary);
}

.multiselect-item input[type="checkbox"] {
    margin: 0;
    cursor: pointer;
}

/* ===== Photo Gallery ===== */

.gallery-container {
    max-width: 1200px;
}

.gallery-filter-bar {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-md);
}

/* Multi-select dropdown */
.gf-multi {
    position: relative;
}

.gf-multi-btn {
    padding: 5px 10px;
    font-size: var(--font-size-sm);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    cursor: pointer;
    white-space: nowrap;
}

.gf-multi-btn.gf-multi-active {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: #e8f0fe;
}

.gf-multi-panel {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 50;
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    min-width: 160px;
    max-height: 240px;
    overflow-y: auto;
    padding: 4px 0;
    margin-top: 2px;
}

.gf-multi.open .gf-multi-panel {
    display: block;
}

.gf-multi-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px;
    font-size: var(--font-size-sm);
    cursor: pointer;
    white-space: nowrap;
}

.gf-multi-item:hover {
    background: var(--color-bg-secondary);
}

.gf-multi-item input[type="checkbox"] {
    margin: 0;
    cursor: pointer;
}

/* Clear button */
.gallery-filter-clear {
    padding: 5px 12px;
    font-size: var(--font-size-sm);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    background: var(--color-bg);
    cursor: pointer;
    color: var(--color-text-secondary);
}

.gallery-filter-clear:hover {
    background: var(--color-bg-secondary);
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.gallery-card {
    position: relative;
    border-radius: var(--border-radius);
    overflow: hidden;
    cursor: pointer;
    aspect-ratio: 1;
    background: var(--color-bg-tertiary);
}

.gallery-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.2s;
}

.gallery-card:hover img {
    transform: scale(1.05);
}

.gallery-card-overlay {
    position: absolute;
    top: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 3px;
    padding: 5px;
}

.gallery-tag {
    font-size: 9px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 3px;
    white-space: nowrap;
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
}

.gallery-wo-link {
    color: #90cdf4;
    text-decoration: none;
}

.gallery-issue-tag {
    color: #ffd;
}

.gallery-card-badge {
    color: #ccc;
}

.gallery-status-open {
    background: #fff3cd;
    color: #856404;
}

.gallery-status-in_progress {
    background: #cce5ff;
    color: #004085;
}

.gallery-status-resolved {
    background: #d4edda;
    color: #155724;
}

.gallery-status-closed {
    background: rgba(255, 255, 255, 0.3);
    color: #fff;
}

.gallery-wo-link:hover {
    color: #fff;
    background: rgba(0, 0, 0, 0.7);
}

@media (max-width: 480px) {
    .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 4px;
    }
}

/* ── Import Progress Dialog ─────────────────────────────── */
.import-dialog {
    border: none;
    border-radius: var(--border-radius-lg);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
    padding: 0;
    max-width: 480px;
    width: 90%;
}
.import-dialog::backdrop {
    background: rgba(0, 0, 0, 0.45);
}
.import-dialog-content {
    padding: var(--spacing-lg);
}
.import-dialog-title {
    margin: 0 0 var(--spacing-md) 0;
    font-size: var(--font-size-lg);
    font-weight: 600;
}
.import-steps {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}
.import-step {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    background: var(--color-bg-secondary);
    transition: all 0.2s ease;
}
.import-step-active {
    color: var(--color-text);
    background: #eef4ff;
    font-weight: 500;
}
.import-step-done {
    color: #107c10;
    background: #f0faf0;
}
.import-step-error {
    color: #a80000;
    background: #fef0f0;
}
.import-step-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.import-step-icon .spinner {
    width: 16px;
    height: 16px;
    border-width: 2px;
}
.import-step-detail {
    font-size: 12px;
    color: var(--color-text-tertiary);
    margin-left: 32px;
    margin-top: 2px;
}
.import-result {
    margin-top: var(--spacing-md);
    padding: var(--spacing-md);
    border-radius: var(--border-radius);
    font-size: var(--font-size-sm);
}
.import-result-success {
    background: #dff6dd;
    color: #107c10;
    border: 1px solid #a7e3a5;
}
.import-result-error {
    background: #fde7e9;
    color: #a80000;
    border: 1px solid #f1bbbc;
}
.import-dialog-footer {
    margin-top: var(--spacing-md);
    display: flex;
    justify-content: flex-end;
}

/* ===================================
   Next Stop Modal
   =================================== */
.next-stop-body {
    padding: var(--spacing-md);
    max-height: 65vh;
    overflow-y: auto;
}

.next-stop-loading {
    text-align: center;
    padding: var(--spacing-lg) 0;
    color: var(--color-text-secondary);
}

.next-stop-done {
    text-align: center;
    padding: var(--spacing-lg) 0;
}

.next-stop-done-text {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--color-success);
}

.next-stop-card {
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.next-stop-card:first-child {
    border-color: var(--color-primary);
    border-width: 2px;
}

.next-stop-addr {
    font-weight: 600;
    font-size: var(--font-size-base);
    margin-bottom: var(--spacing-xs);
}

.next-stop-dist {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-sm);
}

.next-stop-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.next-stop-nav-btn,
.next-stop-start-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-sm);
    font-weight: 600;
    padding: 8px 16px;
    border-radius: var(--border-radius);
    text-decoration: none;
    text-align: center;
    min-height: var(--touch-target-min);
    color: #fff;
}

.next-stop-nav-btn {
    background: var(--color-success);
}

.next-stop-start-btn {
    background: var(--color-primary);
}

.next-stop-more {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin: var(--spacing-sm) 0 0;
}

.next-stop-empty {
    text-align: center;
    padding: var(--spacing-lg) 0;
    color: var(--color-text-secondary);
}

.next-stop-footer {
    padding: var(--spacing-md);
    border-top: 1px solid var(--color-border-light);
    text-align: center;
}

.next-stop-all-btn {
    display: block;
    width: 100%;
    text-align: center;
}

/* ===================================
   Address Confirmation Screen
   =================================== */
.address-confirm-screen {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: var(--color-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
}
.address-confirm-screen.hidden { display: none; }
.address-confirm-card {
    background: #fff;
    border-radius: var(--border-radius-lg);
    box-shadow: 0 4px 24px rgba(0,0,0,0.12);
    padding: 2rem 1.5rem;
    max-width: 420px;
    width: 100%;
    text-align: center;
}
.address-confirm-icon { margin-bottom: 1rem; }
.address-confirm-title {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 0.5rem;
}
.address-confirm-text {
    color: var(--color-text-muted);
    margin: 0 0 1.25rem;
    font-size: 0.95rem;
}
.address-confirm-address {
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    padding: 1rem;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 1.5rem;
    line-height: 1.4;
}
.address-confirm-actions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.address-confirm-btn {
    padding: 0.85rem 1.5rem;
    font-size: 1rem;
    border-radius: var(--border-radius);
    cursor: pointer;
    font-weight: 600;
}

/* ===================================
   Signature Pad
   =================================== */
.signature-pad-wrapper {
    position: relative;
    border: 2px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    background: #fff;
    overflow: hidden;
}

.signature-canvas {
    display: block;
    width: 100%;
    height: 180px;
    cursor: crosshair;
    touch-action: none;
}

.signature-clear-btn {
    position: absolute;
    top: var(--spacing-xs);
    right: var(--spacing-xs);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border-light);
    border-radius: var(--border-radius);
    padding: 4px 12px;
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    cursor: pointer;
}

.signature-clear-btn:hover {
    background: var(--color-border-light);
}

/* ===================================
   Book Appointment
   =================================== */
.book-slot-options {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.book-slot-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 16px 20px;
    font-size: 1.05rem;
    font-weight: 600;
    background: #fff;
    color: var(--color-text);
    border: 2px solid var(--color-border-light);
    border-radius: var(--border-radius-lg);
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
}
.book-slot-btn:hover:not(.disabled) {
    border-color: var(--color-primary);
    background: #f0f4ff;
}
.book-slot-btn.selected {
    border-color: var(--color-primary);
    background: #e0e7ff;
    color: var(--color-primary);
}
.book-slot-btn.disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background: var(--color-bg);
}
.book-slot-full {
    font-size: 0.8rem;
    color: #b91c1c;
    font-weight: 600;
}

/* ===================================
   WO Panel / Premise Drawer
   =================================== */
.wo-panel-overlay { display:none; position:fixed; top:var(--header-height,56px); right:0; bottom:0; left:0; background:rgba(0,0,0,0.35); z-index:800; }
.wo-panel-overlay.show { display:block; }
.wo-panel { position:fixed; top:var(--header-height,56px); right:0; bottom:0; width:clamp(640px, 67vw, 1400px); max-width:100vw; background:var(--color-bg); border-left:1px solid var(--color-border-light); box-shadow:-4px 0 24px rgba(0,0,0,0.15); z-index:900; display:flex; flex-direction:column; transform:translateX(100%); transition:transform 0.25s ease; overflow:hidden; }
.wo-panel.open { transform:translateX(0); }
.wo-panel-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:20px 20px 18px; border-bottom:1px solid var(--color-border-light); background:#e8f0fb; flex-shrink:0; }
.wo-panel-premise { font-size:1.25rem; font-weight:700; color:var(--color-text); line-height:1.2; }
.wo-panel-premise-label { display:block; font-size:0.68rem; font-weight:600; text-transform:uppercase; letter-spacing:0.06em; color:#4a6fa5; margin-bottom:2px; }
.wo-panel-addr { font-size:0.83rem; color:#4a5568; margin-top:5px; line-height:1.4; }
.wo-panel-close { background:none; border:none; font-size:1.4rem; line-height:1; color:var(--color-text-muted); cursor:pointer; padding:0 4px; flex-shrink:0; }
.wo-panel-close:hover { color:var(--color-text); }
.wo-panel-edit-btn { background:none; border:none; font-size:1.1rem; line-height:1; color:var(--color-text-muted); cursor:pointer; padding:2px 6px; flex-shrink:0; border-radius:4px; }
.wo-panel-edit-btn:hover { color:var(--color-primary); background:var(--color-bg); }

/* ── Record Edit Panel ── */
.wo-panel-edit { border-bottom:1px solid var(--color-border-light); background:var(--color-bg); flex-shrink:0; }
.wo-panel-edit.hidden { display:none; }
.edit-panel-inner { padding:12px 16px; }
.edit-panel-title { font-size:0.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--color-text-muted); margin-bottom:10px; }
.edit-panel-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.edit-field { display:flex; flex-direction:column; gap:3px; }
.edit-field-wide { grid-column:1 / -1; }
.edit-label { font-size:0.72rem; font-weight:600; color:var(--color-text-muted); text-transform:uppercase; letter-spacing:.3px; }
.edit-input { padding:5px 8px; border:1px solid var(--color-border-light); border-radius:var(--border-radius); font-size:0.85rem; background:var(--color-bg); color:var(--color-text); }
.edit-input:focus { outline:none; border-color:var(--color-primary); }
.edit-panel-actions { display:flex; align-items:center; gap:8px; margin-top:10px; flex-wrap:wrap; }
.edit-status { font-size:0.8rem; }
.edit-status-ok  { color:#10b981; }
.edit-status-err { color:#ef4444; }
.wo-panel-body { flex:1; overflow:hidden; display:flex; flex-direction:column; }
.wo-panel-meta { padding:12px 16px 10px; border-bottom:1px solid var(--color-border-light); flex-shrink:0; }
.pm-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:0 12px; }
.pm-col { display:flex; flex-direction:column; gap:8px; min-width:0; }
.pm-field { display:flex; flex-direction:column; gap:2px; min-width:0; }
.pm-label { font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:0.06em; color:var(--color-text-muted); }
.pm-value { font-size:0.82rem; color:var(--color-text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pm-value-muted { font-size:0.82rem; color:var(--color-text-muted); }
.pm-status { display:inline-block; font-size:0.72rem; font-weight:600; padding:1px 8px; border-radius:10px; }
.pm-status-open     { background:#dbeafe; color:#1d4ed8; }
.pm-status-completed { background:#d1fae5; color:#065f46; }
.pm-status-enroute  { background:#fef3c7; color:#92400e; }
.pm-status-inprogress { background:#fff4ce; color:#8a6d00; }
.pm-status-inreview { background:#ede9fe; color:#6d28d9; }
.pm-status-closed   { background:#e5e7eb; color:#6b7280; }
.wo-panel-columns { flex:1; overflow:hidden; display:grid; grid-template-columns:1fr 1fr 1fr; border-top:1px solid var(--color-border-light); min-height:0; }
.wo-panel-col { overflow-y:auto; min-width:0; border-right:1px solid var(--color-border-light); }
.wo-panel-col:last-child { border-right:none; }
.wo-panel-section-title { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; color:var(--color-text-muted); padding:10px 16px 4px; }
.wo-panel-timeline { padding:4px 16px 12px; }

/* Contact Info */
.contact-info-section { margin:0 16px 4px; padding:10px 14px 12px; background:var(--color-bg); border:1px solid var(--color-border-light); border-radius:8px; }
.contact-info-top { margin-bottom:8px; display:flex; align-items:center; gap:8px; }
.contact-info-title { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; color:var(--color-text-muted); }
.contact-source-badge { font-size:0.55rem; font-weight:600; text-transform:uppercase; padding:1px 4px; border-radius:3px; letter-spacing:0.03em; flex-shrink:0; background:#fefcbf; color:#975a16; }
.contacts-add-btn { font-size:0.75rem; color:#3182ce; background:none; border:1px solid #bee3f8; border-radius:4px; padding:1px 8px; cursor:pointer; }
.contacts-add-btn:hover { background:#ebf8ff; }
.contacts-columns { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.contacts-col-header { font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:0.04em; color:var(--color-text-muted); margin-bottom:4px; display:flex; align-items:center; gap:6px; }
.contacts-list { display:flex; flex-direction:column; gap:4px; }
.contacts-empty { font-size:0.78rem; color:var(--color-text-muted); font-style:italic; }
.contact-row { display:flex; align-items:center; gap:6px; font-size:0.8rem; padding:2px 0; }
.contact-type-badge { font-size:0.6rem; font-weight:600; text-transform:uppercase; padding:1px 5px; border-radius:3px; letter-spacing:0.03em; flex-shrink:0; }
.contact-type-phone { background:#e9d8fd; color:#553c9a; }
.contact-type-email { background:#bee3f8; color:#2b6cb0; }
.contact-label { font-size:0.75rem; color:var(--color-text-muted); font-weight:500; }
.contact-value { color:var(--color-text); word-break:break-word; }
.contact-remove-btn { background:none; border:none; color:#cbd5e0; font-size:1rem; cursor:pointer; padding:0 2px; line-height:1; margin-left:auto; flex-shrink:0; }
.contact-remove-btn:hover { color:#e53e3e; }
.dnc-toggle { font-size:0.6rem; font-weight:600; text-transform:uppercase; letter-spacing:0.03em; padding:1px 5px; border-radius:3px; border:1px solid var(--color-border-light); background:var(--color-bg); color:#cbd5e0; cursor:pointer; flex-shrink:0; }
.dnc-toggle:hover:not(.active) { background:#fff5f5; border-color:#feb2b2; color:#e53e3e; }
.dnc-toggle.active { background:#e53e3e; color:#fff; border-color:#e53e3e; }
.contact-row.dnc-row .contact-value { text-decoration:line-through; color:var(--color-text-muted); }
.dnc-chip { display:inline-block; font-size:0.55rem; font-weight:600; text-transform:uppercase; letter-spacing:0.03em; padding:1px 5px; border-radius:3px; background:#e53e3e; color:#fff; margin-left:4px; vertical-align:middle; }
.contact-add-form { display:flex; align-items:center; gap:5px; padding:6px 0 2px; flex-wrap:wrap; }
.contact-type-select, .contact-label-input, .contact-value-input { font-size:0.78rem; padding:4px 6px; border:1px solid var(--color-border-light); border-radius:4px; background:var(--color-bg); color:var(--color-text); }
.contact-label-input { width:80px; }
.contact-value-input { flex:1; min-width:100px; }
.contact-save-btn { font-size:0.78rem; padding:4px 10px; background:#48bb78; color:#fff; border:none; border-radius:4px; cursor:pointer; }
.contact-save-btn:hover { background:#38a169; }
.contact-cancel-btn { font-size:0.78rem; padding:4px 8px; background:none; border:1px solid var(--color-border-light); border-radius:4px; cursor:pointer; color:var(--color-text-muted); }

/* Correspondence Timeline */
.corr-loading, .corr-empty { color:var(--color-text-muted); font-size:0.85rem; padding:12px 0; }
.corr-entry { display:flex; gap:10px; padding:8px 0; border-bottom:1px solid var(--color-border-light); }
.corr-entry:last-child { border-bottom:none; }
.corr-entry-left { flex-shrink:0; padding-top:1px; }
.corr-entry-right { flex:1; min-width:0; }
.corr-badge { display:inline-block; font-size:0.7rem; font-weight:600; padding:2px 7px; border-radius:10px; white-space:nowrap; }
.corr-call   { background:#dbeafe; color:#1d4ed8; }
.corr-notice { background:#fef3c7; color:#92400e; }
.corr-email  { background:#d1fae5; color:#065f46; }
.corr-other  { background:#f3f4f6; color:#374151; }
.corr-visit  { background:#ede9fe; color:#5b21b6; }
.corr-appt   { background:#fef3c7; color:#92400e; }
.corr-agent  { color:var(--color-text-muted); font-style:italic; }
.corr-photos { color:var(--color-text-muted); font-size:0.8rem; }
.corr-date { display:block; font-size:0.78rem; font-weight:600; color:var(--color-text); }
.corr-detail { display:block; font-size:0.78rem; color:var(--color-text-muted); margin-top:2px; word-break:break-word; }
.corr-entry-visit { cursor:pointer; }
.corr-delete-btn { flex-shrink:0; align-self:center; background:none; border:none; color:var(--color-text-muted); cursor:pointer; font-size:0.8rem; padding:2px 4px; border-radius:4px; opacity:0.4; transition:opacity 0.15s, color 0.15s; }
.corr-delete-btn:hover { opacity:1; color:#c53030; }
.corr-delete-btn:disabled { cursor:not-allowed; opacity:0.2; }
.corr-entry-visit:hover { background:var(--color-bg); border-radius:4px; }
.corr-entry-expanded { background:var(--color-bg); border-radius:4px; }
.visit-expand { margin-top:6px; }
.visit-expand-inner { font-size:0.78rem; color:var(--color-text-muted); border-top:1px solid var(--color-border-light); padding-top:6px; }
.visit-expand-row { margin-bottom:4px; }
.visit-expand-notes { white-space:pre-wrap; word-break:break-word; color:var(--color-text); }
.visit-expand-meta { color:var(--color-text-muted); font-style:italic; }
.visit-expand-photos { display:flex; flex-wrap:wrap; gap:6px; margin-top:6px; }
.visit-expand-thumb { width:72px; height:72px; object-fit:cover; border-radius:4px; border:1px solid var(--color-border-light); }
.corr-expand-loading, .corr-expand-err { color:var(--color-text-muted); font-size:0.78rem; }

/* Log Interaction */
.wo-panel-log-quick { display:flex; flex-direction:column; gap:6px; padding:8px 16px 4px; }
.log-quick-row { display:flex; gap:6px; }
.log-quick-row .log-quick-btn { flex:1; min-width:0; padding:5px 6px; }
.log-quick-btn { font-size:0.78rem; font-weight:600; border:1px solid var(--color-border-light); border-radius:12px; background:var(--color-bg); color:var(--color-text-muted); cursor:pointer; text-align:center; }
.log-quick-btn:hover { background:#f7fafc; border-color:var(--color-primary); color:var(--color-primary); }
.log-quick-btn.active { background:var(--color-primary); border-color:var(--color-primary); color:#fff; }
.wo-panel-log-form { display:flex; flex-direction:column; gap:8px; padding:8px 16px; }
.wo-log-type, .wo-log-notes { border:1px solid var(--color-border-light); border-radius:4px; padding:8px 10px; font-size:0.88rem; background:var(--color-bg); color:var(--color-text); width:100%; box-sizing:border-box; font-family:inherit; }
textarea.wo-log-notes { min-height:60px; resize:vertical; }
.wo-log-submit-btn { width:100%; }

/* Appointment Calendar (WO Panel) */
.appt-section { padding:0 16px 12px; }
.appt-loading { padding:8px 16px; color:var(--color-text-muted); font-size:0.82rem; }
.appt-current { font-size:0.82rem; color:var(--color-text-muted); margin-bottom:8px; }
.appt-current strong { color:var(--color-text); }
.mini-cal { background:var(--color-bg); border:1px solid var(--color-border-light); border-radius:8px; padding:12px; margin-bottom:10px; }
.mini-cal-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.mini-cal-title { font-size:0.9rem; font-weight:700; color:var(--color-text); }
.mini-cal-nav { background:var(--color-bg); border:1px solid var(--color-border-light); border-radius:6px; padding:4px 10px; cursor:pointer; font-size:0.8rem; color:var(--color-text); }
.mini-cal-nav:hover { background:#f0f0f0; }
.mini-cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.mini-cal-dow { text-align:center; font-size:0.65rem; font-weight:700; text-transform:uppercase; color:var(--color-text-muted); padding:2px 0 4px; }
.mini-cal-day { display:flex; flex-direction:column; align-items:center; justify-content:center; border-radius:6px; padding:3px 0; cursor:pointer; min-height:36px; transition:opacity 0.1s; }
.mini-cal-day:hover:not(.mini-cal-weekend):not(.mini-cal-blocked):not(.mini-cal-full) { opacity:0.8; }
.mini-cal-num { font-size:0.78rem; font-weight:600; line-height:1; }
.mini-cal-count { font-size:0.6rem; color:var(--color-text-muted); margin-top:1px; }
.mini-cal-weekend { opacity:0.35; cursor:default; }
.mini-cal-blocked { background:#e2e8f0; opacity:0.5; cursor:default; }
.mini-cal-ok   { background:#c6f6d5; }
.mini-cal-warn { background:#fefcbf; }
.mini-cal-full { background:#fed7d7; cursor:default; }
.mini-cal-full .mini-cal-num { text-decoration:line-through; color:#a0aec0; }
.mini-cal-today { box-shadow:0 0 0 2px #3182ce; }
.mini-cal-past  { opacity: 0.35; cursor: default; pointer-events: none; }
.mini-cal-selected { background:#3182ce !important; }
.mini-cal-selected .mini-cal-num  { color:#fff; }
.mini-cal-selected .mini-cal-count { color:#bee3f8; }
.appt-slots-label { font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; color:var(--color-text-muted); margin-bottom:4px; }
.slot-toggle { display:flex; border:1px solid var(--color-border-light); border-radius:6px; overflow:hidden; margin-bottom:10px; }
.slot-btn { flex:1; display:flex; flex-direction:column; align-items:center; background:var(--color-bg); border:none; border-right:1px solid var(--color-border-light); padding:7px 0; font-size:0.8rem; font-weight:600; color:var(--color-text); cursor:pointer; transition:background 0.15s; }
.slot-btn:last-child { border-right:none; }
.slot-btn:hover { background:#f0f0f0; }
.slot-btn.active { background:#3182ce; color:#fff; }
.slot-btn-label { font-weight:600; }
.slot-btn-cap { font-size:0.7rem; font-weight:400; opacity:0.7; margin-top:2px; }
.slot-btn.active .slot-btn-cap { opacity:0.9; }
.slot-btn.cap-full:not(.active) { background:#fff5f5; color:#c53030; }
.slot-btn.cap-warn:not(.active) { background:#fffff0; color:#b7791f; }
.appt-actions { display:flex; flex-wrap:wrap; gap:8px; }
.btn-schedule { padding:8px 20px; background:#276749; color:#fff; border:none; border-radius:6px; font-size:0.85rem; font-weight:600; cursor:pointer; }
.btn-schedule:hover:not(:disabled) { background:#22543d; }
.btn-schedule:disabled { opacity:0.5; cursor:default; }
.btn-unschedule { padding:8px 16px; background:none; color:#e53e3e; border:1px solid #fed7d7; border-radius:6px; font-size:0.85rem; cursor:pointer; }
.btn-unschedule:hover:not(:disabled) { background:#fff5f5; }

/* ===================================
   Self-ID Drawer (Home page)
   =================================== */
.selfid-overlay { display:none; position:fixed; top:var(--header-height,56px); right:0; bottom:0; left:0; background:rgba(0,0,0,0.35); z-index:800; }
.selfid-overlay.show { display:block; }
.selfid-drawer { position:fixed; top:var(--header-height,56px); right:0; bottom:0; width:clamp(800px,90vw,1600px); max-width:100vw; background:var(--color-bg); border-left:1px solid var(--color-border-light); box-shadow:-4px 0 24px rgba(0,0,0,0.15); z-index:900; display:flex; flex-direction:column; transform:translateX(100%); transition:transform 0.25s ease; overflow:hidden; }
.selfid-drawer.open { transform:translateX(0); }
.selfid-drawer-header { display:flex; align-items:center; gap:12px; padding:22px 20px; border-bottom:1px solid var(--color-border-light); background:#e8f0fb; flex-shrink:0; }
.selfid-header-premise { display:flex; align-items:center; gap:8px; padding:4px 10px; background:#d1fae5; color:#065f46; border-radius:999px; font-size:0.85rem; font-weight:600; flex-shrink:0; }
.selfid-header-premise .selfid-header-premise-label { font-size:0.7rem; font-weight:600; text-transform:uppercase; letter-spacing:0.04em; opacity:0.75; }
.selfid-header-premise .selfid-header-open-btn { background:#065f46; color:#fff; border:none; padding:4px 10px; border-radius:999px; font-size:0.72rem; font-weight:600; cursor:pointer; font-family:inherit; }
.selfid-header-premise .selfid-header-open-btn:hover { background:#047857; }
.selfid-drawer-title { flex:1; font-size:1rem; font-weight:700; color:var(--color-text); margin:0; }
.selfid-back-btn { background:none; border:none; cursor:pointer; color:var(--color-text-muted); padding:2px; display:flex; align-items:center; }
.selfid-back-btn:hover { color:var(--color-text); }
.selfid-list { flex:1; overflow-y:auto; }
.selfid-loading { padding:24px; text-align:center; color:var(--color-text-muted); font-size:0.9rem; }
.selfid-empty { padding:24px; text-align:center; color:var(--color-text-muted); font-size:0.9rem; }
.selfid-item { display:flex; align-items:center; gap:12px; padding:12px 16px; border-bottom:1px solid var(--color-border-light); cursor:pointer; transition:background 0.1s; }
.selfid-item:hover { background:var(--color-bg-secondary, #f7fafc); }
.selfid-item-body { flex:1; min-width:0; }
.selfid-item-name { font-size:0.9rem; font-weight:600; color:var(--color-text); }
.selfid-item-addr { font-size:0.8rem; color:var(--color-text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.selfid-item-meta { display:flex; align-items:center; gap:8px; margin-top:3px; }
.selfid-item-date { font-size:0.72rem; color:var(--color-text-muted); }
.selfid-item-pipe { font-size:0.68rem; font-weight:600; padding:1px 6px; border-radius:10px; background:#dbeafe; color:#1d4ed8; }
.selfid-item-photos { font-size:0.72rem; color:var(--color-text-muted); display:flex; align-items:center; gap:2px; }
.selfid-item-chevron { color:var(--color-text-muted); flex-shrink:0; }
.selfid-item-linked { display:inline-block; font-size:0.65rem; font-weight:600; padding:1px 5px; border-radius:3px; background:#d1fae5; color:#065f46; }
.selfid-detail-body { flex:1; overflow-y:auto; padding:16px; }
.selfid-detail-field { margin-bottom:14px; }
.selfid-detail-label { font-size:0.7rem; font-weight:600; text-transform:uppercase; letter-spacing:0.05em; color:var(--color-text-muted); margin-bottom:3px; }
.selfid-detail-value { font-size:0.88rem; color:var(--color-text); padding:6px 10px; background:#f7fafc; border:1px solid var(--color-border-light); border-radius:6px; }
.selfid-detail-row { display:flex; gap:12px; }
.selfid-detail-row .selfid-detail-field { flex:1; min-width:0; }
.selfid-detail-photos { display:flex; flex-wrap:wrap; gap:8px; }
.selfid-detail-photo { width:120px; height:120px; object-fit:cover; border-radius:8px; border:1px solid var(--color-border-light); cursor:pointer; transition:transform 0.15s; }
.selfid-detail-photo:hover { transform:scale(1.05); }
.selfid-drawer-footer { display:flex; flex-direction:column; gap:10px; padding:12px 16px; border-top:1px solid var(--color-border-light); flex-shrink:0; }
.selfid-review-actions { display:flex; gap:6px; }
.selfid-review-actions > button { flex:1; }
.selfid-footer-right { display:flex; gap:8px; }
.selfid-footer-right > button { flex:1; }
/* Self-ID Status Badges */
.selfid-status-pending { background:#e2e8f0; color:#4a5568; }
.selfid-status-review { background:#fefcbf; color:#975a16; }
.selfid-status-scheduled { background:#bee3f8; color:#2b6cb0; }
.selfid-status-approved { background:#c6f6d5; color:#276749; }
.selfid-status-rejected { background:#fed7d7; color:#9b2c2c; }
.selfid-status-reschedule { background:#feebc8; color:#9c4221; }
/* Review Action Buttons */
.btn-approve { padding:6px 14px; border-radius:6px; font-size:0.82rem; font-weight:600; border:none; cursor:pointer; background:#c6f6d5; color:#276749; transition:background 0.15s; }
.btn-approve:hover:not(:disabled) { background:#9ae6b4; }
.btn-approve:disabled { opacity:0.5; cursor:not-allowed; }
.btn-schedule-appt { padding:6px 14px; border-radius:6px; font-size:0.82rem; font-weight:600; border:none; cursor:pointer; background:#bee3f8; color:#2b6cb0; transition:background 0.15s; }
.btn-schedule-appt:hover { background:#90cdf4; }
.btn-review { padding:6px 14px; border-radius:6px; font-size:0.82rem; font-weight:600; border:none; cursor:pointer; background:#fefcbf; color:#975a16; transition:background 0.15s; }
.btn-review:hover { background:#fef08a; }
.btn-reject { padding:6px 14px; border-radius:6px; font-size:0.82rem; font-weight:600; border:none; cursor:pointer; background:#fed7d7; color:#9b2c2c; transition:background 0.15s; }
.btn-reject:hover { background:#feb2b2; }
.btn-reschedule { padding:6px 14px; border-radius:6px; font-size:0.82rem; font-weight:600; border:none; cursor:pointer; background:#feebc8; color:#9c4221; transition:background 0.15s; }
.btn-reschedule:hover:not(:disabled) { background:#fbd38d; }
.btn-reschedule:disabled { opacity:0.5; cursor:not-allowed; }
/* User Drawer */
.user-drawer { position:fixed; top:var(--header-height,56px); right:0; bottom:0; width:clamp(340px,30vw,420px); max-width:100vw; background:var(--color-bg); border-left:1px solid var(--color-border-light); box-shadow:-4px 0 24px rgba(0,0,0,0.15); z-index:900; display:flex; flex-direction:column; transform:translateX(100%); transition:transform 0.25s ease; overflow:hidden; }
.user-drawer.open { transform:translateX(0); }
.user-drawer-body { flex:1; overflow-y:auto; padding:16px; }
.user-drawer-body .form-group { margin-bottom:14px; }
.selfid-footer-right { display:flex; gap:8px; margin-left:auto; }
/* Two-column drawer layout */
.selfid-drawer-columns { flex:1; display:grid; grid-template-columns:minmax(260px, 1fr) minmax(280px, 1.3fr) minmax(240px, 1fr); min-height:0; overflow:hidden; }
.selfid-col-photos { padding:16px; border-right:1px solid var(--color-border-light); overflow-y:auto; display:flex; flex-direction:column; gap:10px; background:#f8fafc; }
.selfid-col-photos .selfid-photo-label { font-size:0.75rem; font-weight:600; text-transform:uppercase; letter-spacing:0.05em; color:var(--color-text-muted); }
.selfid-col-photos .selfid-photo-item { display:block; width:100%; border-radius:8px; overflow:hidden; border:1px solid var(--color-border-light); background:#fff; }
.selfid-col-photos .selfid-photo-item img { display:block; width:100%; height:auto; object-fit:contain; cursor:zoom-in; }
.selfid-col-photos .selfid-photo-empty { color:var(--color-text-muted); font-size:0.88rem; font-style:italic; padding:20px 0; text-align:center; }
.selfid-col-left { overflow-y:auto; border-right:1px solid var(--color-border-light); }
.selfid-col-right { overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:8px; }
.selfid-col-title { font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; color:var(--color-text-muted); }
.premise-results-inline { flex:1; overflow-y:auto; }
.btn-unlink-premise { font-size:0.75rem; padding:6px 10px; background:none; border:1px solid #fed7d7; border-radius:4px; color:#e53e3e; cursor:pointer; flex-shrink:0; }
.btn-unlink-premise:hover { background:#fff5f5; }
.pipe-type-radio { display:flex; align-items:center; gap:8px; padding:8px 12px; background:#f9fafb; border:1px solid #e5e7eb; border-radius:6px; cursor:pointer; font-size:0.88rem; transition:border-color 0.15s; }
.pipe-type-radio:hover { border-color:#0067b1; }
.pipe-type-radio input[type="radio"] { margin:0; accent-color:#0067b1; width:16px; height:16px; }
.pipe-type-radio.selected { border-color:#0067b1; background:#eff6ff; }
@media (max-width: 700px) {
    .selfid-drawer { width:100vw; }
    .selfid-drawer-columns { grid-template-columns:1fr; }
    .selfid-col-left, .selfid-col-photos { border-right:none; border-bottom:1px solid var(--color-border-light); }
}

/* ── Audit Page ─────────────────────────────────────────────── */
.audit-container { padding:12px 16px 16px; max-width:1600px; margin:0 auto; }
.audit-filters {
    display:flex; gap:12px; align-items:flex-end; flex-wrap:wrap;
    padding:10px 12px; background:var(--color-bg); border:1px solid var(--color-border-light);
    border-radius:8px; margin-bottom:12px;
}
.audit-filter-group { display:flex; flex-direction:column; gap:4px; }
.audit-filter-label { font-size:0.7rem; font-weight:600; text-transform:uppercase; letter-spacing:0.05em; color:var(--color-text-muted); }
.audit-range-group { flex-direction:row; align-items:flex-end; gap:8px; }
.audit-range-group .input-field { min-width:140px; }
.audit-filter-group .input-field { min-width:160px; }
.audit-filter-spacer { margin-left:auto; }
.audit-counter { align-self:center; font-size:0.9rem; font-weight:600; color:var(--color-text-secondary); }

.audit-body {
    display:grid; grid-template-columns:2fr 1fr; gap:16px;
    align-items:start;
}
.audit-left {
    background:var(--color-bg); border:1px solid var(--color-border-light);
    border-radius:8px; padding:12px;
    display:flex; flex-direction:column; gap:10px;
    height:calc(100vh - 160px);
    min-height:420px;
    overflow:hidden;
}
.audit-photo-stage {
    position:relative; flex:1 1 0; min-height:0;
    background:#0b0b0b; border-radius:6px;
    display:flex; align-items:center; justify-content:center;
    overflow:hidden;
}
.audit-main-photo {
    max-width:100%; max-height:100%;
    width:auto; height:auto;
    object-fit:contain;
    display:block;
    cursor:zoom-in;
}

/* Photo zoom lightbox */
.audit-zoom-overlay {
    position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(0,0,0,0.92); z-index:10000;
    display:flex; flex-direction:column;
}
.audit-zoom-controls {
    display:flex; gap:8px; align-items:center; justify-content:center;
    padding:12px; background:rgba(0,0,0,0.5); flex-shrink:0;
    position:relative;
}
.audit-zoom-ctrl {
    background:rgba(255,255,255,0.15); color:#fff; border:none;
    width:36px; height:36px; border-radius:50%; cursor:pointer;
    font-size:1.2rem; font-weight:600; line-height:1;
    display:flex; align-items:center; justify-content:center;
    transition:background 0.12s;
}
.audit-zoom-ctrl:hover { background:rgba(255,255,255,0.3); }
.audit-zoom-ctrl.audit-zoom-reset { width:auto; padding:0 14px; font-size:0.85rem; border-radius:18px; }
.audit-zoom-close-btn { position:absolute; top:6px; right:12px; width:40px; height:40px; font-size:1.6rem; }
.audit-zoom-level { color:#fff; font-size:0.9rem; font-weight:600; min-width:60px; text-align:center; }
.audit-zoom-stage {
    flex:1; overflow:auto; display:flex;
    align-items:center; justify-content:center;
    cursor:grab;
    min-height:0;
}
.audit-zoom-stage.dragging { cursor:grabbing; }
.audit-zoom-img {
    display:block; user-select:none;
    transition:transform 0.05s ease-out;
    transform-origin:center center;
    max-width:none; max-height:none;
}
.audit-no-photo { color:#9ca3af; font-size:0.95rem; }
.audit-photo-nav {
    position:absolute; top:50%; transform:translateY(-50%);
    width:44px; height:44px; border-radius:50%;
    background:rgba(0,0,0,0.55); color:#fff; border:none; cursor:pointer;
    font-size:1.6rem; line-height:1; display:flex; align-items:center; justify-content:center;
    transition:background 0.15s;
}
.audit-photo-nav:hover { background:rgba(0,0,0,0.8); }
.audit-photo-prev { left:10px; }
.audit-photo-next { right:10px; }
.audit-photo-thumbs {
    display:flex; gap:6px; overflow-x:auto; padding:4px 2px;
}
.audit-thumb {
    flex:0 0 auto; width:64px; height:64px;
    border:2px solid transparent; border-radius:4px; overflow:hidden; cursor:pointer;
    background:#f3f4f6;
}
.audit-thumb.active { border-color:#0067b1; }
.audit-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.audit-photo-caption { font-size:0.82rem; color:var(--color-text-secondary); text-align:center; }

.audit-right {
    background:var(--color-bg); border:1px solid var(--color-border-light);
    border-radius:8px; padding:14px;
    display:flex; flex-direction:column; gap:6px;
    position:sticky; top:72px;
    max-height:calc(100vh - 88px); overflow-y:auto;
}
.audit-panel-header { border-bottom:1px solid var(--color-border-light); padding-bottom:8px; margin-bottom:2px; }
.audit-panel-title { font-size:0.95rem; font-weight:700; color:var(--color-text); line-height:1.3; }
.audit-panel-sub { font-size:0.78rem; color:var(--color-text-secondary); margin-top:2px; }

.audit-section { display:flex; flex-direction:column; gap:2px; margin-top:4px; }
.audit-section-label {
    font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:0.05em;
    color:var(--color-text-muted);
    display:flex; align-items:center; gap:6px;
}
.audit-section-value { font-size:0.85rem; color:var(--color-text); }
/* Compact inline fields: label + value on one line */
.audit-section-compact { display:flex; flex-direction:row; align-items:baseline; gap:8px; margin-top:0; }
.audit-section-compact .audit-section-label { flex:0 0 auto; }
.audit-section-compact .audit-section-value { flex:1; font-size:0.85rem; }
.audit-comments { white-space:pre-wrap; background:var(--color-bg-secondary); padding:8px; border-radius:4px; font-size:0.85rem; }

.audit-pipe-options { display:flex; flex-direction:column; gap:4px; }
.audit-pipe-options .pipe-type-radio { padding:6px 10px; font-size:0.85rem; }

.audit-status-row { display:flex; flex-wrap:wrap; gap:4px; }
.audit-status-btn {
    padding:5px 10px; font-size:0.78rem; font-weight:600;
    background:#fff; color:var(--color-text); border:1.5px solid var(--color-border-light);
    border-radius:14px; cursor:pointer; transition:all 0.15s;
}
.audit-status-btn:hover { border-color:var(--color-text-muted); }
.audit-status-btn.active { color:#fff; }

.audit-flash {
    font-size:0.7rem; font-weight:700; color:#16a34a; text-transform:uppercase;
    opacity:0; transition:opacity 0.2s;
}
.audit-flash.visible { opacity:1; }

.audit-panel-footer {
    display:flex; gap:8px; margin-top:auto; padding-top:12px;
    border-top:1px solid var(--color-border-light);
}
.audit-panel-footer button { flex:1; }
.audit-panel-nav {
    display:flex; gap:8px; padding-bottom:10px; border-bottom:1px solid var(--color-border-light);
    margin-bottom:10px;
}
.audit-panel-nav button { flex:1; }
.audit-shortcut-hint { text-align:center; font-size:0.72rem; color:var(--color-text-muted); }

@media (max-width: 900px) {
    .audit-body { grid-template-columns:1fr; }
    .audit-right { position:static; max-height:none; }
    .audit-photo-stage { min-height:320px; }
}

/* ── WO Panel Inline Editors ──────────────────────────────── */
.pm-edit-pencil { background:none; border:none; cursor:pointer; font-size:0.75rem; color:#6b7280; padding:0 3px; }
.pm-edit-pencil:hover { color:#0067b1; }
.pm-inline-editor { display:flex; flex-wrap:wrap; gap:4px; margin-top:6px; }
.pm-edit-chip {
    cursor:pointer; border:none; font-family:inherit; transition:opacity 0.12s;
}
.pm-edit-chip:hover { opacity:0.75; }
.pm-edit-chip-active { outline:2px solid #333; outline-offset:1px; }
.pm-assigned-check { display:flex; align-items:center; gap:6px; font-size:0.82rem; cursor:pointer; padding:3px 6px; border-radius:4px; }
.pm-assigned-check:hover { background:#f3f4f6; }
.pm-assigned-check input { cursor:pointer; }

/* ── Material Code Mapping Table ──────────────────────────── */
.material-codes-table { width:100%; border-collapse:collapse; font-size:0.88rem; }
.material-codes-table th { text-align:left; font-size:0.75rem; text-transform:uppercase; letter-spacing:0.04em; color:var(--color-text-muted); padding:6px 8px; border-bottom:1px solid var(--color-border-light); }
.material-codes-table td { padding:6px 8px; border-bottom:1px solid var(--color-border-light); }
.material-codes-table .mc-code-input { padding:4px 6px; border:1px solid #cbd5e0; border-radius:4px; font-size:0.88rem; font-family:inherit; }
.material-codes-table .mc-remove-btn { background:none; border:none; color:#e53e3e; cursor:pointer; font-size:1.1rem; padding:2px 6px; }

/* ── Export Builder ──────────────────────────────────────── */
.eb-container { max-width:1200px; margin:0 auto; padding:16px; height:calc(100vh - 56px); display:flex; flex-direction:column; overflow:hidden; }
.eb-top-bar {
    display:flex; gap:16px; align-items:flex-end; flex-wrap:wrap;
    padding:12px 16px; background:var(--color-bg); border:1px solid var(--color-border-light);
    border-radius:8px; margin-bottom:16px;
}
.eb-label { font-size:0.7rem; font-weight:600; text-transform:uppercase; letter-spacing:0.04em; color:var(--color-text-muted); display:block; margin-bottom:4px; }
.eb-config-selector, .eb-config-name-group { display:flex; flex-direction:column; }
.eb-checkbox-label { display:flex; align-items:center; gap:6px; font-size:0.88rem; cursor:pointer; align-self:center; }
.eb-top-actions { display:flex; gap:8px; margin-left:auto; }
.eb-action-btn {
    padding:8px 18px; font-size:0.88rem; font-weight:600; font-family:inherit;
    background:var(--color-bg); color:var(--color-text); border:1px solid var(--color-border);
    border-radius:6px; cursor:pointer; transition:background 0.12s;
}
.eb-action-btn:hover { background:var(--color-bg-secondary); }
.eb-status { display:none; padding:8px 12px; border-radius:6px; font-size:0.85rem; font-weight:600; margin-bottom:12px; }
.eb-status-ok { background:#d1fae5; color:#065f46; }
.eb-status-error { background:#fee2e2; color:#991b1b; }


.eb-columns { display:flex; gap:12px; align-items:stretch; flex:1; min-height:0; overflow:hidden; }
.eb-col-wide { flex:1.3; }
.eb-col {
    flex:1; background:var(--color-bg); border:1px solid var(--color-border-light);
    border-radius:8px; display:flex; flex-direction:column; overflow:hidden;
}
.eb-col-header {
    padding:10px 14px; font-size:0.82rem; font-weight:700; text-transform:uppercase;
    letter-spacing:0.04em; color:var(--color-text-muted);
    background:var(--color-bg-tertiary); border-bottom:1px solid var(--color-border-light);
}
.eb-field-search { padding:8px 10px; border-bottom:1px solid var(--color-border-light); }
.eb-field-search .input-field { font-size:0.85rem; padding:6px 10px; }
.eb-field-list { flex:1 1 0; min-height:0; overflow-y:auto; padding:4px 0 40px; }
.eb-category {
    padding:6px 14px 4px; font-size:0.7rem; font-weight:700; text-transform:uppercase;
    letter-spacing:0.04em; color:var(--color-text-muted); background:var(--color-bg-secondary);
    border-bottom:1px solid var(--color-border-light); position:sticky; top:0; z-index:1;
}
.eb-field-item {
    display:flex; align-items:center; gap:8px; padding:7px 14px;
    cursor:pointer; font-size:0.88rem; border-bottom:1px solid var(--color-border-light);
    transition:background 0.1s;
}
.eb-field-item:hover { background:var(--color-bg-secondary); }
.eb-field-item.eb-selected { background:#dbeafe; }
.eb-field-label { flex:1; }
.eb-field-key { font-size:0.72rem; color:var(--color-text-muted); }
.eb-field-order {
    width:22px; height:22px; border-radius:50%; background:var(--color-bg-tertiary);
    display:flex; align-items:center; justify-content:center;
    font-size:0.72rem; font-weight:700; color:var(--color-text-muted); flex-shrink:0;
}
.eb-empty { padding:20px; text-align:center; color:var(--color-text-muted); font-size:0.88rem; }

.eb-arrows {
    display:flex; flex-direction:column; gap:8px; justify-content:center; align-self:center;
}
.eb-arrow-btn {
    width:40px; height:40px; border:1px solid var(--color-border-light);
    border-radius:6px; background:var(--color-bg); cursor:pointer;
    font-size:1.2rem; display:flex; align-items:center; justify-content:center;
    color:var(--color-text); transition:background 0.12s;
}
.eb-arrow-btn:hover { background:var(--color-bg-secondary); }
.eb-rename-btn-text { font-size:0.72rem; width:auto; padding:0 10px; }

.eb-field-filter-btn {
    background:none; border:none; cursor:pointer; font-size:0.6rem; color:#9ca3af;
    padding:2px 4px; margin-left:auto; flex-shrink:0;
}
.eb-field-filter-btn:hover { color:#0067b1; }
.eb-field-filter-btn.active { color:#0067b1; font-weight:700; }
.eb-field-filter-panel {
    padding:8px 14px 10px; background:#f8fafc; border-bottom:1px solid var(--color-border-light);
}
.eb-ff-inner { display:flex; flex-direction:column; gap:6px; }
.eb-ff-checks { display:flex; flex-wrap:wrap; gap:4px 10px; }
.eb-ff-check { display:flex; align-items:center; gap:4px; font-size:0.82rem; cursor:pointer; white-space:nowrap; }
.eb-ff-blank-row { display:flex; gap:10px; padding-top:4px; border-top:1px solid #e5e7eb; margin-top:4px; }
.eb-ff-date-row { display:flex; gap:6px; align-items:center; }
.eb-ff-date-row .input-field { font-size:0.82rem; padding:4px 6px; }
.eb-ff-label { font-size:0.75rem; color:var(--color-text-muted); }
.eb-ff-num-row { display:flex; gap:6px; align-items:center; }
.eb-ff-num-row .input-field { font-size:0.82rem; padding:4px 6px; }
.eb-ff-text-row { display:flex; gap:6px; align-items:center; }
.eb-ff-text-row .input-field { font-size:0.82rem; padding:4px 6px; }

/* Custom Column Modal */
.eb-modal-overlay {
    position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(0,0,0,0.45); z-index:9999;
    display:flex; align-items:center; justify-content:center;
}
.eb-modal {
    background:var(--color-bg); border-radius:8px; box-shadow:0 20px 60px rgba(0,0,0,0.3);
    width:480px; max-width:90vw;
    display:flex; flex-direction:column;
}
.eb-modal-header {
    display:flex; justify-content:space-between; align-items:center;
    padding:14px 18px; border-bottom:1px solid var(--color-border-light);
}
.eb-modal-header h3 { margin:0; font-size:1rem; }
.eb-modal-close { background:none; border:none; font-size:1.5rem; cursor:pointer; color:var(--color-text-muted); padding:0 4px; }
.eb-modal-body { padding:16px 18px; }
.eb-modal-body code { background:var(--color-bg-secondary); padding:1px 4px; border-radius:3px; font-size:0.72rem; }
.eb-modal-footer {
    display:flex; gap:8px; justify-content:flex-end;
    padding:12px 18px; border-top:1px solid var(--color-border-light);
}

.eb-tabs {
    display:flex; border-bottom:2px solid var(--color-border-light); background:var(--color-bg-tertiary);
}
.eb-tab {
    flex:1; padding:10px 12px; font-size:0.82rem; font-weight:600; text-align:center;
    background:none; border:none; cursor:pointer; color:var(--color-text-muted);
    border-bottom:2px solid transparent; margin-bottom:-2px; transition:all 0.15s;
}
.eb-tab:hover { color:var(--color-text); }
.eb-tab.active { color:#0067b1; border-bottom-color:#0067b1; }

.eb-display-toggle { flex-shrink:0; display:flex; align-items:center; }
.eb-display-toggle input { width:16px; height:16px; cursor:pointer; }
.eb-filter-dot { color:#0067b1; font-size:0.55rem; margin-left:auto; flex-shrink:0; }
.eb-custom-edit-btn { background:none; border:none; cursor:pointer; color:#6b7280; font-size:0.8rem; padding:2px 6px; }
.eb-custom-edit-btn:hover { color:#0067b1; }
.eb-has-filter { background:#f0f7ff; }
.eb-filter-inline { padding:8px 14px; background:#f8fafc; border-bottom:1px solid var(--color-border-light); }

.eb-reorder-bar {
    display:flex; gap:6px; padding:8px 10px; border-top:1px solid var(--color-border-light);
    background:var(--color-bg-tertiary); justify-content:center;
}

@media (max-width: 700px) {
    .eb-columns { flex-direction:column; }
    .eb-arrows { flex-direction:row; }
}

/* ── Confined Space Entry Permit ─────────────────────────── */
.permit-container { max-width:980px; margin:0 auto; padding:var(--spacing-md); }
.permit-status-bar { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px; padding:10px 14px; background:#f8fafc; border:1px solid var(--color-border-light); border-radius:8px; flex-wrap:wrap; }
.permit-status-row { display:flex; align-items:center; justify-content:space-between; width:100%; gap:12px; flex-wrap:wrap; }
.permit-status-meta { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.permit-status-label { font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; color:#64748b; }
.permit-status-value { font-weight:600; color:#0f172a; }
.permit-status-pill { padding:3px 10px; border-radius:999px; font-size:0.72rem; font-weight:700; letter-spacing:0.04em; }
.permit-status-draft     { background:#e2e8f0; color:#334155; }
.permit-status-active    { background:#dcfce7; color:#166534; }
.permit-status-completed { background:#dbeafe; color:#1e40af; }
.permit-status-cancelled { background:#fee2e2; color:#991b1b; }

.permit-section { background:#fff; border:1px solid var(--color-border-light); border-radius:10px; padding:16px 18px; margin-bottom:14px; box-shadow:0 1px 2px rgba(0,0,0,0.03); }
.permit-section h2 { margin:0 0 12px 0; font-size:1.05rem; font-weight:700; color:#0f172a; }
.permit-section h3 { margin:14px 0 8px 0; font-size:0.92rem; font-weight:700; color:#0f172a; }
.permit-section p.permit-cert { font-size:0.88rem; color:#475569; line-height:1.5; }

.permit-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:10px 14px; }
.permit-grid > label { display:flex; flex-direction:column; gap:4px; font-size:0.85rem; color:#0f172a; }
.permit-grid > label > span { font-size:0.75rem; font-weight:600; color:#475569; }
.permit-grid > label.permit-grid-wide { grid-column:1 / -1; }
.permit-grid input[type="text"], .permit-grid input[type="date"], .permit-grid input[type="time"], .permit-grid select, .permit-grid textarea {
    border:1px solid var(--color-border); border-radius:6px; padding:7px 9px; font-size:0.92rem; background:#fff; color:#0f172a; font-family:inherit;
}
.permit-grid textarea { resize:vertical; min-height:50px; }
.permit-grid label.permit-checkbox { flex-direction:row; align-items:center; gap:8px; }
.permit-grid label.permit-checkbox > span { display:inline; font-weight:600; }

.permit-tests-wrap { overflow-x:auto; margin:12px 0; }
.permit-tests, .permit-checklist { width:100%; border-collapse:collapse; min-width:640px; }
.permit-tests th, .permit-tests td, .permit-checklist th, .permit-checklist td { border:1px solid #e2e8f0; padding:6px 8px; font-size:0.86rem; vertical-align:middle; }
.permit-tests thead th, .permit-checklist thead th { background:#f1f5f9; font-weight:700; color:#0f172a; }
.permit-tests td input, .permit-checklist td input[type="text"] { width:100%; border:1px solid var(--color-border-light); border-radius:4px; padding:4px 6px; font-size:0.85rem; box-sizing:border-box; }
.permit-tests-actions { display:flex; align-items:center; gap:10px; margin-top:6px; }
.permit-tests-hint { font-size:0.78rem; color:#64748b; }
.permit-row-remove { width:24px; height:24px; border-radius:50%; border:1px solid var(--color-border-light); background:#fff; color:#94a3b8; cursor:pointer; line-height:1; }
.permit-row-remove:hover { color:#dc2626; border-color:#fecaca; background:#fef2f2; }

.permit-yn { white-space:nowrap; }
.permit-yn label { margin-right:10px; font-size:0.85rem; }

.permit-branch-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)); gap:10px; }
.permit-branch-card { display:flex; align-items:flex-start; gap:10px; border:1px solid var(--color-border-light); border-radius:8px; padding:12px; cursor:pointer; background:#fff; }
.permit-branch-card.active { border-color:#0067b1; background:#eff6ff; box-shadow:0 0 0 1px #0067b1 inset; }
.permit-branch-card input { margin-top:3px; }
.permit-branch-title { font-weight:700; color:#0f172a; font-size:0.92rem; }
.permit-branch-hint { font-size:0.8rem; color:#64748b; line-height:1.45; margin-top:2px; }

.permit-entrants { display:grid; gap:10px; }
.permit-entrants > label { display:flex; flex-direction:column; gap:4px; }
.permit-entrants > label > span { font-size:0.75rem; font-weight:600; color:#475569; }
.permit-entrant-list { display:flex; flex-direction:column; gap:6px; margin-bottom:6px; }
.permit-entrant-row { display:flex; gap:6px; }
.permit-entrant-row input { flex:1; border:1px solid var(--color-border); border-radius:6px; padding:7px 9px; font-size:0.92rem; }
.btn-sm { padding:4px 10px; font-size:0.82rem; }

.permit-entry-exit { display:flex; flex-direction:column; gap:10px; margin:8px 0 14px; }
.permit-entry-row { display:flex; align-items:center; gap:14px; flex-wrap:wrap; padding:10px 12px; background:#f8fafc; border:1px solid var(--color-border-light); border-radius:8px; }
.permit-entry-label { font-size:0.85rem; font-weight:600; color:#475569; min-width:100px; }
.permit-entry-stamp { font-size:0.95rem; font-weight:600; color:#0f172a; font-variant-numeric:tabular-nums; }
.permit-entry-stamp.permit-entry-empty { color:#94a3b8; font-weight:400; }

.permit-overdue-banner { background:#fef2f2; border:1px solid #fecaca; border-left:4px solid #dc2626; border-radius:8px; padding:14px 16px; margin-bottom:16px; }
.permit-overdue-title { font-weight:700; color:#991b1b; font-size:1rem; margin-bottom:8px; }
.permit-overdue-list { display:flex; flex-direction:column; gap:4px; }
.permit-overdue-link { color:#7f1d1d; font-size:0.9rem; text-decoration:none; }
.permit-overdue-link:hover { text-decoration:underline; }
.permit-overdue-more { color:#991b1b; font-size:0.85rem; font-weight:600; padding-top:4px; }
.nav-card-overdue-badge { position:absolute; top:10px; right:12px; background:#dc2626; color:#fff; font-size:0.75rem; font-weight:700; padding:2px 8px; border-radius:999px; min-width:22px; text-align:center; box-shadow:0 1px 3px rgba(0,0,0,0.2); }

/* Confined Space Permit shortcut on the New Visit form */
.permit-shortcut-btn { width:100%; display:flex; align-items:center; justify-content:center; padding:14px 16px; font-size:1rem; font-weight:600; }

/* Premise number + Access Flag share a single header row. Premise hugs
   left, access block pushed all the way to the right via margin-left:auto
   so it lives in the wide empty blue area. */
.wo-panel-title { flex: 1 1 auto; min-width: 0; }
.wo-panel-premise-line { display:flex; align-items:center; gap:16px; flex-wrap:wrap; width:100%; }
.wo-panel-premise-id { display:flex; flex-direction:column; flex-shrink:0; }
/* Slim Access Flag controls — pushed right within the premise row */
.wo-panel-access { display:flex; align-items:center; gap:6px; min-width:260px; max-width:520px; flex-wrap:nowrap; margin-left:auto; }
.wo-panel-access-btn { display:inline-flex; align-items:center; gap:4px; font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; padding:3px 8px; border-radius:4px; border:1px solid #d1d5db; background:#fff; color:#6b7280; cursor:pointer; transition:all 0.15s; flex-shrink:0; }
.wo-panel-access-btn:hover { border-color:#f59e0b; color:#92400e; }
.wo-panel-access-on .wo-panel-access-btn { background:#f59e0b; color:#fff; border-color:#f59e0b; }
.wo-panel-access-icon { font-size:0.85rem; line-height:1; }
.wo-panel-access-notes { flex:1; min-width:120px; font-size:0.78rem; padding:3px 8px; border:1px solid #e5e7eb; border-radius:4px; background:#fff; color:#1f2937; }
.wo-panel-access-notes:disabled { background:#f9fafb; color:#9ca3af; }
.wo-panel-access-on .wo-panel-access-notes { border-color:#fcd34d; background:#fffbeb; }
/* Premises table Access column chip */
.access-chip { display:inline-block; font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; padding:2px 7px; border-radius:4px; background:#f59e0b; color:#fff; cursor:help; }

/* Tech-facing access flag surfaces (My WOs / Nearby WOs cards + create.html banners) */
.wo-card-access-flagged { border-left: 4px solid #f59e0b; }
.wo-card-access-chip { display:inline-flex; align-items:center; gap:4px; background:#fffbeb; color:#92400e; border:1px solid #fde68a; border-radius:4px; padding:2px 8px; font-size:0.78rem; font-weight:600; max-width:100%; }
.wo-card-access-chip-icon { font-size:0.95rem; }

.address-confirm-flag { background:#fffbeb; border:1px solid #f59e0b; border-radius:8px; padding:14px 16px; margin:14px 0; text-align:left; }
.address-confirm-flag-title { font-weight:700; color:#92400e; font-size:0.92rem; margin-bottom:6px; }
.address-confirm-flag-notes { color:#7c2d12; font-size:0.92rem; line-height:1.4; margin-bottom:12px; white-space:pre-wrap; }
.address-confirm-flag-ack { background:#f59e0b; color:#fff; border:none; border-radius:6px; padding:10px 16px; font-size:0.92rem; font-weight:600; cursor:pointer; width:100%; }
.address-confirm-flag-ack:hover { background:#d97706; }

.visit-access-flag { display:flex; align-items:flex-start; gap:10px; background:#fffbeb; border:1px solid #fcd34d; border-left:4px solid #f59e0b; border-radius:6px; padding:10px 14px; margin-top:10px; }
.visit-access-flag-icon { font-size:1.1rem; line-height:1.2; }
.visit-access-flag-title { font-weight:700; color:#92400e; font-size:0.85rem; }
.visit-access-flag-notes { color:#7c2d12; font-size:0.88rem; line-height:1.4; margin-top:2px; white-space:pre-wrap; }

/* Access Flag modal — in-app replacement for window.alert in the New Visit flow */
.access-flag-modal { position:fixed; inset:0; background:rgba(0,0,0,0.55); z-index:9500; display:flex; align-items:center; justify-content:center; padding:16px; }
.access-flag-modal.hidden { display:none; }
.access-flag-modal-card { background:#fffbeb; border:2px solid #f59e0b; border-radius:14px; max-width:440px; width:100%; padding:24px 22px 22px; box-shadow:0 12px 40px rgba(0,0,0,0.3); text-align:center; }
.access-flag-modal-icon { font-size:2.6rem; line-height:1; color:#f59e0b; margin-bottom:8px; }
.access-flag-modal-title { font-size:1.25rem; font-weight:700; color:#92400e; margin:0 0 12px; }
.access-flag-modal-notes { background:#fff; border:1px solid #fde68a; border-radius:8px; padding:12px 14px; color:#7c2d12; font-size:0.95rem; line-height:1.45; text-align:left; white-space:pre-wrap; margin-bottom:18px; }
.access-flag-modal-btn { width:100%; background:#f59e0b !important; color:#fff !important; padding:14px 18px; font-weight:700; border-radius:8px; border:none; cursor:pointer; font-size:1rem; }
.access-flag-modal-btn:hover { background:#d97706 !important; }

/* Client Portal week rows */
.portal-weeks-list { display:flex; flex-direction:column; gap:12px; }
.portal-week { background:#fff; border:1px solid var(--color-border-light); border-radius:10px; padding:16px 18px; box-shadow:0 1px 3px rgba(0,0,0,0.05); }
.portal-week-header { display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.portal-week-range { font-size:1.05rem; font-weight:700; color:#1f2937; }
.portal-week-meta { font-size:0.82rem; color:var(--color-text-secondary); margin-top:3px; }
.portal-week-btn { padding:9px 18px; font-size:0.92rem; font-weight:600; }
.portal-week-btn:disabled { opacity:0.5; cursor:not-allowed; }
.portal-week-status { font-size:0.82rem; color:var(--color-text-secondary); margin-top:10px; min-height:1em; }

/* Premises page Table/Map view toggle */
.view-toggle { display:inline-flex; border:1px solid #d1d5db; border-radius:8px; overflow:hidden; background:#f3f4f6; margin-left:auto; }
.view-toggle-btn { padding:6px 14px; font-size:0.85rem; font-weight:600; border:none; background:transparent; color:#374151; cursor:pointer; transition:background 0.15s; }
.view-toggle-btn:hover { background:#e5e7eb; }
.view-toggle-btn.active { background:#0067b1; color:#fff; }
.premises-toolbar { display:flex; align-items:center; gap:12px; }
.premises-map { width:100%; height:calc(100vh - 220px); min-height:500px; position:relative; }
.premises-map-leaflet { width:100%; height:100%; border:1px solid #e5e7eb; border-radius:6px; }
.premises-map-status { position:absolute; bottom:8px; left:8px; background:rgba(255,255,255,0.92); padding:4px 10px; border-radius:6px; font-size:0.75rem; color:#374151; box-shadow:0 1px 3px rgba(0,0,0,0.15); pointer-events:none; }

/* Safety / Emergency button — header SOS icon */
.safety-sos-btn { color:#dc2626 !important; }
.safety-sos-btn:hover, .safety-sos-btn:focus { background:#fee2e2 !important; }

/* Bottom-sheet popup invoked when SOS is tapped */
.safety-sheet-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.45); z-index:9000; display:flex; align-items:flex-end; justify-content:center; }
.safety-sheet { width:100%; max-width:480px; background:#fff; border-radius:16px 16px 0 0; padding:20px 18px 28px; box-shadow:0 -4px 20px rgba(0,0,0,0.2); display:flex; flex-direction:column; gap:12px; }
.safety-sheet-title { font-size:1.15rem; font-weight:700; color:#991b1b; }
.safety-sheet-sub { font-size:0.9rem; color:#475569; line-height:1.4; }
.safety-sheet-btn { padding:14px 16px; border-radius:10px; font-size:1rem; font-weight:600; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:10px; }
.safety-sheet-help { background:#dc2626; color:#fff; }
.safety-sheet-help:hover:not(:disabled) { background:#b91c1c; }
.safety-sheet-help:disabled { opacity:0.7; cursor:wait; }
.safety-sheet-cancel { background:#e2e8f0; color:#0f172a; }
.safety-sheet-cancel:hover { background:#cbd5e1; }
.safety-sheet-icon { font-size:1.2rem; }

/* Admin/power_user broadcast banner pinned above the app header */
.safety-broadcast-banner { background:#7f1d1d; color:#fff; padding:10px 14px; box-shadow:0 2px 4px rgba(0,0,0,0.15); }
.safety-broadcast-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding:6px 0; }
.safety-broadcast-row + .safety-broadcast-row { border-top:1px solid rgba(255,255,255,0.15); }
.safety-broadcast-icon { font-size:1.2rem; }
.safety-broadcast-text { flex:1; font-size:0.92rem; }
.safety-broadcast-map { color:#fef2f2; font-weight:600; text-decoration:underline; font-size:0.85rem; }
.safety-broadcast-nogps { color:#fecaca; font-size:0.8rem; font-style:italic; }
.safety-broadcast-ack { background:#fff; color:#7f1d1d; border:none; padding:6px 14px; border-radius:6px; font-size:0.82rem; font-weight:700; cursor:pointer; }
.safety-broadcast-ack:hover { background:#fef2f2; }

.permit-actions { display:flex; gap:8px; flex-wrap:wrap; padding-top:10px; }
.permit-toast { position:fixed; bottom:20px; left:50%; transform:translateX(-50%); padding:10px 18px; border-radius:8px; background:#0f172a; color:#fff; font-size:0.9rem; opacity:0; pointer-events:none; transition:opacity 0.2s; z-index:50; }
.permit-toast.show { opacity:0.95; }
.permit-toast-success { background:#166534; }
.permit-toast-error   { background:#991b1b; }
.permit-empty { padding:40px 20px; text-align:center; color:#64748b; background:#fff; border:1px solid var(--color-border-light); border-radius:10px; }

/* Permits list page */
.permits-container { max-width:1100px; margin:0 auto; padding:var(--spacing-md); }
.permits-toolbar { display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:12px; }
.permits-toolbar input, .permits-toolbar select { border:1px solid var(--color-border); border-radius:6px; padding:7px 9px; font-size:0.9rem; background:#fff; }
.permits-toolbar input { flex:1; min-width:200px; max-width:320px; }
.permits-count { font-size:0.85rem; color:#64748b; margin-left:auto; }
.permits-table { width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--color-border-light); border-radius:10px; overflow:hidden; box-shadow:0 1px 2px rgba(0,0,0,0.03); }
.permits-table th, .permits-table td { padding:10px 14px; border-bottom:1px solid var(--color-border-light); text-align:left; font-size:0.9rem; }
.permits-table thead th { background:#f8fafc; font-weight:700; color:#0f172a; font-size:0.78rem; text-transform:uppercase; letter-spacing:0.04em; }
.permits-table tbody tr { cursor:pointer; }
.permits-table tbody tr:hover { background:#f8fafc; }
.permits-empty { padding:40px 20px; text-align:center; color:#64748b; }
.permit-id-link { color:#0067b1; font-weight:600; font-family:ui-monospace, Menlo, monospace; font-size:0.82rem; }

.wo-panel-permit-cta { padding:8px 16px 4px; }
.wo-panel-permit-cta .btn-secondary { display:inline-block; }

.permit-picker { max-width:560px; margin:24px auto; padding:24px 20px; background:#fff; border:1px solid var(--color-border-light); border-radius:12px; text-align:center; box-shadow:0 1px 4px rgba(0,0,0,0.05); }
.permit-picker h2 { margin:0 0 8px 0; font-size:1.1rem; color:#0f172a; }
.permit-picker-hint { color:#64748b; font-size:0.92rem; margin:0 0 16px 0; }
.permit-picker-input-wrap { position:relative; }
.permit-picker-input { width:100%; padding:12px 14px; font-size:1rem; border:1px solid var(--color-border); border-radius:8px; box-sizing:border-box; }
.permit-picker-input:focus { outline:none; border-color:#0067b1; box-shadow:0 0 0 3px rgba(0,103,177,0.12); }
.permit-picker-or { color:#94a3b8; font-size:0.82rem; margin:14px 0; letter-spacing:0.04em; }

