:root{--primary:#0b3d91;--primary-dark:#082d6b;--accent:#e8a317;--accent-hover:#d4940f}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Open Sans,sans-serif;background:linear-gradient(135deg,#0b3d91,#1a5bc4 50%,#0b3d91);min-height:100vh;color:#333}h1,h2,h3{font-family:Montserrat,sans-serif}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:16px;padding:40px;max-width:440px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3)}.login-card h1{color:var(--primary);text-align:center;font-size:1.6rem}.login-card .subtitle{text-align:center;color:#888;margin:4px 0 24px;font-size:.9rem}.login-card label{display:block;font-weight:600;margin-bottom:6px;font-size:.85rem}.login-card input{width:100%;padding:12px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;outline:none;transition:border-color .2s}.login-card input:focus{border-color:var(--primary)}.login-card button[type=submit]{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;margin-top:16px;transition:background .2s}.login-card button[type=submit]:hover{background:var(--accent-hover)}.login-error{color:#dc3545;font-size:.85rem;margin-top:8px}.pw-wrapper{position:relative}.pw-wrapper input{width:100%;padding-right:50px}.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;background:var(--accent);border:none;border-radius:6px;cursor:pointer;color:#fff;display:inline-flex;align-items:center;justify-content:center;padding:0;line-height:1}.dashboard{min-height:100vh;background:#f5f6fa}.dash-header{background:var(--primary);color:#fff;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.dash-header h1{font-size:1.3rem}.dash-header .sub{opacity:.7;font-size:.85rem}.dash-header a.header-btn,.dash-header button{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.25);color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;transition:background .15s}.dash-header a.header-btn:hover,.dash-header button:hover{background:hsla(0,0%,100%,.2)}.dash-header .btn-primary{background:var(--accent)!important;border-color:var(--accent)!important;font-weight:700}.dash-header .btn-primary:hover{background:var(--accent-hover)!important}.dash-header .btn-danger{background:rgba(220,53,69,.15)!important;border-color:rgba(220,53,69,.4)!important}.dash-header .btn-danger:hover{background:rgba(220,53,69,.3)!important}.dash-content{padding:24px;max-width:1200px;margin:0 auto}.vehicle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));grid-gap:16px;gap:16px;margin-top:16px}.vehicle-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;transition:transform .15s,box-shadow .15s;text-decoration:none;color:inherit;display:block}.vehicle-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.12)}.vehicle-card h3{color:var(--primary);font-size:1.1rem;margin-bottom:4px}.vehicle-card .plate{display:inline-block;background:#f0f0f0;padding:2px 10px;border-radius:4px;font-size:.8rem;font-weight:600;margin-bottom:8px}.vehicle-card .meta{display:flex;gap:16px;font-size:.85rem;color:#666}.vehicle-card .meta span{display:flex;align-items:center;gap:4px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background:#28a745}.status-dot.offline{background:#dc3545}.status-dot.unknown{background:#ffc107}.detail-page{min-height:100vh;background:#f5f6fa}.detail-header{background:var(--primary);color:#fff;padding:12px 24px;display:flex;align-items:center;gap:16px}.detail-header a{color:#fff;text-decoration:none;font-size:1.2rem}.detail-header h1{font-size:1.2rem}.detail-header .plate-badge{background:hsla(0,0%,100%,.2);padding:2px 10px;border-radius:4px;font-size:.85rem}.detail-header .driver-badge{font-size:.8rem;opacity:.8}.copy-info-btn{position:absolute;top:8px;right:8px;width:30px;height:30px;border:1px solid hsla(0,0%,100%,.3);background:hsla(0,0%,100%,.1);border-radius:6px;cursor:pointer;color:#fff;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .15s}.copy-info-btn:hover{background:hsla(0,0%,100%,.25)}.copy-info-btn.header{position:static;margin-left:auto}.vehicle-card .copy-info-btn{position:absolute;top:8px;right:36px;color:#888;background:#f0f0f0;border-color:#ddd}.vehicle-card .copy-info-btn:hover{background:#e0e0e0}.share-link-btn{position:absolute;top:8px;right:72px;width:30px;height:30px;border:1px solid #ddd;background:#f0f0f0;border-radius:6px;cursor:pointer;color:#888;font-size:.95rem;display:flex;align-items:center;justify-content:center}.share-link-btn:hover{background:#e0e0e0}.edit-btn{position:absolute;top:8px;right:108px;width:30px;height:30px;border:1px solid #ddd;background:#f0f0f0;border-radius:6px;cursor:pointer;color:#888;font-size:.95rem;display:flex;align-items:center;justify-content:center}.edit-btn:hover{background:#e0e0e0;color:var(--primary)}.vehicle-type-badge{display:block;font-size:.75rem;color:var(--primary);font-weight:600;margin-bottom:2px}.driver-name{display:block;font-size:.8rem;color:#888;margin-bottom:6px}.driver-clickable:hover{color:var(--primary);text-decoration:underline}.detail-header .type-badge{font-size:.75rem;background:rgba(232,163,23,.25);padding:2px 8px;border-radius:4px;color:var(--accent);font-weight:600}.detail-body{display:flex;height:calc(100vh - 52px)}.detail-map{flex:1 1;min-height:400px}.detail-sidebar{width:360px;background:#fff;overflow-y:auto;padding:20px;box-shadow:-2px 0 8px rgba(0,0,0,.05)}.info-section{margin-bottom:20px}.info-section h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);margin-bottom:10px}.info-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.info-item .label{display:block;font-size:.7rem;text-transform:uppercase;color:#888;letter-spacing:.03em}.info-item .value{display:block;font-size:1rem;font-weight:600;color:#222}.time-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.time-filter{padding:5px 12px;border:1px solid #ddd;border-radius:20px;background:#fff;cursor:pointer;font-size:.8rem;transition:all .15s}.time-filter.active{background:var(--primary);color:#fff;border-color:var(--primary)}.route-expand-btn{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--primary);transition:all .2s;font-family:Montserrat,sans-serif}.route-expand-btn:hover{background:#eef2f7;border-color:var(--primary)}.route-expand-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.expand-arrow{font-size:.7rem;transition:transform .2s;display:inline-block}.expand-arrow.open{transform:rotate(90deg)}.driving-time-section .value.warning{color:#dc3545;font-weight:700}.driving-bar{height:8px;background:#e9ecef;border-radius:4px;margin-top:8px;overflow:hidden}.driving-bar-fill{height:100%;background:linear-gradient(90deg,#28a745,var(--accent),#dc3545);border-radius:4px;transition:width .5s}.driving-bar-label{font-size:.7rem;color:#999;margin-top:2px;display:block}.stops-section{margin-top:4px}.stops-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:rgba(232,163,23,.1);border:1px solid rgba(232,163,23,.25);border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:600;color:var(--accent);transition:background .15s}.stops-toggle:hover{background:rgba(232,163,23,.18)}.stops-toggle.active{background:rgba(232,163,23,.15)}.stops-list{margin-top:8px}.stop-entry{display:flex;align-items:flex-start;gap:8px;font-size:.83rem;padding:6px 0;color:#444;border-bottom:1px solid #f0f0f0}.stop-entry:last-child{border-bottom:none}.stop-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:4px}.stop-dot.start{background:#28a745}.stop-details{display:flex;flex-direction:column;gap:1px;min-width:0}.stop-time{font-weight:500}.stop-address{font-size:.75rem;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}.speed-legend{display:flex;gap:10px;flex-wrap:wrap;font-size:.8rem;color:#ccc}.speed-dot{display:inline-block;width:18px;height:4px;border-radius:2px;margin-right:4px;vertical-align:middle}.route-notice{font-style:italic;font-size:.8rem;color:#aaa;margin-top:12px}.info-footer{font-size:.75rem;color:#bbb;margin-top:8px}.loading-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff;gap:16px}.spinner{width:40px;height:40px;border:3px solid hsla(0,0%,100%,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.add-btn{background:var(--accent)!important;border-color:var(--accent)!important;font-weight:700}.add-btn:hover{background:var(--accent-hover)!important}.vehicle-card-link{text-decoration:none;color:inherit;display:block}.delete-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#f0f0f0;border:none;cursor:pointer;font-size:1.1rem;color:#999;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s;opacity:0}.vehicle-card:hover .delete-btn{opacity:1}.delete-btn:hover{background:#dc3545;color:#fff}.delete-confirm{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;background:#fff;padding:6px 10px;border-radius:6px;box-shadow:0 2px 12px rgba(0,0,0,.2);font-size:.8rem}.admin-pw-input{width:120px;padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:.8rem;outline:none}.admin-pw-input:focus{border-color:var(--primary)}.delete-error{color:#dc3545;font-size:.75rem;width:100%}.confirm-yes{background:#dc3545;color:#fff}.confirm-no,.confirm-yes{border:none;padding:3px 10px;border-radius:4px;cursor:pointer;font-size:.8rem}.confirm-no{background:#e0e0e0}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-card{background:#fff;border-radius:16px;padding:32px;max-width:480px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3);max-height:90vh;overflow-y:auto}.modal-card h2{color:var(--primary);font-size:1.3rem;margin-bottom:20px}.form-row{margin-bottom:14px}.form-row label{display:block;font-weight:600;margin-bottom:4px;font-size:.85rem;color:#444}.form-row input,.form-row select{width:100%;padding:10px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s}.form-row input:focus,.form-row select:focus{border-color:var(--primary)}.provider-fields{border-top:1px solid #eee;padding-top:14px;margin-top:14px}.modal-error{color:#dc3545;font-size:.85rem;margin:8px 0}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.btn-cancel{padding:10px 20px;background:#e0e0e0;border:none;border-radius:8px;cursor:pointer;font-size:.9rem}.btn-cancel:hover{background:#d0d0d0}.btn-save{padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:700}.btn-save:hover{background:var(--accent-hover)}.btn-save:disabled{opacity:.6;cursor:not-allowed}.abrechnung-page{min-height:100vh;background:#f0f2f5}.abrechnung-content{padding:24px;max-width:1200px;margin:0 auto}.date-range-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,.08);margin-bottom:24px}.date-range-picker{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.date-range-picker.compact{gap:8px}.date-field{display:flex;flex-direction:column;gap:4px}.date-field label{font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase}.date-field input[type=date]{padding:8px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;outline:none;transition:border-color .2s}.date-field input[type=date]:focus{border-color:var(--primary)}.btn-calculate{padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:700;font-size:.9rem;white-space:nowrap}.btn-calculate.compact{padding:6px 14px;font-size:.8rem}.btn-calculate:hover{background:var(--accent-hover)}.btn-calculate:disabled{opacity:.6;cursor:not-allowed}.settings-summary{font-size:.8rem;color:#888;margin-top:10px}.billing-cards{display:flex;flex-direction:column;gap:16px}.billing-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.08)}.billing-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:var(--primary);color:#fff}.billing-vehicle-name{color:#fff;text-decoration:none;font-weight:700;font-size:1.05rem}.billing-vehicle-name:hover{text-decoration:underline}.billing-plate{margin-left:8px;font-size:.8rem;opacity:.8}.billing-km{font-size:1.1rem;font-weight:700}.billing-rows{padding:12px 20px}.billing-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid #f0f0f0;flex-wrap:wrap}.billing-row:last-of-type{border-bottom:none}.billing-row.manual{padding:6px 0}.billing-label{flex:1 1;font-weight:600;font-size:.9rem;color:#333;min-width:100px}.billing-input-group{display:flex;align-items:center;gap:4px}.billing-input-group input[type=number]{width:80px;padding:5px 8px;border:2px solid #e0e0e0;border-radius:6px;font-size:.85rem;text-align:right;outline:none}.billing-input-group input[type=number]:focus{border-color:var(--primary)}.billing-unit{font-size:.75rem;color:#888;white-space:nowrap}.billing-cost{font-weight:600;font-size:.95rem;min-width:90px;text-align:right;color:var(--primary)}.manual-name{width:100%;padding:5px 8px;border:1px solid transparent;border-bottom:1px dashed #ccc;border-radius:0;font-size:.9rem;outline:none;background:none;font-weight:600;color:#333}.manual-name:focus{border-bottom-color:var(--primary);border-bottom-style:solid}.manual-name::placeholder{color:#bbb;font-weight:400}.qty-input{width:45px!important}.add-manual-btn{display:block;width:100%;padding:6px;margin-top:4px;border:2px dashed #ddd;border-radius:6px;background:none;cursor:pointer;color:#888;font-size:.8rem}.add-manual-btn:hover{border-color:var(--accent);color:var(--accent)}.billing-card-total{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#f0f2f5;border-top:2px solid var(--primary);font-weight:700;font-size:1rem}.billing-grand{color:var(--primary);font-size:1.15rem;font-weight:700}.billing-summary-card{background:var(--primary);color:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 2px 8px rgba(0,0,0,.15)}.billing-summary-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.95rem}.billing-summary-row.total{border-top:2px solid hsla(0,0%,100%,.3);padding-top:12px;margin-top:6px;font-size:1.15rem}.billing-summary-card .billing-grand{color:var(--accent)}.field-remove-btn.small{width:22px;height:22px;font-size:.9rem}.billing-empty{text-align:center;padding:60px 20px;color:#888;background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.08)}.custom-field-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.custom-field-row input,.custom-field-row select{padding:8px 10px;border:2px solid #e0e0e0;border-radius:6px;font-size:.85rem;outline:none}.custom-field-row input[type=text]{flex:2 1}.custom-field-row input[type=number]{flex:1 1;width:80px}.custom-field-row select{flex:1 1}.field-remove-btn{width:28px;height:28px;border-radius:50%;border:none;background:#f0f0f0;cursor:pointer;font-size:1.1rem;color:#999;display:flex;align-items:center;justify-content:center;flex-shrink:0}.field-remove-btn:hover{background:#dc3545;color:#fff}.add-field-btn{display:block;width:100%;padding:8px;border:2px dashed #ddd;border-radius:8px;background:none;cursor:pointer;color:#888;font-size:.85rem;margin-top:4px}.add-field-btn:hover{border-color:var(--accent);color:var(--accent)}.billing-section .date-range-picker{margin-bottom:12px}.billing-details{margin-top:8px}.billing-total{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:2px solid var(--primary);font-weight:700;font-size:1.1rem;color:#fff}.total-value{color:var(--accent);font-size:1.2rem}@media (max-width:768px){.detail-body{flex-direction:column;height:auto}.detail-map{height:50vh}.detail-sidebar{width:100%}.vehicle-grid{grid-template-columns:1fr}.modal-card{padding:24px}.date-range-picker{flex-direction:column}.billing-table{font-size:.8rem}.billing-table td,.billing-table th{padding:8px 10px}}