.cocktail-lab{max-width:720px;margin:0 auto;padding:0 var(--space-md) var(--space-2xl)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.lab-steps{display:flex;flex-direction:column;gap:var(--space-xl)}.lab-section{background:var(--bg-secondary, #1a1020);border:1px solid rgba(201,165,90,.12);border-radius:8px;padding:var(--space-lg)}.step-label{display:block;margin-bottom:var(--space-xs)}.step-heading{font-family:var(--font-heading);font-size:1.2rem;color:var(--accent-gold, #c9a55a);margin:0 0 var(--space-md)}.base-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--space-sm)}.base-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-sm);background:var(--bg-tertiary, #2a1530);border:1px solid rgba(201,165,90,.12);border-radius:6px;cursor:pointer;text-align:center;transition:background .2s ease,border-color .2s ease}.base-btn:hover{background:#c9a55a0f;border-color:#c9a55a4d}.base-btn.selected{background:#c9a55a1f;border-color:var(--accent-gold, #c9a55a)}.base-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.base-icon{font-size:1.6rem;line-height:1}.base-label{font-size:.875rem;font-weight:600;color:var(--text-primary, #d4d4d4)}.base-badge{font-size:.65rem;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--accent-gold, #c9a55a);opacity:.8}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-sm)}.color-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-sm);background:var(--bg-tertiary, #2a1530);border:1px solid rgba(201,165,90,.12);border-radius:6px;cursor:pointer;text-align:center;transition:background .2s ease,border-color .2s ease}.color-btn:hover{background:#c9a55a0f;border-color:#c9a55a4d}.color-btn.selected{background:#c9a55a1a;border-color:var(--accent-gold, #c9a55a)}.color-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.color-swatch{display:block;width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.15);flex-shrink:0}.color-label{font-size:.875rem;font-weight:600;color:var(--text-primary, #d4d4d4)}.color-hint{font-size:.7rem;color:var(--text-muted, #888);line-height:1.3}.vibe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-sm)}.vibe-btn{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:var(--space-md);background:var(--bg-tertiary, #2a1530);border:1px solid rgba(201,165,90,.12);border-radius:6px;cursor:pointer;text-align:left;transition:background .2s ease,border-color .2s ease}.vibe-btn:hover{background:#c9a55a0f;border-color:#c9a55a4d}.vibe-btn.selected{background:#c9a55a1f;border-color:var(--accent-gold, #c9a55a)}.vibe-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.vibe-icon{font-size:1.3rem;line-height:1}.vibe-name{font-size:.9rem;font-weight:600;color:var(--text-primary, #d4d4d4)}.vibe-desc{font-size:.72rem;color:var(--text-muted, #888);line-height:1.4}.mix-cta{display:flex;justify-content:center;padding-top:var(--space-md)}.mix-btn{font-size:1.05rem;padding:var(--space-md) var(--space-xl);letter-spacing:.03em}.recipe-result{display:flex;flex-direction:column;gap:0;border-radius:8px;overflow:hidden;border:1px solid rgba(201,165,90,.18)}.recipe-color-bar{height:6px;width:100%;flex-shrink:0}.recipe-card{background:var(--bg-secondary, #1a1020);padding:var(--space-xl)}.recipe-header{margin-bottom:var(--space-xl)}.recipe-name{font-family:var(--font-heading);font-size:1.8rem;color:var(--accent-gold, #c9a55a);margin:0 0 var(--space-sm)}.recipe-tags{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.recipe-tag{font-size:.75rem;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary, #aaa);background:var(--bg-tertiary, #2a1530);border:1px solid rgba(201,165,90,.1);border-radius:4px;padding:2px 8px}.recipe-section{margin-bottom:var(--space-lg)}.recipe-section-label{display:block;margin-bottom:var(--space-sm);font-size:.65rem}.ingredients-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-xs)}.ingredient-row{display:flex;align-items:baseline;gap:var(--space-md);padding:var(--space-xs) 0;border-bottom:1px solid rgba(201,165,90,.06)}.ingredient-amount{font-family:var(--font-mono);font-size:.8rem;font-weight:700;color:var(--accent-gold, #c9a55a);min-width:52px;flex-shrink:0}.ingredient-item{font-size:.9rem;color:var(--text-primary, #d4d4d4)}.recipe-text{font-size:.9rem;color:var(--text-secondary, #aaa);line-height:1.65;margin:0}.recipe-actions{display:flex;gap:var(--space-md);flex-wrap:wrap;margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid rgba(201,165,90,.08)}.share-btn,.mix-another-btn{flex:1;min-width:140px;justify-content:center}.dry-ice-panel{background:#e87d0d14;border:1px solid rgba(232,125,13,.3);border-top:none;padding:var(--space-xl)}.dry-ice-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.dry-ice-icon{font-size:1.4rem;line-height:1}.dry-ice-title{font-family:var(--font-heading);font-size:1.1rem;color:#e87d0d;margin:0}.dry-ice-body{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl)}.dry-ice-col-label{display:block;color:#e87d0d;font-size:.62rem;margin-bottom:var(--space-sm)}.dry-ice-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-sm)}.dry-ice-list li{font-size:.82rem;color:var(--text-secondary, #aaa);line-height:1.55;padding-left:var(--space-md);position:relative}.dry-ice-list li:before{content:"–";position:absolute;left:0;color:#e87d0d}@media(prefers-reduced-motion:reduce){.base-btn,.color-btn,.vibe-btn{transition:none}}@media(max-width:520px){.cocktail-lab{padding-left:var(--space-sm);padding-right:var(--space-sm)}.lab-section{padding:var(--space-md)}.base-grid{grid-template-columns:repeat(3,1fr)}.color-grid,.vibe-grid{grid-template-columns:repeat(2,1fr)}.recipe-card{padding:var(--space-lg) var(--space-md)}.dry-ice-body{grid-template-columns:1fr}.recipe-actions{flex-direction:column}.share-btn,.mix-another-btn{width:100%}}
