@layer reset{*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}}@layer tokens{:root{--bg-primary: #0f1419;--bg-secondary: #1a1f2e;--bg-tertiary: #252b3b;--bg-hover: #2d3548;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #6e7681;--border-color: #30363d;--border-hover: #484f58;--accent-primary: #3b82f6;--accent-hover: #2563eb;--accent-light: rgba(59,130,246,.1);--success: #10b981;--success-light: rgba(16,185,129,.1);--warning: #f59e0b;--warning-light: rgba(245,158,11,.1);--error: #ef4444;--error-light: rgba(239,68,68,.1);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .5);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--ease: cubic-bezier(.2,.7,.2,1);--dur-1: .15s;--dur-2: .2s;--status-success: var(--success);--status-success-bg: var(--success-light);--status-warn: var(--warning);--status-warn-bg: var(--warning-light);--status-info: var(--accent-primary);--status-info-bg: var(--accent-light);--status-error: var(--error);--status-error-bg: var(--error-light)}}@layer base{:root{color-scheme:dark}html{overflow-x:hidden;width:100%;overflow-y:auto;scrollbar-gutter:stable}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden;width:100%;max-width:100vw}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}a{color:var(--accent-primary);text-decoration:none;transition:color var(--dur-2) var(--ease)}a:hover{color:var(--accent-hover)}.container{max-width:1280px;margin-inline:auto;padding-inline:1rem}@media (min-width: 768px){.container{padding-inline:2rem}}:where(button,[href],input,select,textarea):focus{outline:none}:where(button,[href],input,select,textarea):focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}select{background-color:var(--bg-tertiary);color:var(--text-primary)}select option{background-color:var(--bg-secondary);color:var(--text-primary);padding:8px 12px}select option:checked,select option:hover{background-color:var(--accent-primary);color:#fff}*{scrollbar-width:thin;scrollbar-color:var(--bg-tertiary) var(--bg-secondary)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.spinner{width:40px;height:40px;border:4px solid var(--bg-tertiary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}}@layer components{.btn{font:inherit;font-size:1rem;border-radius:var(--radius-md);cursor:pointer;font-weight:500}.btn-primary{padding:.875rem 1.5rem;background:var(--accent-primary);color:#fff;border:none;transition:background-color var(--dur-2) var(--ease),transform var(--dur-1) var(--ease),box-shadow var(--dur-1) var(--ease);font-weight:600;border-radius:var(--radius-md)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.75rem 1.5rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);transition:background-color var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease),transform var(--dur-1) var(--ease);border-radius:var(--radius-md)}.btn-secondary:hover{border-color:var(--border-hover);transform:translateY(-1px)}.btn-view{padding:.5rem 1rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);font-size:.875rem;transition:color var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease)}.btn-view:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.btn-edit{background:var(--success);color:#fff;border:none;padding:.5rem 1rem;font-size:.9rem;transition:background-color var(--dur-2) var(--ease),transform var(--dur-1) var(--ease),box-shadow var(--dur-1) var(--ease);display:inline-flex;align-items:center;gap:.25rem;border-radius:var(--radius-md)}.btn-edit:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-edit:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.btn-admin-edit{background:var(--warning, #f59e0b);color:#fff;border:none;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;transition:background-color var(--dur-2) var(--ease),transform var(--dur-1) var(--ease),box-shadow var(--dur-1) var(--ease);display:inline-flex;align-items:center;gap:.25rem;border-radius:var(--radius-md)}.btn-admin-edit:hover:not(:disabled){background:#d97706;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-admin-edit:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.loading-container{min-height:100vh;display:grid;place-items:center;gap:1rem}.loading{display:grid;place-items:center;padding-block:4rem;gap:1rem;text-align:center}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;font-size:.875rem;color:var(--text-secondary);display:inline-flex;align-items:center;gap:.25rem}.form-group label.error{color:var(--error)}.form-group :is(input,select,textarea){padding:.75rem 1rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:background-color var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease),box-shadow var(--dur-1) var(--ease);font-size:.9rem}.form-group select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.form-group select option{background:var(--bg-secondary);color:var(--text-primary);padding:.5rem}.form-group select option:hover,.form-group select option:focus,.form-group select option:checked{background:var(--accent-primary);color:#fff}.form-group :is(input,select,textarea):hover{border-color:var(--border-hover)}.form-group :is(input,select,textarea):focus-visible{border-color:var(--accent-primary);background:var(--bg-primary);box-shadow:0 0 0 2px var(--accent-light)}.form-group :is(input,select,textarea).error{border-color:var(--error);background:var(--error-light)}.form-group input.readonly{background:var(--bg-secondary);color:var(--text-muted)}.form-group :is(input,select,textarea):disabled{opacity:.6;cursor:not-allowed}.error-message,.error-box,.success-message{border-radius:var(--radius-md);font-size:.875rem;padding:.875rem}.error-message{background:var(--error-light);border:1px solid var(--error);color:var(--error)}.error-box{background:var(--error-light);border:1px solid var(--error);color:var(--error);display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.success-message{background:var(--status-success-bg);border:1px solid var(--status-success);color:var(--status-success);font-weight:500;margin-bottom:1.5rem}.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem;color:var(--text-secondary);font-size:.875rem}.breadcrumb a{color:var(--text-secondary);transition:color var(--dur-1) var(--ease)}.breadcrumb a:hover{color:var(--accent-primary);text-decoration:none}.breadcrumb span{margin-inline:.5rem}.detail-card,.stat-card,.recent-requests,.events-table-container,.logs-container,.booking-edit-form{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.detail-card,.recent-requests,.booking-edit-form{padding:1.5rem}.detail-card.full-width{grid-column:1 / -1}.detail-card h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.1rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.stat-card{padding:1.5rem;display:flex;gap:1rem;align-items:center;transition:border-color var(--dur-2) var(--ease),transform var(--dur-1) var(--ease),box-shadow var(--dur-1) var(--ease);text-decoration:none;color:inherit;width:100%;text-align:left}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card:not(.clickable):hover{border-color:var(--border-hover)}.stat-icon{font-size:2.5rem;width:64px;height:64px;display:grid;place-items:center;border-radius:var(--radius-lg);background:var(--bg-tertiary)}.stat-card.success .stat-icon{background:var(--status-success-bg)}.stat-card.warning .stat-icon{background:var(--status-warn-bg)}.stat-card.info .stat-icon{background:var(--status-info-bg)}.stat-card.error .stat-icon{background:var(--status-error-bg)}.stat-content{flex:1}.stat-title{font-size:.875rem;color:var(--text-secondary);font-weight:500;margin-bottom:.25rem}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary)}.stat-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.booking-edit-form{box-shadow:var(--shadow-md);margin:1rem 0}.form-header{margin-bottom:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:1rem}.form-header h3{margin:0 0 .5rem}.form-description{margin:0;color:var(--text-secondary);font-size:.9rem}.validation-errors{background:var(--error-light);border:1px solid var(--error);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.5rem}.validation-errors h4{margin:0 0 .5rem;color:var(--error)}.validation-errors ul{margin:0;padding-left:1.2rem}.validation-errors li{color:var(--error);margin-bottom:.25rem}.form-section{margin-bottom:2rem}.form-section h4{margin:0 0 1rem;font-size:1.1rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color)}.status-badge{padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;border:1px solid transparent}.status-badge.success{color:var(--status-success);background:var(--status-success-bg);border-color:var(--status-success)}.status-badge.needs_info{color:var(--status-warn);background:var(--status-warn-bg);border-color:var(--status-warn)}.status-badge.processing{color:var(--status-info);background:var(--status-info-bg);border-color:var(--status-info)}.status-badge.error{color:var(--status-error);background:var(--status-error-bg);border-color:var(--status-error)}.request-status{font-size:1.5rem;width:40px;height:40px;display:grid;place-items:center;border-radius:var(--radius-md);background:var(--bg-secondary)}.request-status.success{background:var(--status-success-bg)}.request-status.needs_info{background:var(--status-warn-bg)}.request-status.processing{background:var(--status-info-bg)}.request-status.error{background:var(--status-error-bg)}.requests-list{display:flex;flex-direction:column;gap:1rem}.request-card{display:flex;gap:1rem;padding:1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--dur-2) var(--ease),transform var(--dur-1) var(--ease)}.request-card:hover{border-color:var(--border-hover);transform:translate(4px)}.request-info{flex:1}.request-id{font-weight:600;margin-bottom:.25rem}.request-details{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.separator{margin:0 .5rem}.request-time{font-size:.75rem;color:var(--text-muted)}.requests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));gap:1.5rem}.requests-grid .request-card{background:var(--bg-secondary);border-radius:var(--radius-lg);transition:border-color var(--dur-2) var(--ease),transform var(--dur-1) var(--ease),box-shadow var(--dur-1) var(--ease);flex-direction:column}.requests-grid .request-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--shadow-md)}.card-header{padding:1rem;background:var(--bg-tertiary);display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}.card-header .request-id{font-family:monospace;color:var(--text-muted);font-size:.875rem}.card-header .invoice-badge{font-size:.9rem;padding:.15rem .4rem;border-radius:var(--radius-sm)}.card-header .invoice-badge.present{background:var(--success-bg)}.card-header .invoice-badge.missing{background:var(--warning-light);opacity:.6}.card-header .invoice-badge.error{background:var(--error-light);opacity:.8}.card-body{padding:1.25rem;display:flex;flex-direction:column;gap:.875rem;flex:1}.card-body .info-row{padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.card-body .info-row:last-child{border-bottom:none;padding-bottom:0}.card-footer{padding:.75rem 1rem;background:var(--bg-tertiary);border-top:1px solid var(--border-color)}.booking-groups-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.5rem 0}.booking-total{font-size:.875rem;color:var(--text-secondary)}.toolbar-actions{display:flex;gap:.5rem}.toolbar-btn{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:.3rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:border-color .2s,color .2s}.toolbar-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}.booking-groups{display:flex;flex-direction:column;gap:.5rem}.date-group{border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.date-group-header{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:var(--bg-tertiary);border:none;cursor:pointer;text-align:left;color:var(--text-primary);font-size:.95rem;font-weight:600;transition:background .15s}.date-group-header:hover{background:var(--bg-secondary)}.date-group-header .chevron{font-size:.85rem;color:var(--text-muted);width:1rem;text-align:center;flex-shrink:0}.date-group-header .date-label{flex:1}.date-group-header .group-count{background:var(--accent-primary);color:#fff;font-size:.75rem;font-weight:600;padding:.1rem .55rem;border-radius:999px;min-width:1.4rem;text-align:center}.booking-table{border-top:1px solid var(--border-color)}.booking-table-header{display:grid;grid-template-columns:2.5rem 1fr 1fr 1fr 1fr 4rem 5.5rem 5rem;gap:.25rem;padding:.4rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.bth-cell{font-size:.75rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bth-sortable{background:none;border:none;padding:0;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;font:inherit;color:inherit;text-transform:inherit;letter-spacing:inherit;font-weight:inherit;font-size:inherit;transition:color .15s ease}.bth-sortable:hover{color:var(--text-primary)}.bth-sortable.bth-sorted{color:var(--status-info)}.sort-arrow{font-size:.6rem;opacity:.4}.bth-sorted .sort-arrow{opacity:1}.bth-nights,.bth-total{text-align:right}.bth-sortable.bth-nights,.bth-sortable.bth-total{justify-content:flex-end}.booking-row{display:grid;grid-template-columns:2.5rem 1fr 1fr 1fr 1fr 4rem 5.5rem 5rem;gap:.25rem;padding:.55rem 1rem;text-decoration:none;color:var(--text-primary);border-bottom:1px solid var(--border-color);transition:background .12s;align-items:center}.booking-row:last-child{border-bottom:none}.booking-row:hover{background:var(--bg-tertiary)}.cell{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell-status{font-size:.9rem;text-align:center}.cell-conf{font-family:monospace;font-size:.8rem;color:var(--text-muted)}.cell-guest{font-weight:500}.cell-city,.cell-supplier{color:var(--text-secondary)}.cell-nights{text-align:right;color:var(--text-secondary)}.cell-total{text-align:right;font-weight:600;font-variant-numeric:tabular-nums}.cell-badges{display:flex;gap:.2rem;justify-content:flex-end}.row-badge{font-size:.75rem;opacity:.7}.row-badge.present{opacity:1;border-radius:20%;border:1px solid var(--success);background:var(--success-light);color:var(--success)}.row-badge.missing{border-radius:20%;border:1px solid var(--warning);background:var(--warning-light);color:var(--warning)}.row-badge.error{opacity:1;border-radius:20%;border:1px solid var(--error);background:var(--error-light);color:var(--error)}.info-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.info-row .label{color:var(--text-secondary);font-size:.875rem;min-width:140px}.info-row .value{color:var(--text-primary);font-weight:500;text-align:right;font-size:.875rem}.info-row .value.highlight{color:var(--accent-primary);font-weight:600;font-size:1.125rem}.info-row.invoice_match_details{padding-top:.75rem}.main-content{min-height:calc(100vh - 72px);padding-block:2rem}.page-header{margin-bottom:2rem}.page-header h1{margin-bottom:.5rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.page-header p{word-wrap:break-word;overflow-wrap:break-word}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(500px,100%),1fr));gap:1.5rem;margin-bottom:3rem}.recent-requests{border-radius:var(--radius-lg)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.section-header h2{font-size:1.25rem}.view-all{color:var(--accent-primary);font-weight:500;transition:color var(--dur-2) var(--ease)}.view-all:hover{color:var(--accent-hover)}.empty-state{text-align:center;padding:4rem 2rem;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;color:var(--text-primary)}.empty-state p{margin:0;color:var(--text-secondary)}.queue-info{background:var(--bg-secondary);padding:1rem 1.5rem;border-radius:var(--radius-md);margin-bottom:1.5rem;border:1px solid var(--border-color)}.queue-count{font-size:1.5rem;font-weight:600;color:var(--accent-primary)}.queue-list{display:flex;flex-direction:column;gap:.75rem}.queue-item{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color .2s ease}.queue-item:hover{border-color:var(--border-hover)}.queue-item-icon{font-size:1.5rem;flex-shrink:0}.queue-item-content{flex:1;min-width:0}.queue-item-subject{font-weight:500;color:var(--text-primary);margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.queue-item-meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.875rem;color:var(--text-secondary)}.queue-item-status{color:var(--text-muted)}.queue-hint{margin-top:2rem;padding:1rem 1.5rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:3px solid var(--accent-primary)}.queue-hint p{margin:0;color:var(--text-secondary);font-size:.875rem}.queue-hint a{color:var(--accent-primary)}.operations-page{padding:2rem;max-width:1200px;margin:0 auto}.operations-page h1{color:var(--text-primary);margin-bottom:.5rem}.page-description{color:var(--text-secondary);margin-bottom:2rem}.phases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem;margin-top:2rem}.phase-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color .2s,transform .2s}.phase-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.phase-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.phase-icon{font-size:1.5rem}.phase-header h2{color:var(--text-primary);font-size:1.1rem;margin:0;flex:1}.weight-badge{font-size:.7rem;padding:.2rem .5rem;border-radius:4px;text-transform:uppercase;font-weight:600}.weight-light{background:var(--success-light);color:var(--success)}.weight-medium{background:var(--warning-light);color:var(--warning)}.weight-heavy{background:var(--error-light);color:var(--error)}.phase-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin-bottom:1.5rem}.phase-actions{display:flex;flex-direction:column;gap:.75rem}.btn-trigger{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:#fff;border:none;padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;cursor:pointer;transition:opacity .2s,transform .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-trigger:hover:not(:disabled){opacity:.9;transform:scale(1.02)}.btn-trigger:disabled{opacity:.7;cursor:not-allowed}.btn-trigger .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;display:inline-block;margin:0}.phase-message{font-size:.85rem;padding:.5rem;border-radius:var(--radius-sm);background:var(--success-light);color:var(--success)}.phase-message.error{background:var(--error-light);color:var(--error)}.info-box{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem}.info-box h3{color:var(--text-primary);margin:0 0 1rem;font-size:1rem}.info-box ul{margin:0;padding-left:1.5rem;color:var(--text-secondary)}.info-box li{margin-bottom:.5rem;line-height:1.5}.info-box li strong{color:var(--text-muted)}.unmatched-section{margin-top:2rem}.unmatched-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.unmatched-header h2{color:var(--text-primary);margin:0;font-size:1.25rem}.unmatched-count{background:var(--accent-primary);color:#fff;font-size:.8rem;font-weight:600;padding:.15rem .6rem;border-radius:999px;min-width:1.5rem;text-align:center}.section-description{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem}.unmatched-loading{display:flex;align-items:center;gap:.75rem;padding:2rem;justify-content:center;color:var(--text-secondary)}.unmatched-error{padding:1rem 1.5rem;background:#dc35451a;border:1px solid rgba(220,53,69,.3);border-radius:var(--radius-md);color:#dc3545}.unmatched-empty{padding:2rem;text-align:center;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.unmatched-list{display:flex;flex-direction:column;gap:.5rem}.unmatched-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color .2s}.unmatched-item:hover{border-color:var(--border-hover)}.unmatched-item-icon{font-size:1.5rem;flex-shrink:0}.unmatched-item-content{flex:1;min-width:0}.unmatched-item-subject{font-weight:500;color:var(--text-primary);margin-bottom:.35rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unmatched-item-meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.825rem;color:var(--text-secondary)}.unmatched-item-actions{flex-shrink:0;display:flex;gap:.5rem;align-items:center}.btn-retry{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-hover) 100%);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;font-weight:500;transition:opacity .2s,transform .2s;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.btn-retry:hover:not(:disabled){opacity:.9;transform:scale(1.02)}.btn-retry:disabled{opacity:.7;cursor:not-allowed}.btn-retry .spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;display:inline-block;border-radius:50%;animation:spin .6s linear infinite}.unmatched-section.has-unmatched{border:2px solid var(--warning);border-radius:var(--radius-lg);padding:1.5rem;background:var(--warning-light)}.unmatched-section.has-unmatched .unmatched-count{background:var(--warning)}.duplicate-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.1rem .5rem;border-radius:999px;background:var(--warning-light);color:var(--warning);border:1px solid var(--warning);margin-left:.5rem;vertical-align:middle}.unmatched-item.unmatched-duplicate{border-color:var(--warning);background:var(--warning-light)}.failed-erp-section.has-unmatched{border-color:var(--status-error, #ef4444);background:var(--status-error-bg, rgba(239, 68, 68, .06))}.failed-erp-section.has-unmatched .unmatched-count.failed-erp-count{background:var(--status-error, #ef4444)}.erp-type-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.1rem .5rem;border-radius:999px;margin-right:.5rem;vertical-align:middle}.erp-type-booking{background:var(--status-info-bg, rgba(59, 130, 246, .1));color:var(--status-info, #3b82f6);border:1px solid var(--status-info, #3b82f6)}.erp-type-invoice{background:#8b5cf61a;color:#8b5cf6;border:1px solid #8b5cf6}.erp-error-msg{color:var(--status-error, #ef4444);font-size:.85rem;font-family:monospace}.spinner-sm{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.filters{margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem}.search-input{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;padding:.5rem;border-radius:var(--radius-md)}.search-input:focus-visible{border-color:var(--accent-primary)}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background-color var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease);font-weight:500}.filter-btn:hover{border-color:var(--border-hover)}.filter-btn.active{background:var(--status-info-bg);border-color:var(--status-info);color:var(--status-info)}.filter-btn.success.active{background:var(--status-success-bg);border-color:var(--status-success);color:var(--status-success)}.filter-btn.warning.active{background:var(--status-warn-bg);border-color:var(--status-warn);color:var(--status-warn)}.filter-btn.processing.active{background:var(--status-info-bg);border-color:var(--status-info);color:var(--status-info)}.filter-btn.error.active{background:var(--status-error-bg);border-color:var(--status-error);color:var(--status-error)}.filter-btn.price_mismatch.active{background:var(--warning-light);border-color:var(--warning);color:var(--warning)}.filter-btn.inv_present.active{background:var(--success-light);border-color:var(--success);color:var(--success)}.filter-btn.inv_missing.active{background:var(--warning-light);border-color:var(--warning);color:var(--warning)}.filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;height:1.4rem;padding:0 .35rem;margin-left:.35rem;border-radius:999px;font-size:.75rem;font-weight:700;line-height:1;background:#ffffff1f;color:inherit}.filter-btn.active .filter-count{background:#ffffff2e}.price-mismatch-indicator{font-size:.8rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color);flex-wrap:wrap;gap:1rem}.detail-header h1{margin:0 0 .5rem}.header-actions{display:flex;align-items:center;gap:1rem}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(400px,100%),1fr));gap:1.5rem}.json-viewer,.html-viewer{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem;overflow-x:auto}.json-viewer{background:var(--bg-primary)}.json-viewer pre{margin:0;color:var(--text-primary);font-size:.875rem;font-family:Courier New,monospace;line-height:1.4}.html-viewer{background:var(--bg-secondary);padding:1.5rem}.info-table th{background-color:var(--bg-secondary)!important}.version-details{margin-bottom:1rem;padding:1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.version-details summary{cursor:pointer;padding:.5rem;font-weight:500;display:flex;gap:.5rem;align-items:center;-webkit-user-select:none;user-select:none}.version-details summary:hover{background:var(--bg-hover);border-radius:var(--radius-sm)}.version-details[open] summary{margin-bottom:.5rem}.events-table-container{overflow:hidden}.events-table{width:100%;border-collapse:collapse}.events-table thead{background:var(--bg-tertiary)}.events-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.events-table tbody tr{border-top:1px solid var(--border-color);transition:background-color var(--dur-2) var(--ease)}.events-table tbody tr.clickable{cursor:pointer}.events-table tbody tr:hover{background:var(--bg-tertiary)}.events-table td{padding:1rem}.endpoint-badge{display:inline-block;padding:.25rem .75rem;background:var(--status-info-bg);color:var(--status-info);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.client-id{font-family:monospace;font-size:.875rem;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:grid;place-items:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);max-width:800px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:1.25rem}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:.25rem;transition:color var(--dur-2) var(--ease)}.close-btn:hover{color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.event-detail{display:flex;gap:1rem}.event-detail.full{flex-direction:column}.event-detail strong{min-width:120px;color:var(--text-secondary)}.logs-header{padding:1rem 1.5rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);font-size:.875rem;color:var(--text-secondary);font-weight:500}.logs-list{max-height:70vh;overflow-y:auto}.log-entry{padding:.75rem 1.5rem;border-bottom:1px solid var(--border-color);transition:background-color var(--dur-2) var(--ease)}.log-entry:last-child{border-bottom:none}.log-entry:hover{background:var(--bg-tertiary)}.log-entry.error{background:var(--status-error-bg);border-left:3px solid var(--status-error)}.log-entry.warning{background:var(--status-warn-bg);border-left:3px solid var(--status-warn)}.log-entry.info{border-left:3px solid var(--status-info)}.log-entry pre{margin:0;font-family:Courier New,monospace;font-size:.875rem;color:var(--text-primary);white-space:pre-wrap;word-wrap:break-word}.navbar{background:linear-gradient(135deg,var(--bg-secondary) 0%,#1e2536 100%);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;box-shadow:0 4px 12px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navbar-container{max-width:1400px;margin-inline:auto;padding-inline:1.5rem;display:flex;align-items:center;justify-content:space-between;height:72px;gap:2rem}.navbar-brand{cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:transform var(--dur-2) var(--ease)}.navbar-brand:hover{transform:scale(1.02)}.logo{font-size:1.5rem}.navbar-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-tertiary) 100%);border-radius:var(--radius-md);padding:.5rem;border:1px solid var(--border-color);transition:all var(--dur-2) var(--ease)}.navbar-icon:hover{border-color:var(--accent-primary);box-shadow:0 0 12px #3b82f64d}.navbar-icon img{width:100%;height:100%;object-fit:contain}.navbar-brand h1{font-size:1.3rem;font-weight:600;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-primary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.navbar-menu{display:flex;gap:.25rem;flex:1;justify-content:center;padding:0 2rem}.navbar-menu a{padding:.75rem 1.25rem;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;font-size:.95rem;transition:all var(--dur-2) var(--ease);position:relative;display:flex;align-items:center;gap:.5rem}.navbar-menu a:before{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%) scaleX(0);width:80%;height:2px;background:var(--accent-primary);transition:transform var(--dur-2) var(--ease);border-radius:2px}.navbar-menu a:hover{color:var(--text-primary);background:#3b82f614;transform:translateY(-2px)}.navbar-menu a:hover:before{transform:translate(-50%) scaleX(1)}.navbar-menu a.active{color:var(--accent-primary);background:var(--accent-light);box-shadow:0 0 16px #3b82f633}.navbar-menu a.active:before{transform:translate(-50%) scaleX(1)}.navbar-user{display:flex;align-items:center;gap:.75rem}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-lg);transition:all var(--dur-2) var(--ease)}.user-info:hover{background:#3b82f61f;border-color:var(--accent-primary);box-shadow:0 0 12px #3b82f64d}.user-icon{font-size:1.5rem;width:36px;height:36px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent-primary) 0%,#2563eb 100%);border-radius:50%;box-shadow:0 2px 8px #3b82f64d}.user-details{display:flex;flex-direction:column;gap:.1rem}.user-name{font-weight:600;font-size:.95rem;line-height:1.2;color:var(--text-primary)}.user-role{font-size:.75rem;color:var(--accent-primary);line-height:1.2;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.btn-logout{padding:.65rem 1.25rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:600;cursor:pointer;transition:all var(--dur-2) var(--ease);box-shadow:0 2px 8px #ef44444d;font-size:.9rem}.btn-logout:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.btn-logout:active{transform:translateY(0)}.mobile-menu-button{display:none;background:var(--bg-tertiary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:background-color var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease)}.mobile-menu-button:hover{background:var(--bg-hover);border-color:var(--border-hover)}.menu-icon{font-size:1.5rem;line-height:1}.mobile-menu-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:150}.mobile-menu{display:none;position:fixed;top:64px;right:0;width:280px;max-width:85vw;height:calc(100vh - 64px);background:var(--bg-secondary);border-left:1px solid var(--border-color);box-shadow:var(--shadow-lg);z-index:200;overflow-y:auto}.mobile-menu-header{padding:1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.mobile-user-info{display:flex;align-items:center;gap:.75rem}.mobile-user-icon{font-size:2rem;width:48px;height:48px;display:grid;place-items:center;background:var(--bg-secondary);border-radius:50%;border:2px solid var(--border-color)}.mobile-user-name{font-weight:600;font-size:1rem;color:var(--text-primary)}.mobile-user-role{font-size:.875rem;color:var(--text-muted)}.mobile-menu-items{padding:.5rem}.mobile-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color var(--dur-2) var(--ease),color var(--dur-2) var(--ease);text-align:left;margin-bottom:.25rem}.mobile-menu-item:hover{background:var(--bg-tertiary)}.mobile-menu-item.active{background:var(--accent-light);color:var(--accent-primary)}.menu-item-icon{font-size:1.25rem;width:32px;display:grid;place-items:center}.mobile-menu-footer{padding:1rem;border-top:1px solid var(--border-color)}.mobile-logout-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;background:var(--error);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:1rem;cursor:pointer;transition:background-color var(--dur-2) var(--ease)}.mobile-logout-button:hover{background:#dc2626}.desktop-only{display:flex}.mobile-only{display:none}.navbar-brand{cursor:pointer;transition:opacity .2s ease;flex-shrink:1;min-width:0}.navbar-brand h1{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-brand:hover{opacity:.8}.navbar-user{position:relative;min-width:220px}.navbar-user .user-info{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;width:100%;background:transparent;border:1px solid rgba(59,130,246,.2);cursor:pointer;transition:all .2s ease;border-radius:12px;color:var(--text-primary);font-family:inherit}.navbar-user .user-info:hover{background:#3b82f614;border-color:#3b82f666;box-shadow:0 0 12px #3b82f633}.navbar-user .user-info[aria-expanded=true]{background:#3b82f61f;border-color:var(--accent-primary);box-shadow:0 0 12px #3b82f64d}.dropdown-arrow{font-size:.7rem;margin-left:auto;transition:transform .2s ease;color:var(--accent-primary)}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;left:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 25px #00000080;overflow:hidden;z-index:1000;animation:slideDown .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;background:transparent;border:none;cursor:pointer;transition:all .2s ease;color:var(--text-primary);font-size:.95rem;text-align:left;font-family:inherit;font-weight:500}.dropdown-item:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.dropdown-item:not(:last-child){border-bottom:1px solid var(--border-color)}.dropdown-item.logout{color:#ef4444}.dropdown-item.logout:hover{background:#ef44441a;color:#ef4444}.dropdown-item.bookings:hover{background:#3b82f61a;color:var(--accent-primary)}.dropdown-icon{font-size:1.1rem;width:24px;display:flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:grid;place-items:center;z-index:2000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #0009;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:var(--bg-tertiary)}.modal-header h2{font-size:1.25rem;margin:0;color:var(--text-primary)}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:.25rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;font-family:inherit}.close-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.modal-large{max-width:700px}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--text-secondary);gap:1rem}.users-table{overflow-x:auto;margin-bottom:1rem}.users-table table{width:100%;border-collapse:collapse}.users-table thead{background:var(--bg-tertiary)}.users-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}.users-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.users-table tbody tr:hover{background:var(--bg-tertiary)}.users-table tbody tr.current-user{background:#3b82f60d}.users-table td{padding:1rem;color:var(--text-primary)}.username-cell{display:flex;align-items:center;gap:.5rem}.username-text{font-weight:500;font-family:monospace}.current-badge{background:var(--accent-primary);color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase}.super-admin-badge{display:inline-block;font-size:.875rem;margin-left:.5rem;animation:pulse 2s ease-in-out infinite;cursor:help}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.role-badge.role-admin{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.role-badge.role-manager{background:#f59e0b1a;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.role-badge.role-user{background:#3b82f61a;color:var(--accent-primary);border:1px solid rgba(59,130,246,.3)}.role-selector{display:flex;align-items:center;gap:.5rem}.role-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;min-width:140px}.role-select option{background:var(--bg-secondary);color:var(--text-primary);padding:.5rem}.role-select:hover{border-color:var(--accent-primary)}.role-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.role-select:disabled{opacity:.5;cursor:not-allowed}.role-select.role-admin{border-color:#ef44444d;background:#ef44440d}.role-select.role-manager{border-color:#f59e0b4d;background:#f59e0b0d}.role-select.role-user{border-color:#3b82f64d;background:#3b82f60d}.role-changing{font-size:1rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-delete{padding:.5rem 1rem;background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit;display:inline-flex;align-items:center;gap:.25rem}.btn-delete:hover{background:#ef44441a;border-color:#ef4444}.btn-delete:disabled{opacity:.6;cursor:not-allowed}.btn-delete-invoice{padding:.625rem 1.25rem;background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;display:inline-flex;align-items:center;gap:.25rem}.btn-delete-invoice:hover{background:#ef44441a;border-color:#ef4444}.btn-delete-invoice:disabled{opacity:.6;cursor:not-allowed}.btn-manual-match{padding:.625rem 1.25rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:opacity .2s,transform .1s;white-space:nowrap}.btn-manual-match:hover{opacity:.9;transform:scale(1.02)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;cursor:default}.match-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1001;background:var(--bg-secondary, #1e2130);border:1px solid var(--border-color, rgba(255,255,255,.1));border-radius:16px;width:90vw;max-width:1100px;height:85vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #00000080;overflow:hidden}.match-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, rgba(255,255,255,.1));flex-shrink:0}.match-dialog-header h2{margin:0;font-size:1.1rem;font-weight:600}.btn-close{background:none;border:none;color:var(--text-secondary, #9ca3af);font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:background .15s}.btn-close:hover{background:#ffffff1a;color:#fff}.match-dialog-body{display:flex;flex:1;overflow:hidden}.match-dialog-preview{flex:0 0 58%;display:flex;flex-direction:column;border-right:1px solid var(--border-color, rgba(255,255,255,.1));padding:1rem;gap:.75rem;overflow:hidden}.preview-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #9ca3af);flex-shrink:0}.invoice-iframe{flex:1;width:100%;border:none;border-radius:8px;background:#fff;min-height:0}.preview-actions{flex-shrink:0;text-align:right}.btn-open-new{font-size:.8rem;color:var(--accent-primary, #3b82f6);text-decoration:none}.btn-open-new:hover{text-decoration:underline}.match-dialog-form{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.form-section{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.825rem;font-weight:600;color:var(--text-secondary, #9ca3af)}.required{color:#ef4444}.form-select,.form-input{width:100%;padding:.55rem .75rem;background:var(--bg-primary, #0f1117);border:1px solid var(--border-color, rgba(255,255,255,.12));border-radius:8px;color:var(--text-primary, #e2e8f0);font-size:.875rem;outline:none;box-sizing:border-box}.form-select:focus,.form-input:focus{border-color:var(--accent-primary, #3b82f6)}.form-loading{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary, #9ca3af)}.form-empty{font-size:.85rem;color:var(--text-secondary, #9ca3af);margin:0}.booking-details{margin-top:.5rem;background:#ffffff0a;border:1px solid var(--border-color, rgba(255,255,255,.08));border-radius:8px;padding:.75rem;display:flex;flex-direction:column;gap:.35rem}.booking-detail-row{display:flex;justify-content:space-between;font-size:.8rem;gap:.5rem}.booking-detail-row span:first-child{color:var(--text-secondary, #9ca3af);flex-shrink:0}.booking-detail-row .amount{font-weight:600;color:var(--accent-primary, #3b82f6)}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer}.collapsible-toggle{background:none;border:1px solid var(--border-color, rgba(255,255,255,.12));border-radius:8px;color:var(--text-secondary, #9ca3af);padding:.5rem .75rem;font-size:.825rem;cursor:pointer;text-align:left;width:100%;transition:background .15s}.collapsible-toggle:hover{background:#ffffff0f}.creditor-fields{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.input-row{display:flex;gap:.5rem}.match-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;border-radius:8px;padding:.75rem;font-size:.85rem}.match-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#86efac;border-radius:8px;padding:1rem;font-size:.9rem;text-align:center}.btn-submit-match{padding:.75rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:opacity .2s;margin-top:auto}.btn-submit-match:hover:not(:disabled){opacity:.9}.btn-submit-match:disabled{opacity:.5;cursor:not-allowed}.btn-reclassify{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;font-size:.8rem;border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:pointer;transition:all .15s ease;background:var(--bg-tertiary);color:var(--text-primary)}.btn-reclassify-confirmation{border-color:var(--success);color:var(--success)}.btn-reclassify-confirmation:hover:not(:disabled){background:var(--success-light)}.btn-reclassify-invoice{border-color:var(--accent-primary);color:var(--accent-primary)}.btn-reclassify-invoice:hover:not(:disabled){background:var(--accent-light)}.btn-reclassify:disabled{opacity:.6;cursor:not-allowed}.other-email-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .2s}.other-email-wrapper:hover{border-color:var(--border-hover)}.other-email-wrapper .unmatched-item.other-email-expandable{border:none;border-radius:0}.other-email-header{display:flex;align-items:center;gap:1rem;cursor:pointer;flex:1;min-width:0}.other-email-chevron{font-size:.75rem;color:var(--text-secondary);transition:transform .2s;flex-shrink:0}.other-email-chevron.rotated{transform:rotate(90deg)}.other-email-details{border-top:1px solid var(--border-color);padding:1rem 1.25rem;background:var(--bg-secondary, #f8f9fa);display:flex;flex-direction:column;gap:1rem}.other-email-details-section{display:flex;flex-direction:column;gap:.35rem}.other-email-details-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.other-email-details-body{font-size:.875rem;color:var(--text-primary);line-height:1.5;max-height:300px;overflow-y:auto;padding:.75rem;background:var(--bg-primary, #fff);border:1px solid var(--border-color);border-radius:var(--radius-md, 6px);word-break:break-word}.other-email-details-body img{max-width:100%;height:auto}.other-email-attachment-item{font-size:.875rem;color:var(--text-primary);padding:.5rem .75rem;background:var(--bg-primary, #fff);border:1px solid var(--border-color);border-radius:var(--radius-md, 6px)}.pending-badge{display:inline-block;padding:.125rem .5rem;font-size:.7rem;border-radius:9999px;font-weight:600;margin-left:.5rem;vertical-align:middle}.pending-badge-invoice{background:var(--accent-light);color:var(--accent-primary);border:1px solid var(--accent-primary)}.pending-badge-confirmation{background:var(--success-light);color:var(--success);border:1px solid var(--success)}.pending-info{font-size:.8rem;color:var(--text-muted);font-style:italic}.alert-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap;align-items:center}.alert-actions .btn-accept-mismatch{margin-top:0}.btn-cancel{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;font-family:inherit;transition:all .2s ease}.btn-cancel:hover{background:var(--bg-hover)}.dialog-footer{display:flex;justify-content:flex-end;padding-top:1rem;margin-top:1rem;border-top:1px solid var(--border-color)}.add-user-section{margin-bottom:1.5rem}.btn-add-user{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-family:inherit;width:100%;justify-content:center}.btn-add-user:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.add-user-form-container{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.form-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.form-section-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.btn-cancel-form{background:none;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;padding:.25rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease;font-family:inherit}.btn-cancel-form:hover{color:var(--text-primary);background:var(--bg-hover)}.add-user-form{margin-top:1rem}.form-row-inline{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;align-items:end}.form-actions-inline{display:flex;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.modal-change-password{max-width:350px}.change-password-form{display:flex;flex-direction:column;align-items:center;width:100%}.change-password-form .form-row-inline{display:flex;flex-direction:column;width:100%;padding:0 1.5rem}.change-password-form .form-group{width:100%}.change-password-form .form-actions-inline{justify-content:center;width:100%;margin-left:-1.5rem;margin-right:-1.5rem;padding-left:1.5rem;padding-right:1.5rem;box-sizing:content-box}.force-change-overlay{z-index:10000;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-force-password{max-width:500px;border:2px solid var(--warning);box-shadow:0 20px 60px #00000080}.modal-force-password .modal-header{background:#f59e0b1a;border-bottom:2px solid rgba(245,158,11,.3)}.modal-force-password .modal-header h2{color:var(--warning)}.force-password-form{display:flex;flex-direction:column;gap:1.25rem;width:100%}.force-password-form .form-group{display:flex;flex-direction:column;gap:.5rem}.force-password-form .form-actions{display:flex;justify-content:center;padding-top:.5rem}.force-password-form small{font-size:.8rem;margin-top:-.25rem}.btn-submit{padding:.75rem 1.5rem;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-family:inherit;white-space:nowrap}.btn-submit:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.skillz-ai-logo{margin:0 auto 1rem;padding-top:1rem;width:20%}.login-container{min-height:100vh;display:grid;place-items:center;padding:1rem;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.login-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.75rem;margin-bottom:.5rem}.login-icon{width:100px;height:100px;margin:0 auto 1rem;border-radius:50%;overflow:hidden;background:var(--bg-primary);border:3px solid var(--border-color);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;transition:all .3s ease}.login-icon:hover{transform:scale(1.05);box-shadow:var(--shadow-lg);border-color:var(--accent-primary)}.login-icon img{width:100%;height:100%;object-fit:contain;padding:.5rem}@media (max-width: 480px){.login-icon{width:60px;height:60px;margin:0 auto .75rem}.login-header h1{font-size:1.5rem}}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-footer{margin-top:1.5rem;text-align:center}.login-footer p{font-size:.75rem}.invoice-preview-container{width:100%;height:400px;margin:1rem 0;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-tertiary)}.invoice-preview{width:100%;height:100%;border:none}.invoice-preview-image{width:100%;height:100%;object-fit:contain;background:var(--bg-secondary)}.invoice-word-preview{display:flex;align-items:center;gap:1.25rem;padding:2rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin:1rem 0}.invoice-word-preview .word-icon{font-size:3.5rem;line-height:1}.invoice-word-preview .word-info{flex:1}.invoice-word-preview .word-filename{font-weight:600;font-size:1rem;color:var(--text-primary);margin:0 0 .25rem;word-break:break-all}.invoice-word-preview .word-hint{font-size:.85rem;color:var(--text-muted);margin:0}.invoice-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.btn-download,.btn-view{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:var(--radius-md);font-weight:500;font-size:.9rem;text-decoration:none;transition:all var(--dur-2) var(--ease);cursor:pointer}.btn-download{background:var(--accent-primary);color:#fff;border:none}.btn-download:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-md);color:#fff}.invoice-badge{padding:.375rem .875rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;border:1px solid transparent}.invoice-badge.present{color:var(--success);background:var(--success-light);border-color:var(--success)}.invoice-badge.missing{color:var(--warning);background:var(--warning-light);border-color:var(--warning)}.invoice-badge.error{color:var(--error);background:var(--error);border-color:var(--error)}.price-badge{padding:.375rem .875rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;border:1px solid transparent}.price-badge.match{color:var(--success);background:var(--success-light);border-color:var(--success)}.price-badge.mismatch{color:var(--error);background:var(--error-light, rgba(255, 77, 77, .1));border-color:var(--error)}.price-badge.unchecked{color:var(--text-muted);background:var(--bg-tertiary);border-color:var(--border-color)}.price-mismatch-alert{margin-top:1rem;padding:1rem;background:var(--error-light, rgba(255, 77, 77, .1));border:1px solid var(--error);border-radius:var(--radius-md);color:var(--error)}.price-mismatch-alert strong{display:block;margin-bottom:.5rem}.price-mismatch-alert p{margin:0;font-size:.9rem}.invoice-present,.invoice-missing{display:flex;flex-direction:column}.email-details{margin-bottom:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-tertiary);transition:all var(--dur-2) var(--ease)}.email-details:hover{box-shadow:var(--shadow-sm);border-color:var(--border-hover)}.email-details[open]{border-color:var(--accent-primary);box-shadow:var(--shadow-md)}.email-summary{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(to right,var(--bg-secondary),var(--bg-tertiary));cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--dur-2) var(--ease);gap:1rem}.email-summary:hover{background:linear-gradient(to right,var(--bg-hover),var(--bg-secondary))}.email-details[open] .email-summary{background:linear-gradient(to right,rgba(59,130,246,.15),var(--bg-secondary));border-bottom:1px solid var(--border-color)}.email-summary-left{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.email-icon{font-size:1.25rem;flex-shrink:0}.email-subject{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.email-date{font-size:.9rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.follow-up-badge{color:var(--warning);font-weight:600;margin-left:.5rem}.email-content{padding:1.5rem;background:var(--bg-primary)}.email-meta{background:var(--bg-secondary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.25rem;border:1px solid var(--border-color)}.email-meta-row{display:flex;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.email-meta-row:last-child{border-bottom:none;padding-bottom:0}.email-meta-row:first-child{padding-top:0}.email-meta-label{font-weight:600;color:var(--text-secondary);min-width:120px;flex-shrink:0}.email-meta-value{color:var(--text-primary);word-break:break-word}.email-body-container{background:var(--bg-secondary);border-radius:var(--radius-md);padding:1rem;border:1px solid var(--border-color)}.email-body-label{font-weight:600;color:var(--text-secondary);margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:2px solid var(--border-color)}.email-body-content{max-height:500px;overflow-y:auto;font-size:.95rem;line-height:1.6;color:var(--text-primary);padding:.5rem 0}.email-body-content :global(p){margin:0 0 .75rem}.email-body-content :global(table){width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9rem}.email-body-content :global(td),.email-body-content :global(th){padding:.5rem;border:1px solid var(--border-color)}.email-body-content :global(th){background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary)}.email-body-content :global(a){color:var(--accent-primary);text-decoration:none}.email-body-content :global(a:hover){text-decoration:underline;color:var(--accent-hover)}.email-body-content::-webkit-scrollbar{width:8px}.email-body-content::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.email-body-content::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:4px}.email-body-content::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}}@layer utilities{.timestamp{font-size:.75rem;color:var(--text-muted);font-family:monospace}}@layer responsive{@media (max-width: 768px){.main-content{padding-block:1rem}.operations-page{padding:1rem}.phases-grid{grid-template-columns:1fr}.unmatched-item{flex-direction:column;align-items:flex-start}.unmatched-item-actions{width:100%}.btn-retry{width:100%;justify-content:center}.unmatched-item-meta{flex-direction:column;gap:.25rem}.other-email-header{flex-wrap:wrap}.other-email-details-body{max-height:200px}.desktop-only{display:none!important}.mobile-only,.mobile-menu-button,.mobile-menu-overlay{display:block}.mobile-menu{display:flex;flex-direction:column}.stats-grid,.requests-grid,.detail-grid{grid-template-columns:1fr}.booking-table-header,.booking-row{grid-template-columns:2.5rem 1fr 1fr 1fr 4rem 5rem 4rem}.bth-supplier,.cell-supplier{display:none}.request-details{display:flex;flex-direction:column;gap:.25rem}.separator{display:none}.events-table-container{overflow-x:auto}.events-table{min-width:600px}.container{padding-inline:.5rem;max-width:100vw}.detail-card{padding:1rem;overflow-wrap:break-word;word-wrap:break-word}.detail-header{flex-direction:column;gap:.5rem}.header-actions{width:100%;flex-wrap:wrap}.info-row{flex-direction:column;align-items:flex-start;gap:.25rem}.info-row .label{min-width:auto;font-weight:600}.info-row .value{text-align:left}.form-row{grid-template-columns:1fr;gap:.75rem}.form-actions{flex-direction:column}.form-actions button{width:100%}.json-viewer,.html-viewer{overflow-x:auto;max-width:100%}.json-viewer pre{font-size:.75rem;white-space:pre-wrap;word-wrap:break-word}.breadcrumb{flex-wrap:wrap;font-size:.75rem;margin-bottom:1rem}.status-badge{font-size:.7rem;padding:.2rem .5rem}.detail-header h1{font-size:1.5rem;word-break:break-word}}@media (max-width: 768px){.form-row-inline{grid-template-columns:1fr}.form-actions-inline{justify-content:stretch}.btn-submit{width:100%}.email-summary{flex-direction:column;align-items:flex-start;gap:.5rem}.email-date{font-size:.85rem}.email-meta-label{min-width:100px}}@media (max-width: 612px){.detail-card{max-width:97vw!important}}@media (max-width: 480px){.container{padding-inline:.5rem;max-width:100vw;overflow-x:hidden}.detail-card{padding:.75rem;max-width:95vw!important}.detail-card h3{font-size:1rem}.detail-header h1{font-size:1.25rem}.navbar-container{padding-inline:.75rem;height:64px;gap:.5rem}.navbar{background:var(--bg-secondary);box-shadow:var(--shadow-sm)}.navbar-brand{min-width:0;flex:1}.navbar-brand h1{font-size:1rem;background:none;-webkit-text-fill-color:var(--text-primary)}.navbar-icon{width:40px;height:40px;background:transparent;border:none;padding:.25rem}.navbar-icon:hover{box-shadow:none;border-color:transparent}.navbar-user{min-width:auto;max-width:none}.btn-primary,.btn-secondary{padding:.75rem 1rem;font-size:.9rem}.page-header h1{font-size:1.5rem}.page-header p{font-size:.875rem}h1{font-size:1.5rem}h2{font-size:1.25rem}.booking-table-header{grid-template-columns:2rem 1fr 1fr 4rem 4.5rem 3.5rem;font-size:.7rem;padding:.3rem .5rem}.booking-row{grid-template-columns:2rem 1fr 1fr 4rem 4.5rem 3.5rem;padding:.5rem}.bth-supplier,.cell-supplier,.bth-city,.cell-city{display:none}.cell{font-size:.8rem}.date-group-header{padding:.6rem .75rem;font-size:.85rem}.booking-groups-toolbar{flex-direction:column;gap:.5rem;align-items:flex-start}*{word-wrap:break-word;overflow-wrap:break-word}}}
