:root{color-scheme:dark;--color-bg: #0D0D0D;--color-surface: #141414;--color-surface-2: #1a1a1a;--color-surface-3: #222222;--color-gold: #C8862A;--color-gold-light: #e0a84a;--color-gold-dim: rgba(200, 134, 42, .15);--color-border: rgba(200, 134, 42, .2);--color-border-subtle: rgba(255, 255, 255, .06);--color-text: #f0ebe3;--color-muted: #7a7268;--color-dim: #4a4540;--color-green: #4caf7d;--color-green-dim: rgba(76, 175, 125, .12);--color-red: #e05555;--color-red-dim: rgba(224, 85, 85, .15);--color-amber: #C8862A;--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", "Courier New", monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 12px;--radius-pill: 999px;--amber-600: #C8862A;--amber-100: rgba(200, 134, 42, .15);--text-900: #f0ebe3;--text-700: #bfb8ae;--text-500: #7a7268;--text-400: #5a554d;--line-200: rgba(200, 134, 42, .2);--line-300: rgba(200, 134, 42, .3);--surface-0: #141414;--surface-50: #1a1a1a;--surface-1: #1a1a1a;--border: rgba(200, 134, 42, .2);--bg-100: #1a1a1a;--bg-200: #222222}*{box-sizing:border-box}body{margin:0;color:var(--color-text);background:var(--color-bg);font-family:var(--font-body);font-size:14px;line-height:1.4}button,input,select,textarea{font:inherit;color:inherit}input:focus,select:focus,textarea:focus,button:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-gold-dim)}.app-shell{display:flex;min-height:100vh}.sidebar{width:270px;background:var(--color-surface);border-right:1px solid var(--color-border);padding:20px 16px;display:flex;flex-direction:column;gap:18px}.sidebar-brand-block{padding:8px 8px 12px}.sidebar-brand{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--color-text);letter-spacing:.01em}.sidebar-brand-subtitle{font-family:var(--font-mono);font-size:11px;font-weight:300;color:var(--color-muted);margin-top:2px}.sidebar-nav{display:flex;flex-direction:column;gap:6px}.sidebar-link{border:1px solid transparent;border-radius:var(--radius-sm);padding:8px 12px;color:var(--color-muted);text-decoration:none;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-body);font-size:14px;transition:color .15s,background .15s}.sidebar-link:hover{color:var(--color-text);background:var(--color-surface-2)}.sidebar-link-active{background:var(--color-gold-dim);color:var(--color-text);font-weight:500}.sidebar-badge{font-family:var(--font-mono);font-size:11px;background:var(--color-surface-2);color:var(--color-muted);border-radius:var(--radius-pill);border:none;padding:1px 7px;min-width:24px;text-align:center}.sidebar-link-active .sidebar-badge{background:var(--color-gold-dim);color:var(--color-gold)}.sidebar-section-label{font-family:var(--font-mono);font-size:9px;font-weight:400;color:var(--color-dim);text-transform:uppercase;letter-spacing:.18em;padding:16px 12px 6px}.sidebar-status{margin-top:auto;display:flex;flex-direction:column;gap:10px;font-family:var(--font-mono);font-size:11px;color:var(--color-muted);padding:10px;border:1px solid var(--color-border);background:var(--color-surface-2);border-radius:var(--radius-lg)}.sidebar-status-row{display:flex;justify-content:space-between;align-items:center}.status-pill{border-radius:var(--radius-pill);padding:2px 8px;font-family:var(--font-mono);font-size:10px;font-weight:500}.status-connected{color:var(--color-green);background:var(--color-green-dim)}.status-error{color:var(--color-red);background:var(--color-red-dim)}.status-checking{color:var(--color-muted);background:var(--color-surface-3)}.main{flex:1;min-width:0}.topbar{position:sticky;top:0;z-index:20;background:#0d0d0deb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border);padding:20px 28px;display:flex;justify-content:space-between;align-items:center}.topbar-title-group h1{margin:0;font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--color-text)}.topbar-title-group p{margin:3px 0 0;font-family:var(--font-body);font-size:13px;color:var(--color-muted)}.topbar-actions{display:flex;gap:10px;align-items:center}.content{padding:22px 26px}.card-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:18px 20px}.stat-label{font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-muted);text-transform:uppercase;letter-spacing:.15em}.stat-value{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--color-text);margin-top:8px;line-height:1}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.toolbar{padding:14px 16px;border-bottom:1px solid var(--color-border-subtle);display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;background:var(--color-surface)}.toolbar-item{display:flex;flex-direction:column;gap:4px;min-width:180px}.toolbar-item span{font-family:var(--font-mono);font-size:10px;color:var(--color-muted);text-transform:uppercase;letter-spacing:.1em}.toolbar-search{flex:1;min-width:260px}.toolbar input,.toolbar select{min-width:180px;border:1px solid var(--color-border);border-radius:var(--radius-md);height:38px;padding:0 12px;background:var(--color-surface-2);color:var(--color-text);font-family:var(--font-body);font-size:14px}.toolbar input::placeholder{color:var(--color-muted)}.toolbar input:focus,.toolbar select:focus{border-color:var(--color-gold);box-shadow:0 0 0 2px var(--color-gold-dim)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:11px 12px;border-bottom:1px solid var(--color-border-subtle);text-align:left;vertical-align:middle;font-size:14px}.table th{font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-muted);text-transform:uppercase;letter-spacing:.12em;white-space:nowrap;background:var(--color-surface)}.table th button{border:none;background:transparent;cursor:pointer;font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-muted);text-transform:uppercase;letter-spacing:.12em;padding:0}.table-row-clickable{cursor:pointer;transition:background .12s}.table-row-clickable:hover{background:var(--color-surface-2)}.table-row-selected{background:var(--color-gold-dim)}.table-primary{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-text)}.table-secondary{font-family:var(--font-body);font-size:11px;color:var(--color-muted);margin-top:2px}.tag{font-family:var(--font-mono);font-size:10px;font-weight:500;border-radius:var(--radius-pill);padding:2px 8px;color:var(--color-gold-light);background:#c8862a33;border:none}.table-actions{display:flex;gap:8px;align-items:center}.bulk-actions-bar{margin:0 0 12px;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-gold-dim);display:flex;justify-content:space-between;align-items:center;gap:10px}.bulk-actions-summary{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--color-gold-light)}.bulk-actions-buttons{display:flex;gap:8px;align-items:center}.table-image-button{border:none;background:transparent;padding:0;cursor:pointer;line-height:0}.table-image-thumb{width:44px;height:44px;object-fit:contain;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface-2)}.pagination{display:flex;justify-content:space-between;align-items:center;padding:12px;color:var(--color-muted);font-family:var(--font-mono);font-size:12px}.btn{font-family:var(--font-body);font-size:13px;font-weight:500;border:1px solid var(--color-border);background:transparent;color:var(--color-text);border-radius:var(--radius-md);padding:8px 12px;cursor:pointer;transition:border-color .15s,background .15s}.btn:hover{border-color:var(--color-gold);background:var(--color-gold-dim)}.btn:disabled{background:var(--color-surface-2);color:var(--color-muted);cursor:not-allowed;border-color:var(--color-border-subtle)}.btn-primary{background:var(--color-gold);color:#0d0d0d;border-color:var(--color-gold)}.btn-primary:hover{background:var(--color-gold-light)}.btn-danger{background:transparent;color:#c47a7a;border-color:transparent}.btn-danger:hover{color:var(--color-red);background:var(--color-red-dim);border-color:transparent}.btn-danger-fill{background:var(--color-red);color:#fff;border-color:var(--color-red)}.btn-danger-fill:hover{background:#c94444}.btn-secondary{background:var(--color-surface-2);color:var(--color-text);border-color:var(--color-border)}.btn-ghost{background:transparent;border-color:var(--color-border);color:var(--color-text)}.btn-ghost:hover{border-color:var(--color-gold);background:var(--color-gold-dim)}.btn-warning{background:var(--color-gold);color:#000;border-color:var(--color-gold)}.btn-warning:hover{background:#d4942e}.impact-warning{background:#c4942e1a;border:1px solid var(--color-gold);border-radius:6px;padding:12px 16px}.impact-warning p{margin:0 0 8px;line-height:1.5}.impact-warning p:last-child{margin-bottom:0}.modal-backdrop{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:20px;z-index:30}.modal{width:min(1020px,100%);max-height:90vh;overflow:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text)}.modal-confirm{width:min(560px,100%)}.modal-header,.modal-footer{padding:16px 18px}.modal-header{border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--color-text)}.modal-subtitle{margin:4px 0 0;font-family:var(--font-body);font-size:13px;color:var(--color-muted)}.modal-body{padding:16px 18px;color:var(--color-text)}.modal-footer{border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:8px}.image-lightbox{width:min(920px,100%);max-height:88vh;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:12px;display:grid;gap:10px}.image-lightbox-close{justify-self:end}.image-lightbox-image{width:100%;max-height:calc(88vh - 80px);object-fit:contain;border-radius:var(--radius-md);background:var(--color-surface-2)}.form{padding:18px;display:grid;gap:14px}.form-section{background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:18px 20px}.form-section h3{margin:0;font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--color-gold);text-transform:uppercase;letter-spacing:.18em}.form-section-description{margin:4px 0 14px;font-family:var(--font-body);font-size:12px;color:var(--color-muted)}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.field{display:flex;flex-direction:column;gap:5px;font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-muted);text-transform:uppercase;letter-spacing:.1em}.field-label-row{display:flex;align-items:center;gap:6px}.field input,.field select,.field textarea{width:100%;box-sizing:border-box;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px 10px;background:var(--color-surface);color:var(--color-text);font-family:var(--font-body);font-size:14px;font-weight:400;text-transform:none;letter-spacing:normal}.field input::placeholder,.field textarea::placeholder{color:var(--color-muted)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--color-gold);box-shadow:0 0 0 2px var(--color-gold-dim)}.field textarea{resize:vertical;min-height:88px}.field-ai input,.field-ai select,.field-ai textarea{border-left:4px solid var(--color-gold);background:var(--color-gold-dim)}.field-full{margin-top:10px}.media-preview{margin-top:12px;display:grid;gap:8px}.media-upload-controls{display:grid;gap:8px;margin-bottom:12px}.autofill-actions{margin-top:4px;display:grid;gap:6px}.autofill-helper-text{margin:0;font-size:12px;color:var(--color-muted)}.autofill-error{font-size:12px;color:var(--color-red)}.autofill-button-content{display:inline-flex;align-items:center;gap:8px}.button-spinner{width:12px;height:12px;border-radius:var(--radius-pill);border:2px solid var(--color-border);border-top-color:var(--color-gold);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.media-upload-status{font-size:12px;color:var(--color-muted)}.media-upload-error{font-size:12px;color:var(--color-red)}.media-preview-label{font-size:12px;color:var(--color-muted)}.media-preview-link{display:inline-flex;width:fit-content;border-radius:var(--radius-md)}.media-preview-image{width:180px;height:180px;object-fit:contain;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-2)}.ai-image-candidates{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2);padding:10px}.ai-image-candidate-row{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:8px}.ai-image-candidate-thumb-link{display:inline-flex;border-radius:8px}.ai-image-candidate-thumb{width:56px;height:56px;object-fit:contain;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface-3)}.ai-image-candidate-url{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-gold);text-decoration:none}.ai-image-candidate-url:hover{text-decoration:underline;color:var(--color-gold-light)}.checkbox-grid{margin-top:10px}.checkbox-row{display:flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:13px;color:var(--color-text)}input[type=checkbox]{accent-color:var(--color-gold);width:14px;height:14px}.checkbox-row-ai{border-left:4px solid var(--color-gold);padding-left:8px;border-radius:var(--radius-sm);background:var(--color-gold-dim)}.autofill-banner{border:1px solid var(--color-border);background:var(--color-gold-dim);color:var(--color-gold-light);border-radius:var(--radius-md);padding:10px 12px;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.autofill-banner-content{display:grid;gap:2px}.autofill-banner-title{font-weight:600}.autofill-banner-copy{font-size:13px}.autofill-banner-progress{margin-top:6px;font-size:12px}.autofill-banner-close{min-width:34px;padding:6px 10px}.error-banner{border:1px solid rgba(224,85,85,.3);background:var(--color-red-dim);color:var(--color-red);border-radius:var(--radius-md);padding:10px 12px;margin:0 18px 12px;font-family:var(--font-mono);font-size:11px}.toast-stack{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px;z-index:40}.toast{background:var(--color-surface-3);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px 12px;min-width:240px;font-family:var(--font-body);font-size:13px}.placeholder{background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:22px;color:var(--color-muted)}.bulk-upload-panel{margin-bottom:14px;padding:14px}.bulk-upload-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.bulk-upload-row h3{margin:0}.bulk-upload-row p{margin:4px 0 0;color:var(--color-muted);font-size:13px}.bulk-layout{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,1fr);gap:12px}.bulk-row-selected{background:var(--color-gold-dim)}.bulk-review-panel{min-height:520px}.bulk-review-body{padding:14px;display:grid;gap:10px}.bulk-review-body h3,.bulk-review-body h4{margin:0}.bulk-preview-image,.bulk-preview-placeholder{width:100%;min-height:220px;max-height:320px;object-fit:contain;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2)}.bulk-preview-placeholder{display:grid;place-items:center;color:var(--color-muted)}.bulk-candidate-list{display:grid;gap:6px}.bulk-candidate-btn{display:flex;justify-content:space-between;align-items:center;width:100%}.bulk-candidate-btn-selected{border-color:var(--color-gold);background:var(--color-gold-dim)}.bulk-search-block{display:grid;gap:8px}.bulk-search-row{display:flex;gap:8px}.bulk-search-row input{flex:1;border:1px solid var(--color-border);border-radius:var(--radius-md);height:36px;padding:0 10px;background:var(--color-surface-2);color:var(--color-text)}.bulk-search-results{display:grid;gap:6px;max-height:160px;overflow:auto}.bulk-search-result-btn{justify-content:flex-start;width:100%}.bulk-review-actions{display:flex;gap:8px}.create-new-modal-body{display:grid;gap:10px}.bulk-duplicate-warning{border:1px solid var(--color-border);background:var(--color-gold-dim);color:var(--color-gold-light);border-radius:var(--radius-md);padding:10px;display:grid;gap:6px}.bulk-duplicate-warning-title{font-weight:600}.bulk-duplicate-warning-copy{font-size:13px}.bulk-duplicate-row{display:flex;justify-content:space-between;gap:8px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-gold-dim);padding:6px 8px}.bulk-status-uploaded{color:var(--color-muted);background:var(--color-surface-3)}.bulk-status-processed{color:var(--color-green);background:var(--color-green-dim)}.bulk-status-needs_review{color:var(--color-gold-light);background:var(--color-gold-dim)}.bulk-status-approved{color:var(--color-green);background:var(--color-green-dim)}.bulk-status-created_new_bottle{color:#93b8f7;background:#3b82f61f}.bulk-status-rejected,.bulk-status-error{color:var(--color-red);background:var(--color-red-dim)}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;gap:16px;background:var(--color-bg)}.login-shell{text-align:center}.login-shell h1{margin:0;font-family:var(--font-display);font-size:34px;font-weight:600;color:var(--color-text)}.login-subtitle{margin:8px 0 0;font-family:var(--font-mono);font-size:13px;color:var(--color-muted)}.login-panel{width:min(440px,100%);padding:18px;display:grid;gap:12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg)}@media(max-width:1280px){.card-grid,.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:900px){.sidebar{display:none}.topbar,.content{padding:14px 16px}.bulk-layout{grid-template-columns:1fr}.import-commit-bar{left:0}}@media(max-width:760px){.card-grid,.form-grid,.import-drawer-body{grid-template-columns:1fr}}.combobox-container{position:relative}.combobox-input-wrap{position:relative;display:flex;align-items:center}.combobox-input{width:100%;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 32px 8px 10px;background:var(--color-surface);font-size:13px;color:var(--color-text);box-sizing:border-box;font-family:var(--font-body);text-transform:none;letter-spacing:normal}.combobox-input:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 2px var(--color-gold-dim)}.combobox-input:disabled{background:var(--color-surface-3);color:var(--color-dim);cursor:not-allowed}.combobox-clear-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--color-dim);font-size:18px;line-height:1;padding:0 4px}.combobox-clear-btn:hover{color:var(--color-text)}.combobox-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 16px #0006;z-index:100;max-height:240px;overflow-y:auto}.combobox-message{padding:10px 12px;font-size:12px;color:var(--color-dim);text-align:center}.combobox-option{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;background:none;border:none;text-align:left;cursor:pointer;font-family:var(--font-body);font-size:13px;color:var(--color-text);flex-wrap:wrap;text-transform:none;letter-spacing:normal}.combobox-option:hover,.combobox-option-active{background:var(--color-surface-2)}.combobox-option-selected{font-weight:600}.combobox-option-label{flex:1}.combobox-option-sublabel{width:100%;font-size:11px;color:var(--color-dim);padding-left:0}.combobox-badge{font-family:var(--font-mono);font-size:10px;font-weight:500;padding:1px 6px;border-radius:4px;background:var(--color-gold-dim);color:var(--color-gold);white-space:nowrap}.sidebar-badge-review{font-family:var(--font-mono);font-size:11px;border-radius:var(--radius-pill);border:1px solid var(--color-gold);background:var(--color-gold-dim);color:var(--color-gold);min-width:24px;text-align:center;padding:1px 6px}.badge{display:inline-block;font-family:var(--font-mono);font-size:10px;font-weight:500;border-radius:var(--radius-pill);padding:2px 8px;border:1px solid transparent;vertical-align:middle}.badge-success{background:var(--color-green-dim);border-color:transparent;color:var(--color-green)}.badge-muted{background:var(--color-surface-2);border-color:var(--color-border-subtle);color:var(--color-muted)}.badge-warning{background:var(--color-gold-dim);border-color:transparent;color:var(--color-gold-light)}.badge-amber{background:#c8862a33;border-color:transparent;color:var(--color-gold-light)}.badge-danger{background:var(--color-red-dim);border-color:transparent;color:var(--color-red)}.import-page{padding-bottom:96px}.import-upload-panel{margin-bottom:12px;padding:14px}.import-upload-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.import-upload-row h3{margin:0 0 4px}.import-upload-row p{margin:0;color:var(--color-muted);font-size:13px}.import-upload-actions{display:flex;align-items:center;gap:8px}.import-upload-meta{margin-top:6px;font-size:12px;color:var(--color-muted)}.import-file-input{display:none}.import-badge{display:inline-block;font-family:var(--font-mono);font-size:10px;font-weight:500;border-radius:var(--radius-pill);padding:2px 8px;border:1px solid transparent}.import-badge-success{background:var(--color-green-dim);border-color:transparent;color:var(--color-green)}.import-badge-warning{background:var(--color-gold-dim);border-color:transparent;color:var(--color-gold-light)}.import-badge-danger{background:var(--color-red-dim);border-color:transparent;color:var(--color-red)}.import-badge-muted{background:var(--color-surface-3);border-color:transparent;color:var(--color-muted)}.import-badge-info{background:#3b82f61f;border-color:transparent;color:#93b8f7}.import-thumb{width:40px;height:40px;border-radius:8px;border:1px solid var(--color-border);object-fit:contain;background:var(--color-surface-2)}.import-thumb-placeholder{display:grid;place-items:center;color:var(--color-muted)}.import-error-text{color:var(--color-red)}.import-commit-bar{position:fixed;left:270px;right:0;bottom:0;z-index:22;background:#0d0d0df2;border-top:1px solid var(--color-border);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.import-inline-warning{color:var(--color-gold-light);font-size:12px}.import-results{margin-top:12px;padding:14px}.import-results h3{margin:0 0 4px}.import-drawer-backdrop{position:fixed;inset:0;background:#000000bf;z-index:35;display:flex;justify-content:flex-end}.import-drawer{width:min(1100px,100%);height:100%;background:var(--color-surface);display:flex;flex-direction:column;border-left:1px solid var(--color-border)}.import-drawer-header,.import-drawer-footer{padding:12px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.import-drawer-footer{border-top:1px solid var(--color-border);border-bottom:none;margin-top:auto}.import-drawer-header h2{margin:0;font-family:var(--font-display);font-size:18px;font-weight:600}.import-drawer-body{padding:14px 16px;overflow:auto;display:grid;grid-template-columns:1fr 1fr;gap:14px}.import-drawer-column{display:grid;align-content:start;gap:8px}.import-drawer-column h3{margin:0}.import-drawer-image{width:100%;min-height:220px;max-height:320px;object-fit:contain;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2)}.import-drawer-list{display:grid;grid-template-columns:120px 1fr;gap:6px 8px;margin:0}.import-drawer-list dt{font-family:var(--font-mono);font-size:11px;color:var(--color-muted)}.import-drawer-list dd{margin:0;font-size:13px;color:var(--color-text)}.import-alert{border-radius:var(--radius-md);padding:10px;border:1px solid transparent;font-size:13px;font-family:var(--font-mono);font-size:11px}.import-alert-warning{background:var(--color-gold-dim);border-color:var(--color-border);color:var(--color-gold-light)}.import-alert-muted{background:#3b82f614;border-color:#3b82f633;color:#93b8f7}.import-alert-success{background:var(--color-green-dim);border-color:#4caf7d4d;color:var(--color-green)}.import-inline-create{margin-top:4px;width:fit-content;font-size:12px;padding:2px 8px}.import-inline-panel{margin-top:10px;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:10px;background:var(--color-surface-2)}.request-drawer-backdrop{position:fixed;inset:0;background:#000000bf;z-index:35;display:flex;justify-content:flex-end}.request-drawer{width:min(700px,100%);height:100%;background:var(--color-surface);display:flex;flex-direction:column;border-left:1px solid var(--color-border)}.request-drawer-header,.request-drawer-footer{padding:12px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.request-drawer-footer{border-top:1px solid var(--color-border);border-bottom:none;margin-top:auto}.request-drawer-header h2{margin:0;font-family:var(--font-display);font-size:18px;font-weight:600}.request-drawer-body{padding:16px;overflow:auto;display:flex;flex-direction:column;gap:20px}.request-drawer-section h3{margin:0 0 8px;font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-gold);text-transform:uppercase;letter-spacing:.18em}.request-drawer-list{display:grid;grid-template-columns:120px 1fr;gap:6px 8px;margin:0}.request-drawer-list dt{font-family:var(--font-mono);font-size:11px;color:var(--color-muted)}.request-drawer-list dd{margin:0;font-size:13px;color:var(--color-text)}.request-drawer-loading{font-size:13px;color:var(--color-muted);padding:8px 0}.detail-drawer-backdrop{position:fixed;inset:0;background:#000000bf;z-index:35;display:flex;justify-content:flex-end}.detail-drawer{width:min(760px,100%);height:100%;background:var(--color-surface);display:flex;flex-direction:column;border-left:1px solid var(--color-border)}.detail-drawer-header,.detail-drawer-footer{padding:12px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:12px}.detail-drawer-footer{border-top:1px solid var(--color-border);border-bottom:none;margin-top:auto}.detail-drawer-header h2{margin:0;font-family:var(--font-display);font-size:18px;font-weight:600}.detail-drawer-body{padding:16px;overflow:auto;display:flex;flex-direction:column;gap:20px}.detail-drawer-section h3{margin:0 0 8px;font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-gold);text-transform:uppercase;letter-spacing:.18em}.detail-drawer-list{display:grid;grid-template-columns:150px 1fr;gap:6px 8px;margin:0}.detail-drawer-list dt{font-family:var(--font-mono);font-size:11px;color:var(--color-muted)}.detail-drawer-list dd{margin:0;font-size:13px;color:var(--color-text);word-break:break-word}.detail-drawer-image{width:100%;max-height:260px;object-fit:contain;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface-2)}.detail-drawer-json{margin:0;border:1px solid var(--color-border);border-radius:8px;padding:10px;background:var(--color-surface-2);font-family:var(--font-mono);font-size:12px;line-height:1.5;overflow:auto;color:var(--color-text)}.request-status-badge{font-family:var(--font-mono);font-size:10px;font-weight:500;border-radius:var(--radius-pill);padding:2px 8px;text-transform:capitalize}.request-status-pending{color:var(--color-gold-light);background:var(--color-gold-dim)}.request-status-added{color:var(--color-green);background:var(--color-green-dim)}.request-status-rejected{color:var(--color-red);background:var(--color-red-dim)}.request-status-duplicate{color:var(--color-muted);background:var(--color-surface-3)}.request-type-badge{font-family:var(--font-mono);font-size:10px;font-weight:500;border-radius:var(--radius-pill);padding:2px 8px}.request-type-add_request{color:#93b8f7;background:#3b82f61f}.request-type-issue_report{color:var(--color-gold-light);background:var(--color-gold-dim)}.request-type-app_feedback{color:#c4b5fd;background:#8b5cf61f}.feedback-type-badge{display:inline-block;font-family:var(--font-mono);padding:1px 6px;border-radius:var(--radius-pill);font-size:10px;font-weight:500;margin-left:4px;vertical-align:middle}.feedback-type-bug{color:var(--color-red);background:var(--color-red-dim)}.feedback-type-feature_request{color:#93b8f7;background:#3b82f61f}.feedback-type-general{color:var(--color-muted);background:var(--color-surface-3)}.request-feedback-message{white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto;padding:8px;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;line-height:1.5;color:var(--color-text)}.request-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.request-table th{text-align:left;padding:10px 12px;font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-muted);text-transform:uppercase;letter-spacing:.12em;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.request-table td{padding:10px 12px;border-bottom:1px solid var(--color-border-subtle)}.request-table-row{cursor:pointer;transition:background .12s}.request-table-row:hover{background:var(--color-surface-2)}.user-info-cell{display:flex;flex-direction:column;gap:1px;line-height:1.3}.user-info-name{font-weight:500;color:var(--color-text)}.user-info-username{font-size:.8em;color:var(--color-muted)}.request-filters{display:flex;gap:12px;align-items:flex-end;margin-bottom:12px}.request-filter-group{display:flex;flex-direction:column;gap:4px}.request-filter-group label{font-family:var(--font-mono);font-size:10px;color:var(--color-muted);font-weight:400;text-transform:uppercase;letter-spacing:.1em}.request-filter-group select,.request-filter-group input{padding:6px 10px;border:1px solid var(--color-border);border-radius:8px;font-size:13px;background:var(--color-surface-2);color:var(--color-text)}.request-filter-search{flex:1}.request-filter-search input{width:100%}.request-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 0;font-family:var(--font-mono);font-size:12px;color:var(--color-muted)}.request-resolved-info{display:flex;align-items:center;gap:10px;width:100%}.request-resolved-date{font-size:13px;color:var(--color-muted)}.request-resolved-link{font-size:13px;color:var(--color-gold)}.request-resolved-link:hover{color:var(--color-gold-light)}.request-confirm-inline{display:flex;align-items:center;justify-content:space-between;width:100%;font-size:13px}.request-notes-textarea{width:100%;border:1px solid var(--color-border);border-radius:8px;padding:8px 10px;font-size:13px;resize:vertical;background:var(--color-surface-2);color:var(--color-text)}.request-notes-textarea:focus{border-color:var(--color-gold);box-shadow:0 0 0 2px var(--color-gold-dim)}.request-notes-saved{font-size:11px;color:var(--color-green);margin-left:8px;font-weight:400;text-transform:none;letter-spacing:0}.request-notes-error{font-size:11px;color:var(--color-red);margin-left:8px;font-weight:400;text-transform:none;letter-spacing:0}.request-comparison-table{width:100%;border-collapse:collapse;font-size:13px;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.request-comparison-table th{text-align:left;padding:6px 10px;font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-muted);text-transform:uppercase;letter-spacing:.1em;background:var(--color-surface-2);border-bottom:1px solid var(--color-border)}.request-comparison-table td{padding:6px 10px;border-bottom:1px solid var(--color-border-subtle)}.comparison-diff td:nth-child(3){background:var(--color-gold-dim);font-weight:600}.scan-image-container{display:flex;flex-direction:column;gap:6px}.scan-image-thumbnail{max-width:240px;max-height:240px;object-fit:contain;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface-2)}.scan-image-link{font-size:12px;color:var(--color-gold)}.scan-image-link:hover{color:var(--color-gold-light)}.scan-image-loading,.scan-image-error{font-size:13px;color:var(--color-muted);padding:8px 0}.associated-bottles-section summary{cursor:pointer;font-family:var(--font-mono);font-size:10px;font-weight:400;color:var(--color-gold);text-transform:uppercase;letter-spacing:.18em;padding:4px 0}.associated-bottle-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--color-border-subtle);cursor:pointer;transition:background .12s}.associated-bottle-row:hover{background:var(--color-surface-2)}.associated-bottle-thumb{width:40px;height:40px;object-fit:contain;border-radius:6px;border:1px solid var(--color-border);background:var(--color-surface-2);flex-shrink:0}.associated-bottle-thumb-placeholder{width:40px;height:40px;border-radius:6px;border:1px solid var(--color-border);background:var(--color-surface-2);flex-shrink:0;display:grid;place-items:center;color:var(--color-muted);font-size:16px}.associated-bottle-info{flex:1;min-width:0}.associated-bottle-name{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.associated-bottle-meta{font-family:var(--font-mono);font-size:11px;color:var(--color-muted);display:flex;gap:8px;margin-top:2px}.filter-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-left:3px solid var(--color-gold);border-radius:var(--radius-sm);margin-bottom:12px;font-family:var(--font-mono);font-size:11px;color:var(--color-muted)}.filter-banner button{background:none;border:none;cursor:pointer;font-size:16px;color:var(--color-muted);padding:0 4px;line-height:1}.filter-banner button:hover{color:var(--color-text)}.merge-progress-bar{margin-bottom:10px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-md);padding:10px 12px;font-size:13px;color:var(--color-muted)}.merge-confidence-tabs{display:flex;gap:8px;padding:10px 12px;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.merge-effects-list{margin:0;padding-left:18px;display:grid;gap:4px;color:var(--color-muted);font-size:13px}.merge-absorbed-name{font-family:var(--font-body);font-size:14px;color:var(--color-text);font-weight:600}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-dim);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-muted)}.metrics-content{display:flex;flex-direction:column;gap:24px;padding:24px}.metrics-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.metrics-section-header{display:flex;align-items:center;gap:10px;width:100%;padding:16px 20px;background:var(--color-surface-2);border:none;border-bottom:1px solid var(--color-border);cursor:pointer;text-align:left;color:var(--color-text);font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:.02em}.metrics-section-header:hover{background:var(--color-surface-3)}.metrics-chevron{font-size:10px;color:var(--color-muted);transition:transform .15s ease}.metrics-chevron-open{transform:rotate(90deg)}.metrics-section-title{flex:1}.metrics-section-body{padding:20px}.metrics-loading{text-align:center;padding:40px 0;color:var(--color-muted);font-family:var(--font-mono);font-size:13px}.metrics-error{display:block;width:100%;text-align:center;padding:40px 0;color:var(--color-red);background:none;border:none;cursor:pointer;font-family:var(--font-mono);font-size:13px}.metrics-error:hover{text-decoration:underline}.metrics-empty{text-align:center;padding:32px 0;color:var(--color-dim);font-family:var(--font-mono);font-size:13px}.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}@media(max-width:900px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}.metrics-subsection-title{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--color-gold);margin:24px 0 12px;letter-spacing:.03em;text-transform:uppercase}.metrics-subtext{color:var(--color-dim);font-family:var(--font-mono);font-size:11px;margin:4px 0 12px}.metrics-table-wrap{overflow-x:auto}.metrics-table{width:100%;border-collapse:collapse;font-family:var(--font-body);font-size:13px}.metrics-table th{text-align:left;padding:8px 12px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.metrics-table td{padding:8px 12px;border-bottom:1px solid var(--color-border);color:var(--color-text)}.metrics-table tbody tr:hover{background:var(--color-surface-2)}.category-pill{display:inline-block;padding:2px 8px;border-radius:var(--radius-pill);font-family:var(--font-mono);font-size:10px;color:#fff;text-transform:capitalize;white-space:nowrap}.bar-chart{display:flex;flex-direction:column;gap:6px;margin-bottom:24px}.bar-chart-row{display:flex;align-items:center;gap:10px}.bar-chart-label{width:80px;flex-shrink:0;font-family:var(--font-mono);font-size:12px;color:var(--color-muted);text-align:right;text-transform:capitalize}.bar-chart-track{flex:1;height:20px;background:var(--color-surface-2);border-radius:var(--radius-sm);overflow:hidden}.bar-chart-bar{height:100%;background:var(--color-gold);border-radius:var(--radius-sm);min-width:2px;transition:width .3s ease}.bar-chart-count{width:80px;flex-shrink:0;font-family:var(--font-mono);font-size:12px;color:var(--color-text)}.bar-chart-empty{text-align:center;padding:32px 0;color:var(--color-dim);font-family:var(--font-mono);font-size:13px;background:var(--color-surface-2);border-radius:var(--radius-md);margin-bottom:24px}.rebuy-tiles{display:flex;gap:16px;margin-bottom:8px}.rebuy-tile{flex:1;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;text-align:center}.rebuy-tile-label{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);margin-bottom:8px}.rebuy-tile-value{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--color-text)}.rebuy-tile-pct{font-family:var(--font-mono);font-size:12px;color:var(--color-gold);margin-top:4px}.metrics-side-by-side{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:8px}@media(max-width:900px){.metrics-side-by-side{grid-template-columns:1fr}}.metrics-tile-row{display:flex;gap:16px;margin-bottom:24px}.metrics-big-tile{flex:1;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:24px;text-align:center}.metrics-big-tile-value{font-family:var(--font-display);font-size:36px;font-weight:700;color:var(--color-text)}.metrics-big-tile-label{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);margin-top:8px}.manual-entries-section{border-left:3px solid var(--color-gold);padding-left:16px;margin:24px 0}.pressure-callout{flex:1;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:24px;text-align:center}.pressure-callout-value{font-family:var(--font-display);font-size:42px;font-weight:700;color:var(--color-amber, var(--color-gold))}.pressure-callout-label{font-family:var(--font-mono);font-size:11px;color:var(--color-muted);margin-top:8px;line-height:1.4}.metrics-posthog-link{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:20px;font-family:var(--font-mono);font-size:12px;color:var(--color-muted)}.metrics-posthog-link a{color:var(--color-gold);text-decoration:none}.metrics-posthog-link a:hover{text-decoration:underline}.scan-test-layout{display:grid;grid-template-columns:380px minmax(0,1fr);gap:16px;align-items:start}@media(max-width:900px){.scan-test-layout{grid-template-columns:1fr}}.scan-test-drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:32px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;color:var(--color-muted);font-size:13px}.scan-test-drop-zone:hover{border-color:var(--color-gold);background:var(--color-gold-dim)}.scan-test-preview{max-width:100%;max-height:400px;object-fit:contain;border-radius:var(--radius-md);border:1px solid var(--color-border);margin-top:12px;display:block}.scan-test-url-row{display:flex;gap:8px;margin-top:12px}.scan-test-url-row input{flex:1;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;background:var(--color-surface-2);color:var(--color-text);font-size:13px;font-family:var(--font-body)}.scan-test-url-row input:focus{outline:none;border-color:var(--color-gold);box-shadow:0 0 0 2px var(--color-gold-dim)}.scan-test-summary{display:flex;flex-wrap:wrap;gap:20px;align-items:center;padding:14px 16px;margin-bottom:12px}.scan-test-label{font-family:var(--font-mono);font-size:11px;color:var(--color-muted);margin-right:6px}.scan-test-value{font-size:13px;color:var(--color-text)}.scan-test-section{margin-bottom:12px}.scan-test-section-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:transparent;border:none;cursor:pointer;width:100%;text-align:left;color:var(--color-text);font-family:var(--font-body);font-size:14px;font-weight:600}.scan-test-section-header:hover{background:var(--color-surface-2)}.scan-test-chevron{display:inline-block;font-size:10px;transition:transform .15s;color:var(--color-muted)}.scan-test-chevron-open{transform:rotate(90deg)}.scan-test-section-body{border-top:1px solid var(--color-border-subtle)}.scan-test-kv-table{width:100%;border-collapse:collapse}.scan-test-kv-table th{padding:8px 10px;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--color-muted);text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap}.scan-test-kv-table td{padding:5px 10px;border-bottom:1px solid var(--color-border-subtle);vertical-align:top;font-size:13px;color:var(--color-text)}.scan-test-kv-table td:first-child{font-family:var(--font-mono);font-size:11px;color:var(--color-muted);white-space:nowrap;width:210px}.scan-test-group-label{font-family:var(--font-body)!important;font-size:12px!important;font-weight:600!important;color:var(--color-gold)!important;padding-top:12px!important;text-transform:uppercase;letter-spacing:.5px}.scan-test-null{color:var(--color-dim);font-style:italic}.scan-test-bool-true{color:var(--color-green);font-family:var(--font-mono);font-size:12px}.scan-test-bool-false{color:var(--color-red);font-family:var(--font-mono);font-size:12px}.scan-test-best-row{background:var(--color-gold-dim)}.scan-test-best-badge{display:inline-block;margin-left:8px;background:var(--color-gold);color:#0d0d0d;font-size:10px;font-weight:600;padding:1px 6px;border-radius:var(--radius-pill);vertical-align:middle;text-transform:uppercase}.scan-test-match-type{font-family:var(--font-mono);font-size:11px;color:var(--color-muted);background:var(--color-surface-3);padding:2px 6px;border-radius:var(--radius-sm)}.scan-test-reasons-list{list-style:none;margin:0;padding:0;font-size:11px;color:var(--color-muted);font-family:var(--font-mono)}.scan-test-reasons-list li:before{content:"•";color:var(--color-dim)}.scan-test-raw{max-height:500px;overflow:auto;padding:12px;margin:0;font-family:var(--font-mono);font-size:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word;background:var(--color-surface-2);color:var(--color-text)}
