:root{
  --bg:#0f1115; --card:#181b22; --card2:#1f242d; --ink:#eef2f6; --mut:#9aa6b2;
  --line:#2a313c; --brand:#15c07a; --warn:#f0b429; --bad:#ef5350; --good:#15c07a;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font:15px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.wrap{max-width:760px;margin:0 auto;padding:0 14px}
a{color:var(--brand)}
.topbar{background:linear-gradient(180deg,#0b3d2e,#0f1115);
  padding:14px 0 10px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.topbar h1{margin:0;font-size:20px}
.meta{color:var(--mut);font-size:12px;margin-top:2px}
.filters{display:flex;align-items:center;justify-content:space-between;
  gap:10px;padding:12px 14px;flex-wrap:wrap}
.seg{display:flex;background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{background:transparent;color:var(--mut);border:0;padding:8px 12px;font-size:13px;cursor:pointer}
.seg button.active{background:var(--brand);color:#04130c;font-weight:600}
.chk{color:var(--mut);font-size:12px;display:flex;align-items:center;gap:6px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:14px;margin:0 0 12px;display:flex;gap:12px}
.score{flex:0 0 58px;text-align:center}
.ring{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:18px;border:3px solid var(--good)}
.score small{display:block;color:var(--mut);font-size:10px;margin-top:4px}
.body{flex:1;min-width:0}
.club{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--brand)}
.title{font-weight:600;margin:2px 0 4px}
.when{color:var(--mut);font-size:13px;margin-bottom:8px}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.tag{background:var(--card2);border:1px solid var(--line);border-radius:999px;
  padding:3px 9px;font-size:12px;color:var(--ink)}
.tag.warn{border-color:var(--warn);color:var(--warn)}
.tag.event{border-color:#7c5cff;color:#b9a8ff}
.why{font-size:12.5px;color:var(--mut);border-top:1px dashed var(--line);padding-top:8px}
.why b{color:var(--ink)}
.links{margin-top:8px;font-size:13px;display:flex;gap:14px;flex-wrap:wrap}
.foot{color:var(--mut);font-size:12px;padding:18px 14px 40px;text-align:center}
.empty{color:var(--mut);text-align:center;padding:40px 0}
.bar{height:5px;border-radius:3px;background:var(--card2);margin-top:6px;overflow:hidden}
.bar > i{display:block;height:100%;background:var(--brand)}

/* 7-day outdoor outlook */
.outlook-wrap{padding:14px 14px 4px}
.outlook-header{display:flex;align-items:baseline;gap:10px;margin-bottom:10px}
.outlook-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--mut)}
.outlook-days{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.outlook-days::-webkit-scrollbar{display:none}
.day-tile{flex:0 0 72px;background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:10px 6px 8px;text-align:center;cursor:default}
.day-tile:hover{border-color:var(--mut)}
.day-name{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--mut);letter-spacing:.04em}
.day-md{font-size:10px;color:var(--mut);margin-bottom:4px}
.day-emoji{font-size:20px;line-height:1.2;margin:2px 0}
.day-score{font-size:18px;font-weight:700;line-height:1}
.day-label{font-size:10px;margin:2px 0 4px;font-weight:600}
.day-temp{font-size:11px;color:var(--ink)}
.day-lo{color:var(--mut)}
.day-badges{font-size:10px;color:var(--mut);margin-top:3px;display:flex;justify-content:center;gap:4px;flex-wrap:wrap}
.day-rain,.day-wind{white-space:nowrap}
