.sp .page-container {
    min-width: 0
}

.sp .detailed-sections {
    background: none
}

.sp .detailed-sections-container {
    border: none;
    width: 960px;
    padding-bottom: 0
}

.site-header.sp {
    max-width: 960px;
    margin: 0 auto;
    border-bottom: 8px solid #001c58
}

.site-header.sp .header-container {
    width: 100%
}

.sp .site-header-upper {
    height: 131px;
    margin: 0 22px;
    width: auto
}

.sp .site-header-upper .site-names {
    width: 52.72926%
}

.sp .site-header-upper .site-name {
    width: 470px;
    height: 131px;
    background: url(../../../sp/img/common/sp-kkmn-logo.png) left 39px no-repeat
}

.sp .site-header-upper .contact-info {
    width: 47.27074%
}

.sp .site-header-upper .site-phone {
    padding-top: 28px;
    font-size: 3.5em;
    letter-spacing: -0.025em;
    height: 91px
}

.sp .site-header-upper .fd-logo {
    width: 58px;
    height: 34px;
    background-image: url(../../../sp/img/common/sp-freedial-logo.png)
}

.sp .site-header-upper .business-hour {
    font-size: 1.16667em;
    padding-left: 59px
}

.page-index.sp .site-header.sp {
    border-bottom: none
}

.site-footer.sp {
    padding-top: 70px;
    padding-bottom: 100px
}

.site-footer.sp .office-name {
    font-size: 2em;
    margin-bottom: 40px
}

.site-footer.sp .office-address {
    font-size: 1.33333em;
    line-height: 1.625;
    margin-bottom: 60px
}

.site-footer.sp .colophon {
    font-size: 1.33333em
}

.page-index.sp .entry-block .entryform-container {
    background-color: #0b79ac;
    padding-bottom: 16px;
    border-radius: 0px;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box
}

.page-index.sp .entry-block .entryform-title {
    width: 100%;
    height: 226.5px;
    background: url(../img/sp-entry-title.png) 15px 15px no-repeat;
    background-size: 97.3438%;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden
}

.page-index.sp .entry-block .entryform-form {
    background-color: #fff;
    margin: 0 24px;
    padding: 42px 0 48px;
    font-size: 1.5em
}

.page-index.sp .entry-block .entryform-table {
    margin-bottom: 58px;
    padding: 0 36px
}

.page-index.sp .entry-block .entryform-table .form-row {
    overflow: hidden
}

.page-index.sp .entry-block .entryform-table .form-row+.form-row {
    margin-top: 20px
}

.page-index.sp .entry-block .entryform-table .form-label {
    display: block;
    float: left;
    width: 90px;
    height: 90px;
    background-color: #075478;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 1.5;
    -webkit-border-top-right-radius: 0;
    -webkit-border-bottom-right-radius: 0;
    -webkit-border-bottom-left-radius: 15px;
    -webkit-border-top-left-radius: 15px;
    -moz-border-radius-topright: 0;
    -moz-border-radius-bottomright: 0;
    -moz-border-radius-bottomleft: 15px;
    -moz-border-radius-topleft: 15px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 15px;
    border-top-left-radius: 15px;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden
}

.page-index.sp .entry-block .entryform-table .form-row:nth-of-type(1) .form-label {
    background-image: url(../../img/entry-form-num1.png);
    background-position-x: 35px
}

.page-index.sp .entry-block .entryform-table .form-row:nth-of-type(2) .form-label {
    background-image: url(../../img/entry-form-num2.png)
}

.page-index.sp .entry-block .entryform-table .form-row:nth-of-type(3) .form-label {
    background-image: url(../../img/entry-form-num3.png)
}

.page-index.sp .entry-block .entryform-table .form-row:nth-of-type(4) .form-label {
    background-image: url(../../img/entry-form-num4.png)
}

.page-index.sp .entry-block .entryform-table .form-row:nth-of-type(5) .form-label {
    background-image: url(../../img/entry-form-num5.png)
}

.page-index.sp .entry-block .entryform-table .form-row:nth-of-type(6) .form-label {
    background-image: url(../../img/entry-form-num6.png)
}

.page-index.sp .entry-block .entryform-table input[type="text"],
.page-index.sp .entry-block .entryform-table input[type="tel"],
.page-index.sp .entry-block .entryform-table select {
    display: block;
    float: left;
    height: 90px;
    border: 3px solid #075478;
    border-left: none;
    padding: 0 0.75em
}

