.map-wrapper{flex:1;min-height:0}.popup{min-width:170px;max-width:230px;font-family:var(--font-body)}.popup-img{width:100%;height:110px;object-fit:cover;border-radius:8px;margin-bottom:8px}.popup-img-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-surface-soft);color:var(--color-orange)}.popup-img-placeholder svg{width:28px;height:28px}.popup strong{display:block;font-family:var(--font-display);font-size:.98rem;font-weight:600;margin-bottom:4px;color:var(--color-brown-dark)}.popup p{font-size:.82rem;color:var(--color-text-soft);line-height:1.35;white-space:pre-line}.popup-distance{margin-top:4px;font-weight:600;color:var(--color-orange)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;background:#140810eb;animation:lightbox-in .18s ease}@keyframes lightbox-in{0%{opacity:0}}.lightbox-stage{position:relative;width:100%;height:100%;overflow:hidden;touch-action:pan-y}.lightbox-track{display:flex;width:100%;height:100%;will-change:transform}.lightbox-slide{flex:0 0 100%;display:flex;align-items:center;justify-content:center}.lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.lightbox-close,.lightbox-nav{position:absolute;z-index:2;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#ffffff29;color:#fff;cursor:pointer;transition:background .15s ease}.lightbox-close:hover,.lightbox-nav:hover{background:#ffffff47}.lightbox-close{top:16px;right:16px;width:40px;height:40px}.lightbox-close svg{width:20px;height:20px}.lightbox-nav{top:50%;transform:translateY(-50%);width:44px;height:44px;font-size:28px;line-height:1;padding-bottom:3px}.lightbox-prev{left:12px}.lightbox-next{right:12px}.lightbox-nav:disabled{opacity:.3;cursor:default}.lightbox-nav:disabled:hover{background:#ffffff29}.lightbox-counter{position:absolute;bottom:18px;left:50%;transform:translate(-50%);color:#fff;font-size:.85rem;background:#0006;padding:4px 12px;border-radius:999px}.list-scroll{flex:1;min-height:0;display:flex;flex-direction:column}.shed-list{flex:1;min-height:0;list-style:none;padding:14px 16px 24px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.shed-card-li{display:flex;min-width:0}.shed-card-li>.shed-card{flex:1 1 auto;min-width:0}.shed-card{display:flex;flex-direction:column;gap:10px;background:var(--color-surface);border-radius:var(--radius-md);padding:12px;border:1px solid var(--color-border);box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow .18s ease,transform .18s ease}.shed-card-top{display:flex;gap:14px}.shed-card:hover,.shed-card:focus-visible{box-shadow:var(--shadow-md);transform:translateY(-1px)}.shed-card--selected{border-color:var(--color-orange);box-shadow:0 0 0 2px var(--color-orange),var(--shadow-md)}.shed-img{width:88px;height:88px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.shed-img-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-surface-soft);color:var(--color-orange)}.shed-img-placeholder svg{width:32px;height:32px}.shed-info{display:flex;flex-direction:column;justify-content:flex-start;flex:1;min-width:0}.shed-info .shed-status{margin-top:auto;margin-bottom:8px}.shed-info h2{display:flex;align-items:baseline;font-family:var(--font-display);font-size:1.1rem;font-weight:600;margin-top:8px;margin-bottom:4px;color:var(--color-text)}.shed-info h2 .verified-badge{width:1cap;height:1cap}.shed-name-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shed-card--featured{border-color:var(--color-orange);background:linear-gradient(180deg,rgba(214,40,57,.06),var(--color-surface) 60%);box-shadow:0 0 0 1px var(--color-orange),var(--shadow-md)}.featured-tag{display:inline-flex;align-items:center;align-self:flex-start;gap:3px;font-size:.7rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:#fff;background:var(--color-orange);padding:2px 8px;border-radius:999px;margin-bottom:4px}.shed-status{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:5px}.status-badge{font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap}.status-badge.open{background:#e3f3e3;color:var(--color-success)}.status-badge.closed{background:var(--color-surface-soft);color:var(--color-text-soft)}.status-badge.fresh{background:#fbeede;color:var(--color-orange-dark)}.status-badge.soldout{background:#fde4e1;color:var(--color-error)}.shed-city{font-weight:500;color:var(--color-text)}.shed-info p{font-size:.85rem;color:var(--color-text-soft);line-height:1.4;white-space:pre-line}.shed-distance{margin-top:2px;font-weight:600;color:var(--color-orange)}.shed-distance--aside{margin-top:0;align-self:center;margin-left:auto;padding-left:8px;font-size:.85rem;white-space:nowrap}.directions-btn{display:block;text-align:center;padding:7px 12px;background:var(--color-surface-soft);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;color:var(--color-brown);text-decoration:none;transition:background .15s ease,color .15s ease}.directions-btn:hover{background:var(--color-brown);color:#fff;border-color:var(--color-brown)}.list-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--color-text-soft);padding:40px 16px}.list-empty-icon{width:36px;height:36px;color:var(--color-text-faint)}.shed-extra{display:flex;flex-direction:column;gap:6px}.shed-hours{font-size:.84rem;font-weight:600;color:var(--color-success)}.shed-stocked{font-size:.82rem;color:var(--color-text-soft)}.shed-socials{display:flex;flex-wrap:wrap;gap:6px}.shed-socials a{font-size:.78rem;font-weight:600;color:var(--color-brown);background:var(--color-surface-soft);border:1px solid var(--color-border);border-radius:999px;padding:3px 10px;text-decoration:none}.shed-socials a:hover{background:var(--color-brown);color:#fff;border-color:var(--color-brown)}.shed-detail{position:relative;display:flex;flex-direction:column;flex:1;min-height:0;animation:detail-in .22s ease}.shed-detail-scroll{flex:1;min-height:0;overflow-y:auto;padding-bottom:24px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}@keyframes detail-in{0%{opacity:0;transform:translateY(6px)}}.shed-detail-close{position:absolute;top:12px;right:12px;z-index:2;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:none;background:#ffffffeb;color:var(--color-text);box-shadow:var(--shadow-sm);transition:background .15s ease}.shed-detail-close:hover{background:#fff}.shed-detail-close svg{width:16px;height:16px}.shed-detail-head{display:flex;gap:14px;padding:16px 56px 0 16px}.shed-detail-imgcol{display:flex;flex-direction:column;align-items:center;gap:10px;flex-shrink:0}.shed-detail-socials{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.social-icon{display:flex;align-items:center;justify-content:center;color:var(--color-orange);transition:transform .15s ease,color .15s ease}.social-icon svg{width:26px;height:26px;display:block}.social-icon:hover{transform:scale(1.12);color:var(--color-orange-dark)}.shed-detail-img{width:104px;height:104px;flex-shrink:0;object-fit:cover;border-radius:var(--radius-md)}.shed-detail-img.shed-img-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-surface-soft);color:var(--color-orange)}.shed-detail-img.shed-img-placeholder svg{width:40px;height:40px}.shed-detail-heading{display:flex;flex-direction:column;gap:6px;min-width:0}.shed-detail-body{display:flex;flex-direction:column;gap:8px;padding:14px 16px 16px}.shed-detail-heading h2{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--color-text);line-height:1.2}.shed-detail-heading h2 .verified-badge{width:1cap;height:1cap;vertical-align:baseline}.shed-detail-address{font-size:.9rem;color:var(--color-text-soft);line-height:1.4;white-space:pre-line}.shed-hours-block{margin-top:4px}.shed-hours-block h3{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--color-text);margin-bottom:6px}.shed-hours-table{width:100%;border-collapse:collapse;font-size:.86rem}.shed-hours-table th{text-align:left;font-weight:500;color:var(--color-text-soft);padding:4px 0}.shed-hours-table td{text-align:right;color:var(--color-text);padding:4px 0}.shed-hours-table tr.is-today th,.shed-hours-table tr.is-today td{font-weight:700;color:var(--color-brown)}.shed-hours-none{margin:0;font-size:.86rem;color:var(--color-text-soft)}.shed-detail-about h3{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--color-text);margin-bottom:6px}.shed-detail-description{font-size:.9rem;line-height:1.5;color:var(--color-text);white-space:pre-line}.shed-detail-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.shed-gallery-thumb{padding:0;border:none;background:none;cursor:pointer;display:block;border-radius:8px;overflow:hidden;-webkit-tap-highlight-color:transparent}.shed-gallery-thumb:active{opacity:.85}.shed-detail-gallery img{width:100%;aspect-ratio:1 / 1;object-fit:cover;display:block;border-radius:8px;border:1px solid var(--color-border)}.shed-detail-body .menu-btn{margin-top:6px;padding:10px 12px;font-size:.9rem;display:block;text-align:center;border-radius:var(--radius-sm);background:var(--color-brown);color:#fff3e0;text-decoration:none;font-weight:600;transition:background .15s ease}.shed-detail-body .menu-btn:hover{background:var(--color-brown-dark)}.shed-detail-body .directions-btn{margin-top:6px;padding:10px 12px;font-size:.9rem}.shed-page-link{display:block;text-align:center;margin-top:8px;font-size:.85rem;font-weight:600;color:var(--color-brown);text-decoration:underline}.shed-page-link:hover{color:var(--color-orange-dark)}.search-bar{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:12px 16px;background:var(--color-surface-soft);border-bottom:1px solid var(--color-border);max-height:200px;overflow:hidden;transition:max-height .34s cubic-bezier(.34,1.26,.64,1),padding .34s cubic-bezier(.34,1.26,.64,1),opacity .24s ease,border-color .24s ease}.search-bar--collapsed{max-height:0;padding-top:0;padding-bottom:0;opacity:0;border-bottom-color:transparent;pointer-events:none}.near-me-btn{display:flex;align-items:center;gap:7px;background:var(--color-orange);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 16px;font-size:.88rem;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-sm);transition:background .15s ease,transform .1s ease}.near-me-btn .btn-icon{width:16px;height:16px}.near-me-btn:hover:not(:disabled){background:var(--color-orange-dark)}.near-me-btn:active:not(:disabled){transform:scale(.97)}.near-me-btn:disabled{opacity:.6;cursor:not-allowed}.postcode-form{display:flex;gap:6px}.postcode-input-wrap{position:relative;display:flex;align-items:center}.postcode-input-icon{position:absolute;left:11px;width:15px;height:15px;color:var(--color-text-faint);pointer-events:none}.postcode-form input{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:9px 12px 9px 32px;font-size:.9rem;width:150px;outline:none;background:var(--color-surface);transition:border-color .15s ease}.postcode-form input:focus{border-color:var(--color-orange)}.postcode-form button{background:var(--color-brown);color:#fff;border:none;border-radius:var(--radius-sm);padding:9px 16px;font-size:.9rem;font-weight:600;transition:background .15s ease,transform .1s ease}.postcode-form button:hover:not(:disabled){background:var(--color-brown-dark)}.postcode-form button:active:not(:disabled){transform:scale(.97)}.postcode-form button:disabled{opacity:.5;cursor:not-allowed}.search-error{width:100%;color:var(--color-error);font-size:.85rem;margin-top:2px}@media (max-width: 480px){.near-me-label{display:none}.postcode-form,.postcode-input-wrap{flex:1}.postcode-form input{width:100%}}.town-banner{background:var(--color-surface);border-bottom:1px solid var(--color-border);max-height:200px;overflow:hidden;transition:max-height .3s ease,opacity .25s ease,padding .3s ease;opacity:1}.town-banner--hidden{max-height:0;opacity:0;border-bottom-color:transparent}.town-banner-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 16px}.town-banner-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--color-brown-dark);line-height:1.2}.town-banner-intro{margin-top:2px;font-size:.85rem;color:var(--color-text-soft);line-height:1.4}@media (max-width: 560px){.town-banner-intro{font-size:.82rem}}.app{display:flex;flex-direction:column;height:100%}.header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:1000}.logo{display:flex;align-items:center;gap:9px;min-width:0;text-decoration:none;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.logo:focus{outline:none}.logo-mark{width:38px;height:38px;flex-shrink:0;object-fit:contain}.logo-icon{width:19px;height:19px}.logo-text{margin:0;font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--color-brown-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.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}.btn-icon{width:16px;height:16px;flex-shrink:0}.header-actions{display:flex;align-items:center;gap:10px}.bakers-login-btn{display:flex;align-items:center;gap:6px;background:var(--color-brown);color:#fff;border:none;border-radius:var(--radius-sm);padding:9px 14px;font-size:.88rem;font-weight:600;white-space:nowrap;text-decoration:none;box-shadow:var(--shadow-sm);transition:background .15s ease,transform .1s ease}.bakers-login-btn:hover{background:var(--color-brown-dark)}.bakers-login-btn:active{transform:scale(.97)}.header-link{color:var(--color-brown);font-weight:600;font-size:.88rem;text-decoration:none;white-space:nowrap}.header-link:hover{text-decoration:underline}@media (max-width: 899px){.header-link{display:none}}.main{flex:1;min-height:0;display:flex;flex-direction:column}.map-view-slot{flex:1;min-height:0;display:flex;flex-direction:column;position:relative}.list-view-slot{min-height:0;display:flex;flex-direction:column;border-top:1px solid var(--color-border);background:var(--color-surface)}.list-drag-handle{display:none}@media (max-width: 899px){.main{position:relative}.list-view-slot{position:absolute;bottom:0;left:0;right:0;height:50%;border-top:none;border-radius:14px 14px 0 0;box-shadow:0 -4px 24px #00000026;overflow:hidden;z-index:10}.list-drag-handle{display:flex;align-items:center;justify-content:center;height:34px;flex-shrink:0;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;background:var(--color-surface)}.list-drag-handle:active{cursor:grabbing}.list-peek-grab{position:absolute;left:0;right:0;height:44px;z-index:11;touch-action:none;background:transparent}.list-drag-pill{width:40px;height:4px;border-radius:2px;background:#00000026}}@media (min-width: 900px){.main{flex-direction:row}.map-view-slot{order:2;flex:1 1 auto}.list-view-slot{order:1;position:static;flex:0 0 440px;min-width:0;max-width:440px;height:auto;border-top:none;border-right:1px solid var(--color-border);border-radius:0;box-shadow:none;overflow:visible;z-index:auto}}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--color-text-soft);font-size:.95rem;padding:40px 16px;text-align:center}.empty-spinner{width:32px;height:32px;border-radius:50%;border:3px solid var(--color-border);border-top-color:var(--color-orange);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{--color-bg: #fff3e0;--color-surface: #ffffff;--color-surface-soft: #f2e6d6;--color-border: #e7d6c0;--color-brown-dark: #3a1530;--color-brown: #4b1d3f;--color-orange: #d62839;--color-orange-dark: #b21f2d;--color-pink: #ff6b8b;--color-text: #4b1d3f;--color-text-soft: #7a5c6e;--color-text-faint: #a98fa0;--color-success: #2d7a2d;--color-error: #c0392b;--font-display: "Fredoka", "Segoe UI", sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--shadow-sm: 0 1px 3px rgba(75, 29, 63, .08);--shadow-md: 0 4px 16px rgba(75, 29, 63, .1);--shadow-lg: 0 12px 32px rgba(75, 29, 63, .16)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.verified-badge{display:inline-flex;align-items:center;justify-content:center;width:.95em;height:.95em;margin-left:.24em;color:var(--color-brown-dark);vertical-align:middle;line-height:0;flex:none}.verified-badge svg{display:block;width:100%;height:100%}html,body{height:100%}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;touch-action:manipulation}#root{height:100%;display:flex;flex-direction:column}button{cursor:pointer;font-family:inherit}button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--color-orange);outline-offset:2px}input,textarea{font-family:inherit}.uppercase-input::placeholder{text-transform:none}@media (pointer: coarse){input,textarea,select{font-size:16px!important}}::selection{background:#d6283938}@media (prefers-reduced-motion: no-preference){*{scroll-behavior:smooth}}
