@charset "utf-8";

/* -------------------------------------------------- 
 * front_page.css
 * 
 * トップページ(front_page)用のCSS
 * ※第1階層フォルダごとに読み込ませるCSSを分けて作成
-------------------------------------------------- */


/* -------------------------------- 
	Parts 
-------------------------------- */


/* heading */

.heading01::after {
    content: "";
    display: block;
    width: 1.3em;
    height: 0.1em;
    max-width: 50px;
    background: #383b4e;
    margin: 0.6em auto;
}

.inner>.heading01:first-child {
    margin-top: 0;
}


/* header
--------------------*/

/* .header a:link,
.header a:visited,
.header a:hover,
.header a:active {
    color: #ddd;
} */

@media only screen and (min-width: 992px) {
    .show-nav .header a:link,
    .show-nav .header a:visited,
    .show-nav .header a:hover,
    .show-nav .header a:active {
        color: #fff;
        border-color: 0 none;
    }
}

.header a:hover {
    color: #fff;
}

.header a.btn-default:hover {
    background-color: rgba( 225, 225, 225, .3);
}

.front_page {
    background: #000;
}

.front_page section .btn {
    min-width: 230px;
    padding: 14px 30px;
}

.front_page .contents {
    min-height: 100vh;
    position: relative;
    z-index: 2;
}


/* -------------------------------- 
	mainvisual area 
-------------------------------- */

.section_mainvisual {
    position: relative;
}

.bg_mainvisual {
    opacity: 0;
    -webkit-transition: opacity 1s ease 1s;
    transition: opacity 1s ease 1s;
}

.bg_mainvisual .sp {
    position: relative;
    height: 100vh;
    width: 100%;
    overflow: hidden;
    background: url(../img/top/mainvisual_static.png) center 50% no-repeat;
    background-size: cover;
}

.bg_mainvisual .sp img {
    display: none;
}

.play .bg_mainvisual {
    opacity: 1;
}

.section_mainvisual .inner {
    background: none;
    width: 100%;
    max-width: 100%;
    z-index: 1;
    margin: 0;
    padding: 0;
}

.section_mainvisual .text {
    text-align: center;
    width: 100%;
    padding: 0 8%;
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 1;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.section_mainvisual .scroll_down {
    width: 100%;
    text-align: center;
}

.section_mainvisual .scroll_down a {
    background: url(../img/top/scroll_down.png) center 25px no-repeat;
    background-size: 28px 72px;
    display: inline-block;
    overflow: hidden;
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: bold;
    color: #fff;
    padding-bottom: 80px;
}

.section_mainvisual .text .scroll_down {
    margin-top: 42px;
    opacity: 0;
    -webkit-transition: opacity 1s ease 0.6s;
    transition: opacity 1s ease 0.6s;
}

.section_mainvisual .text .scroll_down a {
    height: 40px;
    padding-bottom: 0px;
}

.section_mainvisual h1,
.section_mainvisual p {
    position: relative;
    text-align: center;
    margin: 0;
    opacity: 0;
    -webkit-transition: opacity 1s ease 0.5s;
    transition: opacity 1s ease 0.5s;
}

.play .section_mainvisual h1,
.play .section_mainvisual p,
.play .section_mainvisual .text .scroll_down {
    opacity: 1;
}

.section_mainvisual .main_title {
    color: #fc0;
    font-family: museo-slab, sans-serif;
    font-style: normal;
    line-height: 1.1;
    font-weight: 900;
    font-size: 50px;
    font-size: 5rem;
    margin-bottom: 20px;
}

.section_mainvisual .main_title small {
    font-size: 34%;
    font-weight: 500;
}

.section_mainvisual .main_title span {
    display: block;
    font-weight: 700;
    font-size: 18px;
    font-size: 1.8rem;
}

.section_mainvisual .cb-cubelogo {
    width: 100%;
    max-width: 546px;
    height: 75px;
    fill: #fff;
    vertical-align: bottom;
}

.section_mainvisual h1 {
    font-size: 16px;
    font-size: 1.6rem;
    color: #fff;
}

.section_mainvisual .button_area {
    padding: 30px 13% 10px;
}

.section_mainvisual .button_area li {
    padding: 10px 0;
}

.section_mainvisual .button_area li .btn {
    width: 100%;
}

.section_mainvisual .button_area li span.small {
    display: block;
    font-size: 75%;
    color: #fc0;
    padding: 10px 0 0;
}

.section_mainvisual .new_release {
    display: -webkit-flex;
    display: flex;
    justify-content: space-between;
    width: 320px;
    margin: 30px auto;
}

.section_mainvisual .goto_co {
    width: 150px;
    height: auto;
    background: url(../img/top/bt_eccube.png) no-repeat;
    background-size: contain;
}

.section_mainvisual .goto_co img {
    opacity: 0;
    transition: 0.5s;
}

.section_mainvisual .goto_co:hover img {
    opacity: 1;
}

.section_mainvisual .goto_eccube4_lp {
    width: 150px;
    height: auto;
    background: url(../img/top/bt_eccume_material.png) no-repeat;
    background-size: contain;
}

.section_mainvisual .goto_eccube4_lp img {
    opacity: 0;
    transition: 0.5s;
}

.section_mainvisual .goto_eccube4_lp:hover img {
    opacity: 1;
}

@media only screen and (max-width: 767px) {}

@media only screen and (min-width: 768px) {
    .section_mainvisual .inner {
        height: 100vh;
    }
    .bg_mainvisual {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        width: 100%;
        z-index: -1;
    }
    .bg_mainvisual img {
        display: none;
    }
    .section_mainvisual .main_title {
        font-size: 110px;
        font-size: 11rem;
        margin-bottom: 20px;
    }
    .section_mainvisual .main_title span {
        font-size: 32px;
        font-size: 3.2rem;
    }
    .section_mainvisual h1 {
        font-size: 23px;
        font-size: 2.3rem;
    }
    .section_mainvisual .scroll_down {
        position: absolute;
        left: 0;
        bottom: 0;
    }
    .section_mainvisual .scroll_down a {
        background-size: 28px 72px;
        padding-bottom: 80px;
        height: auto;
    }
    .section_mainvisual .new_release {
        width: 480px;
        margin: 60px auto 0;
    }
    .section_mainvisual .goto_co {
        width: 200px;
        height: auto;
    }
    .section_mainvisual .goto_eccube4_lp {
        width: 200px;
        height: auto;
    }
}


/* -------------------------------- 
	intro area 
-------------------------------- */

.section_intro {
    text-align: center;
    background: #fc0;
    padding: 50px 0 70px;
    position: relative;
    -webkit-transition: background 1s ease;
    transition: background 1s ease;
}

.demosite_slider {
    max-width: 883px;
    background-size: auto 100%;
    position: relative;
    -webkit-transition: background 0.3s ease;
    transition: background 0.3s ease;
}

.demosite_slider_text {
    margin-bottom: 30px;
}

.section_intro .inner .text .text-accent {
    font-size: 18px;
    font-size: 1.8rem;
    margin-bottom: 0.5em;
}

@media only screen and (min-width: 992px) {
    .section_intro {
        padding: 140px 0;
        overflow: hidden;
    }
    .section_intro .inner::before,
    .section_intro .inner::after {
        content: "";
        display: table;
    }
    .section_intro .inner::after {
        clear: both;
    }
    .section_intro .inner>div {
        float: left;
    }
    .section_intro .inner .text {
        width: 32%;
    }
    .section_intro .inner .text .text-accent {
        font-size: 20px;
        font-size: 2rem;
    }
    .section_intro .inner .image {
        width: 68%;
        padding-top: 3%;
    }
    .section_intro .inner .image .demosite_slider {
        margin-right: -15%;
        margin-left: -5%;
    }
}

.demosite_slider_text h3 {
    margin: 20px 0 30px;
    text-align: center;
    -webkit-transition: background 1s ease;
    transition: background 1s ease;
}

.demosite_slider_text h3 span {
    font-size: 10px;
    font-size: 1rem;
    display: block;
    margin: 0 auto;
}

.demosite_slider_text h3 img {
    display: inline-block;
    width: 100%;
    max-width: 147px;
}

@media only screen and (min-width: 768px) {
    .demosite_slider_text h3 img {
        max-width: 294px;
    }
}

.demosite_slider .wrap_image {
    position: relative;
    z-index: 1;
}

.demosite_slider_wrap {
    position: absolute;
    z-index: 1;
}

.demosite_pc_wrap {
    position: relative;
    width: 100%;
}

.demosite_pc_wrap .demosite_slider_wrap {
    left: -webkit-calc( 140 / 883 * 100%);
    left: calc( 140 / 883 * 100%);
    top: -webkit-calc( 30 / 461 * 100%);
    top: calc( 30 / 461 * 100%);
    width: -webkit-calc( 563 / 883 * 100%);
    width: calc( 563 / 883 * 100%);
}

.demosite_tb_wrap {
    position: absolute;
    left: -webkit-calc( 508 / 883 * 100%);
    left: calc( 508 / 883 * 100%);
    top: -webkit-calc( 90 / 461 * 100%);
    top: calc( 90 / 461 * 100%);
    width: -webkit-calc( 245 / 883 * 100%);
    width: calc( 245 / 883 * 100%);
}

.demosite_tb_wrap .demosite_slider_wrap {
    left: -webkit-calc( 11 / 245 * 100%);
    left: calc( 11 / 245 * 100%);
    top: -webkit-calc( 29 / 350 * 100%);
    top: calc( 29 / 350 * 100%);
    width: -webkit-calc( 222 / 245 * 100%);
    width: calc( 222 / 245 * 100%);
}

.demosite_sp_wrap {
    position: absolute;
    left: -webkit-calc( 692 / 883 * 100%);
    left: calc( 692 / 883 * 100%);
    top: -webkit-calc( 176 / 461 * 100%);
    top: calc( 176 / 461 * 100%);
    width: -webkit-calc( 134 / 883 * 100%);
    width: calc( 134 / 883 * 100%);
}

.demosite_sp_wrap .demosite_slider_wrap {
    left: -webkit-calc( 6 / 134 * 100%);
    left: calc( 6 / 134 * 100%);
    top: -webkit-calc( 43 / 267 * 100%);
    top: calc( 43 / 267 * 100%);
    width: -webkit-calc( 120 / 134 * 100%);
    width: calc( 120 / 134 * 100%);
}

.bgcolor0,
.bgcolor0 .demosite_slider_text h3 {
    background: #f9e9ea;
}

.bgcolor1,
.bgcolor1 .demosite_slider_text h3 {
    background: #cbe5d7;
}

.bgcolor2,
.bgcolor2 .demosite_slider_text h3 {
    background: #eee;
}

.bgcolor0 .demosite_slider {
    background: url(../img/top/bg_fashion.png) center bottom no-repeat;
    background-size: 100% auto;
}

.bgcolor1 .demosite_slider {
    background: url(../img/top/bg_interior.png) center bottom no-repeat;
    background-size: 100% auto;
}

.bgcolor2 .demosite_slider {
    background: url(../img/top/bg_sweets.png) center bottom no-repeat;
    background-size: 100% auto;
}


/* Dots */

.slick-dots {
    display: block;
    width: 100%;
    padding: 0;
    list-style: none;
    text-align: center;
}

.slick-dots li {
    position: relative;
    display: inline-block;
    width: 12px;
    height: 12px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer;
}

.slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 12px;
    height: 12px;
    padding: 5px;
    cursor: pointer;
    color: transparent;
    border: 0;
    outline: none;
    background: transparent;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
    outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
    opacity: 1;
}

.slick-dots li button:before {
    content: " ";
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    width: 10px;
    height: 10px;
    text-align: center;
    background-color: #a7a3ab;
    border-radius: 50%;
}

.slick-dots li.slick-active button:before {
    background-color: #fdd546;
}

.slick-dots li button.thumbnail img {
    width: 0;
    height: 0;
}


/* -------------------------------- 
	about area 
-------------------------------- */

.section_about {
    background: url(../img/common/pattern_wave.png) #fc0;
    text-align: center;
    padding: 70px 0;
}

.section_about .button_set {
    display: block;
}

.section_about .button_area {
    padding: 20px 0;
}

.section_about .text {
    max-width: 680px;
    margin: 0 auto;
}

.section_about .icons {
    display: -webkit-box;
    /* Android < 4.3 */
    display: -webkit-flex;
    /* safari(PC) */
    display: flex;
    -webkit-box-pack: justify;
    /* Android < 4.3 */
    -webkit-justify-content: space-between;
    /* safari(PC) */
    justify-content: space-between;
    max-width: 700px;
    margin: 30px auto;
}

.section_about .icons li {
    padding: 0 3%;
}

@media only screen and (min-width: 768px) {
    .section_about .icons {
        margin: 60px auto;
    }
    .section_about .text p {
        margin: 25px 0;
    }
    .section_about .button_set {
        display: flex;
        -webkit-box-pack: justify;
        -webkit-justify-content: center;
        justify-content: center;
    }
    .section_about .button_area {
        padding: 30px 25px;
    }
}

@media only screen and (min-width: 992px) {
    .section_about {
        padding: 120px 0 100px;
    }
}


/* -------------------------------- 
	function area 
-------------------------------- */

.section_function {
    text-align: center;
    background: #f7f7f9;
    padding: 50px 0;
}

.section_function .infinity_shape img {
    width: 100%;
    height: auto;
}

@media only screen and (max-width: 767px) {
    .section_function .infinity_shape {
        margin: 30px 0;
    }
    .section_function .infinity_shape ul {
        display: -webkit-box;
        /* Android < 4.3 */
        display: -webkit-flex;
        /* safari(PC) */
        display: flex;
        -webkit-flex-wrap: wrap;
        /* safari(PC) */
        flex-wrap: wrap;
    }
    .section_function .infinity_shape ul li {
        display: -webkit-box;
        /* Android < 4.3 */
        display: -webkit-flex;
        /* safari(PC) */
        display: flex;
        -webkit-box-align: center;
        /* Android < 4.3 */
        -webkit-align-items: center;
        /* safari(PC) */
        align-items: center;
        -webkit-box-pack: center;
        /* Android < 4.3 */
        -webkit-justify-content: center;
        /* safari(PC) */
        justify-content: center;
        -webkit-box-flex: 0;
        flex: 0 1 25%;
    }
}

.section_function .infinity_shape ul li span img:first-child {
    margin-bottom: 5px;
}

.section_function .infinity_shape li:nth-of-type(2n + 1) {
    background: #fc0;
}

.section_function .infinity_shape li:nth-of-type(-2n + 3) {
    background: #424555;
}

.section_function .infinity_shape li:nth-of-type(2n) {
    background: #424555;
}

.section_function .infinity_shape li:nth-of-type(-2n + 4) {
    background: #fc0;
}

@media only screen and (min-width: 768px) {
    .section_function {
        padding: 80px 0;
    }
    .section_function .infinity_shape {
        margin: 0;
    }
    .section_function .infinity_shape ul {
        margin: 50px auto 60px;
        width: 714px;
        height: 371px;
        position: relative;
    }
    /* 平行四辺形 */
    .section_function .infinity_shape ul::before,
    .section_function .infinity_shape ul::after {
        content: "";
        display: block;
        height: 114px;
        position: absolute;
        z-index: 0;
    }
    .section_function .infinity_shape ul::before {
        background: url(../img/top/parallelogram02.png);
        background-size: contain;
        width: 214px;
        height: 371px;
        left: 249px;
        top: 0;
    }
    .section_function .infinity_shape ul::after {
        background: url(../img/top/parallelogram01.png);
        background-size: contain;
        width: 214px;
        height: 371px;
        left: 250px;
        top: 1px;
    }
    .section_function .infinity_shape li {
        background: none !important;
        position: absolute;
        z-index: 1;
    }
    .section_function .infinity_shape li:nth-of-type(1) {
        top: 0;
        left: 108px;
    }
    .section_function .infinity_shape li:nth-of-type(2) {
        top: 0;
        left: 0;
    }
    .section_function .infinity_shape li:nth-of-type(3) {
        top: 186px;
        left: 0;
    }
    .section_function .infinity_shape li:nth-of-type(4) {
        top: 248px;
        left: 108px;
    }
    .section_function .infinity_shape li:nth-of-type(5) {
        top: 0;
        right: 108px;
    }
    .section_function .infinity_shape li:nth-of-type(6) {
        top: 0;
        right: 0;
    }
    .section_function .infinity_shape li:nth-of-type(7) {
        top: 186px;
        right: 0;
    }
    .section_function .infinity_shape li:nth-of-type(8) {
        top: 248px;
        right: 109px;
    }
    .section_function .infinity_shape li span {
        position: absolute;
        z-index: 1;
    }
}

