*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{width:100%}:root{--primary: #3b82f6;--primary-dark: #1e40af;--primary-light: #93c5fd;--danger: #ef4444;--danger-dark: #dc2626;--bourbon: #b45309;--scotch: #78350f;--rye: #a16207;--irish: #166534;--japanese: #991b1b;--accent: #f97316;--accent-dark: #ea580c;--accent-light: #fdba74;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-500: #6b7280;--gray-700: #374151;--gray-900: #111827}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gray-100);color:var(--gray-900);line-height:1.5}.app{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}h1{color:#0f172a;margin-bottom:1.5rem}.navbar{background:linear-gradient(135deg,#0f172a,#1e293b);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0003;width:100%}.nav-logo{height:3rem;width:3rem;margin-right:.5rem;margin-top:-.35rem;vertical-align:middle}.nav-brand a{display:flex;align-items:center;font-size:4rem;font-weight:400;color:var(--primary-light);text-decoration:none;letter-spacing:3px;font-family:Bebas Neue,Impact,Arial Black,sans-serif;text-transform:uppercase;line-height:1}.nav-brand a img{-webkit-text-fill-color:initial}.nav-brand a{background:linear-gradient(135deg,#93c5fd,#60a5fa,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-tagline{display:block;font-size:.8rem;letter-spacing:.25rem;text-transform:uppercase;color:#94a3b8;margin-top:-.25rem;text-align:center}.nav-links{display:flex;gap:1.5rem;align-items:center}.nav-links a{color:#d6d3d1;text-decoration:none;font-weight:500}.nav-links a:hover{color:var(--primary-light)}.nav-links a.active{color:var(--accent);font-weight:600}.nav-logout{background:none;border:1px solid #78716c;color:#d6d3d1;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem}.nav-logout:hover{background:#ffffff1a;border-color:#a8a29e}.nav-dropdown{position:relative}.nav-dropdown-toggle{background:none;border:none;color:#d6d3d1;font-weight:500;font-size:1rem;cursor:pointer;display:flex;align-items:center;gap:.25rem;padding:.25rem 0}.nav-dropdown-toggle:hover{color:var(--primary-light)}.dropdown-arrow{width:16px;height:16px}.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#0f172a;border:1px solid #1e293b;border-radius:.5rem;box-shadow:0 4px 12px #0000004d;min-width:140px;padding:.5rem 0;z-index:100;margin-top:.5rem}.nav-dropdown-menu:before{content:"";position:absolute;top:-.5rem;left:0;right:0;height:.5rem}.nav-dropdown-menu a{display:block;padding:.625rem 1rem;color:#d6d3d1;text-decoration:none;font-weight:500}.nav-dropdown-menu a:hover{background:#ffffff1a;color:var(--primary-light)}.nav-dropdown-logout{display:block;width:100%;padding:.625rem 1rem;color:#d6d3d1;text-decoration:none;font-weight:500;background:none;border:none;border-top:1px solid #1e293b;margin-top:.5rem;text-align:left;cursor:pointer;font-size:inherit}.nav-dropdown-logout:hover{background:#ffffff1a;color:#ef4444}.app-footer{background:#020617;color:#94a3b8;padding:1rem 2rem;text-align:center;font-size:.8125rem;border-top:1px solid #0f172a;margin-top:auto;width:100%}.app-footer .footer-separator{margin:0 .75rem;color:#475569}@media (max-width: 600px){.app-footer{padding:1rem;font-size:.75rem;display:flex;flex-wrap:wrap;justify-content:center;gap:.25rem 0}.app-footer .footer-separator{margin:0 .5rem}}.main-content{width:100%;max-width:1200px;margin:0 auto;padding:2rem;flex:1}.table-scroll-container{overflow-x:auto;margin:0 -2rem;padding:0 2rem}.table-scroll-container .inventory-table{min-width:800px}.btn{display:inline-block;padding:.625rem 1.25rem;border-radius:.375rem;font-weight:500;text-decoration:none;cursor:pointer;border:none;font-size:.875rem;transition:background .2s}.btn-primary{background:var(--primary-dark);color:#fff}.btn-primary:hover{background:#1e3a8a}.btn-secondary{background:#fff;color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-50)}.btn-edit{background:var(--accent);color:#fff}.btn-edit:hover{background:var(--accent-dark)}.btn-small{padding:.375rem .75rem;font-size:.75rem}.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.btn-text{background:transparent;color:var(--gray-500);border:none;padding:.5rem 1rem;font-size:.875rem}.btn-text:hover{color:var(--primary);background:transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.auth-page{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 200px)}.auth-card{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px;border-top:4px solid var(--primary)}.auth-card h1{text-align:center}.auth-link{text-align:center;margin-top:1rem;color:var(--gray-500)}.auth-link a{color:var(--primary)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.375rem;font-weight:500;color:var(--gray-700)}.clearable-input{position:relative;display:flex;width:100%}.clearable-input input{flex:1;padding-right:2rem!important;min-width:0}.clearable-input-x{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.15rem;line-height:1;color:var(--gray-400);cursor:pointer;padding:0 .15rem;display:flex;align-items:center;justify-content:center}.clearable-input input[type=number]::-webkit-inner-spin-button,.clearable-input input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.clearable-input input[type=number]{-moz-appearance:textbox}.clearable-input-x:hover{color:var(--gray-700)}.filter-top-bar>.clearable-input,.share-form>.clearable-input{flex:1;min-width:200px}.dashboard-search>.clearable-input{width:100%}.upc-search-input-group>.clearable-input{width:160px}.add-location-form>.clearable-input,.add-zone-form>.clearable-input{flex:1}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:1rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-actions{display:flex;gap:1rem;margin-top:1.5rem;align-items:center}.quantity-field{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--gray-700);font-size:.875rem;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--gray-200)}.quantity-field .quantity-input{width:70px;padding:.625rem .5rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:.875rem;text-align:center;height:auto}.button-group{display:flex;gap:1rem}.error-message{background:#fef2f2;border:1px solid #fecaca;color:var(--danger);padding:.75rem;border-radius:.375rem;margin-bottom:1rem}.confidence-warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.9rem;line-height:1.4}.confidence-notice{background:#eff6ff;border:1px solid #93c5fd;color:#1e40af;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.9rem;line-height:1.4}.source-diagnostics{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem}.source-diagnostics-label{font-size:.85rem;color:var(--gray-500)}.source-badge{display:inline-block;padding:.2rem .5rem;border-radius:.25rem;font-size:.8rem;font-weight:500}.source-found{background:#dcfce7;color:#166534;border:1px solid #86efac}.source-partial{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.source-none{background:var(--gray-100);color:var(--gray-500);border:1px solid var(--gray-300)}.partial-data-notice{background:#eff6ff;border:1px solid #93c5fd;color:#1e40af;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.9rem;line-height:1.4}.partial-data-list{margin:.5rem 0;padding-left:1.25rem;text-align:left}.partial-data-list li{margin-bottom:.2rem}.partial-data-hint{font-size:.85rem;margin-top:.5rem;opacity:.8}.taught-system-notice{background:#dcfce7;border:1px solid #86efac;color:#166534;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.9rem;line-height:1.4}.retry-hints-form{margin:.75rem 0;padding:.75rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:.375rem}.retry-hints-label{font-size:.9rem;color:var(--gray-700);margin-bottom:.5rem}.retry-hints-fields{display:flex;flex-direction:column;gap:.5rem}.retry-hint-input{padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:.95rem}.retry-hint-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #3b82f626}.dashboard{max-width:900px;margin:0 auto}.dashboard h1{font-size:1.75rem}.dashboard-search{position:relative;margin-bottom:1.5rem}.dashboard-search-input{width:100%;padding:.875rem 1rem;font-size:1rem;border:2px solid var(--gray-200);border-radius:.5rem;background:#fff;transition:border-color .15s,box-shadow .15s}.dashboard-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.dashboard-search-input::placeholder{color:var(--gray-400)}.search-indicator{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--gray-500);font-size:.875rem}.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--gray-200);border-radius:.5rem;box-shadow:0 4px 12px #00000026;margin-top:.5rem;z-index:50;max-height:400px;overflow-y:auto}.search-result-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;text-decoration:none;color:var(--gray-900);border-bottom:1px solid var(--gray-100);transition:background .15s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#eff6ff}.result-brand{font-weight:500}.result-expression{color:var(--gray-500);font-size:.875rem}.result-type{margin-left:auto;font-size:.75rem;padding:.25rem .5rem;background:var(--gray-100);border-radius:.25rem;color:var(--gray-600)}.search-view-all{display:block;padding:.75rem 1rem;text-align:center;color:var(--primary);text-decoration:none;font-weight:500;border-top:1px solid var(--gray-200)}.search-view-all:hover{background:var(--gray-50)}.search-no-results{padding:1rem;text-align:center;color:var(--gray-500)}.dashboard-welcome{color:var(--gray-500);margin-bottom:2rem}.world-map-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;margin-bottom:24px}.world-map-container h2{font-size:1.1rem;margin:0;padding:1rem 1.25rem;background:linear-gradient(135deg,#0f172a,#1e293b);color:var(--primary-light);font-weight:600}.world-map-inner{position:relative;padding:1rem 1.25rem .5rem}.world-map-tooltip{position:absolute;top:1rem;right:1.25rem;background:#0f172aeb;color:#fff;padding:.5rem .75rem;border-radius:8px;font-size:.85rem;display:flex;flex-direction:column;gap:2px;pointer-events:none;z-index:10}.world-map-legend{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem 1rem;font-size:.8rem;color:var(--gray-600)}.legend-bar{width:120px;height:10px;border-radius:5px;background:linear-gradient(to right,#dbeafe,#3b82f6,#1e3a5f)}.legend-label{font-weight:600;min-width:1.5em}.legend-unmapped{margin-left:auto;font-style:italic;color:var(--gray-500)}.world-map-stats{border-top:1px solid var(--gray-200);padding:1rem 1.25rem}.world-map-stats-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.world-map-stats-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--gray-900)}.stats-count{font-size:.85rem;color:var(--gray-500)}.stats-close{margin-left:auto;background:none;border:none;font-size:1.25rem;color:var(--gray-400);cursor:pointer;padding:0 .25rem;line-height:1}.stats-close:hover{color:var(--gray-700)}.stats-loading{font-size:.85rem;color:var(--gray-500);padding:.5rem 0}.stats-body{display:flex;flex-direction:column;gap:.75rem}.stats-value{font-size:.9rem;color:var(--gray-700)}.stats-section h4{margin:0 0 .375rem;font-size:.8rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.3px}.stats-tags{display:flex;flex-wrap:wrap;gap:.375rem}.stats-tag{font-size:.8rem;padding:.25rem .625rem;background:var(--gray-100);border-radius:6px;color:var(--gray-700)}.stats-tag strong{margin-left:.25rem;color:var(--gray-900)}.stats-view-all{display:inline-block;font-size:.85rem;font-weight:500;color:#2563eb;text-decoration:none;padding-top:.25rem}.stats-view-all:hover{text-decoration:underline}@media (max-width: 600px){.world-map-container h2{padding:.75rem 1rem;font-size:1rem}.world-map-inner{padding:.5rem .5rem 0}.world-map-legend{flex-wrap:wrap;padding:.5rem 1rem .75rem;font-size:.75rem}.legend-unmapped{width:100%;margin-left:0;margin-top:.25rem}.world-map-stats{padding:.75rem 1rem}}.dashboard-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem;margin-bottom:2rem}.dashboard-actions .btn{display:flex;align-items:center;justify-content:center;padding:1rem 1.5rem;font-size:.95rem;border-radius:10px;transition:all .2s ease}.dashboard-actions .btn:hover{transform:translateY(-2px)}.dashboard-actions .btn-primary{box-shadow:0 4px 12px #3b82f64d}.recent-items{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.recent-items h2{font-size:1.1rem;margin:0;padding:1rem 1.25rem;background:linear-gradient(135deg,#0f172a,#1e293b);color:var(--primary-light);font-weight:600}.recent-items ul{list-style:none;padding:.5rem 1.25rem 1.25rem;margin:0}.recent-items li{margin-bottom:.5rem}.recent-items li:last-child{margin-bottom:0}.recent-items a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;text-decoration:none;color:var(--gray-900);background:var(--gray-50);border-radius:8px;transition:all .2s ease}.recent-items a:hover{background:var(--gray-100);transform:translate(4px)}.recent-items a .bottle-image{flex-shrink:0}.item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.item-name{font-weight:600;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-expression{font-size:.85rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-meta{flex-shrink:0;display:flex;align-items:center;gap:.5rem}.item-type{font-size:.75rem;padding:.25rem .5rem;border-radius:9999px;text-transform:uppercase;font-weight:600}.item-type.bourbon{background:#fef3c7;color:var(--bourbon)}.item-type.scotch{background:#fde68a;color:var(--scotch)}.item-type.rye{background:#fef9c3;color:var(--rye)}.item-type.irish{background:#d1fae5;color:var(--irish)}.item-type.japanese{background:#fee2e2;color:var(--japanese)}.item-type.tennessee{background:#fed7aa;color:#c2410c}.item-type.canadian{background:#fce7f3;color:#be185d}.item-type.single{background:#e0e7ff;color:#4338ca}.item-type.blended{background:#f3e8ff;color:#7c3aed}.item-age{font-size:.75rem;color:var(--gray-500);padding:.25rem .5rem;background:var(--gray-100);border-radius:.25rem}.item-qty{color:var(--gray-500);font-size:.875rem}.inventory-header{display:flex;justify-content:space-between;align-items:center}.filter-top-bar{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.search-input{flex:1;min-width:200px;padding:.625rem;border:1px solid var(--gray-300);border-radius:.375rem}.upc-search-input-group{display:flex;align-items:center;gap:.5rem}.upc-search-input{width:160px;padding:.625rem;border:1px solid var(--gray-300);border-radius:.375rem}.btn-scan-upc{display:inline-flex;align-items:center;gap:.35rem;padding:.625rem .75rem;font-size:.875rem;background:#fff;color:var(--gray-700);border:1px solid var(--gray-300);border-radius:.375rem;white-space:nowrap;cursor:pointer}.btn-scan-upc:hover{background:var(--gray-50);border-color:var(--gray-500)}.sort-controls{display:flex;gap:.5rem;align-items:center}.sort-controls select{padding:.625rem;border:1px solid var(--gray-300);border-radius:.375rem;background:#fff}.btn-toggle-filters{display:inline-flex;align-items:center;gap:.35rem;padding:.375rem .75rem;font-size:.75rem;border-radius:.375rem;background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300);cursor:pointer;white-space:nowrap;transition:background .2s,border-color .2s}.btn-toggle-filters:hover{background:var(--gray-200)}.btn-toggle-filters.active{background:var(--primary);color:#fff;border-color:var(--primary)}.filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--danger);color:#fff;font-size:.6875rem;font-weight:700;line-height:1}.filter-panel{max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease}.filter-panel--open{max-height:200px;opacity:1}.filter-panel-inner{display:flex;flex-wrap:wrap;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--gray-200);margin-bottom:.75rem}.filter-panel-inner select{padding:.625rem;border:1px solid var(--gray-300);border-radius:.375rem;background:#fff}.btn-clear-filters{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300);white-space:nowrap}.btn-clear-filters:hover{background:var(--gray-200)}.filter-pills{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;padding:.625rem 0;margin-bottom:.75rem}.filter-pill{display:inline-flex;align-items:center;gap:.35rem;background:#dbeafe;color:var(--primary-dark);padding:.25rem .625rem;border-radius:2rem;font-size:.8125rem;font-weight:500}.filter-pill-remove{background:none;border:none;color:var(--primary-dark);font-size:1.1rem;line-height:1;cursor:pointer;padding:0 .125rem;font-weight:700;opacity:.7;transition:opacity .15s}.filter-pill-remove:hover{opacity:1;color:var(--danger)}.btn-clear-all-pills{background:none;border:none;color:var(--gray-500);font-size:.8125rem;cursor:pointer;text-decoration:underline;padding:.25rem .5rem}.btn-clear-all-pills:hover{color:var(--danger)}.filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filters select{padding:.625rem;border:1px solid var(--gray-300);border-radius:.375rem;background:#fff}.inventory-table{width:100%;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border-collapse:collapse;overflow:hidden}.inventory-table th,.inventory-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--gray-200);vertical-align:middle}.inventory-table th{background:#0f172a;color:#93c5fd;font-weight:600;font-size:.875rem}.inventory-table tr:hover{background:#eff6ff}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1.5rem;padding:1rem 0}.pagination-info{color:var(--gray-500);font-size:.875rem;padding:0 1rem}.pagination .btn{min-width:auto;padding:.5rem .75rem}.pagination .btn:disabled{opacity:.5;cursor:not-allowed}.pagination-top{margin-top:0;padding:.5rem 0}.bottle-name{display:block;font-weight:500}.bottle-brand{display:block;font-size:.75rem;color:var(--gray-500)}.type-badge{display:inline-block;font-size:.75rem;padding:.25rem .5rem;border-radius:9999px;text-transform:capitalize;font-weight:600}.type-badge.bourbon{background:#fef3c7;color:var(--bourbon)}.type-badge.scotch{background:#fde68a;color:var(--scotch)}.type-badge.rye{background:#fef9c3;color:var(--rye)}.type-badge.irish{background:#d1fae5;color:var(--irish)}.type-badge.japanese{background:#fee2e2;color:var(--japanese)}.type-badge.tennessee{background:#fed7aa;color:#c2410c}.type-badge.canadian{background:#fce7f3;color:#be185d}.type-badge.single{background:#e0e7ff;color:#4338ca}.type-badge.blended{background:#f3e8ff;color:#7c3aed}.type-badge.whiskey{background:#fef3c7;color:#b45309}.type-badge.vodka{background:#dbeafe;color:#2563eb}.type-badge.gin{background:#d1fae5;color:#059669}.type-badge.tequila{background:#fef3c7;color:#d97706}.type-badge.rum{background:#fee2e2;color:#dc2626}.type-badge.brandy{background:#ede9fe;color:#7c3aed}.type-badge.mezcal{background:#ecfccb;color:#65a30d}.type-badge.liqueur{background:#fce7f3;color:#db2777}.type-badge.other{background:#f1f5f9;color:#6b7280}.details-cell{color:var(--gray-500);font-size:.875rem}.actions-cell{display:inline-flex;gap:.5rem;align-items:stretch;white-space:nowrap}.actions-cell .btn{display:inline-flex;align-items:center}.empty-state{text-align:center;padding:3rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.empty-state p{margin:0;color:var(--gray-500);font-size:1.1rem}.empty-state .btn-scan{max-width:280px}.form-page{max-width:700px;margin:0 auto}.bottle-form{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--gray-200)}.form-section:last-of-type{border-bottom:none;padding-bottom:0}.form-section h3{font-size:1rem;color:var(--primary-dark);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-light);display:inline-block}.type-fields{background:var(--gray-50);padding:1rem;border-radius:.375rem;margin:1rem 0}.type-fields h3{font-size:.875rem;color:var(--gray-700);margin-bottom:1rem}@media (max-width: 768px){input,select,textarea{font-size:16px!important}.navbar{flex-direction:column;gap:.25rem;padding:1.5rem 1rem .5rem}.nav-brand a{font-size:4rem;line-height:1}.nav-links{flex-wrap:wrap;justify-content:center}.main-content{padding:1.25rem}.table-scroll-container{margin:0 -1.25rem;padding:0 1.25rem}.table-scroll-container:after{content:"";display:block;min-width:1.25rem;height:1px}.table-scroll-container{display:flex}.table-scroll-container .inventory-table{flex-shrink:0}.form-row{grid-template-columns:1fr}.inventory-table{font-size:.875rem}.inventory-table th,.inventory-table td{padding:.5rem}.form-actions{flex-direction:column}.quantity-field{width:100%;justify-content:space-between}.quantity-field .quantity-input{flex:1;max-width:100px}.button-group{width:100%;flex-direction:column}.button-group .btn{width:100%}.filter-top-bar{flex-direction:column}.filter-top-bar .search-input,.filter-top-bar>.clearable-input{width:100%;min-width:0}.upc-search-input-group{width:100%}.upc-search-input,.upc-search-input-group>.clearable-input{flex:1;width:auto}.sort-controls{width:100%}.sort-controls select{flex:1}.btn-toggle-filters{width:100%;justify-content:center}.filter-panel--open{max-height:500px}.filter-panel-inner{flex-direction:column}.filter-panel-inner select,.filter-panel-inner .btn-clear-filters{width:100%}}.scan-page{max-width:700px;margin:0 auto}.scan-steps{display:flex;justify-content:space-between;margin-bottom:2rem;padding:0 1rem}.scan-step{display:flex;flex-direction:column;align-items:center;opacity:.5}.scan-step.active,.scan-step.completed{opacity:1}.scan-step.completed .step-number{background:#22c55e}.step-number{width:2rem;height:2rem;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;margin-bottom:.5rem}.step-label{font-size:.75rem;color:var(--gray-700);text-align:center}.scan-section{background:#fff;padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;text-align:center}.scan-section p{color:var(--gray-500);margin-bottom:1.5rem}.scan-section h2{margin-bottom:.5rem;color:var(--primary-dark)}.btn-large{padding:1rem 2rem;font-size:1rem}.scan-actions{display:flex;justify-content:center;gap:1rem;margin-top:1.5rem}.captured-preview{position:relative;max-width:400px;margin:0 auto 1.5rem}.captured-preview img{width:100%;border-radius:.5rem;border:2px solid var(--gray-200)}.preview-actions{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.capture-buttons{display:flex;flex-direction:column;align-items:center;gap:1rem}.manual-upc-form{max-width:300px;margin:0 auto}.manual-upc-form .form-group{text-align:left}.manual-upc-actions{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.barcode-options{display:flex;flex-direction:column;align-items:center;gap:1rem}.or-divider{color:var(--gray-400);font-size:.8rem;text-transform:lowercase;font-style:italic;padding:.5rem 0}.manual-upc-form{display:flex;gap:.5rem;width:100%;max-width:350px;margin:0 auto}.manual-upc-form>.clearable-input{flex:1}.manual-upc-form .upc-input{flex:1;padding:.75rem 1rem;border:2px solid var(--gray-200);border-radius:.5rem;font-size:1rem;font-family:monospace;text-align:center;letter-spacing:1px}.manual-upc-form .upc-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.manual-upc-inline{display:flex;gap:.5rem;width:100%;max-width:350px}.manual-upc-inline input{flex:1;padding:.625rem;border:1px solid var(--gray-300);border-radius:.375rem;font-size:1rem}.captured-preview.small{max-width:250px}.status-message{color:var(--gray-500);padding:1.5rem 1rem;text-align:center}.lookup-spinner{width:36px;height:36px;margin:0 auto .75rem;border:3px solid var(--gray-700);border-top-color:var(--amber);border-radius:50%;animation:spin .8s linear infinite}.lookup-status-text{font-size:1rem;font-weight:500;color:var(--gray-300);margin-bottom:.25rem}.lookup-status-sub{font-size:.8rem;color:var(--gray-500)}.lookup-failed{display:flex;flex-direction:column;align-items:center;gap:1rem}.upc-display{display:flex;align-items:center;gap:.75rem;background:var(--gray-100);padding:.75rem 1rem;border-radius:.375rem}.upc-label{color:var(--gray-500);font-size:.875rem}.upc-code{font-family:monospace;font-size:1rem;font-weight:600;color:var(--gray-900)}.failed-actions{display:flex;gap:1rem;margin-top:.5rem}.scan-skip{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--gray-200)}.scan-skip .btn-text{font-size:.8rem}.btn-link{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.875rem;padding:.25rem}.btn-link:hover{text-decoration:underline}.scanning-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:.5rem;font-weight:500}.progress-bar{width:80%;height:8px;background:#ffffff4d;border-radius:4px;margin-top:.5rem;overflow:hidden}.progress-fill{height:100%;background:var(--primary-light);transition:width .3s ease}.upc-info{font-family:monospace;background:var(--gray-100);padding:.5rem 1rem;border-radius:.25rem;display:inline-block}.ocr-details{text-align:left;margin-bottom:1.5rem;background:var(--gray-50);padding:1rem;border-radius:.375rem}.ocr-details summary{cursor:pointer;font-weight:500;color:var(--gray-700)}.ocr-details pre{margin-top:.5rem;font-size:.75rem;white-space:pre-wrap;word-break:break-word;max-height:150px;overflow-y:auto}.image-capture{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;z-index:1000;display:flex;flex-direction:column}.image-capture-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--gray-200);background:#0f172a;color:var(--primary-light)}.image-capture-header h3{margin:0}.btn-close{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;color:var(--primary-light)}.btn-close:hover{color:#fff}.capture-options{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;background:var(--gray-50)}.btn-capture{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 2rem;font-size:1.1rem;min-width:200px;border-radius:.5rem}.btn-capture .btn-icon{width:24px;height:24px}.capture-divider{color:var(--gray-400);font-size:.875rem;font-style:italic;padding:.25rem 0}.camera-starting{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.camera-starting .spinner{width:48px;height:48px;border:4px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.camera-starting p{color:var(--gray-600);margin:0}.camera-view{flex:1;display:flex;flex-direction:column;background:#000;min-height:0;overflow:hidden}.camera-view video{flex:1;width:100%;object-fit:contain;min-height:0}.camera-controls{flex-shrink:0;display:flex;justify-content:center;align-items:stretch;gap:1rem;padding:1rem 1.5rem;background:#0f172a}.btn-control{padding:.875rem 2rem;font-size:1rem;min-width:140px;border-radius:10px;font-weight:600}.camera-controls .btn-outline{background:#111827;color:#fff;border:2px solid rgba(255,255,255,.3)}.camera-controls .btn-outline:hover{background:#1f2937;border-color:#ffffff80;color:#fff}.btn-shutter{padding:.875rem 2rem;min-width:140px;border-radius:10px;background:var(--accent);border:none;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1rem;font-weight:600;color:#fff}.btn-shutter svg{width:20px;height:20px;color:#fff}.btn-shutter:hover{background:var(--accent-dark)}.image-preview{flex:1;display:flex;flex-direction:column;padding:1rem;min-height:0;overflow:hidden}.image-preview img{flex:1;width:100%;max-height:calc(100% - 80px);object-fit:contain;border-radius:.5rem}.preview-controls{flex-shrink:0;display:flex;justify-content:center;gap:1rem;padding:1.5rem;background:#fff;border-top:1px solid var(--gray-200)}.scan-section .bottle-form{text-align:left;box-shadow:none;padding:0}.scan-section .form-actions{justify-content:center}.scan-mode-select{display:flex;gap:1.5rem;justify-content:center;margin:2rem 0;flex-wrap:wrap}.scan-mode-option{background:#fff;border:2px solid var(--gray-200);border-radius:12px;padding:2rem;width:200px;text-align:center;cursor:pointer;transition:all .2s ease}.scan-mode-option:hover{border-color:var(--primary);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.scan-mode-option .mode-icon{width:60px;height:60px;margin:0 auto 1rem;color:var(--primary)}.scan-mode-option .mode-icon svg{width:100%;height:100%}.scan-mode-option h3{margin:0 0 .5rem;color:var(--gray-800);font-size:1.2rem}.scan-mode-option p{margin:0;color:var(--gray-500);font-size:.9rem}.upc-lookup-section{background:var(--gray-50);border:2px dashed var(--gray-300);border-radius:12px;padding:1.5rem;margin-bottom:2rem;text-align:center}.upc-lookup-header h3{margin:0 0 .5rem;color:var(--gray-800)}.upc-lookup-header p{margin:0 0 1.25rem;color:var(--gray-500);font-size:.9rem}.quick-add-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.25rem}.btn-scan{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1rem .75rem;border-radius:10px;font-size:.85rem;font-weight:500;text-decoration:none;min-height:80px;transition:all .2s ease}.btn-scan .btn-icon{width:28px;height:28px;flex-shrink:0}.btn-scan span{text-align:center;line-height:1.2}.btn-scan.btn-primary{background:var(--accent)}.btn-scan.btn-primary:hover{background:var(--accent-dark)}.btn-scan:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f973164d}.upc-lookup-section .upc-form{display:flex;gap:.5rem;max-width:400px;margin:0 auto}.upc-lookup-section .upc-form>.clearable-input{flex:1}.upc-lookup-section .upc-form .upc-input{flex:1;padding:.65rem 1rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.95rem}.upc-lookup-section .upc-form .upc-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.lookup-message{margin-top:1rem;padding:.75rem 1rem;border-radius:6px;font-size:.9rem}.lookup-message.success{background:#d4edda;color:#155724}.lookup-message.error{background:#fff3cd;color:#856404}@media (max-width: 600px){.quick-add-buttons{grid-template-columns:1fr}.btn-scan{flex-direction:row;justify-content:flex-start;padding:.875rem 1.25rem;min-height:auto}.btn-scan .btn-icon{width:24px;height:24px}.upc-lookup-section .upc-form{flex-direction:column}.upc-lookup-section .upc-form .upc-input{width:100%}}.locations-page{max-width:700px;margin:0 auto}.add-location-form{background:var(--gray-50);border:2px dashed var(--gray-300);border-radius:12px;padding:1.25rem;margin-bottom:2rem;display:flex;gap:.75rem;align-items:center}.add-location-form .form-input{flex:1;padding:.75rem 1rem;border:1px solid var(--gray-300);border-radius:8px;font-size:1rem}.add-location-form .form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.locations-list{display:flex;flex-direction:column;gap:1rem}.location-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.location-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:linear-gradient(135deg,#0f172a,#1e293b)}.location-header h3{margin:0;color:var(--primary-light);font-size:1.1rem;font-weight:600}.location-header form{display:flex;gap:.5rem;align-items:center;flex:1}.location-header form .form-input{flex:1;padding:.5rem .75rem;border:1px solid var(--gray-400);border-radius:6px;font-size:.95rem}.location-actions{display:flex;gap:.5rem;align-items:stretch}.location-actions .btn{display:inline-flex;align-items:center}.zones-section{padding:1.25rem}.zones-section h4{margin:0 0 .75rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500)}.zones-list{list-style:none;padding:0;margin:0 0 1rem}.zone-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--gray-50);border-radius:8px;margin-bottom:.5rem}.zone-item:last-child{margin-bottom:0}.zone-item span{font-weight:500;color:var(--gray-700)}.zone-item form{display:flex;gap:.5rem;align-items:center;flex:1}.zone-item form .form-input-small{flex:1;padding:.4rem .6rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem}.zone-actions{display:flex;gap:.375rem;align-items:stretch}.zone-actions .btn{display:inline-flex;align-items:center}.add-zone-form{display:flex;gap:.5rem;align-items:center;margin-top:.75rem}.add-zone-form .form-input-small{flex:1;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.9rem}.locations-page .empty-state{text-align:center;padding:2rem;background:#fff;border-radius:12px;color:var(--gray-500)}@media (max-width: 600px){.add-location-form{flex-direction:column}.add-location-form .form-input,.add-location-form .btn{width:100%}.location-header{flex-direction:column;gap:.75rem;align-items:flex-start}.location-actions{width:100%}.location-actions .btn{flex:1}.zone-item{flex-direction:column;align-items:flex-start;gap:.5rem}.zone-actions{width:100%}.zone-actions .btn{flex:1}}.sharing-page{max-width:700px;margin:0 auto}.sharing-sections{display:flex;flex-direction:column;gap:2rem}.sharing-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.sharing-section h2{margin:0;padding:1rem 1.25rem;background:linear-gradient(135deg,#0f172a,#1e293b);color:var(--primary-light);font-size:1.1rem;font-weight:600}.sharing-section .section-description{margin:0;padding:1rem 1.25rem 0;color:var(--gray-500);font-size:.9rem}.share-form{display:flex;gap:.75rem;padding:1rem 1.25rem;background:var(--gray-50);margin:1rem 1.25rem;border-radius:8px;border:1px dashed var(--gray-300)}.share-form .form-input{flex:1;padding:.75rem 1rem;border:1px solid var(--gray-300);border-radius:8px;font-size:1rem}.share-form .form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.shares-list{list-style:none;padding:0 1.25rem 1.25rem;margin:0}.share-item{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;background:var(--gray-50);border-radius:8px;margin-bottom:.5rem}.share-item:last-child{margin-bottom:0}.share-info{display:flex;flex-direction:column;gap:.125rem}.share-name{font-weight:600;color:var(--gray-800)}.share-username{font-size:.85rem;color:var(--gray-500)}.sharing-section .empty-state{margin:0;padding:1.5rem 1.25rem;text-align:center;color:var(--gray-500);font-style:italic}@media (max-width: 600px){.share-form{flex-direction:column}.share-form .form-input,.share-form .btn{width:100%}.share-item{flex-direction:column;align-items:flex-start;gap:.75rem}.share-item .btn{width:100%}}.profile-page{max-width:600px;margin:0 auto}.profile-form{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014}.profile-form .form-section{padding:1.5rem;border-bottom:1px solid var(--gray-200)}.profile-form .form-section:last-of-type{border-bottom:none}.profile-form .form-section h3{margin:0 0 .5rem;font-size:1rem;color:var(--gray-700)}.profile-form .section-description{margin:0 0 1rem;font-size:.875rem;color:var(--gray-500)}.profile-form .form-group{margin-bottom:1rem}.profile-form .form-group:last-child{margin-bottom:0}.profile-form .form-group label{display:block;margin-bottom:.375rem;font-weight:500;color:var(--gray-700);font-size:.875rem}.profile-form .form-input{width:100%;padding:.625rem .875rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.9375rem;transition:border-color .15s,box-shadow .15s}.profile-form .form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.profile-form .form-input.disabled{background-color:var(--gray-100);color:var(--gray-500);cursor:not-allowed}.profile-form .form-hint{display:block;margin-top:.25rem;font-size:.75rem;color:var(--gray-500)}.profile-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.profile-form .form-actions{padding:1.25rem 1.5rem;background:var(--gray-50);border-top:1px solid var(--gray-200)}.profile-form .form-actions .btn{min-width:140px}.profile-page .success-message{background:#dcfce7;color:#166534;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.profile-page .error-message{background:#fee2e2;color:#dc2626;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}@media (max-width: 600px){.profile-form .form-row{grid-template-columns:1fr}.profile-form .form-actions .btn{width:100%}}.admin-page{max-width:1200px;margin:0 auto;padding:2rem}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--gray-200);padding-bottom:.5rem}.tab-btn{padding:.75rem 1.5rem;border:none;background:none;cursor:pointer;font-size:1rem;color:var(--gray-500);border-radius:.5rem .5rem 0 0;transition:all .2s}.tab-btn:hover{color:var(--primary);background:var(--gray-100)}.tab-btn.active{color:var(--primary);background:var(--gray-100);font-weight:600}.admin-content{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.admin-page .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.admin-page .stat-card{background:var(--gray-50);border-radius:8px;padding:1.5rem;text-align:center}.admin-page .stat-card h3{font-size:.875rem;color:var(--gray-500);margin-bottom:.5rem}.admin-page .stat-value{font-size:2.5rem;font-weight:700;color:var(--primary)}.admin-section{margin-bottom:2rem}.admin-section h3{margin-bottom:1rem;color:var(--gray-700);font-size:1.1rem}.type-breakdown{display:flex;flex-direction:column;gap:.5rem}.type-row{display:flex;justify-content:space-between;padding:.5rem 1rem;background:var(--gray-50);border-radius:4px}.type-name{font-weight:500}.type-count{color:var(--primary);font-weight:600}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--gray-200)}.admin-table th{background:var(--gray-50);font-weight:600;color:var(--gray-700)}.admin-table tr:hover{background:var(--gray-50)}.no-data{text-align:center;color:var(--gray-500);padding:2rem!important}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;border:none;cursor:pointer}.badge-admin{background:#dcfce7;color:#166534}.badge-admin:hover{background:#bbf7d0}.badge-user{background:var(--gray-100);color:var(--gray-700)}.badge-user:hover{background:var(--gray-200)}.badge:disabled{cursor:not-allowed;opacity:.6}.action-buttons{display:flex;gap:.5rem}.btn-small{padding:.375rem .75rem;font-size:.75rem;border-radius:4px;cursor:pointer;border:none;font-weight:500}.btn-secondary{background:var(--gray-200);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-300)}.btn-danger{background:#111827;color:#fff}.btn-danger:hover{background:#000}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.admin-settings{display:flex;flex-direction:column;gap:1rem}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--gray-50);border-radius:8px}.setting-info h4{margin:0 0 .25rem;color:var(--gray-900)}.setting-info p{margin:0;font-size:.875rem;color:var(--gray-500)}.toggle-switch{position:relative;display:inline-block;width:50px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--gray-300);transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.action-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.action-promote_admin,.action-demote_admin{background:#dbeafe;color:#1d4ed8}.action-reset_password{background:#dbeafe;color:#3b82f6}.action-delete_user{background:#fee2e2;color:#dc2626}.action-update_settings{background:#dcfce7;color:#166534}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:12px;padding:1.5rem;max-width:400px;width:90%}.success-modal{text-align:center}.success-modal-title,.success-modal-detail{font-size:1rem;font-weight:500;color:var(--gray-900)}.success-modal .modal-actions .btn-primary{background:var(--accent);color:#fff;padding:.75rem 2rem;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:1rem}.success-modal .modal-actions .btn-primary:hover{background:var(--accent-dark)}.modal h3{margin-bottom:1rem;color:var(--gray-900)}.modal p{margin-bottom:1rem;color:var(--gray-700)}.modal .form-group{margin-bottom:1rem}.modal .form-group label{display:block;margin-bottom:.5rem;font-weight:500}.modal .form-group input{width:100%;padding:.75rem;border:1px solid var(--gray-300);border-radius:6px;font-size:1rem}.modal .help-text{display:block;margin-top:.5rem;font-size:.75rem;color:var(--gray-500)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.modal-actions .btn-primary{background:var(--primary);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500}.modal-actions .btn-primary:hover{background:var(--primary-dark)}.modal-actions .btn-secondary{background:var(--gray-200);color:var(--gray-700);padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500}.modal-actions .btn-danger{background:#111827;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:500}.modal-actions .btn-danger:hover{background:#000}.warning-text{color:#dc2626;font-size:.875rem}.nav-admin-link{color:#93c5fd!important;font-weight:600!important}.admin-page .success-message{background:#dcfce7;color:#166534;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;cursor:pointer}.admin-page .error-message{background:#fee2e2;color:#dc2626;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;cursor:pointer}@media (max-width: 768px){.admin-page{padding:1rem}.admin-tabs{flex-wrap:wrap}.tab-btn{padding:.5rem 1rem;font-size:.875rem}.admin-table{display:block;overflow-x:auto}.admin-users-table{overflow-x:visible}.admin-users-table thead{display:none}.admin-users-table tbody{display:flex;flex-direction:column;gap:.75rem}.admin-users-table tbody tr{display:flex;flex-direction:column;background:#fff;border:1px solid var(--gray-200);border-radius:.5rem;padding:.75rem;gap:.35rem}.admin-users-table tbody tr:hover{background:#fff}.admin-users-table tbody td{display:flex;justify-content:space-between;align-items:center;padding:.2rem 0;border-bottom:none;font-size:.875rem}.admin-users-table tbody td:before{content:attr(data-label);font-weight:600;color:var(--gray-500);font-size:.75rem;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;margin-right:1rem}.admin-users-table .action-buttons{flex-direction:row;justify-content:flex-end;gap:.5rem;padding-top:.35rem;border-top:1px solid var(--gray-100);margin-top:.25rem}.admin-users-table .action-buttons:before{display:none}.action-buttons{flex-direction:column}}.star-rating{display:inline-flex;gap:2px;align-items:center}.star-rating .star{cursor:pointer;transition:transform .1s,color .1s}.star-rating .star:hover{transform:scale(1.1)}.star-rating .star.filled{color:#fbbf24}.star-rating .star.empty{color:var(--gray-300)}.star-rating.read-only .star{cursor:default}.star-rating.read-only .star:hover{transform:none}.star-rating.small .star{width:16px;height:16px}.star-rating.medium .star{width:24px;height:24px}.star-rating.large .star{width:32px;height:32px}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026!important}.category-selector{background:var(--gray-50);border:2px dashed var(--gray-300);border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;text-align:center}.category-label{display:block;font-size:.85rem;font-weight:600;color:var(--gray-700);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.category-buttons{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}.quick-add-inline{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--gray-300);display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap}.quick-add-inline .btn-scan{flex-direction:row;min-height:auto;padding:.5rem 2.5rem;gap:.5rem;font-size:.85rem;white-space:nowrap}.quick-add-inline .btn-scan .btn-icon{width:20px;height:20px}.upc-form-inline{display:flex;gap:.5rem;align-items:center}.upc-form-inline>.clearable-input{width:180px;flex-shrink:0}.upc-form-inline .upc-input{padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:6px;font-size:.85rem;width:180px}.upc-form-inline .btn{flex-shrink:0;white-space:nowrap}.upc-form-inline .upc-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.quick-add-inline .lookup-message{width:100%;margin-top:.5rem}.category-btn{padding:.5rem 1rem;border:2px solid var(--gray-300);border-radius:10px;background:#fff;color:var(--gray-700);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease}.category-btn:hover{border-color:var(--accent);color:var(--accent)}.category-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}@media (max-width: 600px){.category-selector{padding:1rem}.category-buttons{grid-template-columns:repeat(3,1fr);gap:.375rem}.category-btn{padding:.4rem .5rem;font-size:.8rem}.quick-add-inline{flex-direction:column}.upc-form-inline{width:100%}.upc-form-inline>.clearable-input{flex:1 1 0;width:auto}.upc-form-inline .upc-input{flex:1 1 0;width:auto}.desktop-only{display:none!important}}.scan-clear-row{display:flex;gap:.5rem;align-items:center}.mobile-only{display:none}@media (max-width: 600px){.mobile-only{display:flex!important}.scan-clear-row{width:100%}.scan-clear-row .btn-scan{padding-left:.5rem;padding-right:.5rem;flex-basis:0;min-width:0}.scan-clear-row .btn-scan:first-child{flex-grow:3}.scan-clear-row .btn-scan.mobile-only{flex-grow:2}}.barcode-scanner{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:1000;display:flex;flex-direction:column}.barcode-scanner-header{display:flex;justify-content:center;align-items:center;padding:1rem;background:#0f172a;color:var(--primary-light);z-index:2;position:relative}.barcode-scanner-header h3{margin:0}.barcode-scanner-header .btn-close{position:absolute;right:.5rem}.barcode-scanner-body{flex:1;position:relative;overflow:hidden}.barcode-scanner-body video{width:100%;height:100%;object-fit:cover}.barcode-scan-region{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:260px;height:260px;box-shadow:0 0 0 9999px #00000080;border-radius:8px;z-index:1}.corner-bracket{position:absolute;width:24px;height:24px;border-color:#fff;border-style:solid;border-width:0;transition:border-color .3s}.corner-bracket.top-left{top:-2px;left:-2px;border-top-width:3px;border-left-width:3px;border-top-left-radius:8px}.corner-bracket.top-right{top:-2px;right:-2px;border-top-width:3px;border-right-width:3px;border-top-right-radius:8px}.corner-bracket.bottom-left{bottom:-2px;left:-2px;border-bottom-width:3px;border-left-width:3px;border-bottom-left-radius:8px}.corner-bracket.bottom-right{bottom:-2px;right:-2px;border-bottom-width:3px;border-right-width:3px;border-bottom-right-radius:8px}.barcode-scan-region.detected .corner-bracket{border-color:#22c55e}.barcode-scan-region.detected{box-shadow:0 0 0 9999px #00000080,0 0 20px #22c55e66}.scan-line{position:absolute;left:8px;right:8px;height:2px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.8),transparent);animation:scanLineMove 2s ease-in-out infinite}@keyframes scanLineMove{0%,to{top:10%}50%{top:90%}}.barcode-scanner-instruction{position:absolute;bottom:1.5rem;left:0;right:0;text-align:center;z-index:2;color:#ffffffe6;font-size:1.17rem;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.6)}.detected-code{display:inline-block;background:#22c55ee6;color:#fff;font-family:monospace;font-size:1.1rem;font-weight:600;padding:.5rem 1.25rem;border-radius:8px;letter-spacing:1px}.barcode-scan-region.locking .corner-bracket{border-color:#f59e0b;animation:lockingPulse .6s ease-in-out infinite}.barcode-scan-region.locking{box-shadow:0 0 0 9999px #00000080,0 0 15px #f59e0b66}@keyframes lockingPulse{0%,to{opacity:1}50%{opacity:.5}}.locking-code{display:inline-block;background:#f59e0bd9;color:#fff;font-family:monospace;font-size:1.1rem;font-weight:600;padding:.5rem 1.25rem;border-radius:8px;letter-spacing:1px;animation:lockingPulse .6s ease-in-out infinite}.barcode-scanner-footer{display:flex;justify-content:center;padding:1rem 1.5rem;background:#0f172a;z-index:2}.barcode-scanner-footer .btn-outline{background:#111827;color:#fff;border:2px solid rgba(255,255,255,.3)}.barcode-scanner-footer .btn-outline:hover{background:#1f2937;border-color:#ffffff80;color:#fff}.query-console{padding:.5rem 0}.query-input{width:100%;font-family:Courier New,Courier,monospace;font-size:.875rem;padding:1rem;border:1px solid var(--gray-300);border-radius:8px;background:#0f172a;color:#e2e8f0;resize:vertical;line-height:1.5}.query-input::placeholder{color:#64748b}.query-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f626}.query-actions{display:flex;align-items:center;gap:1rem;margin-top:.75rem}.query-status{font-size:.8rem;color:var(--gray-500)}.query-error{margin-top:.75rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:6px;font-family:Courier New,Courier,monospace;font-size:.8rem;white-space:pre-wrap}.query-results{margin-top:1rem;overflow-x:auto;border:1px solid var(--gray-200);border-radius:8px}.query-results .admin-table{margin:0;font-size:.8rem}.query-results .admin-table td{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:Courier New,Courier,monospace}.null-value{color:var(--gray-400);font-style:italic}.action-run_query{background:#fef3c7;color:#92400e}.bottle-image{display:block;object-fit:contain;border-radius:4px;background:var(--gray-50)}.bottle-image--thumbnail{width:40px;height:50px}.bottle-image--large{width:260px;height:346px}.bottle-image-cell{width:50px;padding-right:0!important}.bottle-image-hero .bottle-image{box-shadow:0 2px 8px #0000001f;border-radius:8px}@media (max-width: 768px){.bottle-image--thumbnail{width:32px;height:40px}.bottle-image--large{width:140px;height:186px}}.image-search-modal{background:#fff;border-radius:12px;padding:1.5rem;max-width:600px;width:95%;max-height:85vh;overflow-y:auto}.image-search-modal h3{margin:0 0 .25rem;color:var(--gray-900)}.image-search-query{color:var(--gray-500);font-size:.85rem;margin-bottom:1rem}.image-search-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 0}.image-search-loading .spinner{width:36px;height:36px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.image-search-loading p{color:var(--gray-500);margin:0}.image-search-hint{color:var(--gray-500);font-size:.85rem;margin-bottom:.75rem}.image-search-error{background:#fff3cd;color:#856404;padding:.75rem 1rem;border-radius:6px;font-size:.9rem;margin-bottom:1rem}.image-search-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.image-search-item{border:2px solid var(--gray-200);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--gray-50);position:relative}.image-search-item:hover{border-color:var(--primary-light);box-shadow:0 2px 8px #3b82f626}.image-search-item.selected{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f633}.image-search-item img{width:100%;height:100%;object-fit:cover}.image-search-title{position:absolute;bottom:0;left:0;right:0;background:#0009;color:#fff;font-size:.65rem;padding:2px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.image-search-actions{display:flex;gap:.75rem;justify-content:flex-end}.image-upload-section{margin-top:.5rem;margin-bottom:1rem}.image-upload-divider{display:flex;align-items:center;gap:1rem;margin:1rem 0;color:var(--gray-400);font-size:.85rem}.image-upload-divider:before,.image-upload-divider:after{content:"";flex:1;height:1px;background:var(--gray-200)}.image-upload-btn{display:block;width:100%;padding:1rem;border:2px dashed var(--gray-300);border-radius:8px;background:var(--gray-50);color:var(--gray-500);font-size:.9rem;cursor:pointer;transition:border-color .15s,color .15s}.image-upload-btn:hover{border-color:var(--primary-light);color:var(--primary)}.image-upload-preview{position:relative;display:inline-block;border:2px solid var(--primary);border-radius:8px;overflow:hidden;box-shadow:0 0 0 3px #3b82f633}.image-upload-preview img{display:block;max-width:200px;max-height:200px;object-fit:contain}.image-upload-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;border:none;background:#0009;color:#fff;font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.image-upload-remove:hover{background:#000c}.btn-find-image{display:inline-flex;align-items:center;gap:.35rem;margin-top:.5rem;font-size:.85rem;padding:.4rem .75rem}.bottle-image-hero{display:flex;flex-direction:column;align-items:center;margin-bottom:1.5rem}@media (max-width: 600px){.image-search-grid{grid-template-columns:repeat(2,1fr)}.image-search-actions{flex-direction:column}.image-search-actions .btn{width:100%}.image-upload-preview img{max-width:150px;max-height:150px}}.view-bottle-page{max-width:700px;margin:0 auto}.back-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--primary);text-decoration:none;font-size:.875rem;font-weight:500;margin-bottom:1rem}.back-link:hover{color:var(--primary-dark)}.view-bottle-top{display:flex;flex-direction:row;align-items:flex-start;gap:1.5rem;margin-bottom:1.5rem;width:100%}.view-bottle-image-wrap{flex-shrink:0}.view-bottle-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1rem;padding-top:.5rem}.view-bottle-title{margin-bottom:0;line-height:1.2;font-size:1.6rem;text-align:left;word-wrap:break-word;overflow-wrap:break-word}.view-bottle-expression{color:var(--gray-500);font-weight:400;font-size:1.3rem}.view-bottle-badges{display:flex;gap:.5rem;flex-wrap:wrap}.view-header-meta{border-radius:.375rem;overflow:hidden;border:1px solid var(--gray-200);font-size:.8rem}.view-header-row{display:grid;grid-template-columns:1fr 1fr}.view-header-row:nth-child(odd){background:#fff}.view-header-row:nth-child(2n){background:var(--gray-50)}.view-header-row--full{grid-template-columns:1fr}.view-header-field{display:flex;flex-direction:column;gap:0;padding:.25rem .5rem}.view-header-field .view-detail-label{font-size:.6rem}.view-header-field .view-detail-value{font-size:.8rem}.view-bottle-location-info{display:flex;flex-direction:column;gap:.15rem;font-size:.95rem;color:var(--gray-700)}.view-location-line{line-height:1.4}.view-location-label{font-weight:600;color:var(--gray-500);font-size:.8rem;text-transform:uppercase;letter-spacing:.3px}.view-bottle-actions{display:flex;gap:.75rem}.view-detail-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500)}.view-detail-value{font-size:.95rem;color:var(--gray-900)}.bottle-name-link{text-decoration:none;color:inherit;display:block}.bottle-name-link:hover .bottle-name{color:var(--primary)}@media (max-width: 768px){.view-bottle-top{gap:1rem}.view-bottle-title{font-size:1.25rem}.view-bottle-expression{font-size:1.05rem}.view-bottle-location-info{font-size:.85rem}}.collection-toggle.viewing-other{background:#f9731633!important;color:#f97316!important;border-radius:4px}.collection-switcher{min-width:220px}.collection-switcher .collection-option{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:.5rem 1rem;background:none;border:none;color:var(--gray-700);font-size:.85rem;cursor:pointer;text-align:left;white-space:nowrap}.collection-switcher .collection-option:hover{background:var(--gray-100)}.collection-switcher .collection-option.active{font-weight:600;color:var(--primary)}.permission-badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.permission-badge.write{background:#dcfce7;color:#166534}.permission-badge.read{background:#e0e7ff;color:#3730a3}.collection-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:6px 16px;font-size:.85rem;font-weight:500;text-align:center}.collection-banner-write{background:#dcfce7;color:#166534;border-bottom:2px solid #86efac}.collection-banner-read{background:#e0e7ff;color:#3730a3;border-bottom:2px solid #a5b4fc}.collection-banner-btn{background:#ffffffb3!important;border:1px solid rgba(0,0,0,.15)!important;font-size:.75rem!important;padding:2px 10px!important}.share-permission-select{max-width:130px}.permission-select{padding:4px 8px;border:1px solid var(--gray-300);border-radius:4px;font-size:.8rem;background:#fff}.share-actions{display:flex;align-items:center;gap:8px}.spinner{width:36px;height:36px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.loading{display:flex;align-items:center;justify-content:center;padding:3rem}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;box-shadow:0 4px 16px #00000026;font-size:.9rem;font-weight:500;pointer-events:auto;animation:toast-slide-in .25s ease-out;min-width:250px;max-width:420px}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:#dcfce7;color:#166534;border-left:4px solid #22c55e}.toast-error{background:#fef2f2;color:#991b1b;border-left:4px solid #ef4444}.toast-info{background:#eff6ff;color:#1e40af;border-left:4px solid #3b82f6}.toast-warning{background:#fffbeb;color:#92400e;border-left:4px solid #f59e0b}.toast-message{flex:1}.toast-close{background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.5;color:inherit;padding:0 .25rem;line-height:1}.toast-close:hover{opacity:1}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:201}.hamburger-line{display:block;width:24px;height:2px;background:#d6d3d1;border-radius:2px;transition:transform .3s,opacity .3s}.hamburger--open .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger--open .hamburger-line:nth-child(2){opacity:0}.hamburger--open .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu-overlay{display:none}@media (max-width: 768px){.hamburger{display:flex}.nav-links{display:none!important}.mobile-menu-overlay{display:block;position:fixed;top:0;left:0;width:100%;height:100%;background:#0000;z-index:300;pointer-events:none;transition:background .3s ease}.mobile-menu-overlay--open{background:#0009;pointer-events:auto}.mobile-menu{position:absolute;top:0;right:0;width:100%;max-width:320px;height:100%;background:linear-gradient(180deg,#0f172a,#1a2640);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column}.mobile-menu-overlay--open .mobile-menu{transform:translate(0)}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.08)}.mobile-menu-user{font-size:1.1rem;font-weight:600;color:#f1f5f9}.mobile-menu-close{background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:6px;transition:color .15s,background .15s}.mobile-menu-close:hover{color:#f1f5f9;background:#ffffff14}.mobile-menu-section{padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.06)}.mobile-menu-section-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#64748b;padding:0 1.25rem .5rem}.mobile-menu-item{display:flex;align-items:center;gap:.875rem;padding:.8rem 1.25rem;color:#cbd5e1;text-decoration:none;font-size:.95rem;font-weight:500;background:none;border:none;width:100%;text-align:left;cursor:pointer;transition:background .15s,color .15s}.mobile-menu-item:hover{background:#ffffff0f;color:#f1f5f9}.mobile-menu-item.active{color:var(--accent, #f59e0b);background:#f59e0b14}.mobile-menu-item.active svg{color:var(--accent, #f59e0b)}.mobile-menu-item svg{flex-shrink:0;color:#64748b;transition:color .15s}.mobile-menu-item:hover svg{color:#94a3b8}.mobile-menu-admin{color:#a78bfa}.mobile-menu-admin svg{color:#a78bfa}.mobile-menu-collection{position:relative}.mobile-menu-collection.active{color:var(--accent, #f59e0b);background:#f59e0b14}.mobile-menu-collection-info{display:flex;flex-direction:column;gap:2px}.mobile-menu-collection-info .permission-badge{font-size:.65rem}.mobile-menu-footer{margin-top:auto;padding:.75rem 0;border-top:1px solid rgba(255,255,255,.08)}.mobile-menu-logout{display:flex;align-items:center;gap:.875rem;padding:.8rem 1.25rem;color:#ef4444;font-size:.95rem;font-weight:500;background:none;border:none;width:100%;text-align:left;cursor:pointer;transition:background .15s}.mobile-menu-logout svg{color:#ef4444;flex-shrink:0}.mobile-menu-logout:hover{background:#ef444414}}.inventory-cards{display:none}@media (max-width: 768px){.inventory-cards{display:flex;flex-direction:column;gap:.75rem}.table-scroll-container{display:none!important}.inventory-card{display:flex;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;overflow:hidden;text-decoration:none;color:inherit;transition:box-shadow .15s;position:relative}.inventory-card:hover{box-shadow:0 4px 16px #0000001f}.inventory-card-image{flex-shrink:0;width:70px;display:flex;align-items:center;justify-content:center;padding:.5rem;background:var(--gray-50)}.inventory-card-image .bottle-image{width:54px;height:68px}.inventory-card-body{flex:1;padding:.75rem;min-width:0;display:flex;flex-direction:column;gap:.25rem}.inventory-card-title{font-weight:600;font-size:.95rem;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inventory-card-expression{font-size:.8rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inventory-card-meta{display:flex;gap:.375rem;flex-wrap:wrap}.inventory-card-meta .type-badge{font-size:.65rem;padding:1px 6px}.inventory-card-details{display:flex;gap:.5rem;font-size:.75rem;color:var(--gray-500);flex-wrap:wrap;align-items:center}.inventory-card-details .status-badge{font-size:.7rem}.inventory-card-location{font-size:.75rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inventory-card-actions{display:flex;flex-direction:column;gap:.375rem;padding:.5rem;justify-content:center;border-left:1px solid var(--gray-100)}.inventory-card-actions .btn{font-size:.7rem;padding:.25rem .5rem;white-space:nowrap}}.fill-level-slider{display:flex;align-items:center;gap:.75rem}.fill-slider{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--gray-200);border-radius:3px;outline:none;cursor:pointer}.fill-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:var(--primary);border-radius:50%;cursor:pointer;border:2px solid white;box-shadow:0 1px 4px #0003}.fill-slider::-moz-range-thumb{width:20px;height:20px;background:var(--primary);border-radius:50%;cursor:pointer;border:2px solid white;box-shadow:0 1px 4px #0003}.fill-slider-value{font-weight:600;font-size:.95rem;color:var(--gray-700);min-width:3rem;text-align:right}.fill-mode-options{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.fill-mode-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:2px solid var(--gray-200);border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s}.fill-mode-option:hover{border-color:var(--primary-light);background:var(--gray-50)}.fill-mode-option.active{border-color:var(--primary);background:#eff6ff}.fill-mode-option input[type=radio]{accent-color:var(--primary);width:18px;height:18px;flex-shrink:0}.fill-mode-content{display:flex;flex-direction:column;gap:.125rem}.fill-mode-title{font-weight:600;font-size:.9rem;color:var(--gray-900)}.fill-mode-desc{font-size:.8rem;color:var(--gray-500)}@media (max-width: 768px){.toast-container{top:auto;bottom:1rem;right:.5rem;left:.5rem}.toast{min-width:0;max-width:100%}}.dashboard-panels{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.dashboard-panel{background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;overflow:hidden}.dashboard-panel h2{font-size:.95rem;font-weight:600;color:#fff;margin:0;padding:10px 16px;background:linear-gradient(135deg,#0f172a,#1e293b)}.panel-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;color:var(--gray-500);text-align:center}.panel-empty svg{color:#22c55e}.panel-empty p{margin:0;font-size:.9rem}.low-fill-header{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#0f172a,#1e293b);padding:10px 16px}.low-fill-header h2{margin:0;padding:0;background:none}.low-fill-toggles{display:flex;gap:6px}.low-fill-toggle{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:12px;border:1.5px solid rgba(255,255,255,.2);background:transparent;color:#fff6;cursor:pointer;transition:all .15s}.low-fill-toggle:hover{border-color:#fff6;color:#fff9}.low-fill-toggle.active.empty{background:#fef2f2;color:#991b1b;border-color:#fca5a5}.low-fill-toggle.active.low{background:#fef3c7;color:#92400e;border-color:#fcd34d}.low-fill-toggle.active.no-backup{background:#fef2f2;color:#dc2626;border-color:#fca5a5}.low-fill-list{list-style:none;padding:0;margin:0}.low-fill-item{display:flex;align-items:center;gap:.75rem;padding:8px 16px;text-decoration:none;color:inherit;border-bottom:1px solid var(--gray-100);transition:background .15s}.low-fill-item:hover{background:var(--gray-50)}.low-fill-list li:last-child .low-fill-item{border-bottom:none}.low-fill-info{flex:1;min-width:0}.low-fill-name{display:block;font-weight:600;font-size:.85rem;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.low-fill-expression{display:block;font-size:.75rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.low-fill-backup{display:block;font-size:.7rem;color:#16a34a;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.low-fill-no-backup{display:block;font-size:.7rem;color:#dc2626;font-weight:500}.low-fill-badge{flex-shrink:0;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:12px;background:#fef3c7;color:#92400e}.low-fill-badge.empty{background:#fef2f2;color:#991b1b}.breakdown-donut-container{display:flex;align-items:center;gap:1rem;padding:16px}.breakdown-donut-wrap{position:relative;width:120px;height:120px;flex-shrink:0}.breakdown-donut-svg{width:100%;height:100%;transform:rotate(-90deg)}.breakdown-donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;line-height:1.2}.breakdown-donut-total{display:block;font-size:1.25rem;font-weight:700;color:var(--gray-900)}.breakdown-donut-label{display:block;font-size:.65rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.breakdown-legend{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.breakdown-legend-item{display:flex;align-items:center;gap:6px;text-decoration:none;color:inherit;padding:3px 0;transition:opacity .15s}.breakdown-legend-item:hover{opacity:.7}.breakdown-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.breakdown-legend-name{flex:1;font-size:.8rem;color:var(--gray-700)}.breakdown-legend-count{font-size:.8rem;font-weight:600;color:var(--gray-700)}.breakdown-divider{border-top:1px solid var(--gray-200, #e5e7eb);margin:4px 16px 0;padding-top:10px}.breakdown-divider-label{font-size:.78rem;font-weight:600;color:var(--gray-500, #6b7280);text-transform:uppercase;letter-spacing:.3px}.distillery-chart{padding:8px 16px 12px;display:flex;flex-direction:column;gap:8px}.distillery-bar-row{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;border-radius:4px;padding:2px 0;transition:background .15s}.distillery-bar-row:hover{background:var(--gray-50, #f9fafb)}.distillery-bar-label{width:140px;min-width:140px;font-size:.8rem;font-weight:500;color:var(--gray-700, #374151);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}.distillery-bar-track{flex:1;height:20px;background:var(--gray-100, #f3f4f6);border-radius:4px;overflow:hidden}.distillery-bar-fill{height:100%;border-radius:4px;min-width:4px;transition:width .4s ease}.distillery-bar-count{width:28px;min-width:28px;font-size:.8rem;font-weight:700;color:var(--gray-700, #374151);text-align:right}@media (max-width: 768px){.dashboard-panels{grid-template-columns:1fr}.distillery-bar-label{width:100px;min-width:100px;font-size:.75rem}}.shopping-page{max-width:800px;margin:0 auto}.shopping-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.shopping-header h1{margin-bottom:0}.btn-add-wanted{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:6px;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-add-wanted:hover{background:var(--accent-dark)}.btn-add-wanted--cancel{background:var(--gray-500, #6b7280)}.btn-add-wanted--cancel:hover{background:var(--gray-600, #4b5563)}.btn-add-wanted svg{flex-shrink:0}.shopping-form{background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;padding:1.5rem;margin-bottom:1.5rem;border-top:3px solid var(--primary)}.shopping-form h3{margin:0 0 1rem;color:var(--primary-dark)}.shopping-items{display:flex;flex-direction:column;gap:.5rem}.shopping-item{display:flex;align-items:flex-start;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f;overflow:hidden;transition:box-shadow .15s}.shopping-item:hover{box-shadow:0 4px 16px #0000001a}.shopping-item.purchased{opacity:.5}.shopping-item.purchased .shopping-item-title{text-decoration:line-through}.shopping-priority{width:5px;align-self:stretch;flex-shrink:0}.shopping-priority.priority-high{background:#ef4444}.shopping-priority.priority-medium{background:#f59e0b}.shopping-priority.priority-low{background:#22c55e}.shopping-item-body{flex:1;padding:.75rem 1rem;min-width:0}.shopping-item-title{font-weight:600;font-size:.95rem;color:var(--gray-900)}.shopping-item-expression{font-size:.8rem;color:var(--gray-500);margin-top:.125rem}.shopping-item-meta{display:flex;gap:.375rem;flex-wrap:wrap;align-items:center;margin-top:.375rem}.shopping-item-meta .type-badge{font-size:.65rem;padding:1px 6px}.priority-badge{font-size:.65rem;font-weight:600;padding:1px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px}.priority-badge-high{background:#fef2f2;color:#dc2626}.priority-badge-medium{background:#fffbeb;color:#d97706}.priority-badge-low{background:#f0fdf4;color:#16a34a}.shopping-price{font-size:.8rem;font-weight:600;color:#10b981}.shopping-item-notes{font-size:.8rem;color:var(--gray-500);margin-top:.375rem;line-height:1.4}.shopping-item-actions{display:flex;gap:.375rem;padding:.75rem .5rem;align-items:flex-start}.shopping-item-actions .btn{padding:.375rem;display:flex;align-items:center;justify-content:center}.btn-copy{background:#0891b2;color:#fff}.btn-copy:hover{background:#0e7490}.btn-wanted{background:var(--primary);color:#fff}.btn-wanted:hover{background:var(--primary-dark)}.btn-purchase{background:#22c55e;color:#fff}.btn-purchase:hover{background:#16a34a}.shopping-toggle-purchased{margin:1rem 0 .5rem}.shopping-items-purchased{opacity:.7}@media (max-width: 768px){.shopping-header{flex-direction:column;align-items:stretch;gap:.75rem}.shopping-header h1{margin-bottom:0}}
