@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";.btn{min-height:44px;font-family:var(--font-family);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:none;outline:none;justify-content:center;align-items:center;padding:12px 24px;font-size:1rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-full{width:100%}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 14px #c084fc63}.btn-primary:hover{box-shadow:0 6px 20px #c084fc99}.btn-secondary{color:var(--text-main);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a}.btn-secondary:hover{border-color:var(--secondary);background:#ffffff26}.btn-outline{color:var(--primary);border:1px solid var(--primary);background:0 0}.btn-outline:hover{background:#c084fc1a}.input-wrapper{flex-direction:column;width:100%;margin-bottom:16px;display:flex}.input-label{color:var(--text-muted);margin-bottom:6px;font-size:.9rem;font-weight:500}.input-container{align-items:center;width:100%;display:flex;position:relative}.input-icon{color:var(--text-muted);transition:color var(--transition-fast);position:absolute;left:14px}.input-field{width:100%;font-family:var(--font-family);background:var(--bg-card);border:1px solid var(--glass-border);color:var(--text-main);border-radius:var(--radius-sm);min-height:48px;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);outline:none;padding:14px 16px;font-size:1rem}.input-field.with-icon{padding-left:42px}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary);background:#ffffff14}.input-field:focus+.input-icon,.input-container:focus-within .input-icon{color:var(--primary)}.card{padding:var(--space-6);position:relative;overflow:hidden}@media (width<=380px){.card{padding:var(--space-5)}}.card-hover:hover{box-shadow:0 12px 40px 0 #00000080, 0 0 20px var(--primary-glow);border-color:#c084fc4d}.card-clickable{cursor:pointer}.auth-container{min-height:100dvh;padding:calc(24px + env(safe-area-inset-top)) max(24px, env(safe-area-inset-right)) calc(24px + env(safe-area-inset-bottom)) max(24px, env(safe-area-inset-left));justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-bg-bubbles{z-index:0;pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.bubble{background:radial-gradient(circle at 30% 30%,#ffffff1a,#c084fc0d);border-radius:50%;animation:15s linear infinite float-up;position:absolute;box-shadow:inset 0 0 20px #ffffff0d}.b1{width:120px;height:120px;animation-duration:25s;bottom:-120px;left:10%}.b2{width:80px;height:80px;animation-duration:18s;animation-delay:2s;bottom:-80px;left:80%}.b3{width:200px;height:200px;animation-duration:35s;animation-delay:5s;bottom:-200px;left:50%}@keyframes float-up{0%{opacity:0;transform:translateY(0)scale(1)}10%{opacity:1}90%{opacity:1}to{opacity:0;transform:translateY(-120vh)scale(1.2)}}.auth-content{z-index:1;flex-direction:column;align-items:center;width:100%;max-width:420px;display:flex;position:relative}.auth-logo{flex-direction:column;align-items:center;margin-bottom:40px;display:flex}.auth-logo .text-primary{color:var(--primary);margin-bottom:8px}.auth-logo h1{margin:0;font-size:clamp(2.2rem,9vw,3rem);font-weight:700}.auth-card{text-align:center;width:100%;padding:40px 32px!important}.auth-step h2{margin-bottom:8px;font-size:clamp(1.4rem,6vw,1.75rem)}.auth-subtitle{color:var(--text-muted);text-wrap:pretty;font-size:.95rem;line-height:1.5}.auth-back-link{color:var(--text-muted);cursor:pointer;min-height:44px;transition:color var(--transition-fast);background:0 0;border:none;margin-top:8px;padding:8px 12px;font-family:inherit;font-size:.9rem;text-decoration:underline}.auth-back-link:active{color:var(--text-main)}@media (hover:hover){.auth-back-link:hover{color:var(--text-main)}}.ml-2{margin-left:8px}.auth-error-msg{color:var(--error);margin-top:8px;font-size:.85rem;animation:.3s ease-in-out shake}.text-primary-icon{color:var(--primary);filter:drop-shadow(0 0 8px var(--primary-glow))}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@media (width<=380px){.auth-logo{margin-bottom:28px}.auth-card{padding:32px 20px!important}}.scattered-tags-container{z-index:0;flex-wrap:wrap;place-content:flex-start center;gap:14px;width:100%;padding:24px 0 100px;display:flex}.scatter-tag{cursor:pointer;-webkit-user-select:none;user-select:none;pointer-events:auto;justify-content:center;align-items:center;padding:16px 26px;transition:filter .2s,box-shadow .2s,background-color .2s;display:flex;position:relative;box-shadow:0 4px 15px #0000004d}.scatter-tag.active{filter:brightness(1.15);box-shadow:0 0 25px #ffffff26,inset 0 0 10px #fff3}.tag-text{color:#fff;pointer-events:none;text-shadow:0 2px 4px #0003;font-size:1.1rem;font-weight:600}.pill{border-radius:40px}.square{border-radius:28px;padding:22px 32px}.wave{border-radius:12px 30px;padding:18px 28px}.star{border-radius:50% 30%/30% 50%;padding:24px 34px}.bottom-nav{width:100%;padding:12px max(24px, env(safe-area-inset-right)) calc(12px + env(safe-area-inset-bottom)) max(24px, env(safe-area-inset-left));z-index:50;border-bottom:none;border-left:none;border-right:none;border-bottom-right-radius:0;border-bottom-left-radius:0;position:fixed;bottom:0;left:0}.nav-container{justify-content:space-around;align-items:center;display:flex}.nav-item{color:var(--text-muted);transition:color var(--transition-fast);flex-direction:column;align-items:center;gap:4px;font-size:.75rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{color:var(--text-main)}.nav-item.active{color:var(--primary)}.nav-fab{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow);transition:transform var(--transition-fast);border-radius:50%;margin-bottom:-16px;padding:8px;transform:translateY(-16px)}.nav-item.active .nav-fab{box-shadow:0 0 25px var(--primary);transform:translateY(-16px)scale(1.1)}.home-container{min-height:100dvh;padding:calc(16px + env(safe-area-inset-top)) max(20px, env(safe-area-inset-right)) calc(110px + env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-left))}.home-content{z-index:10;pointer-events:none;position:relative}.home-header{text-align:center;pointer-events:auto;flex-direction:column;align-items:center;display:flex}.home-header h1{text-shadow:0 4px 20px #0009;text-wrap:balance;margin-bottom:24px;font-size:clamp(1.9rem,6.5vw,2.3rem);font-weight:700;line-height:1.15}.search-wrapper{width:100%;max-width:480px;margin:0 auto 20px}.glass-search .input-field{-webkit-backdrop-filter:blur(16px);background:#ffffff12;border-color:#ffffff1f;border-radius:18px;height:56px;font-size:1.05rem;box-shadow:0 8px 32px #0006}.glass-search .input-icon{color:var(--primary);opacity:.85}.sticky-tags-ribbon{top:env(safe-area-inset-top,0);z-index:100;-webkit-backdrop-filter:blur(12px);background:#0f0f0f66;border-bottom:1px solid #ffffff1a;width:100%;padding:8px 0;position:fixed;left:0}.ribbon-scroll{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;padding:0 20px;display:flex;overflow-x:auto}.ribbon-scroll::-webkit-scrollbar{display:none}.ribbon-pill{color:#f8fafc;box-sizing:content-box;background:#ffffff1a;border:1px solid #fff3;border-radius:20px;flex:none;align-items:center;padding:4px 12px;font-size:.8rem;font-weight:500;display:inline-flex}.pointer{cursor:pointer}.ml-1{margin-left:4px}.home-results-cta{bottom:calc(110px + env(safe-area-inset-bottom));z-index:99;pointer-events:auto;justify-content:center;width:100%;display:flex;position:fixed;left:0}.cta-button-group{align-items:center;gap:12px;display:flex}.reset-btn{color:#94a3b8;cursor:pointer;-webkit-backdrop-filter:blur(16px);background:#ffffff0d;border:1px solid #fff3;border-radius:30px;padding:14px 20px;font-size:.95rem;font-weight:600;transition:all .2s}.reset-btn:hover{color:#fff;background:#ffffff1a}.cta-button{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(16px);background:linear-gradient(135deg,#c084fc40,#38bdf840);border:1px solid #fff3;border-radius:30px;align-items:center;padding:14px 28px;font-size:1rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 10px 30px #c084fc66}@media (hover:hover){.cta-button:hover{border-color:#fff6;transform:translateY(-2px)scale(1.03);box-shadow:0 15px 35px #c084fc99}}.cta-button:active{transform:translateY(1px)scale(.99)}@media (width<=380px){.home-content{padding-top:calc(32px + env(safe-area-inset-top));padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right))}.home-header h1{margin-bottom:20px}.top-active-filters{padding:14px 16px}.cta-button{padding:13px 22px;font-size:.95rem}}.search-results-container{min-height:100dvh;padding:0 max(20px, env(safe-area-inset-right)) calc(100px + env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-left))}.results-header{-webkit-backdrop-filter:blur(16px);z-index:50;padding:calc(12px + env(safe-area-inset-top)) 0 10px 0;background:#09090bbf;border-bottom:1px solid #ffffff14;flex-direction:column;gap:8px;display:flex;position:sticky;top:0}.header-nav-row{justify-content:space-between;align-items:center;width:100%;display:flex}.header-nav-row h2{text-align:center;font-size:clamp(1.1rem,4.5vw,1.25rem);font-weight:700;border:none!important;padding-left:0!important}.results-search-wrapper{width:100%}.results-search-input .input-field{background:#ffffff14;border-radius:14px;height:44px;font-size:.95rem}.results-search-input .input-icon{color:var(--primary);opacity:.7}.results-active-tags{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.tag-pill-dismissable{color:var(--primary);border-radius:var(--radius-xs);background:#c084fc1a;border:1px solid #c084fc40;align-items:center;padding:6px 6px 6px 10px;font-size:.78rem;font-weight:500;display:inline-flex}.tag-pill-dismissable .pointer{box-sizing:content-box;margin:-8px -2px -8px 0;padding:8px}.results-body{padding-top:16px}.empty-results-state{text-align:center;flex-direction:column;align-items:center;margin-top:24px;padding:48px 24px;display:flex}.empty-results-state h3{margin-bottom:8px;font-size:1.25rem}.empty-results-state p{color:var(--text-muted);text-wrap:pretty;max-width:300px;margin-bottom:24px;font-size:.9rem;line-height:1.5}.add-drink-shortcut-btn{background:var(--gradient-primary);color:#fff;cursor:pointer;box-shadow:var(--shadow-glow);transition:transform var(--transition-fast);border:none;border-radius:20px;padding:12px 24px;font-weight:600}.add-drink-shortcut-btn:hover{transform:scale(1.05)}.results-grid{flex-direction:column;gap:16px;display:flex}.drink-card{height:100%;transition:transform var(--transition-fast);flex-direction:column;display:flex;overflow:hidden}.drink-card:active{transform:scale(.98)}.drink-card-image{border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);background-position:50%;background-size:cover;height:120px;position:relative}.drink-card-score{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);background:#000000a6;border-radius:10px;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:8px;right:8px}.drink-card-type-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);background:#000000a6;border-radius:8px;align-items:center;gap:4px;padding:3px 8px;font-size:.7rem;font-weight:600;display:flex;position:absolute;bottom:8px;left:8px}.drink-card-content{flex-direction:column;flex-grow:1;padding:12px;display:flex}.drink-card-content h3{white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.95rem;font-weight:600;overflow:hidden}.drink-brand{letter-spacing:.03em;text-transform:uppercase;color:var(--text-muted);align-items:center;margin-bottom:4px;font-size:.72rem;font-weight:700;display:flex}.drink-location{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;align-items:center;margin-bottom:12px;font-size:.75rem;display:flex;overflow:hidden}.drink-consensus-pills{flex-wrap:wrap;gap:4px;margin-top:auto;display:flex}.consensus-pill{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:6px;align-items:center;gap:4px;padding:3px 6px;font-size:.68rem;font-weight:500;display:flex}.consensus-pill .pct{color:var(--primary);font-weight:700}.no-consensus-pill{color:var(--text-muted);font-size:.68rem;font-style:italic}.icon-btn{color:var(--text-main);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;margin-left:-8px;padding:8px;display:inline-flex}@media (width<=380px){.search-results-container{padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right))}}.sucked-badge{justify-content:center;width:100%;margin-bottom:4px;font-weight:700;color:var(--error)!important;background:#f8717126!important;border-color:#f871714d!important}.consensus-chart-wrapper{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:16px;margin:24px 0;padding:16px 0}.rating-distribution{flex-direction:column;gap:8px;width:100%;margin-top:16px;display:flex}.rating-distribution-row{align-items:center;gap:12px;font-size:.9rem;display:flex}.star-label{color:var(--text-secondary);align-items:center;gap:4px;width:32px;display:flex}.star-icon{color:var(--warning);font-size:1rem}.distribution-bar-track{background:#ffffff0d;border-radius:4px;flex:1;height:8px;overflow:hidden}.distribution-bar-fill{background:var(--warning);border-radius:4px;height:100%;transition:width .3s}.count-label{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums;width:24px}.edit-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}@media (width>=600px){.edit-modal-overlay{align-items:center;padding:24px}}.edit-modal{border-bottom-right-radius:0;border-bottom-left-radius:0;flex-direction:column;width:100%;max-width:560px;max-height:92dvh;display:flex;overflow:hidden}@media (width>=600px){.edit-modal{border-radius:var(--radius-xl)}}.edit-modal-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:flex-start;padding:20px 20px 12px;display:flex}.edit-modal-header h2{font-size:1.25rem;font-weight:700}.edit-modal-drink{color:var(--text-muted);margin-top:2px;font-size:.85rem}.edit-modal-close{border:1px solid var(--glass-border);color:var(--text-main);border-radius:var(--radius-pill);cursor:pointer;width:36px;min-width:36px;height:36px;transition:background var(--transition-fast);background:#ffffff0d;justify-content:center;align-items:center;display:inline-flex}.edit-modal-close:hover{background:#ffffff1f}.edit-modal-body{flex:1;padding:20px;overflow-y:auto}.edit-field+.edit-field{margin-top:28px}.edit-field-hint{color:var(--text-muted);margin-top:4px;font-size:.75rem}.favorite-shelf-toggle{margin-top:28px}.comment-textarea{width:100%}.edit-price-input{align-items:center;gap:8px;display:flex}.edit-price-input input{flex:1}.edit-modal-error{color:var(--error);border-radius:var(--radius-sm);background:#f8717114;border:1px solid #f8717133;margin-top:16px;padding:10px 14px;font-size:.85rem}.edit-modal-footer{padding:16px 20px calc(16px + env(safe-area-inset-bottom));border-top:1px solid var(--glass-border);gap:12px;display:flex}.edit-modal-footer .btn{flex:1}.btn-disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.edit-modal .mt-2{margin-top:8px}.edit-modal .mt-3{margin-top:12px}.edit-modal .mb-1{margin-bottom:4px}.drink-profile-container{min-height:100dvh;padding-bottom:calc(110px + env(safe-area-inset-bottom));background:var(--bg-dark)}.profile-hero{background-position:50%;background-size:cover;height:280px;position:relative}.profile-hero-empty{flex-direction:column;min-height:50vh;padding:24px;display:flex}.empty-profile-content{text-align:center;flex-direction:column;align-items:center;gap:16px;margin:auto;display:flex}.hero-overlay{padding:calc(20px + env(safe-area-inset-top)) max(20px, env(safe-area-inset-right)) 20px max(20px, env(safe-area-inset-left));background:linear-gradient(#0006 0%,#09090b66 40%,#09090b 100%);flex-direction:column;justify-content:space-between;display:flex;position:absolute;inset:0}.profile-hero-header{justify-content:space-between;align-items:center;width:100%;display:flex}.back-btn{-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);color:#fff;cursor:pointer;width:44px;height:44px;transition:transform var(--transition-fast);background:#00000080;border-radius:50%;justify-content:center;align-items:center;display:flex}.back-btn:hover{transform:scale(1.08)}.hero-type-badge{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);background:#000000a6;border-radius:12px;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:600;display:flex}.hero-content{width:100%}.hero-title-row{justify-content:space-between;align-items:flex-end;width:100%;display:flex}.hero-title-main{flex-grow:1;padding-right:16px}.hero-title-main h1{text-shadow:0 2px 10px #000000b3;text-wrap:balance;margin-bottom:4px;font-size:clamp(1.5rem,6vw,1.85rem);font-weight:700;line-height:1.2}.location-text{color:var(--text-muted);align-items:center;font-size:.88rem;font-weight:500;display:flex}.brand-text{color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px;font-size:.8rem;font-weight:700}.drink-meta-text{color:var(--text-muted);margin-top:4px;font-size:.82rem}.communal-score-wrapper{flex-direction:column;align-items:center;display:flex}.communal-score{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);background:#000000b3;border-radius:18px;align-items:center;gap:6px;padding:8px 16px;font-size:1.15rem;font-weight:700;display:flex;box-shadow:0 4px 15px #0000004d}.communal-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:.65rem;font-weight:600}.profile-content{padding:0 max(20px, env(safe-area-inset-right)) 0 max(20px, env(safe-area-inset-left));z-index:10;flex-direction:column;gap:24px;display:flex;position:relative}.drink-profile-container h2{color:var(--text-main);border-left:3px solid var(--primary);margin-bottom:16px;padding-left:10px;font-size:1.2rem;font-weight:700}.recipe-section{background:linear-gradient(135deg,#38bdf80d,#0000001a);border-color:#38bdf840;border-radius:20px;padding:20px}.section-subtitle{color:var(--secondary);align-items:center;margin-bottom:8px;font-size:.95rem;font-weight:700;display:flex}.recipe-text{color:var(--text-main);white-space:pre-line;overflow-wrap:break-word;text-wrap:pretty;font-size:.9rem;line-height:1.6}.consensus-section{border-radius:20px;padding:20px}.consensus-percentage-bars{flex-direction:column;gap:12px;margin-top:16px;display:flex}.percentage-bar-item{flex-direction:column;gap:6px;display:flex}.bar-label{justify-content:space-between;font-size:.85rem;font-weight:600;display:flex}.bar-val{color:var(--primary)}.bar-track{background:#ffffff14;border-radius:4px;height:8px;overflow:hidden}.bar-fill{border-radius:4px;height:100%;transition:width .6s ease-out}.no-reviews-note{color:var(--text-muted);padding:16px 0;font-size:.9rem;font-style:italic}.reviews-section{margin-top:8px}.reviews-feed{flex-direction:column;gap:16px;display:flex}.review-card{border-radius:18px;padding:16px 20px}.review-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.reviewer-info{align-items:center;gap:8px;display:flex}.reviewer-name{font-size:.95rem;font-weight:600}.favorite-badge{color:var(--accent);background:#f472b626;border:1px solid #f472b64d;border-radius:6px;align-items:center;gap:3px;padding:2px 6px;font-size:.65rem;font-weight:700;display:flex}.review-rating{color:var(--warning);background:#fbbf241a;border-radius:8px;align-items:center;gap:4px;padding:3px 8px;font-size:.85rem;font-weight:700;display:flex}.review-text{color:var(--text-main);overflow-wrap:break-word;text-wrap:pretty;margin-bottom:8px;font-size:.9rem;line-height:1.5}.review-meta{color:var(--text-muted);margin-bottom:6px;font-size:.78rem;font-weight:600}.review-date{color:var(--text-muted);font-size:.75rem;display:block}.py-8{padding-top:32px;padding-bottom:32px}.sticky-action{width:100%;padding:16px max(20px, env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-left));z-index:50;background:linear-gradient(#09090b00 0%,#09090b 15%);justify-content:center;display:flex;position:fixed;bottom:0;left:0}.sticky-action button{border-radius:14px;height:50px;font-size:1rem;font-weight:600;box-shadow:0 8px 24px #c084fc40}.text-beer{color:var(--warning)}.text-wine{color:var(--accent)}.text-cocktail{color:var(--secondary)}@media (width<=380px){.profile-content{gap:18px}.recipe-section,.consensus-section{padding:16px}}.dominant-badges{flex-wrap:wrap;gap:8px;margin-top:8px;margin-bottom:8px;display:flex}.dominant-badge{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;background:#c084fc26;border:1px solid #c084fc4d;border-radius:12px;padding:4px 10px;font-size:.75rem;font-weight:700}.flex-col{flex-direction:column;display:flex}.gap-4{gap:16px}.radar-chart-container{flex-direction:column;display:flex}.add-drink-container{min-height:100dvh;padding-bottom:calc(40px + env(safe-area-inset-bottom));background:var(--bg-dark)}.add-header{z-index:50;background:var(--bg-dark);padding:calc(16px + env(safe-area-inset-top)) max(20px, env(safe-area-inset-right)) 16px max(20px, env(safe-area-inset-left));border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.progress-bar-track{background:#ffffff14;border-radius:3px;flex-grow:1;height:6px;margin:0 16px;overflow:hidden}.progress-bar-fill{background:var(--gradient-primary);border-radius:3px;height:100%;transition:width .3s cubic-bezier(.4,0,.2,1)}.add-content{padding:24px max(20px, env(safe-area-inset-right)) 24px max(20px, env(safe-area-inset-left))}.form-step{flex-direction:column;display:flex}.step-title{margin-bottom:4px;font-size:clamp(1.35rem,5.5vw,1.6rem);font-weight:700}.step-subtitle{color:var(--text-muted);margin-bottom:12px;font-size:.9rem;line-height:1.4}.section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600;display:block}.setting-cards{flex-direction:column;gap:12px;display:flex}.setting-card{text-align:left;cursor:pointer;width:100%;transition:border-color var(--transition-fast), background var(--transition-fast);background:linear-gradient(135deg,#ffffff0a,#ffffff03);border-radius:18px;align-items:center;padding:16px 20px;display:flex;position:relative}.setting-card:active{transform:scale(.99)}.setting-card.active{border-color:var(--primary);background:#c084fc0d}.setting-card .card-icon{color:var(--primary);box-sizing:content-box;background:#c084fc1a;border-radius:12px;margin-right:16px;padding:10px}.setting-card .card-info h4{margin-bottom:2px;font-size:1rem;font-weight:600}.setting-card .card-info p{color:var(--text-muted);font-size:.8rem}.setting-card .check-icon{color:var(--primary);position:absolute;top:20px;right:20px}.type-buttons{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.type-btn{border-radius:var(--radius-md);cursor:pointer;min-height:48px;transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);background:#ffffff08;justify-content:center;align-items:center;padding:14px 8px;font-size:.9rem;font-weight:600;display:flex}.type-btn:active{transform:scale(.97)}.type-btn.active{border-color:var(--secondary);color:var(--secondary);background:#38bdf814}.autocomplete-wrapper{position:relative}.autocomplete-dropdown{z-index:60;width:100%;max-height:200px;margin-top:6px;padding:8px 0;position:absolute;top:100%;left:0;overflow-y:auto}.dropdown-item{cursor:pointer;align-items:center;padding:12px 16px;font-size:.9rem;transition:background .2s;display:flex}.dropdown-item:hover{background:#ffffff14}.dropdown-sub{color:var(--text-muted);font-size:.8rem}.add-new-spot-trigger{width:100%;color:var(--text-main);cursor:pointer;text-align:left;background:#c084fc08;border-color:#c084fc33;border-radius:12px;align-items:center;padding:14px 16px;font-size:.88rem;display:flex}.add-new-spot-trigger:hover{border-color:var(--primary);background:#c084fc14}.selected-confirmation-pill{background:#34d39914;border:1px solid #34d39933;border-radius:12px;align-items:center;padding:10px 16px;font-size:.85rem;display:flex}.recipe-input,.comment-textarea{border:1px solid var(--glass-border);width:100%;color:var(--text-main);font-family:var(--font-family);resize:none;transition:border-color var(--transition-fast);background:#0000004d;border-radius:12px;outline:none;padding:12px 16px;font-size:1rem}.recipe-input:focus,.comment-textarea:focus{border-color:var(--primary)}.rating-stars{justify-content:center;gap:12px;display:flex}.star-btn{cursor:pointer;background:0 0;border:none;padding:8px;transition:transform .15s}.star-btn:active{transform:scale(1.1)}@media (hover:hover){.star-btn:hover{transform:scale(1.18)}}.glow-star{filter:drop-shadow(0 0 10px #fbbf2499)}.tags-selector-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;display:grid}.tag-toggle-btn{border:1px solid var(--glass-border);color:var(--text-muted);border-radius:var(--radius-xs);cursor:pointer;min-height:44px;transition:all var(--transition-fast);background:#ffffff0a;justify-content:center;align-items:center;padding:8px 12px;font-size:.82rem;font-weight:500;display:inline-flex}.tag-toggle-btn:active{transform:scale(.96)}.tag-toggle-btn.active{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 12px var(--primary-glow);border-color:#0000;font-weight:600}.favorite-shelf-toggle{border-radius:18px;padding:16px 20px}.toggle-row{justify-content:space-between;align-items:center;display:flex}.toggle-row h4{margin-bottom:2px;font-size:.95rem;font-weight:600}.toggle-row .sub-text{color:var(--text-muted);font-size:.78rem}.ios-toggle{display:none}.ios-toggle-label{cursor:pointer;border:1px solid var(--glass-border);background:#ffffff1a;border-radius:16px;width:52px;height:32px;transition:background .3s;position:relative}.ios-toggle-label:after{content:"";background:#fff;border-radius:50%;width:28px;height:28px;transition:left .3s;position:absolute;top:1px;left:1px;box-shadow:0 2px 5px #0000004d}.ios-toggle:checked+.ios-toggle-label{background:var(--success);border-color:var(--success)}.ios-toggle:checked+.ios-toggle-label:after{left:21px}.mt-12{margin-top:48px}.mt-8{margin-top:32px}.mt-6{margin-top:24px}.mt-4{margin-top:16px}.mt-3{margin-top:12px}.space-y-4>*+*{margin-top:16px}.block{display:block}.text-center{text-align:center}.step-navigation button{border-radius:14px;height:52px;font-size:1rem;font-weight:600}.icon-btn{color:var(--text-main);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:8px;display:inline-flex}.photo-upload-zone{border:1px dashed var(--glass-border);text-align:center;cursor:pointer;min-height:120px;transition:all var(--transition-fast);background:#ffffff05;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.photo-upload-zone:hover{border-color:var(--primary);background:#c084fc08}.upload-options-row{justify-content:space-evenly;gap:16px;width:100%;display:flex}.upload-label-trigger{cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast);background:#ffffff08;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;flex:1;align-items:center;padding:16px;font-size:.88rem;display:flex}.upload-label-trigger:hover{border-color:var(--primary);background:#ffffff14}.hidden-file-input{display:none}.upload-loading{flex-direction:column;align-items:center;gap:12px;display:flex}.spinner{border:3px solid #ffffff1a;border-top-color:var(--primary);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite upload-spin}@keyframes upload-spin{to{transform:rotate(360deg)}}.photo-preview-wrapper{flex-direction:column;align-items:center;width:100%;display:flex;position:relative}.uploaded-photo-preview{object-fit:cover;border:1px solid var(--glass-border);border-radius:10px;max-width:100%;max-height:200px;box-shadow:0 4px 12px #0000004d}.remove-photo-btn{color:#f87171;cursor:pointer;transition:all var(--transition-fast);background:#ef44441a;border:1px solid #ef444433;border-radius:8px;margin-top:12px;padding:6px 12px;font-size:.8rem}.remove-photo-btn:hover{background:#ef444433;border-color:#ef4444}@media (width<=380px){.add-content,.add-header{padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right))}.type-buttons{gap:8px}.type-btn{padding:14px 4px;font-size:.85rem}}.submit-error{color:var(--error);border-radius:var(--radius-sm);background:#f8717114;border:1px solid #f8717133;padding:10px 14px;font-size:.85rem}.warning-border{border-color:#f871714d!important}.text-error{color:var(--error)!important}.warning-toggle:checked+.warning-toggle-label{background:var(--error)!important}.taste-profile-section{border-radius:20px;margin-top:24px;padding:20px}.taste-subtitle{color:var(--text-muted);margin-top:4px;margin-bottom:8px;font-size:.85rem}.mb-6{margin-bottom:24px}.profile-container{min-height:100dvh;padding:0 max(20px, env(safe-area-inset-right)) calc(110px + env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-left))}.profile-header{padding:calc(28px + env(safe-area-inset-top)) 0 20px 0;border-bottom:1px solid #ffffff0d}.profile-user-row{justify-content:space-between;align-items:center;width:100%;display:flex}.profile-header h1{margin-bottom:4px;font-size:clamp(1.7rem,7vw,2.1rem);font-weight:700}.stats-text{color:var(--text-muted);align-items:center;gap:6px;font-size:.88rem;font-weight:500;display:flex}.text-warning-icon{color:var(--warning)}.profile-actions{gap:.5rem;display:flex}.profile-actions .logout-btn[title=Admin]{color:var(--primary)!important;background:#c084fc1f!important;border-color:#c084fc40!important}.profile-actions .logout-btn[title=Admin]:hover{box-shadow:0 0 15px var(--primary-glow);background:var(--primary)!important;color:#fff!important}.logout-btn{cursor:pointer;width:44px;height:44px;transition:all var(--transition-fast);border-radius:12px;justify-content:center;align-items:center;display:flex;color:var(--error)!important;background:#f871711a!important;border-color:#f8717133!important}.logout-btn:hover{box-shadow:0 0 15px #f8717166;background:var(--error)!important;color:#fff!important}.cabinet-section{margin-top:24px;margin-bottom:24px}.section-title{align-items:center;margin-bottom:14px;font-size:1.15rem;font-weight:700;display:flex}.cabinet-grid{scroll-snap-type:x mandatory;scrollbar-width:none;gap:16px;margin-bottom:16px;padding-bottom:8px;display:flex;overflow-x:auto}.cabinet-grid::-webkit-scrollbar{display:none}.cabinet-item{scroll-snap-align:start;cursor:pointer;border:1px solid var(--glass-border);box-shadow:var(--shadow-card);transition:all var(--transition-fast);background:linear-gradient(135deg,#ffffff0f,#ffffff05);border-radius:20px;flex-direction:column;flex:0 0 140px;display:flex;padding:10px!important}.cabinet-item:active{transform:scale(.98)}@media (hover:hover){.cabinet-item:hover{border-color:var(--primary);box-shadow:0 10px 20px #c084fc33}}.cabinet-image{background-position:50%;background-size:cover;border-radius:14px;height:120px;margin-bottom:8px;position:relative}.cabinet-score-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);background:#000000a6;border-radius:8px;align-items:center;gap:3px;padding:3px 6px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:6px;right:6px}.cabinet-info{flex-direction:column;display:flex}.cabinet-name{color:var(--text-main);margin-bottom:2px;font-size:.82rem;font-weight:600;line-height:1.2}.cabinet-loc{color:var(--text-muted);font-size:.7rem;line-height:1.2}.empty-cabinet-state{text-align:center;border-radius:18px;flex-direction:column;align-items:center;width:100%;padding:24px;display:flex}.empty-cabinet-state p{margin-bottom:4px;font-size:.88rem;font-weight:600}.empty-cabinet-state .sub-note{color:var(--text-muted);max-width:280px;font-size:.75rem;line-height:1.4}.history-section{margin-top:8px}.history-header-row{justify-content:space-between;align-items:center;width:100%;margin-bottom:16px;display:flex}.history-header-row .section-title{margin:0}.filter-group{border-radius:16px;gap:4px;display:flex;background:#00000040!important;padding:3px 6px!important}.filter-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:12px;align-items:center;padding:6px 10px;font-size:.8rem;font-weight:600;display:flex}.filter-btn:hover{color:var(--text-main)}.filter-btn.active{background:var(--primary);color:#fff;box-shadow:0 4px 10px var(--primary-glow)}.history-feed{flex-direction:column;gap:12px;display:flex}.history-row{border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--transition-fast), background var(--transition-fast);align-items:flex-start;gap:14px;padding:14px 50px 14px 14px;display:flex;position:relative}.history-edit-btn{border-radius:var(--radius-pill);border:1px solid var(--glass-border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;z-index:2;transition:background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);background:#ffffff0d;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:10px;right:10px}.history-edit-btn:hover{border-color:var(--primary);color:var(--text-main);background:#c084fc1f}.history-edit-btn:active{transform:scale(.92)}.history-row:active{background:var(--bg-card-hover);transform:scale(.99)}.history-thumb{border:1px solid var(--glass-border);background-position:50%;background-size:cover;border-radius:12px;flex-shrink:0;width:52px;height:52px}.history-info{flex-grow:1;min-width:0}.history-info h4{margin:0;font-size:.95rem;font-weight:600;line-height:1.3}.history-loc-small{color:var(--text-muted);font-size:.72rem;line-height:1.2;display:block}.history-comment{color:var(--text-main);margin-top:6px;margin-bottom:6px;font-size:.85rem;font-style:italic;line-height:1.4}.history-meta{color:var(--text-muted);align-items:center;gap:6px;font-size:.75rem;display:flex}.rating-small{color:var(--warning);align-items:center;gap:3px;font-weight:700;display:flex}.fav-mini-indicator{align-items:center;display:flex}.dot{opacity:.5}.date-small{color:var(--text-muted)}.empty-history-state{padding:24px 0}.mr-1{margin-right:4px}.mr-2{margin-right:8px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}@media (width<=380px){.profile-container{padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right))}}.admin-container{min-height:100dvh;padding:calc(1.5rem + env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) calc(4rem + env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left))}.admin-header{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.admin-header h1{margin:0;font-size:clamp(1.6rem,6.5vw,2rem)}.admin-back{border:1px solid var(--glass-border);width:44px;height:44px;color:var(--text-main);cursor:pointer;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.admin-tabs{border-radius:14px;gap:.5rem;margin-bottom:1.25rem;padding:.35rem;display:flex}.admin-tab{min-height:44px;color:var(--text-muted);border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.4rem;padding:.6rem;font-weight:600;display:flex}.admin-tab.active{background:var(--gradient-accent);color:#fff}.admin-error{margin-bottom:1rem}.admin-card{margin-bottom:1.5rem;padding:1.25rem}.admin-form{flex-direction:column;gap:.85rem;margin-top:.75rem;display:flex}.admin-list{flex-direction:column;gap:.75rem;display:flex}.admin-row{border:1px solid var(--glass-border);border-radius:14px;justify-content:space-between;align-items:center;gap:.75rem;padding:.9rem 1rem;display:flex}.admin-row-main{flex:1;min-width:0}.admin-row-title{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.admin-code-text{color:var(--text-main);word-break:break-all;font-weight:700}.admin-row-meta{color:var(--text-muted);margin-top:.25rem;font-size:.8rem}.admin-status{text-transform:uppercase;letter-spacing:.03em;border-radius:999px;padding:.15rem .5rem;font-size:.7rem;font-weight:700}.status-active{color:var(--success);background:#34d39926}.status-revoked{color:var(--error);background:#f8717126}.status-expired{color:var(--text-muted);background:#94a3b826}.status-admin{color:var(--primary);background:#c084fc2e}.admin-row-actions{flex-shrink:0;gap:.4rem;display:flex}.admin-icon-btn{border-radius:var(--radius-xs);border:1px solid var(--glass-border);background:var(--bg-card);width:40px;height:40px;color:var(--text-main);cursor:pointer;transition:var(--transition-fast);justify-content:center;align-items:center;display:flex}.admin-icon-btn:active{background:var(--bg-card-hover)}@media (hover:hover){.admin-icon-btn:hover{background:var(--bg-card-hover)}.admin-icon-btn.danger:hover{color:var(--error);border-color:var(--error)}}.admin-empty{text-align:center;padding:1.5rem 0}.library-container{min-height:100dvh;padding-bottom:calc(100px + env(safe-area-inset-bottom));position:relative}.library-header{padding:calc(24px + env(safe-area-inset-top)) max(20px, env(safe-area-inset-right)) 20px max(20px, env(safe-area-inset-left));-webkit-backdrop-filter:blur(12px);z-index:50;background:#0f0f0f66;border-bottom:1px solid #ffffff1a;position:sticky;top:0}.header-title-row{align-items:center;margin-bottom:16px;display:flex}.header-icon{color:var(--primary);margin-right:12px}.library-header h2{background:linear-gradient(135deg,#c084fc,#38bdf8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:1.6rem;font-weight:700}.library-search-row{gap:12px;display:flex}.library-search-input{flex:1}.filter-btn{color:#f8fafc;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff26;border-radius:18px;justify-content:center;align-items:center;width:56px;height:56px;transition:all .2s;display:flex;position:relative}.filter-btn:active{transform:scale(.96)}.filter-btn.active-filters{color:var(--primary);background:#c084fc26;border-color:#c084fc4d}.filter-badge{background-color:var(--accent);width:8px;height:8px;box-shadow:0 0 8px var(--accent);border-radius:50%;position:absolute;top:14px;right:14px}.library-body{padding:24px max(20px, env(safe-area-inset-right)) 40px max(20px, env(safe-area-inset-left))}.library-meta{color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:16px;font-size:.9rem;display:flex}.active-type-pill{color:var(--secondary);background:#38bdf826;border:1px solid #38bdf84d;border-radius:12px;align-items:center;padding:4px 10px;font-size:.8rem;font-weight:500;display:inline-flex}.empty-library-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;margin-top:40px;padding:60px 24px;display:flex}.drawer-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;width:100%;height:100%;position:fixed;top:0;left:0}.filter-drawer{width:100%;padding:24px max(24px, env(safe-area-inset-right)) calc(24px + env(safe-area-inset-bottom)) max(24px, env(safe-area-inset-left));z-index:101;background:#1a1a1c;border-top:1px solid #ffffff1a;border-radius:24px 24px 0 0;position:fixed;bottom:0;left:0;box-shadow:0 -10px 40px #00000080}.drawer-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.drawer-header h3{margin:0;font-size:1.25rem;font-weight:600}.drawer-body{flex-direction:column;gap:20px;margin-bottom:32px;display:flex}.form-group label{color:var(--text-muted);margin-bottom:8px;font-size:.9rem;font-weight:500;display:block}.glass-select{color:#fff;appearance:none;background:#ffffff0d url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%24%2024%22%20fill%3D%22none%22%20stroke%3D%22%2394a3b8%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%3Cpolyline%20points%3D%226%209%2012%2015%2018%209%22%3E%3C%2Fpolyline%3E%3C%2Fsvg%3E) right 16px center/16px no-repeat;border:1px solid #ffffff26;border-radius:14px;width:100%;padding:14px 16px;font-size:1rem}.glass-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #c084fc33}.drawer-footer{gap:16px;display:flex}.drawer-footer .btn{flex:1}:root{--bg-dark:#09090b;--bg-card:#ffffff0d;--bg-card-hover:#ffffff1a;--glass-border:#ffffff1a;--primary:#c084fc;--primary-glow:#c084fc66;--secondary:#38bdf8;--accent:#f472b6;--text-main:#f8fafc;--text-muted:#94a3b8;--success:#34d399;--warning:#fbbf24;--error:#f87171;--font-family:"Outfit", system-ui, -apple-system, sans-serif;--gradient-primary:linear-gradient(135deg, var(--primary), var(--secondary));--gradient-accent:linear-gradient(135deg, var(--primary), var(--accent));--gradient-glass:linear-gradient(135deg, #ffffff0d, #ffffff03);--shadow-glow:0 0 20px var(--primary-glow);--shadow-card:0 8px 32px 0 #0000005e;--transition-fast:.2s ease-in-out;--transition-smooth:.4s cubic-bezier(.4, 0, .2, 1);--radius-xs:8px;--radius-sm:12px;--radius-md:14px;--radius-lg:18px;--radius-xl:24px;--radius-pill:999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--gutter:20px}@media (width<=380px){:root{--radius-xl:20px;--radius-lg:16px}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}body{background-color:var(--bg-dark);color:var(--text-main);font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none;-webkit-tap-highlight-color:transparent;background-image:radial-gradient(circle at 15%,#c084fc26,#0000 25%),radial-gradient(circle at 85% 30%,#38bdf826,#0000 25%);min-height:100dvh;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}.glass-panel{background:var(--gradient-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card)}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;text-wrap:balance;font-weight:600}.text-gradient{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}button{font-family:var(--font-family);color:var(--text-main)}input,textarea,select{font-family:var(--font-family);border:1px solid var(--glass-border);color:var(--text-main);border-radius:var(--radius-sm);transition:var(--transition-fast);background:#0000004d;outline:none;padding:12px 16px;font-size:16px}input:focus,textarea:focus{border-color:var(--primary);box-shadow:var(--shadow-glow)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0003}::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-glow)}.hover-scale{transition:transform var(--transition-fast)}.hover-glow{transition:box-shadow var(--transition-fast)}@media (hover:hover){.hover-scale:hover{transform:scale(1.05)}.hover-glow:hover{box-shadow:var(--shadow-glow)}}.hover-scale:active{transform:scale(.97)}
