.spirit-pills{display:flex;gap:8px;overflow-x:auto;padding:4px 0;scrollbar-width:none;-webkit-overflow-scrolling:touch}.spirit-pills::-webkit-scrollbar{display:none}.spirit-pill{flex-shrink:0;padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.8rem;cursor:pointer;min-height:var(--tap-target);display:flex;align-items:center;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}.spirit-pill:hover{border-color:var(--accent);color:var(--text-primary)}.spirit-pill[data-active=true]{background:var(--accent);border-color:var(--accent);color:#fff}.filter-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.filter-drawer{position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-top:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:20px 16px;z-index:101;max-height:80vh;overflow-y:auto;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.filter-drawer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.filter-drawer-title{font-size:1.1rem;font-weight:500}.filter-drawer-close{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;min-width:var(--tap-target);min-height:var(--tap-target);display:flex;align-items:center;justify-content:center}.filter-section{margin-bottom:20px}.filter-section-label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);letter-spacing:1.5px;margin-bottom:10px}.filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{padding:6px 12px;border-radius:16px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.78rem;cursor:pointer;min-height:36px;display:flex;align-items:center;transition:background .2s,color .2s,border-color .2s}.filter-chip:hover{border-color:var(--accent)}.filter-chip[data-active=true]{background:var(--accent);border-color:var(--accent);color:#fff}.filter-drawer-actions{display:flex;gap:8px;margin-top:20px}.filter-drawer-btn{flex:1;min-height:var(--tap-target);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9rem;cursor:pointer;transition:background .2s}.filter-drawer-clear{border:1px solid var(--border);background:transparent;color:var(--text-secondary)}.filter-drawer-done{border:none;background:var(--accent);color:#fff;font-weight:600}@media(min-width:1024px){.filter-drawer{position:fixed;top:0;right:0;bottom:0;left:auto;width:360px;border-radius:0;border-top:none;border-left:1px solid var(--border);animation:slideLeft .25s ease}@keyframes slideLeft{0%{transform:translate(100%)}to{transform:translate(0)}}}.filter-badges{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0}.filter-badge{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);font-size:.72rem;cursor:pointer;transition:border-color .2s}.filter-badge:hover{border-color:var(--accent)}.filter-badge-x{font-size:.65rem;color:var(--text-muted);margin-left:2px}.blueprint{display:block}.blueprint-layer{transition:opacity .3s ease}.blueprint-label{font-family:var(--font-mono);letter-spacing:2px;pointer-events:none;-webkit-user-select:none;user-select:none}.blueprint-measurement{font-family:var(--font-mono);pointer-events:none}.blueprint-ratio-bar{transition:opacity .3s ease}.drink-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:border-color .2s,transform .15s;text-decoration:none;color:inherit;display:block}.drink-card:hover{border-color:var(--accent);transform:translateY(-2px)}.drink-card-thumbnail{background:var(--bg-blueprint);padding:12px;display:flex;align-items:center;justify-content:center;aspect-ratio:4 / 3}.drink-card-thumbnail .blueprint{width:100%;height:100%;max-height:120px}.drink-card-body{padding:10px 12px;display:flex;flex-direction:column;gap:2px}.drink-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:4px}.drink-card-name{font-size:.85rem;font-weight:500;line-height:1.3}.drink-card-heart{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1rem;padding:2px;min-width:var(--tap-target);min-height:var(--tap-target);display:flex;align-items:center;justify-content:center;margin:-8px -8px -8px 0;transition:color .2s}.drink-card-heart[data-favorited=true]{color:var(--favorite)}.drink-card-desc{font-size:.72rem;color:var(--text-muted);line-height:1.4}.drink-card-meta{display:flex;gap:6px;margin-top:4px;flex-wrap:wrap}.drink-card-tag{padding:2px 6px;border-radius:8px;border:1px solid var(--border);font-size:.6rem;color:var(--text-muted);font-family:var(--font-mono)}.drink-card-tag-spirit{border-color:var(--accent);color:var(--accent)}.home{max-width:var(--max-width);margin:0 auto;padding:20px 16px}.home-header{text-align:center;margin-bottom:20px}.home-header-row{display:flex;align-items:center;justify-content:center;gap:12px}.home-brand{font-size:1.5rem;font-weight:300;letter-spacing:3px;color:var(--text-primary)}.home-theme-toggle{background:none;border:1px solid var(--border);border-radius:50%;width:32px;height:32px;font-size:.9rem;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:border-color .2s,color .2s}.home-theme-toggle:hover{border-color:var(--accent);color:var(--text-primary)}.home-count{font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono);margin-top:2px}.home-search-row{display:flex;gap:8px;margin-bottom:12px}.home-search{flex:1;height:var(--tap-target);padding:0 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-input);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;outline:none;transition:border-color .2s}.home-search::placeholder{color:var(--text-muted)}.home-search:focus{border-color:var(--accent)}.home-action-btn{width:var(--tap-target);height:var(--tap-target);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,color .2s;flex-shrink:0;position:relative}.home-action-btn:hover{border-color:var(--accent)}.home-action-btn[data-active=true]{color:var(--favorite);border-color:var(--favorite)}.home-filter-count{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#fff;font-size:.55rem;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono)}.home-pills{margin-bottom:8px}.home-badges{margin-bottom:12px}.home-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.home-empty{grid-column:1 / -1;text-align:center;padding:40px 16px;color:var(--text-muted);font-size:.9rem}.home-footer{text-align:center;padding:32px 0 16px;font-size:.72rem;color:var(--text-muted)}.home-footer a{color:var(--accent);text-decoration:none}.home-footer a:hover{text-decoration:underline}@media(min-width:768px){.home{padding:32px 24px}.home-grid{grid-template-columns:repeat(3,1fr);gap:16px}}@media(min-width:1024px){.home-grid{grid-template-columns:repeat(4,1fr)}}.drink-detail{max-width:var(--max-width);margin:0 auto;padding:16px}.drink-detail-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.drink-detail-back{background:none;border:none;color:var(--accent);font-size:1.2rem;cursor:pointer;min-width:var(--tap-target);min-height:var(--tap-target);display:flex;align-items:center;justify-content:center}.drink-detail-title{font-size:1.1rem;font-weight:400;letter-spacing:2px;text-align:center;flex:1}.drink-detail-fav{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-muted);min-width:var(--tap-target);min-height:var(--tap-target);display:flex;align-items:center;justify-content:center}.drink-detail-fav[data-favorited=true]{color:var(--favorite)}.drink-detail-blueprint{background:var(--bg-blueprint);border-radius:var(--radius-lg);border:1px solid var(--border);padding:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.drink-detail-blueprint .blueprint{max-width:220px;width:100%;height:auto}.drink-detail-section{margin-bottom:20px}.drink-detail-label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);letter-spacing:1.5px;margin-bottom:8px}.drink-detail-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.drink-detail-badge{padding:4px 10px;border-radius:12px;border:1px solid var(--border);font-size:.72rem;color:var(--text-secondary);font-family:var(--font-mono)}.drink-detail-badge-spirit{border-color:var(--accent);color:var(--accent)}.drink-detail-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}.drink-detail-tag{padding:3px 8px;border-radius:10px;border:1px solid var(--border);font-size:.65rem;color:var(--text-muted)}.drink-detail-list{list-style:none;display:flex;flex-direction:column;gap:6px}.drink-detail-list li{font-size:.85rem;color:var(--text-primary)}.drink-detail-list li span{color:var(--text-muted);font-family:var(--font-mono);font-size:.75rem}.drink-detail-steps{list-style:none;display:flex;flex-direction:column;gap:8px}.drink-detail-step{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border)}.drink-detail-step-num{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);font-weight:600;flex-shrink:0;min-width:20px}.drink-detail-step-text{font-size:.82rem;color:var(--text-primary);line-height:1.4}.drink-detail-step-timer{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);margin-top:2px}.drink-detail-mix-btn{display:block;width:100%;padding:14px;border:none;border-radius:var(--radius-md);background:var(--accent);color:#fff;font-family:var(--font-body);font-size:1rem;font-weight:600;letter-spacing:1px;cursor:pointer;min-height:var(--tap-target);transition:background .2s;margin-top:24px;text-align:center;text-decoration:none}.drink-detail-mix-btn:hover{background:var(--accent-hover)}@media(min-width:1024px){.drink-detail-content{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}.drink-detail-blueprint{position:sticky;top:20px}}.timer{display:flex;flex-direction:column;align-items:center;gap:12px}.timer-circle{position:relative;width:160px;height:160px}.timer-svg{transform:rotate(-90deg);width:100%;height:100%}.timer-track{fill:none;stroke:var(--border);stroke-width:4}.timer-progress{fill:none;stroke:var(--accent);stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .3s linear}.timer-progress[data-finished=true]{stroke:var(--success)}.timer-display{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:2rem;font-weight:500;color:var(--text-primary)}.timer-display[data-finished=true]{color:var(--success)}.timer-controls{display:flex;gap:8px}.timer-btn{min-width:var(--tap-target);min-height:var(--tap-target);padding:10px 24px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;cursor:pointer;transition:background .2s,border-color .2s}.timer-btn:hover{border-color:var(--accent)}.timer-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.timer-btn-primary:hover{background:var(--accent-hover)}.mix-mode{min-height:100dvh;background:var(--bg-primary);display:flex;flex-direction:column;padding:16px;max-width:600px;margin:0 auto}.mix-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.mix-exit{background:none;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;min-height:var(--tap-target);min-width:var(--tap-target);display:flex;align-items:center;justify-content:center}.mix-progress-text{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.mix-blueprint{background:var(--bg-blueprint);border-radius:var(--radius-lg);border:1px solid var(--border);padding:12px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.mix-blueprint .blueprint{max-width:180px;width:100%}.mix-step{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}.mix-step-num{font-family:var(--font-mono);font-size:3rem;font-weight:200;color:var(--accent);line-height:1}.mix-step-instruction{font-size:1.2rem;line-height:1.5;color:var(--text-primary);max-width:400px}.mix-step-detail-toggle{background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;padding:4px 8px;min-height:var(--tap-target);display:flex;align-items:center}.mix-step-detail{font-size:.85rem;color:var(--text-secondary);line-height:1.6;max-width:400px;padding:12px 16px;background:var(--bg-card);border-radius:var(--radius-sm);text-align:left}.mix-timer-section{margin:16px 0}.mix-nav{display:flex;gap:12px;padding:16px 0;margin-top:auto}.mix-nav-btn{flex:1;min-height:56px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-family:var(--font-body);font-size:1rem;cursor:pointer;transition:background .2s,border-color .2s}.mix-nav-btn:hover{border-color:var(--accent)}.mix-nav-btn:disabled{opacity:.3;cursor:not-allowed}.mix-nav-btn-next{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.mix-nav-btn-next:hover{background:var(--accent-hover)}.mix-done{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center}.mix-done-icon{font-size:3rem}.mix-done-text{font-size:1.3rem;color:var(--text-primary)}.mix-done-sub{color:var(--text-muted);font-size:.9rem}.mix-dots{display:flex;gap:6px;justify-content:center;margin-bottom:16px}.mix-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.mix-dot[data-active=true]{background:var(--accent)}.mix-dot[data-done=true]{background:var(--text-muted)}:root{--font-mono: "SF Mono", "Fira Code", "Fira Mono", monospace;--font-body: system-ui, -apple-system, sans-serif;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--tap-target: 44px;--max-width: 1200px;--accent: #c67c4e;--accent-hover: #d4915f;--favorite: #c67c4e;--success: #4ade80}:root,[data-theme=dark]{--bg-primary: #0d1117;--bg-card: #1a2332;--bg-input: #1a2332;--bg-blueprint: #141e2b;--border: #2a3040;--text-primary: #e2e8f0;--text-secondary: #8b9bb4;--text-muted: #64748b;--blueprint-stroke: #e2e8f0;--blueprint-measure: #64748b;color-scheme:dark}[data-theme=light]{--bg-primary: #f8f6f3;--bg-card: #ffffff;--bg-input: #ffffff;--bg-blueprint: #eae6df;--border: #ddd7ce;--text-primary: #1c1917;--text-secondary: #57534e;--text-muted: #a8a29e;--blueprint-stroke: #44403c;--blueprint-measure: #78716c;color-scheme:light}@media(prefers-color-scheme:light){:root:not([data-theme]){--bg-primary: #f8f6f3;--bg-card: #ffffff;--bg-input: #ffffff;--bg-blueprint: #eae6df;--border: #ddd7ce;--text-primary: #1c1917;--text-secondary: #57534e;--text-muted: #a8a29e;--blueprint-stroke: #44403c;--blueprint-measure: #78716c;color-scheme:light}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}#root{min-height:100dvh}
