:root{color:#1f2937;background:#f5f7f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{overflow-x:hidden;width:100%}body{margin:0;min-width:0;overflow-x:hidden;width:100%}button,input,select,textarea{font:inherit;max-width:100%;min-width:0}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.auth-shell{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:24px}.auth-form,.add-panel,.collection-panel{background:#fff;border:1px solid #dde4e7;border-radius:8px}.auth-form{display:grid;gap:16px;max-width:420px;padding:24px;width:100%}.sidebar{background:#18232f;color:#f8fafc;padding:24px 18px}.brand-mark{display:flex;align-items:center;gap:10px;font-weight:700;margin-bottom:28px}.brand-mark.dark{color:#252321}nav{display:grid;gap:6px}.nav-item{border:0;background:transparent;color:#cbd5e1;cursor:pointer;padding:10px 12px;text-align:left;border-radius:6px}.nav-item.active,.nav-item:hover{background:#334155;color:#fff}.workspace{min-width:0;padding:28px}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:24px}.eyebrow{color:#64748b;font-size:.85rem;margin:0 0 4px}h1{margin:0;font-size:2rem;line-height:1.15}.primary-action{display:inline-flex;align-items:center;gap:8px;border:0;border-radius:6px;background:#0f766e;color:#fff;cursor:pointer;min-height:40px;padding:0 14px}.primary-action:disabled{cursor:progress;opacity:.65}.secondary-action{align-items:center;background:#fff;border:1px solid #0f766e;border-radius:6px;color:#0f766e;cursor:pointer;display:inline-flex;justify-content:center;min-height:40px;padding:0 14px}.secondary-action:disabled{cursor:progress;opacity:.65}.icon-action{align-items:center;background:#fff;border:1px solid #d6d3cb;border-radius:6px;color:#252321;cursor:pointer;display:inline-flex;height:40px;justify-content:center;width:40px}.icon-action.small{height:34px;width:34px}.scroll-top-action{align-items:center;background:#0f766e;border:0;border-radius:50%;bottom:max(20px,env(safe-area-inset-bottom));box-shadow:0 6px 18px #0f172a3d;color:#fff;cursor:pointer;display:inline-flex;height:46px;justify-content:center;position:fixed;right:max(20px,env(safe-area-inset-right));width:46px;z-index:20}.scroll-top-action:hover{background:#115e59}.scroll-top-action:focus-visible{outline:3px solid rgba(15,118,110,.28);outline-offset:3px}.segmented{background:#ede8df;border-radius:8px;display:grid;gap:4px;grid-template-columns:1fr 1fr;padding:4px}.segmented button{background:transparent;border:0;border-radius:6px;cursor:pointer;min-height:36px}.segmented .selected{background:#fff;color:#0f766e;font-weight:700}label{color:#334155;display:grid;gap:6px;font-size:.9rem;font-weight:600}label input,label select,label textarea{background:#fbfcfd;border:1px solid #d6e0e4;border-radius:6px;min-height:40px;padding:0 10px}label input:focus,label select:focus,label textarea:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f;outline:0}label textarea{min-height:88px;padding:10px;resize:vertical}.form-error{color:#b91c1c;font-size:.9rem;margin:0}.form-success{color:#0f766e;font-size:.9rem;margin:0}.confirmation-warning{background:#fffbeb;border:1px solid #fde68a;border-radius:6px;color:#92400e!important;font-size:.9rem;margin:0;padding:8px 10px}.work-grid{align-items:start;display:grid;gap:24px;grid-template-columns:minmax(360px,460px) 1fr}.simple-grid{align-items:start;display:grid;gap:24px;grid-template-columns:minmax(280px,360px) minmax(0,1fr)}.repository-view{display:grid;gap:18px}.add-panel,.collection-panel{padding:18px}.add-panel{display:grid;gap:16px}.add-perfume-panel{background:transparent;border:0;padding:0}.add-header,.form-section{background:#fff;border:1px solid #dde4e7;border-radius:8px;padding:16px}.add-header{display:grid;gap:6px}.form-section{display:grid;gap:14px}.section-heading{align-items:center;display:flex;gap:8px}.section-heading span{align-items:center;background:#e6f4f1;border-radius:999px;color:#0f766e;display:inline-flex;font-size:.78rem;font-weight:800;height:24px;justify-content:center;width:24px}.section-heading p{color:#1f2937;font-size:.95rem;font-weight:800;margin:0}.panel-title{align-items:center;display:flex;gap:8px}.panel-title h2{font-size:1rem;margin:0}.context-line{color:#475569;margin:-4px 0 0}.field-grid{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.bottle-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.field-with-presets{display:grid;gap:7px;min-width:0}.volume-presets{display:flex;flex-wrap:wrap;gap:6px}.volume-preset{background:#fff;border:1px solid #cbd5e1;border-radius:999px;color:#475569;cursor:pointer;font-size:.76rem;min-height:28px;padding:3px 9px}.volume-preset:hover,.volume-preset.selected{background:#e6f4f1;border-color:#0f766e;color:#0f766e}.photo-drop{align-items:center;background:#f8fafb;border:1px dashed #b7c7cd;border-radius:8px;color:#64748b;display:flex;justify-content:center;max-height:280px;min-height:170px;overflow:hidden;padding:14px;position:relative;text-align:center}.photo-drop.has-preview{padding:0}.recognition-preview-grid{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr));padding:8px;width:100%}.recognition-preview-tile{aspect-ratio:1;border-radius:6px;overflow:hidden;position:relative}.recognition-preview-tile .recognition-preview{height:100%;object-fit:cover;width:100%}.preview-remove{background:#0f172ac7;border:0;border-radius:999px;bottom:6px;color:#fff;cursor:pointer;font-size:.72rem;font-weight:700;left:6px;padding:5px 8px;position:absolute}.photo-choice-row{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.recognition-action-row{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.recognition-action-row .secondary-action{width:100%}.file-action{font-weight:700;position:relative}.file-action input{cursor:pointer;top:0;right:0;bottom:0;left:0;opacity:0;position:absolute;width:100%}.compact-file-action{min-height:34px;padding:7px 10px}.range-field{gap:8px}.range-field input[type=range]{padding:0}.range-ticks{color:#64748b;display:flex;font-size:.75rem;justify-content:space-between;padding:0 2px}.search-row{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #d6d3cb;border-radius:8px;padding:0 12px;min-height:44px}.search-row input{border:0;outline:0;width:100%}.basic-filter-panel{align-items:end;display:grid;gap:10px;grid-template-columns:minmax(220px,1fr) minmax(150px,220px) auto auto}.basic-filter-panel label{font-size:.82rem}.basic-filter-panel .secondary-action{min-height:40px}.filter-panel{align-items:end;display:grid;gap:10px;grid-template-columns:repeat(4,minmax(120px,1fr));margin-top:14px}.advanced-filter-panel{background:#f8fafb;border:1px solid #edf2f4;border-radius:8px;padding:12px}.filter-panel label{font-size:.82rem}.filter-panel .secondary-action{min-height:40px}.collection-list{display:grid;gap:12px;margin-top:18px}.collection-pagination{align-items:center;border-top:1px solid #edf2f4;color:#64748b;display:flex;font-size:.85rem;gap:14px;justify-content:space-between;margin-top:18px;padding-top:14px}.empty-state{border:1px dashed #c8c2b8;border-radius:8px;padding:32px;background:#fff;max-width:560px}.empty-state h2{margin:0 0 8px;font-size:1.2rem}.empty-state p{color:#64748b;margin:0}.perfume-card{background:#fff;border:1px solid #e5e0d8;border-radius:8px;padding:16px;scroll-margin-top:14px}.perfume-card.revealed,.perfume-card:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e24;outline:0}.perfume-photo{aspect-ratio:4 / 3;background:#f8fafb;border-radius:6px;display:block;height:auto;margin-bottom:12px;max-height:220px;object-fit:contain;width:min(100%,260px)}.card-header{align-items:start;display:flex;gap:12px;justify-content:space-between}.button-row{display:flex;gap:10px}.button-row.compact{flex:0 0 auto;gap:6px}.small-text{font-size:.78rem;min-height:34px;padding:7px 10px}.storage-card-content{align-items:start;display:grid;gap:16px;grid-template-columns:112px minmax(0,1fr)}.storage-card-main{display:grid;gap:8px;min-width:0}.storage-photo-frame{align-items:center;aspect-ratio:1;background:#f1f5f4;border:1px solid #d8e1df;border-radius:8px;color:#64748b;cursor:pointer;display:flex;justify-content:center;overflow:hidden;position:relative;width:92px}.storage-card-content .storage-photo-frame{width:112px}.storage-photo-frame input{cursor:pointer;top:0;right:0;bottom:0;left:0;opacity:0;position:absolute}.storage-photo{height:100%;object-fit:cover;width:100%}.storage-photo-overlay{align-items:center;background:#0f172ab3;border-radius:999px;bottom:7px;color:#fff!important;display:inline-flex!important;height:28px;justify-content:center;margin:0!important;opacity:0;position:absolute;right:7px;transition:opacity .15s ease;width:28px}.storage-photo-frame:hover .storage-photo-overlay,.storage-photo-frame:focus-within .storage-photo-overlay{opacity:1}.text-action{background:transparent;border:0;color:#64748b;cursor:pointer;font:inherit;font-size:.82rem;margin-top:6px;padding:0}.text-action:hover{color:#0f766e;text-decoration:underline}.storage-content-link{color:#0f766e;font-weight:700}.storage-action-row{align-items:center;display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}.storage-action-row .text-action{margin-top:0}.perfume-card h2,.perfume-card p{margin:0}.perfume-card p{color:#475569;margin-top:2px}.perfume-card span{color:#0f766e;display:block;font-size:.9rem;margin-top:10px}.storage-line{align-items:center;color:#334155!important;display:flex;gap:6px;font-size:.86rem;font-weight:700;margin-top:8px!important}.storage-line.muted{color:#64748b!important;font-weight:500}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;min-width:0}.tag-chip{background:#e6f4f1;border-radius:999px;color:#0f766e;display:inline-flex;font-size:.78rem;line-height:1;padding:5px 8px}.note-chip{background:#fff7ed;border:0;border-radius:999px;color:#9a3412;display:inline-flex;font-size:.78rem;line-height:1;max-width:100%;padding:5px 8px;white-space:normal;word-break:break-word}.button-chip{cursor:pointer}.chip-grid{display:flex;flex-wrap:wrap;gap:8px;min-width:0}.choice-chip{align-items:center;background:#f8fafb;border:1px solid #d6e0e4;border-radius:999px;color:#334155;cursor:pointer;display:inline-flex;flex-direction:row;font-size:.85rem;font-weight:700;gap:6px;min-height:34px;padding:0 10px}.choice-chip:has(input:checked){background:#e6f4f1;border-color:#0f766e;color:#0f766e}.choice-chip input{min-height:auto;padding:0;width:14px}.note-editor{background:#f8fafb;border:1px solid #edf2f4;border-radius:8px;display:grid;gap:10px;min-width:0;overflow:hidden;padding:12px}.note-editor p{color:#334155;font-size:.9rem;font-weight:700;margin:0}.note-editor-grid{display:grid;gap:10px;grid-template-columns:minmax(0,1fr);min-width:0}.collapsible-editor{background:#f8fafb;border:1px solid #edf2f4;border-radius:8px;min-width:0;overflow:hidden}.collapsible-editor summary{align-items:center;color:#334155;cursor:pointer;display:flex;font-size:.9rem;font-weight:700;justify-content:space-between;list-style:none;min-height:44px;padding:10px 12px}.collapsible-editor summary::-webkit-details-marker{display:none}.collapsible-editor summary:after{content:"+";font-size:1.15rem;font-weight:500;line-height:1}.collapsible-editor[open] summary{border-bottom:1px solid #edf2f4}.collapsible-editor[open] summary:after{content:"−"}.collapsible-content{display:grid;gap:10px;padding:12px}.perfume-card .metadata-line{color:#64748b;font-size:.85rem;margin-top:10px}.checkbox-group{display:grid;gap:8px}.checkbox-group p{color:#334155;font-size:.9rem;font-weight:700;margin:0}.checkbox-row{align-items:center;display:flex;flex-direction:row;gap:8px;font-weight:500}.checkbox-row input{min-height:auto;padding:0;width:16px}.photo-upload{background:#fff;border:1px solid #dde4e7;border-radius:8px;display:grid;gap:12px;padding:16px}.photo-gallery{background:#fff;border:1px solid #dde4e7;border-radius:8px;display:grid;gap:10px;padding:16px}.photo-gallery p{color:#334155;font-size:.9rem;font-weight:700;margin:0}.photo-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(120px,160px))}.photo-tile{border:1px solid #e5e0d8;border-radius:8px;margin:0;overflow:hidden}.photo-thumbnail{aspect-ratio:1 / 1;background:#f8fafb;display:block;height:130px;object-fit:contain;width:100%}.photo-tile figcaption{align-items:center;display:flex;gap:8px;justify-content:space-between;padding:8px}.photo-tile figcaption span{color:#475569;font-size:.82rem}.recognition-result{display:grid;gap:16px}.recognition-result h2,.recognition-result p{margin:0}.recognition-result p{color:#64748b;margin-top:4px}.recognized-details{border:1px solid #dde4e7;border-radius:8px;display:grid;gap:12px;padding:12px}.duplicate-warning{background:#fff7ed;border-color:#fed7aa}.duplicate-warning .section-heading span{background:#fed7aa;color:#9a3412}.visual-cues{background:#f8fafc}.recognized-details p{color:#334155;font-size:.9rem;font-weight:700}.recognized-details dl{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr));margin:0}.recognized-details dt{color:#64748b;font-size:.75rem;text-transform:uppercase}.recognized-details dd{color:#1f2937;font-size:.9rem;margin:2px 0 0}.fact-list{display:grid;gap:8px}.fact-row{align-items:start;border:1px solid #e5e0d8;border-radius:6px;display:grid;gap:10px;grid-template-columns:minmax(0,1fr) auto;min-width:0;padding:10px}.fact-row div{display:grid;gap:3px}.fact-row strong{color:#1f2937;font-size:.85rem}.fact-row span,.fact-row small{color:#64748b;font-size:.82rem}.fact-row a{color:#0f766e}.recognition-preview{aspect-ratio:4 / 3;background:#f8fafb;border:0;border-radius:8px;display:block;max-height:260px;object-fit:contain;width:100%}.candidate-list{display:grid;gap:8px}.candidate-row{align-items:center;border:1px solid #e5e0d8;border-radius:8px;display:grid;gap:10px;grid-template-columns:auto 1fr auto;padding:10px}.candidate-row input{min-height:auto;padding:0;width:16px}.candidate-row strong{color:#0f766e;font-size:.85rem}.nested-panel{border-style:dashed}.stacked-form{border-top:1px solid #e5e0d8;display:grid;gap:10px;padding-top:14px}.stacked-form:first-child{border-top:0;padding-top:0}.stacked-form h3{font-size:.95rem;margin:0}.muted-text{color:#64748b;font-size:.9rem}.perfume-card dl{display:grid;gap:8px;grid-template-columns:repeat(3,minmax(0,1fr));margin:14px 0 0}.perfume-card dt{color:#64748b;font-size:.75rem}.perfume-card dd{font-weight:700;margin:2px 0 0}@media (max-width: 760px){.app-shell{grid-template-columns:1fr}.sidebar{padding:16px}nav{grid-template-columns:repeat(4,minmax(0,1fr))}.nav-item{text-align:center}.workspace{padding:14px}.toolbar{align-items:center;flex-direction:row;gap:12px;margin-bottom:12px}.toolbar .eyebrow{display:none}.toolbar h1{font-size:1.35rem;line-height:1.2}.toolbar .icon-action{flex:0 0 36px;height:36px;width:36px}.scroll-top-action{bottom:max(14px,env(safe-area-inset-bottom));height:44px;right:max(14px,env(safe-area-inset-right));width:44px}.work-grid,.simple-grid,.field-grid,.bottle-grid,.filter-panel,.basic-filter-panel{grid-template-columns:1fr}.add-header,.form-section,.photo-gallery,.photo-upload,.collection-panel,.perfume-card{padding:12px}.candidate-row,.fact-row{grid-template-columns:minmax(0,1fr)}.button-row{flex-wrap:wrap}.button-row>button{flex:1 1 140px}.collection-pagination{align-items:stretch;flex-direction:column}.storage-card-content{grid-template-columns:84px minmax(0,1fr)}.storage-card-content .storage-photo-frame{width:84px}.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.photo-choice-row,.recognition-action-row{grid-template-columns:1fr}}
