:root{color:#17201a;background:#f5f7f3;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #f5f7f3;--surface: #ffffff;--surface-muted: #eef3ee;--ink: #17201a;--muted: #5e6b63;--border: #d8e0d8;--green: #0f766e;--green-soft: #e3f4ef;--amber: #b7791f;--amber-soft: #fff4db;--red: #b14336;--red-soft: #fde8e4;--blue: #2f6fbc;--shadow: 0 18px 50px rgba(23, 32, 26, .08)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg)}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:wait;opacity:.74}.app-shell{min-height:100vh}.app-header{display:flex;align-items:center;gap:16px;width:min(1180px,calc(100% - 32px));margin:0 auto;padding:28px 0 18px}.brand-mark{display:grid;place-items:center;width:48px;height:48px;border:2px solid var(--ink);border-radius:8px;background:var(--surface);color:var(--ink);font-size:1.35rem;font-weight:800;box-shadow:var(--shadow)}.app-header h1,.section-heading h2,.results-header h2,.table-heading h2,.status-panel h2,.recommendation-card h3{margin:0;color:var(--ink)}.app-header h1{font-size:clamp(2rem,5vw,3.8rem);line-height:.95}.city-label,.eyebrow{margin:0 0 6px;color:var(--green);font-size:.78rem;font-weight:800;text-transform:uppercase}.app-main{display:grid;grid-template-columns:minmax(280px,390px) minmax(0,1fr);gap:24px;width:min(1180px,calc(100% - 32px));margin:0 auto;padding:12px 0 48px}.search-panel,.status-panel{border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.search-panel{align-self:start;padding:22px;position:sticky;top:18px}.section-heading,.results-header,.table-heading,.card-topline,.form-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.search-form{display:grid;gap:18px;margin-top:20px}.form-grid{display:grid;gap:14px}.field{display:grid;gap:7px}.field-label{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:.9rem;font-weight:750}.field input{width:100%;min-height:44px;border:1px solid var(--border);border-radius:8px;background:#fbfcfa;color:var(--ink);padding:10px 12px;outline:none}.field input:focus{border-color:var(--green);box-shadow:0 0 0 3px #0f766e24}.field input[aria-invalid=true]{border-color:var(--red)}.field-error{color:var(--red);font-size:.82rem;font-weight:700}.primary-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:8px;min-height:44px}.primary-button{gap:8px;flex:1;background:var(--green);color:#fff;padding:0 18px;font-weight:800}.primary-button:hover:not(:disabled){background:#0b625b}.icon-button{width:44px;border:1px solid var(--border);background:var(--surface-muted);color:var(--ink)}.icon-button:hover{border-color:var(--green);color:var(--green)}.results-region{min-width:0}.results-stack{display:grid;gap:18px}.results-header{align-items:flex-end;min-height:64px}.query-meta{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;color:var(--muted);font-size:.86rem}.query-meta span{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid var(--border);border-radius:999px;background:var(--surface);padding:6px 10px}.recommendation-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.recommendation-card{display:grid;gap:16px;min-height:254px;border:1px solid var(--border);border-radius:8px;background:var(--surface);padding:18px;box-shadow:var(--shadow)}.recommendation-card h3{min-height:54px;font-size:clamp(1.2rem,2vw,1.55rem);line-height:1.12}.rank-badge{display:inline-flex;align-items:center;justify-content:center;min-width:42px;min-height:30px;border-radius:999px;background:var(--amber-soft);color:#7a4b00;font-weight:850}.status-badge{display:inline-flex;align-items:center;gap:5px;width:fit-content;border-radius:999px;padding:5px 8px;font-size:.78rem;font-weight:800;white-space:nowrap}.status-badge.available{background:var(--green-soft);color:#0b625b}.status-badge.unavailable{background:var(--red-soft);color:var(--red)}.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px;margin:0}.metric-grid div{min-width:0}.metric-grid dt{color:var(--muted);font-size:.78rem;font-weight:800}.metric-grid dd{margin:3px 0 0;color:var(--ink);font-size:1.1rem;font-weight:850}.route-strip{display:grid;grid-template-columns:repeat(4,minmax(46px,1fr));gap:6px;align-self:end}.route-strip span{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-height:34px;border-radius:8px;background:var(--surface-muted);color:var(--muted);font-size:.82rem;font-weight:800}.table-heading{justify-content:flex-start;margin-top:6px}.table-wrap{width:100%;overflow-x:auto;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}table{width:100%;min-width:980px;border-collapse:collapse}th,td{border-bottom:1px solid var(--border);padding:12px 10px;text-align:left;vertical-align:middle;font-size:.88rem}th{position:sticky;top:0;background:#f9fbf8;color:var(--muted);font-size:.76rem;font-weight:850;text-transform:uppercase;white-space:nowrap}td{color:var(--ink)}tr:last-child td{border-bottom:0}.name-cell{min-width:170px;font-weight:820}.status-panel{display:flex;align-items:flex-start;gap:14px;padding:22px;color:var(--muted)}.status-panel svg{flex:0 0 auto}.status-panel-idle svg,.status-panel-loading svg{color:var(--green)}.status-panel-error svg{color:var(--red)}.status-panel h2{font-size:1.08rem}.status-panel p{margin:6px 0 0}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:940px){.app-main{grid-template-columns:1fr}.search-panel{position:static}.recommendation-grid{grid-template-columns:1fr}.recommendation-card{min-height:auto}.recommendation-card h3{min-height:0}}@media(max-width:620px){.app-header,.app-main{width:min(100% - 20px,1180px)}.app-header{padding-top:20px}.brand-mark{width:42px;height:42px}.search-panel,.status-panel,.recommendation-card{padding:16px}.results-header,.form-actions{align-items:stretch;flex-direction:column}.query-meta{justify-content:flex-start}.icon-button,.primary-button{width:100%}}
