:root{--crimson: #A4122E;--cellar: #7E0D22;--ink: #161616;--paper: #FFFFFF;--mist: #F7F5F2;--stone: #6E6A64;--canvas: #ECE9E3;--line: #ECECEC;--line-warm: #E2DACE;--tag-bg: #FDF3F5;--tag-border: #F0D6DC;--font: "Mukta", system-ui, sans-serif;--r-sm: 4px;--r-md: 8px;--r-lg: 14px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:var(--font);background:var(--canvas);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}::selection{background:#a4122e26}.chat-messages{scrollbar-width:thin;scrollbar-color:#D8CFC2 transparent}.chat-messages::-webkit-scrollbar{width:9px}.chat-messages::-webkit-scrollbar-thumb{background:#d8cfc2;border:3px solid transparent;border-radius:999px;background-clip:content-box}.chat-messages::-webkit-scrollbar-thumb:hover{background:#c2b7a6;background-clip:content-box}#app{height:100vh;display:flex;flex-direction:column}.header{flex:none;background:var(--paper);border-bottom:1px solid var(--line)}.header .container{max-width:100%;padding:0 26px}.header-content{height:62px;display:flex;align-items:center;gap:14px}.logo-image{height:28px;width:auto;display:block}.header-content:after{content:"Ask JS";font-weight:800;font-size:17px;letter-spacing:.5px;color:var(--ink)}.header-divider{width:1px;height:24px;background:var(--line-warm)}.main{flex:1;min-height:0;display:flex}.main .container{max-width:100%;padding:0;width:100%;display:flex}.sidebar{flex:none;width:248px;border-right:1px solid var(--line);background:#faf9f7;padding:18px 14px;display:flex;flex-direction:column;gap:24px;overflow-y:auto}.new-convo-btn{display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:700;font-size:14px;color:#fff;background:var(--crimson);border:none;padding:11px 14px;border-radius:var(--r-md);cursor:pointer;transition:background .18s ease}.new-convo-btn:hover{background:var(--cellar)}.new-convo-btn svg{width:16px;height:16px;flex:none}.scan-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;font-family:inherit;font-weight:600;font-size:13.5px;color:var(--ink);background:var(--paper);border:1px solid var(--line-warm);padding:10px 14px;border-radius:var(--r-md);cursor:pointer;transition:border-color .18s ease,color .18s ease}.scan-btn:hover{border-color:var(--crimson);color:var(--crimson)}.scan-btn svg{width:17px;height:17px;flex:none}.message.user .message-bubble.scan-bubble{background:var(--paper);border:1px solid var(--line-warm);padding:6px;border-radius:16px;box-shadow:0 8px 22px #1616161f;color:var(--ink)}.scan-thumb{display:block;width:200px;max-width:58vw;max-height:260px;border-radius:11px;object-fit:cover}.scan-thumb-ph{width:200px;max-width:58vw;height:150px;border-radius:11px;background:linear-gradient(100deg,var(--mist) 30%,#efece7 50%,var(--mist) 70%);background-size:220% 100%;animation:scan-shimmer 1.2s ease-in-out infinite}@keyframes scan-shimmer{0%{background-position:180% 0}to{background-position:-180% 0}}.scan-progress{min-width:230px}.scan-progress-row{display:flex;align-items:center;gap:10px}.scan-progress .scan-status{font-size:14px;color:var(--ink);line-height:1.3}.scan-bar{margin-top:10px;height:6px;border-radius:999px;background:var(--line-warm);overflow:hidden}.scan-bar-fill{height:100%;width:0;border-radius:999px;background:var(--crimson);transition:width .25s ease}.scan-bar-fill.indet{width:40%!important;animation:scan-indet 1.15s ease-in-out infinite;transition:none}@keyframes scan-indet{0%{margin-left:-40%}to{margin-left:100%}}.sidebar-section{display:flex;flex-direction:column;gap:8px}.sidebar-heading{font-size:11px;font-weight:700;letter-spacing:1.5px;color:#9a9189;text-transform:uppercase}.sidebar-list{display:flex;flex-direction:column;gap:2px}.recent-item{font-size:13.5px;color:#4a443d;padding:8px 10px;border-radius:6px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid transparent;transition:background .15s ease,color .15s ease,border-color .15s ease}.recent-item:hover{background:#fff}.recent-item.active{background:#fff;border-color:var(--line);color:var(--ink);font-weight:600}.saved-item{display:flex;align-items:center;gap:9px;padding:6px;border-radius:6px;text-decoration:none;cursor:pointer;transition:background .15s ease}.saved-item:hover{background:#fff}.swipe-row{position:relative;overflow:hidden;border-radius:6px}.swipe-row-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:6px;display:flex;align-items:center;justify-content:flex-end;padding-right:14px;background:var(--crimson);color:#fff;font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;opacity:0}.swipe-row.swiping .swipe-row-bg{opacity:1}.swipe-row-content{position:relative;display:flex;align-items:center;gap:9px;border-radius:6px;background:#faf9f7;transition:transform .18s ease,background .15s ease;touch-action:pan-y}.row-text{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.swipe-row-content.saved-item .saved-name{flex:1 1 auto;min-width:0}.row-delete{flex:none;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;margin-left:4px;padding:0;border:none;background:transparent;color:#b7afa4;border-radius:50%;cursor:pointer;opacity:0;transition:opacity .15s ease,color .15s ease,background .15s ease}.swipe-row-content:hover .row-delete,.row-delete:focus-visible{opacity:1}.row-delete:hover{color:var(--crimson);background:#a4122e14}@media (hover: none){.row-delete{opacity:.45}}.followups{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.followup-chip{font-family:inherit;font-size:13px;font-weight:600;color:#4a443d;background:var(--paper);border:1px solid var(--line-warm);border-radius:999px;padding:8px 14px;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.followup-chip:hover{background:var(--crimson);color:#fff;border-color:var(--crimson)}.saved-score{flex:none;width:28px;height:28px;border-radius:50%;background:var(--crimson);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px}.saved-name{font-size:13px;color:#4a443d;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-item:hover .saved-name{color:var(--ink)}.sidebar-empty{font-size:12.5px;color:#9a9189;line-height:1.45;padding:2px 10px}.sidebar-toggle,.sidebar-backdrop{display:none}@media (max-width: 860px){.sidebar-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;margin-right:2px;background:none;border:none;color:var(--ink);cursor:pointer;flex:none}.sidebar-toggle svg{width:22px;height:22px}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;z-index:200;transform:translate(-100%);transition:transform .25s ease;box-shadow:0 24px 60px #0000004d}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#16161673;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:150}.sidebar-backdrop.show{opacity:1;pointer-events:auto}}.chat-container{flex:1;min-height:0;display:flex;flex-direction:column;position:relative;background-color:#fcfbf9;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.045 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"),radial-gradient(1100px 460px at 50% -8%,#fff,#fff0 70%),linear-gradient(180deg,#fcfbf9,#f6f2ec)}.welcome-message{max-width:680px;margin:0 auto;padding:64px 40px 8px;text-align:left}.welcome-message:before{content:"ASK JS · WINE ASSISTANT";display:block;font-size:12px;font-weight:700;letter-spacing:2.5px;color:var(--crimson);margin-bottom:16px}.welcome-message h2{font-weight:800;font-size:36px;line-height:1.05;letter-spacing:-.8px;margin-bottom:14px}.welcome-message p{color:var(--stone);font-size:16px;line-height:1.6;margin-bottom:22px;max-width:560px}.quick-actions{display:flex;gap:9px;flex-wrap:wrap}.quick-btn{font-family:inherit;font-size:13px;color:var(--ink);background:var(--paper);border:1px solid var(--line-warm);padding:9px 14px;border-radius:999px;cursor:pointer;transition:background .18s ease,color .18s ease,border-color .18s ease}.quick-btn:hover{background:var(--crimson);color:#fff;border-color:var(--crimson)}.quick-btn.skeleton{height:18px;border-color:transparent;pointer-events:none;background:linear-gradient(90deg,var(--canvas) 25%,#F4F1EC 37%,var(--canvas) 63%);background-size:400% 100%;animation:askjs-shimmer 1.2s ease-in-out infinite}@keyframes askjs-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.chat-messages{flex:1;min-height:0;overflow-y:auto;padding:30px 40px 24px;scroll-behavior:smooth}.message{max-width:680px;margin:0 auto 22px;display:flex;gap:13px;align-items:flex-start}.message.user{justify-content:flex-end}.message.user .message-avatar{display:none}.message-avatar{width:34px;height:34px;flex:none;background:var(--paper);border:1px solid #E7E1D8;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden}.message-avatar img{height:16px;width:auto;display:block}.message-content{min-width:0}.message.assistant .message-content{flex:1}.message.user .message-content{max-width:70%}.message-bubble{font-size:15px;line-height:1.6;word-wrap:break-word;overflow-wrap:break-word}.message.assistant .message-bubble{color:#222}.message.user .message-bubble{background:var(--ink);color:#fff;padding:12px 17px;border-radius:14px 14px 3px}.message-bubble strong{font-weight:700}.wine-card{margin:16px 0 6px;background:var(--paper);border:1px solid #EAE3D8;border-radius:12px;overflow:hidden;box-shadow:0 1px 2px #1616160a,0 12px 30px #16161614;transition:box-shadow .2s ease,transform .2s ease}.wine-card:hover{box-shadow:0 2px 4px #1616160d,0 18px 42px #1616161c;transform:translateY(-1px)}.wine-body{display:flex;gap:16px;padding:18px;align-items:flex-start}.wine-bottle{flex:none;width:46px;display:flex;align-items:center;justify-content:center}.wine-photo{width:100%;max-width:48px;max-height:132px;object-fit:contain;display:block}.wine-main{flex:1;min-width:0}.wine-eyebrow{font-size:11px;letter-spacing:1px;color:#9a9189;font-weight:700;text-transform:uppercase}.wine-name{font-weight:800;font-size:20px;line-height:1.1;letter-spacing:-.3px;margin:3px 0 2px;overflow-wrap:anywhere;word-break:break-word}a.wine-name{display:inline-block;max-width:100%;color:inherit;text-decoration:none;cursor:pointer;transition:color .15s ease}a.wine-name:hover{color:var(--crimson);text-decoration:underline;text-underline-offset:2px}.wine-meta{font-size:13px;color:var(--stone)}.wine-score{flex:none;width:56px;height:56px;border-radius:50%;background:var(--crimson);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center}.wine-score .score-num{font-weight:800;font-size:23px;line-height:.9}.wine-score .score-lab{font-size:6.5px;letter-spacing:1px;font-weight:700;color:#f0cdcf;margin-top:2px}.wine-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}.wine-tag{font-size:11px;padding:4px 9px;background:var(--tag-bg);border:1px solid var(--tag-border);border-radius:999px;color:var(--cellar)}.wine-foot{padding:2px 18px 16px}.wine-quote{margin:0 0 12px;font-size:13.5px;line-height:1.55;font-style:italic;color:#5a534b}.wine-link{display:flex;gap:18px;align-items:center;flex-wrap:wrap}.wine-action{font-size:13px;font-weight:700;color:var(--crimson);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s ease}.wine-action:hover{color:var(--cellar)}.wine-action.save-wine{color:var(--stone)}.wine-action.save-wine:hover{color:var(--ink)}.wine-action.save-wine.saved{color:var(--crimson)}.tasting-notes-link{font-size:13px;font-weight:700;color:var(--crimson);text-decoration:none}.tasting-notes-link:hover{color:var(--cellar)}.chat-input-container{flex:none;position:relative;padding:14px 40px 22px;background:transparent}.chat-input-container:before{content:"";position:absolute;left:0;right:0;top:-28px;height:28px;background:linear-gradient(to top,#f6f2ec,#f6f2ec00);pointer-events:none}.chat-input-wrapper{max-width:680px;margin:0 auto;display:flex;align-items:center;gap:10px;background:var(--paper);border:1.5px solid var(--line-warm);border-radius:999px;padding:7px 7px 7px 8px;box-shadow:0 1px 2px #1616160a,0 8px 24px #1616160d;transition:border-color .2s ease,box-shadow .2s ease}.chat-input-wrapper:focus-within{border-color:var(--crimson);box-shadow:0 0 0 3px #a4122e1f,0 8px 24px #1616160f}#chatInput{flex:1;border:none;outline:none;background:transparent;font-family:inherit;font-size:16px;color:var(--ink);padding:6px 0}#chatInput::placeholder{color:#a59c91}.composer-scan-btn{flex:none;width:40px;height:40px;border:none;border-radius:50%;background:transparent;color:var(--stone);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .18s ease,background .18s ease,transform .12s ease}.composer-scan-btn:hover{color:var(--crimson);background:#a4122e14}.composer-scan-btn:active{transform:scale(.92)}.composer-scan-btn svg{width:21px;height:21px;display:block}.send-btn{flex:none;width:44px;height:44px;border:none;border-radius:50%;background:var(--crimson);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #a4122e59;transition:background .18s ease,transform .12s ease,box-shadow .18s ease}.send-btn svg{width:18px;height:18px;display:block}.send-btn:hover{background:var(--cellar);transform:translateY(-1px);box-shadow:0 4px 14px #a4122e73}.send-btn:active{transform:translateY(0) scale(.95)}.send-btn:disabled{background:#c9c0b4;box-shadow:none;cursor:not-allowed;transform:none}.typing-indicator{display:flex;align-items:center;gap:12px;padding:2px 0}.wine-spinner{flex:none;display:inline-flex;animation:askjs-spin 2.4s linear infinite;transform-origin:center}.loading-message{font-size:15px;color:var(--stone)}@keyframes askjs-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.wine-spinner{animation-duration:6s}}@media (max-width: 720px){.header .container{padding:0 16px}.welcome-message{padding:32px 18px 4px}.welcome-message h2{font-size:26px}.chat-messages{padding:20px 16px}.chat-input-container{padding:12px 16px 18px}.message.user .message-content{max-width:82%}.wine-card{margin-left:0}}@media (min-width: 861px){.sidebar{width:288px}.new-convo-btn{font-size:16px;padding:13px 16px}.sidebar-heading{font-size:13px}.recent-item,.saved-name{font-size:16px}.saved-score{width:32px;height:32px;font-size:13px}.sidebar-empty{font-size:14.5px;line-height:1.5}.quick-btn{font-size:15.5px;padding:11px 17px}.followup-chip{font-size:15px}.message-bubble{font-size:17px;line-height:1.65}.welcome-message p{font-size:18px}.wine-name{font-size:22px}.wine-quote{font-size:15px}}.video-head{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#9a9189;margin:18px 0 8px}.video-card{margin:0 0 10px;background:var(--paper);border:1px solid #EAE3D8;border-radius:12px;overflow:hidden;box-shadow:0 1px 2px #1616160a,0 8px 22px #16161612}.video-thumb{display:block;width:100%;padding:0;border:none;cursor:pointer;aspect-ratio:16 / 9;background-color:#2a2320;background-size:cover;background-position:center;position:relative}.video-thumb .video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:#a4122eeb;display:flex;align-items:center;justify-content:center;transition:background .15s ease,transform .15s ease}.video-thumb .video-play:after{content:"";margin-left:4px;border-style:solid;border-width:9px 0 9px 15px;border-color:transparent transparent transparent #fff}.video-thumb:hover .video-play{background:var(--crimson);transform:translate(-50%,-50%) scale(1.06)}.video-embed{aspect-ratio:16 / 9;background:#000}.video-embed iframe{width:100%;height:100%;border:0;display:block}.video-meta{padding:11px 14px 13px;display:flex;flex-direction:column;gap:3px}.video-title{font-weight:700;font-size:14.5px;line-height:1.25;color:var(--ink);text-decoration:none}.video-title:hover{color:var(--crimson);text-decoration:underline;text-underline-offset:2px}.video-label{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--crimson)}
