:root{--color-dark-blue:#00175a;--color-bright-blue:#006fcf;--color-bg-light-blue:#e8f0f9;--color-bg-white:#fff;--color-green:#28cd6e;--color-amber:#ffcb1b;--color-gray-mid:#626262;--font-primary:"DM Sans", sans-serif;--font-mono:"DM Mono", monospace;--radius-btn:1.5rem;--transition-btn:transform .5s cubic-bezier(.61,1,.88,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-primary);color:var(--color-dark-blue);background:var(--color-bg-light-blue);-webkit-font-smoothing:antialiased;flex-direction:column;min-height:100vh;font-size:14px;line-height:1.5;display:flex}a{color:var(--color-bright-blue);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{font-weight:600;line-height:1.2}#root{flex-direction:column;min-height:100vh;display:flex}.nav{background:var(--color-dark-blue);border-bottom:1px solid #ffffff1a;flex-shrink:0;align-items:center;gap:20px;height:80px;padding:0 40px;display:flex}.nav-logo{align-items:center;gap:14px;text-decoration:none;display:flex}.nav-logo:hover{text-decoration:none}.nav-logo-img{width:auto;height:60px}.nav-divider{background:#ffffff40;flex-shrink:0;width:1px;height:24px}.nav-label{color:#ffffffb3;font-size:14px;font-weight:400}.nav-spacer{flex:1}.nav-user-name{color:#ffffff80;font-size:13px}.nav-badge{color:#fff;letter-spacing:.06em;text-transform:uppercase;background:#ffffff1f;border-radius:99px;margin-left:12px;padding:4px 12px;font-size:12px;font-weight:600}.nav-sign-out{color:#ffffff8c;margin-left:20px;font-size:13px;text-decoration:none}.nav-sign-out:hover{color:#ffffffd9;text-decoration:none}.tab-nav{background:var(--color-dark-blue);border-top:1px solid #ffffff14;flex-shrink:0;gap:2px;padding:0 40px;display:flex}.tab-link{color:#ffffff8c;letter-spacing:.02em;white-space:nowrap;border-bottom:3px solid #0000;padding:12px 18px;font-size:13px;font-weight:600;text-decoration:none;transition:color .15s}.tab-link:hover{color:#ffffffd9;text-decoration:none}.tab-link.active{color:#fff;border-bottom-color:var(--color-bright-blue)}.tab-count{background:var(--color-amber);color:#5a3d00;border-radius:99px;margin-left:6px;padding:1px 7px;font-size:11px;font-weight:700}.main-content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:48px 24px 80px}.main-content-900{flex:1;width:100%;max-width:900px;margin:0 auto;padding:52px 24px 80px}.main-content-wide{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:40px 24px 80px}.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--color-bright-blue);margin-bottom:10px;font-size:13px;font-weight:600}.page-title{letter-spacing:-.045em;color:var(--color-dark-blue);margin-bottom:40px;font-size:42px;font-weight:600;line-height:1.1}.page-title-sm{letter-spacing:-.04em;color:var(--color-dark-blue);margin-bottom:8px;font-size:36px;font-weight:600;line-height:1.1}.page-sub{color:var(--color-gray-mid);margin-bottom:28px;font-size:15px;line-height:1.6}.page-subtitle{color:var(--color-gray-mid);margin-bottom:40px;font-size:18px;line-height:1.6}.page-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:28px;display:flex}.card{background:var(--color-bg-white);border:1px solid #00000012;border-radius:16px;margin-bottom:24px;padding:32px}.card-title{color:var(--color-dark-blue);border-bottom:1px solid #00000012;margin-bottom:24px;padding-bottom:20px;font-size:20px;font-weight:600}.card-header{border-bottom:1px solid #00000012;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:20px;display:flex}.btn{border-radius:var(--radius-btn);font-family:var(--font-primary);cursor:pointer;transition:var(--transition-btn);white-space:nowrap;border:none;align-items:center;gap:8px;padding:1rem 2.625rem;font-size:16px;font-weight:600;line-height:1;text-decoration:none;display:inline-flex}.btn:hover:not(:disabled){text-decoration:none;transform:scale(1.04)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-bright-blue);color:#fff}.btn-dark{background:var(--color-dark-blue);color:#fff}.btn-outline{color:var(--color-bright-blue);border:2px solid var(--color-bright-blue);background:0 0}.btn-outline-dark{color:var(--color-dark-blue);background:0 0;border:1.5px solid #0003}.btn-danger{color:#c00;background:0 0;border:1.5px solid #fcc}.btn-danger:hover:not(:disabled){background:#fef0f0;transform:none}.btn-ghost{color:#ffffff8c;background:0 0;border:none}.btn-ghost:hover:not(:disabled){color:#fff;transform:none}.btn-sm{height:34px;font-family:var(--font-primary);cursor:pointer;white-space:nowrap;transition:var(--transition-btn);border:none;border-radius:99px;align-items:center;gap:6px;padding:0 14px;font-size:12px;font-weight:600;display:inline-flex}.btn-sm:hover:not(:disabled){transform:scale(1.04)}.btn-sm:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm-primary{background:var(--color-bright-blue);color:#fff}.btn-sm-outline{color:var(--color-dark-blue);background:0 0;border:1.5px solid #0003}.btn-sm-danger{color:#c00;background:0 0;border:1.5px solid #fcc}.btn-sm-danger:hover:not(:disabled){background:#fef0f0;transform:none}.btn-sm-green{color:#0d6e3a;border:1.5px solid var(--color-green);background:0 0}.btn-sm-gray{color:#888;background:0 0;border:1.5px solid #ddd}.btn-compact{border-radius:var(--radius-btn);height:52px;font-family:var(--font-primary);cursor:pointer;transition:var(--transition-btn);white-space:nowrap;border:none;align-items:center;gap:8px;padding:0 2rem;font-size:15px;font-weight:600;display:inline-flex}.btn-compact:hover:not(:disabled){transform:scale(1.04)}.btn-compact:disabled{opacity:.5;cursor:not-allowed}.btn-compact-primary{background:var(--color-bright-blue);color:#fff}.btn-compact-dark{background:var(--color-dark-blue);color:#fff}.btn-arrow{flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin;display:none}.btn.loading .spinner{display:block}.btn.loading .btn-arrow{display:none}.btn-compact.loading .spinner{display:block}.btn-compact.loading .btn-arrow{display:none}.input-field{height:52px;font-family:var(--font-primary);color:var(--color-dark-blue);background:#fff;border:1.5px solid #00000026;border-radius:10px;outline:none;flex:1;width:100%;padding:0 18px;font-size:16px;transition:border-color .2s}.input-field:focus{border-color:var(--color-bright-blue)}.input-field::placeholder{color:#aaa}textarea.input-field{resize:vertical;height:auto;padding:14px 18px;font-size:14px;line-height:1.6}.input-row{align-items:center;gap:12px;display:flex}.field{margin-bottom:18px}.field label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-gray-mid);margin-bottom:7px;font-size:12px;font-weight:600;display:block}.filter-select{height:38px;font-family:var(--font-primary);color:var(--color-dark-blue);cursor:pointer;background:#fff;border:1.5px solid #00000026;border-radius:99px;outline:none;padding:0 14px;font-size:13px;font-weight:600}.filter-select:focus{border-color:var(--color-bright-blue)}.result-box{border-radius:10px;margin-top:20px;padding:20px 24px;display:none}.result-box.visible{display:block}.result-box-success{background:#ebf5ff;border:1px solid #006fcf40}.result-box-error{background:#fef0f0;border:1px solid #fccaca}.result-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-gray-mid);margin-bottom:8px;font-size:12px;font-weight:600}.result-link-row{align-items:center;gap:10px;display:flex}.result-link-text{color:var(--color-bright-blue);word-break:break-all;flex:1;font-size:15px;font-weight:600}.copy-btn{background:var(--color-dark-blue);color:#fff;font-family:var(--font-primary);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:600;transition:opacity .2s}.copy-btn:hover{opacity:.85}.error-msg{color:#b00;background:#fef0f0;border:1px solid #fccaca;border-radius:8px;margin-bottom:20px;padding:11px 14px;font-size:14px;font-weight:600}.reused-badge{border:1px solid var(--color-amber);color:#7a5c00;background:#fff8e1;border-radius:6px;margin-top:10px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.status-result{margin-top:20px;display:none}.status-result.visible{display:block}.status-header{background:var(--color-dark-blue);color:#fff;border-radius:12px 12px 0 0;padding:20px 24px}.status-hotel{margin-bottom:4px;font-size:20px;font-weight:600}.status-meta{color:#ffffffa6;font-size:14px}.status-body{background:#fff;border:1px solid #00000012;border-top:none;border-radius:0 0 12px 12px}.link-row{border-bottom:1px solid #0000000f;align-items:center;gap:16px;padding:16px 24px;display:flex}.link-row:last-child{border-bottom:none}.status-pill{letter-spacing:.04em;text-transform:uppercase;border-radius:99px;flex-shrink:0;padding:4px 12px;font-size:12px;font-weight:700}.pill-pending{color:#7a5c00;border:1px solid var(--color-amber);background:#fff8e1}.link-detail{flex:1;min-width:0}.link-url{color:var(--color-bright-blue);text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px;font-size:13px;font-weight:600;display:block;overflow:hidden}.link-dates{color:var(--color-gray-mid);font-size:12px}.link-amount{text-align:right;flex-shrink:0}.amount-val{color:var(--color-dark-blue);font-size:18px;font-weight:600}.amount-conf{color:var(--color-gray-mid);font-size:11px}.no-links{text-align:center;color:var(--color-gray-mid);padding:24px;font-size:15px}.event-summary{background:#ebf5ff;border:1px solid #006fcf40;border-radius:10px;margin-top:20px;padding:20px 24px;display:none}.event-summary.visible{display:block}.event-summary-title{color:var(--color-dark-blue);margin-bottom:3px;font-size:16px;font-weight:600}.event-summary-meta{color:var(--color-gray-mid);margin-bottom:14px;font-size:13px}.event-link-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.event-link-text{color:var(--color-bright-blue);word-break:break-all;flex:1;font-size:14px;font-weight:600}.conf-count{color:var(--color-gray-mid);min-height:18px;margin-top:6px;font-size:12px}.guest-chips{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.guest-chip{color:var(--color-dark-blue);background:#fff;border:1px solid #006fcf33;border-radius:6px;padding:5px 12px;font-size:13px}.guest-chip span{color:var(--color-gray-mid);margin-top:1px;font-size:11px;display:block}.stats-bar{grid-template-columns:repeat(4,1fr);gap:16px;max-width:900px;margin-bottom:28px;display:grid}.stat-card{background:#fff;border:1px solid #00000012;border-radius:12px;padding:20px 24px}.stat-value{letter-spacing:-.04em;color:var(--color-dark-blue);margin-bottom:4px;font-size:32px;font-weight:700}.stat-value.green{color:#0d6e3a}.stat-value.amber{color:#7a5c00}.stat-label{letter-spacing:.06em;text-transform:uppercase;color:var(--color-gray-mid);font-size:12px;font-weight:600}.table-scroll{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{letter-spacing:.07em;text-transform:uppercase;color:var(--color-gray-mid);text-align:left;white-space:nowrap;background:#fafbff;border-bottom:1px solid #00000012;padding:10px 16px;font-size:11px;font-weight:700}.data-table td{vertical-align:middle;border-bottom:1px solid #0000000a;padding:12px 16px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#e8f0f94d}.badge{letter-spacing:.03em;white-space:nowrap;border-radius:6px;padding:3px 9px;font-size:11px;font-weight:700;display:inline-block}.status-pill-round{white-space:nowrap;border-radius:99px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:700;display:inline-flex}.pill-active{color:#0d6e3a;border:1px solid var(--color-green);background:#edfbf3}.pill-inactive{color:#888;background:#f5f5f5;border:1px solid #ddd}.pill-submitted{color:#0d6e3a;border:1px solid var(--color-green);background:#edfbf3}.pill-awaiting{color:#7a5c00;border:1px solid var(--color-amber);background:#fff8e1}.type-badge{letter-spacing:.04em;border-radius:4px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-block}.type-single{background:var(--color-bg-light-blue);color:var(--color-bright-blue)}.type-event{color:#5b3db5;background:#f0eeff}.badge-login_success{color:#0d6e3a;border:1px solid var(--color-green);background:#edfbf3}.badge-login_failure{color:#b00;background:#fef0f0;border:1px solid #fcc}.badge-logout{color:#555;background:#f5f5f5;border:1px solid #ddd}.badge-link_generated{color:#004e96;background:#ebf5ff;border:1px solid #006fcf4d}.badge-link_reused{color:#7a5c00;border:1px solid var(--color-amber);background:#fff8e1}.badge-invoice_submitted,.badge-event_invoice_submitted{color:#0d6e3a;border:1px solid var(--color-green);background:#edfbf3}.badge-event_complete{background:var(--color-dark-blue);color:#fff;border:1px solid var(--color-dark-blue)}.badge-bulk_upload_matched{color:#0d6e3a;border:1px solid var(--color-green);background:#edfbf3}.badge-bulk_upload_unmatched{color:#7a4500;background:#fff8f0;border:1px solid #ff8c0066}.badge-manual_assigned,.badge-user_created{color:#004e96;background:#ebf5ff;border:1px solid #006fcf4d}.badge-user_deleted{color:#b00;background:#fef0f0;border:1px solid #fcc}.badge-user_deactivated{color:#7a5c00;border:1px solid var(--color-amber);background:#fff8e1}.badge-user_activated{color:#0d6e3a;border:1px solid var(--color-green);background:#edfbf3}.badge-user_password_changed{color:#333;background:#f5f5f5;border:1px solid #ddd}.badge-api_key_generated{color:#004e96;background:#ebf5ff;border:1px solid #006fcf4d}.badge-api_key_revoked{color:#b00;background:#fef0f0;border:1px solid #fcc}.badge-default{color:#555;background:#f5f5f5;border:1px solid #ddd}.role-badge{color:var(--color-gray-mid);font-size:12px;font-weight:600}.you-badge{background:var(--color-bg-light-blue);color:var(--color-bright-blue);letter-spacing:.04em;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:10px;font-weight:700}.origin-single{background:var(--color-bg-light-blue);color:var(--color-bright-blue)}.origin-event{color:#5b3db5;background:#f0eeff}.filter-tabs{flex-wrap:wrap;gap:6px;display:flex}.filter-tab{background:var(--color-bg-light-blue);cursor:pointer;color:var(--color-gray-mid);font-size:12px;font-weight:600;font-family:var(--font-primary);border:1px solid #0000001a;border-radius:99px;padding:5px 14px;transition:all .15s}.filter-tab:hover{border-color:var(--color-bright-blue);color:var(--color-bright-blue)}.filter-tab.active{background:var(--color-dark-blue);color:#fff;border-color:var(--color-dark-blue)}.btn-download{background:var(--color-dark-blue);color:#fff;border-radius:var(--radius-btn);font-family:var(--font-primary);cursor:pointer;transition:var(--transition-btn);border:none;align-items:center;gap:8px;padding:8px 18px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.btn-download:hover{color:#fff;text-decoration:none;transform:scale(1.04)}.btn-download-outline{color:var(--color-dark-blue);border:1.5px solid var(--color-dark-blue);border-radius:var(--radius-btn);font-family:var(--font-primary);cursor:pointer;transition:var(--transition-btn);background:0 0;align-items:center;gap:8px;padding:8px 18px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.btn-download-outline:hover{text-decoration:none;transform:scale(1.04)}.btn-download-white{color:var(--color-dark-blue);border-radius:var(--radius-btn);font-family:var(--font-primary);cursor:pointer;transition:var(--transition-btn);background:#fff;border:none;flex-shrink:0;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.btn-download-white:hover{color:var(--color-dark-blue);text-decoration:none;transform:scale(1.04)}.export-card{background:var(--color-dark-blue);border-radius:16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;margin-bottom:24px;padding:32px;display:flex}.export-info{color:#fff}.export-title{margin-bottom:6px;font-size:20px;font-weight:600}.export-meta{color:#ffffffa6;font-size:14px;line-height:1.5}.mono{font-family:var(--font-mono);color:var(--color-bright-blue);font-size:12px}.mono-gray{font-family:var(--font-mono);color:var(--color-gray-mid);font-size:12px}.mono-dark{font-family:var(--font-mono);color:var(--color-dark-blue);font-size:12px}.key-mask{font-family:var(--font-mono);color:var(--color-dark-blue);background:var(--color-bg-light-blue);border-radius:6px;padding:3px 10px;font-size:12px}.key-none{color:#aaa;font-size:12px;font-style:italic}.upload-zone{text-align:center;cursor:pointer;background:#e8f0f959;border:2px dashed #006fcf59;border-radius:12px;padding:48px 24px;transition:border-color .2s,background .2s}.upload-zone:hover,.upload-zone.dragover{border-color:var(--color-bright-blue);background:#e8f0f9b3}.upload-zone input[type=file]{display:none}.upload-zone.disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.upload-icon-wrap{background:var(--color-bg-light-blue);border-radius:10px;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 16px;display:flex}.upload-heading{color:var(--color-dark-blue);margin-bottom:6px;font-size:16px;font-weight:600}.upload-hint{color:var(--color-gray-mid);margin-bottom:20px;font-size:14px}.file-strip{text-align:left;background:#e8f0f9cc;border:1px solid #006fcf4d;border-radius:8px;align-items:center;gap:12px;margin-top:16px;padding:12px 16px;display:none}.file-strip.visible{display:flex}.file-strip-name{color:var(--color-dark-blue);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:600;overflow:hidden}.file-strip-size{color:var(--color-gray-mid);flex-shrink:0;font-size:13px}.file-strip-remove{cursor:pointer;color:var(--color-gray-mid);opacity:.7;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:16px;line-height:1}.file-strip-remove:hover{opacity:1}.submit-row{justify-content:flex-end;margin-top:28px;display:flex}.alert{border-radius:10px;align-items:flex-start;gap:16px;margin-bottom:28px;padding:20px 24px;display:flex}.alert-success{border:1px solid var(--color-green);background:#edfbf3}.alert-icon{background:var(--color-green);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.alert-body h3{color:var(--color-dark-blue);margin-bottom:3px;font-size:16px;font-weight:600}.alert-body p{color:var(--color-gray-mid);font-size:14px}.details-grid{grid-template-columns:1fr 1fr;gap:24px 32px;display:grid}.detail-item{flex-direction:column;gap:5px;display:flex}.detail-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-gray-mid);font-size:12px;font-weight:600}.detail-value{color:var(--color-dark-blue);font-size:17px;line-height:1.4}.detail-value-large{letter-spacing:-.02em;font-size:22px;font-weight:600}.event-banner{background:var(--color-dark-blue);color:#fff;border-radius:16px;margin-bottom:24px;padding:28px 32px}.event-banner-label{letter-spacing:.08em;text-transform:uppercase;color:#ffffff8c;margin-bottom:8px;font-size:12px;font-weight:600}.event-banner-name{letter-spacing:-.03em;margin-bottom:10px;font-size:24px;font-weight:600}.event-banner-desc{color:#ffffffbf;font-size:15px;line-height:1.6}.progress-wrap{margin-bottom:32px}.progress-label{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.progress-text{color:var(--color-dark-blue);font-size:15px;font-weight:600}.progress-frac{color:var(--color-gray-mid);font-size:13px}.progress-track{background:#006fcf26;border-radius:99px;height:8px;overflow:hidden}.progress-fill{background:var(--color-bright-blue);border-radius:99px;height:100%;transition:width .5s}.progress-fill.complete{background:var(--color-green)}.booking-row{background:#fff;border:1px solid #00000012;border-radius:12px;align-items:center;gap:16px;margin-bottom:12px;padding:20px 24px;display:flex}.booking-row.submitted{background:#fafffe;border-color:#28cd6e4d}.booking-status{flex-shrink:0}.status-dot{border-radius:50%;width:10px;height:10px}.dot-pending{background:#00000026}.dot-submitted{background:var(--color-green)}.booking-info{flex:1;min-width:0}.booking-guest{color:var(--color-dark-blue);margin-bottom:3px;font-size:16px;font-weight:600}.booking-meta{color:var(--color-gray-mid);font-size:13px}.booking-conf{color:var(--color-bright-blue);margin-top:2px;font-family:monospace;font-size:12px}.ocr-warn{color:#b05800;margin-top:4px;font-size:11px}.booking-amount{text-align:right;flex-shrink:0;min-width:80px}.booking-action{flex-shrink:0}.submitted-chip{border:1px solid var(--color-green);color:#0d6e3a;background:#edfbf3;border-radius:99px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-flex}.upload-trigger{background:var(--color-bright-blue);color:#fff;border-radius:var(--radius-btn);font-family:var(--font-primary);cursor:pointer;transition:var(--transition-btn);border:none;align-items:center;gap:8px;padding:8px 18px;font-size:14px;font-weight:600;display:inline-flex}.upload-trigger:hover:not(:disabled){transform:scale(1.04)}.upload-trigger:disabled{opacity:.7;cursor:not-allowed}.bulk-results{flex-direction:column;gap:10px;margin-top:20px;display:flex}.bulk-result-row{border:1px solid #00000014;border-radius:10px;padding:14px 18px}.bulk-result-row.matched{background:#edfbf3;border-color:#28cd6e4d}.bulk-result-row.unmatched{background:#fff8f0;border-color:#ff8c004d}.bulk-result-row.error{background:#fef0f0;border-color:#fccaca}.result-file{margin-bottom:6px;font-size:13px;font-weight:700}.result-detail{color:var(--color-gray-mid);font-size:13px}.result-amount{color:var(--color-dark-blue);font-size:13px;font-weight:600}.pick-list{flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px;display:flex}.pick-label{color:#7a4500;font-size:13px;font-weight:600}.pick-select{min-width:200px;height:38px;font-family:var(--font-primary);color:var(--color-dark-blue);background:#fff;border:1.5px solid #ff8c0080;border-radius:8px;outline:none;flex:1;padding:0 12px;font-size:13px}.pick-confirm{background:var(--color-dark-blue);color:#fff;font-family:var(--font-primary);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600}.pick-confirm:hover{opacity:.85}.pick-discard{color:#c00;font-family:var(--font-primary);cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid #fcc;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600}.pick-discard:hover{background:#fef0f0}.verify-layout{grid-template-columns:340px 1fr;gap:24px;display:grid}@media (width<=900px){.verify-layout{grid-template-columns:1fr}}.queue{flex-direction:column;gap:10px;display:flex}.queue-item{cursor:pointer;background:#fff;border:1px solid #00000014;border-radius:12px;padding:16px 18px;transition:border-color .15s,box-shadow .15s}.queue-item:hover{border-color:var(--color-bright-blue)}.queue-item.active{border-color:var(--color-bright-blue);box-shadow:0 0 0 3px #006fcf1f}.qi-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.qi-guest{font-size:15px;font-weight:600}.qi-origin{letter-spacing:.04em;border-radius:4px;padding:2px 7px;font-size:10px;font-weight:700}.qi-meta{color:var(--color-gray-mid);font-size:12px;line-height:1.5}.qi-conf{font-family:var(--font-mono);color:var(--color-bright-blue);font-size:11px}.preview{background:#fff;border:1px solid #00000012;border-radius:16px;flex-direction:column;min-height:600px;display:flex;overflow:hidden}.preview-empty{color:var(--color-gray-mid);flex:1;justify-content:center;align-items:center;font-size:15px;display:flex}.pv-header{border-bottom:1px solid #00000012;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 24px;display:flex}.pv-title{font-size:18px;font-weight:600}.pv-sub{color:var(--color-gray-mid);margin-top:3px;font-size:13px}.pv-details{flex-wrap:wrap;gap:24px;margin-top:10px;display:flex}.pv-detail{font-size:13px}.pv-detail .lbl{letter-spacing:.07em;text-transform:uppercase;color:var(--color-gray-mid);margin-bottom:2px;font-size:10px;font-weight:700;display:block}.pv-detail .val{color:var(--color-dark-blue);font-weight:600}.zoom-bar{background:#fafbff;border-bottom:1px solid #0000000f;align-items:center;gap:8px;padding:10px 24px;display:flex}.zoom-btn{cursor:pointer;width:32px;height:32px;color:var(--color-dark-blue);background:#fff;border:1.5px solid #00000026;border-radius:8px;justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex}.zoom-btn:hover{border-color:var(--color-bright-blue)}.zoom-level{color:var(--color-gray-mid);text-align:center;min-width:48px;font-size:13px}.zoom-hint{color:var(--color-gray-mid);margin-left:auto;font-size:12px}.pv-viewport{background:#3a3a3a;flex:1;justify-content:center;align-items:flex-start;padding:20px;display:flex;overflow:auto}.pv-viewport img{transform-origin:top;max-width:none;transition:transform .15s;box-shadow:0 4px 20px #0000004d}.pv-viewport iframe{background:#fff;border:none;width:100%;height:70vh}.action-bar{border-top:1px solid #00000012;align-items:center;gap:12px;padding:20px 24px;display:flex}.btn-validate{background:var(--color-green);color:#fff}.btn-reject{color:#c00;background:0 0;border:1.5px solid #fcc}.btn-reject:hover{background:#fef0f0;transform:none}.action-note{color:var(--color-gray-mid);max-width:320px;margin-left:auto;font-size:12px}.reject-result{background:#fff8f0;border-top:1px solid #ff8c004d;padding:20px 24px;display:none}.reject-result.visible{display:block}.reject-result h4{color:#7a4500;margin-bottom:8px;font-size:14px}.reject-link-row{align-items:center;gap:10px;display:flex}.reject-link{font-family:var(--font-mono);color:var(--color-bright-blue);word-break:break-all;background:#fff;border:1px solid #006fcf40;border-radius:8px;flex:1;padding:10px 14px;font-size:13px}.empty{text-align:center;color:var(--color-gray-mid);background:#fff;border:1px solid #00000012;border-radius:16px;padding:64px;font-size:16px}.empty-icon{background:#edfbf3;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 18px;display:flex}.loading-state{color:var(--color-gray-mid);justify-content:center;align-items:center;gap:.5rem;padding:3rem;font-size:.9rem;display:flex}.login-page{font-family:var(--font-primary);background:var(--color-dark-blue);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-wrap{width:100%;max-width:420px}.logo-area{text-align:center;margin-bottom:36px}.logo-img{width:auto;height:52px}.login-card{background:#fff;border-radius:20px;padding:40px 40px 36px;box-shadow:0 24px 64px #0000004d}.login-card-title{color:var(--color-dark-blue);letter-spacing:-.03em;margin-bottom:6px;font-size:24px;font-weight:600}.login-card-subtitle{color:var(--color-gray-mid);margin-bottom:32px;font-size:14px}.btn-login{background:var(--color-bright-blue);color:#fff;border-radius:var(--radius-btn);width:100%;height:52px;font-family:var(--font-primary);cursor:pointer;transition:var(--transition-btn);border:none;margin-top:8px;font-size:16px;font-weight:600}.btn-login:hover:not(:disabled){transform:scale(1.03)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.footer{background:var(--color-dark-blue);color:#ffffff73;flex-shrink:0;padding:40px 40px 32px;font-size:11.5px;line-height:1.7}.footer-inner{max-width:900px;margin:0 auto}.footer-legal{margin-bottom:12px}.footer-copy{color:#fff9;font-weight:600}.detail-text{font-family:var(--font-mono);color:var(--color-gray-mid);text-overflow:ellipsis;white-space:nowrap;cursor:pointer;max-width:320px;font-size:11px;display:block;overflow:hidden}.detail-text.expanded{white-space:normal;word-break:break-all;text-overflow:initial}.inline-input{height:34px;font-family:var(--font-primary);color:var(--color-dark-blue);background:#fff;border:1.5px solid #00000026;border-radius:8px;outline:none;width:160px;padding:0 12px;font-size:13px;transition:border-color .2s}.inline-input:focus{border-color:var(--color-bright-blue)}.form-label-sm{letter-spacing:.08em;text-transform:uppercase;color:var(--color-gray-mid);margin-bottom:6px;font-size:11px;font-weight:700;display:block}.form-input-std{height:44px;font-family:var(--font-primary);color:var(--color-dark-blue);background:#fff;border:1.5px solid #00000026;border-radius:10px;outline:none;width:100%;min-width:160px;padding:0 14px;font-size:15px;transition:border-color .2s}.form-input-std:focus{border-color:var(--color-bright-blue)}.form-select-std{height:44px;font-family:var(--font-primary);color:var(--color-dark-blue);background:#fff;border:1.5px solid #00000026;border-radius:10px;outline:none;width:100%;padding:0 14px;font-size:15px}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.w-full{width:100%}.text-muted{color:var(--color-gray-mid)}.text-blue{color:var(--color-bright-blue)}.text-danger{color:#c00}.text-success{color:#0d6e3a}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:500px;max-height:90vh;display:flex;overflow-y:auto;box-shadow:0 20px 60px #00000040}.modal-header{color:var(--color-dark-blue);border-bottom:1px solid #00000012;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;font-size:18px;font-weight:600;display:flex}.modal-close{cursor:pointer;color:var(--color-gray-mid);background:0 0;border:none;padding:.25rem;font-size:1.25rem;line-height:1}.modal-body{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.modal-footer{border-top:1px solid #00000012;justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;display:flex}.copy-box{background:var(--color-bg-light-blue);border:1px solid #006fcf33;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.copy-box input{font-size:.8rem;font-family:var(--font-mono);color:var(--color-dark-blue);background:0 0;border:none;outline:none;flex:1;min-width:0}@media (width<=768px){.nav{padding:0 20px}.tab-nav{padding:0 20px;overflow-x:auto}.main-content,.main-content-900{padding:32px 16px 64px}.page-title{font-size:30px}.details-grid{grid-template-columns:1fr}.stats-bar{grid-template-columns:1fr 1fr}.export-card{flex-direction:column}.login-card{padding:28px 24px}.card{padding:24px}}
