:root{--bg-primary: #0D0F12;--bg-secondary: #161920;--bg-card: rgba(255, 255, 255, .04);--bg-card-hover: rgba(255, 255, 255, .07);--bg-glass: rgba(22, 25, 32, .85);--bg-input: rgba(255, 255, 255, .06);--bg-input-focus: rgba(255, 255, 255, .09);--accent: #D4A053;--accent-light: #E8C48A;--accent-dim: rgba(212, 160, 83, .12);--accent-glow: rgba(212, 160, 83, .25);--green: #2D8A6E;--green-dim: rgba(45, 138, 110, .12);--copper: #C17840;--burgundy: #8B2252;--emerald: #2D8A6E;--ice-blue: #6BA3BE;--text-primary: #F0ECE4;--text-secondary: rgba(240, 236, 228, .6);--text-tertiary: rgba(240, 236, 228, .35);--text-accent: var(--accent);--text-muted: rgba(240, 236, 228, .3);--border: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15);--border-accent: rgba(212, 160, 83, .3);--danger: #E74C3C;--danger-dim: rgba(231, 76, 60, .12);--success: #2ECC71;--success-dim: rgba(46, 204, 113, .12);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px var(--accent-glow);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--font-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-size-adjust:100%}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100dvh;overflow-x:hidden}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}input,button,textarea,select{font:inherit}h1{font-family:var(--font-display);font-size:1.625rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;line-height:1.2}h2{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary)}p{color:var(--text-secondary)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.app-shell{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg-primary);position:relative}.app-header{display:none;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.app-logo{display:flex;align-items:center;gap:var(--space-sm)}.app-logo h1{font-size:1.375rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.app-logo-icon-img{width:32px;height:32px;border-radius:var(--radius-sm)}.header-signout-btn{display:none}.desktop-nav{display:none;gap:var(--space-xs)}.nav-btn{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-full);cursor:pointer;font-weight:500;font-size:.875rem;transition:all var(--duration-fast)}.nav-btn:hover{background:var(--accent-dim);color:var(--text-primary)}.nav-btn.active{background:var(--accent);color:#fff;font-weight:600}.nav-icon{font-size:1rem}.sign-out-btn{color:var(--text-tertiary)}.sign-out-btn:hover{color:var(--danger);background:var(--danger-dim)}.upgrade-nav-btn{color:var(--accent);font-weight:600}.app-main{flex:1;padding:var(--space-md);padding-top:calc(var(--space-md) + env(safe-area-inset-top,0px));padding-bottom:calc(80px + var(--space-md) + env(safe-area-inset-bottom,0px));max-width:600px;width:100%;margin:0 auto;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.mobile-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;background:var(--bg-secondary);border-top:1px solid var(--border);padding:var(--space-sm) 0;padding-bottom:calc(var(--space-sm) + env(safe-area-inset-bottom,0px));z-index:100;box-shadow:0 -2px 10px #0000000a}.mobile-nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;border:none;background:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);min-width:56px;min-height:44px;transition:all var(--duration-fast)}.mobile-nav-btn.active{color:var(--accent)}.mobile-nav-icon{font-size:1.25rem;line-height:1}.mobile-nav-label{font-size:.625rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:10px 20px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-weight:600;font-size:.875rem;border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast);min-height:44px;font-family:var(--font-body);white-space:nowrap}.btn:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.btn-primary:hover{background:#e5961f;border-color:#e5961f}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:#0000000a;color:var(--text-primary)}.btn-danger{background:transparent;border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:var(--danger-dim)}.btn-danger-text{color:var(--danger)}.btn-sm{padding:6px 14px;font-size:.8rem;min-height:36px}.btn-feature{background:var(--accent-dim);border:1px solid rgba(246,166,35,.2);color:var(--accent);font-weight:600;border-radius:var(--radius-full);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:all .2s;font-size:.85rem;font-family:var(--font-body)}.btn-feature:hover{background:#f6a62326}.btn-edit{background:var(--accent-dim);border:1px solid rgba(246,166,35,.2);color:var(--accent);font-weight:600;border-radius:var(--radius-full);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:all .2s;font-family:var(--font-body);font-size:.875rem}.btn-edit:hover{background:#f6a62326}.btn-share{background:#4c9f7014;border:1px solid rgba(76,159,112,.2);color:var(--green);font-weight:600;border-radius:var(--radius-full);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:all .2s;font-family:var(--font-body);font-size:.875rem}.btn-share:hover{background:#4c9f701f}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;font-weight:600;font-size:.85rem;margin-bottom:var(--space-xs);color:var(--text-primary)}.form-input,input[type=text],input[type=email],input[type=password],input[type=number],textarea,select{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;transition:border-color var(--duration-fast),box-shadow var(--duration-fast)}.form-input:focus,input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}::placeholder{color:var(--text-tertiary)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236B7280' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}textarea{resize:vertical;min-height:80px;line-height:1.6}.form-submit{width:100%;margin-top:var(--space-lg)}.chip-group{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.chip{padding:6px 16px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--duration-fast);min-height:36px;display:inline-flex;align-items:center}.chip:hover{border-color:var(--accent);color:var(--text-primary)}.chip.active,.chip-active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);transition:all var(--duration-fast)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.toast{position:fixed;bottom:calc(80px + var(--space-lg) + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);background:var(--text-primary);color:#fff;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;box-shadow:var(--shadow-lg);z-index:200;animation:toastIn .3s var(--ease-bounce);white-space:nowrap}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f243066;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:150;display:flex;align-items:flex-end;justify-content:center;animation:overlayIn .2s ease-out;padding:0}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:500px;max-height:90dvh;overflow-y:auto;padding:var(--space-lg);padding-bottom:calc(var(--space-2xl) + env(safe-area-inset-bottom,0px));position:relative;animation:modalSlideUp .3s var(--ease-out);box-shadow:var(--shadow-lg)}@keyframes modalSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-close{position:absolute;top:var(--space-md);right:var(--space-md);background:var(--bg-primary);border:1px solid var(--border);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);font-size:1rem;z-index:10;transition:all var(--duration-fast)}.modal-close:hover{background:var(--danger-dim);color:var(--danger);border-color:var(--danger)}.modal-title{font-size:1.375rem;font-weight:700;padding-right:48px;margin-bottom:var(--space-xs)}.modal-section{margin-top:var(--space-lg)}.modal-section h3{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:var(--space-sm)}.modal-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border)}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-lg)}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.4}.empty-state h3{font-size:1.125rem;margin-bottom:var(--space-sm);color:var(--text-primary)}.empty-state p{color:var(--text-secondary);max-width:280px;margin:0 auto var(--space-lg);font-size:.9rem}.page-header{margin-bottom:var(--space-lg)}.page-header h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-xs)}.page-subtitle{color:var(--text-secondary);font-size:.9rem}.auth-screen{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--bg-primary)}.auth-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-2xl);width:100%;max-width:400px;box-shadow:var(--shadow-md);text-align:center}.auth-logo-icon{font-size:3rem;margin-bottom:var(--space-md)}.auth-logo-img{width:64px;height:64px;border-radius:var(--radius-lg);margin-bottom:var(--space-md)}.auth-card h1{font-size:1.75rem;margin-bottom:var(--space-xs)}.auth-tagline{color:var(--text-secondary);margin-bottom:var(--space-xl);font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:var(--space-md);text-align:left}.auth-form input{padding:14px 16px;border-radius:var(--radius-md)}.auth-form .btn{width:100%}.auth-toggle{margin-top:var(--space-md);font-size:.85rem;color:var(--text-secondary)}.auth-toggle button{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:.85rem}.auth-error{color:var(--danger);font-size:.85rem;padding:var(--space-sm);background:var(--danger-dim);border-radius:var(--radius-sm);text-align:center}.auth-consent{display:flex;align-items:flex-start;gap:var(--space-sm);font-size:.8rem;color:var(--text-secondary);cursor:pointer;padding:var(--space-xs) 0}.auth-consent input[type=checkbox]{margin-top:2px;accent-color:var(--accent);flex-shrink:0}.auth-consent a{color:var(--accent);text-decoration:underline}.auth-consent a:hover{color:#f4e28c}.auth-loading{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);background:var(--bg-primary);color:var(--text-secondary)}.auth-loading-icon{font-size:2.5rem;animation:pulse 2s infinite}.auth-loading-logo{width:300px;max-width:80vw;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.cocktail-grid{display:flex;flex-direction:column;gap:var(--space-sm)}.cocktail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);cursor:pointer;transition:all var(--duration-fast);box-shadow:var(--shadow-sm)}.cocktail-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm)}.card-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.favorite-btn{background:none;border:none;font-size:1.125rem;cursor:pointer;padding:4px;transition:transform .15s;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.favorite-btn:hover{transform:scale(1.15)}.spirit-badge{display:inline-flex;align-items:center;padding:3px 12px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-full);background:var(--accent-dim);color:var(--accent);border:1px solid rgba(246,166,35,.15);margin-bottom:var(--space-sm)}.spirit-badge-sm{font-size:.65rem;padding:2px 8px}.card-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:var(--space-xs)}.card-badges .spirit-badge{margin-bottom:0}.abv-badge{display:inline-flex;align-items:center;padding:3px 10px;font-size:.65rem;font-weight:600;letter-spacing:.02em;border-radius:var(--radius-full)}.abv-low{background:#4caf501f;color:#81c784;border:1px solid rgba(76,175,80,.2)}.abv-refreshing{background:#26c6da1f;color:#4dd0e1;border:1px solid rgba(38,198,218,.2)}.abv-strong{background:#ef6c4d1f;color:#ef6c4d;border:1px solid rgba(239,108,77,.2)}.card-ingredients{display:flex;flex-direction:column;gap:2px;margin-top:var(--space-sm);list-style:none;padding:0}.card-ingredients li{font-size:.8rem;color:var(--text-secondary);display:flex;gap:var(--space-sm);align-items:baseline;padding:2px 0}.card-ingredients .amount{color:var(--accent);font-weight:600;white-space:nowrap;min-width:48px;margin-right:4px}.card-garnish{font-size:.8rem;color:var(--text-secondary);margin-top:var(--space-xs);font-style:italic}.cocktail-actions-bar{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.btn-feature-compact{padding:6px 14px;font-size:.8rem;border-radius:var(--radius-full);background:var(--accent-dim);border:1px solid rgba(246,166,35,.15);color:var(--accent);font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font-body)}.btn-feature-compact:hover{background:#f6a62326}.premium-quick-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding:var(--space-md);margin-top:var(--space-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.search-wrapper{position:relative;margin-bottom:var(--space-md)}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);font-size:.9rem;pointer-events:none}.search-input{width:100%;padding:12px 16px 12px 40px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg-secondary);font-size:.9rem;color:var(--text-primary);transition:all var(--duration-fast)}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.filter-bar,.filter-row{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md);align-items:center}.filter-select,.form-select{padding:8px 32px 8px 14px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg-secondary);font-size:.8rem;color:var(--text-primary);cursor:pointer;font-weight:500;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236B7280' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.results-count{font-size:.8rem;color:var(--text-tertiary);margin-left:auto}.modal-ingredients{list-style:none}.ingredients-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.ingredients-header h3{margin:0}.serving-selector{display:flex;align-items:center;gap:var(--space-xs);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-full);padding:3px 5px}.serving-btn{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:var(--bg-secondary);color:var(--accent);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0;line-height:1}.serving-btn:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent)}.serving-btn:disabled{opacity:.3;cursor:not-allowed}.serving-count{font-size:.85rem;font-weight:600;color:var(--text-primary);min-width:75px;text-align:center}.serving-label{font-weight:400;color:var(--text-secondary);font-size:.8rem}.modal-ingredients li{padding:var(--space-sm) 0;font-size:.95rem;display:flex;gap:var(--space-md);border-bottom:1px solid var(--border)}.modal-ingredients li:last-child{border-bottom:none}.modal-ingredients .amount{color:var(--accent);font-weight:600;min-width:100px}.modal-instructions{font-size:.95rem;color:var(--text-secondary);line-height:1.8;white-space:pre-line}.modal-garnish{font-size:.95rem;color:var(--text-secondary);font-style:italic}.share-toast{position:absolute;bottom:var(--space-lg);left:50%;transform:translate(-50%);background:var(--success);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;white-space:nowrap;animation:toastIn .3s var(--ease-bounce)}.subs-list{margin-top:var(--space-sm)}.sub-item{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm)}.sub-original{font-size:.85rem;margin-bottom:var(--space-xs);color:var(--text-primary)}.sub-suggestion{display:flex;align-items:baseline;gap:var(--space-sm);padding:4px 0}.sub-arrow{color:var(--accent);font-weight:600}.sub-name{font-weight:500;font-size:.85rem}.sub-in-bar{color:var(--green)}.sub-tag{font-size:.7rem;background:var(--green-dim);color:var(--green);padding:2px 8px;border-radius:var(--radius-full);margin-left:var(--space-xs);font-weight:600}.sub-notes{font-size:.75rem;color:var(--text-tertiary);display:block;margin-top:2px}.subs-none{font-size:.85rem;color:var(--green);font-weight:500;padding:var(--space-sm) 0}.collection-picker,.shopping-picker{margin-top:var(--space-sm)}.picker-empty{font-size:.85rem;color:var(--text-tertiary);padding:var(--space-sm)}.picker-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:var(--space-sm)}.picker-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-xs);cursor:pointer;font-size:.9rem;transition:all var(--duration-fast);background:var(--bg-secondary);min-height:44px}.picker-item:hover{border-color:var(--accent)}.picker-item-active{background:var(--accent-dim);border-color:var(--accent)}.picker-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-sm)}.made-it-section{margin-top:var(--space-sm)}.made-it-inline{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:var(--space-sm)}.star-rating{display:flex;gap:4px}.star-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:0;transition:transform .15s;filter:grayscale(1) opacity(.3)}.star-btn.star-filled{filter:none}.star-btn:hover{transform:scale(1.2)}.made-it-notes{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);padding:var(--space-sm);font-family:var(--font-body);font-size:.85rem;resize:vertical;min-height:40px}.made-it-actions{display:flex;gap:var(--space-sm);align-items:center}.made-it-count{font-size:.8rem;color:var(--text-tertiary);margin-top:var(--space-xs)}.made-it-toast{color:var(--success);font-size:.85rem;font-weight:600}.spirits-container{padding:0}.spirit-count{font-size:.8rem;color:var(--text-tertiary);margin-bottom:var(--space-md)}.spirit-list{display:flex;flex-direction:column;gap:var(--space-sm)}.spirit-category-section{margin-bottom:var(--space-lg)}.spirit-category-header{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);padding:var(--space-xs) 0;margin-bottom:var(--space-sm);border-bottom:1px solid var(--border)}.spirit-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);transition:all var(--duration-fast)}.spirit-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.spirit-info{display:flex;justify-content:space-between;align-items:flex-start}.spirit-info h3{font-size:.95rem;font-weight:600}.spirit-name-editable{cursor:pointer;border-bottom:1px dashed transparent;transition:border-color .15s}.spirit-name-editable:hover{border-bottom-color:var(--accent)}.spirit-name-input{font-size:1rem;font-weight:700;color:var(--text-primary);background:var(--surface-2);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:2px 6px;width:100%;outline:none;font-family:inherit}.spirit-brand{font-size:.8rem;color:var(--text-secondary);margin:2px 0}.spirit-notes{font-size:.8rem;color:var(--text-tertiary);font-style:italic;margin-top:var(--space-xs)}.spirit-edit-links{display:flex;gap:var(--space-sm);margin-top:4px}.spirit-edit-link{font-size:.72rem;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:2px 0;transition:color .15s}.spirit-edit-link:hover{color:var(--accent)}.spirit-delete{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);border-radius:50%;transition:all var(--duration-fast);font-size:.9rem;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}.spirit-delete:hover{color:var(--danger);background:var(--danger-dim)}.fill-level-controls{margin-top:var(--space-sm)}.fill-bar{width:100%;height:6px;background:var(--border);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-xs)}.fill-bar-inner{height:100%;border-radius:var(--radius-full);transition:width .4s ease,background .3s}.fill-full{background:var(--green)}.fill-three-quarter{background:#6bbf8b}.fill-half{background:var(--accent)}.fill-quarter{background:#e8853a}.fill-empty{background:var(--danger)}.fill-buttons{display:flex;gap:4px}.fill-btn{flex:1;padding:4px;font-size:.65rem;font-weight:500;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast);min-height:32px}.fill-btn:hover{border-color:var(--accent);color:var(--text-primary)}.fill-btn-active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.add-spirit-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.spirit-form-row{display:flex;gap:var(--space-md);margin-bottom:var(--space-md)}.spirit-form-row .form-group{flex:1;margin-bottom:0}.spirit-form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.form-container{padding:0}.form-label{font-weight:600;font-size:.85rem;color:var(--text-primary);margin-bottom:var(--space-xs);display:block}.form-textarea{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;min-height:80px;resize:vertical;font-family:var(--font-body);line-height:1.6}.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.add-ingredient-btn{background:transparent;border:1px dashed var(--border);border-radius:var(--radius-md);color:var(--accent);font-weight:600;font-size:.85rem;padding:var(--space-sm) var(--space-md);cursor:pointer;width:100%;text-align:center;transition:all var(--duration-fast);font-family:var(--font-body);min-height:44px}.add-ingredient-btn:hover{border-color:var(--accent);background:var(--accent-dim)}.add-actions-row{display:flex;gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap}.btn-batch{background:var(--accent-dim);border:1px solid rgba(246,166,35,.2);color:var(--accent)}.btn-scan,.scan-recipe-btn{background:var(--green-dim);border:1px solid rgba(76,159,112,.2);color:var(--green)}.spinner-container{text-align:center;padding:var(--space-md) 0}.spinner-subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--space-lg)}.spinner-filter{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;margin-bottom:var(--space-lg)}.wheel-wrapper{position:relative;width:300px;height:300px;margin:0 auto var(--space-xl)}.wheel-pointer{position:absolute;top:-10px;left:50%;transform:translate(-50%);font-size:1.5rem;z-index:5;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.spin-btn{background:var(--accent);color:#fff;border:none;padding:14px 48px;border-radius:var(--radius-full);font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:var(--shadow-md);font-family:var(--font-body);min-height:48px}.spin-btn:hover{background:#e5961f;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.spin-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.winner-announcement{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--bg-card);border:2px solid var(--accent);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);animation:fadeIn .3s ease-out}.winner-announcement h3{font-size:1.25rem;margin-bottom:var(--space-sm)}.batch-container{padding:0}.batch-textarea{width:100%;min-height:120px;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;font-family:var(--font-body);line-height:1.6;resize:vertical}.batch-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.batch-input-section{margin-bottom:var(--space-lg)}.batch-tips{font-size:.8rem;color:var(--text-tertiary);margin-top:var(--space-sm)}.batch-review-section{margin-top:var(--space-lg)}.batch-review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.batch-review-count{font-size:.85rem;color:var(--text-secondary)}.batch-cards{display:flex;flex-direction:column;gap:var(--space-sm)}.batch-card-header{display:flex;gap:var(--space-sm);align-items:center}.batch-card-check{margin-right:var(--space-sm)}.batch-card-content{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm)}.batch-card-ingredients{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-xs)}.batch-card-garnish{font-size:.8rem;color:var(--text-secondary);font-style:italic;margin-top:4px}.batch-ing{font-size:.75rem;color:var(--text-secondary)}.batch-ing-amount{color:var(--accent);font-weight:500}.batch-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg)}.batch-select-all{margin-left:auto}.batch-parsing{text-align:center;padding:var(--space-xl)}.batch-spinner{font-size:2rem;animation:pulse 1.5s infinite}.batch-error{color:var(--danger);font-size:.85rem;padding:var(--space-sm);background:var(--danger-dim);border-radius:var(--radius-sm)}.batch-success{text-align:center;padding:var(--space-xl)}.batch-success-icon{font-size:3rem;margin-bottom:var(--space-md)}.menu-scanner-container{padding:0}.menu-scan-btn{width:100%;margin-top:var(--space-md)}.menu-rescan-btn{margin-top:var(--space-sm)}.menu-scanning-state{text-align:center;padding:var(--space-2xl)}.menu-empty-state{text-align:center;padding:var(--space-xl)}.menu-empty-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.4}.menu-pages-strip{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap;margin-top:var(--space-md)}.menu-page-thumb{position:relative;width:72px;height:96px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--accent);flex-shrink:0}.menu-page-thumb img{width:100%;height:100%;object-fit:cover}.menu-page-badge{position:absolute;bottom:2px;left:2px;background:var(--accent);color:var(--bg-primary);font-size:.65rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.menu-page-remove{position:absolute;top:2px;right:2px;background:#000000b3;color:#fff;border:none;font-size:.65rem;width:18px;height:18px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.menu-scan-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.menu-scan-actions .menu-scan-btn{flex:1;margin-top:0}.menu-submit-btn{background:var(--accent)!important}.menu-pages-hint{font-size:.8rem;color:var(--text-secondary);margin-top:var(--space-sm)}.scan-error,.detail-error{color:var(--danger);font-size:.85rem;padding:var(--space-sm);background:var(--danger-dim);border-radius:var(--radius-sm);margin-top:var(--space-sm)}.camera-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:200;display:flex;flex-direction:column}.camera-container{flex:1;display:flex;flex-direction:column;height:100%}.camera-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);padding-top:calc(var(--space-md) + env(safe-area-inset-top,0px));position:absolute;top:0;left:0;right:0;z-index:10;background:linear-gradient(to bottom,rgba(0,0,0,.5),transparent)}.camera-close-btn,.camera-flip-btn{background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;color:#fff;border-radius:50%;width:44px;height:44px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.camera-feed{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#000}.camera-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.camera-guide{position:absolute;top:12%;right:12%;bottom:12%;left:12%;pointer-events:none;z-index:5}.camera-guide-corner{position:absolute;width:24px;height:24px;border-color:#ffffff80;border-style:solid;border-width:0}.camera-guide-corner.tl{top:0;left:0;border-top-width:2px;border-left-width:2px;border-radius:4px 0 0}.camera-guide-corner.tr{top:0;right:0;border-top-width:2px;border-right-width:2px;border-radius:0 4px 0 0}.camera-guide-corner.bl{bottom:0;left:0;border-bottom-width:2px;border-left-width:2px;border-radius:0 0 0 4px}.camera-guide-corner.br{bottom:0;right:0;border-bottom-width:2px;border-right-width:2px;border-radius:0 0 4px}.camera-controls{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) var(--space-xl);padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom,0px));background:linear-gradient(to top,rgba(0,0,0,.6),transparent);position:absolute;bottom:0;left:0;right:0;z-index:10}.camera-library-btn{width:44px;height:44px;border-radius:var(--radius-sm);background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff}.camera-shutter{width:72px;height:72px;border-radius:50%;background:transparent;border:4px solid rgba(255,255,255,.6);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .15s}.camera-shutter:active{transform:scale(.92)}.camera-shutter-inner{width:56px;height:56px;border-radius:50%;background:#fff}.camera-preview{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg)}.camera-preview-img{max-width:100%;max-height:60vh;border-radius:var(--radius-lg);object-fit:contain}.camera-error{background:#dc354526;border:1px solid rgba(220,53,69,.4);color:#ff6b6b;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.85rem;text-align:center;margin-top:var(--space-sm)}.camera-preview-actions{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.camera-action-btn{min-width:120px}.camera-upload-btn{width:100%;margin-top:var(--space-md)}.camera-fallback{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-2xl);color:#fff}.camera-fallback-icon{font-size:3rem;margin-bottom:var(--space-md)}.camera-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-2xl);color:#fff}.camera-loading-spinner{font-size:2rem;animation:pulse 1.5s infinite}.camera-loading-shimmer{margin-top:var(--space-md);height:4px;width:200px;background:#ffffff1a;border-radius:var(--radius-full);overflow:hidden}.camera-loading-shimmer:after{content:"";display:block;height:100%;width:40%;background:#ffffff4d;border-radius:var(--radius-full);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(350%)}}.wcim-container{padding:0}.wcim-filters{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md)}.wcim-stats{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.wcim-stat{flex:1;text-align:center;padding:var(--space-sm);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md)}.wcim-stat-full{border-color:var(--green)}.wcim-stat-almost{border-color:var(--accent)}.wcim-stat-number{font-size:1.25rem;font-weight:700}.wcim-stat-label{font-size:.7rem;color:var(--text-tertiary)}.wcim-results{display:flex;flex-direction:column;gap:var(--space-sm)}.wcim-card-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.wcim-card-title{font-weight:600}.wcim-ingredients{display:flex;flex-wrap:wrap;gap:4px;margin-top:var(--space-sm)}.wcim-ing{font-size:.75rem;padding:2px 8px;border-radius:var(--radius-full)}.wcim-ing-have{background:var(--green-dim);color:var(--green)}.wcim-ing-missing{background:var(--danger-dim);color:var(--danger)}.collections-container{padding:0}.collections-add-btn{margin-bottom:var(--space-lg)}.collections-create{margin-bottom:var(--space-lg);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.collections-create-row{display:flex;gap:var(--space-sm);align-items:flex-end}.collections-emoji-picker{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.collections-list{display:flex;flex-direction:column;gap:var(--space-sm)}.collection-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--duration-fast)}.collection-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.collection-card-header{display:flex;justify-content:space-between;align-items:center}.collection-emoji{font-size:1.25rem;margin-right:var(--space-sm)}.collection-info h3{font-size:.95rem;font-weight:600}.collection-count{font-size:.8rem;color:var(--text-tertiary)}.collection-body{margin-top:var(--space-sm)}.collection-recipes{display:flex;flex-direction:column;gap:var(--space-xs);margin-top:var(--space-sm)}.collection-recipe-item{padding:var(--space-sm);background:var(--bg-primary);border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer;transition:background var(--duration-fast)}.collection-recipe-item:hover{background:var(--accent-dim)}.collection-empty{font-size:.8rem;color:var(--text-tertiary);font-style:italic;padding:var(--space-sm)}.collection-delete{margin-left:auto}.shopping-container{padding:0}.shopping-actions{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.shopping-group{margin-bottom:var(--space-md)}.shopping-group-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);font-weight:600;font-size:.9rem;color:var(--text-primary);border-bottom:1px solid var(--border)}.shopping-group-icon{font-size:1rem}.shopping-items{padding:var(--space-xs) 0}.shopping-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);transition:background var(--duration-fast);min-height:44px}.shopping-item:hover{background:var(--bg-card-hover)}.shopping-item-checked{opacity:.5}.shopping-check{font-size:1.1rem;cursor:pointer;min-width:32px;text-align:center}.shopping-item-info{flex:1;cursor:pointer}.shopping-item-name{font-size:.9rem;display:block}.shopping-item-done{text-decoration:line-through}.shopping-buy-toggle{font-size:.72rem;color:var(--accent);background:none;border:none;cursor:pointer;padding:2px 0;font-weight:500;display:block;margin-top:2px}.shopping-affiliate-links{display:flex;gap:8px;padding:8px 0 8px 36px;flex-wrap:wrap}.shopping-affiliate-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-full);background:var(--accent-dim);color:var(--accent);border:1px solid rgba(246,166,35,.15);font-size:.75rem;font-weight:600;text-decoration:none;transition:background .15s,transform .1s}.shopping-affiliate-btn:hover{background:#f6a62333;transform:scale(1.03)}.shopping-affiliate-btn:active{transform:scale(.97)}.shopping-item-remove{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:.85rem;padding:var(--space-xs);min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--duration-fast)}.shopping-item-remove:hover{color:var(--danger);background:var(--danger-dim)}.shopping-sub-btn{background:none;border:1px solid rgba(246,166,35,.2);color:var(--accent);font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);cursor:pointer;transition:all .2s;font-family:var(--font-body);margin-left:auto}.shopping-sub-btn:hover{background:var(--accent-dim)}.shopping-sub-suggestion{font-size:.75rem;color:var(--text-secondary);padding:4px 0 4px var(--space-xl);display:flex;gap:var(--space-xs);align-items:baseline}.shopping-sub-arrow{color:var(--accent);font-weight:600}.shopping-sub-name{font-weight:500}.shopping-sub-notes{color:var(--text-tertiary);font-size:.7rem}.history-container{padding:0}.history-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm);margin-bottom:var(--space-xl)}.history-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);text-align:center;box-shadow:var(--shadow-sm)}.history-stat-value{font-size:1.5rem;font-weight:700;color:var(--accent)}.history-stat-label{font-size:.75rem;color:var(--text-tertiary);margin-top:2px}.history-entry{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);box-shadow:var(--shadow-sm)}.history-entry-info h4{margin:0;font-size:.95rem}.history-entry-date{font-size:.75rem;color:var(--text-tertiary)}.history-entry-rating{font-size:.85rem;white-space:nowrap;color:var(--accent)}.history-entry-notes{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.restock-container{padding:0}.restock-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm);transition:border-color .2s}.restock-card:hover{border-color:var(--border-accent)}.restock-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-sm)}.restock-spirit-name{font-weight:600;font-size:1rem}.restock-spirit-brand{font-size:.8rem;color:var(--text-tertiary)}.restock-badge{background:var(--accent-dim);border:1px solid rgba(246,166,35,.2);color:var(--accent);font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:var(--radius-full);white-space:nowrap}.restock-recipes{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.restock-recipe-chip{font-size:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-full);padding:2px 10px;color:var(--text-secondary)}.restock-affiliate{display:block;margin-top:var(--space-sm);font-size:.75rem;color:var(--text-tertiary);font-style:italic}.restock-empty{text-align:center;padding:var(--space-2xl);color:var(--text-tertiary)}.upgrade-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f243080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;animation:overlayIn .2s ease-out}.upgrade-modal{background:var(--bg-secondary);border-radius:var(--radius-xl);padding:var(--space-2xl);max-width:420px;width:calc(100% - 32px);max-height:calc(100vh - 48px);overflow-y:auto;box-shadow:var(--shadow-lg);text-align:center;position:relative}.upgrade-close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;cursor:pointer;color:var(--text-tertiary);font-size:1.2rem}.upgrade-icon{font-size:2.5rem;margin-bottom:var(--space-md)}.upgrade-header h2{margin-bottom:var(--space-sm)}.upgrade-reason{color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--space-lg)}.upgrade-features{text-align:left;margin-bottom:var(--space-lg)}.upgrade-feature-row{display:flex;gap:var(--space-sm);align-items:center;padding:var(--space-sm) 0;font-size:.9rem}.upgrade-feature-icon{font-size:1.1rem}.upgrade-pricing{margin-bottom:var(--space-lg)}.upgrade-price-option{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-xs);cursor:pointer;transition:all var(--duration-fast)}.upgrade-price-option:hover{border-color:var(--border-hover)}.upgrade-price-option.selected{border-color:var(--accent);background:var(--accent-dim)}.upgrade-price-badge{font-size:.7rem;background:var(--accent);color:#fff;padding:2px 8px;border-radius:var(--radius-full);font-weight:600}.upgrade-price-amount{font-size:1.1rem;font-weight:700}.upgrade-price-period{font-size:.8rem;color:var(--text-tertiary)}.upgrade-cta{width:100%;margin-top:var(--space-md)}.upgrade-dismiss{background:none;border:none;color:var(--text-tertiary);font-size:.85rem;cursor:pointer;margin-top:var(--space-md);font-family:var(--font-body)}.auth-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-lg);background:var(--bg-primary);border-radius:var(--radius-full);padding:3px}.auth-tabs button{flex:1;padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-full);background:transparent;color:var(--text-secondary);font-weight:500;font-size:.85rem;cursor:pointer;transition:all var(--duration-fast);font-family:var(--font-body)}.auth-tabs button.active{background:var(--bg-secondary);color:var(--text-primary);font-weight:600;box-shadow:var(--shadow-sm)}.auth-success{color:var(--success);font-size:.85rem;padding:var(--space-sm);background:var(--success-dim);border-radius:var(--radius-sm);text-align:center}@media(min-width:768px){.app-header,.desktop-nav{display:flex}.mobile-nav,.header-signout-btn{display:none}.app-main{padding:var(--space-xl);padding-bottom:var(--space-xl);max-width:700px}.modal-content{border-radius:var(--radius-xl);max-width:500px}.modal-overlay{align-items:center;padding:var(--space-lg)}}.dashboard{padding:0}.dashboard-hero{background:linear-gradient(135deg,#d4a05333,#c1784026);border:1px solid var(--border-accent);border-radius:var(--radius-xl);padding:var(--space-2xl) var(--space-lg);text-align:center;color:#fff;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow-md);margin-bottom:var(--space-lg)}.dashboard-hero:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.dashboard-hero-emoji{font-size:2.5rem;margin-bottom:var(--space-sm)}.dashboard-hero-title{font-size:1.375rem;font-weight:700;color:#fff;margin-bottom:var(--space-xs)}.dashboard-hero-sub{font-size:.9rem;opacity:.9;margin-bottom:var(--space-md);color:#ffffffe6}.dashboard-hero-btn{background:var(--accent);border-color:var(--accent);color:#0d0f12}.dashboard-hero-btn:hover{background:var(--accent-light)}.dashboard-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}.dashboard-pill{flex:1 1 calc(50% - var(--space-sm));padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--duration-fast);font-family:var(--font-body);min-height:44px;display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.dashboard-pill:hover{border-color:var(--accent);background:var(--accent-dim)}.dashboard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm);margin-bottom:var(--space-lg)}.dashboard-stat{text-align:center;padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--duration-fast)}.dashboard-stat:hover{border-color:var(--accent)}.dashboard-stat-number{display:block;font-size:1.5rem;font-weight:700;color:var(--accent)}.dashboard-stat-label{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;font-weight:600;letter-spacing:.04em}.dashboard-section{margin-bottom:var(--space-lg)}.dashboard-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.dashboard-section-header h3{font-size:1rem}.dashboard-recent{display:flex;flex-direction:column;gap:var(--space-xs)}.dashboard-recent-card{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast)}.dashboard-recent-card:hover{border-color:var(--accent)}.dashboard-recent-name{font-weight:500;font-size:.9rem}.dashboard-recent-rating{color:var(--accent);font-size:.8rem}.dashboard-suggestions{display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard-suggestion-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast);box-shadow:var(--shadow-sm)}.dashboard-suggestion-card:hover{border-color:var(--accent)}.dashboard-suggestion-icon{font-size:1.5rem}.dashboard-suggestion-card strong{font-size:.9rem;display:block}.dashboard-suggestion-card p{font-size:.8rem;color:var(--text-tertiary);margin:0}.profile-container{padding:0}.profile-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.profile-avatar{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;font-size:1.25rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-info{flex:1;min-width:0}.profile-name{font-size:1rem;font-weight:600;word-break:break-all}.profile-badge{font-size:.7rem;font-weight:600;padding:2px 10px;border-radius:var(--radius-full);display:inline-block;margin-top:4px}.profile-badge-premium{background:var(--accent-dim);color:var(--accent)}.profile-badge-free{background:var(--bg-primary);color:var(--text-tertiary);border:1px solid var(--border)}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-bottom:var(--space-lg)}.profile-stat{text-align:center;padding:var(--space-sm);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md)}.profile-stat-number{display:block;font-size:1.25rem;font-weight:700;color:var(--accent)}.profile-stat-label{font-size:.65rem;color:var(--text-tertiary);text-transform:uppercase;font-weight:600;letter-spacing:.04em}.profile-menu{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-lg)}.profile-menu-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;font-weight:500;transition:all var(--duration-fast);font-family:var(--font-body);color:var(--text-primary);min-height:48px;width:100%;text-align:left}.profile-menu-item:hover{border-color:var(--accent);background:var(--accent-dim)}.profile-upgrade{background:linear-gradient(135deg,#d4a05314,#2d8a6e0f);border:1px solid var(--border-accent);border-radius:var(--radius-xl);padding:var(--space-xl);text-align:center;margin-bottom:var(--space-lg)}.profile-upgrade h3{margin-bottom:var(--space-xs)}.profile-upgrade p{font-size:.85rem;color:var(--text-secondary);margin-bottom:var(--space-md)}.profile-footer{text-align:center;padding:var(--space-md) 0}.fab{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom,0px));right:var(--space-md);width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 16px #f6a62366;z-index:90;display:flex;align-items:center;justify-content:center;transition:all .2s;font-weight:300;line-height:1}.fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #f6a62380}.fab:active{transform:scale(.95)}@media(min-width:768px){.fab{bottom:var(--space-xl)}}.restock-fill-label{font-size:.75rem;color:var(--text-tertiary);margin-top:2px}.filter-pills{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none;-webkit-overflow-scrolling:touch;margin-bottom:var(--space-xs)}.filter-pills::-webkit-scrollbar{display:none}.filter-pill{flex-shrink:0;padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s;white-space:nowrap}.filter-pill:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.filter-pill.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-light);font-weight:600}.meta-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);background:#ffffff0f;color:var(--text-secondary);font-size:.7rem;gap:3px;white-space:nowrap}.dashboard-greeting{padding:0 var(--space-md);margin-bottom:var(--space-sm)}.dashboard-greeting h2{font-size:1.4rem;font-weight:600;color:var(--text-primary);margin:0}.dashboard-tier-badge{display:inline-block;font-size:.55rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);margin-top:4px;letter-spacing:.03em}.dashboard-tier-founder{background:linear-gradient(135deg,#d4af37,#f4e28c);color:#1a1a2e}.dashboard-tier-premium{background:var(--accent-dim);color:var(--accent)}.form-row-2col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media(max-width:480px){.form-row-2col{grid-template-columns:1fr}}.dashboard-cotw{background:var(--bg-card);border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:var(--space-md);cursor:pointer;transition:all .2s}.dashboard-cotw:hover{background:var(--bg-card-hover);border-color:var(--accent);box-shadow:0 0 20px #d4a0531a}.dashboard-cotw-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:6px}.dashboard-cotw-detail{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dashboard-cotw-ings{font-size:.8rem;color:var(--text-secondary)}.profile-edit-row{display:flex;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);align-items:center}.profile-edit-row .form-input{flex:1;min-width:0}.profile-menu-item-disabled{opacity:.45;cursor:default;pointer-events:none}.coming-soon-tag{margin-left:auto;font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:var(--radius-full);background:var(--accent-dim);color:var(--accent-light);font-weight:600}.analytics-container{padding:var(--space-md);max-width:800px;margin:0 auto}.analytics-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.analytics-header h2{flex:1;margin:0;font-size:1.3rem}.analytics-error{text-align:center;padding:var(--space-xl);color:var(--text-secondary)}.analytics-error code{background:var(--bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);font-size:.85rem}.analytics-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-bottom:var(--space-lg)}.analytics-kpi{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;display:flex;flex-direction:column;gap:4px}.analytics-kpi-accent{border-color:var(--accent);background:var(--accent-dim)}.analytics-kpi-premium{border-color:var(--accent-light);background:linear-gradient(135deg,var(--accent-dim),rgba(212,160,83,.08))}.analytics-kpi-value{font-size:1.8rem;font-weight:700;color:var(--text-primary);line-height:1}.analytics-kpi-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.analytics-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md)}.analytics-card h3{margin:0 0 var(--space-sm) 0;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary)}.analytics-conversion-rate{font-size:3rem;font-weight:700;color:var(--accent);line-height:1.1;margin-bottom:var(--space-xs)}.analytics-stats-grid{display:flex;flex-direction:column;gap:2px}.analytics-stat-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0;border-bottom:1px solid var(--border);font-size:.9rem;color:var(--text-secondary)}.analytics-stat-row:last-child{border-bottom:none}.analytics-stat-row strong{color:var(--text-primary);font-variant-numeric:tabular-nums}.analytics-chart{display:flex;align-items:flex-end;gap:2px;height:120px;padding-top:var(--space-sm)}.analytics-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.analytics-bar{width:100%;min-height:2px;background:var(--accent);border-radius:2px 2px 0 0;transition:height .3s ease}.analytics-bar-label{font-size:.6rem;color:var(--text-tertiary);margin-top:4px;white-space:nowrap}.analytics-funnel{display:flex;flex-direction:column;gap:var(--space-xs)}.analytics-funnel-step{display:flex;align-items:center;gap:var(--space-sm)}.analytics-funnel-bar{height:28px;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:var(--bg-primary);min-width:28px;transition:width .5s ease}.analytics-funnel-label{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.analytics-funnel-pct{color:var(--accent);font-weight:600}.analytics-activity{display:flex;flex-direction:column;gap:2px}.analytics-activity-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;border-bottom:1px solid var(--border);font-size:.85rem}.analytics-activity-item:last-child{border-bottom:none}.analytics-activity-type{font-size:1rem;width:24px;text-align:center;flex-shrink:0}.analytics-activity-detail{flex:1;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.analytics-activity-time{font-size:.75rem;color:var(--text-tertiary);flex-shrink:0}@media(max-width:480px){.analytics-kpis{grid-template-columns:repeat(2,1fr)}.analytics-kpi-value{font-size:1.4rem}}.analytics-tabs{display:flex;gap:var(--space-xs);background:var(--card-bg);border-radius:var(--radius-lg);padding:4px;margin-bottom:var(--space-lg)}.analytics-tab{flex:1;padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.analytics-tab:hover{color:var(--text-primary);background:#ffffff0d}.analytics-tab-active{background:var(--accent);color:var(--bg-primary);font-weight:600}.analytics-tab-active:hover{background:var(--accent);color:var(--bg-primary)}.analytics-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xxl) 0;color:var(--text-secondary)}.analytics-spinner{width:32px;height:32px;border:3px solid var(--border-subtle);border-top-color:var(--accent);border-radius:50%;animation:analytics-spin .8s linear infinite}@keyframes analytics-spin{to{transform:rotate(360deg)}}.analytics-retention-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.analytics-retention-card{background:#ffffff08;border-radius:var(--radius-md);padding:var(--space-lg);text-align:center}.analytics-retention-value{font-size:2rem;font-weight:700;margin-bottom:var(--space-xs)}.analytics-retention-value[data-quality=good]{color:#4ade80}.analytics-retention-value[data-quality=ok]{color:var(--accent)}.analytics-retention-value[data-quality=low]{color:#f87171}.analytics-retention-label{font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.analytics-retention-sub{font-size:.75rem;color:var(--text-tertiary)}.analytics-adoption{display:flex;flex-direction:column;gap:var(--space-md)}.analytics-adoption-row{display:flex;flex-direction:column;gap:4px}.analytics-adoption-info{display:flex;justify-content:space-between;align-items:baseline;font-size:.85rem}.analytics-adoption-count{color:var(--text-tertiary);font-size:.78rem}.analytics-adoption-track{height:8px;background:#ffffff0f;border-radius:4px;overflow:hidden}.analytics-adoption-fill{height:100%;background:linear-gradient(90deg,var(--accent),#e5a54b);border-radius:4px;transition:width .6s ease}.analytics-chart-wau{align-items:flex-end;gap:var(--space-sm)}.analytics-bar-col-wau{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.analytics-bar-value{font-size:.7rem;color:var(--text-tertiary);font-weight:600}.analytics-bar-wau{width:100%;min-height:4px;background:linear-gradient(to top,var(--accent),#e5a54b);border-radius:3px 3px 0 0}.analytics-conversion-bar-track{height:12px;background:#ffffff0f;border-radius:6px;overflow:hidden}.analytics-conversion-bar-fill{height:100%;background:linear-gradient(90deg,#c9a54e,#e5c06b);border-radius:6px;transition:width .6s ease}.analytics-conversion-legend{display:flex;justify-content:center;gap:var(--space-lg);margin-top:var(--space-sm);font-size:.78rem;color:var(--text-secondary)}.analytics-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}.analytics-dot-premium{background:#c9a54e}.analytics-dot-free{background:var(--border-subtle)}.onboarding-widget{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);box-shadow:0 4px 12px #0003}.onboarding-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md)}.onboarding-title{display:flex;gap:var(--space-md);align-items:center}.onboarding-icon{font-size:1.5rem;background:#c17f3e1a;border-radius:var(--radius-full);width:40px;height:40px;display:flex;align-items:center;justify-content:center}.onboarding-title h3{font-size:1.1rem;font-weight:600;margin:0 0 2px;color:var(--text-primary)}.onboarding-title p{font-size:.85rem;color:var(--text-tertiary);margin:0}.onboarding-dismiss-btn{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:all var(--duration-fast)}.onboarding-dismiss-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.onboarding-progress-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);margin-bottom:var(--space-lg);overflow:hidden}.onboarding-progress-fill{height:100%;background:var(--accent);transition:width .5s cubic-bezier(.175,.885,.32,1.275)}.onboarding-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-md)}.onboarding-step{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--duration-fast)}.onboarding-step.completed{opacity:.7;background:#c17f3e0d;border-color:#c17f3e33}.onboarding-step-check{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;color:var(--accent);margin-top:2px}.onboarding-step-circle{width:20px;height:20px;border:2px solid var(--border-hover);border-radius:50%}.onboarding-step-content{flex:1}.onboarding-step-content strong{display:block;font-size:.95rem;color:var(--text-primary);margin-bottom:4px}.onboarding-step-content p{font-size:.85rem;color:var(--text-secondary);margin:0;line-height:1.4}.onboarding-step .btn{align-self:center;white-space:nowrap}.founder-welcome-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d0f12eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:300;display:flex;align-items:center;justify-content:center;padding:var(--space-md);overflow-y:auto}.founder-welcome{background:var(--bg-secondary);border:1px solid rgba(212,175,55,.25);border-radius:var(--radius-xl);max-width:480px;width:100%;max-height:calc(100vh - 32px);overflow-y:auto;padding:var(--space-2xl) var(--space-xl);box-shadow:0 24px 64px #00000080,0 0 80px #d4af3714}.founder-welcome-header{text-align:center;margin-bottom:var(--space-xl)}.founder-welcome-badge{font-size:3.5rem;margin-bottom:var(--space-sm);animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.founder-welcome-header h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#d4af37,#f4e28c,#d4af37);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm)}.founder-welcome-subtitle{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.founder-welcome-benefits{margin-bottom:var(--space-xl)}.founder-welcome-benefits h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:var(--space-md);font-weight:700}.founder-welcome-benefit{display:flex;gap:var(--space-md);padding:var(--space-md);background:#d4af370d;border:1px solid rgba(212,175,55,.1);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);transition:border-color .2s}.founder-welcome-benefit:hover{border-color:#d4af3740}.founder-welcome-benefit-icon{font-size:1.3rem;flex-shrink:0;margin-top:2px}.founder-welcome-benefit strong{display:block;font-size:.9rem;margin-bottom:2px}.founder-welcome-benefit p{margin:0;font-size:.8rem;color:var(--text-tertiary);line-height:1.4}.founder-welcome-feedback{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl)}.founder-welcome-feedback h3{font-size:.95rem;margin-bottom:var(--space-sm)}.founder-welcome-feedback p{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin:0}.founder-welcome-cta{width:100%;padding:var(--space-md) var(--space-lg);font-size:1.05rem;font-weight:700;background:linear-gradient(135deg,#d4af37,#c5942a);color:#1a1a2e;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;box-shadow:0 4px 16px #d4af374d}.founder-welcome-cta:hover{transform:translateY(-1px);box-shadow:0 6px 24px #d4af3766;background:linear-gradient(135deg,#e0be47,#d4af37)}
