:root{
  --bg:#f6f1eb; --panel:#f7f2ec; --card:#fbf8f4; --ink:#1c1c1c; --muted:#5e5e5e;
  --line:rgba(0,0,0,.10); --accent:#22313f; --accent2:#2b6a78; --chip:#ffffff;
  --shadow:0 18px 55px rgba(0,0,0,.12); --radius:18px;
}
*{box-sizing:border-box} html,body{height:100%}

/* --- HOVER site-style header (for subdomain tool) --- */
.siteHeader{max-width:1160px;margin:0 auto;padding:26px 12px 10px;text-align:center;}
.brand{display:inline-block;text-decoration:none;}
.brandLogo{width:min(190px,52vw);height:auto;display:block;margin:0 auto;}
.siteTagline{margin-top:6px;font-family:"Source Sans 3",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:14px;letter-spacing:.02em;color:var(--muted);}
.siteNav{margin-top:16px;display:flex;justify-content:center;flex-wrap:wrap;gap:22px;font-family:"Playfair Display",serif;font-size:19px;line-height:1.2;}
.siteNav a{color:var(--ink);text-decoration:none;border-bottom:1px solid transparent;padding:2px 0;}
.siteNav a:hover{border-bottom-color:rgba(0,0,0,.35);}
@media (max-width:520px){.siteNav{gap:14px;font-size:17px}}
/* ---------------------------------------------------- */