@media only screen and (min-width: 992px) {
    .section_function {
        padding: 120px 0 100px;
    }
}


/* -------------------------------- 
	network area 
-------------------------------- */

.section_network {
    background: #383b4a;
    padding: 50px 0;
    text-align: center;
}

.section_network .heading01 {
    color: #fff;
}

.section_network .heading01::after {
    background: #fff;
}

.section_network .heading01+p {
    color: #fff;
}

.section_network .circle_shape {
    text-align: left;
}

.section_network .circle_shape ul {
    max-width: 500px;
    margin: 0 auto;
}

.section_network .circle_shape li {
    display: table;
    table-layout: fixed;
}

.section_network .circle_shape h3 {
    text-align: center;
    margin: 30px 0 10px;
}

@media only screen and (max-width: 767px) {
    .section_network .circle_shape {
        padding-top: 10px;
    }
    .section_network .circle_shape h3 {
        display: none;
    }
}

.section_network .circle_shape .icon {
    width: 56px;
    padding: 10px 10px 10px 0;
    display: table-cell;
    vertical-align: middle;
}

.section_network .circle_shape p {
    display: table-cell;
    padding: 10px 0;
}

.section_network .circle_shape strong {
    color: #fff;
    font-size: 16px;
    font-size: 1.6rem;
    vertical-align: middle;
}

.section_network .circle_shape .detail {
    display: block;
    color: #9c9da5;
}

.section_network .circle_shape img {
    width: 100%;
    height: auto;
}

@media only screen and (min-width: 768px) {
    .section_network {
        padding: 80px 0;
    }
    .section_network .inner {
        overflow: hidden;
    }
    .section_network .circle_shape {
        position: relative;
        margin-top: 50px;
    }
    .section_network .circle_shape h3 {
        position: absolute;
        top: 163px;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
    }
    .section_network .circle_shape ul {
        position: relative;
        height: 567px;
        background: url(../img/top/bg_circle.png) center center no-repeat;
    }
    .section_network .circle_shape ul li {
        display: block;
        position: absolute;
    }
    .section_network .circle_shape ul li .icon {
        padding: 0;
        width: 58px;
        display: inline-block;
    }
    .section_network .circle_shape ul li p {
        display: block;
        position: absolute;
        top: -4px;
        min-width: 12em;
        margin: 0;
        padding: 0;
    }
    .section_network .circle_shape strong {
        font-size: 15px;
        font-size: 1.5rem;
        letter-spacing: -0.08em;
    }
    .section_network .circle_shape .detail {
        font-size: 10px;
        font-size: 1rem;
    }
    .section_network .circle_shape ul li:nth-of-type(1) {
        text-align: center;
        left: 221px;
        top: 63px;
    }
    .section_network .circle_shape ul li:nth-of-type(2) {
        text-align: right;
        left: 108px;
        top: 99px;
    }
    .section_network .circle_shape ul li:nth-of-type(3) {
        text-align: right;
        left: 39px;
        top: 197px;
    }
    .section_network .circle_shape ul li:nth-of-type(4) {
        text-align: right;
        left: 39px;
        top: 315px;
    }
    .section_network .circle_shape ul li:nth-of-type(5) {
        text-align: right;
        left: 108px;
        top: 411px;
    }
    .section_network .circle_shape ul li:nth-of-type(6) {
        text-align: center;
        left: 221px;
        top: 446px;
    }
    .section_network .circle_shape ul li:nth-of-type(7) {
        text-align: left;
        left: 335px;
        top: 411px;
    }
    .section_network .circle_shape ul li:nth-of-type(8) {
        text-align: left;
        left: 404px;
        top: 314px;
    }
    .section_network .circle_shape ul li:nth-of-type(9) {
        text-align: left;
        left: 404px;
        top: 197px;
    }
    .section_network .circle_shape ul li:nth-of-type(10) {
        text-align: left;
        left: 334px;
        top: 100px;
    }
    .section_network .circle_shape ul li:nth-of-type(1) p {
        top: auto;
        bottom: 67px;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
    }
    .section_network .circle_shape ul li:nth-of-type(2) p {
        right: 67px;
    }
    .section_network .circle_shape ul li:nth-of-type(3) p {
        right: 67px;
    }
    .section_network .circle_shape ul li:nth-of-type(4) p {
        right: 67px;
    }
    .section_network .circle_shape ul li:nth-of-type(5) p {
        right: 67px;
    }
    .section_network .circle_shape ul li:nth-of-type(6) p {
        top: 61px;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
    }
    .section_network .circle_shape ul li:nth-of-type(7) p {
        left: 67px;
    }
    .section_network .circle_shape ul li:nth-of-type(8) p {
        left: 67px;
    }
    .section_network .circle_shape ul li:nth-of-type(9) p {
        left: 67px;
    }
    .section_network .circle_shape ul li:nth-of-type(10) p {
        left: 67px;
    }
}

@media only screen and (min-width: 992px) {
    .section_network {
        padding: 120px 0 100px;
    }
}

@media only screen and (min-width: 1200px) {
    .section_network .inner {
        display: table;
        table-layout: fixed;
        max-width: 1300px;
        margin: 0 auto;
    }
    .section_network .text .heading01::after {
        margin-left: 0;
    }
    .section_network .text {
        width: 33%;
        display: table-cell;
        padding: 0 50px;
        vertical-align: top;
        text-align: left;
    }
    .section_network .circle_shape {
        width: 67%;
        display: table-cell;
        padding: 0 50px;
        vertical-align: top;
    }
}


/* -------------------------------- 
	howto area 
-------------------------------- */

.section_howto {
    background: url(../img/common/pattern_triangle.png) #fc0;
    padding: 50px 0;
}

@media only screen and (min-width: 768px) {
    .section_howto {
        padding: 80px 0;
    }
}

.section_howto h2 {
    text-align: center;
}

.section_howto h3 {
    font-size: 20px;
    font-size: 2rem;
    margin: 0;
}

.section_howto .column {
    margin-bottom: 20px;
}

.section_howto .column h3 {
    position: relative;
    margin-top: -30px;
}

.section_howto .column h3::before {
    content: "";
    display: block;
    width: 54px;
    height: 54px;
    background: #fc0;
    margin: 0 auto 1em;
}

.section_howto .column h3 span {
    display: block;
    text-align: center;
    width: 100%;
    height: 54px;
    line-height: 54px;
    font-size: 30px;
    font-size: 3rem;
    vertical-align: middle;
    color: #fff;
    position: absolute;
    top: 0;
}

@media only screen and (min-width: 768px) {
    .section_howto .column_wrap {
        padding-top: 20px;
    }
    .section_howto .column h3 {
        margin-top: -40px;
        font-size: 24px;
        font-size: 2.4rem;
    }
    .section_howto .column h3::before {
        width: 72px;
        height: 72px;
        margin-bottom: 33px;
    }
    .section_howto .column h3 span {
        height: 72px;
        line-height: 72px;
        font-size: 34px;
        font-size: 3.4rem;
    }
}

.section_howto h4 {
    margin: 0.5em 0 0;
    font-size: 14px;
    font-size: 1.4rem;
}

.section_howto .column:nth-child(1)>div {
    background: #fff;
    color: #333;
    position: relative;
}

.section_howto .column .image {
    overflow: hidden;
}

.section_howto .column .image img {
    min-width: 100%;
}

.section_howto .column .text {
    text-align: center;
    padding: 5px 8% 20px;
}

.section_howto .column .text p {
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1.8;
}

.section_howto .column:nth-child(2)>div,
.section_howto .column:nth-child(3)>div {
    background: #fff;
    color: #333;
    position: relative;
}

.section_howto .links {
    margin: 8px 18px;
}

.section_howto .links a {
    display: inline-block;
    background: url(../img/common/arrow_right_circle.svg) left 0.2em no-repeat;
    background-size: 16px;
    font-size: 16px;
    font-size: 1.6rem;
    padding-left: 20px;
}

.section_howto .button_area {
    padding-top: 15px;
}

.section_howto .button_area .small {
    display: block;
    padding: 8px 18px;
    font-size: 14px;
}

@media only screen and (min-width: 992px) {
    .section_howto {
        padding: 130px 0;
    }
}


/* -------------------------------- 
	cases area 
-------------------------------- */

.p-caces {
    background: #f7f7f9;
    padding: 50px 0 40px;
}

.p-caces .inner {
    max-width: 1550px;
    padding-left: 3%;
    padding-right: 3%;
}

.p-caces__title {
    text-align: center;
}
.p-cases__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 30px;
}

.p-cases__list .c-thumb {
    width: 48%;
    margin-bottom: 20px;
}

.p-cases__list .c-thumb__inner {
    overflow: hidden;
    width: 100%;
    max-height: 108px;
    border-radius: 6px;
}

.p-cases__list .c-thumb__inner img {
    width: 100%;
    height: auto;
    transform: scale(.999999);
    transition: .4s;
    image-rendering: smooth;
    -webkit-backface-visibility: hidden;
}

.p-cases__list .c-thumb__inner:hover img {
    transform: scale(1.06);
}

.p-cases__list .p-cases__name {
    font-size: 14px;
    font-weight: 700;
    margin: 10px 0 0;
}

.p-cases__list .p-cases__data {
    font-size: 12px;
    margin: 0;
    color: #717171;
}

.p-cases__nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 10px;
}

.p-cases__nav .c-tab {
    margin: 5px 10px;
}

.p-cases__nav .c-tab a {
    font-size: 13px;
    font-weight: 700;
    display: block;
    padding: 5px 15px;
    background: #E5E5E5;
    border-radius: 18px;
    transform: scale(1);
}

.p-cases__nav .c-tab:hover a {
    background: #FECE2F;
    transform: scale(1.02);
}

.p-caces__btnset {
    margin: 30px auto;
    text-align: center;
}

.p-caces__btnset .c-btn {
    display: inline-block;
    min-width: 230px;
    padding: 14px 30px;
    box-sizing: border-box;
    position: relative;
    text-align: center;
}

.p-caces__btnset .c-btn::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 20px;
    display: block;
    width: 8px;
    height: 8px;
    border-top: 1px solid #707070;
    border-right: 1px solid #707070;
    transform: translateY(-50%) rotate(45deg);
}

.p-caces__btnset .c-btn__default {
    border: 1px solid #707070;
}

.p-caces__btnset .c-btn__primary {
    margin-top: 20px;
    border: 1px solid #FECE2F;
    background: #FECE2F;
}

@media (min-width: 576px) {
    .p-cases__list .c-thumb__inner {
        max-height: 145px;
    }
}

@media only screen and (min-width: 768px) {
    .p-caces {
        padding: 120px 0;
    }
    .p-cases__list {
        margin-top: 60px;
    }
    .p-cases__list .c-thumb__inner {
        max-height: 240px;
    }
    .p-cases__list .c-thumb {
        width: 23.5%;
        margin-bottom: 20px;
    }
    .p-cases__nav {
        margin-top: 20px;
    }
    .p-cases__nav .c-tab {
        margin: 10px 10px;
    }
    .p-caces__btnset {
        margin: 40px auto;
        text-align: center;
        max-width: 700px;
        display: flex;
        justify-content: center;
    }
    .p-caces__btnset .c-btn {
        min-width: 250px;
        margin: 0 25px;
    }
    .p-caces__btnset .c-btn__primary {
        margin-top: 0;
    }
}


/* -------------------------------- 
	news area
-------------------------------- */

.section_news {
    text-align: center;
    background: #fff;
    padding: 50px 0;
}

.section_news h3 {
    font-size: 14px;
    font-size: 1.4rem;
    color: #000;
    margin: 35px 0 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid #000;
}

.section_news .column:not(:first-of-type) h3 {
    margin-top: 60px;
}

.section_news a:not(.btn):link,
.section_news a:not(.btn):visited,
.section_news a:not(.btn):hover,
.section_news a:not(.btn):active {
    color: #333;
}

.section_news ul {
    margin: 0 auto;
}

.section_news ul li {
    text-align: left;
    line-height: 1.6;
    border-bottom: 1px solid #ccc;
}

.section_news ul li a {
    display: block;
}

.section_news ul li p {
    margin: 0;
    font-size: 14px;
    font-size: 1.4rem;
}

.section_news ul li .date {
    color: #383b4a;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    font-style: italic;
    margin: 0;
    padding: 0.8em 0 0.4em;
}

.section_news ul li .date .category {
    display: inline-block;
}

.section_news ul li .date .category::before {
    content: "/";
    margin: 0 5px;
}

.section_news ul li p:not(.date) {
    padding: 0 0 0.8em;
}

.section_news ul li a:hover p:not(.date) {
    text-decoration: underline;
}

.section_news .button_more {
    padding-top: 1.5em;
}

.section_news .button_more a {
    transition: all .2s ease;
}

.section_news .button_more a span {
    color: #383b4a;
    font-weight: bold;
    vertical-align: middle;
}

.section_news .button_more a i {
    vertical-align: middle;
    margin-left: 5px;
}

.section_news .button_more a:link i,
.section_news .button_more a:visited i,
.section_news .button_more a:active i {
    font-size: 20px;
    font-size: 2.0rem;
    color: #d4d4d4;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
}

.section_news .button_more .btn-xs {
    font-weight: 700;
    min-width: 180px;
    padding: 10px 20px;
}

.section_news .banner_area {
    padding: 50px 0 10px;
}
.section_news .c-eccubeday2021__bnr{
    padding: 20px;
    text-align: center;
}
.section_news .c-eccubeday2021__bnr a{
    display: inline-block;
    max-width: 800px;
    height: auto;
    transition: .3s;
}
.section_news .c-eccubeday2021__bnr a:hover{
    opacity: .8;
}

@media only screen and (min-width: 768px) {
    .section_news {
        padding: 80px 0 10px;
    }
    .section_news .inner {
        position: relative;
        overflow: hidden;
    }
    .section_news .heading01 {
        margin-bottom: 0;
    }
    .section_news h3 {
        padding-bottom: 15px;
    }
    .section_news .column:not(:first-of-type) h3 {
        margin-top: 35px;
    }
    .section_news .column {
        width: 48%;
        float: left;
        padding-bottom: 80px;
    }
    .section_news .column:nth-of-type(3n) {
        float: right;
    }
    .section_news ul li p {
        font-size: 16px;
        font-size: 1.6rem;
    }
    .section_news ul li .date {
        padding: 1.9em 0 0.5em;
        font-size: 14px;
        font-size: 1.4rem;
        word-wrap: break-word;
        overflow-wrap: break-word;
    }
    .section_news ul li p:not(.date) {
        padding-bottom: 1.5em;
    }
    .section_news .button_more {
        text-align: right;
    }
    .section_news .button_more .btn-xs {
        min-width: 180px;
        padding: 10px 20px;
    }
    .section_news .banner_area {
        clear: both;
        padding: 0 0 80px;
    }
    .section_news .banner_area a:hover img {
        opacity: 0.8;
    }
}

@media only screen and (min-width: 992px) {
    .section_news .inner {
        -webkit-box-sizing: content-box;
        box-sizing: content-box;
    }
    .section_news .column {
        width: 47.5%;
    }
    .section_news {
        padding: 100px 0 10px;
    }
}


/* -------------------------------- 
	tsubo area
-------------------------------- */

.section_tsubo {
    background: #fff;
    padding: 50px 0;
    text-align: center;
}
.section_tsubo .blognews>div a {
    background: #fff;
    display: block;
    color: #666;
    margin-bottom: 20px;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
    text-align: center;
}

@media only screen and (min-width: 768px) {
    .section_tsubo {
        padding: 80px 0;
        overflow: hidden;
    }
}

.section_tsubo .blognews {
    text-align: left;
    margin-bottom: 30px;
    padding-top: 10px;
}
.section_tsubo .blognews>div a:hover {
    background: rgba( 2555, 255, 255, 0.5);
}

.section_tsubo .blognews a strong {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 0 10px 10px;
    display: inline-block;
    font-weight: normal;
    text-align: left;
}

.section_tsubo .blognews a .date {
    font-size: 14px;
    font-size: 1.4rem;
    display: block;
    padding: 10px 10px 0;
    color: #ccc;
    font-style: italic;
    text-align: left;
}

@media only screen and (max-width: 767px) {
    .section_tsubo .blognews>div a:not(:first-child) {
        display: none;
    }
}

