:root{--paper: #fffefa;--canvas: #f7f6f2;--ink: #242420;--muted: #7f7a70;--hairline: #e9e3d9;--soft-line: #f0ebe3;--olive: #737363;--olive-light: #efeee6;--radius-card: 14px;--shadow-soft: 0 12px 30px rgba(48, 45, 38, .035);color:#242420;background:#f7f6f2;font-family:Noto Sans SC,PingFang SC,Microsoft YaHei,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 50% 0%,rgba(191,184,166,.16),transparent 26rem),#f7f6f2}button,textarea,input{font:inherit}button{cursor:pointer}.app-shell{display:grid;min-height:100vh;place-items:center;padding:18px}.phone-frame{position:relative;display:flex;flex-direction:column;width:min(100%,390px);height:min(844px,calc(100vh - 40px));min-height:680px;overflow:hidden;border:1px solid var(--hairline);border-radius:28px;background:var(--paper);box-shadow:0 24px 64px #2f2d2612}.screen{flex:1 1 0%;min-height:0;overflow-y:auto;padding:18px 22px 24px}.topline,.card-head{display:flex;align-items:center;justify-content:space-between;color:#252520;font-size:12px;letter-spacing:0}.home-screen{display:grid;grid-template-rows:auto 1fr auto;gap:14px}.home-hero-copy,.section-heading.centered{text-align:center;padding-top:42px}.home-hero-copy h1,.section-heading h2,.recommendation-copy h2{margin:0;color:#272722;font-family:Georgia,"Noto Serif SC",Songti SC,serif;font-weight:500;letter-spacing:0}.home-hero-copy h1{font-size:23px;line-height:1.28}.home-hero-copy p,.section-heading p,.recommendation-copy p,.cocktail-card p,.insight-panel p,.shopping-grid p,.step-line p{color:var(--muted);line-height:1.68}.home-hero-copy p,.section-heading p{margin:8px 0 0;font-size:13px}.section-heading h2{font-size:24px;line-height:1.28}.eyebrow,.group-label,.bartender-note span,.bartender-line span,.recommendation-copy span{color:#8e8879;font-size:12px;font-weight:600;letter-spacing:0}.glass-stage{position:relative;display:grid;place-items:center;min-height:180px;isolation:isolate}.glass-stage:before{position:absolute;inset:30px 50px 38px;z-index:-1;border-radius:999px;background:#f5f2eb;content:""}.glass-entry{display:grid;width:min(62vw,204px);padding:0;border:0;background:transparent;box-shadow:none}.listening-glass{width:min(62vw,204px);max-width:100%;filter:drop-shadow(0 18px 18px rgba(64,61,52,.08))}.listening-glass svg{display:block;width:100%;overflow:visible}.glass-entry .listening-glass{width:100%;transition:transform .18s ease,filter .18s ease}.glass-entry:hover .listening-glass{transform:translateY(-2px);filter:drop-shadow(0 22px 20px rgba(64,61,52,.12))}.glass-shadow,.visual-shadow{fill:#524e441f}.ambient-glow{opacity:.36;animation:glassPulse 5.2s ease-in-out infinite}.rim-back,.rim-front,.bowl,.stem,.base{fill:#ffffff1a;stroke:url(#glassStroke);stroke-width:1.8}.rim-back{opacity:.32}.liquid-fill{fill:url(#liquidGradient);opacity:.64;transform-origin:120px 165px;animation:liquidBreathe 6s ease-in-out infinite}.liquid-surface{fill:#fff6}.citrus .liquid-stop-one,.ruby .liquid-stop-one,.amber .liquid-stop-one{stop-color:#eef5d7}.citrus .liquid-stop-two,.ruby .liquid-stop-two,.amber .liquid-stop-two{stop-color:#cfe3a4}.citrus .liquid-stop-three,.ruby .liquid-stop-three,.amber .liquid-stop-three{stop-color:#98b36b}.liquid-shine,.spirit-thread,.thinking-swirl,.rim-light,.reveal-arc{fill:none;stroke-linecap:round}.liquid-shine{stroke:#ffffffb8;stroke-width:2}.spirit-thread{stroke:#8996678f;stroke-width:2;stroke-dasharray:150;animation:spiritListen 4.8s ease-in-out infinite}.thinking-swirl{opacity:0;stroke:#89966752;stroke-width:1.8;stroke-dasharray:120}.thinking .thinking-swirl{opacity:1;animation:swirlThink 4s ease-in-out infinite}.ice rect{fill:#ffffff7a;stroke:#7f7f7338;stroke-width:1}.bubbles circle{fill:#ffffffd9;animation:bubbleRise 4s ease-in-out infinite}.rim-light{stroke:#8996677a;stroke-width:2;animation:rimListening 3.6s ease-in-out infinite}.reveal-arc{opacity:0;stroke:#8996676b;stroke-width:1.6;stroke-dasharray:130}.revealing .reveal-arc{opacity:1;animation:revealSweep 2.2s ease-in-out infinite}.bartender-note{position:absolute;bottom:8px;left:50%;display:grid;gap:6px;min-width:160px;transform:translate(-50%);text-align:center}.bartender-note p{margin:0;color:#4f4c45;font-size:13px}.home-actions{display:grid;gap:10px}.home-action-card{display:grid;grid-template-columns:40px 1fr;gap:13px;align-items:center;width:100%;min-height:84px;border:1px solid var(--hairline);border-radius:var(--radius-card);padding:15px;color:#2c2b25;background:var(--paper);text-align:left;box-shadow:var(--shadow-soft)}.home-action-icon{display:grid;width:36px;height:36px;place-items:center;border:1px solid #979986;border-radius:999px;color:#696c58;font-size:22px}.home-action-card strong{display:block;font-size:15px;font-weight:600}.home-action-card small{display:block;margin-top:5px;color:#8a867c;font-size:12px}.home-bottom-nav{flex-shrink:0;display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--soft-line);padding:11px 0 8px;color:#858177;font-size:12px;text-align:center}.home-bottom-nav button{border:0;color:inherit;background:transparent;font:inherit}.home-bottom-nav button:before{display:block;margin-bottom:4px;color:currentColor;content:"◇";font-size:14px}.home-bottom-nav .active{color:#292821;font-weight:600}.primary-action,.secondary-action,.ghost-button,.choice,.chip,.segmented button,.chat-examples button{border:1px solid var(--hairline);color:#292821;background:var(--paper);box-shadow:none}.primary-action,.secondary-action{width:100%;min-height:54px;border-radius:var(--radius-card);padding:14px 18px;text-align:center;font-weight:600}.primary-action{border-color:var(--olive);background:var(--olive);color:#fffdf8;box-shadow:0 12px 24px #39382d21}.primary-action:disabled{opacity:.58}.primary-action span,.secondary-action span{display:block;margin-top:6px;font-size:12px;font-weight:400;opacity:.72}.secondary-action,.compact-action{background:var(--paper);color:#5e5a50}.ghost-button{display:grid;min-width:36px;height:36px;place-items:center;margin-bottom:14px;border-radius:999px;color:#2d2c26}.icon-back{width:36px;padding:0;font-size:20px}.result-screen>.icon-back,.follow-screen>.icon-back,.share-screen>.icon-back,.preference-screen>.icon-back{position:sticky;top:0;z-index:10;margin:-6px 0 4px;background:var(--paper)}.preference-screen,.chat-screen,.result-screen,.menu-screen{padding-bottom:24px}.option-group,.ingredient-groups{display:grid;gap:12px;margin-top:28px}.group-label{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;color:#56534b;text-align:center;margin-bottom:6px}.group-label:before,.group-label:after{height:1px;background:var(--soft-line);content:""}.choice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.choice{min-height:48px;border-radius:var(--radius-card);padding:10px 12px;text-align:center}.choice strong{display:block;font-weight:600}.choice span{display:block;margin-top:4px;color:#8a867c;font-size:11px;line-height:1.4}.selected{border-color:#a9ab98!important;background:var(--olive-light)!important}.segmented{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.segmented button{min-height:46px;border-radius:var(--radius-card)}.bottom-action{margin-top:26px}.ingredient-textarea,.chat-input-card textarea{width:100%;resize:vertical;border:1px solid var(--hairline);border-radius:var(--radius-card);padding:14px;color:#292821;background:var(--paper);outline:none}.ingredient-textarea{min-height:104px;margin-top:22px}.ingredient-textarea::placeholder,.chat-input-card textarea::placeholder{color:#a29d92}.taste-sliders,.chat-bubble,.chat-input-card,.understanding-card,.bartender-line,.result-visual-card,.insight-panel,.shopping-grid>div,.recipe-block,.steps-block,.soft-warning,.hero-recommendation-card,.menu-card{border:1px solid var(--hairline);border-radius:var(--radius-card);background:var(--paper);box-shadow:var(--shadow-soft)}.taste-sliders{display:grid;gap:12px;margin-top:14px;padding:14px 15px}.taste-sliders label{display:grid;grid-template-columns:48px 1fr;align-items:center;gap:12px;color:#5f5c54;font-size:13px}input[type=range]{accent-color:var(--olive)}.ingredient-group{display:grid;gap:10px}.chip-row{display:flex;gap:8px;margin-top:0;overflow-x:auto;padding-bottom:4px}.chip-row.wrap{flex-wrap:wrap;overflow:visible}.chip,.tag-row span{border-radius:999px;padding:7px 12px;color:#5f5c54;background:var(--paper);white-space:nowrap}.chat-screen{display:flex;flex-direction:column;flex:1 1 0%;min-height:0;overflow-y:auto}.chat-companion{display:grid;justify-items:center;margin-top:-6px}.chat-companion .listening-glass{width:128px}.chat-bubble,.understanding-card,.chat-input-card{display:grid;gap:12px;margin-top:16px;padding:14px 15px}.chat-bubble strong,.understanding-card strong,.insight-panel strong{color:#292821;font-size:14px;font-weight:600}.understanding-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.agent-source-badge{flex:0 0 auto;border:1px solid rgba(138,132,113,.22);border-radius:999px;padding:4px 8px;background:#ffffffb8;color:#767165;font-size:11px;line-height:1}.agent-source-badge.ai{border-color:#7a8d6859;background:#ecf2e4c7;color:#5f6e4d}.agent-source-badge.local{border-color:#b47e5647;background:#faefe5c7;color:#9a6848}.llm-health-card{display:grid;gap:10px;margin-top:14px;border:1px dashed rgba(138,132,113,.28);border-radius:var(--radius-card);padding:12px;background:#ffffff94}.chat-recommendations{display:grid;gap:10px;margin-top:14px}.chat-rec-head{display:grid;gap:3px;padding:0 2px}.chat-rec-head strong{color:#302f29;font-size:15px}.chat-rec-head span{color:#8a8579;font-size:12px}.chat-recommendation-card{display:grid;grid-template-columns:108px 1fr;gap:10px;align-items:center;width:100%;border:1px solid var(--hairline);border-radius:var(--radius-card);padding:10px;background:#ffffffc2;box-shadow:var(--shadow-soft);color:inherit;font:inherit;text-align:left;cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.chat-recommendation-card.primary{border-color:#7e896057;background:#fcfcf7e6}.chat-recommendation-card:active{transform:scale(.992)}.chat-recommendation-card:hover{border-color:#7e89606b;box-shadow:0 14px 28px #36302217}.chat-rec-visual{display:grid;place-items:center;min-width:0}.chat-rec-visual .cocktail-visual{width:122px;max-width:none}.external-visual-placeholder.compact{width:86px;height:108px}.chat-rec-copy{display:grid;gap:4px;min-width:0}.best-badge{display:inline-flex;width:fit-content;border-radius:999px;padding:4px 8px;background:#e2ecd6e0;color:#60724f;font-size:11px;line-height:1}.chat-rec-copy h3{margin:2px 0 0;color:#2e2d27;font-family:Georgia,"Noto Serif SC",Songti SC,serif;font-size:21px;font-style:italic;font-weight:500;line-height:1.1}.chat-rec-name{margin:3px 0 0;color:#5d584e;font-size:13px}.tag-row.compact{gap:5px}.tag-row.compact span{padding:2px 8px;font-size:11px;border:1px solid rgba(126,137,96,.18);background:#7e896017;color:#4a563e}.chat-rec-reason{display:-webkit-box;margin:0;overflow:hidden;color:#747064;font-size:12px;line-height:1.55;-webkit-box-orient:vertical;-webkit-line-clamp:3}.llm-health-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.llm-health-head strong{color:#3b3932;font-size:13px;font-weight:600}.llm-health-status{border-radius:999px;padding:4px 8px;font-size:11px;line-height:1}.llm-health-status.ok{background:#e2efd8db;color:#5b7048}.llm-health-status.fail{background:#fae7e0e6;color:#a0573e}.llm-health-card textarea{min-height:54px;resize:vertical;border:1px solid var(--soft-line);border-radius:12px;padding:9px 10px;background:#ffffffc7;color:#3d3b34;font:inherit}.secondary-action{min-height:38px;border-radius:999px;border:1px solid rgba(121,116,96,.24);background:#ffffffb8;color:#5f5a4e;font-weight:600}.secondary-action:disabled{opacity:.58}.llm-health-result{display:grid;gap:6px;border-top:1px solid var(--soft-line);padding-top:9px}.llm-health-result p{margin:0;color:#343229;font-size:13px;line-height:1.6}.llm-health-result small{color:#8a8578;font-size:11px}.chat-top-bar{display:flex;align-items:center;justify-content:space-between}.debug-toggle{display:grid;place-items:center;width:34px;height:34px;margin-bottom:14px;border:1px solid var(--hairline);border-radius:10px;background:none;cursor:pointer;transition:background .15s}.debug-toggle:hover{background:#0000000a}.debug-toggle-icon{font-size:15px;color:#8a8578}.debug-drawer-backdrop{position:fixed;inset:0;z-index:100;background:#00000040;display:flex;justify-content:flex-end;animation:debug-fade-in .2s ease-out}@keyframes debug-fade-in{0%{background:#0000}to{background:#00000040}}.debug-drawer{width:310px;max-width:78vw;height:100%;background:#fcfcf9;display:flex;flex-direction:column;overflow-y:auto;animation:debug-slide-in .22s ease-out}@keyframes debug-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.debug-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 10px;border-bottom:1px solid var(--soft-line)}.debug-drawer-head strong{font-size:15px;color:#3b3932}.debug-drawer-close{display:grid;place-items:center;width:28px;height:28px;border:none;border-radius:8px;background:none;font-size:17px;color:#8a8578;cursor:pointer}.debug-drawer-close:hover{background:#0000000f}.debug-drawer-body{padding:16px 18px;overflow-y:auto;flex:1}.agent-trace-section{margin-top:18px;padding-top:16px;border-top:1px solid var(--soft-line)}.agent-trace-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.agent-trace-head strong{font-size:13px;color:#3b3932}.agent-trace-count{font-size:11px;color:#8a8578;background:#0000000d;border-radius:999px;padding:2px 8px}.agent-trace-list{display:grid;gap:8px}.agent-trace-item{border:1px solid var(--hairline);border-radius:10px;padding:10px 12px;background:#fff9}.agent-trace-step{display:flex;align-items:center;gap:8px;margin-bottom:6px}.agent-trace-num{display:grid;place-items:center;width:20px;height:20px;border-radius:999px;background:#e2efd8;color:#5b7048;font-size:11px;font-weight:600;flex-shrink:0}.agent-trace-step strong{font-size:13px;font-weight:600;color:#3b3932}.agent-trace-detail{margin:0;font-size:12px;line-height:1.6;color:#6b6760;padding-left:28px}.agent-trace-empty{margin:0;font-size:12px;color:#b0aca4;text-align:center;padding:16px 0}.chat-examples{display:grid;gap:8px}.chat-examples button{min-height:42px;border-radius:var(--radius-card);padding:10px 12px;color:#5d5a52;text-align:left}.chat-input-card{margin-top:auto}.summary-row{display:grid;grid-template-columns:54px 1fr;gap:10px;border-top:1px solid var(--soft-line);padding-top:9px}.summary-row span{color:#858177;font-size:12px}.summary-row p{margin:0;color:#3d3b34}.hero-recommendation-card{display:grid;grid-template-columns:minmax(0,47%) minmax(0,53%);gap:8px;align-items:center;min-height:286px;padding:18px 16px 18px 10px;overflow:hidden}.hero-recommendation-card .cocktail-visual{width:128%;max-width:none;margin-left:-18%}.recommendation-copy h2{margin:0;font-size:31px;font-style:italic;line-height:1.05}.recommendation-copy p{margin:5px 0 12px;color:#56534b}.tag-row{display:flex;flex-wrap:wrap;gap:7px}.hero-reason{display:grid;gap:8px;margin-top:22px}.hero-reason strong{color:#3b3932;font-size:14px;font-weight:700}.hero-reason p{margin:0;color:#777267;font-size:14px;line-height:1.85}.bartender-line,.recipe-block,.steps-block,.insight-panel,.soft-warning,.citation-card{margin-top:12px;padding:15px 16px}.trust-signal-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.trust-signal-row span{border:1px solid rgba(178,161,120,.32);border-radius:999px;background:#f6f1e5b8;padding:7px 10px;color:#6d6656;font-size:12px}.citation-card{display:grid;gap:8px;border:1px solid var(--hairline);border-radius:var(--radius-card);background:#fffdf8e6}.citation-card a{color:#686350;font-size:13px;line-height:1.5;text-decoration:underline;text-underline-offset:3px}.external-visual-placeholder{display:grid;place-items:center;min-height:150px;border-radius:999px 999px 18px 18px;border:1px solid rgba(124,126,105,.38);background:linear-gradient(180deg,#ffffffb8,#f4ebd1b3),radial-gradient(circle at 50% 78%,rgba(124,126,105,.16),transparent 46%);color:#787565}.external-visual-placeholder span{font-size:12px;color:#8b8678}.external-visual-placeholder strong{font-family:Georgia,"Noto Serif SC",Songti SC,serif;font-size:46px;font-style:italic;font-weight:400}.bartender-line p{margin:8px 0 0;color:#3a3932;font-family:Georgia,"Noto Serif SC",Songti SC,serif;font-size:16px;line-height:1.65}.recipe-line,.step-line{display:grid;border-top:1px solid var(--soft-line);padding:11px 0;color:#4f4c45}.recipe-line{grid-template-columns:1fr auto;gap:14px;align-items:center}.recipe-line span:last-child{color:#777663}.step-line{grid-template-columns:28px 1fr;gap:12px;align-items:start;padding:14px 0}.step-line span:first-child{display:grid;width:24px;height:24px;place-items:center;border-radius:50%;background:var(--olive);color:#fffdf8;font-size:12px;line-height:1}.step-line p,.shopping-grid p,.insight-panel p{margin:0}.step-line p{color:#6f6b61;font-size:15px;line-height:1.6;padding-top:1px}.recipe-line span{font-size:15px;line-height:1.45}.shopping-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.follow-reference-card,.follow-step-card,.photo-upload-card,.share-card-preview{border:1px solid var(--hairline);border-radius:var(--radius-card);background:var(--paper);box-shadow:var(--shadow-soft)}.follow-reference-card{display:grid;grid-template-columns:48% 1fr;gap:12px;align-items:center;margin-top:18px;padding:14px}.follow-reference-card .cocktail-visual{width:118%;margin-left:-10%}.follow-reference-card h3,.share-card-preview h3{margin:7px 0 4px;color:#2a2924;font-family:Georgia,"Noto Serif SC",Songti SC,serif;font-size:25px;font-style:italic;font-weight:500;line-height:1.15}.follow-reference-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.6}.compact-recipe{margin-top:12px}.follow-step-card{display:grid;gap:14px;margin-top:12px;padding:16px}.follow-step-timeline{position:relative;display:grid;grid-template-columns:repeat(var(--step-count),minmax(0,1fr));gap:0;padding:6px 0 2px}.follow-step-timeline:before{position:absolute;top:20px;left:calc(100% / var(--step-count) / 2);right:calc(100% / var(--step-count) / 2);height:1px;background:var(--soft-line);content:""}.follow-step-timeline button{position:relative;z-index:1;display:grid;justify-items:center;gap:8px;min-width:0;border:0;background:transparent;padding:0;color:#8a867c}.follow-step-timeline button span{display:grid;width:30px;height:30px;place-items:center;border:1px solid var(--soft-line);border-radius:50%;background:var(--paper);color:#777363;font-size:13px;font-weight:600}.follow-step-timeline button em{color:#8a867c;font-size:11px;font-style:normal;line-height:1.25;text-align:center;white-space:nowrap}.follow-step-timeline button.active span{border-color:var(--olive);background:var(--olive);color:#fffdf8}.follow-step-timeline button.active em{color:#37352f;font-weight:600}.follow-step-card .current-step-copy{margin:0;color:#4d4a42;font-family:Georgia,"Noto Serif SC",Songti SC,serif;font-size:18px;line-height:1.7}.step-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.step-actions .secondary-action{min-height:44px;padding:10px 12px}.photo-upload-card{display:grid;justify-items:center;gap:8px;margin-top:12px;padding:24px 16px;border-style:dashed;color:#56534b;text-align:center}.photo-upload-card span{color:#8e8879;font-size:12px;font-weight:600}.photo-upload-card strong{color:#2d2c26;font-size:17px}.photo-upload-card input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.share-card-preview{display:grid;gap:14px;margin-top:18px;padding:18px}.share-card-preview h3 small{display:block;margin-top:5px;color:#5a574e;font-family:Noto Sans SC,PingFang SC,Microsoft YaHei,system-ui,sans-serif;font-size:15px;font-style:normal;font-weight:600}.share-compare{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:stretch}.share-reference,.share-photo{display:grid;min-height:158px;place-items:center;overflow:hidden;border:1px solid var(--soft-line);border-radius:12px;background:#fffdfa}.share-reference{position:relative}.share-reference .cocktail-visual{width:122%}.share-reference span{position:absolute;bottom:9px;left:50%;transform:translate(-50%);color:#8e8879;font-size:11px}.share-photo img{width:100%;height:100%;object-fit:cover}.share-photo span{color:#9a9488;font-size:13px}.share-card-preview blockquote{margin:0;border-top:1px solid var(--soft-line);padding-top:14px;color:#4d4a42;font-family:Georgia,"Noto Serif SC",Songti SC,serif;font-size:17px;line-height:1.75;white-space:pre-line}.caption-style-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:14px}.caption-style-row button{min-height:42px;border:1px solid var(--hairline);border-radius:999px;color:#5f5c54;background:var(--paper)}.caption-style-row button.selected{border-color:#a9ab98;background:var(--olive-light);color:#2d2c26;font-weight:600}.soft-warning{color:#7d6440;background:#fbf7ef;font-size:13px}.cocktail-card,.ambient-card{display:none}.menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:22px}.menu-card{display:grid;justify-items:center;min-width:0;padding:12px 10px;color:#292821;text-align:center}.menu-card .cocktail-visual{width:100%;max-width:136px;margin-bottom:6px}.menu-card span{color:#777663;font-family:Georgia,"Noto Serif SC",Songti SC,serif;font-size:17px;font-style:italic;line-height:1.2}.menu-card strong{margin-top:3px;font-size:13px;font-weight:600}.menu-card small{margin-top:4px;color:#8a867c;font-size:11px}.menu-card .tag-row{justify-content:center;margin-top:8px}.menu-card .tag-row em{border:1px solid var(--soft-line);border-radius:999px;padding:3px 7px;color:#77736a;font-size:10px;font-style:normal}.cocktail-visual{width:min(100%,286px);aspect-ratio:1 / 1}.cocktail-visual svg{display:block;width:100%;height:100%}.progress-liquid-layer{transition:clip-path .42s ease,opacity .3s ease}.visual-stage-building .progress-liquid-layer{clip-path:inset(calc(100% - var(--build-progress)) 0 0 0)}.visual-stage-building .foam-layer,.visual-stage-building .bubble-layer,.visual-stage-building .straw-layer,.visual-stage-building .garnish-layer,.visual-stage-building .ice-layer{transition:opacity .36s ease,transform .36s ease}.glass-line{fill:#ffffff14;stroke:#7f8270;stroke-width:1.7;stroke-linejoin:round}.glass-back{opacity:.28}.glass-highlight{fill:none;stroke:#ffffffe6;stroke-linecap:round;stroke-width:2}.drink-liquid{filter:none;transform-box:fill-box;transform-origin:center}.foam-layer,.bubble-layer circle{fill:#ffffffb8}.ice-layer rect{fill:#ffffff7a;stroke:#7e816f3d}.straw-layer path{fill:none;stroke:#7a8270;stroke-linecap:round;stroke-width:3}.garnish-layer{filter:none;transform-box:fill-box;transform-origin:center}.cocktail-motion-prepare .glass-highlight{animation:glassReady 2.8s ease-in-out infinite}.cocktail-motion-add .drink-liquid{animation:liquidPour 1.8s ease-in-out infinite}.cocktail-motion-add .ice-layer rect{animation:iceSettle 1.8s ease-in-out infinite}.cocktail-motion-stir .drink-liquid{animation:liquidStir 1.5s ease-in-out infinite}.cocktail-motion-stir .ice-layer{transform-box:fill-box;transform-origin:center;animation:iceSwirl 1.5s ease-in-out infinite}.cocktail-motion-finish .bubble-layer circle{animation:cocktailBubbleRise 1.8s ease-in-out infinite}.cocktail-motion-finish .garnish-layer{animation:garnishPresent 2.4s ease-in-out infinite}.mint-stem,.citrus-line,.cherry-stem,.pick{fill:none;stroke-linecap:round}.mint-stem{stroke:#6f8c54;stroke-width:1.8}.mint-leaf{fill:#7faa63}.citrus-peel,.lemon-wheel{fill:#dce88d;stroke:#8ca34e;stroke-width:1.7}.orange-wheel{fill:#e4a34a;stroke:#b87330;stroke-width:1.7}.citrus-line{stroke:#50602d80;stroke-width:1.4}.orange-peel{fill:none;stroke:#cf7b35;stroke-linecap:round;stroke-width:6}.cherry-stem{stroke:#7e6f4c;stroke-width:1.8}.cherry{fill:#a53436}.olive{fill:#7b8a58;stroke:#5f6f43;stroke-width:1.8}.pick{stroke:#8e7a57;stroke-width:1.8}.coffee-bean{fill:#684432}.salt-rim,.sugar-rim{fill:none;stroke-linecap:round;stroke-width:4;stroke-dasharray:2 5}.salt-rim,.sugar-rim{stroke:#d2cdc0e6}@keyframes glassPulse{0%,to{opacity:.28;transform:scale(.99)}50%{opacity:.48;transform:scale(1.02)}}@keyframes liquidBreathe{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes spiritListen{0%{stroke-dashoffset:150;opacity:.22}45%{stroke-dashoffset:0;opacity:.82}to{stroke-dashoffset:-150;opacity:.22}}@keyframes swirlThink{0%{stroke-dashoffset:120}55%{stroke-dashoffset:0}to{stroke-dashoffset:-120}}@keyframes bubbleRise{0%{opacity:0;transform:translateY(10px) scale(.8)}35%{opacity:.86}to{opacity:0;transform:translateY(-20px) scale(1.08)}}@keyframes rimListening{0%,to{opacity:.38}50%{opacity:.82}}@keyframes revealSweep{0%{stroke-dashoffset:130;opacity:0}40%,70%{opacity:.8}to{stroke-dashoffset:-130;opacity:0}}@keyframes glassReady{0%,to{opacity:.42;transform:translateY(0)}50%{opacity:.95;transform:translateY(-1px)}}@keyframes liquidPour{0%,to{transform:translateY(0) scaleY(.98)}50%{transform:translateY(-2px) scaleY(1.03)}}@keyframes liquidStir{0%,to{transform:translate(0) rotate(0)}35%{transform:translate(-2px) rotate(-1.4deg)}70%{transform:translate(2px) rotate(1.4deg)}}@keyframes iceSettle{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes iceSwirl{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(3px) rotate(2deg)}}@keyframes cocktailBubbleRise{0%{opacity:0;transform:translateY(8px) scale(.9)}45%{opacity:.9}to{opacity:0;transform:translateY(-16px) scale(1.08)}}@keyframes garnishPresent{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-2px) rotate(-1.5deg)}}@media(prefers-reduced-motion:reduce){.cocktail-motion-prepare .glass-highlight,.cocktail-motion-add .drink-liquid,.cocktail-motion-add .ice-layer rect,.cocktail-motion-stir .drink-liquid,.cocktail-motion-stir .ice-layer,.cocktail-motion-finish .bubble-layer circle,.cocktail-motion-finish .garnish-layer{animation:none}}@media(max-width:720px){.app-shell{padding:0}.phone-frame{width:100%;height:100vh;min-height:100vh;border:none;border-radius:0;box-shadow:none}}@media(max-width:380px){.screen{padding-inline:18px}.glass-stage{min-height:190px}.choice-grid{gap:8px}.home-hero-copy h1,.section-heading h2{font-size:21px}.shopping-grid,.hero-recommendation-card{grid-template-columns:1fr}.hero-recommendation-card .cocktail-visual{width:min(78%,220px);margin:0 auto}}.chat-top-bar{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-top-bar .icon-back{margin-bottom:0}.chat-title{font-size:15px;font-weight:600;color:#3b3932}.chat-title-spacer{width:34px}.chat-messages-area{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:10px 0 14px;scroll-behavior:smooth}.chat-message{display:flex;gap:8px;max-width:100%}.chat-message.user-message{justify-content:flex-end}.chat-message.ai-message{justify-content:flex-start;align-items:flex-start}.chat-avatar{flex-shrink:0;width:32px;height:32px;margin-top:2px}.chat-avatar .listening-glass{width:32px;height:32px}.chat-bubble-content{display:flex;flex-direction:column;gap:8px;min-width:0;max-width:85%}.chat-bubble{display:grid;gap:6px;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.6;color:#3d3b34}.chat-bubble p{margin:0}.ai-bubble{background:#ffffffc7;border:1px solid rgba(138,132,113,.15);border-top-left-radius:4px;box-shadow:0 2px 8px #3630220a}.user-bubble{background:#e2ecd6b8;border:1px solid rgba(139,156,108,.18);border-top-right-radius:4px;max-width:82%}.thinking-bubble{padding:12px 17px;min-width:70px}.thinking-dots{display:flex;gap:4px;align-items:center;justify-content:center}.thinking-dots span{width:6px;height:6px;border-radius:50%;background:#bbb7a8;animation:dotPulse 1.4s ease-in-out infinite}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.25;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.cursor-blink{color:#8a8578;font-weight:300;animation:cursorBlink .8s step-end infinite}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.thinking-inline{border:1px solid rgba(138,132,113,.14);border-radius:12px;background:#fcfcf8cc;overflow:hidden}.thinking-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;font-size:12px;color:#6b6760;cursor:pointer;text-align:left;font-family:inherit}.thinking-toggle:hover{background:#00000005}.thinking-dot{width:8px;height:8px;border-radius:50%;background:#c8d6b0;flex-shrink:0;animation:dotPulse 2s ease-in-out infinite}.thinking-chevron{margin-left:auto;font-size:10px;color:#a09b8e;transition:transform .2s ease}.thinking-chevron.open{transform:rotate(180deg)}.thinking-steps{padding:0 12px 10px;display:flex;flex-direction:column;gap:6px}.thinking-step{display:flex;gap:8px;padding:6px 0;border-top:1px solid rgba(138,132,113,.08)}.thinking-step:first-child{border-top:none}.thinking-step-num{display:grid;place-items:center;width:18px;height:18px;border-radius:999px;background:#e8f0db;color:#6b7d4e;font-size:10px;font-weight:600;flex-shrink:0;margin-top:1px}.thinking-step strong{display:block;font-size:12px;font-weight:600;color:#3b3932;margin-bottom:2px}.thinking-step p{margin:0;font-size:11px;line-height:1.5;color:#767165}.examples-bar{margin-top:8px}.chat-input-card{flex-shrink:0;display:grid;gap:10px;padding:12px 0 0;border-top:1px solid rgba(138,132,113,.1);margin-top:auto}.chat-input-card textarea{border:1px solid var(--soft-line);border-radius:14px;padding:10px 12px;background:#ffffffc7;color:#3d3b34;font:inherit;font-size:14px;resize:none;line-height:1.5}.chat-input-card textarea::placeholder{color:#b5b0a4}.chat-bubble-content .chat-recommendations{margin-top:4px}.chat-bubble-content .soft-warning{margin-top:4px;padding:8px 12px;border-radius:10px;background:#fff3cdb3;color:#8a6d3b;font-size:13px;line-height:1.5}.chat-bubble,.chat-bubble-content .chat-bubble{margin-top:0}.chat-rec-ingredients{margin:0;color:#6b6760;font-size:13px;line-height:1.55;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.thinking-dot.live{animation:thinkingDotLive 1s ease-in-out infinite;background:#9bb87c}@keyframes thinkingDotLive{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}.thinking-step.latest{animation:stepFadeIn .35s ease-out}@keyframes stepFadeIn{0%{opacity:.4;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.connection-status-trigger{position:fixed;top:12px;right:16px;z-index:1000;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:#141210d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.connection-status-trigger:hover{transform:scale(1.1);box-shadow:0 0 12px #f5cf8a4d}.connection-dot{position:absolute;bottom:2px;right:2px;width:10px;height:10px;border-radius:50%;border:2px solid rgba(20,18,16,.9)}.connection-dot.ok{background:#6abf69}.connection-dot.degraded{background:#f0a040}.connection-dot.fail{background:#e05555}.connection-modal-overlay{position:fixed;inset:0;z-index:2000;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.connection-modal{background:#1e1c1a;border:1px solid rgba(255,255,255,.12);border-radius:16px;width:min(380px,90vw);max-height:80vh;overflow-y:auto;box-shadow:0 16px 48px #00000080}.connection-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.connection-modal-header h3{margin:0;font-size:16px;color:#e8e0d5}.connection-modal-header button{background:none;border:none;color:#8a8478;font-size:18px;cursor:pointer}.connection-modal-header button:hover{color:#e8e0d5}.connection-modal-body{padding:16px 20px 20px}.connection-note{color:#8a8478;font-size:13px;margin:0 0 8px}.connection-url{color:#b8b0a0;font-size:12px;margin:0 0 12px;word-break:break-all}.connection-loading{display:flex;align-items:center;gap:10px;color:#b8b0a0;font-size:14px;padding:16px 0}.connection-loading .thinking-dot{width:8px;height:8px;border-radius:50%;background:#9bb87c;animation:connectionPulse 1s ease-in-out infinite}@keyframes connectionPulse{0%,to{opacity:.4}50%{opacity:1}}.thinking-dot.live{animation:connectionPulse 1s ease-in-out infinite}.connection-overall{font-size:15px;font-weight:600;padding:10px 14px;border-radius:10px;margin-bottom:14px}.connection-overall.ok{background:#6abf6926;color:#6abf69}.connection-overall.degraded{background:#f0a04026;color:#f0a040}.connection-overall.fail{background:#e0555526;color:#e05555}.connection-checks{list-style:none;margin:0 0 12px;padding:0}.connection-check{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:10px;margin-bottom:6px;background:#ffffff08}.connection-check.ok{border-left:3px solid #6abf69}.connection-check.fail{border-left:3px solid #e05555}.connection-check.pending{border-left:3px solid #555}.connection-check.checking{border-left:3px solid #f0a040}.check-icon{font-size:16px;flex-shrink:0;margin-top:1px}.connection-check div{flex:1;min-width:0}.connection-check strong{display:block;font-size:13px;color:#d8d0c0;margin-bottom:2px}.connection-check small{display:block;font-size:11px;color:#8a8478;word-break:break-all}.connection-timestamp{color:#5a5450;font-size:11px}.llm-chat-bubble{margin-top:12px;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.6}.llm-chat-label{font-size:11px;font-weight:600;margin-bottom:6px;color:#8a8478}.llm-chat-bubble p{margin:0;color:#d8d0c0;white-space:pre-wrap;word-break:break-word}.llm-chat-bubble.user-bubble{background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.llm-chat-bubble.ai-bubble{background:#9bb87c1a;border:1px solid rgba(155,184,124,.15)}.llm-chat-bubble.error-bubble{background:#e055551a;border:1px solid rgba(224,85,85,.2)}.llm-chat-bubble.error-bubble p{color:#e05555}.thinking-dot.done{animation:none;background:#6abf69}.thinking-step.fallback{border-left:3px solid #f0a040;padding-left:8px;margin-left:-4px;background:#f0a0400f;border-radius:0 8px 8px 0}.thinking-step.fallback .thinking-step-num{background:#f0a04026;color:#f0a040}.thinking-step.fallback strong{color:#f0a040}.thinking-bubble{display:flex;align-items:center;gap:10px;padding:12px 16px}.thinking-bubble .thinking-dot{width:8px;height:8px;border-radius:50%;background:#9bb87c;flex-shrink:0;animation:dotPulse 1s ease-in-out infinite}.thinking-bubble .thinking-dot.live{animation:connectionPulse 1s ease-in-out infinite}.thinking-bubble span:not(.thinking-dot){color:#b8b0a0;font-size:13px}.thinking-dot.done{animation:none!important;background:#6abf69}.thinking-done-bar{display:flex;align-items:center;gap:8px;padding:4px 0 8px;font-size:12px;color:#8a8478}.thinking-done-bar .thinking-dot.done{animation:none;background:#6abf69;width:7px;height:7px}.thinking-done .thinking-toggle{background:transparent;border:none;padding:4px 0 8px;font-size:12px;color:#8a8478;cursor:pointer}.thinking-done .thinking-toggle:hover{color:#b8b0a0}.thinking-done .thinking-dot.done{animation:none;background:#6abf69;width:7px;height:7px}.thinking-done .thinking-steps{padding:4px 0 0}.thinking-done-bar{display:none}
