:root{--bg-glow: #fff8e7;--bg-top: #f7f2e8;--bg-bottom: #ecdcc0;--surface: rgba(255, 250, 242, .9);--surface-strong: #fff1d7;--surface-soft: rgba(255, 255, 255, .58);--surface-elevated: rgba(255, 248, 238, .96);--text: #22201e;--muted: #6d665d;--accent: #ad2f23;--accent-strong: #8f261b;--border: #d8cab0;--shadow: rgba(34, 32, 30, .16);--shadow-soft: 0 16px 36px rgba(34, 32, 30, .14);--shadow-strong: 0 26px 56px rgba(34, 32, 30, .2);--shadow-card: 0 22px 48px rgba(64, 42, 22, .16);--shadow-lifted: 0 18px 40px rgba(34, 32, 30, .2);--highlight-edge: inset 0 1px 0 rgba(255, 255, 255, .62);--font-main: "Manrope", "Avenir Next", "Segoe UI", sans-serif;--toggle-bg: rgba(255, 252, 245, .85);--toggle-border: #decba9;--toggle-active-bg: #ffffff;--toggle-active-text: #332e28;--toggle-passive-text: #695f55;--btn-primary-text: #fff8f6;--btn-hover-shadow: rgba(110, 28, 20, .2);--secondary-bg: #f5e8d2;--secondary-border: #dac8a8;--secondary-text: #2a2520;--wine-card-bg: rgba(255, 255, 255, .72);--notification-success-bg: #ffffff;--notification-success-border: #d8cab0;--notification-success-text: #22201e;--notification-close: #6d665d}[data-theme=dark]{--bg-glow: #1c2233;--bg-top: #141722;--bg-bottom: #0d1019;--surface: rgba(25, 31, 45, .94);--surface-strong: #242a3c;--surface-soft: rgba(35, 41, 57, .72);--surface-elevated: rgba(28, 34, 49, .98);--text: #e9edf7;--muted: #b4bbcd;--accent: #ff8e6e;--accent-strong: #ff7350;--border: #3f4761;--shadow: rgba(0, 0, 0, .38);--shadow-soft: 0 18px 38px rgba(0, 0, 0, .34);--shadow-strong: 0 28px 60px rgba(0, 0, 0, .42);--shadow-card: 0 24px 50px rgba(0, 0, 0, .36);--shadow-lifted: 0 18px 40px rgba(0, 0, 0, .44);--highlight-edge: inset 0 1px 0 rgba(255, 255, 255, .08);--toggle-bg: rgba(29, 34, 48, .88);--toggle-border: #424a64;--toggle-active-bg: #f1f4fb;--toggle-active-text: #1b2233;--toggle-passive-text: #d3daea;--btn-primary-text: #24140e;--btn-hover-shadow: rgba(0, 0, 0, .35);--secondary-bg: #2b3246;--secondary-border: #49516c;--secondary-text: #eef3ff;--wine-card-bg: rgba(34, 40, 56, .78);--notification-success-bg: #1f2739;--notification-success-border: #4a5674;--notification-success-text: #e9edf7;--notification-close: #b4bbcd}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-main);color:var(--text);background:radial-gradient(circle at 12% 14%,color-mix(in srgb,var(--surface-strong) 52%,transparent) 0%,transparent 26%),radial-gradient(circle at top right,color-mix(in srgb,var(--bg-glow) 100%,transparent) 0%,transparent 34%),linear-gradient(180deg,var(--bg-top) 0%,var(--bg-bottom) 100%);-webkit-user-select:text;user-select:text}#root,.page-shell,.card,.wine-card,h1,h2,p,strong,code,a{-webkit-user-select:text;user-select:text}.page-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:92px 20px 20px}[data-stage-environment-visible=true] .page-shell{padding-top:164px}.card{width:100%;max-width:760px;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 18%),linear-gradient(180deg,var(--surface-elevated) 0%,color-mix(in srgb,var(--surface-strong) 76%,var(--surface)) 100%);border:1px solid var(--border);border-radius:24px;padding:24px;box-shadow:var(--shadow-strong),var(--highlight-edge);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:fade-up .34s ease-out}.auth-card{max-width:520px}.login-hero{display:grid;gap:18px}.login-wordmark{justify-self:start}.login-hero-copy{display:grid;gap:10px}.login-cta{width:100%}.app-shell{min-height:100vh;padding:16px 16px calc(92px + env(safe-area-inset-bottom))}[data-stage-environment-visible=true] .app-shell{padding-top:94px}.app-topbar{position:sticky;top:12px;z-index:12;display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 auto 16px;width:min(960px,100%);padding:12px 14px;border-radius:22px;border:1px solid color-mix(in srgb,var(--border) 88%,transparent);background:linear-gradient(180deg,rgba(255,255,255,.16) 0%,transparent 100%),color-mix(in srgb,var(--surface) 92%,transparent);box-shadow:var(--shadow-soft),var(--highlight-edge);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}[data-stage-environment-visible=true] .app-topbar{top:90px}.app-topbar-actions{display:flex;align-items:center;gap:10px}.stage-environment-notice{position:fixed;top:14px;left:50%;transform:translate(-50%);z-index:11;width:min(720px,calc(100% - 28px));display:grid;gap:4px;padding:10px 12px;border-radius:18px;border:1px solid color-mix(in srgb,#f3b34c 72%,var(--border));background:color-mix(in srgb,#fff2c8 90%,var(--surface));box-shadow:var(--shadow-soft),var(--highlight-edge);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:#473118;font-size:.82rem;line-height:1.35}.stage-environment-notice strong{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}[data-theme=dark] .stage-environment-notice{border-color:color-mix(in srgb,#ffbb63 74%,var(--border));background:color-mix(in srgb,#46311f 88%,var(--surface));color:#ffe3ba}.app-brand-link{color:inherit;text-decoration:none}.app-page{width:min(960px,100%);margin:0 auto;display:grid;gap:18px}.app-page-header{display:flex;flex-direction:column;gap:14px;align-items:stretch}.app-page-header-copy{display:grid;gap:6px}.app-page-subtitle{max-width:54ch}.app-page-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.app-page-content{display:grid;gap:16px}.app-card{max-width:none}.bottom-nav{position:fixed;left:50%;bottom:calc(14px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:16;width:min(460px,calc(100% - 20px));display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:8px;border-radius:22px;border:1px solid color-mix(in srgb,var(--border) 86%,transparent);background:color-mix(in srgb,var(--surface) 92%,transparent);box-shadow:var(--shadow-strong),var(--highlight-edge);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.bottom-nav.bottom-nav-with-action{grid-template-columns:repeat(3,minmax(0,1fr))}.bottom-nav-link{min-height:54px;border-radius:16px;color:var(--muted);text-decoration:none;display:grid;justify-items:center;align-content:center;gap:4px;font-size:.82rem;font-weight:700;transition:background-color .12s ease,color .12s ease,transform .12s ease,box-shadow .12s ease}.bottom-nav-link-action{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:color-mix(in srgb,var(--accent) 16%,var(--surface));color:color-mix(in srgb,var(--accent) 82%,var(--text));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 24%,transparent);cursor:pointer;font:inherit;padding:0}.bottom-nav-link svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.bottom-nav-link.active{background:color-mix(in srgb,var(--accent) 12%,var(--surface));color:color-mix(in srgb,var(--accent) 78%,var(--text));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 20%,transparent)}.app-wordmark{display:inline-flex;align-items:center;gap:10px}.app-wordmark.compact{gap:8px}.app-wordmark-mark{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:radial-gradient(circle at 30% 26%,rgba(255,255,255,.42) 0%,transparent 34%),linear-gradient(145deg,color-mix(in srgb,var(--accent) 18%,var(--surface)),color-mix(in srgb,var(--surface) 72%,white));color:var(--accent-strong);box-shadow:var(--shadow-soft),inset 0 1px #ffffff73}.app-wordmark-mark.avatar{overflow:hidden;padding:2px;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.58) 0%,transparent 38%),linear-gradient(155deg,color-mix(in srgb,var(--accent) 14%,white),color-mix(in srgb,var(--surface) 76%,black 4%))}.app-wordmark.compact .app-wordmark-mark{width:34px;height:34px;border-radius:12px}.app-wordmark-mark svg{width:22px;height:22px}.app-wordmark-avatar-image,.app-wordmark-avatar-fallback{width:100%;height:100%;border-radius:999px}.app-wordmark-avatar-image{display:block;object-fit:cover;background:color-mix(in srgb,var(--surface) 82%,black 4%)}.app-wordmark-avatar-fallback{display:grid;place-items:center;background:radial-gradient(circle at 28% 24%,rgba(255,255,255,.55) 0%,transparent 34%),linear-gradient(155deg,color-mix(in srgb,var(--accent-soft) 58%,white),color-mix(in srgb,var(--accent) 26%,var(--surface)));color:var(--accent-strong);font-size:.82rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;box-shadow:inset 0 1px #ffffff59}.app-wordmark-copy{display:grid;gap:1px}.app-wordmark-name{font-size:1rem;font-weight:800;letter-spacing:-.03em}.app-wordmark-tagline{font-size:.75rem;color:var(--muted);letter-spacing:.02em}.legal-copy{line-height:1.5}.legal-page-shell{align-items:flex-start;padding-top:96px;padding-bottom:140px}[data-stage-environment-visible=true] .legal-page-shell{padding-top:168px}.legal-card{display:grid;gap:18px}.legal-header{display:flex;justify-content:flex-end}.legal-close-btn{align-self:start}.legal-section{display:grid;gap:8px}.legal-list{margin:0;padding-left:20px;display:grid;gap:8px;color:var(--muted);line-height:1.45}.legal-links{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.legal-links-footer{padding-top:6px;border-top:1px solid color-mix(in srgb,var(--border) 85%,transparent)}.legal-link,.legal-inline-link{color:var(--accent-strong);text-decoration-thickness:.08em;text-underline-offset:.16em}.legal-link{margin-top:0}.legal-copyright{margin:0}.legal-copyright-footer{margin-top:-6px}.collection-card{display:flex;flex-direction:column;gap:20px}.collection-cabinet-splash{position:relative;overflow:hidden;display:grid;gap:22px;padding:clamp(24px,4vw,34px);background:radial-gradient(circle at top right,rgba(255,255,255,.24) 0%,transparent 34%),linear-gradient(145deg,color-mix(in srgb,var(--surface-strong) 90%,white),color-mix(in srgb,var(--surface) 88%,transparent))}.collection-cabinet-splash:before{content:"";position:absolute;inset:auto -76px -96px auto;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 14%,white) 0%,transparent 70%);pointer-events:none}.collection-cabinet-splash-copy{position:relative;display:grid;gap:10px;max-width:56ch}.collection-cabinet-splash-steps{position:relative;list-style:none;margin:0;padding:0;display:grid;gap:12px}.collection-cabinet-splash-step{display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px;align-items:start;padding:16px 18px;border-radius:20px;border:1px solid color-mix(in srgb,var(--border) 84%,transparent);background:color-mix(in srgb,var(--surface-soft) 84%,transparent);box-shadow:var(--shadow-soft),var(--highlight-edge)}.collection-cabinet-splash-step-index{width:36px;height:36px;border-radius:999px;display:grid;place-items:center;font-size:.94rem;font-weight:800;color:var(--accent-strong);background:linear-gradient(180deg,rgba(255,255,255,.28) 0%,transparent 100%),color-mix(in srgb,var(--surface-strong) 94%,white);border:1px solid color-mix(in srgb,var(--accent) 18%,var(--border));box-shadow:var(--highlight-edge)}.collection-cabinet-splash-step-copy{display:grid;gap:6px}.collection-cabinet-splash-step-copy strong{font-size:1rem}.collection-cabinet-splash-step-copy span{color:var(--muted);line-height:1.5}.collection-cabinet-splash-actions{position:relative;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start}.collection-cabinet-action-btn{position:relative;min-width:48px;width:48px;height:48px;padding:0;border-radius:16px;display:grid;place-items:center}.collection-cabinet-action-btn.topbar{flex:0 0 auto}.collection-cabinet-action-icon{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.collection-cabinet-reminder{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border-radius:20px;border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--surface-strong) 88%,white) 0%,transparent 100%),color-mix(in srgb,var(--surface) 92%,transparent);box-shadow:var(--shadow-soft),var(--highlight-edge)}.collection-cabinet-reminder-copy{display:grid;gap:6px}.collection-empty{display:grid;gap:12px;justify-items:start;align-content:start}.collection-empty-actions{display:flex;flex-wrap:wrap;gap:10px}.collection-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.collection-header-copy{display:grid;gap:6px}.collection-selected-cabinet{font-size:.92rem}.collection-actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.collection-primary-action{min-width:148px}.collection-toolbar{display:flex;justify-content:flex-start;align-items:center}.compact-action-btn{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:10px 14px;border-radius:999px;font-weight:700}.compact-action-btn.active{border-color:color-mix(in srgb,var(--accent) 36%,var(--secondary-border));background:color-mix(in srgb,var(--accent) 12%,var(--secondary-bg));color:color-mix(in srgb,var(--accent) 78%,var(--text))}.compact-action-icon{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.compact-action-badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 18%,var(--surface));color:color-mix(in srgb,var(--accent) 84%,var(--text));font-size:.72rem;font-weight:800}.secondary-link-btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}h1,h2,p{margin:0}h1{font-size:clamp(1.4rem,2.8vw,2.1rem);letter-spacing:-.02em}h2{font-size:1.05rem}.kicker{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-size:.74rem;font-weight:700;margin-bottom:8px}.muted{color:var(--muted);line-height:1.45}.footnote{margin-top:10px;font-size:.85rem}.error-text{color:var(--accent-strong);font-weight:600}.success-text{color:var(--text);font-weight:600}.notification-viewport{position:fixed;left:50%;top:calc(72px + env(safe-area-inset-top));bottom:auto;transform:translate(-50%);width:min(480px,calc(100% - 20px));z-index:30;display:grid;gap:8px;pointer-events:none}[data-stage-environment-visible=true] .notification-viewport{top:calc(148px + env(safe-area-inset-top))}.notification-toast{pointer-events:auto;border-radius:14px;border:1px solid var(--notification-success-border);background:var(--notification-success-bg);color:var(--notification-success-text);box-shadow:var(--shadow-soft),var(--highlight-edge);padding:10px 12px;display:grid;grid-template-columns:1fr auto;gap:8px;align-items:start;animation:toast-in .18s ease-out}.notification-message{margin:0;line-height:1.38;font-size:.95rem;font-weight:600}.notification-close-btn{border:0;background:transparent;color:var(--notification-close);width:26px;height:26px;border-radius:999px;cursor:pointer;font-size:1.1rem;line-height:1;display:grid;place-items:center}.notification-close-btn:hover{background:color-mix(in srgb,var(--notification-close) 20%,transparent)}.primary-btn,.secondary-btn,.ghost-link{border-radius:14px;border:1px solid transparent;font:inherit;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.theme-toggle-wrap{z-index:10;display:grid;justify-items:end;gap:6px}.theme-toggle-wrap:not(.inline){position:fixed;top:14px;right:14px}.theme-toggle-wrap.inline{justify-items:stretch}.cookie-notice{position:fixed;left:50%;bottom:calc(14px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:15;width:min(680px,calc(100% - 20px));border-radius:18px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 94%,var(--surface-strong));box-shadow:var(--shadow-strong),var(--highlight-edge);padding:14px 16px;display:grid;gap:12px}.cookie-notice-copy{display:grid;gap:6px}.cookie-notice-title{font-size:.98rem;font-weight:800}.cookie-notice-text{color:var(--muted);line-height:1.45;font-size:.92rem}.cookie-notice-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:10px}.cookie-notice-link{margin-top:0;padding:8px 0}.cookie-notice-dismiss{min-width:120px}.theme-controls-row{display:flex;align-items:center;gap:8px}.theme-toggle{display:inline-flex;padding:4px;border-radius:999px;border:1px solid var(--toggle-border);background:var(--toggle-bg);box-shadow:var(--shadow-soft),var(--highlight-edge);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.theme-toggle-btn{border:0;background:transparent;color:var(--toggle-passive-text);border-radius:999px;width:36px;height:36px;display:grid;place-items:center;padding:0;cursor:pointer;transition:background-color .12s ease,color .12s ease}.theme-toggle-icon,.top-action-icon{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.theme-toggle-btn.active{background-color:var(--toggle-active-bg);color:var(--toggle-active-text)}.theme-toggle-btn:disabled{opacity:.7;cursor:not-allowed}.theme-error{max-width:240px;font-size:.8rem;text-align:right}.top-logout-btn{width:36px;height:36px;border-radius:999px;border:1px solid var(--toggle-border);background:var(--toggle-bg);color:var(--toggle-passive-text);display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-soft),var(--highlight-edge);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:transform .12s ease,box-shadow .12s ease,color .12s ease,background-color .12s ease}.top-logout-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px var(--btn-hover-shadow);color:var(--toggle-active-text);background-color:var(--toggle-active-bg)}.top-logout-btn:disabled{opacity:.7;cursor:not-allowed}.primary-btn,.secondary-btn,button{-webkit-user-select:none;user-select:none}.primary-btn,.secondary-btn{padding:12px 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;box-shadow:0 10px 24px #22201e14}.primary-btn{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-strong) 100%);color:var(--btn-primary-text);font-weight:700;box-shadow:0 14px 28px color-mix(in srgb,var(--accent) 26%,transparent)}.primary-btn:hover:not(:disabled),.secondary-btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px var(--btn-hover-shadow)}.primary-btn:disabled{opacity:.7;cursor:not-allowed}.secondary-btn{background-color:var(--secondary-bg);color:var(--secondary-text);border-color:var(--secondary-border);box-shadow:var(--highlight-edge),0 10px 22px color-mix(in srgb,var(--shadow) 30%,transparent)}.ghost-link{display:inline-block;margin-top:12px;color:var(--accent-strong);text-decoration:none;padding:4px 0}.wine-grid{list-style:none;margin:0;padding:0;display:grid;gap:14px}.wine-card{border:1px solid var(--border);border-radius:20px;padding:18px;background:linear-gradient(180deg,rgba(255,255,255,.14) 0%,transparent 22%),linear-gradient(180deg,var(--wine-card-bg) 0%,color-mix(in srgb,var(--surface-soft) 72%,var(--wine-card-bg)) 100%);display:grid;grid-template-columns:56px minmax(0,1fr);align-items:stretch;column-gap:14px;gap:10px;box-shadow:var(--shadow-card),var(--highlight-edge);animation:reveal .3s ease both}.wine-card-icon-wrap{display:grid;align-items:center;justify-items:center;align-self:stretch}.wine-card-icon{width:38px;height:38px}.wine-card-content{display:grid;gap:9px;align-content:start}.wine-card-content h2{line-height:1.25}.wine-meta-line{color:var(--muted);font-size:.95rem}.wine-meta-line strong{color:var(--text);font-weight:700}.wine-review-preview{display:grid;gap:6px;padding:12px 14px;border-radius:16px;border:1px solid color-mix(in srgb,var(--border) 82%,transparent);background:color-mix(in srgb,var(--surface-soft) 76%,transparent);box-shadow:var(--highlight-edge)}.wine-review-preview-label{color:var(--muted);font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.wine-review-preview-text{margin:0;color:var(--text);line-height:1.5;overflow:hidden;overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.wine-actions{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1214186b;display:grid;align-items:end;z-index:20;padding:12px}.sheet-panel{width:100%;max-width:760px;max-height:calc(100dvh - 24px);margin:0 auto;border-radius:18px 18px 0 0;border:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 14%),linear-gradient(165deg,var(--surface-elevated) 0%,var(--surface-strong) 100%);box-shadow:var(--shadow-strong),var(--highlight-edge);padding:18px;display:grid;gap:16px;overflow-y:auto}.sheet-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.sheet-header-copy{display:grid;gap:6px}.sheet-form{display:grid;gap:12px}.sheet-description{color:var(--muted);line-height:1.45}.sheet-field{display:grid;gap:6px;font-size:.95rem}.sheet-field span{font-weight:700}.sheet-field input,.sheet-field select{height:42px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;padding:0 12px;box-shadow:var(--highlight-edge)}.sheet-field input:focus,.sheet-field select:focus{outline:2px solid color-mix(in srgb,var(--accent) 55%,white);outline-offset:1px}.sheet-textarea{min-height:120px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;padding:10px 12px;resize:vertical;box-shadow:var(--highlight-edge)}.sheet-textarea:focus{outline:2px solid color-mix(in srgb,var(--accent) 55%,white);outline-offset:1px}.sheet-field input[aria-invalid=true]{border-color:var(--accent-strong)}.photo-entry-card{border:1px solid var(--border);border-radius:16px;background:color-mix(in srgb,var(--surface) 82%,transparent);padding:14px;display:grid;gap:12px;box-shadow:var(--shadow-soft),var(--highlight-edge)}.photo-entry-title{font-weight:700;margin:0 0 4px}.photo-stage-card{gap:12px}.photo-guidance-list{margin:0;padding-left:20px;display:grid;gap:8px;color:var(--muted);line-height:1.45}.photo-guidance-list.compact{gap:6px}.photo-beta-note{font-size:.92rem}.photo-success-note{border-radius:12px;padding:10px 12px;background:color-mix(in srgb,var(--accent) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));color:var(--text)}.photo-preview-shell{border-radius:16px;overflow:hidden;border:1px solid var(--border);background:color-mix(in srgb,var(--surface-strong) 88%,black);min-height:280px;display:grid;place-items:center;box-shadow:inset 0 1px #ffffff14}.photo-preview-video,.photo-preview-empty,.photo-preview-image{width:100%;min-height:280px}.photo-preview-video{display:block;object-fit:cover;background:#0f1115}.photo-preview-video.mirrored{transform:scaleX(-1)}.photo-preview-image{display:block;object-fit:cover;background:#0f1115}.photo-preview-empty{display:grid;place-items:center;color:color-mix(in srgb,var(--accent) 58%,var(--text))}.photo-preview-icon{width:56px;height:56px}@media(max-width:640px){.photo-preview-shell,.photo-preview-video,.photo-preview-empty,.photo-preview-image{min-height:220px}}.sheet-textarea[aria-invalid=true]{border-color:var(--accent-strong)}.sheet-actions{display:flex;justify-content:flex-end;gap:10px;align-items:center;flex-wrap:wrap}.collection-filters{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px;align-items:end;padding:16px;border-radius:18px;border:1px solid color-mix(in srgb,var(--border) 80%,transparent);background:color-mix(in srgb,var(--surface-soft) 80%,transparent);box-shadow:var(--shadow-soft),var(--highlight-edge);animation:reveal .18s ease both}.collection-filters .sheet-field{min-width:0}.filter-field-wide{grid-column:span 4}.filter-field-medium,.filter-field-date{grid-column:span 2}@media(max-width:1100px){.collection-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-field-wide{grid-column:1 / -1}.filter-field-medium,.filter-field-date{grid-column:span 1}}@media(max-width:720px){.collection-cabinet-splash{gap:18px;padding:22px}.collection-cabinet-splash-step{grid-template-columns:1fr;gap:10px}.collection-cabinet-splash-step-index{width:40px;height:40px}.collection-cabinet-splash-actions{flex-direction:column-reverse;align-items:stretch}.collection-cabinet-reminder{flex-direction:column;align-items:stretch}.cabinet-wizard-benefits{grid-template-columns:1fr}.cabinet-result-btn{flex-direction:column;align-items:stretch}.cabinet-result-badges{justify-content:flex-start}.cabinet-wizard[data-step=select]{padding-bottom:calc(132px + env(safe-area-inset-bottom))}.collection-header{align-items:flex-start;flex-direction:column}.collection-actions{width:100%;justify-content:flex-start}.collection-filters{grid-template-columns:1fr}.filter-field-wide,.filter-field-medium,.filter-field-date{grid-column:auto}.sheet-actions,.collection-empty-actions{flex-direction:column-reverse;align-items:stretch}}.rating-input-row{display:flex;flex-wrap:wrap;gap:8px}.rating-chip{min-width:42px;height:42px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;font-weight:700;cursor:pointer}.rating-chip.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 36%,transparent)}.cabinet-wizard{width:100%;display:grid;gap:16px;padding:20px;border-radius:22px;border:1px solid color-mix(in srgb,var(--border) 86%,transparent);background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 16%),linear-gradient(165deg,var(--surface-elevated) 0%,color-mix(in srgb,var(--surface-strong) 82%,var(--surface)) 100%);box-shadow:var(--shadow-strong),var(--highlight-edge)}.cabinet-wizard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.cabinet-wizard-header-copy{display:grid;gap:8px}.cabinet-wizard-benefits{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.cabinet-wizard-benefit{display:grid;gap:6px;padding:14px;border-radius:16px;border:1px solid color-mix(in srgb,var(--border) 84%,transparent);background:color-mix(in srgb,var(--surface-soft) 82%,transparent);box-shadow:var(--highlight-edge)}.cabinet-wizard-benefit strong{font-size:.95rem}.cabinet-wizard-benefit span{color:var(--muted);line-height:1.45;font-size:.92rem}.cabinet-wizard-actions{justify-content:flex-start}.cabinet-results{list-style:none;margin:0;padding:0;display:grid;gap:10px;max-height:360px;overflow-y:auto}.cabinet-result-btn{width:100%;border-radius:16px;border:1px solid color-mix(in srgb,var(--border) 88%,transparent);background:linear-gradient(180deg,rgba(255,255,255,.14) 0%,transparent 100%),color-mix(in srgb,var(--surface) 94%,transparent);color:var(--text);text-align:left;padding:14px 16px;display:flex;align-items:flex-start;justify-content:space-between;gap:14px;cursor:pointer;box-shadow:var(--shadow-soft),var(--highlight-edge)}.cabinet-result-btn:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.cabinet-result-btn.selected{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent),var(--shadow-soft),var(--highlight-edge)}.cabinet-result-btn.current{border-color:color-mix(in srgb,var(--accent) 18%,var(--border))}.cabinet-result-main{display:grid;gap:6px}.cabinet-result-name{font-size:.98rem;font-weight:800;line-height:1.25}.cabinet-result-meta{color:var(--muted);font-size:.9rem;line-height:1.4}.cabinet-result-badges{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.cabinet-result-badge{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--border) 78%,transparent);background:color-mix(in srgb,var(--surface-soft) 88%,transparent);font-size:.78rem;font-weight:700}.cabinet-result-badge.selected{border-color:color-mix(in srgb,var(--accent) 38%,transparent);background:color-mix(in srgb,var(--accent) 12%,var(--surface));color:color-mix(in srgb,var(--accent) 78%,var(--text))}.cabinet-section-block{display:grid;gap:8px;border:1px solid var(--border);border-radius:14px;padding:12px;background:color-mix(in srgb,var(--surface) 80%,transparent);box-shadow:var(--shadow-soft),var(--highlight-edge)}.cabinet-section-title{font-weight:700}.cabinet-slot-grid{display:grid;gap:6px}.cabinet-slot-cell{position:relative}.cabinet-slot-btn{min-height:76px;width:100%;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;padding:8px 6px;cursor:pointer;display:grid;place-items:center;box-shadow:var(--highlight-edge)}.cabinet-slot-btn:hover:not(:disabled):not(.occupied){border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.cabinet-slot-btn.readonly{cursor:default}.cabinet-slot-btn.readonly:hover:not(:disabled):not(.occupied){border-color:var(--border)}.cabinet-slot-btn.selected{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent)}.cabinet-slot-btn.occupied{background:color-mix(in srgb,var(--accent) 8%,var(--surface));border-color:color-mix(in srgb,var(--accent) 28%,var(--border));color:color-mix(in srgb,var(--accent) 62%,var(--text));cursor:help}.cabinet-slot-content{display:grid;width:100%;min-height:100%;grid-template-rows:auto 1.1em 1fr;justify-items:center;align-content:start;gap:2px}.cabinet-slot-code{font-size:.72rem;font-weight:700;line-height:1}.cabinet-slot-status{min-height:1.1em;font-size:.62rem;line-height:1}.cabinet-slot-content.empty .cabinet-slot-status{visibility:hidden}.cabinet-slot-icon-wrap{min-height:24px;display:grid;place-items:center}.cabinet-slot-icon{width:22px;height:22px}.cabinet-slot-icon.empty{color:color-mix(in srgb,var(--muted) 74%,var(--border));opacity:.82}.cabinet-slot-btn.selected .cabinet-slot-icon.empty{color:color-mix(in srgb,var(--accent) 70%,var(--text))}.cabinet-slot-icon.occupied{color:color-mix(in srgb,var(--accent) 78%,var(--text))}.cabinet-slot-tooltip{position:absolute;left:50%;bottom:calc(100% + 6px);transform:translate(-50%);z-index:2;width:max-content;max-width:min(220px,calc(100vw - 72px));padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 92%,var(--surface-strong));box-shadow:var(--shadow-lifted),var(--highlight-edge);display:grid;gap:3px}.wine-bottle-icon{--wine-bottle-outline: color-mix(in srgb, var(--accent) 72%, var(--text));--wine-bottle-fill: color-mix(in srgb, var(--accent) 70%, var(--text));color:var(--wine-bottle-outline);overflow:visible;filter:drop-shadow(0 6px 12px color-mix(in srgb,var(--wine-bottle-fill) 28%,transparent))}.wine-bottle-outline{stroke:var(--wine-bottle-outline)}.wine-bottle-fill{fill:var(--wine-bottle-fill)}.wine-bottle-cork{fill:color-mix(in srgb,#d9a560 84%,white);stroke:color-mix(in srgb,#9e6a2f 88%,var(--wine-bottle-outline));stroke-width:1}.wine-bottle-cork-detail{stroke:color-mix(in srgb,#8a5928 86%,var(--wine-bottle-outline));stroke-width:.9;stroke-linecap:round}.wine-bottle-icon[data-wine-type=RED]{--wine-bottle-outline: #7d1f29;--wine-bottle-fill: #a92533}.wine-bottle-icon[data-wine-type=WHITE]{--wine-bottle-outline: #9a7c1e;--wine-bottle-fill: #d8bc5c}.wine-bottle-icon[data-wine-type=ROSE]{--wine-bottle-outline: #a24e6d;--wine-bottle-fill: #d9839d}.wine-bottle-icon[data-wine-type=SPARKLING]{--wine-bottle-outline: #49674a;--wine-bottle-fill: #d0bb69}.wine-bottle-icon[data-wine-type=ORANGE]{--wine-bottle-outline: #8b4e17;--wine-bottle-fill: #d6842e}.wine-bottle-icon[data-variant=placeholder]{filter:none}.cabinet-slot-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:6px 5px 0;border-style:solid;border-color:color-mix(in srgb,var(--surface) 92%,var(--surface-strong)) transparent transparent}.cabinet-slot-tooltip-name{font-weight:700;font-size:.82rem}.cabinet-slot-tooltip-line{font-size:.76rem;color:var(--muted)}.cabinet-slot-tooltip-line strong{color:var(--text);font-weight:700}.field-error-text{font-size:.85rem}@media(max-width:640px){body{font-size:17px}[data-stage-environment-visible=true] .page-shell{padding-top:172px}.card{padding:20px;border-radius:22px}.app-shell{padding:12px 12px calc(96px + env(safe-area-inset-bottom))}[data-stage-environment-visible=true] .app-shell{padding-top:102px}.app-topbar{top:8px;padding:10px;border-radius:18px}.app-topbar-actions{gap:8px}[data-stage-environment-visible=true] .app-topbar{top:96px}.app-page-header{gap:12px}h1{font-size:1.72rem;line-height:1.15}h2{font-size:1.12rem}.collection-cabinet-splash-step-copy strong{font-size:1.03rem}.muted,.sheet-description,.wine-meta-line,.cookie-notice-text,.notification-message{font-size:.98rem}.footnote,.legal-copy{font-size:.92rem}.app-page-actions{display:grid;grid-template-columns:1fr}.primary-btn,.secondary-btn,.compact-action-btn{min-height:52px;font-size:1rem}.theme-toggle-btn,.top-logout-btn{width:40px;height:40px}.sheet-field span{font-size:.96rem}.sheet-field input,.sheet-field select{height:48px;font-size:16px}.sheet-textarea{font-size:16px}.desktop-only-action{display:none}.wine-card{grid-template-columns:40px minmax(0,1fr);padding:14px}.wine-card-icon{width:28px;height:28px}.cookie-notice{width:calc(100% - 16px);padding:12px}.cookie-notice-actions{justify-content:stretch}.cookie-notice-link,.cookie-notice-dismiss{width:100%;text-align:center}.bottom-nav-link{min-height:58px;font-size:.88rem}.bottom-nav-link svg{width:22px;height:22px}.notification-viewport{top:calc(84px + env(safe-area-inset-top));bottom:auto}[data-stage-environment-visible=true] .notification-viewport{top:calc(164px + env(safe-area-inset-top))}}@media(min-width:700px){.card{padding:30px}.theme-toggle-wrap:not(.inline){top:20px;right:20px}.stage-environment-notice{top:20px;width:min(720px,calc(100% - 40px))}.app-shell{padding:20px 20px 28px}[data-stage-environment-visible=true] .page-shell{padding-top:176px}[data-stage-environment-visible=true] .app-shell{padding-top:98px}[data-stage-environment-visible=true] .app-topbar{top:94px}[data-stage-environment-visible=true] .legal-page-shell{padding-top:176px}.app-page-header{flex-direction:row;justify-content:space-between;align-items:flex-end}.app-page-actions{justify-content:flex-end;align-items:center}.bottom-nav{display:none}.sheet-backdrop{align-items:center;padding:20px}.sheet-panel{border-radius:18px;padding:20px}.notification-viewport{top:auto;bottom:calc(20px + env(safe-area-inset-bottom));width:min(520px,calc(100% - 40px))}[data-cookie-notice-visible=true] .notification-viewport{bottom:calc(160px + env(safe-area-inset-bottom))}[data-stage-environment-visible=true] .notification-viewport{top:auto}}.admin-shell{min-height:100vh;padding:16px 16px 28px}[data-stage-environment-visible=true] .admin-shell{padding-top:94px}.admin-topbar{width:min(1320px,100%)}.admin-layout{width:min(1320px,100%);margin:0 auto;display:grid;grid-template-columns:320px minmax(0,1fr);gap:18px;align-items:start}.admin-sidebar,.admin-card{max-width:none}.admin-sidebar{position:sticky;top:96px;display:grid;gap:20px;padding:22px}[data-stage-environment-visible=true] .admin-sidebar{top:174px}.admin-sidebar-copy{display:grid;gap:8px}.admin-sidebar-nav{display:grid;gap:10px}.admin-sidebar-link{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;padding:16px 18px;border-radius:18px;border:1px solid color-mix(in srgb,var(--border) 88%,transparent);background:color-mix(in srgb,var(--surface-soft) 88%,transparent);color:inherit;text-align:left;text-decoration:none;display:grid;gap:4px;box-shadow:var(--shadow-soft),var(--highlight-edge)}.admin-sidebar-link span{font-size:1rem;font-weight:800}.admin-sidebar-link small{color:var(--muted);font-size:.84rem}.admin-sidebar-link.active{border-color:color-mix(in srgb,var(--accent) 26%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 10%,var(--surface-strong)) 0%,transparent 100%),color-mix(in srgb,var(--surface) 94%,transparent)}.admin-sidebar-link.disabled{cursor:not-allowed;opacity:.72}.admin-main{min-width:0}.admin-card{display:grid;gap:18px}.admin-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.admin-pagination-summary{display:grid;gap:4px;justify-items:end;color:var(--muted);font-size:.9rem}.admin-user-wines-filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:20px}.admin-user-wines-filters .sheet-field{min-width:180px;flex:1 1 200px}.admin-user-wines-filters .primary-btn{align-self:flex-end}.admin-table-wrap{overflow-x:auto;border-radius:20px;border:1px solid color-mix(in srgb,var(--border) 90%,transparent);background:color-mix(in srgb,var(--surface-soft) 78%,transparent)}.admin-table{width:100%;min-width:1520px;border-collapse:collapse}.admin-table.admin-table--user-wines{min-width:720px}.admin-table-review{max-width:360px;white-space:pre-wrap;word-break:break-word}.admin-table th,.admin-table td{padding:14px 16px;border-bottom:1px solid color-mix(in srgb,var(--border) 82%,transparent);vertical-align:top;text-align:left}.admin-table th{position:sticky;top:0;background:color-mix(in srgb,var(--surface-elevated) 96%,transparent);color:var(--muted);font-size:.8rem;letter-spacing:.05em;text-transform:uppercase}.admin-table td{font-size:.94rem;line-height:1.45}.admin-table-message{min-width:280px;max-width:420px;white-space:pre-wrap;word-break:break-word}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table-stack{display:grid;gap:4px}.admin-table-stack small,.admin-table-code{color:var(--muted)}.admin-table-code{font-family:SFMono-Regular,SF Mono,Menlo,monospace;font-size:.82rem;word-break:break-all}.admin-feedback-status{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.82rem;font-weight:700;border:1px solid transparent;white-space:nowrap}.admin-feedback-status-new{background:color-mix(in srgb,var(--accent) 12%,var(--surface));border-color:color-mix(in srgb,var(--accent) 24%,var(--border));color:var(--text)}.admin-feedback-status-processed{background:color-mix(in srgb,var(--notification-success-bg) 86%,var(--surface));border-color:var(--notification-success-border);color:var(--notification-success-text)}.admin-feedback-action{white-space:nowrap}.admin-subscription-panel{width:min(720px,calc(100vw - 32px))}.admin-subscription-summary{display:grid;gap:10px;padding:16px;border-radius:18px;border:1px solid color-mix(in srgb,var(--border) 84%,transparent);background:color-mix(in srgb,var(--surface-soft) 82%,transparent)}.admin-subscription-actions{flex-wrap:wrap}.admin-pagination{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-pagination-actions{display:flex;gap:10px}.landing-shell{width:min(1080px,calc(100% - 32px));margin:0 auto;min-height:100vh;display:grid;gap:18px;padding:96px 0 32px}[data-stage-environment-visible=true] .landing-shell{padding-top:168px}.landing-hero{max-width:none;display:grid;grid-template-columns:minmax(0,1.35fr) minmax(260px,.9fr);gap:20px;overflow:hidden}.landing-hero-copy,.landing-feature-card,.landing-showcase{position:relative;z-index:1}.landing-wordmark{justify-self:start}.landing-subtitle{max-width:54ch}.landing-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.landing-showcase{align-self:stretch;display:grid;gap:12px;padding:18px;border-radius:22px;border:1px solid color-mix(in srgb,var(--border) 78%,transparent);background:radial-gradient(circle at top right,color-mix(in srgb,var(--accent) 18%,transparent) 0%,transparent 38%),linear-gradient(180deg,color-mix(in srgb,var(--surface-strong) 82%,var(--surface)),color-mix(in srgb,var(--surface) 92%,transparent));box-shadow:var(--shadow-card),var(--highlight-edge)}.landing-showcase-card{display:grid;gap:6px;padding:14px 16px;border-radius:18px;border:1px solid color-mix(in srgb,var(--border) 82%,transparent);background:color-mix(in srgb,var(--surface-elevated) 84%,transparent)}.landing-showcase-card.accent{border-color:color-mix(in srgb,var(--accent) 36%,var(--border));background:color-mix(in srgb,var(--accent) 10%,var(--surface-elevated))}.landing-showcase-card strong{font-size:1rem}.landing-showcase-card span{color:var(--muted);line-height:1.5}.landing-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.landing-feature-card{max-width:none;min-height:220px;display:grid;align-content:start;gap:10px}.landing-footer{display:grid;gap:12px;justify-items:center;padding-bottom:calc(8px + env(safe-area-inset-bottom))}@media(max-width:920px){.landing-hero,.landing-feature-grid{grid-template-columns:1fr}.landing-feature-card{min-height:0}}@media(max-width:640px){.landing-shell{width:min(100%,calc(100% - 24px));padding-top:86px}[data-stage-environment-visible=true] .landing-shell{padding-top:160px}.landing-actions{flex-direction:column;align-items:stretch}.landing-actions .primary-btn,.landing-actions .secondary-btn{width:100%}}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes reveal{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
