*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;font-size:16px;line-height:1.5;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,Hiragino Sans,Meiryo,sans-serif;color:#1a1f29;background-color:#f4f6f9;overflow-x:hidden}#root{width:100%}.app{width:100%;max-width:1280px;margin:0 auto;padding:16px;display:flex;flex-direction:column;gap:16px;min-width:0}.app__header{margin:0}.app__title{margin:0;font-size:1.5rem;line-height:1.3;overflow-wrap:break-word;word-break:break-word}.status-bar__refresh,.time-range-filter__clear,.preset-button,.time-range-filter__select{min-height:44px;font-size:16px;font-family:inherit}.status-bar__refresh,.time-range-filter__clear,.preset-button{min-width:44px;padding:8px 16px;border:1px solid #b7c0cc;border-radius:6px;background-color:#fff;color:#1a1f29;cursor:pointer}.status-bar__refresh:hover:not(:disabled),.time-range-filter__clear:hover:not(:disabled),.preset-button:hover:not(:disabled){background-color:#eef2f7}.status-bar__refresh:disabled,.time-range-filter__clear:disabled{opacity:.6;cursor:not-allowed}.status-bar__refresh{background-color:#1f6feb;border-color:#1f6feb;color:#fff}.status-bar__refresh:hover:not(:disabled){background-color:#1a5fd0}.preset-button--active{background-color:#1f6feb;border-color:#1f6feb;color:#fff}.time-range-filter__select{padding:8px 12px;border:1px solid #b7c0cc;border-radius:6px;background-color:#fff;color:#1a1f29}.status-bar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;background-color:#fff;border:1px solid #e1e6ec;border-radius:8px;min-width:0}.status-bar__info{min-width:0}.status-bar__label{color:#5b6675}.status-bar__timestamp{font-variant-numeric:tabular-nums;font-weight:600}.status-bar__loading{display:inline-flex;align-items:center;gap:8px;color:#5b6675}.status-bar__spinner{display:inline-block;width:16px;height:16px;border:2px solid #c5cdd8;border-top-color:#1f6feb;border-radius:50%;animation:status-bar-spin .8s linear infinite}@keyframes status-bar-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.status-bar__spinner{animation:none}}.status-bar__warning,.status-bar__error{flex-basis:100%;width:100%;margin:0;padding:8px 12px;border-radius:6px;overflow-wrap:break-word}.status-bar__warning{background-color:#fff3c4;color:#6b5400}.status-bar__error{background-color:#ffd6d6;color:#8a1f1f}.time-range-filter{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;padding:12px 16px;background-color:#fff;border:1px solid #e1e6ec;border-radius:8px;min-width:0}.time-range-filter__range{display:flex;flex-wrap:wrap;align-items:flex-end;gap:8px;min-width:0}.time-range-filter__field{display:flex;flex-direction:column;gap:4px}.time-range-filter__label{font-size:.875rem;color:#5b6675}.time-range-filter__separator{align-self:center;padding-bottom:8px;color:#5b6675}.preset-selector{display:flex;flex-wrap:wrap;gap:8px;min-width:0}.wind-mode-toggle{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.wind-mode-toggle__label{font-size:.875rem;font-weight:600;color:#3a4556}.wind-mode-toggle__btn{padding:6px 12px;border:1px solid #e1e6ec;border-radius:6px;background:#fff;font-size:.8125rem;cursor:pointer}.wind-mode-toggle__btn--active{background:#1f6feb;color:#fff;border-color:#1f6feb}.wind-forecast-table__scroll{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid #e1e6ec;border-radius:8px;background-color:#fff}.wind-forecast-table{border-collapse:collapse;width:auto}.wind-forecast-table__caption{caption-side:top;text-align:left;padding:8px 12px;font-size:.875rem;color:#5b6675}.wind-forecast-table th,.wind-forecast-table td{border:1px solid #e1e6ec;padding:6px 10px;text-align:center;white-space:nowrap}.wind-forecast-table thead th{position:sticky;top:0;z-index:2;background-color:#eef2f7;font-weight:600}.wind-forecast-table__time{font-variant-numeric:tabular-nums;font-size:.8125rem}.wind-forecast-table__time--actual{background-color:#e0e7ef}.wind-forecast-table__actual-badge{display:block;font-size:.625rem;font-weight:400;color:#5b6675}.wind-forecast-table__weather{display:block;font-size:.6875rem;line-height:1.3}.wind-forecast-table__temp{margin-left:2px;color:#3a4556}.wind-forecast-table__precip{display:block;color:#1f6feb;font-size:.625rem}.wind-forecast-table__corner,.wind-forecast-table__altitude{position:sticky;left:0;background-color:#eef2f7;font-weight:600;font-variant-numeric:tabular-nums}.wind-forecast-table__corner{z-index:3}.wind-forecast-table__altitude{z-index:1}.wind-forecast-table__empty{margin:0;padding:24px 16px;text-align:center;color:#5b6675;background-color:#fff;border:1px solid #e1e6ec;border-radius:8px}.wind-cell{font-variant-numeric:tabular-nums;font-size:.8125rem}.wind-cell--calm{background-color:#d7f5dd}.wind-cell--moderate{background-color:#fff3c4}.wind-cell--strong{background-color:#ffd6d6}.wind-cell--missing{color:#97a1b0;background-color:#f7f9fb}.wind-cell__speed{font-weight:600}.wind-cell__direction{color:#3a4556}@media(max-width:767px){.app{padding:12px;gap:12px}.app__title{font-size:1.25rem}.status-bar,.time-range-filter,.time-range-filter__range{flex-direction:column;align-items:stretch}.time-range-filter__separator{display:none}.preset-selector{flex-direction:column}.status-bar__refresh,.time-range-filter__clear,.preset-button,.time-range-filter__select{width:100%;min-height:44px}}.amedas-section{margin:0}.amedas-section__title{font-size:1rem;font-weight:600;margin:0 0 8px}.amedas-cards{display:flex;gap:12px;flex-wrap:wrap}.amedas-card{flex:1;min-width:240px;border:1px solid #e1e6ec;border-radius:8px;background:#fff;padding:12px}.amedas-card__station{font-size:.875rem;font-weight:600;margin:0 0 8px}.amedas-card__scroll{overflow-x:auto;max-height:220px;overflow-y:auto}.amedas-card__table{width:100%;border-collapse:collapse;font-size:.8125rem;font-variant-numeric:tabular-nums}.amedas-card__table th,.amedas-card__table td{padding:3px 6px;text-align:center;border-bottom:1px solid #eef2f7;white-space:nowrap}.amedas-card__table th{background:#eef2f7;font-weight:600;position:sticky;top:0}.amedas-card__empty{color:#5b6675;font-size:.8125rem;margin:0}.amedas-section__source{margin:8px 0 0;font-size:.75rem;color:#5b6675}.amedas-error,.amedas-loading{font-size:.875rem;color:#5b6675}.app__footer{margin-top:8px;padding:12px 4px;border-top:1px solid #e1e6ec}.app__attribution{margin:0;font-size:.875rem;color:#5b6675;text-align:center;overflow-wrap:break-word}.app__attribution-link{color:#1f6feb;text-decoration:underline}.app__attribution-link:hover{color:#1a5fd0}
