:root{--blue:#0b5cad;--light:#eaf5ff;--dark:#08243d;--line:#d5e7f5;--red:#ef4444;--green:#16a34a;--yellow:#f59e0b}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:#f4f8fc;color:#12263a}.login{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#063b72,#37a8ff)}.card{background:#fff;border-radius:18px;padding:22px;box-shadow:0 12px 40px #0002}.login .card{width:360px}input,select,textarea,button{font:inherit;border-radius:10px;border:1px solid #c8d8e6;padding:10px;width:100%}button,.btn{border:0;background:var(--blue);color:white;cursor:pointer;text-decoration:none;display:inline-flex;gap:6px;align-items:center;justify-content:center;padding:10px 14px;border-radius:10px;width:auto}.danger{background:#dc2626}.ok{background:#16a34a}.warn{background:#f59e0b}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.side{background:#dff0ff;border-right:1px solid #b8daf5;padding:16px;position:sticky;top:0;height:100vh}.brand{font-size:22px;font-weight:800;color:var(--dark);margin-bottom:20px}.nav a{display:block;padding:12px;border-radius:12px;color:#083358;text-decoration:none;margin:5px 0}.nav a:hover,.nav a.active{background:#bde3ff}.main{padding:18px}.top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.stat{background:#fff;border-radius:16px;padding:18px;box-shadow:0 8px 24px #0b5cad12}.stat b{font-size:30px}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden}.table th,.table td{padding:10px;border-bottom:1px solid #e6eef6;text-align:left}.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.modal{position:fixed;inset:0;background:#0007;display:none;align-items:center;justify-content:center;z-index:50}.modal.show{display:flex}.modal .card{max-width:760px;width:95%;max-height:92vh;overflow:auto}.formgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}.dispo{background:white;border-radius:16px;box-shadow:0 10px 28px #0b5cad16;overflow:auto;height:calc(100vh - 120px);position:relative}.timeline{min-width:1600px}.head,.row{display:grid;grid-template-columns:170px repeat(17,80px)}.head{position:sticky;top:0;background:#eff8ff;z-index:5}.head div,.vehicle-cell{padding:10px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);font-weight:700}.slot{min-height:180px;
    height:auto;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative}.vehicle-cell{background:#f7fbff}.order{position:absolute;top:10px;left:6px;right:6px;background:#1e88e5;color:white;border-radius:12px;padding:8px;box-shadow:0 6px 18px #0003;cursor:grab;font-size:13px}.order[data-status="angenommen"]{background:#f59e0b}.order[data-status="patient_im_auto"]{background:#7c3aed}.order[data-status="abgeschlossen"]{background:#16a34a}.ctx{position:fixed;background:#fff;border:1px solid #cbd5e1;border-radius:12px;box-shadow:0 12px 30px #0003;display:none;z-index:90;min-width:210px}.ctx button{display:block;width:100%;background:#fff;color:#123;text-align:left;border-radius:0}.mobile{background:#f3f9ff}.mobile .wrap{max-width:520px;margin:auto;padding:14px}.ride{background:white;border-radius:16px;padding:14px;margin:12px 0;box-shadow:0 8px 20px #0b5cad15}.steps{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.pill{display:inline-block;padding:5px 9px;border-radius:20px;background:#e0f2fe;color:#075985;font-size:12px}@media(max-width:800px){.layout{grid-template-columns:1fr}.side{height:auto;position:relative}.head,.row{grid-template-columns:130px repeat(17,70px)}}
.order[data-status="zur_abholung"],.order[data-status="abholung_erreicht"]{background:#0284c7}.order[data-status="am_ziel"]{background:#0f766e}.ride .btn{width:100%;font-size:14px}.ride p{line-height:1.45}.mobile h1{margin-top:0}.mobile .toolbar .btn{margin:2px 0}

.order[data-status="gesendet"]{background:#f59e0b;color:#111827}
.order[data-status="gesehen"]{background:#15803d;color:#fff}
.legend{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;font-size:13px;font-weight:700;background:#e5eef8;color:#123}
.legend:before{content:"";width:12px;height:12px;border-radius:50%;display:inline-block;background:#1e88e5}
.legend.sent:before{background:#f59e0b}.legend.seen:before{background:#15803d}.legend.open:before{background:#1e88e5}
.ride .pill{font-weight:700}.ride:has(.pill){border-left:5px solid #15803d}

.order[data-status="offen"]{background:#1e88e5}
.order[data-status="gesendet"]{background:#facc15;color:#000}
.order[data-status="gesehen"]{background:#15803d;color:#fff}
.order[data-status="zur_abholung"],.order[data-status="abholung_erreicht"]{background:#fb923c}
.order[data-status="am_ziel"]{background:#a855f7}
/* CareMan-ähnliche Dispo Grand Ansicht */
.care-window{background:#efefef;border-bottom:1px solid #cfcfcf;margin:0;color:#111;font-family:Arial,sans-serif}.care-title{height:24px;padding:4px 8px;font-size:13px}.care-title span{margin-left:20px;color:#333}.care-menu{display:flex;gap:24px;height:26px;align-items:center;padding:0 8px;font-size:13px;background:#f7f7f7}.care-toolbar{height:38px;display:flex;align-items:center;gap:6px;padding:4px 8px;background:#e9e9e9}.ico{width:28px;height:26px;border:1px solid #bdbdbd;background:#fff;color:#111;border-radius:2px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;padding:0}.selectbar{margin-left:40px;width:300px;height:24px;border:1px solid #aaa;background:#ddd}.live-dot{margin-left:auto;font-weight:bold;color:#0a7f22;font-size:12px}.care-date{background:#fff;height:36px;line-height:36px;border-bottom:2px solid #111;padding:0 8px;font-family:Arial,sans-serif}.care-counter{float:right;font-size:12px}.care-dispo{border-radius:0;height:calc(100vh - 70px);box-shadow:none;border:2px solid #111;background:#ffffbf}.care-timeline{min-width:3288px}.care-head,.care-row,.dark-band{display:grid;grid-template-columns:180px repeat(21,148px)}.care-head{background:#c9c2ff;color:#00114a;font-size:12px;height:42px;position:sticky;top:0;z-index:9}.care-head div{border-right:1px dotted #777;border-bottom:1px solid #555;padding:3px;font-weight:normal}.corner{display:grid!important;grid-template-columns:1fr 1fr;background:#eee!important;color:#000!important}.corner span{border-right:1px solid #111;padding:8px 4px;font-weight:bold}.dark-band{height:38px}.dark-band .band{height:38px;background:linear-gradient(#9ab0bf,#102132,#9ab0bf)!important;border-bottom:1px solid #111}.vehicle-cell.group{background:#a8d8ff!important;color:#00325e;font-weight:bold}.care-row{height:38px}.care-slot{height:38px;background:#ffffbf;border-right:1px dotted #9a9a74;border-bottom:1px solid #777;overflow:visible}.carcode{height:38px;background:#eee;border-right:2px solid #111;border-bottom:1px solid #777;color:#000;font-size:13px;padding:4px 6px;line-height:14px}.carcode b{float:left}.carcode small{float:right;color:#000;font-weight:bold}.carcode.unplanned{background:#fff4cc}.care-order{top:4px;left:2px;right:auto;width:62px;min-height:28px;border-radius:0;background:#bff8ff!important;color:#000!important;border:2px solid #00747e;box-shadow:1px 1px 1px #0005;font-size:11px;line-height:11px;text-align:center;padding:3px 2px}.care-order b{font-weight:bold;display:block;white-space:normal}.care-order .fms-dot{position:absolute;right:-7px;top:9px;width:9px;height:9px;border-radius:50%;border:1px solid #111;background:var(--statusColor)}.care-order[data-status="gesendet"]{background:#fff59d!important;border-color:#b38b00}.care-order[data-status="gesehen"]{background:#15803d!important;border-color:#064e3b;color:#fff!important}.care-order[data-status="angenommen"]{background:#a7f3d0!important;border-color:#166534}.care-order[data-status="zur_abholung"],.care-order[data-status="abholung_erreicht"]{background:#fed7aa!important;border-color:#c2410c}.care-order[data-status="patient_im_auto"]{background:#a5f3fc!important;border-color:#0e7490}.care-order[data-status="am_ziel"]{background:#e9d5ff!important;border-color:#7e22ce}.fms{height:42px;background:#eee;border-top:1px solid #bbb;display:flex;align-items:center;gap:18px;padding:0 8px;font-size:12px;color:#111}.fms i{width:14px;height:14px;display:inline-block;border:1px solid #aaa;margin-right:5px;vertical-align:middle}.ctx button:hover{background:#dbeafe}
/* Verbesserungen: Fahrzeugverwaltung, Drag-and-drop und aktuelle Uhrzeit */
.actions{display:flex;gap:6px;flex-wrap:wrap}.badge{display:inline-block;padding:5px 9px;border-radius:999px;font-weight:800;font-size:12px}.badge.green{background:#dcfce7;color:#166534}.badge.red{background:#fee2e2;color:#991b1b}.okmsg{margin-bottom:12px;background:#dcfce7;color:#14532d}.hint{align-self:center;color:#475569;font-size:13px}.drop-target{outline:2px solid #ef4444;outline-offset:-2px;background:#fff7aa!important}.order.dragging{opacity:.55}.care-order{user-select:none}.now-line{position:absolute;top:42px;bottom:0;width:0;border-left:3px solid #ef0000;z-index:20;pointer-events:none;filter:drop-shadow(0 0 2px #fff)}.now-line span{position:absolute;top:-19px;left:-22px;background:#ef0000;color:#fff;font-size:11px;font-weight:bold;padding:2px 5px;border-radius:3px;white-space:nowrap}.care-timeline{position:relative}.care-dispo{position:relative}.care-slot{min-height:38px}.care-order{z-index:10}.care-slot .care-order:nth-child(2){top:20px}.care-slot .care-order:nth-child(3){top:36px}.care-slot .care-order:nth-child(n+4){top:52px}

.dispo-popup .card{max-width:920px;width:min(920px,96vw);max-height:92vh;overflow:auto}
.popup-head{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid #d7d7d7;margin:-4px 0 14px;padding-bottom:10px}
.popup-head h2{margin:0;font-size:20px}
.xbtn{border:0;background:#ef4444;color:white;border-radius:6px;font-size:26px;line-height:30px;width:34px;height:34px;cursor:pointer}
.popup-grid{grid-template-columns:repeat(2,minmax(220px,1fr));gap:10px}
.popup-grid label{font-weight:700;font-size:13px;color:#1f2937;display:flex;flex-direction:column;gap:4px}
.popup-grid .wide{grid-column:1/-1}
.popup-grid input,.popup-grid select,.popup-grid textarea{width:100%;box-sizing:border-box;border:1px solid #b7bec7;border-radius:6px;padding:9px;background:white;font-size:14px}
.popup-grid textarea{min-height:62px;resize:vertical}
.popup-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px;border-top:1px solid #e5e7eb;padding-top:12px}
.care-toolbar .ico{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border:1px solid #a3a3a3;background:#eee;height:24px;min-width:26px;margin-right:3px;cursor:pointer;border-radius:2px}

/* Fix: obere CareMan-Menüleiste entfernt, Popup + Status sichtbar */
.main{padding:0}
.care-date{height:38px;line-height:38px}
.mini-ico{display:inline-flex;align-items:center;justify-content:center;width:auto!important;height:26px;line-height:22px;padding:2px 8px;margin-right:6px;border:1px solid #999;background:#eee!important;color:#111!important;border-radius:2px;text-decoration:none;font-size:12px;vertical-align:middle}
.care-order[data-status="gesehen"] .fms-dot{background:#15803d!important}
.fms i[style*="#22c55e"]{background:#15803d!important}


/* Update: linke Navigation nach oben, Dispo Grand auf voller Breite */
.top-nav{height:44px;background:#f2f2f2;border-bottom:1px solid #cfcfcf;display:flex;align-items:center;gap:12px;padding:0 8px;position:sticky;top:0;z-index:1000;box-shadow:0 1px 4px #0001}
.top-brand{font-weight:900;color:#08243d;white-space:nowrap;font-size:15px}.top-links{display:flex;align-items:center;gap:3px;overflow-x:auto;white-space:nowrap}.top-links a{display:inline-flex;align-items:center;height:30px;padding:0 10px;border-radius:5px;text-decoration:none;color:#111;font-size:13px;border:1px solid transparent}.top-links a:hover,.top-links a.active{background:#dbeafe;border-color:#93c5fd;color:#062b55}.top-layout{display:block;min-height:calc(100vh - 44px)}.top-layout .side{display:none!important}.top-layout .main{padding:10px}.dispo-fullscreen-fix+.care-date,.care-date{margin-top:0}.care-dispo{height:calc(100vh - 124px)!important;border-radius:0}.dispo{border-radius:0}.layout{grid-template-columns:1fr!important}
@media(max-width:800px){.top-nav{height:auto;align-items:flex-start;flex-direction:column;padding:6px}.top-links{width:100%}.top-layout .main{padding:6px}.care-dispo{height:calc(100vh - 142px)!important}}

/* Moderne Fahrer-Webseite mit fester unterer Bedienleiste */
.mobile-modern{background:linear-gradient(180deg,#eaf5ff 0,#f8fbff 100%);min-height:100vh;padding-bottom:92px}.driver-hero{background:linear-gradient(135deg,#0b5cad,#38bdf8);color:#fff;border-radius:0 0 24px 24px;padding:18px 16px;box-shadow:0 10px 30px #0b5cad35;position:sticky;top:0;z-index:20}.driver-hero h1{margin:0;font-size:24px}.driver-hero p{margin:6px 0 0;opacity:.95}.driver-wrap{max-width:720px;margin:0 auto;padding:14px}.ride-modern{border:0;border-left:7px solid var(--statusColor,#0b5cad);border-radius:18px;padding:16px;background:#fff;box-shadow:0 8px 28px #0b5cad18;margin:14px 0}.ride-modern .ride-title{font-size:18px;font-weight:900;display:flex;justify-content:space-between;gap:8px}.ride-modern .addr{background:#f1f8ff;border:1px solid #d8ecff;border-radius:12px;padding:10px;margin:10px 0}.driver-bottom{position:fixed;left:0;right:0;bottom:0;background:#ffffffee;backdrop-filter:blur(12px);border-top:1px solid #cfe0ef;box-shadow:0 -8px 24px #0002;z-index:99}.driver-bottom-inner{max-width:720px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:8px}.driver-bottom a,.driver-bottom button{min-height:48px;border-radius:14px;font-size:12px;padding:6px 4px;flex-direction:column;gap:2px}.driver-login-modal{align-items:flex-end}.driver-login-modal .card{border-radius:24px 24px 0 0;max-width:720px;width:100%;max-height:82vh}.driver-login-status{background:#fff;border-radius:16px;padding:12px;margin:10px 0;box-shadow:0 6px 18px #0b5cad14}.driver-empty{background:white;border-radius:18px;padding:18px;text-align:center;box-shadow:0 8px 24px #0b5cad14}.driver-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.driver-actions .btn,.driver-actions button{width:100%;border-radius:12px}.driver-status-green{background:#dcfce7;color:#14532d}.driver-status-yellow{background:#fef3c7;color:#92400e}.driver-status-blue{background:#dbeafe;color:#1d4ed8}
@media(max-width:520px){.driver-bottom-inner{grid-template-columns:repeat(4,1fr);gap:4px;padding:7px}.driver-bottom a,.driver-bottom button{font-size:11px}.driver-actions{grid-template-columns:1fr}.driver-hero h1{font-size:21px}}

/* Fahrer-Webseite: feste untere Leiste nur als Zugang, Dienstfunktionen im separaten Menü */
.driver-bottom-menu{grid-template-columns:1fr 1fr!important;gap:10px!important}
.driver-bottom-menu button{font-size:13px!important;font-weight:800;background:#0b5cad;color:#fff;border:0;box-shadow:0 8px 18px #0b5cad2e}
.driver-bottom-menu button:first-child{background:#0f766e}
.driver-service-modal{align-items:flex-end;z-index:120}
.driver-service-modal .service-card{border-radius:24px 24px 0 0;max-width:720px;width:100%;max-height:85vh;overflow:auto}
.service-status{background:#f1f8ff;border:1px solid #d8ecff;border-radius:16px;padding:14px;margin:8px 0 14px}
.service-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.service-grid a,.service-grid button{min-height:72px;border-radius:16px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:5px;text-align:center}
.service-grid button{background:#0b5cad;color:#fff;border:0}
.service-grid .btn{width:auto;text-decoration:none;color:#fff}
.service-grid .warn{background:#f59e0b;color:#111827}
.service-grid .ok{background:#15803d;color:#fff}
.service-grid .danger{background:#dc2626;color:#fff}
.back-rides{margin-top:14px;width:100%;border-radius:16px;background:#111827;color:#fff;border:0;padding:14px;font-weight:900}
@media(max-width:520px){.service-grid{grid-template-columns:1fr}.driver-bottom-menu{grid-template-columns:1fr 1fr!important}}
/* Fahrer Dienst-Menü Fix: Popups immer im Vordergrund */
.front-modal{z-index:99999!important;align-items:center!important;justify-content:center!important;background:rgba(3,7,18,.72)!important;backdrop-filter:blur(8px)}
.front-modal.show{display:flex!important;position:fixed!important;inset:0!important}
.front-modal .card{position:relative!important;z-index:100000!important;width:min(94vw,480px)!important;box-shadow:0 24px 80px rgba(0,0,0,.45)!important;border:1px solid rgba(255,255,255,.22)!important}
.driver-service-modal{z-index:90000!important}
.driver-service-modal.show{display:flex!important;position:fixed!important;inset:0!important}
.service-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0}
.service-grid button,.service-grid a{min-height:70px;border-radius:18px;text-decoration:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-weight:800}
.driver-login-modal select{width:100%;padding:14px;border-radius:14px;border:1px solid #cbd5e1;background:#fff;font-size:18px}
.driver-login-modal label{font-weight:800;color:#0f172a}
.grid2{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:end}.grid2 input{padding:10px;border-radius:10px;border:1px solid #cbd5e1}
@media(max-width:700px){.service-grid{grid-template-columns:1fr}.grid2{grid-template-columns:1fr}}


/* Fahrer-Anmeldung auf CareMan Grand: Auto-Zeitlinie ab aktueller roter Uhrzeit bis 00:00 grün markieren */
.care-row{position:relative}
.service-line{position:absolute;top:0;height:38px;background:rgba(34,197,94,.55);border-left:3px solid #15803d;border-right:3px solid #15803d;border-radius:0;z-index:3;pointer-events:auto;box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}
.service-line span{position:absolute;left:6px;top:2px;background:#15803d;color:#fff;font-size:10px;line-height:13px;padding:1px 5px;border-radius:3px;white-space:nowrap;font-weight:800}
.carcode.car-online{background:#dcfce7!important;border-left:5px solid #15803d;color:#064e3b!important}
.service-active-row .care-order{z-index:12}

/* Fahrer-Aufträge als einzelne Kanban-Fenster */
.driver-kanban-list{display:grid;grid-template-columns:1fr;gap:14px;margin:12px 0 90px}
.driver-kanban-card{background:#fff;border-radius:20px;border-left:8px solid var(--statusColor,#0b5cad);box-shadow:0 10px 30px #0b5cad1c;padding:14px;cursor:pointer;transition:.15s transform,.15s box-shadow;position:relative;overflow:hidden}
.driver-kanban-card:active{transform:scale(.99)}
.driver-kanban-card:hover{box-shadow:0 14px 36px #0b5cad2b}
.driver-kanban-card:before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:var(--statusColor,#0b5cad);opacity:.8}
.kanban-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.kanban-top b{font-size:18px;color:#0f172a}
.driver-kanban-card h3{margin:5px 0 10px;font-size:20px;color:#08243d}
.kanban-route{display:grid;gap:8px;margin:10px 0;color:#334155;font-size:14px}
.kanban-route span{background:#f1f8ff;border:1px solid #d8ecff;border-radius:12px;padding:9px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.driver-kanban-card button{width:100%;margin-top:8px;border-radius:14px;font-weight:900;background:#0b5cad;color:#fff}
.driver-back-main{display:flex;align-items:center;justify-content:center;background:#111827;color:#fff;text-decoration:none;border-radius:16px;padding:13px 16px;font-weight:900;margin:10px 0 14px;box-shadow:0 8px 22px #0002}
.ride-detail{margin-bottom:100px}
@media(min-width:680px){.driver-kanban-list{grid-template-columns:1fr 1fr}.ride-detail{max-width:720px;margin-left:auto;margin-right:auto}}

/* Fahrer-Auftragsfenster: nur Name und Abholzeit */
.driver-simple-order{min-height:96px;display:grid;grid-template-columns:82px 1fr;align-items:center;gap:12px;padding:16px 14px!important}
.driver-simple-order .simple-time{background:#eaf5ff;border:1px solid #b8daf5;border-radius:16px;padding:12px 8px;text-align:center;font-size:22px;font-weight:900;color:#08243d}
.driver-simple-order h3{margin:0!important;font-size:23px!important;line-height:1.15;color:#08243d}
.driver-simple-order .kanban-route,.driver-simple-order button,.driver-simple-order .kanban-top{display:none!important}
/* Popup im Dispo Grand bleibt vorne und wird nicht von Auto-Refresh geschlossen */
.dispo-popup.show{display:flex!important;z-index:9999!important}
.dispo-popup .order-form{border:3px solid #0b5cad}

/* Moderne Dienst Statistik */
.stats-pro-hero{display:flex;align-items:center;justify-content:space-between;gap:14px;background:linear-gradient(135deg,#0b5cad,#38bdf8);color:white;border-radius:22px;padding:22px;margin-bottom:14px;box-shadow:0 16px 38px #0b5cad30}.stats-pro-hero h1{margin:0;font-size:30px}.stats-pro-hero p{margin:6px 0 0;opacity:.94}.live-chip{background:#ffffff22;border:1px solid #ffffff55;border-radius:999px;padding:9px 13px;font-weight:900;white-space:nowrap}.stats-filter-card{margin-bottom:14px}.stats-filter{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:12px;align-items:end}.stats-filter label{font-weight:800;color:#0f172a}.stats-filter input,.stats-filter select{margin-top:5px}.stats-filter button{width:100%;height:43px;font-weight:900}.stats-kpis{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px;margin-bottom:14px}.kpi-card{background:#fff;border-radius:20px;padding:18px;box-shadow:0 10px 26px #0b5cad14;border:1px solid #e2edf7}.kpi-card span{display:block;color:#52657a;font-weight:800;font-size:13px}.kpi-card b{display:block;font-size:32px;margin:8px 0;color:#08243d}.kpi-card small{color:#64748b}.stats-dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.stat-panel{margin-bottom:14px}.stat-panel h2{margin-top:0;color:#08243d}.bar-row{margin:13px 0}.bar-label{display:flex;justify-content:space-between;gap:10px;font-size:14px;margin-bottom:6px}.bar-track{height:14px;border-radius:999px;background:#e8f2fb;overflow:hidden}.bar-track i{display:block;height:100%;background:linear-gradient(90deg,#0b5cad,#38bdf8);border-radius:999px}.bar-track.driver i{background:linear-gradient(90deg,#15803d,#86efac)}.day-bars{height:190px;display:flex;align-items:end;gap:8px;border-bottom:1px solid #dce8f4;padding:14px 4px 24px;overflow-x:auto}.day-col{height:150px;min-width:42px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative}.day-col i{display:block;width:26px;background:linear-gradient(180deg,#38bdf8,#0b5cad);border-radius:8px 8px 0 0;min-height:4px}.day-col span{position:absolute;bottom:-22px;font-size:11px;color:#64748b}.table-scroll{overflow:auto}.pro-table th{position:sticky;top:0;background:#eff8ff;z-index:2}.state-running,.state-done{display:inline-block;border-radius:999px;padding:4px 8px;font-weight:900;font-size:12px}.state-running{background:#dcfce7;color:#166534}.state-done{background:#e2e8f0;color:#334155}.idea-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.idea-grid div{background:#f1f8ff;border:1px solid #d8ecff;border-radius:14px;padding:13px;font-weight:800;color:#123b5c}@media(max-width:980px){.stats-filter{grid-template-columns:1fr 1fr}.stats-kpis{grid-template-columns:1fr 1fr}.stats-dashboard-grid{grid-template-columns:1fr}}@media(max-width:620px){.stats-pro-hero{display:block}.live-chip{display:inline-block;margin-top:12px}.stats-filter,.stats-kpis{grid-template-columns:1fr}.kpi-card b{font-size:28px}}
.driver-push-btn{margin-top:10px;background:#111827;color:#fff;border:0;border-radius:999px;padding:10px 14px;font-weight:800;box-shadow:0 8px 20px #0003}.driver-push-btn:active{transform:scale(.98)}
.report .badge{display:inline-block;padding:3px 8px;border-radius:999px;background:#e2e8f0}
@media(max-width:900px){.report-grid{grid-template-columns:1fr 1fr!important}}
/* Fahrer-Sprachumschalter oben rechts */
.driver-hero-lang{display:flex;align-items:center;justify-content:space-between;gap:12px}
.driver-lang-switch{display:flex;gap:8px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.driver-lang-switch button{border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.16);color:#fff;border-radius:999px;padding:8px 12px;font-weight:800;box-shadow:0 8px 20px rgba(0,0,0,.18);cursor:pointer}
.driver-lang-switch button:hover{background:rgba(255,255,255,.28)}
body.rtl{direction:rtl;text-align:right}
body.rtl .driver-actions,body.rtl .service-grid,body.rtl .driver-bottom-inner{direction:rtl}
body.rtl .driver-back-main{display:block;text-align:right}
@media(max-width:640px){.driver-hero-lang{align-items:flex-start}.driver-lang-switch button{padding:7px 10px;font-size:12px}}

/* smoother CareMan Grand drag/drop */
body.is-dragging .care-order{transition:none!important}
.care-order{will-change:transform;touch-action:none;user-select:none}
.care-order.dragging{opacity:.72;transform:scale(1.03);z-index:50;box-shadow:0 14px 30px rgba(15,23,42,.28)}
.care-slot.drop-target{outline:2px dashed #0b5cad;outline-offset:-3px;background:rgba(11,92,173,.08)}
.service-line span{display:none!important}


/* Finale Auftragsfarben im CareMan Grand */
.care-order[data-status="offen"]{background:#bff8ff!important;color:#000!important;border-color:#00747e!important}
.care-order[data-status="gesendet"]{background:#facc15!important;color:#111827!important;border-color:#a16207!important}
.care-order[data-status="gesehen"]{background:#15803d!important;color:#fff!important;border-color:#064e3b!important}
.care-order[data-status="angenommen"]{background:#166534!important;color:#fff!important;border-color:#052e16!important}
.care-order[data-status="zur_abholung"],.care-order[data-status="abholung_erreicht"]{background:#fb923c!important;color:#111827!important;border-color:#c2410c!important}
.care-order[data-status="patient_im_auto"]{background:#06b6d4!important;color:#001f2a!important;border-color:#0e7490!important}
.care-order[data-status="am_ziel"]{background:#a855f7!important;color:#fff!important;border-color:#6b21a8!important}
/* Fahrer Tankstellen-Karte NRW */
.tankmap-page{padding-bottom:86px;background:#eef6ff}.map-hero{position:relative;z-index:10}.map-hero .btn{background:#fff;color:#0f172a;border-radius:14px;padding:10px 14px;text-decoration:none;font-weight:800}.map-filter{position:fixed;top:86px;left:10px;right:10px;z-index:800;display:flex;gap:8px;overflow:auto;padding:8px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-radius:18px;box-shadow:0 10px 30px rgba(15,23,42,.12)}.map-filter button{border:0;background:#e0f2fe;color:#075985;font-weight:900;border-radius:14px;padding:10px 14px;white-space:nowrap}.map-filter button.active,.map-filter button:hover{background:#38bdf8;color:#fff}#tankMap{position:fixed;left:0;right:0;top:0;bottom:76px;z-index:1}.tank-marker div{width:42px;height:42px;border-radius:15px;background:#0ea5e9;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:1000;border:3px solid #fff;box-shadow:0 8px 22px rgba(2,6,23,.24);font-size:12px}.station-panel{position:fixed;left:12px;right:12px;bottom:88px;z-index:900;background:rgba(255,255,255,.96);border-radius:22px;padding:14px;box-shadow:0 18px 45px rgba(15,23,42,.22);border:1px solid #dbeafe}.station-title{display:flex;justify-content:space-between;gap:10px;align-items:center}.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:10px 0}.price-grid div{background:#f0f9ff;border:1px solid #bae6fd;border-radius:14px;text-align:center;padding:10px;font-size:13px}.price-grid b{font-size:18px;color:#0f766e}.nav-big{display:block;text-align:center;background:#16a34a;color:#fff;text-decoration:none;border-radius:16px;padding:13px;font-weight:1000;margin-top:10px}.driver-bottom .active{background:#dbeafe}

/* CareDispo Modernisierung ohne Funktionsverlust */
.modern-top-nav{position:sticky;top:0;z-index:1000;background:rgba(246,251,255,.94)!important;backdrop-filter:blur(14px);border-bottom:1px solid #dbeafe;box-shadow:0 10px 32px rgba(15,23,42,.08)}
.top-brand{display:flex!important;align-items:center;gap:9px;font-weight:1000;color:#08243d}.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,#0b5cad,#38bdf8);box-shadow:0 10px 24px rgba(11,92,173,.25)}.top-brand small{background:#dbeafe;color:#0b5cad;border-radius:999px;padding:3px 8px;font-size:11px}.top-links a{transition:.18s transform,.18s background,.18s box-shadow}.top-links a:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(11,92,173,.12)}
.modern-hero{display:flex;justify-content:space-between;align-items:center;gap:18px;background:linear-gradient(135deg,#08243d,#0b5cad 55%,#38bdf8);color:white;border-radius:28px;padding:28px;margin-bottom:16px;box-shadow:0 24px 55px rgba(11,92,173,.28);overflow:hidden;position:relative}.modern-hero:after{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;border-radius:999px;background:rgba(255,255,255,.12)}.modern-hero h1{font-size:38px;margin:4px 0}.modern-hero p{margin:0;opacity:.92}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:900;opacity:.86}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:2}.btn.glass{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);backdrop-filter:blur(8px);font-weight:900}.btn.glass:hover{background:rgba(255,255,255,.28)}
.quick-command{display:grid;grid-template-columns:260px 1fr;gap:14px;align-items:center;margin-bottom:16px;position:relative;border:1px solid #e0edf8}.quick-command b{font-size:18px}.quick-command span,.muted{color:#64748b}.quick-command input{height:48px;border:2px solid #dbeafe;background:#f8fcff;font-weight:800}.quick-results{position:absolute;left:282px;right:22px;top:74px;z-index:50;background:#fff;border:1px solid #dbeafe;border-radius:18px;box-shadow:0 18px 45px rgba(15,23,42,.18);display:none;overflow:hidden}.quick-results a{display:flex;justify-content:space-between;gap:10px;padding:12px 14px;text-decoration:none;color:#0f172a;border-bottom:1px solid #edf5ff}.quick-results a:hover{background:#eff8ff}.quick-results a:last-child{border-bottom:0}
.modern-kpis{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px;margin-bottom:16px}.kpi-modern{border-radius:24px;padding:20px;color:#0f172a;background:#fff;box-shadow:0 14px 34px rgba(11,92,173,.11);border:1px solid #e2edf7;position:relative;overflow:hidden}.kpi-modern:before{content:"";position:absolute;right:-26px;top:-26px;width:90px;height:90px;border-radius:999px;background:currentColor;opacity:.09}.kpi-modern span{font-weight:900;color:#52657a}.kpi-modern b{display:block;font-size:38px;margin:8px 0;color:#08243d}.kpi-modern small{color:#64748b}.kpi-modern.blue{color:#0ea5e9}.kpi-modern.yellow{color:#eab308}.kpi-modern.green{color:#22c55e}.kpi-modern.dark{color:#08243d}
.cockpit-grid{display:grid;grid-template-columns:1.25fr .9fr;gap:16px;margin-bottom:16px}.cockpit-card{min-height:330px}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.card-head h2{margin:0;color:#08243d}.card-head a{color:#0b5cad;font-weight:900;text-decoration:none}.live-list{display:grid;gap:10px}.live-item{display:grid;grid-template-columns:72px 1fr auto;gap:12px;align-items:center;padding:12px;border-radius:18px;background:#f8fcff;border:1px solid #e4f1fc}.live-item .timebox{background:#08243d;color:#fff;border-radius:14px;padding:10px 6px;text-align:center;font-weight:1000}.live-item b{font-size:16px}.live-item span{color:#64748b;font-size:13px}.live-item em{font-style:normal;font-size:12px;font-weight:900;border-radius:999px;padding:6px 9px;background:#e2e8f0;white-space:nowrap}.live-item.status-gesendet em{background:#fef3c7;color:#92400e}.live-item.status-gesehen em{background:#dcfce7;color:#166534}.live-item.status-angenommen em{background:#bbf7d0;color:#14532d}.live-item.status-am_ziel em{background:#f3e8ff;color:#6b21a8}
.vehicle-mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.vehicle-mini{display:block;text-decoration:none;color:#0f172a;background:#f8fcff;border:1px solid #dbeafe;border-radius:18px;padding:14px;transition:.18s transform,.18s box-shadow}.vehicle-mini:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(11,92,173,.14)}.vehicle-mini b{display:block;font-size:17px}.vehicle-mini span{display:block;color:#64748b;font-size:12px;margin:3px 0 10px}.vehicle-mini i{font-style:normal;font-weight:900;background:#e0f2fe;color:#075985;border-radius:999px;padding:4px 8px;font-size:12px}.vehicle-mini.inactive{opacity:.55;filter:grayscale(.4)}.smart-panel{margin-bottom:18px}.live-chip-soft{background:#dcfce7;color:#166534;border-radius:999px;padding:7px 11px;font-weight:900}.modern-ideas div{background:linear-gradient(180deg,#ffffff,#f0f9ff);box-shadow:0 8px 20px rgba(11,92,173,.08)}
.care-date{position:sticky;top:58px;z-index:998;background:rgba(255,255,255,.95)!important;backdrop-filter:blur(12px);box-shadow:0 6px 18px rgba(15,23,42,.08)}.mini-ico{box-shadow:0 8px 18px rgba(11,92,173,.12);font-weight:900}.care-dispo{scroll-behavior:smooth}.care-order{transition:.12s transform,.12s box-shadow,.12s filter}.care-order:hover{transform:scale(1.06);box-shadow:0 12px 24px rgba(15,23,42,.25);filter:saturate(1.08)}.now-line{animation:pulseNow 1.8s infinite}@keyframes pulseNow{0%,100%{filter:drop-shadow(0 0 2px #fff)}50%{filter:drop-shadow(0 0 8px #ef0000)}}
@media(max-width:980px){.modern-hero{display:block}.hero-actions{margin-top:16px}.quick-command{grid-template-columns:1fr}.quick-results{left:22px;top:120px}.modern-kpis{grid-template-columns:1fr 1fr}.cockpit-grid{grid-template-columns:1fr}}@media(max-width:640px){.modern-kpis{grid-template-columns:1fr}.modern-hero h1{font-size:30px}.live-item{grid-template-columns:62px 1fr}.live-item em{grid-column:1/-1;justify-self:start}}

/* Final-Fix: CareMan Grand breite Zeitfenster + minutengenaue Auftragsposition */
.care-timeline{min-width:3288px!important;position:relative!important}
.care-head,.care-row,.dark-band{grid-template-columns:180px repeat(21,148px)!important}
.care-row{height:82px!important;min-height:82px!important}
.dark-band{height:38px!important;min-height:38px!important}
.care-slot{height:82px!important;min-height:82px!important;position:relative!important;overflow:visible!important}
.care-order{position:absolute!important;right:auto!important;min-width:74px!important;max-width:288px!important;height:30px!important;min-height:30px!important;line-height:11px!important;z-index:12!important;margin:0!important}
.care-slot .care-order:nth-child(2),.care-slot .care-order:nth-child(3),.care-slot .care-order:nth-child(n+4){top:auto}


/* Final-Fix 2: linke Fahrzeug-Spalte fest + Auftraglinien halb so hoch */
.care-dispo{overflow:auto!important;position:relative!important;}
.care-head .corner,
.dark-band .vehicle-cell,
.care-row .vehicle-cell{
  position:sticky!important;
  left:0!important;
  z-index:40!important;
}
.care-head .corner{z-index:80!important;}
.care-row .vehicle-cell{z-index:45!important;}
.dark-band .vehicle-cell{z-index:46!important;}
.care-head{z-index:70!important;}
.care-head,.care-row,.dark-band{grid-template-columns:180px repeat(21,148px)!important;}
.care-row{height:42px!important;min-height:42px!important;}
.care-slot{height:42px!important;min-height:42px!important;position:relative!important;overflow:visible!important;}
.carcode{height:42px!important;min-height:42px!important;padding:3px 6px!important;line-height:13px!important;}
.care-order{height:18px!important;min-height:18px!important;line-height:9px!important;font-size:9px!important;padding:2px 2px!important;min-width:74px!important;max-width:288px!important;}
.care-order .fms-dot{top:4px!important;}
.service-line{height:42px!important;}

.daten-panel,.info-panel,.data-box,.vehicle-details,.details-panel,.detail-panel,.sidebar-details{display:none!important;}

/* FIX: Dispo Grand ohne blaues Daten-Fenster, breite Zeitfenster, feste Fahrzeugspalte */
.care-timeline{min-width:3288px!important;}
.care-head,.care-row,.dark-band{grid-template-columns:180px repeat(21,148px)!important;}
.dark-band,.vehicle-cell.group{display:none!important;height:0!important;min-height:0!important;overflow:hidden!important;}
.care-head .corner,.care-row .carcode{position:sticky!important;left:0!important;z-index:30!important;}
.care-head .corner{z-index:45!important;}
.care-row{position:relative!important;height:38px!important;}
.care-slot{height:38px!important;}
.carcode{height:38px!important;}
.care-order{min-height:18px!important;padding:2px 2px!important;font-size:10px!important;line-height:10px!important;}


/* Zusatz-Fix: eigene Zeitachsen-Linie unter Nummer/Zusatz im CareMan Grand */
.care-axis-row{
  display:grid!important;
  grid-template-columns:180px repeat(21,148px)!important;
  position:sticky!important;
  top:42px!important;
  z-index:60!important;
  min-height:22px!important;
  height:22px!important;
  background:#f8fbff!important;
}
.care-axis-left{
  position:sticky!important;
  left:0!important;
  z-index:70!important;
  background:#eef6ff!important;
  border-right:1px solid #9eb9cf!important;
  border-bottom:2px solid #0b5cad!important;
  color:#08243d!important;
  font-size:10px!important;
  font-weight:900!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
}
.care-axis-hour{
  position:relative!important;
  height:22px!important;
  border-right:1px solid #c7d9e8!important;
  border-bottom:2px solid #0b5cad!important;
  background:#ffffff!important;
}
.care-axis-hour:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  border-left:2px solid #0b5cad;
}
.care-axis-hour span{
  position:absolute;
  left:4px;
  top:3px;
  font-size:10px!important;
  line-height:10px!important;
  font-weight:900!important;
  color:#08243d!important;
}
.care-head{position:sticky!important;top:0!important;}
.care-head .corner{height:42px!important;min-height:42px!important;}
.care-head div:not(.corner){height:42px!important;min-height:42px!important;}
.now-line{top:64px!important;}

/* Kontextmenü für Dispo Grand: neuer Auftrag / ändern / Rückfahrt / abschließen */
.ctx{z-index:5000!important;min-width:240px!important;overflow:hidden!important}
.ctx hr{border:0;border-top:1px solid #e2e8f0;margin:4px 0}
.ctx button{font-size:13px!important;padding:9px 12px!important;cursor:pointer!important}
.ctx button.danger{color:#b91c1c!important;font-weight:900!important}
.ctx button:hover{background:#dbeafe!important}

/* Fix: Jetzt-Linie sichtbar über voller Dispo-Höhe und Auftrags-Menü editierbar */
.now-line{position:absolute!important;bottom:0!important;z-index:90!important;pointer-events:none!important;}
.now-line span{font-size:11px!important;font-weight:900!important;white-space:nowrap!important;}
.table .btn{padding:5px 8px!important;font-size:12px!important;text-decoration:none!important;display:inline-block!important;margin:2px!important;}


/* Anpassung: rote Jetzt-Linie näher an Fahrzeuge; Dispo darf beim Drag nicht automatisch scrollen */
body.is-dragging .care-dispo{scroll-behavior:auto!important;overflow:auto!important;}
body.is-dragging .care-order{cursor:grabbing!important;}

/* FIX: CareMan Grand bleibt beim Auftrag-Verschieben unbeweglich */
body.is-dragging .care-dispo{overflow:hidden!important;scroll-behavior:auto!important;}
body.is-dragging .care-timeline{scroll-behavior:auto!important;}
body.is-dragging, body.is-dragging *{user-select:none!important;}

.transport-certificate-alert{display:inline-block;margin:6px 0 4px 0;padding:4px 8px;border-radius:8px;background:#dc2626;color:#fff;font-weight:800;font-size:12px;box-shadow:0 4px 12px rgba(220,38,38,.25)}
.order-form label select#order_transport_certificate{font-weight:800}
