*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cyan: #00AEEF;--cyan-dark: #0094cf;--cyan-light: #e6f7fd;--slate: #2C3E50;--slate-light: #4a6278;--bg: #f5f4f0;--card: #ffffff;--border: #e8e6de;--border-strong: #c8c6be;--text: #1a2b3c;--text-muted: #888;--text-light: #aaa;--green: #22c55e;--green-bg: #dcfce7;--green-text: #15803d;--amber: #f59e0b;--amber-bg: #fffbeb;--amber-text: #92400e;--red: #ef4444;--red-bg: #fef2f2;--red-text: #991b1b;--blue-bg: #dbeafe;--blue-text: #1d4ed8;--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 4px rgba(0,0,0,.08);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px)}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#app{height:100%;display:flex;flex-direction:column;background:var(--bg)}.app-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:480px;margin:0 auto;position:relative;background:var(--bg)}.screen{flex:1;overflow-y:auto;padding-bottom:calc(64px + var(--safe-bottom))}.screen-full{flex:1;overflow-y:auto}.page-header{background:var(--cyan);color:#fff;padding:calc(12px + var(--safe-top)) 16px 14px;position:sticky;top:0;z-index:10}.page-header h1{font-size:20px;font-weight:600}.page-header .subtitle{font-size:12px;opacity:.75;margin-top:2px}.page-header .meta{font-size:10px;opacity:.65;letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}.header-row{display:flex;justify-content:space-between;align-items:center}.back-btn{background:transparent;border:none;color:#fff;cursor:pointer;padding:0;display:flex;align-items:center;gap:4px;font-size:13px;font-family:inherit}.avatar{width:38px;height:38px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.header-chips{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.chip{background:#ffffff2e;font-size:11px;padding:3px 10px;border-radius:10px}.bottom-nav{background:var(--card);border-top:.5px solid var(--border);display:flex;padding-bottom:var(--safe-bottom);position:sticky;bottom:0}.nav-item{flex:1;padding:10px 4px 12px;text-align:center;cursor:pointer;border:none;background:transparent;font-family:inherit}.nav-item svg,.nav-item .nav-icon{display:block;margin:0 auto 3px;width:22px;height:22px;color:var(--text-light)}.nav-item.active svg,.nav-item.active .nav-icon{color:var(--cyan)}.nav-item span{font-size:10px;color:var(--text-light);display:block}.nav-item.active span{color:var(--cyan)}.card{background:var(--card);border-radius:var(--radius-lg);border:.5px solid var(--border);padding:12px 14px}.card+.card{margin-top:8px}.cards-list{padding:10px 12px 16px;display:flex;flex-direction:column;gap:8px}.section-label{font-size:11px;color:var(--text-muted);font-weight:500;padding:8px 12px 4px}.loc-card{background:var(--card);border-radius:var(--radius-lg);border:.5px solid var(--border);padding:12px 14px;cursor:pointer;transition:border-color .15s}.loc-card:hover{border-color:var(--border-strong)}.loc-card-header{display:flex;justify-content:space-between;align-items:flex-start}.loc-name{font-size:13px;font-weight:600;color:var(--text)}.loc-sub{font-size:11px;color:var(--text-muted);margin-top:2px}.progress-bar{background:var(--border);border-radius:3px;height:3px;margin-top:8px}.progress-fill{background:var(--cyan);border-radius:3px;height:3px;transition:width .3s}.loc-footer{display:flex;justify-content:space-between;margin-top:5px}.badge{display:inline-flex;align-items:center;gap:2px;font-size:10px;padding:2px 7px;border-radius:8px;font-weight:500;white-space:nowrap}.badge-blue{background:var(--blue-bg);color:var(--blue-text)}.badge-green{background:var(--green-bg);color:var(--green-text)}.badge-amber{background:var(--amber-bg);color:var(--amber-text)}.badge-red{background:var(--red-bg);color:var(--red-text)}.badge-gray{background:#f0ede6;color:var(--text-muted)}.badge-link{background:transparent;color:var(--cyan);font-weight:600;font-size:11px}.task-row{padding:10px 0;border-bottom:.5px solid var(--border);display:flex;align-items:center;gap:10px}.task-row:last-child{border-bottom:none;padding-bottom:0}.task-row.clickable{cursor:pointer}.task-row.clickable:hover{background:#fafaf8;margin:0 -14px;padding:10px 14px;border-radius:6px}.check-circle{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border-strong);background:transparent;flex-shrink:0;display:flex;align-items:center;justify-content:center}.check-circle.done{background:var(--green);border-color:var(--green)}.check-circle.melding{background:var(--amber);border-color:var(--amber)}.check-circle.verhinderd{background:var(--red);border-color:var(--red)}.task-name{font-size:13px;color:var(--text);font-weight:500}.task-meta{display:flex;gap:4px;margin-top:3px}.gps-ok{background:var(--green-bg);border:.5px solid #bbf7d0;color:var(--green-text);border-radius:var(--radius);padding:10px 12px;display:flex;align-items:center;gap:8px;margin-bottom:10px}.gps-fail{background:var(--red-bg);border:.5px solid #fca5a5;color:var(--red-text);border-radius:var(--radius);padding:10px 12px;display:flex;align-items:center;gap:8px;margin-bottom:10px}.gps-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gps-ok .gps-icon{background:var(--green-bg)}.gps-fail .gps-icon{background:var(--red-bg)}.signoff-opt{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);border:1.5px solid var(--border);margin-bottom:8px;cursor:pointer;background:#fff;transition:all .15s}.signoff-opt.selected-uitvoerd{border-color:var(--green);background:var(--green-bg)}.signoff-opt.selected-melding{border-color:var(--amber);background:var(--amber-bg)}.signoff-opt.selected-verhinderd{border-color:var(--red);background:var(--red-bg)}.opt-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#f0ede6;transition:background .15s}.btn{border:none;border-radius:var(--radius);padding:12px 20px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;width:100%;transition:opacity .15s}.btn-primary{background:var(--cyan);color:#fff}.btn-primary:active{opacity:.85}.btn-primary:disabled{background:var(--border-strong);color:#fff;cursor:not-allowed}.btn-danger{background:var(--red);color:#fff}.btn-secondary{background:#fff;border:.5px solid var(--border);color:var(--text)}.btn-ghost{background:transparent;color:var(--cyan);border:.5px solid var(--cyan)}.btn-nav{background:var(--card);border:.5px solid var(--border);border-radius:var(--radius);padding:8px 12px;font-size:12px;color:var(--cyan);font-weight:500;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:6px;width:100%}.form-group{margin-bottom:14px}.form-label{font-size:12px;color:var(--text-muted);font-weight:500;margin-bottom:5px;display:block}.form-input,.form-select,.form-textarea{width:100%;border:.5px solid var(--border);border-radius:var(--radius);padding:10px 12px;font-size:14px;color:var(--text);background:#fafaf8;font-family:inherit;outline:none;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--cyan);background:#fff}.form-textarea{resize:none;height:72px}.photo-zone{border:1.5px dashed var(--border-strong);border-radius:var(--radius);padding:16px;text-align:center;cursor:pointer;transition:border-color .15s}.photo-zone:hover{border-color:var(--cyan)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:8px 12px;font-size:11px;color:var(--text-muted);font-weight:500;border-bottom:.5px solid var(--border);background:#fafaf8}.data-table td{padding:10px 12px;border-bottom:.5px solid var(--border);color:var(--text)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#fafaf8}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{background:#fff;border:.5px solid var(--border);border-radius:var(--radius);padding:12px}.stat-label{font-size:11px;color:var(--text-muted);margin-bottom:4px}.stat-value{font-size:24px;font-weight:600;color:var(--text)}.stat-value.cyan{color:var(--cyan)}.stat-value.green{color:var(--green)}.stat-value.amber{color:var(--amber)}.stat-value.red{color:var(--red)}.empty{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-icon{font-size:48px;margin-bottom:12px;opacity:.3}.empty h3{font-size:15px;font-weight:500;color:var(--text);margin-bottom:6px}.empty p{font-size:13px;line-height:1.5}.loading{display:flex;align-items:center;justify-content:center;padding:32px;gap:8px;color:var(--text-muted);font-size:13px}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{border-radius:var(--radius);padding:10px 12px;font-size:13px;margin-bottom:12px;display:flex;align-items:flex-start;gap:8px}.alert-error{background:var(--red-bg);color:var(--red-text);border:.5px solid #fca5a5}.alert-success{background:var(--green-bg);color:var(--green-text);border:.5px solid #bbf7d0}.alert-info{background:var(--blue-bg);color:var(--blue-text);border:.5px solid #93c5fd}.ticket-card{background:var(--card);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:12px 14px;cursor:pointer}.ticket-card:hover{border-color:var(--border-strong)}.priority-urgent{border-left:3px solid var(--red)}.priority-hoog{border-left:3px solid var(--amber)}.login-screen{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:#fff}.login-logo{width:64px;height:64px;background:var(--cyan);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.login-logo svg{width:36px;height:36px;color:#fff}.flex-between{display:flex;justify-content:space-between;align-items:center}.text-cyan{color:var(--cyan)}.text-muted{color:var(--text-muted);font-size:12px}.text-small{font-size:11px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.fw-500{font-weight:500}.w-full{width:100%}.gap-4{gap:4px}.flex{display:flex}.items-center{align-items:center}
