@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--blue-primary:#1a6fdb;--blue-dark:#1258b5;--blue-light:#e8f1fc;--body-bg:#f3f6fb;--card-bg:#fff;--text-primary:#0f172a;--text-secondary:#64748b;--text-muted:#94a3b8;--border:#e2e8f0;--input-bg:#f8fafc;--green:#16a34a;--green-light:#dcfce7;--red:#dc2626;--red-light:#fee2e2;--amber:#d97706;--amber-light:#fef3c7;--purple:#7c3aed;--purple-light:#f3f0ff;--cyan:#0891b2}html,body{height:100%;color:var(--text-primary);background:var(--body-bg);flex-direction:column;font-family:DM Sans,sans-serif;font-size:13px;display:flex;overflow:hidden}#root{flex-direction:column;height:100%;display:flex}.topnav{border-bottom:1px solid var(--border);z-index:100;background:#fff;flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 20px;display:flex}.topnav-logo{cursor:pointer;align-items:center;gap:8px;min-width:170px;transition:min-width .3s;display:flex;overflow:hidden}.topnav-logo.collapsed{min-width:44px}.topnav-logo.collapsed .logo-text{display:none}.logo-mark{color:#fff;background:linear-gradient(135deg,#1a6fdb,#3b9bff);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.logo-text{font-size:13px;font-weight:600;line-height:1.2}.logo-text span{color:var(--text-muted);font-size:10px;font-weight:400;display:block}.burger-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:background .15s;display:flex}.burger-btn:hover{background:var(--blue-light);color:var(--blue-primary)}.topnav-search{background:var(--input-bg);border:1px solid var(--border);max-width:340px;height:34px;color:var(--text-muted);border-radius:8px;flex:1;align-items:center;gap:8px;padding:0 12px;font-size:12px;display:flex}.topnav-right{align-items:center;gap:14px;margin-left:auto;display:flex}.icon-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex;position:relative}.icon-btn:hover{background:var(--blue-light);color:var(--blue-primary)}.notif-dot{background:var(--red);border:1.5px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:5px;right:5px}.user-avatar{color:#fff;background:linear-gradient(135deg,#1a6fdb,#60a5fa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.user-info .name{font-size:12px;font-weight:600}.user-info .role{color:var(--text-muted);font-size:10px}.user-chip{cursor:pointer;align-items:center;gap:8px;display:flex}.role-badge{color:#7c3aed;background:#f3f0ff;border:1px solid #c4b5fd;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.view-toggle-btn{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:#fff;border-radius:20px;align-items:center;gap:7px;padding:5px 12px;font-family:inherit;font-size:11.5px;font-weight:600;transition:all .2s;display:inline-flex}.view-toggle-btn:hover{border-color:var(--blue-primary);color:var(--blue-primary);background:var(--blue-light)}.view-toggle-btn.emp-mode{background:var(--blue-primary);border-color:var(--blue-primary);color:#fff}.toggle-dot{background:var(--text-muted);border-radius:50%;flex-shrink:0;width:7px;height:7px;transition:background .2s}.view-toggle-btn:hover .toggle-dot{background:var(--blue-primary)}.view-toggle-btn.emp-mode .toggle-dot{background:#ffffffb3}.app-body{flex:1;display:flex;overflow:hidden}.sidebar{border-right:1px solid var(--border);background:#fff;flex-direction:column;flex-shrink:0;width:200px;height:100%;transition:width .3s;display:flex;overflow:hidden auto}.sidebar.collapsed{width:0}.sidebar-inner{flex-direction:column;width:200px;min-width:200px;height:100%;padding:16px 0;display:flex}.sidebar-section{margin-bottom:8px;padding:0 12px}.sidebar-label{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;padding:0 4px;font-size:10px;font-weight:600}.sidebar-item{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;width:100%;margin-bottom:2px;padding:7px 10px;font-family:inherit;font-size:12.5px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-item:hover{background:var(--blue-light);color:var(--blue-primary)}.sidebar-item.active{background:var(--blue-primary);color:#fff}.s-badge{background:var(--red);color:#fff;border-radius:20px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.sidebar-item.active .s-badge{background:#ffffff4d}.sidebar-divider{background:var(--border);height:1px;margin:10px 12px}.main-content{flex:1;min-width:0;padding:24px 24px 48px;overflow-y:auto}.right-panel{border-left:1px solid var(--border);background:#fff;flex-direction:column;flex-shrink:0;width:290px;height:100%;transition:width .3s;display:flex;overflow:hidden}.right-panel.collapsed{width:0}.right-panel-inner{flex-direction:column;width:290px;min-width:290px;height:100%;display:flex;overflow:hidden}.chat-panel-top{background:linear-gradient(160deg,#1258b5 0%,#2563eb 50%,#3b9bff 100%);flex-shrink:0;padding:18px 16px 20px;position:relative;overflow:hidden}.chat-top-graphics{pointer-events:none;position:absolute;inset:0;overflow:hidden}.chat-bubble-bg{background:#ffffff0f;border-radius:50%;position:absolute}.chat-toggle-btn{cursor:pointer;color:#fff;background:#fff3;border:none;border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:700;display:flex;position:absolute;top:10px;right:10px}.chat-avatar-ring{background:#ffffff26;border:2px solid #ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 10px;font-size:22px;display:flex}.chat-greeting{text-align:center;color:#fff}.chat-greeting .hello{margin-bottom:2px;font-size:16px;font-weight:700}.chat-greeting .sub{opacity:.85;font-size:11.5px}.chat-messages{flex-direction:column;flex-shrink:0;gap:8px;padding:12px 12px 4px;display:flex}.chat-msg{align-items:flex-end;gap:8px;display:flex}.chat-msg-avatar{color:#fff;background:linear-gradient(135deg,#1a6fdb,#60a5fa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:9px;font-weight:700;display:flex}.chat-bubble{border-radius:10px;max-width:82%;padding:7px 10px;font-size:11.5px;line-height:1.45}.chat-msg.bot .chat-bubble{background:var(--blue-light);color:#1e40af;border-bottom-left-radius:3px}.chat-msg.user{flex-direction:row-reverse}.chat-msg.user .chat-bubble{background:var(--blue-primary);color:#fff;border-bottom-right-radius:3px}.chat-messages-scroll{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.chat-suggestions{flex-direction:column;flex-shrink:0;gap:5px;padding:4px 12px 8px;display:flex}.chat-suggestion-pill{background:var(--blue-light);color:var(--blue-primary);cursor:pointer;text-align:center;border:1px solid #bfdbfe;border-radius:20px;padding:5px 12px;font-size:11px;font-weight:500}.chat-suggestion-pill:hover{background:#dbeafe}.chat-divider{background:var(--border);flex-shrink:0;height:1px;margin:0 12px}.chat-input-area{flex-shrink:0;padding:10px 12px}.chat-input-wrap{border:1.5px solid var(--border);background:var(--input-bg);border-radius:10px;align-items:center;gap:6px;padding:6px 8px;display:flex}.chat-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:12px}.chat-input::placeholder{color:var(--text-muted)}.chat-action-btn{cursor:pointer;width:26px;height:26px;color:var(--text-muted);background:0 0;border:none;border-radius:6px;font-size:14px}.chat-send-btn{background:var(--blue-primary);cursor:pointer;color:#fff;border:none;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;display:flex}#chatCollapsedBtn{background:var(--blue-primary);color:#fff;cursor:pointer;writing-mode:vertical-rl;border:none;border-radius:10px 0 0 10px;justify-content:center;align-items:center;width:28px;height:72px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;display:none;position:fixed;top:50%;right:0;transform:translateY(-50%);box-shadow:-2px 0 8px #00000026}.back-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;margin-bottom:16px;padding:4px 0;font-family:inherit;font-size:12px;font-weight:500;display:inline-flex}.back-btn:hover{color:var(--blue-primary)}.page-title{letter-spacing:-.4px;margin-bottom:4px;font-size:22px;font-weight:800}.page-sub{color:var(--text-secondary);margin-bottom:22px;font-size:12.5px}.card{border:1px solid var(--border);background:#fff;border-radius:12px;margin-bottom:16px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.card-header{border-bottom:1px solid var(--border);background:#fafbfd;justify-content:space-between;align-items:center;padding:13px 18px;display:flex}.card-title{align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.card-body{padding:18px}.card-link{color:var(--blue-primary);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:11.5px;font-weight:600}.card-link:hover{text-decoration:underline}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;height:34px;padding:0 16px;font-family:inherit;font-size:12.5px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--blue-primary);color:#fff}.btn-primary:hover{background:var(--blue-dark)}.btn-secondary{border:1.5px solid var(--border);color:var(--text-primary);background:#fff}.btn-secondary:hover{border-color:var(--blue-primary);color:var(--blue-primary)}.btn-sm{height:28px;padding:0 12px;font-size:11.5px}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#15803d}.status-pill{white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:700;display:inline-flex}.pill-approved{color:#15803d;background:#dcfce7;border:1px solid #86efac}.pill-pending{color:#7c3aed;background:#f3f0ff;border:1px solid #c4b5fd}.pill-booking{color:#d97706;background:#fef3c7;border:1px solid #fde68a}.pill-action{color:#dc2626;background:#fee2e2;border:1px solid #fca5a5}.pill-draft{color:#64748b;background:#f1f5f9;border:1px solid #cbd5e1}.pill-closed{color:#15803d;background:#dcfce7;border:1px solid #86efac}.pill-inprogress{color:#1d4ed8;background:#dbeafe;border:1px solid #93c5fd}.pill-rejected{color:#dc2626;background:#fee2e2;border:1px solid #fca5a5}.pill-inreview{color:#1d4ed8;background:#dbeafe;border:1px solid #93c5fd}.pill-tour{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa}.pill-expense{color:#7e22ce;background:#fdf4ff;border:1px solid #e9d5ff}.kpi-row{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}.kpi-row-4{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.kpi-card{border:1px solid var(--border);background:#fff;border-radius:12px;align-items:center;gap:14px;padding:16px 18px;display:flex;box-shadow:0 1px 3px #0000000a}.kpi-card.clickable{cursor:pointer;transition:box-shadow .15s}.kpi-card.clickable:hover{box-shadow:0 4px 14px #00000017}.kpi-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.kpi-content{flex:1}.kpi-value{letter-spacing:-.5px;margin-bottom:3px;font-family:DM Mono,monospace;font-size:24px;font-weight:800;line-height:1}.kpi-label{color:var(--text-secondary);font-size:11.5px;font-weight:500}.kpi-sub{color:var(--text-muted);margin-top:2px;font-size:10.5px}.kpi-trip{background:linear-gradient(135deg,#1258b5,#2563eb);border-color:#0000}.kpi-trip .kpi-label{color:#fffc}.kpi-trip .kpi-value{color:#fff}.kpi-trip .kpi-sub{color:#ffffffa6}.kpi-trip .kpi-icon{background:#ffffff26}.nav-cards{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}.nav-card{border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:12px;flex-direction:column;gap:8px;padding:20px 18px;transition:all .15s;display:flex}.nav-card:hover{border-color:var(--blue-primary);transform:translateY(-1px);box-shadow:0 4px 16px #1a6fdb1a}.nav-card.featured{background:linear-gradient(135deg,#1258b5,#1a6fdb);border-color:#0000}.nav-card.featured:hover{box-shadow:0 4px 20px #1a6fdb59}.nav-card-icon{border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;margin-bottom:4px;font-size:18px;display:flex}.nav-card.featured .nav-card-icon{background:#fff3}.nav-card-arrow,.nav-card-arrow-dark{border:1.5px solid var(--border);width:28px;height:28px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;margin-top:auto;margin-left:auto;display:flex}.nav-card-title{font-size:15px;font-weight:700}.nav-card.featured .nav-card-title{color:#fff}.nav-card-desc{color:var(--text-secondary);font-size:11.5px;line-height:1.4}.nav-card.featured .nav-card-desc{color:#ffffffbf}.form-type-cards{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.form-type-card{border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:12px;flex-direction:column;gap:10px;padding:24px 20px;transition:all .15s;display:flex}.form-type-card:hover{border-color:var(--blue-primary);transform:translateY(-2px);box-shadow:0 4px 16px #1a6fdb1a}.ftc-icon{border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.ftc-title{font-size:14px;font-weight:700}.ftc-desc{color:var(--text-secondary);font-size:12px;line-height:1.45}.table-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.toolbar-left{flex:1;align-items:center;gap:8px;display:flex}.search-box{border:1.5px solid var(--border);height:34px;color:var(--text-muted);background:#fff;border-radius:8px;align-items:center;gap:7px;min-width:220px;padding:0 12px;font-size:12px;display:flex}.search-box input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;min-width:0;font-family:inherit;font-size:12px}.search-box input::placeholder{color:var(--text-muted)}.toolbar-btn{cursor:pointer;border:1.5px solid var(--border);height:34px;color:var(--text-secondary);background:#fff;border-radius:8px;align-items:center;gap:6px;padding:0 14px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex;position:relative}.toolbar-btn:hover{border-color:var(--blue-primary);color:var(--blue-primary)}.toolbar-btn.active{border-color:var(--blue-primary);color:var(--blue-primary);background:var(--blue-light)}.result-count{color:var(--text-muted);margin-left:auto;font-size:12px}.filter-dropdown{border:1px solid var(--border);z-index:200;background:#fff;border-radius:10px;min-width:200px;padding:10px;display:none;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 8px 24px #0000001f}.filter-dropdown.open{display:block}.filter-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:8px;margin-bottom:6px;font-size:10px;font-weight:700}.filter-section-title:first-child{margin-top:0}.filter-option{cursor:pointer;border-radius:6px;align-items:center;gap:7px;padding:5px 6px;font-size:12px;display:flex}.filter-option:hover{background:var(--blue-light)}.filter-option input{cursor:pointer;accent-color:var(--blue-primary)}.sort-dropdown{border:1px solid var(--border);z-index:200;background:#fff;border-radius:10px;min-width:170px;padding:6px;display:none;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 8px 24px #0000001f}.sort-dropdown.open{display:block}.sort-option{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:7px 10px;font-size:12px;font-weight:500;display:flex}.sort-option:hover{background:var(--blue-light);color:var(--blue-primary)}.sort-option.selected{background:var(--blue-light);color:var(--blue-primary);font-weight:700}.req-table-wrap{border:1px solid var(--border);background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.req-table{border-collapse:collapse;width:100%}.req-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:#fafbfd;padding:10px 14px;font-size:10px;font-weight:700}.req-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:12px 14px;font-size:12px}.req-table tr:last-child td{border-bottom:none}.req-table tbody tr:hover td{cursor:pointer;background:#f8fafc}.req-id{color:var(--blue-primary);font-family:DM Mono,monospace;font-size:11.5px;font-weight:600}.req-dest{font-weight:600}.req-date{color:var(--text-muted);font-family:DM Mono,monospace;font-size:11px}.req-project{color:var(--text-secondary);font-size:11.5px}.req-emp{font-weight:600}.mono{font-family:DM Mono,monospace}.pagination{border-top:1px solid var(--border);background:#fafbfd;justify-content:center;align-items:center;gap:4px;padding:14px;display:flex}.page-btn{border:1.5px solid var(--border);width:30px;height:30px;color:var(--text-secondary);cursor:pointer;background:#fff;border-radius:7px;justify-content:center;align-items:center;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s;display:flex}.page-btn:hover{border-color:var(--blue-primary);color:var(--blue-primary)}.page-btn.active{background:var(--blue-primary);border-color:var(--blue-primary);color:#fff}.page-btn.nav{gap:4px;width:auto;padding:0 10px}.adv-status-card{border:1px solid var(--border);background:#fff;border-radius:12px;align-items:center;gap:20px;margin-bottom:16px;padding:20px;display:flex;box-shadow:0 1px 3px #0000000a}.donut-wrap{flex-shrink:0;position:relative}.donut-label{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-pct{color:var(--text-primary);font-size:17px;font-weight:800;line-height:1}.donut-sub{color:var(--text-muted);font-size:10px;font-weight:500}.adv-stats{flex-wrap:wrap;flex:1;gap:24px;display:flex}.adv-stat{flex-direction:column;gap:3px;display:flex}.adv-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:10.5px;font-weight:500}.adv-stat-value{color:var(--text-primary);font-family:DM Mono,monospace;font-size:18px;font-weight:800}.adv-stat-sub{color:var(--text-muted);font-size:10px}.adv-table{border-collapse:collapse;width:100%}.adv-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--border);background:#fafbfd;padding:9px 14px;font-size:10px;font-weight:700}.adv-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:11px 14px;font-size:12px}.adv-table tr:last-child td{border-bottom:none}.form-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.form-grid-2{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}.form-grid-4{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.form-group{flex-direction:column;gap:5px;display:flex}.span-2{grid-column:span 2}.span-3{grid-column:span 3}.span-4{grid-column:span 4}.form-label{color:var(--text-secondary);font-size:11.5px;font-weight:600}.form-label .req{color:var(--red)}.form-input{border:1.5px solid var(--border);color:var(--text-primary);background:#fff;border-radius:8px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.form-input:focus{border-color:var(--blue-primary);box-shadow:0 0 0 3px #1a6fdb14}.form-input::placeholder{color:var(--text-muted)}.form-input:disabled,.form-input.readonly{background:var(--input-bg);color:var(--text-secondary);cursor:default}select.form-input{cursor:pointer}.form-textarea{border:1.5px solid var(--border);color:var(--text-primary);resize:vertical;background:#fff;border-radius:8px;outline:none;width:100%;min-height:90px;padding:10px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.form-textarea:focus{border-color:var(--blue-primary);box-shadow:0 0 0 3px #1a6fdb14}.form-textarea::placeholder{color:var(--text-muted)}.reports-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.stat-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.stat-row:last-child{border-bottom:none;padding-bottom:0}.stat-row:first-child{padding-top:0}.stat-label{color:var(--text-secondary);font-size:12px}.stat-val{font-family:DM Mono,monospace;font-size:13px;font-weight:700}.bar-chart{align-items:flex-end;gap:10px;height:110px;padding-bottom:8px;display:flex}.bar-col{flex-direction:column;flex:1;align-items:center;gap:5px;display:flex}.bar-fill{border-radius:5px 5px 0 0;width:100%;transition:opacity .15s}.bar-fill:hover{opacity:.75}.bar-lbl{color:var(--text-muted);text-align:center;font-size:10px;font-weight:500}.bar-val{color:var(--text-primary);font-size:10px;font-weight:700}.h-bar-row{margin-bottom:10px}.h-bar-top{justify-content:space-between;margin-bottom:4px;font-size:12px;display:flex}.h-bar-track{background:#f1f5f9;border-radius:20px;height:8px;overflow:hidden}.h-bar-fill{border-radius:20px;height:100%}.summary-stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}.sum-card{border:1px solid var(--border);background:#fff;border-radius:12px;padding:16px 18px;box-shadow:0 1px 3px #0000000a}.sum-card-val{margin-bottom:3px;font-family:DM Mono,monospace;font-size:22px;font-weight:800}.sum-card-label{color:var(--text-secondary);font-size:11.5px}.sum-card-sub{color:var(--text-muted);margin-top:2px;font-size:10.5px}.empty-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-state .icon{font-size:40px}.empty-state .msg{color:var(--text-secondary);font-size:14px;font-weight:600}.empty-state .sub{font-size:12px}.loading-spinner{color:var(--text-muted);justify-content:center;align-items:center;padding:40px;font-size:13px;display:flex}.modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:90%;max-width:480px;padding:28px;box-shadow:0 20px 60px #00000026}.modal-title{margin-bottom:8px;font-size:16px;font-weight:800}.modal-sub{color:var(--text-secondary);margin-bottom:20px;font-size:12.5px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar-bottom{margin-top:auto}.status-stepper{padding:0 12px}.stepper-title{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px;padding:0 4px;font-size:10px;font-weight:600}.step{align-items:flex-start;gap:8px;padding:5px 4px;display:flex;position:relative}.step:not(:last-child):after{content:"";background:var(--border);width:2px;height:calc(100% - 8px);position:absolute;top:24px;left:11px}.step.done:after{background:var(--blue-primary)}.step.active:after{background:linear-gradient(to bottom, var(--blue-primary), var(--border))}.step-dot{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:700;display:flex}.step.done .step-dot{background:var(--blue-primary);color:#fff}.step.active .step-dot{background:var(--amber);color:#fff;box-shadow:0 0 0 3px #fef3c7}.step.pending .step-dot{color:var(--text-muted);border:2px solid var(--border);background:#f1f5f9;font-size:9px}.step-info{flex:1;padding-top:3px}.step-label{color:var(--text-primary);font-size:12px;font-weight:600;line-height:1.3}.step.pending .step-label{color:var(--text-muted);font-weight:500}.step.active .step-label{color:var(--amber)}.step-sub{color:var(--text-muted);margin-top:1px;font-size:10px}.page-meta{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.meta-tag{color:var(--text-muted);font-family:DM Mono,monospace;font-size:11px}.section-badge{border-radius:4px;padding:2px 8px;font-family:DM Mono,monospace;font-size:10px;font-weight:700}.badge-dtp1{color:#1d4ed8;background:#dbeafe}.badge-dtp2{color:#15803d;background:#dcfce7}.badge-dtp3{color:#92400e;background:#fef3c7}.stage-badge{background:var(--amber-light);color:var(--amber);border:1px solid #fde68a;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:10.5px;font-weight:700;display:inline-flex}.detail-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.detail-item{flex-direction:column;gap:3px;display:flex}.detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:10.5px;font-weight:500}.detail-value{color:var(--text-primary);font-size:13px;font-weight:600}.section-rule{background:var(--border);height:1px;margin:16px 0}.sub-heading{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;font-size:11px;font-weight:700}.collapse-toggle{color:var(--blue-primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-family:inherit;font-size:12px;font-weight:600;display:flex}.collapse-toggle svg{transition:transform .2s}.collapse-toggle.open svg{transform:rotate(90deg)}.collapsible{max-height:0;transition:max-height .3s;overflow:hidden}.collapsible.open{max-height:2000px}.info-notice{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:9px;align-items:flex-start;gap:9px;margin-bottom:14px;padding:10px 13px;font-size:12px;line-height:1.55;display:flex}.direction-block{border:1px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden}.direction-header{border-bottom:1px solid var(--border);background:#f0f7ff;justify-content:space-between;align-items:center;padding:9px 14px;display:flex}.direction-route{color:var(--blue-primary);font-size:11px;font-weight:700}.direction-date{color:var(--text-secondary);font-family:DM Mono,monospace;font-size:10px}.sel-count{color:var(--text-muted);font-size:10.5px;font-weight:600}.sel-count span{color:var(--blue-primary);font-weight:700}.flight-table{border-collapse:collapse;width:100%}.flight-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:#fafbfd;padding:8px 10px;font-size:10px;font-weight:600}.flight-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:9px 10px;font-size:12px}.flight-table tr:last-child td{border-bottom:none}.flight-table tr.selected td{background:#f0f7ff}.flight-table tr.selected td:first-child{border-left:3px solid var(--blue-primary)}.font-mono{font-family:DM Mono,monospace}.elig-yes{color:#15803d;background:#dcfce7;border-radius:4px;align-items:center;gap:3px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex}.elig-no{color:var(--red);background:#fee2e2;border-radius:4px;align-items:center;gap:3px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex}.fcheck{border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;transition:all .15s;display:inline-flex}.fcheck.checked{background:var(--blue-primary);border-color:var(--blue-primary)}.fcheck.checked:after{content:"";border-bottom:2px solid #fff;border-left:2px solid #fff;width:8px;height:5px;display:block;transform:rotate(-45deg)translateY(-1px)}.hotel-table{border-collapse:collapse;width:100%}.hotel-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border);background:#fafbfd;padding:8px 12px;font-size:10px;font-weight:600}.hotel-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:11px 12px;font-size:12.5px}.hotel-table tr:last-child td{border-bottom:none}.hotel-table tr.selected td{background:#f0f7ff}.hotel-table tr.selected td:nth-child(2){color:var(--blue-primary);font-weight:700}.hotel-rating{color:var(--text-secondary);font-size:11.5px}.hotel-rating span{color:#f59e0b;font-size:12px}.hotel-dates{color:var(--text-secondary);margin-bottom:12px;font-size:12px;font-weight:500}.hotel-dates strong{color:var(--text-primary)}.view-prices-btn{background:var(--blue-primary);color:#fff;cursor:pointer;border:none;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-family:inherit;font-size:11.5px;font-weight:600;transition:background .15s;display:inline-flex}.view-prices-btn:hover{background:var(--blue-dark)}.email-block{border:1px solid var(--border);background:#fafbfd;border-radius:10px;margin-top:16px;overflow:hidden}.email-block-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;display:flex}.email-block-title{color:var(--text-primary);flex-wrap:wrap;align-items:center;gap:7px;font-size:12px;font-weight:700;display:flex}.email-tag{background:var(--blue-light);color:var(--blue-primary);border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.email-body{padding:14px}.email-textarea{border:1.5px solid var(--border);width:100%;min-height:280px;color:var(--text-primary);resize:vertical;background:#fff;border-radius:8px;outline:none;padding:13px 14px;font-family:DM Mono,monospace;font-size:11.5px;line-height:1.7;transition:border-color .15s}.email-textarea:focus{border-color:var(--blue-primary);box-shadow:0 0 0 3px #1a6fdb12}.email-hint{color:var(--text-muted);align-items:center;gap:5px;margin-top:7px;font-size:11px;display:flex}.driver-block{border:1px solid var(--border);background:#fafbfd;border-radius:10px;padding:16px}.driver-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px;display:grid}.form-input.autofill{color:#1258b5;background:#f0f7ff;border-color:#bfdbfe}.no-driver-row{align-items:center;gap:8px;padding:8px 0;display:flex}.no-driver-check{width:16px;height:16px;accent-color:var(--red);cursor:pointer}.no-driver-label{color:var(--red);cursor:pointer;font-size:12.5px;font-weight:600}.form-actions{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:4px;padding-top:16px;display:flex}.actions-right{align-items:center;gap:8px;margin-left:auto;display:flex}.stage-btns{flex-wrap:wrap;gap:5px;display:inline-flex}.stage-btn{color:var(--text-muted);cursor:pointer;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:20px;padding:3px 11px;font-family:inherit;font-size:10.5px;font-weight:700;transition:all .15s}.stage-btn.active{background:var(--amber-light);color:var(--amber);border-color:#fde68a}.stage-btn.done{color:#15803d;background:#f0fdf4;border-color:#86efac}.radio-cell{width:32px}.fradio{border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;transition:all .15s;display:inline-flex}.fradio.selected{border-color:var(--green);background:var(--green)}.fradio.selected:after{content:"";background:#fff;border-radius:50%;width:6px;height:6px;display:block}.hotel-table tr.td-preferred td:nth-child(2):after{content:" · TD Preference";color:var(--blue-primary);font-size:10px;font-weight:700}.driver-readonly{border:1px solid var(--border);background:#fafbfd;border-radius:10px;padding:16px}.driver-readonly-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-top:12px;display:grid}.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#15803d;box-shadow:0 3px 10px #16a34a4d}.ro-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.ro-item{flex-direction:column;gap:3px;display:flex}.ro-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:10.5px;font-weight:500}.ro-value{color:var(--text-primary);font-size:13px;font-weight:600}.badge-dtp5{color:#7e22ce;background:#fdf4ff;border:1px solid #e9d5ff}.badge-dtp6{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa}.exp-group{border:1px solid var(--border);border-radius:10px;margin-bottom:8px;overflow:hidden}.group-header{cursor:pointer;-webkit-user-select:none;user-select:none;background:#fafbfd;align-items:center;gap:10px;padding:11px 14px;display:flex}.group-header:hover{background:#f1f5f9}.group-icon{font-size:15px}.group-name{flex:1;font-size:13px;font-weight:700}.group-count{color:var(--text-muted);font-size:11px;font-weight:500}.group-sub{color:var(--blue-primary);margin-left:4px;font-family:DM Mono,monospace;font-size:13px;font-weight:700}.group-chev{color:var(--text-muted);flex-shrink:0;transition:transform .2s}.group-chev.open{transform:rotate(90deg)}.exp-group-rows{border-top:1px solid var(--border)}.exp-table{border-collapse:collapse;width:100%;font-size:12px}.exp-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:#fafbfd;padding:8px 12px;font-size:10px;font-weight:700}.exp-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:10px 12px}.exp-table tr:last-child td{border-bottom:none}.exp-table tr:hover td{background:#f8fafc}.col-amt{width:90px;min-width:90px;font-family:DM Mono,monospace;font-size:12.5px;font-weight:600;text-align:right!important}.col-elig{width:64px;min-width:64px;text-align:center!important}.col-select{width:60px;text-align:center!important}.elig-pass{width:20px;height:20px;color:var(--green);background:#dcfce7;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.elig-fail{width:20px;height:20px;color:var(--red);background:#fee2e2;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.elig-pending{width:20px;height:20px;color:var(--amber);background:#fef3c7;border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.pay-badge{color:var(--text-secondary);background:#f1f5f9;border-radius:4px;align-items:center;padding:1px 7px;font-size:10.5px;font-weight:600;display:inline-flex}.receipt-chip{color:var(--green);cursor:pointer;background:#f0fdf4;border:1px solid #86efac;border-radius:4px;align-items:center;gap:4px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex}.no-receipt{color:var(--text-muted);font-size:10px}.hod-bill-check{border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:17px;height:17px;transition:all .15s;display:inline-flex}.hod-bill-check.checked{background:var(--blue-primary);border-color:var(--blue-primary)}.hod-bill-check.checked:after{content:"";border-bottom:2px solid #fff;border-left:2px solid #fff;width:9px;height:6px;display:block;transform:rotate(-45deg)translate(1px,-1px)}.hod-bill-check.inelig-unchecked{border-color:var(--red);background:#fff8f8}.bill-comment-row td{background:#fafbfd;padding:0 12px 10px!important}.bill-comment-wrap{border:1.5px solid var(--border);background:#f8fafc;border-radius:8px;align-items:flex-start;gap:8px;padding:8px 10px;display:flex}.bill-comment-wrap.inelig-comment{background:#fff1f2;border-color:#fca5a5}.bill-comment-label{color:var(--text-secondary);white-space:nowrap;padding-top:1px;font-size:11px;font-weight:700}.bill-comment-label.inelig-label{color:var(--red)}.bill-comment-req{color:var(--red);margin-left:2px}.bill-comment-input{color:var(--text-primary);resize:none;background:0 0;border:none;outline:none;flex:1;min-height:32px;font-family:inherit;font-size:12px;line-height:1.4}.bill-comment-input::placeholder{color:var(--text-muted)}.grand-total-row{background:#f0f7ff;border-top:1.5px solid #bfdbfe;justify-content:flex-end;align-items:center;gap:16px;padding:14px 18px;display:flex}.gt-label{color:var(--text-secondary);font-size:13px;font-weight:700}.gt-amount{color:var(--blue-primary);font-family:DM Mono,monospace;font-size:18px;font-weight:800}.adv-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.adv-item{background:var(--input-bg);border:1px solid var(--border);border-radius:9px;padding:12px 14px}.adv-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;font-size:10.5px;font-weight:500}.adv-value{color:var(--text-primary);font-family:DM Mono,monospace;font-size:16px;font-weight:800}.adv-value.debit{color:var(--red)}.adv-value.credit{color:var(--green)}.adv-sub{color:var(--text-muted);margin-top:3px;font-size:10px}.decision-card{border:1.5px solid var(--border);background:#fff;border-radius:12px;margin-bottom:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.decision-card-header{border-bottom:1px solid var(--border);background:#fafbfd;justify-content:space-between;align-items:center;padding:13px 18px;display:flex}.decision-card-title{align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.decision-card-body{padding:18px}.comment-label{color:var(--text-secondary);align-items:center;gap:4px;margin-bottom:7px;font-size:12px;font-weight:700;display:flex}.req-star{color:var(--red)}.comment-box{border:1.5px solid var(--border);background:var(--input-bg);width:100%;min-height:100px;color:var(--text-primary);resize:vertical;border-radius:9px;outline:none;padding:10px 13px;font-family:inherit;font-size:13px;transition:border-color .15s}.comment-box:focus{border-color:var(--blue-primary);background:#fff;box-shadow:0 0 0 3px #1a6fdb14}.comment-box::placeholder{color:var(--text-muted)}.comment-hint{color:var(--text-muted);margin-top:5px;margin-bottom:18px;font-size:11px}.field-error{color:var(--red);margin-top:4px;margin-bottom:4px;font-size:11px;font-weight:600;display:none}.decision-confirmed{background:#f0fdf4;border-top:1.5px solid #86efac;align-items:center;gap:14px;padding:16px 18px;display:none}.decision-confirmed.show{display:flex}.ct-title{color:var(--green);font-size:14px;font-weight:800}.ct-sub{color:var(--text-secondary);margin-top:2px;font-size:12px}.btn-undo{border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;margin-left:auto;padding:7px 16px;font-family:inherit;font-size:12px;font-weight:600}.btn-undo:hover{border-color:var(--blue-primary);color:var(--blue-primary)}.btn-approve{background:var(--green);color:#fff}.btn-approve:hover{background:#15803d;box-shadow:0 3px 10px #16a34a4d}.btn-reject{color:var(--red);border:2px solid var(--red);background:#fff}.btn-reject:hover{background:var(--red-light)}
