:root{
  --green:#28a745; --yellow:#c9a501; --red:#cc2020; --ink:#111; --muted:#666;
  --btn-bg:#fff; --btn-bd:#bbb; --btn-ink:#111; --safe-top:env(safe-area-inset-top, 0px);
}
html,body{height:100%;}
body{font-family:Inter,system-ui,Arial,sans-serif;background:#f5f6f7;color:var(--ink);margin:0;
     overflow:hidden;-ms-overflow-style:none;scrollbar-width:none;position:relative;}
body::-webkit-scrollbar{display:none}

#pageWrapper{position:relative;width:100%;height:100%;transition:transform .45s ease;will-change:transform;}
body.page-one #pageWrapper{transform:translateY(0);}
body.page-two #pageWrapper{transform:translateY(-100%);}

.page{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;
      background:#f5f6f7;padding:calc(var(--safe-top)) 12px 20px;box-sizing:border-box;}
#pageTwo{top:100%;padding-top:16px;}

#pageOneContent{width:100%;max-width:980px;flex:1;display:flex;flex-direction:column;overflow:hidden;align-self:center;}
#pageTwoContent{width:100%;max-width:980px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 0 24px;
                scrollbar-width:none;}
#pageTwoContent::-webkit-scrollbar{display:none}

.page-control{position:absolute;width:38px;height:38px;border-radius:19px;border:none;background:rgba(0,0,0,0.08);
              display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .3s ease;
              opacity:1;z-index:20;}
.page-control .arrow{font-size:18px;line-height:1;color:#2f3947;animation:hint-bounce 1.4s ease-in-out infinite;}
#scrollHint{right:16px;bottom:6px;}
#scrollUpHint{right:16px;top:calc(var(--safe-top) + 16px);opacity:0;pointer-events:none;}
body.page-two #scrollHint{opacity:0;pointer-events:none;}
body.page-two #scrollUpHint{opacity:1;pointer-events:auto;}

@keyframes hint-bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(4px)}
}

#mainbox{border-radius:10px;padding:8px 14px;color:#fff;width:100%;margin:0 auto 2px;
         font-weight:600;text-align:center;min-height:72px;display:flex;flex-direction:column;
         justify-content:center;gap:2px;position:relative;box-sizing:border-box;}
.settings-btn{position:absolute;top:4px;right:4px;width:40px;height:40px;border:none;background:rgba(0,0,0,0.18);
              border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;
              transition:background .2s ease,opacity .2s ease;opacity:0.85;}
.settings-btn:hover{background:rgba(0,0,0,0.26);opacity:1;}
.settings-btn:focus-visible{outline:2px solid rgba(255,255,255,0.75);outline-offset:2px;}
.settings-btn .hamburger{display:flex;flex-direction:column;gap:4px;}
.settings-btn .hamburger span{display:block;width:20px;height:2px;background:#fff;border-radius:1px;
                              transition:transform .2s ease,opacity .2s ease;}
.location-label{font-size:14px;letter-spacing:0.08em;text-transform:uppercase;opacity:0.85}
#topline{font-size:13px;font-weight:600;line-height:1.2;min-height:38px;overflow:hidden;text-overflow:ellipsis;
         white-space:normal;padding:0 32px;display:flex;flex-direction:column;justify-content:center;align-items:center;}
#topline .topline-primary{white-space:nowrap;display:block;}
#topline .topline-secondary{display:block;font-size:11px;opacity:0.85;margin-top:2px;}
#subline{font-size:10.5px;opacity:.9;line-height:1.2;min-height:30px;overflow:hidden;text-overflow:ellipsis;
         padding:0 18px;white-space:normal;display:flex;flex-direction:column;justify-content:center;align-items:center;}
#subline.single-line{display:block;white-space:nowrap;gap:0;overflow:visible;}
#subline .no-wrap{white-space:nowrap;}
.green{background:var(--green)} .yellow{background:var(--yellow)} .red{background:var(--red)}
.stale{background:#495057}

#controls{width:100%;max-width:980px;margin:0 auto 0px;display:grid;gap:2px;grid-template-columns:1fr;align-items:center;
          justify-items:center;}