.page-index.sp .entry-block .entryform-table input[type="text"],
.page-index.sp .entry-block .entryform-table input[type="tel"] {
    width: calc(100% - 90px);
    -webkit-border-top-right-radius: 12px;
    -webkit-border-bottom-right-radius: 12px;
    -webkit-border-bottom-left-radius: 0;
    -webkit-border-top-left-radius: 0;
    -moz-border-radius-topright: 12px;
    -moz-border-radius-bottomright: 12px;
    -moz-border-radius-bottomleft: 0;
    -moz-border-radius-topleft: 0;
    border-top-right-radius: 12px;
    border-bottom-right-radius: 12px;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box
}

.page-index.sp .entry-block .entryform-table select {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    border-right: none;
    border-radius: 0px;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    width: calc(100% - 105px)
}

.page-index.sp .entry-block .entryform-table .form-set {
    position: relative;
    overflow: hidden
}

.page-index.sp .entry-block .entryform-table .form-set.select::after {
    content: "▼";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 78px;
    height: 90px;
    border: 3px solid #075478;
    -webkit-border-top-right-radius: 12px;
    -webkit-border-bottom-right-radius: 12px;
    -webkit-border-bottom-left-radius: 0;
    -webkit-border-top-left-radius: 0;
    -moz-border-radius-topright: 12px;
    -moz-border-radius-bottomright: 12px;
    -moz-border-radius-bottomleft: 0;
    -moz-border-radius-topleft: 0;
    border-top-right-radius: 12px;
    border-bottom-right-radius: 12px;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    border-left: none;
    background-color: #0b79ac;
    color: #fff;
    line-height: 90px;
    text-align: center;
    pointer-events: none
}

.page-index.sp .entry-block .entryform-table .form-note {
    font-size: 0.83333em;
    color: #666;
    margin-top: 4px
}

.page-index.sp .entry-block .entryform-submit-container {
    text-align: center
}

.page-index.sp .entry-block .entryform-submit {
    width: 100%;
    height: 136px;
    border: none;
    background: url(../img/sp-entry-btn.png) center top no-repeat;
    background-size: 849px 136px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-indent: 130%
}

.page-index.sp .entry-block .entryform-submit:disabled {
    opacity: 0.5;
    cursor: not-allowed
}

.page-index.sp .intro-sect {
    max-width: 960px;
    margin: 0 auto;
    background: url("../../../sp/img/index/sp-intro-bg.jpg") center top/contain no-repeat;
    height: 636px
}

.page-index.sp .intro-sect .sect-container {
    width: 100%;
    padding-top: 30px
}

.page-index.sp .intro-sect .intro-main {
    height: 444px;
    background: url(../img/sp-intro-titles.png) right top/contain no-repeat;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden
}

