.rv-header {
    background: #fff;
    box-shadow: 0 2px 12px rgba(60,70,100,0.06);
    padding-bottom: 8px;
}
.rv-header__top {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 18px 0 18px;
    flex-wrap: wrap;
    gap: 12px;
}
.rv-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    text-decoration: none;
    color: #314157;
    font-size: 1.12rem;
}
.rv-logo img {
    height: 46px;
    width: auto;
    border-radius: 10px;
}
.rv-nav {
    display: flex;
    gap: 28px;
    flex-wrap: wrap;
}
.rv-nav a {
    color: #314157;
    text-decoration: none;
    font-weight: 500;
    font-size: 1.04rem;
    transition: color 0.15s;
    padding-bottom: 2px;
    border-bottom: 2px solid transparent;
}
.rv-nav a:hover {
    color: #e15e40;
    border-bottom: 2px solid #e15e40;
}
.rv-header__contacts {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    font-size: 0.96rem;
    gap: 2px;
}
.rv-header__contacts a {
    color: #e15e40;
    font-weight: 600;
    text-decoration: none;
    margin-bottom: 2px;
}
@media (max-width: 900px) {
    .rv-header__top {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    .rv-header__contacts {
        align-items: flex-start;
    }
    .rv-nav {
        gap: 16px;
    }
}
@media (max-width: 600px) {
    .rv-header__top {
        padding: 10px 7px 0 7px;
    }
    .rv-logo img {
        height: 36px;
    }
    .rv-nav a {
        font-size: 0.98rem;
    }
    .rv-header__contacts {
        font-size: 0.91rem;
    }
}
.rv-footer {
    background: #f8f9fc;
    border-top: 1px solid #e2e5ee;
    margin-top: 40px;
    font-size: 0.98rem;
}
.rv-footer__main {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    gap: 28px;
    padding: 32px 18px 14px 18px;
    flex-wrap: wrap;
}
.rv-footer__col {
    display: flex;
    flex-direction: column;
    gap: 13px;
    min-width: 170px;
}
.rv-footer__logo img {
    height: 38px;
    width: auto;
    border-radius: 7px;
}
.rv-footer__nav {
    display: flex;
    flex-direction: column;
    gap: 7px;
}
.rv-footer__nav a {
    color: #314157;
    text-decoration: none;
    transition: color 0.15s;
}
.rv-footer__nav a:hover {
    color: #e15e40;
}
.rv-footer__contacts a {
    color: #e15e40;
    font-weight: 600;
    text-decoration: none;
}
.rv-footer__bottom {
    background: #f2f3f7;
    text-align: center;
    padding: 9px 0 5px 0;
    font-size: 0.94rem;
    color: #79819a;
    border-top: 1px solid #e2e5ee;
}
@media (max-width: 900px) {
    .rv-footer__main {
        flex-direction: column;
        align-items: flex-start;
        gap: 18px;
        padding: 22px 8px 8px 8px;
    }
}
@media (max-width: 600px) {
    .rv-footer__logo img {
        height: 29px;
    }
    .rv-footer__main {
        font-size: 0.91rem;
    }
}

body {
    font-family: 'Segoe UI', Arial, sans-serif;
    color: #21243b;
    background: #fff;
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
}

.container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 18px;
}

.main-page {
    background: #fff;
}

