:root{--bg: #15100e;--bg-elevated: #1f1815;--surface: #2a201c;--surface-2: #362a25;--border: #3d2f29;--ink: #f4ead9;--ink-muted: #b8a896;--ink-dim: #7d6d61;--wine: #8b1a2c;--wine-bright: #c43955;--gold: #d4a04a;--cream: #e8d5a6;--rot: #8b1a2c;--weiss: #c8a85a;--rose: #d97b7b;--schaum: #e8d5a6;--dessert: #6b4423;--radius: 14px;--radius-sm: 8px;--shadow: 0 4px 20px rgba(0,0,0,.4)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,sans-serif;font-size:16px;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}body{background:radial-gradient(ellipse at top,rgba(139,26,44,.12) 0%,transparent 60%),var(--bg);background-attachment:fixed;min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh}h1,h2,h3{font-family:Fraunces,Georgia,serif;font-weight:500;letter-spacing:-.01em}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}code{font-family:SF Mono,Menlo,monospace;font-size:.9em;background:var(--surface);padding:2px 6px;border-radius:4px}.app-shell{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;padding-bottom:76px}.app-header{position:sticky;top:0;z-index:50;background:#15100ed9;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.header-inner{max-width:700px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:10px;color:var(--cream);font-family:Fraunces,serif;font-size:18px;font-weight:500;letter-spacing:.02em}.app-main{flex:1;width:100%;max-width:700px;margin:0 auto;padding:20px}.page{display:flex;flex-direction:column;gap:18px}.page-title{font-size:28px;font-weight:500;margin-bottom:4px}.section-title{font-size:18px;font-weight:500;color:var(--cream);margin-top:8px;display:flex;align-items:center;gap:10px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;background:#15100eeb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:10px 0 calc(10px + env(safe-area-inset-bottom))}.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:11px;color:var(--ink-dim);padding:4px 14px;transition:color .15s}.bottom-nav a.active{color:var(--cream)}.bottom-nav a.active svg{color:var(--gold)}.login-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at top,rgba(139,26,44,.18) 0%,transparent 60%),var(--bg)}.login-card{width:100%;max-width:380px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:32px 26px;box-shadow:var(--shadow);text-align:center}.brand-mark{color:var(--gold);margin-bottom:16px}.login-card h1{font-size:28px;margin-bottom:4px}.login-card .subtitle{color:var(--ink-muted);margin-bottom:28px;font-size:14px}.login-card form{display:flex;flex-direction:column;gap:14px;text-align:left}.login-card .hint{margin-top:16px;font-size:12px;color:var(--ink-dim);font-style:italic}.form,label{display:flex;flex-direction:column;gap:6px}.form{gap:14px}label{font-size:13px;color:var(--ink-muted);font-weight:500;letter-spacing:.02em}input,select,textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--ink);font-size:16px;transition:border-color .15s,background .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);background:var(--surface-2)}textarea{resize:vertical}fieldset{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}fieldset legend{padding:0 6px;font-size:13px;color:var(--ink-muted)}.row{display:flex;gap:10px}button{cursor:pointer;border:none;background:var(--surface);color:var(--ink);padding:12px 18px;border-radius:var(--radius-sm);font-weight:500;transition:background .15s,transform .1s;border:1px solid var(--border)}button:hover{background:var(--surface-2)}button:active{transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed}.primary-btn,.login-card button[type=submit]{background:var(--wine);color:var(--cream);border-color:var(--wine);padding:14px 18px;font-weight:600;letter-spacing:.02em}.primary-btn:hover,.login-card button[type=submit]:hover{background:var(--wine-bright);border-color:var(--wine-bright)}.ghost-btn{background:transparent;border:1px solid var(--border);color:var(--ink-muted);font-size:13px;padding:8px 12px}.ghost-btn.full-width{width:100%;margin-top:8px}.consume-btn{background:var(--wine);color:var(--cream);border-color:var(--wine);font-weight:600;white-space:nowrap;padding:10px 16px}.consume-btn:hover{background:var(--wine-bright)}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.muted{color:var(--ink-muted)}.muted.small,.small.muted{font-size:13px}.center{text-align:center;padding:30px 0}.hero{text-align:center;padding:30px 0 20px}.hero-eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}.hero-number{font-family:Fraunces,serif;font-size:96px;font-weight:400;line-height:1;background:linear-gradient(135deg,var(--cream) 0%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-variation-settings:"opsz" 144}.hero-label{color:var(--ink-muted);font-size:14px;margin-top:4px;letter-spacing:.04em}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:18px;text-align:center;transition:border-color .15s,transform .1s}.stat-card:active{transform:scale(.98)}.stat-card:hover{border-color:var(--gold)}.stat-value{font-family:Fraunces,serif;font-size:32px;font-weight:500;color:var(--cream)}.stat-label{font-size:12px;color:var(--ink-muted);letter-spacing:.04em;margin-top:4px}.quick-actions{display:flex;gap:10px}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:500}.action-btn.primary{background:var(--wine);border-color:var(--wine);color:var(--cream)}.alert-section{margin-top:20px}.alert-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px #d4a04a33}.alert-list{display:flex;flex-direction:column;gap:10px}.alert-item{display:flex;justify-content:space-between;align-items:center;gap:12px}.alert-wine{font-weight:500}.alert-meta{text-align:right}.alert-deadline{color:var(--gold);font-size:13px;font-weight:500}.scan-area{margin:10px 0}.big-btn{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:50px 20px;background:linear-gradient(135deg,var(--wine) 0%,#6b1422 100%);color:var(--cream);border:none;border-radius:var(--radius);font-size:18px;font-weight:500;letter-spacing:.02em}.camera-wrap{position:relative;width:100%;aspect-ratio:4/3;background:#000;border-radius:var(--radius);overflow:hidden}.camera-wrap video{width:100%;height:100%;object-fit:cover}.scan-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.scan-frame{width:75%;height:30%;border:2px solid var(--gold);border-radius:8px;box-shadow:0 0 0 9999px #0006;position:relative}.scan-frame:before,.scan-frame:after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--gold);animation:scanline 2s ease-in-out infinite}@keyframes scanline{0%,to{top:0;opacity:0}50%{top:calc(100% - 2px);opacity:1}}.stop-btn{position:absolute;bottom:14px;left:50%;transform:translate(-50%);background:#000000b3;border:1px solid var(--cream);color:var(--cream)}.manual-input{display:flex;gap:8px}.manual-input input{flex:1}.wine-card{border-left:3px solid var(--gold)}.wine-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:6px}.wine-card h3{font-size:22px;font-family:Fraunces,serif;font-weight:500}.producer{color:var(--cream);font-style:italic;margin-bottom:4px}.tag{display:inline-block;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.color-rot{background:#8b1a2c33;color:#e88799;border:1px solid var(--rot)}.color-weiss{background:#c8a85a26;color:var(--weiss);border:1px solid var(--weiss)}.color-rose{background:#d97b7b26;color:var(--rose);border:1px solid var(--rose)}.color-schaum{background:#e8d5a626;color:var(--schaum);border:1px solid var(--schaum)}.color-dessert{background:#6b44234d;color:#c89970;border:1px solid #c89970}.stock-list{display:flex;flex-direction:column;gap:10px}.stock-item{display:flex;justify-content:space-between;align-items:center;gap:14px}.stock-info{flex:1;min-width:0}.stock-info .wine-name{font-weight:500;font-size:16px;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vintage{font-family:Fraunces,serif;font-size:24px;font-weight:500;color:var(--gold);display:flex;align-items:baseline;gap:8px}.vintage .qty{font-family:Inter,sans-serif;font-size:14px;color:var(--ink-muted);font-weight:400}.location{margin-top:4px;font-size:13px;color:var(--ink-muted)}.notes{margin-top:4px;font-size:13px;font-style:italic}.meta-row{display:flex;align-items:center;gap:8px;margin-top:6px;flex-wrap:wrap}.vintage-pill{font-family:Fraunces,serif;background:var(--surface);color:var(--gold);padding:2px 10px;border-radius:99px;font-size:13px;font-weight:500;border:1px solid var(--border)}.qty-pill{background:var(--surface);color:var(--cream);padding:2px 10px;border-radius:99px;font-size:12px;border:1px solid var(--border)}.search-bar{display:flex;gap:8px;align-items:center}.search-bar input{flex:1}.add-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--wine);color:var(--cream);border-radius:var(--radius-sm);font-size:24px;font-weight:300;flex-shrink:0}.location-section{margin-top:10px}.location-heading{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;font-family:Inter,sans-serif;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-muted);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.location-heading .count{color:var(--gold);font-size:12px;letter-spacing:.05em}.history-list{display:flex;flex-direction:column;gap:10px}.history-item{display:flex;gap:16px;align-items:flex-start}.history-date{flex-shrink:0;text-align:center;width:50px;border-right:1px solid var(--border);padding-right:14px}.history-date .day{font-family:Fraunces,serif;font-size:24px;font-weight:500;color:var(--gold);line-height:1}.history-date .month{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);margin-top:4px}.history-date .year{font-size:11px;color:var(--ink-dim)}.history-content{flex:1}.history-name{font-weight:500;color:var(--cream)}.error{background:#c439551a;border:1px solid var(--wine);border-radius:var(--radius-sm);padding:12px 14px;color:#f0a3b3;font-size:14px}.empty{text-align:center;padding:24px}.splash{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.info{background:#d4a04a1a;border:1px solid var(--gold);border-radius:var(--radius-sm);padding:12px 14px;color:var(--cream);font-size:14px}.info strong{color:var(--gold)}.qr-badge,.ean-badge{display:inline-block;font-family:SF Mono,Menlo,monospace;font-size:11px;letter-spacing:.05em;padding:3px 10px;border-radius:4px;margin-bottom:10px}.qr-badge{background:#d4a04a26;color:var(--gold);border:1px solid var(--gold)}.ean-badge{background:var(--surface);color:var(--ink-muted);border:1px solid var(--border)}.location-pill{background:var(--surface);color:var(--ink-muted);padding:2px 10px;border-radius:99px;font-size:12px;border:1px solid var(--border)}.full-width{width:100%}.row .flex{flex:1}.step-indicator{display:flex;gap:8px;margin-bottom:8px;font-size:12px;color:var(--ink-dim);letter-spacing:.04em}.step{flex:1;text-align:center;padding:8px 6px;background:var(--surface);border-radius:6px;border:1px solid var(--border)}.step.active{color:var(--cream);background:var(--bg-elevated);border-color:var(--gold)}.step.done{color:var(--gold);border-color:var(--gold);background:#d4a04a0d}.scan-counter{position:absolute;top:14px;right:14px;background:#000000b3;color:var(--gold);font-family:Fraunces,serif;font-size:18px;padding:6px 14px;border-radius:99px;border:1px solid var(--gold)}.scanned-list{display:flex;flex-direction:column;gap:6px;margin-top:8px;max-height:320px;overflow-y:auto}.scanned-chip{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-family:SF Mono,Menlo,monospace;font-size:13px;color:var(--cream)}.scanned-chip span{color:var(--ink-dim);font-family:Inter,sans-serif}.scanned-chip code{flex:1}.remove-btn{background:transparent;border:none;color:var(--ink-dim);cursor:pointer;font-size:18px;padding:0 6px}.remove-btn:hover{color:var(--wine-bright)}.hint-list{list-style:none;padding:0;margin-top:8px}.hint-list li{padding:8px 0;font-size:13px;color:var(--ink-muted);border-bottom:1px solid var(--border)}.hint-list li:last-child{border-bottom:none}.hint-list strong{color:var(--cream)}.aging-row{display:flex;gap:10px}.aging-field{flex:0 0 auto;width:calc(50% - 5px);max-width:130px}.aging-field input{width:100%}.stock-item.clickable{cursor:pointer;transition:border-color .15s,transform .05s}.stock-item.clickable:hover{border-color:var(--gold)}.stock-item.clickable:active{transform:scale(.99)}input[list]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--ink);font-size:16px;width:100%;font-family:inherit}input[list]:focus{outline:none;border-color:var(--gold);background:var(--surface-2)}.row>label.flex{min-width:0}.row>label.flex input[type=number],.row>label.flex input[type=date]{width:100%;min-width:0;box-sizing:border-box}.qr-section{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;padding:14px}.qr-list{display:flex;flex-direction:column;gap:6px}.qr-list-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-family:SF Mono,Menlo,monospace;font-size:13px;color:var(--cream)}.qr-list-item code{flex:1;background:transparent;padding:0}
