
.contacts { padding: 40px 16px 72px; }


.contacts__title{
    font: 600 32px/1.2 var(--font);
    text-transform: uppercase;
    margin: 70px auto 70px;
    text-align: center;
}


.contacts__top{
    display: flex;
    /* grid-template-columns: 1fr auto auto; */
    gap: 24px;
    align-items: start;
    margin-bottom: 18px;
    color: var(--blue);
    flex-direction: row;
    flex-wrap: wrap;
}
.contacts__item{
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 10px 12px;
    border-radius: var(--radius-lg);
}
.contacts__item-title{ font: 600 18px/1.2 var(--font); color: var(--black); }
.contacts__item-sub{ font: 400 14px/1.16 var(--font); color: var(--red); }


.icon{ width: 22px; height: 22px; flex: 0 0 22px; display: inline-block; }
.icon.pin   { background: url('../images/location.svg') center/contain no-repeat; }
.icon.phone { background: url('../images/phone.svg')   center/contain no-repeat; }
.icon.mail  { background: url('../images/email.svg')   center/contain no-repeat; }


.contacts__grid{
    display: grid;
    grid-template-columns: auto 400px;
    gap: 40px;
    align-items: stretch;
}


.contacts__map{ overflow: hidden; min-height: 380px; }
.contacts__map .map-wrapper{
    border-radius: 40px;
    position: relative;
    overflow: hidden;
    display: block;
}
.contacts__map iframe{ border: 0; width: 100%; height: 100%; min-height: 380px; }


.contacts__form{
    background: var(--grey-soft);
    border-radius: var(--radius-xl);
    padding: 24px;
    color: var(--black);
}
.contacts__form-title{
    font: 600 24px/1.2 var(--font);
    text-transform: uppercase;
    margin: 0 0 6px;
}
.contacts__form-sub{font: 500 16px/1.2 var(--font);margin: 20px 0 14px 0;}


.field{ display: block; margin-bottom: 12px; }
.field input,
.field textarea{
    width: calc(100% - 24px);
    border: none;
    border-radius: 16px;
    background: #fff;
    padding: 14px;
    font: 400 14px/1.4 var(--font);
    color: var(--black);
    outline: none;
    transition: box-shadow .2s;
}
.field textarea{ resize: vertical; }
.field input::placeholder,
.field textarea::placeholder{ color: var(--black); opacity: .4; }
.field input:focus,
.field textarea:focus{
    box-shadow: 0 0 0 3px rgba(176,53,53,.12);
}


.agree{
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 6px 0 16px;
    font: 400 14px/1.4 var(--font);
    color: #444;
}
.agree input[type="checkbox"]{
    appearance: none;
    -webkit-appearance: none;
    width: 24px;
    min-width: 24px;
    height: 24px;
    margin-top: 3px;
    border-radius: 6px;
    background: #fff;
    box-shadow: inset 0 0 0 1px #e5e2db;
    cursor: pointer;
    transition: box-shadow .2s, background-color .2s;
}
.agree input[type="checkbox"]:focus-visible{
    box-shadow: 0 0 0 3px rgba(176,53,53,.16), inset 0 0 0 1px #e5e2db;
}
.agree input[type="checkbox"]:checked{
    background:
            url('../images/check-mark-red.svg')
            center/14px no-repeat #fff;
    box-shadow: inset 0 0 0 1px #e5e2db;
}
.agree a{
    font: 700 14px/1.4 var(--font);
    color: var(--red-soft);
    text-decoration: underline;
}



@media (max-width: 992px){
    .contacts__grid{ grid-template-columns: 1fr; }
    .contacts__map{ min-height: 320px; }
}
@media (max-width: 720px){
    .contacts__top{ grid-template-columns: 1fr; }
}
