html,
body{
height:100%;
}

body{
min-height:100vh;
display:flex;
flex-direction:column;
}

.contactpage{
flex:1 0 auto;
background:#fff;
}

.site-footer{
margin-top:auto;
}

.contactpage__inner{
max-width:var(--container);
margin:0 auto;
padding:0 24px;
}

.contactpage__top{
padding:25px 0 18px;
}

.contactpage__crumbs{
font-size:12px;
color:rgba(0,0,0,.45);
display:flex;
gap:8px;
align-items:center;
margin:0 0 10px;
}

.contactpage__crumbs a{
color:inherit;
text-decoration:none;
transition:color .25s var(--ease);
}

.contactpage__crumbs a:hover{
color:rgba(139,30,63,.72);
}

.contactpage__h1{
margin:0 0 6px;
font-size:18px;
line-height:1.4;
font-weight:600;
color:rgba(0,0,0,.86);
}

.contactpage__lead{
margin:0;
font-size:13px;
color:rgba(0,0,0,.55);
line-height:1.45;
}

.contactpage__content{
padding:8px 0 110px;
}

.contactpage__layout{
display:grid;
grid-template-columns:minmax(280px, 1fr) minmax(420px, 620px);
gap:80px;
align-items:start;
}

.contactpage__left{
max-width:100%;
}

.contactpage__right{
width:100%;
}

.contactpage__block + .contactpage__block{
margin-top:28px;
}

.contactpage__block a{
  color: #8B1E3F;
  text-decoration: none;
  transition: color .25s ease;
}

.contactpage__block a:hover {
  color: #555;
}

/* FORM */

.contactform{
display:flex;
flex-direction:column;
gap:14px;
max-width:none;
width:100%;
}

.contactform input::placeholder,
.contactform textarea::placeholder,
.contactform select{
color:rgba(0,0,0,.45);
}

.contactform input,
.contactform select,
.contactform textarea{
width:100%;
padding:10px 12px;
font-size:13px;
border:1px solid rgba(0,0,0,.1);
background:#fff;
transition:border .2s ease, box-shadow .2s ease;
}

.contactform input:focus,
.contactform select:focus,
.contactform textarea:focus{
outline:none;
border-color:rgba(139,30,63,.6);
box-shadow:0 0 0 2px rgba(139,30,63,.08);
}

.contactform input::placeholder,
.contactform textarea::placeholder{
color:rgba(0,0,0,.45);
}

.contactform textarea{
min-height:110px;
resize:vertical;
font-family:inherit;
}

.checkbox{
display:flex;
align-items:flex-start;
gap:10px;
font-size:13px;
color:rgba(0,0,0,.6);
line-height:1.45;
}

.checkbox input{
width:auto;
margin:3px 0 0;
flex:0 0 auto;
accent-color:#8b1e3f;
}

.checkbox span{
display:block;
}

/* BUTTON */

.contactform__submit{
position: relative;
display: inline-block;
align-self: center;
margin: 10px auto 0 auto;
padding: 2px 0;
border: 0;
background: none;
color: var(--accent);
font-size: 16px;
font-weight: 500;
line-height: 1.5;
overflow: hidden;
cursor: pointer;
}

.contactform__submit span{
display: block;
transition: transform .5s cubic-bezier(0.68,-0.55,0.265,1.55);
}

.contactform__submit::after{
content: attr(data-hover);
position: absolute;
left: 0;
right: 0;
top: 100%;
white-space: nowrap;
text-align: left;
transition: top .5s cubic-bezier(0.68,-0.55,0.265,1.55);
}

.contactform__submit:hover span{
transform: translateY(-100%);
}

.contactform__submit:hover::after{
top: 0;
}

/* EMAIL BLOCK */

.contactpage__block p{
font-size:14px;
color:rgba(0,0,0,.65);
line-height:1.5;
}

.contactpage__block strong{
color:rgba(0,0,0,.85);
}

.orderform{
  max-width:none;
}

#orderTemplateDisplay{
  background: rgba(0,0,0,.03);
  color: rgba(0,0,0,.7);
  cursor: default;
}

/* MOBILE */

@media (max-width: 900px){

.contactpage__layout{
grid-template-columns:1fr;
gap:28px;
}

.contactpage__left,
.contactpage__right{
max-width:none;
}

}

@media (max-width: 599px){

.contactpage__top{
padding:22px 0 14px;
}

.contactpage__h1{
font-size:17px;
}

.contactpage__content{
padding:8px 0 70px;
}

.contactform{
gap:12px;
}

.contactform input,
.contactform select,
.contactform textarea{
font-size:13px;
}

}

.form-popup {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}

.form-popup.is-open {
  display: block;
}

.form-popup__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
}

.form-popup__box {
  position: relative;
  max-width: 480px;
  width: calc(100% - 32px);
  margin: 120px auto 0;
  background: #fff;
  padding: 32px 24px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18);
  z-index: 1;
  text-align: center;
}

.form-popup__close {
  position: absolute;
  top: 12px;
  right: 12px;
  border: 0;
  background: transparent;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}

.form-popup__title {
  margin: 0 0 12px;
  font-weight: 600;
}

.form-popup__text {
  margin: 0;
}