:root {
    --turquoise: #009eaa;
    --turquoise-dark: #007d86;
    --turquoise-soft: #e8f8f9;
    --red-brand: #ef002d;
    --red: #e3342f;
    --red-soft: #fff0f1;
    --yellow: #f0b429;
    --yellow-soft: #fff8df;
    --green: #1ea55b;
    --green-soft: #edf9f2;
    --dark: #172326;
    --dark-2: #223236;
    --muted: #66777b;
    --muted-2: #8b999c;
    --line: #d8e0e2;
    --line-soft: #e9eef0;
    --surface: #ffffff;
    --background: #f2f5f6;
    --sidebar: #11191b;
    --shadow: 0 12px 36px rgba(23, 35, 38, .08);
    --radius: 14px;
    --radius-small: 9px;
    --sidebar-width: 252px;
    --transition: 160ms ease;
}

* { box-sizing: border-box; }
html { min-height: 100%; scroll-behavior: smooth; }
body {
    margin: 0;
    min-height: 100%;
    background: var(--background);
    color: var(--dark);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 14px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}
button, input, textarea, select { font: inherit; }
a { color: var(--turquoise-dark); }
img { max-width: 100%; }
code { font-family: "SFMono-Regular", Consolas, monospace; font-size: .92em; }
.sr-only { position: absolute !important; width: 1px !important; height: 1px !important; padding: 0 !important; margin: -1px !important; overflow: hidden !important; clip: rect(0, 0, 0, 0) !important; white-space: nowrap !important; border: 0 !important; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: var(--sidebar-width) minmax(0, 1fr); }
.sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 50;
    width: var(--sidebar-width);
    display: flex;
    flex-direction: column;
    background: var(--sidebar);
    color: #fff;
    overflow-y: auto;
}
.brand {
    display: block;
    padding: 22px 20px 17px;
    color: #fff;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.brand img { display: block; width: 100%; height: auto; background: #fff; border-radius: 7px; padding: 8px 8px 5px; }
.brand strong { display: block; margin-top: 12px; color: #fff; font-size: 16px; letter-spacing: -.01em; }
.brand span { display: block; margin-top: 2px; color: #aec4c8; font-size: 10px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; }
.main-nav { padding: 16px 12px; display: grid; gap: 4px; }
.nav-link {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 43px;
    padding: 9px 12px;
    border-radius: 9px;
    color: #c8d4d6;
    text-decoration: none;
    font-weight: 650;
    transition: background var(--transition), color var(--transition), transform var(--transition);
}
.nav-link:hover { background: rgba(255,255,255,.07); color: #fff; }
.nav-link.active { background: var(--turquoise); color: #fff; box-shadow: inset 3px 0 0 #fff; }
.nav-icon { width: 22px; height: 22px; display: grid; place-items: center; font-size: 16px; font-weight: 800; }
.nav-icon::before { content: "•"; }
.nav-icon[data-icon="dashboard"]::before { content: "▦"; }
.nav-icon[data-icon="shipments"]::before { content: "▤"; }
.nav-icon[data-icon="subcontractors"]::before { content: "◆"; }
.nav-icon[data-icon="tours"]::before { content: "↔"; }
.nav-icon[data-icon="analytics"]::before { content: "▥"; }
.nav-icon[data-icon="reports"]::before { content: "▧"; }
.nav-icon[data-icon="users"]::before { content: "●"; }
.nav-icon[data-icon="settings"]::before { content: "⚙"; }
.nav-icon[data-icon="help"]::before { content: "?"; }
.sidebar-footer { margin-top: auto; padding: 16px; border-top: 1px solid rgba(255,255,255,.08); }
.sidebar-footer small { display: block; margin-top: 12px; color: #7f9498; text-align: center; }
.user-compact { margin-bottom: 12px; }
.user-compact strong, .user-compact span { display: block; }
.user-compact strong { font-size: 13px; }
.user-compact span { margin-top: 2px; color: #9fb2b6; font-size: 11px; }

.main-area { grid-column: 2; min-width: 0; }
.topbar {
    position: sticky;
    top: 0;
    z-index: 35;
    min-height: 78px;
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 12px clamp(18px, 2.6vw, 38px);
    background: rgba(255,255,255,.95);
    border-bottom: 1px solid var(--line-soft);
    backdrop-filter: blur(12px);
}
.topbar h1 { margin: 1px 0 0; font-size: clamp(20px, 2vw, 27px); line-height: 1.1; letter-spacing: -.025em; }
.topbar-actions { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.eyebrow { color: var(--turquoise-dark); font-size: 10px; font-weight: 800; letter-spacing: .105em; text-transform: uppercase; }
.account-link { width: 37px; height: 37px; display: grid; place-items: center; border-radius: 50%; background: var(--dark); color: #fff; text-decoration: none; font-weight: 800; }
.menu-toggle { display: none; width: 40px; height: 40px; border: 0; border-radius: 9px; background: var(--background); padding: 9px; cursor: pointer; }
.menu-toggle span { display: block; height: 2px; margin: 4px 0; background: var(--dark); }
.content { padding: clamp(18px, 2.5vw, 36px); max-width: 1700px; margin: 0 auto; }
.content-narrow { max-width: 760px; margin: 0 auto; }
.sidebar-backdrop { display: none; }

.panel {
    background: var(--surface);
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    box-shadow: 0 4px 14px rgba(23,35,38,.035);
    padding: clamp(18px, 2vw, 25px);
    margin-bottom: 22px;
}
.panel-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-bottom: 19px; }
.panel-header h2 { margin: 2px 0 0; font-size: 18px; letter-spacing: -.015em; }
.panel-actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: 8px; }
.panel-span-2 { grid-column: span 2; }
.accent-panel { border-top: 4px solid var(--turquoise); }
.sticky-panel { position: sticky; top: 100px; }
.muted { color: var(--muted); }
.divider { margin: 25px 0; border: 0; border-top: 1px solid var(--line-soft); }

.button {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    border: 1px solid transparent;
    border-radius: var(--radius-small);
    padding: 8px 13px;
    text-decoration: none;
    font-weight: 750;
    line-height: 1.2;
    cursor: pointer;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition), border-color var(--transition);
}
.button:hover { transform: translateY(-1px); }
.button-primary { background: var(--turquoise); color: #fff; box-shadow: 0 5px 14px rgba(0,158,170,.18); }
.button-primary:hover { background: var(--turquoise-dark); }
.button-secondary { background: #fff; color: var(--dark); border-color: var(--line); }
.button-secondary:hover { border-color: var(--turquoise); color: var(--turquoise-dark); }
.button-ghost { background: transparent; color: var(--muted); border-color: rgba(255,255,255,.15); }
.button-dark { background: var(--dark); color: #fff; }
.button-full { width: 100%; }
.button-large { min-height: 46px; }
.text-link, .table-action { color: var(--turquoise-dark); font-weight: 750; text-decoration: none; }
.text-link:hover, .table-action:hover { text-decoration: underline; }

.alert { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 18px; padding: 13px 15px; border: 1px solid; border-radius: 10px; }
.alert-success { color: #11683a; background: var(--green-soft); border-color: #bce4ce; }
.alert-error { color: #a11e26; background: var(--red-soft); border-color: #f1c1c5; }
.alert-warning { color: #7c5900; background: var(--yellow-soft); border-color: #ecd991; }
.alert-close { border: 0; background: transparent; color: currentColor; font-size: 20px; line-height: 1; cursor: pointer; }

.traffic-signal {
    position: relative;
    display: grid;
    gap: 8px;
    padding: 10px;
    border: 3px solid #384346;
    border-radius: 18px;
    background: linear-gradient(145deg, #101617, #263033 58%, #111718);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.13), inset 0 -10px 22px rgba(0,0,0,.35), 0 14px 28px rgba(12,20,22,.22);
}
.traffic-signal::before {
    content: "";
    position: absolute;
    left: 50%;
    top: -8px;
    width: 48%;
    height: 8px;
    transform: translateX(-50%);
    border-radius: 7px 7px 0 0;
    background: #20292b;
}
.traffic-signal__lamp {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 1;
    overflow: hidden;
    border: 3px solid #080b0c;
    border-radius: 50%;
    background: #252c2e;
    box-shadow: inset 0 8px 14px rgba(0,0,0,.78), inset 0 -2px 2px rgba(255,255,255,.08);
    opacity: .34;
    transition: opacity var(--transition), filter var(--transition), box-shadow var(--transition);
}
.traffic-signal__lamp::after {
    content: "";
    position: absolute;
    inset: 10% 16% 55% 16%;
    border-radius: 50%;
    background: linear-gradient(180deg, rgba(255,255,255,.42), rgba(255,255,255,0));
    transform: rotate(-10deg);
}
.traffic-signal__lamp--red { background: radial-gradient(circle at 50% 55%, #e43732 0 42%, #8d1818 72%, #441010 100%); }
.traffic-signal__lamp--yellow { background: radial-gradient(circle at 50% 55%, #f6bd28 0 42%, #9a6d08 72%, #4d3506 100%); }
.traffic-signal__lamp--green { background: radial-gradient(circle at 50% 55%, #24b768 0 42%, #117040 72%, #0a3823 100%); }
.traffic-signal__lamp.is-active { opacity: 1; filter: saturate(1.18) brightness(1.08); }
.traffic-signal__lamp--red.is-active { box-shadow: inset 0 8px 14px rgba(0,0,0,.42), 0 0 16px rgba(227,52,47,.78), 0 0 34px rgba(227,52,47,.38); }
.traffic-signal__lamp--yellow.is-active { box-shadow: inset 0 8px 14px rgba(0,0,0,.38), 0 0 16px rgba(240,180,41,.76), 0 0 34px rgba(240,180,41,.34); }
.traffic-signal__lamp--green.is-active { box-shadow: inset 0 8px 14px rgba(0,0,0,.38), 0 0 16px rgba(30,165,91,.74), 0 0 34px rgba(30,165,91,.32); }
.traffic-signal--large { width: 92px; gap: 10px; padding: 12px; border-radius: 21px; }
.traffic-signal--regular { width: 70px; }
.traffic-signal--compact { width: 39px; gap: 4px; padding: 5px; border-width: 2px; border-radius: 10px; box-shadow: inset 0 1px 0 rgba(255,255,255,.12), inset 0 -7px 13px rgba(0,0,0,.35), 0 7px 14px rgba(12,20,22,.16); }
.traffic-signal--compact::before { top: -5px; height: 5px; }
.traffic-signal--compact .traffic-signal__lamp { border-width: 2px; }
.traffic-signal--mini { width: 44px; gap: 4px; padding: 5px; border-width: 2px; border-radius: 11px; box-shadow: inset 0 1px 0 rgba(255,255,255,.12), inset 0 -7px 13px rgba(0,0,0,.35), 0 7px 14px rgba(12,20,22,.16); }
.traffic-signal--mini::before { top: -5px; height: 5px; }
.traffic-signal--mini .traffic-signal__lamp { border-width: 2px; }

.signal-overview {
    display: grid;
    grid-template-columns: 120px minmax(280px,1fr) minmax(285px,.72fr);
    align-items: center;
    gap: 26px;
    margin-bottom: 22px;
    padding: 25px 28px;
    overflow: hidden;
    border: 1px solid var(--line-soft);
    border-top: 5px solid var(--status-color);
    border-radius: var(--radius);
    background: linear-gradient(118deg, #fff 0 58%, var(--status-soft) 100%);
    box-shadow: var(--shadow);
}
.signal-overview__visual { display: grid; place-items: center; min-height: 230px; }
.signal-overview__content h2 { margin: 4px 0 8px; font-size: clamp(23px,2.3vw,34px); letter-spacing: -.035em; }
.signal-overview__content p { max-width: 760px; margin: 0 0 18px; color: var(--muted); font-size: 13px; }
.signal-overview__counts { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 9px; }
.signal-count {
    position: relative;
    min-width: 0;
    display: grid;
    place-items: center;
    padding: 14px 8px 12px;
    overflow: hidden;
    border: 1px solid var(--line-soft);
    border-radius: 11px;
    background: rgba(255,255,255,.88);
    color: var(--dark);
    text-decoration: none;
    box-shadow: 0 5px 16px rgba(23,35,38,.05);
}
.signal-count::after { content: ""; position: absolute; inset: auto 0 0; height: 4px; background: var(--status-color); }
.signal-count > span { width: 12px; height: 12px; margin-bottom: 7px; border-radius: 50%; background: var(--status-color); box-shadow: 0 0 0 4px var(--status-soft); }
.signal-count strong { font-size: 25px; line-height: 1; }
.signal-count small { margin-top: 5px; color: var(--muted); font-weight: 750; }
.signal-count:hover { border-color: var(--status-color); transform: translateY(-1px); }

.status-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; margin-bottom: 22px; }
.status-card {
    position: relative;
    min-height: 132px;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: 1fr auto;
    align-items: center;
    gap: 0 15px;
    padding: 20px;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: #fff;
    color: var(--dark);
    text-decoration: none;
    box-shadow: var(--shadow);
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
}
.status-card::after { content: ""; position: absolute; inset: auto 0 0; height: 5px; background: currentColor; }
.status-card:hover { transform: translateY(-2px); box-shadow: 0 16px 40px rgba(23,35,38,.12); }
.status-card.green { color: var(--green); }
.status-card.yellow { color: var(--yellow); }
.status-card.red { color: var(--red); }
.status-card div strong, .status-card div span { display: block; }
.status-card div strong { color: var(--dark); font-size: 30px; line-height: 1; }
.status-card div span { margin-top: 5px; color: var(--dark); font-weight: 750; }
.status-card small { grid-column: 2; color: var(--muted); }
.traffic-light-dot { width: 28px; height: 28px; display: inline-block; border-radius: 50%; background: currentColor; box-shadow: inset 0 -4px 8px rgba(0,0,0,.15), 0 0 0 7px currentColor; opacity: .92; }
.status-card .traffic-signal--compact { justify-self: center; }

.status-green { --status-color: var(--green); --status-soft: var(--green-soft); }
.status-yellow { --status-color: var(--yellow); --status-soft: var(--yellow-soft); }
.status-red { --status-color: var(--red); --status-soft: var(--red-soft); }
.status-neutral { --status-color: var(--muted); --status-soft: #eef2f3; }
.badge { display: inline-flex; align-items: center; gap: 7px; min-height: 27px; padding: 4px 9px; border-radius: 999px; color: var(--status-color); background: var(--status-soft); font-size: 11px; font-weight: 850; white-space: nowrap; }
.badge > span { width: 8px; height: 8px; border-radius: 50%; background: var(--status-color); }
.status-indicator { width: 12px; height: 12px; display: inline-block; border-radius: 50%; background: var(--status-color); box-shadow: 0 0 0 4px var(--status-soft); }
.mini-badge { display: inline-block; padding: 3px 7px; border-radius: 5px; background: #edf2f3; color: var(--muted); font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; }
.mini-badge.active, .mini-badge.sent { background: var(--green-soft); color: var(--green); }
.mini-badge.inactive, .mini-badge.failed { background: var(--red-soft); color: var(--red); }
.mini-badge.logged { background: var(--turquoise-soft); color: var(--turquoise-dark); }
.mini-badge.skipped { background: var(--yellow-soft); color: #7c5900; }
.warning-text { display: block; margin-top: 3px; color: #8f6600; }

.dashboard-grid { display: grid; grid-template-columns: minmax(0, 2fr) minmax(300px, 1fr); gap: 22px; }
.chart-panel { min-width: 0; }
.chart-canvas { display: block; width: 100%; height: 260px; }
.chart-canvas.chart-wide { height: 270px; }
.chart-canvas.chart-tall { height: 330px; }
.case-list { display: grid; }
.case-row { display: grid; grid-template-columns: 18px minmax(170px,.8fr) minmax(200px,1.4fr) auto; align-items: center; gap: 14px; padding: 13px 4px; border-bottom: 1px solid var(--line-soft); color: var(--dark); text-decoration: none; }
.case-row:last-child { border-bottom: 0; }
.case-row:hover { background: #fafcfc; }
.case-main strong, .case-main span, .case-feedback span, .case-feedback small { display: block; }
.case-main span, .case-feedback small { color: var(--muted); font-size: 11px; }
.case-feedback span { font-size: 12px; }

.table-wrap { width: 100%; overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; white-space: nowrap; }
.data-table th { padding: 10px 11px; border-bottom: 2px solid var(--line); color: var(--muted); font-size: 10px; text-align: left; text-transform: uppercase; letter-spacing: .07em; }
.data-table td { padding: 12px 11px; border-bottom: 1px solid var(--line-soft); vertical-align: middle; }
.data-table tbody tr:hover { background: #fafcfc; }
.data-table td small, .data-table td strong { display: block; }
.data-table td small { margin-top: 3px; color: var(--muted); font-size: 10.5px; white-space: normal; max-width: 360px; }
.data-table .critical-row { background: #fffafa; }
.data-table .critical-row td:first-child { box-shadow: inset 3px 0 0 var(--red); }
.progress { width: 130px; height: 6px; display: inline-block; margin-right: 7px; overflow: hidden; border-radius: 99px; background: #e9eef0; vertical-align: middle; }
.progress span { display: block; height: 100%; background: var(--turquoise); }

.field { display: grid; gap: 6px; min-width: 0; }
.field > span, .field legend { color: var(--dark-2); font-size: 11.5px; font-weight: 750; }
.field input, .field select, .field textarea, .inline-search input {
    width: 100%;
    min-height: 40px;
    border: 1px solid var(--line);
    border-radius: var(--radius-small);
    background: #fff;
    color: var(--dark);
    padding: 8px 10px;
    outline: none;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.field textarea { min-height: 88px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus, .inline-search input:focus { border-color: var(--turquoise); box-shadow: 0 0 0 3px rgba(0,158,170,.12); }
.field small { color: var(--muted); font-size: 10.5px; }
.field .field-error { color: var(--red); font-weight: 700; }
.field-full { grid-column: 1 / -1; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.form-grid.one-column, .form-stack { display: grid; grid-template-columns: 1fr; gap: 15px; }
.form-panel { padding: clamp(20px, 3vw, 34px); }
.form-section { padding: 22px 0; border-top: 1px solid var(--line-soft); }
.section-heading { display: flex; align-items: flex-start; gap: 13px; margin-bottom: 18px; }
.section-heading > span { width: 28px; height: 28px; flex: 0 0 auto; display: grid; place-items: center; border-radius: 50%; background: var(--dark); color: #fff; font-size: 12px; font-weight: 800; }
.section-heading h3 { margin: 1px 0 2px; font-size: 15px; }
.section-heading p { margin: 0; color: var(--muted); font-size: 12px; }
.form-footer { display: flex; justify-content: flex-end; gap: 8px; padding-top: 20px; border-top: 1px solid var(--line-soft); }
.filter-grid { display: grid; grid-template-columns: repeat(4, minmax(150px,1fr)); align-items: end; gap: 13px; }
.filter-actions { display: flex; align-items: center; gap: 8px; }
.inline-form { display: flex; align-items: flex-end; gap: 12px; flex-wrap: wrap; }
.inline-form .grow { flex: 1 1 350px; }
.inline-search { width: min(300px,100%); }
.inline-search label { display: block; margin-bottom: 4px; color: var(--muted); font-size: 10px; font-weight: 700; }

.status-choice { margin: 0; padding: 0; border: 0; display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 12px; }
.status-choice legend { margin-bottom: 8px; }
.status-option { position: relative; display: grid; grid-template-columns: 26px 1fr; gap: 1px 10px; padding: 14px; border: 1px solid var(--line); border-radius: 10px; background: #fff; cursor: pointer; }
.status-option input { position: absolute; opacity: 0; }
.status-option .traffic-light-dot { width: 17px; height: 17px; margin: 4px; color: var(--status-color); box-shadow: 0 0 0 4px var(--status-soft); }
.status-option strong { color: var(--dark); }
.status-option small { grid-column: 2; color: var(--muted); }
.status-option:has(input:checked) { border-color: var(--status-color); box-shadow: 0 0 0 3px var(--status-soft); background: var(--status-soft); }
.mini-status-choice { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; margin: 0; padding: 0; border: 0; }
.mini-status-choice legend { margin-bottom: 5px; font-size: 11px; font-weight: 750; }
.mini-status-choice label { position: relative; display: flex; align-items: center; gap: 6px; padding: 8px; border: 1px solid var(--line); border-radius: 8px; cursor: pointer; }
.mini-status-choice input { position: absolute; opacity: 0; }
.mini-status-choice label > span { width: 9px; height: 9px; border-radius: 50%; background: var(--status-color); }
.mini-status-choice label:has(input:checked) { border-color: var(--status-color); background: var(--status-soft); }

.switch-row { display: flex; align-items: flex-start; gap: 12px; padding: 13px; border: 1px solid var(--line-soft); border-radius: 10px; cursor: pointer; }
.switch-row input { position: absolute; opacity: 0; }
.switch { position: relative; width: 41px; height: 23px; flex: 0 0 auto; border-radius: 99px; background: #bdc8ca; transition: background var(--transition); }
.switch::after { content: ""; position: absolute; top: 3px; left: 3px; width: 17px; height: 17px; border-radius: 50%; background: #fff; transition: transform var(--transition); box-shadow: 0 1px 3px #0003; }
.switch-row input:checked + .switch { background: var(--turquoise); }
.switch-row input:checked + .switch::after { transform: translateX(18px); }
.switch-row > span:last-child strong, .switch-row > span:last-child small { display: block; }
.switch-row > span:last-child small { color: var(--muted); }
.switch-row.compact { padding: 10px; }
.check-row { display: flex; align-items: flex-start; gap: 8px; color: var(--muted); font-size: 12px; cursor: pointer; }

.info-box { padding: 13px; border: 1px solid #b9e1e4; border-radius: 10px; background: var(--turquoise-soft); color: #225b60; }
.internal-note { margin-top: 15px; padding: 14px; border-left: 4px solid var(--yellow); background: var(--yellow-soft); }
.internal-note p { margin: 6px 0 0; }
.empty-state { display: grid; place-items: center; padding: 40px 20px; text-align: center; color: var(--muted); }
.empty-state strong { color: var(--dark); font-size: 15px; }
.empty-state span { margin-top: 4px; }
.empty-state.compact { padding: 24px 12px; }

.detail-hero { display: flex; align-items: center; gap: 20px; margin-bottom: 22px; padding: 20px 23px; border: 1px solid var(--line-soft); border-left: 5px solid var(--status-color); border-radius: var(--radius); background: linear-gradient(100deg, var(--status-soft), #fff 56%); }
.detail-status { display: flex; align-items: center; gap: 13px; }
.detail-status .traffic-signal--mini { flex: 0 0 auto; }
.detail-status strong { display: block; font-size: 21px; }
.detail-title { padding-left: 20px; border-left: 1px solid var(--line); }
.detail-title h2 { margin: 0; font-size: 24px; }
.detail-title p { margin: 3px 0 0; color: var(--muted); }
.detail-actions { margin-left: auto; display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.detail-grid { display: grid; grid-template-columns: minmax(0,1fr) 340px; gap: 22px; }
.facts-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 0; margin: 0; border: 1px solid var(--line-soft); border-radius: 10px; overflow: hidden; }
.facts-grid > div { padding: 13px; border-right: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); }
.facts-grid > div:nth-child(4n) { border-right: 0; }
.facts-grid dt { color: var(--muted); font-size: 10px; font-weight: 750; text-transform: uppercase; letter-spacing: .05em; }
.facts-grid dd { margin: 5px 0 0; font-weight: 700; }
.status-note-box { margin-top: 16px; padding: 15px 17px; border-left: 4px solid var(--status-color); background: var(--status-soft); border-radius: 0 9px 9px 0; }
.status-note-box p { margin: 6px 0 0; }
.message-form { display: grid; gap: 12px; margin-bottom: 23px; padding-bottom: 20px; border-bottom: 1px solid var(--line-soft); }
.timeline { display: grid; }
.timeline-item { position: relative; display: grid; grid-template-columns: 20px 1fr; gap: 9px; }
.timeline-item::before { content: ""; position: absolute; left: 6px; top: 20px; bottom: -7px; width: 1px; background: var(--line); }
.timeline-item:last-child::before { display: none; }
.timeline-marker { width: 13px; height: 13px; margin-top: 5px; border-radius: 50%; background: var(--turquoise); box-shadow: 0 0 0 4px var(--turquoise-soft); }
.timeline-item.internal .timeline-marker { background: var(--yellow); box-shadow: 0 0 0 4px var(--yellow-soft); }
.timeline-card { margin-bottom: 17px; padding: 13px 15px; border: 1px solid var(--line-soft); border-radius: 10px; background: #fff; }
.timeline-card header { display: flex; justify-content: space-between; gap: 10px; }
.timeline-card header span { color: var(--muted); font-size: 10.5px; }
.timeline-card p { margin: 8px 0 0; }
.feedback-list { display: grid; gap: 13px; }
.feedback-card { padding: 16px; border: 1px solid var(--line-soft); border-radius: 11px; }
.feedback-card header { display: flex; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.feedback-card header strong, .feedback-card header span { display: block; }
.feedback-card header > div span { color: var(--muted); font-size: 10.5px; }
.feedback-card dl { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 13px; margin: 0; }
.feedback-card dt { color: var(--muted); font-size: 10px; font-weight: 750; text-transform: uppercase; }
.feedback-card dd { margin: 3px 0 0; }
.history-list { display: grid; }
.history-row { display: grid; grid-template-columns: 16px 1fr; gap: 11px; padding: 10px 0; border-bottom: 1px solid var(--line-soft); }
.history-row:last-child { border-bottom: 0; }
.history-row .status-indicator { margin-top: 5px; }
.history-row strong, .history-row span, .history-row small { display: block; }
.history-row span, .history-row small { color: var(--muted); font-size: 10.5px; }
.history-row p { margin: 5px 0 0; color: var(--muted); font-size: 11px; }
.contact-card > strong, .contact-card > span, .contact-card > a { display: block; margin-top: 7px; }
.contact-card > span { color: var(--muted); }

.split-layout { display: grid; grid-template-columns: minmax(0,1fr) 360px; gap: 22px; align-items: start; }
.split-layout.wide-sidebar { grid-template-columns: minmax(0,1fr) 400px; }
.form-sidebar { position: sticky; top: 100px; }
.settings-layout { display: grid; grid-template-columns: minmax(0,1.5fr) minmax(300px,.8fr); gap: 22px; }
.smtp-fields { padding: 16px; border: 1px dashed var(--line); border-radius: 10px; background: #fafcfc; }
.code-box { overflow-x: auto; margin: 9px 0; padding: 11px 13px; border-radius: 8px; background: var(--dark); color: #d9eff1; }
.template-grid { display: grid; gap: 10px; }
.template-card { border: 1px solid var(--line-soft); border-radius: 10px; overflow: hidden; }
.template-card summary { display: flex; align-items: center; justify-content: space-between; gap: 15px; padding: 14px 16px; cursor: pointer; list-style: none; background: #fbfcfc; }
.template-card summary::-webkit-details-marker { display: none; }
.template-card summary strong, .template-card summary span { display: block; }
.template-card summary div > span { margin-top: 3px; color: var(--muted); font-size: 10px; }
.template-card form { padding: 18px; border-top: 1px solid var(--line-soft); }

.kpi-grid { display: grid; grid-template-columns: repeat(5,minmax(0,1fr)); gap: 13px; margin-bottom: 22px; }
.kpi-card { padding: 17px; border: 1px solid var(--line-soft); border-radius: 12px; background: #fff; box-shadow: 0 4px 14px rgba(23,35,38,.035); }
.kpi-card span, .kpi-card strong, .kpi-card small { display: block; }
.kpi-card span { color: var(--muted); font-size: 10px; font-weight: 750; text-transform: uppercase; letter-spacing: .05em; }
.kpi-card strong { margin: 7px 0 3px; font-size: 24px; }
.kpi-card small { color: var(--muted); }
.kpi-card.critical { border-top: 4px solid var(--red); }
.kpi-card.warning { border-top: 4px solid var(--yellow); }
.analytics-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 22px; }
.analytics-wide { grid-column: 1 / -1; }

.report-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 18px; margin-bottom: 22px; }
.report-card { display: grid; grid-template-columns: 54px 1fr; gap: 16px; align-items: start; padding: 22px; border: 1px solid var(--line-soft); border-radius: var(--radius); background: #fff; box-shadow: 0 4px 14px rgba(23,35,38,.035); }
.report-card > .button, .report-card > form { grid-column: 2; }
.report-icon { width: 50px; height: 50px; display: grid; place-items: center; border-radius: 12px; color: #fff; font-size: 19px; font-weight: 900; }
.report-icon.red { background: var(--red); }
.report-icon.turquoise { background: var(--turquoise); }
.report-icon.dark { background: var(--dark); }
.report-card h2 { margin: 3px 0 5px; font-size: 18px; }
.report-card p { margin: 0; color: var(--muted); }
.report-form { display: grid; gap: 10px; }
.report-form.two-fields { grid-template-columns: 1fr 1fr; }
.report-form.two-fields .button { grid-column: 1 / -1; }

.help-hero { margin-bottom: 22px; padding: 25px; border-radius: var(--radius); background: linear-gradient(120deg, var(--dark), #243b40); color: #fff; }
.help-hero h2 { margin: 4px 0 8px; font-size: 24px; }
.help-hero p { max-width: 850px; margin: 0; color: #c6d6d9; }
.workflow-strip { display: flex; align-items: center; gap: 10px; margin-top: 24px; overflow-x: auto; }
.workflow-strip span { min-width: 105px; display: flex; align-items: center; gap: 8px; color: #dbe6e8; font-weight: 700; }
.workflow-strip b { width: 25px; height: 25px; display: grid; place-items: center; border-radius: 50%; background: var(--turquoise); color: #fff; }
.workflow-strip i { width: 35px; height: 1px; background: #5f767a; }
.help-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 16px; }
.help-card { position: relative; min-height: 170px; }
.help-card h3 { margin: 3px 0 8px; font-size: 15px; }
.help-card p { margin: 0; color: var(--muted); }
.help-number { color: var(--turquoise); font-size: 11px; font-weight: 900; letter-spacing: .08em; }
.rules-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 14px; }
.rule-card { display: flex; align-items: flex-start; gap: 14px; padding: 16px; border: 1px solid var(--line-soft); border-top: 4px solid currentColor; border-radius: 10px; }
.rule-card.green { color: var(--green); }
.rule-card.yellow { color: var(--yellow); }
.rule-card.red { color: var(--red); }
.rule-card .traffic-light-dot { width: 16px; height: 16px; margin: 5px; box-shadow: 0 0 0 5px currentColor; }
.rule-card h3 { margin: 0 0 5px; color: var(--dark); }
.rule-card p { margin: 0; color: var(--muted); }

.login-page { min-height: 100vh; display: grid; place-items: center; padding: 25px; background: radial-gradient(circle at 10% 10%, rgba(0,158,170,.12), transparent 32%), linear-gradient(140deg, #eef4f5, #fff); }
.login-card { width: min(920px,100%); display: grid; grid-template-columns: minmax(300px,.95fr) minmax(340px,1fr); overflow: hidden; border: 1px solid var(--line-soft); border-radius: 20px; background: #fff; box-shadow: 0 25px 80px rgba(23,35,38,.16); }
.login-brand { display: flex; flex-direction: column; justify-content: center; padding: 38px; background: var(--dark); color: #fff; }
.login-brand img { width: 100%; padding: 12px; border-radius: 9px; background: #fff; }
.brand-line { height: 5px; margin: 18px 0; background: var(--red-brand); }
.login-brand strong { display: block; color: #fff; font-size: 21px; letter-spacing: -.015em; }
.login-brand span { margin-top: 3px; color: #c5d4d7; font-size: 12px; font-weight: 750; letter-spacing: .07em; text-transform: uppercase; }
.login-content { padding: 42px; }
.login-content h1 { margin: 3px 0 8px; font-size: 30px; }
.login-content > p { margin: 0 0 22px; color: var(--muted); }
.login-note { margin-top: 18px !important; font-size: 11px; }
.password-field { position: relative; }
.password-field input { padding-right: 78px; }
.password-field button { position: absolute; right: 6px; top: 6px; bottom: 6px; border: 0; border-radius: 6px; background: var(--background); color: var(--turquoise-dark); font-size: 11px; font-weight: 750; cursor: pointer; }

@media (max-width: 1200px) {
    .filter-grid { grid-template-columns: repeat(3,minmax(150px,1fr)); }
    .facts-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
    .facts-grid > div:nth-child(2n) { border-right: 0; }
    .kpi-grid { grid-template-columns: repeat(3,minmax(0,1fr)); }
    .detail-grid { grid-template-columns: minmax(0,1fr) 310px; }
}

@media (max-width: 980px) {
    .app-shell { display: block; }
    .sidebar { transform: translateX(-103%); transition: transform 220ms ease; box-shadow: 12px 0 40px rgba(0,0,0,.22); }
    body.sidebar-open .sidebar { transform: translateX(0); }
    .main-area { min-width: 0; }
    .menu-toggle { display: block; }
    .sidebar-backdrop { position: fixed; inset: 0; z-index: 45; background: rgba(10,20,22,.48); }
    body.sidebar-open .sidebar-backdrop { display: block; }
    .dashboard-grid, .settings-layout, .detail-grid, .split-layout, .split-layout.wide-sidebar { grid-template-columns: 1fr; }
    .signal-overview { grid-template-columns: 105px 1fr; }
    .signal-overview__counts { grid-column: 1 / -1; }
    .panel-span-2 { grid-column: auto; }
    .detail-side { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 18px; }
    .detail-side .panel { margin-bottom: 0; }
    .sticky-panel, .form-sidebar { position: static; }
    .status-grid { grid-template-columns: repeat(3,1fr); }
    .help-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
    .rules-grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
    body { font-size: 13px; }
    .content { padding: 14px; }
    .topbar { min-height: 68px; padding: 10px 14px; }
    .topbar .eyebrow { display: none; }
    .topbar-actions .button { display: none; }
    .panel { padding: 16px; margin-bottom: 14px; }
    .panel-header { flex-direction: column; align-items: stretch; margin-bottom: 15px; }
    .panel-actions { justify-content: flex-start; }
    .signal-overview { grid-template-columns: 1fr; gap: 16px; padding: 21px 18px; text-align: center; }
    .signal-overview__visual { min-height: 0; }
    .signal-overview__content p { margin-left: auto; margin-right: auto; }
    .signal-overview__counts { grid-column: auto; }
    .status-grid { grid-template-columns: 1fr; gap: 10px; }
    .status-card { min-height: 95px; padding: 15px; }
    .status-card div strong { font-size: 24px; }
    .dashboard-grid, .analytics-grid, .report-grid { grid-template-columns: 1fr; gap: 14px; }
    .analytics-wide { grid-column: auto; }
    .filter-grid, .form-grid { grid-template-columns: 1fr; }
    .filter-actions { flex-wrap: wrap; }
    .status-choice { grid-template-columns: 1fr; }
    .detail-hero { align-items: flex-start; flex-wrap: wrap; gap: 14px; padding: 16px; }
    .detail-status { width: 100%; justify-content: flex-start; }
    .detail-title { width: 100%; padding-left: 0; border-left: 0; }
    .detail-title h2 { font-size: 20px; }
    .detail-actions { width: 100%; margin-left: 0; justify-content: flex-start; }
    .detail-side { grid-template-columns: 1fr; }
    .facts-grid { grid-template-columns: 1fr; }
    .facts-grid > div { border-right: 0; }
    .feedback-card dl { grid-template-columns: 1fr; }
    .case-row { grid-template-columns: 16px 1fr auto; }
    .case-feedback { grid-column: 2 / -1; }
    .kpi-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
    .help-grid { grid-template-columns: 1fr; }
    .report-card { grid-template-columns: 45px 1fr; padding: 17px; }
    .report-icon { width: 42px; height: 42px; }
    .report-form.two-fields { grid-template-columns: 1fr; }
    .report-form.two-fields .button { grid-column: auto; }
    .login-page { padding: 12px; }
    .login-card { grid-template-columns: 1fr; }
    .login-brand { padding: 24px; }
    .login-brand img { max-width: 430px; }
    .login-content { padding: 27px 23px; }
    .workflow-strip { align-items: flex-start; }
    .workflow-strip i { min-width: 20px; margin-top: 13px; }
}

@media (max-width: 460px) {
    .signal-overview__counts { grid-template-columns: 1fr; }
    .kpi-grid { grid-template-columns: 1fr; }
    .mini-status-choice { grid-template-columns: 1fr; }
    .button { width: 100%; }
    .detail-actions .button, .panel-actions .button { width: auto; }
    .account-link { flex: 0 0 auto; }
}

@media print {
    .sidebar, .topbar, .button, .filter-panel, .sidebar-backdrop { display: none !important; }
    .app-shell { display: block; }
    .main-area { display: block; }
    .content { max-width: none; padding: 0; }
    .panel { break-inside: avoid; box-shadow: none; }
}

/* LogistikMonitor 1.2 – Branding und Datenintegration */
.brand { padding: 14px 14px 16px; }
.brand img { width: 100%; height: 92px; object-fit: cover; object-position: center; padding: 0; border-radius: 9px; background: #090d0e; box-shadow: 0 8px 24px rgba(0,0,0,.25); }
.brand strong { margin-top: 10px; }
.login-brand img { width: 100%; padding: 0; border-radius: 10px; background: #080c0d; box-shadow: 0 14px 35px rgba(0,0,0,.28); }
.nav-icon[data-icon="integrations"]::before { content: "⇄"; }

.integration-hero {
    display: grid;
    grid-template-columns: minmax(0,1.5fr) minmax(320px,.8fr);
    align-items: center;
    gap: 28px;
    margin-bottom: 20px;
    padding: clamp(22px,3vw,36px);
    overflow: hidden;
    border-radius: var(--radius);
    color: #fff;
    background: radial-gradient(circle at 85% 20%, rgba(239,0,45,.26), transparent 30%), linear-gradient(130deg,#11191b,#172b30 58%,#102125);
    box-shadow: var(--shadow);
}
.integration-hero h2 { margin: 5px 0 10px; max-width: 900px; font-size: clamp(22px,3vw,36px); line-height: 1.15; letter-spacing: -.035em; }
.integration-hero p { max-width: 880px; margin: 0; color: #c3d2d5; font-size: 14px; }
.integration-flow { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; }
.integration-flow b { color: #9db0b4; font-size: 22px; }
.source-chip { min-width: 90px; padding: 13px 16px; border-radius: 10px; text-align: center; font-weight: 850; letter-spacing: .02em; box-shadow: 0 8px 24px rgba(0,0,0,.18); }
.source-chip.carlo { background: #fff; color: #19282c; }
.source-chip.spedion { background: var(--turquoise); color: #fff; }
.source-chip.monitor { background: var(--red-brand); color: #fff; }
.integration-kpis { grid-template-columns: repeat(4,minmax(0,1fr)); }
.status-card.neutral { border-top-color: var(--turquoise); }
.status-card.neutral::after { background: var(--turquoise-soft); }
.integration-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 20px; margin-bottom: 20px; }
.integration-source-card { margin-bottom: 0; }
.connection-state { padding: 6px 10px; border-radius: 999px; font-size: 11px; font-weight: 800; }
.connection-state.is-enabled { color: var(--green); background: var(--green-soft); }
.connection-state.is-disabled { color: var(--muted); background: var(--background); }
.source-purpose { display: grid; gap: 3px; margin: -5px 0 18px; padding: 13px 15px; border-left: 4px solid var(--turquoise); border-radius: 0 9px 9px 0; background: var(--turquoise-soft); }
.source-purpose span { color: var(--muted); font-size: 12px; }
.form-grid-2 { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 13px; }
.integration-settings-form .switch-row { align-items: center; }
.integration-settings-form .switch-row input { position: static; width: 18px; height: 18px; opacity: 1; accent-color: var(--turquoise); flex: 0 0 auto; }
.integration-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 18px; padding-top: 17px; border-top: 1px solid var(--line-soft); }
.integration-actions form { margin: 0; }
.upload-inline { display: flex; align-items: center; gap: 8px; flex: 1 1 340px; }
.upload-inline input[type="file"] { min-width: 0; flex: 1; padding: 8px; border: 1px dashed var(--line); border-radius: 8px; background: var(--background); }
.template-links { display: flex; gap: 14px; margin-top: 12px; font-size: 12px; font-weight: 750; }
.source-meta { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 0; margin: 18px 0 0; border: 1px solid var(--line-soft); border-radius: 10px; overflow: hidden; }
.source-meta > div { padding: 11px 12px; border-right: 1px solid var(--line-soft); }
.source-meta > div:last-child { border-right: 0; }
.source-meta dt { color: var(--muted); font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; }
.source-meta dd { margin: 3px 0 0; font-size: 12px; font-weight: 700; }
.mapping-details { margin-top: 18px; border-top: 1px solid var(--line-soft); padding-top: 15px; }
.mapping-details > summary { cursor: pointer; color: var(--turquoise-dark); font-weight: 800; }
.mapping-details form { margin-top: 14px; }
.compact-table input[type="text"] { width: 100%; min-width: 260px; padding: 8px 10px; border: 1px solid var(--line); border-radius: 7px; }
.compact-table input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--turquoise); }
.compact-table small { display: block; color: var(--red); }
.form-help { color: var(--muted); font-size: 11px; }
.input-suffix { display: flex; align-items: stretch; }
.input-suffix input { border-radius: 9px 0 0 9px; }
.input-suffix span { display: grid; place-items: center; min-width: 50px; padding: 0 10px; border: 1px solid var(--line); border-left: 0; border-radius: 0 9px 9px 0; background: var(--background); color: var(--muted); font-weight: 750; }
.run-status { display: inline-flex; padding: 4px 8px; border-radius: 999px; font-size: 10px; font-weight: 850; }
.run-status-success { color: var(--green); background: var(--green-soft); }
.run-status-warning { color: #9b6a00; background: var(--yellow-soft); }
.run-status-failed { color: var(--red); background: var(--red-soft); }
.run-status-running { color: var(--turquoise-dark); background: var(--turquoise-soft); }
.run-log-row td { padding-top: 0; background: #fafcfc; }
.run-log-row pre { max-height: 220px; overflow: auto; white-space: pre-wrap; color: var(--muted); font-size: 11px; }

.integration-dashboard-strip { display: grid; grid-template-columns: minmax(260px,1.3fr) minmax(360px,1fr) auto; align-items: center; gap: 20px; margin-bottom: 20px; border-left: 5px solid var(--turquoise); }
.integration-dashboard-strip h2 { margin: 2px 0 4px; }
.integration-dashboard-strip p { margin: 0; color: var(--muted); }
.integration-dashboard-values { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.integration-dashboard-values span { padding: 10px; border-radius: 9px; background: var(--background); text-align: center; color: var(--muted); font-size: 10px; }
.integration-dashboard-values strong { display: block; color: var(--dark); font-size: 20px; }

.monitoring-panel { border-top: 4px solid var(--turquoise); }
.monitoring-timeline { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 1px; margin-bottom: 18px; overflow: hidden; border: 1px solid var(--line-soft); border-radius: 10px; background: var(--line-soft); }
.monitoring-timeline > div { min-height: 96px; display: flex; flex-direction: column; justify-content: center; padding: 13px; background: #fff; }
.monitoring-timeline span { color: var(--turquoise-dark); font-size: 9px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.monitoring-timeline strong { margin: 3px 0 8px; font-size: 12px; }
.monitoring-timeline time { color: var(--dark); font-weight: 800; }
.monitoring-facts { margin-bottom: 16px; }
.detection-reason { padding: 14px 16px; border-left: 5px solid currentColor; border-radius: 0 9px 9px 0; }
.detection-reason.status-green { color: var(--green); background: var(--green-soft); }
.detection-reason.status-yellow { color: #9b6a00; background: var(--yellow-soft); }
.detection-reason.status-red { color: var(--red); background: var(--red-soft); }
.detection-reason p { margin: 4px 0 0; color: var(--dark); }
.external-reference-list { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-top: 15px; }
.external-reference-list > strong { width: 100%; font-size: 11px; color: var(--muted); }
.external-reference-list span { padding: 6px 9px; border-radius: 7px; background: var(--background); font-size: 11px; }
.auto-control-card { border-top: 4px solid var(--turquoise); }
.auto-control-card p { color: var(--muted); font-size: 12px; }

@media (max-width: 1250px) {
    .integration-grid { grid-template-columns: 1fr; }
    .integration-dashboard-strip { grid-template-columns: 1fr; }
    .integration-dashboard-strip .button { justify-self: start; }
}
@media (max-width: 980px) {
    .integration-hero { grid-template-columns: 1fr; }
    .integration-kpis { grid-template-columns: repeat(2,minmax(0,1fr)); }
    .monitoring-timeline { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 720px) {
    .integration-kpis, .form-grid-2, .source-meta, .integration-dashboard-values, .monitoring-timeline { grid-template-columns: 1fr; }
    .source-meta > div { border-right: 0; border-bottom: 1px solid var(--line-soft); }
    .source-meta > div:last-child { border-bottom: 0; }
    .upload-inline { display: grid; grid-template-columns: 1fr; }
    .compact-table input[type="text"] { min-width: 180px; }
    .brand img { height: 86px; }
}

/* LogistikMonitor 1.3 – lesbares Logo und eigenständige Tourmeldungen */
.brand {
    padding: 14px 15px 16px;
}
.brand .brand-lockup {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr);
    align-items: center;
    gap: 7px;
}
.brand .brand-lockup img {
    width: 58px;
    height: 64px;
    object-fit: contain;
    object-position: center;
    padding: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    filter: drop-shadow(0 5px 8px rgba(0,0,0,.42));
}
.brand .brand-wordmark {
    min-width: 0;
    display: flex;
    align-items: baseline;
    letter-spacing: -.045em;
    white-space: nowrap;
    font-size: 17px;
    font-weight: 900;
    line-height: 1;
    text-transform: none;
}
.brand .brand-wordmark span { display: inline; margin: 0; color: #17b7c2; font: inherit; letter-spacing: inherit; text-transform: none; }
.brand .brand-wordmark b { color: #ff2145; font-weight: 900; }
.brand .brand-subtitle {
    display: block;
    margin: 5px 0 0 65px;
    color: #a9bec2;
    font-size: 9px;
    font-weight: 750;
    letter-spacing: .095em;
    line-height: 1.25;
    text-transform: uppercase;
}

.login-logo-lockup {
    display: grid;
    grid-template-columns: minmax(95px, 125px) minmax(0, 1fr);
    align-items: center;
    gap: 16px;
}
.login-brand .login-logo-lockup img {
    width: 100%;
    height: 150px;
    object-fit: contain;
    padding: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    filter: drop-shadow(0 12px 17px rgba(0,0,0,.48));
}
.login-wordmark {
    display: flex;
    align-items: baseline;
    white-space: nowrap;
    font-size: clamp(27px, 3vw, 42px);
    font-weight: 900;
    line-height: .95;
    letter-spacing: -.055em;
}
.login-wordmark span { margin: 0; color: #17b7c2; font: inherit; letter-spacing: inherit; text-transform: none; }
.login-wordmark b { color: #ff2145; font-weight: 900; }
.login-logo-lockup small {
    display: block;
    margin-top: 11px;
    color: #b7c9cc;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .13em;
    text-transform: uppercase;
}
.nav-icon[data-icon="tour-problems"]::before { content: "!"; }

.tour-report-intro {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    border-left: 5px solid var(--turquoise);
}
.tour-report-intro h2 { margin: 3px 0 6px; }
.tour-report-intro p { max-width: 980px; margin: 0; color: var(--muted); }
.tour-report-kpis { margin-bottom: 20px; }
.tour-report-state-icon {
    width: 54px;
    height: 54px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: var(--turquoise-soft);
    color: var(--turquoise-dark);
    font-size: 30px;
    font-weight: 800;
}
.processing-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 104px;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 850;
    white-space: nowrap;
}
.processing-new { color: #a11a2d; background: #ffe9ed; }
.processing-in_progress { color: #8a6100; background: var(--yellow-soft); }
.processing-resolved { color: #146c3d; background: var(--green-soft); }
.row-emphasis { background: #fff9fa; }
.row-emphasis td:first-child { box-shadow: inset 4px 0 0 var(--red); }
.static-alert { margin: 0 0 22px; }
.check-row-prominent {
    padding: 15px;
    border: 1px solid var(--line-soft);
    border-radius: 10px;
    background: var(--turquoise-soft);
    color: var(--dark);
}
.check-row-prominent input { width: 19px; height: 19px; margin-top: 2px; accent-color: var(--turquoise); flex: 0 0 auto; }
.check-row-prominent span, .check-row-prominent strong, .check-row-prominent small { display: block; }
.check-row-prominent small { margin-top: 3px; color: var(--muted); }

.tour-report-hero {
    display: grid;
    grid-template-columns: 100px minmax(0, 1fr) auto;
    align-items: center;
    gap: 22px;
    margin-bottom: 22px;
    padding: 22px 25px;
    overflow: hidden;
    border: 1px solid var(--line-soft);
    border-left: 7px solid var(--status-color);
    border-radius: var(--radius);
    background: linear-gradient(115deg, var(--status-soft), #fff 58%);
    box-shadow: var(--shadow);
}
.tour-report-hero h2 { margin: 4px 0 5px; font-size: clamp(22px, 2.4vw, 32px); }
.tour-report-hero p { margin: 0; color: var(--muted); }
.tour-report-hero-signal { display: grid; place-items: center; }
.tour-report-meta { display: flex; flex-wrap: wrap; gap: 7px 16px; margin-top: 11px; color: var(--muted); font-size: 11px; }
.detail-layout { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 22px; align-items: start; }
.tour-report-details > div { grid-template-columns: minmax(125px, .35fr) minmax(0, 1fr); }
.tour-message-list { display: grid; gap: 12px; margin-bottom: 18px; }
.tour-message {
    max-width: 88%;
    padding: 13px 15px;
    border: 1px solid var(--line-soft);
    border-radius: 11px 11px 11px 3px;
    background: var(--background);
}
.tour-message.from-company {
    justify-self: end;
    border-radius: 11px 11px 3px 11px;
    border-color: #bfe5e8;
    background: var(--turquoise-soft);
}
.tour-message header { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 6px; }
.tour-message header span { color: var(--muted); font-size: 10px; }
.tour-message p { margin: 0; line-height: 1.55; }
.tour-message-form { padding-top: 17px; border-top: 1px solid var(--line-soft); }
.report-self-service-card { border-top: 4px solid var(--turquoise); }
.report-self-service-card p { color: var(--muted); }
.compact-contact a { overflow-wrap: anywhere; }

@media (max-width: 1120px) {
    .brand .brand-lockup { grid-template-columns: 54px minmax(0, 1fr); }
    .brand .brand-wordmark { font-size: 16px; }
    .detail-layout { grid-template-columns: 1fr; }
    .detail-layout .sticky-panel { position: static; }
}

@media (max-width: 720px) {
    .brand .brand-lockup img { height: 60px; }
    .login-logo-lockup { grid-template-columns: 90px minmax(0, 1fr); gap: 12px; }
    .login-brand .login-logo-lockup img { height: 110px; }
    .login-wordmark { font-size: clamp(25px, 10vw, 39px); }
    .tour-report-intro { align-items: stretch; flex-direction: column; }
    .tour-report-intro .button { width: 100%; }
    .tour-report-hero { grid-template-columns: 72px minmax(0, 1fr); padding: 18px; }
    .tour-report-hero > .processing-badge { grid-column: 1 / -1; justify-self: start; }
    .tour-report-meta { display: grid; gap: 4px; }
    .tour-message { max-width: 100%; }
}

@media (max-width: 460px) {
    .login-logo-lockup { grid-template-columns: 74px minmax(0, 1fr); }
    .login-brand .login-logo-lockup img { height: 92px; }
    .login-wordmark { font-size: 28px; }
    .tour-report-hero { grid-template-columns: 1fr; text-align: center; }
    .tour-report-hero > .processing-badge { justify-self: center; }
}

.tour-report-dashboard-strip {
    display: grid;
    grid-template-columns: minmax(260px, 1.25fr) minmax(300px, .8fr) auto;
    align-items: center;
    gap: 20px;
    border-left: 5px solid var(--red-brand);
}
.tour-report-dashboard-strip h2 { margin: 2px 0 5px; }
.tour-report-dashboard-strip p { margin: 0; color: var(--muted); }
.tour-report-dashboard-values { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.tour-report-dashboard-values span { padding: 10px; border-radius: 9px; background: var(--background); text-align: center; color: var(--muted); font-size: 10px; }
.tour-report-dashboard-values strong { display: block; color: var(--dark); font-size: 21px; }
.tour-report-dashboard-values .critical { background: var(--red-soft); color: var(--red); }
.tour-report-dashboard-values .critical strong { color: var(--red); }
.tour-problem-case-row { grid-template-columns: 16px minmax(180px, .75fr) minmax(260px, 1.25fr) auto; }

@media (max-width: 1100px) {
    .tour-report-dashboard-strip { grid-template-columns: 1fr; }
    .tour-report-dashboard-strip .panel-actions { justify-content: flex-start; }
}
@media (max-width: 720px) {
    .tour-report-dashboard-values { grid-template-columns: repeat(3, 1fr); }
    .tour-problem-case-row { grid-template-columns: 16px 1fr auto; }
    .tour-problem-case-row .case-feedback { grid-column: 2 / -1; }
}
@media (max-width: 460px) {
    .tour-report-dashboard-values { grid-template-columns: 1fr; }
}
