.city-detail-hero-section {
    background:
        radial-gradient(circle at top left, rgba(214, 231, 226, 0.68), transparent 34%),
        linear-gradient(180deg, #f8f2e8 0%, #f7f9f7 48%, #ffffff 100%);
}

.city-detail-hero-shell {
    background:
        radial-gradient(circle at top right, rgba(217, 111, 50, 0.16), transparent 30%),
        linear-gradient(135deg, #f5eee3 0%, #fffdf8 44%, #eef5f4 100%);
    box-shadow: 0 28px 64px rgba(15, 34, 30, 0.08);
}

.city-detail-hero-copy {
    max-width: 70rem;
}

.city-detail-hero-title {
    margin: 0 0 1rem;
    color: #17313a;
    font-size: clamp(2.5rem, 4.2vw, 4.4rem);
    font-weight: 800;
    line-height: 0.97;
    letter-spacing: -0.05em;
}

.city-detail-hero-lead,
.city-detail-hero-intro {
    color: #5f7278;
    font-size: clamp(1.05rem, 1.02rem + 0.22vw, 1.2rem);
    line-height: 1.8;
}

.city-detail-hero-lead {
    margin-bottom: 1rem;
}

.city-detail-hero-lead > :last-child,
.city-detail-hero-intro > :last-child {
    margin-bottom: 0;
}

.city-detail-hero-intro strong,
.city-detail-hero-intro b,
.city-detail-hero-lead strong,
.city-detail-hero-lead b {
    color: #17313a;
    font-weight: 800;
}

.city-detail-hero-actions {
    margin-top: 1.6rem;
}

.city-detail-hero-cta.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3.15rem;
    padding: 0.85rem 1.4rem;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(135deg, #17313a 0%, #244650 100%);
    color: #fff;
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: 0 14px 28px rgba(23,49,58,.18);
    transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

.city-detail-hero-cta.btn:hover,
.city-detail-hero-cta.btn:focus {
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(23,49,58,.22);
    filter: brightness(1.02);
}

@media (max-width: 767.98px) {
    .city-detail-hero-shell {
        border-radius: 1.5rem !important;
        padding: 1.5rem !important;
    }

    .city-detail-hero-title {
        font-size: 2.1rem;
        line-height: 1.02;
    }

    .city-detail-hero-lead,
    .city-detail-hero-intro {
        font-size: 1rem;
        line-height: 1.72;
    }

    .city-detail-hero-cta.btn {
        width: 100%;
        min-height: 3rem;
        padding: 0.8rem 1rem;
    }
}
