:root{color:#14211f;background:#f4f8f6;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--ink: #14211f;--muted: #52635f;--line: #d7e2de;--surface: #ffffff;--surface-strong: #eef6f2;--teal: #0b6b72;--teal-soft: #dff2ee;--green: #0b8f7f;--coral: #ef6f54;--amber: #f1b84b;--night: #172331;--shadow: 0 18px 45px rgba(14, 42, 39, .12)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#0b6b7224,#f4f8f600 280px),var(--surface-strong)}button,input{font:inherit}button{cursor:pointer}.app-shell{width:min(1180px,calc(100% - 24px));margin:0 auto;padding:18px 0 28px}.app-header,.control-band,.dashboard-grid,.table-panel{margin-bottom:16px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.brand-lockup,.phase-pill,.station-card,.icon-actions,.panel-heading,.moon-summary{display:flex;align-items:center}.brand-lockup{gap:12px;min-width:0}.brand-mark{display:grid;place-items:center;flex:0 0 44px;width:44px;height:44px;color:#fff;background:var(--teal);border-radius:8px;box-shadow:var(--shadow)}h1,h2,p{margin:0}h1{color:var(--ink);font-size:1.45rem;line-height:1.1;letter-spacing:0}h2{color:var(--ink);font-size:1.05rem;line-height:1.25;letter-spacing:0}.brand-lockup p,.status-note,.station-card span,.moon-summary span,.station-result small{color:var(--muted);font-size:.88rem}.phase-pill{flex:0 0 auto;gap:8px;justify-content:center;min-width:0;min-height:48px;max-width:min(260px,44vw);padding:6px 12px 6px 8px;color:var(--night);background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 28px #0e2a2714}.phase-name{overflow:hidden;color:inherit;font-size:.9rem;font-weight:800;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.phase-pill.is-full{border-color:var(--amber);box-shadow:0 0 0 3px #f1b84b38}.phase-pill.is-new{color:#fff;background:var(--night);border-color:var(--night)}.control-band{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:14px}.station-picker,.station-actions,.chart-panel,.moon-panel,.table-panel{background:var(--surface);border:1px solid rgba(215,226,222,.9);border-radius:8px;box-shadow:var(--shadow)}.station-picker,.station-actions{padding:14px}.station-picker{align-self:start}.station-picker.is-compact{padding-bottom:14px}.station-picker label{display:block;margin-bottom:8px;color:var(--muted);font-size:.82rem;font-weight:700}.search-bar{display:flex;align-items:center;gap:8px;min-height:46px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:#fbfdfc}.search-bar svg{color:var(--teal);flex:0 0 auto}.search-bar input{width:100%;min-width:0;border:0;outline:0;color:var(--ink);background:transparent}.station-results{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:10px}.station-sort-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px}.station-sort-row>span{color:var(--muted);font-size:.82rem;font-weight:800}.sort-slider{display:inline-grid;grid-template-columns:repeat(2,minmax(84px,1fr));min-height:38px;padding:3px;background:var(--surface-strong);border:1px solid var(--line);border-radius:999px}.sort-slider button{min-width:0;padding:0 12px;color:var(--muted);background:transparent;border:0;border-radius:999px;font-weight:800}.sort-slider button.is-active{color:#fff;background:var(--teal);box-shadow:0 6px 16px #0b6b7233}.sort-slider button:hover{color:var(--ink)}.sort-slider button.is-active:hover{color:#fff}.station-result{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;min-height:58px;padding:9px 10px;color:var(--ink);text-align:left;background:var(--surface-strong);border:1px solid transparent;border-radius:8px}.station-result span,.station-result small{overflow:hidden;max-width:100%;text-overflow:ellipsis;white-space:nowrap}.station-result.is-selected{background:var(--teal-soft);border-color:#0b6b7259}.station-actions{display:grid;align-content:start;gap:12px}.station-card{gap:10px;min-height:58px;padding:12px;color:var(--teal);background:var(--teal-soft);border-radius:8px}.station-card div{display:grid;gap:3px;min-width:0}.station-card strong,.station-card span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-actions{gap:8px}.icon-actions button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;min-width:0;padding:0 12px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px}.icon-actions button:hover,.segmented-control button:hover,.station-result:hover{border-color:#0b6b7280}.status-note{min-height:20px}.station-picker-note{margin-top:10px}.error-banner{margin-bottom:16px;padding:12px 14px;color:#7a2416;background:#fff1ed;border:1px solid rgba(239,111,84,.4);border-radius:8px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:14px}.chart-panel,.moon-panel,.table-panel{padding:16px}.panel-heading{justify-content:space-between;gap:12px;margin-bottom:14px}.eyebrow{display:block;margin-bottom:3px;color:var(--teal);font-size:.76rem;font-weight:800;text-transform:uppercase;letter-spacing:0}.segmented-control{display:inline-grid;grid-template-columns:repeat(3,44px);min-height:38px;padding:3px;background:var(--surface-strong);border:1px solid var(--line);border-radius:8px}.segmented-control button{color:var(--muted);background:transparent;border:0;border-radius:6px;font-weight:800}.segmented-control button.is-active{color:#fff;background:var(--teal)}.chart-frame{position:relative;height:360px;min-height:320px}.loading-panel{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--muted);background:#ffffffbd;z-index:2}.chart-tooltip{display:grid;gap:4px;padding:10px 12px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 12px 32px #0e2a2729}.chart-tooltip span{color:var(--muted);font-size:.85rem}.moon-panel{min-width:0}.moon-summary{gap:16px;padding:14px;background:linear-gradient(135deg,#edf8f4,#fff6e8);border:1px solid var(--line);border-radius:8px}.moon-summary div{display:grid;gap:5px}.moon-orb,.mini-moon,.phase-graphic{display:inline-block;flex:0 0 auto;border-radius:50%;background:#f6edc8;border:1px solid rgba(23,35,49,.18)}.moon-orb{width:72px;height:72px;box-shadow:inset -12px 0 20px #17233138,0 10px 28px #1723311f}.phase-graphic{width:32px;height:32px;box-shadow:inset -6px 0 10px #1723312e,0 8px 18px #1723311a}.moon-heading-graphic{width:38px;height:38px;box-shadow:inset -8px 0 12px #1723312e,0 8px 18px #1723311a}.mini-moon{width:24px;height:24px}.moon-orb.new,.mini-moon.new,.phase-graphic.new{background:var(--night)}.moon-orb.full,.mini-moon.full,.phase-graphic.full{background:#fff4c7;box-shadow:0 0 0 4px #f1b84b38}.moon-orb.waxing-crescent,.mini-moon.waxing-crescent,.phase-graphic.waxing-crescent{background:linear-gradient(90deg,var(--night) 58%,#fff4c7 60%)}.moon-orb.first-quarter,.mini-moon.first-quarter,.phase-graphic.first-quarter{background:linear-gradient(90deg,var(--night) 50%,#fff4c7 50%)}.moon-orb.waxing-gibbous,.mini-moon.waxing-gibbous,.phase-graphic.waxing-gibbous{background:linear-gradient(90deg,var(--night) 24%,#fff4c7 26%)}.moon-orb.waning-gibbous,.mini-moon.waning-gibbous,.phase-graphic.waning-gibbous{background:linear-gradient(90deg,#fff4c7 74%,var(--night) 76%)}.moon-orb.last-quarter,.mini-moon.last-quarter,.phase-graphic.last-quarter{background:linear-gradient(90deg,#fff4c7 50%,var(--night) 50%)}.moon-orb.waning-crescent,.mini-moon.waning-crescent,.phase-graphic.waning-crescent{background:linear-gradient(90deg,#fff4c7 40%,var(--night) 42%)}.moon-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:14px}.moon-day{display:grid;justify-items:center;align-content:center;gap:6px;min-height:92px;padding:8px;color:var(--muted);background:#fbfdfc;border:1px solid var(--line);border-radius:8px;text-align:center}.moon-day span,.moon-day small{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.moon-day span{color:var(--ink);font-size:.82rem;font-weight:800}.moon-day small{font-size:.72rem}.moon-day.is-full{border-color:var(--amber);background:#fff8e7}.moon-day.is-new{color:#fff;border-color:var(--night);background:var(--night)}.moon-day.is-new span,.moon-day.is-new small{color:#fff}.tide-table-wrap{overflow-x:auto}.tide-table{width:100%;min-width:680px;border-collapse:collapse}.tide-table th,.tide-table td{padding:12px 10px;text-align:left;border-bottom:1px solid var(--line)}.tide-table th{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:0}.tide-table tr.is-full-row{background:#fff8e7}.tide-table tr.is-new-row{background:#eef2f4}.tide-badge{display:inline-flex;align-items:center;justify-content:center;min-width:64px;min-height:28px;padding:4px 10px;border-radius:999px;font-weight:800}.tide-badge.high{color:#7a2416;background:#ffe4dc}.tide-badge.low{color:#064a43;background:#dff2ee}@media (max-width: 960px){.control-band,.dashboard-grid{grid-template-columns:1fr}.station-results{grid-template-columns:repeat(2,minmax(0,1fr))}.moon-strip{grid-template-columns:repeat(8,minmax(0,1fr))}}@media (max-width: 640px){.app-shell{width:min(100% - 18px,1180px);padding-top:12px}.app-header{align-items:flex-start;flex-direction:column}.phase-pill{align-self:flex-end;max-width:100%;justify-content:center}.station-results,.moon-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.station-sort-row{align-items:stretch;flex-direction:column}.sort-slider{width:100%}.icon-actions{display:grid;grid-template-columns:1fr 1fr}.icon-actions button{padding:0 8px}.chart-frame{height:330px}.panel-heading{align-items:flex-start;flex-direction:column}.segmented-control{width:100%;grid-template-columns:repeat(3,1fr)}}
