:root {
    --color-main-bg: #F5F6FA;
    --color-frame-bg: #E6E9F3;
    --color-section-bg: #FFFFFF;
    --color-primary: #3F567A;
    --color-primary-over: #FFF;
    --color-secondary: #F5F6FA;
    --color-text-primary: #8598AD;
    --color-tertiary: #cd4f4f;
    --color-disabled: #ddd;
    --size-text-default: 14px;
    --size-text-3L: 25px;
    --size-text-LL: 20px;
    --size-text-L: 16px;
    --size-text-S: 12px;
    --size-text-SS: 10px;
    --size-text-icon: 14px;
    --content-min-witdh: 1000px;
    --sidemenu-witdh: 240px;
}

html {
    background-color: var(--color-frame-bg);
}

body {
    font-family: 'Zen Kaku Gothic New', sans-serif;
    padding: 0;
    font-size: var(--size-text-L);
    color: var(--color-text-primary);
}

.envAlert {
    display: block;
    background-color: var(--color-tertiary);
    position: fixed;
    top:0;
    left:50%;
    transform: translateX(-50%);
    z-index: 1000;
    color:#fff;
    padding:0.6em 4em 0.7em;
    border-radius: 0 0 10px 10px;
    text-align: center;
    font-size: var(--size-text-M);
}

.estimateLoader {
    position: absolute;
    display: block;
    border-radius: 100px;
    text-align: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 30px;
    height: 30px;
}

input[type="file"] {
    width:100%;
}


input,
textarea {
    background-color: var(--color-secondary);
    border-radius: 20px;
    font-size: var(--size-text-L);
    color: var(--color-primary);
    padding: 0.6em 0.6em 0.6em 1em;
    margin: 0 0 2px;
    
}

select {
    background-color: var(--color-secondary);
    border-radius: 20px;
    font-size: var(--size-text-L);
    color: var(--color-primary);
    padding: 0.6em 0 0.6em 1em;
    margin: 0 0 2px;
    
}


.bottomMargin {
    margin-bottom:50px !important;
}

textarea {
    width:100%;
}

select {
    padding-right: 35px;
    width:100%;
}
.input_select {
    position: relative;
}
.input_select:after {
    content: "";
    position: absolute;
    right: 15px;
    top:50%;
    width: 10px;
    height: 10px;
    border-top: 2px solid var(--color-primary);;
    border-left: 2px solid var(--color-primary);
    transform: translateY(-100%) rotate(-135deg);
  font-size: 20px;
  pointer-events: none;
}

input[type="number"] {
    width: 120px;
}

input[type="radio"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin-top: -0.75em;
    margin-right: 0.5em;
    padding: 0.5em;
    position: absolute;
    left: 10px;
    top: 50%;
    border: 0.25em solid var(--color-primary-over);
    border-radius: 50%;
    background-color: var(--color-primary-over);
    transition: 0.2s all linear;
}

label.disabled {
    color:#aaa;
    background-color: var(--color-disabled);
    opacity: 0.8;
}

label.disabled input[type="radio"]:disabled,
label.disabled input[type="checkbox"]:disabled 
{
   opacity: 0.5;
}




input[type='checkbox'] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin-top: -0.75em;
    margin-right: 0.5em;
    padding: 0.5em;
    position: absolute;
    left: 10px;
    top: 50%;
    border: 0.25em solid var(--color-primary-over);
    border-radius: 50%;
    transition: 0.2s all linear;
}

input[type='checkbox']:checked {
    border: 0.25em solid var(--color-primary-over);
    background-color: var(--color-primary);
}

input[type="number"]::placeholder {
    color: var(--color-text-primary);
}



input[type="radio"]:checked,
input[type='checkbox']:checked,
.radio_w input[type="radio"]:checked {
    border: 0.25em solid var(--color-primary-over);
    background-color: var(--color-primary);
}

label {
    color: var(--color-primary);
    background-color: var(--color-secondary);
    margin-bottom: 2px;
    margin-right: 10px;
    padding: 0.6em 1em;
    padding-left: 2.5em;
    display: inline-block;
    border-radius: 100px;
    position: relative;
    min-width: 120px;
    vertical-align: top;
}

label.noStyle {
    background-color:inherit;
    padding:0 0 0 35px;
    width: 100%;
}

.labelStyle01 {
    border-radius:100px;
    border: var(--color-primary) 1px solid;
    font-size:var(--size-text-S);
    padding:0 0.3em;
    margin-right:0.3em;
    letter-spacing: -0.1em;
    line-height: 1.0;
    white-space: nowrap;
}

dd {
    flex-wrap: wrap;
    align-items: center;
}

dd label {
    color: var(--color-primary);
    width: calc(33.3% - 1em);
    padding-right: 2em;
}

.align-items-baseline {
    align-items: baseline;
}

a b,
button b {
    padding: 0 0.2em;
}

a b::before,
button b::before {
    content: '';
    padding-right: 0.1em;
}

a b::after,
button b::after {
    content: '';
    padding-left: 0.1em;
}

a.disabled {
    opacity: 0.2;
    cursor:default;
    pointer-events: none;
}


.w100{
    width:100%;
}


.fm-err {
    width: 100%;
    display: block;
    background-color:#cd4f4f;
    color:#fff;
    border-radius: 100px;
    margin-bottom: 1px;
    position: relative;
    padding:0.05em 0 0.1em 0.8em; 

}

.fm-err p {
    margin:0.3em 1em !important;
    font-size: var(--size-text-S);
    padding-left:1em;
    text-align: left !important;

}

.fm-err::before {
    content:url('/common/img/icon_alert.svg');
    padding-right:0.5em;
    position: absolute;
    top:50%;
    left:12px;
    transform: translateY(-50%);

}


.fm-err2 {
    width: 100%;
    display: block;
    background-color:var(--color-primary);
    color:#fff;
    border-radius: 100px;
    margin-bottom: 0.5em;
     margin-bottom: 0.5em;
   position: relative;
    padding:0.05em 0 0.1em 0.8em; 

}

.fm-err2 p {
    margin:0.3em 1em !important;
    font-size: var(--size-text-M);
    padding-left:1em;
    text-align: left !important;

}
.fm-err2 p a {
    text-decoration: underline;
}
.fm-err2::before {
    content:url('/common/img/icon_alert.svg');
    padding-right:0.5em;
    position: absolute;
    top:50%;
    left:12px;
    transform: translateY(-50%);

}

.btnStyleA {
    background-color: var(--color-primary);
    color: var(--color-primary-over);
    padding: 0.6em 2em 0.6em;
    border-radius: 100px;
    min-width: 140px;
    min-height: 40px;
    text-align: center;
    font-size: var(--size-text-default);
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    
}

.btnStyleB {
    display: flex;
    background-color: var(--color-primary-over);
    color: var(--color-primary);
    padding: 0.6em 1em 0.6em;
    border: 1px solid var(--color-primary);
    border-radius: 100px;
    min-width: 100px;
    text-align: center;
    font-size: var(--size-text-default);
    min-height: 40px;
    align-items: center;
    justify-content: center;
    cursor: pointer;

}

.btnStyleC {
    display: inline-block;
    background-color: var(--color-primary);
    color: var(--color-primary-over);
    padding: 1em 1em 1em;
    border-radius: 100px;
    min-width: 140px;
    text-align: center;
    font-size: var(--size-text-default);
    max-width: 300px;
    margin: 0 auto;
    cursor: pointer;

}

.btnStyleD {
    display: inline-flex ;
    background-color: var(--color-tertiary);
    color: var(--color-primary-over);
    padding: 0.6em 2em 0.6em;
    border-radius: 10px;
    min-width: 140px;
    text-align: center;
    font-size: var(--size-text-default);
    align-items: center;
    justify-content: center;
    min-height: 50px;
    border-right: 3px solid #921e1e ;
    border-bottom: 3px solid #921e1e ;
    cursor: pointer;
    position: relative; 
    cursor: pointer;

}



.btnStyleMini {
    font-size:var(--size-text-S) !important;
    line-height: 1.2;
    margin-top:0.3em;
    padding:0.1em;
}

.btnStyleText {
    display: inline-block;
    min-height: auto;
    font-size:var(--size-text-S) !important;
    line-height: 1.0;
    padding: 0.3em 2em 0.3em;
}

.titleStyleA {
    border:1px var(--color-primary) solid;
    padding:0.3em 1em;
    display: block;
    text-align: center;
    color:var(--color-primary);
    font-size:var(--size-text-default);

}

.btn-hint {
    font-size:var(--size-text);
    pointer-events: none;
    min-height: 50px;
    text-align: left;
    padding: 0.5em 1em;
    min-width:400px;
    color:var(--color-primary);
    position:absolute;
    display: inline-flex ;
    left:calc(100% + 20px );
    background-color: var(--color-main-bg);
    border: 1px solid var(--color-frame-bg);

    align-items: center;
    justify-content: left;
    border-radius: 5px;
}
.btn-hint::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -24px;
    margin-top: -12px;
    border: 12px solid transparent;
    border-right: 12px solid var(--color-main-bg);
    z-index: 2;
    
}