.hero-banner {
    padding: 44px 0 28px 0;
    background: #f7f7fb;
}
.hero-content {
    display: flex;
    gap: 48px;
    align-items: center;
    flex-wrap: wrap;
}
.hero-img {
    width: 360px;
    border-radius: 22px;
    box-shadow: 0 8px 38px rgba(0,0,0,0.09);
    object-fit: cover;
    max-width: 100%;
}
.hero-text {
    flex: 1 1 320px;
    min-width: 270px;
}
.hero-text h1 {
    font-size: 2.5rem;
    margin-bottom: 18px;
    font-weight: 700;
    color: #3959ab;
}
.hero-text p {
    font-size: 1.14rem;
    margin-bottom: 22px;
    color: #333c54;
}
.btn {
    background: linear-gradient(90deg, #3959ab 0%, #587ed8 100%);
    color: #fff;
    padding: 13px 36px;
    border-radius: 2rem;
    font-weight: 600;
    text-decoration: none;
    font-size: 1.05rem;
    box-shadow: 0 4px 20px rgba(57,89,171,.08);
    border: none;
    transition: background 0.18s;
    cursor: pointer;
    display: inline-block;
}
.btn:hover, .btn:focus {
    background: linear-gradient(90deg, #273d70 0%, #3c68b4 100%);
}

.about {
    padding: 40px 0 24px 0;
    background: #fff;
}
.about h2 {
    font-size: 1.8rem;
    font-weight: 600;
    margin-bottom: 15px;
    color: #3959ab;
}
.about p {
    font-size: 1.08rem;
    color: #222;
    max-width: 770px;
}

.advantages {
    background: #f1f5fc;
    padding: 44px 0 38px 0;
}
.advantages h2 {
    font-size: 1.6rem;
    margin-bottom: 18px;
    color: #3959ab;
    font-weight: 600;
}
.adv-list {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
    list-style: none;
    margin: 0;
    padding: 0;
    justify-content: space-between;
}
.adv-list li {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: 1.06rem;
    flex: 1 1 200px;
    min-width: 180px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(38,57,129,.05);
    padding: 12px 16px;
}
.adv-list img {
    width: 38px;
    height: 38px;
    object-fit: contain;
}

.rooms-preview {
    padding: 44px 0 34px 0;
    background: #fff;
}
.rooms-preview h2 {
    font-size: 1.5rem;
    margin-bottom: 19px;
    color: #3959ab;
    font-weight: 600;
}
.rooms-list {
    display: flex;
    gap: 32px;
    flex-wrap: wrap;
    justify-content: space-between;
}
.room-card {
    background: #f7f9fd;
    border-radius: 18px;
    box-shadow: 0 4px 18px rgba(38,57,129,.08);
    padding: 24px 18px 20px;
    flex: 1 1 260px;
    min-width: 260px;
    max-width: 340px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    transition: box-shadow .2s;
}
.room-card:hover {
    box-shadow: 0 8px 36px rgba(38,57,129,.14);
}
.room-card img {
    width: 100%;
    border-radius: 14px;
    margin-bottom: 13px;
    object-fit: cover;
    min-height: 120px;
    background: #dde4ef;
}
.room-card h3 {
    font-size: 1.13rem;
    margin-bottom: 7px;
    color: #273d70;
    font-weight: 600;
}
.room-card p {
    font-size: 0.98rem;
    margin-bottom: 13px;
    color: #343c5a;
}
.room-link {
    color: #3959ab;
    font-weight: 600;
    text-decoration: underline;
    font-size: 1.01rem;
    margin-top: auto;
    transition: color .15s;
}
.room-link:hover { color: #273d70; }

.services {
    background: #f7f9fd;
    padding: 44px 0 38px 0;
}
.services h2 {
    font-size: 1.4rem;
    color: #3959ab;
    margin-bottom: 18px;
    font-weight: 600;
}
.services-list {
    display: flex;
    gap: 22px;
    flex-wrap: wrap;
    justify-content: space-between;
}
.service {
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 2px 12px rgba(57,89,171,.07);
    padding: 18px 12px 14px;
    min-width: 120px;
    flex: 1 1 128px;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 14px;
    text-align: center;
    transition: box-shadow .2s;
}
.service:hover {
    box-shadow: 0 8px 30px rgba(57,89,171,.15);
}
.service img {
    width: 38px;
    margin-bottom: 8px;
}
.service p {
    font-size: .97rem;
    margin: 0;
}

.gallery-preview {
    padding: 38px 0 30px 0;
    background: #fff;
}
.gallery-preview h2 {
    font-size: 1.4rem;
    color: #3959ab;
    margin-bottom: 18px;
    font-weight: 600;
}
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-bottom: 18px;
}
.gallery-grid img {
    width: 100%;
    aspect-ratio: 4/3;
    border-radius: 14px;
    object-fit: cover;
    background: #dde4ef;
}
.gallery-more {
    display: block;
    margin: 0 auto;
    width: max-content;
}

.hotel-map {
    background: #f1f4f9;
    padding: 38px 0 26px 0;
}
.hotel-map h2 {
    font-size: 1.3rem;
    color: #3959ab;
    margin-bottom: 14px;
    font-weight: 600;
}
.map-block {
    width: 100%;
    height: 220px;
    border-radius: 16px;
    box-shadow: 0 3px 18px rgba(38,57,129,.07);
    background: #e5e5e5;
}

.faq {
    padding: 36px 0 30px 0;
    background: #fff;
}
.faq h2 {
    font-size: 1.27rem;
    color: #3959ab;
    margin-bottom: 14px;
    font-weight: 600;
}
.faq-list {
    max-width: 720px;
    margin: 0 auto;
}
.faq-item {
    margin-bottom: 15px;
}
.faq-question {
    background: #3959ab;
    color: #fff;
    border: none;
    padding: 13px 18px;
    border-radius: 1rem;
    width: 100%;
    text-align: left;
    cursor: pointer;
    font-size: 1rem;
    font-weight: 500;
    outline: none;
    transition: background .16s;
    box-shadow: 0 1px 6px rgba(38,57,129,.04);
}
.faq-question.open {
    background: #23375f;
}
.faq-answer {
    display: none;
    padding: 14px 20px 14px 22px;
    background: #f6f8fc;
    border-radius: 0 0 1rem 1rem;
    font-size: .97rem;
    color: #273d70;
}

.contact-form-block {
    padding: 44px 0 36px 0;
    background: #f7f7fb;
}
.contact-form-block h2 {
    font-size: 1.23rem;
    color: #3959ab;
    margin-bottom: 14px;
    font-weight: 600;
}
.contact-form {
    max-width: 500px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.contact-form input, .contact-form textarea {
    padding: 12px;
    border: 1px solid #d7dce7;
    border-radius: 12px;
    font-size: 1rem;
    background: #fff;
    transition: border-color .16s;
}
.contact-form input:focus, .contact-form textarea:focus {
    border-color: #3959ab;
    outline: none;
}
.contact-form textarea {
    min-height: 64px;
    resize: vertical;
}
.contact-form button {
    margin-top: 7px;
}
.form-success {
    color: #30a86a;
    margin-top: 10px;
    font-size: 1.03rem;
}

.realty-mention {
    background: #f7f7fb;
    padding: 36px 0 32px 0;
}
.realty-block {
    text-align: center;
    font-size: 1.11rem;
    color: #273d70;
    max-width: 600px;
    margin: 0 auto;
}
.realty-block a {
    color: #3959ab;
    font-weight: 600;
    text-decoration: underline;
    transition: color .15s;
}
.realty-block a:hover { color: #273d70; }

/* Адаптация для экранов <900px и <600px */
@media (max-width: 900px) {
    .hero-content {
        flex-direction: column;
        gap: 24px;
    }
    .rooms-list, .services-list {
        flex-direction: column;
        gap: 18px;
    }
    .gallery-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .adv-list {
        flex-direction: column;
        gap: 18px;
    }
}
@media (max-width: 600px) {
    .container {
        padding: 0 6px;
    }
    .hero-img { width: 100%; }
    .gallery-grid {
        grid-template-columns: 1fr;
    }
    .room-card, .service {
        min-width: unset;
        max-width: 100%;
    }
    .adv-list li {
        min-width: unset;
        padding: 11px 8px;
    }
    .faq-list {
        padding: 0 2px;
    }
    .map-block {
        height: 150px;
    }
}
.prices-page {
    background: #fff;
}
.section-head {
    padding: 40px 0 18px 0;
    background: #f7f7fb;
}
.section-head h1 {
    font-size: 2rem;
    color: #3959ab;
    font-weight: 700;
    margin-bottom: 14px;
}
.section-head .lead {
    font-size: 1.13rem;
    color: #273d70;
}

.section-pricetable {
    padding: 36px 0 24px 0;
    background: #fff;
}
.section-pricetable h2 {
    font-size: 1.33rem;
    margin-bottom: 12px;
    color: #3959ab;
    font-weight: 600;
}
.price-table-wrap {
    overflow-x: auto;
    margin-bottom: 9px;
}
.price-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 1rem;
    background: #f9fbff;
    box-shadow: 0 1px 12px rgba(38,57,129,.07);
    border-radius: 16px;
    overflow: hidden;
    min-width: 580px;
}
.price-table th,
.price-table td {
    padding: 15px 13px;
    text-align: center;
}
.price-table th {
    background: #3959ab;
    color: #fff;
    font-weight: 600;
    font-size: 1.02rem;
}
.price-table tbody tr:nth-child(odd) {
    background: #f1f5fc;
}
.price-table tbody tr:nth-child(even) {
    background: #fff;
}
.price-table td {
    color: #23375f;
}
.price-note {
    margin-top: 10px;
    font-size: 0.99rem;
    color: #858da9;
}

.section-includes {
    background: #f7f9fd;
    padding: 34px 0 20px 0;
}
.section-includes h2 {
    font-size: 1.19rem;
    color: #3959ab;
    font-weight: 600;
    margin-bottom: 13px;
}
.inc-list {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 36px;
    list-style: none;
    margin: 0;
    padding: 0;
    max-width: 800px;
}
.inc-list li {
    display: flex;
    align-items: center;
    gap: 13px;
    font-size: 1.04rem;
    background: #fff;
    border-radius: 12px;
    padding: 10px 16px;
    box-shadow: 0 1px 8px rgba(38,57,129,.04);
    min-width: 220px;
    margin-bottom: 7px;
}
.inc-list img {
    width: 30px;
    height: 30px;
    object-fit: contain;
}

.section-payment {
    padding: 36px 0 22px 0;
    background: #fff;
}
.section-payment h2 {
    font-size: 1.19rem;
    color: #3959ab;
    font-weight: 600;
    margin-bottom: 13px;
}
.payment-columns {
    display: flex;
    gap: 32px;
    flex-wrap: wrap;
}
.payment-col {
    background: #f7f9fd;
    border-radius: 14px;
    box-shadow: 0 1px 10px rgba(38,57,129,.04);
    padding: 18px 22px 16px 22px;
    min-width: 250px;
    flex: 1 1 220px;
}
.payment-col h3 {
    font-size: 1.08rem;
    color: #273d70;
    font-weight: 600;
    margin-bottom: 9px;
}
.payment-col ul {
    list-style: disc inside;
    margin: 0 0 2px 0;
    padding: 0;
}
.payment-col li {
    font-size: 1.02rem;
    margin-bottom: 6px;
}

.section-faq-prices {
    background: #f1f4f9;
    padding: 33px 0 24px 0;
}
.section-faq-prices h2 {
    font-size: 1.13rem;
    color: #3959ab;
    margin-bottom: 12px;
    font-weight: 600;
}
.faq-list {
    max-width: 680px;
    margin: 0 auto;
}
.faq-item {
    margin-bottom: 13px;
}
.faq-question {
    background: #3959ab;
    color: #fff;
    border: none;
    padding: 12px 17px;
    border-radius: 1rem;
    width: 100%;
    text-align: left;
    cursor: pointer;
    font-size: 1rem;
    font-weight: 500;
    transition: background .14s;
    box-shadow: 0 1px 5px rgba(38,57,129,.03);
}
.faq-question.open {
    background: #23375f;
}
.faq-answer {
    display: none;
    padding: 12px 18px 12px 21px;
    background: #f6f8fc;
    border-radius: 0 0 1rem 1rem;
    font-size: .98rem;
    color: #273d70;
}

.section-quickcontact {
    background: #f7f7fb;
    padding: 26px 0 36px 0;
}
.quickcontact-block {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 24px;
    justify-content: space-between;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 1px 8px rgba(38,57,129,.03);
    padding: 18px 28px;
    max-width: 760px;
    margin: 0 auto;
}
.quickcontact-block strong {
    font-size: 1.08rem;
    color: #3959ab;
}
.quickcontact-block p {
    margin: 7px 0 0 0;
    color: #222c4a;
    font-size: 1.01rem;
}

/* Адаптив */
@media (max-width: 900px) {
    .inc-list {
        flex-direction: column;
        gap: 12px;
    }
    .payment-columns {
        flex-direction: column;
        gap: 18px;
    }
    .quickcontact-block {
        flex-direction: column;
        gap: 14px;
        padding: 13px 7px;
    }
}
@media (max-width: 600px) {
    .price-table { min-width: 350px; font-size: .94rem; }
    .inc-list li { min-width: unset; font-size: .98rem; }
    .section-head h1 { font-size: 1.22rem; }
    .faq-question { font-size: .99rem; padding: 10px 10px; }
}
.gallery-page { background: #fff; }
.gallery-head { padding: 42px 0 18px 0; background: #f7f7fb; text-align: center; }
.gallery-head h1 { font-size: 2rem; color: #3959ab; font-weight: 700; margin-bottom: 11px; }
.gallery-head p { color: #273d70; font-size: 1.08rem; }
.gallery-filters { padding: 24px 0 2px 0; background: #fff; }
.gallery-filter-list {
    display: flex;
    gap: 14px;
    list-style: none;
    justify-content: center;
    padding: 0;
    margin: 0;
}
.gallery-filter {
    background: #f1f5fc;
    color: #3959ab;
    border: none;
    border-radius: 2rem;
    padding: 9px 22px;
    font-size: 1.01rem;
    cursor: pointer;
    font-weight: 600;
    transition: background .14s, color .14s;
}
.gallery-filter.active,
.gallery-filter:hover {
    background: #3959ab;
    color: #fff;
}
.gallery-grid-block { padding: 12px 0 44px 0; }
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
.gallery-item {
    border-radius: 18px;
    overflow: hidden;
    background: #f1f4fa;
    box-shadow: 0 2px 11px rgba(38,57,129,.05);
    transition: box-shadow .16s;
    cursor: pointer;
    position: relative;
}
.gallery-item img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
    display: block;
    transition: transform .15s;
    background: #dde4ef;
}
.gallery-item:hover { box-shadow: 0 8px 36px rgba(38,57,129,.10);}
.gallery-item:hover img { transform: scale(1.04);}
@media (max-width: 1000px) {
    .gallery-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
    .gallery-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .gallery-grid { grid-template-columns: 1fr; }
}

.gallery-modal {
    display: none;
    position: fixed;
    z-index: 1110;
    left: 0; top: 0; width: 100vw; height: 100vh;
    background: rgba(28,36,58,0.84);
    align-items: center;
    justify-content: center;
    transition: opacity .15s;
}
.gallery-modal-img {
    max-width: 92vw;
    max-height: 82vh;
    border-radius: 14px;
    box-shadow: 0 4px 36px rgba(0,0,0,.18);
    background: #f8fafc;
}
.gallery-modal-close {
    position: absolute;
    top: 38px;
    right: 44px;
    font-size: 2.4rem;
    color: #fff;
    font-weight: bold;
    cursor: pointer;
    transition: color .12s;
    z-index: 1;
    line-height: 1;
}
.gallery-modal-close:hover { color: #e94646; }
@media (max-width: 700px) {
    .gallery-modal-close { top: 14px; right: 16px; font-size: 2rem; }
}
.contacts-page { background: #fff; }
.contacts-head { padding: 42px 0 18px 0; background: #f7f7fb; text-align: center; }
.contacts-head h1 { font-size: 2rem; color: #3959ab; font-weight: 700; margin-bottom: 10px; }
.contacts-head p { color: #273d70; font-size: 1.09rem; }

.contacts-main { padding: 28px 0 12px 0; background: #fff; }
.contacts-flex {
    display: flex;
    gap: 44px;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
}
.contacts-info {
    min-width: 260px;
    max-width: 340px;
    flex: 1 1 260px;
}
.contacts-list {
    list-style: none;
    margin: 0 0 22px 0;
    padding: 0;
}
.contacts-list li {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: 1.06rem;
    margin-bottom: 17px;
    background: #f7f9fd;
    border-radius: 10px;
    padding: 10px 15px;
    box-shadow: 0 1px 8px rgba(38,57,129,.05);
}
.contacts-list img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    flex-shrink: 0;
}
.contacts-list a {
    color: #3959ab;
    font-weight: 600;
    text-decoration: underline;
    transition: color .12s;
}
.contacts-list a:hover { color: #273d70; }
.cont-desc {
    color: #858da9;
    font-size: .98rem;
    margin-left: 9px;
}

.contacts-work {
    margin-top: 10px;
    font-size: 1.04rem;
    color: #23375f;
}
.contacts-form-block {
    background: #f7f9fd;
    border-radius: 14px;
    box-shadow: 0 1px 8px rgba(38,57,129,.04);
    padding: 18px 22px 20px 22px;
    min-width: 270px;
    flex: 1 1 320px;
    max-width: 460px;
}
.contacts-form-block h2 {
    font-size: 1.11rem;
    color: #3959ab;
    margin-bottom: 13px;
    font-weight: 600;
}
.contacts-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.contacts-form input, .contacts-form textarea {
    padding: 12px;
    border: 1px solid #d7dce7;
    border-radius: 12px;
    font-size: 1rem;
    background: #fff;
    transition: border-color .16s;
}
.contacts-form input:focus, .contacts-form textarea:focus {
    border-color: #3959ab;
    outline: none;
}
.contacts-form textarea {
    min-height: 56px;
    resize: vertical;
}
.contacts-form button {
    margin-top: 6px;
}
.form-success {
    color: #30a86a;
    margin-top: 8px;
    font-size: 1.03rem;
}

.contacts-map-block { background: #f1f4f9; padding: 35px 0 23px 0; }
.contacts-map-block h2 {
    font-size: 1.18rem;
    color: #3959ab;
    font-weight: 600;
    margin-bottom: 12px;
}
.contacts-map {
    width: 100%;
    height: 230px;
    border-radius: 16px;
    box-shadow: 0 2px 14px rgba(38,57,129,.07);
    background: #e5e5e5;
}

.contacts-faq {
    background: #fff;
    padding: 35px 0 30px 0;
}
.contacts-faq h2 {
    font-size: 1.08rem;
    color: #3959ab;
    margin-bottom: 13px;
    font-weight: 600;
}
.faq-list { max-width: 680px; margin: 0 auto; }
.faq-item { margin-bottom: 12px; }
.faq-question {
    background: #3959ab;
    color: #fff;
    border: none;
    padding: 12px 17px;
    border-radius: 1rem;
    width: 100%;
    text-align: left;
    cursor: pointer;
    font-size: 1rem;
    font-weight: 500;
    transition: background .13s;
    box-shadow: 0 1px 5px rgba(38,57,129,.03);
}
.faq-question.open { background: #23375f; }
.faq-answer {
    display: none;
    padding: 12px 18px 12px 21px;
    background: #f6f8fc;
    border-radius: 0 0 1rem 1rem;
    font-size: .98rem;
    color: #273d70;
}

/* Адаптив */
@media (max-width: 900px) {
    .contacts-flex {
        flex-direction: column;
        gap: 18px;
    }
    .contacts-info,
    .contacts-form-block {
        max-width: 100%;
        min-width: unset;
    }
}
@media (max-width: 600px) {
    .contacts-map { height: 140px; }
    .contacts-head h1 { font-size: 1.22rem; }
    .faq-question { font-size: .99rem; padding: 10px 10px; }
}
