body { font-family: Arial, sans-serif; margin: 0; background: #faf7f2; color: #2b2b2b; }
header, footer { padding: 1rem 1.2rem; background: #4b2e1f; color: #fff; }
main { padding: 1rem 1.2rem; }
.controls { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; margin-bottom: 1rem; }
.manual-location { display: flex; flex-direction: column; gap: 0.25rem; min-width: 320px; }
.manual-location input { padding: 0.55rem 0.65rem; border: 1px solid #cdb9a9; border-radius: 8px; }
button { background: #8a4b25; color: #fff; border: 0; padding: 0.7rem 1rem; border-radius: 8px; cursor: pointer; }
button:hover { background: #6e3c1d; }
#status { margin: 0.7rem 0 0.2rem 0; }
.source-badge { margin: 0 0 0.7rem 0; color: #6e3c1d; font-size: 0.9rem; }
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); gap: 0.8rem; }
.card { background: #fff; border-radius: 10px; padding: 0.9rem; box-shadow: 0 1px 6px rgba(0,0,0,.08); }
.card h3 { margin: 0 0 .4rem 0; font-size: 1.05rem; }
.badge { display: inline-block; font-size: .75rem; border-radius: 999px; padding: .1rem .55rem; margin-bottom: .4rem; }
.badge-open { background: #dff6df; color: #0b6510; }
.badge-soon { background: #fff2cf; color: #8a5a00; }
.badge-tomorrow { background: #e6edff; color: #20418f; }
.badge-later { background: #f0f0f0; color: #4c4c4c; }
.link { display: inline-block; margin-top: .35rem; }