.btn-hint::after {
  content: "";
  position: absolute;
  top: 50%;
  left: -28px;
  margin-top: -14px;
  border: 14px solid transparent;
  border-right: 14px solid var(--color-frame-bg);
  z-index: 1;
    
}




.btnStyleA.icon,
.btnStyleB.icon,
.btnStyleC.icon,
.btnStyleD.icon
{
    justify-content: center;
}

.hr {
    border-top: 1px solid var(--color-text-primary);
    border-bottom: 1px solid var(--color-text-primary);
    margin-top: 30px;
    margin-bottom: 50px;
    position: relative;
}

.hr::before {
    content: "";
    position: absolute;
    top: -24px;
    left: 50%;
    margin-left: -15px;
    border: 12px solid transparent;
    border-bottom: 12px solid #FFF;
    z-index: 2;
}

.hr::after {
    content: "";
    position: absolute;
    top: -28px;
    left: 50%;
    margin-left: -17px;
    border: 14px solid transparent;
    border-bottom: 14px solid var(--color-text-primary);
    z-index: 1;
}

.icon {
    display: flex;
    justify-content: left;
    align-items: center;
}

.icon::before {
    width: 30px;
    height: auto;
    padding-right: 10px;
    display: inline-block;
    vertical-align: middle;
    text-align: center;
    line-height: 1.0;
}

.icon-calculator::before {      content: url('../img/icon_calculator.svg'); }
.icon-calculator.active::before {   content: url('../img/icon_calculator_w.svg');   }

.icon-home::before {        content: url('../img/icon_home.svg');   }
.icon-home.active::before { content: url('../img/icon_home_w.svg'); }

.icon-list::before {        content: url('../img/icon_list.svg');   }
.icon-list.active::before { content: url('../img/icon_list_w.svg');}


.icon-chart::before {        content: url('../img/icon_chart.svg');   }
.icon-chart.active::before { content: url('../img/icon_chart_w.svg'); }


.icon-truck::before {       content: url('../img/icon_truck.svg');}
.icon-truck.active::before {    content: url('../img/icon_truck_w.svg');}

.icon-person::before {    content: url('../img/icon_person.svg');}
.icon-person.active::before {    content: url('../img/icon_person_w.svg');}

.icon-product::before {    content: url('../img/icon_product.svg');}
.icon-product.active::before {    content: url('../img/icon_product_w.svg');}

.icon-datalist::before {    content: url('../img/icon_datalist.svg');}
.icon-datalist.active::before {    content: url('../img/icon_datalist_w.svg');}

.icon-order::before {    content: url('../img/icon_order.svg');}
.icon-order.active::before {    content: url('../img/icon_order_w.svg');}

.icon-building::before {    content: url('../img/icon_building.svg');}
.icon-building.active::before {    content: url('../img/icon_building_w.svg');}

.icon-contact::before {    content: url('../img/icon_mailsend.svg');}
.icon-contact.active::before {    content: url('../img/icon_mailsend_w.svg');}

.icon-cart::before {    content: url('../img/icon_cart.svg');}
.icon-cart.active::before {    content: url('../img/icon_cart_w.svg');}

.icon-info::before {    content: url('../img/icon_info.svg');}
.icon-info.active::before {    content: url('../img/icon_info_w.svg');}

.icon-search::before {    content: url('../img/icon_search.svg');}
.icon-arrow::before {    content: "»";}
.icon-arrow_r::before {    content: "«";}

.icon-download::before {    content: url('../img/icon_download.png');}
.icon-speaker::before {    content: url('../img/icon_speaker.svg');}

.icon-inquiry::before {      content: url('../img/icon_inquiry.svg'); }
.icon-inquiry.active::before {   content: url('../img/icon_inquiry_w.svg');   }

.icon-login::before {      content: url('../img/icon_door.svg'); }
.icon-login.active::before {   content: url('../img/icon_door_w.svg');   }

.icon-log::before {      content: url('../img/icon_log.svg'); }
.icon-log.active::before {   content: url('../img/icon_log_w.svg');   }


nav {
    position: fixed;
    width: 250px;
    background-color: var(--color-section-bg);
    border-radius: 0 0 10px 0;
    padding: 30px 30px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.05);
    z-index: 9;
    overflow-y: auto;
    overflow-x:hidden;
    max-height:100vh;
}

nav input,
nav .menu-btn {
    display: none;
}

nav h3 {
    display: block;
    margin: 0 auto;
    width: 100px;
    height: auto;
    text-align: center;
}

nav h3 img {
    width: 100%;
}

nav .nav_btn {
    margin-top: 30px;
}

nav .nav_btn li a {
    display: block;
}

nav dl {
    margin: 30px 0 0;
}

nav dt {
    margin: 1.2em 0 0.5em;
    padding-bottom: 0.5em;
    color: var(--color-primary);
    border-bottom: 1px solid var(--color-main-bg);
    font-size: var(--size-text-L);
}

nav dd a {
    position: relative;
    display: block;
    padding: 0.5em 0 0.6em;
    color: var(--color-text-primary);
    font-size: var(--size-text-default);
}

nav dd a.active {
    background-color: var(--color-primary);
    color: var(--color-primary-over);
    margin-left: -10px;
    padding-left: 10PX;
    margin-right: -40px;
    border-radius: 5px 5px 0 5px;
}

nav dd a.active::after {
    position: absolute;
    right:0;
    bottom:-10px;
    content: "";
    border-top: 10px solid #09316F;
    border-right: 10px solid transparent;

}

.sp_header {
    display: none;
}

header {
    width: 100%;
    position: fixed;
    top: 0;
    right: 0px;
    min-width: calc(var(--content-min-witdh) - 60px);
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: calc(var(--sidemenu-witdh) + 50px);
    background-color: var(--color-section-bg);
    border-radius: 0 10px 0 0;
    /* padding: 15px 0 15px 30px; */
    display: flex;
    justify-content: space-between;
    align-items: center;
    /* width: 100%; */
    /* max-width: 1020px; */
    box-shadow: 0 0 10px rgb(0 0 0 / 5%);
    z-index: 8;
}

header .header_usrinfo a,
.sp_header .header_usrinfo a {
    display: flex;
    align-items: center;
}

