@import url(https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Inter:wght@300;400;500;600&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Helvetica Neue,sans-serif;margin:0;overflow:hidden;padding:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.search-bar{align-items:center;display:flex;max-width:400px;position:relative}.search-bar__icon{color:var(--color-warm-gray);left:var(--spacing-md);pointer-events:none;position:absolute;z-index:1}.search-bar__input{background:var(--color-ivory);border:1px solid var(--color-taupe);border-radius:var(--radius-full);font-size:.9rem;padding:var(--spacing-sm) var(--spacing-md) var(--spacing-sm) calc(var(--spacing-xl) + var(--spacing-md));transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.search-bar__input:focus{border-color:var(--color-warm-gray);box-shadow:0 0 0 3px #9b9b9b1a;outline:none}.search-bar__input::placeholder{color:var(--color-warm-gray)}.search-bar__dropdown{animation:fadeIn var(--transition-fast);background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);left:0;max-height:400px;overflow-y:auto;position:absolute;right:0;top:calc(100% + var(--spacing-xs));z-index:100}.search-bar__result{align-items:center;background:#fff;border:none;cursor:pointer;display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:background-color var(--transition-fast);width:100%}.search-bar__result:hover{background-color:var(--color-ivory)}.search-bar__result:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.search-bar__result:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.search-bar__result-thumbnail,.search-bar__result:only-child{border-radius:var(--radius-md)}.search-bar__result-thumbnail{background:linear-gradient(135deg,var(--color-ivory) 0,var(--color-taupe) 100%);flex-shrink:0;height:40px;overflow:hidden;width:40px}.search-bar__result-thumbnail img{display:block;height:100%;object-fit:cover;width:100%}.search-bar__result-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.search-bar__result-name{color:var(--color-charcoal);font-size:.9rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-bar__result-family{font-size:.75rem;font-weight:500;text-transform:capitalize}.search-bar__result-badge{background:var(--color-taupe);border-radius:var(--radius-full);color:var(--color-charcoal);flex-shrink:0;font-size:.7rem;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm)}.search-bar__dropdown::-webkit-scrollbar{width:6px}.search-bar__dropdown::-webkit-scrollbar-track{background:#0000}.search-bar__dropdown::-webkit-scrollbar-thumb{background:var(--color-taupe);border-radius:var(--radius-full)}.search-bar__dropdown::-webkit-scrollbar-thumb:hover{background:var(--color-warm-gray)}.header{background:var(--color-ivory);border-bottom:1px solid var(--color-taupe);padding:var(--spacing-lg) var(--spacing-2xl);position:-webkit-sticky;position:sticky;top:0;z-index:100}.header__content{align-items:center;display:flex;gap:var(--spacing-xl);justify-content:space-between;margin:0 auto;max-width:1600px}.header__title-container{align-items:center;display:flex;gap:10px}.header__logo{height:40px;margin-right:10px}.header__title{color:var(--color-text-primary);font-size:1.75rem;font-weight:500;letter-spacing:.02em;margin:0;white-space:nowrap}@media (max-width:768px){.header__content{align-items:flex-start;flex-direction:column;gap:var(--spacing-md)}.header__title{font-size:1.5rem}}.network-graph{align-items:center;background:var(--color-ivory);display:flex;flex:1 1;justify-content:center;overflow:hidden;position:relative}.network-graph__container{height:100%;position:relative;width:100%}.network-graph__svg{display:block;-webkit-user-select:none;user-select:none}.network-graph__controls{display:flex;flex-direction:column;gap:var(--spacing-xs);position:absolute;right:var(--spacing-md);top:var(--spacing-md);z-index:10}.network-graph__control-btn{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:1px solid var(--color-taupe);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:var(--color-charcoal);cursor:pointer;display:flex;font-size:1.25rem;font-weight:600;height:36px;justify-content:center;transition:all var(--transition-fast);width:36px}.network-graph__control-btn:hover{background:#fff;box-shadow:var(--shadow-md);transform:scale(1.05)}.network-graph__control-btn:active{transform:scale(.95)}.graph-edge{transition:stroke-opacity var(--transition-base)}.graph-node{transition:all var(--transition-fast)}.graph-node:focus,.graph-node:hover{filter:brightness(1.1)}.graph-node:focus{outline:none}.node-label{text-wrap:wrap;animation:fadeIn var(--transition-fast);font-weight:500;max-width:200px;text-shadow:0 1px 3px #fffc}.info-card{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;font-family:Arial,sans-serif;overflow:visible;position:relative;width:100%}.info-card__color-bar{height:4px;left:0;position:absolute;top:0;width:100%}.info-card__content{display:flex;flex-direction:column;justify-content:space-between;padding:12px 16px 16px}.info-card__main{align-items:flex-start;display:flex;gap:12px}.info-card__text{word-wrap:break-word;flex:1 1;min-width:0;overflow-wrap:break-word}.info-card__title{word-wrap:break-word;color:#333;font-size:16px;font-weight:700;line-height:1.2;margin:0 0 4px}.info-card__tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.info-card__tag{border-radius:3px;color:#333;font-size:10px;font-weight:500;padding:3px 8px;text-transform:capitalize}.info-card__tag--note{background:#f0f0f0;color:#666}.info-card__description{word-wrap:break-word;color:#555;font-size:14px;line-height:1.5;margin:0;overflow-wrap:break-word;white-space:normal}.info-card__thumbnail{align-items:center;background:#f5f5f5;border-radius:4px;display:flex;flex-shrink:0;height:60px;justify-content:center;overflow:hidden;width:60px}.info-card__image{height:100%;object-fit:cover;width:100%}.image-placeholder{align-items:center;background:linear-gradient(135deg,var(--color-ivory) 0,var(--color-taupe) 100%);border-radius:var(--radius-md);display:flex;justify-content:center;overflow:hidden;position:relative;width:100%}.image-placeholder--chemical{background:linear-gradient(135deg,#f5f5f5,#e8e8e8);color:var(--color-warm-gray)}.image-placeholder--visual{background:linear-gradient(135deg,var(--color-ivory) 0,var(--color-taupe) 100%)}.image-placeholder__content{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.placeholder-icon{height:50%;opacity:.3;width:50%}.placeholder-gradient{animation:pulseGlow 3s ease-in-out infinite;background:radial-gradient(circle at 30% 40%,#d4c4b44d 0,#0000 60%),radial-gradient(circle at 70% 60%,#faf8f580 0,#0000 60%);inset:0;position:absolute}.image-placeholder--with-image{background:none}.image-placeholder__img{display:block;height:100%;object-fit:cover;width:100%}.pairing-chip{align-items:flex-start;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;flex-direction:column;margin-bottom:var(--spacing-sm);margin-right:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.pairing-chip:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.pairing-chip:active{transform:translateY(0)}.pairing-chip__name{color:var(--color-text-primary);font-size:.875rem;font-weight:500;margin-bottom:var(--spacing-xs)}.pairing-chip__family{color:var(--color-text-secondary);font-size:.75rem;letter-spacing:.05em;opacity:.8;text-transform:uppercase}.note-editor{display:flex;flex-direction:column;gap:12px}.note-editor__textarea{border:1px solid #e0e0e0;border-radius:4px;font-family:inherit;font-size:14px;line-height:1.5;padding:12px;resize:vertical;transition:border-color .2s;width:100%}.note-editor__textarea:focus{border-color:#666;outline:none}.note-editor__actions{display:flex;gap:8px;justify-content:flex-end}.note-editor__add-button,.note-editor__cancel-button,.note-editor__edit-button,.note-editor__save-button{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.note-editor__save-button{background-color:#333;color:#fff}.note-editor__save-button:hover{background-color:#000}.note-editor__cancel-button{background-color:#f0f0f0;color:#333}.note-editor__cancel-button:hover{background-color:#e0e0e0}.note-editor__add-button{background-color:#f8f8f8;border:1px dashed #ccc;color:#666;padding:12px;width:100%}.note-editor__add-button:hover{background-color:#f0f0f0;border-color:#999;color:#333}.note-editor__display{background-color:#fafafa;border:1px solid #e8e8e8;border-radius:4px;display:flex;flex-direction:column;gap:8px;padding:12px}.note-editor__content{color:#333;font-size:14px;line-height:1.6;white-space:pre-wrap}.note-editor__edit-button{align-self:flex-end;background-color:#fff;border:1px solid #e0e0e0;color:#666}.note-editor__edit-button:hover{background-color:#f8f8f8;color:#333}.accord-info-card{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:calc(100vw - 20px);overflow:hidden;pointer-events:none;transform:translate(-50%,-100%) translateY(-12px);width:280px;z-index:1000}.accord-info-card__color-band{display:flex;height:4px;width:100%}.accord-info-card__color-segment{flex:1 1;min-width:10px}.accord-info-card__title-container{display:flex;gap:8px}.accord-info-card__image-container{height:60px;overflow:hidden;position:relative;width:100%}.accord-info-card__image{height:100%;object-fit:cover;object-position:center;width:100%}.accord-info-card__content{max-height:300px;overflow-y:auto;padding:14px}.accord-info-card__title{word-wrap:break-word;color:#333;font-size:15px;font-weight:600;margin:0 0 6px}.accord-info-card__category{background:#f0f0f0;border-radius:3px;color:#666;display:inline-block;font-size:10px;font-weight:500;margin-bottom:8px;padding:3px 8px;text-transform:capitalize}.accord-info-card__description{word-wrap:break-word;color:#555;font-size:12px;line-height:1.5;margin:8px 0 0;overflow-wrap:break-word;white-space:normal}.detail-panel{background:var(--color-ivory);box-shadow:var(--shadow-lg);height:100vh;overflow-y:auto;position:fixed;right:0;top:0;width:400px;z-index:100}.detail-panel__header{margin-bottom:var(--spacing-xl);position:relative}.detail-panel__header>div{position:relative}.detail-panel__header .image-placeholder{border-radius:0;margin-bottom:var(--spacing-md)}.detail-panel__name{font-size:1.75rem;margin-bottom:var(--spacing-sm);padding:0 var(--spacing-xl)}.detail-panel__badges{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:0 var(--spacing-xl)}.detail-panel__badge{border-radius:var(--radius-full);color:var(--color-text-primary);display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.05em;padding:var(--spacing-xs) var(--spacing-md);text-transform:uppercase}.detail-panel__badge--note{background:var(--color-taupe)}.detail-panel__close{align-items:center;background:#ffffffe6;border:none;border-radius:var(--radius-full);box-shadow:var(--shadow-sm);color:var(--color-text-primary);cursor:pointer;display:flex;flex-shrink:0;font-size:1.5rem;height:32px;justify-content:center;line-height:1;padding:0;position:absolute;right:var(--spacing-md);top:var(--spacing-md);transition:all var(--transition-fast);width:32px;z-index:10}.detail-panel__close:hover{background:#fff;box-shadow:var(--shadow-md);transform:scale(1.05)}.detail-panel__content{display:flex;flex-direction:column;gap:var(--spacing-xl);padding:0 var(--spacing-xl) var(--spacing-xl)}.detail-panel__section{border-bottom:1px solid #d4c4b44d;padding-bottom:var(--spacing-lg)}.detail-panel__section:last-child{border-bottom:none}.detail-panel__section-title{color:var(--color-warm-gray);font-size:.75rem;font-weight:600;letter-spacing:.1em;margin-bottom:var(--spacing-md);text-transform:uppercase}.detail-panel__formula{color:var(--color-warm-gray);font-family:Courier New,monospace;font-size:1.1rem;font-weight:500;margin-top:var(--spacing-sm);text-align:center}.detail-panel__perfume-list{display:flex;flex-direction:column;gap:var(--spacing-sm);list-style:none;margin:0;padding:0}.detail-panel__perfume-list li{color:var(--color-text-secondary);font-size:.95rem;line-height:1.6;padding-left:var(--spacing-md);position:relative}.detail-panel__perfume-list li:before{color:var(--color-warm-gray);content:"·";font-weight:700;left:0;position:absolute}.detail-panel__pairings{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin:calc(var(--spacing-xs)*-1)}.detail-panel__accords{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.detail-panel__accord-chip{align-items:center;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:all .2s}.detail-panel__accord-chip:hover{background:#fff;border-color:#8b7355;box-shadow:0 2px 6px #8b735526;transform:translateY(-1px)}.detail-panel__accord-name{color:#333;font-size:13px;font-weight:500}.detail-panel__accord-percentage{background:#8b73551a;border-radius:3px;color:#8b7355;font-size:12px;font-weight:600;padding:2px 6px}@media (max-width:1024px){.detail-panel{width:350px}}@media (max-width:768px){.detail-panel{bottom:0;height:50vh;right:0;top:auto;width:100%}}.detail-panel::-webkit-scrollbar{width:8px}.detail-panel::-webkit-scrollbar-track{background:#0000}.detail-panel::-webkit-scrollbar-thumb{background:var(--color-taupe);border-radius:var(--radius-full)}.detail-panel::-webkit-scrollbar-thumb:hover{background:var(--color-warm-gray)}.legend{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border-radius:var(--radius-md);bottom:var(--spacing-lg);box-shadow:var(--shadow-lg);left:var(--spacing-lg);max-width:200px;padding:var(--spacing-md);position:fixed;z-index:50}.legend__section{margin-bottom:var(--spacing-md)}.legend__section:last-child{margin-bottom:0}.legend__title{color:var(--color-charcoal);font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:var(--spacing-sm);text-transform:uppercase}.legend__items{grid-gap:var(--spacing-xs);display:grid;gap:var(--spacing-xs);grid-template-columns:1fr 1fr}.legend__item{align-items:center;display:flex;gap:var(--spacing-xs)}.legend__color{border:1px solid #0000001a;border-radius:50%;flex-shrink:0;height:12px;width:12px}.legend__label{color:var(--color-charcoal);font-size:.7rem;overflow:hidden;text-overflow:ellipsis;text-transform:capitalize;white-space:nowrap}.legend__size-guide{display:flex;flex-direction:column;gap:var(--spacing-xs)}.legend__size-item{align-items:center;display:flex;gap:var(--spacing-sm)}.tab-navigation{background-color:#fff;border-bottom:1px solid #e0e0e0;display:flex;gap:4px;padding:0 20px}.tab-navigation__tab{background:none;border:none;border-bottom:2px solid #0000;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;position:relative;transition:all .2s}.tab-navigation__tab:hover{background-color:#f8f8f8;color:#333}.tab-navigation__tab--active{border-bottom-color:#000;color:#000}.tab-navigation__tab--active:hover{background-color:initial}.accord-rating{display:flex;gap:4px}.accord-rating__star{background:none;border:none;color:#ddd;cursor:pointer;font-size:20px;padding:0;transition:color .2s,transform .1s}.accord-rating__star:not(:disabled):hover{color:#ffc107;transform:scale(1.1)}.accord-rating__star--filled{color:#ffc107}.accord-rating__star:disabled{cursor:default}.info-card-popover{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-width:calc(100vw - 20px);overflow:visible;pointer-events:none;transform:translate(-50%,-100%) translateY(-12px);width:300px;z-index:1000}.info-card-popover__color-bar{border-radius:8px 8px 0 0;height:4px;width:100%}.info-card-popover__content{max-height:400px;overflow-y:auto;padding:16px}.info-card-popover__main{align-items:flex-start;display:flex;gap:12px}.info-card-popover__text{word-wrap:break-word;flex:1 1;min-width:0;overflow-wrap:break-word}.info-card-popover__title{word-wrap:break-word;color:#000;font-size:16px;font-weight:600;margin:0 0 4px}.info-card-popover__tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.info-card-popover__tag{border-radius:3px;color:#333;font-size:10px;font-weight:500;padding:3px 8px;text-transform:capitalize}.info-card-popover__tag--note{background:#f0f0f0;color:#666}.info-card-popover__description{word-wrap:break-word;color:#555;font-size:13px;line-height:1.5;margin:0;overflow-wrap:break-word;white-space:normal}.info-card-popover__thumbnail{background:#f0f0f0;border-radius:4px;flex-shrink:0;height:60px;overflow:hidden;width:60px}.info-card-popover__image{height:100%;object-fit:cover;width:100%}.accord-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;padding:0;transition:box-shadow .2s,transform .2s}.accord-card:hover{box-shadow:0 2px 8px #00000026}.accord-card--highlighted{animation:highlight-pulse 2s ease-in-out}@keyframes highlight-pulse{0%{box-shadow:0 0 0 0 #8b7355b3;transform:scale(1)}50%{box-shadow:0 0 0 10px #8b735500;transform:scale(1.02)}to{box-shadow:0 1px 3px #0000001a;transform:scale(1)}}.accord-card__color-band{display:flex;height:6px;width:100%}.accord-card__color-segment{flex:1 1;min-width:20px}.accord-card__image-container{height:100px;overflow:hidden;position:relative;width:100%}.accord-card__image{height:100%;object-fit:cover;object-position:center;width:100%}.accord-card__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px;padding:20px 20px 0}.accord-card__title{color:#000;font-size:20px;font-weight:600;margin:0 0 4px}.accord-card__category{background-color:#f0f0f0;border-radius:4px;color:#666;display:inline-block;font-size:12px;padding:2px 8px;text-transform:capitalize}.accord-card__description{color:#555;font-size:14px;line-height:1.6}.accord-card__description,.accord-card__ingredients{margin-bottom:16px;padding:0 20px}.accord-card__ingredients-title{color:#333;font-size:14px;font-weight:600;margin-bottom:8px}.accord-card__ingredients-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.accord-card__ingredient{align-items:center;display:flex;font-size:13px;gap:8px}.accord-card__ingredient-badge{border-radius:4px;color:#333;font-size:12px;font-weight:500;padding:4px 10px}.accord-card__ingredient-badge--clickable{cursor:pointer;transition:all .2s}.accord-card__ingredient-badge--clickable:hover{box-shadow:0 2px 4px #00000026;filter:brightness(.95);transform:translateY(-1px)}.accord-card__ingredient-percentage{color:#666;font-weight:600;min-width:40px}.accord-card__ingredient-notes{color:#888;font-style:italic}.accord-card__notes{border-top:1px solid #e8e8e8;margin-top:16px;padding:16px 20px 20px}.accord-card__notes-button{background-color:#f8f8f8;border:1px dashed #ccc;border-radius:4px;color:#666;cursor:pointer;font-size:13px;padding:8px;transition:all .2s;width:100%}.accord-card__notes-button:hover{background-color:#f0f0f0;border-color:#999;color:#333}.accord-card__notes-editor{display:flex;flex-direction:column;gap:8px}.accord-card__notes-textarea{border:1px solid #e0e0e0;border-radius:4px;font-family:inherit;font-size:13px;line-height:1.5;padding:10px;resize:vertical;width:100%}.accord-card__notes-textarea:focus{border-color:#666;outline:none}.accord-card__notes-actions{display:flex;gap:8px;justify-content:flex-end}.accord-card__notes-cancel,.accord-card__notes-save{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;padding:6px 14px;transition:all .2s}.accord-card__notes-save{background-color:#333;color:#fff}.accord-card__notes-save:hover{background-color:#000}.accord-card__notes-cancel{background-color:#f0f0f0;color:#333}.accord-card__notes-cancel:hover{background-color:#e0e0e0}.accord-card__notes-display{background-color:#fafafa;border-radius:4px;color:#333;font-size:13px;line-height:1.6;padding:10px;white-space:pre-wrap}.accord-card__actions{border-top:1px solid #e8e8e8;display:flex;gap:8px;margin-top:16px;padding:16px 20px 20px}.accord-card__delete,.accord-card__edit{border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;padding:6px 14px;transition:all .2s}.accord-card__edit{background-color:#f0f0f0;color:#333}.accord-card__edit:hover{background-color:#e0e0e0}.accord-card__delete{background-color:#fee;color:#c00}.accord-card__delete:hover{background-color:#fdd}.accord-creator-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.accord-creator{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:600px;width:100%}.accord-creator__header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 24px}.accord-creator__title{color:#333;font-size:20px;font-weight:600;margin:0}.accord-creator__close{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:background .2s;width:32px}.accord-creator__close:hover{background:#f0f0f0}.accord-creator__content{flex:1 1;overflow-y:auto;padding:24px}.accord-creator__field{margin-bottom:20px}.accord-creator__label{color:#555;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.accord-creator__input,.accord-creator__select,.accord-creator__textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.accord-creator__input:focus,.accord-creator__select:focus,.accord-creator__textarea:focus{border-color:#8b7355;outline:none}.accord-creator__textarea{min-height:80px;resize:vertical}.accord-creator__section{border-top:1px solid #e0e0e0;margin-top:24px;padding-top:24px}.accord-creator__section-title{color:#333;font-size:16px;font-weight:600;margin:0 0 16px}.accord-creator__add-ingredient{display:flex;gap:8px;margin-bottom:16px}.accord-creator__select{flex:1 1;min-width:0}.accord-creator__percentage-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 12px;width:80px}.accord-creator__percentage-input:focus{border-color:#8b7355;outline:none}.accord-creator__add-button{background:#8b7355;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background .2s;white-space:nowrap}.accord-creator__add-button:hover:not(:disabled){background:#6f5b43}.accord-creator__add-button:disabled{background:#ccc;cursor:not-allowed}.accord-creator__ingredients-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.accord-creator__ingredient{align-items:center;background:#f9f9f9;border-radius:6px;display:flex;gap:12px;padding:8px 12px}.accord-creator__ingredient-badge{border-radius:4px;color:#333;flex:1 1;font-size:14px;font-weight:500;padding:6px 12px}.accord-creator__ingredient-percentage{color:#555;font-size:14px;font-weight:600;min-width:50px;text-align:right}.accord-creator__remove-button{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:20px;height:24px;justify-content:center;padding:0;transition:all .2s;width:24px}.accord-creator__remove-button:hover{background:#e0e0e0;color:#333}.accord-creator__total{color:#555;font-size:14px;font-weight:500;text-align:right}.accord-creator__total--valid{color:#4caf50;font-weight:600}.accord-creator__total--invalid{color:#f44336;font-weight:600}.accord-creator__actions{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.accord-creator__cancel,.accord-creator__save{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s}.accord-creator__cancel{background:#f5f5f5;color:#555}.accord-creator__cancel:hover{background:#e0e0e0}.accord-creator__save{background:#8b7355;color:#fff}.accord-creator__save:hover:not(:disabled){background:#6f5b43}.accord-creator__save:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.accords-panel{background-color:#fafafa;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.accords-panel__filters{background:#fff;border-bottom:1px solid #e0e0e0;display:flex;gap:8px;justify-content:end;padding:16px 40px}.accords-panel__filter-pill{background:#f0f0f0;border:1px solid #e0e0e0;border-radius:20px;color:#666;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s}.accords-panel__filter-pill:hover{background:#e8e8e8;color:#333}.accords-panel__filter-pill--active{background:#333;border-color:#333;color:#fff}.accords-panel__filter-pill--active:hover{background:#000;border-color:#000}.accords-panel__create-pill{background:var(--color-taupe-dark);border:1px solid var(--color-taupe-dark);border-radius:20px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;margin-left:8px;padding:8px 16px;transition:all .2s}.accords-panel__create-pill:hover{background:var(--color-taupe-focus);border-color:var(--color-taupe-focus)}.accords-panel__content{background:var(--color-ivory);flex:1 1;overflow-y:auto;padding:24px 40px}.accords-panel__grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.accords-panel__empty{align-items:center;color:#666;display:flex;flex-direction:column;grid-column:1/-1;justify-content:center;padding:60px 20px;text-align:center}.accords-panel__empty p{font-size:16px;margin-bottom:20px}.accords-panel__create-button{background-color:#333;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:background-color .2s}.accords-panel__create-button:hover{background-color:#000}@media (max-width:1200px){.accords-panel__grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media (max-width:768px){.accords-panel__grid{grid-template-columns:1fr}.accords-panel__content,.accords-panel__header,.accords-panel__tabs{padding-left:20px;padding-right:20px}}.ingredient-selector{margin-bottom:16px;position:relative}.ingredient-selector__input{background:#fff;border:2px dashed #ccc;border-radius:4px;font-size:14px;padding:12px;transition:all .2s;width:100%}.ingredient-selector__input:focus{background:#fafafa;border-color:#333;border-style:solid;outline:none}.ingredient-selector__results{background:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 4px 12px #0000001a;left:0;list-style:none;margin:4px 0 0;max-height:300px;overflow-y:auto;padding:0;position:absolute;right:0;top:100%;z-index:10}.ingredient-selector__result-item{align-items:center;cursor:pointer;display:flex;gap:12px;padding:12px;transition:background .2s}.ingredient-selector__result-item:hover{background:#f8f8f8}.ingredient-selector__result-badge{border-radius:4px;color:#333;font-size:13px;font-weight:500;padding:4px 10px}.ingredient-selector__result-note{color:#666;font-size:12px;text-transform:capitalize}.ingredient-row{background:#fff;border:1px solid #e0e0e0;border-radius:4px;display:flex;flex-direction:column;gap:8px;padding:12px}.ingredient-row__info{align-items:center;display:flex;flex:1 1;gap:12px}.ingredient-row__badge{border-radius:4px;color:#333;font-size:14px;font-weight:500;padding:6px 12px}.ingredient-row__badge--clickable{cursor:pointer;transition:all .2s}.ingredient-row__badge--clickable:hover{box-shadow:0 2px 4px #00000026;filter:brightness(.95);transform:translateY(-1px)}.ingredient-row__note{background:#f0f0f0;border-radius:3px;color:#666;font-size:12px;padding:4px 8px;text-transform:capitalize}.ingredient-row__controls{align-items:center;display:flex;gap:12px}.ingredient-row__weight{align-items:center;display:flex;gap:4px}.ingredient-row__weight-input{border:1px solid #e0e0e0;border-radius:4px;font-size:14px;padding:8px;text-align:right;width:80px}.ingredient-row__weight-input:focus{border-color:#333;outline:none}.ingredient-row__unit{color:#666;font-size:14px;font-weight:500}.ingredient-row__dilution-input{border:1px solid #e0e0e0;border-radius:4px;font-size:13px;padding:8px;width:100px}.ingredient-row__dilution-input:focus{border-color:#333;outline:none}.ingredient-row__remove-button{align-items:center;background:#fee;border:none;border-radius:4px;color:#c00;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;line-height:1;transition:all .2s;width:32px}.ingredient-row__remove-button:hover{background:#fdd}.ingredient-row__notes{background:#fafafa;border-radius:3px;color:#666;font-size:12px;font-style:italic;padding:8px}.formula-calculator{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:24px;padding:20px}.formula-calculator h3{color:#000;font-size:18px;margin:0 0 16px}.formula-calculator h4{color:#333;font-size:14px;font-weight:600;margin:16px 0 12px}.formula-calculator__summary{display:flex;gap:32px;margin-bottom:24px}.formula-calculator__stat{display:flex;flex-direction:column;gap:4px}.formula-calculator__stat label{color:#666;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.formula-calculator__value{color:#000;font-size:24px;font-weight:600}.formula-calculator__note-distribution{border-bottom:1px solid #e8e8e8;margin-bottom:24px;padding-bottom:24px}.formula-calculator__distribution-bars{display:flex;flex-direction:column;gap:12px}.formula-calculator__distribution-item{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:100px 1fr 60px}.formula-calculator__distribution-item label{color:#666;font-size:13px}.formula-calculator__bar-container{background:#f0f0f0;border-radius:4px;height:24px;overflow:hidden}.formula-calculator__bar{border-radius:4px;height:100%;transition:width .3s ease}.formula-calculator__bar--top{background:linear-gradient(90deg,#f5d68a,#f0c070)}.formula-calculator__bar--middle{background:linear-gradient(90deg,#e8b5c5,#e090a8)}.formula-calculator__bar--base{background:linear-gradient(90deg,#c4a570,#a88850)}.formula-calculator__distribution-item>span{color:#333;font-size:13px;font-weight:600;text-align:right}.formula-calculator__percentages{border-bottom:1px solid #e8e8e8;margin-bottom:24px;padding-bottom:24px}.formula-calculator__percentages-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.formula-calculator__percentage-item{grid-gap:16px;background:#fafafa;border-radius:4px;display:grid;font-size:13px;gap:16px;grid-template-columns:1fr auto auto;padding:8px}.formula-calculator__ingredient-name{color:#333;font-weight:500}.formula-calculator__ingredient-weight{color:#666}.formula-calculator__ingredient-percentage{color:#000;font-weight:600;min-width:50px;text-align:right}.formula-calculator__warnings{background:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:16px}.formula-calculator__warnings h4{color:#856404;margin-top:0}.formula-calculator__warnings-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.formula-calculator__warnings-list li{background:#fff;border-radius:3px;color:#856404;font-size:13px;padding:8px}.formula-builder{display:flex;flex:1 1;overflow:hidden}.formula-builder__sidebar{background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden;width:300px}.formula-builder__sidebar-header{border-bottom:1px solid #e0e0e0;padding:20px}.formula-builder__sidebar-header h2{font-size:20px;margin:0 0 12px}.formula-builder__new-button{background-color:var(--color-taupe-dark);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px;transition:background-color .2s;width:100%}.formula-builder__new-button:hover{background-color:var(--color-taupe-focus)}.formula-builder__formula-list{flex:1 1;overflow-y:auto;padding:12px}.formula-builder__empty{color:#999;font-size:14px;padding:20px;text-align:center}.formula-builder__formula-item{background:#fafafa;border-radius:4px;cursor:pointer;margin-bottom:8px;padding:16px;position:relative;transition:all .2s}.formula-builder__formula-item:hover{background:#f0f0f0}.formula-builder__formula-item--active{background:#e8f4ff;border-left:3px solid #333}.formula-builder__formula-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.formula-builder__formula-item-header h3{color:#000;font-size:16px;margin:0}.formula-builder__formula-item-weight{color:#666;font-size:13px;margin:4px 0}.formula-builder__formula-item-description{color:#888;font-size:12px;line-height:1.4;margin:8px 0 0}.formula-builder__delete-button{background:#fee;border:none;border-radius:3px;color:#c00;cursor:pointer;font-size:12px;margin-top:8px;padding:4px 8px;transition:background .2s}.formula-builder__delete-button:hover{background:#fdd}.formula-builder__editor{background:var(--color-ivory);display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:32px 40px}.formula-builder__placeholder{align-items:center;color:#666;display:flex;flex:1 1;flex-direction:column;justify-content:center}.formula-builder__placeholder h2{margin-bottom:8px}.formula-builder__editor-header{align-items:center;display:flex;gap:20px;margin-bottom:16px}.formula-builder__name-input{border:2px solid #e0e0e0;border-radius:4px;flex:1 1;font-size:20px;font-weight:600;padding:12px}.formula-builder__name-input:focus{border-color:#333;outline:none}.formula-builder__rating{align-items:center;display:flex;gap:8px}.formula-builder__rating label{color:#666;font-size:14px}.formula-builder__description-input{border:1px solid #e0e0e0;border-radius:4px;font-family:inherit;font-size:14px;margin-bottom:24px;padding:12px;resize:vertical;width:100%}.formula-builder__description-input:focus{border-color:#333;outline:none}.formula-builder__ingredients-section{margin-bottom:24px}.formula-builder__ingredients-section h3{font-size:18px;margin-bottom:12px}.formula-builder__ingredients-list{display:flex;flex-direction:column;gap:8px;margin-top:16px}.formula-builder__no-ingredients{background:#fff;border-radius:4px;color:#999;font-size:14px;margin-top:16px;padding:40px 20px;text-align:center}.formula-builder__notes-section{margin-bottom:24px}.formula-builder__notes-section h3{font-size:18px;margin-bottom:12px}.formula-builder__notes-input{border:1px solid #e0e0e0;border-radius:4px;font-family:inherit;font-size:14px;padding:12px;resize:vertical;width:100%}.formula-builder__notes-input:focus{border-color:#333;outline:none}.formula-builder__actions{border-top:1px solid #e0e0e0;display:flex;gap:12px;padding-top:24px}.formula-builder__cancel-button,.formula-builder__save-button{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:12px 32px;transition:all .2s}.formula-builder__save-button{background-color:#333;color:#fff}.formula-builder__save-button:hover:not(:disabled){background-color:#000}.formula-builder__save-button:disabled{cursor:not-allowed;opacity:.5}.formula-builder__cancel-button{background-color:#f0f0f0;color:#333}.formula-builder__cancel-button:hover{background-color:#e0e0e0}:root{--color-ivory:#faf8f5;--color-taupe:#d4c4b4;--color-taupe-dark:#8b7355;--color-taupe-focus:#6f5b43;--color-warm-gray:#9b9b9b;--color-charcoal:#6b6b6b;--color-text-primary:#3a3a3a;--color-text-secondary:#6b6b6b;--color-floral:#e8d5d5;--color-citrus:#f5e6c8;--color-woody:#d4c4a8;--color-musk:#e5ddd5;--color-amber:#deb887;--color-marine:#c5d8e8;--color-green:#c8dbc8;--color-gourmand:#e8d0c0;--color-spicy:#d4a574;--color-fruity:#f0d4d4;--color-animalic:#c9b896;--font-serif:"Cormorant Garamond","Georgia",serif;--font-sans:"Inter","Helvetica Neue",sans-serif;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001f;--transition-fast:150ms ease;--transition-base:300ms ease;--transition-slow:500ms ease;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);font-family:var(--font-serif);font-weight:500;margin:0}h1{font-size:2.5rem;letter-spacing:.02em}h2{font-size:1.75rem;letter-spacing:.01em}h3{font-size:1.25rem}body,button,input,p,span{color:var(--color-text-primary);font-family:var(--font-sans)}p{color:var(--color-text-secondary);font-size:.95rem;line-height:1.6;margin:0 0 var(--spacing-md) 0}.subtitle{color:var(--color-warm-gray);font-size:.875rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes pulseGlow{0%,to{opacity:.6}50%{opacity:1}}.fade-in{animation:fadeIn var(--transition-base)}.slide-in-right{animation:slideInRight var(--transition-base)}.app{background:var(--color-ivory);flex-direction:column;height:100vh}.app,.main-content{display:flex;overflow:hidden}.main-content{flex:1 1;position:relative}.app__placeholder{align-items:center;color:#666;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px;text-align:center}.app__placeholder h2{color:#333;font-size:24px;margin-bottom:12px}.app__placeholder p{font-size:16px}*{box-sizing:border-box}
/*# sourceMappingURL=main.7983400e.css.map*/