.page-service {
    --page-blue: rgb(0 143 255);
    --page-blue-dark: #075f9d;
    --page-ink: #162033;
    --page-soft: #f4f8fc;
    color: var(--page-ink);
}

.page-service-hero {
    background: linear-gradient(135deg, var(--page-blue-dark), var(--page-blue));
    color: #fff;
    padding: 3rem 0;
}

.page-kicker {
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: 0.75rem;
    text-transform: uppercase;
}

.page-service h1 {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.15;
    margin-bottom: 1rem;
}

.page-lead {
    font-size: 1.05rem;
    line-height: 1.8;
    margin-bottom: 1.5rem;
}

.page-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.page-actions .btn {
    border-radius: 4px;
    font-weight: 700;
    min-height: 44px;
    padding: 0.65rem 1rem;
}

.page-hero-image,
.contact-main-image {
    border: 6px solid rgb(255 255 255 / 22%);
    box-shadow: 0 18px 45px rgb(0 0 0 / 18%);
    width: 100%;
}

.page-hero-image {
    aspect-ratio: 16 / 10;
    background-position: center;
    background-size: cover;
    min-height: 280px;
}

.contact-main-image {
    display: block;
    height: auto;
    object-fit: cover;
}

.page-shortcuts {
    padding-top: 2rem;
}

.page-shortcuts a {
    color: #000;
    font-weight: 700;
    text-decoration: none;
}

.page-shortcuts img {
    height: 72px;
    margin: 0 auto 0.75rem;
    object-fit: contain;
    width: 72px;
}

.page-content-wrap,
.contact-grid,
.contact-info {
    padding-bottom: 2.5rem;
    padding-top: 1.5rem;
}

.page-content,
.page-side-panel,
.info-panel {
    background: #fff;
    border: 1px solid #dbe8f5;
    border-radius: 6px;
    box-shadow: 0 10px 28px rgb(22 32 51 / 8%);
    height: 100%;
    padding: 1.5rem;
}

.page-content {
    font-size: 1rem;
    line-height: 1.8;
}

.page-content img,
.page-gallery img {
    height: auto;
    max-width: 100%;
}

.page-content table {
    width: 100% !important;
}

.page-side-panel {
    background: var(--page-soft);
}

.page-side-panel h2,
.info-panel h2 {
    font-size: 1.35rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.page-side-panel ul {
    line-height: 1.9;
    margin-bottom: 1.5rem;
    padding-left: 1.25rem;
}

.panel-link {
    background: var(--page-blue);
    border-radius: 4px;
    color: #fff;
    display: inline-flex;
    font-weight: 700;
    min-height: 44px;
    padding: 0.7rem 1rem;
    text-decoration: none;
}

.page-gallery img {
    aspect-ratio: 4 / 3;
    border-radius: 4px;
    object-fit: cover;
    width: 100%;
}

.contact-card {
    align-items: center;
    background: #fff;
    border: 1px solid #dbe8f5;
    border-radius: 6px;
    box-shadow: 0 10px 28px rgb(22 32 51 / 8%);
    color: var(--page-ink);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    height: 100%;
    justify-content: center;
    min-height: 210px;
    padding: 1.5rem;
    text-align: center;
    text-decoration: none;
}

.contact-card:hover {
    color: var(--page-blue-dark);
}

.contact-card img {
    height: 84px;
    object-fit: contain;
    width: 84px;
}

.contact-icon {
    color: #dc3545;
    font-size: 84px;
    line-height: 1;
}

.contact-card strong {
    font-size: 1.2rem;
}

.info-list {
    display: grid;
    gap: 1rem;
}

.info-list div {
    border-top: 1px solid #e2edf7;
    padding-top: 1rem;
}

.info-list strong,
.info-list span {
    display: block;
}

.info-panel-dark {
    background: var(--page-blue-dark);
    border-color: var(--page-blue-dark);
    color: #fff;
}

@media (max-width: 767.98px) {
    .page-service-hero {
        padding: 2rem 0;
    }

    .page-service h1 {
        font-size: 2rem;
    }

    .page-actions {
        display: grid;
    }
}
