@charset "utf-8";

/* -------------------------------------------------- 
 * co.css
 * 
 * /product/co/用CSS
 * ※第1階層フォルダごとに読み込ませるCSSを分けて作成
 -------------------------------------------------- */

/*
 * 0) ec-cube.co ABテストヘッダー product_pageheader
-------------------------------------------------- */
section[class$="_pageheader"] .pageheader.p-simpleform {
    height: auto;
}
.p-simpleform .p-simpleform__left {
    text-align: center;
    max-width: 500px;
    margin: 0 auto;
}
.p-simpleform .inner {
    padding: 7rem 2rem 6rem;
}
.p-simpleform .pageheader_title {
    font-family: museo-slab, sans-serif;
    font-style: normal;
    font-weight: 900;
    line-height: 1.1;
    color: #fc0;
    font-size: 5rem;
    margin-bottom: 0rem;
}
.p-simpleform .p-co__text {
    color: #fff;
    font-weight: bold;
    margin-bottom: 2rem;
}
.p-simpleform_note {
    color: #fff;
    font-size: 1.4rem;
    line-height: 1.4;
    text-align: left;
    margin: 1rem 0;
    font-weight: normal;
    vertical-align: top;
}
.p-simpleform_note a {
    color: #fff;
    font-size: 1.4rem;
    text-decoration: underline;
}

@media only screen and (max-width: 991px) {
    .p-simpleform_note {
        font-size: 1.3rem;
    }
    .p-simpleform_note a {
        font-size: 1.3rem;
    }    
}

.p-form_input_wrap {
    width: 100%;
    margin: 0 0 1rem 0;
    position: relative;
}
.p-form {
    margin-top: 2rem;
}
.p-form input {
    padding: 1rem;
    border-radius: 0.6rem;
    border: 3px solid #fff;
    box-shadow: 0 0 0rem #ffedb3;
    width: 100%;
    transition: 0.5s;
}
.p-form input:focus {
    border: 3px solid #fff;
    box-shadow: 0 0 1rem #ffedb3;
    outline: 0;
}
.p-form input.error {
    border: 3px solid #ff5858;
    box-shadow: 0 0 1rem rgba(255, 88, 88, 0.74);
    background: #fff6d0;
}
.p-form__mail.is-focus {
    border: 3px solid #fff;
    box-shadow: 0 0 0rem #ffedb3;
    background: #fff;
    outline: 0;
    animation: blinking 4s infinite;
}
@keyframes blinking {
    0% {
        border: 3px solid #ffedb3;
        box-shadow: 0 0 0rem #ffedb3;
    }
    25% {
        border: 3px solid #ffedb3;
        box-shadow: 0 0 2rem #ffedb3;
    }
    50% {
        border: 3px solid #ffedb3;
        box-shadow: 0 0 0rem #ffedb3;
    }
    75% {
        border: 3px solid #ffedb3;
        box-shadow: 0 0 3rem #ffedb3;
    }
    100% {
        border: 3px solid #fff;
        box-shadow: 0 0 0rem #ffedb3;
    }
}
.error-message {
    position: absolute;
    bottom: 4rem;
    left: 0;
    background: #ff5858;
    color: #fff;
    text-align: left;
    font-size: 1.3rem;
    padding: 0.6rem 2rem 0.5rem;
    border-radius: 50px;
    width: 100%;
}
.error-message span {
    position: relative;
}
.error-message span:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 25%;
    margin-left: -2rem;
    border: 1.5rem solid transparent;
    border-top: 2.2rem solid #ff5858;
}
.p-form_btn {
    padding: 1rem 2rem;
    border-radius: 0.6rem;
    border: 2px solid transparent;
    background: #38c2eb;
    color: #fff;
    font-weight: bold;
    width: 100%;
    font-size: 1.7rem;
    margin: 0 0 1rem 0;
}
.p-form_btn:hover {
    background: #34b3d9;
}
.u-flex {
    display: block;
}
.u-flex__between {
    justify-content: space-between;
}
.u-flex__align-center {
    align-items: center;
}
.p-simpleform__right {
    width: 100%;
    display: none;
}
.p-simpleform__right p {
    font-size: 1rem;
    color: #fff;
    text-align: center;
    margin: 1rem 0 0;
}
@media only screen and (min-width: 992px) {
    .p-simpleform .inner {
        padding: 12rem 0 6rem;
    }
    .p-simpleform .p-simpleform__left {
        text-align: left;
        width: 46%;
        max-width: none;
        margin: 0 0 7rem 0;
    }
    .p-simpleform__right {
        width: 45%;
        display: block;
    }
    .p-simpleform .pageheader_title {
        font-size: 8rem;
        margin-top: 5rem;
    }
    .u-flex {
        display: flex;
    }
}

/*
 * 1) ec-cube.co
-------------------------------------------------- */

/* product_pageheader */

.product_pageheader .heading_area .u-small {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1;
}
.product_pageheader .pageheader {
    background: url(../img/product/product_co_pageheader_bg.jpg) center center
        no-repeat;
    background-size: cover;
}
.product_pageheader .pageheader_title .u-small {
    display: block;
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 1;
    letter-spacing: 3px;
}
.section:nth-of-type(even) {
    background: #fff;
}
.section:nth-of-type(odd) {
    background: #f9f9f9;
}
/* heading */
.heading01 {
    text-align: center;
}
.heading01 sup {
    display: inline-block;
    font-size: 30%;
    position: relative;
    top: -1em;
}
.p-co__header .pageheader_title {
    margin-bottom: 0;
}
.p-co__header .p-co__text,
.p-co__header .p-co__header_link {
    color: #fff;
    font-size: 1.8rem;
    font-weight: 700;
    text-shadow: 1px 1px 0 0 rgba(0, 0, 0, 0.5);
}
.p-co__header .p-co__header_link {
    text-decoration: underline;
}
.p-co__header .p-co__header_link:hover {
    text-decoration: none;
}
@media only screen and (min-width: 768px) {
}
@media only screen and (min-width: 992px) {
    .heading01 {
        font-size: 35px;
        font-size: 3.5rem;
    }
}
.heading03 {
    margin: 0;
}
.section .heading01 .u-small {
    display: block;
    font-size: 15px;
    font-size: 1.5rem;
    line-height: 1.5;
    letter-spacing: 2px;
}

/* subsc-link */
.button_area .subsc-link {
    display: block;
    max-width: 670px;
    margin: 20px auto 0;
    padding: 20px 10px 15px;
    border-radius: 10px;
    font-size: 20px;
    font-size: 2rem;
}
.entry_attention {
    text-align: center;
    font-size: 14px;
    font-size: 1.4rem;
}
.entry_attention a {
    text-decoration: underline;
    color: #337ab7;
}
.entry_attention a:hover {
    text-decoration: none;
}
@media only screen and (min-width: 768px) {
    .button_area .subsc-link {
        margin: 60px auto 0;
        border-radius: 10px;
        font-size: 24px;
        font-size: 2.4rem;
    }
}
/* co_support */
.button_area .co_support {
    display: block;
    max-width: 670px;
    margin: 20px auto 0;
    padding: 20px 10px;
    border-radius: 10px;
    font-size: 20px;
    font-size: 2rem;
}

/* co_intro
--------------------*/
.co_intro .icons {
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin: 30px auto;
}
.co_intro .text {
    line-height: 1.8;
}
.co_intro .icons li {
    max-width: 30%;
    text-align: center;
    margin-bottom: 0;
}
.subsc-link img {
    padding: 0 10px;
    transform: translateY(-5px);
}

@media only screen and (min-width: 768px) {
    .co_intro {
        padding: 80px 0;
    }
    .co_intro .icons {
        max-width: 880px;
        margin: 60px auto;
    }
    .co_intro .icons li {
        max-width: 240px;
        text-align: center;
        margin-bottom: 0;
    }
}
@media only screen and (min-width: 992px) {
    .co_intro {
        padding: 100px 0;
    }
    .co_intro .icons {
        margin: 70px auto;
    }
}