header .header_usrinfo p,
.sp_header .header_usrinfo p {
    padding-left: 15px;
    padding-right: 30px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

header .header_usrinfo a::after,
.sp_header .header_usrinfo a::after {
    /*content: url(../img/icon_arrow_down.svg);*/
}

header .header_usrinfo p strong,
.sp_header .header_usrinfo p strong {
    font-size: var(--size-default);
    display: block;
    flex-basis: 100%;

}

header .header_usrinfo p small,
.sp_header .header_usrinfo p small {
    font-size: var(--size-text-S);
}

header img.avatar,
.sp_header img.avatar {
    width: 40px;
    height: 40px;
    border-radius: 100%;
    border: 1px solid var(--color-text-primary);
}

main {
    min-width: var(--content-min-witdh);
    margin-left: var(--sidemenu-witdh);
    border-radius: 0 0 10px 10px;
    /* width: 100%; */
    /* max-width: 1020px; */
    padding: 60px 80px 60px 55px ;
    background-color: var(--color-main-bg);
    /*box-shadow: 0 0 10px rgb(0 0 0 / 5%);*/
    padding-top: 100px;
    min-height: 300px;
}

main h1 {
    font-size: var(--size-text-LL);
    color: var(--color-primary);
}

main h2 {
    padding-top: 0.8em;
    font-size: var(--size-text-default);
    margin-bottom: 30px;
}

main .contentHead {
   display: flex;
   flex-wrap: nowrap;
   justify-content: space-between;
}

.content {
    background-color: var(--color-section-bg);
    border-radius: 10px;
    /* padding: 30px 40px 20px; */
    padding: 30px 45px 30px;
    margin-bottom: 30px;
}

.contentColumn {
    display: flex;
    flex-wrap: nowrap;
}


.contentColumn article {
    margin-right:30px;
}

.contentColumn article:last-child  {
    margin-right:0;
}

.contentLiquid {
    width:60%;

}

.contetnFix {
    width:40%;
}

.content.paddingSmall {
    padding:25px 45px 20px;
}

.content.tabContent{
    border-radius: 0 0 15px 15px;

}

.contentSmall {
    max-width: 500px;
    margin: 0 auto;
    padding: 40px 65px 20px;
    text-align: center;
    background-color: #fff;

}

h4 {
    background-color: var(--color-main-bg);
    padding: 0.7em 1.5em;
    border-left: 10px solid var(--color-primary);
    margin-bottom: 1em;
}

h5 {
   color:var(--color-primary);
   border-bottom: 1px solid var(--color-main-bg);
   padding:0.5em 0;
}

footer {
    display: block;
    font-style: oblique;
    color: var(--color-text-primary);
    text-align: center;
    padding: 50px 0;
}

.formStyle dl,
.formStyle1 dl {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 2em;
    align-items: flex-start;
}

.formStyle dl:last-child,
.formStyle1 dl:last-child {
    margin-bottom: 0;
}

.formStyle dl dt,
.formStyle1 dl dt {
    position: relative;
    text-align: right;
    margin: 5px 0;
    /*padding-top:0.5em;*/
    font-size: var(--size-text-default);
}

.form_dt dt {
    padding-top:0.5em;
}

.formStyle dl dt {
    width: 180px;
    padding-right: 60px;
    white-space: nowrap;
}

.formStyle1 dl dt {
    margin-right: var(--size-text-3L);
    white-space: nowrap;
}

.formStyle dl dd,
.formStyle1 dl dd {
    width: calc(100% - 180px);
    margin: 5px 0;
    color: var(--color-primary);
    display: flex;
    align-items: stretch;
    align-items: baseline;
}

dd.noform,
dd:empty {
    padding-top:0.4em;
    padding-left:1em;
} 

.formStyle dl dd label,
.formStyle1 dl dd label {
    display: flex;
    align-items: center;
}

.formStyle .input-name,
.formStyle1 .input-name {
    margin-top: 1em;
    position: relative;
}

.fixed-style {
    background-color: var(--color-section-bg);
    min-width: var(--content-min-witdh) + 20px;
    position: fixed;
    width: calc(100% - var(--sidemenu-witdh) - 60px);
    bottom: 0;
    right: 0;
    min-height: 100px;
    padding: 0;
    box-shadow: 0 0 3px 3px rgba(0, 0, 0, 0.05);
    border-left: 10px solid var(--color-primary);
    z-index: 11;
    transition: height 0.5s;
}

main.main-estimate {
    margin-bottom: 200px;
}

.estimateStyle {
    padding: 20px;
    position: relative;
}

.fixed-style h4 {
    padding: 1em 2em;
    border-left: none;
    background-color: #fff;
    color: var(--color-primary);
    margin-bottom: 0;
    border-bottom: 1px solid var(--color-frame-bg);
}

.estimateStyle dl {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 1em;
    align-items: baseline;
}

.estimateStyle dl dt {
    width: 150px;
    text-align: right;
    padding-right: 10px;
    position: relative;
    margin: 5px 0;
    font-size: var(--size-text-default);
}

.estimateStyle dl dd {
    width: calc(33.3% - 150px);
    color: var(--color-primary);
    font-size: var(--size-text-L);
}

.estimateStyle dl dd.sum {
    width: calc(33.3% - 150px);
    margin: 0px 0;
    color: var(--color-primary);
    font-size: var(--size-text-3L);
}

.estimateStyle .input-name {
    margin-top: 1em;
    position: relative;
}

.estimateStyle .btn_section {
    text-align: center;
}

.input-name .name {
    position: relative;
    display: inline-block;
    margin-right: 0em;
}

.input-name .name:nth-child(n+2) {
    margin-left: 2em;
}

dd .input-name:last-child span:last-child {
    display:none;
}

.input-name .name::before {
    content: attr(name);
    width: 100%;
    height: 2em;
    display: inline-block;
    font-size: var(--size-text-default);
    position: absolute;
    margin-top: -1.5em;
    text-align: center;
}

#form_estimate .input-size {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
}


#form_estimate .input_select {
    display: inline-block;
    position: relative 

}



.input-size .input-size-form input[type="text"] {
    width:100px;
}

.input-size .input-size-form .input-size-form-cont {
    display: block;
    margin-bottom:1em;
    white-space: nowrap;
}



.input-size .name::before {
    content: attr(name);
    display: inline-block;
    font-size: var(--size-text-default);
    text-align: center;
    width:70px;
}

.input-size .input-size-img {
    width:300px;

}

.input-size .input-size-img img {
    width:100%;
}


.input_icon_wrap {
    position: relative;
}
.input_icon_wrap::before {
    position: absolute;
    left:20px;
    top:50%;
    transform:translateY(-50%);
    z-index: 10;
}

.input_icon_wrap.icon_datepicker::before {  content:url(/common/img/icon_calendar.svg); }



input.datepicker {
    position: relative;
}
input.datepicker {
    padding-left:60px;
}
input.datepicker~span.datepicker_icon::before {
    position: absolute;
    content:url(/common/img/icon_calendar.svg);
    left:20px;
    top:50%;
    transform: translate(0,-50%);
}


.chart_step {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom:10px;
    color:var(--color-primary);
    width:99%;
    overflow-x: auto;
    overflow-y: hidden;
    padding:0 4px;


}
.chart_step img {
    width:100%;
}

.chart_step_group {
}

.chart_step dl {
    display: block;
    margin-bottom:0;
}

.chart_step_group:nth-of-type(1) {flex-grow:3;} 
.chart_step_group:nth-of-type(2) {flex-grow:2;}
.chart_step_group:nth-of-type(3) {flex-grow:1;}


.chart_step dl dt {
    background-color: var(--color-section-bg);
    display: block;
    border-radius: 5px;
    margin-bottom:5px;
    padding:0.4em 1em;
    filter: drop-shadow(0 0 3px rgba(0,0,0,0.1));
    margin-right:5px;
    white-space: nowrap;
    text-align: left;

}
.chart_step_group:last-child dt {
    margin-right:0;
}

.chart_step dl dd {
    display: block;
    width:auto;

}

.chart_step dl dd ol {
    display: flex;
    align-items: stretch;
    
}

.chart_step dl dd li  {
    filter: drop-shadow(0 0 3px rgba(0,0,0,0.1));
    flex-grow:1;
    display: block;
    background-color: var(--color-section-bg);
    width:calc( 100% - 40px );
    padding:7px 20px 7px 20px;
    border-radius: 5px;
    text-align: center;
    position: relative;
    /*clip-path: polygon(0 0, calc( 100% - 40px) 0, 100% 50%, calc( 100% - 40px) 100%, 0% 100%);*/
    min-width:120px;
    margin-right:40px;
    position: relative;
    border:2px solid var(--color-section-bg);

}

.chart_step dl dd li::after  {
    position: absolute;
    display: block;
    width:30px;
    right:-40px;
    margin:0 5px;
    top:0;
    content: '';
    background-image: url('/common/img/chart_step_mark1.svg');
    background-position: center center;
    background-repeat: no-repeat;
    height:100%;
    background-size: contain;

}

.chart_step dl dd li.mark2::after  { background-image: url('/common/img/chart_step_mark2.svg'); }
.chart_step dl dd li.mark3::after  { background-image: url('/common/img/chart_step_mark3.svg'); }


.chart_step dl dd li a {
 
}

.chart_step dl dd li.current  {
    background-color: var(--color-primary);
    color:#fff;
    border-color: #fff;
    /*filter: drop-shadow(0 0 3px 0 var(--color-primary));*/

}

/*
.chart_step_group:nth-of-type(1) dd li:nth-of-type(1)  {  z-index: 10;  }
.chart_step_group:nth-of-type(1) dd li:nth-of-type(2)  {  z-index: 9;  }
.chart_step_group:nth-of-type(1) dd li:nth-of-type(3)  {  z-index: 8;  }
.chart_step_group:nth-of-type(1) dd li:nth-of-type(4)  {  z-index: 7;  }
.chart_step_group:nth-of-type(2) dd li:nth-of-type(1)  {  z-index: 6;  }
.chart_step_group:nth-of-type(2) dd li:nth-of-type(2)  {  z-index: 5;  }
.chart_step_group:nth-of-type(2) dd li:nth-of-type(3)  {  z-index: 4;      }
*/
.chart_step_group:nth-of-type(1) dd li:first-child a  { 

}
.chart_step_group:nth-of-type(3) dd li:last-child  { 
    margin-right:0px;
}

.chart_step_group:nth-of-type(3) dd li:last-child::after  { 
    content:none;
}
.chart_step_group:nth-of-type(3) dd li:last-child a
{ 
    /*
    clip-path:none;
    padding-right:10px;
    */
}


.chart_step dl dd li a::before {

}

.chart_step dl dd li span {
    display: block;
    border-bottom: 1px solid rgba(0,0,0,0.07);
    font-size: var(--size-text-3L);
    padding-bottom:0.1em;

}

.chart_step dl dd li span::before {
    content:'step';
    font-size: var(--size-text-default);

}

.chart_step dl dd li strong {
    display: block;
    padding-top:0.4em;
    white-space:nowrap;
}


.chart_step dl dd li.styleB {
    min-height:90px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-main-bg);
}
.chart_step dl dd li.styleB a  {
    padding-right:0 !important;
}

.chart_step dl dd li.styleB span::before{
    content:none;
    
}



.chart_step.user_regist .chart_step_group:nth-of-type(1) {flex-grow:6;} 
.chart_step.user_regist .chart_step_group:nth-of-type(2) {flex-grow:2;}
.chart_step.user_regist .chart_step_group:nth-of-type(3) {flex-grow:1;}






.formStyle dt.hissu::after,
.formStyle1 dt.hissu::after {
    position: absolute;
    content: '必須';
    background-color: var(--color-primary);
    color: var(--color-primary-over);
    font-size: var(--size-text-S);
    padding: 0.2em 0;
    text-align: center;
    margin-left: 1em;
    width: 40px;
    /*top:8px;*/
}

