body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#0b1220;color:#e5e7eb;margin:0}
main{max-width:1100px;margin:24px auto;padding:16px}

.location-picker{position:relative;background:#111a2b;border:1px solid #23314f;border-radius:12px;padding:12px;margin-bottom:14px}
.location-picker label{display:block;font-size:14px;color:#9fb0d1;margin-bottom:8px}
.location-picker input{width:100%;box-sizing:border-box;border:1px solid #2a3d63;background:#0f172a;color:#e5e7eb;border-radius:10px;padding:11px 12px;font-size:15px;outline:none}
.location-picker input:focus{border-color:#5b8cff}
.loc-actions{margin-top:8px}
.loc-actions button{border:1px solid #2a3d63;background:#13213d;color:#dbeafe;border-radius:10px;padding:9px 12px;cursor:pointer}
.loc-actions button:hover{background:#1a2c50}
.loc-actions button:disabled{opacity:.6;cursor:not-allowed}
.picked{margin:8px 0 0 0;color:#a7f3d0;font-size:14px}

.suggestions{position:absolute;left:12px;right:12px;top:84px;background:#0f172a;border:1px solid #2a3d63;border-radius:10px;max-height:280px;overflow:auto;z-index:8}
.suggestion{display:flex;justify-content:space-between;gap:12px;width:100%;background:transparent;color:#e5e7eb;border:0;border-bottom:1px solid #1c2a45;padding:10px 12px;text-align:left;cursor:pointer}
.suggestion:last-child{border-bottom:0}
.suggestion:hover{background:#15203a}
.suggestion span{color:#8ea3c8;font-size:12px;white-space:nowrap}

.three-day{display:flex;flex-direction:column;gap:12px;margin:10px 0 14px}
.model-three-day{background:#0e172a;border:1px solid #223555;border-radius:12px;padding:10px}
.model-three-day h3{margin:0 0 8px 0;font-size:16px;color:#bcd3ff}
.three-day-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.day-card{background:#111a2b;border:1px solid #2a3d63;border-radius:12px;padding:10px}
.day-card h4{margin:0 0 8px 0;font-size:15px}
.day-card .row{display:flex;justify-content:space-between;color:#d7e3ff;font-size:14px;margin:4px 0}

#cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.card{background:#111a2b;border:1px solid #23314f;border-radius:12px;padding:12px}
.ok{border-color:#1f8b4c}
.bad{border-color:#8b1f2e}
h3{margin:0 0 8px 0}
pre{white-space:pre-wrap;background:#0f172a;padding:12px;border-radius:10px;border:1px solid #22304b}
