/* ============================================================
   DEERING'S GARAGE — Industrial / Performance Dashboard Theme
   ============================================================ */

:root {
    --bg-primary: #1a1a1a;
    --bg-secondary: #222222;
    --bg-card: #2a2a2a;
    --bg-card-header: #1f1f1f;
    --bg-input: #1a1a1a;

    --accent-red: #c0392b;
    --accent-red-bright: #e74c3c;
    --accent-red-dark: #8e2a20;
    --accent-chrome: #8a8a8a;
    --accent-chrome-bright: #cccccc;

    --text-primary: #f0f0f0;
    --text-secondary: #aaaaaa;
    --text-muted: #666666;
    --text-dim: #444444;

    --border-color: #333333;
    --border-strong: #444444;
    --border-accent: #c0392b;

    --success: #27ae60;
    --success-bright: #2ecc71;
    --warning: #f39c12;
    --warning-bright: #f1c40f;
    --danger: #c0392b;
    --info: #2980b9;
    --info-bright: #3498db;
    --purple: #9b59b6;

    --carbon-fiber: repeating-linear-gradient(
        45deg,
        transparent,
        transparent 2px,
        rgba(255, 255, 255, 0.015) 2px,
        rgba(255, 255, 255, 0.015) 4px
    );
    --brushed-metal: linear-gradient(135deg, #2c2c2c 0%, #353535 50%, #2c2c2c 100%);
    --chrome-gradient: linear-gradient(135deg, #555 0%, #888 50%, #555 100%);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body { min-height: 100vh; }

body {
    background: var(--bg-primary);
    background-image: var(--carbon-fiber);
    color: var(--text-primary);
    font-family: 'Rajdhani', 'Segoe UI', system-ui, sans-serif;
    font-size: 16px;
    line-height: 1.45;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--accent-red-bright); text-decoration: none; }
a:hover { color: var(--accent-chrome-bright); }

h1, h2, h3, h4, h5 { font-family: 'Rajdhani', sans-serif; font-weight: 700; letter-spacing: 0.02em; }

.mono, code, pre, .data-value, .odometer-value, .gauge-value-text, .metric-value {
    font-family: 'Share Tech Mono', 'Courier New', monospace;
}

/* ============================================================
   RACING STRIPE + NAVIGATION
   ============================================================ */
.racing-stripe {
    height: 3px;
    background: linear-gradient(90deg,
        var(--accent-red) 0%,
        var(--accent-red-bright) 50%,
        var(--accent-red) 100%);
    width: 100%;
    box-shadow: 0 0 6px rgba(231, 76, 60, 0.5);
}

.navbar {
    background: #111;
    background-image: var(--carbon-fiber);
    border-bottom: 2px solid var(--accent-red);
    padding: 0.65rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
    position: sticky;
    top: 0;
    z-index: 100;
}
.navbar-brand {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
    color: var(--text-primary);
}
.navbar-brand img { height: 38px; width: auto; }
.navbar-brand .brand-name {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: 1.1rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.navbar-brand .brand-name .accent { color: var(--accent-red); }

.navbar-links {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    flex-wrap: wrap;
}
.navbar-links a {
    color: var(--text-secondary);
    text-decoration: none;
    padding: 0.45rem 0.85rem;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600;
    font-size: 0.85rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border-bottom: 2px solid transparent;
    transition: color 0.15s, border-color 0.15s;
}
.navbar-links a:hover { color: var(--text-primary); }
.navbar-links a.active {
    color: var(--accent-red-bright);
    border-bottom-color: var(--accent-red);
}

.nav-toggle { display: none; }

/* ============================================================
   LAYOUT
   ============================================================ */
.container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 1.25rem 1rem 3rem;
}

.footer {
    background: #111;
    border-top: 1px solid var(--border-color);
    padding: 1rem 1.5rem;
    color: var(--text-muted);
    font-size: 0.78rem;
    text-align: center;
    font-family: 'Rajdhani', sans-serif;
    letter-spacing: 0.05em;
}

/* ============================================================
   FLASH MESSAGES (dashboard alert style)
   ============================================================ */
.flash {
    padding: 0.7rem 1rem 0.7rem 1.1rem;
    border-radius: 3px;
    margin-bottom: 0.7rem;
    background: var(--bg-card);
    border-left: 4px solid var(--accent-chrome);
    font-family: 'Rajdhani', sans-serif;
    font-size: 0.95rem;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.flash::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent-chrome);
    box-shadow: 0 0 6px currentColor;
}
.flash-success { border-left-color: var(--success); color: var(--success-bright); }
.flash-success::before { background: var(--success); color: var(--success); }
.flash-error,
.flash-danger { border-left-color: var(--danger); color: var(--accent-red-bright); }
.flash-error::before,
.flash-danger::before { background: var(--danger); color: var(--danger); }
.flash-warning { border-left-color: var(--warning); color: var(--warning-bright); }
.flash-warning::before { background: var(--warning); color: var(--warning); }
.flash-info { border-left-color: var(--info); color: var(--info-bright); }
.flash-info::before { background: var(--info); color: var(--info); }

/* ============================================================
   CARDS
   ============================================================ */
.card {
    background: var(--bg-card);
    background-image: var(--carbon-fiber);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    margin-bottom: 1.25rem;
    overflow: hidden;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
}
.card-stripe { border-top: 2px solid var(--accent-red); }
.card-header {
    background: var(--bg-card-header);
    border-bottom: 2px solid var(--accent-red);
    padding: 0.65rem 1rem;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: 0.95rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-primary);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.card-header .accent { color: var(--accent-red-bright); }
.card-body { padding: 1rem; }

.detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.75rem;
    padding: 0.85rem 1rem;
}
.detail-item { padding: 0.25rem 0; }
.detail-label {
    font-family: 'Rajdhani', sans-serif;
    font-size: 0.7rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 0.15rem;
}
.detail-value {
    font-size: 0.95rem;
    color: var(--text-primary);
    word-break: break-word;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600;
    letter-spacing: 0.06em;
    border: 1px solid transparent;
    cursor: pointer;
    padding: 0.5rem 1.05rem;
    border-radius: 3px;
    transition: all 0.15s ease;
    text-transform: uppercase;
    font-size: 0.85rem;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    line-height: 1.2;
    background: var(--bg-card-header);
    color: var(--text-primary);
    border-color: var(--border-strong);
}
.btn:hover { background: #2a2a2a; }
.btn-red { background: var(--accent-red); color: #fff; border-color: var(--accent-red-dark); }
.btn-red:hover { background: var(--accent-red-bright); box-shadow: 0 0 10px rgba(231, 76, 60, 0.45); color: #fff; }
.btn-chrome {
    background: var(--chrome-gradient);
    color: #f0f0f0;
    border-color: #444;
}
.btn-chrome:hover {
    background: linear-gradient(135deg, #666 0%, #999 50%, #666 100%);
    color: #fff;
}
.btn-black { background: #000; color: #f0f0f0; border-color: #2a2a2a; }
.btn-black:hover { background: #1a1a1a; }
.btn-blue { background: var(--info); color: #fff; border-color: #1f6a9b; }
.btn-blue:hover { background: var(--info-bright); }
.btn-green { background: var(--success); color: #fff; border-color: #1f8949; }
.btn-green:hover { background: var(--success-bright); box-shadow: 0 0 10px rgba(39, 174, 96, 0.45); }
.btn-gray { background: #444; color: #f0f0f0; border-color: #555; }
.btn-gray:hover { background: #555; }
.btn-outline {
    background: transparent;
    color: var(--text-secondary);
    border: 1px solid var(--border-strong);
}
.btn-outline:hover { color: var(--text-primary); border-color: var(--accent-red); }
.btn-sm { padding: 0.3rem 0.7rem; font-size: 0.72rem; }
.btn-lg { padding: 0.75rem 1.6rem; font-size: 1rem; }
.btn-block { width: 100%; justify-content: center; }
.btn-group { display: flex; flex-wrap: wrap; gap: 0.4rem; align-items: center; }

/* ============================================================
   STATUS BADGES / WARNING LIGHTS
   ============================================================ */
.badge,
.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.22rem 0.7rem;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 700;
    font-family: 'Rajdhani', sans-serif;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 1px solid;
    background: var(--bg-card-header);
    color: var(--text-secondary);
    border-color: var(--border-strong);
    white-space: nowrap;
}
.badge::before,
.status-badge::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
    box-shadow: 0 0 6px currentColor;
}

.badge-intake,    .status-Intake               { color: #5b9bd5; border-color: #2980b9; background: #142233; }
.badge-diagnostic,.status-Diagnostic           { color: #f39c12; border-color: #b8770f; background: #2a2010; }
.badge-waiting,   .status-Waiting-for-Approval { color: #f1c40f; border-color: #b89b0e; background: #2a2510; }
.badge-approved,  .status-Approved             { color: #27ae60; border-color: #1f8949; background: #102a18; }
.badge-parts,     .status-Waiting-for-Parts    { color: #e91e63; border-color: #ad1750; background: #2a1018; }
.badge-progress,  .status-In-Progress          { color: #3498db; border-color: #1f6a9b; background: #102233; }
.badge-complete,  .status-Complete             { color: #27ae60; border-color: #1f8949; background: #102a18; }
.badge-pickup,    .status-Ready-for-Pickup     { color: #2ecc71; border-color: #1f8949; background: #102a18; }
.badge-pickedup,  .status-Picked-Up            { color: #95a5a6; border-color: #555; background: #1a1a1a; }
.badge-cancelled, .status-Cancelled            { color: #c0392b; border-color: #8e2a20; background: #2a1010; }

/* Estimate status (legacy class names) */
.badge-est-draft    { color: #aaa;     border-color: #555; background: #1f1f1f; }
.badge-est-sent     { color: #3498db;  border-color: #1f6a9b; background: #102233; }
.badge-est-approved { color: #27ae60;  border-color: #1f8949; background: #102a18; }
.badge-est-invoiced { color: #f39c12;  border-color: #b8770f; background: #2a2010; }
.badge-est-voided   { color: #c0392b;  border-color: #8e2a20; background: #2a1010; }

/* Warning lights (dashboard) */
.warning-lights {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: 0.85rem;
}
.warning-light-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    padding: 0.85rem 0.5rem;
    text-align: center;
}
.warning-light {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    margin: 0 auto 0.45rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.05rem;
    font-family: 'Share Tech Mono', monospace;
    color: rgba(255,255,255,0.85);
    background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.12), rgba(0,0,0,0.6) 70%);
    border: 2px solid currentColor;
    color: var(--text-muted);
    box-shadow: 0 0 0 rgba(0,0,0,0);
    transition: box-shadow 0.3s;
}
.warning-light .count { color: var(--text-primary); }
.warning-light.lit { box-shadow: 0 0 12px currentColor, inset 0 0 12px rgba(0,0,0,0.4); }
.warning-light.pulse { animation: pulse-glow 2s ease-in-out infinite; }

.light-intake     { color: #5b9bd5; }
.light-diagnostic { color: #f39c12; }
.light-progress   { color: #3498db; }
.light-parts      { color: #e91e63; }
.light-ready      { color: #2ecc71; }
.light-approval   { color: #f1c40f; }

.warning-label {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600;
    font-size: 0.7rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--text-secondary);
    line-height: 1.2;
}

@keyframes pulse-glow {
    0%, 100% { box-shadow: 0 0 8px currentColor, inset 0 0 6px rgba(0,0,0,0.4); }
    50%      { box-shadow: 0 0 22px currentColor, 0 0 36px currentColor, inset 0 0 10px rgba(0,0,0,0.4); }
}

/* ============================================================
   GAUGES (SVG-based tachometer cards)
   ============================================================ */
.gauge-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}
.gauge-card {
    background: var(--bg-card);
    background-image: var(--carbon-fiber);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 1rem 0.75rem 0.85rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.gauge-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent 0%, var(--accent-red) 50%, transparent 100%);
}
.gauge-svg { display: block; margin: 0 auto; width: 100%; max-width: 220px; height: auto; }
.gauge-label {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: 0.8rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-top: 0.2rem;
}
.gauge-sub {
    font-family: 'Rajdhani', sans-serif;
    font-size: 0.7rem;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    margin-top: 0.15rem;
}
.gauge-value-text {
    font-family: 'Share Tech Mono', monospace;
    fill: var(--text-primary);
}

/* SVG needle pivot */
.gauge-needle {
    transform-origin: 100px 100px;
    transform: rotate(var(--needle-angle, -135deg));
    animation: needle-sweep 1.2s ease-out;
}
@keyframes needle-sweep {
    from { transform: rotate(-135deg); }
    to   { transform: rotate(var(--needle-angle, -135deg)); }
}

/* Hero (large) gauge variant */
.gauge-card.gauge-hero { padding: 1.25rem; }
.gauge-card.gauge-hero .gauge-svg { max-width: 320px; }
.gauge-card.gauge-hero .gauge-label { font-size: 0.95rem; margin-top: 0.5rem; }

/* ============================================================
   ODOMETER / METRIC CLUSTER
   ============================================================ */
.metric-cluster {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0.85rem;
    margin-bottom: 1.5rem;
}
.metric-card {
    background: var(--brushed-metal);
    border: 1px solid var(--border-strong);
    border-radius: 4px;
    padding: 0.9rem 1rem;
    text-align: left;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 2px 4px rgba(0,0,0,0.4);
    position: relative;
}
.metric-card.profit { border-left: 4px solid var(--success); }
.metric-card.loss   { border-left: 4px solid var(--danger); }
.metric-card.tax    { border-left: 4px solid var(--warning); }
.metric-card.info   { border-left: 4px solid var(--info); }
.metric-label {
    font-family: 'Rajdhani', sans-serif;
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 0.3rem;
}
.metric-value {
    font-family: 'Share Tech Mono', monospace;
    font-size: 1.5rem;
    color: var(--text-primary);
    letter-spacing: 0.05em;
    line-height: 1.1;
    word-break: break-word;
}
.metric-card.profit .metric-value { color: var(--success-bright); }
.metric-card.loss .metric-value   { color: var(--accent-red-bright); }

/* ============================================================
   TABLES
   ============================================================ */
.table-wrap { overflow-x: auto; }
table.data-table,
.card table {
    width: 100%;
    border-collapse: collapse;
    background: transparent;
}
.card table thead tr,
.data-table thead tr { background: var(--bg-card-header); }
.card table th,
.data-table th {
    border-bottom: 2px solid var(--accent-red);
    padding: 0.55rem 0.7rem;
    text-align: left;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-secondary);
}
.card table td,
.data-table td {
    padding: 0.55rem 0.7rem;
    border-bottom: 1px solid var(--border-color);
    font-size: 0.9rem;
    vertical-align: middle;
    color: var(--text-primary);
}
.card table tbody tr,
.data-table tbody tr {
    transition: background 0.1s, box-shadow 0.1s;
    border-left: 3px solid transparent;
}
.card table tbody tr:hover,
.data-table tbody tr:hover {
    background: rgba(192, 57, 43, 0.06);
    border-left-color: var(--accent-red);
}
.card table tbody tr td:first-child,
.data-table tbody tr td:first-child { font-family: 'Share Tech Mono', monospace; }

.td-action { text-align: right; white-space: nowrap; }

/* ============================================================
   FORMS
   ============================================================ */
.form-group { margin-bottom: 1rem; }
.form-row,
.form-row-2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.85rem;
    margin-bottom: 1rem;
}
.form-row-3 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.7rem;
    margin-bottom: 1rem;
}
label,
.form-label {
    display: block;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 0.3rem;
}
input[type='text'],
input[type='password'],
input[type='email'],
input[type='tel'],
input[type='number'],
input[type='url'],
input[type='date'],
input[type='time'],
input[type='datetime-local'],
input[type='file'],
input[type='search'],
select,
textarea,
.form-control {
    width: 100%;
    background: var(--bg-input);
    border: 1px solid var(--border-strong);
    border-radius: 3px;
    color: var(--text-primary);
    padding: 0.5rem 0.7rem;
    font-family: 'Rajdhani', sans-serif;
    font-size: 0.95rem;
    transition: border-color 0.15s, box-shadow 0.15s;
}
textarea { resize: vertical; min-height: 70px; font-family: 'Rajdhani', sans-serif; }
input:focus,
select:focus,
textarea:focus,
.form-control:focus {
    outline: none;
    border-color: var(--accent-red);
    box-shadow: 0 0 0 2px rgba(192, 57, 43, 0.2);
}
input::placeholder,
textarea::placeholder { color: #555; }

/* Checkbox/radio inherit native, just spaced */
input[type='checkbox'],
input[type='radio'] { width: auto; accent-color: var(--accent-red); }

/* Style native file inputs a bit */
input[type='file'] { padding: 0.35rem 0.5rem; font-size: 0.85rem; }

/* ============================================================
   LOGIN PAGE
   ============================================================ */
.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    background: var(--bg-primary);
    background-image:
        radial-gradient(circle at 20% 20%, rgba(192,57,43,0.10), transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(192,57,43,0.06), transparent 60%),
        var(--carbon-fiber);
}
.login-box {
    background: var(--bg-card);
    border: 1px solid var(--border-strong);
    border-top: 3px solid var(--accent-red);
    border-radius: 6px;
    padding: 2rem 1.75rem;
    width: 100%;
    max-width: 380px;
    text-align: center;
    box-shadow: 0 6px 25px rgba(0,0,0,0.55), 0 0 30px rgba(192,57,43,0.08);
}
.login-box img { max-width: 130px; height: auto; margin-bottom: 0.6rem; }
.login-box h1 {
    font-family: 'Rajdhani', sans-serif;
    font-size: 1rem;
    color: var(--text-secondary);
    letter-spacing: 0.15em;
    text-transform: uppercase;
    margin-bottom: 1.4rem;
}

/* ============================================================
   EQUIPMENT / DETAIL CARDS
   ============================================================ */
.equipment-card {
    background: #232323;
    border: 1px solid var(--border-color);
    border-left: 3px solid var(--accent-red);
    border-radius: 3px;
    padding: 0.9rem 1rem;
    margin-bottom: 0.85rem;
}
.equip-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.5rem;
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--border-color);
}
.equip-number {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-primary);
}

/* ============================================================
   STATUS TIMELINE
   ============================================================ */
.timeline {
    position: relative;
    padding: 0.5rem 0 0.5rem 1.6rem;
}
.timeline::before {
    content: '';
    position: absolute;
    top: 0.5rem;
    bottom: 0.5rem;
    left: 0.45rem;
    width: 2px;
    background: linear-gradient(180deg, var(--accent-red), var(--border-color));
}
.timeline-item {
    position: relative;
    padding: 0.4rem 0 0.85rem;
}
.timeline-item::before {
    content: '';
    position: absolute;
    left: -1.3rem;
    top: 0.6rem;
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 50%;
    background: var(--text-muted);
    border: 2px solid var(--bg-card);
    box-shadow: 0 0 0 1px var(--text-muted);
}
.timeline-item.active::before {
    background: var(--accent-red);
    box-shadow: 0 0 0 1px var(--accent-red), 0 0 12px var(--accent-red);
}
.timeline-time {
    font-family: 'Share Tech Mono', monospace;
    font-size: 0.72rem;
    color: var(--text-muted);
}
.timeline-title {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600;
    color: var(--text-primary);
}
.timeline-note { font-size: 0.85rem; color: var(--text-secondary); }

/* ============================================================
   PHOTOS GRID
   ============================================================ */
.photo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 0.6rem;
}
.photo-card {
    background: #1a1a1a;
    border: 1px solid var(--border-color);
    border-radius: 3px;
    overflow: hidden;
    transition: transform 0.15s, border-color 0.15s;
}
.photo-card:hover { transform: scale(1.02); border-color: var(--accent-red); }
.photo-card img { display: block; width: 100%; height: 110px; object-fit: cover; }
.photo-info {
    padding: 0.35rem 0.5rem;
    font-size: 0.72rem;
    color: var(--text-secondary);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.3rem;
    font-family: 'Rajdhani', sans-serif;
    letter-spacing: 0.04em;
}

/* ============================================================
   TECH NOTES (clipboard / mechanic feel)
   ============================================================ */
.note-entry {
    background: #232323;
    border: 1px solid var(--border-color);
    border-radius: 3px;
    padding: 0.7rem 0.9rem;
    margin-bottom: 0.55rem;
}
.note-entry.public { border-left: 3px solid var(--success); }
.note-entry.private { border-left: 3px solid var(--text-muted); }
.note-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
    font-family: 'Rajdhani', sans-serif;
    font-size: 0.72rem;
    color: var(--text-muted);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 0.3rem;
}
.note-meta .public-tag  { color: var(--success-bright); }
.note-meta .private-tag { color: var(--text-secondary); }
.note-body {
    font-family: 'Share Tech Mono', monospace;
    font-size: 0.88rem;
    color: var(--text-primary);
    white-space: pre-wrap;
    line-height: 1.45;
}

/* ============================================================
   LEGAL / WARRANTY BLOCKS
   ============================================================ */
.legal-box {
    background: #1d1d1d;
    border: 1px dashed var(--border-strong);
    border-radius: 3px;
    padding: 0.85rem 1rem;
    color: var(--text-secondary);
    font-size: 0.82rem;
    line-height: 1.5;
}
.legal-box h3 {
    font-size: 0.78rem;
    letter-spacing: 0.15em;
    color: var(--accent-red-bright);
    margin-bottom: 0.4rem;
}

/* ============================================================
   UTILITIES
   ============================================================ */
.text-mono { font-family: 'Share Tech Mono', monospace; }
.text-muted { color: var(--text-muted); }
.text-secondary { color: var(--text-secondary); }
.text-red { color: var(--accent-red-bright); }
.text-success { color: var(--success-bright); }
.text-warning { color: var(--warning-bright); }
.text-uppercase { text-transform: uppercase; letter-spacing: 0.1em; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: 0.5rem; }
.mt-2 { margin-top: 1rem; }
.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: 0.5rem; }
.mb-2 { margin-bottom: 1rem; }
.hide-mobile { display: initial; }
.no-print { }

.conditional { display: none; }
.conditional.active { display: block; }

/* Details/summary chrome-button look */
details > summary {
    cursor: pointer;
    list-style: none;
    user-select: none;
    display: inline-block;
}
details > summary::-webkit-details-marker { display: none; }

/* ============================================================
   PRINT — let print_order.html use its own light styling
   ============================================================ */
@media print {
    body { background: white; color: black; }
    .navbar, .footer, .no-print { display: none !important; }
}

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width: 768px) {
    .navbar { padding: 0.55rem 0.9rem; }
    .nav-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: transparent;
        border: 1px solid var(--border-strong);
        color: var(--text-primary);
        padding: 0.3rem 0.55rem;
        border-radius: 3px;
        cursor: pointer;
        font-size: 1.1rem;
    }
    .navbar-links {
        display: none;
        width: 100%;
        flex-direction: column;
        align-items: stretch;
        margin-top: 0.5rem;
        border-top: 1px solid var(--border-color);
        padding-top: 0.5rem;
    }
    .navbar-links.open { display: flex; }
    .navbar-links a { padding: 0.55rem 0.5rem; border-bottom: 1px solid var(--border-color); }
    .navbar-links a.active { border-bottom-color: var(--accent-red); }

    .gauge-grid { grid-template-columns: 1fr 1fr; }
    .hide-mobile { display: none; }

    /* Stack table to label-value */
    .card table thead { display: none; }
    .card table,
    .card table tbody,
    .card table tr,
    .card table td { display: block; width: 100%; }
    .card table tr {
        background: #232323;
        margin-bottom: 0.6rem;
        border: 1px solid var(--border-color);
        border-radius: 3px;
        padding: 0.4rem 0.6rem;
    }
    .card table td {
        border-bottom: 1px solid var(--border-color);
        padding: 0.35rem 0;
        display: flex;
        justify-content: space-between;
        gap: 0.5rem;
    }
    .card table td:last-child { border-bottom: none; }
    .card table td::before {
        content: attr(data-label);
        font-family: 'Rajdhani', sans-serif;
        font-size: 0.72rem;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--text-muted);
    }
}

/* ============================================================
   Z06 INSTRUMENT CLUSTER — extended dashboard styles
   ============================================================ */

/* Tighter card for Z06 gauges */
.gauge-card.z06-gauge {
    padding: 0.7rem 0.6rem 0.85rem;
    background:
        radial-gradient(ellipse at center, rgba(40,40,40,0.4) 0%, rgba(10,10,10,0.0) 70%),
        var(--bg-card);
    background-image:
        radial-gradient(ellipse at center, rgba(40,40,40,0.4) 0%, rgba(10,10,10,0.0) 70%),
        var(--carbon-fiber);
    border-radius: 8px;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.04),
        0 4px 14px rgba(0,0,0,0.45);
}
.z06-gauge .gauge-svg { max-width: 240px; }

.needle, .needle-shadow {
    transform-origin: 100px 100px;
    transform: rotate(var(--needle-angle, -135deg));
}
.needle        { animation: needle-sweep 1.5s cubic-bezier(0.34, 1.56, 0.64, 1) forwards; }
.needle-shadow {
    animation: needle-sweep 1.5s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
    transform-origin: 102px 102px;
}
@keyframes needle-sweep {
    from { transform: rotate(-135deg); }
    to   { transform: rotate(var(--needle-angle, -135deg)); }
}

/* ============================================================
   STATUS CONTROL PANEL (rocker switches)
   ============================================================ */
.switch-panel {
    position: relative;
    background:
        repeating-linear-gradient( 45deg, transparent, transparent 2px, rgba(255,255,255,0.025) 2px, rgba(255,255,255,0.025) 4px),
        repeating-linear-gradient(-45deg, transparent, transparent 2px, rgba(255,255,255,0.018) 2px, rgba(255,255,255,0.018) 4px),
        linear-gradient(180deg, #1a1a1a 0%, #0e0e0e 100%);
    border: 1px solid #2a2a2a;
    border-top: 2px solid #3a3a3a;
    border-radius: 6px;
    padding: 1.6rem 1rem 1rem;
    margin: 1rem 0 1.25rem;
    box-shadow: inset 0 2px 8px rgba(0,0,0,0.6), 0 2px 6px rgba(0,0,0,0.4);
}
.switch-panel-label {
    position: absolute;
    top: -10px; left: 1rem;
    background: var(--bg-primary);
    padding: 0 .6rem;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .72rem;
    letter-spacing: .2em;
    color: #c0392b;
    text-shadow: 0 0 6px rgba(192,57,43,0.4);
}
.switch-panel-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
    gap: 0.85rem;
    align-items: end;
}
.rocker-wrap {
    text-align: center;
    display: flex; flex-direction: column; align-items: center;
    gap: 0.3rem;
}

.rocker {
    position: relative;
    width: 60px; height: 64px;
    border: none;
    border-radius: 4px;
    padding: 0;
    background: linear-gradient(180deg, #2a2a2a 0%, #1a1a1a 100%);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.05),
        inset 0 -1px 0 rgba(0,0,0,0.6),
        0 2px 3px rgba(0,0,0,0.6);
    cursor: pointer;
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .1s;
}
.rocker:active { transform: translateY(1px); }
.rocker-half {
    flex: 1;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .6rem;
    letter-spacing: .15em;
    color: #555;
    transition: background .15s, color .15s, box-shadow .15s;
}
.rocker-on {
    background: linear-gradient(180deg, #252525 0%, #1a1a1a 100%);
    border-bottom: 1px solid #0a0a0a;
}
.rocker-off {
    background: linear-gradient(180deg, #181818 0%, #101010 100%);
    color: #444;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.6);
}
.rocker-led {
    position: absolute;
    top: 4px; right: 4px;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #1a1a1a;
    box-shadow: inset 0 0 2px rgba(0,0,0,0.6);
    transition: background .15s, box-shadow .25s;
}

/* Rocker color variants — switch glow color when ON */
.rocker.rk-intake    { --rk-color: #2980b9; }
.rocker.rk-diag      { --rk-color: #f39c12; }
.rocker.rk-approval  { --rk-color: #e74c3c; }
.rocker.rk-progress  { --rk-color: #e67e22; }
.rocker.rk-parts     { --rk-color: #9b59b6; }
.rocker.rk-ready     { --rk-color: #27ae60; }

.rocker.on .rocker-on {
    background: linear-gradient(180deg, var(--rk-color) 0%, color-mix(in srgb, var(--rk-color) 60%, black) 100%);
    color: #fff;
    text-shadow: 0 0 4px rgba(0,0,0,.6);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.18), 0 0 8px var(--rk-color);
}
.rocker.on .rocker-off { opacity: .55; }
.rocker.on .rocker-led {
    background: var(--rk-color);
    box-shadow:
        0 0 6px var(--rk-color),
        0 0 12px var(--rk-color),
        inset 0 0 2px rgba(255,255,255,0.6);
}

.rocker-count {
    font-family: 'Share Tech Mono', monospace;
    font-size: .95rem;
    color: var(--text-primary);
}
.rocker-label {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 600;
    font-size: .68rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-secondary);
    line-height: 1.15;
}

/* ============================================================
   GUARDED PUSH-TO-START "NEW ORDER" BUTTON
   ============================================================ */
.launch-wrap { gap: 0.35rem; }
.launch-housing {
    position: relative;
    width: 68px; height: 68px;
    perspective: 200px;
}
.launch-btn {
    position: absolute; inset: 0;
    border-radius: 50%;
    border: none;
    background:
        radial-gradient(circle at 35% 30%, #ff6b5b 0%, #c0392b 45%, #6a0000 100%);
    box-shadow:
        inset 0 -3px 6px rgba(0,0,0,0.5),
        inset 0 2px 4px rgba(255,255,255,0.2),
        0 0 14px rgba(192,57,43,0.55),
        0 3px 6px rgba(0,0,0,0.6);
    color: #fff;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .58rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    text-align: center;
    cursor: pointer;
    z-index: 1;
    transition: transform .12s, box-shadow .12s;
}
.launch-btn .launch-ring {
    position: absolute; inset: 6px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.18);
    pointer-events: none;
}
.launch-btn.pressed {
    transform: scale(0.92);
    box-shadow:
        inset 0 4px 10px rgba(0,0,0,0.7),
        0 0 24px #e74c3c,
        0 0 38px rgba(231,76,60,0.55);
}
.launch-guard {
    position: absolute; inset: 0;
    border-radius: 50%;
    background:
        repeating-linear-gradient(45deg, #e67e22 0 8px, #1a1a1a 8px 14px);
    border: 2px solid #b86200;
    box-shadow:
        inset 0 -3px 6px rgba(0,0,0,0.5),
        0 3px 6px rgba(0,0,0,0.6);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    z-index: 2;
    transform-origin: top center;
    transition: transform 0.4s cubic-bezier(0.68, -0.55, 0.27, 1.55);
    backface-visibility: hidden;
}
.launch-guard.open { transform: rotateX(110deg); }
.launch-guard-stripes {
    position: absolute; inset: 4px;
    border-radius: 50%;
    background: radial-gradient(circle at center, rgba(255,255,255,0.06) 0%, transparent 60%);
    pointer-events: none;
}
.launch-guard-text {
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .55rem;
    letter-spacing: .08em;
    color: #fff;
    background: rgba(0,0,0,0.55);
    padding: 1px 4px;
    border-radius: 2px;
}

/* ============================================================
   WORK ORDERS TABLE — Z06 enhancements
   ============================================================ */
.workorders-card { position: relative; }

.filter-toggle-row {
    display: flex; gap: 0.3rem; align-items: center; flex-wrap: wrap;
}
.filter-toggle {
    background: linear-gradient(180deg, #1f1f1f, #131313);
    color: var(--text-secondary);
    border: 1px solid var(--border-color);
    padding: .28rem .7rem;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .68rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    border-radius: 12px;
    cursor: pointer;
    transition: all .15s;
}
.filter-toggle:hover { color: var(--text-primary); border-color: var(--border-strong); }
.filter-toggle.on {
    background: linear-gradient(180deg, var(--accent-red), var(--accent-red-dark));
    color: #fff;
    border-color: var(--accent-red-dark);
    box-shadow: 0 0 8px rgba(192,57,43,0.4), inset 0 1px 0 rgba(255,255,255,0.1);
}

.z06-table tbody tr {
    background-image:
        repeating-linear-gradient(45deg, transparent 0 4px, rgba(255,255,255,0.008) 4px 5px);
    border-left: 3px solid transparent;
    transition: background-color .15s, border-left-color .15s, box-shadow .15s;
}
.z06-table tbody tr:hover {
    background-color: rgba(192,57,43,0.06);
    border-left-color: var(--accent-red);
    box-shadow: inset 0 0 18px rgba(192,57,43,0.08);
}
.order-id-mono {
    font-family: 'Share Tech Mono', monospace;
    color: var(--accent-red-bright);
    letter-spacing: .05em;
}
.unread-badge {
    display: inline-block;
    margin-left: .4rem;
    background: var(--accent-red);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: 1px 7px;
    border-radius: 10px;
    vertical-align: middle;
    box-shadow: 0 0 6px rgba(231,76,60,.5);
}
.tier-low  { color: #888; }
.tier-mid  { color: #f1c40f; }
.tier-high { color: #f39c12; }
.tier-top  { color: #2ecc71; text-shadow: 0 0 4px rgba(46,204,113,.4); }

.btn-z06-view {
    display: inline-block;
    background: linear-gradient(135deg, #6a0000 0%, #c0392b 100%);
    color: #fff;
    padding: .35rem .8rem;
    border-radius: 3px;
    font-family: 'Rajdhani', sans-serif;
    font-weight: 700;
    font-size: .78rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    text-decoration: none;
    border: 1px solid #8e2a20;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 1px 3px rgba(0,0,0,0.5);
    transition: filter .15s;
}
.btn-z06-view:hover { filter: brightness(1.15); color: #fff; }

/* ============================================================
   FAST & FURIOUS BANNER + SHAKE + KONAMI OVERLAY
   ============================================================ */
.ff-toast {
    position: fixed;
    top: -120px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, #1a0000, #2a0000, #1a0000);
    border: 2px solid #c0392b;
    border-top: 4px solid #e74c3c;
    border-radius: 0 0 8px 8px;
    padding: 18px 32px;
    display: flex;
    align-items: center;
    gap: 16px;
    color: #fff;
    font-family: 'Rajdhani', sans-serif;
    font-style: italic;
    max-width: 700px;
    min-width: 400px;
    transition: top 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
    z-index: 9999;
    box-shadow: 0 8px 32px rgba(192,57,43,0.5), 0 0 60px rgba(192,57,43,0.3);
}
.ff-toast.show { top: 0; }
.ff-toast-icon { font-size: 36px; }
.ff-toast-text { font-size: 18px; line-height: 1.4; font-weight: 500; }

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25%      { transform: translateX(-10px); }
    75%      { transform: translateX(10px); }
}

/* Konami code: full-screen overlay with GIF + huge text */
.konami-overlay {
    position: fixed;
    inset: 0;
    background: rgba(192,57,43,0.3);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 99999;
    transition: opacity 1s;
    animation: konami-flash 0.3s;
}
.konami-overlay.fade-out { opacity: 0; }
.konami-overlay img {
    max-width: 600px;
    max-height: 60vh;
    border: 4px solid #e74c3c;
    border-radius: 8px;
    box-shadow: 0 0 60px rgba(231,76,60,0.8);
}
.konami-text {
    font-family: 'Rajdhani', sans-serif;
    font-size: 72px;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 0 20px #e74c3c, 0 4px 8px rgba(0,0,0,0.8);
    letter-spacing: 0.1em;
    margin-top: 24px;
    text-align: center;
}
@keyframes konami-flash {
    0%   { background: rgba(231,76,60,0.8); }
    100% { background: rgba(192,57,43,0.3); }
}
@keyframes shake-big {
    0%, 100% { transform: translateX(0); }
    10% { transform: translateX(-20px) rotate(-1deg); }
    20% { transform: translateX( 20px) rotate( 1deg); }
    30% { transform: translateX(-20px) rotate(-1deg); }
    40% { transform: translateX( 20px) rotate( 1deg); }
    50% { transform: translateX(-15px); }
    60% { transform: translateX( 15px); }
    70% { transform: translateX(-10px); }
    80% { transform: translateX( 10px); }
    90% { transform: translateX(-5px); }
}

