* {
    box-sizing: border-box;
}

body {
    margin: 0;
    background: #f6f8f7;
    color: #202733;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

a {
    color: #0f766e;
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

.pulse-header {
    align-items: center;
    background: #ffffff;
    border-bottom: 1px solid #d9e1e4;
    display: flex;
    gap: 18px;
    justify-content: space-between;
    padding: 16px 28px;
}

.pulse-brand {
    color: #202733;
    font-size: 21px;
    font-weight: 850;
}

.pulse-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.pulse-nav a {
    color: #52606d;
    font-weight: 700;
}

.pulse-main {
    margin: 0 auto;
    padding: 42px 0 76px;
    width: min(1120px, calc(100% - 36px));
}

.pulse-home {
    align-items: end;
    display: grid;
    gap: 24px;
    grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.8fr);
    margin-bottom: 34px;
}

.pulse-home-copy {
    max-width: 780px;
}

.pulse-home-copy span {
    color: #b45309;
    font-size: 13px;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
}

.pulse-home-copy h1 {
    font-size: clamp(42px, 7vw, 78px);
    letter-spacing: 0;
    line-height: 0.98;
    margin: 8px 0 20px;
}

.pulse-stats {
    background: #ffffff;
    border: 1px solid #d9e1e4;
    border-radius: 8px;
    display: grid;
    gap: 1px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: hidden;
}

.pulse-stats div {
    background: #f9fbfb;
    display: grid;
    gap: 4px;
    min-height: 102px;
    padding: 16px;
}

.pulse-stats strong {
    color: #202733;
    font-size: 32px;
    letter-spacing: 0;
}

.pulse-stats span {
    color: #667085;
    font-weight: 800;
}

.pulse-page-head {
    margin-bottom: 28px;
    max-width: 820px;
}

.pulse-page-head span,
time,
.pulse-result strong {
    color: #b45309;
    font-size: 13px;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
}

.pulse-page-head h1,
.pulse-detail-head h1 {
    font-size: clamp(36px, 5vw, 64px);
    letter-spacing: 0;
    line-height: 1.02;
    margin: 8px 0 12px;
}

.pulse-page-head p,
.pulse-detail-head p,
.pulse-card p,
.pulse-result p {
    color: #667085;
    font-size: 17px;
    line-height: 1.6;
}

.pulse-search {
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(0, 1fr) auto;
    max-width: 680px;
}

.pulse-search input {
    background: #ffffff;
    border: 1px solid #cbd5df;
    border-radius: 6px;
    color: #202733;
    font: inherit;
    min-height: 46px;
    padding: 12px;
}

.pulse-button,
.pulse-search button {
    align-items: center;
    background: #0f766e;
    border: 0;
    border-radius: 6px;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    font-weight: 800;
    justify-content: center;
    min-height: 42px;
    padding: 11px 16px;
}

.pulse-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
}

.pulse-card,
.pulse-result {
    background: #ffffff;
    border: 1px solid #d9e1e4;
    border-radius: 8px;
    overflow: hidden;
}

.pulse-card img,
.pulse-card-media {
    aspect-ratio: 16 / 10;
    background: #e8eef0;
    display: grid;
    object-fit: cover;
    place-items: center;
    width: 100%;
}

.pulse-card-media span {
    align-items: center;
    background: #1d4ed8;
    border-radius: 8px;
    color: #ffffff;
    display: inline-flex;
    font-size: 34px;
    font-weight: 850;
    height: 68px;
    justify-content: center;
    width: 68px;
}

.pulse-card-body,
.pulse-result {
    padding: 18px;
}

.pulse-card h2,
.pulse-result h3,
.pulse-section h2,
.pulse-panel h2 {
    letter-spacing: 0;
    margin: 8px 0;
}

.pulse-meta,
.pulse-empty {
    color: #667085;
}

.pulse-detail {
    max-width: 880px;
}

.pulse-hero {
    aspect-ratio: 16 / 8;
    border-radius: 8px;
    margin-bottom: 26px;
    object-fit: cover;
    width: 100%;
}

.pulse-detail-head {
    margin-bottom: 24px;
}

.pulse-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 14px 0;
}

.pulse-tags a,
.pulse-tags span {
    background: #ffffff;
    border: 1px solid #d9e1e4;
    border-radius: 999px;
    color: #394452;
    font-weight: 750;
    padding: 7px 10px;
}

.pulse-body {
    color: #283342;
    font-size: 18px;
    line-height: 1.75;
}

.pulse-panel,
.pulse-section {
    border-top: 1px solid #d9e1e4;
    margin-top: 28px;
    padding-top: 24px;
}

.pulse-section-head {
    align-items: center;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    margin-bottom: 16px;
}

.pulse-section-head h2 {
    font-size: 24px;
    margin: 0;
}

.pulse-section-head a {
    font-weight: 800;
}

.pulse-link-grid,
.pulse-directory {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}

.pulse-link-grid a,
.pulse-directory a {
    background: #ffffff;
    border: 1px solid #d9e1e4;
    border-radius: 8px;
    color: #202733;
    display: grid;
    gap: 7px;
    min-height: 118px;
    padding: 16px;
}

.pulse-link-grid a:hover,
.pulse-directory a:hover {
    border-color: #0f766e;
    text-decoration: none;
}

.pulse-link-grid strong,
.pulse-directory strong {
    font-size: 18px;
}

.pulse-link-grid span,
.pulse-directory span,
.pulse-directory small {
    color: #667085;
    line-height: 1.45;
}

.pulse-defs {
    display: grid;
    gap: 10px;
    grid-template-columns: 130px minmax(0, 1fr);
}

.pulse-defs dt {
    color: #667085;
    font-weight: 800;
}

.pulse-defs dd {
    margin: 0;
}

.pulse-results {
    display: grid;
    gap: 14px;
}

@media (max-width: 760px) {
    .pulse-home {
        grid-template-columns: 1fr;
    }

    .pulse-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .pulse-search,
    .pulse-defs {
        grid-template-columns: 1fr;
    }
}
