/* ============================================================
   Job Dispatch — Government service design system
   ------------------------------------------------------------
   Calm, accessible, predictable. Inspired by aus.gov.au /
   GOV.UK service standards. Built on Bootstrap 5.3.

   - Public Sans (open-source gov standard) for body
   - System sans for headings (kept simple, weight-driven hierarchy)
   - High-contrast service blue primary
   - Generous spacing, soft borders, no editorial flourishes
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Public+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* --------------------------------------------
   Design tokens
   -------------------------------------------- */
:root {
    /* Surface */
    --bg:           #F5F7FA;
    --bg-deep:      #E8ECF1;
    --card:         #FFFFFF;

    /* Text */
    --ink:          #1A1F2B;     /* near-black, high contrast */
    --ink-soft:     #2A3140;
    --ink-mute:     #5C6470;
    --ink-faint:    #8590A0;

    /* Lines */
    --line:         #D6DBE2;
    --line-strong:  #9BA4B0;

    /* Brand — service blue */
    --primary:      #0B5FFF;
    --primary-dark: #003BB3;
    --primary-tint: #E8F0FF;
    --primary-faint:#F4F8FF;

    /* Semantic */
    --ok:           #137333;
    --ok-tint:      #E6F4EA;
    --warn:         #B26200;
    --warn-tint:    #FFF4E0;
    --danger:       #B00020;
    --danger-tint:  #FCE8E8;
    --info:         #0B5FFF;
    --info-tint:    #E8F0FF;

    /* Type */
    --font-body:    'Public Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-mono:    ui-monospace, 'SF Mono', Menlo, monospace;

    /* Focus */
    --focus-ring:   #FFBF47;     /* gov.uk-style yellow focus indicator */
    --focus-ring-shadow: 0 0 0 3px var(--focus-ring), 0 0 0 5px var(--ink);

    /* Shadow — soft, not editorial */
    --shadow-sm: 0 1px 2px rgba(26, 31, 43, 0.04), 0 1px 1px rgba(26, 31, 43, 0.06);
    --shadow-md: 0 1px 3px rgba(26, 31, 43, 0.06), 0 4px 12px rgba(26, 31, 43, 0.06);
}

/* --------------------------------------------
   Base
   -------------------------------------------- */
html, body { background: var(--bg); }
body {
    font-family: var(--font-body);
    color: var(--ink-soft);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-body);
    color: var(--ink);
    font-weight: 700;
    line-height: 1.25;
    letter-spacing: -0.01em;
}
h1, .h1 { font-size: clamp(1.75rem, 4vw, 2.25rem); }
h2, .h2 { font-size: clamp(1.5rem, 3.5vw, 1.875rem); }
h3, .h3 { font-size: 1.375rem; }
h4, .h4 { font-size: 1.25rem; }
h5, .h5 { font-size: 1.0625rem; }
h6, .h6 { font-size: 0.875rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--ink-mute); }

p { color: var(--ink-soft); margin-bottom: 1rem; }

/* Eyebrow / small caption */
.eyebrow {
    display: inline-block;
    font-size: .8125rem;
    font-weight: 600;
    color: var(--ink-mute);
    text-transform: uppercase;
    letter-spacing: .06em;
}

/* Italic class — only used for emphasis inside paragraphs, never for headings */
.italic-serif { font-style: normal; font-weight: 700; color: var(--ink); }

/* Tabular figures for prices/IDs */
.num, .stat-num, .table td, .table th, code, time {
    font-variant-numeric: tabular-nums;
}

/* --------------------------------------------
   Skip link
   -------------------------------------------- */
