        /* ═══════════════════════════════════════════
           CT DELIVERY — DARK PRECISION
           Premium driver mission control
           ═══════════════════════════════════════════ */

        * { touch-action: manipulation; }

        :root {
            --font: 'Outfit', -apple-system, sans-serif;
            --black: #0C1018;
            --dark-1: #111722;
            --dark-2: #171E2A;
            --dark-3: #1E2636;
            --dark-4: #2A3345;
            --white: #F0F2F5;
            --gray-1: #F2F3F5;
            --gray-2: #E0E2E7;
            --gray-3: #A0A8B8;
            --gray-4: #6B7588;
            --accent: #5BA8E6;
            --accent-glow: rgba(91, 168, 230, 0.20);
            --accent-dim: rgba(91, 168, 230, 0.08);
            --green: #34D399;
            --green-bright: #5EEAD4;
            --green-glow: rgba(52, 211, 153, 0.25);
            --red: #F43F5E;
            --yellow: #FBBF24;
            --blue: #3B82F6;
            --purple: #A855F7;

            /* light theme */
            --bg: var(--gray-1);
            --surface: #fff;
            --surface-2: #F7F8FA;
            --surface-glass: rgba(255,255,255,0.72);
            --text: #0C1018;
            --text-2: #4A5568;
            --text-3: #94A3B8;
            --border: rgba(0,0,0,0.08);
            --border-subtle: rgba(0,0,0,0.04);
            --nav-bg: rgba(255,255,255,0.82);
            --nav-border: rgba(0,0,0,0.06);
            --header-bg: var(--black);
            --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
            --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
            --shadow-lg: 0 8px 32px rgba(0,0,0,0.12);
            --glass-blur: blur(20px);
        }

        html.dark {
            --bg: var(--black);
            --surface: rgba(23, 30, 42, 0.80);
            --surface-2: rgba(30, 38, 54, 0.70);
            --surface-glass: rgba(17, 23, 34, 0.75);
            --text: var(--white);
            --text-2: #94A3B8;
            --text-3: #4A5568;
            --border: rgba(255,255,255,0.06);
            --border-subtle: rgba(255,255,255,0.03);
            --nav-bg: rgba(17, 23, 34, 0.85);
            --nav-border: rgba(255,255,255,0.06);
            --shadow-sm: 0 1px 3px rgba(0,0,0,0.2);
            --shadow-md: 0 4px 16px rgba(0,0,0,0.3);
            --shadow-lg: 0 8px 32px rgba(0,0,0,0.4);
        }

        * {
            margin: 0; padding: 0; box-sizing: border-box;
            -webkit-tap-highlight-color: transparent;
        }

        html {
            font-family: var(--font);
            background: var(--bg);
            color: var(--text);
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            overflow-x: hidden;
        }

        .hero, .action-panel, .dlv-form, .hero-go, .hero-done, .up-next-line,
        .ls, .code-card, .sms-card, .rapport-summary, .rapport-actions { max-width: 100%; box-sizing: border-box; }

        body {
            min-height: 100vh;
            min-height: 100dvh;
            overflow-x: hidden;
            transition: background 0.3s ease, color 0.3s ease;
            width: 100%;
            max-width: 100vw;
        }

        /* ═══════ FLOATING PILL HEADER ═══════ */
        .hdr {
            position: fixed;
            top: 10px;
            left: 50%;
            transform: translateX(-50%);
            z-index: 100;
            width: calc(100% - 24px);
            max-width: 500px;
            background: rgba(12, 16, 24, 0.85);
            backdrop-filter: blur(24px);
            -webkit-backdrop-filter: blur(24px);
            color: #fff;
            padding: 8px 12px;
            border-radius: 50px;
            border: 1px solid rgba(255,255,255,0.08);
            box-shadow: 0 4px 24px rgba(0,0,0,0.3);
        }
        html:not(.dark) .hdr {
            background: rgba(255,255,255,0.85);
            color: var(--black);
            border-color: rgba(0,0,0,0.06);
            box-shadow: 0 4px 24px rgba(0,0,0,0.08);
        }
        .hdr-row {
            display: flex;
            align-items: center;
            gap: 8px;
        }
        .hdr-back {
            width: 32px; height: 32px;
            border-radius: 50%;
            background: rgba(255,255,255,0.1);
            border: none;
            color: inherit;
            font-size: 1.1rem;
            cursor: pointer;
            display: none;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            transition: background 0.15s;
        }
        html:not(.dark) .hdr-back { background: rgba(0,0,0,0.06); }
        .hdr-back:active { background: rgba(255,255,255,0.2); }

        /* CT logo circle — integrated center */
        .hdr-brand {
            width: 42px; height: 42px;
            border-radius: 50%;
            background: var(--accent);
            color: #fff;
            font-family: 'Syne', sans-serif;
            font-size: 0.95rem;
            font-weight: 800;
            letter-spacing: -0.5px;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            box-shadow: 0 2px 10px var(--accent-glow);
        }

        .hdr-info {
            flex: 1;
            min-width: 0;
            text-align: center;
        }
        .hdr-title {
            font-size: 0.88rem;
            font-weight: 700;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            opacity: 0.7;
        }

        .hdr-right {
            display: flex;
            align-items: center;
            gap: 6px;
            flex-shrink: 0;
        }
        .hdr-prog-text {
            font-size: 0.82rem;
            font-weight: 800;
            color: var(--accent);
            font-variant-numeric: tabular-nums;
            display: none;
        }
        .hdr-dark {
            width: 32px; height: 32px;
            border-radius: 50%;
            background: rgba(255,255,255,0.06);
            border: none;
            color: inherit;
            opacity: 0.5;
            font-size: 0.85rem;
            cursor: pointer;
            display: flex; align-items: center; justify-content: center;
            flex-shrink: 0;
            transition: opacity 0.15s;
        }
        html:not(.dark) .hdr-dark { background: rgba(0,0,0,0.04); }
        .hdr-dark:active { opacity: 1; }

        /* Progress (hidden — wizard dots in card) */
        .hdr-progress { display: none !important; }

        /* ═══════ FIXED BOTTOM NAV — Glass ═══════ */
        .nav {
            position: fixed;
            bottom: 0; left: 0; right: 0;
            z-index: 100;
            background: var(--nav-bg);
            backdrop-filter: var(--glass-blur);
            -webkit-backdrop-filter: var(--glass-blur);
            border-top: 1px solid var(--nav-border);
            display: none; /* hidden on hub */
            height: 62px;
            padding-bottom: env(safe-area-inset-bottom);
            transition: background 0.3s ease;
        }
        .nav-inner {
            display: flex;
            height: 100%;
            max-width: 500px;
            margin: 0 auto;
        }
        .nav-tab {
            flex: 1;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 3px;
            background: none;
            border: none;
            color: var(--text-3);
            font: inherit;
            font-size: 0.6rem;
            font-weight: 600;
            cursor: pointer;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            transition: color 0.2s;
            position: relative;
        }
        .nav-tab.on { color: var(--accent); }
        .nav-tab.on::after {
            content: '';
            position: absolute;
            top: 0;
            left: 25%; right: 25%;
            height: 2px;
            background: var(--accent);
            border-radius: 0 0 4px 4px;
            box-shadow: 0 2px 8px var(--accent-glow);
        }
        .nav-tab:active { opacity: 0.5; }
        .nav-ico { font-size: 1rem; line-height: 1; }

        /* ═══════ CONTENT AREA ═══════ */
        .content {
            padding-top: 72px; /* floating pill */
            overflow-x: hidden;
            padding-bottom: 10px;
            min-height: 100vh;
            min-height: 100dvh;
        }
        .content.has-nav {
            padding-bottom: 72px; /* nav */
        }

        /* Views */
        .screen { display: none; width: 100%; }
        .screen.on { display: flex; flex-direction: column; min-height: calc(100vh - 62px); min-height: calc(100dvh - 62px); width: 100%; }
        .content.has-nav .screen.on { min-height: calc(100vh - 56px - 62px); min-height: calc(100dvh - 56px - 62px); }

        /* ═══════ SCREEN: PROFILE PICKER (Netflix-style) ═══════ */
        .picker {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            min-height: calc(100vh - 72px);
            min-height: calc(100dvh - 72px);
            padding: 20px;
        }
        .picker-title {
            font-size: 1.4rem;
            font-weight: 800;
            margin-bottom: 8px;
            letter-spacing: -0.5px;
        }
        .picker-sub {
            font-size: 0.85rem;
            color: var(--text-3);
            margin-bottom: 40px;
        }
        .picker-grid {
            display: flex;
            flex-wrap: wrap;
            justify-content: center;
            gap: 24px;
            max-width: 400px;
        }
        .picker-profile {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 10px;
            cursor: pointer;
            transition: transform 0.2s;
            background: none;
            border: none;
            color: inherit;
            font: inherit;
            padding: 0;
        }
        .picker-profile:active { transform: scale(0.92); }
        .picker-profile:hover .picker-avatar {
            box-shadow: 0 0 0 3px var(--accent), 0 8px 24px rgba(0,0,0,0.3);
        }
        .picker-avatar {
            width: 80px;
            height: 80px;
            border-radius: 20px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.8rem;
            font-weight: 900;
            color: #fff;
            transition: box-shadow 0.25s, transform 0.25s;
            box-shadow: 0 4px 16px rgba(0,0,0,0.2);
        }
        .picker-profile:hover .picker-avatar {
            transform: scale(1.08);
        }
        .picker-name {
            font-size: 0.9rem;
            font-weight: 700;
            color: var(--text-2);
        }
        .picker-route {
            font-size: 0.7rem;
            font-weight: 600;
            color: var(--text-3);
            margin-top: -6px;
        }
        .picker-plate {
            font-size: 0.65rem;
            font-weight: 800;
            letter-spacing: 1.5px;
            color: var(--accent);
            background: var(--accent-dim);
            padding: 3px 10px;
            border-radius: 6px;
            margin-top: 2px;
        }

        /* ═══════ SCREEN: HUB ═══════ */
        .hub { padding: 24px 16px; max-width: 500px; margin: 0 auto; }
        .hub-hello {
            font-size: 2rem;
            font-weight: 900;
            letter-spacing: -1.5px;
            margin-bottom: 2px;
            line-height: 1.1;
        }
        .hub-sub {
            color: var(--text-3);
            font-size: 0.85rem;
            font-weight: 500;
            letter-spacing: 0.3px;
            margin-bottom: 32px;
        }

        .hub-card {
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            -webkit-backdrop-filter: var(--glass-blur);
            border: 1px solid var(--border);
            border-radius: 20px;
            padding: 24px 22px;
            margin-bottom: 16px;
            cursor: pointer;
            transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.2s, border-color 0.2s;
            position: relative;
            overflow: hidden;
            box-shadow: var(--shadow-sm);
        }
        .hub-card:active { transform: scale(0.975); }
        .hub-card:hover { border-color: rgba(91,168,230,0.3); box-shadow: var(--shadow-md); }
        .hub-card-accent {
            position: absolute;
            top: 0; left: 0; bottom: 0;
            width: 4px;
            border-radius: 0 2px 2px 0;
        }
        .hub-card-top {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 6px;
        }
        .hub-card-name {
            font-size: 1.25rem;
            font-weight: 800;
            letter-spacing: -0.5px;
        }
        .hub-card-count {
            background: var(--accent-dim);
            color: var(--accent);
            padding: 5px 12px;
            border-radius: 10px;
            font-weight: 700;
            font-size: 0.8rem;
            letter-spacing: 0.3px;
        }
        .hub-card-desc {
            color: var(--text-2);
            font-size: 0.85rem;
            margin-bottom: 18px;
            line-height: 1.4;
        }
        .hub-card-bar {
            height: 6px;
            background: var(--border);
            border-radius: 3px;
            overflow: hidden;
        }
        .hub-card-fill {
            height: 100%;
            background: linear-gradient(90deg, var(--green), var(--green-bright));
            border-radius: 3px;
            transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
        }
        .hub-card-stats {
            display: flex;
            justify-content: space-between;
            margin-top: 10px;
            font-size: 0.78rem;
            font-weight: 600;
            color: var(--text-3);
            font-variant-numeric: tabular-nums;
        }

        .hub-card-arrow {
            position: absolute;
            right: 20px;
            top: 50%;
            transform: translateY(-50%);
            font-size: 1.4rem;
            color: var(--text-3);
            opacity: 0.3;
        }

        /* ═══════ SCREEN: NEXT STOP — Mission Control ═══════ */
        .next {
            padding: 10px 14px;
            max-width: 500px;
            margin: 0 auto;
            display: flex;
            flex-direction: column;
            flex: 1;
            justify-content: center;
            width: 100%;
            box-sizing: border-box;
        }
        @media (max-width: 600px) {
            .next, .list, .codes, .depot, .rapport, .picker {
                max-width: 100%;
                padding-left: 12px;
                padding-right: 12px;
            }
            .next {
                justify-content: flex-start;
            }
        }

        /* Hero = top zone (client + address + nav) */
        .hero {
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            -webkit-backdrop-filter: var(--glass-blur);
            border: 1px solid var(--border);
            border-radius: 20px;
            overflow: hidden;
            flex-shrink: 0;
            box-shadow: var(--shadow-md);
        }
        .hero.prio {
            border-color: rgba(244, 63, 94, 0.4);
            border-width: 1px;
            box-shadow: var(--shadow-md), 0 0 0 1px rgba(244, 63, 94, 0.15), inset 0 0 40px rgba(244, 63, 94, 0.03);
        }
        .hero.fuel {
            border-color: rgba(251, 191, 36, 0.4);
            border-width: 1px;
            box-shadow: var(--shadow-md), 0 0 0 1px rgba(251, 191, 36, 0.15), inset 0 0 40px rgba(251, 191, 36, 0.03);
        }

        .hero-top { padding: 18px 18px 14px; }

        .hero-step {
            display: flex;
            align-items: center;
            gap: 12px;
            margin-bottom: 14px;
            padding-bottom: 14px;
            border-bottom: 1px solid var(--border);
        }
        .hero-num {
            background: linear-gradient(135deg, var(--accent), #4A9AE0);
            color: #fff;
            width: 44px; height: 44px;
            border-radius: 12px;
            display: flex; align-items: center; justify-content: center;
            font-weight: 900;
            font-size: 1.1rem;
            flex-shrink: 0;
            box-shadow: 0 2px 12px var(--accent-glow);
        }
        .hero-step-info { display: flex; flex-direction: column; }
        .hero-label {
            font-size: 0.68rem;
            font-weight: 600;
            color: var(--text-3);
            text-transform: uppercase;
            letter-spacing: 1.5px;
        }
        .hero-step-progress {
            display: flex;
            gap: 3px;
            margin-top: 6px;
        }
        .hero-step-dot {
            width: 16px;
            height: 4px;
            border-radius: 2px;
            background: var(--border);
        }
        .hero-step-dot.done { background: var(--green); }
        .hero-step-dot.current { background: var(--accent); }

        .hero-code {
            display: inline-block;
            background: var(--accent-dim);
            color: var(--accent);
            padding: 3px 9px;
            border-radius: 6px;
            font-size: 0.7rem;
            font-weight: 700;
            letter-spacing: 0.5px;
            margin-right: 8px;
            border: 1px solid rgba(91, 168, 230, 0.15);
        }
        html.dark .hero-code {
            background: rgba(91, 168, 230, 0.1);
            border-color: rgba(91, 168, 230, 0.2);
        }

        .hero-client {
            font-size: 1.45rem;
            font-weight: 900;
            letter-spacing: -0.5px;
            margin-bottom: 4px;
            line-height: 1.2;
        }

        .hero-badges {
            display: inline-flex;
            gap: 6px;
            flex-wrap: wrap;
            margin-bottom: 6px;
        }
        .hb-prio {
            background: linear-gradient(135deg, var(--red), #E11D48);
            color: #fff;
            padding: 3px 10px;
            border-radius: 6px;
            font-size: 0.65rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            box-shadow: 0 2px 8px rgba(244, 63, 94, 0.25);
        }
        .hb-tag {
            background: rgba(168,85,247,0.1);
            color: var(--purple);
            padding: 3px 10px;
            border-radius: 6px;
            font-size: 0.65rem;
            font-weight: 700;
            border: 1px solid rgba(168,85,247,0.15);
        }
        html.dark .hb-tag { color: #C084FC; border-color: rgba(192,132,252,0.2); }

        .hero-addr {
            font-size: 0.88rem;
            color: var(--text-2);
            margin-bottom: 8px;
            line-height: 1.35;
        }

        /* Collapsible notes */
        .hero-notes-toggle {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            background: var(--surface-2);
            border: 1px solid var(--border);
            color: var(--text-3);
            padding: 6px 12px;
            border-radius: 10px;
            font: inherit;
            font-size: 0.73rem;
            font-weight: 600;
            cursor: pointer;
            margin-bottom: 4px;
            transition: color 0.2s, border-color 0.2s, background 0.2s;
        }
        .hero-notes-toggle:active { color: var(--accent); border-color: rgba(91,168,230,0.3); background: var(--accent-dim); }
        .hero-notes-body { display: none; margin-top: 8px; }
        .hero-notes-body.open { display: block; }

        /* Alerts */
        .hero-alerts {
            display: flex; gap: 6px; flex-wrap: wrap;
            margin-bottom: 10px;
        }
        .ha {
            padding: 7px 14px;
            border-radius: 10px;
            font-size: 0.78rem;
            font-weight: 700;
            color: #fff;
            letter-spacing: 0.2px;
        }
        .ha.red { background: linear-gradient(135deg, var(--red), #E11D48); box-shadow: 0 2px 8px rgba(244,63,94,0.2); }
        .ha.blue { background: linear-gradient(135deg, var(--blue), #2563EB); box-shadow: 0 2px 8px rgba(59,130,246,0.2); }

        /* Notes */
        .hero-notes {
            display: flex;
            flex-direction: column;
            gap: 6px;
            margin-bottom: 10px;
        }
        .hn {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 12px 14px;
            border-radius: 12px;
            font-size: 0.88rem;
            font-weight: 600;
            border: 1px solid transparent;
            transition: background 0.2s;
        }
        .hn-ico { font-size: 1.1rem; flex-shrink: 0; }
        .hn.danger  { background: rgba(244,63,94,0.06); color: var(--red); border-color: rgba(244,63,94,0.1); }
        .hn.warning { background: rgba(251,191,36,0.06); color: #B8860B; border-color: rgba(251,191,36,0.1); }
        .hn.info    { background: rgba(59,130,246,0.06); color: var(--blue); border-color: rgba(59,130,246,0.1); }
        .hn.success { background: rgba(52,211,153,0.06); color: var(--green); border-color: rgba(52,211,153,0.1); }
        .hn.lock    { background: rgba(168,85,247,0.06); color: var(--purple); border-color: rgba(168,85,247,0.1); }
        html.dark .hn.warning { color: var(--yellow); border-color: rgba(251,191,36,0.15); }
        html.dark .hn.danger { color: #FB7185; border-color: rgba(244,63,94,0.15); }
        html.dark .hn.info { color: #60A5FA; border-color: rgba(59,130,246,0.15); }
        html.dark .hn.success { color: var(--green-bright); border-color: rgba(52,211,153,0.15); }
        html.dark .hn.lock { color: #C084FC; border-color: rgba(168,85,247,0.15); }

        /* Photo btn */
        .hero-photo {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: var(--surface-2);
            border: 1px dashed var(--border);
            color: var(--text-2);
            padding: 10px 16px;
            border-radius: 12px;
            font: inherit;
            font-size: 0.83rem;
            font-weight: 600;
            cursor: pointer;
            margin-bottom: 4px;
            transition: border-color 0.2s, color 0.2s, background 0.2s;
        }
        .hero-photo:active { border-color: rgba(91,168,230,0.4); color: var(--accent); background: var(--accent-dim); }

        /* ★ THE GREEN NAVIGATE BAR — Premium Waze ★ */
        .hero-go {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 10px;
            width: 100%;
            background: linear-gradient(135deg, var(--green), #2DD4BF);
            color: #0C1018;
            border: none;
            padding: 20px;
            border-radius: 0 0 20px 20px;
            font: inherit;
            font-weight: 900;
            font-size: 1.15rem;
            cursor: pointer;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            transition: transform 0.15s, box-shadow 0.2s, filter 0.2s;
            box-shadow: 0 -1px 0 rgba(52,211,153,0.2) inset, 0 4px 24px var(--green-glow);
        }
        .hero-go:active { filter: brightness(1.1); transform: scale(0.98); }
        .hero-go svg { width: 22px; height: 22px; }

        /* ★ DONE BUTTON — Big green confirm ★ */
        .hero-done {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            width: 100%;
            background: linear-gradient(135deg, var(--green), #2DD4BF);
            border: none;
            color: #0C1018;
            padding: 18px;
            border-radius: 16px;
            font: inherit;
            font-weight: 900;
            font-size: 1.05rem;
            cursor: pointer;
            transition: all 0.2s ease;
            box-shadow: 0 4px 16px var(--green-glow);
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        .hero-done:active { filter: brightness(1.15); transform: scale(0.97); }

        /* Completed state */
        .hero-done.checked {
            background: linear-gradient(135deg, var(--green), #2DD4BF);
            border-color: transparent;
            color: #0C1018;
            box-shadow: 0 4px 16px var(--green-glow);
        }

        /* ═══════ SCREEN: DEPOT (pre-departure) ═══════ */
        .depot { padding: 16px 14px; max-width: 500px; margin: 0 auto; }

        .depot-card {
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            border: 1px solid rgba(91,168,230,0.2);
            border-radius: 20px;
            padding: 22px 18px;
            margin-bottom: 14px;
            box-shadow: var(--shadow-sm);
        }
        .depot-icon { font-size: 2.5rem; margin-bottom: 10px; }
        .depot-title { font-size: 1.3rem; font-weight: 900; margin-bottom: 4px; letter-spacing: -0.3px; }
        .depot-sub { font-size: 0.83rem; color: var(--text-3); margin-bottom: 18px; line-height: 1.4; }

        .depot-total {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            padding: 14px;
            background: var(--surface-2);
            border-radius: 12px;
            margin-top: 14px;
            font-weight: 700;
            font-size: 0.95rem;
            border: 1px solid var(--border);
        }
        .depot-total-val { color: var(--accent); font-size: 1.4rem; font-weight: 900; }

        .depot-go {
            width: 100%;
            padding: 18px;
            border-radius: 16px;
            background: linear-gradient(135deg, var(--green), #2DD4BF);
            color: #0C1018;
            border: none;
            font: inherit;
            font-weight: 900;
            font-size: 1.1rem;
            cursor: pointer;
            letter-spacing: 1px;
            text-transform: uppercase;
            box-shadow: 0 4px 24px var(--green-glow);
            transition: transform 0.15s, filter 0.15s;
        }
        .depot-go:active { filter: brightness(1.1); transform: scale(0.98); }

        .depot-skip {
            display: block;
            margin: 14px auto 0;
            background: none;
            border: none;
            color: var(--text-3);
            font: inherit;
            font-size: 0.8rem;
            cursor: pointer;
            padding: 8px;
            transition: color 0.2s;
        }
        .depot-skip:active { color: var(--accent); }

        /* Compact "up next" single line */
        .up-next-line {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 14px 16px;
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            border-left: 3px solid var(--accent);
            border: 1px solid var(--border);
            border-radius: 14px;
            font-size: 0.82rem;
            color: var(--text-3);
            cursor: pointer;
            transition: border-color 0.2s, background 0.2s;
            box-shadow: var(--shadow-sm);
        }
        .up-next-line:active { opacity: 0.6; }
        .up-next-line strong { color: var(--text); font-weight: 700; }

        /* ═══════ BOTTOM SHEET (Quick Complete) ═══════ */
        .sheet-overlay {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.6);
            z-index: 300;
        }
        .sheet-overlay.open { display: block; }

        .sheet {
            position: fixed;
            bottom: 0; left: 50%; right: auto;
            transform: translateX(-50%) translateY(100%);
            width: 100%;
            max-width: 500px;
            z-index: 301;
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            -webkit-backdrop-filter: var(--glass-blur);
            border-top: 1px solid var(--border);
            border-radius: 24px 24px 0 0;
            padding: 20px 18px;
            padding-bottom: calc(20px + env(safe-area-inset-bottom));
            max-height: 85vh;
            overflow-y: auto;
            transition: transform 0.35s cubic-bezier(0.32, 0.72, 0, 1);
            box-shadow: 0 -8px 40px rgba(0,0,0,0.3);
        }
        .sheet-overlay.open .sheet { transform: translateX(-50%) translateY(0); }

        .sheet-overlay {
            transition: opacity 0.25s;
            opacity: 0;
        }
        .sheet-overlay.open { opacity: 1; }

        .sheet-handle {
            width: 40px; height: 4px;
            background: var(--text-3);
            border-radius: 2px;
            margin: 0 auto 16px;
            opacity: 0.4;
        }

        .sheet-title {
            font-size: 1.1rem;
            font-weight: 800;
            margin-bottom: 16px;
            text-align: center;
        }

        /* Status selector */
        .sheet-status {
            display: flex;
            gap: 8px;
            margin-bottom: 16px;
        }
        .sheet-status-btn {
            flex: 1;
            padding: 14px 8px;
            border-radius: 12px;
            border: 2px solid var(--border);
            background: var(--surface-2);
            color: var(--text);
            font: inherit;
            font-weight: 700;
            font-size: 0.82rem;
            cursor: pointer;
            text-align: center;
            transition: all 0.15s;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 4px;
        }
        .sheet-status-btn .status-dot {
            width: 10px; height: 10px;
            border-radius: 50%;
        }
        .sheet-status-btn.active { border-width: 3px; }
        .sheet-status-btn.s-delivered.active { border-color: var(--green); background: rgba(52,211,153,0.1); color: var(--green); }
        .sheet-status-btn.s-absent.active { border-color: var(--yellow); background: rgba(251,191,36,0.1); color: var(--yellow); }
        .sheet-status-btn.s-problem.active { border-color: var(--red); background: rgba(244,63,94,0.1); color: var(--red); }
        .sheet-status-btn:active { transform: scale(0.96); }

        /* Time adjuster in sheet */
        .sheet-time {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 10px;
            margin-bottom: 14px;
            padding: 8px 0;
        }
        .sheet-time-label {
            font-size: 0.75rem;
            font-weight: 600;
            color: var(--text-3);
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }
        .sheet-time-val {
            font-weight: 900;
            font-size: 1.3rem;
            color: var(--accent);
            font-variant-numeric: tabular-nums;
            min-width: 60px;
            text-align: center;
        }
        .sheet-time-btn {
            width: 44px; height: 38px;
            border: 2px solid var(--border);
            border-radius: 10px;
            background: var(--surface-2);
            color: var(--text);
            font: inherit;
            font-size: 0.8rem;
            font-weight: 700;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.15s;
        }
        .sheet-time-btn:active { background: var(--accent); color: #fff; border-color: var(--accent); }

        /* Quick colis counter */
        .sheet-colis-main {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 16px;
            margin-bottom: 12px;
            padding: 10px 0;
        }
        .sheet-colis-label {
            font-weight: 600;
            font-size: 0.9rem;
            color: var(--text-2);
        }
        .sheet-colis-count {
            display: flex;
            align-items: center;
            gap: 0;
        }
        .sheet-colis-btn {
            width: 48px; height: 48px;
            border: 2px solid var(--border);
            background: var(--surface-2);
            color: var(--text);
            font: inherit;
            font-size: 1.4rem;
            font-weight: 800;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.15s;
        }
        .sheet-colis-btn:first-child { border-radius: 12px 0 0 12px; }
        .sheet-colis-btn:last-child { border-radius: 0 12px 12px 0; }
        .sheet-colis-btn:active { background: var(--accent); color: #fff; border-color: var(--accent); }
        .sheet-colis-val {
            width: 56px; height: 48px;
            border-top: 2px solid var(--border);
            border-bottom: 2px solid var(--border);
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 900;
            font-size: 1.6rem;
            font-variant-numeric: tabular-nums;
            color: var(--accent);
        }

        /* Other types expandable */
        .sheet-other-toggle {
            display: block;
            width: 100%;
            background: none;
            border: 1px dashed var(--border);
            color: var(--text-3);
            padding: 10px;
            border-radius: 10px;
            font: inherit;
            font-size: 0.8rem;
            font-weight: 600;
            cursor: pointer;
            text-align: center;
            margin-bottom: 12px;
        }
        .sheet-other-toggle:active { color: var(--accent); border-color: var(--accent); }
        .sheet-other-grid {
            display: none;
            grid-template-columns: repeat(4, 1fr);
            gap: 8px;
            margin-bottom: 12px;
        }
        .sheet-other-grid.open { display: grid; }

        /* Note field */
        .sheet-note {
            display: none;
            width: 100%;
            background: var(--surface-2);
            border: 2px solid var(--border);
            border-radius: 12px;
            padding: 12px;
            font: inherit;
            font-size: 0.9rem;
            color: var(--text);
            outline: none;
            resize: none;
            height: 60px;
            margin-bottom: 12px;
        }
        .sheet-note.open { display: block; }
        .sheet-note:focus { border-color: var(--accent); }

        /* Photo capture */
        .sheet-photo-row {
            display: none;
            gap: 10px;
            align-items: center;
            margin-bottom: 12px;
        }
        .sheet-photo-row.open { display: flex; }

        .sheet-photo-btn {
            display: flex;
            align-items: center;
            gap: 8px;
            background: var(--surface-2);
            border: 2px dashed var(--border);
            color: var(--text-2);
            padding: 12px 16px;
            border-radius: 12px;
            font: inherit;
            font-size: 0.85rem;
            font-weight: 600;
            cursor: pointer;
            flex: 1;
        }
        .sheet-photo-btn:active { border-color: var(--accent); color: var(--accent); }

        .sheet-photo-preview {
            width: 56px;
            height: 56px;
            border-radius: 10px;
            object-fit: cover;
            border: 2px solid var(--border);
            display: none;
        }
        .sheet-photo-preview.has-img { display: block; }

        /* Validate button */
        .sheet-validate {
            width: 100%;
            padding: 18px;
            border-radius: 14px;
            background: linear-gradient(135deg, var(--green), #2DD4BF);
            color: #0C1018;
            border: none;
            font: inherit;
            font-weight: 900;
            font-size: 1.05rem;
            cursor: pointer;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            box-shadow: 0 4px 16px var(--green-glow);
        }
        .sheet-validate:active { filter: brightness(1.1); transform: scale(0.97); }

        /* All done state */
        .all-done {
            text-align: center;
            padding: 60px 20px;
        }
        .all-done-ico { font-size: 4rem; margin-bottom: 16px; }
        .all-done-title { font-size: 1.7rem; font-weight: 900; margin-bottom: 8px; letter-spacing: -0.5px; }
        .all-done-sub { color: var(--text-3); font-size: 0.9rem; line-height: 1.5; }

        /* ═══════ SCREEN: LIST ═══════ */
        .list { padding: 10px 14px; max-width: 500px; margin: 0 auto; }

        .ls {
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            border: 1px solid var(--border);
            border-radius: 16px;
            margin-bottom: 8px;
            overflow: hidden;
            transition: opacity 0.2s, border-color 0.2s, box-shadow 0.2s;
            box-shadow: var(--shadow-sm);
        }
        .ls.done { opacity: 0.35; }
        .ls.prio { border-color: rgba(244,63,94,0.3); box-shadow: var(--shadow-sm), 0 0 0 1px rgba(244,63,94,0.1); }
        .ls.fuel { border-color: rgba(251,191,36,0.3); box-shadow: var(--shadow-sm), 0 0 0 1px rgba(251,191,36,0.1); }

        .ls-row {
            display: flex;
            align-items: center;
            padding: 14px;
            gap: 10px;
            cursor: pointer;
        }
        .ls-row:active { opacity: 0.6; }

        .ls-chk {
            width: 20px; height: 20px;
            accent-color: var(--green);
            cursor: pointer;
            flex-shrink: 0;
        }
        .ls-num {
            width: 32px; height: 32px;
            border-radius: 10px;
            background: var(--surface-2);
            border: 1px solid var(--border);
            display: flex; align-items: center; justify-content: center;
            font-weight: 800; font-size: 0.82rem;
            color: var(--text-3);
            flex-shrink: 0;
            transition: background 0.2s, color 0.2s;
        }
        .ls.done .ls-num { background: var(--green); color: #fff; border-color: transparent; }
        .ls-info { flex: 1; min-width: 0; }
        .ls-code {
            font-size: 0.65rem; font-weight: 700;
            color: var(--accent);
            margin-right: 6px;
            letter-spacing: 0.3px;
        }
        .ls-name { font-weight: 700; font-size: 0.88rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
        .ls-addr { font-size: 0.76rem; color: var(--text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 1px; }

        .ls-go {
            width: 42px; height: 42px;
            border-radius: 12px;
            background: linear-gradient(135deg, var(--green), #2DD4BF);
            color: #0C1018;
            border: none;
            font-size: 1.05rem;
            cursor: pointer;
            flex-shrink: 0;
            display: flex; align-items: center; justify-content: center;
            box-shadow: 0 2px 8px var(--green-glow);
            transition: transform 0.15s, filter 0.15s;
        }
        .ls-go:active { filter: brightness(1.1); transform: scale(0.95); }
        .ls.done .ls-go { opacity: 0.3; box-shadow: none; }

        /* Expand detail */
        .ls-detail {
            display: none;
            padding: 0 14px 14px;
            border-top: 1px solid var(--border);
        }
        .ls-detail.open { display: block; }
        .ls-detail .hero-notes { margin-top: 10px; margin-bottom: 6px; }
        .ls-detail .hero-alerts { margin-top: 10px; }
        .ls-detail .hero-photo { margin-top: 8px; }

        /* ═══════ SCREEN: CODES ═══════ */
        .codes { padding: 20px 16px; max-width: 500px; margin: 0 auto; }
        .codes-title {
            font-size: 0.65rem;
            font-weight: 700;
            letter-spacing: 3.5px;
            text-transform: uppercase;
            color: var(--accent);
            margin-bottom: 18px;
            opacity: 0.9;
        }

        .code-card {
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 20px;
            margin-bottom: 10px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            box-shadow: var(--shadow-sm);
            transition: border-color 0.2s;
        }
        .code-card-label { font-weight: 600; color: var(--text-2); font-size: 0.92rem; }
        .code-card-val {
            font-weight: 900;
            font-size: 1.5rem;
            color: var(--accent);
            letter-spacing: 4px;
            font-variant-numeric: tabular-nums;
        }

        .sms-card {
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 22px;
            margin-top: 20px;
            box-shadow: var(--shadow-sm);
        }
        .sms-label {
            font-size: 0.65rem;
            font-weight: 700;
            letter-spacing: 2.5px;
            text-transform: uppercase;
            color: var(--text-3);
            margin-bottom: 12px;
        }
        .sms-text { font-size: 0.88rem; color: var(--text-2); line-height: 1.55; margin-bottom: 16px; }
        .sms-btn {
            background: linear-gradient(135deg, var(--blue), #2563EB);
            color: #fff;
            border: none;
            padding: 14px 24px;
            border-radius: 14px;
            font: inherit;
            font-weight: 700;
            font-size: 0.9rem;
            cursor: pointer;
            width: 100%;
            box-shadow: 0 4px 16px rgba(59,130,246,0.2);
            transition: transform 0.15s, filter 0.15s;
        }
        .sms-btn:active { filter: brightness(1.1); transform: scale(0.98); }

        /* ═══════ PHOTO MODAL ═══════ */
        .modal {
            display: none;
            position: fixed; inset: 0;
            background: rgba(12,16,24,0.95);
            z-index: 500;
            align-items: center; justify-content: center;
            padding: 16px;
            backdrop-filter: blur(8px);
        }
        .modal.on { display: flex; }
        .modal-box {
            background: var(--surface);
            border-radius: 20px;
            padding: 12px;
            max-width: 480px; width: 100%;
            max-height: 85vh;
            position: relative;
            box-shadow: var(--shadow-lg);
            border: 1px solid var(--border);
        }
        .modal-box img { width: 100%; max-height: 65vh; object-fit: contain; border-radius: 14px; display: block; }
        .modal-cap { text-align: center; margin-top: 12px; font-weight: 700; font-size: 0.9rem; }
        .modal-x {
            position: absolute; top: -10px; right: -10px;
            width: 36px; height: 36px; border-radius: 50%;
            background: var(--red); color: #fff; border: none;
            font-size: 1.3rem; cursor: pointer;
            display: flex; align-items: center; justify-content: center;
            box-shadow: 0 4px 12px rgba(244,63,94,0.3);
            transition: transform 0.15s;
        }
        .modal-x:active { transform: scale(0.9); }

        /* ═══════ TRANSITIONS ═══════ */
        @keyframes slideUp {
            from { transform: translateY(20px); opacity: 0; }
            to { transform: translateY(0); opacity: 1; }
        }
        .anim-up { animation: slideUp 0.35s cubic-bezier(0.4, 0, 0.2, 1); }

        @keyframes pop {
            0% { transform: scale(0.85); opacity: 0; }
            70% { transform: scale(1.03); }
            100% { transform: scale(1); opacity: 1; }
        }
        .anim-pop { animation: pop 0.4s cubic-bezier(0.4, 0, 0.2, 1); }

        /* Stagger entrance for picker profiles */
        @keyframes fadeUp {
            from { opacity: 0; transform: translateY(20px) scale(0.9); }
            to { opacity: 1; transform: translateY(0) scale(1); }
        }
        .picker-profile { opacity: 0; animation: fadeUp 0.4s ease-out forwards; }
        .picker-profile:nth-child(1) { animation-delay: 0.05s; }
        .picker-profile:nth-child(2) { animation-delay: 0.12s; }
        .picker-profile:nth-child(3) { animation-delay: 0.19s; }
        .picker-profile:nth-child(4) { animation-delay: 0.26s; }
        .picker-profile:nth-child(5) { animation-delay: 0.33s; }
        .picker-title { animation: fadeUp 0.3s ease-out; }

        /* Loader */
        .loader-overlay {
            display: none;
            position: fixed;
            inset: 0;
            z-index: 400;
            background: var(--bg);
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 16px;
        }
        .loader-overlay.on { display: flex; }
        .loader-truck { font-size: 2.5rem; animation: truckBounce 0.6s ease-in-out infinite; }
        @keyframes truckBounce {
            0%, 100% { transform: translateY(0); }
            50% { transform: translateY(-8px); }
        }
        .loader-dots { display: flex; gap: 6px; }
        .loader-dot {
            width: 8px; height: 8px;
            border-radius: 50%;
            background: var(--accent);
            animation: dotPulse 1s ease-in-out infinite;
        }
        .loader-dot:nth-child(2) { animation-delay: 0.2s; }
        .loader-dot:nth-child(3) { animation-delay: 0.4s; }
        @keyframes dotPulse {
            0%, 100% { opacity: 0.3; transform: scale(0.8); }
            50% { opacity: 1; transform: scale(1.2); }
        }

        /* Tap ripple on buttons */
        @keyframes tapPulse {
            0% { box-shadow: 0 0 0 0 rgba(91,168,230,0.4); }
            100% { box-shadow: 0 0 0 12px rgba(91,168,230,0); }
        }
        .dlv-mini-btn:active, .sheet-colis-btn:active, .sheet-time-btn:active {
            animation: tapPulse 0.3s ease-out;
        }

        /* Screen transitions */
        @keyframes screenIn {
            from { opacity: 0; }
            to { opacity: 1; }
        }
        .screen.on > * { animation: screenIn 0.2s ease-out; }

        @keyframes slideLeft {
            from { transform: translateX(30px); opacity: 0; }
            to { transform: translateX(0); opacity: 1; }
        }
        .anim-slide { animation: slideLeft 0.3s ease-out; }

        @keyframes checkmark {
            0% { transform: scale(0); }
            50% { transform: scale(1.2); }
            100% { transform: scale(1); }
        }
        .anim-check { animation: checkmark 0.4s cubic-bezier(0.4, 0, 0.2, 1); }

        /* ═══════ HUB ENHANCED ═══════ */
        .hub-card-icon {
            font-size: 2rem;
            margin-bottom: 8px;
        }
        .hub-card-status {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 4px 12px;
            border-radius: 8px;
            font-size: 0.68rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            margin-bottom: 12px;
        }
        .hub-card-status.idle { background: var(--surface-2); color: var(--text-3); border: 1px solid var(--border); }
        .hub-card-status.active { background: rgba(52,211,153,0.08); color: var(--green); border: 1px solid rgba(52,211,153,0.15); }
        .hub-card-status.complete { background: var(--green); color: #fff; }
        .hub-card-status .pulse {
            width: 6px; height: 6px;
            border-radius: 50%;
            background: currentColor;
            animation: blink 1.5s infinite;
        }
        @keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.3} }

        .hub-card-cta {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            margin-top: 16px;
            padding: 16px;
            border-radius: 14px;
            background: linear-gradient(135deg, var(--accent), #4A9AE0);
            color: #fff;
            font-weight: 800;
            font-size: 0.92rem;
            letter-spacing: 0.3px;
            box-shadow: 0 4px 20px var(--accent-glow);
            transition: transform 0.2s, filter 0.2s;
        }

        /* ═══════ ACTION PANEL (bottom zone) ═══════ */
        .departure-btn {
            width: 100%;
            background: var(--accent-dim);
            border: 2px dashed var(--accent);
            color: var(--accent);
            padding: 12px 16px;
            border-radius: 12px;
            font-family: var(--font);
            font-weight: 800;
            font-size: 0.9rem;
            cursor: pointer;
            margin-bottom: 10px;
            transition: all 0.2s;
        }
        .departure-btn:active { transform: scale(0.97); background: var(--accent); color: #fff; }
        .departure-set {
            background: var(--surface);
            border: 1px solid var(--border);
            color: var(--text-2);
            padding: 10px 16px;
            border-radius: 12px;
            font-size: 0.85rem;
            font-weight: 600;
            margin-bottom: 10px;
        }
        .departure-set strong { color: var(--accent); font-weight: 900; }

        .action-panel {
            flex: 1;
            display: flex;
            flex-direction: column;
            gap: 10px;
            margin-top: 10px;
        }

        /* Compact delivery form */
        .dlv-form {
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            border: 1px solid var(--border);
            border-radius: 18px;
            padding: 14px 16px;
            box-shadow: var(--shadow-sm);
        }

        .dlv-time-btn {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            width: 100%;
            padding: 12px;
            margin-bottom: 12px;
            border-radius: 12px;
            border: 1px solid var(--border);
            background: var(--surface-2);
            font: inherit;
            font-size: 0.85rem;
            font-weight: 700;
            color: var(--text-3);
            cursor: pointer;
            transition: border-color 0.2s, color 0.2s, background 0.2s, box-shadow 0.2s;
        }
        .dlv-time-btn:active { border-color: rgba(91,168,230,0.3); }
        .dlv-time-btn.set {
            border-color: rgba(91,168,230,0.3);
            color: var(--accent);
            background: var(--accent-dim);
            box-shadow: 0 0 0 1px rgba(91,168,230,0.08);
        }

        /* Colis — mini cards grid */
        .dlv-colis-grid {
            display: grid;
            grid-template-columns: repeat(5, 1fr);
            gap: 6px;
        }
        .dlv-colis-card {
            background: var(--surface-2);
            border: 1px solid var(--border);
            border-radius: 14px;
            display: flex;
            flex-direction: column;
            align-items: center;
            padding: 10px 2px 8px;
            gap: 2px;
            position: relative;
            overflow: hidden;
            transition: border-color 0.2s, box-shadow 0.2s;
        }
        .dlv-colis-card::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0;
            height: 3px;
        }
        .dlv-colis-card.has-val {
            border-color: rgba(91,168,230,0.3);
            box-shadow: 0 0 0 1px rgba(91,168,230,0.08);
        }
        .dlv-colis-val {
            font-weight: 900;
            font-size: 1.3rem;
            line-height: 1;
            font-variant-numeric: tabular-nums;
            color: var(--text-3);
            margin: 2px 0;
            transition: color 0.2s;
        }
        .dlv-colis-card.has-val .dlv-colis-val {
            color: var(--accent);
        }
        .dlv-colis-name {
            font-size: 0.52rem;
            font-weight: 700;
            color: var(--text-3);
            text-align: center;
            line-height: 1.15;
            text-transform: uppercase;
            letter-spacing: 0.3px;
        }
        .dlv-colis-btns {
            display: flex;
            gap: 3px;
            margin-top: 3px;
        }
        .dlv-mini-btn {
            width: 36px; height: 36px;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: var(--surface);
            color: var(--text);
            font: inherit;
            font-size: 0.95rem;
            font-weight: 800;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.1s;
        }
        .dlv-mini-btn:active { background: var(--accent); color: #fff; border-color: var(--accent); transform: scale(0.9); }

        /* ═══════ SCREEN: RAPPORT ═══════ */
        .rapport { padding: 16px; max-width: 500px; margin: 0 auto; }
        .rapport-title {
            font-size: 0.65rem;
            font-weight: 700;
            letter-spacing: 3.5px;
            text-transform: uppercase;
            color: var(--accent);
            margin-bottom: 18px;
            opacity: 0.9;
        }

        .rapport-summary {
            background: var(--surface);
            backdrop-filter: var(--glass-blur);
            border: 1px solid var(--border);
            border-radius: 20px;
            padding: 22px;
            margin-bottom: 14px;
            box-shadow: var(--shadow-sm);
        }
        .rapport-summary h3 { font-size: 1.1rem; font-weight: 900; margin-bottom: 14px; letter-spacing: -0.2px; }

        .rapport-stat-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 10px;
            margin-bottom: 18px;
        }
        .rapport-stat {
            background: var(--surface-2);
            border-radius: 14px;
            padding: 16px;
            text-align: center;
            border: 1px solid var(--border);
        }
        .rapport-stat-val { font-size: 1.8rem; font-weight: 900; color: var(--accent); }
        .rapport-stat-label {
            font-size: 0.68rem;
            font-weight: 600;
            color: var(--text-3);
            text-transform: uppercase;
            letter-spacing: 0.8px;
            margin-top: 4px;
        }

        .rapport-entry {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 12px 0;
            border-bottom: 1px solid var(--border);
            font-size: 0.85rem;
        }
        .rapport-entry:last-child { border-bottom: none; }
        .rapport-entry-num {
            width: 26px; height: 26px;
            border-radius: 8px;
            background: var(--green);
            color: #fff;
            display: flex; align-items: center; justify-content: center;
            font-weight: 800; font-size: 0.72rem; flex-shrink: 0;
        }
        .rapport-entry-num.pending { background: var(--text-3); }
        .rapport-entry-info { flex: 1; min-width: 0; }
        .rapport-entry-client { font-weight: 700; }
        .rapport-entry-meta { font-size: 0.76rem; color: var(--text-3); margin-top: 1px; }

        .rapport-actions {
            display: flex;
            flex-direction: column;
            gap: 10px;
            margin-top: 18px;
        }
        .rapport-btn {
            padding: 15px;
            border-radius: 14px;
            font: inherit;
            font-weight: 700;
            font-size: 0.9rem;
            cursor: pointer;
            border: none;
            text-align: center;
            transition: transform 0.15s, filter 0.15s;
        }
        .rapport-btn.primary { background: linear-gradient(135deg, var(--blue), #2563EB); color: #fff; box-shadow: 0 4px 16px rgba(59,130,246,0.2); }
        .rapport-btn.secondary { background: var(--surface-2); color: var(--text); border: 1px solid var(--border); }
        .rapport-btn:active { transform: scale(0.98); filter: brightness(1.05); }

        /* ═══════ RESPONSIVE ═══════ */
        @media (max-width: 380px) {
            .hero-client { font-size: 1.2rem; }
            .hero-go { padding: 16px; font-size: 1rem; }
            .hero-done { padding: 16px; font-size: 0.95rem; }
            .dlv-input { padding: 10px; font-size: 0.9rem; }
        }
