:root{--tabbar-edge-inset: 24px;--tabbar-base-height: 4rem;--tabbar-reserved-height: calc(var(--tabbar-edge-inset) + var(--tabbar-base-height));--tabbar-active-bg: rgba(0, 0, 0, .12);--background: #ffffff;--foreground: #09090b;--card: #ffffff;--card-foreground: #09090b;--muted: #f4f4f5;--muted-hover: #e9e9eb;--muted-foreground: #71717a;--muted-foreground-secondary: #95959c;--border: #e4e4e7;--input: #e4e4e7;--ring: rgba(24, 24, 27, .24);--focus-border: #a1a1aa;--primary: #18181b;--primary-hover: #27272a;--primary-foreground: #fafafa;--secondary: #f4f4f5;--secondary-foreground: #18181b;--danger: #991b1b;--danger-soft: #7f1d1d;--danger-foreground: #fafafa;--star: #f5b301;--surface-subtle: #fafafa;--surface-subtle-secondary: #f4f4f4;--surface-hover: #fcfcfd;--on-image: #ffffff;--on-image-muted: rgba(255, 255, 255, .65);--image-overlay: linear-gradient(to bottom, transparent 30%, rgba(0, 0, 0, .55) 100%);--location-badge-bg: #000000;--location-badge-bg-selected: #3f3f46;--location-badge-fg: #ffffff;--nav-overlay-gradient: linear-gradient(to bottom, rgba(255, 255, 255, .45) 0%, rgba(255, 255, 255, 0) 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .18);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .15);--radius: 12px;--shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 10px 24px rgba(16, 24, 40, .06)}@media(prefers-color-scheme:dark){:root{color-scheme:dark;--tabbar-active-bg: rgba(255, 255, 255, .12);--background: #09090b;--foreground: #fafafa;--card: #18181b;--card-foreground: #fafafa;--muted: #27272a;--muted-hover: #3f3f46;--muted-foreground: #a1a1aa;--muted-foreground-secondary: #71717a;--border: #27272a;--input: #3f3f46;--ring: rgba(250, 250, 250, .16);--focus-border: #52525b;--primary: #fafafa;--primary-hover: #e4e4e7;--primary-foreground: #18181b;--secondary: #27272a;--secondary-foreground: #fafafa;--danger: #ef4444;--danger-soft: #b91c1c;--danger-foreground: #fafafa;--star: #f5b301;--surface-subtle: #111113;--surface-subtle-secondary: #18181b;--surface-hover: #1c1c1f;--on-image: #ffffff;--on-image-muted: rgba(255, 255, 255, .65);--image-overlay: linear-gradient(to bottom, transparent 30%, rgba(0, 0, 0, .7) 100%);--location-badge-bg: #3f3f46;--location-badge-bg-selected: #71717a;--location-badge-fg: #ffffff;--nav-overlay-gradient: linear-gradient(to bottom, rgba(9, 9, 11, .45) 0%, rgba(9, 9, 11, 0) 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .5);--shadow: 0 1px 2px rgba(0, 0, 0, .2), 0 10px 24px rgba(0, 0, 0, .3)}}[data-theme=dark]{color-scheme:dark;--tabbar-active-bg: rgba(255, 255, 255, .16);--background: #09090b;--foreground: #fafafa;--card: #18181b;--card-foreground: #fafafa;--muted: #27272a;--muted-hover: #3f3f46;--muted-foreground: #a1a1aa;--muted-foreground-secondary: #71717a;--border: #27272a;--input: #3f3f46;--ring: rgba(250, 250, 250, .16);--focus-border: #52525b;--primary: #fafafa;--primary-hover: #e4e4e7;--primary-foreground: #18181b;--secondary: #27272a;--secondary-foreground: #fafafa;--danger: #ef4444;--danger-soft: #b91c1c;--danger-foreground: #fafafa;--star: #f5b301;--surface-subtle: #111113;--surface-subtle-secondary: #18181b;--surface-hover: #1c1c1f;--on-image: #ffffff;--on-image-muted: rgba(255, 255, 255, .65);--image-overlay: linear-gradient(to bottom, transparent 30%, rgba(0, 0, 0, .7) 100%);--location-badge-bg: #3f3f46;--location-badge-bg-selected: #71717a;--location-badge-fg: #ffffff;--nav-overlay-gradient: linear-gradient(to bottom, rgba(9, 9, 11, .45) 0%, rgba(9, 9, 11, 0) 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .5);--shadow: 0 1px 2px rgba(0, 0, 0, .2), 0 10px 24px rgba(0, 0, 0, .3)}[data-theme=light]{color-scheme:light;--tabbar-active-bg: rgba(0, 0, 0, .12);--background: #ffffff;--foreground: #09090b;--card: #ffffff;--card-foreground: #09090b;--muted: #f4f4f5;--muted-hover: #e9e9eb;--muted-foreground: #71717a;--muted-foreground-secondary: #95959c;--border: #e4e4e7;--input: #e4e4e7;--ring: rgba(24, 24, 27, .24);--focus-border: #a1a1aa;--primary: #18181b;--primary-hover: #27272a;--primary-foreground: #fafafa;--secondary: #f4f4f5;--secondary-foreground: #18181b;--danger: #991b1b;--danger-soft: #7f1d1d;--danger-foreground: #fafafa;--star: #f5b301;--surface-subtle: #fafafa;--surface-subtle-secondary: #f4f4f4;--surface-hover: #fcfcfd;--on-image: #ffffff;--on-image-muted: rgba(255, 255, 255, .65);--image-overlay: linear-gradient(to bottom, transparent 30%, rgba(0, 0, 0, .55) 100%);--location-badge-bg: #000000;--location-badge-bg-selected: #3f3f46;--location-badge-fg: #ffffff;--nav-overlay-gradient: linear-gradient(to bottom, rgba(255, 255, 255, .45) 0%, rgba(255, 255, 255, 0) 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .18);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .15);--shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 10px 24px rgba(16, 24, 40, .06)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;min-height:100%}body{color:var(--foreground);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.32;background:var(--background);-webkit-font-smoothing:antialiased}h1,h2,h3{margin:0;font-weight:700}a{color:inherit;text-decoration:none}a,button,[role=button],input,label,select,summary,textarea{touch-action:manipulation;-webkit-tap-highlight-color:transparent}ul{list-style:none;margin:0;padding:0}.app-shell{min-height:100vh;display:flex;flex-direction:column;position:relative}.page-transition{animation:page-fade-in .12s ease-out}@keyframes page-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.page-transition{animation:none}}html[data-viewport-mode=admin] .app-shell{min-width:1180px}html[data-viewport-mode=admin] .navbar{display:block}html[data-viewport-mode=admin] .tabbar,html[data-viewport-mode=admin] .mobile-navbar-right{display:none}.main-content{flex:1;max-width:720px;width:100%;margin:0 auto;padding:1rem 1rem 2rem}.main-content:has(.admin-layout){max-width:1280px}html[data-viewport-mode=admin] .main-content{padding:1rem}.top-curtain{position:absolute;top:0;left:0;right:0;height:calc(80px + env(safe-area-inset-top,0px));background-image:url(/bg.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;pointer-events:none;z-index:1;-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 80' preserveAspectRatio='none'><path d='M0 0H40V72C35 82.67 25 82.67 20 72C15 61.33 5 61.33 0 72Z' fill='black'/></svg>"),linear-gradient(black,black);mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 80' preserveAspectRatio='none'><path d='M0 0H40V72C35 82.67 25 82.67 20 72C15 61.33 5 61.33 0 72Z' fill='black'/></svg>"),linear-gradient(#000,#000);-webkit-mask-size:40px 80px,100% env(safe-area-inset-top,0px);mask-size:40px 80px,100% env(safe-area-inset-top,0px);-webkit-mask-repeat:repeat-x,no-repeat;mask-repeat:repeat-x,no-repeat;-webkit-mask-position:left bottom,left top;mask-position:left bottom,left top;transition:transform .2s ease}html[data-scrolled=true] .top-curtain{transform:translateY(-20px)}@media(max-width:640px){.top-curtain{position:fixed;height:calc(40px + env(safe-area-inset-top,0px))}.app-shell:has(.locations-page) .top-curtain{display:none}}@media(min-width:641px){.beer-list-page,.admin-layout{padding-top:8px}.breweries-page,.my-list-page,.info-page,.beer-detail-page,.brewery-detail-page{padding-top:16px}}.navbar{background:transparent;position:relative;z-index:2}.app-shell:has(.locations-page){position:relative}.app-shell:has(.locations-page) .navbar{position:absolute;top:0;left:0;right:0;z-index:10;overflow:hidden}.navbar-progressive-blur{display:none}.app-shell:has(.locations-page) .main-content{height:100vh}.navbar-inner{max-width:720px;margin:0 auto;display:flex;align-items:center;gap:1.5rem;padding:1rem}.navbar-links{display:flex;gap:1.25rem}.navbar-link{font-size:1.5rem;font-weight:400;color:color-mix(in srgb,var(--primary) 35%,transparent);transition:color .12s ease}.navbar-link:hover,.navbar-link.active{color:var(--foreground)}.tabbar,.mobile-navbar-right{display:none}.tabbar-link-icon{width:1.75rem;height:1.75rem;background:currentColor;-webkit-mask-position:center;mask-position:center;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain}.tabbar-link-label{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-picker{display:inline-grid;grid-template-columns:1fr 1fr;position:relative;background:var(--muted);border-radius:999px;overflow:hidden;height:2.5rem}.day-picker-indicator{position:absolute;top:0;bottom:0;left:0;width:50%;background:var(--primary);border-radius:999px;transition:transform .24s cubic-bezier(.4,0,.2,1);pointer-events:none}.day-picker[data-active-index="1"] .day-picker-indicator{transform:translate(100%)}.day-picker-btn{border:none;border-radius:999px;background:transparent;color:var(--muted-foreground-secondary);font:inherit;font-size:.88rem;font-weight:500;padding:.4rem 1rem;cursor:pointer;position:relative;z-index:1;transition:color .12s ease}.day-picker-btn:hover{color:var(--foreground)}.day-picker-btn.active{color:var(--primary-foreground)}.day-picker-btn:active{transform:scale(.96);transition:color 60ms ease-out,transform 60ms ease-out}.search-input-wrap{position:relative;display:block;width:100%}.search-input-wrap:before{content:"";position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;background-color:var(--muted-foreground);-webkit-mask:url(/icons/search.svg) no-repeat center / contain;mask:url(/icons/search.svg) no-repeat center / contain;pointer-events:none}.search-input{width:100%;height:2.5rem;border:1px solid var(--input);border-radius:999px;background:var(--card);color:var(--foreground);padding:0 2.25rem 0 2.5rem;font:inherit;font-size:.9rem;font-weight:500}.search-input::-webkit-search-cancel-button,.search-input::-webkit-search-decoration{-webkit-appearance:none;-moz-appearance:none;appearance:none}.search-input::placeholder{color:var(--focus-border)}.search-input:focus{outline:none;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}.search-input-clear{position:absolute;top:50%;right:.6rem;transform:translateY(-50%);width:1.6rem;height:1.6rem;border:none;background-color:var(--muted-foreground);-webkit-mask:url(/icons/dismiss.svg) no-repeat center / contain;mask:url(/icons/dismiss.svg) no-repeat center / contain;cursor:pointer;padding:0}.filter-select{width:100%;height:2.5rem;border:1px solid var(--input);border-radius:8px;background:var(--card);color:var(--foreground);padding:0 2rem 0 .7rem;font:inherit;font-size:.9rem;font-weight:500;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}.filter-select:focus{outline:none;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .filter-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}}[data-theme=dark] .filter-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}.floor-select-wrap{position:relative;display:block;width:100%}.floor-select-wrap>.filter-select{color:transparent}.floor-select-wrap>.filter-select option{color:var(--foreground)}.floor-select-label{position:absolute;top:50%;left:.7rem;transform:translateY(-50%);pointer-events:none;color:var(--foreground);font:inherit;font-size:.9rem;font-weight:500}@media(max-width:640px){.floor-select-label{font-size:16px}}@media(max-width:640px){.search-input,.filter-select{font-size:16px}}.beer-list-controls{position:sticky;top:0;z-index:5;display:grid;grid-template-columns:minmax(0,1fr) 5rem;column-gap:.5rem;row-gap:.5rem;padding:.5rem 0 1rem;margin-bottom:1rem}.beer-list-controls-day{grid-column:1;grid-row:1;max-height:2.5rem;overflow:hidden;transform-origin:top center}.beer-list-controls>.floor-select-wrap{position:absolute;top:.5rem;right:0;width:5rem}.beer-list-controls>.search-input-wrap{grid-column:1 / -1;grid-row:2;width:auto;margin-right:0}@supports (animation-timeline: scroll()){.beer-list-controls{animation:beer-controls-row-gap linear both;animation-timeline:scroll(root);animation-range:0 80px}.beer-list-controls-day{animation:beer-controls-day-collapse linear both;animation-timeline:scroll(root);animation-range:0 80px}.beer-list-controls>.search-input-wrap{animation:beer-controls-search-shrink linear both;animation-timeline:scroll(root);animation-range:0 80px}}@keyframes beer-controls-row-gap{to{row-gap:0}}@keyframes beer-controls-day-collapse{to{max-height:0;opacity:0}}@keyframes beer-controls-search-shrink{to{margin-right:5.5rem}}.beer-list-daybar{position:sticky;top:0;z-index:5;padding:.5rem 0 1rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.beer-list-daybar .day-picker{align-self:flex-start}.beer-list-daybar .floor-select-wrap{width:5rem;flex-shrink:0}.catalog-sync-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-height:1.75rem;margin:2rem 0 0;color:var(--muted-foreground);font-size:.78rem}.catalog-sync-row button{border:none;border-radius:999px;background:var(--surface-subtle);color:var(--foreground);font:inherit;font-size:.78rem;font-weight:600;padding:.25rem .7rem;cursor:pointer}.catalog-sync-row button:hover{background:var(--muted)}.brewery-group{margin-bottom:.5rem}.brewery-group-header{font-size:1.5rem;font-weight:600;margin-top:24px;padding:1.25rem 0 .35rem;display:flex;align-items:baseline;gap:.5rem}.brewery-group-link{display:flex;align-items:center;justify-content:space-between;flex:1;min-width:0;color:inherit}.brewery-group-label{display:flex;align-items:flex-end;gap:.5rem;flex:1;min-width:0;overflow:hidden}.brewery-name-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(hover:hover){.brewery-group-link:hover .brewery-name-text{text-decoration:underline;text-underline-offset:3px}}.brewery-meta-stack{display:flex;flex-direction:row;flex-shrink:0;align-items:flex-end;gap:12px}.brewery-country,.brewery-floor{white-space:nowrap;font-size:.72rem;font-weight:600;color:var(--muted-foreground);letter-spacing:.04em}.beer-items-spaced{margin-top:.75rem}.beer-item{border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent)}.beer-item:last-child{border-bottom:none}.beer-item-action-row{display:flex;align-items:center;gap:.65rem}.beer-item-link{display:flex;align-items:center;gap:.85rem;min-width:0;padding:.7rem 0;transition:background .1s ease}@media(hover:hover){.beer-item:hover{background:var(--muted);margin:0 -.5rem;padding:0 .5rem;border-radius:6px;border-bottom-color:transparent}}.beer-item-action-row .beer-item-link{flex:1;min-width:0}.beer-item-copy{display:flex;flex:1;flex-direction:column;gap:.15rem;min-width:0}.beer-item-indicators{display:inline-flex;align-items:center;gap:.35rem;flex-shrink:0;color:var(--foreground)}.beer-item-indicator{width:24px;height:24px;display:block}.beer-item-indicator-star{width:32px;height:32px;color:var(--star)}.beer-item-indicator-checkmark{background:#22c55e;-webkit-mask:url(/icons/status/checkmark.svg) center / contain no-repeat;mask:url(/icons/status/checkmark.svg) center / contain no-repeat}.beer-item-check-toggle{width:2rem;height:2rem;flex:0 0 2rem;display:inline-flex;align-items:center;justify-content:center;padding:0;border:1px solid var(--border);border-radius:999px;color:transparent;background:var(--background);cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease}@media(hover:hover){.beer-item-check-toggle:hover{border-color:var(--foreground);color:var(--foreground)}.beer-item-check-toggle:hover .beer-item-check-toggle-check{stroke-dashoffset:0}}.beer-item-check-toggle:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}.beer-item-check-toggle.is-checked{border-color:var(--foreground);color:var(--background);background:var(--foreground)}.beer-item-check-toggle-icon{width:1.6rem;height:1.6rem;overflow:visible}.beer-item-check-toggle-check{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:16;stroke-dashoffset:16;transform-origin:center;transition:stroke-dashoffset .22s cubic-bezier(.16,1,.3,1),transform .22s cubic-bezier(.16,1,.3,1)}.beer-item-check-toggle.is-checked .beer-item-check-toggle-check{stroke-dashoffset:0;animation:beer-item-check-pop .22s cubic-bezier(.16,1,.3,1)}@keyframes beer-item-check-pop{0%{transform:scale(.82) rotate(-5deg)}72%{transform:scale(1.08) rotate(1deg)}to{transform:scale(1) rotate(0)}}@media(prefers-reduced-motion:reduce){.beer-item-check-toggle-check{transition:none}.beer-item-check-toggle.is-checked .beer-item-check-toggle-check{animation:none}}.beer-item-favorite-toggle{width:2.25rem;height:2.25rem;flex:0 0 2.25rem;display:inline-flex;align-items:center;justify-content:center;padding:0;border:none;background:transparent;cursor:pointer;color:color-mix(in srgb,var(--foreground) 18%,transparent);transition:color .12s ease,transform .12s ease}@media(hover:hover){.beer-item-favorite-toggle:hover{color:color-mix(in srgb,var(--star) 70%,var(--foreground) 30%)}}.beer-item-favorite-toggle:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring);border-radius:999px}.beer-item-favorite-toggle.is-favorite{color:var(--star)}.beer-item-favorite-toggle .beer-item-indicator-star{width:26px;height:26px;color:inherit}.beer-item-thumbnail{position:relative;flex-shrink:0;width:54px;height:54px}.beer-item-image{width:54px;height:54px;background:var(--muted);object-fit:cover}.beer-item-image-placeholder{display:block;width:54px;height:54px;background:var(--muted)}.beer-item-thumbnail .beer-item-indicators{position:absolute;bottom:-6px;right:-6px;gap:0;background:var(--background);border-radius:999px;padding:0}.beer-item-top-label{font-size:.8rem;font-weight:500;color:var(--muted-foreground);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.beer-name-line{min-width:0}.beer-day-badges{white-space:nowrap}.beer-day-badge{display:inline-block;vertical-align:middle;margin-left:.35rem;padding:.05rem .4rem;border-radius:999px;background:var(--muted);color:var(--primary);font-size:.7rem;font-weight:600;letter-spacing:.02em;line-height:1.3;font-variant-numeric:tabular-nums;transform:translateY(-.045em)}.beer-name{font-weight:600;font-size:.95rem;min-width:0}.my-list-page .beer-item-top-label{font-size:.95rem;font-weight:600}.my-list-page .beer-item-thumbnail{order:1}.beer-item-link.is-checked .beer-name{color:var(--muted-foreground)}.beer-item-link.is-checked .beer-day-badge{opacity:.55}.beer-item-link.is-checked .beer-item-image{filter:grayscale(1) opacity(.45)}.beer-meta{font-size:.95rem;color:var(--muted-foreground)}.page-status{text-align:center;color:var(--muted-foreground);padding:3rem 1rem}.page-status.error{color:var(--danger)}.page-status h2{margin-bottom:.5rem}.app-update-prompt{position:fixed;bottom:.85rem;left:50%;z-index:80;display:inline-flex;align-items:center;gap:.45rem;max-width:calc(100vw - 2rem);transform:translate(-50%);border:1px solid color-mix(in srgb,var(--border) 70%,transparent);border-radius:999px;background:color-mix(in srgb,var(--card) 94%,transparent);box-shadow:var(--shadow-lg);color:var(--foreground);padding:.35rem .45rem .35rem .8rem;font-size:.82rem;font-weight:600;white-space:nowrap;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.app-update-prompt>span{min-width:0;overflow:hidden;text-overflow:ellipsis}.app-update-prompt button{border:none;border-radius:999px;background:var(--primary);color:var(--primary-foreground);font:inherit;font-size:.78rem;padding:.25rem .65rem;cursor:pointer}.empty{color:var(--muted-foreground);padding:1rem 0}.brewery-empty{color:var(--muted-foreground);padding:.9rem 0}.badge{display:inline-flex;align-items:center;height:1.35rem;border:1px solid var(--border);border-radius:999px;padding:0 .46rem;background:var(--card);color:var(--muted-foreground);font-size:.74rem;font-weight:600;margin-right:.22rem}.badge-manual{border-color:var(--muted-foreground);background:var(--muted-foreground);color:#fff}.back-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.88rem;color:var(--muted-foreground);margin-bottom:.75rem}.back-link-chevron{width:1.1em;height:1.1em;display:inline-block;background-color:currentColor;-webkit-mask:url(/icons/chevron.svg) no-repeat center / contain;mask:url(/icons/chevron.svg) no-repeat center / contain}.back-link:hover{color:var(--foreground)}@media(max-width:640px){.back-link{align-self:flex-start;width:auto;max-width:max-content;display:inline-flex;align-items:center;font-size:1rem;font-weight:500;line-height:1;color:var(--foreground);background:var(--muted);border-radius:999px;padding:.56rem .8rem;margin-bottom:1rem;text-decoration:none;transition:background .12s ease,border-color .12s ease,transform .12s ease}.back-link:hover{background:var(--muted-hover);color:var(--foreground)}.back-link:active{transform:scale(.97)}}.detail-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;margin-bottom:.75rem}.brewery-hero-card{height:220px;max-width:520px;display:flex;flex-direction:column;justify-content:flex-end;border:none;margin-bottom:2.75rem;position:relative;overflow:hidden}.brewery-hero-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--image-overlay);z-index:1}.brewery-hero-card.has-image{background:var(--muted)}.brewery-hero-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.brewery-hero-card h2{color:var(--on-image);font-size:1.5rem;font-weight:600;margin-bottom:0;position:relative;z-index:2}.brewery-hero-card .brewery-detail-country{color:var(--on-image-muted);margin:-.8rem 0 0;position:relative;z-index:2}.beer-detail-page{display:flex;flex-direction:column;gap:40px}.detail-card h2{font-size:1.35rem;margin-bottom:.75rem}.detail-card h3{font-size:1rem;margin-bottom:.6rem}.detail-grid{display:grid;grid-template-columns:auto 1fr;gap:.3rem 2.5rem;margin:0}.detail-grid dt{color:var(--muted-foreground);font-size:.88rem}.detail-grid dd{margin:0;font-size:.92rem}.detail-grid a{color:var(--foreground)}.detail-grid a:hover{text-decoration:underline}.beer-headline{display:flex;align-items:flex-end;gap:1rem;justify-content:space-between}.beer-headline-copy{display:flex;flex-direction:column;gap:0;min-width:0;line-height:180%}.beer-headline-image{width:96px;height:96px;flex-shrink:0;background:var(--muted);object-fit:cover}.beer-headline-brewery{font-size:1.5rem;font-weight:700;color:var(--muted-foreground-secondary);text-decoration:none}.beer-headline-brewery:hover{text-decoration:underline}.beer-headline-subtitle{font-size:1.5rem;margin-top:16px;display:flex;flex-direction:column;line-height:120%}.beer-headline-style{color:var(--primary)}@media(max-width:640px){.beer-headline{align-items:flex-start}.beer-headline-image{width:80px;height:80px}}.notes-section{display:flex;flex-direction:column;gap:12px}.action-buttons{display:flex;flex-direction:row;gap:10px;flex-wrap:wrap}.action-btn{display:inline-flex;align-items:center;gap:8px;padding:.5rem 1rem;border-radius:10px;border:0;background:var(--muted);color:var(--foreground);font:inherit;font-size:.92rem;font-weight:500;cursor:pointer;text-decoration:none;transition:border-color .15s ease,background .15s ease,color .15s ease,transform .14s ease-out;-webkit-user-select:none;user-select:none}.action-btn:hover{border-color:var(--muted-foreground);background:var(--muted-hover)}.action-btn:active{background:var(--muted-hover);transform:scale(.96);transition:background 60ms ease-out,transform 60ms ease-out}.action-btn-icon{display:inline-block;width:1.25rem;height:1.25rem;background:currentColor;-webkit-mask-position:center;mask-position:center;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain}.action-btn--star-active{color:var(--primary);border-color:transparent;background:#fbbf24}.action-btn--star-active:hover{background:#f59e0b;border-color:transparent;color:var(--primary)}.action-btn--check-active{background:#16a34a;border-color:transparent;color:#fff}.action-btn--check-active:hover{background:#15803d;border-color:transparent;color:#fff}@media(max-width:640px){.action-buttons{gap:8px}.action-buttons .action-btn{flex:1 1 0;justify-content:center;padding:.75rem 1rem;font-size:1rem}.action-buttons .action-btn:first-child{flex-basis:100%}}.note-editor{width:100%;min-height:4rem;border:1px solid var(--input);border-radius:8px;padding:.5rem .7rem;font:inherit;font-size:.9rem;resize:vertical;color:var(--foreground);background:var(--card)}.note-editor:focus{outline:none;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}.breweries-controls{display:grid;grid-template-columns:minmax(0,1fr) 5rem auto;gap:.5rem;margin-bottom:1rem}.view-toggle{display:inline-flex;align-items:stretch;height:2.5rem;border:1px solid var(--input);border-radius:8px;background:var(--card);overflow:hidden}.view-toggle-btn{position:relative;width:2.5rem;border:none;background:transparent;cursor:pointer;padding:0;opacity:.48;transition:opacity .12s ease,background-color .12s ease}.view-toggle-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:1.5rem;height:1.5rem;margin:auto;background-color:var(--foreground);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain}.view-toggle-btn:hover{opacity:.85}.view-toggle-btn.active{opacity:1;background-color:var(--surface-subtle-secondary)}.view-toggle-grid:before{-webkit-mask-image:url(/icons/grid.svg);mask-image:url(/icons/grid.svg)}.view-toggle-list:before{-webkit-mask-image:url(/icons/list.svg);mask-image:url(/icons/list.svg)}.brewery-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.brewery-list-item{border-bottom:none}.brewery-list-link{display:flex;flex-direction:column;justify-content:flex-end;position:relative;height:160px;border-radius:12px;overflow:hidden;background:var(--muted);padding:.75rem;transition:opacity .12s ease}.brewery-list-link:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--image-overlay);z-index:1;pointer-events:none}.brewery-list-link.has-image{background:var(--muted)}.brewery-list-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.brewery-list-link:hover{opacity:.88}.brewery-list-name{font-weight:600;font-size:.95rem;color:var(--on-image);position:relative;z-index:2}.brewery-list-country{font-size:.72rem;font-weight:600;color:var(--on-image-muted);letter-spacing:.04em;position:relative;z-index:2}.brewery-list-meta{display:flex;flex-wrap:wrap;gap:.4rem;position:relative;z-index:2}.brewery-rows{display:flex;flex-direction:column;gap:.5rem}.brewery-row-item{border-bottom:none}.brewery-row-link{display:flex;align-items:center;gap:1rem;padding:.24rem 0;border-radius:12px;background:transparent;transition:background-color .12s ease}.brewery-row-link:hover{background:var(--surface-subtle)}.brewery-row-thumb{flex:none;width:3rem;height:3rem;border-radius:10px;overflow:hidden;background:var(--muted)}.brewery-row-image{width:100%;height:100%;object-fit:cover;display:block}.brewery-row-name{font-size:1.2rem;font-weight:600;color:var(--foreground)}.brewery-detail-country{color:var(--muted-foreground);font-size:.88rem;font-weight:600;letter-spacing:.04em;margin:0}.beer-note-preview{font-size:.78rem;color:var(--muted-foreground);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.info-content h2{font-size:1.25rem;margin-bottom:.5rem}.info-text{color:var(--foreground);line-height:1.6;margin:0}.info-text p{margin:0 0 .75rem}.info-text p:last-child{margin-bottom:0}.info-text h1,.info-text h2,.info-text h3{margin:1rem 0 .4rem;font-weight:600}.info-text ul,.info-text ol{margin:0 0 .75rem 1.25rem}.info-text li{margin-bottom:.25rem}.info-text a{color:var(--primary);text-decoration:underline}.info-text strong{font-weight:600}.info-text em{font-style:italic}.main-content:has(.locations-page){max-width:none;padding:0;margin:0;display:flex;flex-direction:column}.main-content:has(.locations-page)>.page-transition{flex:1;display:flex;flex-direction:column;min-height:0}.locations-page{flex:1;display:flex;flex-direction:column}.locations-tab{flex:1;position:relative}.locations-map{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.locations-map-canvas{width:100%;height:100%}.locations-map .mk-map-view{border-radius:0}.locations-map-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--muted);display:flex;align-items:center;justify-content:center;text-align:center}.locations-list{--locations-panel-radius: 14px;--locations-panel-padding: 4px;position:absolute;top:1rem;left:1rem;bottom:1rem;width:280px;z-index:10;background:var(--card);border-radius:var(--locations-panel-radius);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;gap:2px;padding:var(--locations-panel-padding)}.locations-cards{flex:1;display:flex;flex-direction:column;gap:2px;overflow-y:auto;min-height:0}.locations-panel-tabs{--locations-tabs-padding: 3px;--locations-tabs-radius: calc( var(--locations-panel-radius) - var(--locations-panel-padding) );display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-bottom:6px;padding:var(--locations-tabs-padding);background:var(--muted);border-radius:var(--locations-tabs-radius)}.locations-panel-tab{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-width:0;height:2rem;border:none;border-radius:calc(var(--locations-tabs-radius) - var(--locations-tabs-padding));background:transparent;color:var(--muted-foreground);cursor:pointer;font:inherit;font-size:.8rem;font-weight:600;transition:background .16s ease,color .16s ease}.locations-panel-tab span{color:inherit;opacity:.65;font-size:.72rem}.locations-panel-tab.active{color:var(--foreground);background:var(--card)}.locations-panel-tab:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}.locations-empty{margin:0;padding:1rem .75rem;color:var(--muted-foreground);font-size:.86rem}.locations-warning{margin:0 0 4px;padding:.7rem .75rem;border-radius:8px;background:color-mix(in srgb,var(--danger) 8%,var(--card));color:var(--danger);font-size:.78rem;line-height:1.35}.geocode-message{margin:.35rem 0 0;font-size:.82rem;line-height:1.35}.geocode-message.success{color:#166534}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .geocode-message.success{color:#4ade80}}[data-theme=dark] .geocode-message.success{color:#4ade80}.geocode-message.error{color:var(--danger)}.location-card{display:flex;flex-direction:column;gap:4px;padding:calc(.75rem - 2px);border:1px solid transparent;border-radius:10px;cursor:pointer;transition:background .1s ease,border-color .1s ease}.location-card:hover{background:var(--muted)}.location-card:focus-visible{border-color:var(--foreground);box-shadow:0 0 0 3px var(--ring);outline:none}.location-card.selected{background:var(--primary)}.location-card.selected .location-name,.location-card.selected .location-address{color:var(--primary-foreground)}.location-card.selected .location-notes,.location-card.selected .location-date,.location-card.selected .location-time,.location-card.selected .location-event-description{color:color-mix(in srgb,var(--primary-foreground) 65%,transparent)}.location-card.selected .location-event-name,.location-card.selected .location-map-link{color:var(--primary-foreground)}.location-card.selected .location-map-link:hover{color:color-mix(in srgb,var(--primary-foreground) 60%,transparent)}.location-card.selected .location-badge{background:var(--location-badge-bg-selected)}.location-badge{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:999px;background:var(--location-badge-bg);color:var(--location-badge-fg);border:none;font-size:.72rem;font-weight:700;flex-shrink:0}.location-card-venue{display:flex;align-items:center;gap:.5rem}.location-date-group{display:flex;align-items:center;gap:.3rem}.location-name{flex:1;min-width:0;font-weight:600;font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-date{color:var(--muted-foreground);font-size:.74rem;font-weight:700;text-transform:uppercase;white-space:nowrap}.location-time{color:var(--muted-foreground);font-size:.78rem;font-weight:600;white-space:nowrap}.location-address,.location-notes{font-size:.82rem;color:var(--muted-foreground)}.location-event-description{font-size:.82rem;color:var(--muted-foreground);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.location-event-name{color:var(--foreground);font-size:.88rem;font-weight:600}.location-map-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:500;color:var(--muted-foreground);line-height:1;margin-top:auto}.location-map-link:hover{color:var(--foreground)}.muted{color:var(--muted-foreground)}.navbar-right{margin-left:auto;display:flex;align-items:center;gap:1.25rem}.navbar-icon-btn{display:flex;align-items:center;border:none;background:none;padding:0;color:color-mix(in srgb,var(--primary) 35%,transparent);cursor:pointer;transition:color .12s ease}.navbar-icon-btn:hover,.navbar-icon-btn.active{color:var(--foreground)}.login-page{display:flex;justify-content:center;padding-top:3rem}.login-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;width:100%;max-width:360px}.login-card h2{font-size:1.25rem;margin-bottom:1rem}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.86rem;color:var(--muted-foreground)}.login-form input{width:100%;height:2.25rem;border:1px solid var(--input);border-radius:8px;background:var(--card);color:var(--foreground);padding:0 .7rem;font:inherit}.login-form input:focus{outline:none;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}.login-error{color:var(--danger);font-size:.86rem;margin:0}.login-button{width:100%}.button{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;height:2.25rem;padding:0 .85rem;background:var(--primary);color:var(--primary-foreground);cursor:pointer;font:inherit;font-size:.9rem;font-weight:600;transition:background .14s ease}.button:hover{background:var(--primary-hover)}.button:disabled{opacity:.5;cursor:not-allowed}.button[aria-disabled=true]{opacity:.5;cursor:not-allowed}.admin-nav-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.admin-nav{display:flex;flex-wrap:wrap;gap:.25rem}.admin-nav-link{padding:.4rem .7rem;border-radius:999px;font-size:.88rem;font-weight:500;color:var(--muted-foreground);background:var(--surface-subtle);transition:background .12s ease,color .12s ease}.admin-nav-link:hover{background:var(--muted);color:var(--foreground)}.admin-nav-link.active{background:var(--primary);color:var(--primary-foreground)}.admin-build-version{flex:0 0 auto;padding:.25rem .5rem;border:1px solid var(--border);border-radius:999px;color:var(--muted-foreground);font-size:.75rem;line-height:1.2;white-space:nowrap}.admin-panel-head{display:flex;align-items:center;gap:.5rem;padding-top:1.5rem;padding-bottom:1rem}.admin-panel-head h2{margin-right:.25rem}.admin-panel-head .search-input,.admin-panel-head .admin-select{flex-shrink:0;width:auto}.admin-panel-head .search-input:first-of-type{margin-left:auto}.admin-panel-head .button{flex-shrink:0}.admin-head-action{margin-left:auto}.admin-head-trailing{margin-left:auto;display:flex;align-items:center;gap:.5rem}.admin-heading-with-badge{display:flex;align-items:center;gap:.5rem}.admin-search-input{max-width:220px}.admin-filters{display:flex;gap:.5rem;margin-bottom:.75rem}.admin-filters .search-input{flex:1;max-width:400px}.admin-select{width:auto;min-width:160px;height:2.25rem;border:1px solid var(--input);border-radius:8px;background:var(--card);color:var(--foreground);padding:0 .7rem;font:inherit;font-size:.9rem}.admin-select:focus{outline:none;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}.admin-two-col{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:2rem;align-items:start}.admin-section-tabs{display:inline-flex;gap:4px;margin:1rem 0 0;padding:3px;background:var(--muted);border-radius:10px}.admin-section-tab{border:none;border-radius:8px;background:transparent;color:var(--muted-foreground);cursor:pointer;font:inherit;font-size:.86rem;font-weight:600;min-width:7rem;height:2rem;padding:0 .8rem}.admin-section-tab.active{background:var(--card);color:var(--foreground);box-shadow:var(--shadow-sm)}.admin-section-tab:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}.admin-table-wrap{overflow:auto}.admin-sticky-form .admin-form-panel{margin-top:0}.admin-sticky-form{position:sticky;top:1rem;max-height:calc(100dvh - 2rem);overflow-y:auto}.admin-table{width:100%;min-width:640px;border-collapse:collapse}.admin-table th,.admin-table td{border-bottom:1px solid var(--border);padding:.5rem .4rem;text-align:left;font-size:.86rem}.admin-table th{color:var(--muted-foreground);text-transform:uppercase;font-size:.72rem;letter-spacing:.06em;font-weight:700}.admin-table th:last-child,.admin-table td:last-child{text-align:right}.admin-table tbody tr:hover{background:var(--surface-hover)}.admin-table td.admin-cell-center{text-align:center}.admin-row.is-dimmed{opacity:.35;transition:opacity .12s ease}.admin-row.is-targeted,.admin-row.is-targeted:hover{background:var(--muted)}.admin-drag-handle-col{width:28px;padding-left:4px!important;padding-right:4px!important}.admin-drag-handle{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--muted-foreground);cursor:grab;border-radius:4px;transition:color .12s ease,background .12s ease;touch-action:none;-webkit-user-select:none;user-select:none}.admin-row[draggable=true]:hover .admin-drag-handle{color:var(--foreground);background:var(--muted)}.admin-row[draggable=false] .admin-drag-handle{cursor:not-allowed;opacity:.4}.admin-row.is-dragging{opacity:.4}.admin-row.is-dragging .admin-drag-handle{cursor:grabbing}.admin-row.is-drop-before>td{box-shadow:inset 0 2px 0 0 var(--primary)}.admin-row.is-drop-after>td{box-shadow:inset 0 -2px 0 0 var(--primary)}.admin-location-events-table td:nth-child(2),.admin-location-events-table th:nth-child(2){white-space:nowrap}.admin-location-events-table td:nth-child(3),.admin-location-events-table th:nth-child(3),.admin-location-events-table td:nth-child(4),.admin-location-events-table th:nth-child(4){min-width:220px}.admin-form-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-top:2rem}.admin-form-panel h3{font-size:1rem;margin-bottom:.75rem}.admin-form{display:flex;flex-direction:column;gap:.6rem}.app-shell:has(.admin-info-layout){height:100dvh}.app-shell:has(.admin-info-layout) .main-content{display:flex;flex-direction:column;padding-bottom:.75rem}.app-shell:has(.admin-info-layout) .admin-layout{flex:1;min-height:0;display:flex;flex-direction:column}.app-shell:has(.admin-info-layout) .admin-beer-list-page{flex:1;min-height:0;display:flex;flex-direction:column}.admin-info-layout{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1.5rem;align-items:stretch;margin-top:1rem;padding:3px;margin-left:-3px;margin-right:-3px}.admin-info-editor{display:flex;flex-direction:column;gap:.6rem;min-height:0}.admin-info-label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:500;color:var(--muted-foreground)}.admin-info-label-grow{flex:1;min-height:0}.admin-info-textarea.markdown-editor{height:100%;background:var(--card);border:1px solid var(--input);border-radius:var(--radius);color:var(--foreground);transition:border-color .15s,box-shadow .15s}.admin-info-textarea.markdown-editor:focus-within{border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}.admin-info-preview{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;overflow-y:auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:1rem;line-height:1.45}.admin-info-title-input{width:100%;height:2.75rem;border:1px solid var(--input);border-radius:var(--radius);background:var(--card);color:var(--foreground);padding:0 .75rem;font:inherit;font-size:1rem}.admin-info-title-input:focus{outline:none;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}.admin-form label:not(.admin-check){display:flex;flex-direction:column;gap:.25rem;font-size:.82rem;color:var(--muted-foreground)}.admin-form input:not([type=checkbox]):not([type=radio]),.admin-form select,.admin-form textarea{width:100%;min-height:2rem;border:1px solid var(--input);border-radius:6px;background:var(--card);color:var(--foreground);padding:0 .5rem;font:inherit;font-size:.88rem}.admin-form textarea{resize:vertical;min-height:5.5rem;padding-top:.45rem}.admin-form input:not([type=checkbox]):not([type=radio]):focus,.admin-form select:focus,.admin-form textarea:focus{outline:none;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}.admin-field-help{color:var(--muted-foreground);font-size:.74rem;line-height:1.3}.admin-days-fieldset{border:1px solid var(--border);border-radius:6px;margin:0;padding:.4rem .6rem}.admin-days-fieldset legend{color:var(--muted-foreground);font-size:.82rem;padding:0 .2rem}.admin-untappd-row{display:flex;gap:.5rem;align-items:flex-end}.admin-untappd-field{flex:1;min-width:0}.admin-untappd-row .button{flex-shrink:0;margin-bottom:1px}.admin-untappd-preview{display:flex;gap:.75rem;align-items:center;padding:.6rem .75rem;background:var(--muted);border-radius:8px}.admin-untappd-meta{display:flex;flex-direction:column;gap:.15rem;min-width:0}.admin-untappd-meta span:first-child{font-size:.88rem;font-weight:600;color:var(--foreground)}.admin-check{display:inline-flex;flex-direction:row;align-items:center;gap:.4rem;margin-right:.8rem;font-size:.88rem;color:var(--foreground)}.admin-check input{width:auto;height:auto;margin:0}.venue-coord-row{display:flex;gap:.5rem;align-items:flex-end}.venue-coord-row label{flex:1;min-width:0}.venue-coord-row .button{flex-shrink:0;margin-bottom:2px}.admin-form-actions{display:flex;gap:.5rem;margin-top:.25rem}.button-ghost{background:transparent;border-color:var(--border);color:var(--secondary-foreground)}.button-ghost:hover{background:var(--muted)}.button-small{height:1.8rem;padding:0 .65rem;font-size:.82rem}.button-icon{padding:0 .4rem;border:none}.button-danger-text{color:var(--danger)}.admin-row-actions{display:flex;gap:4px;justify-content:flex-end}.admin-thumb{object-fit:cover;flex-shrink:0}.admin-thumb-sm{width:36px;height:36px;border-radius:6px}.admin-thumb-placeholder{border:1px dashed var(--border);background:var(--muted)}.admin-thumb-md{width:60px;height:60px;border-radius:8px}.admin-beer-cell{display:flex;align-items:center;gap:.65rem;min-width:0}.admin-beer-cell-name{min-width:0}.admin-file-input{padding-left:0;height:auto;padding-top:.3rem;padding-bottom:.3rem}.admin-image-preview{display:flex;gap:.5rem;align-items:center}.toast{position:fixed;right:1rem;bottom:1rem;z-index:30;background:var(--primary);color:var(--primary-foreground);border-radius:8px;border:1px solid var(--primary-hover);padding:.5rem .7rem;box-shadow:var(--shadow);opacity:0;transform:translateY(6px);transition:opacity .12s ease,transform .12s ease;pointer-events:none;font-size:.88rem}.toast.visible{opacity:1;transform:translateY(0)}.toast.error{background:var(--danger-soft);border-color:var(--danger);color:var(--danger-foreground)}.ut-section{margin-bottom:1.5rem}.ut-section-title{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.ut-link-controls{display:flex;align-items:center;gap:1rem;margin-top:.6rem;padding:.6rem .75rem;background:var(--muted);border-radius:8px}.ut-search-row{display:flex;gap:.5rem;margin-bottom:.6rem}.ut-search-row .search-input{flex:1}.ut-results{max-height:340px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);padding:.25rem 0}.ut-candidate{display:flex;align-items:center;gap:.65rem;padding:.45rem .75rem;transition:background .1s ease}.ut-candidate:hover{background:var(--surface-hover)}.ut-candidate.selected{background:var(--muted)}.ut-candidate-img{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0;background:var(--muted)}.ut-candidate-img.ut-placeholder{border:1px dashed var(--border)}.ut-candidate-info{flex:1;display:flex;flex-direction:column;gap:.05rem;min-width:0}.ut-candidate-name{font-weight:600;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ut-candidate-meta{font-size:.78rem;color:var(--muted-foreground)}.ut-candidate-brewery{font-size:.76rem;color:var(--muted-foreground)}.ut-import-form{display:flex;flex-direction:column;gap:.6rem;max-width:480px}.ut-import-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.82rem;color:var(--muted-foreground)}.ut-import-form input,.ut-import-form select{width:100%;height:2rem;border:1px solid var(--input);border-radius:6px;background:var(--card);color:var(--foreground);padding:0 .5rem;font:inherit;font-size:.88rem}.ut-import-form input:focus,.ut-import-form select:focus{outline:none;border-color:var(--focus-border);box-shadow:0 0 0 3px var(--ring)}.ut-overrides{border:1px solid var(--border);border-radius:8px;padding:.5rem .75rem}.ut-overrides summary{cursor:pointer;font-size:.84rem;color:var(--muted-foreground);font-weight:500}.ut-overrides[open] summary{margin-bottom:.5rem}.ut-overrides-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.admin-design-page{display:flex;flex-direction:column;gap:1rem;padding-bottom:2rem}.admin-design-lead{margin:0;color:var(--muted-foreground);max-width:68ch}.admin-design-section{border:1px solid var(--border);border-radius:var(--radius);background:var(--card);padding:1rem}.admin-design-section h3{font-size:1rem;margin:0 0 .85rem}.admin-design-stack{display:flex;flex-direction:column;gap:.35rem}.admin-display{font-size:clamp(1.4rem,2.2vw,1.75rem);line-height:1.2}.admin-design-row{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}.admin-design-controls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.admin-design-field{display:flex;flex-direction:column;gap:.35rem}.admin-design-label{font-size:.8rem;color:var(--muted-foreground)}.admin-text-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.admin-text-item{border:1px solid var(--border);border-radius:10px;background:var(--surface-subtle);padding:.55rem;display:flex;flex-direction:column;gap:.45rem}.admin-class-tag{display:inline-flex;align-items:center;width:fit-content;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.72rem;color:var(--muted-foreground);background:var(--card);border:1px solid var(--border);border-radius:999px;padding:.15rem .45rem}.admin-text-item-on-image{background:var(--primary);border-color:var(--primary-hover)}.admin-text-table{min-width:0}.admin-text-table th,.admin-text-table td{padding-left:.25rem;padding-right:.25rem}.admin-token-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem}.admin-token-card{border:1px solid var(--border);border-radius:10px;padding:.55rem;display:flex;gap:.55rem;align-items:center;background:var(--surface-subtle)}.admin-token-swatch{width:1.75rem;height:1.75rem;border-radius:8px;border:1px solid var(--border);flex-shrink:0}.admin-token-copy{min-width:0;display:flex;flex-direction:column;line-height:1.2}.admin-token-name{font-size:.8rem;font-weight:600}.admin-token-var{font-size:.72rem;color:var(--muted-foreground)}.admin-toast-preview-wrap{margin-top:.8rem;display:flex;flex-wrap:wrap;gap:.6rem}.admin-toast-preview{display:inline-flex;align-items:center;border-radius:8px;border:1px solid var(--primary-hover);padding:.45rem .65rem;font-size:.84rem;color:var(--primary-foreground);background:var(--primary)}.admin-toast-preview-error{border-color:var(--danger);color:var(--danger-foreground);background:var(--danger-soft)}.token-background{background:var(--background)}.token-foreground{background:var(--foreground)}.token-card{background:var(--card)}.token-muted{background:var(--muted)}.token-border{background:var(--border)}.token-primary{background:var(--primary)}.token-primary-foreground{background:var(--primary-foreground)}.token-danger{background:var(--danger)}.token-danger-soft{background:var(--danger-soft)}.token-surface-subtle{background:var(--surface-subtle)}.token-surface-hover{background:var(--surface-hover)}.token-card-foreground{background:var(--card-foreground)}.token-muted-hover{background:var(--muted-hover)}.token-muted-foreground{background:var(--muted-foreground)}.token-muted-foreground-secondary{background:var(--muted-foreground-secondary)}.token-input{background:var(--input)}.token-focus,.token-focus-border{background:var(--focus-border)}.token-primary-hover{background:var(--primary-hover)}.token-secondary{background:var(--secondary)}.token-secondary-foreground{background:var(--secondary-foreground)}.token-danger-foreground{background:var(--danger-foreground)}.token-star{background:var(--star)}.token-surface-subtle-secondary{background:var(--surface-subtle-secondary)}.token-on-image{background:var(--on-image)}.token-on-image-muted{background:var(--on-image-muted)}.token-location-badge-bg{background:var(--location-badge-bg)}.token-location-badge-bg-selected{background:var(--location-badge-bg-selected)}.token-location-badge-fg{background:var(--location-badge-fg)}.admin-panel-head .ds-theme-toggle{margin-left:auto}.ds-theme-toggle{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--muted);gap:1px}.ds-theme-btn{border:none;background:transparent;color:var(--muted-foreground);font:inherit;font-size:.82rem;font-weight:500;padding:.3rem .7rem;cursor:pointer;transition:background .1s ease,color .1s ease}.ds-theme-btn:hover{color:var(--foreground);background:var(--muted-hover)}.ds-theme-btn.active{background:var(--card);color:var(--foreground)}@media(max-width:640px){.navbar{display:none}.tabbar{position:fixed;left:var(--tabbar-edge-inset);right:var(--tabbar-edge-inset);bottom:var(--tabbar-edge-inset);z-index:10;display:block;pointer-events:none}.tabbar-inner{width:100%;margin:0 auto;padding:4px;background:color-mix(in srgb,var(--card) 88%,transparent);border-radius:999px;box-shadow:0 0 0 1px #0000000a,0 10px 32px #1018282e;backdrop-filter:blur(22px) saturate(180%);-webkit-backdrop-filter:blur(22px) saturate(180%);pointer-events:auto}.tabbar-links{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:2px;align-items:stretch;position:relative}.tabbar-indicator{position:absolute;top:0;bottom:0;left:0;width:calc((100% - 8px)/5);background:var(--tabbar-active-bg);border-radius:999px;transform:translate(calc(var(--tabbar-active-index, 0) * (100% + 2px)));transition:transform .24s cubic-bezier(.4,0,.2,1);pointer-events:none;z-index:0}.tabbar-link{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:0;min-height:3.4rem;border-radius:999px;color:color-mix(in srgb,var(--primary) 36%,transparent);transition:color .12s ease,background .12s ease,transform .14s ease-out;position:relative;z-index:1}.tabbar-link:hover,.tabbar-link.active{color:var(--foreground)}.tabbar-link:active{color:var(--foreground);transform:scale(.96);transition:color 60ms ease-out,background 60ms ease-out,transform 60ms ease-out}.tabbar-link-label{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%)}.mobile-navbar-right{display:flex;align-items:center;justify-content:flex-end;gap:.35rem;max-width:720px;width:100%;margin:0 auto;padding:.35rem .75rem 0}.mobile-navbar-right .navbar-icon-btn{justify-content:center;width:1.25rem;height:1.25rem;border-radius:999px;background:transparent;transition:color .12s ease,background .12s ease}.mobile-navbar-right .navbar-icon-btn svg{width:.875rem;height:.875rem}.mobile-navbar-right .navbar-icon-btn:hover,.mobile-navbar-right .navbar-icon-btn.active{background:var(--muted)}[data-feedback-toolbar]:not([style]){bottom:calc(var(--tabbar-reserved-height) + 1rem)!important}.app-update-prompt{bottom:calc(var(--tabbar-reserved-height) + .5rem)}.main-content{padding:calc(1.25rem + 24px + env(safe-area-inset-top,0px)) 1.25rem calc(2rem + var(--tabbar-reserved-height))}.main-content:has(.locations-page){padding:0}.beer-detail-page{padding-top:12px}.main-content:has(.brewery-detail-page){padding-top:env(safe-area-inset-top,0px);padding-inline:0}.brewery-detail-page{position:relative;isolation:isolate;padding-top:0}.brewery-detail-page>.back-link{position:absolute;top:calc(env(safe-area-inset-top,0px) + 40px);left:1.25rem;z-index:3;margin:0;background:var(--background)}.brewery-detail-page>.brewery-hero-card{border-radius:0;margin-top:-4px;margin-bottom:1.5rem;padding-bottom:1.75rem;-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 80' preserveAspectRatio='none'><path d='M0 0H40V72C35 82.67 25 82.67 20 72C15 61.33 5 61.33 0 72Z' fill='black'/></svg>"),linear-gradient(black,black);mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 80' preserveAspectRatio='none'><path d='M0 0H40V72C35 82.67 25 82.67 20 72C15 61.33 5 61.33 0 72Z' fill='black'/></svg>"),linear-gradient(#000,#000);-webkit-mask-size:40px 80px,100% calc(100% - 80px);mask-size:40px 80px,100% calc(100% - 80px);-webkit-mask-repeat:repeat-x,no-repeat;mask-repeat:repeat-x,no-repeat;-webkit-mask-position:left bottom,left top;mask-position:left bottom,left top}.brewery-detail-page>.beer-items,.brewery-detail-page>.brewery-empty{padding-inline:1.25rem}.breweries-page,.my-list-page,.info-page,.admin-layout{padding-top:8px}.locations-list{--locations-panel-radius: 18px;top:calc(8px + env(safe-area-inset-top,0px));left:8px;right:8px;bottom:auto;width:auto;height:168px}.locations-list[data-view=events]{height:240px}.locations-cards{flex-direction:row;overflow-x:auto;overflow-y:hidden;gap:6px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.locations-cards::-webkit-scrollbar{display:none}.location-card{flex-shrink:0;width:220px;border-radius:14px}.location-event-description{font-size:.72rem}.day-picker-btn{padding:.65rem 1rem;font-size:15px}.brewery-list-name{font-size:1.1rem}.brewery-list{gap:8px;margin-inline:-12px}.brewery-meta-stack{padding-bottom:4px;flex-direction:column;gap:0}.search-input{height:2.5rem;border-radius:999px;background-size:1.6rem 1.6rem;background-position:.85rem center;padding-left:2.95rem}.search-input::placeholder{color:var(--muted-foreground-secondary)}.beer-list-daybar,.beer-list-controls{top:calc(24px + env(safe-area-inset-top,0px))}.breweries-controls{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"search search" "floor toggle"}.breweries-controls>.search-input-wrap{grid-area:search}.breweries-controls>.floor-select-wrap{grid-area:floor}.breweries-controls>.view-toggle{grid-area:toggle}.navbar-inner{width:100%;border-left:none;border-right:none;border-radius:18px 18px 0 0}.admin-filters{flex-direction:column}.admin-nav-row{align-items:flex-start;flex-direction:column;gap:.5rem}.admin-two-col{grid-template-columns:1fr}.admin-sticky-form{position:static;max-height:none;overflow:visible}.admin-design-controls,.admin-token-grid,.admin-text-grid{grid-template-columns:1fr}.ut-search-row{flex-direction:column}.ut-overrides-grid{grid-template-columns:1fr}.ut-link-controls{flex-direction:column;align-items:stretch}}@media(max-width:720px){.admin-two-col{grid-template-columns:1fr}.app-shell:has(.admin-info-layout){height:auto;overflow:visible}.app-shell:has(.admin-info-layout) .main-content,.app-shell:has(.admin-info-layout) .admin-layout,.app-shell:has(.admin-info-layout) .admin-beer-list-page{display:block;overflow:visible}.admin-info-layout{grid-template-columns:1fr;overflow:visible;height:auto}.admin-info-textarea.markdown-editor{height:auto;min-height:240px}}
