:root {
    --house-primary: #234a6b;        /* кнопки */
    --house-primary-hover: #1c3c57;

    --house-accent: #2f8f5b;         /* зелёный акцент */
    --house-text: #212529;
    --house-muted: #6c757d;
    --house-border: #e9ecef;
}

.btn-house {
    background: #2d5578;
    border: 0;
    color: #fff;
    transition: .2s;
}

.btn-house:hover {
    background: #234a6b;
    color: #fff;
}

.btn-phone {
    padding: 10px 22px;
    min-height: 44px;
    border-radius: 10px;
    font-size: .95rem;
    font-weight: 600;
}

.house-card {
    padding: 0.75rem 1rem;
}

.master-card .card-body {
    padding: 0.75rem 1rem;
}

.master-name {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 0.35rem;
}

.master-description {
    font-size: 0.95rem;
    color: #6c757d;
    margin-bottom: 0.75rem;
}


.category-section {
    margin-bottom: 3rem;
}

.category-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #212529;
    border-bottom: 2px solid #2f8f5b;
    display: inline-block;
    padding-bottom: 0.25rem;
}

.house-logo {
    width: 80px;
    height: 80px;
    object-fit: contain;
}

.house-header-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--house-text);
    line-height: 1.2;
}

.house-header-subtitle {
    font-size: 1.05rem;
    color: var(--house-muted);
}

.house-address {
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.25;
    margin-bottom: .35rem;
}

.house-city {
    font-size: 1rem;
    color: var(--house-muted);
}

.home-page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    padding: 24px;
    text-align: center;
}

.home-logo {
    width: min(440px, 80vw);
    height: auto;
    margin-bottom: 24px;
}

.home-title {
    font-size: clamp(1.35rem, 6vw, 1.8rem);
    font-weight: 700;
    line-height: 1.25;
    color: #212529;
}

.home-title-muted {
    color: var(--house-muted);
    font-size: clamp(1.25rem, 5.5vw, 1.7rem);
    font-weight: 400;
}

.success-icon {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: #2f8f5b;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    font-weight: 700;
}