#row1{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center}
#row2{display:flex;flex-direction:column;gap:2px;align-items:center}
#row2 .btn-row{display:flex;gap:8px;justify-content:center}
#row3{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center}
label.kv{font-size:16px;display:flex;flex-direction:row;align-items:center;gap:6px}
input[type="number"]{font-size:18px;line-height:1;border:1px solid var(--btn-bd);border-radius:10px;padding:.25rem .55rem;
                      width:6.2em;text-align:right;background:#fff}
.numeric-control{display:inline-flex;align-items:center;border:1px solid var(--btn-bd);border-radius:10px;overflow:hidden;background:#fff}
.numeric-control input[type="number"]{border:0;border-radius:0;padding:.35rem .6rem;width:5.4em;font-size:18px;text-align:right;background:transparent}
.numeric-control input[type="number"]:focus{outline:none}
.numeric-control input[type="number"]::-webkit-inner-spin-button,
.numeric-control input[type="number"]::-webkit-outer-spin-button{display:none}
.numeric-control .spin-buttons{display:flex;flex-direction:column;border-left:1px solid var(--btn-bd);height:100%}
.numeric-control .spin-btn{background:#f1f3f5;border:0;padding:0;width:26px;height:20px;font-size:13px;line-height:1;
                           display:flex;align-items:center;justify-content:center;cursor:pointer}
.numeric-control .spin-btn:active{background:#e3e6e9}

.btn{appearance:none;-webkit-appearance:none;background:var(--btn-bg);color:var(--btn-ink);
     border:1px solid var(--btn-bd);border-radius:12px;font-size:16px;padding:.45rem .75rem;
     min-width:44px;min-height:44px;cursor:pointer;touch-action:manipulation;transition:background .15s ease,box-shadow .15s ease,transform .1s ease}
.btn:not(.active):active{transform:translateY(1px)}
.btn.active{background:#0b5ed7;color:#fff;border-color:#0949ad;box-shadow:inset 0 3px 5px rgba(0,0,0,0.25);transform:translateY(1px)}
.btn.active:hover{background:#0a53be}
.btn.active:focus-visible{outline:2px solid rgba(255,255,255,0.75);outline-offset:2px}

/* Visual disabled state for generic buttons (used for Auto button when not on "Today") */
.btn.disabled,
.btn[disabled]{
  opacity:0.55;
  cursor:not-allowed;
  background:#f3f4f6;
  color:#8a8f95;
  border-color:#ddd;
  box-shadow:none;
  transform:none;
}
.btn.disabled:hover,
.btn[disabled]:hover{ /* no hover effect when disabled */
  transform:none;
}
.forecast-line{display:inline-block;margin-top:2px;color:inherit;font-size:12px}
.nav-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;font-size:16px}
.nav-btn .chevron{font-size:16px;display:flex;align-items:center}
.toggle{display:flex;gap:8px;align-items:center;font-size:16px}
.toggle input{width:22px;height:22px}
#autoNote{width:100%;max-width:980px;margin:0 auto 2px;font-size:12px;color:#333;min-height:1.2em;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.warn{background:#fffaf0;border:1px solid #e7d899;color:#7a5e00;padding:.5rem .7rem;border-radius:10px}

#legend{font-size:12px;margin:0 auto 4px;width:100%;max-width:980px;text-align:center}
#legend .k{display:inline-block;margin:0 8px 4px 8px}
.dot{height:12px;width:12px;border-radius:50%;display:inline-block;vertical-align:middle;margin-right:6px}
.dot-green{background:#28a745;}
.dot-yellow{background:#c9a501;}
.dot-red{background:#cc2020;}
#navline{display:flex;justify-content:center;gap:6px;margin:4px auto;width:100%;max-width:940px;transition:opacity .3s ease}
#navline.hide-on-scroll{opacity:0;pointer-events:none}
#when{font-size:15px;color:var(--muted);text-align:center;margin:2px 0 2px}
.hidden{display:none}

.chart-slot{width:100%;max-width:980px;display:flex;flex-direction:column;align-items:center}
#pageOneChartSlot{margin-top:0;padding-bottom:0;}
#pageOneChartSlot .canvasWrap{margin-top:-6px;}
#pageTwoChartSlot{position:sticky;top:0;margin-bottom:12px;background:#f5f6f7;padding:8px 0;z-index:5;} 
.chart-title{font-size:15px;color:var(--muted);margin:0 0 4px;text-align:center}
.chart-title:empty{margin:0;height:0;}
body.page-one #pageTwoChartSlot .chart-title{display:none;}
.canvasWrap{width:100%;max-width:980px;margin:0 auto}
canvas{width:100%;max-width:980px;height:228px}

.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.25);
              opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:90;}
.menu-overlay.visible{opacity:1;pointer-events:auto;}
.side-menu{position:fixed;top:0;right:0;width:280px;max-width:82%;height:100%;background:#e5e8ef;
           box-shadow:-6px 0 18px rgba(0,0,0,0.2);transform:translateX(100%);transition:transform .28s ease;
           z-index:100;display:flex;flex-direction:column;padding:24px 20px;box-sizing:border-box;overflow:hidden;}
.side-menu.open{transform:translateX(0);}
.menu-nav{display:flex;flex-direction:column;gap:18px;height:100%;}
.menu-title{margin:0;font-size:20px;font-weight:700;color:#2f3947;}
.menu-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;}
.menu-item{width:100%;text-align:left;padding:12px 14px;font-size:16px;border-radius:10px;border:0;
           background:#d5dae3;color:#2f3947;cursor:pointer;font-weight:600;transition:background .2s ease,color .2s ease,transform .2s ease;}
.menu-item:hover,.menu-item:focus-visible{background:#c5cada;color:#1f2733;}
.menu-item:focus-visible{outline:2px solid #4a90e2;}
.menu-item:active{transform:translateY(1px);}
.menu-item:disabled{cursor:not-allowed;opacity:0.55;color:#5e6a79;background:#d5dae3;}
.menu-item:disabled:hover,.menu-item:disabled:focus-visible{background:#d5dae3;color:#5e6a79;transform:none;}
.menu-panel{position:absolute;inset:20px;background:#f7f9ff;border-radius:16px;box-shadow:0 18px 40px rgba(0,0,0,0.2);
            transform:translateY(-110%);opacity:0;pointer-events:none;visibility:hidden;display:flex;flex-direction:column;
            gap:10px;padding:22px 20px 24px;box-sizing:border-box;transition:transform .28s ease,opacity .28s ease,visibility .28s;
            overflow:auto;}
.menu-panel-close{align-self:flex-end;background:none;border:0;font-size:22px;color:#2f3947;cursor:pointer;line-height:1;
                  width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;
                  transition:background .2s ease,color .2s ease;}
.menu-panel-close:hover,.menu-panel-close:focus-visible{background:rgba(47,57,71,0.1);color:#111a26;}
.menu-panel-heading{margin:0;font-size:20px;font-weight:700;color:#1f2733;}
.menu-panel-subtitle{margin:0;font-size:15px;color:#5e6a79;}
.menu-panel-meta{margin:8px 0 0;font-size:15px;color:#2f3947;}
.menu-panel-links{margin:2px 0 0;font-size:15px;line-height:1.6;}
.menu-panel-links a{color:#315ad3;text-decoration:none;font-weight:600;}
.menu-panel-links a:hover,.menu-panel-links a:focus-visible{text-decoration:underline;}
.menu-panel-section{margin:16px 0 6px;font-size:16px;color:#1f2733;}
.menu-panel p{line-height:1.55;}
.menu-panel-list{margin:0 0 12px 18px;padding:0;line-height:1.5;}
.menu-panel-list li{margin:0 0 6px;}
.menu-panel-key{display:inline-block;padding:2px 8px;border-radius:12px;background:#e0e4f0;font-size:13px;color:#2f3947;}
.side-menu.panel-open .menu-panel{transform:translateY(-110%);opacity:0;pointer-events:none;visibility:hidden;}
.side-menu[data-panel-open="help"] #helpPanel,
.side-menu[data-panel-open="about"] #aboutPanel{transform:translateY(0);opacity:1;pointer-events:auto;visibility:visible;}
.side-menu.panel-open .menu-nav{opacity:0.35;pointer-events:none;}

.tblWrap{width:100%;max-width:980px;margin:8px auto 24px;overflow:hidden;background:#fff;border-radius:10px;box-shadow:0 0 0 1px rgba(0,0,0,0.05);}
.tblWrap.hidden{display:none}
table{width:100%;border-collapse:collapse}
th,td{border-bottom:1px solid #e7e7e7;padding:10px 8px;font-size:16px;text-align:left}
th{position:sticky;top:0;background:#fafafa;z-index:1}
.hour-toggle{appearance:none;border:0;background:none;font:inherit;text-align:left;width:100%;padding:0;display:flex;align-items:center;gap:8px;color:inherit;cursor:pointer}
.hour-toggle .chevron{transition:transform 0.2s ease}
.hour-toggle.expanded .chevron{transform:rotate(90deg)}
.hour-detail{list-style:none;margin:0;padding:4px 0 0 0;display:flex;flex-direction:column;gap:4px}
.hour-detail li{display:flex;justify-content:space-between;font-size:14px;border-bottom:1px solid rgba(0,0,0,0.05);padding-bottom:4px}
.hour-detail li:last-child{border-bottom:0;padding-bottom:0}

/* Mobile tweaks */
@media (max-width:600px){
  input[type="number"]{font-size:18px}
  .btn{font-size:18px;padding:.65rem 1.05rem;border-radius:14px}
  canvas{height:220px}
  th,td{font-size:15px;padding:10px 8px}
}

/* Dock Location dialog styles */
#dockLocationDialogOverlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);display:flex;align-items:center;justify-content:center;z-index:99999}
#dockLocationDialogOverlay[hidden]{display:none}
#dockLocationDialog{width:calc(100% - 64px);max-width:520px;background:#fff;border-radius:12px;padding:18px;box-shadow:0 20px 40px rgba(0,0,0,0.3);box-sizing:border-box}
#dockLocationDialog{max-height:calc(100% - 100px);overflow:auto}
#dockLocationDialog h3{margin:0 0 8px;font-size:18px}
#dockLocationDialog label{display:block;margin:8px 0;font-size:14px}
#dockLocationDialog input[type="text"],#dockLocationDialog input[type="number"]{width:100%;padding:8px 10px;border:1px solid var(--btn-bd);border-radius:8px;font-size:14px;box-sizing:border-box}
#dockLocationDialog .dialog-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
#dockLocationDialog .dialog-actions .btn{min-width:88px}
/* small map in dialog */
.dock-map{width:100%;height:300px;border-radius:8px;overflow:hidden;margin-top:8px}
@media (max-width:420px){.dock-map{height:240px}}
/* small locate control on the Leaflet map (target icon) */
.leaflet-control-locate{background:transparent;padding:0}
.leaflet-control-locate .locate-btn{background:#fff;border:none;border-radius:999px;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 20px rgba(0,0,0,0.18);width:56px;height:56px}
.leaflet-control-locate .locate-btn:hover{background:#f7fbff}
.leaflet-control-locate .locate-btn svg,
.leaflet-control-locate .locate-btn img{display:block;width:28px;height:28px}

/* Ensure the bottomright control sits above map UI and has spacing from edges */
.leaflet-bottom .leaflet-control-locate { margin-right: 12px; margin-bottom: 12px; }
/* Save status overlay */
.save-status-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.35);z-index:100000}
.save-status-overlay[hidden]{display:none}
.save-status-card{background:var(--green);color:#fff;border-radius:12px;padding:20px;min-width:240px;max-width:88%;box-shadow:0 10px 30px rgba(0,0,0,0.3);display:flex;align-items:center;justify-content:center}
.status-inner{display:flex;flex-direction:column;align-items:center;gap:10px}
.status-text{font-size:15px}
.lds-ring{display:inline-block;position:relative;width:48px;height:48px}
.lds-ring div{box-sizing:border-box;display:block;position:absolute;width:38px;height:38px;margin:6px;border:4px solid #fff;border-radius:50%;animation:lds-ring 1.2s cubic-bezier(0.5,0,0.5,1) infinite;border-color:#fff transparent transparent transparent}
.lds-ring div:nth-child(1){animation-delay:-0.45s}
.lds-ring div:nth-child(2){animation-delay:-0.3s}
.lds-ring div:nth-child(3){animation-delay:-0.15s}
@keyframes lds-ring{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
.status-check{width:56px;height:56px;display:none}
.status-check path{stroke:#fff}
.status-check.animate-check{animation:scale-in .36s ease-out forwards}
@keyframes scale-in{0%{transform:scale(0.4);opacity:0}60%{transform:scale(1.05);opacity:1}100%{transform:scale(1);opacity:1}}
.dialog-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}
.dialog-message{margin-top:8px;font-size:13px;color:var(--muted)}

/* Address suggestion dropdown inside dialog */
#dockAddressSuggestions{margin-top:6px}
#dockAddressSuggestions ul{list-style:none;margin:0;padding:0}
#dockAddressSuggestions li{margin:6px 0}
#dockAddressSuggestions .suggestion-btn{background:#fff;border:1px solid var(--btn-bd);border-radius:8px;padding:8px 10px;font-size:14px;width:100%;text-align:left}
#dockAddressSuggestions .suggestion-btn:hover{background:#f1f5ff}

/* Loading overlay used during data fetches (created by createLoadingOverlay/showLoadingOverlay) */
.loading-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.35);z-index:110000;pointer-events:auto}
.loading-overlay[hidden]{display:none}
.loading-card{background:var(--green);color:#fff;border-radius:12px;padding:20px;min-width:240px;max-width:88%;box-shadow:0 10px 30px rgba(0,0,0,0.3);display:flex;align-items:center;justify-content:center}
.loading-inner{display:flex;flex-direction:column;align-items:center;gap:10px}
.loading-text{font-size:14px;color:#fff;text-align:center;max-width:260px}
