body{margin:0;font-family:system-ui,Arial;background:#eef2f7;color:#0f172a}header{background:#0A236D;color:white;padding:18px 24px}h1{margin:0 0 10px}nav a{color:white;margin-right:16px;text-decoration:none;font-weight:700}main{padding:24px;max-width:1200px;margin:auto}.card{background:white;border-radius:14px;padding:18px;margin-bottom:18px;box-shadow:0 8px 24px #0001}table{width:100%;border-collapse:collapse}th,td{padding:10px;border-bottom:1px solid #e5e7eb;text-align:left}button{background:#FD8C05;border:0;border-radius:8px;padding:9px 13px;font-weight:700}input,select{padding:8px;margin:4px;border:1px solid #cbd5e1;border-radius:8px}.tag{display:inline-block;background:#EBF0F4;border-radius:999px;padding:5px 10px;margin:3px}.flash{background:#fff7ed;border-left:5px solid #FD8C05;padding:8px 14px;margin-bottom:12px}.hint{color:#6B6B6F}
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:end}.toolbar label{font-weight:700}.toolbar .check{display:flex;gap:6px;align-items:center}.summary-row{margin-top:10px}.status{display:inline-block;border-radius:999px;padding:4px 9px;background:#EBF0F4;font-weight:700}.status-vertraagd{background:#fff7ed}.status-op_tijd,.status-live{background:#ecfdf5}.status-vroeg{background:#eff6ff}.status-gepland{background:#EBF0F4}code{background:#EBF0F4;border-radius:6px;padding:2px 5px}
tr.selected{background:#fff7ed}td code{white-space:normal;word-break:break-word}
.button-link{display:inline-block;background:#FD8C05;color:#111827;text-decoration:none;border-radius:8px;padding:8px 12px;font-weight:700;margin-right:8px}.print-actions{max-width:980px;margin:14px auto;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.print-actions a{background:#EBF0F4;color:#0f172a;text-decoration:none;border-radius:8px;padding:8px 12px;font-weight:700}.print-page{background:#dbe3ee;color:#111;font-family:Arial,Helvetica,sans-serif}.print-sheet{background:white;max-width:980px;margin:0 auto 24px;padding:22px;box-shadow:0 8px 24px #0002}.print-header{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;border-bottom:2px solid #111;padding-bottom:8px;margin-bottom:10px}.print-header h1{color:#111;margin:0;font-size:24px}.print-header p{margin:3px 0}.print-logo{font-weight:800;font-size:22px;align-self:start}.print-meta.right{text-align:right}.print-duty{display:inline-block;border:1px solid #111;padding:2px 14px;font-weight:800}.sheet-table{font-size:13px}.sheet-table th,.sheet-table td{border-bottom:1px solid #999;padding:4px 6px;vertical-align:top}.sheet-table th{border-bottom:2px solid #111}.sheet-table tr.type-pause td,.sheet-table tr.type-relief td{background:#e5e7eb;font-weight:700}.sheet-table tr.type-deadhead td,.sheet-table tr.type-car td{font-weight:700}.compact-header{grid-template-columns:1.4fr 1fr}.compact-card{max-width:1120px}.compact-flow{column-count:3;column-gap:18px}.compact-row{break-inside:avoid;display:grid;grid-template-columns:54px 1fr;gap:8px;border-bottom:1px dotted #777;padding:5px 0;font-size:12px}.compact-time strong{display:block}.compact-time span{display:block;color:#444}.compact-title{font-weight:800}.compact-sub,.compact-note{font-size:11px;color:#333}.compact-row.type-pause,.compact-row.type-relief{background:#e5e7eb;padding-left:4px;padding-right:4px;border-bottom:1px solid #aaa}.compact-row.type-deadhead .compact-title,.compact-row.type-car .compact-title{font-weight:900}.print-note{font-size:12px;border-top:1px solid #aaa;padding-top:5px}
@media print{body{background:white;margin:0}.no-print,.print-actions,body>header{display:none!important}main{padding:0}.print-sheet{box-shadow:none;margin:0;max-width:none;padding:8mm}.print-page{background:white}.sheet-table{font-size:10pt}.sheet-table th,.sheet-table td{padding:2.2pt 3pt}.compact-flow{column-count:3}.compact-row{font-size:8.5pt}.compact-sub,.compact-note{font-size:7.5pt}@page{size:A4 portrait;margin:8mm}}

.compact-stops{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:2px;font-size:11px;color:#111}.compact-stops strong{display:inline;font-weight:800}

.warn{color:#a45b00;font-size:.85rem;font-weight:700}.summary-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}.toolbar{display:flex;gap:.75rem;flex-wrap:wrap;align-items:end}.toolbar label{display:flex;flex-direction:column;gap:.25rem}.toolbar .check{flex-direction:row;align-items:center}.status{display:inline-block;padding:.15rem .45rem;border-radius:999px;background:#eef}.status-gepland{background:#eef}.status-onderweg{background:#e8f6ee}.status-vertraagd{background:#fff0df}.status-onbekend{background:#eee}
.dashboard-hero{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;align-items:start}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-title h2{margin:0}.section-title a{font-weight:700;color:#0A236D;text-decoration:none}.dashboard-table th{background:#f8fafc}.dashboard-table td{vertical-align:top}.compact-dashboard-table{font-size:.92rem}.compact-dashboard-table th,.compact-dashboard-table td{padding:8px 7px}@media(max-width:900px){.dashboard-hero,.dashboard-grid{grid-template-columns:1fr}.dashboard-table{font-size:.9rem}}
.diagnose-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.metric-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:14px}.metric-card strong{display:block;text-transform:capitalize}.metric-card span{display:block;font-size:1.8rem;font-weight:900;color:#0A236D}.metric-card small{color:#6B6B6F}.nested-table{margin-top:10px;font-size:.9rem}.nested-table th,.nested-table td{padding:6px;vertical-align:top}.nested-table code{display:block;max-width:280px;white-space:normal;word-break:break-word}

.inline-form{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-top:4px}.inline-form input{max-width:140px}.calendar-note{font-size:.9rem;color:#6B6B6F}

/* Dienstregel-detail: gebruiksvriendelijke ritkaart i.p.v. technische veldtabel */
.trip-hero{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:start;border-left:6px solid #0A236D}
.trip-hero h2{margin:.1rem 0 .4rem;font-size:1.8rem}.eyebrow{margin:0;color:#6B6B6F;font-weight:800;text-transform:uppercase;letter-spacing:.03em;font-size:.78rem}.trip-route{font-size:1.1rem;margin:.25rem 0}.trip-route span{background:#EBF0F4;border-radius:999px;padding:3px 8px;font-weight:800}.trip-meta{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.pill{display:inline-block;background:#EBF0F4;border-radius:999px;padding:7px 11px;font-weight:800}.quality-badge,.quality-dot{display:inline-block;border-radius:999px;padding:4px 9px;font-weight:800;background:#EBF0F4}.quality-ok{border-color:#16a34a}.quality-ok.quality-badge,.quality-ok.quality-dot{background:#ecfdf5;color:#166534}.quality-warn{border-color:#FD8C05}.quality-warn.quality-badge,.quality-warn.quality-dot{background:#fff7ed;color:#9a3412}.quality-problem{border-color:#dc2626}.quality-problem.quality-badge,.quality-problem.quality-dot{background:#fef2f2;color:#991b1b}.issue-list{margin:.5rem 0 0;padding-left:1.2rem}.issue-list li{margin:.2rem 0}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}.detail-grid div{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:11px}.detail-grid strong{display:block;color:#6B6B6F;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}.detail-grid span{display:block;margin-top:3px;font-weight:800}.raw-details{margin-top:14px}.raw-details summary{cursor:pointer;font-weight:800;color:#0A236D}.mini-table{font-size:.88rem;margin-top:8px}.mini-table th,.mini-table td{padding:6px}.timeline-context{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.timeline-item{display:block;text-decoration:none;color:#0f172a;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:12px}.timeline-item.selected{background:#fff7ed;border-color:#FD8C05}.timeline-item span{display:block}.timeline-label{font-size:.78rem;color:#6B6B6F;text-transform:uppercase;font-weight:900;letter-spacing:.03em}@media(max-width:850px){.trip-hero{grid-template-columns:1fr}.trip-meta{justify-content:flex-start}.timeline-context{grid-template-columns:1fr}}