@media only screen and (min-width: 768px) {
    .section_tsubo .blognews {
        margin: 0 -10px;
    }
    .section_tsubo .blognews>div {
        display: -webkit-box;
        /*--- Androidブラウザ用 ---*/
        display: -ms-flexbox;
        /*--- IE10 ---*/
        display: -webkit-flex;
        /* safari(PC) */
        display: flex;
        -webkit-box-pack: justify;
        /*--- Androidブラウザ用 ---*/
        -ms-flex-pack: justify;
        /*--- IE10 ---*/
        -webkit-justify-content: space-between;
        /* safari(PC) */
        justify-content: space-between;
    }
    .section_tsubo .blognews>div a {
        margin: 0 10px 30px;
        position: relative;
        -webkit-box-flex: 0.0;
        -ms-flex: 0 1 47%;
        flex: 0 1 47%;
        display: -webkit-box;
        /*--- Androidブラウザ用 ---*/
        display: -ms-flexbox;
        /*--- IE10 ---*/
        display: -webkit-flex;
        /* safari(PC) */
        display: flex;
        -webkit-box-orient: vertical;
        /*--- Androidブラウザ用 ---*/
        -webkit-flex-direction: column;
        /* safari(PC) */
        flex-direction: column;
    }
    .section_tsubo .blognews>div a .img {
        position: relative;
        width: 100%;
        overflow: hidden;
    }
    .section_tsubo .blognews>div a .img::before {
        content: "";
        display: block;
        padding-top: 65%;
    }
    .section_tsubo .blognews a .date {
        padding: 14px 20px 8px;
    }
    .section_tsubo .blognews a strong {
        padding: 0 20px 20px;
    }
    .section_tsubo .blognews>div a .img span {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
    }
    .section_tsubo .blognews>div a .img span img {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate( -50%, -50%);
        min-height: 100%;
        min-width: 100%;
    }
    .section_tsubo .button_area {
        padding: 40px 0 0;
    }
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .section_tsubo .blognews>div {
        -webkit-flex-wrap: wrap;
        /* safari(PC) */
        flex-wrap: wrap;
    }
    .section_tsubo .blognews>div a:nth-last-of-type(-n+2) {
        display: none;
    }
}

@media only screen and (min-width: 992px) {
    .section_tsubo {
        padding: 100px 0 110px;
    }
    .section_tsubo .inner {
        padding: 0;
        max-width: 1410px;
    }
    .section_tsubo .blognews {
        padding: 45px 10px 10px;
    }
    .section_tsubo .blognews>div a {
        -ms-flex: 0 1 25%;
        flex: 0 1 25%;
        margin: 0 15px;
    }
}

@media only screen and (min-width: 968px) {
    /* -------------------------------- 
        mainvisual area 
    -------------------------------- */
    .bg_mainvisual img {
        display: none;
    }
    .bg_mainvisual video {
        display: block;
        position: fixed;
        right: 0;
        bottom: 0;
        min-width: 100%;
        min-height: 100%;
        width: auto;
        height: auto;
        left: 50%;
        top: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
    }
    .section_mainvisual .button_area li {
        display: inline-block;
    }
    /* -------------------------------- 
        howto area 
    -------------------------------- */
    .section_howto .column_wrap {
        width: 100%;
        margin: 0 auto;
        display: -webkit-box;
        /*--- Androidブラウザ用 ---*/
        display: -ms-flexbox;
        /*--- IE10 ---*/
        display: -webkit-flex;
        /* safari(PC) */
        display: flex;
        -webkit-box-pack: justify;
        /*--- Androidブラウザ用 ---*/
        -ms-flex-pack: justify;
        /*--- IE10 ---*/
        -webkit-justify-content: space-between;
        /* safari(PC) */
        justify-content: space-between;
    }
    .section_howto .column {
        background: #fff;
        -webkit-box-flex: 0.0;
        -ms-flex: 0 1 32%;
        flex: 0 1 32%;
    }
    .section_howto .column:nth-child(1) .image {}
    .section_howto .column:nth-child(1) .text {}
    .section_howto .column:nth-child(2)>div {}
    .section_howto .column:nth-child(2) .image {}
    .section_howto .column:nth-child(2) .text {}
}

@media only screen and (min-width: 992px) {
    /* -------------------------------- 
        Parts 
    -------------------------------- */
    .front_page .contents {
        font-size: 18px;
        font-size: 1.8rem;
    }
    .cases_slider .case .btn_detail {
        display: inline-block;
    }
}


/* -------------------------------- 
    MailMagazine area 
-------------------------------- */


/* mailmagazine_area */

.mailmagazine_area_fixed {
    z-index: 2;
    text-align: center;
    display: none;
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 100%;
    max-width: 344px;
    background: #e3e3e3;
    z-index: 2;
}

.mailmagazine_area_fixed .box_inner {
    position: relative;
}

.mailmagazine_area_fixed dl {
    margin: 0 auto;
    padding: 12px;
    max-width: 344px;
    max-height: 211px;
}

.mailmagazine_area_fixed dl dt,
.mailmagazine_area_fixed dl dd {
    padding: 0 10px 10px;
    vertical-align: middle;
    text-align: center;
}

.mailmagazine_area_fixed dl dt {
    padding: 0 30px 10px 10px;
    font-size: 15px;
    color: #424555;
    font-weight: bold;
    text-align: left;
}

.mailmagazine_area_fixed .form_mailmagazine {
    width: 100%;
    max-width: 367px;
    display: table;
    table-layout: fixed;
    margin: 0 auto;
}

.mailmagazine_area_fixed input {
    width: 80%;
    width: -webkit-calc( 100% - 70px);
    width: calc( 100% - 70px);
    line-height: 33px;
    height: 33px;
    padding: 0 15px;
    border: 0 none;
    border-radius: 0;
    box-shadow: none;
    text-align: left;
    vertical-align: middle;
    font-size: 16px;
    font-size: 1.6rem;
}

.mailmagazine_area_fixed button {
    text-align: center;
    vertical-align: middle;
    padding: 0 25px 0 20px;
    width: 70px;
    height: 33px;
    line-height: 33px;
    font-size: 16px;
    font-size: 1.6rem;
    box-shadow: none;
    border: 0 none;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
}

.mailmagazine_area_fixed .btn_close {
    position: absolute;
    right: 20px;
    top: 10px;
}

.mailmagazine_area_fixed .btn_close a {
    font-size: 26px;
    line-height: 1;
}

.mailmagazine_area_fixed .btn_close a:link {
    color: #424555;
    text-decoration: none;
}

.mailmagazine_area_fixed .btn_close a:visited {
    color: #424555;
    text-decoration: none;
}

.mailmagazine_area_fixed .btn_close a:hover {
    color: #424555;
    text-decoration: none;
    opacity: 0.7;
}

.mailmagazine_area_fixed .btn_close a:active {
    color: #424555;
    text-decoration: none;
}


/*
@media only screen and (max-width: 767px) {
    .front_page .mailmagazine_area_fixed {
        display: none;
    }
}
@media only screen and (min-width: 768px) {
    .front_page .mailmagazine_area {
        display: none;
    }
}
*/


/* EC-CUBE side告知 */

.news_side {
    position: fixed;
    bottom: 80px;
    right: 0;
    z-index: 999999;
    display: flex;
    justify-content: center;
    background: rgba(0, 0, 0, 0.6);
    transform: translateX(92.5%);
    transform: translateX(calc(100% - 28px));
    transition: .4s ease-out;
}

.news_side.is-open {
    transform: translateX(0%);
}

.news_side .btn {
    color: #fff;
    padding: 10px;
    line-height: 100px;
}

.news_side a {
    padding: 16px 20px 16px 0;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    color: #fff;
}

.news_side:hover {
    background: rgba(255, 255, 255, 1);
}

.news_side:hover .btn,
.news_side:hover a {
    color: #000;
}

.thum_news {
    position: relative;
    width: 140px;
    height: 90px;
}

.thum_news img {
    position: absolute;
    top: 0;
    left: 0;
}

.news_side .news_summary h3 {
    margin: 0 0 0 10px;
    color: #ffd400;
    letter-spacing: -.7px;
    font-size: 1.8rem;
}

.news_side .news_summary p {
    margin: 0 0 0 14px;
    font-size: 1.4rem;
    letter-spacing: 1px;
    line-height: 1.5;
}

@media only screen and (max-width: 767px) {
    .news_side {
        display: none;
    }
}


/* Generated with Bounce.js. Edit at https://goo.gl/6jrpDS */

