* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; background: #f7f9fc; color: #1b2b46; }

.container { width: 100%; max-width: 1000px; margin: 0 auto; padding: 16px; }
header h1 { margin: 8px 0 0; font-size: 28px; }
.header .brand { display: flex; align-items: center; gap: 12px; }
.header { display: flex; justify-content: space-between; align-items: center; }
.brand-logo { display: grid; place-items: center; background: #f0f1f4; border-radius: 8px; }
.tagline { display: block; color: #a9b7d0; font-size: 12px; }

.post-btn { display: inline-block; text-decoration: none; background: #2b77ff; color: #ffffff; padding: 10px 12px; border-radius: 8px; font-weight: 600; border: 1px solid rgba(0,0,0,0.04); }

.hero { margin: 8px 0 16px; background: linear-gradient(135deg, #e8f1ff, #ffffff); border: 1px solid #e5eaf2; border-radius: 16px; padding: 20px; }
.hero-content { display: grid; gap: 10px; }
.hero h2 { margin: 0; font-size: 22px; color: #0f1f3a; }
.hero p { margin: 0; color: #425775; }
.bullets { margin: 0; padding-left: 18px; color: #425775; }
.bullets li { margin: 4px 0; }

.filters { background: #ffffff; border: 1px solid #e5eaf2; border-radius: 12px; padding: 16px; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.filter-group h2 { margin: 0 0 8px; font-size: 16px; color: #334b68; font-weight: 600; }
.label { display: block; margin: 0 0 6px; color: #a9b7d0; font-size: 12px; }
.dropdown { position: relative; }
.dropdown-toggle { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 8px; background: #ffffff; color: #1b2b46; border: 1px solid #d6deea; border-radius: 8px; padding: 10px; cursor: pointer; }
.dropdown-toggle:after { content: "\25BC"; font-size: 10px; opacity: 0.8; }
.dropdown[aria-expanded="true"] .dropdown-toggle:after { transform: rotate(180deg); }
.dropdown-menu { position: absolute; z-index: 10; top: calc(100% + 6px); left: 0; right: 0; background: #ffffff; border: 1px solid #d6deea; border-radius: 8px; padding: 8px; display: none; max-height: 220px; overflow: auto; box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.dropdown.open .dropdown-menu { display: block; }
.option { display: flex; align-items: center; gap: 8px; padding: 8px; border-radius: 6px; cursor: pointer; }
.option:hover { background: #f0f6ff; }
.option input { accent-color: #2b77ff; }

.actions { grid-column: 1 / -1; display: flex; gap: 8px; justify-content: flex-start; }
button { appearance: none; border: none; padding: 10px 14px; background: #2b77ff; color: #ffffff; border-radius: 8px; font-weight: 600; cursor: pointer; box-shadow: 0 1px 0 rgba(0,0,0,0.05); }
button.secondary { background: #eef2f8; color: #1b2b46; border: 1px solid #d6deea; }
button:disabled { opacity: 0.6; cursor: not-allowed; }

.results-section { margin-top: 16px; }
.hidden { display: none; }
.status { margin-bottom: 8px; color: #5a6f86; }
.grid { display: grid; grid-template-columns: repeat(1, minmax(0, 1fr)); gap: 12px; }

@media (min-width: 520px) {
  .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 860px) {
  .grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.card { background: #ffffff; border: 1px solid #e5eaf2; border-radius: 12px; padding: 12px; display: grid; gap: 6px; }
.card-title { font-size: 16px; font-weight: 700; color: #0f1f3a; }
.meta { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { background: #eef5ff; border: 1px solid #cfe1ff; color: #1b2b46; padding: 4px 8px; border-radius: 999px; font-size: 12px; }
.muted { color: #5a6f86; font-size: 12px; }

.how-it-helps { margin-top: 20px; background: #ffffff; border: 1px solid #e5eaf2; border-radius: 12px; padding: 16px; }
.how-it-helps h2 { margin: 0 0 12px; font-size: 18px; color: #334b68; }
.steps { display: grid; gap: 12px; }
.step { display: grid; grid-template-columns: auto 1fr; gap: 10px; align-items: start; }
.step-number { width: 28px; height: 28px; display: grid; place-items: center; background: #2b77ff; color: #ffffff; border-radius: 999px; font-weight: 700; }
.step h3 { margin: 0; font-size: 15px; }
.step p { margin: 2px 0 0; color: #425775; }

.footer { opacity: 0.8; font-size: 12px; text-align: center; color: #5a6f86; }

/* Form elements */
.form { display: grid; gap: 12px; }
.form-row { display: grid; gap: 6px; }
.input { width: 100%; background: #ffffff; color: #1b2b46; border: 1px solid #d6deea; border-radius: 8px; padding: 10px; }
.input:focus { outline: 2px solid #2b77ff22; border-color: #2b77ff; }
.checkboxes { display: grid; gap: 8px; }


/* Multiselect chips and suggestions */
.multiselect { position: relative; display: grid; gap: 6px; }
.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip { display: inline-flex; align-items: center; gap: 6px; background: #eef5ff; border: 1px solid #cfe1ff; color: #1b2b46; padding: 6px 8px; border-radius: 999px; font-size: 12px; }
.chip button { display: grid; place-items: center; width: 18px; height: 18px; border-radius: 999px; border: 1px solid #b7cfff; background: #ffffff; color: #1b2b46; padding: 0; font-weight: 700; line-height: 1; }
.suggestions { position: absolute; z-index: 20; top: 100%; left: 0; right: 0; background: #ffffff; border: 1px solid #d6deea; border-radius: 8px; margin-top: 6px; box-shadow: 0 8px 24px rgba(0,0,0,0.08); max-height: 220px; overflow: auto; display: none; }
.suggestions.open { display: block; }
.suggestion-item { padding: 10px; cursor: pointer; }
.suggestion-item:hover, .suggestion-item.active { background: #f0f6ff; }