body{margin:0;color:var(--ink);background:var(--bg);font-family:"Source Sans 3",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;}
.wrap{padding:8px 12px 28px;display:flex;justify-content:center;}
.panel{width:min(1160px,100%);background:var(--panel);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);position:relative;overflow:hidden;}
.watermark{position:absolute;inset:-10%;background-image:url("./assets/hover-logo.png");background-repeat:no-repeat;background-position:center;background-size:min(880px,90vw);opacity:.035;filter:grayscale(1);pointer-events:none;}
.header{padding:22px 18px 10px;position:relative;text-align:center;}
.kicker{font-family:"Playfair Display",serif;font-weight:500;letter-spacing:.02em;opacity:.85;}
.title{margin:6px 0 6px;font-family:"Playfair Display",serif;font-weight:700;font-size:clamp(26px,3.2vw,40px);line-height:1.05;}
.sub{margin:0 auto;color:var(--muted);max-width:64ch;}
.grid{display:grid;grid-template-columns:1fr 1.15fr;gap:14px;padding:12px 12px 18px;position:relative;}
@media (max-width:980px){.grid{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px;position:relative;overflow:hidden;}
.label{font-weight:800;margin-bottom:8px;}
.row{display:flex;gap:10px;align-items:center;}
.row.endRow{justify-content:space-between;flex-wrap:wrap;}
.inputWrap{flex:1;position:relative;}
.input{width:100%;height:44px;padding:10px 12px;border-radius:12px;border:1px solid rgba(0,0,0,.18);background:#fff;color:var(--ink);outline:none;font-size:16px;}
.input:focus{border-color:rgba(34,49,63,.55);box-shadow:0 0 0 4px rgba(34,49,63,.10);}
.input.date{max-width:200px;}
.btn{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 14px;border-radius:999px;border:1px solid rgba(0,0,0,.18);background:#fff;color:var(--ink);text-decoration:none;font-weight:800;font-size:15px;cursor:pointer;user-select:none;white-space:nowrap;}
.btn:hover{border-color:rgba(0,0,0,.35);}
.btn.primary{background:var(--accent);color:#fff;border-color:transparent;}
.btn.primary:hover{filter:brightness(1.03);}
.hint{margin:8px 0 0;color:var(--muted);font-size:13.5px;line-height:1.3;}
.hint.small{font-size:12.5px;margin-top:4px;}
.divider{height:1px;background:var(--line);margin:14px 0;}
.suggestions{position:absolute;top:48px;left:0;right:0;border-radius:14px;background:#fff;border:1px solid rgba(0,0,0,.18);box-shadow:0 18px 55px rgba(0,0,0,.14);overflow:hidden;z-index:50;}
.suggestions.hidden{display:none}
.suggestion{padding:10px 12px;cursor:pointer;font-size:15px;}
.suggestion:hover{background:rgba(34,49,63,.06)}
.compassRow{display:flex;gap:12px;align-items:center;}
@media (max-width:560px){.compassRow{flex-direction:column;align-items:stretch}}
.compass{width:140px;height:140px;border-radius:999px;background:rgba(255,255,255,.7);border:1px solid rgba(0,0,0,.12);position:relative;flex:0 0 auto;display:grid;place-items:center;box-shadow:0 12px 28px rgba(0,0,0,.08);touch-action:none;}
.compassRing{position:absolute;inset:10px;border-radius:999px;border:1px dashed rgba(0,0,0,.18);}
.compassArrow{position:absolute;width:2px;height:52px;background:var(--accent2);top:22px;left:50%;transform-origin:50% 62px;transform:translateX(-50%) rotate(0deg);border-radius:99px;}
.compassArrow::after{content:"";position:absolute;top:-10px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:12px solid var(--accent2);}
.compassDot{position:absolute;width:10px;height:10px;border-radius:99px;background:var(--accent2);box-shadow:0 6px 18px rgba(0,0,0,.15);}
.compassText{position:absolute;bottom:10px;text-align:center;font-family:"Playfair Display",serif;}
.deg{font-weight:700;font-size:18px;line-height:1;}
.cardinal{font-size:13px;opacity:.85;}
.compassControls{flex:1}
.range{width:100%;accent-color:var(--accent2);}
.range.full{margin-top:10px;}
.quickRow{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.chip{height:34px;padding:0 12px;border-radius:999px;border:1px solid rgba(0,0,0,.15);background:var(--chip);font-weight:900;cursor:pointer;}
.chip:hover{border-color:rgba(0,0,0,.35);}
.timeBox{flex:1;padding:8px 10px;border:1px solid rgba(0,0,0,.12);border-radius:12px;background:rgba(255,255,255,.7);}
.time{font-weight:900;font-size:16px;}
.sunMeta{margin-top:2px;color:var(--muted);font-size:12.5px;}
.windows{margin-top:10px;display:flex;flex-direction:column;gap:8px;}
.empty{color:var(--muted);font-size:14px;}
.win{border:1px solid rgba(0,0,0,.12);background:rgba(255,255,255,.7);border-radius:14px;padding:10px 12px;}
.winTop{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.winTitle{font-weight:900}
.pills{display:flex;gap:6px;flex-wrap:wrap;}
.pill{font-size:12px;font-weight:900;border-radius:999px;padding:5px 9px;border:1px solid rgba(0,0,0,.12);background:#fff;}
.pill.best{border-color:rgba(34,106,120,.35);background:rgba(43,106,120,.08)}
.pill.good{border-color:rgba(34,49,63,.30);background:rgba(34,49,63,.06)}
.pill.avoid{border-color:rgba(210,70,70,.28);background:rgba(210,70,70,.06)}
.pill.weather{border-color:rgba(0,0,0,.10);background:rgba(0,0,0,.03)}
.pill.weather.clear{border-color:rgba(210,165,40,.30);background:rgba(210,165,40,.08)}
.pill.weather.cloudy{border-color:rgba(60,90,120,.25);background:rgba(60,90,120,.07)}
.pill.weather.overcast{border-color:rgba(60,90,120,.30);background:rgba(60,90,120,.10)}
.pill.weather.rain{border-color:rgba(210,70,70,.28);background:rgba(210,70,70,.08)}

.winList{margin:8px 0 0;padding-left:18px;color:var(--muted);font-size:13px;}
.winList li{margin:4px 0}
.mapCard{padding:0;overflow:hidden;}
.mapHeader{display:flex;justify-content:space-between;gap:10px;padding:14px 14px 10px;align-items:flex-start;}
.mapBadges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;}
.badge{font-size:12px;font-weight:900;padding:5px 10px;border-radius:999px;background:rgba(34,49,63,.06);border:1px solid rgba(34,49,63,.12);}
.map{height:580px;width:100%;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
@media (max-width:980px){.map{height:520px;}}
.mapFooter{padding:10px 14px 14px;}
.footer{padding:0 18px 18px;position:relative;}
.fine{color:rgba(0,0,0,.60);font-size:12.5px;line-height:1.35;}
.mapboxgl-ctrl-group{border-radius:14px !important;overflow:hidden;box-shadow:0 12px 24px rgba(0,0,0,.12);}
.mapboxgl-ctrl button{width:40px !important;height:40px !important;}