.formStyle dd small,
.formStyle1 dd small {
    vertical-align: middle;
}

.formStyle .btn_section,
.formStyle1 .btn_section {
    display: flex;
    margin: 20px 0 0;
    padding-bottom: 0px;
    align-items: center !important;
}
/*
.formStyle .btn_section button,
.formStyle1 .btn_section button,
.formStyle .btn_section a,
.formStyle1 .btn_section a
*/
.btn_section button,
.btn_section button,
.btn_section a,
.btn_section a
{
    display: inline-flex !important;
    text-align: center;
    justify-content: center;
    min-width: 250px;
    margin-right:3px;

}

.btn_section.both_ends {
    display: flex;
    justify-content: space-between;
}

.user_info_r .formStyle .btn_section:first-of-type button {
    margin-bottom: 2em;
}

.formStyle .form_change,
.formStyle2 .form_change {
    display: none;
}

.content_caption {
    display: inline-block;
    border-radius: 100px;
    padding: 0.5em 0 1em 1em;
    margin-bottom:2em;
    font-size: var(--size-text-default);
    line-height: 1.4;;
}

.txtBig {
    font-size:1.5em !important;

}

.txtSmall {
    font-size:0.9em !important;

}

.colorGray{
    color:#999;
}

.textIcon{
    border:1px solid #ccc;
    font-size:0.8em;
    padding:0 0.2em;
    margin-right:0.2em;

}

.textIcon2{
    background-color: #ccc;
    color:#fff;
    font-size:0.8em;
    padding:0 0.2em;
    margin-right:0.2em;

}

.textHighlight{
    border-bottom: var(--color-tertiary) 1px solid;
    color:var(--color-tertiary);

}

.memo {
    display: block;
    width:100%;
    border-radius: 100px;
    padding: 0.5em 0 1em 1em;
    font-size: var(--size-text-default);
    margin-top:5px;

}

.notice,
.errArr
{
    border: 1px solid var(--color-text-primary);
    border-radius: 100px;
    padding: 0.3em 1em;
    font-size: var(--size-text-default);
}

.notice2
{
    border: 1px solid var(--color-text-primary);
    border-radius: 10px;
    padding: 0.4em 1em;
    font-size: var(--size-text-L);
    background-color: var(--color-primary);
    color:#fff;
    margin-bottom:1em;
}

.warning {
    border: 1px solid var(--color-main-bg);
    border-radius: 5px;
    padding: 0.5em 1em;
    font-size: var(--size-text-default);
    display: flex;
    align-items: center;
    margin-bottom:1em;
}

.warning img {
    padding-right:1em;
}


.errTxt {
    border-radius: 100px;
    padding: 0.3em 1em;
    font-size: var(--size-text-default);
    background-color: #EE0000;
    color: #fff;
    margin-bottom:1px;
}


.fm_width_s {
}


#estimate_box {
    position: fixed;
    right: -300px;
    top: 80px;
    width: 300px;
    background-color: var(--color-section-bg);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.05);
    border-radius: 0 0 0 0px;
    padding: 20px 0;
    min-height: 76px;
    z-index: 15;
    border-left: 3px solid var(--color-primary);
    transition: right 0.5s;
}

#estimate_box.active {
    right: 0;
}

#estimate_box h3 {
    display: block;
    color: var(--color-primary);
    text-align: center;
    padding-bottom: 1em;
    border-bottom: var(--color-secondary) 1px solid;
}

#estimate_box .btn_section {
    margin: 20px 10px;
    text-align: center;
}



#estimate_box ul {
    margin: 0;
    padding:0 20px;
    overflow-y: auto;
    overflow-x: hidden;
    max-height: calc(100vh - 300px);
}

#estimate_box li {
    padding: 0.8em 0;
    border-bottom: var(--color-secondary) 1px solid;
}

#estimate_box strong {
    padding: 0;
    color: var(--color-primary)
}

.estimate_box_item {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.estimate_box_item dl {
    display: flex;
    justify-content: flex-start;
    margin-top: 0.5em;
    align-items: flex-end;
}

.estimate_box_item dt {
    font-size: var(--size-text-S);
    min-width: 30px;
    white-space: nowrap;
}

.estimate_box_item dd {
    font-size: var(--size-text-default);
    padding-right: 5%;
    white-space: nowrap;
}

#estimate_box dd strong {
    white-space: nowrap;
    font-size: var(--size-text-LL);
}


.product_check input {
    /*
    border-radius: 5px;
    appearance:checkbox;
    */
    display: none;;
}

label .product_check .product_checkbox {
    position: absolute;
    top:0;
    left:-40px;
    background-color: var(--color-main-bg);
    width:30px;
    height:30px;
    border-radius: 5px;
    display: block;
    border:var(--color-primary) solid 1px;
}


label .product_check .product_checkbox::after {
    border-right: 4px solid var(--color-primary);
    border-bottom: 4px solid var(--color-primary);
    content: '';
    display: block;
    height: 20px;
    left: 11px;
    margin-top: -12px;
    opacity: 0;
    position: absolute;
    top: 50%;
    transform: rotate(45deg);
    width: 10px;
}

.product_check input[type=checkbox]:checked + .product_checkbox {
    border-color: #666;
}
.product_check input[type=checkbox]:checked + .product_checkbox::after {
    opacity:1;
}


/*
.product_check {
    background-color: var(--color-main-bg);

    box-sizing: border-box;
    cursor: pointer;
    display: inline-block;
    padding: 5px 30px;
    position: relative;
    width: auto;
}
.product_check::before {
    background: #fff;
    border: 1px solid #231815;
    content: '';
    display: block;
    height: 16px;
    left: 5px;
    margin-top: -8px;
    position: absolute;
    top: 50%;
    width: 16px;
}
.product_check::after {
    border-right: 3px solid #ed7a9c;
    border-bottom: 3px solid #ed7a9c;
    content: '';
    display: block;
    height: 9px;
    left: 10px;
    margin-top: -7px;
    opacity: 0;
    position: absolute;
    top: 50%;
    transform: rotate(45deg);
    width: 5px;
}
*/
input[type=checkbox]:checked + .product_check::after {
    opacity: 1;
}

.formStyle .input_table1 {
    
    width: 100%;
    
}
.formStyle .input_table1 tr {
    border-bottom:var(--color-secondary) 1px solid;

}
.formStyle .input_table1 td {
    vertical-align: middle;
    padding:0.4em 0 0.4em 0.5em;
}

.formStyle .input_table1 th {
    padding:0.4em 0 0.4em 0.5em;


}



#cart {
    position: absolute;
    left: -79px;
    top: 0;
    background-color: var(--color-primary);
    padding: 5px 15px;
    border-radius: 20px 0 0 20px;
    color: #fff;
    font-size: var(--size-text-S);
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease-in;
    z-index: 5001;

}

#cart span {
    font-size: var(--size-text-default);
    color: #fff;
    font-weight: bold;
    text-align: center;
    display: block;
    border-radius: 100px;
    width: 24px;
    height: 24px;
    position: absolute;
    top: 3px;
    right: 3px;
    border: 2px solid var(--color-primary);
    background-color: var(--color-tertiary);

}

#cart::before {
    content: '';
    background: url(/common/img/icon_box.svg) center center no-repeat;
    background-size: contain;
    display: block;
    width: 38px;
    height: 38px;
    margin: 0 auto;
}

.ball {
    background-color: var(--color-tertiary);
    height:30px;
    width:30px;
    border-radius: 100px;
    position: fixed;
}

#cart.is-active {
    transform:scale(1.4);
    background-color: var(--color-tertiary);
}

.product_list ul {
    margin-bottom: 30px;
}

.product_list li {
    display: flex;
    width: 100%;
    flex-wrap: nowrap;
    position: relative;
    /*padding: 0 0 20px 50px;*/
    padding: 0 0 20px 40px;
    margin-bottom: 20px;
    border-bottom: var(--color-frame-bg) 1px solid;
    align-items: center;
}

.product_list .number {
    position: absolute;
    left: 0;
    top: 3px;
    display: inline-block;
    text-align: center;
    line-height: 20px;
    font-size: var(--size-default);
    vertical-align: middle;
    background-color: var(--color-primary);
    color: #fff;
    border-radius: 3px;
    width: 20px;
    height: 20px;
    margin-right: 0.5em;
}

.product_list .product_list_head {
    color: var(--color-primary);
    font-size: var(--size-text-LL);
}

.product_list .product_list_table {
    flex-basis:100%;
}

.product_list dl {
    display: flex;
    align-items: baseline;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-bottom: 0;
    margin-top: 10px;
}

.product_list dl dt {
    width: 12%;
    margin: 0.5em 0;
    white-space: nowrap;
    display: flex;
    justify-content: flex-end;
    padding-right:15px;
    flex-grow: 1;
    font-size:var(--size-text-default);

}

.product_list dl dd {
    width: 18%;
    /*white-space: nowrap;*/
    align-items: flex-end;
    margin: 0.3em 0;
    flex-grow: 1;
    line-height: 1.3;

}

