:root{color:#202725;background:#fff;--page-bg: #ffffff;--panel-bg: #ffffff;--surface-bg: #fbfdfc;--panel-tint: #f3f8f5;--highlight-bg: #f4f9fd;--accent-green: #155c36;--accent-blue: #6fa8dc;--text: #202725;--muted: #5f6f68;--border: #c7ddd2;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;background:var(--page-bg);color:var(--text)}button,input{font:inherit}button{cursor:pointer}.app-shell{width:min(100%,960px);min-height:100vh;margin:0 auto;padding:clamp(16px,3vh,24px) 24px 24px;display:grid;gap:16px;align-content:start}.today-panel,.forecast-panel{border:1px solid var(--border);border-radius:8px;background:var(--panel-bg);box-shadow:0 16px 42px #155c3614}.today-panel{container-type:inline-size;padding:28px}.forecast-panel{padding:22px}.city-page{width:min(100%,640px);max-width:640px;align-content:start;gap:8px;padding-top:clamp(8px,3vh,24px)}.search-page{width:min(100%,640px);max-width:640px;grid-template-columns:1fr;gap:8px}.search-page .today-panel{padding-block:22px}.search-page h1{white-space:nowrap;font-size:clamp(1.6rem,9cqw,3.25rem)}.brand-logo{display:block;width:100%;height:auto}.search-page-header{padding:0 4px}.search-page-header h1{margin-bottom:0;display:flex;justify-content:center;line-height:1}.city-page-header{position:relative;padding:0 4px}.city-page-header h1{position:relative;z-index:1;max-width:none;margin-bottom:0;display:flex;justify-content:center;font-size:clamp(1.85rem,7vw,3rem);line-height:1;pointer-events:none}.brand-logo-header{width:min(100%,280px)}.city-page-header-link{position:absolute;inset:-8px;z-index:0;border:0;border-radius:8px;background:transparent}.city-page-header:hover,.city-page-header:has(.city-page-header-link:focus-visible){color:var(--accent-green)}.city-page-header-link:focus-visible{outline:0}.city-detail{container-type:inline-size;padding:18px}.city-heading{max-width:none;margin-bottom:0;overflow-wrap:anywhere;font-size:clamp(1.8rem,8cqw,3.2rem);line-height:1}.city-heading-row{margin-bottom:18px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.city-detail .placeholder-score{margin-bottom:16px}.city-meta{margin-bottom:18px;color:var(--muted);font-weight:700}.back-button{min-height:40px;margin-bottom:24px;border:1px solid var(--border);border-radius:8px;padding:0 12px;background:var(--panel-tint);color:var(--text);font-weight:800}.back-button:hover,.back-button:focus-visible{border-color:var(--accent-blue);outline:0}.eyebrow,.panel-label{margin:0 0 8px;color:var(--muted);font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin-top:0}h1{max-width:none;margin-bottom:12px;font-size:clamp(2.4rem,8vw,4.6rem);line-height:.98;letter-spacing:0}h2{margin-bottom:8px;font-size:1.35rem;line-height:1.15}.answer{max-width:none;margin-bottom:28px;color:var(--muted);font-size:clamp(.98rem,3.8vw,1.1rem);line-height:1.45}.search-page .answer{margin-bottom:20px;line-height:1.35}.search-form{display:grid;gap:8px}.search-form label{color:var(--text);font-weight:700}.city-search-form{margin-bottom:28px}.search-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px}.search-row input{width:100%;min-height:48px;border:1px solid var(--border);border-radius:8px;padding:0 14px;background:var(--surface-bg);color:var(--text)}.search-row input:focus{border-color:var(--accent-blue);outline:3px solid rgba(111,168,220,.24)}.search-row button{min-height:48px;border:0;border-radius:8px;padding:0 18px;background:var(--accent-green);color:#fff;font-weight:800}.search-row button:disabled{cursor:wait;opacity:.72}.search-row .location-button{min-width:48px;padding:0;display:grid;place-items:center;background:var(--accent-green);color:#fff;font-size:1.35rem}.search-row .location-button:hover,.search-row .location-button:focus-visible{outline:3px solid rgba(111,168,220,.24);outline-offset:0}.status{margin:14px 0 0;font-weight:700}.error{color:#9c3f22}.results{margin-top:18px;display:grid;gap:8px}.place-result{width:100%;min-height:58px;border:1px solid var(--border);border-radius:8px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;background:var(--surface-bg);color:var(--text);overflow:hidden}.place-result-main{min-width:0;border:0;padding:10px 12px;background:transparent;color:inherit;text-align:left}.place-result:hover,.place-result:focus-within{border-color:var(--accent-blue)}.place-result-main:focus-visible{outline:3px solid rgba(111,168,220,.24);outline-offset:-3px}.place-result-main span{font-weight:800}.place-result small{color:var(--muted)}.favorites-section{margin-top:22px}.favorites-section h2{margin-bottom:10px;color:var(--muted);font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}.favorites-results{margin-top:0}.favorite-button{width:48px;min-height:48px;border:0;border-left:1px solid var(--border);display:grid;place-items:center;background:var(--surface-bg);color:var(--muted);font-size:1.25rem;line-height:1}.favorite-button:hover,.favorite-button:focus-visible{color:var(--accent-blue);outline:3px solid rgba(111,168,220,.24);outline-offset:-3px}.favorite-button-active{color:var(--accent-green)}.city-favorite-button{width:46px;min-height:46px;border:1px solid var(--border);border-radius:8px}.forecast-panel p{margin-bottom:0;color:var(--muted);line-height:1.5}.placeholder-score{width:fit-content;margin-top:18px;border-radius:8px;padding:8px 10px;background:var(--panel-tint);color:var(--text);font-weight:800}.loading-row{width:fit-content;margin:18px 0 16px;border-radius:8px;padding:8px 10px;display:inline-flex;align-items:center;gap:8px;background:var(--panel-tint);color:var(--text);font-weight:800}.loading-spinner{width:16px;height:16px;border:2px solid rgba(111,168,220,.25);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.wind-sections{margin:18px 0;display:grid;gap:12px}.wind-card{border:1px solid var(--border);border-radius:8px;padding:12px;display:grid;gap:12px;background:var(--surface-bg)}.wind-card-current-collapsed{gap:8px;padding-block:8px}.current-wind-toggle{width:100%;border:0;padding:0;display:grid;grid-template-columns:minmax(0,1fr) var(--forecast-status-column, 9.25rem) 1.35rem;align-items:center;gap:10px;background:transparent;color:inherit;text-align:left}.current-wind-toggle .wind-card-label{margin-bottom:0}.current-wind-toggle:focus-visible{border-radius:8px;outline:3px solid rgba(111,168,220,.24);outline-offset:4px}.current-wind-toggle .current-hourly-caret{grid-column:3}.current-wind-summary-icon{width:24px;height:24px;border:1px solid var(--border);border-radius:50%;display:inline-grid;place-items:center;background:#fff;font-size:.78rem;line-height:1}.current-wind-details{display:grid;gap:12px}.forecast-days-list{display:grid}.daily-wind-row{border-bottom:1px solid var(--border);padding:6px 0;display:grid;gap:0}.daily-wind-row:last-child{border-bottom:0;padding-bottom:0}.daily-wind-toggle{width:100%;border:0;padding:0;background:transparent;color:inherit;text-align:left}.daily-wind-toggle:focus-visible{border-radius:8px;outline:3px solid rgba(111,168,220,.24);outline-offset:3px}.daily-wind-heading{display:grid;grid-template-columns:minmax(0,1fr) var(--forecast-status-column, 9.25rem) 1.35rem;gap:8px;align-items:center}.daily-wind-date{display:block;color:var(--text);font-size:1rem;font-weight:900;line-height:1.1}.daily-wind-label{display:inline-flex;align-items:center;gap:4px;justify-self:start;font-weight:900;white-space:nowrap}.daily-wind-caret{color:var(--accent-blue);position:relative;width:1.35rem;height:1.35rem;display:inline-block;font-size:0}.daily-wind-caret:before{content:"";position:absolute;top:50%;left:50%;box-sizing:border-box;width:.58rem;height:.58rem;border-right:3px solid currentColor;border-bottom:3px solid currentColor;transform:translate(-50%,-43%) rotate(45deg) scaleY(1);transform-origin:center;transition:transform .16s ease}.daily-wind-toggle[aria-expanded=true] .daily-wind-caret:before{transform:translate(-50%,-43%) scaleY(-1) rotate(45deg)}.daily-hourly-panel{border-top:1px solid rgba(111,168,220,.35);padding-top:12px;display:grid;gap:8px}.current-hourly-panel{border-top:0;padding-top:0}.forecast-details{display:grid;grid-template-rows:0fr;margin-top:0;opacity:0;transition:grid-template-rows .18s ease,margin-top .18s ease,opacity .14s ease}.forecast-details-expanded{grid-template-rows:1fr;margin-top:8px;opacity:1}.forecast-details-inner{min-height:0;overflow:hidden}.daily-hourly-label{color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:0;text-transform:uppercase}.current-hourly{border-top:1px solid var(--border);display:grid;gap:0}.current-hourly-toggle{width:100%;border:0;border-bottom:1px solid var(--border);padding:6px 0;display:grid;grid-template-columns:minmax(0,1fr) var(--forecast-status-column, 9.25rem) 1.35rem;align-items:center;gap:8px;background:transparent;color:var(--text);font-weight:900;text-align:left}.current-hourly-caret{color:var(--accent-blue);grid-column:3;position:relative;width:1.35rem;height:1.35rem;display:inline-block;font-size:0;justify-self:center}.current-hourly-caret:before{content:"";position:absolute;top:50%;left:50%;box-sizing:border-box;width:.58rem;height:.58rem;border-right:3px solid currentColor;border-bottom:3px solid currentColor;transform:translate(-50%,-43%) rotate(45deg) scaleY(1);transform-origin:center;transition:transform .16s ease}.current-hourly-caret-expanded:before{transform:translate(-50%,-43%) scaleY(-1) rotate(45deg)}.current-hourly-toggle:focus-visible{border-radius:8px;outline:3px solid rgba(111,168,220,.24);outline-offset:4px}.best-window-summary{border:1px solid rgba(111,168,220,.35);border-radius:8px;padding:10px;display:grid;gap:8px;background:var(--highlight-bg)}.best-window-summary-time{color:var(--text);font-size:1rem;font-weight:900}.best-window-summary-measurements{margin:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.best-window-summary-measurements dt{color:var(--muted);font-size:.72rem;font-weight:700}.best-window-summary-measurements dd{margin:0;color:var(--text);font-weight:900;white-space:nowrap}.hourly-wind-card{padding-bottom:10px}.hourly-wind-summary{color:var(--muted);font-size:.95rem}.hourly-wind-list{max-height:420px;overflow:auto;overscroll-behavior:contain;scrollbar-gutter:stable;scroll-snap-type:y proximity;display:grid;gap:8px;padding-right:4px;padding-bottom:8px}.hourly-wind-row{border:1px solid var(--border);border-radius:8px;padding:10px;display:grid;grid-template-columns:minmax(68px,auto) minmax(112px,.8fr) minmax(0,1.4fr);gap:10px;align-items:center;background:var(--surface-bg);scroll-snap-align:start}.hourly-wind-row time{color:var(--text);font-weight:900;white-space:nowrap}.hourly-wind-label{display:inline-flex;align-items:center;gap:6px;font-weight:900}.hourly-wind-icon{width:22px;height:22px;border:1px solid var(--border);border-radius:50%;display:inline-grid;place-items:center;background:#fff;font-size:.72rem;line-height:1;flex:0 0 auto}.hourly-wind-measurements{margin:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.hourly-wind-measurements div{min-width:0}.hourly-wind-measurements dt{color:var(--muted);font-size:.72rem;font-weight:700}.hourly-wind-measurements dd{margin:0;color:var(--text);font-weight:900;white-space:nowrap}.wind-card-label{margin-bottom:4px;color:var(--muted);font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}.wind-answer{display:grid;gap:8px}.wind-label{margin:0;color:var(--text);font-size:2rem;font-weight:900;line-height:1;display:flex;align-items:center;gap:8px}.wind-status-icon{width:34px;height:34px;border:1px solid var(--border);border-radius:50%;display:inline-grid;place-items:center;background:#fff;font-size:1rem;line-height:1;flex:0 0 auto}.wind-label-calm,.wind-label-playable{color:var(--accent-green)}.wind-label-windy{color:#9a5a08}.wind-label-rough,.wind-label-skip{color:#9c3f22}.wind-grid{margin:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px 12px;align-items:baseline;justify-items:start}.wind-grid>div{display:flex;flex-direction:row;justify-content:flex-start;align-items:baseline;gap:.35em;min-width:0;max-width:100%}.wind-grid dt{flex:0 0 auto;color:var(--muted);font-size:.78rem;font-weight:700}.wind-grid dd{flex:0 0 auto;margin:0;color:var(--text);font-weight:800;white-space:nowrap}@media(max-width:420px){.wind-card{--forecast-status-column: 7.75rem}.wind-grid{gap:6px}.wind-grid dt{display:block;font-size:.72rem}.wind-grid dd{font-size:clamp(.9rem,4.4vw,1rem)}.wind-grid>div{display:block}.hourly-wind-row{grid-template-columns:auto minmax(0,1fr);align-items:center}.hourly-wind-measurements{grid-column:1 / -1;gap:6px}.hourly-wind-measurements dt{font-size:.72rem}.hourly-wind-measurements dd{font-size:clamp(.95rem,5vw,1.1rem)}.daily-wind-heading{gap:6px}.daily-wind-date{font-size:clamp(.88rem,4.7vw,1rem)}.daily-wind-label{font-size:clamp(.88rem,4.5vw,1rem)}}@media(min-width:760px){.app-shell{grid-template-columns:minmax(0,1.45fr) minmax(280px,.75fr);align-items:center}.city-page,.search-page{grid-template-columns:1fr}}@media(min-width:440px){.answer{white-space:nowrap}}@media(max-width:540px){.app-shell{padding:8px 0 10px;align-content:start}.today-panel,.forecast-panel{padding:12px}.forecast-panel.city-detail{border-inline:0;border-radius:0;padding:10px 8px 12px}.wind-card{padding:8px}.brand-logo-header{width:min(76vw,280px);transform:translate(8px)}.search-row{gap:8px}.search-row button{padding:0 14px}.hourly-wind-list{max-height:none;overflow:visible;scrollbar-gutter:auto;padding-right:0}}
