:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--primary-color);text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;font-family:system-ui,-apple-system,sans-serif;background-color:var(--bg-color);line-height:1.5;color:var(--text-color);transition:all .3s ease;min-height:100vh}body.modal-open{overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 8px 32px #00000026;width:380px;max-width:95vw;max-height:90vh;overflow-y:auto;position:relative}.modal h2{margin-top:0;margin-bottom:2rem;color:#1f2937;font-size:1.5rem;font-weight:700;text-align:center;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.form-row{display:flex;flex-direction:column;margin-bottom:1.5rem}.form-row label{display:flex;flex-direction:column;font-weight:600;color:#374151;margin-bottom:.5rem;font-size:.875rem;text-transform:uppercase;letter-spacing:.025em}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.container{max-width:900px;margin:2rem auto;padding:2rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014}h1{text-align:center;margin-bottom:2rem}.fragrance-form{display:flex;flex-direction:column;gap:0;margin-bottom:0}.fragrance-form input[type=text],.fragrance-form input[type=number],.fragrance-form input[type=url]{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.fragrance-form input[type=text]:focus,.fragrance-form input[type=number]:focus,.fragrance-form input[type=url]:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.fragrance-form button{padding:.75rem 1.5rem;border:none;background:#646cff;color:#fff;border-radius:8px;cursor:pointer;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.025em;transition:all .2s ease;margin-right:.75rem;min-width:120px}.fragrance-form button:hover{background:#5a5fd8;transform:translateY(-1px);box-shadow:0 4px 12px #646cff4d}.fragrance-form button[type=button]{background:#6b7280}.fragrance-form button[type=button]:hover{background:#5b626f;box-shadow:0 4px 12px #6b72804d}.fragrance-form .form-row:last-child{display:flex;flex-direction:row;justify-content:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.fragrance-form input[type=checkbox]{width:18px;height:18px;accent-color:#646cff;margin-right:.5rem}.fragrance-form .checkbox-row{display:flex;flex-direction:row;align-items:center;margin-top:.5rem}.fragrance-form .checkbox-row label{margin:0;font-weight:500;text-transform:none;letter-spacing:normal;color:#374151}.error{color:#b00;margin-bottom:1rem}.fragrance-table{width:100%;border-collapse:collapse;margin-top:1rem}.fragrance-table th,.fragrance-table td{border:1px solid #eee;padding:.5rem .75rem;text-align:left}.fragrance-table th{background:#f6f6ff}.fragrance-table td button{margin-right:.5rem;padding:.25rem .75rem;border-radius:4px;border:none;background:#646cff;color:#fff;cursor:pointer}.fragrance-table td button:last-child{background:#b00}.fragrance-table .clickable-row{cursor:pointer;transition:background-color .2s ease}.fragrance-table .clickable-row:hover{background-color:#f8faff}.container.dark-mode .fragrance-table .clickable-row:hover{background-color:#374151}.card{padding:2em}.read-the-docs{color:#888}body.dark-mode{background:#0f0f0f;color:#e0e0e0;transition:background-color .3s ease}.container.dark-mode{background:#1a1a1a;color:#e0e0e0;box-shadow:0 2px 8px #ffffff0d}.container.dark-mode .fragrance-table th{background:#2d2d2d;color:#e0e0e0;border-color:#444}.container.dark-mode .fragrance-table td{border-color:#444;color:#e0e0e0}.container.dark-mode .modal{background:#2d2d2d;color:#e0e0e0;box-shadow:0 8px 32px #0006}.container.dark-mode .modal h2{color:#e0e0e0;border-bottom-color:#404040}.container.dark-mode .form-row label,.container.dark-mode .fragrance-form .checkbox-row label{color:#d1d5db}.container.dark-mode .fragrance-form .form-row:last-child{border-top-color:#404040}.container.dark-mode .fragrance-form input[type=text],.container.dark-mode .fragrance-form input[type=number],.container.dark-mode .fragrance-form input[type=url]{background:#1a1a1a;color:#e0e0e0;border-color:#555}.container.dark-mode .fragrance-form input[type=text]:focus,.container.dark-mode .fragrance-form input[type=number]:focus,.container.dark-mode .fragrance-form input[type=url]:focus{outline:1px solid #646cff}.container.dark-mode .error{color:#ff6b6b}.modal-close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover{background:#f3f4f6;color:#374151}.modal-delete-btn{position:absolute;top:1rem;left:1rem;background:#ef4444;border:none;cursor:pointer;color:#fff;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #ef444433}.modal-delete-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.modal-delete-btn:active{transform:translateY(0);box-shadow:0 2px 4px #ef444433}.container.dark-mode .modal-close-btn{color:#9ca3af}.container.dark-mode .modal-close-btn:hover{background:#374151;color:#d1d5db}.search-container{position:relative;margin-bottom:1.5rem;width:100%}.search-input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;background:#fff;box-sizing:border-box}.search-input:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#6b7280;font-size:1rem;pointer-events:none}.container.dark-mode .search-input{background:#1a1a1a;color:#e0e0e0;border-color:#555}.container.dark-mode .search-input:focus{border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.container.dark-mode .search-icon{color:#9ca3af}.qr-scanner-modal{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 8px 32px #00000026;width:400px;max-width:95vw;max-height:90vh;overflow-y:auto;position:relative;text-align:center}.scanner-container{margin-top:1rem}.scanner-video{width:100%;max-width:300px;height:300px;border-radius:8px;background:#000;object-fit:cover}.scanner-instructions{margin-top:1rem;color:#6b7280;font-size:.875rem;padding:.75rem;background:#f9fafb;border-radius:6px}.camera-selection{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:1rem}.camera-selection-label{font-size:.875rem;font-weight:600;color:#374151}.camera-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.camera-btn{padding:.5rem 1rem;border:2px solid #d1d5db;border-radius:.375rem;background:#f9fafb;color:#374151;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s ease;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.camera-btn:hover{border-color:#9ca3af;background:#f3f4f6}.camera-btn.active{border-color:#6366f1;background:#6366f1;color:#fff}.camera-btn.active:hover{background:#4f46e5}.container.dark-mode .qr-scanner-modal{background:#2d2d2d;color:#e0e0e0;box-shadow:0 8px 32px #0006}.container.dark-mode .qr-scanner-modal h2{color:#e0e0e0}.container.dark-mode .scanner-instructions{background:#374151;color:#d1d5db}.container.dark-mode .camera-selection-label{color:#e0e0e0}.container.dark-mode .camera-btn{border-color:#4b5563;background:#374151;color:#d1d5db}.container.dark-mode .camera-btn:hover{border-color:#6b7280;background:#4b5563}.container.dark-mode .camera-btn.active{border-color:#6366f1;background:#6366f1;color:#fff}.url-input-container{text-align:left}.url-input-container label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.025em}.url-input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;background:#fff;box-sizing:border-box}.url-input:focus{outline:none;border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.url-instructions{margin-top:.75rem;color:#6b7280;font-size:.875rem;padding:.75rem;background:#f9fafb;border-radius:6px;line-height:1.4}.container.dark-mode .url-input-container label{color:#d1d5db}.container.dark-mode .url-input{background:#1a1a1a;color:#e0e0e0;border-color:#555}.container.dark-mode .url-input:focus{border-color:#646cff;box-shadow:0 0 0 3px #646cff1a}.container.dark-mode .url-instructions{background:#374151;color:#d1d5db}.slider{width:100%;height:6px;border-radius:3px;background:#e5e7eb;outline:none;transition:background .2s ease;cursor:pointer;-webkit-appearance:none;appearance:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#646cff;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0003;transition:all .2s ease}.slider::-webkit-slider-thumb:hover{background:#5a5fd8;transform:scale(1.1);box-shadow:0 3px 6px #0000004d}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#646cff;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px #0003;transition:all .2s ease}.slider::-moz-range-thumb:hover{background:#5a5fd8;transform:scale(1.1);box-shadow:0 3px 6px #0000004d}.slider::-moz-range-track{width:100%;height:6px;cursor:pointer;background:#e5e7eb;border-radius:3px;border:none}.container.dark-mode .slider{background:#4b5563}.container.dark-mode .slider::-webkit-slider-thumb{border-color:#374151}.container.dark-mode .slider::-moz-range-thumb{border-color:#374151}.container.dark-mode .slider::-moz-range-track{background:#4b5563}.header-container{display:flex;justify-content:center;align-items:center;margin-bottom:1rem;padding:3rem 1rem;border-bottom:2px solid #e5e7eb;background:#f9f3ed;background-image:repeating-linear-gradient(0deg,transparent,transparent 50px,rgba(204,153,102,.05) 50px,rgba(204,153,102,.05) 100px),repeating-linear-gradient(90deg,transparent,transparent 50px,rgba(204,153,102,.05) 50px,rgba(204,153,102,.05) 100px),url("data:image/svg+xml,%3Csvg width='150' height='150' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='floral' x='0' y='0' width='150' height='150' patternUnits='userSpaceOnUse'%3E%3Crect fill='%23f9f3ed' width='150' height='150'/%3E%3Cg%3E%3Cellipse cx='22' cy='25' rx='12' ry='16' fill='%23e8c4a0' opacity='0.6'/%3E%3Cellipse cx='14' cy='23' rx='10' ry='14' fill='%23f0d6b8' opacity='0.7' transform='rotate(-30 14 23)'/%3E%3Cellipse cx='30' cy='23' rx='10' ry='14' fill='%23f0d6b8' opacity='0.7' transform='rotate(30 30 23)'/%3E%3Cellipse cx='22' cy='15' rx='10' ry='14' fill='%23f0d6b8' opacity='0.7' transform='rotate(0 22 15)'/%3E%3Cellipse cx='22' cy='31' rx='10' ry='14' fill='%23f0d6b8' opacity='0.7' transform='rotate(0 22 31)'/%3E%3Ccircle cx='22' cy='25' r='5' fill='%23c9a66b' opacity='0.8'/%3E%3Cpath d='M17 30 Q12 40 17 45' stroke='%2398b897' fill='none' stroke-width='2' opacity='0.6'/%3E%3C/g%3E%3Cg%3E%3Cellipse cx='108' cy='38' rx='10' ry='14' fill='%23dac8e8' opacity='0.6'/%3E%3Cellipse cx='102' cy='36' rx='8' ry='12' fill='%23e8dcf5' opacity='0.7' transform='rotate(-35 102 36)'/%3E%3Cellipse cx='114' cy='36' rx='8' ry='12' fill='%23e8dcf5' opacity='0.7' transform='rotate(35 114 36)'/%3E%3Cellipse cx='108' cy='30' rx='8' ry='12' fill='%23e8dcf5' opacity='0.7'/%3E%3Cellipse cx='108' cy='42' rx='8' ry='12' fill='%23e8dcf5' opacity='0.7'/%3E%3Ccircle cx='108' cy='38' r='4' fill='%23a88bc4' opacity='0.7'/%3E%3Cpath d='M106 43 Q103 50 106 56' stroke='%2398b897' fill='none' stroke-width='1.5' opacity='0.6'/%3E%3C/g%3E%3Cg%3E%3Cellipse cx='68' cy='82' rx='13' ry='17' fill='%23ffe5b8' opacity='0.6'/%3E%3Cellipse cx='61' cy='80' rx='11' ry='15' fill='%23fff0cc' opacity='0.7' transform='rotate(-25 61 80)'/%3E%3Cellipse cx='75' cy='80' rx='11' ry='15' fill='%23fff0cc' opacity='0.7' transform='rotate(25 75 80)'/%3E%3Cellipse cx='68' cy='73' rx='11' ry='15' fill='%23fff0cc' opacity='0.7'/%3E%3Cellipse cx='68' cy='89' rx='11' ry='15' fill='%23fff0cc' opacity='0.7'/%3E%3Ccircle cx='68' cy='82' r='5' fill='%23d4a86e' opacity='0.8'/%3E%3Cpath d='M65 87 Q61 95 65 102' stroke='%2398b897' fill='none' stroke-width='2' opacity='0.6'/%3E%3C/g%3E%3Cg%3E%3Cellipse cx='38' cy='108' rx='11' ry='15' fill='%23f0d6b8' opacity='0.6'/%3E%3Cellipse cx='32' cy='106' rx='9' ry='13' fill='%23fce7d6' opacity='0.7' transform='rotate(-28 32 106)'/%3E%3Cellipse cx='44' cy='106' rx='9' ry='13' fill='%23fce7d6' opacity='0.7' transform='rotate(28 44 106)'/%3E%3Cellipse cx='38' cy='100' rx='9' ry='13' fill='%23fce7d6' opacity='0.7'/%3E%3Cellipse cx='38' cy='114' rx='9' ry='13' fill='%23fce7d6' opacity='0.7'/%3E%3Ccircle cx='38' cy='108' r='4' fill='%23d4a574' opacity='0.8'/%3E%3C/g%3E%3Cg%3E%3Cellipse cx='132' cy='115' rx='10' ry='13' fill='%23e8c4a0' opacity='0.6'/%3E%3Cellipse cx='127' cy='113' rx='8' ry='11' fill='%23f0d6b8' opacity='0.7' transform='rotate(-32 127 113)'/%3E%3Cellipse cx='137' cy='113' rx='8' ry='11' fill='%23f0d6b8' opacity='0.7' transform='rotate(32 137 113)'/%3E%3Cellipse cx='132' cy='108' rx='8' ry='11' fill='%23f0d6b8' opacity='0.7'/%3E%3Cellipse cx='132' cy='120' rx='8' ry='11' fill='%23f0d6b8' opacity='0.7'/%3E%3Ccircle cx='132' cy='115' r='4' fill='%23c9a66b' opacity='0.8'/%3E%3C/g%3E%3Cpath d='M0 45 Q20 38 45 43 Q70 48 95 42 Q120 36 150 44' stroke='%2398b897' fill='none' stroke-width='2' opacity='0.4'/%3E%3Cpath d='M0 95 Q30 88 60 93 Q90 98 120 92 Q135 87 150 94' stroke='%2398b897' fill='none' stroke-width='2' opacity='0.4'/%3E%3Cellipse cx='55' cy='15' rx='4' ry='6' fill='%23e8dcf5' opacity='0.6' transform='rotate(40 55 15)'/%3E%3Cellipse cx='93' cy='58' rx='4' ry='6' fill='%23f0d6b8' opacity='0.6' transform='rotate(-25 93 58)'/%3E%3Cellipse cx='15' cy='95' rx='4' ry='6' fill='%23dac8e8' opacity='0.6' transform='rotate(55 15 95)'/%3E%3Cellipse cx='138' cy='72' rx='4' ry='6' fill='%23ffe5b8' opacity='0.6' transform='rotate(-15 138 72)'/%3E%3Cellipse cx='85' cy='125' rx='4' ry='6' fill='%23e8c4a0' opacity='0.6' transform='rotate(28 85 125)'/%3E%3Cellipse cx='12' cy='62' rx='4' ry='6' fill='%23dac8e8' opacity='0.6' transform='rotate(-42 12 62)'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='150' height='150' fill='url(%23floral)'/%3E%3C/svg%3E");background-size:auto,auto,150px 150px;border-radius:12px 12px 0 0;position:relative;overflow:hidden}.header-container:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#ffffff4d,#f9f3ed33);pointer-events:none;z-index:0}.header-container h1{position:relative;z-index:1;text-shadow:0 2px 4px rgba(255,255,255,.9)}.header-buttons{display:flex;gap:.75rem;align-items:center}.action-buttons-container{display:flex;gap:1rem;justify-content:center;align-items:center;margin-bottom:2rem;padding:1rem;background:#f8faff;border:1px solid #e5e7eb;border-radius:.75rem;flex-wrap:wrap}.action-button{padding:.75rem 1.25rem;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s ease;text-align:center;min-width:120px}.action-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.action-button.primary{background:#646cff}.action-button.primary:hover{background:#535bf2}.action-button.secondary{background:#f59e0b}.action-button.secondary:hover{background:#d97706}.action-button.success{background:#059669}.action-button.success:hover{background:#047857}.action-button.dark-toggle{background:#6b7280}.action-button.dark-toggle:hover{background:#4b5563}.container.dark-mode .action-buttons-container{background:#1f2937;border-color:#404040}.container.dark-mode .header-container{border-bottom-color:#404040;background:#2d3748;background-image:repeating-linear-gradient(0deg,transparent,transparent 50px,rgba(105,80,65,.08) 50px,rgba(105,80,65,.08) 100px),repeating-linear-gradient(90deg,transparent,transparent 50px,rgba(105,80,65,.08) 50px,rgba(105,80,65,.08) 100px),url("data:image/svg+xml,%3Csvg width='150' height='150' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='dfloral' x='0' y='0' width='150' height='150' patternUnits='userSpaceOnUse'%3E%3Crect fill='%232d3748' width='150' height='150'/%3E%3Cg%3E%3Cellipse cx='22' cy='25' rx='12' ry='16' fill='%23a0826a' opacity='0.5'/%3E%3Cellipse cx='14' cy='23' rx='10' ry='14' fill='%23b89876' opacity='0.6' transform='rotate(-30 14 23)'/%3E%3Cellipse cx='30' cy='23' rx='10' ry='14' fill='%23b89876' opacity='0.6' transform='rotate(30 30 23)'/%3E%3Cellipse cx='22' cy='15' rx='10' ry='14' fill='%23b89876' opacity='0.6' transform='rotate(0 22 15)'/%3E%3Cellipse cx='22' cy='31' rx='10' ry='14' fill='%23b89876' opacity='0.6' transform='rotate(0 22 31)'/%3E%3Ccircle cx='22' cy='25' r='5' fill='%23755a3e' opacity='0.7'/%3E%3Cpath d='M17 30 Q12 40 17 45' stroke='%23567568' fill='none' stroke-width='2' opacity='0.5'/%3E%3C/g%3E%3Cg%3E%3Cellipse cx='108' cy='38' rx='10' ry='14' fill='%23997fa5' opacity='0.5'/%3E%3Cellipse cx='102' cy='36' rx='8' ry='12' fill='%23ad94ba' opacity='0.6' transform='rotate(-35 102 36)'/%3E%3Cellipse cx='114' cy='36' rx='8' ry='12' fill='%23ad94ba' opacity='0.6' transform='rotate(35 114 36)'/%3E%3Cellipse cx='108' cy='30' rx='8' ry='12' fill='%23ad94ba' opacity='0.6'/%3E%3Cellipse cx='108' cy='42' rx='8' ry='12' fill='%23ad94ba' opacity='0.6'/%3E%3Ccircle cx='108' cy='38' r='4' fill='%236b5678' opacity='0.6'/%3E%3Cpath d='M106 43 Q103 50 106 56' stroke='%23567568' fill='none' stroke-width='1.5' opacity='0.5'/%3E%3C/g%3E%3Cg%3E%3Cellipse cx='68' cy='82' rx='13' ry='17' fill='%23cda86f' opacity='0.5'/%3E%3Cellipse cx='61' cy='80' rx='11' ry='15' fill='%23dbb87f' opacity='0.6' transform='rotate(-25 61 80)'/%3E%3Cellipse cx='75' cy='80' rx='11' ry='15' fill='%23dbb87f' opacity='0.6' transform='rotate(25 75 80)'/%3E%3Cellipse cx='68' cy='73' rx='11' ry='15' fill='%23dbb87f' opacity='0.6'/%3E%3Cellipse cx='68' cy='89' rx='11' ry='15' fill='%23dbb87f' opacity='0.6'/%3E%3Ccircle cx='68' cy='82' r='5' fill='%23937550' opacity='0.7'/%3E%3Cpath d='M65 87 Q61 95 65 102' stroke='%23567568' fill='none' stroke-width='2' opacity='0.5'/%3E%3C/g%3E%3Cg%3E%3Cellipse cx='38' cy='108' rx='11' ry='15' fill='%23b89876' opacity='0.5'/%3E%3Cellipse cx='32' cy='106' rx='9' ry='13' fill='%23c9a88a' opacity='0.6' transform='rotate(-28 32 106)'/%3E%3Cellipse cx='44' cy='106' rx='9' ry='13' fill='%23c9a88a' opacity='0.6' transform='rotate(28 44 106)'/%3E%3Cellipse cx='38' cy='100' rx='9' ry='13' fill='%23c9a88a' opacity='0.6'/%3E%3Cellipse cx='38' cy='114' rx='9' ry='13' fill='%23c9a88a' opacity='0.6'/%3E%3Ccircle cx='38' cy='108' r='4' fill='%238b6f47' opacity='0.7'/%3E%3C/g%3E%3Cg%3E%3Cellipse cx='132' cy='115' rx='10' ry='13' fill='%23a0826a' opacity='0.5'/%3E%3Cellipse cx='127' cy='113' rx='8' ry='11' fill='%23b89876' opacity='0.6' transform='rotate(-32 127 113)'/%3E%3Cellipse cx='137' cy='113' rx='8' ry='11' fill='%23b89876' opacity='0.6' transform='rotate(32 137 113)'/%3E%3Cellipse cx='132' cy='108' rx='8' ry='11' fill='%23b89876' opacity='0.6'/%3E%3Cellipse cx='132' cy='120' rx='8' ry='11' fill='%23b89876' opacity='0.6'/%3E%3Ccircle cx='132' cy='115' r='4' fill='%23755a3e' opacity='0.7'/%3E%3C/g%3E%3Cpath d='M0 45 Q20 38 45 43 Q70 48 95 42 Q120 36 150 44' stroke='%23567568' fill='none' stroke-width='2' opacity='0.35'/%3E%3Cpath d='M0 95 Q30 88 60 93 Q90 98 120 92 Q135 87 150 94' stroke='%23567568' fill='none' stroke-width='2' opacity='0.35'/%3E%3Cellipse cx='55' cy='15' rx='4' ry='6' fill='%23ad94ba' opacity='0.5' transform='rotate(40 55 15)'/%3E%3Cellipse cx='93' cy='58' rx='4' ry='6' fill='%23b89876' opacity='0.5' transform='rotate(-25 93 58)'/%3E%3Cellipse cx='15' cy='95' rx='4' ry='6' fill='%23997fa5' opacity='0.5' transform='rotate(55 15 95)'/%3E%3Cellipse cx='138' cy='72' rx='4' ry='6' fill='%23cda86f' opacity='0.5' transform='rotate(-15 138 72)'/%3E%3Cellipse cx='85' cy='125' rx='4' ry='6' fill='%23a0826a' opacity='0.5' transform='rotate(28 85 125)'/%3E%3Cellipse cx='12' cy='62' rx='4' ry='6' fill='%23997fa5' opacity='0.5' transform='rotate(-42 12 62)'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='150' height='150' fill='url(%23dfloral)'/%3E%3C/svg%3E");background-size:auto,auto,150px 150px}.container.dark-mode .header-container:before{background:linear-gradient(135deg,#1a1a1a66,#2d374833)}.container.dark-mode .header-container h1{text-shadow:0 2px 8px rgba(0,0,0,.9)}@media (max-width: 768px){#root{padding:1rem;max-width:100%}.container{margin:1rem auto;padding:1rem;max-width:100%;box-sizing:border-box}h1{font-size:1.5rem;margin-bottom:1rem}.header-container{flex-direction:column;align-items:stretch;gap:1rem;margin-bottom:1.5rem}.header-container h1{text-align:center;margin:0}.header-buttons{justify-content:center;flex-wrap:wrap;gap:.5rem}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1rem 0}.fragrance-table{min-width:600px;font-size:.875rem}.fragrance-table th,.fragrance-table td{padding:.5rem;white-space:nowrap}.fragrance-table td button{padding:.25rem .5rem;font-size:.75rem;margin-right:.25rem}.modal{width:95vw;max-width:95vw;padding:1.5rem;margin:1rem;max-height:85vh}.modal h2{font-size:1.25rem;margin-bottom:1.5rem;padding-bottom:.75rem}.form-row{margin-bottom:1rem}.form-row label{font-size:.8rem}.fragrance-form input[type=text],.fragrance-form input[type=number],.fragrance-form input[type=url]{padding:.75rem;font-size:1rem}.fragrance-form button{padding:.75rem 1rem;font-size:.8rem;margin-right:.5rem;margin-bottom:.5rem;min-width:100px}.fragrance-form .form-row:last-child{flex-direction:column;gap:.5rem}.search-input{padding:.75rem 1rem .75rem 2.5rem;font-size:1rem}.qr-scanner-modal{width:95vw;max-width:95vw;padding:1.5rem}.scanner-video{max-width:250px;height:250px}.scanner-instructions{font-size:.8rem;padding:.5rem}.url-input{padding:.75rem;font-size:1rem}.url-instructions{font-size:.8rem;padding:.5rem}.slider{height:8px}.slider::-webkit-slider-thumb{width:24px;height:24px}.slider::-moz-range-thumb{width:24px;height:24px}.modal-close-btn{top:.75rem;right:.75rem;width:36px;height:36px;font-size:1.25rem}.modal-delete-btn{top:.75rem;left:.75rem;width:40px;height:40px}}@media (max-width: 480px){#root{padding:.5rem}.container{margin:.5rem auto;padding:.75rem}h1{font-size:1.25rem}.modal{padding:1rem;width:98vw;max-width:98vw}.modal h2{font-size:1.1rem}.fragrance-table{font-size:.8rem}.fragrance-table th,.fragrance-table td{padding:.375rem}.fragrance-form button{padding:.625rem .75rem;font-size:.75rem;min-width:80px}.scanner-video{max-width:200px;height:200px}}.tab-navigation{display:flex;margin-bottom:2rem;border-bottom:2px solid #e5e7eb;gap:.5rem}.tab-button{padding:.75rem 1.5rem;border:none;background:transparent;color:#6b7280;cursor:pointer;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.025em;transition:all .2s ease;border-bottom:3px solid transparent;position:relative}.tab-button:hover{color:#374151;background:#f9fafb}.tab-button.active{color:#646cff;border-bottom-color:#646cff;background:#f8faff}.find-url-btn{background:#646cff;color:#fff;border:none;border-radius:.375rem;padding:.25rem .5rem;cursor:pointer;font-size:.875rem;transition:all .2s ease;min-width:32px;display:inline-flex;align-items:center;justify-content:center}.find-url-btn:hover:not(:disabled){background:#535bf2;transform:translateY(-1px)}.find-url-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.6}.container.dark-mode .find-url-btn:disabled{background:#4b5563;color:#6b7280}.find-urls-section{margin:1rem 0;padding:1rem;background:#f8faff;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;flex-direction:column;gap:1rem}.find-all-urls-btn{background:#10b981;color:#fff;border:none;border-radius:.375rem;padding:.75rem 1.5rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s ease;align-self:flex-start}.find-all-urls-btn:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.find-all-urls-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.8}.progress-container{display:flex;flex-direction:column;gap:.5rem}.progress-bar{width:100%;height:.5rem;background:#e5e7eb;border-radius:.25rem;overflow:hidden}.progress-fill{height:100%;background:#10b981;transition:width .3s ease;border-radius:.25rem}.progress-text{font-size:.875rem;color:#6b7280;font-weight:500}.container.dark-mode .find-urls-section{background:#1f2937;border-color:#404040}.container.dark-mode .find-all-urls-btn:disabled{background:#4b5563;color:#6b7280}.container.dark-mode .progress-bar{background:#4b5563}.container.dark-mode .progress-text{color:#9ca3af}.bottom-utilities{margin-top:2rem;padding:1rem;border-top:1px solid #e5e7eb;background:#f9fafb;display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap}.bottom-utility-btn{background:#6b7280;color:#fff;border:none;border-radius:.375rem;padding:.5rem 1rem;cursor:pointer;font-size:.875rem;transition:all .2s ease;opacity:.8}.bottom-utility-btn:hover:not(:disabled){background:#4b5563;opacity:1;transform:translateY(-1px)}.bottom-utility-btn:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.import-btn{cursor:pointer}.import-btn:hover{background:#4b5563!important;opacity:1!important;transform:translateY(-1px)!important}.container.dark-mode .bottom-utilities{background:#1f2937;border-top-color:#404040}.container.dark-mode .bottom-utility-btn:disabled{background:#4b5563;color:#6b7280}.container.dark-mode .tab-navigation{border-bottom-color:#404040}.container.dark-mode .tab-button{color:#9ca3af}.container.dark-mode .tab-button:hover{color:#d1d5db;background:#374151}.container.dark-mode .tab-button.active{color:#646cff;background:#1e1b2e}.insights-container{padding:1rem 0}.insights-container h2{margin-bottom:2rem;text-align:center;color:#1f2937;font-size:1.5rem;font-weight:700}.insights-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.insight-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .3s ease;position:relative;box-shadow:0 2px 4px #0000000d}.insight-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a;border-color:#646cff}.insight-rank{position:absolute;top:-10px;right:-10px;background:#646cff;color:#fff;font-weight:700;font-size:.875rem;padding:.5rem .75rem;border-radius:50%;min-width:40px;height:40px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #646cff4d}.insight-content h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:#1f2937;line-height:1.3}.insight-supplier{color:#6b7280;font-size:.875rem;margin-bottom:1rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.insight-rating{background:#fef3c7;color:#d97706;padding:.5rem .75rem;border-radius:6px;font-weight:600;font-size:.875rem;margin-bottom:.5rem;display:inline-block}.insight-longevity{background:#dbeafe;color:#2563eb;padding:.5rem .75rem;border-radius:6px;font-weight:600;font-size:.875rem;margin-bottom:.5rem;display:inline-block;margin-left:.5rem}.insight-buy-again{background:#dcfce7;color:#16a34a;padding:.5rem .75rem;border-radius:6px;font-weight:600;font-size:.875rem;margin-bottom:.5rem;display:inline-block;margin-top:.5rem}.insight-notes{margin-top:1rem;color:#4b5563;font-size:.875rem;line-height:1.5;font-style:italic;border-top:1px solid #e5e7eb;padding-top:1rem}.no-data{text-align:center;color:#6b7280;font-style:italic;grid-column:1 / -1;padding:3rem 1rem;background:#f9fafb;border-radius:8px;border:2px dashed #d1d5db}.container.dark-mode .insights-container h2{color:#e0e0e0}.container.dark-mode .insight-card{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.container.dark-mode .insight-card:hover{border-color:#646cff;box-shadow:0 8px 25px #0000004d}.container.dark-mode .insight-content h3{color:#e0e0e0}.container.dark-mode .insight-supplier{color:#9ca3af}.container.dark-mode .insight-rating{background:#451a03;color:#fbbf24}.container.dark-mode .insight-longevity{background:#1e3a8a;color:#60a5fa}.container.dark-mode .insight-buy-again{background:#14532d;color:#4ade80}.container.dark-mode .insight-notes{color:#d1d5db;border-top-color:#404040}.container.dark-mode .no-data{background:#374151;border-color:#4b5563;color:#9ca3af}@media (hover: none) and (pointer: coarse){.fragrance-form button{min-height:44px;font-size:.9rem}.fragrance-table td button{min-height:36px;padding:.5rem .75rem}.modal-close-btn,.modal-delete-btn{min-height:44px;min-width:44px}.slider::-webkit-slider-thumb{width:28px;height:28px}.slider::-moz-range-thumb{width:28px;height:28px}.tab-button{min-height:44px;padding:.75rem 1rem}}
