/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--surface:#fafaf8;--surface-dim:#f0eeeb;--surface-container:#eaeae6;--surface-container-high:#e0deda;--on-surface:#1c1b1a;--on-surface-variant:#4a4845;--outline:#c4c0bb;--outline-variant:#e0dcda;--primary:#b45309;--primary-container:#fef3c7;--on-primary-container:#78350f;--secondary:#625b71;--tertiary:#7d5260;--error:#b3261e;--shadow:#00000014;--shadow-md:#0000001f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:9999px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}.dark{--surface:#1a1a1a;--surface-dim:#121212;--surface-container:#242424;--surface-container-high:#2e2e2e;--on-surface:#e8e4e0;--on-surface-variant:#9e9892;--outline:#444040;--outline-variant:#2e2a2a;--primary:#f59e0b;--primary-container:#3d2800;--on-primary-container:#ffd980;--shadow:#00000080;--shadow-md:#0009;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}body{background:var(--surface-dim);color:var(--on-surface);-webkit-font-smoothing:antialiased;background-image:url(/pattern-light.svg);background-size:140px 120px;margin:0;font-family:system-ui,-apple-system,sans-serif}html.dark body{background-image:url(/pattern-dark.svg)}a{color:var(--on-surface-variant);text-decoration:underline;-webkit-text-decoration-color:var(--outline);-webkit-text-decoration-color:var(--outline);-webkit-text-decoration-color:var(--outline);text-decoration-color:var(--outline)}#app{background:var(--surface);max-width:960px;min-height:100dvh;box-shadow:0 0 40px var(--shadow);flex-direction:column;margin:0 auto;display:flex}#header{border-bottom:1px solid var(--outline-variant);background:var(--surface);flex-shrink:0}.header-inner{justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.brand{letter-spacing:-.02em;color:var(--primary);white-space:nowrap;flex-shrink:0;align-items:center;gap:8px;font-family:Georgia,serif;font-size:1.05rem;font-weight:800;text-decoration:none;display:flex}.brand-text{display:none}@media (width>=480px){.brand-text{display:inline}}.header-logo{flex-shrink:0}.weather-badge{color:var(--on-surface-variant);white-space:nowrap;font-size:.7rem}.location-button{background:var(--surface-container);color:var(--on-surface-variant);border:1px solid var(--outline-variant);border-radius:var(--radius-full);cursor:pointer;flex:1;align-items:center;gap:6px;min-width:0;max-width:280px;padding:8px 14px;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .15s;display:flex}.location-button:hover{background:var(--surface-container-high)}.location-button #location-label{text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.location-chevron{opacity:.6;flex-shrink:0;font-size:.7rem}#kofi-link{z-index:10;text-decoration:none;position:absolute;top:8px;right:8px}.kofi-btn{background:var(--surface-container);color:var(--on-surface-variant);border-radius:var(--radius-full);white-space:nowrap;box-shadow:0 1px 4px var(--shadow);border:1px solid var(--outline-variant);align-items:center;gap:6px;padding:5px 12px;font-family:system-ui,sans-serif;font-size:.75rem;font-weight:700;transition:background .15s;display:inline-flex}.kofi-btn:hover{background:var(--surface-container-high)}.report-link{z-index:10;color:var(--primary);cursor:pointer;font-family:system-ui,sans-serif;font-size:.75rem;font-weight:600;text-decoration:none;position:absolute;top:44px;right:12px}.report-link:hover{text-decoration:underline}.report-link[hidden]{display:none}.kofi-btn img{opacity:.7}#location-overlay{z-index:1000;justify-content:center;align-items:flex-start;padding-top:80px;display:flex;position:fixed;inset:0}#location-overlay[hidden]{display:none}.location-overlay-backdrop{background:#00000080;position:absolute;inset:0}.location-overlay-content{background:var(--surface);border-radius:var(--radius-lg);width:90%;max-width:420px;box-shadow:0 10px 40px var(--shadow-md);padding:24px;position:relative}.location-overlay-content h3{margin:0 0 16px;font-size:1.05rem;font-weight:700}.location-overlay-close{width:32px;height:32px;color:var(--on-surface-variant);cursor:pointer;border-radius:var(--radius-full);background:0 0;border:none;font-size:1.4rem;line-height:1;position:absolute;top:12px;right:12px}.location-overlay-close:hover{background:var(--surface-container)}#contact-overlay{z-index:1000;justify-content:center;align-items:flex-start;padding-top:60px;display:flex;position:fixed;inset:0;overflow-y:auto}#contact-overlay[hidden]{display:none}.contact-overlay-backdrop{background:#00000080;position:fixed;inset:0}.contact-overlay-content{background:var(--surface);border-radius:var(--radius-lg);width:90%;max-width:440px;box-shadow:0 10px 40px var(--shadow-md);margin-bottom:40px;padding:24px;position:relative}.contact-overlay-content h3{margin:0 0 4px;font-size:1.1rem;font-weight:700}.contact-desc{color:var(--on-surface-variant);margin:0 0 16px;font-size:.85rem}.contact-overlay-close{width:32px;height:32px;color:var(--on-surface-variant);cursor:pointer;border-radius:var(--radius-full);background:0 0;border:none;font-size:1.4rem;line-height:1;position:absolute;top:12px;right:12px}.contact-overlay-close:hover{background:var(--surface-container)}.contact-pub-context{background:var(--surface-container);border-radius:var(--radius-md);color:var(--on-surface);margin-bottom:12px;padding:8px 12px;font-size:.85rem;font-weight:600}.contact-field{margin-bottom:12px}.contact-field label{color:var(--on-surface);margin-bottom:4px;font-size:.8rem;font-weight:600;display:block}.contact-optional{color:var(--on-surface-variant);font-weight:400}.contact-field input,.contact-field textarea,.contact-field select{border:1px solid var(--outline);border-radius:var(--radius-md);background:var(--surface);width:100%;color:var(--on-surface);font:inherit;padding:10px 12px;font-size:.88rem;line-height:1.5}.contact-field input:focus,.contact-field textarea:focus,.contact-field select:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary);outline:none}@supports (color:color-mix(in lab, red, red)){.contact-field input:focus,.contact-field textarea:focus,.contact-field select:focus{box-shadow:0 0 0 2px color-mix(in srgb, var(--primary) 15%, transparent)}}.contact-field textarea{resize:vertical;min-height:100px}.contact-hp{position:absolute;left:-9999px}.contact-submit{border-radius:var(--radius-md);background:var(--primary);color:#fff;font:inherit;cursor:pointer;border:none;align-items:center;gap:6px;margin-top:4px;padding:10px 20px;font-size:.88rem;font-weight:600;display:inline-flex}.contact-submit:hover{opacity:.9}.contact-submit:disabled{opacity:.5;cursor:not-allowed}.contact-status{border-radius:var(--radius-md);margin-top:12px;padding:10px 14px;font-size:.85rem}.contact-status--success{background:#22c55e}@supports (color:color-mix(in lab, red, red)){.contact-status--success{background:color-mix(in srgb, #22c55e 12%, var(--surface))}}.contact-status--success{color:#16a34a;border:1px solid #22c55e40}.contact-status--error{background:#ef4444}@supports (color:color-mix(in lab, red, red)){.contact-status--error{background:color-mix(in srgb, #ef4444 12%, var(--surface))}}.contact-status--error{color:#dc2626;border:1px solid #ef444440}@media (width<=500px){#contact-overlay{align-items:stretch;padding-top:0}.contact-overlay-content{border-radius:0;width:100%;max-width:none;min-height:100vh;margin-bottom:0}}.location-gps-btn{border:1px solid var(--outline);border-radius:var(--radius-md);background:var(--surface-container);width:100%;color:var(--on-surface);cursor:pointer;justify-content:center;align-items:center;gap:8px;margin-bottom:12px;padding:12px;font-family:inherit;font-size:.9rem;font-weight:600;transition:background .15s;display:flex}.location-gps-btn:hover{background:var(--surface-container-high)}.location-gps-btn #gps-icon{align-items:center;display:flex}.location-search-wrap{position:relative}#location-search-input{border:1px solid var(--outline);border-radius:var(--radius-md);background:var(--surface-container);width:100%;color:var(--on-surface);outline:none;padding:12px 16px;font-family:inherit;font-size:.9rem}#location-search-input:focus{border-color:var(--primary)}#location-search-results{max-height:240px;margin:8px 0 0;padding:0;list-style:none;overflow-y:auto}#location-search-results li{cursor:pointer;color:var(--on-surface);border-radius:var(--radius-sm);padding:10px 14px;font-size:.85rem;transition:background .1s}#location-search-results li:hover{background:var(--surface-container)}#location-search-results li.no-results{color:var(--on-surface-variant);cursor:default}#main{flex-direction:column;flex:1 0 auto;display:flex}@media (width>=768px){#main{flex-direction:row;align-items:flex-start;padding-right:340px;position:relative}}.sunny-badge{white-space:nowrap;background:var(--surface-container);color:var(--on-surface);border:1px solid var(--outline-variant);border-radius:9999px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:600;line-height:1.2;display:inline-flex}.sunny-badge:before{content:"☀";font-size:.85em;line-height:1}.sunny-badge--trap{color:#78350f;background:#fde68a;border-color:#fbbf24}.sunny-badge--very{color:#92400e;background:#fef3c7;border-color:#fcd34d}.sunny-badge--sunny{color:#a16207;background:#fffbeb;border-color:#fef3c7}.sunny-badge--partial{background:var(--surface-container);color:var(--on-surface-variant);border-color:var(--outline-variant)}.sunny-badge--shaded{background:var(--surface-container-high);color:var(--on-surface-variant);border-color:var(--outline)}html.dark .sunny-badge--trap{color:#fde68a;background:#78350f;border-color:#d97706}html.dark .sunny-badge--very{color:#fcd34d;background:#5a2c0a;border-color:#b45309}html.dark .sunny-badge--sunny{color:#fde68a;background:#3d2305;border-color:#92400e}.sunny-badge--lg{box-sizing:border-box;white-space:normal;border-radius:12px;align-items:center;width:100%;padding:10px 14px;font-size:.95rem;display:flex;position:relative}.sunny-badge--lg:before{display:none}.sunny-badge--lg .sunny-badge-main{align-items:center;gap:14px;display:flex}.sunny-badge--lg .sunny-badge-score{flex-shrink:0;align-items:baseline;gap:2px;font-size:2rem;font-weight:800;line-height:1;display:flex}.sunny-badge--lg .sunny-badge-score:before{content:"☀";margin-right:6px;font-size:1.4rem;line-height:1}.sunny-badge--lg .sunny-badge-score-max{font-size:.85rem;font-weight:700}.sunny-badge--lg .sunny-badge-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sunny-badge--lg .sunny-badge-label{letter-spacing:.01em;font-size:1rem;font-weight:700;line-height:1.2}.sunny-badge--lg .sunny-badge-window{opacity:1;font-size:.8rem;font-weight:600;line-height:1.2}.sunny-badge--lg .sunny-badge-explainer{font-size:.7rem;line-height:1;position:absolute;top:8px;right:12px}.sunny-badge--lg .sunny-badge-explainer a{color:inherit;text-decoration:underline}.pub-info-sun{margin:8px 0 12px}.pub-info-sun:empty{display:none}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.seo-intro--landing{clip:auto;white-space:normal;border-bottom:1px solid var(--outline-variant);background:var(--surface);text-align:left;flex-shrink:0;width:auto;height:auto;padding:10px 16px 12px;position:static;overflow:visible}.seo-intro--landing .seo-breadcrumb{color:var(--on-surface-variant);margin:0 0 2px;font-size:.75rem}.seo-intro--landing .seo-breadcrumb a{color:inherit;text-decoration:none}.seo-intro--landing .seo-breadcrumb a:hover{text-decoration:underline}.seo-intro--landing h1{color:var(--on-surface);margin:0;font-size:1.05rem;font-weight:600;line-height:1.3}.seo-intro--landing>p{color:var(--on-surface-variant);margin:2px 0 0;font-size:.8rem;line-height:1.4}@media (width>=768px){.seo-intro--landing{padding:14px 24px}.seo-intro--landing h1{font-size:1.25rem}.seo-intro--landing>p{font-size:.875rem}}.seo-intro--landing .seo-pub-list-wrap{margin-top:6px}.seo-intro--landing .seo-pub-list-wrap>summary{cursor:pointer;color:var(--on-surface-variant);-webkit-user-select:none;user-select:none;align-items:center;gap:4px;font-size:.75rem;list-style:none;display:inline-flex}.seo-intro--landing .seo-pub-list-wrap>summary::-webkit-details-marker{display:none}.seo-intro--landing .seo-pub-list-wrap>summary:before{content:"▸";font-size:.7rem;transition:transform .15s;display:inline-block}.seo-intro--landing .seo-pub-list-wrap[open]>summary:before{transform:rotate(90deg)}.seo-intro--landing .seo-pub-list-wrap>summary:hover{color:var(--on-surface)}.seo-intro--landing .seo-pub-list{columns:2;column-gap:24px;margin:8px 0 4px;padding:0;font-size:.85rem;line-height:1.6;list-style:none}.seo-intro--landing .seo-pub-list li{break-inside:avoid}.seo-intro--landing .seo-pub-list a{color:var(--primary);min-height:24px;padding:4px 0;text-decoration:none;display:inline-block}.seo-intro--landing .seo-pub-list a:hover{text-decoration:underline}@media (width>=768px){.seo-intro--landing .seo-pub-list{columns:3}}@media (width<=480px){.seo-intro--landing .seo-pub-list{columns:1}}#viz{flex-direction:column;flex:1;align-items:center;min-height:calc(100dvh - 108px);padding:8px 16px;display:flex}@media (width>=768px){#viz{justify-content:flex-start;min-height:0;padding:16px 24px}}#circle-wrap{width:100%;max-width:min(400px,100vw - 32px);position:relative;container-type:inline-size}#porthole-controls-left,#porthole-controls-right{z-index:5;align-items:center;gap:4px;display:flex;position:absolute;bottom:4px}#porthole-controls-left{left:4px}#porthole-controls-right{right:4px}.porthole-btn--rim{border:1px solid var(--outline-variant);border-radius:var(--radius-md);background:var(--surface-container);width:30px;height:30px;color:var(--on-surface-variant);cursor:pointer;box-shadow:0 1px 6px var(--shadow);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:inline-flex}.porthole-btn--rim:hover{background:var(--surface-container-high)}.porthole-btn--rim:disabled{opacity:.3;cursor:default}.porthole-btn--rim.active{background:var(--primary);color:#fff;border-color:var(--primary)}.porthole-zoom{background:var(--surface-container);border:1px solid var(--outline-variant);border-radius:var(--radius-md);box-shadow:0 1px 6px var(--shadow);flex-direction:row;align-items:center;display:flex;overflow:hidden}.porthole-zoom .porthole-btn--rim{box-shadow:none;border:none;border-radius:0;width:30px;height:26px}.porthole-zoom .porthole-btn--rim:first-child{border-right:1px solid var(--outline-variant)}.porthole-zoom .porthole-btn--rim:last-child{border-left:1px solid var(--outline-variant)}.zoom-label{color:var(--on-surface-variant);text-align:center;padding:2px 0;font-family:system-ui,sans-serif;font-size:.65rem;font-weight:700}#arc-wrap{width:100%;max-width:min(400px,100vw - 32px);margin-top:-4px}@media (width>=768px){#circle-wrap,#arc-wrap{max-width:460px}}#circle-canvas,#circle-canvas-big,#arc-canvas{width:100%;display:block}#arc-canvas{height:110px}#circle-canvas{height:calc(100cqi + 32px)}.arc-controls{justify-content:space-between;align-items:center;margin-top:6px;padding:0 4px;display:flex}.arc-left{align-items:center;gap:10px;display:flex}#btn-play{border-radius:var(--radius-full);background:var(--primary);color:#fff;cursor:pointer;width:36px;height:36px;box-shadow:0 1px 3px var(--shadow-md);border:none;justify-content:center;align-items:center;transition:opacity .15s;display:flex}#btn-play:hover{opacity:.85}#time-display{color:var(--on-surface);font-family:ui-monospace,monospace;font-size:.875rem;font-weight:600}.arc-right{align-items:center;gap:8px;display:flex}#btn-share,#btn-directions{border-radius:var(--radius-full);background:var(--surface-container);width:32px;height:32px;color:var(--on-surface-variant);cursor:pointer;border:none;justify-content:center;align-items:center;transition:background .15s;display:flex}#btn-share:hover,#btn-directions:hover{background:var(--surface-container-high)}#btn-now,#btn-date{color:var(--on-surface-variant);background:var(--surface-container);border-radius:var(--radius-sm);cursor:pointer;border:none;padding:4px 10px;font-size:.8125rem;transition:background .15s}#btn-date:hover{background:var(--surface-container-high)}#date-input{opacity:0;pointer-events:none;position:absolute}#pubs{background:var(--surface);border-top:1px solid var(--outline-variant);border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-width:960px;box-shadow:0 -4px 20px var(--shadow-md);z-index:40;flex-direction:column;max-height:60vh;margin:0 auto;transition:transform .3s;display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(calc(100% - 48px))}#pubs.open{transform:translateY(0)}.pubs-handle{cursor:pointer;flex-direction:column;flex-shrink:0;align-items:center;padding:8px 16px 4px;display:flex}.handle-bar{background:var(--outline);border-radius:2px;width:36px;height:4px;margin-bottom:4px}.handle-label{color:var(--on-surface-variant);font-size:.75rem;font-weight:600}@media (width>=768px){#pubs{border-top:none;border-left:1px solid var(--outline-variant);width:340px;max-width:none;max-height:none;box-shadow:none;border-radius:0;flex:none;margin:0;transition:none;position:absolute;inset:0 0 0 auto;overflow-y:auto;transform:none}.pubs-handle{display:none}}.search-wrap{border-bottom:1px solid var(--outline-variant);align-items:center;gap:8px;padding:10px 12px;display:flex}.filter-chips{border-bottom:1px solid var(--outline-variant);flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;padding:8px 12px;display:flex}.filter-chips--row2{border-bottom:1px solid var(--outline-variant)}.filter-chips:not(.filter-chips--row2)+.filter-chips--row2{border-top:none;padding-top:0}.filter-chips:has(+.filter-chips--row2){border-bottom:none;padding-bottom:4px}.filter-chip{border:1px solid var(--outline);border-radius:var(--radius-full);background:var(--surface);color:var(--on-surface-variant);cursor:pointer;padding:4px 12px;font-family:inherit;font-size:.78rem;transition:all .15s}.filter-chip:hover{background:var(--surface-container)}.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.sort-toggle{background:var(--surface-container);border-radius:var(--radius-full);border:1px solid var(--outline-variant);padding:2px;display:inline-flex}.sort-toggle button{color:var(--on-surface-variant);border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:2px 10px;font-family:inherit;font-size:.72rem;font-weight:600;transition:all .15s}.sort-toggle button:hover{color:var(--on-surface)}.sort-toggle button.active{background:var(--surface);color:var(--primary);box-shadow:0 1px 3px var(--shadow)}.filter-label{color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.distance-toggle{background:var(--surface-container);border-radius:var(--radius-full);border:1px solid var(--outline-variant);padding:2px;display:inline-flex}.distance-toggle button{color:var(--on-surface-variant);border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:2px 9px;font-family:inherit;font-size:.72rem;font-weight:600;transition:all .15s}.distance-toggle button:hover{color:var(--on-surface)}.distance-toggle button.active{background:var(--surface);color:var(--primary);box-shadow:0 1px 3px var(--shadow)}#pub-search{border:1px solid var(--outline);border-radius:var(--radius-full);background:var(--surface-container);color:var(--on-surface);outline:none;flex:1;padding:8px 12px;font-size:.8125rem;transition:border-color .15s}#pub-search:focus{border-color:var(--primary)}#pub-search::placeholder{color:var(--on-surface-variant);opacity:.6}#pub-list{scrollbar-width:thin;scrollbar-color:var(--outline) transparent;flex:1;margin:0;padding:0;list-style:none;overflow-y:auto}#pub-list li{cursor:pointer;border-bottom:1px solid var(--outline-variant);padding:10px 16px;transition:background .12s}#pub-list li:hover{background:var(--surface-container)}#pub-list li[aria-selected=true]{background:var(--primary-container);font-weight:600}.pub-name{text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:500;overflow:hidden}.pub-dist{color:var(--on-surface-variant);flex-shrink:0;margin-left:8px;font-size:.75rem}.pub-meta{color:var(--on-surface-variant);margin-top:2px;font-size:.75rem}.pub-maps{color:var(--primary);margin-top:3px;font-size:.6875rem;font-weight:600;text-decoration:none;transition:opacity .12s;display:inline-block}.pub-maps:hover{opacity:1}.pub-info{width:100%;padding:16px 0}.pub-info[hidden]{display:none}.pub-info-header{margin-bottom:12px}.pub-info-header h2{flex-wrap:wrap;align-items:center;gap:8px;margin:0;font-size:1.05rem;font-weight:700;display:flex}.pub-info-brand{color:var(--on-surface-variant);margin-top:3px;font-size:.8rem}.status-open{color:#14532d;border-radius:var(--radius-full);white-space:nowrap;background:#dcfce7;padding:2px 10px;font-size:.7rem;font-weight:700}html.dark .status-open{color:#bbf7d0;background:#14532d}.status-closed{background:var(--surface-container);color:#3a3835;border-radius:var(--radius-full);white-space:nowrap;padding:2px 10px;font-size:.7rem;font-weight:700}html.dark .status-closed{color:#d6d2cd}.pub-info-grid{grid-template-columns:1fr 1fr;gap:6px;margin-bottom:14px;display:grid}.pub-info-cell{background:var(--surface-container);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.cell-label{color:var(--on-surface-variant);font-size:.82rem}.cell-value{font-size:.82rem;font-weight:700}.val-yes{color:#14532d}.val-no{color:#6b6862}.val-limited{color:#92400e}.val-unknown{color:var(--on-surface-variant);opacity:.3;font-weight:400}.pub-info-hours{color:var(--on-surface-variant);margin-bottom:14px;font-size:.85rem;line-height:1.5}.hours-table{border-collapse:separate;border-spacing:0 2px;width:100%;font-size:.85rem}.hours-table td{border:none;padding:5px 8px}.hours-table td:first-child{color:var(--on-surface-variant);width:48px;font-weight:600}.hours-table tr.hours-today{background:var(--primary-container)}.hours-table tr.hours-today td{color:var(--on-primary-container);font-weight:700}.hours-table tr.hours-today td:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.hours-table tr.hours-today td:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.pub-info-links{flex-wrap:wrap;gap:16px;font-size:.85rem;display:flex}.pub-info-links a{color:var(--primary);text-decoration:none}.pub-info-links a:hover{text-decoration:underline}#footer{color:var(--on-surface-variant);border-top:1px solid var(--outline-variant);background:var(--surface);flex-direction:column;flex-shrink:0;align-items:center;gap:10px;padding:12px 16px;display:flex}@media (width<=767px){#footer{padding-bottom:60px}}.footer-attr{text-align:center;color:var(--on-surface-variant);font-size:.72rem;line-height:1.5}.footer-attr a{color:var(--on-surface);text-decoration:none}.footer-attr a:hover{text-decoration:underline}.footer-right{align-items:center;gap:10px;display:inline-flex}.footer-github{color:var(--on-surface-variant);opacity:.75;justify-content:center;align-items:center;transition:opacity .15s;display:inline-flex}.footer-github:hover{opacity:1;color:var(--on-surface)}.theme-toggle{background:var(--surface-container);border-radius:var(--radius-full);border:1px solid var(--outline-variant);padding:2px;display:inline-flex}.theme-toggle button{color:var(--on-surface-variant);border-radius:var(--radius-full);cursor:pointer;background:0 0;border:none;padding:3px 10px;font-family:inherit;font-size:.68rem;font-weight:600;transition:all .15s}.theme-toggle button:hover{color:var(--on-surface)}.theme-toggle button.active{background:var(--surface);color:var(--primary);box-shadow:0 1px 3px var(--shadow)}#welcome-modal{z-index:110;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.welcome-backdrop{-webkit-backdrop-filter:blur(4px);background:#0009;position:absolute;inset:0}.welcome-content{background:var(--surface);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:min(440px,92vw);padding:28px 28px 22px;position:relative;box-shadow:0 24px 60px #0006}.welcome-header{flex-direction:column;align-items:center;gap:8px;margin-bottom:12px;display:flex}.welcome-logo{width:56px;height:56px}.welcome-content h2{color:var(--on-surface);letter-spacing:-.5px;margin:0;font-family:Georgia,serif;font-size:1.5rem;font-weight:700}.welcome-blurb{color:var(--on-surface-variant);margin:0 0 18px;font-size:.95rem;line-height:1.5}.welcome-question{color:var(--on-surface);margin:0 0 14px;font-size:1rem;font-weight:600}.welcome-actions{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.welcome-actions button{border-radius:var(--radius-md);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-size:1rem;font-weight:600;transition:opacity .15s,transform 80ms;display:inline-flex}.welcome-actions button:active{transform:translateY(1px)}.welcome-primary{background:var(--primary);color:#fff}.welcome-primary:hover{opacity:.92}.welcome-secondary{background:var(--surface-container);color:var(--on-surface);border-color:var(--outline-variant)}.welcome-secondary:hover{background:var(--surface-container-high)}.welcome-skip{color:var(--on-surface-variant);cursor:pointer;text-decoration:underline;-webkit-text-decoration-color:var(--outline);-webkit-text-decoration-color:var(--outline);-webkit-text-decoration-color:var(--outline);text-decoration-color:var(--outline);text-underline-offset:3px;background:0 0;border:none;padding:6px 10px;font-size:.85rem}.welcome-skip:hover{color:var(--on-surface)}#share-dialog{z-index:100;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.share-dialog-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;position:absolute;inset:0}.share-dialog-content{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:min(820px,90vw);padding:20px;position:relative;box-shadow:0 16px 48px #0006}.share-dialog-content img{border-radius:var(--radius-md);width:100%;margin-bottom:12px}.share-dialog-close{color:var(--on-surface-variant);cursor:pointer;background:0 0;border:none;font-size:1.5rem;line-height:1;position:absolute;top:8px;right:12px}.share-dialog-actions{gap:8px;margin-bottom:10px;display:flex}.share-dialog-actions button{border-radius:var(--radius-sm);cursor:pointer;border:none;flex:1;padding:8px;font-size:.8rem;font-weight:600;transition:opacity .15s}.share-btn-copy{background:var(--primary);color:#fff}.share-btn-download{background:var(--surface-container-high);color:var(--on-surface)}.share-dialog-actions button:hover{opacity:.85}.share-dialog-link{border:1px solid var(--outline);border-radius:var(--radius-sm);background:var(--surface-container);width:100%;color:var(--on-surface-variant);outline:none;padding:6px 10px;font-family:ui-monospace,monospace;font-size:.7rem}#circle-fullscreen{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000c;justify-content:center;align-items:center;display:none;position:fixed;inset:0}#circle-fullscreen.active{display:flex}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