.product_list dl dd strong {
    font-size: var(--size-text-3L);
}


/* ==================追加分=================== */

.shadow {
    box-shadow: 0 0 10px rgb(0 0 0 / 5%);
}

.formStyle dl dd.selecter,
.formStyle1 dl dd.selecter {
    position: relative;
}

.text {
    margin: 3em 0;
}

.red {
    color: #9F2626DE;
}


/* =========login========= */

main.login {
    background: none;
    margin: 0 auto;
}

.login h1 {
    margin-bottom: 2em;
}

.login .content {
    max-width: 500px;
    margin: 0 auto;
    padding: 40px 65px;
    text-align: center;
}

h2.side_line {
    color: var(--color-primary);
    margin-bottom: 1.5em;
    position: relative;
    padding: 0 65px;
    text-align: center;
    font-size: var(--size-text-L);
    font-weight: bold;
}

h2.side_line:before {
    position: absolute;
    top: calc(50% - 1px);
    left: 0;
    width: 100%;
    height: 2px;
    content: '';
    background: var(--color-frame-bg);
}

h2.side_line span {
    position: relative;
    padding: 0 1em;
    background: var(--color-primary-over);
}

.login-form input {
    width: 100%;
    margin-bottom: 1em;
    text-align: left;
    padding: 0.8em 2em;
}

.login-form input.input_pass {
    margin-bottom: 0;
}

.login .formStyle .btn_section {
    margin: 1em 0;
}

.login .formStyle {
    margin-bottom: 50px;
}

.login a>span {
    text-decoration: underline #8598AD;
}

.icon-mail::before {
    content: url(../img/icon_mail.svg);
}

.icon-key::before {
    content: url(../img/icon_key.svg);
}

.input_wrapper {
    position: relative;
    /* width: 100px;
width: 50px; */
    cursor: pointer;
}

.input {
    display: block;
    width: 100%;
    /*height: 100%;*/
}

.input_placeholder,
.input_placeholder_pass {
    pointer-events: none;
    position: absolute;
    top: 0.75em;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    font-size: var(--size-text-default);
}

.input_placeholder img,
.input_placeholder_pass img {
    margin-right: 1em;
    margin-left: 1.5em;
}

.refined_search .input_placeholder {
    top: 0.5em;
}

.refined_search input[type="text"].calendar {
    width: 90%;
    display: inline-block;
}

.refined_search p {
    display: inline-block;
}


/* =========signup======== */

.icon_person::before {
    content: url(../img/icon_person.svg)
}

.signup_h3 {
    border-left: 10px solid var(--color-primary);
    padding-left: 2em;
    margin-bottom: 1.5em;
}

.signup h3 {
    color: var(--color-primary);
    font-size: var(--size-text-LL);
    font-weight: bold;
}

.signup_h3 p {
    font-size: var(--size-text-L);
    line-height: 1.5;
    margin-top: 1em;
}

span.br {
    display: block;
}

.signup .formStyle1 .btn_section {
    margin-top: 0;
    margin-bottom: var(--size-text-3L);
}

.signup .content {
    padding: 50px 40px 20px;
}

.signup .content:nth-child(3) input[type="text"] {
    width: 50%;
}

.signup .formStyle1 p {
    margin: 1em 0;
    line-height: 1.5;
}
input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
    color: #8598AD;
}
input:-moz-placeholder,
textarea:-moz-placeholder {
    color: #8598AD;
}
input::-moz-placeholder,
textarea::-moz-placeholder {
    color: #8598AD;
}
input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
    color: #8598AD;
}

input[type="text"],
input[type="email"],
input[type="password"] {
    width: 100%;
}

.radio_w input[type="radio"] {
    background-color: var(--color-secondary);
    border-color: var(--color-secondary);
}

.radio_w label {
    background-color: var(--color-primary-over);
    color: var(--color-primary);
}

.radio_short label {
    width: auto;
}

p.confirmation {
    color: var(--color-primary);
    margin-left: 15px;
}
/*
dt.hissu:nth-child(19),
dt.hissu:nth-child(21) {
    margin-top: 20px;
}

dt.hissu:nth-child(19)::after {
    margin-top: -22px;
}

dd:nth-child(20),
dd:nth-child(22) {
    position: relative;
}
*/
.user_info_r h3 {
    margin: 2em 0;
    line-height: 1.5;
}

.user_registration_completed h3 {
    margin-bottom: 2em;
    line-height: 3;
}

.small {
    font-size: smaller;
}

.space {
    margin-bottom: 55px;
}

.user_info_r dd {
    /*padding-right: 10%;*/
}

.user_info_confirmation h3 {
    margin-bottom: 2em;
    line-height: 1.5;
}


/* =========dashbord======== */

.dashbord-wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: left;
}

.col1,
.col2 {
    margin-bottom: 36px;
}

.col1 {
    flex-basis: 100%;
}

.col2 {
    flex-basis: 48%;
}

.col3 {
    flex-basis: 30%;
}

.col4 {
    flex-basis: 24%;
}

.content.col2 {
    margin-right: auto;
}

.content.col2:nth-child(2) {
    margin-right: 0;
}

.content.col3 {
    margin-right: 5%;
    padding-left: 29px;
    padding-right: 29px;
}

.content.col3:nth-child(6) {
    margin-right: 0;
}

.content.col4 {
    margin-right: 1.33%;
}

.content.col4:last-child {
    margin-right: 0;
}