.skip-link {
    position: absolute; top: -48px; left: 1rem; z-index: 10000;
    background: var(--ink); color: #fff; padding: .6rem 1rem;
    border-radius: 0 0 4px 4px; text-decoration: none; font-weight: 600;
    transition: top 150ms ease-out;
}
.skip-link:focus { top: 0; color: #fff; }

/* --------------------------------------------
   Focus rings — gov.uk yellow + ink outline
   -------------------------------------------- */
*:focus-visible {
    outline: 3px solid var(--focus-ring) !important;
    outline-offset: 0 !important;
    box-shadow: 0 0 0 5px var(--ink) !important;
    border-radius: 2px;
}
.form-control:focus,
.form-select:focus {
    outline: 3px solid var(--focus-ring) !important;
    outline-offset: 0 !important;
    box-shadow: 0 0 0 5px var(--ink) !important;
    border-color: var(--ink) !important;
}
.btn:focus-visible {
    outline: 3px solid var(--focus-ring) !important;
    outline-offset: 2px !important;
    box-shadow: none !important;
}

/* --------------------------------------------
   Links
   -------------------------------------------- */
a, a:link, a:visited {
    color: var(--primary);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}
a:hover { color: var(--primary-dark); text-decoration-thickness: 2px; }
.nav-link, .navbar-brand, .btn, .dropdown-item,
.view-toggle a, .skip-link, a.btn { text-decoration: none !important; }

/* --------------------------------------------
   Buttons
   -------------------------------------------- */
.btn {
    font-family: var(--font-body);
    font-weight: 600;
    border-radius: 4px;
    border-width: 1px;
    padding: .55rem 1.25rem;
    transition: background-color 120ms, border-color 120ms, color 120ms;
    min-height: 44px;
    line-height: 1.4;
}
.btn-lg { min-height: 52px; padding: .85rem 1.5rem; font-size: 1.0625rem; }
.btn-sm { min-height: 36px; padding: .35rem .85rem; font-size: .875rem; }

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--primary);
    --bs-btn-border-color: var(--primary);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-color: #fff;
    --bs-btn-disabled-color: #fff;
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    color: #fff !important;
}
.btn-primary:hover { background: var(--primary-dark) !important; border-color: var(--primary-dark) !important; color: #fff !important; }
.btn-primary:active { background: var(--primary-dark) !important; border-color: var(--primary-dark) !important; color: #fff !important; }
.btn-primary:disabled { background: var(--line-strong); border-color: var(--line-strong); }

/* Accent retained as alias = primary in gov palette */
.btn-accent {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
}
.btn-accent:hover { background: var(--primary-dark); border-color: var(--primary-dark); color: #fff; }

.btn-outline-primary {
    background: transparent;
    border-color: var(--primary);
    color: var(--primary);
}
.btn-outline-primary:hover { background: var(--primary); color: #fff; }

.btn-secondary,
.btn-outline-secondary {
    background: transparent;
    border-color: var(--line-strong);
    color: var(--ink);
}
.btn-secondary:hover,
.btn-outline-secondary:hover { background: var(--bg-deep); border-color: var(--ink-mute); color: var(--ink); }

.btn-success { background: var(--ok); border-color: var(--ok); color: #fff; }
.btn-success:hover { background: #0F5A28; border-color: #0F5A28; color: #fff; }
.btn-warning { background: var(--warn); border-color: var(--warn); color: #fff; }
.btn-warning:hover { background: #8A4D00; border-color: #8A4D00; color: #fff; }
.btn-danger { background: var(--danger); border-color: var(--danger); color: #fff; }
.btn-danger:hover { background: #8A0019; border-color: #8A0019; color: #fff; }
.btn-outline-danger { background: transparent; border-color: var(--danger); color: var(--danger); }
.btn-outline-danger:hover { background: var(--danger); color: #fff; }

/* --------------------------------------------
   Forms
   -------------------------------------------- */
.form-control, .form-select {
    font-family: var(--font-body);
    border: 1.5px solid var(--line-strong);
    border-radius: 4px;
    background: var(--card);
    color: var(--ink);
    padding: .55rem .75rem;
    min-height: 44px;
    transition: border-color 120ms;
    font-size: 1rem;
}
.form-control-lg, .form-select-lg { min-height: 52px; font-size: 1.0625rem; padding: .75rem 1rem; }
.form-control:hover:not(:focus), .form-select:hover:not(:focus) { border-color: var(--ink); }
.form-control::placeholder { color: var(--ink-faint); opacity: 1; }
.form-control:disabled, .form-control[readonly] { background: var(--bg-deep); border-color: var(--line); }

.form-label {
    font-weight: 600;
    color: var(--ink);
    margin-bottom: .35rem;
    font-size: 1rem;
}
.form-label.small { font-size: .875rem; }
.form-text { color: var(--ink-mute); font-size: .875rem; }
.text-muted, small.text-muted { color: var(--ink-mute) !important; }

.form-check-input {
    border: 1.5px solid var(--line-strong);
    width: 1.15em; height: 1.15em;
}
.form-check-input:checked { background-color: var(--primary); border-color: var(--primary); }
.form-switch .form-check-input { width: 2.25em; }

/* --------------------------------------------
   Cards & containers
   -------------------------------------------- */
.book-card, .stat-card, .job-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow-sm);
}
.book-card  { padding: 1.75rem; max-width: 560px; margin: 0 auto; }
.stat-card  { padding: 1.25rem; }
.job-card   { padding: 1.1rem; gap: .55rem; }

.table-responsive {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow-sm);
    overflow-x: auto;
}

@media (max-width: 575px) {
    .book-card { padding: 1.25rem; }
}

/* Stat card numerics */
.stat-card .stat-num {
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 2rem;
    color: var(--ink);
    line-height: 1.1;
    letter-spacing: -0.01em;
}
.stat-card .stat-num .text-muted {
    font-size: 1rem;
    font-weight: 500;
    color: var(--ink-mute);
}
.stat-card .stat-label {
    color: var(--ink-mute);
    font-size: .8125rem;
    margin-top: .35rem;
    font-weight: 500;
}

/* --------------------------------------------
   Navbar — service blue banner, white text
   -------------------------------------------- */
.navbar {
    background: var(--primary) !important;
    border-bottom: 4px solid var(--primary-dark);
    padding-top: calc(.85rem + env(safe-area-inset-top, 0px));
    padding-bottom: .85rem;
    padding-left: calc(1rem + env(safe-area-inset-left, 0px));
    padding-right: calc(1rem + env(safe-area-inset-right, 0px));
}
.navbar-dark { color: #fff; }
.navbar-brand {
    font-weight: 700;
    color: #fff !important;
    font-size: 1.1875rem;
    letter-spacing: -0.005em;
}
.navbar-dark .navbar-brand:hover { color: #fff !important; opacity: .85; }
.navbar-dark .nav-link {
    color: rgba(255, 255, 255, 0.92) !important;
    font-weight: 500;
    font-size: .9375rem;
    padding: .5rem 1rem;
    border-radius: 4px;
    transition: background 120ms;
}
.navbar-dark .nav-link:hover {
    color: #fff !important;
    background: rgba(255, 255, 255, 0.12);
}
.navbar-dark .nav-link.active,
.navbar-dark .nav-link[aria-current="page"] {
    color: #fff !important;
    background: rgba(255, 255, 255, 0.18);
}
.navbar-dark .navbar-toggler { border-color: rgba(255,255,255,.4); }
.navbar-dark .navbar-toggler:focus-visible { box-shadow: none !important; }

/* Hover-open dropdowns on desktop */
@media (min-width: 768px) {
    .navbar .nav-item.dropdown:hover > .dropdown-menu { display: block; margin-top: 0; }
    .navbar .nav-item.dropdown > .dropdown-toggle { cursor: default; }
}
.navbar-dark .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

.dropdown-menu {
    border: 1px solid var(--line);
    border-radius: 6px;
    box-shadow: var(--shadow-md);
    padding: .35rem;
}
.dropdown-item { color: var(--ink); font-weight: 500; border-radius: 3px; padding: .55rem .85rem; }
.dropdown-item:hover, .dropdown-item:focus { background: var(--bg-deep); color: var(--ink); }
.dropdown-divider { border-top-color: var(--line); }

.conn-dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; margin-right: 8px; vertical-align: middle; }
.conn-online  { background: #6FDC8C; box-shadow: 0 0 0 2px rgba(255,255,255,.25); }
.conn-offline { background: #FF8389; box-shadow: 0 0 0 2px rgba(255,255,255,.25); }

/* --------------------------------------------
   Auth screens — clean centered card, gov style
   -------------------------------------------- */
.login-body {
    min-height: 100dvh;
    background: var(--bg);
    display: flex;
    align-items: center;
    padding: 1rem;
}
.login-wrap { width: 100%; display: flex; justify-content: center; }
.login-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-top: 6px solid var(--primary);
    border-radius: 6px;
    box-shadow: var(--shadow-md);
    padding: 2.25rem 2rem 2rem;
    width: 100%;
    max-width: 420px;
}
.login-card h4 {
    font-weight: 700;
    font-size: 1.625rem;
    color: var(--ink);
    letter-spacing: -0.005em;
}
.login-logo { display: none; }   /* gov pages don't need a decorative logo block */

/* --------------------------------------------
   Public booking page hero — simple blue band
   -------------------------------------------- */
.book-body { background: var(--bg); min-height: 100dvh; }
.book-hero {
    background: var(--primary);
    color: #fff;
    padding: 2rem 1.5rem 2.5rem;
    text-align: left;
    border-radius: 0;
    margin-bottom: 1.5rem;
    border-bottom: 4px solid var(--primary-dark);
}
.book-hero h1 {
    font-weight: 700;
    font-size: clamp(1.75rem, 5vw, 2.25rem);
    color: #fff;
    margin: 0;
    letter-spacing: -0.01em;
}
.book-hero p {
    color: rgba(255,255,255,0.9);
    margin: .35rem 0 0;
    font-size: 1rem;
}
.book-hero .eyebrow { color: rgba(255,255,255,0.85); }
.book-hero .italic-serif { color: #fff; font-style: normal; }
.book-tick {
    font-size: 3rem;
    color: var(--ok);
    line-height: 1;
    margin-bottom: .75rem;
}

/* --------------------------------------------
   Fieldsets inside booking forms
   -------------------------------------------- */
.book-card fieldset {
    border: 1px solid var(--line);
    border-radius: 6px;
    padding: 1rem 1.1rem .75rem;
    margin-bottom: 1.25rem;
    background: var(--bg);
}
.book-card legend {
    font-weight: 700;
    font-size: .8125rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--ink-mute);
    width: auto;
    padding: 0 .35rem;
    margin-bottom: .35rem;
}

/* --------------------------------------------
   Alerts
   -------------------------------------------- */
.alert {
    border: 1px solid;
    border-left-width: 4px;
    border-radius: 4px;
    padding: 1rem 1.1rem;
    display: flex;
    gap: .65rem;
    align-items: flex-start;
}
.alert > i.bi:first-child { font-size: 1.15rem; line-height: 1.4; flex-shrink: 0; }
.alert-success { background: var(--ok-tint); color: var(--ok); border-color: var(--ok); }
.alert-success > i.bi:first-child { color: var(--ok); }
.alert-danger  { background: var(--danger-tint); color: var(--danger); border-color: var(--danger); }
.alert-danger > i.bi:first-child { color: var(--danger); }
.alert-warning { background: var(--warn-tint); color: var(--warn); border-color: var(--warn); }
.alert-warning > i.bi:first-child { color: var(--warn); }
.alert-info    { background: var(--info-tint); color: var(--primary-dark); border-color: var(--primary); }
.alert-info > i.bi:first-child { color: var(--primary); }
.alert a { color: inherit; font-weight: 700; text-decoration: underline; }

/* --------------------------------------------
   Job cards — gov data-list style
   -------------------------------------------- */
.job-card {
    display: flex; flex-direction: column; gap: .25rem;
    height: 100%;
    border-left: 4px solid var(--line-strong);
}
.job-card.pending  { border-left-color: var(--primary); }
.job-card.active   { border-left-color: var(--warn); }
.job-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: .5rem;
    margin-bottom: .35rem;
}
.job-card .customer {
    font-weight: 700;
    font-size: 1.0625rem;
    color: var(--ink);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .35rem;
    line-height: 1.3;
}
.job-card .actions { display: flex; gap: .5rem; margin-top: .65rem; }

/* Definition-list style data row */
.data-row {
    display: grid;
    grid-template-columns: 84px 1fr;
    gap: .5rem;
    padding: .25rem 0;
    font-size: .9375rem;
    line-height: 1.4;
    align-items: baseline;
}
.data-row .data-label {
    color: var(--ink-mute);
    font-weight: 600;
    font-size: .8125rem;
    text-transform: uppercase;
    letter-spacing: .03em;
}
.data-row .data-value {
    color: var(--ink);
}
.data-row a[href^="tel:"] {
    color: var(--primary);
    font-weight: 600;
    text-decoration: none;
}
.data-row a[href^="tel:"]:hover { text-decoration: underline; }
@media (max-width: 575px) {
    .data-row { grid-template-columns: 76px 1fr; gap: .45rem; }
    .data-row .data-label { font-size: .75rem; }
}

/* --------------------------------------------
   Department code chip — small, uppercase, mono-ish
   -------------------------------------------- */
.dept-code {
    display: inline-block;
    padding: 1px 7px;
    border: 1px solid var(--line-strong);
    border-radius: 3px;
    font-family: var(--font-mono);
    font-size: .75rem;
    font-weight: 700;
    color: var(--ink);
    background: var(--bg);
    letter-spacing: .02em;
    line-height: 1.6;
    vertical-align: middle;
}

/* Leg badge — quiet text label, not a colour chip */
.leg-badge {
    display: inline-block;
    padding: 1px 8px;
    border: 1px solid var(--line-strong);
    border-radius: 3px;
    font-size: .75rem;
    font-weight: 600;
    color: var(--ink-mute);
    background: var(--card);
    text-transform: none;
    line-height: 1.6;
    vertical-align: middle;
}
.leg-badge.return { background: var(--primary-tint); color: var(--primary-dark); border-color: var(--primary); }

/* --------------------------------------------
   Status badges — pill-shaped, semantic color
   -------------------------------------------- */
.job-status-badge,
.badge {
    display: inline-block;
    padding: 3px 10px;
    border: 1px solid transparent;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 600;
    background: var(--bg-deep);
    color: var(--ink);
    line-height: 1.4;
    text-transform: none;
    letter-spacing: 0;
}
.badge-pending     { background: var(--primary-tint); color: var(--primary-dark); border-color: var(--primary); }
.badge-claimed     { background: var(--warn-tint); color: var(--warn); border-color: var(--warn); }
.badge-in_progress { background: var(--warn-tint); color: var(--warn); border-color: var(--warn); }
.badge-completed   { background: var(--ok-tint); color: var(--ok); border-color: var(--ok); }
.badge-cancelled   { background: var(--danger-tint); color: var(--danger); border-color: var(--danger); }

.badge.bg-primary  { background: var(--primary) !important; color: #fff !important; border-color: var(--primary); }
.badge.bg-secondary{ background: var(--bg-deep) !important; color: var(--ink) !important; border-color: var(--line); }
.badge.bg-success  { background: var(--ok-tint) !important; color: var(--ok) !important; border-color: var(--ok); }
.badge.bg-danger   { background: var(--danger-tint) !important; color: var(--danger) !important; border-color: var(--danger); }
.badge.bg-warning  { background: var(--warn-tint) !important; color: var(--warn) !important; border-color: var(--warn); }
.badge.bg-info     { background: var(--info-tint) !important; color: var(--primary-dark) !important; border-color: var(--primary); }
.badge.bg-light    { background: var(--bg-deep) !important; color: var(--ink) !important; border-color: var(--line); }

/* --------------------------------------------
   Tables
   -------------------------------------------- */
.table { margin-bottom: 0; color: var(--ink-soft); }
.table thead th {
    font-size: .8125rem;
    color: var(--ink-mute);
    background: var(--bg);
    border-bottom: 2px solid var(--line-strong);
    padding: .85rem .75rem;
    font-weight: 700;
    text-transform: none;
    letter-spacing: 0;
}
.table tbody tr { border-bottom: 1px solid var(--line); }
.table tbody tr:last-child { border-bottom: 0; }
.table tbody td { padding: .85rem .75rem; vertical-align: middle; }
.table-hover tbody tr:hover { background: var(--primary-faint); }

/* --------------------------------------------
   Code blocks
   -------------------------------------------- */
code, .code {
    font-family: var(--font-mono);
    background: var(--bg-deep);
    color: var(--ink);
    padding: 1px 6px;
    border-radius: 3px;
    font-size: .9em;
}

/* --------------------------------------------
   Toasts
   -------------------------------------------- */
.toast-container { z-index: 9999; }
.toast {
    border: 1px solid var(--line);
    border-radius: 6px;
    box-shadow: var(--shadow-md);
    background: var(--card);
    color: var(--ink);
}
.toast.text-bg-primary { background: var(--primary) !important; color: #fff !important; border-color: var(--primary-dark); }
.toast.text-bg-success { background: var(--ok-tint) !important; color: var(--ok) !important; border: 1px solid var(--ok) !important; }
.toast.text-bg-danger  { background: var(--danger-tint) !important; color: var(--danger) !important; border: 1px solid var(--danger) !important; }
.toast.text-bg-warning { background: var(--warn-tint) !important; color: var(--warn) !important; border: 1px solid var(--warn) !important; }
.toast .btn-close { filter: none; }
.toast.text-bg-primary .btn-close { filter: invert(1) brightness(2); }

/* --------------------------------------------
   Modals
   -------------------------------------------- */
.modal-content {
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow-md);
    background: var(--card);
}
.modal-header { border-bottom: 1px solid var(--line); padding: 1rem 1.25rem; }
.modal-footer { border-top: 1px solid var(--line); padding: 1rem 1.25rem; }
.modal-title { font-weight: 700; font-size: 1.125rem; color: var(--ink); }

/* --------------------------------------------
   Receipt thumb
   -------------------------------------------- */
.receipt-thumb {
    max-width: 48px; max-height: 48px;
    border: 1px solid var(--line);
    border-radius: 4px;
    cursor: pointer;
}
.receipt-preview-img { max-width: 100%; max-height: 220px; border: 1px solid var(--line); border-radius: 4px; }

/* --------------------------------------------
   Page head
   -------------------------------------------- */
.page-head {
    margin-bottom: 1.75rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--line);
}
.page-head .eyebrow { margin-bottom: .25rem; }
.page-head h1, .page-head h4 {
    font-weight: 700;
    margin: 0;
    font-size: clamp(1.625rem, 4vw, 2rem);
    letter-spacing: -0.005em;
    color: var(--ink);
}
.page-head p { margin-top: .35rem; }

/* Section divider */
.section-rule {
    display: flex; align-items: center; gap: .75rem;
    margin: 1.5rem 0 1rem;
}
.section-rule::before,
.section-rule::after {
    content: ''; flex: 1; height: 1px; background: var(--line);
}
.section-rule .eyebrow { margin: 0; white-space: nowrap; }

/* --------------------------------------------
   View toggle (Live / Past) — segmented control
   -------------------------------------------- */
.view-toggle {
    display: inline-flex;
    border: 1px solid var(--line-strong);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 1.5rem;
    background: var(--card);
}
.view-toggle a,
.view-toggle a:link,
.view-toggle a:visited {
    padding: .55rem 1.25rem !important;
    font-weight: 600 !important;
    color: var(--ink) !important;
    text-decoration: none !important;
    border-right: 1px solid var(--line-strong) !important;
    background: var(--card) !important;
    line-height: 1.4 !important;
    font-size: .9375rem !important;
    transition: background 120ms !important;
}
.view-toggle a:last-child { border-right: 0 !important; }
.view-toggle a.active,
.view-toggle a[aria-current="true"] { background: var(--primary) !important; color: #fff !important; }
.view-toggle a:hover { background: var(--bg-deep) !important; }
.view-toggle a.active:hover { background: var(--primary) !important; color: #fff !important; }

/* --------------------------------------------
   Misc utility overrides
   -------------------------------------------- */
hr { border-top: 1px solid var(--line); opacity: 1; }
.text-success { color: var(--ok) !important; }
.text-warning { color: var(--warn) !important; }
.text-danger  { color: var(--danger) !important; }
.text-primary { color: var(--primary) !important; }

.progress { background: var(--bg-deep); border: 1px solid var(--line); height: 8px; border-radius: 4px; }
.progress-bar { background: var(--primary); }

/* ETA quick-pick chips */
.eta-pick {
    border: 1px solid var(--line-strong) !important;
    background: var(--card) !important;
    color: var(--ink) !important;
    font-weight: 600 !important;
    min-width: 64px !important;
    border-radius: 4px !important;
}
.eta-pick:hover { background: var(--primary-tint) !important; border-color: var(--primary) !important; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
}

/* Safe area */
@supports (padding: max(0px)) {
    body { padding-bottom: env(safe-area-inset-bottom, 0); }
}

/* Inline editing (jobs table) */
.inline-edit {
    display: inline-block;
    width: 100%;
    font-size: .8rem;
    line-height: 1.3;
    padding: 0;
    margin: 0;
    border: 1px solid transparent;
    background: transparent;
    outline: none;
    color: inherit;
    font-family: inherit;
}
.inline-edit:focus,
.inline-edit--active {
    border-color: #93c5fd;
    background: #eff6ff;
    border-radius: 3px;
    padding: 0 3px;
}

/* Print */
@media print {
    .navbar, .toast-container, .btn { display: none !important; }
    body { background: #fff !important; }
    .job-card, .book-card, .stat-card, .table-responsive { box-shadow: none !important; }
}
