*{box-sizing:border-box;margin:0;padding:0}body{color:#fff;-webkit-font-smoothing:antialiased;background:#1e1e1e;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{min-height:100vh;display:flex}.app.loading{color:#888;justify-content:center;align-items:center;display:flex}.main-content{flex:1;padding:2rem;overflow-y:auto}.sidebar{background:#191818;flex-direction:column;flex-shrink:0;width:260px;min-height:100vh;padding:28px 0;display:flex}.sidebar-logo{color:#5a9bb5;letter-spacing:1px;padding:24px 24px 36px;font-family:Noto Sans JP,sans-serif;font-size:22px;font-weight:400}.sidebar-logo-accent{background:#c45a20;border-radius:1px;width:40px;height:1px;margin-top:4px}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.nav-item{color:#e8eef5;cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:6px 17px;font-size:14px;font-weight:400;transition:color .15s,background-color .15s;display:flex}.nav-item:hover{color:#c45a20}.nav-item-icon{justify-content:center;align-items:center;display:inline-flex}.spot-regions{flex-direction:column;margin:4px 0 6px;display:flex}.spot-region{margin-top:8px}.spot-region:first-child{margin-top:0}.spot-region-label{color:#5a6878;letter-spacing:1.5px;padding:4px 24px 4px 56px;font-size:9px;font-weight:600}.spot-nav-item{color:#c8d0d8;cursor:pointer;border-left:3px solid #0000;align-items:center;gap:8px;padding:5px 24px 5px 53px;font-size:13px;transition:color .15s,background-color .15s;display:flex}.spot-nav-item:hover{color:#c45a20}.spot-nav-item.active{color:#c45a20;background:#c45a2014;border-left-color:#c45a20}.sidebar-footer{padding:0 20px 8px}.login-item{color:#5a6878;border-top:1px solid #2a2a2a;border-left:none;padding:12px 0 0;font-size:13px}.login-item:hover{color:#c45a20}.conditions-table{background:#262b37;border-radius:5px;max-width:700px;overflow:hidden;box-shadow:0 2px 4px #00000047}.conditions-header,.conditions-row{grid-template-columns:44px 70px 110px 100px 80px 110px 1fr;align-items:stretch;padding:0;display:grid}.conditions-header{border-bottom:1px solid #363c4a}.conditions-header .col{color:#ffffffb3;text-transform:capitalize;padding:.75rem .6rem .5rem;font-size:.8rem;font-weight:600}.conditions-header .col-time,.conditions-header .col-weather{padding-left:0;padding-right:0}.conditions-row{border-bottom:1px solid #2e3340;border-left:3px solid #0000;min-height:64px}.conditions-row:last-child{border-bottom:none}.conditions-row .col{padding:.6rem;display:block}.col-time{background:#1c2028;border-right:1px solid #2e3340;padding:0!important}.conditions-row .col-time{justify-content:center;align-items:center;display:flex!important}.conditions-row .col-weather{flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex!important}.time-label{color:#888;font-size:.75rem}.time-now{writing-mode:vertical-rl;letter-spacing:.15em;color:#fff;font-size:.75rem;font-weight:700;transform:rotate(180deg)}.conditions-row.current{border-left-color:#c45a20}.conditions-row.current .col-time{background:linear-gradient(#c45a20 0%,#b04e18 100%);border-right-color:#1c2028}.weather-icon{font-size:1.2rem;line-height:1}.weather-temp{color:#e8eef5;font-size:.7rem;font-weight:500}.wave-height{color:#fff;font-size:1.4rem;font-weight:700}.wave-unit{color:#fff9;margin-left:1px;font-size:.7rem;font-weight:400}.wave-detail{color:#888;margin-top:-2px;font-size:.6rem;display:block}.quality-badge{letter-spacing:.02em;white-space:nowrap;border-radius:3px;padding:.15rem .5rem;font-size:.7rem;font-weight:700;display:inline-block}.quality-badge.good{color:#6aaf72;background:#2e4a30}.quality-badge.fair-to-good{color:#c0c878;background:#4a4a28}.quality-badge.fair{color:#d4b96e;background:#524418}.quality-badge.poor-to-fair{color:#d49868;background:#523028}.quality-badge.poor{color:#c46050;background:#442018}.tide-value{color:#c4c4c4;font-size:.8rem}.tide-arrow{font-size:.55rem}.tide-arrow.rising{color:#4ca082}.tide-arrow.falling{color:#c85050}.wind-speed{color:#fff;font-size:.85rem;font-weight:600}.wind-unit,.wind-dir{color:#c4c4c4;font-size:.75rem}.wind-gust{color:#888;margin-top:1px;font-size:.65rem;display:block}.swell-height{color:#fff;font-size:.85rem;font-weight:600}.swell-unit,.swell-period,.swell-dir{color:#c4c4c4;font-size:.75rem}.swell-deg{color:#888;font-size:.7rem}.swell-secondary{color:#666;margin-top:1px;font-size:.65rem;display:block}.date-tiles{scrollbar-width:none;gap:.6rem;margin-bottom:1rem;padding-bottom:4px;display:flex;overflow-x:auto}.date-tiles::-webkit-scrollbar{display:none}.date-tile{color:#c4c4c4;cursor:pointer;box-sizing:border-box;text-align:left;background:#262b37;border:2px solid #0000;border-radius:5px;flex-direction:column;flex-shrink:0;justify-content:flex-start;width:150px;height:130px;padding:10px 14px 8px;transition:width .3s ease-out,background-color .15s ease-out;display:flex;overflow:hidden}.date-tile:hover:not(.selected){background:#2e3444}.date-tile.selected{border-color:#c45a20;width:320px}.date-tile-header{justify-content:space-between;align-items:flex-start;margin-bottom:6px;display:flex}.date-tile-label{color:#e8eef5;white-space:nowrap;font-size:13px;font-weight:600}.date-tile-meta{align-items:center;gap:6px;display:flex}.date-tile-weather{font-size:1rem;line-height:1}.date-tile-temp{color:#6a7a90;font-size:11px}.date-tile-body{align-items:flex-end;gap:10px;display:flex}.date-tile-range{align-items:baseline;gap:3px;padding-bottom:4px;display:flex}.date-tile-range-value{color:#e8eef5;font-size:26px;font-weight:600;line-height:1}.date-tile-range-unit{color:#8a9fb5;font-size:11px}.mini-bars{flex-shrink:0;align-items:flex-end;gap:2px;width:50px;height:64px;display:flex}.mini-bar{border-radius:1px 1px 0 0;flex:1;min-height:4px}.mini-bars.empty{width:50px;height:64px}.date-tile-best{border-top:1px solid #ffffff14;align-items:center;gap:6px;margin-top:8px;padding-top:8px;display:flex}.best-label{letter-spacing:.1em;color:#5a7080;font-size:9px;font-weight:600}.best-range{color:#c45a20;letter-spacing:.02em;font-size:11px;font-weight:600}.timeline-header{color:#888;align-items:center;gap:.75rem;margin-bottom:.5rem;padding-left:.25rem;font-size:.8rem;display:flex}.interval-toggle{background:#262b37;border:1px solid #363c4a;border-radius:4px;display:flex;overflow:hidden}.interval-toggle button{color:#888;cursor:pointer;background:0 0;border:none;padding:.25rem .6rem;font-size:.7rem;transition:background .15s,color .15s}.interval-toggle button:hover{color:#c4c4c4}.interval-toggle button.active{color:#fff;background:#4c8492}.forecast-content{max-width:700px;transition:opacity .15s;position:relative}.forecast-content.loading{opacity:.4;pointer-events:none}.forecast-spinner{z-index:1;border:3px solid #363c4a;border-top-color:#4c8492;border-radius:50%;width:28px;height:28px;animation:.6s linear infinite spin;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes spin{to{transform:translate(-50%,-50%)rotate(360deg)}}.spot-loading,.spot-error{color:#888;padding:2rem}.live-conditions{background:#262b37;border-radius:5px;flex-wrap:wrap;align-items:center;gap:1.5rem;max-width:700px;margin-bottom:1rem;padding:1rem 1.25rem;display:flex;box-shadow:0 2px 4px #00000047}.live-stat{flex-direction:column;gap:.2rem;display:flex}.stat-label{color:#8a9fb5;letter-spacing:.15em;font-size:.65rem;font-weight:500}.stat-row{align-items:baseline;gap:.3rem;display:flex}.stat-value{color:#e8eef5;font-size:1.6rem;font-weight:300;line-height:1.1}.stat-unit{color:#8a9fb5;font-size:.75rem}.stat-detail{color:#8a9fb5;align-self:center;font-size:.75rem}.tide-direction-arrow,.tide-direction-label{align-self:center}.tide-direction-arrow.rising,.tide-direction-label.rising{color:#c890b5}.tide-direction-arrow.falling,.tide-direction-label.falling{color:#9c8cb5}.tide-direction-arrow{font-size:.7rem}.tide-direction-label{font-size:.8rem}.stat-value.rating-good{color:#6aaf72}.stat-value.rating-fair-to-good{color:#c0c878}.stat-value.rating-fair{color:#d4b96e}.stat-value.rating-poor-to-fair{color:#d49868}.stat-value.rating-poor{color:#c46050}.live-divider{background:#ffffff26;width:1px;height:36px}.spot-cams{flex-direction:column;gap:1rem;max-width:700px;margin-bottom:1rem;display:flex}.cam-frame{background:#262b37;border-radius:5px;overflow:hidden;box-shadow:0 2px 4px #00000047}.cam-frame iframe{aspect-ratio:16/9;border:0;width:100%;display:block}.cam-caption{color:#888;letter-spacing:.02em;padding:.5rem .75rem;font-size:.75rem}.compass-card{background:#262b37;border-radius:5px;max-width:700px;margin-top:1rem;padding:1rem;box-shadow:0 2px 4px #00000047}.compass-header{justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;display:flex}.compass-title{color:#fff;margin:0;font-size:.9rem;font-weight:600}.compass-legend{flex-direction:column;align-items:flex-end;gap:.2rem;display:flex}.compass-legend-item{align-items:center;gap:.35rem;font-size:.7rem;display:flex}.compass-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.compass-legend-label{color:#c4c4c4;font-weight:500}.compass-legend-detail{color:#888}.compass-body{background:#1a2838;border-radius:4px;width:280px;height:280px;margin:0 auto;position:relative;overflow:hidden}.compass-map{object-fit:cover;opacity:.7;width:100%;height:100%;position:absolute;inset:0}.compass-overlay{width:100%;height:100%;position:absolute;inset:0}.compass-cardinal{fill:#ffffffb3;font-family:inherit;font-size:11px;font-weight:600}.swell-chart-card{background:#262b37;border-radius:5px;max-width:700px;margin-top:1rem;padding:1rem 1rem .5rem;box-shadow:0 2px 4px #00000047}.swell-chart-header{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.swell-chart-title{color:#fff;margin:0;font-size:.9rem;font-weight:600}.swell-chart-legend{flex-direction:column;align-items:flex-end;gap:.2rem;display:flex}.swell-legend-item{align-items:center;gap:.35rem;font-size:.7rem;display:flex}.swell-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.swell-legend-label{color:#c4c4c4;font-weight:500}.swell-legend-detail{color:#888}.swell-tooltip{background:#1e1e1e;border:1px solid #363c4a;border-radius:4px;padding:.5rem .75rem;font-size:.75rem}.swell-tooltip-time{color:#fff;margin-bottom:.3rem;font-weight:600}.swell-tooltip-row{color:#c4c4c4;align-items:center;gap:.35rem;padding:.1rem 0;display:flex}.swell-tooltip-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}
