:root{--wine:#7b2d3f;--wine-dark:#5c2130;--wine-light:#7b2d3f14;--wine-border:#7b2d3f40;--bg:#faf7f5;--surface:#fff;--surface-2:#f4efed;--text:#1a0a0e;--text-muted:#7a6469;--text-on-wine:#fff;--border:#e8dde0;--border-strong:#cfc0c4;--shadow-sm:0 1px 2px #0000000f;--shadow:0 2px 8px #00000014;--shadow-lg:0 8px 24px #0000001f;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-full:9999px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;font-size:16px;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--wine:#c4667a;--wine-dark:#a84f61;--wine-light:#c4667a1a;--wine-border:#c4667a4d;--bg:#140b0d;--surface:#1e1215;--surface-2:#271920;--text:#f0e8ea;--text-muted:#9e8a8e;--text-on-wine:#fff;--border:#2e1e22;--border-strong:#4a3038;--shadow-sm:0 1px 2px #0000004d;--shadow:0 2px 8px #0006;--shadow-lg:0 8px 24px #00000080}}*,:before,:after{box-sizing:border-box}body{margin:0}h1,h2,h3{font-family:var(--sans);color:var(--text);margin:0}p{margin:0}button{font-family:var(--sans);cursor:pointer}#root{background:var(--bg);flex-direction:column;min-height:100svh;display:flex}.home{flex-direction:column;width:100%;max-width:600px;min-height:100svh;margin:0 auto;display:flex}.home-header{background:var(--wine);color:var(--text-on-wine);z-index:10;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.home-brand{letter-spacing:-.3px;font-size:20px;font-weight:700}.home-search-wrap{background:var(--surface);border-bottom:1px solid var(--border);z-index:9;padding:14px 16px;position:sticky;top:52px}.search-box{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);align-items:center;gap:10px;padding:10px 14px;transition:border-color .15s;display:flex}.search-box:focus-within{border-color:var(--wine)}.search-icon{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.search-input{color:var(--text);font-size:15px;font-family:var(--sans);background:0 0;border:none;outline:none;flex:1}.search-input::placeholder{color:var(--text-muted)}.search-clear{color:var(--text-muted);background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.search-clear:hover{color:var(--text)}.wine-list{background:var(--surface);flex-direction:column;flex:1;display:flex}.list-state{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:15px}.list-state--error{color:#c0392b}.wine-row{background:var(--surface);border:none;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:14px;width:100%;padding:14px 16px;transition:background .12s;display:flex}.wine-row:active,.wine-row:hover{background:var(--wine-light)}.wine-row-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:2px}.wine-row-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.wine-row-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.wine-row-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.wine-row-end{flex-shrink:0;align-items:center;gap:8px;display:flex}.wine-row-bottles{color:var(--wine);background:var(--wine-light);border:1px solid var(--wine-border);border-radius:var(--radius-full);text-align:center;min-width:24px;padding:2px 9px;font-size:13px;font-weight:600}.wine-row-chevron{width:16px;height:16px;color:var(--border-strong);flex-shrink:0}.detail{flex-direction:column;width:100%;max-width:600px;min-height:100svh;margin:0 auto;animation:.2s ease-out slideIn;display:flex}@keyframes slideIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.detail-header{background:var(--wine);z-index:10;padding:14px 16px;position:sticky;top:0}.detail-back{color:var(--text-on-wine);opacity:.9;background:0 0;border:none;align-items:center;gap:4px;padding:4px 0;font-size:15px;font-weight:500;display:inline-flex}.detail-back:hover{opacity:1}.detail-hero{background:var(--surface);border-top:4px solid #888;border-bottom:1px solid var(--border);padding:24px 20px 20px}.detail-color-badge{letter-spacing:1px;color:#fff;border-radius:var(--radius-full);text-transform:uppercase;margin-bottom:12px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.detail-name{letter-spacing:-.5px;color:var(--text);margin-bottom:4px;font-size:26px;font-weight:700;line-height:1.2}.detail-winery{color:var(--text-muted);font-size:16px}.detail-info{background:var(--border);border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;gap:1px;display:grid}.detail-info-item{background:var(--surface);flex-direction:column;gap:2px;padding:12px 16px;display:flex}.detail-info-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-size:11px;font-weight:600}.detail-info-value{color:var(--text);font-size:14px;font-weight:500}.detail-notes{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 20px}.detail-notes-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:700}.detail-notes-text{color:var(--text);font-size:14px;line-height:1.6}.cellar-section{background:var(--surface);flex:1;padding:24px 20px 40px}.cellar-title{text-transform:uppercase;letter-spacing:.8px;color:var(--wine);border-bottom:1.5px solid var(--wine-border);margin-bottom:24px;padding-bottom:12px;font-size:13px;font-weight:700}.cellar-field{margin-bottom:28px}.cellar-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px;font-size:13px;font-weight:600;display:block}.cellar-label-hint{text-transform:none;letter-spacing:0;font-weight:400}.stepper{border:1.5px solid var(--border);border-radius:var(--radius-full);align-items:center;display:inline-flex;overflow:hidden}.stepper-btn{background:var(--surface-2);width:48px;height:48px;color:var(--text);border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;line-height:1;transition:background .12s;display:flex}.stepper-btn:hover:not(:disabled){background:var(--wine-light);color:var(--wine)}.stepper-btn:disabled{opacity:.3;cursor:not-allowed}.stepper-value{text-align:center;min-width:56px;color:var(--text);border-left:1.5px solid var(--border);border-right:1.5px solid var(--border);padding:0 4px;font-size:22px;font-weight:600;line-height:48px}.rating-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:96px;color:var(--text);background:var(--surface);font-size:22px;font-weight:600;font-family:var(--sans);text-align:center;padding:10px 14px;transition:border-color .15s}.rating-input:focus{border-color:var(--wine);outline:none}.rating-input::placeholder{color:var(--border-strong)}.rating-track{background:var(--border);border-radius:var(--radius-full);height:4px;margin-top:10px;overflow:hidden}.rating-fill{background:var(--wine);border-radius:var(--radius-full);height:100%;transition:width .2s}.tag-input-area{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:text;flex-wrap:wrap;align-items:center;gap:8px;min-height:50px;padding:10px 12px;transition:border-color .15s;display:flex}.tag-input-area:focus-within{border-color:var(--wine)}.tag{background:var(--wine-light);border:1px solid var(--wine-border);color:var(--wine);border-radius:var(--radius-full);align-items:center;gap:5px;padding:3px 8px 3px 10px;font-size:13px;font-weight:500;display:inline-flex}.tag-remove{color:var(--wine);opacity:.6;background:0 0;border:none;padding:0;font-size:16px;line-height:1}.tag-remove:hover{opacity:1}.tag-inline-input{color:var(--text);font-size:14px;font-family:var(--sans);background:0 0;border:none;outline:none;flex:1;min-width:140px}.tag-inline-input::placeholder{color:var(--text-muted)}.field-hint{color:var(--text-muted);margin-top:6px;font-size:12px}.save-btn{background:var(--wine);width:100%;color:var(--text-on-wine);border-radius:var(--radius);letter-spacing:.2px;border:none;margin-top:8px;padding:16px;font-size:16px;font-weight:600;transition:background .15s,opacity .15s;display:block}.save-btn:hover:not(:disabled){background:var(--wine-dark)}.save-btn:disabled{opacity:.6;cursor:not-allowed}.save-btn--saved{background:#2d7a4f}.save-error{color:#c0392b;border-radius:var(--radius-sm);background:#c0392b14;border:1px solid #c0392b33;margin-bottom:12px;padding:10px 14px;font-size:14px}.remove-btn{width:100%;color:var(--text-muted);text-underline-offset:3px;background:0 0;border:none;margin-top:12px;padding:14px;font-size:14px;text-decoration:underline;transition:color .12s;display:block}.remove-btn:hover{color:#c0392b}@media (width>=640px){.home,.detail{border-left:1px solid var(--border);border-right:1px solid var(--border);box-shadow:var(--shadow-lg)}#root{background:var(--surface-2);align-items:center}}.login{flex-direction:column;width:100%;max-width:600px;min-height:100svh;margin:0 auto;display:flex}.login-body{background:var(--surface);flex-direction:column;flex:1;padding:40px 24px 48px;display:flex}.login-title{letter-spacing:-.5px;color:var(--text);margin-bottom:28px;font-size:26px;font-weight:700}.login-form{flex-direction:column;gap:18px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:13px;font-weight:600}.login-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--bg);font-size:16px;font-family:var(--sans);padding:13px 14px;transition:border-color .15s}.login-input:focus{border-color:var(--wine);outline:none}.login-error{color:#c0392b;border-radius:var(--radius-sm);background:#c0392b14;border:1px solid #c0392b33;padding:10px 14px;font-size:14px}.login-toggle{color:var(--wine);text-underline-offset:3px;font-size:14px;font-family:var(--sans);background:0 0;border:none;align-self:center;margin-top:20px;text-decoration:underline}.logout-btn{color:var(--text-on-wine);border-radius:var(--radius-sm);font-size:13px;font-family:var(--sans);background:#ffffff26;border:1px solid #ffffff4d;padding:6px 14px;transition:background .15s}.logout-btn:hover{background:#ffffff40}.app-loading{min-height:100svh;color:var(--text-muted);background:var(--bg);justify-content:center;align-items:center;font-size:15px;display:flex}