.page-index.sp .intro-sect .intro-services {
    height: 162px;
    background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(80%, #162c5c));
    background: linear-gradient(to bottom, transparent, #162c5c 80%);
    padding-top: 27px
}

.page-index.sp .intro-sect .services-list {
    text-align: center;
    padding: 0;
    text-indent: 0;
    list-style: none
}

.page-index.sp .intro-sect .services-list .list-item,
.page-index.sp .intro-sect .services-list .list-item-etc {
    font-size: 1.44444em;
    display: inline-block;
    line-height: 1.76923;
    color: white;
    margin: 0 7px 21px;
    border-radius: 4px;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box
}

.page-index.sp .intro-sect .services-list .list-item {
    background-color: #69c;
    padding: 0 16px
}

.page-index.sp .praise-sect .sect-main {
    background-position: 363px top, -30px top
}

.page-index.sp .praise-sect .sect-main-title {
    background-position: 13px top
}

.page-index.sp .entry-sect {
    padding-top: 0;
    padding-bottom: 0
}

.page-index.sp .compare-sect .sect-main {
    background-position: 363px top
}

.page-index.sp .compare-sect .compare-steps .list-item {
    margin-left: 30px
}

.page-index.sp .compare-sect .compare-steps .list-item+.list-item {
    width: 280px
}

.page-index.sp .compare-sect .compare-steps .list-item+.list-item::before {
    content: none
}

.page-index.sp .troub-sect {
    margin-bottom: 0
}

.page-index.sp .troub-sect .sect-title {
    background-size: 93.75% auto
}

.page-index.sp .troub-sect .troub-intro {
    background-position: 363px top, right top
}

.page-index.sp .troub-sect .troub-cases .col-header {
    padding-left: 0;
    padding-right: 0
}

.page-index.sp .troub-sect .troub-cases .col-main {
    margin-left: 0;
    margin-right: 0
}

.page-index.sp .troub-sect .troub-cases .col-main .case-concern {
    padding-left: 40px;
    padding-right: 40px
}

.page-index.sp .troub-sect .troub-cases .col-main .case-solution {
    margin-left: 40px;
    margin-right: 40px
}

.page-estimate.sp .thanks-container {
    display: none;
    text-align: center
}

.page-estimate.sp .thanks-container.visible {
    display: block
}

.page-estimate.sp .main-container {
    background: none
}

.page-estimate.sp .form-header {
    height: 278px;
    background: url(../img/estimate/sp-form-bg.jpg) left top/cover no-repeat
}

.page-estimate.sp .page-title {
    background: none;
    text-align: center;
    text-indent: 0px;
    white-space: normal;
    font-size: 3.16667em;
    line-height: 1.33333;
    font-weight: normal;
    color: #001c58;
    padding-top: 65px;
    letter-spacing: -0.050em;
    text-shadow: 0px 3px 3px #fff
}

.page-estimate.sp .page-title small {
    font-size: 0.84211em
}

.page-estimate.sp .page-title strong {
    font-weight: normal;
    color: #c00
}

.page-estimate.sp .form-container {
    border: none;
    margin: 0
}

.page-estimate.sp .form-desc {
    border: none;
    font-size: 2em;
    line-height: 1.41667;
    padding: 65px 68px;
    background-color: white
}

.page-estimate.sp .form-table {
    border: none;
    font-size: 36px
}

.page-estimate.sp .form-table table,
.page-estimate.sp .form-table tbody,
.page-estimate.sp .form-table tr,
.page-estimate.sp .form-table th,
.page-estimate.sp .form-table td {
    display: block;
    width: 100%
}

.page-estimate.sp .form-table .req-label {
    line-height: 1.25
}

.page-estimate.sp .form-table th {
    padding: 20px 60px
}

.page-estimate.sp .form-table th {
    background-color: #005982;
    border: 2px solid #00184a;
    border-left: none;
    border-right: none;
    color: white;
    font-size: 1.16667em;
    text-align: left;
    line-height: 1.0
}

.page-estimate.sp .form-table th th>label {
    font-size: 1.0em
}

.page-estimate.sp .form-table td {
    padding: 50px 60px;
    border-bottom: none
}

.page-estimate.sp .form-table tr.req-form>td {
    padding-top: 13px
}

.page-estimate.sp .form-table .cf_bldg_type th label {
    margin: 0
}

.page-estimate.sp .form-table .cf_bldg_type td label {
    font-size: 1.25em
}

.page-estimate.sp .form-table .cf_bldg_type input[type="radio"] {
    width: 40px;
    height: 40px;
    vertical-align: middle
}

.page-estimate.sp .form-table label[for=cf_pref],
.page-estimate.sp .form-table label[for=cf_address] {
    display: block;
    width: auto;
    padding: 0;
    text-align: left;
    margin: 0 0 0.25em 0;
    font-size: 1.0em
}

.page-estimate.sp .form-table select {
    width: 100%;
    height: 2.5em
}

.page-estimate.sp .form-table input[type="text"],
.page-estimate.sp .form-table input[type="tel"],
.page-estimate.sp .form-table textarea {
    font-size: 1.0em
}

.page-estimate.sp .form-table .error-msg {
    font-size: 1.0em;
    line-height: 1.25;
    margin-bottom: 2px
}

.page-estimate.sp .form-table .error-msg.pref,
.page-estimate.sp .form-table .error-msg.address {
    margin-left: 0
}

.page-estimate.sp .form-table input[name="cf_address"] {
    width: 100%
}

.page-estimate.sp p.note {
    font-size: 1.66667em;
    margin: 0 auto 70px;
    border-top: 2px solid #b3b3b3;
    padding-top: 70px
}

.page-estimate.sp .submit-btn-container {
    width: 462px;
    height: 120px
}

.page-estimate.sp button.form-submit {
    font-size: 3.16667em;
    line-height: 120px;
    border-radius: 15px;
    -moz-background-clip: padding;
    -webkit-background-clip: padding-box;
    background-clip: padding-box
}

.page-estimate.sp .thanks-container {
    font-size: 2em;
    padding: 10em 0.5em
}

.page-agreement.sp .page-main {
    font-size: 2em
}

.up-fz-14 {
    font-size: 14px;
}

.up-fz-18 {
    font-size: 18px;
}

.up-mt-10 {
    margin-top: 10px;
}

.up-fw-500 {
    font-weight: 500;
}

@media(max-width:599px) {
    .up-fz-12\@sp {
        font-size: 12px;
    }
}