/* co_recommend
--------------------*/
.co_recommend .heading03 {
    font-size: 24px;
    font-size: 2.4rem;
    font-weight: 700;
    color: #57acb3;
    text-align: center;
    max-width: 810px;
    border-bottom: 1px #57acb3 solid;
    padding-bottom: 20px;
    margin: 0 auto;
}
.co_recommend .heading03 .u-small {
    display: block;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.5;
}
.co_recommend .co_recommend_list {
    max-width: 810px;
    margin: 0 auto;
    padding: 20px 0px 20px 10px;
    box-sizing: border-box;
}
.co_recommend .co_recommend_list li {
    width: 100%;
    box-sizing: border-box;
    padding: 5px 10px 5px 16px;
    background: url(../img/product/bullet01.png) left 0.7em no-repeat;
    background-size: 10px 10px;
}
.co_recommend .co_recommend_list li strong {
    background: linear-gradient(transparent 65%, #ffeb6d 70%);
}

@media only screen and (min-width: 768px) {
    .co_recommend {
        padding: 80px 0;
    }
    .co_recommend .co_recommend_list {
        max-width: 810px;
        margin: 0 auto;
        display: -webkit-box;
        display: -webkit-flex;
        display: flex;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        justify-content: space-between;
        flex-wrap: wrap;
        padding: 40px 0px 0 25px;
        box-sizing: border-box;
    }
    .co_recommend .co_recommend_list li {
        width: 50%;
    }
}
@media only screen and (min-width: 992px) {
    .co_recommend {
        padding: 100px 0;
    }
    .co_recommend .co_recommend_list {
        padding: 40px 0 0 35px;
    }
}

/* co_case
--------------------*/
.co_case {
    padding: 50px 0;
}
.co_case .inner {
    max-width: 1000px;
}
.co_case__lead {
    text-align: center;
    margin-bottom: 30px;
    transform: translateY(-10px);
}
.co_case__wrap {
    margin-top: 50px;
}
.co_case__list {
    display: flex;
    flex-wrap: wrap;
}
.co_case__list .co_case__thumb {
    max-width: 360px;
}
.co_case__list .co_case__mask {
    filter: drop-shadow(1px 1px 3px rgba(0, 0, 0, 0.05));
    margin-bottom: 10px;
    overflow: hidden;
    border-radius: 6px;
    transform: translateY(0px) scale(0.999);
    transition: 0.3s;
}
.co_case__list .co_case__mask img,
.co_case__list .co_case__mask:hover img {
    image-rendering: smooth;
    -webkit-backface-visibility: hidden;
}
.co_case__list a:hover,
.co_case__list a:hover .co_case__mask {
    opacity: 0.8;
    transform: translateY(2px) scale(1.04);
    transition: 0.2s;
    image-rendering: smooth;
    -webkit-backface-visibility: hidden;
}
.co_case__list span {
    display: inline-block;
    font-size: 10px;
    background: #f5f5f5;
    color: #fff;
    padding: 2px 10px;
    border-radius: 4px;
    margin: 10px 10px 6px 0;
}
.co_case__list .tag_new {
    background: #ea619b;
}
.co_case__list .tag_food {
    background: #f29443;
}
.co_case__list .tag_fashion {
    background: #65cbd3;
}
.co_case__list .tag_garden {
    background: #73c379;
}
.co_case__list .tag_cosme {
    background: #ea619b;
}
.co_case__list .tag_interior {
    background: #8b6051;
}
.co_case__list .tag_goods {
    background: #26a69a;
}
.co_case__list .co_case__name {
    font-size: 14px;
    margin: 0;
}
.co_case__list .co_case__url {
    margin: 0 0 30px 0;
    color: #337ab7;
    font-size: 12px;
}
.co_case .swiper-container-horizontal > .swiper-scrollbar {
    background: #f8f8f8;
}
.co_case .swiper-scrollbar-drag {
    background: #ffcc00;
}

@media only screen and (min-width: 768px) {
    .co_case {
        padding: 100px 0;
    }
    .co_case .inner {
    }
    .co_case__list {
        display: flex;
        justify-content: space-between;
    }
    .co_case__list li {
        width: 31%;
        padding: 0;
    }
    .co_case .swiper-container {
        padding: 10px;
    }
}

/*--- アドバイザーボタン ---*/
.co_case .button_area .c-btn__primary a {
    background: #67aae2;
    color: #fff;
    margin-top: 10px;
}
.co_case .button_area .c-advisor_btn a {
    display: block;
    position: relative;
    font-size: 16px;
    font-weight: 700;
    text-align: center;
    padding: 10px;
    box-shadow: 0px 2px 6px 2px rgb(0 0 0 / 10%);
    text-decoration: none;
    border-radius: 6px;
}
.co_case .button_area .c-advisor_btn a:hover {
    opacity: 0.8;
}
.co_case .button_area .c-advisor_btn a::before {
    content: "";
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    display: block;
    width: 8px;
    height: 8px;
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translateY(-50%) rotate(45deg);
}
.co_case .button_area .c-advisor_btn small {
    display: block;
    font-size: 12px;
    font-weight: 400;
    color: #fff;
}
@media screen and (min-width: 768px) {
    .co_case .button_area .c-advisor_btn {
        width: 440px;
        margin: 30px auto 0px;
    }
    .co_case .button_area .c-advisor_btn small {
        font-size: 80%;
    }
    .co_case .button_area .c-advisor_btn a {
        font-size: 20px;
        padding: 20px;
    }
}

/* p-case__pickup
--------------------*/
.p-case__picup {
    padding-bottom: 40px;
    border-bottom: 1px solid #ccc;
}
.p-case__thumb {
    width: 100%;
    transition: 0.3s;
}
.p-case__thumb .p-case__mask {
    display: block;
    filter: drop-shadow(1px 1px 3px rgba(0, 0, 0, 0.05));
    margin-bottom: 10px;
    overflow: hidden;
    border-radius: 6px;
    transform: translateY(0px) scale(0.999);
    transition: 0.3s;
}
.p-case__thumb .p-case__mask img,
.p-case__thumb .p-case__mask:hover img {
    image-rendering: smooth;
    -webkit-backface-visibility: hidden;
}
.p-case__thumb:hover,
.p-case__thumb:hover .p-case__mask {
    opacity: 0.9;
    transform: translateY(2px) scale(1.01);
    transition: 0.3s;
    image-rendering: smooth;
    -webkit-backface-visibility: hidden;
}
.p-case__introduction {
    width: 100%;
}
.p-case__name {
    font-size: 20px;
    font-size: 2rem;
    font-weight: bold;
    margin: 0;
}
.p-case__name .tag_pickup {
    font-size: 10px;
    font-size: 1rem;
    color: #fff;
    padding: 4px 10px 4px 30px;
    background: #d6b96a url(../img/product/co/icon_pickup.svg) 1.1em center
        no-repeat;
    background-size: 11.5px 10px;
    display: inline-block;
    border-radius: 4px;
    transform: translate(5px, -4px);
}
.p-case__description {
    font-size: 13px;
    font-size: 1.3rem;
    margin: 0;
}
.p-case__url a {
    font-size: 13px;
    font-size: 1.3rem;
    color: #2d87c3;
}
.p-case__title {
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    margin: 20px 0 5px;
}
.p-case__title::before {
    content: "- ";
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
}
.p-case__problem {
    display: flex;
    flex-wrap: wrap;
}
.p-case__problem li {
    font-size: 12px;
    font-size: 1.2rem;
    background: #f5f6f7;
    padding: 5px 10px;
    border-radius: 5px;
    margin: 5px 5px 0 0;
}
.p-case__adopt li {
    font-size: 14px;
    font-size: 1.4rem;
    padding-left: 0.9em;
    text-indent: -0.9em;
}
.p-case__adopt li::before {
    content: "・";
    font-size: 12px;
    font-size: 1.2rem;
}
@media screen and (min-width: 768px) {
    .p-case__picup {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding-bottom: 0;
        border-bottom: none;
    }
    .p-case__thumb {
        width: 45%;
        transition: 0.4s;
        padding-top: 10px;
    }
    .p-case__introduction {
        width: 52%;
    }
}

/* co_flow
--------------------*/
.co_flow .entry_attention {
    text-align: center;
    font-size: 14px;
    font-size: 1.4rem;
}

.co_flow .flows {
    display: block;
    max-width: 880px;
    margin: 30px auto 0;
}
.co_flow .flows li {
    clear: both;
    padding: 20px 0;
}
.co_flow .flows li h3 {
    margin: 0 0 0 80px;
}
.co_flow .flows li p {
    margin: 0 0 0 80px;
}
.co_flow .flows li img {
    position: relative;
    float: left;
}

@media only screen and (min-width: 768px) {
    .co_flow {
        padding: 80px 0;
    }
    .co_flow .flows {
        display: -webkit-box;
        display: -webkit-flex;
        display: flex;
        -webkit-box-pack: justify;
        -webkit-justify-content: space-between;
        justify-content: space-between;
        max-width: 880px;
        text-align: center;
        margin: 60px auto 0;
    }
    .co_flow .flows li {
        width: 20%;
        padding: 0;
        position: relative;
    }
    .co_flow .flows li::after {
        content: "";
        display: block;
        width: 21px;
        height: 49px;
        background: url(../img/product/co/icon_arrow.png) center no-repeat;
        background-size: cover;
        position: absolute;
        top: 50%;
        right: 0;
        transform: translate(200%, -50%);
    }
    .co_flow .flows li:last-child::after {
        content: "";
        display: none;
    }
    .co_flow .flows li img {
        float: none;
    }
    .co_flow .flows li h3 {
        margin: 15px auto 10px;
    }
    .co_flow .flows li p {
        margin: auto;
        font-size: 1.4rem;
    }
}
@media only screen and (min-width: 992px) {
    .co_flow {
        padding: 100px 0;
    }
    .co_flow .flows {
        margin: 70px auto 0;
    }
}

/* co_plan
--------------------*/
.co_plan__header {
    text-align: center;
    color: #fff;
    padding: 20px 10px 10px;
}
.co_plan__header .co_plan__title {
    font-size: 2rem;
    font-weight: 700;
    margin: 10px;
}
.co_plan__header .co_plan__lead {
    font-size: 1.1rem;
}
.co_plan__cost li {
    padding: 14px 10px;
    text-align: center;
    font-size: 1.4rem;
}
.co_plan__cost li:first-child {
    padding: 20px 10px 5px;
}
.co_plan__cost li:nth-child(even) {
    background: #f8f8f8;
}
.co_plan__cost .co_plan__title {
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 700;
    height: 60px;
    margin: 0;
}
.co_plan__cost .co_plan__title strong {
    display: block;
    font-size: 1.4rem;
    margin-right: 10px;
}
.co_plan__cost .co_plan__title .co_plan__price {
    display: block;
    font-size: 2rem;
    text-align: left;
    line-height: 1.4;
}
.co_plan__cost .co_plan__explanation {
    display: inline-block;
    font-size: 1.1rem;
    text-align: left;
}
.co_plan__subtitle {
    text-align: center;
    font-size: 1.4rem;
    font-weight: 700;
    padding: 12px 10px;
    margin: 0;
}
.co_plan__function li {
    padding: 14px 15%;
    font-size: 1.4rem;
    font-weight: 700;
}
.co_plan__function li a {
    text-decoration: underline;
}
.co_plan__function li:nth-child(even) {
    background: #f8f8f8;
}
.co_plan__function li::before {
    content: "";
    display: inline-block;
    background-size: contain;
    width: 14px;
    height: 9px;
    padding-right: 20px;
}

.co_plan .u-btn {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
}
.co_plan .u-btn a,
.co_plan .u-btn span {
    display: block;
    font-size: 1.4rem;
    font-weight: 700;
    padding: 15px;
    color: #fff;
    text-align: center;
    border-radius: 32px;
}
.co_plan .p-price_note {
    margin: -3rem 0 4rem;
    text-align: center;
    font-size: 1.4rem;
}
.p-price_note {
    color: #e55747;
}
@media only screen and (min-width: 768px) {
    .co_plan .u-btn {
        width: 75%;
    }
    .co_plan .u-btn a,
    .co_plan .u-btn span {
        padding: 20px;
    }
}

/*Liteプラン*/
.co_plan__lite {
    width: 90%;
    background: #fff;
    position: relative;
    border: 1px solid #ffcc00;
    border-radius: 10px;
    overflow: hidden;
    margin: 0 auto 30px;
    padding-bottom: 10rem;
}
.co_plan__lite .co_plan__header,
.co_plan__lite .co_plan__subtitle {
    background: #ffcc00;
    color: #fff;
}
.co_plan__lite .co_plan__function li::before {
    background: url("../img/product/co/icon_check_lite.svg") no-repeat;
}
.co_plan__lite .u-btn a,
.co_plan__lite .u-btn span {
    background: #ffcc00;
}
.co_plan__lite .u-btn a:hover {
    background: #ffb700;
}
/*Standardプラン*/
.co_plan__standard {
    width: 90%;
    background: #fff;
    position: relative;
    padding-bottom: 10rem;
    border: 1px solid #57acb3;
    border-radius: 10px;
    overflow: hidden;
    margin: 0 auto;
}
.co_plan__standard .co_plan__header,
.co_plan__standard .co_plan__subtitle {
    background: #57acb3;
    color: #fff;
}
.co_plan__standard .co_plan__function li::before {
    background: url("../img/product/co/icon_check_st.svg") no-repeat;
}
.co_plan__standard .co_plan__function li.u_icon__plus::before {
    background: url("../img/product/co/icon_plus_st.svg") no-repeat;
    width: 14px;
    height: 14px;
    transform: translate(1px, 2px);
}
.co_plan__recommend {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    margin: 0;
    padding: 142px 0 10px;
    display: none;
}
.co_plan__recommend .u-pos {
    display: inline-block;
    background: #57acb3;
    color: #fff;
    font-size: 1.4rem;
    font-weight: 700;
    margin: 0;
    padding: 15px 10px;
    border-radius: 0 10px 10px 0;
}
.co_plan__standard .co_plan_notice a {
    background: #ff8e8e;
    cursor: default;
}
.co_plan__tax {
    font-size: 1.2rem;
    text-align: right;
    margin: 10px auto 20px;
    max-width: 80%;
}
.co_plan__standard .u-btn a {
    background: #57acb3;
}
.co_plan__standard .u-btn a:hover {
    background: #3f939a;
}
.p-co_point .p-comparison__standard {
    margin-top: 6rem;
}
.p-co_point .p-comparison__standard .c-co_lead__txt {
    margin-bottom: 6rem;
}
.p-co_point .c-features-point:last-child {
    margin-bottom: 5rem !important;
}
.p-features-manual {
    margin-top: 2rem !important;
}
.p-features-manual a {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
}
.p-features-manual a {
    width: 48% !important;
    padding: 0.5rem !important;
}
.p-features-manual p {
    font-size: 1.1rem;
}
.p-features-manual a:after {
    right: 8px !important;
    width: 6px !important;
    height: 6px !important;
}
@media only screen and (min-width: 768px) {
    .co_plan__table {
        display: flex;
        justify-content: center;
    }
    .co_plan__recommend {
        display: block;
    }
    /*Liteプラン*/
    .co_plan__lite {
        width: 330px;
        margin: 0;
    }
    /*Standardプラン*/
    .co_plan__standard {
        width: 360px;
        margin: 0 0 0 40px;
    }
    .co_plan__tax {
        max-width: 690px;
    }
    .p-co_point .p-comparison__standard {
        margin-top: 10rem;
    }
    .p-features-manual a {
        width: 47% !important;
    }
    .p-features-manual p {
        font-size: 1.4rem;
    }
    .p-features-manual a:after {
        right: 15px !important;
        width: 8px !important;
        height: 8px !important;
    }
}
.co_plan__note {
    color: #000;
    text-align: center;
}
.co_plan__note a {
    text-decoration: underline;
}
.c-co_txt__underline {
    text-decoration: underline;
}

/* co_faq
--------------------*/
.section.co_faq {
    background: #f5f5f5;
}
.co_faq_list {
    max-width: 954px;
    margin: 20px auto 40px;
}
.co_faq_list li {
    margin-bottom: 20px;
}
.co_faq_list .co_faq_title {
    position: relative;
    background: #fff;
    padding: 20px 40px;
    box-sizing: border-box;
    margin: 0;
}
.co_faq_list .co_faq_title:hover {
    cursor: pointer;
    background: #404c54;
    color: #fff;
}
.co_faq_list .co_faq_title::before {
    content: "Q.";
    position: absolute;
    top: 18px;
    left: 20px;
}
.co_faq_list .co_faq_text {
    padding: 20px 40px 20px 30px;
    margin: 0;
    background: #fff;
    display: none;
    line-height: 2;
    position: relative;
}
.co_faq_list .co_faq_text a {
    text-decoration: underline;
    color: #337ab7;
}
.co_faq_list .co_faq_text a:hover {
    text-decoration: none;
}
.acordion_icon {
    position: absolute;
    top: 24px;
    right: 20px;
    width: 16px;
    height: 16px;
    display: inline-block;
}
.acordion_icon::before {
    content: "";
    display: block;
    width: 16px;
    height: 1px;
    background: #333;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}
.acordion_icon::after {
    content: "";
    display: block;
    width: 1px;
    height: 16px;
    background: #333;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}
.co_faq_list .co_faq_title:hover .acordion_icon::before,
.co_faq_list .co_faq_title:hover .acordion_icon::after {
    background: #fff;
    opacity: 1;
    transition: 0.3s;
}
/* active */
.co_faq_list .is-active .co_faq_title {
    cursor: pointer;
    background: #404c54;
    color: #fff;
}
.co_faq_list .is-active .acordion_icon::before {
    background: #fff;
}
.co_faq_list .is-active .acordion_icon::after {
    background: #fff;
    opacity: 0;
}
.co_faq_list .is-active .co_faq_title:hover .acordion_icon::after {
    opacity: 0;
}
.co_faq .button_area {
    padding: 0 20px;
}
@media only screen and (min-width: 768px) {
    .co_faq {
        padding: 80px 0;
    }
    .co_faq_list .co_faq_title {
        padding: 20px 40px 20px 70px;
    }
    .co_faq_list .co_faq_title::before {
        top: 18px;
        left: 40px;
    }
    .co_faq_list .co_faq_text {
        padding: 20px 60px 20px 40px;
    }
    .acordion_icon {
        position: absolute;
        top: 23px;
        right: 40px;
        width: 20px;
        height: 20px;
        display: inline-block;
    }
    .acordion_icon::before {
        content: "";
        display: block;
        width: 20px;
        height: 1px;
        background: #333;
        position: absolute;
        top: 50%;
        left: 0;
        transform: translateY(-50%);
    }
    .acordion_icon::after {
        content: "";
        display: block;
        width: 1px;
        height: 20px;
        background: #333;
        position: absolute;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
    }
}
@media only screen and (min-width: 992px) {
    .co_faq {
        padding: 100px 0;
    }
}

/* Thanksページ */

.co_thanks .text {
    text-align: center;
}
.button_area .co-link {
    display: block;
    max-width: 360px;
    margin: 20px auto 0;
    padding: 20px 10px 15px;
    border-radius: 10px;
    font-size: 20px;
    font-size: 2rem;
}
.p-gg-form {
    padding: 6rem 0rem;
    text-align: center;
    box-sizing: border-box;
}
.p-gg-form iframe {
    height: 3150px;
}
.p-gg-form_pagetop {
    text-align: center;
    font-size: 1.5rem;
}
.p-gg-form_pagetop a {
    text-decoration: underline;
    color: #014d98;
}
@media only screen and (min-width: 768px) {
    .p-gg-form {
        padding: 6rem 5rem;
    }
    .p-gg-form iframe {
        height: 2900px;
    }
    .button_area .co-link {
        margin: 60px auto 0;
        border-radius: 10px;
        font-size: 24px;
        font-size: 2.4rem;
    }
}

/* コロナに負けるなキャンペーン */

.cp_covid-19 {
    background: url(../img/product/co/cp_covid-19/bg_covid-19_sp@2x.png);
    background-size: cover;
    color: #1f3660;
}
.cp_covid-19_inner {
    max-width: 954px;
    margin: 0 auto;
    padding: 40px 20px;
}
.cp_covid-19_msg {
    width: 100%;
    margin-bottom: 20px;
}
.cp_covid-19_msg .cp_covid-19_ttl {
    font-size: 2.1rem;
    font-weight: 700;
    text-align: center;
    margin-top: 0;
}
.cp_covid-19_subttl {
    display: block;
}
.cp_covid-19_msg p .pc {
    display: none;
}
.cp_covid-19_msg a {
    color: #1f3660;
    text-decoration: underline;
}
.cp_covid-19_img {
    width: 100%;
    text-align: center;
}
.cp_covid-19_bnr {
    margin-top: 25px;
    background: #fff9db;
    padding: 30px;
    border-radius: 14px;
}
.cp_covid-19_bnr .cp_covid-19_ttl {
    margin-bottom: 10px;
}
.cp_covid-19_btn {
    display: block;
    width: 100%;
    background: #ffcc00;
    text-align: center;
    font-size: 1.7rem;
    color: #1f3660;
    padding: 14px;
    border-radius: 28px;
}
@media only screen and (max-width: 767px) {
    .br-sp {
        display: none;
    }
}
@media only screen and (min-width: 768px) {
    .br-pc {
        display: none;
    }
    .cp_covid-19 {
        background: url(../img/product/co/cp_covid-19/bg_covid-19_pc@2x.png);
        background-size: cover;
    }
    .cp_covid-19_inner {
        padding: 40px 0;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
    }
    .cp_covid-19_msg {
        width: 60%;
        margin-bottom: 0;
    }
    .cp_covid-19_msg .cp_covid-19_ttl {
        text-align: left;
    }
    .cp_covid-19_subttl {
        display: inline-block;
        padding-left: 5px;
    }
    .cp_covid-19_msg p {
        font-size: 13px;
    }
    .cp_covid-19_msg p .pc {
        display: block;
    }
    .cp_covid-19_msg a {
        color: #1f3660;
        text-decoration: underline;
    }
    .cp_covid-19_msg a:hover {
        text-decoration: none;
    }
    .cp_covid-19_img {
        width: 40%;
        text-align: center;
    }
    .cp_covid-19_bnr {
        width: 100%;
        margin-top: 20px;
        padding: 11px 40px 10px;
        border-radius: 14px;
        display: flex;
        align-items: center;
    }
    .cp_covid-19_bnr .cp_covid-19_ttl {
        margin-bottom: 0;
        width: 60%;
    }
    .cp_covid-19_btn {
        width: 35%;
        margin: 0 2.5%;
        font-size: 1.7rem;
        padding: 14px;
        border-radius: 28px;
    }
}

/* co_soudankai
--------------------*/
.p-soudankai {
    padding: 0;
}
.p-soudankai__link {
    max-width: 954px;
    height: auto;
    width: 100%;
}
.p-soudankai__bnr {
    position: fixed;
    width: 100%;
    height: auto;
    max-width: 380px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    bottom: 0px;
    z-index: 3;
    box-shadow: 3px 3px 6px rgba(0, 0, 0, 0.1);
}
.p-soudankai__bnr__inner {
    position: relative;
}
.p-soudankai__bnr__btn--close {
    position: absolute;
    right: 0;
    top: 0;
    border: none;
    background: none;
    padding: 0;
    width: 44px;
    height: 44px;
}
.p-soudankai .closed {
    display: none !important;
}
@media only screen and (min-width: 768px) {
    .p-soudankai__bnr {
        right: 30px;
        bottom: 20px;
        left: auto;
        transform: none;
        -webkit-transform: none;
        -ms-transform: none;
    }
}

/* co_trial
--------------------*/
.p-co_trial {
    background: url(../img/product/co/bnr_trial_on@2x.png);
    background-size: cover;
    box-shadow: 0px 0px 12px 4px rgba(0, 0, 0, 0.04);
}

/* co_form co_support
------------------------*/

.p-co_form,
.p-co_support {
    padding: 50px 0;
}
.p-co_form__inner {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 3600px;
}
.p-co_form__inner iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.p-co_support__inner {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 1500px;
}
.p-co_support__inner iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
@media only screen and (min-width: 768px) {
    .p-co_form,
    .p-co_support {
        padding: 80px 0;
    }
    .p-co_form__inner {
        padding-top: 3550px;
    }
    .p-co_support__inner {
        padding-top: 1300px;
    }
}

/* -------------------------------- 
	20201222 構築ガイドページ
-------------------------------- */
.l-guide {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 20px 50px;
}

@media (min-width: 768px) {
    .l-guide {
        display: flex;
        flex-direction: row-reverse;
        padding: 0 0 100px;
    }
}

/* サイドナビ */
.l-guide .c-nav {
    margin-top: 40px;
    width: 100%;
}
.l-guide .c-nav__list {
    border: 1px solid #ccc;
    width: 100%;
    height: auto;
    border-radius: 6px;
    overflow: hidden;
}
.l-guide .c-nav__list .c-nav__title {
    border-top: 1px solid #ccc;
    padding: 0;
}
.l-guide .c-nav__list .c-nav__title:first-child {
    border-top: none;
}
.l-guide .c-nav__list .c-nav__title span {
    position: relative;
    padding: 10px 15px;
    font-size: 1.2rem;
}
.l-guide .c-nav__list .c-nav__title i {
    font-family: fontAwesome;
    color: #ccc;
    position: absolute;
    top: 15px;
    right: 20px;
    font-size: 1.8rem;
    cursor: pointer;
}
.l-guide .c-nav__list a {
    text-decoration: underline;
}
.l-guide .c-nav__list a:hover {
    text-decoration: none;
}
.l-guide .c-nav__list .c-nav__title > span {
    display: block;
    background: #f5f5f5;
    padding: 15px;
    color: #000;
    font-weight: 700;
    font-size: 1.3rem;
    text-decoration: none;
}
.l-guide .c-nav__title .c-nav__child li {
    border-top: 0 solid #f5f5f5;
    padding: 0 15px;
    opacity: 0;
    line-height: 0;
    font-size: 1.2rem;
    transition: 0.5s;
}
.l-guide .c-nav__title.is-active .c-nav__child li {
    border-top: 1px solid #f5f5f5;
    padding: 10px 15px;
    opacity: 1;
    transition: 0.5s;
    line-height: 1.6;
}

@media (min-width: 768px) {
    .l-guide .c-nav {
        margin-top: 60px;
        width: 25%;
    }
    .c-nav .c-sticky {
        position: -webkit-sticky;
        position: sticky;
        top: 80px;
    }
}
/* 構築ガイドメイン */
.l-guide .p-guide {
}
.p-guide .c-guide__title {
    margin-top: 40px;
    border: 1px solid #ccc;
    border-radius: 6px;
    background: #f5f5f5;
    font-size: 1.8rem;
    font-weight: 700;
    padding: 10px;
}
.p-guide .c-guide__subtitle {
    font-size: 1.6rem;
    font-weight: 700;
    padding: 10px;
    border-bottom: 1px solid #ccc;
    margin-top: 30px;
}
.p-guide .c-guide__subtitle::before {
    content: "- ";
}
.p-guide .c-guide__lead {
    padding: 0 10px;
    font-size: 1.4rem;
}
.p-guide .c-guide__lead a {
    text-decoration: underline;
}
.p-guide .c-guide__lead a:hover {
    text-decoration: none;
}
.p-guide .c-guide__btn a {
    position: relative;
    display: inline-block;
    text-align: center;
    min-width: 280px;
    padding: 15px 60px 15px 20px;
    font-weight: 700;
    border: 1px solid #ccc;
    margin: 10px 0 0 10px;
    font-size: 1.4rem;
}
.p-guide .c-guide__btn a:hover {
    background: #ffd000;
    color: #fff;
    border: 1px solid #fff;
}
.p-guide .c-guide__btn a::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    display: block;
    width: 8px;
    height: 8px;
    border-top: 1px solid #707070;
    border-right: 1px solid #707070;
    transform: translateY(-50%) rotate(45deg);
}
.p-guide .c-guide__btn a:hover::before {
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
}
.p-guide .c-guide__notes {
    background: #fafafa;
    padding: 20px;
    margin: 0 10px;
}
.u-highlight {
    background: linear-gradient(transparent 60%, #feefad 60%);
}
.p-guide .c-text__small {
    font-size: 1.2rem;
    color: red;
}
.p-guide p.c-guide__attensition {
    padding-left: 1rem;
    font-size: 1.2rem;
}
.p-guide p.c-guide__attensition a {
    text-decoration: underline;
}
.p-guide .p-trial h3 {
    padding: 2rem 1rem 0.2rem;
    border-bottom: 1px solid #ccc;
}
.p-guide .p-trial .p-trial__standard {
    background: #fcfce5;
    padding: 2rem;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.p-guide .p-trial .p-trial__standard li {
    width: 40%;
}
.p-guide .c-layout__col2 {
    display: flex;
}
@media (min-width: 768px) {
    .l-guide .p-guide {
        width: 75%;
        padding-right: 40px;
        box-sizing: border-box;
    }
    .p-guide .c-guide__title {
        margin-top: 60px;
        font-size: 2rem;
        padding: 10px 20px;
    }
    .p-guide .c-guide__subtitle {
        font-size: 1.6rem;
    }
}

/* -------------------------------------------------- */
/*
*  ec-cube.co リニューアル
-------------------------------------------------- */
/*
header .p-co__header
-------------------------------------------------- */
.co_pageheader {
    height: auto !important;
}
.p-co__header {
    position: static !important;
    margin: 0 auto !important;
    padding: 3rem 0 5rem !important;
    height: auto !important;
    -webkit-transform: translate(0%) !important;
    transform: translate(0%) !important;
}
.p-co__header .p-co__header_link {
    text-decoration: none;
    max-width: 420px;
}
.p-co__header .c-co_btn a.blue {
    background-color: #38c2eb;
    border-color: #38c2eb;
}
.p-co__header .c-co_btn a.blue:hover {
    background-color: #34b3d9;
    border-color: #34b3d9;
    opacity: 1;
}

/*
intro No.1
-------------------------------------------------- */
.p-intro_img {
    padding: 0rem 1rem;
    height: auto;
}
.p-intro_txt {
    padding: 1rem 0rem;
}
.p-intro_txt small {
    font-size: 1rem;
}

.c-co_title {
    font-size: 20px;
    font-size: 2rem;
    text-align: center;
    line-height: 1.4;
}

@media only screen and (min-width: 768px) {
    .c-co_title {
        font-size: 30px;
        font-size: 3rem;
    }

    .p-intro_img {
        width: 45%;
        height: auto;
        padding: 0rem 1rem;
    }
    .p-intro_txt {
        width: 54%;
        padding: 0rem 0rem;
    }
    .p-intro_lead {
        padding: 1.5rem 0rem;
    }
    .p-intro h2 {
        margin: 0;
        font-size: 2.2rem;
    }
    .p-intro .inner {
        max-width: 1064px;
    }
}

/*
onayami こんなお悩みはありませんか？
-------------------------------------------------- */
.p-onayami {
    position: relative;
    background: #ffd665 !important;
    padding: 6rem 0 !important;
}
.p-onayami:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -100px;
    border: 100px solid transparent;
    border-top: 30px solid #ffd665;
}
.p-onayami .u-underline {
    margin-bottom: 0;
}
.p-onayami_list {
    font-weight: bold;
    width: 90%;
    margin: 0 auto;
}
.p-onayami_list li {
    width: 100%;
    margin-bottom: 1rem;
    text-align: center;
}
.p-onayami_bnr {
    height: auto;
}
@media only screen and (min-width: 768px) {
    .p-onayami_list {
        max-width: 1064px;
    }
    .p-onayami_list li {
        width: 48%;
        margin-bottom: 0.5rem;
    }
    .p-onayami:before {
        margin-left: -200px;
        border: 200px solid transparent;
        border-top: 60px solid #ffd665;
    }
}
/* .p-onayami_list li{
        background: #fff;
        width: 90%;
        position: relative;
        padding: 2rem;
    }
    .p-onayami_list p{
        color: #383B4A;
        font-size: 1.9rem;
    }
    .p-onayami_icon{
        position: absolute;
        height: auto;
        right: 0;
        bottom: 0;
    }
    @media only screen and (min-width: 768px){
        .p-onayami_list li{
            background: #fff;
            width: 48%;
            max-width: 450px;
        }
    } */

/*
p-features 特徴
-------------------------------------------------- */
.p-features {
}
.c-co_lead__txt {
    margin: 3rem 0 4rem;
}
.c-co_lead__txt br {
    display: none;
}
.p-features__list {
    margin: 4rem auto 1rem;
}
.p-features__list li {
    text-align: center;
    width: 48%;
}
.p-features__list h3 {
    font-size: 1.8rem;
}
.p-features__list p {
    font-size: 1.4rem;
    text-align: left;
}
.p-features__note {
    margin-bottom: 6rem;
}
.c-features-point {
    clear: both;
    margin-bottom: 5rem;
}
.c-features-point__img {
    height: auto;
}
.c-features-point__txt h3 {
    font-size: 2rem;
    font-weight: bold;
}
.c-features-point__vertical {
    width: 100%;
}
.c-features-point__vertical h3 {
    text-align: center;
}
.p-features .c-co_btn {
    margin-top: 3rem;
}
@media only screen and (min-width: 768px) {
    .c-co_lead__txt {
        text-align: center;
    }
    .c-co_lead__txt br {
        display: block;
    }
    .p-features__list li {
        max-width: 180px;
    }
    .p-features__note {
        float: right;
        margin-bottom: 10rem;
    }
    .c-features-point__img {
        width: 48.875%;
    }
    .c-features-point__txt {
        width: 46.875%;
    }
    .c-features-point__txt a {
        text-decoration: underline;
    }
    .c-features-point__vertical {
        width: 46.875%;
        max-width: 440px;
    }
    .c-features-point__vertical {
    }
    .c-features-point {
        margin-bottom: 8rem;
    }
}

/*
 c-co_btn 2週間無料トライアル CVP
-------------------------------------------------- */
.c-co_cvp {
    padding: 6rem 0 5rem;
    text-align: center;
    background-color: #ecf6fa;
    overflow: hidden;
    position: relative;
}
.c-co_cvp:before {
    content: "";
    position: absolute;
    top: -250%;
    left: -10%;
    right: -10%;
    height: 500%;
    z-index: 0;
    background: url(../img/product/co/coLP/co_cvp_BG.svg) 0 0 repeat;
    transform: rotate(-30deg);
}
.c-co_cvp .inner {
    position: relative;
    z-index: 1;
}
.c-co_btn a {
    font-size: 1.6rem;
    border-radius: 0.6rem;
    border: 3px solid #ffcc00;
    content: "";
    display: block;
    text-align: center;
    text-decoration: none;
    padding: 1rem;
    width: 100%;
    max-width: 320px;
    font-weight: bold;
    box-sizing: border-box;
    background-color: #ffcc00;
    position: relative;
    margin: 1rem;
    color: #fff;
}
.c-co_btn a:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    display: block;
    width: 8px;
    height: 8px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: translateY(-50%) rotate(45deg);
}
.c-co_btn a.blue {
    background-color: #88c8ea;
    border: 3px solid #88c8ea;
}
.c-co_btn a.pink {
    background-color: #ea629b;
    border: 3px solid #ea629b;
}
.c-co_btn a.green {
    background-color: #57acb3;
    border: 3px solid #57acb3;
}
.c-co_btn a:hover {
    opacity: 0.8;
}
.c-co_btn p {
    margin: 0;
    text-align: center;
}

/*
c-co_point ポイント拡張
-------------------------------------------------- */
.p-co_point__txt {
    text-align: left;
}
.p-co_point__txt {
    text-align: left;
}
.p-co_point__txt br {
    display: none;
}
.p-co_point__list li {
    width: 49%;
    margin: 0.5%;
}
.p-point_btn__list li {
    width: 100%;
}
.p-point_btn__list {
    margin-top: 2rem;
}
.c-plus {
    position: relative;
    width: 36px;
    display: none;
    margin: 1rem auto 4.8rem;
}
.c-plus:before,
.c-plus:after {
    position: absolute;
    top: 5px;
    left: 50%;
    content: "";
    display: inline-block;
    width: 36px;
    width: 36px;
    border-top: 4px solid #ffcc00;
    transform: translateX(-50%);
}
.c-plus:after {
    top: 5px;
    left: -1px;
    transform: rotate(90deg);
}
.c-plus__pink:before,
.c-plus__pink:after {
    border-color: #ea629b !important;
}
.c-plus__green:before,
.c-plus__green:after {
    border-color: #57acb3 !important;
}
.p-point_btn__list .c-co_btn a {
    max-width: none;
}

@media only screen and (min-width: 768px) {
    .p-co_point__txt {
        text-align: center;
    }
    .p-co_point__txt br {
        display: block;
    }
    .p-co_point__list li {
        width: 19%;
        margin: 0.5%;
    }
    .p-point_btn__list li {
        width: 33%;
    }
    .c-plus {
        display: block;
    }
}
/*
c-co_plugin 充実した拡張プラグイン
-------------------------------------------------- */

.p-co_plugin__txt {
    text-align: center;
    margin-bottom: 4rem;
}
.p-co_plugin__list li {
    margin-bottom: 3rem;
}
.p-co_plugin__list a:hover img {
    opacity: 0.8;
}
.c-plugin__left {
    width: 43%;
    height: auto;
}
.c-plugin__right {
    width: 53%;
}
.c-plugin__cat {
    background: #88c8ea;
    font-size: 1.4rem;
    color: #fff;
    padding: 0.5rem 1rem;
}
.c-plugin__name {
    margin: 1rem 0 0.5rem;
}
.c-plugin__price {
    margin: 0 0 0.5rem;
    font-weight: bold;
}
.c-plugin__txt {
    font-size: 1.4rem;
    margin: 0;
}
.p-plugin-more__title {
    font-size: 2rem;
    text-align: center;
    font-weight: bold;
    line-height: 1.3;
    margin: 3rem 0 5rem;
}
.p-plugin-more__title {
    font-size: 2rem;
}
.p-more_small {
    font-size: 1.55rem;
}
.p-more_big {
    font-size: 3rem;
}
.p-plugin-more__list li {
    width: 48%;
    margin: 0 0 2rem;
}
.p-plugin-more__list li h3 {
    font-size: 1.6rem;
    text-align: center;
}
.p-plugin-more__list img {
    height: auto;
}
.p-plugin-more__list a:hover img {
    opacity: 0.8;
}
@media only screen and (min-width: 768px) {
    .p-co_plugin__list li {
        width: 48%;
    }
    .p-plugin-more__list li {
        width: 22%;
    }
    .p-plugin-more__title {
        font-size: 3rem;
        margin: 1rem 0 5rem;
    }
    .p-more_small {
        font-size: 2.2rem;
    }
    .p-more_big {
        font-size: 4rem;
    }
}
/*
 p-co_template 高品質なデザインテンプレート
-------------------------------------------------- */
.p-co_template {
    text-align: center;
}
.p-co_template__txt {
    margin-bottom: 4rem;
}
.p-co_template__list li {
    width: 48%;
    margin-bottom: 2rem;
}
.p-co_template__list .c-co_btn a:after {
    border: none;
}
.p-co_template__list a:hover img {
    transform: scale(1.05, 1.05);
    transition: 0.2s all;
}
.p-co_template__list img {
    height: auto;
    transition: 0.2s all;
}
.p-co_template .c-co_btn {
    margin: 1rem 0 0;
}
.p-co_template .c-co_btn p {
    font-size: 1.5rem;
}
@media only screen and (min-width: 768px) {
    .p-co_template__list li {
        width: 18%;
    }
}
/* -------------------------------- 
	.p-partner
-------------------------------- */
.p-partner {
    padding: 40px 20px;
    background: url(../img/product/reason/bg_header@2x.png) no-repeat;
    background-size: cover;
}
.p-partner__title {
    font-size: 20px;
    font-size: 2rem;
    color: #fff;
    text-align: center;
}
.p-partner__txt {
    text-align: center;
    color: #fff;
}
.p-partner__list {
    overflow: hidden;
    display: flex;
    margin: 40px 0;
}
.p-partner__list a {
    display: block;
    width: 160px;
    margin: 0 20px;
}
.p-partner .p-partner__btn a {
    font-size: 14px;
    font-size: 1.4rem;
}
@media only screen and (min-width: 768px) {
    .p-partner {
        padding: 80px 20px;
    }
    .p-partner__title {
        font-size: 24px;
        font-size: 2.4rem;
    }
    .p-partner .p-partner__btn a {
        font-size: 16px;
        font-size: 1.6rem;
    }
}
/*
 p-co_doc 国産ならではの安心 ドキュメントや情報も充実
-------------------------------------------------- */
.p-co_doc {
    background: url(../img/common/pattern_triangle.png) center center repeat !important;
}
.p-co_doc__list {
}
.p-co_doc__list li {
    background: #f8f8f8;
    padding: 3rem 2rem;
    text-align: center;
    margin: 0 auto 2rem;
}
.p-co_doc__txt {
    max-width: 320px;
    margin: 0 auto 2rem;
    text-align: left;
}
.p-co_doc__list .c-co_btn a {
    margin: 1rem 0;
}
.p-co_doc__list .c-co_btn a p {
    font-size: 1.5rem;
}
.p-co_doc__list .c-co_btn a:after {
    right: 1.2rem;
}
@media only screen and (min-width: 768px) {
    .p-co_doc__list li {
        width: 31%;
        margin-bottom: 0;
    }
}

/* -------------------------------- 
プラン比較ページ
------------------------------------- */
.p-plans__intro dl {
    width: 100%;
    background: #f9f9f9;
    padding: 2.5rem;
    box-sizing: border-box;
    margin-top: 1rem;
    margin-bottom: 3rem;
}
.p-plans__intro dl dt {
    color: #fc0;
    font-weight: bold;
    text-align: center;
    font-size: 2.2rem;
    margin-bottom: 1rem;
}
.p-plans .u-txt__red {
}
@media only screen and (min-width: 768px) {
    .p-plans__intro dl {
        width: 48%;
        margin-bottom: 0rem;
    }
    .p-plans .c-co_lead__txt {
        margin: 3rem 0;
    }
}

/*
 プラン比較表
-------------------------------------------------- */
.c-sticky_table thead th {
    /* 縦スクロール時に固定する */
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    /* tbody内のセルより手前に表示する */
    z-index: 1;
}
.sticky_table th:first-child {
    /* 横スクロール時に固定する */
    position: -webkit-sticky;
    position: sticky;
    left: 0;
}
.sticky_table thead th:first-child {
    /* ヘッダー行内の他のセルより手前に表示する */
    z-index: 2;
}
.p-comparison__table {
    width: 100%;
    text-align: center;
    border-spacing: 3px;
    word-break: break-all;
    border-collapse: separate;
}
.p-comparison__table th,
.p-comparison__table td {
    font-weight: bold;
    font-size: 1.3rem;
    text-align: center;
}
.c-table_plans__header,
.c-table_service__header {
    text-align: center;
    padding: 1em;
}
.c-table_plans__header.c-empty {
    background: transparent;
}
.c-table_plans__header.c-lite,
.c-table_plans__header.c-standard {
    background: #fc0;
    color: #fff;
    width: 32%;
    border-radius: 6px 6px 0px 0px;
}
.c-table_service__header {
    background: #e7f3f4;
    border: 1px solid #dbdbdb;
}
.p-comparison__table .c-table_body th {
    width: 23%;
}
.c-table__service-name {
    background: #fefae5;
    text-align: left !important;
    padding: 1rem 1.5rem;
    border: 1px solid #dbdbdb;
}
.c-table_plans__header.c-standard {
    background: #57acb3;
}
.c-table__data {
    padding: 1rem 0.5em;
    background: #fff;
    border: 1px solid #dbdbdb;
}
.c-no-data {
    background: #ededed;
}
.c-table__data .fa-circle-o {
    color: #ff9900;
    font-size: 3rem;
}
.c-table__data em {
    font-weight: bold;
    font-style: normal;
}
.c-table-note__midium {
    font-size: 90%;
    font-weight: normal;
    display: inline-block;
    text-align: left;
}
.c-table-note {
    font-size: 70%;
    font-weight: normal;
    margin: 0 0 0.5rem;
    display: inline-block;
    text-align: left;
}
.p-comparison__table a {
    text-decoration: underline;
}
.c-table_txt__padding {
    padding-top: 1.5rem;
}
@media only screen and (min-width: 768px) {
    .p-comparison__table th,
    .p-comparison__table td {
        font-size: 1.5rem;
    }
    .c-table-note__midium {
        font-size: 1.4rem;
        font-weight: normal;
    }
}

/*
 機能制限版トライアルについて
-------------------------------------------------- */
.p-comparison_trial {
    background: #fefae5;
    padding: 2rem 1.5rem;
    text-align: left;
    margin-top: 6rem;
}
.p-comparison_trial h3 {
    font-size: 1.8rem;
    text-align: center;
}
.p-comparison_trial__list {
    font-size: 1.4rem;
}
.p-comparison_trial__list li {
    display: inline-block;
    text-align: left;
    vertical-align: top;
    padding: 1rem 1.5rem;
}
.p-comparison_trial a {
    text-decoration: underline;
}
@media only screen and (min-width: 768px) {
    .p-comparison_trial {
        text-align: center;
    }
    .p-comparison_trial h3 {
        font-size: 2rem;
    }
}
/*
 スタンダードプランの特徴
-------------------------------------------------- */
.p-comparison__standard p {
    margin-bottom: 0;
}
.p-comparison__standard .c-features-point__txt h3 {
    margin: 0;
    text-align: center;
}
.p-comparison__standard .c-features-point__img {
    text-align: center;
    width: 100%;
    margin: 3rem 0 2rem;
}
.p-comparison__standard .c-features-point__img img {
    height: auto;
}

@media only screen and (min-width: 768px) {
    .p-comparison__standard .c-features-point__txt h3 {
        font-size: 2.3rem;
        text-align: left;
    }
    .p-comparison__standard .c-features-point__img {
        width: 46.875%;
        height: auto;
        margin: 0;
    }
    .p-comparison__standard .c-features-point {
        margin-top: 5rem;
        margin-bottom: 10rem;
    }
}
/*
 変更可能範囲 p-comparison__custom
-------------------------------------------------- */
.p-custom__chart {
    overflow-y: scroll;
}
.p-custom__chart img {
    max-width: 768px;
    height: auto;
}
.p-comparison__custom .c-co_btn a {
    max-width: 350px;
}
@media only screen and (min-width: 768px) {
    .p-custom__chart {
        overflow: visible;
    }
    .p-custom__chart img {
        width: 100%;
        max-width: none;
    }
    .p-comparison__custom .c-co_btn a {
        max-width: 350px;
    }
}

/*
 月額料金の比較
-------------------------------------------------- */
.p-comparison__price_table {
    margin: 0 auto;
    margin-bottom: 3rem;
}

.p-table_price {
    width: 100%;
    text-align: center;
    border-spacing: 3px;
    word-break: break-all;
    border-collapse: separate;
}
.p-table_price th,
.p-table_price td {
    text-align: center;
    font-weight: bold;
    font-size: 1.3rem;
    border: 1px solid #dbdbdb;
}
.c-table_price__header {
    text-align: center;
    padding: 0.5em 0.5em;
}
.c-table_price__header.p-month {
    background: #fefae5;
}
.c-table_price__header.p-lite,
.c-table_price__header.p-standard {
    background: #fc0;
    color: #fff;
    width: 35%;
}
.c-table_price__header.p-standard {
    background: #57acb3;
}
.c-table_price__data {
    padding: 1rem 0.5em;
    background: #fff;
}
.p-comparison__price-graph {
    background-color: #fefae5;
    padding: 3rem;
    text-align: center;
}
.p-comparison__price-graph img {
    width: 100%;
    height: auto;
}
.p-price-graph__title {
    font-size: 1.5rem;
    margin: 0;
    margin-bottom: 2rem;
}
@media only screen and (min-width: 768px) {
    .p-comparison__price_table {
        margin-bottom: 6rem;
    }
    .c-table_price__header {
        padding: 1em 0.5em;
    }
    .c-table_price__data {
        padding: 1em 0.5em;
    }
    .p-table_price th,
    .p-table_price td {
        font-size: 1.6rem;
    }
    .c-table_price__header.p-lite,
    .c-table_price__header.p-standard {
        width: 40%;
    }
    .p-comparison__price-graph {
        padding: 5rem;
    }
    .p-price-graph__title {
        font-size: 2.4rem;
    }
}
/* -------------------------------- 
	Parts 
-------------------------------- */
.u-maker__blue {
    background: linear-gradient(transparent 60%, #bcefff 60%);
}
.u-maker__yellow {
    background: linear-gradient(transparent 60%, #ffe395 60%);
}
.u-marker__gray {
    background: linear-gradient(transparent 60%, #f8f8f8 60%);
}
.u-txt__small {
    display: block;
    font-size: 1.3rem;
    line-height: 1.5;
    letter-spacing: 2px;
    font-weight: normal;
    padding-bottom: 0.5rem;
}
.u-txt__note {
    font-size: 1.3rem;
}
.u-txt__center {
    text-align: center;
}
.u-txt__left {
    text-align: left;
}
.u-txt__right {
    text-align: right;
}
.u-txt__bold {
    font-weight: bold;
}
.u-txt__green {
    color: #57acb3 !important;
}
.u-txt__red {
    color: #e55747;
}
.u-txt__underline {
    text-decoration: underline;
}
.u-bg_lightyellow {
    background-color: #fefae5;
}
.u-underline {
    position: relative;
    padding: 0 0 25px;
    margin: 0 0 28px;
    position: relative;
}
.u-underline:after {
    content: "";
    display: block;
    width: 50px;
    height: 2px;
    background: #ffcc00;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}
.u-underline__gray:after {
    background: #383b4e;
}
.u-pt20 {
    padding-top: 2rem;
}
@media only screen and (min-width: 768px) {
    .u-txt__small {
        font-size: 1.5rem;
    }
}
/*
* Flex素材
-------------------------------------------------- */
.u-flex {
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    flex-wrap: wrap;
}

.u-flex_between {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.u-flex_start {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: flex-start;
}
.u-flex_row-reverse {
    flex-direction: row-reverse;
}
.u-flex_around {
    justify-content: space-around;
}
.u-flex_center {
    justify-content: center;
}
.u-flex_align-top {
    align-items: flex-start;
}
.u-flex_align-bottom {
    align-items: flex-end;
}
.u-flex_align-middle {
    align-items: center;
}
.u-flex_align-start {
    align-items: flex-start;
}
.u-flex_align-end {
    align-items: flex-end;
}
.u-flex_align-center {
    align-items: center;
}
.u-flex_align-baseline {
    align-items: baseline;
}
.u-flex_align-stretch {
    align-items: stretch;
}
@media only screen and (max-width: 767px) {
    .fl-wrap {
        display: block;
    }
}

/*
* coLP headerナビ
-----------------------------------------------------------*/

.p-co_header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 998;
    width: 100%;
    height: auto;
    transition: 0.5s;
}
.p-co_header.js-scroll {
    top: -100px;
}
.p-co_header.js-active {
    width: 100%;
    height: 100%;
}
.js-active .p-co_header__nav {
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    padding-top: 110px;
}
.p-co_header__list {
    display: none;
}
.js-active .p-co_header__list {
    display: block;
}
.p-co_header__logo {
    position: absolute;
    top: 25px;
    left: 20px;
    width: 50px;
    height: 50px;
}
.p-co_header__logo .cb-logo_basic {
    width: 50px;
    height: 50px;
}
.p-co_header__list a {
    display: block;
    font-size: 15px;
    font-size: 1.5rem;
    color: #fff;
    font-weight: bold;
    padding: 20px 15px;
}
.p-co_header__link {
    text-align: center;
}
.p-co_header__cvp {
    margin-top: 40px !important;
}
.p-co_header__menu {
    position: absolute;
    top: 26px;
    right: 25px;
    width: 50px;
    height: 50px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
    cursor: pointer;
}
.p-co_header__menu span {
    position: absolute;
    display: block;
    width: 25px;
    height: 2px;
    background: #000;
}
.p-co_header__menu span:nth-child(1) {
    top: 32%;
    left: 50%;
    transform: translate(-50%, 0);
}
.p-co_header__menu span:nth-child(2) {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.p-co_header__menu span:nth-child(3) {
    bottom: 32%;
    left: 50%;
    transform: translate(-50%, 0);
}
.js-active .p-co_header__menu span:nth-child(1) {
    width: 30px;
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
}
.js-active .p-co_header__menu span:nth-child(2) {
    display: none;
}
.js-active .p-co_header__menu span:nth-child(3) {
    width: 30px;
    bottom: 50%;
    transform: translate(-50%, 50%) rotate(-45deg);
}

@media (min-width: 768px) {
    .p-co_header.js-view {
        background: rgba(255, 255, 255, 0.9);
    }
    .p-co_header__logo {
        top: 13px;
        left: 30px;
    }
    .p-co_header__menu {
        display: none;
    }
    .p-co_header__list {
        display: flex;
        justify-content: flex-end;
        align-items: center;
        padding: 10px 30px 10px 100px;
    }
    .p-co_header__list a {
        font-size: 16px;
        font-size: 1.6rem;
    }
    .p-co_header.js-view a {
        color: #000;
    }
    .p-co_header__list a:hover {
        text-decoration: underline;
    }
    .p-co_header__list .p-co_header__cvp {
        margin: 0 0 0 20px !important;
        padding: 10px 30px;
        border-radius: 30px;
        color: #fff !important;
    }
    .p-co_header__list .p-co_header__cvp::after {
        display: none;
    }
    .p-co_header__list .p-co_header__cvp:hover {
        text-decoration: none;
        background: #34b3d9;
    }
}

/*
* coLP セキュリティコンテンツ
-----------------------------------------------------------*/
.p-co_security {
}
.p-co_security .inner {
    max-width: 1000px;
}
.p-co_security .p-security__lead {
    text-align: center;
}
.p-co_security .p-security__news {
    margin-top: 30px;
    text-align: center;
    background: #fffbe6;
    padding: 10px;
}
.p-co_security .p-security__news a {
    color: #014d98;
    text-decoration: underline;
}
.p-co_security .p-security__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    text-align: center;
}
.p-co_security .p-security__item {
    width: 48%;
    border: 2px solid #fedc33;
    border-radius: 8px;
    box-sizing: border-box;
    margin: 20px 0 0;
    padding: 30px 20px 10px;
}
.p-co_security .p-security__icon {
    width: 100%;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.p-co_security .p-security__icon img {
    max-width: 100%;
    height: auto;
}
.p-co_security .p-security__title {
    font-size: 16px;
    font-size: 1.6rem;
    height: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 32px;
}
.p-co_security .p-security__description {
    font-size: 13px;
    font-size: 1.3rem;
}
@media (min-width: 768px) {
    .p-co_security {
        padding: 80px 0;
    }
    .p-co_security .p-security__item {
        width: 22%;
        margin: 30px 0 0;
        padding: 40px 20px 20px;
    }
}
@media (min-width: 992px) {
    .p-co_security {
        padding: 100px 0;
    }
}

/*
* EC-CUBEアドバイザーバナー
-----------------------------------------------------------*/
.c-floatingbnr {
    max-width: 75%;
    bottom: 10px;
    left: 10px;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
    cursor: pointer;
}
.c-floatingbnr .c-floatingbnr__close {
    width: 30px;
    height: 30px;
    background: #fdc300;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 50%;
    cursor: pointer;
}
.c-floatingbnr .c-floatingbnr__close:hover {
    background: rgb(54, 54, 54);
}
.c-floatingbnr .c-floatingbnr__close::before,
.c-floatingbnr .c-floatingbnr__close::after {
    content: "";
    display: block;
    width: 20px;
    height: 1px;
    background: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
}
.c-floatingbnr .c-floatingbnr__close::before {
    transform: translate(-50%, -50%) rotate(45deg);
}
.c-floatingbnr .c-floatingbnr__close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}
@media (min-width: 450px) {
    .c-floatingbnr {
        width: 375px;
        bottom: 90px;
        left: auto;
        right: 30px;
    }
    .c-floatingbnr .c-floatingbnr__close {
        width: 40px;
        height: 40px;
        /*top: -20px;
        right: -20px;*/
    }    
}
/* .c-overlay {
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.8);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    display: none;
    cursor: pointer;
}
.c-popup {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    height: auto;
    background: #fff;
    z-index: 1000;
    padding: 30px 10px;
    margin-top: 60px;
    display: none;
}
.c-popup__close {
    width: 40px;
    height: 40px;
    background: #fdc300;
    position: absolute;
    top: -20px;
    right: -20px;
    border-radius: 50%;
    cursor: pointer;
    display: none;
}
.c-popup__close:hover {
    background: #001531;
}
.c-popup__close::before,
.c-popup__close::after {
    content: "";
    display: block;
    width: 30px;
    height: 1px;
    background: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
}
.c-popup__close::before {
    transform: translate(-50%, -50%) rotate(45deg);
}
.c-popup__close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}
.c-popup .p-update__title {
    padding: 0 20px 15px;
    margin: 10px 0;
    border-bottom: 1px solid #ccc;
    font-size: 1.9rem;
    line-height: 1.4;
    font-weight: bold;
    background: url(../img/product/co/update/bg_update.svg) right bottom
        no-repeat;
}
.c-popup .p-update__title .u-text__small {
    font-size: 1.4rem;
    color: #fdc300;
}
.c-popup .p-update__lead {
    padding: 10px 20px 0;
    font-size: 1.4rem;
    margin-top: 0;
}
.c-popup .p-update__inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    justify-items: center;
}
.c-popup .p-security,
.c-popup .p-seo,
.c-popup .p-src,
.c-popup .p-pullrequest {
    width: 100%;
    padding: 0 0 20px 0;
    background: url(../img/product/co/update/bg_triangle.svg) left bottom
        no-repeat;
    margin-top: 20px;
}
.c-popup .p-pullrequest {
    padding-bottom: 10px;
}
.c-popup .p-security__title {
    font-size: 1.8rem;
    font-weight: bold;
    padding: 10px 10px 10px 70px;
    margin: 0 0 10px 0;
    background: url(../img/product/co/update/bg_security.svg) 10px center
        no-repeat;
}
.c-popup .p-seo__title {
    font-size: 1.8rem;
    font-weight: bold;
    padding: 10px 10px 10px 70px;
    margin: 0 0 10px 0;
    background: url(../img/product/co/update/bg_seo.svg) 10px center no-repeat;
}
.c-popup .p-src__title {
    font-size: 1.8rem;
    font-weight: bold;
    padding: 10px 10px 10px 70px;
    margin: 20px 0 10px 0;
    background: url(../img/product/co/update/bg_src.svg) 10px center no-repeat;
}
.c-popup .p-security__title .u-marker__gray,
.c-popup .p-seo__title .u-marker__gray,
.c-popup .p-src__title .u-marker__gray {
    padding: 10px 0;
}
.c-popup .p-security__list li,
.c-popup .p-seo__list li,
.c-popup .p-src__list li {
    font-size: 1.4rem;
    padding-left: 20px;
}
.c-popup .p-src__list {
    margin-top: 20px;
}
.c-popup .p-pullrequest {
    text-align: center;
}
.c-popup .p-pullrequest__title {
    font-size: 1.4rem;
    font-weight: bold;
    margin: 0;
    padding-top: 10px;
}
.c-popup .p-pullrequest__count {
    font-size: 3.4rem;
    font-weight: bold;
    margin: 5px 0 0 0;
    line-height: 1;
}
.c-popup .p-pullrequest__count .u-text__small {
    font-size: 1.6rem;
}
.c-popup .p-pullrequest__btn {
    margin: 6px 0 0 0;
}
.c-popup .p-pullrequest__btn a {
    display: block;
    width: 80%;
    margin: 0 auto;
    background: #5ca6f0;
    color: #fff;
    font-size: 1.4rem;
    font-weight: bold;
    border-radius: 4px;
    padding: 10px;
}
.c-popup .p-pullrequest__btn a:hover {
    background: #4b98e5;
}
.c-popup .p-pullrequest > .u-text__small {
    font-size: 1.2rem;
    margin: 5px 0 0;
}
.c-popup .p-update__btn {
    margin-top: 30px;
}
.c-popup .p-update__btn a {
    display: block;
    width: 90%;
    margin: 0 auto;
    background: #ffc400;
    color: #fff;
    font-size: 1.6rem;
    font-weight: bold;
    border-radius: 4px;
    padding: 15px;
    text-align: center;
}
.c-popup .p-update__btn a:hover {
    background: #001531;
}
.c-popup .p-update__annotation {
    font-size: 1.2rem;
    text-align: center;
}

@media (min-width: 718px) {
    .p-update__bnrTop {
        overflow: hidden;
        margin: 20px auto 0;
        border-radius: 6px;
        width: 90%;
        cursor: pointer;
    }
    .p-update__bnrTop:hover img {
        opacity: 0.8;
    }
    .c-popup {
        width: 840px;
        padding: 45px 50px;
        margin-top: 60px;
    }
    .c-popup .p-update__inner {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        justify-items: center;
        padding-left: 20px;
    }
    .c-popup .p-update__title {
        font-size: 2.6rem;
    }
    .c-popup .p-update__lead {
        font-size: 1.6rem;
    }
    .c-popup .p-security__title {
        font-size: 2rem;
    }
    .c-popup .p-seo__title {
        font-size: 2rem;
    }
    .c-popup .p-src__title {
        font-size: 2rem;
    }
    .c-popup .p-security,
    .c-popup .p-seo,
    .c-popup .p-src,
    .c-popup .p-pullrequest {
        width: 48%;
        padding: 0 0 20px 0;
        background: url(../img/product/co/update/bg_triangle.svg) left bottom
            no-repeat;
        margin-top: 20px;
    }
    .c-popup .p-update__btn a {
        width: 70%;
    }
} */

/*
* 移行対応可能パートナー案内
-----------------------------------------------------------*/
.c-co_lead__txt a {
    text-decoration: underline;
}
.p-btn_txt__small {
    font-size: 1.2rem;
    color: #fff;
    font-weight: normal;
    display: block;
}
.p-co_ikoupartner__list {
    justify-content: space-between;
    display: flex;
    flex-wrap: wrap;
}

.p-co_ikoupartner__list a {
    width: 48%;
    background: #fff;
    box-shadow: 0px 3px 6px #00000029;
    box-sizing: border-box;
    margin-bottom: 3rem;
    position: relative;
    display: block;
}
.p-partner_detail {
    padding: 1.5rem 1.5rem 4.5rem;
}
.p-partner_logo {
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 150px;
}
.p-partner_logo img {
    transition: 0.2s all;
}
.p-co_ikoupartner__list a:hover img {
    transform: scale(1.05, 1.05);
    transition: 0.2s all;
}
.p-partner_name {
    padding-left: 0px;
    min-height: 65px;
    position: relative;
    margin-bottom: 1rem;
    text-align: center;
}
.partner_origin .p-partner_name {
    padding-left: 0;
    margin-bottom: 17px;
    min-height: inherit;
}
.p-partner_name::after {
    display: none;
    content: "";
    width: 40px;
    height: 40px;
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -34px;
    background-size: cover;
}
.p-partner_name .p-company_name {
    font-size: 1.6rem;
    font-weight: bold;
    margin: 0;
}
.p-partner_name .p-partner_address {
    color: #666;
    font-size: 1.1rem;
    margin: 0;
}
.p-partner_btn {
    color: #fff;
    background: #88c8ea;
    text-align: center;
    font-weight: bold;
    padding: 1rem 0;
    width: 100%;
    position: absolute;
    bottom: 0;
}
.p-co_ikoupartner__list a:hover .p-partner_btn {
    opacity: 0.8;
}
.p-partner_name::after {
    background-image: url(../img/integrate/budge_platinum.png);
}
.partner_gold .p-partner_name::after {
    background-image: url(../img/integrate/budge_gold_2017.png);
}
.partner_silver .p-partner_name::after {
    background-image: url(../img/integrate/budge_silver_2017.png);
}
.partner_bronze .p-partner_name::after {
    background-image: url(../img/integrate/budge_bronze_2017.png);
}
.partner_normal .p-partner_name::after {
    background-image: url(../img/integrate/budge_normal_2017.png);
}
.partner_pre .p-partner_name::after {
    background-image: url(../img/integrate/budge_pre_2017.png);
}

@media (min-width: 768px) {
    .p-co_ikoupartner__list {
        justify-content: flex-start;
    }
    .p-co_ikoupartner__list a {
        width: 30%;
        margin: 0 1.5% 5rem;
        background: #fff;
    }
    .p-partner_detail {
        padding: 2.5rem 1.5rem 4.5rem;
    }
    .p-partner_name .p-company_name {
        font-size: 2rem;
        font-weight: bold;
        margin: 0;
    }
    .p-partner_name {
        text-align: left;
        padding-left: 65px;
    }
    .p-partner_name::after {
        display: block;
        width: 55px;
        height: 55px;
    }
}
/*
* オリコプラン注意喚起案内
-----------------------------------------------------------*/

.p-co__orico-notice {
    width: 100%;
    background: #fff;
    padding: 16px 20px 18px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.p-co__orico-notice .p-co__orico-header {
    text-align: center;
    font-weight: bold;
    color: #ff4752;
    margin: 0 0 5px 0;
    font-size: 1.5rem;
}
.p-co__orico-notice img {
    width: 38px;
    height: auto;
    margin: 0 0 3px 0;
}
.p-co__orico-notice .p-co__orico-header .p-simpleform_note {
    font-size: 1.1rem;
    color: #ff4752;
    text-align: left;
    margin: 0;
    font-weight: normal;
    vertical-align: super;
}
.p-co__orico-notice .p-co__orico-note {
    color: #000;
    font-size: 1.3rem;
    text-align: center;
    margin: 0rem 0;
    font-weight: normal;
}
.p-museo-slab {
    font-family: museo-slab, sans-serif;
    font-style: normal;
    font-weight: 900;
    font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
    .p-co__orico-notice {
        text-align: center;
        padding: 23px 0 23px 0;
        flex-direction: row;
    }
    .p-co__orico-notice > div {
        padding: 0 0 7px 0;
    }
    .p-co__orico-notice .p-co__orico-header {
        text-align: left;
        margin: 0 0 0px 0;
        font-size: 1.8rem;
    }
    .p-co__orico-notice .p-co__orico-note {
        text-align: left;
    }
    .p-co__orico-notice img {
        width: 60px;
        height: auto;
        margin: 0 10px 0px 15px;
    }
    .p-museo-slab {
        font-size: 2.2rem;
    }
}
.u-sp-none {
    display: none;
}
.u-sp-visible {
    display: block;
}
@media only screen and (min-width: 768px) {
    .u-sp-none {
        display: block;
    }
    .u-sp-visible {
        display: none;
    }
}
/*
 * バージョンアップについて
-------------------------------------------------- */
@media only screen and (min-width: 992px){
    .p-version section .inner{
        max-width: 1110px;
    }
}
/* はじめに ---- */
.p-version_security{
    background: #FEFAE5;
    padding: 3rem 3rem 4rem;
    text-align: center;
}
    .p-version_security__title{
        font-size: 1.8rem;
    }
    .p-version_security .c-lead__txt{
        text-align: left;
        margin: 0;
    }
.p-version_caution{
    background: #FEFAE5;
    padding: 3rem 3rem 3rem;
    text-align: center;
}
.p-version_caution__title{
    font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
    .p-version_security{
        padding: 3rem 0 5rem;
    }
    .p-version_security__title{
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .p-version_security__title h2{
        padding-left: 15px;
        font-size: 2.2rem;
    }
    .p-icon_caution{
        width: 58px;
        height: 58px;
    }
    .p-version_security .c-lead__txt{
        text-align: center;
    }
    .u-sp-none {
        display: block;
    }
    .u-sp-visible {
        display: none;
    }
    .p-version_caution__title{
        font-size: 1.8rem;
    }
}
/* バージョンアップの種類 ---- */
.p-varsion_type__2column{
    width: 100%;
    box-sizing: border-box;
}
.p-varsion_type__item{
    width: 100%;
    background: #fff;
    padding: 3rem 1rem;
    margin-bottom: 30px;
    text-align: center;
}
.p-varsion_item__title{
    font-size: 1.8rem;
    font-weight: bold;
}
.p-varsion_item__img{
    padding: 2.5rem 0 2rem;
}
.p-varsion_type__item .c-lead{
    text-align: left;
    margin-top: 0;
}
.p-varsion_type__item dd .c-lead:last-child{
    margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
    .p-varsion_type__2column {
        display: flex;
        justify-content: space-between;
    }
    .p-varsion_item__title{
        font-size: 2.5rem;
        font-weight: bold;
    }
    .p-varsion_type__item{
        padding: 4rem;
        width: 48%;
    }
    .p-varsion_item__img{
        padding: 2.5rem 0 2rem;
    }
}

/* メジャーバージョンアップを実施したい場合 ---- */
.p-majorversion__content{
    background: #f5f5f5;
    margin-bottom: 3rem;
    padding: 3rem;
}
    .p-majorversion__txt{
        width: 100%;
        box-sizing: border-box;
    }
    .p-majorversion__title{
        border-bottom: 1px solid #707070;
        margin: 0 0 2rem;
        padding: 0 0 2rem;
    }
    .p-majorversion__title h3{
        text-align: center;
        font-size: 1.8rem;
        margin: 0;
    }
@media only screen and (min-width: 768px) {
    .p-majorversion__content{
        display: flex;
        padding: 4rem 4rem 4rem 0;
    }
    .p-majorversion__title{
        border-bottom: none;
        border-right: 1px solid #707070;
        display: flex;
        align-items: center;
        justify-content:center;
        width: 38%;
        padding: 0;
        margin: 0;
    }
    .p-majorversion__title h3{
        font-size: 2.5rem;
    }
    .p-majorversion__txt{
        width: 62%;
        padding-left: 4rem;
    }
    .p-majorversion__txt .c-lead{
        margin-top: 0;
    }
    .p-majorversion__txt .c-lead:last-child{
        margin-bottom: 0;
    }
}
/* 共通フローティングバナー設置のための調整コード */
.grecaptcha-badge {
    bottom: 120px !important;
}