@-webkit-keyframes bounce {
    0% {
        -webkit-transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    4% {
        -webkit-transform: matrix3d(1.432, 0, 0, 0, 0, 1.432, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.432, 0, 0, 0, 0, 1.432, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    7.91% {
        -webkit-transform: matrix3d(1.889, 0, 0, 0, 0, 1.889, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.889, 0, 0, 0, 0, 1.889, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    11.91% {
        -webkit-transform: matrix3d(2.189, 0, 0, 0, 0, 2.189, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.189, 0, 0, 0, 0, 2.189, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    15.82% {
        -webkit-transform: matrix3d(2.276, 0, 0, 0, 0, 2.276, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.276, 0, 0, 0, 0, 2.276, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    20.42% {
        -webkit-transform: matrix3d(2.196, 0, 0, 0, 0, 2.196, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.196, 0, 0, 0, 0, 2.196, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    24.92% {
        -webkit-transform: matrix3d(2.059, 0, 0, 0, 0, 2.059, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.059, 0, 0, 0, 0, 2.059, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    29.53% {
        -webkit-transform: matrix3d(1.96, 0, 0, 0, 0, 1.96, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.96, 0, 0, 0, 0, 1.96, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    34.03% {
        -webkit-transform: matrix3d(1.931, 0, 0, 0, 0, 1.931, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.931, 0, 0, 0, 0, 1.931, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    43.14% {
        -webkit-transform: matrix3d(1.985, 0, 0, 0, 0, 1.985, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.985, 0, 0, 0, 0, 1.985, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    52.15% {
        -webkit-transform: matrix3d(2.017, 0, 0, 0, 0, 2.017, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.017, 0, 0, 0, 0, 2.017, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    70.37% {
        -webkit-transform: matrix3d(1.996, 0, 0, 0, 0, 1.996, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.996, 0, 0, 0, 0, 1.996, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    88.59% {
        -webkit-transform: matrix3d(2.001, 0, 0, 0, 0, 2.001, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.001, 0, 0, 0, 0, 2.001, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    100% {
        -webkit-transform: matrix3d(2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
}

@keyframes bounce {
    0% {
        -webkit-transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    4% {
        -webkit-transform: matrix3d(1.432, 0, 0, 0, 0, 1.432, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.432, 0, 0, 0, 0, 1.432, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    7.91% {
        -webkit-transform: matrix3d(1.889, 0, 0, 0, 0, 1.889, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.889, 0, 0, 0, 0, 1.889, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    11.91% {
        -webkit-transform: matrix3d(2.189, 0, 0, 0, 0, 2.189, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.189, 0, 0, 0, 0, 2.189, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    15.82% {
        -webkit-transform: matrix3d(2.276, 0, 0, 0, 0, 2.276, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.276, 0, 0, 0, 0, 2.276, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    20.42% {
        -webkit-transform: matrix3d(2.196, 0, 0, 0, 0, 2.196, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.196, 0, 0, 0, 0, 2.196, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    24.92% {
        -webkit-transform: matrix3d(2.059, 0, 0, 0, 0, 2.059, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.059, 0, 0, 0, 0, 2.059, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    29.53% {
        -webkit-transform: matrix3d(1.96, 0, 0, 0, 0, 1.96, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.96, 0, 0, 0, 0, 1.96, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    34.03% {
        -webkit-transform: matrix3d(1.931, 0, 0, 0, 0, 1.931, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.931, 0, 0, 0, 0, 1.931, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    43.14% {
        -webkit-transform: matrix3d(1.985, 0, 0, 0, 0, 1.985, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.985, 0, 0, 0, 0, 1.985, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    52.15% {
        -webkit-transform: matrix3d(2.017, 0, 0, 0, 0, 2.017, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.017, 0, 0, 0, 0, 2.017, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    70.37% {
        -webkit-transform: matrix3d(1.996, 0, 0, 0, 0, 1.996, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(1.996, 0, 0, 0, 0, 1.996, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    88.59% {
        -webkit-transform: matrix3d(2.001, 0, 0, 0, 0, 2.001, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2.001, 0, 0, 0, 0, 2.001, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
    100% {
        -webkit-transform: matrix3d(2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
        transform: matrix3d(2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1);
    }
}


/* 20210210追加 アドバイザーバナー */

.p-advisor__bnr {
    background: url(../img/advisor/bnr_advisor_flow_hover@2x.png);
}

.p-campain__bnr{
    background: url(../img/product/co/campaign/standard_sueoki/std_campain_side_banner_hover.png);
}
/*
.c-floatingbnr {
    background-size: cover;
    box-shadow: 0px 0px 12px 4px rgba(0, 0, 0, .04);
    display: block;
}

.c-floatingbnr__close {
    position: absolute;
    top: 0;
    right: 0;
    transform: none;
}

@media (max-width:376px) {
    .c-floatingbnr__close {
        width: 30px;
        height: 30px;
    }
}*/


/* 20210118追加 coキャンペーンバナー
.p-campaign__bnr.c-floatingbnr{
    position: fixed;
    bottom:30px;
    right: 50%;
    width: 320px;
    height: 160px;
    display: block;
    transform: translate(50%,0);
}
.p-campaign__bnr.c-floatingbnr a:hover .c-floatingbnr__img{
    opacity: 1;
}
.c-floatingbnr__close{
    position: absolute;
    top: 0;
    right: 0;
    transform: translate(50%,-50%);
}

@media (min-width:376px){
    .p-campaign__bnr.c-floatingbnr{
        position: fixed;
        bottom:40px;
        right: 40px;
        width: 190px;
        height: 375px;
        display: block;
        transform: translate(0);
    }
}
 */

/*
 SEO施策　トップページにSEO記事
 */
.l-knowHow{
    background: #f7f7f9;
    padding: 80px 0;
    text-align: center;
}
.l-knowHow .inner{
    max-width: 1350px;
    margin: 0 auto;
    padding: 0 4%;
}
.l-knowHow .p-knowHow__list{
    margin: 45px 10px 10px;
}
.l-knowHow .p-knowHow__article{
    padding: 15px;
    background: rgba(255,255,255,0);
    transition: .5s;
}
.l-knowHow .p-knowHow__article:hover{
    background: rgba(255,255,255,1);
}

.l-knowHow .p-knowHow__title{
    font-size: 16px;
    font-size: 1.6rem;
    margin: 10px;
    text-align: left;
}
.l-knowHow .p-knowHow__description{
    font-size: 14px;
    font-size: 1.4rem;
    margin: 0 10px;
    text-align: left;
}

@media (min-width:769px){
    .l-knowHow{
        background: #f7f7f9;
        padding: 100px 0 110px;
    }
    .l-knowHow .inner{
        padding: 0;
        max-width: 1410px;
    }
    .l-knowHow .p-knowHow__list{
        display: flex;
        margin: 45px 10px 10px;
    }
}


/*
 SEO施策　トップページのファーストビュー以下のsectionを遅延読み込み
 トップページ修正した際には高さの変更お願いします。
 */
/**/
 .p-firstview,
.section_intro,
.section_caces,
.section_about,
.section_function,
/*.section_network,*/
.p-howtobuild,
.section_howto,
.section_news,
.section_tsubo {
    content-visibility: auto;
}

.p-firstview{
    contain-intrinsic-size: 982px;
}

.section_caces {
    contain-intrinsic-size: 3774px;
}

.section_about {
    contain-intrinsic-size: 930px;
}

.section_function {
    contain-intrinsic-size: 601px;
}

.section_network {
    contain-intrinsic-size: 1170px;
}

.p-howtobuild{
    contain-intrinsic-size: 4060px;
}

.section_news {
    contain-intrinsic-size: 1075x;
}
.section_knowHow{
    contain-intrinsic-size: 1624px;
}
.section_tsubo {
    contain-intrinsic-size: 552px;
}

@media (min-width:768px) {

    .p-firstview{
        contain-intrinsic-size: 901px;
    }
    .section_caces {
        contain-intrinsic-size: 2114px;
    }
    .section_about {
        contain-intrinsic-size: 1050px;
    }
    .section_function {
        contain-intrinsic-size: 980px;
    }
    .section_network {
        contain-intrinsic-size: 787px;
    }
    .p-howtobuild{
        contain-intrinsic-size: 3478px;
    }

    .section_news {
        contain-intrinsic-size: 1675x;
    }
    .section_knowHow{
        contain-intrinsic-size: 710px;
    }
    .section_tsubo {
        contain-intrinsic-size: 774px;
    }
}


/*
 SEO施策　トップページのファーストビュー
 レイアウトシフト対策
 */
img{
    max-width: 100%;
    height: auto;
}

.imageWrap {
    display: inline-block;
    width: 100%;
    max-width: 100%;
}

.thumbWrap {
    margin: 0;
    height: 0;
    overflow: hidden;
    position: relative;
}

.pc .thumbWrap {
    padding-top: 56.25%;
}

.sp .thumbWrap {
    padding-top: 100%;
}

.thumb {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/*
 事例インタビュー 20220317
 */
 .p-pickup__bottom-section .c-title__h4 {
    margin: 0 0px 10px 0;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold;
    text-align: center;
    color: #000;
}
 .p-pickup__bottom-section .c-title__h4 {
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.45;
    color: #000;
    margin: 0 0 30px 0;
}
.p-pickup__bottom-section .c-title__h4::after {
    content: "";
    display: block;
    width: 1.3em;
    height: 0.1em;
    max-width: 50px;
    background: #393b4b;
    margin: 0.6em auto;
}
.genre-tag {
    width: 85px;
    height: 20px;
    border-radius: 5px;
    font-size: 9px;
    font-size: 0.9rem;
    font-weight: bold;
    line-height: 2.2;
    color: #fff;
    text-align: center;
}
.p-pickup__bottom-section .c-inner > div .c-text {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.85;
    color: #000;
}
.p-pickup__bottom-section-info {
    display: flex;
    flex-direction: column;
    padding: 0 10px 10px 10px;
}
.p-pickup__bottom-section-info .c-title {
    margin: 8px 0 0px 0;
    padding-bottom: 13px;
    font-size: 12px;
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 1.41;
    color: #000;
}
.genre-tag.p-genre-sports {
    background-color: #895A9B;
}
.genre-tag.p-genre-apparel {
    background-color: #38c2eb;
}
.genre-tag.p-genre-food {
    background-color: #f29443;
}
.genre-tag.p-genre-cosmetic {
    background-color: #ea619b;
}
.p-pickup__bottom-section-info .c-title2 {
    margin: 13px 0 20px 0;
    font-size: 11px;
    font-size: 1.1rem;
    font-weight: bold;
    line-height: 1.45;
    color: #000;
}
.p-point-btn {
    max-width: 60%;
    height: 44px;
    border: solid 1px #393b4b;
    margin: 5px auto 0 auto;
    font-weight: bold;
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 3.1;
    text-align: center;
    position: relative;
}
.p-pickup__bottom-section .c-inner {
    width: 100%;
    margin: 0;
    padding: 60px 20px;
    display: flex;
    flex-direction: column;
    align-content: space-between;
}
.p-pickup__bottom-section ul li a {
    flex-direction: column;
    align-content: space-between;
    width: 100%;
    height: 100%;
}
.p-pickup__bottom-section ul li:not(:last-child) {
    margin: 0 0 25px 0;
}
.p-pickup__bottom-section ul li {
    width: 100%;
    height: auto;
    background: #fff;
    padding: 12px;
}
.p-pickup__bottom-section ul li .c-img {
    overflow: hidden;
    padding-bottom: 7px;
}
.c-bnr__hover {
    width: 100%;
    height: auto;
    transition: .4s;
    image-rendering: smooth;
}
.c-bnr__hover:hover {
    transform: scale(1.05);
}    

.p-pickup__bottom-section {
        background: #eee;
    }
.p-caces {
    background: #f7f7f9;
    padding: 20px 0 0px;
}
.p-pickup__bottom-section .genre-tag {
    margin: 5px 14px 0 0;
}

@media only screen and (min-width: 550px) {
    .p-pickup__bottom-section .c-inner {
        max-width: 950px;
        margin: 0 auto;
    }  
    .p-pickup__bottom-section-txt {
        margin: 0 auto;
        padding: 0 15px;
        text-align: center;
    }    

    .p-pickup__bottom-section ul {
        display: flex;
        flex-direction: row;
        justify-content:space-around;
        flex-wrap: wrap;
        margin-top: 30px;
    }
    .p-pickup__bottom-section ul li:not(:last-child) {
        margin-bottom: 0;
    } 
    .p-pickup__bottom-section ul li:nth-child(1), 
    .p-pickup__bottom-section ul li:nth-child(2){
        margin-bottom: 5%;
    }       
    .p-pickup__bottom-section ul li {
        max-width: 45%;
    }  
    .p-pickup__bottom-section ul li .c-img {
        padding-bottom: 5px;
    }  
}    

@media only screen and (min-width: 1100px) {
    .p-pickup__bottom-section .genre-tag {
        margin: 0px 14px 0 0;
    }
    .p-pickup__bottom-section .c-inner {
        margin: 0 auto;
        padding: 75px 0;
        display: block;
        max-width: 1550px;
        padding-left: 3%;
        padding-right: 3%;
    }   
    .p-pickup__bottom-section ul {
        flex-wrap: wrap;

    }
    .p-pickup__bottom-section ul li:not(:last-child) {
        margin: 0 2% 0 0;
    }
    .p-pickup__bottom-section ul li {
        max-width: 23%;
        background: #fff;
        display: flex;
        flex-direction: column;
        position: relative;
    }
    .p-pickup__bottom-section ul li a {
        display: block;
        width: 100%;
        height: auto;
    }
    .p-pickup__bottom-section-info {
        display: flex;
        flex-direction: column;
        padding: 0 20px 20px 20px;
    }
    .p-pickup__bottom-section .c-inner > div {
        width: 100%;
        margin: 0 0px 0 0;
    }
    .p-pickup__bottom-section .c-title__h4 {
        text-align: center;
        font-size: 3.2rem !important;
        margin-bottom: 40px;
    }
    .p-pickup__bottom-section .c-inner > div .c-text {
        font-size: 16px;
        font-size: 1.6rem;
        line-height: 1.625;
        color: #000;
        margin-bottom: 50px;
        text-align: center;
    }
    .p-pickup__bottom-section-info .c-title {
        margin: 10px 0 0px 0;
        padding-bottom: 15px;
        font-size: 14px;
        font-size: 1.4rem;
        line-height: 1.57;
    }
    .p-pickup__bottom-section-info .c-title-apparel {
        padding-bottom: 15%;
    }    

    .p-pickup__bottom-section-info .c-title2 {
        margin: 15px 0 30px 0;
        font-size: 12px;
        font-size: 1.2rem;
    }
    .p-pickup__bottom-section ul li .c-img {
        margin-bottom: 20px;
    }
    .genre-tag {
        width: 90px;
        height: 24px;
        font-size: 11px;
        font-size: 1.1rem;
        font-weight: bold;
        line-height: 2.4;
        color: #fff;
        text-align: center;
    }
    .p-point-btn {
        max-width: 100%;
        height: 58px;
        font-weight: bold;
        font-size: 16px;
        font-size: 1.6rem;
        text-align: center;
    }
    .p-caces {
        padding: 40px 0 0 0;
    }
}
.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;
    }
}

/* -------------------------------------- 
	20220603 ファーストビュー first_view
----------------------------------------- */
.front_page{
    background: #fff;
}
.p-firstview__bg {
    background: url(../img/top/first_view/firstview_bg_sp.png) no-repeat;
    background-size:  cover;  
    position: relative;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    margin: 0 auto;
    padding: 100px 0 65px;
    z-index: 0;
}
.p-firstview .l-inner{
    display: flex;
    flex-direction: column;
    padding: 0;
}
/* p-firstview__copy */
.p-firstview__copy{
    height: auto;
    margin: auto;
    text-align: center;
}
.p-firstview__copy_en {
    display: none;
}
.p-firstview__main_img img {
    width: 65%;
}
.p-firstview__subcopy{
    font-weight: normal;
    font-size: var(--u-text__m - 1px);
    color: #fff;
    margin: var(--u-length__s) 0 0 0;
    line-height: 1.8;
}
.p-firstview__annotation{
    vertical-align: super;
    font-size: 1rem;
}
/* p-firstview__mainvisual */
.p-firstview__mainvisual{
    width: 90vw;
    height: auto;
    margin: var(--u-length__s) auto 120px;
    text-align: center;
}
/* p-firstview__cvp */
.p-firstview__cvp{
    position: absolute;
    text-align: center;
    bottom: 70px;
    width: 100%;
}
.p-firstview__btn li a{
    width: 90%;
    margin: 10px auto;
    letter-spacing: 0.05em;
    display: block;
    transition: all .2s;
    white-space: nowrap;
}
/* p-firstview_bottom */
/* p-firstview_point */
.p-firstview_point{
    display: flex;
    flex-wrap: wrap;
    width: 80%;
    margin: -50px auto 50px;
    justify-content: space-between;
    filter: var(--u-drop-shadow__01);
    
}
.p-firstview_point1 {
    width: 100%;
    margin-bottom: 13px;
}
.p-firstview_point2,
.p-firstview_point3 {
    width: 48%;
    box-sizing: border-box;
}

.p-firstview_point li img{
    width: 100%;
}
.menu_icon{
    transition: background-color 0s;
}
/* p-firstview_quote */
.p-firstview_quote__pc {
    display: none;
}
.p-firstview_quote__sp {
    font-size: 10px;
    margin: 0 20px 40px 20px;
    text-align: justify;
}
@media only screen and (min-width: 768px) {
    .p-firstview__subcopy{

    font-size: var(--u-text__m);
        letter-spacing: .02em;
    }
    .p-firstview__cvp {
        bottom: 220px;
        left: 50%;
        transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
    }
    .p-firstview__mainvisual {
        margin: var(--u-length__s) auto 220px;
    }
    .p-firstview_point{
        width: 60%;
        margin: -180px auto 0px;
    }
}
@media only screen and (min-width: 1000px) {
    
    .p-firstview .l-inner{
        display: flex;
        flex-direction: row;
        justify-content: center;
        align-items: center;
        padding: 50px 25px 80px 25px;
    }
    .p-firstview__bg{
        background: url(../img/top/first_view/firstview_bg.png) no-repeat;
        background-size: cover; 
        position: relative;
        z-index: 0;
    }
    /* p-firstview__copy */
    .p-firstview__copy{
        text-align: left;
        width: 45%;
    }
    .p-firstview__copy_en {
        display: block;
        margin: 0 0 0 0;
        width: 73%;
        opacity: 0.8;
    }
    .p-firstview__main_img {
        text-align: left;
    }
    .p-firstview__main_img img {
        margin: var(--u-length__xs) 0 0 0;
        width: 60%;
        height: auto;
    }
    .p-firstview__subcopy{
        margin: var(--u-length__s) 0 0 0;
        text-align: left;
        font-size: var(--u-text__s);
    }
    /* p-firstview__cvp */
    .p-firstview__cvp{
        margin: var(--u-length__xs) 0 0 0;
        position: unset;
        width: 100%;
        text-align: center;
        transform: unset;
        -webkit-transform: unset;
        -ms-transform: unset;
    }
    .p-firstview__btn{
        width: 90%;
        text-align: center;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
    }
    .p-firstview__btn li {
        width: calc(50% - 5px);
    }
    .p-firstview__btn li a{
        width: 100%;
        margin: 10px 0 0 0;
        border-radius: 5px;
        font-size: 1.4rem;
    }
    /* p-firstview__mainvisual */
    .p-firstview__mainvisual{
        width: 52%;
        height: auto;
        margin: 0;
        position: relative;
    }
    .p-firstview__product {
        position: absolute;
        width: 100%;
        right: 0;
        top: -37%;
        transform: translateY(-37%);
    }
    /* p-firstview_bottom */
    .p-firstview_bottom .l-inner{
        display: block;
        padding: 0;
    }
    /* p-firstview_point */
    .p-firstview_point {
        max-width: 770px;
        margin: -100px 80px var(--u-length__s) auto;
        justify-content: space-around;
        align-items: flex-end;
    }
    .p-firstview_point1 {
        margin-bottom: -0.5px;
    }
    .p-firstview_point1,
    .p-firstview_point2,
    .p-firstview_point3 {
        width: 30%;
    }
    
    .p-firstview__annotation{
        font-size: 1rem;
    }
    .p-firstview_quote__pc{
        font-size: 1.1rem;
        display: block;
        text-align: center;
    }
    .p-firstview_quote__sp {
        display: none;
    }
    .p-firstview_quote {
        margin: 0 80px 0 0;
        text-align: right;
    }
}
@media only screen and (min-width: 1440px) {
    .p-firstview__bg {
        padding: 150px 0 140px 0;
    }
    .p-firstview_bottom{
        position: relative;
    }
    .p-firstview__main_img img {
        width: 384px;
    }
    .p-firstview__subcopy{
        font-size: 2rem;
    }
    .p-firstview__btn li a{
        width: 100%;
        margin: 10px 0 0 0;
        border-radius: 5px;
        font-size: 1.8rem;
    }
    .p-firstview_quote__pc{
        position: absolute;
        width: calc((100% - 60px - 770px) / 2);
        height: auto;
        font-size: 1.1rem;
        right: 20px;
        bottom: 0px;
        text-align: justify;
        padding: 0px 40px 0 0;
        margin: 0;
        text-align: left;
    }
    .p-firstview_quote {
        margin: 0;
        text-align: left;
    }
    .p-firstview_point {
        max-width: 770px;
        margin: -100px auto var(--u-length__s) ;
        justify-content: space-around;
        align-items: flex-end;
    }
}

/* newラベル */
.new-tag {
    position: relative;
}
.new-tag::before {
    content: "";
    top: 0;
    right: 0;
    border-bottom: 65px solid transparent;
    border-right: 65px solid #cfaf2f;
    position: absolute;
    z-index: 1;
}
.new-tag::after {
    content: "NEW";
    font-family: Helvetica;
    font-weight: normal;
    font-size: 14px;
    display: block;
    top: 11.6px;
    right: 5.9px;
    transform: rotate(45deg);
    color: #ffffff;
    position: absolute;
    z-index: 2;
}
/* ---- メニュー背景 白く ----- */
@media screen and (min-width: 992px){
    .front_page .header .inner .btn-contact span,
    .front_page .active .inner .btn-contact span {
        color: #383b4a;
        border: 1px solid #383b4a;
        background: url(../img/header/icon_store_g.svg) no-repeat 20px center;
        background-size: 19px 24px;
    }
    .large.header .inner {
        background: #fff;
    }
}
@media screen and (max-width: 991px){
    /*--- SPナビ色調整 ---*/
    .show-nav .header a:link,.show-nav .header a:visited,
    .show-nav .header a:hover,.show-nav .header a:active {
        color: #fff;
    }
}

@media only screen and (max-width: 768px) {
    .new-tag::before {
        border-bottom: 60px solid transparent;
        border-right: 60px solid #cfaf2f;
    }
    .new-tag::after {
        font-size: 13px;
    }
}  

/* ---- 
 * ネットショップの始め方 6/10
 * ----------------------------------- */

 .p-howtobuild{
    text-align: left;
}
    .p-howtobuild .c-inner{
        max-width: 950px;
        margin: 0 auto;
        padding: 60px 0px;
        overflow: hidden;
    }
    .p-howtobuild_message{
        padding: 0 2rem;
    }
.p-howtobuild p a{
    text-decoration: underline;
}
.p-howtobuild__heading{
    text-align: center;
}
    .p-howtobuild__heading span{
        font-size: 1.8rem;
        display: block;
    }
.p-about_ip{
    background: #f5f5f5;
    text-align: left;
    padding: 2rem;
    margin: 5rem auto 5rem;
    max-width: 680px;
}
    .p-about_ip dt{
        font-weight: bold;
        margin-bottom: 1rem;
        text-align: center;
        
    }
        .c-question__icon_left::before{
            content:'';
            display: inline-block;
            background: url(../img/top/how_to_build/icon_question_yellow@2x.png)no-repeat;
            background-size: contain;
            width: 28px;
            height: 28px;
            vertical-align: middle;
            font-weight: bold;
            margin-right: 0.5em;
        }
        
/*----- 表の設定 ------*/
.p-howtobuild__section{
    display: flex;
    flex-wrap: wrap;
}

.p-step01_diy_content{
    display: flex;
    flex-wrap: wrap;
}
    .p-howtobuild__col2{
        width: calc(100%/2);
        padding: 2rem;
    }
    .p-howtobuild__col1{
        width: 100%;
        padding: 3rem 2rem;
    }
    .p-howtobuild_section__title {
        font-size: 2rem;
    }
    .p-howtobuild_diy__title,
    .p-howtobuild_partner__title,
    .p-howtobuild_secrity__title{
        font-weight: bold;
        font-size: 1.3rem;
        margin-top: 0;
        margin-bottom: .5em;
    }
    .p-howtobuild_partner__title{
        color: #3498BC;
    }
    .p-howtobuild_secrity__title{
        color: #4ab5bf;
    }
    .p-howtobuild__section p{
        font-size: 1.3rem;
        line-height: 1.5;
        margin: .5em 0;
    }
    .p-howtobuild__partner{
        background: #FCFCFC;
    }
.p-arrow{
    position: relative;
    background: #FFF;
    box-sizing: border-box;
}
    .p-arrow::before{
        content: "";
        position: absolute;
        bottom: -25px;
        left: 50%;
        margin-left: -18px;
        border: 15px solid transparent;
        border-top: 15px solid #FFF;
        z-index: 2;
    }
    .p-arrow::after{
        content: "";
        position: absolute;
        bottom: -24px;
        left: 50%;
        margin-left: -15px;
        border: 12px solid transparent;
        border-top: 12px solid #d6d6d6;
        z-index: 1;
    }
    .p-arrow__partner{
        background-color: #FCFCFC;
    }
    .p-arrow__partner::before{
        border-top: 15px solid #FCFCFC;
    }
    .p-howtobuild__box{
        text-align: left;
    }
    .c-howtobuild_border__tl{
        border-top: 1px solid #d6d6d6;
        border-left: 1px solid #d6d6d6;
    }
    .c-howtobuild_border__rb{

        border-bottom: 1px solid #d6d6d6;
    }

@media only screen and (min-width: 768px){
.p-howtobuild{
    text-align: center;
}
    .p-howtobuild .c-inner{
        margin: 0 auto;
        padding: 75px 3%;
        display: block;
        max-width: 1550px;
    }
    .p-howtobuild_message{
        padding: 0rem;
    }
.p-howtobuild__section p{
    font-size: 1.6rem;
    line-height: 1.625;
}
    .p-about_ip{
        text-align: center;
    }
    .p-howtobuild_step_wrap{
        display: flex;
    }
    .p-howtobuild_step{
        background: #f5f5f5;
        padding: 4rem 0 3rem;
    }
    .p-howtobuild_diy__title,
    .p-howtobuild_partner__title,
    .p-howtobuild_secrity__title{
        font-size: 1.8rem;
    }
    .p-howtobuild__col2{
        padding: 3.5rem 2rem;
    }
    .p-howtobuild__col1{
        width: 100%;
        padding: 3.5rem 2rem;
    }
    .c-howtobuild_border__rb{
        border-right: 1px solid #d6d6d6;
        border-bottom: 1px solid #d6d6d6;
    }
    .p-about_ip{
        margin-bottom: 8rem;
    }
}

/*-- 表の頭 --*/
.p-howtobuild_head__content{
    width: 100%;
    display: flex;
}
.p-howtobuild__head{
    display: flex;
    justify-content: flex-end;
}
.p-howtobuild_head__col2{
    width: calc(100%/2);
}
    .p-howtobuild_head__diy{
        background: #FFCE01;
        display: flex;
        align-items: center;
        justify-content: center;
        border-right: 1px solid #fff;
        padding: 1rem;
    }
    .p-howtobuild_head__partner{
        background: #006699;
         color: #fff;
         display: flex;
         align-items: center;
         justify-content: center;
         padding: 1rem;
    }
    .p-howtobuild_partner__balloon{
        display: none;
    }
    .p-howtobuild_partner__icon{
        font-size: 1.8rem;
    }
    .p-howtobuild_diy__icon{
        margin: 0;
        font-size: 1.8rem;
    }
    .p-howtobuild_diy__icon::after{
        content: '';
        display: inline-block;
        background: url(../img/top/how_to_build/icon_diy@2x.png)no-repeat;
        background-size: contain;
        width: 30px;
        height: 31px;
        vertical-align: middle;
        font-weight: bold;
        margin-left: .7rem;
    }
    .p-howtobuild_partner__icon::after{
        content: '';
        display: inline-block;
        background: url(../img/top/how_to_build/icon_partner@2x.png)no-repeat;
        background-size: contain;
        width: 36px;
        height: 24px;
        vertical-align: middle;
        font-weight: bold;
        margin-left: .7rem;
    }
    .p-howtobuild_head__diy.p-arrow::before{
        border-top: 15px solid #FFCE01;
    }
    .p-howtobuild_head__partner.p-arrow::before{
        border-top: 15px solid #006699;
    }
@media only screen and (min-width: 768px){
    .p-howtobuild_diy__icon{
        font-size: 2rem;
    }
    .p-howtobuild_partner__icon{
        font-size: 2rem;
        margin: 1rem 0;
    }
.p-howtobuild_head__partner{
    padding: 2rem 2rem 1.5rem;
}
    .p-howtobuild_diy__icon::after{
        width: 53px;
        height: 54px;
    }
    .p-howtobuild_partner__icon::after{
        width: 66px;
        height: 44px;
    }
    .p-howtobuild_partner__balloon{
        border-radius: 3rem;
        background: #fff;
        color: #006699;
        display: inline-block;
        padding: .3em 2rem .1em;
        font-weight: bold;
        position: relative;
        font-size: 1.3rem!important;
        width: 100%;
    }
    .p-howtobuild_partner__balloon::after{
        content: "";
        position: absolute;
        right: 0;
        top: -7px;
        left: 0;
        width: 0px;
        height: 0px;
        margin: auto;
        border-style: solid;
        border-color: #fff transparent transparent transparent;
        border-width: 10px 10px 0 10px;
        transform:rotate(180deg);
   }
   .p-howtobuild_head__diy.p-arrow::after,
   .p-howtobuild_head__diy.p-arrow::before,
   .p-howtobuild_head__partner.p-arrow::after,
   .p-howtobuild_head__partner.p-arrow::before {
        display: none;
    }
}
/* STEP01 */
/* 自社で作る */
.p-step01_diy_content{
    padding: 0;
}
.p-step01_diy__dl,
.p-step01_diy__cloud{
    padding: 0;
    text-align: center;
}
.p-step01_diy__dl{
    border-right: 1px solid #D6D6D6;
}
    .p-step01_diy__balloon{
        background: #FFE64C;
        margin: 0 0 3rem;
        padding: 1.5rem 0;
        font-size: 1.4rem;
        line-height: 1.5;
        position: relative;
    }
    .p-step01_diy__balloon::after{
        content: "";
        position: absolute;
        right: 0;
        bottom: -10px;
        left: 0;
        width: 0px;
        height: 0px;
        margin: auto;
        border-style: solid;
        border-color: #FFE64C transparent transparent transparent;
        border-width: 10px 10px 0 10px;
    }
    .p-step01_diy__flow{
        margin-top: 2rem;
    }
    .p-step01_diy__flow li{
        background-color: #EFEFEF;
        border-radius: 4px;
        margin-bottom: 2rem;
        padding: 1rem 0;
        font-weight: bold;
        position: relative;
        font-size: 1.2rem;
        width: 80%;
        margin: 0 auto 2rem;
    }
    .p-step01_diy__flow a{
        text-decoration: underline;
    }
    .p-step01_diy__flow li::after{
        content: "";
        position: absolute;
        right: 0;
        bottom: -15px;
        left: 0;
        width: 0px;
        height: 0px;
        margin: auto;
        border-style: solid;
        border-color: #4D4D4D transparent transparent transparent;
        border-width: 5px 4px 0 4px;
    }

        .p-step01_diy__flow li:last-child::after{
            border: none;
        }
    .p-howtobuild__note{
        font-size: 10px!important;;
        text-align: left;
        width: 100%;
        /*margin-top: 1.5rem!important;*//*今だけ*/
        visibility: hidden;
    }
    .p-step01_diy__cloud h4{
        text-align: center;
        font-size: 1.4rem;
    }
    .p-step01_diy__cloud p{
        text-align: left;
        display: inline-block;
        padding: 2rem 1rem 0;
    }
@media only screen and (min-width: 768px){
    .p-step01_diy__balloon{
        font-size: 1.8rem;
        margin-bottom: 3.3rem;
    }
    .p-howtobuild__note{
        font-size: 12px!important;
        text-align: center;
    }
    .p-step01_diy__flow li{
        border-radius: 6px;
        font-size: 1.6rem;
    }
    .p-step01_diy__flow li::after{
        border-width: 7px 7px 0 7px;
    }
}
/* パートナーと作る */
.p-step01_partner{
    padding: 2rem 0 0;
}
.p-step01_partner__flex{
    display: flex;
    align-items:center;
}
    .p-howtobuild__box{
        padding: 1rem 2rem 1rem;
    }
    .p-step01__adhoop{
        border-bottom: 1px solid #D6D6D6;
    }
    .p-step01__hearing{
        padding: 2.5rem 2rem 2rem;
    }
    @media only screen and (min-width: 768px){
        .p-howtobuild__box{

        }
    }

/* 決済サービスの選定 */
.p-howtobuild__alliance{
    background: #fff0d7;
}
    .p-howtobuild_alliance__title{
        margin: 0 0 1rem;
        text-align: center;
    }
    .p-howtobuild__alliance p{
        margin-bottom: 2rem;
    }
    .p-howtobuild_btn__list {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        flex-wrap: wrap;
    }
    .p-howtobuild__btn{
        margin: 0 0 1.5rem;
        width: 100%;
        text-align: center;
    }
        .p-howtobuild__btn a{
            background: #ffce01;
            border-radius: 4px;
            padding: 1rem;
            font-weight: bold;
            display: inline-block;
            width: 100%;
        }
        .p-howtobuild__btn span{
            display: block;
            font-weight: normal;
            font-size: 1.3rem;
        }
.p-arrow__alliance{
    bottom: -3rem;
}
    .p-arrow__alliance::before{
        border-top: 15px solid #fff0d7;
    }
    .p-arrow__alliance:first-child{
        left: 0;
        right: 0;
        margin: auto;
    }
    .p-arrow__alliance:last-child{
        display: none;
    }
@media only screen and (min-width: 768px){
    .p-howtobuild__alliance{
        width: 100%;
    }
    .p-howtobuild_btn__list{
        justify-content: center;
        flex-direction:row;
    }
    .p-howtobuild_alliance__title{
        margin-bottom: 1.5rem;
    }
        .p-howtobuild__btn{
            width: calc(100%/3);
            margin: 1rem;
            min-width: 250px;
        }
    .p-arrow_alliance__wrap{
        width: 100%;
        display: block;
    }
    .p-arrow__alliance{
        bottom: -3.5rem;
    }
        .p-arrow__alliance:first-child{
            left: 25%;
        }
        .p-arrow__alliance:last-child{
            right: 25%;
            display: block;
        }

}


/*------ 
STEP02
自社構築 -----*/

.p-howtobuild_diy_custom{
    padding-bottom: 0;
    text-align: center;
    padding: 2rem;
}
.p-howtobuild_diy_custom__btn h4{
    font-weight: normal;
    font-size: 1rem;
    margin: 0 0 .5em;
}
    .p-howtobuild_diy_custom__list{
        align-items: flex-end;
        margin-top: 1rem;
    }
        .p-howtobuild_diy_custom__list a{
            display: flex;
            justify-content: center;
            align-items: center;
        }
@media only screen and (min-width: 768px){
    .p-howtobuild_diy_custom{
        padding: 3rem 2rem;
    }
.p-howtobuild_diy_custom__btn h4{
    font-size: 1.4rem;
}
    .p-howtobuild_diy_custom__btn{
        width: 45%;
        min-width: 230px;
    }
        .p-howtobuild_diy_custom__btn a{
            min-height: 71px;
        }
    
}
/* パートナーによる構築 */
.p-howtobuild_partner_custom{
    text-align: left;
    padding: 2rem;
}
    .p-howtobuild_partner_custom__img{
        text-align: center;
        position: absolute;
        left: 0;
        right: 0;
        width: 90%;
        height: auto;
        margin: auto;
        bottom: 20px;
        
    }
@media only screen and (min-width: 768px){
.p-howtobuild_partner_custom{
    text-align: left;
    padding: 3rem 2rem;
}
    .p-howtobuild_partner_custom__img{
        text-align: right;
        margin: 2rem 3rem 0 0;
        position: static;
    }
}

/*------ 
STEP03
セキュリティ対策 -----*/
.p-how-to-build-step03{
    background-color: #FCFCFC;
}
.p-howtobuild_secrity{
    text-align: center;
}
.p-howtobuild_secrity__wrap{
    overflow: hidden;
}
.p-howtobuild_secrity__title{
    text-align: center;
}
.p-howtobuild_secrity__content{
    text-align: left;
}
    .p-howtobuild_secrity__btn a{
        background: #4ab5bf;
        color: #fff;
    }
    .p-howtobuild_secrity__btn a:hover{
        opacity: .9;
    }
    .p-howtobuild_secrity__img{
        width: 30%;
        height: auto;
        margin: 2rem auto;
    }
@media only screen and (min-width: 768px){
    .p-howtobuild_secrity__title{
        text-align: left;
    }
       .p-howtobuild_secrity__content,
       .p-howtobuild_secrity_btn__list{
            width: 65%;
            float: right;
            justify-content: flex-start;
            padding-right: 5%;
        }
        .p-howtobuild_secrity__img{
            width: 25%;
            float: left;
            margin: 0 0 0 5%;
        }
        .p-howtobuild_secrity__btn{
            width: 80%;
            margin: 0;
        }
    .p-howtobuild_secrity p{
        margin: 2rem 0;
    }
}

/*------ 
STEP05
公開 -----*/
.p-howtobuild_open{
    text-align: center;
}
.p-howtobuild_open p{
    margin: 2rem 0 1.5rem;
}


/*------ 
STEP06
運営 -----*/
.p-howtobuild_operation__title{
    text-align: center;
}
.p-howtobuild_operation__list{
    margin-top: 2rem;
}
@media only screen and (min-width: 768px){
    .p-howtobuild_operation__list{
        flex-wrap: wrap
    }
    .p-howtobuild_operation__btn{
        width: 31%;
        margin: 1%;
        background: #ffce01;
        border-radius: 4px;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .p-howtobuild_operation__btn a{
        width: 100%;
    }
}

/* ユーティリティ */
    .u-br__sp {
        display: block;
    }
    .u-clear{
        clear: both;
    }
    .u-flex__center{
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .u-mb__2r{
        margin-bottom: 2rem!important;
    }
    .u-mb__3r{
        margin-bottom: 3rem!important;
    }
@media only screen and (min-width: 768px){
    .u-br__pc{
        display: block;
    }
    .u-br__sp{
        display: inline;
    }
}

/* ---- 
 * ネットショップの始め方 6/10 layout issue
 * ----------------------------------- */
 :root {
    /*PC版のSTEPのwidthをここで定義*/
    --p-htb_step-width: 130px;
    /*スマホ版のスライダーセルを短くするwidthをここで定義*/
    --p-htb_width-to-shorten-slider: 40px;
}

.p-htb_flex_row {
    display: flex;
    flex-direction: row;
    width: 100%;
}

.p-htb_flex_column {
    display: flex;
    flex-direction: column;
}

.p-htb_cell_Width_100 {
    width: 100%;
}

.p-htb_cell_ex-for-step {
    width: 100%;
}

.p-htb_partner-color {
    background: #eee;
}

.p-htb_stretch {
    align-content: stretch;
}
@media only screen and (min-width: 768px) {
    .p-htb_flex_row {
        display: flex;
        flex-direction: row;
    }
    .p-htb_flex_column {
        display: flex;
        flex-direction: column;
    }
    .p-htb_cell_ex-for-step {
        width: calc(100% - var(--p-htb_step-width));
        
    }
    .p-htb_cell_ex-for-step_db2 {
        width: calc((100% - var(--p-htb_step-width)) / 2);
    }
    .p-htb_cell_Width_100_db2 {
        width: calc(100% / 2);
    }
    .p-htb_partner-color {
        background: #eee;
    }
}


/* ---- 
 * slider
 * ----------------------------------- */
@keyframes slide-anim-left {
    0% {
        transform: translateX(calc(-50% + var(--p-htb_width-to-shorten-slider)));
    }

    100% {
        transform: translateX(0px);
    }
}

@keyframes slide-anim-right {
    0% {
        transform: translateX(0px);
    }

    100% {
        transform: translateX(calc(-50% + var(--p-htb_width-to-shorten-slider)));
    }
}

/*------- js動作のためmax width指定 -------*/
@media only screen and (max-width: 767px) {
/*表の幅設定*/
.p-howtobuild__inner {
    width: 100%;
    overflow: hidden;
}
.js-htb-slider {
    width: calc((100vw - var(--p-htb_width-to-shorten-slider)) * 2);
}
.js-left_box, .js-right_box {
    width: calc(100vw - var(--p-htb_width-to-shorten-slider));
    border-top: 1px solid #d6d6d6;
}
/*アニメーションの設定*/
.js-htb-slider.js-left {
    animation: slide-anim-left 0.3s;
    animation-direction: alternate;
    animation-timing-function: ease-in-out;
    animation-fill-mode: forwards;
}
.js-htb-slider.js-right {
    animation: slide-anim-right 0.3s;
    animation-direction: alternate;
    animation-timing-function: ease-in-out;
    animation-fill-mode: forwards;
}

.js-htb-box .js-left_box,
.js-htb-box .js-right_box {
    position: relative;
}
    .js-htb-box .js-left_box .js-overlay,
    .js-htb-box .js-right_box .js-overlay {
        content:'';
        background: rgba(100, 100, 100, .5);
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 3;
    }
    .p-overlay_arrow__left{
        position: relative;
        display: inline-block;
        vertical-align: middle;
        text-decoration: none;
        height: 100%;
        width: 100%;
        margin-right: 5px;
        transform: translateX(-1rem);
    } 
    .p-overlay_arrow__right{
        position: relative;
        display: inline-block;
        vertical-align: middle;
        text-decoration: none;
        height: 100%;
        width: 100%;
        transform: translateX(1rem);
    }
    .p-overlay_arrow__left::before,
    .p-overlay_arrow__left::after{
        position: absolute;
        top: 0;
        bottom: 0;
        right: 0;
        margin: auto;
        content:'';
    }
    .p-overlay_arrow__right::before,
    .p-overlay_arrow__right::after {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        content:'';
    }
        .p-overlay_arrow__left::before{
            width: 20px;
            height: 20px;
            -webkit-border-radius: 50%;
            border-radius: 50%;
            background: #333;
        }
        .p-overlay_arrow__left::after{
            right: 9px;
            box-sizing: border-box;
            width: 5px;
            height: 5px;
            border: 5px solid transparent;
            border-right: 5px solid #fff;
        }
        .p-overlay_arrow__right::before{
            width: 20px;
            height: 20px;
            -webkit-border-radius: 50%;
            border-radius: 50%;
            background: #333;
        }
        .p-overlay_arrow__right::after{
            left: 9px;
            box-sizing: border-box;
            width: 5px;
            height: 5px;
            border: 5px solid transparent;
            border-left: 5px solid #fff;
        }
    .js-htb-box.js-left .js-left_box .js-overlay,
    .js-htb-box.js-right .js-right_box .js-overlay {
        display: none;
    }
}
/* ---- 
 * step
 * ----------------------------------- */
.p-htb_step-cell {
    display: none;
}

.p-htb_blank {
    display: none;
}

    .p-htb_step-cell-sp {
        display: block;
        position: relative;
        width: 100%;
        height: 60px;
        margin: 3.5rem 2rem 0;
    }
    .p-htb_step_1column__sp{
        position: static;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .p-step-header {
        position: absolute;
        display: block;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
    }

    .p-htb_step-cell-sp-bg {
        height: 100%;
        width: 100%;
        background: #EFF1F4;
        border-radius: 50px;
    }


@media only screen and (min-width: 768px) {
    .p-htb_step-cell {
        display: block;
        width: var(--p-htb_step-width);
    }

    .p-htb_blank {
        display: block;
        background: #fff;
        height: auto;
    }

    .p-htb_step-cell-sp {
        display: none;
    }
}

/* ---- 
 * bnr
 * ----------------------------------- */

 .p-section__bnr {
    background: #f7f7f9;
 }
 .p-bnr__inner {
    padding: 0px 3% 55px 3%;
 }
 @media (min-width:768px){
    .p-bnr__inner {
    margin: 0px auto;
    padding: 55px 0 75px 0;
    max-width: 1000px;
    background: #f7f7f9;
    }
 }

 /* -------------------------------------- 
 *
 *
 * renewal 2023/01
 * 
 *
----------------------------------------- */
/*　/変数---　*/
:root {
    /*会社紹介エリアのコンテナボックスサイズ*/
    --js-p-company__width: 0px;
}

 /* -------------------------------------- 
 *
 * p-reason
 * 
----------------------------------------- */
.p-reason {
    background: #c5d2e4;
    background: linear-gradient(135deg, #ffffff, #c0c0c0,#fff 150%);
}
.p-reason__heading {
    width: 100%;
    height: 255px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    background-color: var(--u-color__dark_gray);
    background-image: var(--u-gradation__05);
}
.p-reason__heading::before {
    position: absolute;
    content: "";
    left: 0;
    width: 62%;
    height: 100%;
    background-color: var(--u-color__dark_gray);
    background-image: var(--u-gradation__05_reverse);
    clip-path: polygon(0 0, 100% 0, 55% 100%, 0% 100%);
}
.p-reason__heading h4 {
    margin: 0;
    z-index: 1;
    font-size: var(--u-text__m);
}
.p-reason__heading h2 {
    font-size: var(--u-text__xxl);
    margin: 10px 0 0 0;
    z-index: 1;
}
@media (min-width:768px){
    .p-reason__heading {
        height: 300px;
    }
    .p-reason__heading h2 {
        font-size: var(--u-text__xxl);
        margin: 10px 0 13px 0;
        z-index: 1;
    }
}
/* -------------------------------------- 
p-reason-01
----------------------------------------- */
.p-reason-01 {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    z-index: 1;
    margin: var(--u-length__l) 0 0 0;
}
.p-reason-01__column {
    background: #fff;
    filter: var(--u-drop-shadow__01);
}
.p-reason-01__column:last-child {
    margin-bottom: 100px;
}
.p-reason__heading__wrap {
    filter: var(--u-drop-shadow__01);
}
.p-reason-01__heading { /*選ばれる理由01のわく */
    width: calc(100% - var(--u-padding__smartphone) * 2);
    height: 145px;
    margin: -30px auto 30px auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 80%, 50% 100%, 0 80%);
    clip-path: polygon(0 0, 100% 0, 100% 80%, 50% 100%, 0 80%);
    background: linear-gradient(180deg, #3d557d, #0e141b 100%);
}
.p-reason-01__heading h4 {
    margin: 0;
    font-size: var(--u-text__r);
}
.p-reason-01__heading h3 { /*どこまでも自由なカスタマイズ */
    margin: 0;
    font-size: var(--u-text__xl);
    
}
.p-reason-01__contents {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 0 var(--u-padding__smartphone);
    
}
.p-content__container {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    margin: 0px 0 36px 0;
}
.p-content__icon {
    width: 15%;
    height: auto;
    margin: 0 10px 0 2px;
}
.p-content__icon img{
    width: 90%;
    height: auto;
    margin: 0 auto;
    display: block;
}
.p-reason-01__column:first-child .p-reason-01__contents .p-content__container:nth-child(3) .p-content__icon img {
    width: 83%;
}
.p-reason-01__column:last-child .p-reason-01__contents .p-content__container:nth-child(3) .p-content__icon img {
    width: 97%;
}
.p-content__textbox {
    width: 85%;
    padding: 0 0 0 15px;
    border-left: 4px solid var(--u-color__deep_blue);
}
.p-content__textbox h4 {
    margin: 0 0 8px 0;
    color: var(--u-color__deep_blue);
    font-size: var(--u-text__l);
}
.p-content__textbox p {
    margin: 0;
    text-align: justify;
}
 .p-reason-01__heading02 { /*事業デザインに合わせた継続性の高い~ */
    width: calc(100% - var(--u-padding__smartphone) * 2);
    height: 120px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--u-gradation__01);
    margin: 0px auto var(--u-padding__smartphone) auto;
    border-radius: 4px;
    filter: var(--u-drop-shadow__01);
}
.p-multiplication {
    margin: 30px auto 60px auto;
    width: 35px;
}
@media (max-width:768px){
    .p-reason .l-inner {
        padding: 0;
    }
    .p-multiplication {
        width: 35px;
    }
}

@media (min-width:769px){
    
}
@media (min-width:1100px){
    .p-reason-01 {
        flex-direction: row;
        align-items: center;
        margin: 35px 0 0px 0;
        position: relative;
        z-index: 1;
    }
    .p-reason-01__column {
        width: calc(50% - 40px);
    }
    .p-reason-01__column:last-child {
        margin-bottom: 0px;
    }
    .p-reason-01__heading {
        width: calc( 100% + 40px);
        margin: 0 0 0 -20px;
        height: 145px;
    }
    .p-reason-01__heading h4 {
        margin: -8px 0 0 0;
    }
    .p-reason-01__heading h3 {
        margin: 4px 0 0 0;
    }
    .p-reason-01__contents {
        justify-content: space-between;
        padding: 30px 40px;
    }
    .p-content__container {
        margin: 0px 0 50px 0;
    }
    .p-reason-01__contents > .p-content__container:last-child {
        margin: 0px 0 0px 0;
    }
    .p-content__icon {
        width: 10%;
        margin: 0 15px 0 0px;
    }
    .p-content__textbox {
        width: 90%;
        padding: 0 0 0 15px;
        border-left: 5px solid var(--u-color__deep_blue);
    }
    .p-reason-01__heading02 {
        width: calc( 100% + 40px);
        margin: 0 0 0 -20px;
        height: 120px;
        border-radius: 6px;
    }
    .p-reason-01__heading02 h3 {
        font-size: var(--u-text__m);
    }
}
@media (min-width:1200px){
    .p-reason-01__heading02 h3 {
        font-size: var(--u-text__l);
    }
}
 /* -------------------------------------- 
	p-reason-02
----------------------------------------- */

.p-reason-02 {
    background-color: #0337a7;
    background-image: radial-gradient(#67a3d7, #1313d0);
    z-index: 0;
    /* margin-top: -35px; */
    padding: var(--u-length__m) 0 var(--u-length__l) 0;
    /* clip-path: polygon(0 0, 100% 0, 100% 94%, 50% 100%, 0 94%); */
}
.p-reason-02.active {
    -webkit-clip-path: none;
    clip-path: none;
}
.p-line { /* 縦ライン */
    width: 1px;
    height: 50px;
    margin: 0 auto ;
    position: relative;
    display: block;
    overflow: hidden;
}
.p-line__inner { 
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: linear-gradient(to bottom, transparent, #fff);
    animation: line_animation 1s linear infinite;
}
.p-reason-02 .p-line:last-child .p-line__inner {
}
@keyframes line_animation {
    0% {
      transform: translateY(-100%);
    }
  
    100% {
      transform: translateY(100%);
    }
}
.p-reason-02 .l-inner { /* インナーサイズ */
    margin-top: 30px;
    display: flex;
    flex-direction: column ;
    justify-content: center;
}

/* 見出しエリア */
/* .p-reason-02__heading01 h2 {
    margin: 0;
    font-size: calc( var(--u-text__xxl) + 4px);
    font-weight: normal;
    letter-spacing: 0.5rem;
} */
.p-reason-02__heading01 h3 {
    margin: 12px 0 0 0;
    font-size: var(--u-text__l);
    font-weight: normal;
    letter-spacing: 0.5rem;
    line-height: 2;
}
.p-reason-02__heading01 img {
    margin: 20px auto 30px auto;
    display: block;
    width: 310px;
    height: auto;
}
@media (min-width:769px){
    /* .p-reason-02 {
        padding: 100px 0;
    } */
}
/* 
図表エリア
 */
 :root {
    --p-reason-02__image-container-size: 300px;
    --p-reason-02__list-width: 392px;
}

.p-reason-02__image {
    position: relative;
    width: 100%;
    height: 52vw;
}
@media (min-width:769px){
    .p-reason-02__image {
        margin: 30px 0 0 0;
        width: 100%;
        height: var(--p-reason-02__image-container-size);
        display: flex;
        justify-content: space-between;
    }
    /* 見出しエリア */
    .p-reason-02__heading01 h2 {
    }
    .p-reason-02__heading01 h3 {
        margin: 3px 0 0 0;
        font-size: var(--u-text__l);
    }
    .p-reason-02__heading01 img {
        margin: 25px auto 25px auto;
        width: 450px;
        opacity: 0.5;
    }
}
@media (min-width:1200px){
    :root {
        --p-reason-02__image-container-size: 20vw;
        --p-reason-02__list-width: 27vw;
    }
}
@media (min-width:1440px){
    :root {
        --p-reason-02__image-container-size: 300px;
        --p-reason-02__list-width: 392px;
    }
}

/* ひし形 */

.p-reason-02__image .p-rhombus {
    width: 52vw;
    height: 52vw;;
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 1;
}
.p-reason-02__image .p-rhombus:first-child {
    position: absolute;
    top: 0;
    background: #005279;
    background-image: var(--u-gradation__05_reverse);
    left: 1vw;
}
.p-reason-02__image .p-rhombus:nth-child(2) {
    position: absolute;
    top: 0;
    background: #005279;
    background-image: var(--u-gradation__05);
    right: 1vw;
}
.p-reason-02__image .p-rhombus:nth-child(3) {
    position: absolute;
    background: #000;
    width: calc( 2vw + 4vw);
    height: calc( 2vw + 4vw);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    z-index: 10;
}
@media (min-width:769px){
    .p-reason-02__image .p-rhombus {
        width: var(--p-reason-02__image-container-size);
        height: var(--p-reason-02__image-container-size);
    }
    .p-reason-02__image .p-rhombus:first-child {
        left: 50%;
        transform: translateX(-93%);
    }
    .p-reason-02__image .p-rhombus:nth-child(2) {
        right: 50%;
        transform: translateX(93%);
    }
    .p-reason-02__image .p-rhombus:nth-child(3) {
        width: calc(var(--p-reason-02__image-container-size) * 0.14);
        height: calc(var(--p-reason-02__image-container-size) * 0.14);
    }
}
/* ひし形の中身 */
.p-reason-02__image .p-rhombus h3 {
    margin: 0;
    font-size: calc( var(--u-text__xl) - 3px);
}
.p-reason-02__image .p-rhombus p {
    margin: 0;
    font-size: 11px;
}
.p-rhombus__button {
    padding: 1px 8px;
    font-size: 12px;
    background: #fff;
    border-radius: 3px;
    font-weight: bold;
    margin-top: 10px;
    display: block;
}
@media (min-width:1200px){
    .p-rhombus__button {
        display: none;
    }
    .p-reason-02__image .p-rhombus h3 {
        margin: 0;
        font-size: calc( var(--u-text__xl) - 3px);
    }
    .p-reason-02__image .p-rhombus p {
        margin: 4px 0 0 0;
        font-size: 14px;
    }
}
/* 2DX */
.p-reason-02__image .p-2dx {
    position: absolute;
    width: 50px;
    display: block;
    height: auto;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
/* 6角形（EC-CUBEのセキュリティ支援） */
.p-reason-02__heading02 {
    width: calc( 100% - 16px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 15px 0px;
    margin: var(--u-length__s) auto;
    -webkit-clip-path: polygon(10% 0%, 90% 0%, 100% 50%, 90% 100%, 10% 100%, 0% 50%);
    clip-path: polygon(10% 0%, 90% 0%, 100% 50%, 90% 100%, 10% 100%, 0% 50%);
}
.p-reason-02__heading02 h4 {
    margin: 0 0 0 0;
    font-size: var(--u-text__r);
}
.p-reason-02__heading02 h3 {
    margin: 3px 0 0 0;
    font-size: var(--u-text__xl);
}
@media (min-width:769px){
    .p-reason-02__heading02 {
        width: calc(var(--p-reason-02__image-container-size) * 2);
        padding: 15px 0px;
        margin: 30px auto 30px auto;
        clip-path: polygon(5% 0%, 95% 0%, 100% 50%, 95% 100%, 5% 100%, 0% 50%);
    }
}
/* 2DX説明リスト */
/* sp版ポップアップ部分 */
.p-reason-02__list-container, 
.p-left-only, 
.p-right-only {
    display: none;
}
.p-reason-02 .u-sp-only {
    display: block;
}
.p-reason-02 .u-pc-only {
    display: none;
}
.p-close {
    font-size: 45px;
    color: #fff;
    text-align: center;
    margin: -10px auto 0;
}
.p-reason-02__list-container.active {
    display: block;
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.80);
    color: #fff;
    z-index: 99;
    padding: 20px;
    overflow: scroll;
}
.p-reason-02__list-container.active.left .p-left-only {
    display: block;
}
.p-reason-02__list-container.active.right .p-right-only {
    display: block;
}
.p-reason-02__list {
    text-align: center;
}
.p-reason-02__list li {
    border-bottom: 1px solid #fff;
    padding: 15px 0;
    font-weight: bold;
}
.p-popup_2dx {
    width: 45px;
    margin: 0 auto;
}
/* ポップアップ内ひし形 */
.p-popup_rhombus {
    width: 160px;
    height: 160px;
    margin: 10px auto 0;
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
    background: #005279;
    background-image: var(--u-gradation__05_reverse);
    position: relative;
}
.p-popup_rhombus_text {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    top: 120px;
}
.p-reason-02__list-container h3 {
    font-size: 2rem;
    line-height: 1.5;
    margin: 0;
    white-space: nowrap
}
.p-popup_en {
    margin: 3px 0 0;
}
/* リストのリスト */
.p-reason-02__list_list li{
    border-bottom: none;
    padding: 2px 0;
    font-weight: normal;
}
.u-border-none {
    border-bottom: none !important;
    padding-bottom: 0 !important;
}
.u-border-top {
    border-top: 1px solid #fff;
    margin-top: 10px;
}

@media (min-width:768px){
    .p-reason-02__list-container.active {
        padding-top: 100px;
        padding-bottom: 100px;
    } 
    .p-popup_2dx {
        width: 65px;
    }   
    .p-popup_rhombus {
        width: 240px;
        height: 240px;
    }    
    .p-reason-02__list-container h3 {
        font-size: 2.9rem;
    }
    .p-popup_rhombus_text {
        top: 250px;
    }   
    .p-close {
        margin: 10px auto 0;
    }  
}
@media (min-width:1200px){
    .p-reason-02 .u-sp-only {
        display: none;
    }
    .p-reason-02 .u-pc-only {
        display: block;
    }
    .p-reason-02__list-container {
        display: block;
    }
    .p-reason-02__list {
        position: absolute;
        display: block;
        width: var(--p-reason-02__list-width);
        height: calc(var(--p-reason-02__image-container-size) + 0px);
        padding: 30px 0 30px 0;
        display: flex;
        flex-flow: column;
        justify-content: space-around;
        font-weight: bold;
        color: #fff;
        margin: 0 0 0 0;
        text-align: left;
    }
    .p-reason-02__list li {
        border-bottom: none;
        position: relative;
        font-size: 15px;
        list-style: none;
        padding: 0;
    }
    .p-reason-02__list.p-list__right li{
        padding: 0 0 0 10px;
    }
    .p-reason-02__list.p-list__left {
        display: flex;
        left: 0;
    }
    .p-reason-02__list.p-list__right {
        display: flex;
        right: 0;
    }
    /* 下線 */
    .p-reason-02__list > li::before {
        position: absolute;
        content: "";
        bottom: -15px;
        left: 0;
        height: 1px;
        width: 100%;
        background: #fff;
    }
    /* 下線斜め */
    /* .p-reason-02__list.p-list__left > li:nth-child(-n+3)::after {
        position: absolute;
        content: "";
        border-bottom: 1px solid #fff;
        width: 150px;
        height: 1px;
        bottom: -15px;
        right: -150px;
        background: #fff;
        transform: rotate(45deg);
        transform-origin: 0% 0%;
    } */
    .p-reason-02__list.p-list__left > li:nth-child(n+4)::after {
        position: absolute;
        content: "";
        border-bottom: 1px solid #fff;
        width: 150px;
        height: 1px;
        bottom: -15px;
        right: -150px;
        background: #fff;
        transform: rotate(-45deg);
        transform-origin: 0% 0%;
    }
    /* .p-reason-02__list.p-list__right > li:nth-child(-n+2)::after {
        position: absolute;
        content: "";
        border-bottom: 1px solid #fff;
        width: 150px;
        height: 1px;
        bottom: -15px;
        left: 0px;
        background: #fff;
        transform: rotate(135deg);
        transform-origin: 0% 0%;
    } */
    /* .p-reason-02__list.p-list__right > li:nth-child(n+3)::after {
        position: absolute;
        content: "";
        border-bottom: 1px solid #fff;
        width: 150px;
        height: 1px;
        bottom: -15px;
        left: 0px;
        background: #fff;
        transform: rotate(-135deg);
        transform-origin: 0% 0%;
    } */
    /* リスト2階層目 */
    .p-reason-02__list ul li {
        font-size: 1.4rem;
        font-weight: normal;
        line-height: 1.8;
        margin: 0 0 0 15px;
    }
    .p-reason-02__list li {
        font-size: var(--u-text__l);
    }
    /* リストのリスト */
    .p-reason-02__list_list li{
        padding: 0;
        }
        .u-border-top {
            border-top: none;
            margin-top: 0;
        }

}
@media (min-width:1440px){
    .p-reason-02__list li {
        font-size: var(--u-text__l);
    }
}
 /* -------------------------------------- 
 *
 * p-company
 * 
----------------------------------------- */
.p-company {
    width: 100%;
    padding: var(--u-length__xl) 0;
    background: var(--u-gradation__07);
}
.p-company .l-inner {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.p-company-01__column, 
.p-company-02__column {
    width: 100%;
}
.p-company-02__column {
    overflow: hidden;
}
@media (min-width:769px){
    
}
@media (min-width:1000px){
    .p-company .l-inner {
        flex-direction: row;
    }
    .p-company-01__column {
        width: 50%;
    }
    .p-company-02__column {
        width: calc(50% - 30px);
    }
}
 /* -------------------------------------- 
	p-company-01
----------------------------------------- */
.p-company-01__heading h4 {
    font-size: var(--u-text__l);
    color: var(--u-color__yellow);
    text-align: center;
    font-weight: normal;
    margin: 0;
}
.p-company-01__heading h2 {
    font-size: calc( var(--u-text__xxl) - 1px);
    color: #fff;
    text-align: center;
    margin: 10px 0 0 0;
}
.p-company-01__heading h3 {
    font-size: var(--u-text__m);
    color: var(--u-color__yellow);
    text-align: center;
    margin: 30px 0 0 0;
    line-height: 2;
}
.p-company-01__body p {
    color: var(--u-color__light_gray);
    margin: 30px 0 0 0;
    line-height: 1.8;
}
.c-hr__dark {
    display: block;
}
@media (min-width:1000px){
    .p-company-01__heading h4 {
        text-align: left;
    }
    .p-company-01__heading h2 {
        text-align: left;
        margin: 10px 0 0 0;
    }
    .p-company-01__heading h3 {
        text-align: left;
        margin: 30px 0 0 0;
        line-height: 1.75;
    }
    .p-company-01__body {
        width: 95%;
    }
    .p-company-01__body p {
        color: var(--u-color__light_gray);
        margin: 30px 0 0 0;
        line-height: 1.8;
        text-align:justify;
    }
    .c-hr__dark {
        display: none;
    }
}
@media (min-width:1200px){
    .p-company-01__body {
        width: 78%;
    }
}
 /* -------------------------------------- 
	p-company-02
----------------------------------------- */
.p-company-02__heading h4 {
    font-size: 1.4rem;
    margin: 0 0 10px 0;
}
.p-company-02__heading img {
    width: 245px;
    height: auto;
    margin: 0 auto;
    display: block;
}
.p-company-02__heading h3 {
    font-size: 1.6rem;
    font-weight: bold;
    margin: 20px 0 0 0;
}
.p-company-02__box_container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    text-align: center;
    align-items: center;
    margin: 25px 0 0 0;
}
@media (min-width:769px){
    .p-company-02__box_container {
        justify-content: flex-start;
        margin: 25px 0 0 0;
    }
}
/*　/box---　*/
.p-company__box {
    width: calc( 33.33vw - var(--u-padding__smartphone) * 1.1);
    height: calc( 33.33vw - var(--u-padding__smartphone) * 1.1);
    border-radius: 4px;
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 1.44;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: calc( var(--u-padding__smartphone) * 0.75);
    position: relative;
    filter: var(--u-drop-shadow__01);
}
@media (min-width:769px){
    .p-company__box {
        width: calc((var(--js-p-company__width) - 49px) / 4);
        height: calc((var(--js-p-company__width) - 49px) / 4);
        border-radius: 6px;
        font-size: 1.5rem;
        margin: 6px;
        padding: 3px;
    }
    .p-br-company {
        display: block;
    }
}
@media (min-width:1000px){
    .p-company__box {
        width: calc((var(--js-p-company__width) - 37px) / 3);
        height: calc((var(--js-p-company__width) - 37px) / 3);
        font-size: 1.3rem;
    }
}
@media (min-width:1200px){
    .p-company__box {
        width: calc((var(--js-p-company__width) - 49px) / 4);
        height: calc((var(--js-p-company__width) - 49px) / 4);
    }
}
@media (min-width:1440px){
    .p-company__box {
        font-size: 1.5rem;
    }
}
/*　/boxの色---　*/
.p-company__box.p-box__eccube {
    background-color: #fed82f;
    background-image: var(--u-gradation__01);
    color: #000;
}
.p-company__box.p-box__community {
    background-color: #cf5a6a;
    background-image: var(--u-gradation__02);
    color: #fff;
}
.p-company__box.p-box__security {
    background-color: #3194d7;
    background-image: var(--u-gradation__03);
    color: #fff;
}
.p-company__box.p-box__development {
    background-color: #609891;
    background-image: var(--u-gradation__04);
    color: #fff;
}
/*
　/boxの修飾---　
*/
/*　/boxの見出し---　*/
.p-company__box.p-box__eccube::before {
    content: "EC-CUBE";
    color: #000;
    font-size: 1.0rem;
    font-weight: normal;
    position: absolute;
    top: 0.7rem;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.p-company__box.p-box__community::before {
    content: "COMMUNITY";
    color: #fff;
    font-size: 1.0rem;
    font-weight: normal;
    position: absolute;
    top: 0.7rem;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.p-company__box.p-box__security::before {
    content: "SECURITY";
    color: #fff;
    font-size: 1.0rem;
    font-weight: normal;
    position: absolute;
    top: 0.7rem;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.p-company__box.p-box__development::before {
    content: "DEVELOPMENT";
    color: #fff;
    font-size: 1.0rem;
    font-weight: normal;
    position: absolute;
    top: 0.7rem;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
/*
　/boxにリンク先がある場合---　
*/
.p-company__box a {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    color: #fff;
}
.p-company__box.p-box__eccube a {
    color: #000;
}
/*　/詳しく---　*/
.p-company__box a:not(.p-box__eccube)::before {
    content: "詳しく";
    color: #fff;
    font-size: 1.0rem;
    font-weight: normal;
    text-decoration: underline;
    position: absolute;
    bottom: 0.7rem;
    left: 1rem;
}
.p-company__box.p-box__eccube a::before {
    content: "詳しく";
    color: #000;
    font-size: 1.0rem;
    font-weight: normal;
    text-decoration: underline;
    position: absolute;
    bottom: 0.7rem;
    left: 1rem;
}
/*　/右下のさんかくアイコン---　*/
.p-company__box a:not(.p-box__eccube)::after {
    content: "";
    position: absolute;
    bottom: 0.7rem;
    right: 0.7rem;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 8px 8px;
    border-color: transparent transparent #fff transparent;
}
.p-company__box.p-box__eccube a::after {
    content: "";
    position: absolute;
    bottom: 0.7rem;
    right: 0.7rem;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 8px 8px;
    border-color: transparent transparent #000000 transparent;
}/*　---boxの修飾/　*/
  
/*　/Animation---　*/
.p-company-02__box_container .p-company__box {
    opacity: 0;
    transform: translate(100px,50px);
    transition: all 0.3s;
}
.p-company-02__box_container .p-company__box.active {
    opacity: 1;
    transform: translate(0px,0px);
}
.p-company-02__box_container .p-company__box.active:nth-of-type(1) {transition-delay: 0s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(2) {transition-delay: 0.1s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(3) {transition-delay: 0.2s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(4) {transition-delay: 0.3s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(5) {transition-delay: 0.4s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(6) {transition-delay: 0.5s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(7) {transition-delay: 0.6s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(8) {transition-delay: 0.7s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(9) {transition-delay: 0.8s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(10) {transition-delay: 0.9s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(11) {transition-delay: 1.0s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(12) {transition-delay: 1.1s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(13) {transition-delay: 1.2s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(14) {transition-delay: 1.3s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(15) {transition-delay: 1.4s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(16) {transition-delay: 1.5s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(17) {transition-delay: 1.6s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(18) {transition-delay: 1.7s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(19) {transition-delay: 1.8s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(20) {transition-delay: 1.9s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(21) {transition-delay: 2.0s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(22) {transition-delay: 2.1s;}
.p-company-02__box_container .p-company__box.active:nth-of-type(23) {transition-delay: 2.2s;}
 /* -------------------------------------- 
	pickupエリア
----------------------------------------- */
.p-pickup__section {
    padding: var(--u-length__l) 0;
    background-color: #F7F7F7;
    position: relative;
 }
.p-pickup__h2 {
    text-align: center;
    margin: 0 0 var(--u-length__s) 0;
    font-size: var(--u-text__xxl);
    font-family: 'Noto Sans CJK JP';
    font-weight: 500;
    letter-spacing: 0.5rem;
}

/* スライダー */
.p-pickup {
    width: 100%;
    height: auto;
}
.p-pickup li {
    padding: 0 12.5px 0 12.5px;
}
.p-pickup li img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border: 1px solid #ccc;
    border-radius: 6px;
    filter: drop-shadow(0px 3px 3px rgba(0, 0, 0, 0.3));
}
.p-pickup li .slider-text {
    width: 100%;
}
  /* arrow */
.p-pickup__section .slick-arrow {
    width: 80px;
    height: calc(100% + var(--u-length__xl) * 2 + var(--u-text__xxl));
    position: absolute;
    top: calc(0px - var(--u-length__s) - var(--u-length__xl) - var(--u-text__xxl));
    z-index: 1;
    cursor: pointer;
}
.p-pickup__section .prev_icon.slick-arrow {
    left: 0;
}
.p-pickup__section .next_icon.slick-arrow {
    right: 0;
}
.p-pickup__section .slick-arrow:hover {
    background:rgba( 0, 0, 0, .3);
}
.p-pickup__section .slick-arrow::before {
    content: '';
    display: block;
    width: 10px;
    height: 10px;
    border: 1px solid #383b4a;
    border-width: 2px 2px 0 0;
    position: absolute;
    top: calc(var(--u-length__xl) + 0px);
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: rotate(45deg);
}
.p-pickup__section .prev_icon.slick-arrow::before {
    transform: rotate(-135deg);
}
.p-pickup__section .slick-arrow:hover:before {
    border: 1px solid #fff;
    border-width: 2px 2px 0 0;
}
.p-pickup__section .slider-text p {
    font-size: var(--u-text__s);
    margin: var(--u-length__xs) 0 0 0;
}

 /* -------------------------------------- 
	企業ロゴエリア
----------------------------------------- */   
.p-logo__section {
    margin-bottom: 40px;
    z-index: 0;
 }
.p-logo__section .slick-slide {
    margin: 0 50px 0 0;
 }

.slider_logo li {
    width: auto;
    height: 63px;
}
.slider_logo li img {
    height: auto;
}

@media (min-width:768px){
    .p-logo__section {
        margin-top: 70px;
        margin-bottom: 60px;
    }
}
  
 /* -------------------------------------- 
	セキュリティ支援エリア
----------------------------------------- */  

.u-u999_only {
    display: block;
}
.u-o1000_only {
    display: none;
}  
.u-o1600_only {
    display: none;
}
.p-security {
    margin-top: -60px;
}
.p-security_topic__inner a,
.p-security_topic__inner a:link,
.p-security_topic__inner a:visited,
.p-security_topic__inner a:active
{
    color: var(--u-color__blue);
    text-decoration: underline;
}
.p-security__top {
    background: #fff url(../img/top/security/security_bg_sp.png) no-repeat;
    background-size:  cover;  
    padding-top: 80px !important;
    padding-bottom: 80px !important;
}
.p-security__h2 {
    font-size: var(--u-text__xxl);
    margin-top: 0;
    color: var(--u-color__blue);
    text-align: center;
}
.p-security__h2_topic {
    font-size: var(--u-text__m);
    color: #000;
}
.p-security__text {
    max-width: 650px;
    margin: 0 auto;
}
.p-security__h4 {
    color: var(--u-color__blue);
    margin-top: 10px;
}
.p-eccube_security {
    text-align: center;
    margin-top: 35px;
}
.p-security_topic__inner {
    background-color: #fff;
    padding: 50px var(--u-padding__smartphone) 0;
}
/*インナー見出し*/
.p-security__head-img img {
    height: 100%;
    width: auto;
}
.p-security__head-img {
    width: auto;
    height: 42px;
    display: flex;
    justify-content: center;
    margin: 0 0 7px 0;
}
.p-environment__inner .p-security__head-img img{
    height: 75%;
    margin-bottom: 5px;
}
.p-security_h3 {
    text-align: center;
    font-family: adobe-caslon-pro, serif;
    letter-spacing: 0.05em;
    font-size: 4rem;
    border-bottom: 4px solid var(--u-color__blue);
    margin: 0;
    color: var(--u-color__blue);
}
.p-security_h3_sb {
    font-size: var(--u-text__m);
    font-weight: bold;
    text-align: center;
    margin: 0px 0 40px 0;
    line-height: 1.5;
    border-top: 4px solid var(--u-color__blue);
    color: var(--u-color__blue);
    padding: 12px 0 0 0;
}
.p-security__list_name {
    color: var(--u-color__blue);
    font-size: var(--u-text__m);
    font-weight: bold;
    border-bottom: 1px solid var(--u-color__blue);
    position: relative;
    margin-left: 40px;
    padding-bottom: 3px;
    line-height: 1.2;
}
.p-security__list_name::before {
    position: absolute;
    top: -2px;
    left: 0;
    content: url(../img/top/security/s_icon_b.png);
    margin-left: -40px;
 }
 .p-security__list_text {
    padding-left: 40px;
    margin: 7px 0 20px;
 }
 .p-security__list {
    padding: 0 10px;
 }
 .p-vulnerability__list {
    border: 1px solid var(--u-color__blue);
 }
 .p-vulnerability {
    background-image: linear-gradient(62deg, #005AB9 0%, #6EA1D7 100%);
    color: #fff;
    font-weight: bold;
    line-height: 3;
 }
 .p-vulnerability__text {
    margin: 20px 20px 35px 60px;
 }
 .p-vulnerability__text:last-child {
    margin-bottom: 20px;
 }
 .p-application::before {
    content: url(../img/top/security/s_icon_g.png);
 }
 .p-application:last-child{
    margin-bottom: 0;
 }
 .p-people::before {
    content: url(../img/top/security/s_icon_a.png);
 }
 .p-people__figure {
    text-align: center;
 }
 .p-people__img {
    border: 1px solid var(--u-color__cyan);
 }
 .p-people__note {
    font-size: 1.2rem;
    text-align: center;
    margin: 5px 0 0 0;
 }
 .p-security_3topic {
    display: flex;
    flex-direction: column;
 }   
 .p-application__inner {
    order: 1;
 }
 .p-environment__inner {
    order: 2;
 }
 .p-people__inner {
    order: 3;
    padding-bottom: 50px;
 }

 /* color */
 .u-color__g {
    color: var(--u-color__green);
    border-color: var(--u-color__green);
 }
 .u-color__a {
    color: var(--u-color__cyan);
    border-color: var(--u-color__cyan);
 }
 .u-mg__0 {
    margin-bottom: 0;
 }

 @media (min-width:1000px){
    .u-u999_only {
        display: none;
    }
    .u-o1000_only {
        display: block;
        color: var(--u-color__blue);
        font-weight: bold;
        margin: 0 0 10px 0;
    }  
    .p-security {
        background: #fff url(../img/top/security/security_bg_pc.png) no-repeat;
        background-size:  cover;  
    }
    .p-security__h2__text,
    .p-security__h2 {
        text-align: left;
    } 
    .p-security__h2 {
        margin-bottom: 7px;
    }
    .p-eccube_security {
        margin-top: 0;
    }
    .p-eccube_security__text {
        width: 210px;
    }
    .p-security__h4 {
        font-size: 1.4rem;
        color: #000;
    }
    .p-security_3topic {
        flex-direction: column;
        max-width: 1200px;
        margin: 0 auto;
        align-items: stretch;
        flex-wrap: wrap;
        justify-content: center;
        gap: 40px 40px;
        padding: 0 30px 110px 30px;
    } 
    .p-eccube_security__img {
        margin: 0 auto 20px;
        max-width: 650px;
        
    } 
    .p-security__top{
        display: flex;
        padding-left: 30px;
        padding-right: 30px;
        align-items: center;
        background: none;
        justify-content: space-between;
        padding-top: 50px !important;
        padding-bottom: 0 !important;
        max-width: 1200px;
    }
    .p-eccube_security {
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    .p-application_wrapper,
    .p-people__list_wrapper,
    .p-security_title,
    .p-environment__list {
        display: flex;
        gap: 0 30px
    } 
    .p-security__list,
    .p-vulnerability__list,
    .p-people__list,
    .p-environment {
        width: 100%;
    }
    .p-vulnerability__list {
        height: 275px;
    }
    .p-3topic__img {
        max-width: 343px;
        height: 100%;
    }
    .p-security_title {
        align-items: center;
        margin-bottom: 25px;
        margin-top: 20px;
    }
    .p-security__list {
        padding: 0px;
    }
    .p-security_h3 {
        border-bottom: none;
        font-size: 4.5rem;
    }
    .p-security_h3_sb {
        margin: 0 0 13px 0;
        font-size: 1.6rem;
        color: var(--u-color__blue);
        border: none;
    }
    .p-people_h3_sb {
        color: var(--u-color__cyan);
    }
    .p-people__figure {
        text-align: right;
    }
    .p-people__note {
        text-align: right;
    }    
    .p-environment_h3_sb {
        color: var(--u-color__green);
    }
    .p-security_topic__inner {
        border-left: 5px solid var(--u-color__blue);
        padding: 20px 35px;
        filter: drop-shadow(2px 2px 5px rgba(0, 0, 0, 0.2));
    }
    .p-environment__inner {
        border-left:  5px solid var(--u-color__green);
    }
    .p-environment__inner {
        order: 3;
     }
    .p-people__inner {
        order: 2;
        border-left: 5px solid var(--u-color__cyan);
    }
 }   
 @media (min-width:1600px){
    .u-o1600_only {
        display: block;
    }
    .p-eccube_security {
        flex-direction: row;
        align-items: flex-end;
    }
    .p-security_3topic {
        flex-direction: row;
        max-width: 1800px;
        padding-bottom: 110px;
        position: relative !important;
    } 
    .p-eccube_security__img {
        position: absolute;
        max-width: 745px;
        z-index: 1;
        margin-top: -180px;
        left: 50%;
        transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
    } 
    .p-eccube_security__text {
        margin-bottom: 50px;
        margin-right: -50px;
    }
    .p-security__top {
        flex-direction:row;
        padding-top: 110px !important;
        padding-bottom: 30px !important;
        max-width: 1440px;
        flex-direction:row;
    }
    .p-security__text {
        max-width: 1000px;
    }
    .p-security_h3 {
        font-size: 5.4rem;
    }
    .p-people_h3_sb {
        color: var(--u-color__cyan);
    }
    .p-people__note {
        padding-left: 30px;
        text-align: left;
    }    
    .p-application__inner,
    .p-people__inner {
        width: calc(50% - 20px);
    }
    .p-environment__inner {
        width: 75%;
        padding-top: 40px;
        position: relative;
    }
 }
 /* -------------------------------------- 
 *
 * header
 * 
----------------------------------------- */
.large.header.active .inner {
    background: none!important;
}
#header.active > div > div.header_nav_area.l-header > div > nav.global_nav > ul > li > a {
    color: #fff!important;
}
#header.active > div > div.header_nav_area.l-header > div > nav.dev_nav > ul > li > a {
    color: #fff!important;
}
@media screen and (min-width: 992px) {
    .header.active .inner .btn-contact span, 
    .active .inner .btn-contact span {
        color: #fff!important;
        border: 1px solid #fff!important;
        background: url(../img/header/icon_store_w.svg) no-repeat 20px center;
    }
}
.header .inner .c-navicon__header-cvp span {
    background-color: #D0AB00;
    text-shadow: 0px 0px 6px rgb(0 0 0 / 20%);
}
.header .inner .c-navicon__header-cvp span:hover {
    background-color: #fff;
    color: #D0AB00;
    text-shadow: none;
}
 /* -------------------------------------- 
 *
 * 2024/03
 * 
----------------------------------------- */

[class^="u-text-"] {
    margin: 0;
    padding: 0;
}
.p-heading_xxxl {
    font-size: var(--u-text__xxxl);
}
.p-heading_xxl {
    font-size: var(--u-text__xxl);
}
.p-heading_xl {
    font-size: var(--u-text__xl);
}
.p-heading_m {
    font-size: var(--u-text__m);
}
.p-heading_r {
    font-size: var(--u-text__r);
}
.p-heading_decoration {
    border-left: 10px solid;
    padding-left: 30px;
    border-image: linear-gradient(to top, #004bff, #1313d0) 1;
}
/* .p-reason */
/* .p-reason_security */
.p-reason_security {
    width: 100%;
    margin: 0 auto;
    padding: 0 15px;
}
.p-reason_security_body {
    flex-direction: column;
}
.p-reason_security_body {
    flex-direction: column;
}
.p-reason_security_body .p-left {
    width: 100%;
}
.p-reason_security_body .p-right {
    width: 100%;
}
.p-reason_security_body .p-left p {
    margin: 0;
    padding: 0;
    text-align: justify;
}
@media (min-width:769px){
    .p-reason_security_body .p-left {
        padding: 0 30px 0 0;
    }
    .p-reason_security {
        max-width: 769px;
        margin: 0 auto;
    }
}
@media (min-width:900px){
    .p-reason_security {
        max-width: 980px;
        margin: 0 auto;
    }
    .p-reason_security_body {
        flex-direction: row;
    }
    .p-reason_security_body .p-left {
        width: 55%;
    }
    .p-reason_security_body .p-right {
        width: 45%;
    }
}
.p-reason_security_body .p-detail a {
    text-decoration: underline;
    color: #fff;
    margin: 0;
    padding: 0;
    text-align: right;
}
/* .p-development */
.p-development {
    background: #f5f5f7;
}

.p-development01,
.p-development02 {
    background: #fff;
    border-radius: 18px;
    filter: var(--u-drop-shadow__03);
}
.p-eccube_development img {
    width: 200px;
    height: auto;
}
.p-enterprise_points {
    flex-direction: row;
}
.p-enterprise_points.p-square_container li {
    background-color: #1318d0;
    margin-right: 15px;
    font-size: 1.8rem;
    color: #fff;
}
.p-one_stop {
    display: none;
}
.p-eccube_development_img_container{
    display: none;
}
/* .p-one_stop */
@media (min-width:769px){
    .p-enterprise_points.p-square_container li {
        width: 128px;
        height: 128px;
        background-color: #1318d0;
        margin-right: 15px;
        font-size: 1.8rem;
        color: #fff;
    }
    .p-eccube_development > div:first-child {
        width: 70%;
    }
    .p-eccube_development_img_container{
        display: block;
        width: 30%;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .p-one_stop {
        display: block;
    }
    .p-one_stop_container {
        width: 600px;
        margin: 0 auto;
    }
    .p-one_stop_items.p-square_container li {
        width: 85px;
        height: 85px;
        background-color: #ffffff;
        margin-right: 15px;
        font-size: 2.4rem;
    }
    

}
@media (min-width:1040px){
    .p-one_stop_container {
        width: 843px;
        margin: 0 auto;
    }
    .p-one_stop_items.p-square_container li {
        width: 128px;
        height: 128px;
        background-color: #ffffff;
        margin-right: 15px;
        font-size: 2.4rem;
    }
    .p-enterprise_points.p-square_container li {
        width: 128px;
        height: 128px;
    }
}
.p-development_heading {
    font-size: 5rem;
}
.p-development .c-button {
    /* width: 70%; */
}
.p-one_stop {
    padding: var(--u-length__s) var(--u-length__m) var(--u-length__s) 0;
    background: linear-gradient(45deg, #1313d0, #006edb, #53d8c0);
}
.p-square_container > li {
    border-radius: 4px;
    display: flex;
    font-weight: bold;
    justify-content: center;
    align-items: center;
    color: var(--u-color__blue_vivid);
    letter-spacing: 1px;
    text-align: center;
    padding: 10px;
}
.p-one_stop_arrow {
    border: 2px solid #fff;
    width: calc(100% + 30px);
    position: relative;
}
.p-one_stop_arrow::after {
    content: "";
    clip-path: polygon(100% 100%, 0 0, 0 100%);
    width: 20px;
    height: 15px;
    right: -10px;
    bottom: -2px;
    position: absolute;
    background: #fff;
}

/* .p-enterprise */

.p-enterprise01 > div > img {
    max-width: calc(100% - 15px);
    width: 66%;
}
.p-enterprise_points span {
    font-size: 1.0rem;
    letter-spacing: 0;
}

.p-development01_cvp {
    background: #024e9a;
    border-radius: 10px;
    padding: 15px 15px 15px 15px;
    /* margin: 0 200px 0 200px; */
    width: 80%;
    margin: 0 auto;
    background: linear-gradient(45deg, #012e5b, #024e9a, #0065c9, #012e5b);
}
.p-development01_cvp p,
.p-development02_cvp p  {
    font-size: 1.8rem;
    margin: 0;
    padding: 0;
    text-align: center;
    font-weight: bold;
    color: #fff;
}
.p-development01_cvp .c-button {
    margin: 0 auto;
    
}
.p-development01_cvp .c-button a,
.p-development02_cvp .c-button a {
    font-size: 2rem;
    font-weight: bold;
    margin: 0 auto;
    padding: 13px;
    border-radius: 35px !important;
}
.p-development02 .p-development02_cvp {
    margin: 0 auto;
}
.p-development02_cvp {
    background: #024e9a;
    border-radius: 10px;
    padding: 15px 15px 15px 15px;
    /* margin: 0 200px 0 200px; */
    width: 80%;
    /* margin: 0 auto; */
    background: linear-gradient(45deg, #012e5b, #024e9a, #0065c9, #012e5b);
}
.p-serif {
    font-family: serif;

}
.p-circle {
    display: none;
}
.p-br_middle_only {
    display: none;
}
.p-enterprise01 {
    margin: 0 auto;
    flex-direction: column;
}
.p-enterprise {
    display: flex;
    flex-direction: column;
    margin-top: 25px;
}
.p-enterprise02 {
    margin-top: 25px;
    display: flex;
    flex-direction: column;
}
.p-development02 > div:first-child {
    display: flex;
    flex-direction: column;
}
@media (max-width:769px){
    .p-development .u-ph-m {
        padding: 0 10px!important;
    }
}
@media (min-width:1150px){
    .p-enterprise {
        flex-direction: row;
        margin-top: unset;
    }
    .p-enterprise01 {
        margin: unset;
    }
    .p-enterprise02 {
        margin-top: unset;
    }
}
@media (min-width:769px){
    .p-enterprise01 > div > img {
        max-width: calc(100% - 15px);
        width: 80%;
    }
    .p-br_middle_only {
        display: block;
    }
}
@media (min-width:1000px){
    .p-circle {
        display: block;
        width: 220px;
        height: 220px;
        background: #1313d0;
        border-radius: 50%;
        position: absolute;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        color: #fff;
        font-size: 3rem;
        font-weight: bold;
        letter-spacing: 4px;
        bottom: 30px;
        left: 36px;
        filter:  var(--u-drop-shadow__01); 
    }
    .p-development02 > div:first-child {
        flex-direction: row;
    }
    /* .p-development02 インテグレートパートナー */
.p-development02_01 {
    width: calc(100% - 40% - 40px);
    margin-right: 40px;
}
.p-development02_02 {
    width: calc(100% - 60%);
    height: auto;
    z-index: 0;
}
}
@media (min-width:1440px){
    .p-circle {
        display: block;
        width: 220px;
        height: 220px;
        background: #1313d0;
        border-radius: 50%;
        position: absolute;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        color: #fff;
        font-size: 3rem;
        font-weight: bold;
        letter-spacing: 4px;
        bottom: 0;
        left: 36px;
        filter:  var(--u-drop-shadow__01); 
    }
    .p-br_middle_only {
        display: none;
    }
}