:root {
            --bg-primary:    #0b0f1a;
            --bg-card:       #111827;
            --bg-hover:      #1a2236;
            --border:        #1e2d45;
            --accent:        #2563eb;
            --accent-light:  #3b82f6;
            --accent-glow:   rgba(37,99,235,0.18);
            --text-primary:  #e8edf5;
            --text-muted:    #64748b;
            --text-dim:      #94a3b8;
            --success:       #10b981;
            --warning:       #f59e0b;
            --danger:        #ef4444;
            --caja-color:    #0ea5e9;
            --ejec-color:    #8b5cf6;
        }

        * { box-sizing: border-box; margin: 0; padding: 0; }

        body {
            background: var(--bg-primary);
            font-family: 'DM Sans', sans-serif;
            color: var(--text-primary);
            min-height: 100vh;
            overflow-x: hidden;
        }

        /* Background grid */
        body::before {
            content: '';
            position: fixed;
            inset: 0;
            background-image:
                linear-gradient(rgba(37,99,235,0.04) 1px, transparent 1px),
                linear-gradient(90deg, rgba(37,99,235,0.04) 1px, transparent 1px);
            background-size: 40px 40px;
            pointer-events: none;
            z-index: 0;
        }

        /* ─── HEADER ─── */
        header {
            position: relative;
            z-index: 10;
            background: rgba(11,15,26,0.92);
            border-bottom: 1px solid var(--border);
            backdrop-filter: blur(12px);
            padding: 0 2rem;
            height: 64px;
            display: flex;
            align-items: center;
            justify-content: space-between;
        }

        .brand {
            display: flex;
            align-items: center;
            gap: .75rem;
        }
        .brand-icon {
            width: 36px; height: 36px;
            background: var(--accent);
            border-radius: 8px;
            display: grid;
            place-items: center;
            font-size: 1.1rem;
        }
        .brand-name {
            font-family: 'Syne', sans-serif;
            font-weight: 700;
            font-size: 1.05rem;
            letter-spacing: .03em;
            color: var(--text-primary);
        }
        .brand-sub {
            font-size: .7rem;
            color: var(--text-muted);
            margin-top: 1px;
            letter-spacing: .06em;
            text-transform: uppercase;
        }

        .header-right {
            display: flex;
            align-items: center;
            gap: 1.5rem;
        }
        .header-time {
            font-family: 'Syne', sans-serif;
            font-size: .95rem;
            font-weight: 600;
            color: var(--text-dim);
            letter-spacing: .06em;
        }
        .header-user {
            display: flex;
            align-items: center;
            gap: .6rem;
            background: var(--bg-hover);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: .35rem .75rem;
            font-size: .82rem;
            color: var(--text-dim);
        }
        .header-user .avatar {
            width: 24px; height: 24px;
            background: var(--accent);
            border-radius: 50%;
            display: grid;
            place-items: center;
            font-size: .65rem;
            color: #fff;
            font-weight: 600;
        }

        /* ─── MAIN ─── */
        main {
            position: relative;
            z-index: 1;
            padding: 2.5rem 2rem;
            max-width: 1100px;
            margin: 0 auto;
        }

        .page-title {
            font-family: 'Syne', sans-serif;
            font-size: 1.6rem;
            font-weight: 800;
            letter-spacing: -.01em;
            color: var(--text-primary);
        }
        .page-sub {
            color: var(--text-muted);
            font-size: .85rem;
            margin-top: .25rem;
        }

        /* ─── AREA SELECTOR ─── */
        .area-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 1rem;
            margin: 2rem 0;
        }

        .area-card {
            background: var(--bg-card);
            border: 2px solid var(--border);
            border-radius: 14px;
            padding: 1.5rem;
            cursor: pointer;
            transition: all .2s ease;
            position: relative;
            overflow: hidden;
        }
        .area-card::before {
            content: '';
            position: absolute;
            top: 0; left: 0;
            width: 4px; height: 100%;
            background: var(--area-color, var(--accent));
            transition: width .25s ease;
        }
        .area-card:hover {
            border-color: var(--area-color, var(--accent));
            background: var(--bg-hover);
            transform: translateY(-2px);
            box-shadow: 0 8px 32px var(--accent-glow);
        }
        .area-card.selected {
            border-color: var(--area-color, var(--accent));
            background: var(--bg-hover);
            box-shadow: 0 0 0 1px var(--area-color, var(--accent)), 0 8px 32px var(--accent-glow);
        }
        .area-card.selected::before { width: 6px; }

        .area-card[data-area="caja"]     { --area-color: var(--caja-color); }
        .area-card[data-area="ejecutivo"]{ --area-color: var(--ejec-color); }

        .area-label {
            font-family: 'Syne', sans-serif;
            font-weight: 700;
            font-size: 1.15rem;
        }
        .area-prefix {
            display: inline-block;
            background: var(--area-color, var(--accent));
            color: #fff;
            font-family: 'Syne', sans-serif;
            font-size: .7rem;
            font-weight: 700;
            letter-spacing: .1em;
            padding: .2rem .55rem;
            border-radius: 4px;
            margin-bottom: .5rem;
        }
        .area-desc {
            font-size: .8rem;
            color: var(--text-muted);
            margin-top: .35rem;
        }
        .area-counter {
            position: absolute;
            top: 1rem; right: 1.25rem;
            font-family: 'Syne', sans-serif;
            font-size: 1.8rem;
            font-weight: 800;
            color: var(--area-color, var(--accent));
            opacity: .15;
        }

        /* ─── MOTIVO GRID ─── */
        .section-label {
            font-size: .72rem;
            font-weight: 600;
            letter-spacing: .12em;
            text-transform: uppercase;
            color: var(--text-muted);
            margin-bottom: .85rem;
            display: flex;
            align-items: center;
            gap: .5rem;
        }
        .section-label::after {
            content: '';
            flex: 1;
            height: 1px;
            background: var(--border);
        }

        .motivo-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
            gap: .85rem;
        }

        .motivo-card {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 1.1rem 1.25rem;
            cursor: pointer;
            transition: all .18s ease;
            display: flex;
            align-items: flex-start;
            gap: .85rem;
        }
        .motivo-card:hover {
            border-color: var(--accent-light);
            background: var(--bg-hover);
            transform: translateY(-1px);
        }
        .motivo-card.selected {
            border-color: var(--accent-light);
            background: var(--bg-hover);
            box-shadow: 0 0 0 1px var(--accent-light), 0 4px 20px var(--accent-glow);
        }
        .motivo-icon {
            width: 38px; height: 38px;
            background: var(--accent-glow);
            border: 1px solid var(--border);
            border-radius: 8px;
            display: grid;
            place-items: center;
            font-size: 1rem;
            flex-shrink: 0;
            color: var(--accent-light);
        }
        .motivo-card.selected .motivo-icon {
            background: var(--accent);
            border-color: var(--accent);
            color: #fff;
        }
        .motivo-name {
            font-size: .88rem;
            font-weight: 500;
            line-height: 1.3;
        }
        .motivo-desc {
            font-size: .74rem;
            color: var(--text-muted);
            margin-top: .2rem;
            line-height: 1.4;
        }

        /* ─── EMPTY STATE ─── */
        .empty-motivos {
            grid-column: 1/-1;
            text-align: center;
            padding: 3rem;
            color: var(--text-muted);
            font-size: .85rem;
        }
        .empty-motivos i { font-size: 2rem; display: block; margin-bottom: .75rem; opacity: .3; }

        /* ─── CONFIRM PANEL ─── */
        .confirm-bar {
            position: fixed;
            bottom: 0; left: 0; right: 0;
            background: var(--bg-card);
            border-top: 1px solid var(--border);
            padding: 1rem 2rem;
            display: flex;
            align-items: center;
            justify-content: space-between;
            z-index: 100;
            backdrop-filter: blur(12px);
            transform: translateY(100%);
            transition: transform .3s cubic-bezier(.16,1,.3,1);
        }
        .confirm-bar.visible { transform: translateY(0); }

        .confirm-info { display: flex; flex-direction: column; gap: .15rem; }
        .confirm-label { font-size: .7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .1em; }
        .confirm-value { font-family: 'Syne', sans-serif; font-weight: 700; font-size: 1rem; }

        .btn-generate {
            background: var(--accent);
            color: #fff;
            border: none;
            border-radius: 10px;
            padding: .7rem 2rem;
            font-family: 'Syne', sans-serif;
            font-weight: 700;
            font-size: .9rem;
            letter-spacing: .04em;
            cursor: pointer;
            transition: all .18s;
            display: flex;
            align-items: center;
            gap: .5rem;
        }
        .btn-generate:hover {
            background: var(--accent-light);
            transform: translateY(-1px);
            box-shadow: 0 6px 20px var(--accent-glow);
        }
        .btn-generate:active { transform: translateY(0); }

        /* ─── TICKET MODAL ─── */
        .modal-overlay {
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,.75);
            backdrop-filter: blur(4px);
            z-index: 200;
            display: none;
            place-items: center;
        }
        .modal-overlay.show { display: grid; }

        .ticket-modal {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 20px;
            width: 380px;
            padding: 2.5rem;
            text-align: center;
            position: relative;
            animation: popIn .35s cubic-bezier(.16,1,.3,1);
        }
        @keyframes popIn {
            from { transform: scale(.88); opacity: 0; }
            to   { transform: scale(1);  opacity: 1; }
        }

        .ticket-badge {
            font-family: 'Syne', sans-serif;
            font-size: 4.5rem;
            font-weight: 800;
            letter-spacing: -.02em;
            color: var(--accent-light);
            line-height: 1;
            margin: .5rem 0;
        }
        .ticket-area-tag {
            display: inline-block;
            padding: .3rem .9rem;
            border-radius: 20px;
            font-size: .72rem;
            font-weight: 600;
            letter-spacing: .1em;
            text-transform: uppercase;
            margin-bottom: 1rem;
        }
        .ticket-motivo-name {
            color: var(--text-dim);
            font-size: .9rem;
            margin-bottom: 1.5rem;
        }
        .ticket-time {
            font-size: .75rem;
            color: var(--text-muted);
            margin-bottom: 1.75rem;
        }
        .btn-close-modal {
            background: var(--bg-hover);
            border: 1px solid var(--border);
            color: var(--text-primary);
            border-radius: 8px;
            padding: .6rem 1.5rem;
            font-family: 'DM Sans', sans-serif;
            font-size: .85rem;
            cursor: pointer;
            transition: all .18s;
            width: 100%;
        }
        .btn-close-modal:hover { border-color: var(--accent-light); }

        .check-circle {
            width: 56px; height: 56px;
            background: rgba(16,185,129,.15);
            border: 2px solid var(--success);
            border-radius: 50%;
            display: grid;
            place-items: center;
            margin: 0 auto 1rem;
            font-size: 1.4rem;
            color: var(--success);
        }

        /* ─── SCROLLBAR ─── */
        ::-webkit-scrollbar { width: 6px; }
        ::-webkit-scrollbar-track { background: transparent; }
        ::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

        /* ─── STATS ROW ─── */
        .stats-row {
            display: flex;
            gap: 1rem;
            margin-bottom: 2.5rem;
        }
        .stat-pill {
            background: var(--bg-card);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: .5rem 1rem;
            display: flex;
            align-items: center;
            gap: .6rem;
            font-size: .8rem;
        }
        .stat-dot {
            width: 8px; height: 8px;
            border-radius: 50%;
        }
        .stat-num {
            font-family: 'Syne', sans-serif;
            font-weight: 700;
            font-size: .95rem;
        }