:root{--color-bg: #0D0B09;--color-surface: #151412;--color-elevated: #1A1610;--color-border: #2A2520;--color-text: #F5F0E8;--color-text-secondary: #8A8278;--color-text-muted: #8A8278;--color-accent: #D4AF55;--color-accent-bold: #E8853A;--color-success: #5A9E6F;--color-error: #D45B5B;--color-aged-gold: #B8923E;--color-warm-stone: #8A8278;--color-deep-toast: #2A2520;--color-copper: #C75B2A;--color-oak: #3D362E;--color-parchment: #EDE5D8;--color-dim-text: #8A8278;--font-display: "Playfair Display", Georgia, serif;--font-heading: "DM Sans", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--text-display: 2.625rem;--text-h1: 1.75rem;--text-h2: 1.375rem;--text-body: 1rem;--text-small: .875rem;--text-caption: .75rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-full: 9999px;--radius-pill: 100px;--radius-card: 18px;--radius-input: 14px;--touch-min: 2.75rem;--transition-fast: .15s ease;--transition-normal: .25s ease;--plate-border: rgba(212, 175, 85, .5);--plate-frame-tint: rgba(212, 175, 85, .035);--plate-inner-border: rgba(212, 175, 85, .18);--plate-rule: rgba(212, 175, 85, .55);--drawer-shadow: 0 -16px 48px rgba(0, 0, 0, .32);--drawer-backdrop: rgba(13, 11, 9, .55);--drawer-glass-bg: rgba(21, 20, 18, 0)}@media(prefers-color-scheme:light){:root{--color-bg: #FAF7F2;--color-surface: #FFFFFF;--color-elevated: #F5F0E8;--color-border: #E8E2D8;--color-text: #1A1610;--color-text-secondary: #6B6560;--color-text-muted: #8A8278;--color-dim-text: #8A8278;--color-accent: #B8923E;--color-accent-bold: #C75B2A;--color-success: #3D8A54;--color-error: #C0392B;--plate-border: rgba(184, 146, 62, .6);--plate-frame-tint: rgba(184, 146, 62, .05);--plate-inner-border: rgba(184, 146, 62, .28);--plate-rule: rgba(184, 146, 62, .55);--drawer-shadow: 0 -12px 36px rgba(26, 22, 16, .1);--drawer-backdrop: rgba(250, 247, 242, .65);--drawer-glass-bg: rgba(252, 248, 242, 0)}}:root[data-theme=dark]{--color-bg: #0D0B09;--color-surface: #151412;--color-elevated: #1A1610;--color-border: #2A2520;--color-text: #F5F0E8;--color-text-secondary: #8A8278;--color-text-muted: #8A8278;--color-dim-text: #8A8278;--color-accent: #D4AF55;--color-accent-bold: #E8853A;--color-success: #5A9E6F;--color-error: #D45B5B;--plate-border: rgba(212, 175, 85, .5);--plate-frame-tint: rgba(212, 175, 85, .035);--plate-inner-border: rgba(212, 175, 85, .18);--plate-rule: rgba(212, 175, 85, .55);--drawer-shadow: 0 -16px 48px rgba(0, 0, 0, .32);--drawer-backdrop: rgba(13, 11, 9, .55);--drawer-glass-bg: rgba(21, 20, 18, 0)}:root[data-theme=light]{--color-bg: #FAF7F2;--color-surface: #FFFFFF;--color-elevated: #F5F0E8;--color-border: #E8E2D8;--color-text: #1A1610;--color-text-secondary: #6B6560;--color-text-muted: #8A8278;--color-dim-text: #8A8278;--color-accent: #B8923E;--color-accent-bold: #C75B2A;--color-success: #3D8A54;--color-error: #C0392B;--plate-border: rgba(184, 146, 62, .6);--plate-frame-tint: rgba(184, 146, 62, .05);--plate-inner-border: rgba(184, 146, 62, .28);--plate-rule: rgba(184, 146, 62, .55);--drawer-shadow: 0 -12px 36px rgba(26, 22, 16, .1);--drawer-backdrop: rgba(250, 247, 242, .65);--drawer-glass-bg: rgba(252, 248, 242, 0)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-body);line-height:1.5;color:var(--color-text);background-color:var(--color-bg);min-height:100svh}h1,h2,h3{font-family:var(--font-heading);font-weight:700;line-height:1.2}h1{font-size:var(--text-h1)}h2{font-size:var(--text-h2)}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font-heading);font-weight:500;font-size:var(--text-body);cursor:pointer;border:none;background:none;color:inherit;min-height:var(--touch-min);min-width:var(--touch-min)}.skip-link{position:absolute;top:-100%;left:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-sm);z-index:1000;font-weight:600}.skip-link:focus{top:var(--space-md)}*:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}#app{display:flex;flex-direction:column;height:100svh}main{flex:1;display:flex;flex-direction:column;padding:var(--space-md);min-height:0;overflow-y:auto}#app[data-page="/login"]>main{padding:0}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.icon{display:inline-block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:middle;transition:stroke-width .18s ease;flex-shrink:0}.nav-icon:hover .icon,.tab-item.active .icon,.btn-camera:hover .icon,.chat-suggestion:hover .icon{stroke-width:2.4}.nav-top{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--color-elevated);border-bottom:1px solid var(--color-border);min-height:48px}.nav-logo{display:flex;align-items:center;gap:0}.nav-logo .nav-brand-mark{display:inline-block;height:22px;width:auto;margin-right:8px;flex-shrink:0}.nav-logo .logo-my,.nav-logo .logo-cellier{font-family:var(--font-display);font-weight:600;font-size:1.375rem;letter-spacing:-.01em;line-height:1}.nav-logo .logo-my{color:var(--color-accent)}.nav-logo .logo-cellier{color:var(--color-text)}.nav-actions{display:flex;gap:var(--space-sm)}.nav-icon{position:relative;width:var(--touch-min);height:var(--touch-min);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:1.125rem;cursor:pointer;border-radius:var(--radius-sm);background:transparent;border:none;padding:0}.nav-icon:hover{color:var(--color-accent)}.nav-icon-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;display:inline-flex;align-items:center;justify-content:center;background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-full);font-size:10px;font-weight:700;line-height:1;pointer-events:none}.tab-bar{display:flex;background:var(--color-elevated);border-top:1px solid var(--color-border);padding:var(--space-xs) 0;padding-bottom:env(safe-area-inset-bottom,var(--space-xs))}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-xs) 0;cursor:pointer;color:var(--color-text-muted);text-decoration:none;min-height:var(--touch-min);justify-content:center}.tab-item.active{color:var(--color-accent)}.tab-icon{font-size:1.25rem;line-height:1;display:inline-flex;align-items:center;justify-content:center}.tab-icon .henri-mark{font-size:1.375rem;line-height:1}.tab-label{font-family:var(--font-body);font-size:var(--text-caption);font-weight:500}#app[data-page="/login"]>.nav-top,#app[data-page="/login"]>.tab-bar{display:none}@media(min-width:1024px){.tab-bar .tab-item--add{display:none}}.page-chat{display:flex;flex-direction:column;flex:1;min-height:0}.chat-messages{flex:1;min-height:0;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md);overflow-y:auto}.chat-welcome-slot{flex:1;display:flex;flex-direction:column}.chat-welcome-slot:has(.chat-welcome-returning){justify-content:flex-start;padding-top:var(--space-lg)}.chat-welcome{text-align:center;padding:var(--space-md) var(--space-md) var(--space-lg)}.chat-welcome .sparkle-icon{font-size:2rem;color:var(--color-accent);margin-bottom:var(--space-md)}.chat-welcome .brand-mark{display:block;width:48px;height:auto;margin:0 auto var(--space-sm)}.chat-welcome .welcome-greeting{font-family:var(--font-display);font-size:clamp(36px,5vw,52px);font-weight:400;line-height:1.15;color:var(--color-text);margin:4px 0 var(--space-md);letter-spacing:.002em;text-wrap:balance}.chat-welcome .welcome-greeting em{font-style:italic;font-weight:400;color:var(--color-accent)}.chat-welcome .welcome-henri-intro{font-family:var(--font-display);font-size:17px;line-height:1.65;color:var(--color-warm-stone, var(--color-text-secondary));margin:0 auto;max-width:38rem;text-wrap:balance}.chat-welcome .welcome-stats.chat-collection-summary{margin-top:var(--space-md);font-family:var(--font-body);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--color-accent);opacity:.85}.chat-welcome-new{max-width:640px;margin:0 auto;padding:var(--space-xl) var(--space-md) var(--space-lg);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.chat-welcome-new .welcome-eyebrow{font-family:var(--font-body);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--color-warm-stone, var(--color-text-muted));margin-bottom:4px}.chat-welcome-new .welcome-hero{font-family:var(--font-display);font-size:44px;line-height:1.15;font-weight:400;color:var(--color-text);margin:0;text-wrap:balance;letter-spacing:.005em}.chat-welcome-new .welcome-hero em{font-style:italic;font-weight:400;color:var(--color-accent)}.chat-welcome-new .welcome-sub{font-family:var(--font-display);font-style:italic;font-size:15px;line-height:1.65;color:var(--color-text-secondary);margin:0;max-width:44ch;text-wrap:balance}.chat-welcome-new .welcome-sommelier{width:100%;max-width:460px;margin:var(--space-md) auto 0}.chat-welcome-new .welcome-sommelier-quote{font-family:var(--font-display);font-style:italic;font-size:16px;line-height:1.6;color:var(--color-text);margin:0 auto;padding:0 4px;max-width:36ch;text-wrap:balance}.chat-welcome-new .welcome-methods{width:100%;max-width:460px;margin:var(--space-md) auto 0;display:flex;flex-direction:column;gap:10px}.chat-suggestion.welcome-method{display:flex;align-items:center;gap:var(--space-md);padding:14px 18px;background:var(--color-surface);border:1px solid rgba(212,175,85,.35);border-radius:var(--radius-md);cursor:pointer;text-align:left;font-family:inherit;color:inherit;transition:border-color var(--transition-fast),background var(--transition-fast),transform var(--transition-fast);min-height:var(--touch-min)}.chat-suggestion.welcome-method:hover{border-color:var(--color-accent);transform:translateY(-1px)}.chat-suggestion.welcome-method.drag-over{border-color:var(--color-accent);border-style:dashed;background:#d4af5514;transform:translateY(-1px)}.welcome-method-icon{flex:0 0 auto;width:40px;height:40px;border-radius:50%;border:1px solid rgba(212,175,85,.5);display:flex;align-items:center;justify-content:center;color:var(--color-accent)}.welcome-method-body{flex:1 1 auto;display:flex;flex-direction:column;gap:2px;min-width:0}.welcome-method-title{font-family:var(--font-display);font-size:18px;font-style:italic;font-weight:400;color:var(--color-text);line-height:1.2}.welcome-method-sub{font-family:var(--font-body);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--color-warm-stone, var(--color-text-muted))}.welcome-method-arrow{flex:0 0 auto;font-family:var(--font-body);font-size:18px;color:var(--color-accent);opacity:.7;transition:opacity var(--transition-fast),transform var(--transition-fast)}.welcome-method:hover .welcome-method-arrow{opacity:1;transform:translate(2px)}@media(max-width:767px){.chat-welcome-new{padding-top:var(--space-lg)}.chat-welcome-new .welcome-hero{font-size:30px}.welcome-method-title{font-size:16px}}.chat-welcome p{font-size:var(--text-small);color:var(--color-text-secondary);line-height:1.5}.chat-collection-summary{margin-top:var(--space-xs, 6px);font-size:var(--text-caption);color:var(--color-text-muted);letter-spacing:.04em;min-height:1em}.chat-collection-summary[aria-busy=true]{background:var(--color-border);width:14ch;height:.85em;border-radius:4px;opacity:.5;margin-left:auto;margin-right:auto}.cellar-snapshot{display:flex;flex-wrap:nowrap;gap:var(--space-sm);overflow-x:auto;scroll-snap-type:x proximity;margin:0 var(--space-md) var(--space-md);padding:0;scrollbar-width:none;min-height:var(--touch-min)}.cellar-snapshot::-webkit-scrollbar{display:none}.cellar-pill{flex-shrink:0;display:inline-flex;align-items:baseline;gap:8px;padding:8px 14px;border-radius:2px;background:transparent;border:1px solid rgba(212,175,85,.32);cursor:pointer;font-family:var(--font-body);scroll-snap-align:start;min-height:var(--touch-min);transition:border-color var(--transition-fast),background var(--transition-fast)}.cellar-pill:hover{border-color:#d4af5599;background:#d4af550a}.cellar-pill .cellar-pill-name{font-size:10.5px;color:var(--color-text);font-weight:500;letter-spacing:.24em;text-transform:uppercase;max-width:16ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cellar-pill .cellar-pill-count{position:relative;font-size:11px;color:var(--color-warm-stone, var(--color-text-secondary));font-weight:400;letter-spacing:.06em;padding-left:10px}.cellar-pill .cellar-pill-count:before{content:"·";position:absolute;left:0;color:var(--color-accent);opacity:.55}@media(min-width:1200px){.chat-rail .cellar-pill{min-height:32px;padding:6px 12px}}.cellar-pill-skel{width:110px;height:36px;background:var(--color-border);opacity:.5;border:none;pointer-events:none}.drinking-window-card{margin:0 var(--space-md) var(--space-md);padding:28px 32px;background:linear-gradient(180deg,rgba(212,175,85,.025) 0%,transparent 100%);border:1px solid rgba(212,175,85,.28);border-radius:2px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}.drinking-window-card[aria-busy=true]{min-height:140px}.drinking-window-card .dwc-eyebrow{font-family:var(--font-body);font-size:11px;color:var(--color-warm-stone, var(--color-text-secondary));letter-spacing:.32em;text-transform:uppercase}.drinking-window-card .dwc-hero{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:6px}.drinking-window-card .dwc-hero-number{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:clamp(44px,6vw,56px);line-height:1;color:#c75b2a;letter-spacing:.002em}.drinking-window-card .dwc-hero-label{font-family:var(--font-body);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--color-warm-stone, var(--color-text-secondary))}.drinking-window-card .dwc-rule{width:48px;height:1px;background:#d4af5573;margin:12px 0 4px}.drinking-window-card .dwc-secondary{font-family:var(--font-body);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--color-warm-stone, var(--color-text-secondary));opacity:.85}.drinking-window-card .dwc-cta{margin-top:14px;font-family:var(--font-display);font-style:italic;font-size:15px;color:var(--color-accent);text-decoration:underline;text-decoration-color:#d4af5573;text-underline-offset:4px;cursor:pointer;background:none;border:none;padding:4px 8px;transition:text-decoration-color var(--transition-fast),color var(--transition-fast)}.drinking-window-card .dwc-cta:hover{text-decoration-color:var(--color-accent);color:var(--color-accent-bold, var(--color-accent))}.drinking-window-card .dwc-skel-eyebrow,.drinking-window-card .dwc-skel-headline{background:var(--color-border);opacity:.5;border-radius:4px}.drinking-window-card .dwc-skel-eyebrow{width:6ch;height:.85em}.drinking-window-card .dwc-skel-headline{width:80%;height:1.1em}.recent-threads{margin:var(--space-md);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:8px}.recent-threads .rt-eyebrow{font-size:var(--text-caption);color:var(--color-text-muted);font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-xs)}.recent-threads .rt-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0;background:transparent;border:none;border-bottom:1px solid rgba(212,175,85,.1);cursor:pointer;text-align:left;font-family:var(--font-body);width:100%;min-height:var(--touch-min);transition:opacity var(--transition-fast)}.recent-threads .rt-row:last-child{border-bottom:none}.recent-threads .rt-row:hover{opacity:.8}.recent-threads .rt-preview{flex:1;font-family:var(--font-display);font-style:italic;font-size:var(--text-body);font-weight:400;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-threads .rt-time{flex-shrink:0;font-size:var(--text-caption);color:var(--color-text-muted)}.recent-threads .rt-skel{background:var(--color-border);opacity:.5;border-radius:4px;pointer-events:none}.recent-threads .rt-eyebrow.rt-skel{width:8ch;height:.85em;border-bottom:none}.recent-threads .rt-row.rt-skel{height:1.4em;border-bottom:none}.henri-suggestions{margin:var(--space-md);padding:var(--space-md) var(--space-md) calc(var(--space-md) - 4px);background:var(--color-surface);border:1px solid rgba(212,175,85,.22);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:4px}.henri-suggestions .hs-eyebrow{font-family:var(--font-body);font-size:11px;color:var(--color-accent);letter-spacing:.3em;text-transform:uppercase;padding-bottom:10px;margin-bottom:4px;border-bottom:1px solid var(--color-border);opacity:.85}.henri-suggestions .hs-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;background:transparent;border:none;border-bottom:1px solid var(--color-border);cursor:pointer;text-align:left;width:100%;min-height:var(--touch-min);transition:opacity var(--transition-fast)}.henri-suggestions .hs-row:last-child{border-bottom:none}.henri-suggestions .hs-row:hover{opacity:.78}.henri-suggestions .hs-prompt{flex:1;font-family:var(--font-display);font-style:italic;font-size:15px;line-height:1.5;color:var(--color-text);text-wrap:balance}.henri-suggestions .hs-arrow{flex-shrink:0;font-size:16px;color:var(--color-accent);opacity:.7}.tonights-selection{margin:0 var(--space-md) var(--space-md)}.tonights-selection[aria-busy=true]{min-height:240px}.tonights-selection .ts-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm);margin-top:var(--space-md)}.tonights-selection .ts-cta{font-family:var(--font-body);font-size:var(--text-caption);font-weight:600;letter-spacing:.04em;padding:8px 16px;border-radius:var(--radius-full);cursor:pointer;min-height:var(--touch-min);transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.tonights-selection .ts-cta-primary{background:var(--color-accent);border:1px solid var(--color-accent);color:var(--color-bg)}.tonights-selection .ts-cta-primary:hover{background:var(--color-accent-bold);border-color:var(--color-accent-bold)}.tonights-selection .ts-cta-secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-accent)}.tonights-selection .ts-cta-secondary:hover{border-color:var(--color-accent)}.tonights-selection .ts-skel-eyebrow,.tonights-selection .ts-skel-name,.tonights-selection .ts-skel-note{background:var(--color-border);opacity:.5;border-radius:4px;margin:0 auto}.tonights-selection .ts-skel-eyebrow{width:12ch;height:.7em;margin-top:var(--space-sm)}.tonights-selection .ts-skel-name{width:60%;height:1.1em;margin-top:var(--space-md)}.tonights-selection .ts-skel-note{width:80%;height:2.4em;margin-top:var(--space-md);margin-bottom:var(--space-md)}.almanac-card{margin:0 var(--space-md) var(--space-md)}.almanac-card[aria-busy=true]{min-height:220px}.almanac-card .alm-moon{display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:var(--space-xs)}.almanac-card .alm-moon-caption{font-family:var(--font-body);font-size:9px;color:var(--color-text-muted);letter-spacing:.18em;text-transform:uppercase}.almanac-card .alm-pill{display:inline-flex;align-items:center;padding:4px 12px;border:1px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-body);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-secondary);margin:var(--space-sm) auto 0}.almanac-card .alm-aphorism{font-family:var(--font-display);font-style:italic;font-size:22px;line-height:1.25;color:var(--color-text);letter-spacing:-.005em;max-width:22ch;margin:var(--space-md) auto 0}.almanac-card .alm-aphorism-accent{color:var(--color-accent)}.almanac-card .alm-body{font-family:var(--font-display);font-size:13px;font-style:italic;color:var(--color-text-secondary);line-height:1.65;max-width:34ch;margin:var(--space-md) auto 0}.almanac-card .alm-skel-dateline,.almanac-card .alm-skel-moon,.almanac-card .alm-skel-line{background:var(--color-border);opacity:.5;border-radius:4px;margin:var(--space-sm) auto 0}.almanac-card .alm-skel-dateline{width:60%;height:.7em}.almanac-card .alm-skel-moon{width:48px;height:48px;border-radius:50%}.almanac-card .alm-skel-line{width:80%;height:1em}.chat-suggestions{display:flex;flex-direction:column;gap:var(--space-sm);padding:0 var(--space-md)}.chat-suggestion{padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-small);color:var(--color-text);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-body);min-height:var(--touch-min);transition:border-color var(--transition-fast),background var(--transition-fast)}.chat-suggestion .suggest-icon{color:var(--color-accent);font-size:1rem;flex-shrink:0}.chat-suggestion:hover{border-color:var(--color-accent);background:#d4af550d}.msg{max-width:85%;padding:var(--space-md);border-radius:var(--radius-md);font-family:var(--font-display);font-size:var(--text-small);line-height:1.5;word-break:break-word}.msg-user{align-self:flex-end;background:#d4af5526;color:var(--color-text);border-bottom-right-radius:4px}.msg-ai{align-self:flex-start;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-bottom-left-radius:4px}.msg-ai .ai-label{font-size:var(--text-caption);color:var(--color-accent);font-weight:500;margin-bottom:6px;display:flex;align-items:center;gap:4px}.msg-ai .msg-text{white-space:pre-wrap}.msg-ai .msg-text p{margin:0 0 .75em;white-space:normal}.msg-ai .msg-text p:last-child{margin-bottom:0}.msg-ai .msg-text strong{color:var(--color-text);font-weight:600}.msg-ai .msg-text em{font-style:italic}.msg-ai .msg-text ul{margin:0 0 .75em;padding-left:1.25em;list-style:disc;white-space:normal}.msg-ai .msg-text ul:last-child{margin-bottom:0}.msg-ai .msg-text li{margin-bottom:.25em}.msg-ai .msg-text li:last-child{margin-bottom:0}.wine-card{margin-top:var(--space-sm);padding:var(--space-md);background:var(--color-elevated);border-radius:var(--radius-sm);border:1px solid var(--color-border);animation:wine-card-in .2s ease-out both}@keyframes wine-card-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.wine-card{animation:none}}.wine-card .wc-name{font-weight:500;color:var(--color-text);margin-bottom:2px}.wine-card .wc-detail{font-size:var(--text-caption);color:var(--color-text-secondary)}.wine-card .wc-score{font-size:var(--text-caption);color:var(--color-accent);font-weight:600;margin-top:4px}.wine-card .wc-reason{font-size:var(--text-caption);color:var(--color-accent);margin-top:6px;font-style:italic}.msg-streaming .msg-text:after,.msg-streaming .msg-text>p:last-child:after,.msg-streaming .msg-text>ul:last-child>li:last-child:after{content:"";display:inline-block;width:2px;height:1em;background:var(--color-accent);margin-left:2px;animation:blink .8s step-end infinite;vertical-align:text-bottom}.msg-streaming .msg-text:has(p,ul):after{content:none}@keyframes blink{50%{opacity:0}}.chat-new{position:absolute;top:8px;right:12px;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);background:#d4af551a;color:var(--color-accent);font-family:var(--font-body);font-size:var(--text-caption);font-weight:500;border:1px solid rgba(212,175,85,.3);cursor:pointer;z-index:5;min-height:0}.chat-new[hidden]{display:none}.chat-new:hover{background:#d4af552e}.chat-new .icon{width:14px;height:14px}.chat-jump-latest{position:absolute;bottom:calc(var(--space-md) + 3.25rem + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-full);background:var(--color-accent);color:var(--color-bg);font-family:var(--font-body);font-size:var(--text-caption);font-weight:500;border:none;box-shadow:0 4px 16px #0006;cursor:pointer;z-index:6;min-height:var(--touch-min);white-space:nowrap}.chat-jump-latest[hidden]{display:none}.chat-jump-latest:hover{filter:brightness(1.05)}.chat-jump-latest .icon{width:16px;height:16px}.page-chat{position:relative}.chat-input-bar{position:sticky;bottom:0;z-index:5;padding:var(--space-sm) var(--space-md) var(--space-md);padding-bottom:max(var(--space-md),env(safe-area-inset-bottom));background:var(--color-elevated);border-top:1px solid var(--color-border);display:flex;gap:var(--space-sm);align-items:center}.chat-input-bar input{flex:1;padding:.75rem var(--space-md);border-radius:var(--radius-full);font-size:var(--text-small);font-family:var(--font-body);background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);outline:none;transition:border-color var(--transition-fast)}.chat-input-bar input::placeholder{color:var(--color-text-muted)}.chat-input-bar input:focus{border-color:var(--color-accent)}.chat-input-bar .btn-camera,.chat-input-bar .btn-send{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.125rem;padding:0}.chat-input-bar .btn-camera{background:#d4af551a;color:var(--color-accent)}.chat-input-bar .btn-send{background:var(--color-accent);color:var(--color-bg)}.chat-input-bar .btn-send:disabled{opacity:.5;cursor:not-allowed}.msg-warning,.msg-error{margin-top:var(--space-sm);padding:6px 10px;border-radius:var(--radius-sm);font-size:var(--text-caption);border:1px solid transparent}.msg-warning{background:#e8853a1f;color:var(--color-accent-bold);border-color:#e8853a59}.msg-error{background:#d45b5b1f;color:var(--color-error);border-color:#d45b5b66}.msg-retrigger{display:inline-flex;align-items:center;gap:4px;margin-top:var(--space-sm);padding:6px 14px;border-radius:var(--radius-sm);font-size:var(--text-small);background:var(--color-accent-bold);color:var(--color-noir, #0d0b09);border:none;cursor:pointer;min-height:var(--touch-min)}.msg-retrigger:hover{filter:brightness(1.05)}.chat-main{display:flex;flex-direction:column;flex:0 0 auto;min-width:0;min-height:0;position:relative}.chat-rail{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md) 0}.chat-rail[hidden]{display:none}@media(min-width:1200px){.page-chat{flex-direction:row;max-width:1440px;margin:0 auto;width:100%}.chat-main{flex:1 1 0;border-right:1px solid var(--color-border)}.chat-rail{flex:1 1 0;min-width:0;overflow-y:auto;background:var(--color-bg)}}@media(min-width:1024px){.chat-messages{padding:var(--space-xl) 56px;gap:var(--space-lg);max-width:760px;margin:0 auto;width:100%}.msg{max-width:86%;padding:20px 24px;font-size:17px;line-height:1.62;letter-spacing:.003em}.msg-ai .ai-label{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:15px;letter-spacing:.01em;margin-bottom:12px}.msg-user{background:#d4af551a;border:1px solid var(--plate-border)}}@media(min-width:1024px)and (prefers-color-scheme:light){.msg-user{background:#b8923e1a}}:root[data-theme=light] .msg-user{background:#b8923e1a}:root[data-theme=dark] .msg-user{background:#d4af551a}@media(min-width:1024px){.chat-messages[data-message-count="1"],.chat-messages[data-message-count="2"]{justify-content:center}.chat-input-bar .btn-camera{display:none}}.chat-drawer{display:flex;flex-direction:column;flex:1;min-height:0}.chat-drawer-handle,.chat-drawer-backdrop{display:none}@media(min-width:1200px){.page-chat{padding-bottom:144px}.chat-main{overflow-y:auto}.chat-drawer{position:absolute;left:0;right:0;bottom:0;flex:none;background:var(--color-surface);border-top:1px solid var(--plate-border);border-radius:var(--radius-md) var(--radius-md) 0 0;overflow:hidden;box-shadow:var(--drawer-shadow);z-index:30;transition:height .32s cubic-bezier(.2,.7,.2,1)}.chat-drawer.is-collapsed{height:144px}.chat-drawer.is-expanded{height:100%;background:var(--drawer-glass-bg);backdrop-filter:blur(10px) saturate(120%);-webkit-backdrop-filter:blur(10px) saturate(120%)}.chat-drawer.is-collapsed .chat-messages{display:none}.chat-drawer-handle{display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:8px var(--space-lg) 10px;flex:0 0 auto;cursor:pointer;background:var(--color-surface);border-bottom:1px solid var(--color-border);-webkit-user-select:none;user-select:none}.chat-drawer-grip{width:36px;height:3px;border-radius:2px;background:var(--color-warm-stone, var(--color-text-muted));opacity:.32;align-self:center;transition:opacity var(--transition-fast)}.chat-drawer-handle:hover .chat-drawer-grip{opacity:.55}.chat-drawer-handle-row{display:flex;align-items:center;justify-content:space-between;width:100%}.chat-drawer.is-collapsed .chat-drawer-handle{border-bottom-color:transparent}.chat-drawer-handle-label{font-family:var(--font-display);font-style:italic;color:var(--color-text-secondary);font-size:var(--text-small);display:flex;align-items:center;gap:12px}.chat-drawer-handle-label>.henri-mark{color:var(--color-accent);font-style:normal;font-weight:500;font-family:var(--font-body);font-size:11px;letter-spacing:.28em;text-transform:uppercase}.chat-drawer-handle-actions{display:flex;align-items:center;gap:8px}.page-chat>.chat-main>.chat-new{display:none}.chat-drawer-new-chat{font-family:var(--font-display);font-style:italic;font-size:var(--text-small);color:var(--color-accent);background:none;border:none;cursor:pointer;padding:4px 10px;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.chat-drawer-new-chat:hover{border-bottom-color:var(--plate-rule, var(--color-accent))}.chat-drawer-new-chat[hidden]{display:none}.chat-drawer .chat-messages{flex:1;min-height:0;padding:var(--space-lg) var(--space-xl)}.chat-drawer .chat-input-bar{position:static;margin-top:auto;border-top:1px solid var(--color-border)}.chat-drawer-backdrop{display:block;position:absolute;top:0;right:0;bottom:0;left:0;background:transparent;z-index:25;opacity:0;pointer-events:none;transition:opacity .32s ease}.chat-drawer-backdrop.is-visible{opacity:1;pointer-events:auto}}.page-login{display:flex;flex-direction:column;min-height:100dvh;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);position:relative;overflow:hidden;color-scheme:light dark;--login-glow-gold: #D4AF5518;--login-glow-copper: #C75B2A10;--login-glow-gold-desktop: #D4AF5510;--login-glow-copper-desktop: #C75B2A0c;--login-cta-shadow: 0 6px 20px #D4AF5566;--login-cta-shadow-desktop: 0 8px 24px #D4AF5555;--login-inbox-border: #D4AF5555;--login-inbox-icon-shadow: 0 0 24px #D4AF5555;--login-panel-mid: #0a0706;--login-toggle-bg: rgba(13, 11, 9, .7);--login-ambient-gold: #D4AF5514;--login-ambient-copper: #C75B2A0a;--login-almanac-rule: #D4AF5566}.page-login .btn-oauth:focus-visible,.page-login .editorial-tab:focus-visible,.page-login .inbox-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:var(--radius-pill)}.page-login .login-cta:focus-visible{outline:2px solid var(--color-text);outline-offset:3px}.login-glow{position:absolute;border-radius:50%;pointer-events:none;z-index:0}.login-glow--gold{width:420px;height:420px;top:-120px;left:-30%;background:radial-gradient(circle,var(--login-glow-gold),transparent 60%);filter:blur(45px)}.login-glow--copper{width:380px;height:380px;bottom:-120px;right:-30%;background:radial-gradient(circle,var(--login-glow-copper),transparent 60%);filter:blur(45px)}.login-left{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;padding:0 28px 28px}.login-logo{display:flex;flex-direction:column;align-items:center;padding-top:20px;position:relative;z-index:2}.login-logo-img{height:140px;display:block;clip-path:inset(0 0 6.5% 0);margin-bottom:-10px}.login-logo .login-logo-img--light{display:none}.login-logo-tagline{font-family:var(--font-body);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--color-warm-stone);margin-top:8px}.login-form-content{position:relative;z-index:2;flex:1;display:flex;flex-direction:column}.login-headline{text-align:center;margin-bottom:24px}.login-eyebrow{font-family:var(--font-body);font-size:10px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--color-accent);margin-bottom:10px}.login-headline h1{font-family:var(--font-display);font-size:28px;font-weight:400;color:var(--color-text);line-height:1.1;margin:0 0 10px;letter-spacing:-.02em;text-wrap:balance}.login-headline h1 em{font-style:italic;color:var(--color-accent)}.login-headline p{font-family:var(--font-body);font-size:13px;color:var(--color-warm-stone);line-height:1.5;max-width:280px;margin:0 auto}.login-error{padding:var(--space-md);background:#d45b5b1a;border:1px solid var(--color-error);border-radius:var(--radius-input);color:var(--color-error);font-size:13px;line-height:1.4;margin-bottom:20px;text-align:center}.login-oauth{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.btn-oauth{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border-radius:var(--radius-pill);cursor:pointer;font-family:var(--font-heading);font-size:14px;min-height:var(--touch-min);transition:opacity var(--transition-fast)}.btn-oauth:hover{opacity:.9}.btn-oauth--apple{background:var(--color-text);color:var(--color-bg);border:none;font-weight:600}.btn-oauth--google{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-oak);font-weight:500}.btn-oauth svg{flex-shrink:0}.oauth-label-short{display:none}.oauth-label-full{display:inline}.login-divider{display:flex;align-items:center;gap:12px;margin:6px 0 18px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-deep-toast)}.login-divider span{font-family:var(--font-body);font-size:10px;color:var(--color-dim-text);letter-spacing:.2em;text-transform:uppercase;white-space:nowrap}.divider-label-desktop{display:none}.divider-label-mobile{display:inline}.login-email-group{margin-bottom:22px}.login-email-label{display:none}.login-email-field{background:var(--color-surface);border:1px solid var(--color-oak);border-radius:var(--radius-input);padding:4px 4px 4px 16px;display:flex;align-items:center;gap:6px;transition:border-color var(--transition-fast)}.login-email-field:focus-within{border-color:var(--color-accent)}.login-email-field svg{flex-shrink:0}.login-email-field input{flex:1;background:transparent;border:none;outline:none;color:var(--color-text);font-family:var(--font-body);font-size:14px;padding:14px 0}.login-email-field input::placeholder{color:var(--color-text-muted)}.login-email-form{display:flex;flex-direction:column}.login-cta{background:var(--color-accent);color:var(--color-bg);border:none;padding:15px 20px;border-radius:var(--radius-pill);cursor:pointer;font-family:var(--font-heading);font-size:14px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;box-shadow:var(--login-cta-shadow);width:100%;min-height:var(--touch-min);display:flex;align-items:center;justify-content:center;gap:10px;transition:opacity var(--transition-fast)}.login-cta:hover{opacity:.92}.cta-arrow{display:none}.login-cta.is-pending,.inbox-link.is-pending{cursor:wait}.login-cta.is-pending:hover{opacity:1}.inbox-link.is-pending{display:inline-flex;align-items:center}.inbox-link-pending{display:inline-flex;align-items:center;gap:6px}.login-spinner{width:12px;height:12px;border-radius:50%;border:2px solid currentColor;border-right-color:transparent;border-bottom-color:transparent;animation:login-spin .7s linear infinite;display:inline-block;flex-shrink:0}@keyframes login-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.login-spinner{animation-duration:1.6s}}.login-inbox-card{background:var(--color-surface);border:1px solid var(--login-inbox-border);border-radius:var(--radius-card);padding:28px 24px;text-align:center}.inbox-content{display:block}.inbox-icon-circle{width:56px;height:56px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--color-accent),var(--color-aged-gold));display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:var(--login-inbox-icon-shadow);flex-shrink:0}.inbox-text{flex:1}.inbox-title{font-family:var(--font-display);font-size:22px;color:var(--color-text);font-style:italic;margin-bottom:8px}.inbox-body{font-family:var(--font-body);font-size:13px;color:var(--color-parchment);line-height:1.55;margin-bottom:4px}.inbox-email{font-family:var(--font-body);font-size:13px;color:var(--color-accent);font-weight:500;margin-bottom:22px;display:block}.inbox-expiry{font-family:var(--font-body);font-size:11px;color:var(--color-warm-stone);line-height:1.55}.inbox-divider{border-top:1px solid var(--color-deep-toast);margin-top:22px;padding-top:18px}.inbox-actions{display:flex;gap:16px;justify-content:center;position:relative}.inbox-sent-affordance{position:absolute;bottom:calc(100% + 6px);left:50%;display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-pill);background:#d4af551f;color:var(--color-accent);font-family:var(--font-body);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;pointer-events:none;transform:translate(-50%);animation:inbox-sent 3s ease forwards}.inbox-sent-affordance svg{flex-shrink:0}@keyframes inbox-sent{0%{opacity:0;transform:translate(-50%) translateY(2px)}12%{opacity:1;transform:translate(-50%) translateY(0)}88%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-2px)}}@media(prefers-reduced-motion:reduce){.inbox-sent-affordance{animation:none;opacity:1}}.inbox-link{font-family:var(--font-body);font-size:12px;cursor:pointer;background:none;border:none;padding:0}.inbox-link--secondary{color:var(--color-warm-stone)}.inbox-link--primary{color:var(--color-accent)}.inbox-link:disabled{opacity:.5;cursor:not-allowed}.inbox-link:hover:not(:disabled){text-decoration:underline}.login-right{display:none}@media(min-width:768px){.page-login{flex-direction:row}.login-glow--gold{width:700px;height:700px;top:-300px;left:-200px;background:radial-gradient(circle,var(--login-glow-gold-desktop),transparent 60%);filter:blur(60px)}.login-glow--copper{width:700px;height:700px;bottom:-300px;right:-200px;background:radial-gradient(circle,var(--login-glow-copper-desktop),transparent 60%);filter:blur(60px)}.login-left{max-width:640px;padding:48px 80px 32px}.login-logo{padding-top:0;margin-bottom:48px}.login-logo img{height:210px;margin-bottom:-14px}.login-logo-tagline{font-size:13px;letter-spacing:.36em;margin-top:12px}.login-form-content{max-width:420px;width:100%;margin:0 auto;text-align:center}.login-headline{margin-bottom:36px}.login-headline h1{font-size:44px;line-height:1.04;margin-bottom:14px}.login-headline p{font-size:14px;color:var(--color-parchment);line-height:1.55;max-width:none}.login-oauth{flex-direction:row}.btn-oauth{flex:1;padding:13px 18px;font-size:13px}.oauth-label-full{display:none}.oauth-label-short{display:inline}.login-divider{gap:14px;margin:20px 0 24px}.login-divider span{letter-spacing:.16em}.divider-label-mobile{display:none}.divider-label-desktop{display:inline}.login-email-group{margin-bottom:28px;text-align:left}.login-email-label{display:block;font-family:var(--font-body);font-size:10px;letter-spacing:.16em;color:var(--color-warm-stone);text-transform:uppercase;margin-bottom:8px}.login-email-field{border-radius:12px;gap:8px}.login-email-field input{padding:13px 0}.login-cta{width:auto;display:inline-flex;padding:15px 28px;font-size:13px;box-shadow:var(--login-cta-shadow-desktop);align-self:center}.cta-arrow{display:inline-flex}.login-inbox-card{border-radius:20px;padding:32px 28px;max-width:440px;text-align:left}.inbox-content{display:flex;gap:18px;align-items:flex-start}.inbox-icon-circle{width:52px;height:52px;margin:0}.inbox-title{font-size:24px;margin-bottom:6px}.inbox-body{font-size:13.5px;margin-bottom:0}.inbox-email{display:inline;margin-bottom:0}.inbox-expiry{font-size:12px;margin-top:14px}.inbox-divider{margin-top:24px;padding-top:16px}.inbox-actions{gap:22px;justify-content:flex-start}}@media(min-width:1200px){.login-right{display:flex;flex:1;position:relative;overflow:hidden;background:linear-gradient(160deg,var(--color-elevated) 0%,var(--login-panel-mid) 55%,var(--color-bg) 100%);flex-direction:column;border-left:1px solid var(--color-deep-toast)}}.editorial-panel{display:flex;flex-direction:column;height:100%}.editorial-ambient{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.editorial-ambient:before{content:"";position:absolute;top:8%;left:50%;transform:translate(-50%);width:600px;height:600px;background:radial-gradient(circle,var(--login-ambient-gold),transparent 55%);filter:blur(60px)}.editorial-ambient:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 80% 90%,var(--login-ambient-copper),transparent 50%)}.editorial-toggle{position:relative;z-index:3;display:flex;justify-content:center;padding-top:36px}.editorial-toggle-track{display:inline-flex;gap:4px;padding:4px;background:var(--login-toggle-bg);border:1px solid var(--color-deep-toast);border-radius:var(--radius-pill);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.editorial-tab{padding:8px 16px;border-radius:var(--radius-pill);cursor:pointer;background:transparent;color:var(--color-warm-stone);border:none;font-family:var(--font-body);font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;transition:all .2s ease}.editorial-tab.active{background:var(--color-accent);color:var(--color-bg)}.editorial-content{position:relative;z-index:2;flex:1;display:flex;align-items:center;justify-content:center;padding:20px 60px 40px}.editorial-footer{position:relative;z-index:2;padding:20px 40px 28px;border-top:1px solid var(--color-deep-toast);display:flex;align-items:center;justify-content:space-between;font-family:var(--font-body);font-size:10px;color:var(--color-dim-text);letter-spacing:.22em;text-transform:uppercase}.editorial-plate{width:100%;max-width:580px;margin:0 auto;padding:10px}.editorial-plate-frame{position:relative;padding:60px 52px;border:1px solid var(--plate-border);background:linear-gradient(180deg,var(--plate-frame-tint) 0%,transparent 50%,var(--plate-frame-tint) 100%);text-align:center}.editorial-plate-frame:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:1px solid var(--plate-inner-border);pointer-events:none}.editorial-plate-frame:after{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;pointer-events:none;background:radial-gradient(circle at top left,var(--color-accent) 0 1.8px,transparent 2.4px),radial-gradient(circle at top right,var(--color-accent) 0 1.8px,transparent 2.4px),radial-gradient(circle at bottom left,var(--color-accent) 0 1.8px,transparent 2.4px),radial-gradient(circle at bottom right,var(--color-accent) 0 1.8px,transparent 2.4px);background-size:10px 10px;background-position:0 0,100% 0,0 100%,100% 100%;background-repeat:no-repeat;opacity:.8}.editorial-plate-ornament{display:flex;justify-content:center;color:var(--color-accent)}.editorial-plate-eyebrow{font-family:var(--font-body);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--color-warm-stone);margin-top:22px}.editorial-plate-rule{width:72px;height:1px;background:var(--plate-rule);margin:24px auto}.editorial-plate-wine-name{font-family:var(--font-display);font-size:42px;font-style:italic;font-weight:400;color:var(--color-text);line-height:1.18;margin:0;padding:0 4px;letter-spacing:.005em;text-wrap:balance}.editorial-plate-meta{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:20px;font-family:var(--font-body);font-size:11.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--color-accent)}.editorial-plate-meta-sep{opacity:.45}.editorial-plate-quote{font-family:var(--font-display);font-style:italic;font-size:17px;line-height:1.65;color:var(--color-warm-stone);margin:26px auto 0;padding:0 6px;max-width:420px;text-wrap:balance}.editorial-plate--rail{min-width:320px;max-width:500px;margin-left:auto;margin-right:auto;padding:4px}.editorial-plate--rail .editorial-plate-frame{padding:32px 24px}.editorial-plate--rail .editorial-plate-eyebrow{font-size:10px;letter-spacing:.28em;margin-top:14px}.editorial-plate--rail .editorial-plate-rule{width:48px;margin:16px auto}.editorial-plate--rail .editorial-plate-wine-name{font-size:24px}.editorial-plate--rail .editorial-plate-meta{font-size:10px;letter-spacing:.24em;margin-top:12px;gap:10px}.editorial-plate--rail .editorial-plate-quote{font-size:13.5px;max-width:100%;margin-top:18px}.editorial-plate--rail .editorial-plate-frame>.editorial-plate-ornament:last-child{margin-top:24px}.almanac-diagram{display:flex;align-items:center;justify-content:center;gap:28px;margin-bottom:28px}.almanac-diagram-item{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--color-accent)}.almanac-diagram-caption{font-family:var(--font-body);font-size:9px;color:var(--color-dim-text);letter-spacing:.2em;text-transform:uppercase}.almanac-diagram-divider{width:1px;height:48px;background:var(--color-deep-toast)}.almanac-aphorism{font-family:var(--font-display);font-size:42px;font-style:italic;font-weight:400;color:var(--color-text);line-height:1.18;margin:0 0 28px;padding:0 4px;letter-spacing:.005em;text-wrap:balance}.almanac-aphorism-accent{color:var(--color-accent)}.almanac-rule{width:40px;height:1px;background:var(--login-almanac-rule);margin:0 auto 24px}.almanac-body{font-family:var(--font-display);font-style:italic;font-size:17px;line-height:1.65;color:var(--color-warm-stone);margin:0 auto;padding:0 6px;max-width:420px;text-wrap:balance}.almanac-body em{color:var(--color-text);font-style:italic}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .page-login{--login-glow-gold: #B8923E14;--login-glow-copper: #C75B2A0a;--login-glow-gold-desktop: #B8923E0c;--login-glow-copper-desktop: #C75B2A08;--login-cta-shadow: 0 6px 20px #B8923E55;--login-cta-shadow-desktop: 0 8px 24px #B8923E45;--login-inbox-border: #B8923E66;--login-inbox-icon-shadow: 0 0 24px #B8923E40;--login-panel-mid: #E8E2D8;--login-toggle-bg: rgba(255, 255, 255, .7);--login-ambient-gold: #B8923E18;--login-ambient-copper: #C75B2A12;--login-almanac-rule: #B8923E66;--color-warm-stone: #6B6560;--color-parchment: #3D362E;--color-deep-toast: #E8E2D8;--color-aged-gold: #7A5E25;--color-oak: #E8E2D8;--color-copper: #A04D24}:root:not([data-theme=dark]) .page-login .login-logo-img--dark{display:none}:root:not([data-theme=dark]) .page-login .login-logo-img--light{display:block}:root:not([data-theme=dark]) .page-login .login-eyebrow{color:var(--color-aged-gold)}}:root[data-theme=light] .page-login{--login-glow-gold: #B8923E14;--login-glow-copper: #C75B2A0a;--login-glow-gold-desktop: #B8923E0c;--login-glow-copper-desktop: #C75B2A08;--login-cta-shadow: 0 6px 20px #B8923E55;--login-cta-shadow-desktop: 0 8px 24px #B8923E45;--login-inbox-border: #B8923E66;--login-inbox-icon-shadow: 0 0 24px #B8923E40;--login-panel-mid: #E8E2D8;--login-toggle-bg: rgba(255, 255, 255, .7);--login-ambient-gold: #B8923E18;--login-ambient-copper: #C75B2A12;--login-almanac-rule: #B8923E66;--color-warm-stone: #6B6560;--color-parchment: #3D362E;--color-deep-toast: #E8E2D8;--color-aged-gold: #7A5E25;--color-oak: #E8E2D8;--color-copper: #A04D24}:root[data-theme=light] .page-login .login-logo-img--dark{display:none}:root[data-theme=light] .page-login .login-logo-img--light{display:block}:root[data-theme=light] .page-login .login-eyebrow{color:var(--color-aged-gold)}.page-cellar{display:flex;flex-direction:column;height:100%;min-height:0;gap:var(--space-md)}.cellar-header{display:flex;flex-direction:column;gap:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.cellar-title-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-md)}.cellar-title-row h1{font-size:var(--text-h1);color:var(--color-text)}.cellar-stats{display:flex;gap:var(--space-md);font-size:var(--text-small);color:var(--color-text-secondary)}.cellar-stats .stat-value{color:var(--color-accent);font-weight:700}.cellar-subtitle{font-size:var(--text-caption);color:var(--color-text-secondary)}.filter-bar{display:flex;flex-direction:column;gap:var(--space-sm)}.filter-row{display:flex;gap:var(--space-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;align-items:center}.filter-row[data-scroll-state=start]{-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 24px),transparent);mask-image:linear-gradient(to right,#000 calc(100% - 24px),transparent)}.filter-row[data-scroll-state=middle]{-webkit-mask-image:linear-gradient(to right,transparent,#000 24px,#000 calc(100% - 24px),transparent);mask-image:linear-gradient(to right,transparent,#000 24px,#000 calc(100% - 24px),transparent)}.filter-row[data-scroll-state=end]{-webkit-mask-image:linear-gradient(to right,transparent,#000 24px);mask-image:linear-gradient(to right,transparent,#000 24px)}.filter-row-tools{flex-wrap:wrap;gap:var(--space-md)}.filter-chip{padding:10px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-heading);font-size:var(--text-caption);color:var(--color-text-secondary);white-space:nowrap;cursor:pointer;min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center}.filter-chip.active{background:#d4af5526;border-color:var(--color-accent);color:var(--color-accent)}.filter-chip .filter-chip-name{font-weight:500}.filter-chip .filter-chip-count{margin-left:8px;font-size:11px;font-weight:600;color:var(--color-text-muted);letter-spacing:.04em}.filter-chip.active .filter-chip-count{color:var(--color-accent)}.sort-control{display:inline-flex;align-items:center;gap:var(--space-sm);font-family:var(--font-heading);font-size:var(--text-caption);color:var(--color-text-secondary)}.sort-select{padding:10px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-heading);font-size:var(--text-caption);min-height:44px;cursor:pointer}.more-filters{padding:10px 14px;background:transparent;border:1px dashed var(--color-border);border-radius:var(--radius-full);font-family:var(--font-heading);font-size:var(--text-caption);color:var(--color-text-secondary);min-height:44px;cursor:pointer}.more-filters.open{color:var(--color-accent);border-color:var(--color-accent)}.filter-advanced{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-sm) 0 0;border-top:1px solid var(--color-border)}.filter-text{display:flex;flex-direction:column;gap:4px;font-family:var(--font-heading);font-size:var(--text-caption);color:var(--color-text-secondary)}.filter-text input{padding:10px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-body);min-height:44px}.cellar-list-host{flex:1;min-height:0}.virtual-list{position:relative;overflow-y:auto;height:100%;width:100%}.virtual-list-spacer{position:relative;width:100%}.virtual-list-inner{position:absolute;top:0;right:0;bottom:0;left:0}.cellar-card{height:120px;padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);display:flex;flex-direction:column;justify-content:space-between;gap:var(--space-sm);margin-bottom:8px}.cc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-sm);min-width:0}.cc-info{min-width:0;flex:1}.cc-name{font-size:var(--text-body);font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cc-producer{font-size:var(--text-caption);color:var(--color-text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cc-meta{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.cc-vintage{font-family:var(--font-display);font-size:var(--text-small);font-weight:700;color:var(--color-accent)}.cc-qty{font-size:var(--text-caption);color:var(--color-text-secondary);background:var(--color-elevated);padding:2px 8px;border-radius:var(--radius-full)}.cc-bottom{display:flex;justify-content:space-between;align-items:center;gap:var(--space-sm)}.cc-tags{display:flex;gap:6px;flex-wrap:wrap}.cc-actions{display:flex;gap:6px;flex-shrink:0}.btn-action{padding:6px 12px;background:var(--color-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-heading);font-size:var(--text-caption);font-weight:500;cursor:pointer;min-height:44px;min-width:44px}.btn-action:hover{background:var(--color-border);color:var(--color-text)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-caption);font-weight:500;border:1px solid transparent}.badge-now{background:#5a9e6f2e;color:var(--color-success);border-color:#5a9e6f66}.badge-soon{background:#e8853a2e;color:var(--color-accent-bold);border-color:#e8853a66}.badge-past{background:#d45b5b2e;color:var(--color-error);border-color:#d45b5b66}.badge-aging{background:#b8923e26;color:var(--color-aged-gold);border-color:#b8923e66}.badge-score{background:#d4af5526;color:var(--color-accent);border-color:#d4af5566;font-weight:600}.badge-flag{background:#f5f0e80f;color:var(--color-text-muted);border-color:#f5f0e82e}.cellar-error{padding:var(--space-lg);text-align:center;color:var(--color-error)}.btn{border:1px solid transparent;border-radius:var(--radius-input);padding:0 var(--space-md);font-family:var(--font-body);font-size:var(--text-body);font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:var(--color-bg)}.btn-primary:hover:not(:disabled){background:var(--color-aged-gold)}.btn-secondary{background:transparent;color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-elevated)}.page-bottle-detail{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--color-bg)}.bd-loading,.bd-error{padding:var(--space-lg);color:var(--color-text-secondary);text-align:center}.bd-error{color:var(--color-error)}.bd-nav{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);background:var(--color-elevated)}.bd-nav .bd-back{width:var(--touch-min);height:var(--touch-min);border:none;background:transparent;color:var(--color-text);font-size:1.5rem;cursor:pointer;border-radius:var(--radius-sm)}.bd-nav .bd-back:focus-visible,.bd-nav .bd-text-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.bd-nav .bd-title{flex:1;font-size:var(--text-body);font-weight:500;color:var(--color-text)}.bd-nav-actions{display:flex;gap:var(--space-sm)}.bd-nav .bd-text-btn{min-height:var(--touch-min);padding:0 var(--space-md);background:transparent;border:none;color:var(--color-text-secondary);font-size:var(--text-small);font-family:var(--font-body);cursor:pointer;border-radius:var(--radius-sm)}.bd-nav .bd-text-btn.bd-save{color:var(--color-accent);font-weight:600}.bd-nav .bd-text-btn:disabled{opacity:.5;cursor:not-allowed}.bd-content{flex:1;overflow-y:auto;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.bottle-hero{text-align:center;padding:var(--space-lg) var(--space-md);background:linear-gradient(180deg,var(--color-elevated) 0%,var(--color-surface) 100%);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.bottle-hero .bottle-vintage{font-family:var(--font-display);font-size:var(--text-display);color:var(--color-accent);line-height:1}.bottle-hero .bottle-name{font-family:var(--font-heading);font-size:var(--text-h2);font-weight:700;color:var(--color-text);margin-top:var(--space-sm)}.bottle-hero .bottle-producer{font-size:var(--text-small);color:var(--color-text-secondary);margin-top:4px}.bottle-hero .bottle-badges{margin-top:var(--space-md);display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.detail-cell{padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.detail-cell .label{font-family:var(--font-body);font-size:var(--text-caption);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.detail-cell .value{font-size:var(--text-small);color:var(--color-text);font-weight:500}.detail-cell .value.gold{color:var(--color-accent)}.bd-block{padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-sm)}.bd-block .label{font-size:var(--text-caption);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.bd-block .value{font-size:var(--text-body);color:var(--color-text)}.bd-stepper{display:flex;align-items:center;gap:var(--space-md)}.bd-stepper .btn-action{width:var(--touch-min);height:var(--touch-min);border-radius:var(--radius-full);background:var(--color-elevated);border:1px solid var(--color-border);color:var(--color-text);font-size:1.25rem;cursor:pointer}.bd-stepper .btn-action:disabled{opacity:.4;cursor:not-allowed}.bd-qty-value{font-family:var(--font-display);font-size:var(--text-h2);color:var(--color-accent);font-weight:700;min-width:2rem;text-align:center}.bd-location-editor{display:flex;flex-direction:column;gap:var(--space-sm)}.bd-select{min-height:var(--touch-min);padding:0 var(--space-md);background:var(--color-elevated);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-input);font-family:var(--font-body);font-size:var(--text-body)}.bd-select:focus{outline:none;border-color:var(--color-accent)}.bd-notes{width:100%;min-height:5rem;padding:var(--space-sm) var(--space-md);background:var(--color-elevated);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-input);font-family:var(--font-body);font-size:var(--text-body);resize:vertical}.bd-notes:focus{outline:none;border-color:var(--color-accent)}.bd-notes-text{white-space:pre-wrap;color:var(--color-text-secondary)}.bd-hint{color:var(--color-text-muted);font-size:var(--text-small);font-style:italic}.bd-purchase{padding:var(--space-md);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.bd-purchase .label{font-size:var(--text-caption);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-sm)}.bd-purchase-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.bd-purchase-grid>div{display:flex;flex-direction:column}.bd-pk{font-size:var(--text-caption);color:var(--color-text-muted)}.bd-pv{font-size:var(--text-small);color:var(--color-text);font-weight:500}.bd-actions{display:flex;gap:var(--space-sm);padding-top:var(--space-sm)}.bd-actions .btn{flex:1;min-height:var(--touch-min)}.tool-cards{margin-top:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-sm)}.tool-confirm-card{padding:var(--space-lg);background:var(--color-elevated);border:1px solid var(--color-accent);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-md)}.tool-confirm-card .tcc-header{font-family:var(--font-display);font-style:italic;font-size:var(--text-body);font-weight:400;color:var(--color-accent);line-height:1.3}.tool-confirm-card .tcc-title{font-family:var(--font-display);font-style:italic;font-size:var(--text-h2);font-weight:400;color:var(--color-text);line-height:1.2}.tool-confirm-card .tcc-summary{display:flex;flex-direction:column;gap:10px}.tool-confirm-card .tcc-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-md)}.tool-confirm-card .tcc-row>span:first-child{font-family:var(--font-body);font-size:10px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--color-warm-stone, var(--color-text-muted))}.tool-confirm-card .tcc-row>span:last-child{font-family:var(--font-display);font-style:italic;font-size:var(--text-small);color:var(--color-text);text-align:right}.tool-confirm-card .tcc-footer{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-sm);margin-top:var(--space-md)}.tool-confirm-card .tcc-btn{flex:1;min-width:5.5rem;min-height:var(--touch-min);white-space:nowrap}.tool-confirm-card .tcc-status{font-family:var(--font-display);font-style:italic;font-size:var(--text-small);color:var(--color-text-secondary)}.tool-confirm-card .tcc-status-expired{font-family:var(--font-body);color:var(--color-status-warning, var(--color-text-secondary));font-style:normal;font-weight:500;letter-spacing:.04em}.tool-confirm-card .tcc-status-error{font-family:var(--font-body);color:var(--color-error, #d45b5b);font-style:normal;font-weight:500;letter-spacing:.04em;flex-basis:100%;margin-bottom:var(--space-xs)}.tool-confirm-card .tcc-countdown{font-family:var(--font-body);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);font-variant-numeric:tabular-nums;align-self:center;margin-right:auto}.tool-confirm-card .tcc-choices{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-xs)}.tool-confirm-card .tcc-choice{display:flex;flex-direction:column;align-items:stretch;justify-content:center;text-align:left;gap:4px;padding:var(--space-sm) var(--space-md);min-height:var(--touch-min);flex:0 0 auto}.tool-confirm-card .tcc-choice-label{font-family:var(--font-display);font-style:italic;font-size:var(--text-body);font-weight:400;line-height:1.15}.tool-confirm-card .tcc-choice-hint{font-family:var(--font-body);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;opacity:.78}.bottle-hero .badge.badge-score{background:#d4af5526;color:var(--color-accent);border-color:#d4af5566}.scan-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d0b09c7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:var(--space-lg);z-index:1200}.scan-modal{background:var(--color-elevated);border:1px solid rgba(212,175,85,.45);border-radius:var(--radius-lg);width:min(560px,100%);max-height:min(80vh,720px);display:flex;flex-direction:column;box-shadow:0 24px 64px #00000080;overflow:hidden}.scan-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid rgba(212,175,85,.18)}.scan-modal-title{margin:0;font-family:var(--font-display);font-style:italic;font-weight:400;font-size:var(--text-h2);color:var(--color-accent);line-height:1.2}.scan-modal-close{background:transparent;border:none;color:var(--color-text-secondary);font-size:1.75rem;line-height:1;cursor:pointer;width:var(--touch-min);height:var(--touch-min);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.scan-modal-close:hover{color:var(--color-text);background:#d4af5514}.scan-modal-body{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.scan-modal-footer{padding:var(--space-sm) var(--space-lg);border-top:1px solid rgba(212,175,85,.18)}.scan-modal-hint{font-family:var(--font-body);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted)}.scan-modal-drop{border:2px dashed rgba(212,175,85,.45);border-radius:var(--radius-md);padding:var(--space-xl) var(--space-lg);text-align:center;cursor:pointer;background:transparent;transition:background var(--transition-fast),border-color var(--transition-fast);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);min-height:180px;justify-content:center}.scan-modal-drop:hover,.scan-modal-drop:focus-visible,.scan-modal-drop.is-dragging{border-color:var(--color-accent);background:#d4af5514;outline:none}.scan-modal-drop-icon{font-size:2.25rem;color:var(--color-accent)}.scan-modal-drop-prompt{font-family:var(--font-display);font-style:italic;font-size:var(--text-body);color:var(--color-text);line-height:1.4}.scan-modal-drop-sub{font-family:var(--font-body);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);font-style:normal}.scan-modal-status{font-family:var(--font-display);font-style:italic;color:var(--color-text-secondary);text-align:center;padding:var(--space-lg)}.scan-modal-error{display:flex;flex-direction:column;gap:var(--space-md);align-items:stretch}.scan-modal-error-message{font-family:var(--font-body);color:var(--color-error, #d45b5b);margin:0}.scan-modal-empty{display:flex;flex-direction:column;gap:var(--space-sm);font-family:var(--font-body);color:var(--color-text-secondary)}.scan-modal-scanned{font-family:var(--font-display);font-style:italic;color:var(--color-text)}.scan-modal-empty-hint{font-size:var(--text-small);color:var(--color-text-muted);margin:0}.scan-modal-candidates{display:flex;flex-direction:column;gap:var(--space-sm)}.scan-modal-candidate{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:transparent;border:1px solid rgba(212,175,85,.2);border-radius:var(--radius-md);cursor:pointer;text-align:left;gap:var(--space-md);min-height:var(--touch-min);color:var(--color-text);transition:border-color var(--transition-fast),background var(--transition-fast)}.scan-modal-candidate:hover,.scan-modal-candidate:focus-visible{border-color:var(--color-accent);background:#d4af550f;outline:none}.scan-modal-candidate-main{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.scan-modal-candidate-title{font-family:var(--font-display);font-style:italic;font-size:var(--text-body);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scan-modal-candidate-producer,.scan-modal-candidate-region{font-family:var(--font-body);font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--color-text-muted)}.scan-modal-candidate-confidence{font-family:var(--font-body);font-size:var(--text-small);font-weight:600;font-variant-numeric:tabular-nums;color:var(--color-accent);white-space:nowrap}.page-drink-rate{display:flex;flex-direction:column;min-height:100%;background:var(--color-bg)}.dr-loading,.dr-error{padding:var(--space-lg);color:var(--color-text-secondary);text-align:center}.dr-error{color:var(--color-error)}.dr-nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);background:var(--color-bg);position:sticky;top:0;z-index:1}.dr-back{width:44px;height:44px;background:transparent;border:0;color:var(--color-text);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center}.dr-title{font-family:var(--font-heading);font-size:var(--text-body);font-weight:500;color:var(--color-text)}.dr-skip{min-height:44px;padding:0 var(--space-md);background:transparent;border:0;color:var(--color-accent);font-family:var(--font-body);font-size:var(--text-body);font-weight:500;cursor:pointer}.dr-skip:disabled{opacity:.5;cursor:not-allowed}.dr-content{display:flex;flex-direction:column;gap:var(--space-xl);padding:var(--space-lg) var(--space-md) var(--space-2xl);max-width:480px;width:100%;margin:0 auto;align-items:stretch}.dr-wine-info{text-align:center}.dr-vintage{font-family:var(--font-display);font-size:36px;color:var(--color-accent);line-height:1.1}.dr-name{font-size:var(--text-h2);font-weight:700;color:var(--color-text);margin-top:var(--space-sm)}.dr-producer{font-size:var(--text-small);color:var(--color-warm-stone);margin-top:4px}.dr-rating{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.dr-caption{font-size:var(--text-caption);color:var(--color-dim-text);text-align:center;text-transform:uppercase;letter-spacing:1px}.dr-stars{display:flex;gap:var(--space-md)}.dr-star{width:48px;height:48px;font-size:36px;background:transparent;border:0;cursor:pointer;color:var(--color-deep-toast);transition:color var(--transition-fast),transform var(--transition-fast);display:flex;align-items:center;justify-content:center;padding:0}.dr-star.filled{color:var(--color-accent)}.dr-star:hover{transform:scale(1.1)}.dr-star:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.dr-notes textarea{width:100%;min-height:80px;padding:var(--space-md);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-small);resize:vertical;outline:none}.dr-notes textarea:focus{border-color:var(--color-accent)}.dr-notes textarea::placeholder{color:var(--color-dim-text)}.dr-tag-group{display:flex;flex-direction:column;gap:var(--space-sm)}.dr-tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center}.dr-tag{min-height:44px;padding:6px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-family:var(--font-body);font-size:var(--text-caption);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.dr-tag.selected{background:#d4af5526;border-color:var(--color-accent);color:var(--color-accent)}.dr-tag:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.dr-custom{width:100%;min-height:44px;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-small);outline:none}.dr-custom:focus{border-color:var(--color-accent)}.dr-date{display:flex;flex-direction:column;gap:var(--space-sm)}.dr-date-input{width:100%;min-height:44px;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-body);outline:none;color-scheme:dark}.dr-date-input:focus{border-color:var(--color-accent)}.dr-submit{width:100%;min-height:48px;margin-top:var(--space-sm)}.undo-toast-host{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 80px);transform:translate(-50%);z-index:50;pointer-events:none;width:min(calc(100% - var(--space-md) * 2),480px)}.undo-toast-host.is-visible{pointer-events:auto}.undo-toast{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-elevated);border:1px solid var(--color-border);border-radius:var(--radius-pill);box-shadow:0 8px 24px #0000004d;color:var(--color-text);font-family:var(--font-body);font-size:var(--text-small)}.undo-toast-msg{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.undo-toast-countdown{font-variant-numeric:tabular-nums;color:var(--color-text-secondary);font-size:var(--text-caption)}.undo-toast-btn{min-height:44px;padding:0 var(--space-md);background:transparent;border:1px solid var(--color-accent);border-radius:var(--radius-pill);color:var(--color-accent);font-family:var(--font-body);font-size:var(--text-small);font-weight:600;cursor:pointer}.undo-toast-btn:disabled{opacity:.5;cursor:not-allowed}.undo-toast-close{width:32px;height:32px;background:transparent;border:0;color:var(--color-text-muted);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.page-add{display:flex;flex-direction:column;min-height:100dvh;background:var(--color-bg);color:var(--color-text);padding-bottom:calc(var(--touch-min) + var(--space-md) * 2)}.aw-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border);background:var(--color-bg);position:sticky;top:0;z-index:5}.aw-back{font-size:1.5rem;color:var(--color-accent);background:transparent;border:none;padding:0;width:var(--touch-min);height:var(--touch-min);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.aw-back:hover{background:var(--color-elevated)}.aw-header-title{font-family:var(--font-body);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-secondary)}.aw-title{font-size:var(--text-h2);font-family:var(--font-heading);font-weight:600;margin:0}.aw-content{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md);max-width:720px;width:100%;margin:0 auto}.aw-lede{color:var(--color-text-secondary);font-size:var(--text-small)}.aw-picker{gap:0}.aw-eyebrow{font-family:var(--font-body);font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--color-warm-stone, var(--color-text-muted));text-align:center;margin-top:var(--space-md)}.aw-rule{display:block;width:28px;height:1px;background:var(--plate-rule);margin:12px auto 14px}.aw-title-display{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:34px;line-height:1.12;letter-spacing:-.005em;color:var(--color-text);text-align:center;margin:0}.aw-lede-display{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:15px;line-height:1.5;color:var(--color-text-secondary);text-align:center;max-width:280px;margin:12px auto 24px}.aw-methods{display:flex;flex-direction:column;gap:12px;list-style:none;padding:0;margin:0}.aw-method{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;background:linear-gradient(180deg,var(--plate-frame-tint) 0%,transparent 100%),var(--color-surface);border:1px solid rgba(212,175,85,.35);border-radius:14px;text-align:left;cursor:pointer;color:var(--color-text);font-family:var(--font-body);transition:border-color var(--transition-fast),transform var(--transition-fast)}.aw-method:hover{border-color:var(--plate-border);transform:translateY(-1px)}.aw-method:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.aw-method-icon{flex:0 0 auto;width:40px;height:40px;border-radius:50%;border:1px solid var(--plate-rule);background:var(--plate-frame-tint);display:flex;align-items:center;justify-content:center;color:var(--color-accent)}.aw-method-icon-glyph{display:block}.aw-method-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.aw-method-title{font-family:var(--font-body);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text)}.aw-method-sub{font-family:var(--font-display);font-style:italic;font-size:14px;line-height:1.4;color:var(--color-text-secondary)}.aw-method-arrow{flex:0 0 auto;width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--color-warm-stone, var(--color-text-muted))}.aw-method-arrow-icon{display:block}.aw-search-label{font-size:var(--text-small);color:var(--color-text-secondary)}.aw-search-input{font-family:var(--font-body);font-size:var(--text-body);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-input);background:var(--color-surface);color:var(--color-text);min-height:var(--touch-min);width:100%}.aw-search-input:focus{outline:2px solid var(--color-accent);outline-offset:1px;border-color:var(--color-accent)}.aw-status{font-size:var(--text-small);color:var(--color-text-secondary);min-height:1.25rem}.aw-results{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-sm)}.aw-result{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;min-height:var(--touch-min)}.aw-result:hover,.aw-result:focus{border-color:var(--color-accent);background:var(--color-elevated);outline:none}.aw-result-title{font-weight:600;color:var(--color-text)}.aw-result-sub{font-size:var(--text-small);color:var(--color-text-secondary);margin-top:2px}.aw-badge{font-size:var(--text-caption);padding:2px var(--space-sm);border-radius:var(--radius-pill);border:1px solid var(--color-border);color:var(--color-text-secondary);white-space:nowrap}.aw-badge-gold{border-color:var(--color-accent);color:var(--color-accent)}.aw-confirm-hero{background:var(--color-elevated);border:1px solid var(--color-border);border-radius:var(--radius-card);padding:var(--space-lg);text-align:center;display:flex;flex-direction:column;gap:var(--space-sm)}.aw-hero-title{font-family:var(--font-display);font-size:var(--text-h1);color:var(--color-text)}.aw-hero-sub{color:var(--color-text-secondary);font-size:var(--text-small)}.aw-hero-meta{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap;margin-top:var(--space-sm)}.aw-confirm-form{display:flex;flex-direction:column;gap:var(--space-md)}.aw-field{display:flex;flex-direction:column;gap:var(--space-xs)}.aw-label{font-size:var(--text-small);color:var(--color-text-secondary)}.aw-input{font-family:var(--font-body);font-size:var(--text-body);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-input);color:var(--color-text);min-height:var(--touch-min);width:100%}.aw-input-error{color:var(--color-error);border-color:var(--color-error);background:var(--color-surface);display:flex;align-items:center;padding:var(--space-md)}.aw-stepper{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-input);min-height:var(--touch-min)}.aw-step{width:var(--touch-min);height:var(--touch-min);border-radius:var(--radius-md);background:var(--color-elevated);border:1px solid var(--color-border);color:var(--color-accent);font-size:1.25rem;font-weight:600}.aw-qty{flex:1;text-align:center;font-family:var(--font-display);font-size:var(--text-h2);font-weight:700;color:var(--color-accent)}.aw-error{background:#d45b5b1a;border:1px solid var(--color-error);color:var(--color-error);padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--text-small)}.aw-actions{display:flex;gap:var(--space-md);margin-top:var(--space-sm)}.aw-actions .btn{flex:1;min-height:var(--touch-min)}.aw-scan{display:flex;flex-direction:column;gap:var(--space-md)}.aw-viewfinder{position:relative;aspect-ratio:3 / 4;max-width:360px;margin:0 auto;width:100%;background:linear-gradient(180deg,#1a1512,#0a0806);border-radius:var(--radius-card);overflow:hidden}.aw-corner{position:absolute;width:28px;height:28px;border-color:var(--color-accent);border-style:solid}.aw-corner-tl{top:16px;left:16px;border-width:2px 0 0 2px}.aw-corner-tr{top:16px;right:16px;border-width:2px 2px 0 0}.aw-corner-bl{bottom:16px;left:16px;border-width:0 0 2px 2px}.aw-corner-br{bottom:16px;right:16px;border-width:0 2px 2px 0}.aw-scanline{position:absolute;left:16px;right:16px;top:16px;height:2px;background:linear-gradient(to right,transparent,var(--color-accent),transparent);box-shadow:0 0 12px var(--color-accent);animation:aw-scan 2.2s ease-in-out infinite}@keyframes aw-scan{0%{top:16px;opacity:.4}50%{top:calc(100% - 18px);opacity:1}to{top:16px;opacity:.4}}.aw-vf-prompt{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--space-sm);color:var(--color-text-secondary);text-align:center;padding:var(--space-md)}.aw-vf-icon{font-size:2.5rem}.aw-vf-icon-svg{display:inline-flex;align-items:center;justify-content:center;color:var(--color-accent);margin-bottom:var(--space-xs)}.aw-vf-icon-svg .icon{width:48px;height:48px;stroke-width:1.5}.aw-vf-still{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(.78) saturate(.95)}.aw-vf-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;background:#000}.aw-viewfinder .aw-corner,.aw-viewfinder .aw-scanline,.aw-viewfinder .aw-vf-prompt{z-index:1}.aw-shutter{position:absolute;bottom:16px;left:50%;transform:translate(-50%);width:64px;height:64px;border-radius:50%;background:var(--color-accent);border:3px solid var(--color-accent);padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:0 4px 14px #00000073;transition:transform .06s ease}.aw-shutter:active{transform:translate(-50%) scale(.92)}.aw-shutter-inner{display:block;width:52px;height:52px;border-radius:50%;background:var(--color-bg);border:2px solid var(--color-accent)}.aw-scan-hint{text-align:center;color:var(--color-text-secondary);font-style:italic;font-size:var(--text-small);margin:var(--space-sm) 0}.aw-scan-thumbnail{margin:0 0 var(--space-md);display:flex;flex-direction:column;gap:6px;align-items:stretch}.aw-scan-thumbnail img{width:100%;max-height:96px;height:auto;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border)}.aw-scan-thumbnail figcaption{text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:var(--color-text-secondary);text-align:center}.aw-vf-status{font-style:italic;color:var(--color-text)}.aw-vf-hint{font-size:var(--text-small);color:var(--color-text-secondary);max-width:24ch;margin:0 auto}.aw-scan-actions{display:flex;gap:var(--space-md);margin-top:var(--space-sm)}.aw-scan-actions .btn,.aw-scan-actions .btn-primary,.aw-scan-actions .btn-secondary{flex:1;min-height:var(--touch-min);display:inline-flex;align-items:center;justify-content:center}.aw-scan-status{text-align:center;color:var(--color-text-secondary);font-style:italic;padding:var(--space-md) 0}.aw-scan-error{background:#d45b5b1a;border:1px solid var(--color-error);color:var(--color-error);padding:var(--space-md);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-md)}.aw-scan-err-h{font-weight:600;font-size:var(--text-body)}.aw-scan-results{display:flex;flex-direction:column;gap:var(--space-md)}.aw-scan-hero{display:flex;flex-direction:column;gap:4px;background:var(--color-surface);border:1px solid var(--color-accent);border-radius:var(--radius-card);padding:var(--space-md);text-align:left;width:100%;cursor:pointer;min-height:var(--touch-min)}.aw-scan-hero:hover,.aw-scan-hero:focus{background:var(--color-elevated);outline:none}.aw-scan-hero-eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:var(--color-accent)}.aw-scan-hero-title{font-family:var(--font-display);font-size:var(--text-h2);color:var(--color-text)}.aw-scan-hero-sub{color:var(--color-text-secondary);font-size:var(--text-small)}.aw-scan-rest-h{font-size:var(--text-small);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin:var(--space-md) 0 var(--space-sm)}.aw-scan-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-sm)}.aw-scan-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;min-height:var(--touch-min)}.aw-scan-row:hover,.aw-scan-row:focus{border-color:var(--color-accent);background:var(--color-elevated);outline:none}.aw-scan-row-main{display:flex;flex-direction:column;gap:2px;flex:1}.aw-scan-row-title{color:var(--color-text);font-size:var(--text-body)}.aw-scan-row-sub{color:var(--color-text-secondary);font-size:var(--text-small)}.aw-scan-row-conf{font-family:var(--font-mono, monospace);font-size:var(--text-small);color:var(--color-accent);font-variant-numeric:tabular-nums}.aw-scan-empty{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.aw-scan-empty-h{font-family:var(--font-heading);font-size:var(--text-h2);color:var(--color-text)}.aw-scan-empty-p{color:var(--color-text-secondary);font-size:var(--text-small)}.aw-scan-extracted{display:grid;grid-template-columns:max-content 1fr;gap:4px var(--space-md);margin:0}.aw-scan-extracted-row{display:contents}.aw-scan-extracted dt{color:var(--color-text-secondary);font-size:var(--text-small);text-transform:uppercase;letter-spacing:.06em}.aw-scan-extracted dd{color:var(--color-text);margin:0}.page-settings{min-height:100%;background:var(--color-bg);color:var(--color-text);padding-bottom:6rem}.set-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border)}.set-back{width:var(--touch-min);height:var(--touch-min);background:transparent;border:none;color:var(--color-text);font-size:1.5rem;cursor:pointer;border-radius:var(--radius-md)}.set-back:hover{background:var(--color-elevated)}.set-title{font-family:var(--font-heading);font-size:var(--text-h2);margin:0;color:var(--color-text)}.set-content{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-lg)}.set-group{display:flex;flex-direction:column}.set-group-label{font-family:var(--font-heading);font-size:var(--text-caption);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;padding:var(--space-sm) 0 var(--space-sm) var(--space-sm)}.set-group-error{margin:var(--space-xs) var(--space-sm) var(--space-sm);padding:var(--space-sm) var(--space-md);background:#d45b5b1f;border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--text-small)}.set-item{min-height:var(--touch-min);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);display:grid;grid-template-columns:1fr auto;grid-template-areas:"label meta" "actions actions";align-items:center;column-gap:var(--space-md);row-gap:var(--space-sm)}.set-item:first-of-type{border-radius:var(--radius-md) var(--radius-md) 0 0}.set-item:last-of-type{border-radius:0 0 var(--radius-md) var(--radius-md)}.set-item:only-of-type{border-radius:var(--radius-md)}.set-item+.set-item{border-top:none}.set-item-label{grid-area:label;font-size:var(--text-small);color:var(--color-text);min-width:0}.set-item-toggle{grid-area:label;background:transparent;border:none;padding:0;display:flex;align-items:center;gap:var(--space-sm);text-align:left;cursor:pointer;color:inherit;font:inherit;min-height:var(--touch-min);min-width:0}.set-item-toggle:hover .set-item-chevron,.set-item-toggle:focus .set-item-chevron{color:var(--color-accent)}.set-item-chevron{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;flex-shrink:0;color:var(--color-text-secondary);transition:transform .16s ease,color .16s ease}.set-item-chevron.is-open{transform:rotate(90deg);color:var(--color-accent)}.set-item-name{flex:1;min-width:0;overflow-wrap:anywhere}.set-item-meta{grid-area:meta;font-size:var(--text-small);color:var(--color-accent);white-space:nowrap;justify-self:end}.set-item-actions{grid-area:actions;display:flex;gap:var(--space-sm);align-items:center;justify-content:flex-end}.set-action{min-height:var(--touch-min);padding:var(--space-xs) var(--space-sm);background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--text-caption);letter-spacing:.04em;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.set-action:hover:not(:disabled){background:var(--color-elevated);color:var(--color-text)}.set-action-danger{color:var(--color-error);border-color:var(--color-error)}.set-action-danger:hover:not(:disabled){background:#d45b5b1f;color:var(--color-error)}.set-action-primary{color:var(--color-accent);border-color:var(--color-accent)}.set-action-primary:hover:not(:disabled){background:#d4af551f}.set-action:disabled{opacity:.5;cursor:not-allowed}.set-add{justify-content:center;cursor:pointer;background:var(--color-surface)}.set-add:hover:not(:disabled){background:var(--color-elevated)}.set-add-label{font-size:var(--text-small);color:var(--color-accent);font-weight:500}.set-inline-form{display:flex;gap:var(--space-sm);align-items:center;width:100%}.set-inline-input{flex:1;min-width:0;min-height:var(--touch-min);padding:var(--space-sm) var(--space-md);background:var(--color-bg);border:1px solid var(--color-accent);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-small);font-family:var(--font-body)}.set-inline-input:focus{outline:none;box-shadow:0 0 0 2px #d4af554d}.set-cellar-block{border-left:2px solid var(--color-border);padding-left:var(--space-md)}.set-cellar-header{display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"star name meta" "actions actions actions";align-items:center;column-gap:var(--space-sm);row-gap:var(--space-sm);padding:var(--space-sm) 0}.set-cellar-name{grid-area:name;font-size:var(--text-small);color:var(--color-text);font-weight:500;min-width:0;overflow-wrap:anywhere}.set-cellar-meta{grid-area:meta;font-size:var(--text-caption);color:var(--color-text-muted);white-space:nowrap;justify-self:end}.set-cellar-header .set-item-actions{grid-area:actions}.set-cellar-default-btn{grid-area:star;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:0;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.set-cellar-default-btn:hover:not(:disabled){color:var(--color-accent);background:#d4af5514}.set-cellar-default-btn:disabled{cursor:default}.set-cellar-default-btn .set-cellar-star.is-default{color:var(--color-accent)}.set-bin-list{display:flex;flex-direction:column;gap:1px;margin-top:var(--space-xs)}.set-bin{display:grid;grid-template-columns:1fr auto;grid-template-areas:"name meta" "actions actions";align-items:center;column-gap:var(--space-md);row-gap:var(--space-sm);min-height:var(--touch-min);padding:var(--space-sm) var(--space-md);background:var(--color-elevated);border-radius:var(--radius-sm);font-size:var(--text-small)}.set-bin-name{grid-area:name;color:var(--color-text);min-width:0;overflow-wrap:anywhere}.set-bin-meta{grid-area:meta;color:var(--color-text-muted);font-size:var(--text-caption);white-space:nowrap;justify-self:end}.set-bin .set-item-actions{grid-area:actions}.set-empty{font-size:var(--text-caption);color:var(--color-text-muted);font-style:italic;padding:var(--space-sm) var(--space-md)}.set-loading,.set-error{padding:var(--space-lg);text-align:center;color:var(--color-text-secondary)}.set-error{color:var(--color-error)}.set-confirm{margin-top:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-elevated);border:1px solid var(--color-error);border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center;gap:var(--space-md)}.set-confirm-text{font-size:var(--text-small);color:var(--color-text);flex:1}.set-merge-picker{margin-top:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-elevated);border:1px solid var(--color-accent);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-sm)}.set-merge-picker-label{font-size:var(--text-small);color:var(--color-text-secondary)}.set-merge-targets{display:flex;flex-direction:column;gap:var(--space-xs)}.set-merge-target{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--text-body);cursor:pointer}.set-merge-target:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-accent)}.set-merge-target:disabled{opacity:.5;cursor:not-allowed}.set-merge-target-name{font-weight:500}.set-merge-target-meta{font-size:var(--text-caption);color:var(--color-text-secondary)}.set-merge-empty{font-size:var(--text-small);color:var(--color-text-secondary);font-style:italic}.set-item-session{align-items:flex-start}.set-item-info{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-width:0}.set-item-info .set-item-meta{white-space:normal;color:var(--color-text-secondary)}.set-item-current{color:var(--color-accent);font-weight:500;flex:0 0 auto}.set-notif-section+.set-notif-section{border-top:1px solid var(--color-border);margin-top:var(--space-md);padding-top:var(--space-md)}.set-notif-section-label{font-size:var(--text-caption);color:var(--color-text-muted);font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:var(--space-sm)}.set-notif-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-sm) 0}.set-notif-text{display:flex;flex-direction:column;gap:2px;min-width:0}.set-notif-title{font-size:var(--text-small);color:var(--color-text);font-weight:500}.set-notif-subtitle{font-size:var(--text-caption);color:var(--color-text-muted);line-height:1.4}.set-notif-input{flex:0 0 auto;font-family:var(--font-body);font-size:var(--text-small);padding:8px 12px;border-radius:var(--radius-input);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);width:180px;min-height:var(--touch-min)}.set-notif-input:focus{outline:2px solid var(--color-accent);outline-offset:1px}.set-notif-input:disabled{opacity:.5;cursor:not-allowed}.set-notif-switch{flex:0 0 auto;position:relative;width:44px;height:26px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;padding:0;transition:background var(--transition-fast),border-color var(--transition-fast);min-height:26px}.set-notif-switch:hover:not(:disabled){border-color:var(--color-accent)}.set-notif-switch.is-on{background:var(--color-accent);border-color:var(--color-accent)}.set-notif-switch:disabled{opacity:.5;cursor:not-allowed}.set-notif-switch-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--color-text-muted);transition:transform var(--transition-fast),background var(--transition-fast)}.set-notif-switch.is-on .set-notif-switch-thumb{transform:translate(18px);background:var(--color-bg)}.set-theme-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-sm) 0;flex-wrap:wrap}.set-theme-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1 200px}.set-theme-title{font-size:var(--text-small);color:var(--color-text);font-weight:500}.set-theme-subtitle{font-size:var(--text-caption);color:var(--color-text-muted);line-height:1.4}.set-theme-segments{display:inline-flex;flex:0 0 auto;border:1px solid rgba(212,175,85,.35);border-radius:var(--radius-pill);padding:3px;background:transparent}.set-theme-segment{flex:0 0 auto;font-family:var(--font-body);font-size:var(--text-caption);font-weight:500;letter-spacing:.04em;padding:8px 14px;min-height:36px;border:none;background:transparent;color:var(--color-text-muted);border-radius:var(--radius-pill);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.set-theme-segment:hover:not(:disabled):not(.is-active){color:var(--color-text)}.set-theme-segment.is-active{background:#d4af552e;color:var(--color-accent)}.set-theme-segment:disabled{opacity:.55;cursor:not-allowed}@media(max-width:480px){.set-theme-segments{width:100%;justify-content:stretch}.set-theme-segment{flex:1 1 0}}.push-consent-banner{margin:0 var(--space-md) var(--space-md);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-accent);border-radius:var(--radius-md)}.push-consent-banner .pcb-content{display:flex;flex-direction:column;gap:var(--space-sm)}.push-consent-banner .pcb-text{display:flex;flex-direction:column;gap:4px}.push-consent-banner .pcb-title{font-size:var(--text-small);color:var(--color-accent);font-weight:600;letter-spacing:.04em}.push-consent-banner .pcb-body{font-size:var(--text-caption);color:var(--color-text);line-height:1.45}.push-consent-banner .pcb-actions{display:flex;justify-content:flex-end;gap:var(--space-sm)}.push-consent-banner .pcb-cta{font-family:var(--font-body);font-size:var(--text-caption);font-weight:600;letter-spacing:.04em;padding:8px 16px;border-radius:var(--radius-full);cursor:pointer;min-height:var(--touch-min);transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.push-consent-banner .pcb-cta-primary{background:var(--color-accent);border:1px solid var(--color-accent);color:var(--color-bg)}.push-consent-banner .pcb-cta-primary:hover{background:var(--color-accent-bold);border-color:var(--color-accent-bold)}.push-consent-banner .pcb-cta-secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.push-consent-banner .pcb-cta-secondary:hover{border-color:var(--color-accent);color:var(--color-accent)}.set-notif-help{margin-top:var(--space-sm)}.set-notif-help-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:var(--text-caption);color:var(--color-accent);text-decoration:none;padding:var(--space-xs) 0;min-height:var(--touch-min);cursor:pointer}.set-notif-help-link:hover{text-decoration:underline}.set-notif-help-link .icon{flex-shrink:0}.help-page{min-height:100%;background:var(--color-bg);color:var(--color-text);padding-bottom:6rem}.help-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border)}.help-back{width:var(--touch-min);height:var(--touch-min);background:transparent;border:none;color:var(--color-text);font-size:1.5rem;cursor:pointer;border-radius:var(--radius-md)}.help-back:hover{background:var(--color-elevated)}.help-title{font-family:var(--font-heading);font-size:var(--text-h2);margin:0;color:var(--color-text)}.help-content{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-lg);max-width:720px;margin:0 auto}.help-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.help-section-title{font-family:var(--font-heading);font-size:var(--text-h3, 1.125rem);margin:0;color:var(--color-accent)}.help-section-body{color:var(--color-text);font-size:var(--text-body);line-height:1.55;display:flex;flex-direction:column;gap:var(--space-sm)}.help-section-body p{margin:0}.help-steps{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:var(--space-xs)}.help-steps li{line-height:1.5}.help-steps code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;background:var(--color-elevated);padding:1px 6px;border-radius:4px}.help-note{font-size:var(--text-small);color:var(--color-text-muted)}.help-note-strong{color:var(--color-accent);font-weight:600}.help-link{color:var(--color-accent);text-decoration:none;font-weight:600}.help-link:hover{text-decoration:underline}.page-import{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--color-bg);color:var(--color-text)}.import-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.import-back{background:transparent;border:none;font-size:22px;color:var(--color-text);cursor:pointer;padding:4px 8px;border-radius:var(--radius-md);min-height:var(--touch-min);min-width:var(--touch-min);line-height:1}.import-back:hover{background:var(--color-surface)}.import-title{font-family:var(--font-body);font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--color-text-muted)}.import-main{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-xl) var(--space-md);overflow:hidden;min-height:0}.import-step{width:100%;max-width:560px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.import-eyebrow{font-family:var(--font-body);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--color-warm-stone, var(--color-text-muted))}.import-headline{font-family:var(--font-display);font-size:32px;line-height:1.3;font-weight:400;margin:0;padding-top:2px;color:var(--color-text);text-wrap:balance}.import-headline em{font-style:italic;color:var(--color-accent)}.import-body{font-family:var(--font-display);font-style:italic;font-size:15px;line-height:1.6;color:var(--color-text-secondary);max-width:42ch;margin:0 auto;text-wrap:balance}.import-step-upload{position:relative;border:1.5px dashed transparent;border-radius:var(--radius-md);padding:var(--space-xl) var(--space-lg);transition:border-color var(--transition-fast),background var(--transition-fast)}.import-step-upload.drag-over{border-color:var(--color-accent);background:#d4af550f}.import-cta{font-family:var(--font-body);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;padding:14px 28px;border-radius:var(--radius-full);cursor:pointer;min-height:var(--touch-min);transition:background var(--transition-fast),border-color var(--transition-fast)}.import-cta:disabled{opacity:.5;cursor:not-allowed}.import-cta-primary{background:var(--color-accent);border:1px solid var(--color-accent);color:var(--color-bg)}.import-cta-primary:hover:not(:disabled){background:var(--color-accent-bold, var(--color-accent))}.import-file-name{font-family:var(--font-body);font-size:12px;color:var(--color-text-muted);letter-spacing:.08em}.import-discard-link{display:inline-block;background:transparent;border:none;padding:var(--space-sm) var(--space-md);margin-top:var(--space-md);font-family:var(--font-body);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);cursor:pointer;text-decoration:underline;text-underline-offset:4px;transition:color var(--transition-fast)}.import-discard-link:hover{color:var(--color-text)}.import-step-error .import-error-code{font-family:var(--font-body);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted);opacity:.6;margin-top:var(--space-md)}.import-spinner{width:48px;height:48px;border-radius:50%;border:2px solid rgba(212,175,85,.2);border-top-color:var(--color-accent);animation:import-spin 1s linear infinite}@keyframes import-spin{to{transform:rotate(360deg)}}.import-step-confirm{align-self:stretch;height:100%;max-width:720px;display:flex;flex-direction:column;align-items:stretch;text-align:center;gap:0;padding-bottom:var(--space-md)}.import-step-confirm .import-eyebrow,.import-step-confirm .import-headline,.import-step-confirm .import-body{flex-shrink:0}.import-step-confirm .import-headline{margin:6px 0 var(--space-sm)}.import-step-confirm .import-body{margin-bottom:var(--space-md)}.import-step-confirm .import-loc-list{flex:1;min-height:0;overflow-y:auto;margin:0 auto var(--space-md);width:100%}.import-step-confirm .import-cta{flex-shrink:0;align-self:center}.import-loc-list{list-style:none;padding:0;margin:0;width:100%;max-width:520px;display:flex;flex-direction:column;gap:1px;background:var(--color-border);border-radius:var(--radius-md);overflow:hidden;text-align:left}.import-loc-row{display:grid;grid-template-columns:1fr 1fr auto;gap:var(--space-md);align-items:center;padding:12px var(--space-md);background:var(--color-surface);font-size:13px}.import-loc-raw{font-family:var(--font-body);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-loc-target{font-family:var(--font-body);color:var(--color-text);font-weight:500;display:flex;align-items:center;gap:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-loc-flag{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#c75b2a;font-weight:600}.import-loc-confidence{font-family:var(--font-body);font-size:11px;letter-spacing:.1em;color:var(--color-accent);font-weight:600}.import-progress{width:100%;max-width:360px;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.import-progress-fill{height:100%;background:var(--color-accent);transition:width 1.2s ease}.import-stats{display:flex;gap:var(--space-xl);justify-content:center;flex-wrap:wrap;margin-top:var(--space-md)}.import-stat{display:flex;flex-direction:column;align-items:center;gap:6px}.import-stat-num{font-family:var(--font-display);font-style:italic;font-size:42px;line-height:1;color:var(--color-accent)}.import-stat-label{font-family:var(--font-body);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--color-text-muted)}.import-recon-caption{font-family:var(--font-body);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--color-text-muted);margin-top:var(--space-sm)}.import-recon-flags{font-family:var(--font-body);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#c75b2a;margin-top:6px}@media(max-width:767px){.import-headline{font-size:26px}.import-loc-row{grid-template-columns:1fr auto;gap:4px}.import-loc-raw{grid-column:1 / -1;font-size:11px;letter-spacing:.08em;color:var(--color-text-muted);text-transform:uppercase}.import-stat-num{font-size:32px}.import-stats{gap:var(--space-lg)}}.page-search{display:flex;flex-direction:column;gap:var(--space-md);padding-bottom:var(--space-xl)}.search-header{display:flex;flex-direction:column;gap:var(--space-xs);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.search-header h1{font-size:var(--text-h1);color:var(--color-text);margin:0}.search-sub{font-size:var(--text-caption);color:var(--color-text-secondary);margin:0}.search-input-row{display:flex}.search-input{flex:1;min-height:44px;padding:0 var(--space-md);font-size:var(--text-body);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;outline:none}.search-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 22%,transparent)}.search-input::placeholder{color:var(--color-text-secondary)}.search-results{display:flex;flex-direction:column;gap:var(--space-xs)}.search-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);width:100%;min-height:64px;padding:var(--space-sm) var(--space-md);text-align:left;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font:inherit;cursor:pointer;transition:border-color .12s ease,background .12s ease}.search-row:hover{border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 6%,var(--color-surface))}.search-row:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.search-row-main{display:flex;flex-direction:column;gap:2px;min-width:0}.search-row-title{font-size:var(--text-body);font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-row-sub{font-size:var(--text-small);color:var(--color-text-secondary)}.search-row-trail{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.search-row-vintage{font-size:var(--text-small);color:var(--color-accent);font-variant-numeric:tabular-nums}.search-row-cta{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 var(--space-sm);font-size:var(--text-small);font-weight:600;letter-spacing:.02em;color:var(--color-bg);background:var(--color-accent);border-radius:4px}.search-row:hover .search-row-cta{background:var(--color-text)}.search-row--skeleton{cursor:default;pointer-events:none}.search-skeleton-line{background:color-mix(in srgb,var(--color-text) 8%,transparent);border-radius:4px;animation:search-skeleton-pulse 1.4s ease-in-out infinite}.search-skeleton-line--title{height:14px;width:60%;margin-bottom:6px}.search-skeleton-line--sub{height:11px;width:40%}@keyframes search-skeleton-pulse{0%,to{opacity:.5}50%{opacity:1}}.search-state{padding:var(--space-lg) var(--space-md);text-align:center;color:var(--color-text-secondary);border:1px dashed var(--color-border);border-radius:8px}.search-state p{margin:0 0 var(--space-xs)}.search-state p:last-child{margin-bottom:0}.search-state-hint{font-size:var(--text-small)}.search-state--error{border-color:color-mix(in srgb,var(--color-accent) 40%,var(--color-border))}
