@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainVisual {
	padding: 19.4rem 0 8.2rem;
	background-color: #000;
}
#main .mainVisual p {
	margin-bottom: 5.5rem;
	font-size: 4rem;
	text-align: center;
	color: #FFF;
	letter-spacing: 0.12em;
	font-weight: 250;
}
#main .mainVisual > .img {
	margin: 0 auto 1.8rem;
	width: 59.2rem;
	display: block;
}
#main .mainVisual .note {
	margin-bottom: 6.2rem;
	font-size: 1.6rem;
	font-weight: bold;
	letter-spacing: 0.17em;
	color: #606060;
}
#main .mainVisual .mainImg {
	margin-bottom: 5.5rem;
	position: relative;
}
#main .mainVisual .mainImg .textImg {
	padding-bottom: 1.4rem;
	position: absolute;
	top: -19.8rem;
	right: calc(50% - 71rem);
	width: 24.8vw;
	height: 24.8vw;
    max-width: 34.7rem;
	max-height: 34.7rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid #fff;
	border-radius: 50%;
	box-sizing: border-box;
}
#main .mainVisual .mainImg .textImg img {
	width: 31.1rem;
	position: relative;
	z-index: 2;
}
#main .mainVisual .mainImg .textImg::after{
	position: absolute;
	top: 0;
	left: 0;
	width: 24.8vw;
	height: 24.8vw;
    max-width: 34.7rem;
	max-height: 34.7rem;
	content: '';
	background: rgba(0, 0, 238, 1);
	border-radius: 50%;
	mix-blend-mode: multiply;
}
#main .mainVisual .linkUl li {
	margin: 0 2.7rem;
}
#main .mainVisual .linkUl li:first-child a {
	padding-left: 4rem;
	justify-content: flex-start;
}
#main .mainVisual .linkUl li:first-child a img {
    max-width: 38rem;
}
#main .mainVisual .linkUl li a img {
    max-width: 39rem;
}
#main .topBox {
	padding: 10.8rem 0 11.1rem;
	background: url(/lp/gpuserver/assets/img/index/topbox_bg.jpg) no-repeat center top / cover;
    position: relative;
    overflow: hidden;
}
#main .topBox::before {
    content: none;
}
#main .topBox .inner {
	width: 53.7%;
	margin-left: auto;
}
#main .topBox .inner .subBox {
	max-width: 76.5rem;
    width: 100%;
}
#main .topBox .h2Ttl {
	margin-bottom: 2.7rem;
	font-size: 3.6rem;
	font-weight: 300;
	color: #333;
	line-height: 1.7;
	letter-spacing: 0.12rem;
}
#main .topBox p {
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.8;
	letter-spacing: 0.2rem;
	color: #333;
}
#main .features {
    padding: 9.8rem 0 13.8rem;
}
#main .features .featuresUl li {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
#main .features .featuresUl li:not(:last-child) {
    margin-bottom: 7.9rem;
}
#main .features .featuresUl li .photo {
    width: 56.7rem;
}
#main .features .featuresUl li .textBox {
    padding-top: 0.1rem;
    width: calc(100% - 61rem);
}
#main .features .featuresUl li .h3Ttl {
    margin-bottom: 1.8rem;
    font-size: 2.4rem;
    font-weight: 700;
    color: #333;
    line-height: 3.7rem;
    letter-spacing: 0.192rem;
}
#main .features .featuresUl li p {
    font-weight: 250;
    line-height: 3.4rem;
    letter-spacing: 0.19rem;
}
#main .use {
    padding: 9.9rem 0;
    background-color: #EFEFEF;
}
#main .use .content {
    max-width: 113.4rem;
}
#main .use .headLine01 {
    margin-bottom: 2.5rem;
}
#main .use .centerTxt {
    margin-bottom: 10.3rem;
    text-align: center;
    color: #333;
    font-size: 1.9rem;
    font-weight: 250;
    line-height: 1.69;
    letter-spacing: 0.19rem;
}
#main .use .useUl {
    gap: 2.4rem;
}
#main .use .useUl li {
    width: calc((100% - 4.8rem)/3);
}
#main .use .useUl li .photo {
    margin-bottom: 1.5rem;
}
#main .use .useUl li .photo img {
    width: 100%;
}
#main .use .useUl li p {
    color: #333;
    text-align: center;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.032rem;
}
#main .use .useUl li p .sml {
    font-size: 1.4rem;
}
#main .product {
    padding: 19rem 0 13.4rem;
    background-color: #F1F1F1;
}
#main .product .content {
    max-width: 113.4rem;
}
#main .product .headLine01 {
    margin-bottom: 5rem;
    letter-spacing: 0.72rem;
}
#main .product .headLine01 .en {
    margin-bottom: 1.5rem;
}
#main .product .centerTxt {
    margin-bottom: 10.5rem;
    letter-spacing: 0.18rem;
    line-height: 1.71;
    text-align: center;
}
#main .product .centerTxt span {
    margin-top: 0.5rem;
    display: block;
    font-size: 1.4rem;
}
#main .product .inner {
    position: relative;
    z-index: 2;
}
#main .product .inner:not(:last-child) {
    margin-bottom: 11.6rem;
}
#main .product .inner .h3Ttl {
    margin-bottom: 3.8rem;
    font-size: 4rem;
    color: #333;
    font-weight: 250;
    letter-spacing: 0.4rem;
    text-align: center;
}
#main .product .productUl {
    gap: 3.2rem;
}
#main .product .productUl > li {
    width: calc(50% - 1.6rem);
    /* z-index: 2; */
    position: relative;
}
#main .product .productUl li .subBox {
    margin-bottom: 4.9rem;
    padding: 3.2rem 3.5rem 8rem 4.1rem;
    border-radius: 10px;
    background: #F1F1F1;
    box-shadow: -8px -8px 10px 0px #FFF, 8px 8px 10px 0px rgba(0, 0, 0, 0.10);
    box-sizing: border-box;
}
#main .product .productUl li .h4Ttl {
    margin-bottom: 2.4rem;
    font-size: 2rem;
    font-weight: 600;
    color: #333;
}
#main .product .productUl li .h4Ttl.big {
    font-size: 2.2rem;
}
#main .product .productUl .list01 .h4Ttl {
    margin-bottom: 2.3rem;
}
#main .product .productUl li .h4Ttl .en {
    margin-bottom: 1rem;
    display: block;
    font-size: 3.8rem;
    color: #000;
    font-weight: 200;
    line-height: 1.3;
}
#main .product .productUl .flexBox {
    min-height: 35rem;
    display: flex;
    flex-direction: column; 
}
#main .product .productUl .subInner .flexBox {
    flex-direction: row; 
}
#main .product .productUl .list01 .flexBox {
    min-height: 37.6rem;
}
#main .product .productUl .flexBox .photo {
    display: block;
    margin-left: auto;
    margin-right: auto;
    width: 80%;
    box-sizing: border-box;
}
#main .product .productUl .flexBox .photo2 {
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 1.5rem;
    width: 80%;
    box-sizing: border-box;
}
#main .product .productUl .flexBox .rBox {
    padding-bottom: 1.6rem;
    width: 100%;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: flex-end;
}
#main .product .productUl .list02 .flexBox .rBox {
    justify-content: space-between;
}
#main .product .productUl .flexBox .img1 {
    margin: -1rem -0.5rem 0 auto;
    width: 25.4rem;
    mix-blend-mode: multiply;
}
#main .product .productUl .flexBox .img2 {
    margin: 1rem -0.5rem 2rem auto;
    width: 25.4rem;
    mix-blend-mode: multiply;
}
#main .product .productUl .textUl li {
    padding-left: 0.5rem;
    font-size: 1.2rem;
    color: #333;
    position: relative;
}
#main .product .productUl .textUl li::before {
    position: absolute;
    top: 0.8rem;
    left: -0.5rem;
    width: 0.2rem;
    height: 0.2rem;
    border-radius: 50%;
    content: '';
    background-color: #333;
}
#main .product .productUl .productDl {
    margin-top: 1rem;
    width: 92%;
    position: absolute;
	top: calc(100% - 21.5rem);
	left: 50%;
	transform: translateX(-50%);
	z-index: 999;
}
#main .product .productUl .productDl dt {
    padding: 0;
    font-size: 1.4rem;
    text-align: center;
    border: 1px solid #333;
    border-radius: 1rem;
    background: #F1F1F1;
    cursor: pointer;
    position: relative;
}
#main .product .productUl .productDl dt:hover {
    opacity: 0.7;
}
#main .product .productUl .productDl .open {
    padding: 0.8rem 1rem 0.9rem;
    display: block;
}
#main .product .productUl .productDl dt.on .open {
    opacity: 0;
}
#main .product .productUl .productDl .open span {
    padding-right: 2.2rem;
    background: url(/lp/gpuserver/assets/img/common/icon06.png) no-repeat center right / 1.35rem;
}
#main .product .productUl .productDl .close {
    padding: 0.8rem 1rem 0.9rem;
    opacity: 0;
    background-color: #333;
    display: block;
    width: 100%;
    color: #fff;
    border-radius: 0.8rem;
    box-sizing: border-box;
    position: absolute;
    top: 0;
    left: 0;
}
#main .product .productUl .productDl dt.on .close {
    opacity: 1;
}
#main .product .productUl .productDl .close span {
    padding: 0 5.7rem 0 3.2rem;
    background: url(/lp/gpuserver/assets/img/common/icon10.png) no-repeat center right / 1.35rem;
}
#main .product .productUl .productDl dd {
    position: absolute;
    top: 130%;
    left: -3rem;
    right: -3.4rem;
    display: none;
}
#main .product .productUl .productDl dd .colseBtn {
    margin: 0 4.1rem 1rem 3.5rem;
    padding: 0.9rem 1rem;
    font-size: 1.4rem;
    display: block;
    text-align: center;
    color: #fff;
    font-weight: 400;
    background-color: #333;
    border: 1px solid #fff;
    border-radius: 1rem;
    cursor: pointer;
}
#main .product .productUl .productDl dd .colseBtn span {
    padding: 0 5.5rem 0 2rem;
    background: url(/lp/gpuserver/assets/img/common/icon10.png) no-repeat center right / 1.35rem;
}
#main .product .productUl .productDl dd .subInner {
    padding: 4.4rem 5.5rem 8.5rem;
    background-color: #fff;
    border: 1px solid #000;
}
#main .product .productUl .productDl dd .subInner .flexBox .textBox {
	width: calc((100% - 3.5rem)/2);
}
#main .product .productUl .productDl dd .subInner .h5Ttl {
	margin-bottom: 3.8rem;
    padding: 1rem 2rem 0.7rem;
    font-size: 1.6rem;
    min-width: 15.4rem;
    text-align: center;
    font-weight: 400;
    display: inline-block;
    color: #333;
    border: 1px solid #CCC;
}
#main .product .productUl .productDl dd .subInner .ttl {
	margin-bottom: 1.7rem;
	font-size: 1.6rem;
	color: #333;
	font-weight: 600;
}
#main .product .productUl .productDl dd .subInner .ttl01 {
	margin-bottom: 1.2rem;
	padding: 0.8rem 0.9rem;
	font-size: 1.4rem;
	font-weight: 300;
	color: #333;
	border: 1px solid #ccc;
}
#main .product .productUl .productDl dd .subInner .ttl02 {
	margin: 0 0 0.8rem 0.9rem;
	font-size: 1.4rem;
	font-weight: 600;
	color: #333;
}
#main .product .productUl .productDl dd .subInner .txt {
	margin-bottom: 3.5rem;
	color: #333;
	font-size: 1.4rem;
	font-weight: 300;
}
#main .product .productUl .productDl dd .subInner .txt01 {
	margin: 0 -0.5rem 3.2rem 0.9rem;
	font-size: 1.279rem;
	line-height: 2.24rem;
	color: #333;
	font-weight: 300;
}
#main .product .productUl .productDl dd .subInner .ttl02 + .txt01 + .ttl02 {
	margin-top: -1rem;
}
#main .product .productUl .productDl dd .subInner table {
	margin: 0 auto 1.5rem;
	width: 100%;
	border-spacing: 0;
}
#main .product .productUl .productDl dd .subInner th,
#main .product .productUl .productDl dd .subInner td {
	padding: 0.8rem 0.85rem 0.5rem;
	font-size: 1.3rem;
	font-weight: 300;
	line-height: 2.24rem;
	border: 1px solid #ccc;
	box-sizing: border-box;
	word-break: break-all;
	vertical-align: middle;
	text-align: left;
	color: #333;
}
#main .product .productUl .productDl dd .subInner th {
	width: 28%;
    font-size: 1.4rem;
}
#main .product .productUl .productDl dd .subInner th.sml {
    font-size: 1.3rem;
}
#main .product .productUl .productDl dd .subInner td.sml {
    font-size: 1.27rem;
}
#main .product .productUl .productDl dd .subInner td.sml01 {
    font-size: 1.38rem;
}
#main .product .productUl .productDl dd .subInner td.sml02 {
    font-size: 1.4rem;
}
#main .product .productUl .productDl dd .subInner .img01 {
    margin-bottom: 3.4rem;
    width: 20.5rem;
}
#main .product .productUl .productDl dd .subInner .noteUl li {
	font-size: 1.3rem;
	font-weight: 300;
	line-height: 2.08rem;
	color: #787878;
}
#main .product .productUl .productDl dd .subInner .noteUl li:not(:last-child) {
	margin-bottom: 0.9rem;
}
#main .product .productUl .productDl dd .subInner .redBtn {
	margin: 5.1rem 0 5rem;
}
#main .product .productUl .productDl dd .subInner .redBtn a {
	margin: 0 auto;
	padding: 4.4rem 2rem;
	max-width: 52.7rem;
	width: 100%;
	font-size: 1.6rem;
	font-weight: 700;
	display: block;
	text-align: center;
	line-height: 2rem;
	letter-spacing: 0.3rem;
	color: #fff;
	background-color: #B00000;
	font-family: "niveau-grotesk",sans-serif;
}
#main .product .productUl .productDl dd .subInner .redBtn a:hover {
	opacity: 0.7;
}
#main .product .productUl .productDl dd .subInner .btn {
    display: block;
    text-align: center;
}
#main .product .productUl .productDl dd .subInner .closeBtn01 {
    display: inline-block;
}
#main .product .productUl .productDl dd .subInner .closeBtn01 p {
	margin-bottom: 0.8rem;
    text-align: center;
    font-size: 1.4rem;
    font-weight: 600;
    display: inline-block;
    cursor: pointer;
}
#main .product .productUl .productDl dd .subInner .closeBtn01 img {
    width: 5.5rem;
    display: inline-block;
    cursor: pointer;
}
#main .product .productUl .list04 .productDl .subInner .txt01 {
    margin-bottom: 4.5rem;
}
#main .product .productUl .link {
    margin: 0 auto;
    max-width: 28.2rem;
}
#main .product .productUl .link a {
    padding: 1.8rem 1.6rem 1.9rem;
    color: #FFF;
    display: block;
    text-align: center;
    font-family: "niveau-grotesk",sans-serif;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 2.4rem; 
    letter-spacing: 0.2rem;
    background: #B00000;
}
#main .product .productUl .link a:hover {
    opacity: 0.7;
}
#main .product .inner01 {
    z-index: 1;
}
#main .product .inner01 .productUl li .h4Ttl {
    margin-bottom: 3.7rem;
}
#main .features01 {
    padding: 10rem 0 31.4rem;
    background: url(/lp/gpuserver/assets/img/index/features01_bg.png) no-repeat center bottom 0.1rem / 192rem auto,#010101;
}
#main .features01 .content {
    max-width: 147rem;
}
#main .features01 .headLine01 {
    margin-bottom: 2.6rem;
    color: #fff;
}
#main .features01 .headLine01 .en {
    margin-bottom: 2.6rem;
}
#main .features01 p {
    margin-bottom: 9.2rem;
    font-weight: 250;
    line-height: 1.65;
    letter-spacing: 0.19rem;
    color: #fff;
    text-align: center;
}
#main .features01 .photo {
    margin: 0 auto;
    width: 80%;
}
#main .profife {
    padding: 9.8rem 0 17.6rem;
    background-color: #F4F4F4;
}
#main .profife .content {
    max-width: 141.8rem;
}
#main .profife .headLine01 {
    margin-bottom: 7.6rem;
}
#main .profife .inner {
    padding: 7rem 8rem 7.3rem 7rem;
    box-shadow: -4px -4px 4px 0px #FFF, 4px 4px 4px 0px rgba(0, 0, 0, 0.15);
}
#main .profife .imgBox {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
#main .profife .imgBox:not(:last-child) {
    margin-bottom: 6.4rem;
}
#main .profife .inner:not(:last-child) {
    margin-bottom: 7.8rem;
}
#main .profife .inner .imgBox01 {
    flex-direction: row-reverse;
}
#main .profife .inner .imgBox.wid01 {
    margin-bottom: 7rem;
    align-items: center;
}
#main .profife .imgBox .photo {
    width: 48.6%;
}
#main .profife .inner .imgBox01 .photo {
    width: 49.4%;
}
#main .profife .inner .imgBox.wid01 .photo {
    margin: 4rem 1rem 0 0;
    width: 41%;
}
#main .profife .inner .imgBox.wid02 .photo {
    margin-top: 3.8rem;
    width: 57.5%;
}
#main .profife .imgBox .textBox {
    width: 50%;
}
#main .profife .inner .imgBox01 .textBox {
    width: 48.6%;
}
#main .profife .inner .imgBox.wid01 .textBox {
    width: 52%;
}
#main .profife .inner .imgBox.wid02 .textBox {
    width: 39%;
}
#main .profife .imgBox .h5Ttl {
    margin-bottom: 3rem;
    font-size: 2.4rem;
    color: #333;
    font-weight: 600;
    line-height: 3.6rem; 
    letter-spacing: 0.2rem;
}
#main .profife .inner01 .imgBox .h5Ttl {
    letter-spacing: 0.048rem;
}
#main .profife .imgBox .h5Ttl.ttl {
    margin-top: -0.4rem;
}
#main .profife .imgBox .h5Ttl .star {
    font-size: 1.4rem;
    vertical-align: 0.7rem;
}
#main .profife .imgBox .h5Ttl span {
    font-weight: 300;
}
#main .profife .imgBox p {
    font-weight: 250;
    line-height: 170%;
    letter-spacing: 0.038rem;
}
#main .profife .imgBox .note {
    margin-top: 1.8rem;
    font-size: 1.4rem;
    font-weight: 250;
    line-height: 3.4rem;
}
#main .comConsult.box01 {
    /* background: url(/lp/gpuserver/assets/img/index/consult_bg01.png) no-repeat center top / cover; */
    background-color: #000;
}
#main .comConsult.box01::before {
    display: none;
}
#main .comConsult.box01 p {
    color: #FFF;
    text-shadow: 0px 10px 6px rgba(0, 0, 0, 0.25);
}
#main .comConsult.box01 .comLink {
    bottom: -5.5rem;
}
#main .flow {
    padding: 16.5rem 0 14rem;
    background-color: #EFEFEF;
}
#main .flow .content {
    max-width: 162.2rem;
}
#main .flow .headLine01 {
    margin-bottom: 9.7rem;
}
#main .flow .headLine01 .en {
    margin-bottom: 1rem;
}
#main .flow .flowUl {
    gap: 2.4rem;
}
#main .flow .flowUl li {
    width: calc((100% - 9.6rem)/5);
    position: relative;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    justify-content: space-between;
    border: 1px solid #333;
    background-color: #FFFFFF;
}
#main .flow .flowUl li::after {
    position: absolute;
    top: 9.6rem;
    right: -9rem;
    width: 15.45rem;
    height: 0.8rem;
    content: '';
    background: url(/lp/gpuserver/assets/img/common/icon07.png) no-repeat center right / 100% 100%;
    z-index: 2;
}
#main .flow .flowUl li:last-child:after {
    display: none;
}
#main .flow .flowUl li .textBox {
    padding: 3.2rem 2.9rem 1.5rem;
    min-height: 41.4rem;
    box-sizing: border-box;
}
#main .flow .flowUl li .num {
    margin-bottom: -1.2rem;
    color: #29A2C8;
    text-align: center;
    font-family: "futura-pt",sans-serif;
    font-size: 9rem;
    font-weight: 400;
    letter-spacing: 1.8rem;
}
#main .flow .flowUl li .ttl {
    margin-bottom: 1.3rem;
    min-height: 8rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    color: #333;
    text-align: center;
    font-size: 2.4rem;
    font-weight: 500;
    letter-spacing: 0.12rem;
}
#main .flow .flowUl li .text {
    color: #333;
    font-size: 1.6rem;
    font-weight: 300;
}
#main .contact {
    padding: 9.5rem 0;
}
#main .contact .content {
    max-width: 96.5rem;
}
#main .contact .headLine01 {
    margin-bottom: 5rem;
    letter-spacing: 0.72rem;
}
#main .contact .headLine01 .en {
    margin-bottom: 1.4rem;
}
#main .contact .ttl {
    margin-bottom: 1.5rem;
    color: #333;
    text-align: center;
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: 0.09rem;
}
#main .contact .text {
    margin-bottom: 5.8rem;
    color: #333;
    text-align: center;
    font-size: 1.6rem;
    letter-spacing: 0.032rem;
}
#main .contact table {
	margin: 0 auto;
	width: 100%;
	border-collapse: collapse;
}
#main .contact td,
#main .contact th {
	padding: 1.2rem 0.8rem 1.2rem;
    font-size: 1.6rem;
    font-weight: 300;
    color: #333;
	text-align: left;
	vertical-align: top;
    word-break: break-all;
    border-bottom: 1px dashed #CCC;
    border-top: 1px dashed #CCC;
}
#main .contact tr:first-child td,
#main .contact tr:first-child th {
    border-top: 1px solid #CCC;
}
#main .contact th {
	padding: 1.7rem 0 1.1rem 0.9rem;
	width: 32%;
    text-align: left;
    position: relative;
}
#main .contact th .note {
    display: block;
    font-size: 1.2rem;
}
#main .contact th.wid01 {
    padding: 2.5rem 0.8rem 1.3rem;
}
#main .contact th .must {
	width: 3.5rem;
    position: absolute;
    top: 1.8rem;
    right: 1.4rem;
	box-sizing: border-box;
	display: inline-block;
	font-size: 1.28rem;
    font-weight: 300;
	text-align: center;
	color: #FFF;
	border-radius: 0.3rem;
    background: #B00000;
}
#main .contact th .must01 {
    background-color: #B00000;
}
#main .contact th.wid01 .must {
    top: 2.6rem;
}
#main .contact td .radioList {
    margin: 1.2rem 0 0.9rem;
}
#main .contact td .radioList li {
    margin-right: 1.6rem;
}
#main .contact td .radioList li span {
    font-size: 1.6rem;
    font-weight: 300;
}
#main .contact td .checkUl {
    margin: 0.6rem 0;
}
#main .contact td .checkUl li:not(:last-child) {
    margin-bottom: 0.5rem;
}
#main .contact td select,
#main .contact td textarea,
#main .contact td input[type="tel"],
#main .contact td input[type="email"],
#main .contact td input[type="text"] {
    margin-left: 0.5rem;
    padding: 0 1rem;
    width: 89.4%;
    height: 3.4rem;
	color: #111;
	border-radius: 3px;
    border: 1px solid #CCC;
    background: #F0F1F2;
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
#main .contact td textarea {
    padding: 1rem;
    height: 16.1rem;
    resize: vertical;
}
#main .contact input[type="radio"],
#main .contact input[type="checkbox"] {
   display: none;
}
#main .contact input[type="radio"] ~ span {
   padding: 0.2rem 0 0.2rem 2.3rem;
   line-height: 1.6;
   cursor: pointer;
   background: url("/lp/gpuserver/assets/img/common/check.png") no-repeat left 0.2rem center / 1.6rem;
}
#main .contact input[type="radio"]:checked ~ span {
   background-image: url("/lp/gpuserver/assets/img/common/check_on.png");
}
#main .contact input[type="checkbox"] ~ span {
    padding-left: 2.3rem;
   line-height: 1.6;
   cursor: pointer;
   background: url("/lp/gpuserver/assets/img/common/check01.png") no-repeat left 0.5rem center / 1.4rem;
}
#main .contact input[type="checkbox"]:checked ~ span {
    background-image: url("/lp/gpuserver/assets/img/common/check01_on.png");
}
#main .contact .linkUl {
    margin: 3.5rem 0 2.6rem;
}
#main .contact .linkUl li {
    font-size: 1.6rem;
    font-weight: 300;
}
#main .contact .linkUl li:not(:last-child) {
    margin-bottom: 0.6rem;
}
#main .contact .linkUl li a {
    padding: 0.2rem 2.7rem 0.2rem 0;
    color: #0059AA;
	background: url(/lp/gpuserver/assets/img/common/icon08.png) no-repeat center right / 2rem;
}
#main .contact .linkUl li a:hover {
	opacity: 0.7;
}
#main .contact .submit input {
    padding: 2.1rem 1rem 2.2rem;
    width: 100%;
    color: #fff;
    border-radius: 0.6rem;
    background: #0059AA;
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 2.88rem;
    border: none;
    box-sizing: border-box;
    cursor: pointer;
    transition: .3s;
}
#main .contact .error_txt {
    text-align: left;
    color: #ff3d71;
    margin-top: .5em;
}
@media all and (max-width: 1450px) and (min-width: 897px) {
    #main .mainVisual .mainImg .textImg {
        right: 3rem;
    }
    #main .product .productUl .productDl {
        width: 90%;
    }
}
@media all and (max-width: 1280px) and (min-width: 897px) {
    #main .product .productUl .flexBox .photo {
        width: 80%;
    }
    #main .product .productUl .flexBox .rBox {
        width: 100%;
    }
}
@media all and (min-width: 897px) {
    #main .contact .submit input:hover {
        opacity: 0.7;
    }
    #main .product .productUl .productDl dd .colseBtn:hover ,
    #main .product .productUl .productDl dd .subInner .closeBtn01:hover {
        opacity: 0.7;
    }
}
@media all and (max-width: 896px) {
	#main .mainVisual {
		padding: 12rem 0 2rem;
	}
	#main .mainVisual p {
		margin: 0 2rem 3rem;
		font-size: 1.8rem;
        font-weight: bold;
	}
	#main .mainVisual > .img {
		width: 85%;
        margin: 0 auto 1rem;
	}
	#main .mainVisual .note {
		margin: 0 0 4rem 0;
		font-size: 1.3rem;
	}
	#main .mainVisual .linkUl {
		display: block;
	}
	#main .mainVisual .linkUl li {
		margin: 0 auto 2.5rem;
		width: 100%;
	}
    #main .mainVisual .mainImg {
        margin-bottom: 6rem;
    }
	#main .mainVisual .mainImg .textImg {
		padding: 0;
		top: calc(50% - 1.8rem);
		right: calc(4% - 1rem);
        min-width: 12.5rem;
        min-height: 12.5rem;
	}
	#main .mainVisual .mainImg .textImg::after {
        min-width: 12.5rem;
        min-height: 12.5rem;
	}
    #main .mainVisual .linkUl li a img {
        margin: 0 auto;
        width: 87%;
    }
	#main .topBox {
		padding: 6rem 2rem;
		background-position: center left;
	}
    #main .topBox::before {
        background: rgba(255, 255, 255, 0.5);
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        content: '';
        z-index: 1;
    }
	#main .topBox .inner {
		margin: 0 auto;
		width: 100%;
	}
	#main .topBox .inner .subBox {
		width: 100%;
        position: relative;
        z-index: 2;
	}
	#main .topBox .h2Ttl {
        font-size: 1.8rem;
        text-align: center;
        margin: 0 -8px 2.7rem;
        letter-spacing: 0.05rem;
        font-weight: bold;
	}
	#main .topBox p {
		font-size: 1.4rem;
        letter-spacing: 0.05rem;
	}
	#main .features {
		padding: 6rem 0 7rem;
	}
	#main .features .featuresUl li {
		flex-direction: column-reverse;
	}
	#main .features .featuresUl li:not(:last-child) {
		margin-bottom: 5rem;
	}
	#main .features .featuresUl li .photo {
		width: 100%;
	}
	#main .features .featuresUl li .photo img {
		width: 100%;
	}
	#main .features .featuresUl li .textBox {
		margin-bottom: 2rem;
		width: 100%;
	}
	#main .features .featuresUl li .h3Ttl {
		font-size: 1.7rem;
		line-height: 1.65;
        text-align: center;
        margin-bottom: 1.4rem;
	}
	#main .features .featuresUl li p {
		font-size: 1.4rem;
		line-height: 1.7;
        letter-spacing: 0.05rem;
	}
	#main .use {
		padding: 6rem 0;
	}
	#main .use .centerTxt {
		margin-bottom: 4rem;
		font-size: 1.4rem;
		text-align: left;
        letter-spacing: 0.05rem;
	}
	#main .use .useUl {
		gap: 1rem;
	}
	#main .use .useUl li {
		margin-bottom: 1.5rem;
        width: calc(50% - 0.5rem);
	}
	#main .use .useUl li:last-child {
		margin-bottom: 0;
	}
	#main .use .useUl li .photo {
		margin-bottom: 0.9rem;
	}
    #main .use .useUl li .photo img {
        width: 100%;
    }
    #main .use .useUl li p {
        margin: 0 -0.3rem;
        font-size: 1.3rem;
        letter-spacing: 0;
    }
    #main .use .useUl li p .sml {
        font-size: 1.3rem;
    }
	#main .product {
		padding: 10rem 0 1rem;
        position: relative;
        z-index: 7;
	}
    #main .product .headLine01 {
        letter-spacing: 0.5rem;
    }
	#main .product .centerTxt {
		margin-bottom: 5rem;
		text-align: left;
        letter-spacing: 0.05rem;
	}
    #main .product .centerTxt span{
        margin-top: 1rem;
        font-size: 1.2rem;
    }
	#main .product .inner .h3Ttl {
		font-size: 2.1rem;
        margin-bottom: 2.5rem;
        letter-spacing: 0.2rem;
	}
    #main .product .inner01 .productUl li .h4Ttl{
        margin-bottom: 2rem;
    }
	#main .product .productUl {
		display: block;
	}
	#main .product .productUl > li {
		margin-bottom: 7rem;
		width: 100% !important;
        z-index: 2;
	}
    #main .product .productUl > li.list01 {
        z-index: 1;
    }
    #main .product .productUl > li.list03 {
        z-index: 1;
    }
	#main .product .productUl li .subBox {
		margin-bottom: 2rem;
		padding: 3.5rem 2.4rem 6rem;
	}
	#main .product .productUl li .h4Ttl .en {
		font-size: 2.1rem;
        line-height: 1.4;
	}
	#main .product .productUl li .h4Ttl {
		font-size: 1.4rem;
        font-weight: normal;
        margin-bottom: 1rem;
	}
	#main .product .productUl li .h4Ttl.big {
		font-size: 1.4rem;
	}
	#main .product .productUl .flexBox {
		min-height: inherit;
		display: block;
	}
	#main .product .productUl .flexBox .photo {
		margin-bottom: 2rem;
		padding: 0;
		width: 90%;
	}
	#main .product .productUl li .flexBox .rBox {
		width: 100%;
		display: block;
	}
	#main .product .productUl .flexBox .img {
		margin: 0 0 2rem auto;
		width: 50%;
	}
    #main .product .productUl .flexBox .img1 {
        margin: -4rem -0.5rem 0 auto;
    }
    #main .product .productUl .flexBox .img2 {
        margin: -1rem -0.5rem 2rem auto;
    }
	#main .product .productUl .link a {
		padding: 1.5rem;
		font-size: 1.5rem;
	}
    #main .product .productUl .textUl li {
        padding-bottom: 0.4rem;
    }
	#main .product .productUl .productDl dd {
		left: -1.5rem;
		right: -1.5rem;
	}
	#main .product .productUl .productDl {
		top: calc(100% - 17rem);
        left: 4%;
		transform: none;
	}
	#main .product .productUl .productDl dd .subInner {
		padding: 2rem;
	}
	#main .product .productUl .productDl dd .subInner .flexBox .textBox {
		width: 100%;
	}
	#main .product .productUl .productDl dd .subInner p {
		margin-left: 0 !important;
	}
    #main .product .productUl .productDl dt {
        border-radius: 0.6rem;
        padding: 0.3rem 0;
        margin: 0 0.5rem;
    }
    #main .product .productUl .productDl .close {
        border-radius: 0.5rem;
        padding: 1.2rem 0;
        margin: 0;
    }
	#main .product .inner:not(:last-child) {
		margin-bottom: 5rem;
	}
    #main .product .productUl .productDl dd .subInner .h5Ttl {
        padding: 0.5rem;
        margin-bottom: 2rem;
    }
    #main .product .productUl .productDl dd .subInner th {
        font-size: 1.3rem;
    }
    #main .product .productUl .productDl dd .subInner .redBtn {
        margin: 3rem 0;
    }
    #main .product .productUl .productDl dd .subInner .redBtn a {
        padding: 1.5rem;
        font-size: 1.4rem;
    }
    #main .product .productUl .productDl dd .subInner .closeBtn01 img {
        width: 4rem;
    }
    #main .product .productUl .list04 .productDl .subInner .txt01 {
        margin-bottom: 3.2rem;
    }
	#main .features01 {
		padding: 7rem 0;
		background-size: 140% auto;
	}
	#main .features01 p {
		margin-bottom: 5rem;
        letter-spacing: 0.05rem;
        line-height: 1.8;
	}
    #main .features01 .photo {
        width: 100%;
    }
	#main .profife {
		padding: 7rem 0;
	}
	#main .profife .inner {
		padding: 4rem 2rem;
	}
	#main .profife .inner:not(:last-child) {
		margin-bottom: 4rem;
	}
	#main .profife .imgBox {
		display: block;
        margin-bottom: 1rem;
	}
    #main .profife .imgBox p {
        letter-spacing: 0.02rem;
    }
    #main .profife .inner .imgBox.wid01 .photo {
        margin: -1rem 2.5rem 0 0;
    }
	#main .profife .imgBox:not(:last-child) {
		margin-bottom: 5.5rem;
	}
    #main .profife .inner .imgBox.wid01 {
        margin-bottom: 5.5rem;
    }
	#main .profife .imgBox .textBox,
	#main .profife .imgBox .photo {
		width: 100% !important;
	}
	#main .profife .imgBox .textBox {
		margin-bottom: 2rem;
        letter-spacing: 0.05rem;
	}
	#main .profife .imgBox .h5Ttl {
		margin-bottom: 1rem;
		font-size: 1.7rem;
		line-height: 1.6;
        letter-spacing: 0.08rem;
	}
	#main .profife .imgBox .h5Ttl.ttl {
		margin-top: 0;
	}
	#main .profife .imgBox .note {
		font-size: 1.2rem;
        line-height: 1.7;
        margin-top: 1rem;
	}
    #main .comConsult.box01 {
        background: url(/lp/gpuserver/assets/img/index/consult_bg01_sp.png) no-repeat center top / cover , #000;
    }
    #main .comConsult.box01 .comLink {
        bottom: -2.1rem;
    }
	#main .flow {
		padding: 10rem 0 7rem;
	}
	#main .flow .flowUl {
		display: block;
	}
	#main .flow .flowUl li {
        padding: 0;
		width: 100%;
        flex-direction: row;
        align-items: center;
        display: flex;
	}
	#main .flow .flowUl li:not(:last-child) {
		margin-bottom: 1.5rem;
	}
	#main .flow .flowUl li .textBox {
		padding: 1.2rem 1.3rem 0 1.5rem;
        margin: 0 auto;
        width: 65%;
		min-height: inherit;
	}
	#main .flow .flowUl li .num {
		margin-bottom: 1rem;
		line-height: 0.8;
		font-size: 6rem;
	}
	#main .flow .flowUl li:nth-child(1) .ttl,
    #main .flow .flowUl li:nth-child(2) .ttl,
    #main .flow .flowUl li:nth-child(4) .ttl {
		margin-bottom: 0.5rem;
		min-height: inherit;
		font-size: 1.9rem;
        position: relative;
        bottom:1.2rem;
        margin-left: -1.5rem;
        letter-spacing: 0.05rem;
        text-align: left;
        line-height: 1.3;
	}
    #main .flow .flowUl li:nth-child(3) .ttl,
    #main .flow .flowUl li:nth-child(5) .ttl {
		margin-bottom: 0.5rem;
		min-height: inherit;
		font-size: 1.9rem;
        position: relative;
        bottom:0.05rem;
        margin-left: -1.5rem;
        letter-spacing: 0.05rem;
        text-align: left;
        line-height: 1.3;
	}
    #main .flow .flowUl li .num,
    #main .flow .flowUl li .ttl {
        display: inline-block;
    }
    #main .flow .flowUl li .text {
        margin-bottom: 2rem;
        font-size: 1.3rem;
    }
	#main .flow .flowUl li::after {
		display: none;
	}
    #main .flow .flowUl li .photo {
        margin: 0 auto;
        width: 35%;
    }
    #main .flow .flowUl li .photo img {
        width: 100%;
        height: 17rem;
        object-fit: cover;
        object-position: center 20%;
    }
	#main .contact {
		padding: 7rem 0;
	}
	#main .contact .ttl {
		font-size: 1.7rem;
        margin: 5.5rem 0 1rem;
	}
	#main .contact .text {
		font-size: 1.4rem;
        line-height: 1.7;
        margin-bottom: 5rem;
	}
	#main .contact td, #main .contact th {
		display: block;
		width: 100% !important;
	}
    #main .contact tr:not(:last-child) td,
    #main .contact tr:not(:last-child) th {
	    border-bottom: none;
    }
	#main .contact td {
		border-top: none;
	}
	#main .contact th {
		padding: 1.5rem 0 0 !important;
		border-bottom: none;
	}
    #main .contact th .must {
        position: static;
        font-size: 1.2rem;
        text-align: center;
        margin-left: 0.8rem;
        vertical-align: 0.15rem;
    }
	#main .contact tr:first-child td {
		border-top: none;
	}
	#main .contact tr:first-child th {
		border-bottom: none;
	}
	#main .contact td .radioList {
		margin: 0;
	}
	#main .contact td select, #main .contact td textarea, #main .contact td input[type="tel"], #main .contact td input[type="email"], #main .contact td input[type="text"] {
		margin: 0;
		width: 100%;
	}
    #main .contact input[type="radio"] ~ span {
        padding: 0.2rem 0 0.2rem 2.3rem;
    }
	#main .contact .submit input {
		padding: 1.5rem 1rem;
		font-size: 1.6rem;
	}
    #main .contact .linkUl li a  {
        padding: 0.3rem 2.7rem 0.3rem 0;
    }
}