.dashbord section {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.h3_style1 {
    font-size: var(--size-text-LL);
    font-weight: bold;
    color: var(--color-primary);
    flex-basis: 100%;
    padding:10px 0;
    /*margin-bottom:1em;*/
}

.status_l {
    flex-basis: 25%;
    text-align: right;
}

.status_r {
    flex-basis: 52%;
    margin-right: 5%;
}

.status_1 .status_l span,
.status_2 .status_l span {
    font-size: var(--size-text-3L);
    font-weight: bold;
}

.status_1 .status_r span,
.status_2 .status_r span {
    font-size: var(--size-text-LL);
    font-weight: bold;
}

.dashbord dd {
    color: var(--color-primary);
}

.dashbord .status_r dt,
.dashbord .status_r dd {
    display: inline-block;
    line-height: 1.5;
    text-align: right;
    width: 40%;
}

.dashbord .status_r dt {
    margin-right: 15%;
}

.dashbord .btn_section,
.refined_search+.btn_section {
    text-align: center;
    width: 100%;
}

.dashbord .btn_section button {
    font-size: var(--size-text-default);
    margin-bottom: 3px;

}

.listStyle1 a,
.listStyle2 li,
.listStyle2 .list_title {
    display: flex;
    align-items: center;
    width: 100%;
    height: 56px;
    border-bottom: 1px solid var(--color-frame-bg);
}

.listStyle1 ul {
    width: 100%;
    height: 280px;
    overflow: scroll;
    overflow-x: hidden;
}

.listStyle2 ul {
    height: auto;
}

.listStyle1 ul li:last-child a {
    border: none;
}

.listStyle1 time,
.listStyle2 time,
.list_title p:first-child,
.newsinfo .listStyle2 ul li:nth-child(n+2) p:first-child {
    min-width: 125px;
    margin-right: 35px;
}

.listStyle1 .news_title,
.listStyle2 .news_title {
    color: var(--color-primary);
    font-weight: bold;
}


.listStyle3 {
    margin:2em 0 1.5em;
    border:1px var(--color-text-primary) solid;
    border-radius: 5px;
    padding:1em 1em 0.5em;
    position: relative;
}

.listStyle3 strong {
    margin-top:-30px;
    /*position: absolute;*/
    display: inline-flex;
    align-items: center;
    background-color: #fff;
    padding:0 0.5em 0.5em;
    top:-0.7em;
}

.listStyle3 a {
    margin:1em 0 0;
    width:fit-content;
    
}

.listStyle3 strong img {
    padding-right:0.5em;
}


.listStyle3 li {
    padding-left:1em;
    margin:0.5em 0;
    text-indent: -1em;
    font-size:var(--size-text-default);
}

.listStyle3 li::before {
    content:'・';
}

.dashbord_inner {
    min-height: 150px;
}

.dashbord_inner p {
    line-height: 1.5;
}

.dashbord .contact .btn_section a,
.dashbord .manual .btn_section a,
.dashbord .terms .btn_section a {
    width: 100%;
    min-width: 100px;
}

.dashbord .btn_section span {
    font-size: smaller;
}

.user_info_confirmation h3,
.user_info_r h3 {
    margin-top: 0;
}

.icon-hint {
    border-radius: 100px;
    color: var(--color-primary);
    border: var(--color-primary) 1px solid;
    width: 19px;
    height: 19px;
    display: inline-block;
    position: relative;
    vertical-align: middle;
    margin-top: -0.3em;
    margin-left: 0.4em;
    cursor: help;
}

.icon-hint::after {
    position: absolute;
    content: '?';
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.ui-position-right {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translate(0, -5px);
}

.icon_login::before,
.icon_contact::before {
    content: url(../img/icon_login.svg);
    margin-right: 10px;
}

.icon_login::before {
    content: url(../img/icon_login.svg)
}

.icon_contact::before {
    content: url(../img/icon_contact.svg)
}

.refined_search_bar {
    width: 100%;
    display: flex;
    justify-content: space-between;
}

.refined_search {
    width: 100%;
}

.s_02 .box_one,
.s_03 .box_one {
    display: flex;
}

.s_02 .box_one .refined_search_l,
.s_02 .box_one .refined_search_r {
    flex-basis: 50%;
    padding-right: 3%;
}

.estimate_history .formStyle dl dt {
    width: 95px;
    padding-right: 1em;
}

.estimate_history .formStyle dl dd {
    width: calc(100% - 95px);
    position: relative;
    /*align-items: center;*/
}

.estimate_history .formStyle dl {
    width: 100%;
}


/* =========input-date======== */

input[type="date"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
}

input[type="date"]::-webkit-clear-button {
    -webkit-appearance: none;
}

input::-webkit-datetime-edit {
    -webkit-appearance: none;
    color: var(--color-main-bg);
}

input[type="date" i]::-webkit-calendar-picker-indicator {
    -webkit-appearance: none;
    background-image: url(../img/icon_calendar);
}

.accordion_secsion {
    /*margin-bottom: 66px;*/
}

.accordion_secsion.open .accordion_header .i_box {
    -webkit-transform: rotate(-180deg);
    transform: rotate(-180deg);
}


.accordion_secsion.open .accordion_inner  {
    display:block;
}



/* =========estimate_history======== */


/*====================================================================
.s_01 .accordion_one
====================================================================*/

.s_01,
.s_03 {
    max-width: 336px;
    width: 100%;
}

.s_02 {
    width: 100%;
}

.s_01 .accordion_one .accordion_header,
.s_02 .accordion_header,
.s_03 .accordion_one .accordion_header {
    display: flex;
    position: relative;
    z-index: +1;
    cursor: pointer;
    transition-duration: 0.2s;
    padding: 0px;
    margin-left: 15px;
    
}

.s_01 .accordion_one .accordion_header:hover,
.s_02 .accordion_header:hover,
.s_03 .accordion_one .accordion_header:hover {
    opacity: .8;
}

.s_01 .accordion_one .accordion_header .i_box,
.s_02 .accordion_header .i_box,
.s_03 .accordion_one .accordion_header .i_box {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 50%;
    right: 0;
    width: 40px;
    height: 40px;
    margin-top: -20px;
    margin-right: 12px;
    transform-origin: center center;
    transition-duration: 0.2s;
}

.s_02 .accordion_header .i_box {
    background-color: var(--color-frame-bg);
    border-radius: 50%;
}

.s_01 .accordion_one .accordion_header .i_box .one_i,
.s_02 .accordion_header .i_box .one_i,
.s_03 .accordion_one .accordion_header .i_box .one_i {
    display: block;
    width: 18px;
    height: 18px;
}

.s_02 .accordion_header .i_box .one_i {
    color: var(--color-primary);
}

.s_01 .accordion_one .accordion_header.open .i_box,
.s_02 .accordion_header.open .i_box,
.s_03 .accordion_one .accordion_header.open .i_box {
    -webkit-transform: rotate(-180deg);
    transform: rotate(-180deg);
}

.s_01 .accordion_one .accordion_header .i_box .one_i:before,
.s_01 .accordion_one .accordion_header .i_box .one_i:after,
.s_02 .accordion_header .i_box .one_i:before,
.s_02 .accordion_header .i_box .one_i:after,
.s_03 .accordion_one .accordion_header .i_box .one_i:before,
.s_03 .accordion_one .accordion_header .i_box .one_i:after {
    background-color: var(--color-primary-over);
    border-radius: 10px;
    width: 18px;
    height: 4px;
    position: absolute;
    top: 7px;
    left: 0;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
    transform-origin: center center;
}

.s_01 .accordion_one .accordion_header .i_box .one_i:before,
.s_02 .accordion_header .i_box .one_i:before,
.s_03 .accordion_one .accordion_header .i_box .one_i:before {
    width: 4px;
    height: 18px;
    top: 0;
    left: 7px;
}

.s_01 .accordion_one .accordion_header.open .i_box .one_i:before,
.s_02 .accordion_header.open .i_box .one_i:before,
.s_03 .accordion_one .accordion_header.open .i_box .one_i:before {
    content: none;
}

.s_01 .accordion_one .accordion_header.open .i_box .one_i:after,
.s_02 .accordion_header.open .i_box .one_i:after,
.s_03 .accordion_one .accordion_header.open .i_box .one_i:after {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.s_01 .accordion_one .accordion_inner,
.s_02 .accordion_inner,
.s_03 .accordion_one .accordion_inner {
    display: none;
    position: absolute;
    z-index: 11;
    padding: 0 20px 0;
    margin-right: 10px;
    background-color: var(--color-primary-over);
    box-shadow: 0 0 10px rgb(0 0 0 / 5%);
    width: 100%;
    max-width: 336px;
    top:60px;
}

.s_02 .accordion_inner,
.s_03 .accordion_one .accordion_inner {
    max-width: none;
    position:inherit;
    box-shadow: none;
    margin-top:30px;
    
}

.accordion_content1 {
    display: flex;
}

.accordion_inner dd a {
    width: 100%;
    height: 100%;
    height: 55px;
    border-top: 1px solid var(--color-secondary);
    display: flex;
    justify-content: space-between;
    text-align: left;
   
    
}

.accordion_inner dd a span {
    flex-basis: 100%;
}

.search_results_list {
    margin-bottom: 70px;
}

.search_header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 20px 0 50px;
}

.search_header .hit dl {
    margin-bottom: 0;
    align-items: flex-end;
}

.formStyle .hit dt,
.formStyle .hit dd {
    margin: 0;
    width:auto;
}

.formStyle .hit dd {
    color: var(--color-primary);
    font-size: var(--size-text-default);
}

.formStyle .hit dd span,
.listStyle2 .hit dd span {
    font-size: var(--size-text-3L);
    font-weight: bold;
}

.pagination {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
}

.pager {
    max-width: 266px;
    margin: 0 auto;
}

.pagination li a {
    border: 1px solid var(--color-text-primary);
    border-radius: 5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 32px;
    width: 32px;
    margin: 0 3px;
    font-size: var(--size-text-default);
}

.pagination li a.active,
.pagination li a:hover {
    background-color: var(--color-text-primary);
    color: var(--color-primary-over);
}

.results_head {
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--color-frame-bg);
    margin-bottom: 10px;
    padding-bottom: var(--size-text-default);
}

.results_status {
    min-width: 115px;
    font-size: var(--size-text-L);
    text-align: center;
    margin-right: 15px;
    padding: 3px 0.5em;
    color: var(--color-primary-over);
    white-space: nowrap;

}

.mihachu,
.nyukinmachi {
    background-color: #9F2626;
}

.hachuzumi,
.nouhinzumi {
    background-color: #448BC7;
}

.hassoumachi,
.nyukinmachi1 {
    background-color: #69635dde;
}

.status_contact { background-color: #09316F; }
.status_nego  { 
    
    background-color: #9F2626;  font-size: var(--size-text-M); 
    letter-spacing: -0.15em;
}

.results_name {
    color: var(--color-primary);
    font-size: var(--size-text-L);
    font-weight: bold;
    margin-right: auto;
}

.results_nunber span {
    color: var(--color-primary);
    font-size: var(--size-text-L);
    font-weight: bold;
}

.date_list {
    display: flex;
    justify-content: space-between;
    margin-bottom:1em;
}

.date_list_full {
    flex-basis: 100%;
}

.date_list_l,
.date_list_r {
    flex-basis: 35%;
}

.estimate_history .formStyle .estimated_amount dl {
    flex-wrap: wrap;
}

.formStyle .estimated_amount dl dt,
.formStyle .estimated_amount dl dd {
    display: block;
    width: 100%;
    text-align: left;
}

.formStyle .estimated_amount dl dd {
    font-size: var(--size-text-LL);
    font-weight: bold;
}

.estimate_history .formStyle dl dt,
.estimate_history .formStyle dl dd {
    margin-top: 0;
}

.search_results_list .btn_section {
    margin: 0;
    display: flex;
    justify-content: end;
}

.search_results_list .btn_section button,
.date_list+.btn_section button {
    min-width: max-content;
    max-width: 165px;
    width: 100%;
    margin: 0 4px;
}

svg {
    fill: currentColor;
}

.pre .one_i {
    transform: rotate(90deg);
}

.next .one_i {
    transform: rotate(270deg);
}


/* =========shipping_address======== */

.address_select dl,
.address_select dl dt,
.address_select dl dd {
    margin: 0;
}

.address_select label {
    width: 100%;
    margin-bottom: var(--size-text-S);
}

.shipping_address .btn_section {
    margin: 0;
}

.shipping_address .btn_section button {
    width: 300px;
}

.shipping_address button.btnStyleB {
    margin: 0 0 0 170px;
}

.new_point {
    border: 1px solid var(--color-text-primary);
    margin-top: 16px;
    border-radius: 10px;
    margin-bottom: 48px;
    padding: 34px 15px;
    position: relative;
}

.new_point:before {
    position: absolute;
    top: -29px;
    left: 200px;
    width: 0;
    height: 0;
    content: '';
    border-width: 14px 12px 14px 12px;
    border-style: solid;
    border-color: var(--color-text-primary) transparent transparent transparent;
    transform: rotate(180deg);
}

.new_point:after {
    position: absolute;
    top: -14px;
    left: 200px;
    width: 0;
    height: 0;
    content: '';
    border-width: 14px 12px 0 12px;
    border-style: solid;
    border-color: var(--color-primary-over) transparent transparent transparent;
    transform: rotate(180deg);
}

.new_point dl {
    margin: 0;
}

.new_point p {
    text-align: center;
}
/*
.new_pointdt.hissu:nth-child(19),
.new_point dt.hissu:nth-child(21) {
    margin-top: 20px;
}

.new_point dt.hissu:nth-child(19)::after {
    margin-top: -22px;
    margin-left: 60px;
}

.new_point dd:nth-child(20),
.new_point dd:nth-child(22) {
    position: relative;
}
*/

/* =========estimated_result======== */

.estimated_result .content {
    margin-bottom: 50px;
}

.estimated_result .content:last-child {
    margin-bottom: 0;
}

.estimated_result .formStyle .estimated_amount dl dt,
.estimated_result .formStyle .estimated_amount dl dd,
.date_amount dl dt,
.date_amount dl dd {
    display: block;
    width: 100%;
    text-align: left;
}

.estimated_result .formStyle .estimated_amount dl dd,
.date_amount dl dd {
    font-size: var(--size-text-LL);
    font-weight: bold;
}

.date_list+.btn_section {
    margin: 10px 0 0;
}

.estimated_result .content:last-child .formStyle dl:last-child {
    margin: 0;
}


/* =========estimateDeliverypoint======== */

.estimateDeliverypoint .formStyle dl dd label {
    width: 100%;
    margin-bottom: var(--size-text-default);
}

.estimateDeliverypoint .formStyle div:nth-child(4) dl dd:nth-child(2) {
    flex-direction: row;
}

.estimateDeliverypoint .formStyle div:nth-child(4) dl dd:nth-child(2) label {
    width: 35%;
    display: inline-block;
    margin-bottom: 0;
}

.estimateDeliverypoint .formStyle dl:nth-child(2),
.estimateDeliverypoint .formStyle div:nth-child(3) {
    margin: 0;
}

.estimateDeliverypoint .formStyle div:nth-child(3) {
    text-align: center;
}

.hr p {
    padding: 30px;
    width: 100%;
    text-align: center;
    font-size: var(--size-text-default);
}

.estimateDeliverypoint #form_estimate section:last-child {
    margin-bottom: 80px;
}

/* =========estimated_result======== */

.estimated_result .input-name .name {
    margin: 0 2em;
}

.formStyle .align-items-baseline:nth-child(18) dd span,
.formStyle .align-items-baseline:nth-child(17) dd span {
    margin-right: 3em;
}

.btn_section .icon {
    display: inline-flex;
}


/* =========orderManagement======== */

.orderManagement .formStyle .results_status:first-child,
.estimateManagement .formStyle .results_status:first-child {
    margin-bottom: 35px;
}

p.client {
    color: var(--color-primary);
    font-size: var(--size-text-3L);
}

.form_wrapper {
    padding-left: 37px;
}

.date_list+.btn_section button {
    margin-bottom: 1em;
}

.accordion_inner .btn_section {
    text-align: center;
    display: flex !important;
    justify-content: center;
    align-items: center;
    /*margin-top:0;*/

}
.accordion_inner .btn_section button {
   margin-right:10px;

}

.button_box {
    width: 150px;
}

.flex {
    display: flex;
}

.unitprice {
    justify-content: space-between;
}

.unitprice.flex dl {
    flex-direction: column;
}

.formStyle .unitprice dl dt {
    width: auto;
    text-align: left;
    margin: 0;
}

.formStyle .unitprice dl dd {
    width: 100%;
}

.formStyle .unitprice dl dd input {
    width: min-content;
}

.formStyle .unitprice dl dd input.calendar {
    min-width: 300px;
    margin-right: 1em;
}

.formStyle .unitprice dl {
    margin-bottom: 1em;
}

.table_scroll {
    height: 340px;
    overflow: auto;
}

.listStyle1 ul::-webkit-scrollbar,
.table_scroll::-webkit-scrollbar {
    width: 10px;
}

.listStyle1 ul::-webkit-scrollbar-track,
.table_scroll::-webkit-scrollbar-track,
.table_warpper::-webkit-scrollbar-track {
    background-color: var(--color-frame-bg);
    border-radius: 5px;
}

.listStyle1 ul::-webkit-scrollbar-thumb,
.table_scroll::-webkit-scrollbar-thumb,
.table_warpper::-webkit-scrollbar-thumb {
    background-color: var(--color-primary);
    border-radius: 5px;
}

table {
    width: 99%;
    font-size: var(--size-text-L);

    
}

.history tbody {
    font-size: var(--size-text-default);
    position: relative;
}

.history tr {
    height: 50px;
    border-bottom: 1px solid var(--color-frame-bg);
}

.history tr:first-child {
    height: 30px;
    position: sticky;
    top: 0;
    left: 0;
    z-index: 3;
    background-color: var(--color-section-bg);
}

td {
    color: var(--color-primary);
    font-weight: bold;
}

.history tr td {
    vertical-align: middle;
}

.history tr td:first-child {
    width: 75%;
    margin-right: 5%;
}

.listStyle1 .history tr td time {
    margin: 0;
}

.history tr td:nth-child(2) {
    width: 20%;
}

.tableStyle_header {
    margin-bottom: 40px;
}

.tableStyle th {
    text-align: center;
}

.tableStyle tr {
    border-bottom: 1px solid var(--color-frame-bg);
    height: 50px;
}

.tableStyle tr td {
    text-align: center;
    vertical-align: middle;
    width: 10%;
}


.tableStyleList {
    width:100%;
    /*margin-bottom:3em;*/
}

.tableStyleList tr {
    border-bottom: 1px solid var(--color-frame-bg);
    /*height: 50px;*/
}


.tableStyleList tr.highlight td,
.tableStyleList tr.highlight th {
    background-color: var(--color-main-bg);
}

.tableStyleList td.highlight2,
.tableStyleList th.highlight2  {
    background-color: rgba(0, 0, 255, 0.05);

}

.tableStyleList td.highlight3,
.tableStyleList th.highlight3  {
    background-color: rgba(255, 191, 0, 0.2);
}

.tableStyleList .highlight_diff{
    background-color: rgba(255, 247, 3, 0.8) !important;
}


.tableStyleList th {
    text-align: left;
    padding:0.6em 5px;
    vertical-align: middle;


}


.tableStyleList tr td {
    text-align: left;
    vertical-align: middle;
    padding:0.4em 5px;
}


.table-head-between {
    margin:1em 0;
    display: flex;
    justify-content: space-between;
}

.align-right {    text-align: right !important ; }
.align-center {    text-align: center !important ; }
.valign-top {    vertical-align: top !important ; }
.valign-bottom {    vertical-align: bottom !important ; }


/* =========news======== */

.listStyle2 .hit {
    width: 73px;
}

.hit dl {
    display: flex;
}

.listStyle2 .search_header .pager {
    /* margin-left: calc(50% - 206px); */
    margin-right: calc(50% - 303px);
}

.listStyle2>ul li a {
    display: flex;
    width: calc(95% - 150px);
}

.listStyle2 time {
    color: var(--color-primary);
}

.listStyle2 .news_title {
    max-width: 55%;
}

.listStyle2 ul button {
    margin-right: 0;
    margin-left: auto;
}

.list_title p:last-child {
    width: 150px;
    display: block;
    text-align: center;
    margin-left: auto;
    margin-right: 0;
}

.listStyle2 .search_results_footer {
    margin-top: 50px;
}

.search_results_footer {
    margin-top:1em;
}

.formStyle .hit dd {
    padding: 0;
    text-align: center;
}


/* =========newsInfo======== */

.news_info dl>dd:nth-of-type(1) input {
    width: auto;
    max-width: 30%;
}

.news_info dl>dd:nth-of-type(2) input {
    width: auto;
    max-width: 60%;
}

.news_info dl>dd:nth-of-type(3) textarea {
    width: 100%;
    resize: vertical;
}

.newsinfo .listStyle2 ul li:nth-child(n+2) time {
    width: auto;
    max-width: calc(100% - 330px);
}


/* =========postageinfo======== */

.postageinfo .history tr td:first-child {
    width: 20%;
}

.postageinfo .history tr td:nth-child(2) {
    width: 75%;
}

.table_warpper {
    width: 100%;
    overflow: auto;
}

.tableStyle1 .pricelist {
    width: 100%;
    overflow: auto;
}

.tableStyle1 th,
.tableStyle1 td {
    min-width: 100px;
}

.tableStyle1 th {
    vertical-align: bottom;
    padding-bottom: 1em;
}

.tableStyle1 tr {
    width: auto;
    display: flex;
    align-items: baseline;
    position: relative;
}

.tableStyle1 tr:first-child {
    align-items: flex-end;
}

.tableStyle1 tr:first-child th {
    height: 165px;
    display: inline-flex;
    align-items: flex-end;
}

.table_warpper::-webkit-scrollbar {
    height: 10px;
}


/* .table_warpper::-webkit-scrollbar-track {
    background-color: var(--color-frame-bg);
    border-radius: 5px;
}

.table_warpper::-webkit-scrollbar-thumb {
    background-color: var(--color-primary);
    border-radius: 5px;
} */

.row1,
.row2 {
    position: sticky;
    z-index: 1;
    background-color: var(--color-section-bg);
}

.row1 {
    left: 0;
}

.row2 {
    left: 100px;
}



/*
 chosenのデザイン変更
*/
.input_select .chosen-container {

    background-color: var(--color-secondary);
    border-radius: 20px;
    font-size: var(--size-text-L);
    color: var(--color-primary);
    padding: 0.6em 1.0em;
    margin: 0 0 2px;

}

.input_select .chosen-container-single .chosen-single {
    border-width:0px !important;
    background: none;
    box-shadow: none;
    padding:0;

}

.input_select .chosen-container-active {
    /*border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
    */
  }


.input_select .chosen-container-active.chosen-with-drop .chosen-single {
    border-width:0px !important;
}

.input_select .chosen-container-single .chosen-search input[type="text"]{
    border-width:0px !important;
    background-color: #fff;
    border-radius: 15px;
    font-family:inherit;
    padding-left:0.5em;
}

.input_select .chosen-container.chosen-with-drop .chosen-drop{
    border-width:0px !important;
    background-color: var(--color-secondary);
    box-shadow: none;
    margin-top:-0.8em;
}

.input_select .chosen-container-single .chosen-single span,
.input_select .chosen-container .chosen-results li
{
    font-size: var(--size-text-L);
    color: var(--color-primary);
}
.input_select .chosen-container .chosen-results li {
    padding:0.5em 0.5em;
}


.input_select .chosen-container-single .chosen-drop {
    margin-left:-1.5em;
}

.input_select .chosen-container .chosen-results li.highlighted {
    background-color: var(--color-primary);
    color:#fff;
    background-image: none;

}

.input_select .chosen-container .chosen-results{

}


.input_select .chosen-disabled 
{
    background-color: gray;
    cursor: default;
  }
  

.input_select .chosen-container .chosen-results li.disabled-result {
    display: none;
    
}
.input_select .chosen-container .chosen-results li.disabled-disp.active-result {
    display: inherit;
    opacity: 0.3;
    pointer-events: none;
}

/* ステータス系
============================*/

.icon_notice {
    display: inline-block;
    line-height: 1.2;
    font-size: var(--size-text-icon);
    background-color: var(--color-tertiary);
    color:#fff;
    padding: 0.2em 0.5em;
    white-space: nowrap;
    margin:1px 0;
}

.icon_status {
    padding: 0.2em 1em;
    color:#fff;
    display: inline-block;
    margin-right:1em;
    line-height: 1.2 !important;
    white-space: nowrap;
    font-size: var(--size-text-icon);


}
.icon_status2 {
    padding: 0.2em 1em;
    color:#fff;
    display: inline-block;
    margin-right:1em;
    border-radius: 100px;
    line-height: 1.2 !important;
    white-space: nowrap;
    font-size: var(--size-text-icon);

}

.client_status1 {  background-color: #448BC7;  }
.client_status21 {  background-color: #FF840A;  }
.client_status22 {  background-color: #9F2626;  }
.client_status23 {  background-color: #00bd68;  }
.client_status31 {  background-color: #FF840A;  }
.client_status32 {  background-color: #9F2626;  }
.client_status9 {  background-color: #CCD2DD;  }



.order_status10 {  background-color: #9F2626;  }
.order_status30 {  background-color: #3dba34;  }
.order_status40 {  background-color: #118f82;  }
.order_status50 {  background-color: #448BC7;  }
.order_status51 {  background-color: #120279;  }
.order_status90 {  background-color: #CCD2DD;  }



.rank_list {
    display: flex;
    flex-wrap: wrap;
}

dl.rank_list dt {
    /*width:23.3%;*/
    width:36%;
    text-align: left;
    margin-left:2%
}

dl.rank_list dd {
    width:12%;

}


/* 詳細のヘッダー
============================*/
.detailHead {

}

.detailHead h3{
    color:var(--color-primary);
    font-size:var(--size-text-LL);

}

.detailHead dl{
    margin:1em 0;
    display: flex;
    justify-content:  flex-start;
    align-items: stretch;
    flex-wrap: wrap;

}
.detailHead dl dt {
    flex-basis:8%;
    margin:0.3em 0;
    font-size: var(--size-text-default);

}

.detailHead dl dd {
    color:var(--color-primary);
    flex-basis:25.3%;
    margin:0.3em 0;

}


.tabNavi {
    width: calc(100% - 20px);
    margin: 0 auto;

}

.tabNavi ul {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-around;
}

.tabNavi ul li {
    flex-basis: 50%;
    text-align: center;

}

.tabNavi ul li a {
    display: block;
    padding:1em;
    color:var(--color-primary);
    border-radius: 10px 10px 0 0;
    background-color: var(--color-main-bg);
    border:2px solid var(--color-section-bg);
    margin-right:3px;


}

.tabNavi ul li:last-child a {
    margin-right: 0;
}

.tabNavi ul li a.active {
    background-color: var(--color-section-bg);
   border-bottom:1px solid var(--color-main-bg);
   border:2px solid var(--color-section-bg);

}



.tabContent {
    display: none;
}

.tabContent.active {
    display: block;
    
}


.tableStyleA {

}
.tableStyleA th {
    padding: 5px 5px;
}
.tableStyleA td {
    padding: 5px 5px;
}

.scrollArea {
    width:100%;
    overflow-x: auto;
}

.tableStyleA .nowrap {
    white-space: nowrap;
}

input.input_small{
    padding:0.5em 0.2em;
    min-width:50px;
    border-radius: 3px;
    text-align: center;

}



.tableSticky {
    position: sticky;
    left: 0;
    background-color: #fff;

  }
  /*
  .tableSticky:before {
    content: "";
    position: absolute;
    top: -1px;
    left: -1px;
    width: 100%;
    height: 100%;
  }
  */



  .docmentStyle {
    line-height: 1.4;

  }
  .docmentStyle h3 {
    margin-bottom:2em;
}
  .docmentStyle h5 {
    margin-top:1em;
   
}
.docmentStyle ol,
.docmentStyle ul
{
    padding-left:1em;
    padding-top:0.6em;
    padding-bottom:0;

}
.docmentStyle p {
    padding-top:0.6em;
    padding-bottom:1em; 
}


.docmentStyle ol li
 {
    list-style: decimal;
    padding-bottom:0.6em;

}

.docmentStyle ul li
 {
    list-style: disc !important;
    padding-bottom:0.6em;

}

.docmentStyle li li
 {
    list-style: none;
    padding-bottom:0.6em;
    padding-left:2em;
    text-indent: -1.5em;

}

.docmentStyle ul li {
    list-style:disc;
    padding-bottom:0.5em;
}

.docmentStyle ol li:only-child,
.docmentStyle ul li:only-child

{
    list-style: none;
    margin-left:-1em;
}

.docmentStyle strong {
    display: inline-block;
    padding-top:0.5em;
}

.docmentStyle dl {
    display: flex;
    flex-wrap: wrap;
    align-items:stretch;
    

}

.docmentStyle dl dt {
    flex-basis: 300px;
    text-align: right;
    padding:1em;
    border-bottom: 1px solid var(--color-main-bg);

}

.docmentStyle dl dd {
    color:var(--color-primary);
    flex-basis: calc(100% - 300px);
    padding:1em;
    border-bottom: 1px solid var(--color-main-bg);

}


.docmentStyle a {
    padding:0.5em 1.5em;
    background-color: var(--color-main-bg);
    border-radius: 10px;
    margin:0 0.5em;

}


.docmentStyle a:hover {
    background-color: var(--color-primary);
    color:var(--color-main-bg);
}

.docmentStyle table {
    width:100%;
    margin:1em 0;
}
.docmentStyle table th,
.docmentStyle table td {
    padding:0.5em;
    border:var(--color-frame-bg) 1px solid;


}
.docmentStyle table th {
    background-color: var(--color-main-bg);
    color:var(--color-primary);

}

.docmentStyle table td {
    color:var(--color-text-primary);

}
.docmentStyle address {
    border:var(--color-secondary) 1px solid;
    padding:1em;
    margin:1em 0;
}


.kiyaku_section {
    margin:1em 0;
}

.kiyaku_section .docmentInline {
    margin:1em 0;
}


.docmentInline {
    width:100%;
    height:300px;
    font-size:0.8em;
    overflow-y: auto;
    border: 1px solid var(--color-frame-bg);
    padding:2em;

}