@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-opsz-normal-Czevyj-6.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-ext-opsz-normal-CJcjJNj7.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-opsz-normal-DihXLNYH.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--primary:#6e1f30;--primary-hover:#872840;--on-primary:#fffaf6;--brand:#6e1f30;--link:#7d2840;--gold:#a8763a;--gold-soft:#d9b673;--bg:#f6f1ea;--bg-tint:#efe6db;--card:#fffdfb;--text:#2b2226;--muted:#6f6469;--border:#e8ddd2;--ok:#2f7d4f;--danger:#b3261e;--danger-bg:#fdecea;--danger-border:#f3c7c2;--radius:16px;--radius-sm:10px;--radius-pill:999px;--shadow-sm:0 1px 2px #3a16200d, 0 1px 3px #3a16200f;--shadow-md:0 6px 16px -6px #3a16202e, 0 2px 6px -2px #3a162014;--shadow-lg:0 18px 40px -12px #3a162047;--ring:0 0 0 3px #a8763a66;--ease:cubic-bezier(.2, .7, .3, 1);--font-serif:"Fraunces Variable", "Cormorant Garamond", Georgia, "Times New Roman", serif;--font-sans:system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;font-family:var(--font-sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}body{background:radial-gradient(1200px 600px at 100% -10%, #a8763a0f, transparent 60%), radial-gradient(1000px 500px at -10% 0%, #6e1f300d, transparent 55%), var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background-attachment:fixed;margin:0;line-height:1.5}a{color:var(--link);border-bottom:1px solid color-mix(in srgb, var(--link) 30%, transparent);transition:color .15s var(--ease), border-color .15s var(--ease);text-decoration:none}a:hover{color:var(--primary-hover);border-bottom-color:var(--link)}a:has(>button){border-bottom:none}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link{z-index:200;background:var(--primary);color:var(--on-primary);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);transition:top .15s var(--ease);border:none;padding:10px 16px;position:fixed;top:-100px;left:12px}.skip-link:focus-visible{box-shadow:var(--ring), var(--shadow-md);outline:none;top:12px}main:focus{outline:none}.page{max-width:760px;animation:page-in .4s var(--ease) both;margin:0 auto;padding:12px 18px 72px}.page--wide{max-width:1100px}@keyframes page-in{0%{opacity:0;transform:translateY(6px)}}.brand{font-family:var(--font-serif);font-optical-sizing:auto;letter-spacing:-.5px;color:var(--brand);font-size:1.9rem;font-weight:600;line-height:1.1}.brand small{font-family:var(--font-sans);color:var(--muted);letter-spacing:.2px;margin-top:2px;font-size:.82rem;font-weight:500;display:block}h1,h2,h3{font-family:var(--font-serif);font-optical-sizing:auto;color:var(--text);font-weight:600}h1{letter-spacing:-.4px;margin:.3em 0;font-size:1.8rem}h2{margin:0 0 12px;font-size:1.3rem}h3{font-size:1.12rem}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:box-shadow .2s var(--ease), transform .2s var(--ease);margin:16px 0;padding:22px}label{color:var(--muted);margin:14px 0 5px;font-size:.84rem;font-weight:500;display:block}input[type=text],input[type=number],select,textarea{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);width:100%;color:var(--text);transition:border-color .15s var(--ease), box-shadow .15s var(--ease);padding:12px 13px;font-family:inherit;font-size:1rem}input::placeholder,textarea::placeholder{color:color-mix(in srgb, var(--muted) 75%, transparent)}input[type=text]:focus,input[type=number]:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:var(--ring);outline:none}textarea{resize:vertical;min-height:76px}button{border-radius:var(--radius-sm);background:var(--primary);color:var(--on-primary);cursor:pointer;transition:background .15s var(--ease), border-color .15s var(--ease), transform 80ms var(--ease), box-shadow .15s var(--ease);border:1px solid #0000;padding:12px 20px;font-family:inherit;font-size:1rem;font-weight:600}button:hover:not(:disabled){background:var(--primary-hover)}button:active:not(:disabled){transform:translateY(1px)}button:focus-visible,.chip:focus-visible,.wine-tab:focus-visible,.lang-option:focus-visible{box-shadow:var(--ring);outline:none}button.secondary{background:var(--card);color:var(--primary);border-color:var(--border)}button.secondary:hover:not(:disabled){background:var(--bg-tint);border-color:var(--gold-soft)}button.ghost{color:var(--muted);border-color:var(--border);background:0 0}button.ghost:hover:not(:disabled){background:var(--bg-tint);color:var(--text)}button:disabled{opacity:.45;cursor:not-allowed}.row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.grow{flex:1}.muted{color:var(--muted)}.error{color:var(--danger);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius-sm);margin:10px 0;padding:11px 13px;font-size:.92rem}.pill{border-radius:var(--radius-pill);letter-spacing:.2px;background:var(--bg-tint);color:var(--primary);border:1px solid var(--border);padding:4px 12px;font-size:.78rem;font-weight:600;display:inline-block}.code-display{font-family:var(--font-serif);letter-spacing:8px;color:var(--primary);font-size:2.8rem;font-weight:600;line-height:1.1}.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-10{margin-top:10px}.mt-12{margin-top:12px}.mt-14{margin-top:14px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-2{margin-bottom:2px}.mb-4{margin-bottom:4px}.gap-8{gap:8px}.text-sm{font-size:.85rem}.scanner-video{border-radius:8px;width:100%}.loading{color:var(--muted);align-items:center;gap:10px;display:flex}.spinner{border:2px solid color-mix(in srgb, var(--gold) 35%, transparent);border-top-color:var(--gold);border-radius:50%;flex:none;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.chips{flex-wrap:wrap;gap:8px;display:flex}.chip{border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--card);min-height:40px;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s var(--ease), border-color .15s var(--ease), color .15s var(--ease), transform 80ms var(--ease);align-items:center;padding:8px 16px;font-size:.92rem;font-weight:500;display:inline-flex}.chip:hover:not(.selected){border-color:var(--gold-soft);background:var(--bg-tint)}.chip:active{transform:translateY(1px)}.chip.selected{background:var(--primary);border-color:var(--primary);color:var(--on-primary);box-shadow:var(--shadow-sm)}.chip:disabled.selected{opacity:1}.chip:disabled:not(.selected){opacity:.4}.field{margin:16px 0}.field>.field-label{color:var(--text);margin-bottom:8px;font-size:.95rem;font-weight:600}.section-title{text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);align-items:center;gap:10px;margin:28px 0 6px;font-size:.72rem;font-weight:700;display:flex}.section-title:after{content:"";background:linear-gradient(to right, color-mix(in srgb, var(--gold) 45%, transparent), transparent);flex:1;height:1px}.wine-tabs{scrollbar-width:thin;gap:8px;padding-bottom:6px;display:flex;overflow-x:auto}.wine-tab{white-space:nowrap;border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--card);min-height:40px;color:var(--text);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease), border-color .15s var(--ease);padding:9px 16px;font-size:.9rem;font-weight:500}.wine-tab:hover:not(:disabled):not(.active){border-color:var(--gold-soft);background:var(--bg-tint)}.wine-tab:disabled{opacity:.5;cursor:not-allowed}.wine-tab.active{background:var(--primary);color:var(--on-primary);border-color:var(--primary);box-shadow:var(--shadow-sm)}.tab-ready{border-radius:var(--radius-pill);background:color-mix(in srgb, var(--gold) 18%, transparent);color:color-mix(in srgb, var(--gold) 70%, var(--text));margin-left:7px;padding:1px 7px;font-size:.72rem;font-weight:700}.tab-ready.all{background:color-mix(in srgb, var(--ok) 18%, transparent);color:var(--ok)}.wine-tab.active .tab-ready{color:var(--on-primary);background:#ffffff47}.wine-tab.focus-flag:after{content:" ●";color:var(--gold)}.wine-tab.active.focus-flag:after{color:var(--gold-soft)}.setup-list{flex-direction:column;gap:8px;margin:8px 0 0;padding:0;list-style:none;display:flex}.setup-item{background:var(--bg-tint);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:10px;padding:9px 12px;display:flex}.setup-name{font-weight:600}.setup-count{flex:none;font-size:.82rem}.setup-delete{flex:none;min-width:40px;min-height:40px;padding:6px 12px;font-size:1.2rem;line-height:1}.wine-reorder{flex-direction:column;gap:8px;margin:8px 0 0;padding:0;list-style:none;display:flex}.wine-reorder-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);min-height:48px;box-shadow:var(--shadow-sm);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:10px 14px;display:flex}.wine-reorder-item:focus-visible{box-shadow:var(--ring);border-color:var(--gold);outline:none}.wine-reorder-item.dragging{cursor:grabbing;opacity:.9;box-shadow:var(--shadow-lg);border-color:var(--gold-soft);z-index:1}.wine-reorder-grip{color:var(--muted);letter-spacing:-2px;flex:none;font-size:1.25rem;line-height:1}.wine-reorder-name{font-weight:500}.progress-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.progress-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.progress-card-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.progress-card-name{font-size:1.02rem;font-weight:600}.progress-wines{flex-wrap:wrap;gap:7px;margin:0;padding:0;list-style:none;display:flex}.progress-wine{border-radius:var(--radius-pill);border:1px solid var(--border);background:var(--bg-tint);color:var(--muted);align-items:center;gap:6px;padding:5px 11px 5px 9px;font-size:.85rem;display:inline-flex}.progress-wine.done{border-color:color-mix(in srgb, var(--ok) 45%, var(--border));background:color-mix(in srgb, var(--ok) 12%, transparent);color:color-mix(in srgb, var(--ok) 60%, var(--text))}.progress-wine-mark{color:var(--muted);font-weight:700}.progress-wine.done .progress-wine-mark{color:var(--ok)}.progress-wine-ready{font-size:.8rem;line-height:1}.progress-wine.ready{border-color:color-mix(in srgb, var(--ok) 45%, var(--border))}.progress-wine.waiting{border-color:var(--gold);background:color-mix(in srgb, var(--gold) 14%, transparent);color:color-mix(in srgb, var(--gold) 65%, var(--text))}.banner{background:linear-gradient(135deg, var(--primary), var(--primary-hover));color:var(--on-primary);border-radius:var(--radius);box-shadow:var(--shadow-md);border-left:4px solid var(--gold-soft);margin:14px 0;padding:15px 18px}.banner strong{font-family:var(--font-serif);font-weight:600}.banner .muted{color:color-mix(in srgb, var(--on-primary) 78%, transparent)}.status-line{color:var(--muted);align-items:center;gap:8px;font-size:.85rem;display:flex}.conn{background:var(--muted);opacity:.5;width:9px;height:9px;transition:background .2s var(--ease), opacity .2s var(--ease);border-radius:50%}.conn.up{background:var(--ok);opacity:1;box-shadow:0 0 0 3px color-mix(in srgb, var(--ok) 18%, transparent)}.taster-note{border-top:1px solid var(--border);padding:12px 0}.taster-note:last-child{padding-bottom:0}.taster-note-name{color:var(--primary);margin-bottom:4px;font-weight:700}.note-summary{font-size:.92rem;line-height:1.5}.note-label{color:var(--muted);font-weight:600}.note-comment{color:var(--muted);margin-top:4px;font-style:italic}@keyframes reveal-flash{0%{box-shadow:0 0 0 0 var(--primary)}to{box-shadow:0 0 0 4px #0000}}.card.reveal-flash{animation:1.6s ease-out reveal-flash}@media (prefers-reduced-motion:reduce){.card.reveal-flash{animation:none}}.dist-count-line{flex-wrap:wrap;align-items:baseline;gap:6px 12px;margin-bottom:10px;font-size:.8rem;display:flex}.dist-mine-legend{padding:1px 9px;font-size:.8rem}.dist-field{border-top:1px solid var(--border);gap:10px;padding:10px 0;display:flex}.dist-field:first-of-type{border-top:none}.dist-label{color:var(--muted);flex:0 0 130px;font-size:.9rem;font-weight:600}.dist-options{flex-wrap:wrap;gap:6px;display:flex}.dist-option{background:var(--bg-tint);border:1px solid var(--border);border-radius:var(--radius-pill);padding:3px 11px;font-size:.9rem}.dist-option.mine{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.dist-option.mine .dist-count{color:#fff}.dist-count{color:var(--primary);font-weight:700}.dist-comments li.mine{color:var(--primary);font-weight:600}.dist-comments{color:var(--text);margin:0;padding-left:18px;font-size:.9rem}.dist-comments li{margin-bottom:2px}.topbar{border-bottom:1px solid var(--border);background:var(--card);justify-content:space-between;align-items:center;gap:8px;padding:10px 16px;display:flex;position:relative}.topbar-actions{align-items:center;gap:8px;display:inline-flex}.nav-toggle{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:40px;min-height:40px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;font-size:1.25rem;line-height:1;display:none}.nav-toggle:focus-visible{outline:2px solid var(--gold);outline-offset:2px}@media (width<=480px){.nav-toggle{display:inline-flex}.topbar-actions{z-index:20;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);flex-direction:column;align-items:flex-end;gap:12px;margin-top:6px;padding:12px 14px;display:none;position:absolute;top:100%;right:8px}.topbar-actions.open{display:inline-flex}}.nav-brand{font-family:var(--font-serif);font-optical-sizing:auto;letter-spacing:-.5px;color:var(--brand);border-radius:var(--radius);border-bottom:none;padding:4px 6px;font-size:1.35rem;font-weight:600;line-height:1;text-decoration:none}.nav-brand:hover{color:var(--primary)}.nav-brand:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.feedback-link{color:var(--muted);border-radius:var(--radius-sm);padding:4px 8px;font-size:.9rem;text-decoration:none}.feedback-link:hover{color:var(--primary)}.feedback-link:focus-visible{outline:2px solid var(--gold);outline-offset:2px}.lang-switch{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);gap:2px;padding:3px;display:inline-flex}.theme-toggle{background:var(--card);min-width:40px;min-height:40px;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;padding:5px 11px;font-size:1.05rem;line-height:1;display:inline-flex}.theme-toggle:hover:not(:disabled){background:var(--bg-tint);border-color:var(--gold-soft)}.lang-switch .lang-option{letter-spacing:.3px;border-radius:var(--radius-pill);color:var(--muted);transition:background .15s var(--ease), color .15s var(--ease);background:0 0;border:none;padding:5px 11px;font-size:.78rem;font-weight:700}.lang-switch .lang-option:hover{background:var(--bg-tint);color:var(--text)}.lang-switch .lang-option.active{background:var(--primary);color:var(--on-primary)}:root[data-theme=dark]{--primary:#a8324c;--primary-hover:#c33d5b;--on-primary:#fff6f3;--brand:#eab8c3;--link:#ecb9c4;--gold:#cda35f;--gold-soft:#e0c089;--bg:#181215;--bg-tint:#2c2126;--card:#221920;--text:#f1e7e4;--muted:#ab9ca0;--border:#3a2c33;--ok:#4caf72;--danger:#f1a39c;--danger-bg:#2e1a1a;--danger-border:#5a2f2c;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 6px 18px -6px #00000080;--shadow-lg:0 18px 44px -12px #0009;--ring:0 0 0 3px #cda35f73;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
