:root{--color-bg:#faf7f2;--color-surface:#fff;--color-surface-warm:#f5f0e8;--color-text:#1c1917;--color-text-sec:#78716c;--color-text-muted:#a8a29e;--color-border:#e7e5e4;--color-accent:#722f37;--color-accent-bg:#f5e6e8;--color-accent-hover:#5c252c;--color-error:#991b1b;--color-pending:#a8a29e;--font-display:"Fraunces", Georgia, serif;--font-body:"DM Sans", system-ui, sans-serif;--color-error-bg:#fee2e2;--color-code-bg:#1c1917;--color-code-text:#e7e5e4;--color-star:#d4a017;--space-2xs:2px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.6}#root{background:var(--color-surface);flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input{font-family:inherit;font-size:16px}:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}input:focus-visible{border-color:var(--color-accent);outline:none}.btn-primary{background:var(--color-accent);color:#fff;justify-content:center;align-items:center;gap:var(--space-sm);touch-action:manipulation;border-radius:12px;width:100%;height:56px;font-size:16px;font-weight:600;transition:background .15s ease-out;display:flex}.btn-primary:hover{background:var(--color-accent-hover)}.btn-primary:active{opacity:.9;transform:scale(.98)}.btn-secondary{background:var(--color-surface);width:100%;height:56px;color:var(--color-text);border:1.5px solid var(--color-border);justify-content:center;align-items:center;gap:var(--space-sm);touch-action:manipulation;border-radius:12px;font-size:16px;font-weight:600;transition:border-color .15s ease-out;display:flex}.btn-secondary:hover{border-color:var(--color-accent)}.btn-secondary:active{background:var(--color-bg)}.search-input{width:100%;height:44px;padding:0 var(--space-md);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:8px;outline:none;font-size:16px;transition:border-color .15s ease-out}.search-input::placeholder{color:var(--color-text-muted)}.search-input:focus{border-color:var(--color-accent)}.page{padding:var(--space-md);padding-bottom:calc(120px + env(safe-area-inset-bottom,0px));flex:1}.page-header{font-family:var(--font-display);padding:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:10;align-items:center;gap:var(--space-sm);font-size:20px;font-weight:500;display:flex;position:sticky;top:0}.back-btn{width:44px;height:44px;color:var(--color-text);justify-content:center;align-items:center;font-size:20px;display:flex}.empty-state{text-align:center;padding:var(--space-xl) var(--space-md);color:var(--color-text-sec)}.empty-state p{margin-bottom:var(--space-md)}.toast{top:var(--space-md);width:calc(100% - 32px);max-width:400px;padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid var(--color-error);z-index:100;border-radius:8px;justify-content:space-between;align-items:center;animation:.3s ease-out slideDown;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000014}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-100%)}to{opacity:1;transform:translate(-50%)translateY(0)}}.toast button{color:var(--color-accent);padding:var(--space-xs) var(--space-sm);font-size:14px;font-weight:600}.skeleton{background:linear-gradient(90deg, var(--color-border) 25%, var(--color-bg) 50%, var(--color-border) 75%);background-size:200% 100%;border-radius:4px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.tafel-row{width:100%;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);align-items:center;gap:var(--space-sm);text-align:left;min-height:56px;transition:background .15s ease-out;display:flex}.tafel-row:active{background:var(--color-accent-bg)}.tafel-row__nummer{border-radius:var(--radius-full);background:var(--color-accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.tafel-row__info{flex:1;min-width:0}.tafel-row__name{white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:500;overflow:hidden}.tafel-row__regio{color:var(--color-text-sec);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.tafel-row__count{color:var(--color-text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:13px}.section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:12px;font-weight:600}.page-title{font-family:var(--font-display);margin-bottom:var(--space-lg);font-size:22px;font-weight:500}.sticky-header{z-index:10;background:var(--color-surface);padding:var(--space-md);margin:calc(-1 * var(--space-md)) calc(-1 * var(--space-md)) var(--space-md);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.sticky-header .page-title{margin-bottom:0}.stat-row{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);justify-content:space-between;font-size:14px;display:flex}.stat-row__value{font-weight:700}.table-item{width:100%;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:left;justify-content:space-between;align-items:center;transition:border-color .15s ease-out;display:flex}.table-item:hover{border-color:var(--color-accent)}.table-item__name{font-size:16px;font-weight:500}.table-item__count{color:var(--color-text-sec);font-size:13px}.hint{color:var(--color-text-sec);font-size:14px}button.hint,a.hint{align-items:center;min-height:44px;display:inline-flex}.error-box{margin-top:var(--space-md);padding:var(--space-md);background:var(--color-error-bg);border-radius:var(--radius-md)}.error-box p{color:var(--color-error);font-size:14px}.code-block{text-align:left;background:var(--color-code-bg);color:var(--color-code-text);padding:var(--space-md);border-radius:var(--radius-md);font-size:13px;overflow:auto}.login-result{width:100%;padding:var(--space-md);text-align:left;border-bottom:1px solid var(--color-border);flex-direction:column;display:flex}.login-result__name{font-weight:500}.login-result__sub{color:var(--color-text-sec);font-size:14px}#root:has(.admin-page){max-width:960px}@media (width>=640px){.admin-grid{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.tab-bar{width:100%;max-width:480px;height:calc(56px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--color-surface);border-top:1px solid var(--color-border);z-index:50;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.tab-bar__item{height:100%;color:var(--color-text);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;text-decoration:none;display:flex;position:relative}.tab-bar__item.active{color:var(--color-accent)}.tab-bar__icon{font-size:22px;line-height:1}.tab-bar__label{font-size:10px;font-weight:600}.tab-bar__badge{background:var(--color-accent);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:4px;right:calc(50% - 20px)}.qr-scanner{aspect-ratio:1;background:#1a1a1a;border-radius:12px;position:relative;overflow:hidden}#qr-reader{width:100%}#qr-reader video{border-radius:12px}.qr-scanner__loading{color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--space-sm);z-index:1;flex-direction:column;display:flex;position:absolute;inset:0}.qr-scanner__spinner{border:3px solid #444;border-top-color:#fff;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}[id^=qr-reader]>div:not(:has(video)){display:none!important}.qr-scanner__tap{color:#ffffffb3;justify-content:center;align-items:center;gap:var(--space-md);z-index:2;cursor:pointer;font-family:var(--font-body);background:0 0;border:none;flex-direction:column;width:100%;font-size:16px;font-weight:500;display:flex;position:absolute;inset:0}.qr-scanner__tap:active{color:#fff}.qr-scanner__error{color:var(--color-text-muted);text-align:center;padding:var(--space-md);flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.qr-scanner__viewfinder{pointer-events:none;z-index:2;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.qr-scanner__corner{border:0 solid #ffffffb3;width:28px;height:28px;position:absolute}.qr-scanner__corner--tl{border-top-width:3px;border-left-width:3px;border-top-left-radius:4px;top:calc(50% - 125px);left:calc(50% - 125px)}.qr-scanner__corner--tr{border-top-width:3px;border-right-width:3px;border-top-right-radius:4px;top:calc(50% - 125px);right:calc(50% - 125px)}.qr-scanner__corner--bl{border-bottom-width:3px;border-left-width:3px;border-bottom-left-radius:4px;bottom:calc(50% - 125px);left:calc(50% - 125px)}.qr-scanner__corner--br{border-bottom-width:3px;border-right-width:3px;border-bottom-right-radius:4px;bottom:calc(50% - 125px);right:calc(50% - 125px)}.qr-scanner__hint{text-align:center;color:#fff9;font-size:13px;font-weight:500;position:absolute;bottom:calc(50% - 157px);left:0;right:0}.qr-scanner__flash{z-index:3;pointer-events:none;background:#22c55e4d;border-radius:12px;animation:.4s ease-out forwards scanFlash;position:absolute;inset:0}@keyframes scanFlash{0%{opacity:1}to{opacity:0}}.wines-header{z-index:10;background:var(--color-surface);padding:var(--space-md);margin:calc(-1 * var(--space-md)) calc(-1 * var(--space-md)) 0;border-bottom:1px solid var(--color-border);gap:var(--space-sm);flex-direction:column;display:flex;position:sticky;top:0}.wines-header__title-row{justify-content:space-between;align-items:center;gap:var(--space-sm);min-height:44px;display:flex}.wines-search-btn{height:44px;padding:0 var(--space-md);align-items:center;gap:var(--space-sm);color:var(--color-text-sec);border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:var(--color-surface);font-size:14px;font-weight:500;transition:border-color .15s ease-out;display:flex}.wines-search-btn:active{border-color:var(--color-accent)}.wines-search-btn--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.wines-search-input{flex:1;animation:.2s ease-out searchExpand}@keyframes searchExpand{0%{opacity:0;transform-origin:100%;transform:scaleX(.8)}to{opacity:1;transform:scaleX(1)}}.wines-search-close{width:44px;height:44px;color:var(--color-text-sec);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.wines-table-banner{padding:var(--space-sm) 0;border-top:1px solid var(--color-border);background:0 0;justify-content:space-between;align-items:center;font-size:14px;font-weight:500;display:flex}.wines-table-banner__close{color:var(--color-accent);font-size:14px;font-weight:600;text-decoration:underline}.wines-controls{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.wines-filters{gap:var(--space-xs);flex:1;display:flex;overflow-x:auto}.wines-filter{border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-sec);white-space:nowrap;padding:6px 12px;font-size:13px;font-weight:500;transition:all .15s ease-out}.wines-filter--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.wines-sort{gap:var(--space-2xs);flex-shrink:0;display:flex}.wines-sort-btn{border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-sec);justify-content:center;align-items:center;font-size:14px;transition:all .15s ease-out;display:flex}.wines-sort-btn--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.wines-table-heading{z-index:5;background:var(--color-bg);padding:var(--space-sm) var(--space-md);margin:0 calc(-1 * var(--space-md));color:var(--color-text);align-items:center;gap:var(--space-sm);border-bottom:1px solid var(--color-border);width:calc(100% + 2 * var(--space-md));text-align:left;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);transition:background .15s ease-out;display:flex;position:sticky}.wines-table-heading:active{background:var(--color-accent-bg)}.wines-table-heading--active{background:var(--color-accent);color:#fff;border-bottom-color:var(--color-accent)}.wines-table-heading--active .wines-table-heading__title,.wines-table-heading--active .wines-table-heading__regio{color:#fff}.wines-table-heading__clear{opacity:.8;margin-left:auto;font-size:12px;font-weight:500}.wines-table-heading__title{color:var(--color-text);font-weight:700}.wines-table-heading__regio{color:var(--color-text-sec);font-size:13px;font-weight:400}.wines-row{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);align-items:center;gap:var(--space-md);min-height:56px;display:flex;position:relative;overflow:hidden}.wines-row--selected{background:var(--color-accent-bg);margin:0 calc(-1 * var(--space-md));padding:var(--space-sm) var(--space-md);border-bottom-color:#722f371a}.wines-row__number{border-radius:var(--radius-full);background:var(--color-surface-warm);font-variant-numeric:tabular-nums;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.wines-row--selected .wines-row__number{background:var(--color-accent);color:#fff}.wines-row__body{flex:1;min-width:0}.wines-row__name{font-size:15px;font-weight:500}.wines-row__price{color:var(--color-accent);margin-right:var(--space-sm);font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.wines-row__supplier{color:var(--color-text-sec);font-size:13px}.wines-row__meta{margin-top:var(--space-sm);align-items:flex-start;gap:var(--space-sm);flex-direction:column;display:flex}.wines-row__stars{gap:1px;display:flex}.wines-star{color:var(--color-text-muted);justify-content:center;align-items:center;min-width:28px;min-height:28px;padding:2px;font-size:20px;line-height:1;display:flex}.wines-star--active{color:var(--color-star)}.wines-note-edit{align-self:stretch;width:100%}.wines-note-input{border-color:var(--color-accent);resize:none;width:100%;font-size:16px;line-height:1.5;font-family:var(--font-body);padding-top:8px;padding-bottom:8px;overflow:hidden}.wines-row__action{flex-shrink:0}.wines-confirm-overlay{z-index:5;animation:.15s ease-out confirmSlide;display:flex;position:absolute;inset:0}@keyframes confirmSlide{0%{transform:translate(100%)}to{transform:translate(0)}}.wines-confirm-remove{background:var(--color-accent);color:#fff;font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;border:none;flex:1;justify-content:center;align-items:center;display:flex}.wines-confirm-remove:active{background:var(--color-accent-hover)}.wines-confirm-cancel{background:var(--color-surface);color:var(--color-text);font-size:14px;font-weight:600;font-family:var(--font-body);border:none;border-left:1px solid var(--color-border);cursor:pointer;flex:1;justify-content:center;align-items:center;display:flex}.wines-confirm-cancel:active{background:var(--color-bg)}.mylist-note-btn{color:var(--color-text-sec);background:var(--color-surface-warm);border:1.5px solid var(--color-border);border-radius:var(--radius-full);align-items:center;gap:var(--space-sm);text-align:left;min-height:36px;padding:6px 14px 6px 10px;font-size:13px;font-weight:500;transition:border-color .15s ease-out;display:inline-flex}.mylist-note-btn svg{flex-shrink:0}.mylist-note-btn:active{border-color:var(--color-accent);background:var(--color-accent-bg)}.mylist-note-btn--filled{color:var(--color-text);background:0 0;font-style:normal}.wine-item{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);align-items:center;gap:var(--space-sm);min-height:64px;transition:background .15s;display:flex;position:relative;overflow:hidden}.wine-item--selected{background:var(--color-accent-bg);margin-left:calc(-1 * var(--space-md));margin-right:calc(-1 * var(--space-md));padding-left:var(--space-md);padding-right:var(--space-md)}.wine-item__number{background:var(--color-surface-warm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.wine-item--selected .wine-item__number{background:var(--color-accent);color:#fff}.wine-item__info{flex:1;min-width:0}.wine-item__name{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.wine-item__supplier{color:var(--color-text-sec);font-size:13px}.wine-item__note{color:var(--color-text-sec);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:13px;font-style:italic;overflow:hidden}.wine-item__action{border-radius:var(--radius-md);border:1.5px solid var(--color-accent);min-height:44px;color:var(--color-accent);background:0 0;flex-shrink:0;justify-content:center;align-items:center;padding:8px 14px;font-size:14px;font-weight:600;transition:all .15s ease-out;display:flex}.wine-item__action:active{background:var(--color-accent);color:#fff}.wine-item__action--selected{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.wine-item__action--locked{background:var(--color-surface-warm);border-color:var(--color-border);color:var(--color-text-muted);cursor:default}.wine-item__action--remove{border-color:var(--color-error);color:var(--color-error);background:0 0}.wine-item__action--remove:active{background:var(--color-error-bg)}.wine-item__action--pending{opacity:.5}
