@charset "UTF-8";

/* -----------------------------------------------------------------------------

	Foundation

----------------------------------------------------------------------------- */

/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */

html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
}

h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
}

pre {
    font-family: monospace, monospace;
    font-size: 1em;
}

a {
    background-color: transparent;
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline dotted;
}

b,
strong {
    font-weight: bolder;
}

code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em;
}

small {
    font-size: 80%;
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

img {
    border-style: none;
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0;
}

button,
input {
    overflow: visible;
}

button,
select {
    text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    border-style: none;
    padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
    outline: 1px dotted ButtonText;
}

fieldset {
    padding: 0.35em 0.75em 0.625em;
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal;
}

progress {
    vertical-align: baseline;
}

textarea {
    overflow: auto;
}

[type="checkbox"],
[type="radio"] {
    box-sizing: border-box;
    padding: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

[type="search"] {
    -webkit-appearance: textfield;
    outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit;
}

details {
    display: block;
}

summary {
    display: list-item;
}


template {
    display: none;
}

[hidden] {
    display: none;
}

/* normalize.css に追加 */

body { color: #4d4d4d; font-family: 'Noto Sans JP', sans-serif; word-break: break-all; }
img { width: 100%; height: auto; }
a { color:#4d4d4d; text-decoration: none; outline: none; }
a:hover { text-decoration: underline; }
address { font-style:normal; }
main { display: block; }
button, input { outline: none; }

@media screen and (min-width: 1024px) {

    a[href^="tel:"] {
        pointer-events: none;
    }

}

/* -----------------------------------------------------------------------------

	Object => Component

----------------------------------------------------------------------------- */

/* title01_02 */
.c-title01,
.c-title02 {
    text-align: center;
    position: relative;
    padding-top: calc(40 / 375 * 100 * 1vw);
    margin-bottom: calc(30 / 375 * 100 * 1vw);
}
.-top .c-title01,
.-top .c-title02 {
    margin-bottom: calc(30 / 375 * 100 * 1vw);
}
.c-title01::before,
.c-title02::before {
    content: '';
    width: calc(27 / 375 * 100 * 1vw);
    height: calc(27 / 375 * 100 * 1vw);
    position: absolute;
    top: 0;
    left: 50%;
    margin-left: calc(13.5 / 375 * 100 * -1vw);
}
.c-title01::before {
    background: url("../images/ico_gear01.svg") no-repeat;
    background-size: contain;
}
.c-title02::before {
    background: url("../images/ico_gear02.svg") no-repeat;
    background-size: contain;
}
.c-title01__title.-en,
.c-title02__title.-en {
    font-family: 'Source Sans Pro', sans-serif;
    font-weight: 200;
    font-size: calc(42 / 375 * 100 * 1vw);
    margin: 0 0 calc(8 / 375 * 100 * 1vw) 0;
    padding: 0;
    line-height: 1;
}
.c-title02__title.-en { color: #fff; }
.c-title01__title.-jp,
.c-title02__title.-jp {
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: calc(16 / 375 * 100 * 1vw);
    margin: 0;
    padding: 0;
    line-height: 1;
    position: relative;
}
.c-title02__title.-jp { color: #fff; }
.c-title01__title.-jp::before,
.c-title02__title.-jp::before {
    content: '';
    width: calc(111 / 375 * 100 * 1vw);
    height: calc(14 / 375 * 100 * 1vw);
    position: absolute;
    left: 50%;
    margin-left: calc(50 / 375 * 100 * 1vw);
    bottom: 0;
    background-size: calc(14 / 375 * 100 * 1vw) calc(14 / 375 * 100 * 1vw);
}
.c-title02__title.-jp.-bd9::before {
    width: calc(97 / 375 * 100 * 1vw);
    margin-left: calc(62 / 375 * 100 * 1vw);
}
.c-title01__title.-jp::before {
    background-image: repeating-linear-gradient(-45deg, #4d4d4d 0px, #4d4d4d 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
}
.c-title02__title.-jp::before {
    background-image: repeating-linear-gradient(-45deg, #fff 0px, #fff 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
}
.c-title01__title.-jp::after,
.c-title02__title.-jp::after {
    content: '';
    width: calc(110 / 375 * 100 * 1vw);
    height: calc(14 / 375 * 100 * 1vw);
    position: absolute;
    right: 50%;
    margin-right: calc(50 / 375 * 100 * 1vw);
    bottom: 0;
    background-size: calc(14 / 375 * 100 * 1vw) calc(14 / 375 * 100 * 1vw);
}
.c-title02__title.-jp.-bd9::after {
    width: calc(97 / 375 * 100 * 1vw);
    margin-right: calc(62 / 375 * 100 * 1vw);
}
.c-title01__title.-jp::after {
    background-image: repeating-linear-gradient(-45deg, #4d4d4d 0px, #4d4d4d 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
}
.c-title02__title.-jp::after {
    background-image: repeating-linear-gradient(-45deg, #fff 0px, #fff 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
}

/* title03 */
.c-title03 {
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: calc(18 / 375 * 100 * 1vw);
    color: #00acb7;
    padding: 0 0 calc(12 / 375 * 100 * 1vw) 0;
    margin: 0 0 calc(25 / 375 * 100 * 1vw) 0;
    position: relative;
    text-align: center;
}
.c-title03::before {
    content: '';
    width: 100%;
    height: calc(5.25 / 375 * 100 * 1vw);
    position: absolute;
    left: 0;
    bottom: 0;
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#00acb7+0,00acb7+30,ffffff+30,ffffff+33,29a1d8+33,29a1d8+66,ffffff+66,ffffff+66,ffffff+69,0071b2+69,0071b2+100 */
    background: #00acb7; /* Old browsers */
    background: -moz-linear-gradient(left,  #00acb7 0%, #00acb7 30%, #ffffff 31%, #ffffff 33%, #29a1d8 33%, #29a1d8 67%, #ffffff 67%, #ffffff 67%, #ffffff 69%, #0071b2 69%, #0071b2 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(left,  #00acb7 0%,#00acb7 31%,#ffffff 31%,#ffffff 33%,#29a1d8 33%,#29a1d8 67%,#ffffff 67%,#ffffff 67%,#ffffff 69%,#0071b2 69%,#0071b2 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right,  #00acb7 0%,#00acb7 31%,#ffffff 31%,#ffffff 33%,#29a1d8 33%,#29a1d8 67%,#ffffff 67%,#ffffff 67%,#ffffff 69%,#0071b2 69%,#0071b2 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00acb7', endColorstr='#0071b2',GradientType=1 ); /* IE6-9 */
}

/*sdgs*/
.sdgs-box .c-title03 {
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: calc(24 / 375 * 100 * 1vw);
    color: #00acb7;
    padding: 0 0 calc(12 / 375 * 100 * 1vw) 0;
    margin: 0 0 calc(25 / 375 * 100 * 1vw) 0;
    position: relative;
    text-align: center;
}

/* btn */
.c-btn01,
.c-btn02,
.c-btn03,
.c-btnSubmit input,
#mfp_button_send,
#mfp_button_cancel {
    width: calc(245 / 375 * 100 * 1vw);
    padding: calc(15 / 375 * 100 * 1vw) 0;
    text-align: center;
    border-radius: 100vh;
    cursor: pointer;
    margin: 0 auto;
    position: relative;
    font-size: calc(14 / 375 * 100 * 1vw);
    font-weight: 700;
    box-sizing: border-box;
}
.c-btnSubmit {
    width: calc(245 / 375 * 100 * 1vw);
    margin: 0 auto;
    position: relative;
    text-shadow: none;
    box-shadow: none;
}
.c-btnSubmit:hover,
.c-btnSubmit input:hover {
    box-shadow: none;
}

.c-btn01 { color: #fff; background: #00acb7; }
.c-btn02 { color: #00acb7; background: #fff; }
.c-btn03 { color: #4d4d4d; background: #fff; border: 1px solid #4d4d4d; }
.c-btnSubmit input,
#mfp_button_send,
#mfp_button_cancel {
    color: #fff;
    background: #00acb7;
    border: none;
    display: block;
    text-shadow: none;
    box-shadow: none;
}

input[type="submit"][disabled] {
    background: #ccc !important;
    cursor: default;
}
input[type="submit"] {
    color:#fff;
    background:#00acb7 !important;
}

.c-btn01::before,
.c-btn02::before,
.c-btn03::before,
.c-btnSubmit::before {
    content: '';
    position: absolute;
    width: calc(15 / 375 * 100 * 1vw);
    height: 1px;
    right: calc(31 / 375 * 100 * 1vw);
    top: 50%;
    transition: .3s;
    z-index: 2;
}
.c-btn01::before { background: #fff; }
.c-btn02::before { background: #00acb7; }
.c-btn03::before { background: #4d4d4d; }
.c-btnSubmit::before { background: #fff; }

.c-btn01::after,
.c-btn02::after,
.c-btn03::after,
.c-btnSubmit::after {
    content: '';
    position: absolute;
    right: calc(26 / 375 * 100 * 1vw);
    top: 50%;
    margin-top: calc(3 / 375 * 100 * -1vw);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: calc(4 / 375 * 100 * 1vw) 0 calc(4 / 375 * 100 * 1vw) calc(5 / 375 * 100 * 1vw);
    transition: .3s;
    z-index: 2;
}
.c-btn01::after { border-color: transparent transparent transparent #fff; }
.c-btn02::after { border-color: transparent transparent transparent #00acb7; }
.c-btn03::after { border-color: transparent transparent transparent #4d4d4d; }
.c-btnSubmit::after { border-color: transparent transparent transparent #fff; }

.c-btn01 a, .c-btn02 a, .c-btn03 a {
    text-decoration: none;
}

.c-btn01 a { color: #fff; }
.c-btn02 a { color: #00acb7; }
.c-btn03 a { color: #4d4d4d; }

/* toggle button */
.c-toggleBtn, .c-toggleBtn span {
    display: block;
    transition: all .4s;
    box-sizing: border-box;
}
.c-toggleBtn {
    width: calc(44 / 375 * 100 * 1vw);
    height: calc(36 / 375 * 100 * 1vw);
    position: fixed;
    top: calc(15 / 375 * 100 * 1vw);
    right: calc(20 / 375 * 100 * 1vw);
    z-index: 5;
    cursor: pointer;
}
.c-toggleBtn span {
    position: absolute;
    height: 1px;
    background: #000;
}
.c-toggleBtn span:nth-of-type(1),
.c-toggleBtn span:nth-of-type(2),
.c-toggleBtn span:nth-of-type(3) {
    width: calc(36 / 375 * 100 * 1vw);
    left: calc(4 / 375 * 100 * 1vw);
}
.c-toggleBtn span:nth-of-type(1) {
    top: 0;
}
.c-toggleBtn span:nth-of-type(2) {
    top: calc(10 / 375 * 100 * 1vw);
}
.c-toggleBtn span:nth-of-type(3) {
    top: calc(20 / 375 * 100 * 1vw);
}
.c-toggleBtn.-active span:nth-of-type(1) {
    background: #fff;
    width: calc(42 / 375 * 100 * 1vw);
    top: calc(8 / 375 * 100 * 1vw);
    left: 50%;
    margin-left: calc(21 / 375 * 100 * -1vw);
    transform: rotate(-25deg);
}
.c-toggleBtn.-active span:nth-of-type(2) {
    opacity: 0;
}
.c-toggleBtn.-active span:nth-of-type(3) {
    background: #fff;
    width: calc(42 / 375 * 100 * 1vw);
    top: calc(8 / 375 * 100 * 1vw);
    left: 50%;
    margin-left: calc(21 / 375 * 100 * -1vw);
    transform: rotate(25deg);
}
.c-toggleBtn::before {
    content: 'MENU';
    display: block;
    font-size: calc(10 / 375 * 100 * 1vw);
    position: absolute;
    bottom: 0;
    opacity: 1;
    width: 100%;
    text-align: center;
    font-family: 'Source Sans Pro', sans-serif;
    font-weight: 400;
    letter-spacing: 0.2em;
}
.c-toggleBtn.-active::before {
    opacity: 0;
}
.c-toggleBtn::after {
    color: #fff;
    content: 'CLOSE';
    display: block;
    font-size: calc(10 / 375 * 100 * 1vw);
    position: absolute;
    bottom: 0;
    opacity: 0;
    width: 100%;
    text-align: center;
    font-family: 'Source Sans Pro', sans-serif;
    font-weight: 400;
    letter-spacing: 0.2em;
}
.c-toggleBtn.-active::after {
    opacity: 1;
}

@media screen and (min-width: 1024px) {

    /* title01_02 */
    .c-title01,
    .c-title02 {
        padding-top: calc(35 / 1024 * 100 * 1vw);
        margin-bottom: calc(20 / 1024 * 100 * 1vw);
    }
    .-top .c-title01,
    .-top .c-title02 {
        margin-bottom: calc(30 / 1024 * 100 * 1vw);
    }
    .c-title01::before,
    .c-title02::before {
        width: calc(23 / 1024 * 100 * 1vw);
        height: calc(23 / 1024 * 100 * 1vw);
        margin-left: calc(11.5 / 1024 * 100 * -1vw);
    }
    .c-title01::before {
        background: url("../images/ico_gear01.svg") no-repeat;
        background-size: contain;
    }
    .c-title02::before {
        background: url("../images/ico_gear02.svg") no-repeat;
        background-size: contain;
    }
    .c-title01__title.-en,
    .c-title02__title.-en {
        font-size: calc(36 / 1024 * 100 * 1vw);
        margin: 0 0 calc(8 / 1024 * 100 * 1vw) 0;
    }
    .c-title01__title.-jp,
    .c-title02__title.-jp {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
    }
    .c-title01__title.-jp::before,
    .c-title02__title.-jp::before {
        width: calc(119 / 1024 * 100 * 1vw);
        height: calc(12 / 1024 * 100 * 1vw);
        margin-left: calc(40 / 1024 * 100 * 1vw);
        background-size: calc(12 / 1024 * 100 * 1vw) calc(12 / 1024 * 100 * 1vw);
    }
    .c-title02__title.-jp.-bd9::before {
        width: calc(106 / 1024 * 100 * 1vw);
        margin-left: calc(50 / 1024 * 100 * 1vw);
    }
    .c-title01__title.-jp::after,
    .c-title02__title.-jp::after {
        width: calc(119 / 1024 * 100 * 1vw);
        height: calc(12 / 1024 * 100 * 1vw);
        margin-right: calc(40 / 1024 * 100 * 1vw);
        background-size: calc(12 / 1024 * 100 * 1vw) calc(12 / 1024 * 100 * 1vw);
    }
    .c-title02__title.-jp.-bd9::after {
        width: calc(106 / 1024 * 100 * 1vw);
        margin-right: calc(50 / 1024 * 100 * 1vw);
    }

    /* title03 */
    .c-title03 {
        font-size: calc(15.75 / 1024 * 100 * 1vw);
        padding: 0 0 calc(12 / 1024 * 100 * 1vw) 0;
        margin: 0 0 calc(22 / 1024 * 100 * 1vw) 0;
        text-align: left;
    }
    .c-title03::before {
        width: calc(360 / 1024 * 100 * 1vw);
        height: calc(4.5 / 1024 * 100 * 1vw);
    }
	
	 /* title03_sdgs */
    .sdgs-box .c-title03 {
        font-size: calc(15.75 / 1024 * 100 * 1vw);
        padding: 0 0 calc(12 / 1024 * 100 * 1vw) 0;
        margin: 0 0 calc(22 / 1024 * 100 * 1vw) 0;
        text-align: left;
    }

    /* btn */
    .c-btn01,
    .c-btn02,
    .c-btn03,
    .c-btnSubmit input,
    #mfp_button_send,
    #mfp_button_cancel {
        width: calc(210 / 1024 * 100 * 1vw);
        padding: calc(12 / 1024 * 100 * 1vw) 0;
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    #mfp_button_send,
    #mfp_button_cancel {
        margin: 0;
    }
    .c-btnSubmit {
        width: calc(210 / 1024 * 100 * 1vw);
    }

    .c-btn01::before,
    .c-btn02::before,
    .c-btn03::before,
    .c-btnSubmit::before {
        width: calc(12 / 1024 * 100 * 1vw);
        right: calc(27 / 1024 * 100 * 1vw);
    }

    .c-btn01::after,
    .c-btn02::after,
    .c-btn03::after,
    .c-btnSubmit::after {
        right: calc(24 / 1024 * 100 * 1vw);
        margin-top: calc(2.5 / 1024 * 100 * -1vw);
        border-width: calc(3 / 1024 * 100 * 1vw) 0 calc(3 / 1024 * 100 * 1vw) calc(4 / 1024 * 100 * 1vw);
    }

    /* btn hover */
    .c-btn01:hover::before,
    .c-btn02:hover::before,
    .c-btn03:hover::before,
    .c-btnSubmit:hover::before,
    .c-btn01:hover::after,
    .c-btn02:hover::after,
    .c-btn03:hover::after,
    .c-btnSubmit:hover::after {
        transform:translateX(calc(8 / 1024 * 100 * 1vw));
    }

    /* toggle button */
    .c-toggleBtn { display: none; }

}

@media screen and (min-width: 1366px) {

    /* title01_02 */
    .c-title01,
    .c-title02 {
        padding-top: 50px;
        margin-bottom: 25px;
    }
    .-top .c-title01,
    .-top .c-title02 {
        margin-bottom: 40px;
    }
    .c-title01::before,
    .c-title02::before {
        width: 32px;
        height: 32px;
        margin-left: -16px;
    }
    .c-title01__title.-en,
    .c-title02__title.-en {
        font-size: 3rem;
        margin: 0 0 10px 0;
    }
    .c-title01__title.-jp,
    .c-title02__title.-jp {
        font-size: 1.125rem;
    }
    .c-title01__title.-jp::before,
    .c-title02__title.-jp::before {
        width: 159px;
        height: 16px;
        margin-left: 55px;
        background-size: 16px 16px;
    }
    .c-title02__title.-jp.-bd9::before {
        width: 144px;
        margin-left: 71px;
    }
    .c-title01__title.-jp::after,
    .c-title02__title.-jp::after {
        width: 159px;
        height: 16px;
        margin-right: 55px;
        background-size: 16px 16px;
    }
    .c-title02__title.-jp.-bd9::after {
        width: 144px;
        margin-right: 71px;
    }

    /* title03 */
    .c-title03 {
        font-size: 1.3125rem;
        padding: 0 0 16px 0;
        margin: 0 0 25px 0;
    }
    .c-title03::before {
        width: 480px;
        height: 6px;
    }
	
	.sdgs-box .c-title03 {
        font-size: 1.625rem;
        padding: 0 0 16px 0;
        margin: 0 0 25px 0;
    }
    .sdgs-box .c-title03::before {
        width: 480px;
        height: 6px;
    }

    /* btn */
    .c-btn01,
    .c-btn02,
    .c-btn03,
    .c-btnSubmit input,
    #mfp_button_send,
    #mfp_button_cancel {
        width: 280px;
        padding: 18px 0;
        font-size: 1rem;
    }
    .c-btnSubmit {
        width: 280px;
    }

    .c-btn01::before,
    .c-btn02::before,
    .c-btn03::before,
    .c-btnSubmit::before {
        width: 17px;
        height: 1px;
        right: 35px;
    }

    .c-btn01::after,
    .c-btn02::after,
    .c-btn03::after,
    .c-btnSubmit::after {
        right: 30px;
        top: 50%;
        margin-top: -3px;
        border-width: 4px 0 4px 5px;
    }

    /* btn hover */
    .c-btn01:hover::before,
    .c-btn02:hover::before,
    .c-btn03:hover::before,
    .c-btnSubmit:hover::before,
    .c-btn01:hover::after,
    .c-btn02:hover::after,
    .c-btn03:hover::after,
    .c-btnSubmit:hover::after {
        transform:translateX(12px);
    }

}

/* animation
----------------------------------------------------------------------------- */

/* top slider animation */
@keyframes zoomIn {
    0% {
        transform: scale(1.1);
    }
    100% {
        transform: scale(1);
    }
}

@keyframes spin {
    0% {
        transform: rotate(0);
        opacity: 1;
    }
    100% {
        transform: rotate(360deg);
        opacity: 1;
    }
}

@keyframes slideLoop {
    0% {
        transform: translateX(100%);
    }
    100% {
        transform: translateX(-100%);
    }
}
@keyframes slideLoop2 {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-200%);
    }
}

/* -----------------------------------------------------------------------------

	Object => Project

----------------------------------------------------------------------------- */

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

.p-header.-sp {
    width: 100%;
    position: fixed;
    background: #fff;
    padding: calc(11 / 375 * 100 * 1vw) 0 calc(10 / 375 * 100 * 1vw) 0;
    z-index: 3;
}
.p-header__logo {
    width: calc(160 / 375 * 100 * 1vw);
    margin: 0 auto;
    padding: 0;
}

.p-header.-pc { display: none; }

@media screen and (min-width: 1024px) {

    .p-header.-sp { height: 0; padding: 0; display: none; }
    .p-header.-pc { display: block; }
    .p-header.-top { background: #f0f0f0; }
    .p-header.-pc.-fixed {
        position: fixed;
        top: 0;
        left: 0;
        z-index: 10;
        width: 100%;
    }
    .p-header.-pc.-lower.-fixed {
        background: #fff;
    }
    .-top .p-header__wrap.-all {
        width: 100%;
        max-width: calc(950 / 1024 * 100 * 1vw);
        margin: 0 auto;
        display: flex;
        justify-content: space-between;
        padding: calc(8 / 1024 * 100 * 1vw) 0;
    }

    .p-header__logo {
        width: calc(176 / 1024 * 100 * 1vw);
        padding: calc(3 / 1024 * 100 * 1vw) 0 calc(1 / 1024 * 100 * 1vw) 0;
        margin: 0;
    }
    .-top .p-headerNav__list {
        height: 100%;
        margin: 0;
        padding: 0;
        display: flex;
    }
    .p-headerNav__item {
        width: calc(127 / 1024 * 100 * 1vw);
        padding: 0;
        margin: 0;
        box-sizing: border-box;
        text-align: center;
        list-style: none;
        border-right: 1px solid #a9a9a9;
    }
    .p-headerNav__item:first-child {
        border-left: 1px solid #a9a9a9;
    }
    .p-headerNav__wrap {
        width: calc(97 / 1024 * 100 * 1vw);
        height: 100%;
        padding: 0;
        margin: 0 auto;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        border-width: 0 0 2px 0;
        border-style: solid;
        transition: .3s;
        cursor: pointer;
        box-sizing: border-box;
    }
    .p-headerNav__wrap a { text-decoration: none; transition: .3s; }
    .p-headerNav__wrap.-products { border-color: #ed891e; }
    .p-headerNav__wrap.-equipments { border-color: #cbcb00; }
    .p-headerNav__wrap.-aboutus { border-color: #82bc3f; }
	.p-headerNav__wrap.-sdgs { border-color: #e5243b; }
    .p-headerNav__wrap.-news { border-color: #0071b2; }
    .p-headerNav__wrap.-contact { border-color: #892785; }

    .p-headerNav__wrap.-products:hover,
    .p-headerNav__wrap.-products.-active {
        background: #ed891e;
    }
    .p-headerNav__wrap.-equipments:hover,
    .p-headerNav__wrap.-equipments.-active {
        background: #cbcb00;
    }
    .p-headerNav__wrap.-aboutus:hover,
    .p-headerNav__wrap.-aboutus.-active {
        background: #82bc3f;
    }
	.p-headerNav__wrap.-sdgs:hover,
    .p-headerNav__wrap.-sdgs.-active {
        background: #e5243b;
    }
    .p-headerNav__wrap.-news:hover,
    .p-headerNav__wrap.-news.-active {
        background: #0071b2;
    }
    .p-headerNav__wrap.-contact:hover ,
    .p-headerNav__wrap.-contact.-active {
        background: #892785;
    }

    .p-headerNav__text.-jp {
        font-family: 'Noto Serif JP', serif;
        font-weight: 700;
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin-bottom: calc(4 / 1024 * 100 * 1vw);
        letter-spacing: 0.05em;
        transition: .3s;
    }
    .p-headerNav__text.-en {
        font-family: 'Source Sans Pro', sans-serif;
        font-weight: 400;
        font-size: calc(10.5 / 1024 * 100 * 1vw);
        letter-spacing: 0.1em;
        color: #00acb7;
        transition: .3s;
        margin: 0;
        padding: 0;
        line-height: 1;
    }
    .p-headerNav__wrap.-active .p-headerNav__text.-jp a,
    .p-headerNav__wrap.-active .p-headerNav__text.-en,
    .p-headerNav__wrap:hover .p-headerNav__text.-jp a,
    .p-headerNav__wrap:hover .p-headerNav__text.-en {
        color: #fff;
    }

    /* lower */
    .-lower .p-header {
        position: relative;
    }
    .-lower .p-header__logo {
        position: absolute;
        left: 50%;
        margin-left: calc(176px / -2);
        padding: 0;
        top: 0;
        margin-top: calc(18.25 / 1024 * 100 * 1vw);
    }
    .-lower .p-header__wrap.-header {
        width: 100%;
        max-width: calc(900 / 1024 * 100 * 1vw);
        margin: 0 auto;
        padding: calc(15 / 1024 * 100 * 1vw) 0;
        display: flex;
        justify-content: space-between;
        align-items: center;
        position: relative;
    }
    .-lower .p-header__catchcopy {
        font-family: 'Noto Serif JP', serif;
        font-weight: 400;
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin: 0;
        padding: 0;
        display: flex;
        align-items: center;
    }
    .-lower .p-header__iso {
        width: calc(97.5 / 1024 * 100 * 1vw);
        line-height: 0;
        display: block;
        vertical-align: bottom;
    }
    .-lower .p-headerNav {
        background: #f0f0f0;
        padding: calc(7 / 1024 * 100 * 1vw) 0;
        margin: 0;
    }
    .-lower .p-headerNav__list {
        margin: 0;
        padding: 0;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .-lower .p-headerNav__wrap {
        height: calc(46 / 1024 * 100 * 1vw);
        box-sizing: border-box;
    }

}

@media screen and (min-width: 1366px) {

    .-top .p-header__wrap.-all {
        max-width: 1250px;
        padding: 10px 0;
    }

    .p-header__logo {
        width: 224px;
        padding: 4px 0 2px 0;
    }
    .p-headerNav__item {
        width: 160px;
    }
    .p-headerNav__wrap {
        width: 130px;
    }

    .p-headerNav__text.-jp {
        font-size: 1rem;
        margin-bottom: 4px;
    }
    .p-headerNav__text.-en {
        font-size: 0.875rem;
    }

    /* lower */
    .-lower .p-header {
        position: relative;
    }
    .-lower .p-header__logo {
        position: absolute;
        left: 50%;
        margin-left: calc(236px / -2);
        margin-top: 24px;
    }
    .-lower .p-header__wrap.-header {
        width: 100%;
        max-width: 1200px;
        margin: 0 auto;
        padding: 20px 0;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .-lower .p-header__catchcopy {
        font-family: 'Noto Serif JP', serif;
        font-weight: 400;
        font-size: 1rem;
        margin: 0;
        padding: 0;
        display: flex;
        align-items: center;
    }
    .-lower .p-header__iso {
        width: 130px;
        line-height: 0;
        display: block;
        vertical-align: bottom;
    }
    .-lower .p-headerNav {
        background: #f0f0f0;
        padding: 10px 0;
        margin: 0;
    }
    .-lower .p-headerNav__list {
        margin: 0;
        padding: 0;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .-lower .p-headerNav__wrap {
        height: 60px;
        box-sizing: border-box;
    }

}

/* common
----------------------------------------------------------------------------- */

/* border */
.p-border {
    width: 100%;
    height: calc(40 / 375 * 100 * 1vw);
    position: relative;
    background: #00acb7;
}
.p-border::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(40 / 375 * 100 * 1vw);
    background-image: repeating-linear-gradient(-45deg, #fff 0px, #fff 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
    background-size: calc(15 / 375 * 100 * 1vw) calc(15 / 375 * 100 * 1vw);
}

/* common contactus */
.p-commonContact {
    background: #00acb7;
    padding-top: calc(215 / 375 * 100 * 1vw);
    padding-bottom: calc(30 / 375 * 100 * 1vw);
    position: relative;
}
.p-commonContact__text {
    font-size: calc(16 / 375 * 100 * 1vw);
    line-height: 1.5;
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    color: #fff;
    margin-bottom: calc(25 / 375 * 100 * 1vw);
    text-align: center;
}
.p-commonContact__wrap.-illust01,
.p-commonContact__wrap.-illust02 {
    width: 50%;
    height: 50vw;
    line-height: 0;
    display: block;
    vertical-align: bottom;
    position: absolute;
}
.p-commonContact__wrap.-illust01 {
    top: 0;
    left: 0;
}
.p-commonContact__wrap.-illust02 {
    top: 0;
    right: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
.p-commonContact__wrap.-illust02 img {
    width: calc(160 / 375 * 100 * 1vw);
    padding-right: calc(10 / 375 * 100 * 1vw);
}

@media screen and (max-width: 1023px) {

    /* contactus */
    .p-contact .p-commonContact {
        padding-top: calc(30 / 375 * 100 * 1vw);
        padding-bottom: calc(215 / 375 * 100 * 1vw);
    }

    .p-contact .p-commonContact .p-commonContact__text {
        margin-bottom: 0;
    }

    .p-contact .p-commonContact__wrap.-illust01,
    .p-contact .p-commonContact__wrap.-illust02 {
        top: auto;
        bottom: 0;
    }
    .p-contact .p-commonContact__wrap.-illust01 {
        display: flex;
        align-items: flex-end;
    }

}

/* page lead */
.p-pageLead {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto;
}
.p-pageLead__title {
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: calc(18 / 375 * 100 * 1vw);
    color: #00acb7;
    text-align: center;
    margin: 0 0 calc(15 / 375 * 100 * 1vw) 0;
    padding: 0;
}
.p-pageLead__title_sdgs {
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: calc(26 / 375 * 100 * 1vw);
    color: #00acb7;
    text-align: center;
    margin: calc(30 / 375 * 100 * 1vw) 0;
    padding: 0;
}
.p-pageLead__text {
    font-size: calc(16 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0.01em;
    margin: 0;
    padding: 0;
    hanging-punctuation: allow-end;
}

.p-pageLead__text_sdgs {
    font-size: calc(16 / 375 * 100 * 1vw);
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0.01em;
    margin: 0;
    padding: 0;
    hanging-punctuation: allow-end;
}

/* pagetop */
.p-pagetop {
    width: calc(42 / 375 * 100 * 1vw);
    height: calc(42 / 375 * 100 * 1vw);
    background: #4d4d4d;
    position: fixed;
    right: calc(20 / 375 * 100 * 1vw);
    bottom: calc(45 / 375 * 100 * 1vw);
    cursor: pointer;
}
.p-pagetop::after {
    content: '';
    width: calc(16 / 375 * 100 * 1vw);
    height: calc(16 / 375 * 100 * 1vw);
    border: 1px solid;
    border-color: #fff #fff transparent transparent;
    transform: rotate(-45deg);
    position: absolute;
    top: 50%;
    left: 50%;
    margin-left: calc(8 / 375 * 100 * -1vw);
    margin-top: calc(3 / 375 * 100 * -1vw);
}

@media screen and (min-width: 1024px) {

    /* main */
    .p-main.-lower {
        margin-top: calc(137 / 1024 * 100 * 1vw);
    }

    /* border */
    .p-border {
        height: calc(45 / 1024 * 100 * 1vw);
    }
    .p-border::after {
        height: calc(45 / 1024 * 100 * 1vw);
        background-image: repeating-linear-gradient(-45deg, #fff 0px, #fff 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
        background-size: calc(15 / 1024 * 100 * 1vw) calc(15 / 1024 * 100 * 1vw);
    }

    /* contactus */
    .p-commonContact {
        display: flex;
        justify-content: space-between;
        padding-top: 0;
        padding-bottom: 0;
    }
    .p-commonContact__text {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
        margin-bottom: calc(15 / 1024 * 100 * 1vw);
    }
    .p-commonContact__wrap.-text {
        padding: calc(30 / 1024 * 100 * 1vw) 0 0 0;
    }
    .p-commonContact__wrap.-illust01,
    .p-commonContact__wrap.-illust02 {
        width: 100%;
        height: auto;
        max-width: calc(285 / 1024 * 100 * 1vw);
        position: static;
    }
    .p-commonContact__wrap.-illust02 img {
        width: calc(245 / 1024 * 100 * 1vw);
        padding-right: 0;
    }

    /* page lead */
    .p-pageLead {
        max-width: calc(750 / 1024 * 100 * 1vw);
    }
    .p-pageLead__title {
        font-size: calc(15.75 / 1024 * 100 * 1vw);
        margin: 0 0 calc(15 / 1024 * 100 * 1vw) 0;
    }
	
	.p-pageLead__title_sdgs {
        font-size: calc(18 / 1024 * 100 * 1vw);
        margin: 0 0 calc(15 / 1024 * 100 * 1vw) 0;
    }
	
    .p-pageLead__text {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
        letter-spacing: -0.01em;
    }
	.p-pageLead__text_sdgs {
     font-size: calc(13.5 / 1024 * 100 * 1vw);
        letter-spacing: -0.01em;
}
    /* pagetop */
    .p-pagetop {
        width: calc(36 / 1024 * 100 * 1vw);
        height: calc(36 / 1024 * 100 * 1vw);
        right: calc(13 / 1024 * 100 * 1vw);
        bottom: calc(45 / 1024 * 100 * 1vw);
    }
    .p-pagetop::after {
        width: calc(16 / 1024 * 100 * 1vw);
        height: calc(16 / 1024 * 100 * 1vw);
        margin-left: calc(8 / 1024 * 100 * -1vw);
        margin-top: calc(3 / 1024 * 100 * -1vw);
    }

}

@media screen and (min-width: 1366px) {

    /* main */
    .p-main.-lower {
        margin-top: 183px;
    }

    /* border */
    .p-border {
        height: 60px;
    }
    .p-border::after {
        height: 60px;
        background-image: repeating-linear-gradient(-45deg, #fff 0px, #fff 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
        background-size: 20px 20px;
    }

    /* contactus */
    .p-commonContact__text {
        font-size: 1.125rem;
        margin-bottom: 20px;
    }
    .p-commonContact__wrap.-text {
        padding: 40px 0 0 0;
    }
    .p-commonContact__wrap.-illust01,
    .p-commonContact__wrap.-illust02 {
        max-width: 380px;
    }
    .p-commonContact__wrap.-illust02 img {
        width: 326px;
    }

    /* page lead */
    .p-pageLead {
        max-width: 1000px;
    }
    .p-pageLead__title {
        font-size: 1.3125rem;
        margin: 0 0 20px 0;
    }
	.p-pageLead__title_sdgs {
        font-size: 1.875rem;
        margin: 40px 0 40px 0;
    }
    .p-pageLead__text {
        font-size: 1.125rem;
    }
	.p-pageLead__text_sdgs {
        font-size: 1.125rem;
    }

    /* pagetop */
    .p-pagetop {
        width: 48px;
        height: 48px;
        right: 15px;
        bottom: 60px;
    }
    .p-pagetop::after {
        width: 20px;
        height: 20px;
        top: 50%;
        left: 50%;
        margin-left: -10px;
        margin-top: -3px;
    }

}

/* nav sp
----------------------------------------------------------------------------- */

.p-toggleNav {
    position: fixed;
    width: 100%;
    height: 0;
    top: 0;
    left: 0;
    overflow: hidden;
    z-index: 3;
    opacity: 0;
    transition: all .3s;
    background: rgba(0,172,183,0.9);
    box-sizing: border-box;
}
.p-toggleNav.-active {
    height: 100vh;
    opacity: 1;
    background: rgba(0,172,183,0.9);
    padding-top: calc(11 / 375 * 100 * 1vw);
}
.p-toggleNav__logo {
    width: calc(160 / 375 * 100 * 1vw);
    margin: 0 auto calc(15 / 375 * 100 * 1vw) auto;
}
.p-toggleNav__img {
    width: calc(160 / 375 * 100 * 1vw);
    margin: 0 auto calc(30 / 375 * 100 * 1vw) auto;
    padding-right: calc(17 / 375 * 100 * 1vw);
}
.p-toggleNav__wrap {
    width: calc(300 / 375 * 100 * 1vw);
    margin: 0 auto calc(10 / 375 * 100 * 1vw) auto;
    display: flex;
    justify-content: space-between;
}
.p-toggleNav__list {
    width: 100%;
    margin: 0;
    padding: 0;
}
.p-toggleNav__item {
    width: 100%;
    border: 1px solid #fff;
    margin: 0;
    padding: calc(8 / 375 * 100 * 1vw) 0;
    cursor: pointer;
    list-style: none;
    text-align: center;
    position: relative;
}
.p-toggleNav__item a {
    text-decoration: none;
}
.p-toggleNav__item + .p-toggleNav__item {
    margin-top: calc(10 / 375 * 100 * 1vw);
}
.p-toggleNav__item.-products::after,
.p-toggleNav__item.-equipments::after,
.p-toggleNav__item.-aboutus::after,
.p-toggleNav__item.-sdgs::after,
.p-toggleNav__item.-news::after,
.p-toggleNav__item.-contact::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 0 calc(30 / 375 * 100 * 1vw) calc(30 / 375 * 100 * 1vw);
}
.p-toggleNav__item.-products::after { border-color: transparent transparent #ed891e transparent; }
.p-toggleNav__item.-equipments::after { border-color: transparent transparent #cbcb00 transparent; }
.p-toggleNav__item.-aboutus::after { border-color: transparent transparent #82bc3f transparent; }
.p-toggleNav__item.-sdgs::after { border-color: transparent transparent #e5243b transparent; }
.p-toggleNav__item.-news::after { border-color: transparent transparent #0071b2 transparent; }
.p-toggleNav__item.-contact::after { border-color: transparent transparent #892785 transparent; }

.p-toggleNav__text.-jp {
    font-size: calc(14 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.05em;
    margin-bottom: calc(3 / 375 * 100 * 1vw);
}
.p-toggleNav__text.-en {
    font-size: calc(12.25 / 375 * 100 * 1vw);
    font-family: 'Source Sans Pro', sans-serif;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #fff;
}
.p-toggleNav__text.-jp a,
.p-toggleNav__text.-en a {
    color: #fff;
}
.p-toggleNav__img {
    width: calc(160 / 375 * 100 * 1vw);
    margin: 0 auto;
}

/* ovrelay */
.p-toggleNavOverlay {
    visibility: hidden;
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,0);
    transition: all .5s;
    z-index: 2;
}
.p-toggleNavOverlay.-active {
    visibility: visible;
    cursor: pointer;
}

@media screen and (min-width: 1024px) {

    .p-toggleNav { display: none; }

}

/* footer
----------------------------------------------------------------------------- */

.p-footer {
    background: #fff;
}
.p-footer__wrap.-all {
    width: 100%;
    margin: 0 auto;
    padding: calc(20 / 375 * 100 * 1vw) 0 calc(25 / 375 * 100 * 1vw) 0;
}
.p-footer__wrap.-info {
    margin-bottom: calc(20 / 375 * 100 * 1vw);
}
.p-footer__logo.-normal {
    display: none;
}
.p-footer__logo.-copy {
    width: calc(200 / 375 * 100 * 1vw);
    line-height: 0;
    display: block;
    vertical-align: bottom;
    margin: 0 auto calc(20 / 375 * 100 * 1vw) auto;
}
.p-footer__logo.-copy.-pc { display: none; }
.p-footerOffice__base {
    font-size: calc(12 / 375 * 100 * 1vw);
    letter-spacing: 0.05em;
    font-weight: 700;
    margin-bottom: calc(7 / 375 * 100 * 1vw);
    text-align: center;
}
.p-footerOffice + .p-footerOffice {
    padding-top: calc(15 / 375 * 100 * 1vw);
}
.p-footerOffice__address,
.p-footerOffice__contact {
    font-size: calc(14 / 375 * 100 * 1vw);
    letter-spacing: 0.05em;
    font-weight: 400;
    margin-bottom: calc(7 / 375 * 100 * 1vw);
    text-align: center;
}
.p-footer__wrap.-sub {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}
.p-footer__iso {
    width: calc(120 / 375 * 100 * 1vw);
    margin-bottom: calc(30 / 375 * 100 * 1vw);
    margin-left: auto;
    margin-right: auto;
}
.p-footer__tennis {
    width: calc(245 / 375 * 100 * 1vw);
    margin: 0 auto;
    color: #fff;
    background: #29a1d8;
    font-size: calc(12 / 375 * 100 * 1vw);
    font-weight: 700;
    padding: calc(14 / 375 * 100 * 1vw) 0;
    text-align: center;
    border-radius: 100vh;
    cursor: pointer;
}
.p-footer__tennis a {
    color: #fff;
    text-decoration: none;
    padding-left: calc(36 / 375 * 100 * 1vw);
    display: inline-block;
    position: relative;
}
.p-footer__tennis a::before {
    content: '';
    width: calc(30 / 375 * 100 * 1vw);
    height: calc(31.5 / 375 * 100 * 1vw);
    background: url("../images/ico_tennis_sp.png") no-repeat top center;
    background-size: contain;
    position: absolute;
    top: 50%;
    margin-top: calc(15.75 / 375 * 100 * -1vw);
    left: 0;
}
.p-footerCopyright {
    background: #00acb7;
    padding: calc(25 / 375 * 100 * 1vw) 0;
}
.p-footerCopyright__text {
    font-size: calc(14 / 375 * 100 * 1vw);
    font-family: 'Source Sans Pro', sans-serif;
    font-weight: 200;
    text-align: center;
    color: #fff;
    letter-spacing: 0.1em;
    display: block;
}

@media screen and (min-width: 1024px) {

    .p-footer__wrap.-all {
        max-width: calc(900 / 1024 * 100 * 1vw);
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(40 / 1024 * 100 * 1vw) 0;
        display: flex;
        justify-content: space-between;
    }
    .p-footer__wrap.-info {
        padding-top: calc(40 / 1024 * 100 * 1vw);
        margin-bottom: 0;
    }
    .p-footer__logo.-normal {
        width: calc(135 / 1024 * 100 * 1vw);
        margin-bottom: calc(18 / 1024 * 100 * 1vw);
        display: block;
    }
    .p-footer__logo.-copy {
        width: calc(188 / 1024 * 100 * 1vw);
        margin: 0;
    }
    .p-footer__logo.-copy.-sp { display: none; }
    .p-footer__logo.-copy.-pc { display: block; }
    .p-footerOffice__base {
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin-bottom: calc(5 / 1024 * 100 * 1vw);
        text-align: left;
    }
    .p-footerOffice + .p-footerOffice {
        padding-top: calc(8 / 1024 * 100 * 1vw);
    }
    .p-footerOffice__address,
    .p-footerOffice__contact {
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin-bottom: calc(5 / 1024 * 100 * 1vw);
        text-align: left;
    }
    .p-footer__wrap.-sub {
        max-width: calc(210 / 1024 * 100 * 1vw);
        padding-top: calc(40 / 1024 * 100 * 1vw);
        margin-left: 0;
        margin-right: 0;
    }
    .p-footer__iso {
        width: calc(120 / 1024 * 100 * 1vw);
        margin-bottom: calc(50 / 1024 * 100 * 1vw);
        margin-left: 0;
        margin-right: 0;
    }
    .p-footer__tennis {
        width: auto;
        margin: 0;
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(12 / 1024 * 100 * 1vw) 0;
    }
    .p-footer__tennis a {
        padding-left: calc(30 / 1024 * 100 * 1vw);
    }
    .p-footer__tennis a::before {
        width: calc(25 / 1024 * 100 * 1vw);
        height: calc(27 / 1024 * 100 * 1vw);
        background: url("../images/ico_tennis_pc.png") no-repeat top center;
        background-size: contain;
        margin-top: calc(14 / 1024 * 100 * -1vw);
    }
    .p-footerCopyright {
        padding: calc(25 / 1024 * 100 * 1vw) 0;
    }
    .p-footerCopyright__text {
        font-size: calc(12 / 1024 * 100 * 1vw);
        width: 100%;
        max-width: calc(900 / 1024 * 100 * 1vw);
        margin: 0 auto;
        text-align: left;
    }

}

@media screen and (min-width: 1366px) {

    .p-footer__wrap.-all {
        max-width: 1200px;
        padding: 40px 0 60px 0;
    }
    .p-footer__wrap.-info {
        padding-top: 55px;
    }
    .p-footer__logo.-normal {
        width: 180px;
        margin-bottom: 20px;
    }
    .p-footer__logo.-copy {
        width: 252px;
    }
    .p-footerOffice__base {
        font-size: 1rem;
        margin-bottom: 8px;
    }
    .p-footerOffice + .p-footerOffice {
        padding-top: 10px;
    }
    .p-footerOffice__address,
    .p-footerOffice__contact {
        font-size: 1rem;
        margin-bottom: 8px;
    }
    .p-footer__wrap.-sub {
        max-width: 280px;
        padding-top: 60px;
    }
    .p-footer__iso {
        width: 160px;
        margin-bottom: 55px;
    }
    .p-footer__tennis {
        font-size: 1rem;
        padding: 18px 0;
    }
    .p-footer__tennis a {
        padding-left: 40px;
    }
    .p-footer__tennis a::before {
        width: 34px;
        height: 36px;
        margin-top: -18px;
    }
    .p-footerCopyright {
        padding: 30px 0;
    }
    .p-footerCopyright__text {
        font-size: 1rem;
        max-width: 1200px;
    }

}

/* Top
----------------------------------------------------------------------------- */

/* loading */
#p-topLoading {
    width: 100%;
    height: 100vh;
    height: calc(var(--vh, 1vh) * 100);
    transition: all 1s;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#0ba6bc+0,00acb8+100 */
    background: #0ba6bc; /* Old browsers */
    background: -moz-linear-gradient(left,  #0ba6bc 0%, #00acb8 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(left,  #0ba6bc 0%,#00acb8 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right,  #0ba6bc 0%,#00acb8 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0ba6bc', endColorstr='#00acb8',GradientType=1 ); /* IE6-9 */
}
.p-topLoading__illust {
    width: calc(46 / 365 * 100 * 1vw);
    height: calc(46 / 365 * 100 * 1vw);
    animation: spin 6s .8s linear infinite;
    opacity: 0;
}
.-done {
    opacity: 0;
    visibility: hidden;
}

/* slider */
.swiper {
    width: 100%;
    height: 100vh;
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
}
.swiper-slide img {
    display: block;
    width: 100%;
    height: 100vh;
    object-fit: cover;
    padding-top: calc(60 / 375 * 100 * 1vw);
    box-sizing: border-box;
    z-index: 2;
}

.swiper-slide-active img {
    animation: zoomIn 3.5s linear 0s 1 normal both;
}

/* hero */
.p-topHero {
    width: 100%;
    height: 100vh;
    height: calc(var(--vh, 1vh) * 100);
    position: relative;
    overflow: hidden;
    z-index: 1;
}
.p-topHero__video { display: none; }
.p-topHero__catchcopy {
    width: calc(101 / 375 * 100 * 1vw);
    right: calc(20 / 375 * 100 * 1vw);
    bottom: calc(85 / 375 * 100 * 1vw);
    position: absolute;
}
.p-topHero__logo {
    width: calc(210 / 375 * 100 * 1vw);
    right: calc(20 / 375 * 100 * 1vw);
    bottom: calc(20 / 375 * 100 * 1vw);
    position: absolute;
}

/* products */
.p-topProducts {
    padding: calc(90 / 375 * 100 * 1vw) 0 calc(45 / 375 * 100 * 1vw) 0;
    background: url("../images/bg_top_sp_products.png") no-repeat left center #fff;
    background-size: contain;
}
.p-topProducts__catchcopy {
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    font-size: calc(16 / 375 * 100 * 1vw);
    line-height: 1.5;
    text-align: center;
    margin: 0 0 calc(15 / 375 * 100 * 1vw) 0;
    padding: 0;
}
.p-topProducts__list {
    width: calc(335 / 375 * 100 * 1vw);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 auto calc(30 / 375 * 100 * 1vw) auto;
    padding: 0;
}
.p-topProducts__item {
    width: calc(158 / 375 * 100 * 1vw);
    font-size: calc(13 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    margin: calc(20 / 375 * 100 * 1vw) 0 0 0;
    padding: calc(10 / 375 * 100 * 1vw) 0;
    list-style: none;
    background: #fff;
    border: 1px dashed #4d4d4d;
    text-align: center;
}
.p-topProducts__item:nth-child(1),
.p-topProducts__item:nth-child(2) {
    margin: 0;
}
/* products slide */
.p-topProducts__img {
    position: relative;
    display: flex;
    width: 100%;
    height: calc(100 / 375 * 100 * 1vw);
    left: 50%;
    margin-left: -50%;
    overflow: hidden;
    margin-bottom: calc(20 / 375 * 100 * 1vw);
}
.p-topProducts__img img {
    width: auto;
    height: 100%;
}
.p-topProducts__img img:first-child {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform;
}

/* animation delay add */
.p-topProducts__img .-slideLoop {
    animation: slideLoop 90s -45s linear infinite;
}
.p-topProducts__img .-slideLoop2 {
    animation: slideLoop2 90s linear infinite;
}

/* IE11 only */
@media all and (-ms-high-contrast: none) {

    .p-topProducts__img img:first-child {
        animation: slideLoop 90s -45s linear infinite;
    }
    .p-topProducts__img img + img {
        animation: slideLoop2 90s linear infinite;
    }

}

/* equipments */
.p-topEquipments {
    padding: calc(30 / 375 * 100 * 1vw) 0;
    background: #00acb7;
}
.p-topEquipments__wrap.-all {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto;
}
.p-topEquipments__wrap.-img {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: calc(20 / 375 * 100 * 1vw);
}
.p-topEquipments__img {
    width: 100%;
    max-width: calc(158 / 375 * 100 * 1vw);
    margin-top: calc(20 / 375 * 100 * 1vw);
    display: flex;
    align-items: flex-end;
}
.p-topEquipments__img:nth-child(1),
.p-topEquipments__img:nth-child(2) {
    margin-top: 0;
}
.p-topEquipments__wrap.-text {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
}
.p-topEquipments__eyecatch {
    width: calc(200 / 375 * 100 * 1vw);
    margin-left: auto;
    margin-right: auto;
    margin-bottom: calc(20 / 375 * 100 * 1vw);
}
.p-topEquipments__catchcopy {
    font-size: calc(16 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    line-height: 1.5;
    color: #fff;
    margin: 0 0 calc(25 / 375 * 100 * 1vw) 0;
    padding: 0;
}

/* aboutus */
.p-topAbout {
    padding: calc(30 / 375 * 100 * 1vw) 0 0 0;
    background: #fff;
}
.p-topAbout__wrap.-all {
    width: 100%;
    background: url("../images/bg_top_sp_about.jpg") no-repeat top center #00acb7;
    padding-top: calc(475 / 375 * 100 * 1vw);
    padding-bottom: calc(30 / 375 * 100 * 1vw);
    background-size: contain;
    position: relative;
}
.p-topAbout__wrap.-inner {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto;
}
.p-topAbout__wrap.-text {
    width: calc(335 / 375 * 100 * 1vw);
}
.p-topAbout__title {
    width: calc(260 / 375 * 100 * 1vw);
    font-size: calc(85.75 / 375 * 100 * 1vw);
    font-family: 'Sacramento', cursive;
    color: #fff;
    transform: rotate(-25deg);
    position: absolute;
    top: calc(350 / 375 * 100 * 1vw);
    left: calc(50% - (130 / 375 * 100 * 1vw));
}
.p-topAbout__leadcopy {
    font-size: calc(16 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    text-align: center;
    color: #fff;
    margin-bottom: calc(15 / 375 * 100 * 1vw);
}
.p-topAbout__text {
    font-size: calc(16 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    line-height: 1.5;
    color: #fff;
    margin-bottom: calc(25 / 375 * 100 * 1vw);
}

/* news */
.p-topNews {
    padding: calc(30 / 375 * 100 * 1vw) 0;
    background: #fff;
}
.p-topNews__list {
    width: 100%;
    max-width: calc(275 / 375 * 100 * 1vw);
    margin: 0 auto calc(15 / 375 * 100 * 1vw) auto;
}
.p-topNews__item {
    width: 100%;
    box-sizing: border-box;
    padding: calc(15 / 375 * 100 * 1vw) 0;
    cursor: pointer;
}
.p-topNews__item:first-child {
    padding: 0 0 calc(15 / 375 * 100 * 1vw) 0;
}
.p-topNews__date {
    font-size: calc(14 / 375 * 100 * 1vw);
    letter-spacing: 0.05em;
    margin-bottom: calc(10 / 375 * 100 * 1vw);
}
.p-topNews__title {
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    letter-spacing: 0.05em;
}
.p-topNews__title a {
    text-decoration: none;
    border-bottom: 1px solid #4d4d4d;
    transition: .3s;
}

@media screen and (min-width: 1024px) {

    /* loading */
    body.-top {
        /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#0ba6bc+0,00acb8+100 */
        background: #0ba6bc; /* Old browsers */
        background: -moz-linear-gradient(left,  #0ba6bc 0%, #00acb8 100%); /* FF3.6-15 */
        background: -webkit-linear-gradient(left,  #0ba6bc 0%,#00acb8 100%); /* Chrome10-25,Safari5.1-6 */
        background: linear-gradient(to right,  #0ba6bc 0%,#00acb8 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0ba6bc', endColorstr='#00acb8',GradientType=1 ); /* IE6-9 */
    }
    .p-topLoading__illust {
        width: calc(46 / 1024 * 100 * 1vw);
        height: calc(46 / 1024 * 100 * 1vw);
        animation: spin 6s linear infinite;
        opacity: 1;
    }

    /* slider */
    .swiper { display: none; }

    /* hero */
    .p-topHero {
        width: 100%;
        height: 100vh;
        max-height: 56.25vw;
        overflow: hidden;
        position: relative;
    }
    .p-topHero__video {
        display: block;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translateX(-50%) translateY(-50%);
        min-width: 102%;
        min-height: 102%;
        max-height: 56.25vw;
        background: #f0f0f0;
    }
    .p-topHero__catchcopy {
        width: calc(128 / 1024 * 100 * 1vw);
        right: calc(60 / 1024 * 100 * 1vw);
        bottom: calc(140 / 1024 * 100 * 1vw);
        position: absolute;
    }
    .p-topHero__logo {
        width: calc(315 / 1024 * 100 * 1vw);
        right: calc(60 / 1024 * 100 * 1vw);
        bottom: calc(45 / 1024 * 100 * 1vw);
        position: absolute;
    }

    /* products */
    .p-topProducts {
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(45 / 1024 * 100 * 1vw) 0;
        background: url("../images/bg_top_pc_products.png") no-repeat left center #fff;
        background-size: contain;
    }
    .p-topProducts__catchcopy {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
        margin: 0 0 calc(20 / 1024 * 100 * 1vw) 0;
    }
    .p-topProducts__list {
        width: calc(750 / 1024 * 100 * 1vw);
        margin: 0 auto calc(30 / 1024 * 100 * 1vw) auto;
    }
    .p-topProducts__item {
        width: calc(133 / 1024 * 100 * 1vw);
        font-size: calc(10.5 / 1024 * 100 * 1vw);
        margin: 0;
        padding: calc(8 / 1024 * 100 * 1vw) 0;
    }
    /* products slide */
    .p-topProducts__img {
        width: 100%;
        margin-left: -50%;
        height: calc(144 / 1024 * 100 * 1vw);
        margin-bottom: calc(25 / 1024 * 100 * 1vw);
    }

    /* equipments */
    .p-topEquipments {
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(45 / 1024 * 100 * 1vw) 0;
    }
    .p-topEquipments__wrap.-all {
        max-width: calc(900 / 1024 * 100 * 1vw);
        display: flex;
        justify-content: space-between;
        position: relative;
    }
    .p-topEquipments__wrap.-img {
        max-width: calc(666 / 1024 * 100 * 1vw);
        margin-bottom: 0;
    }
    .p-topEquipments__img {
        max-width: calc(202 / 1024 * 100 * 1vw);
        margin-top: 0;
        margin-bottom: 0;
    }
    .p-topEquipments__img:nth-child(1),
    .p-topEquipments__img:nth-child(2),
    .p-topEquipments__img:nth-child(4),
    .p-topEquipments__img:nth-child(5) {
        margin-right: calc(30 / 1024 * 100 * 1vw);
    }
    .p-topEquipments__img:nth-child(1),
    .p-topEquipments__img:nth-child(2),
    .p-topEquipments__img:nth-child(3) {
        margin-bottom: calc(30 / 1024 * 100 * 1vw);
    }
    .p-topEquipments__wrap.-text {
        max-width: calc(210 / 1024 * 100 * 1vw);
        position: absolute;
        top: calc(75 / 1024 * 100 * -1vw);
        right: 0;
    }
    .p-topEquipments__eyecatch {
        width: auto;
        margin-left: 0;
        margin-right: 0;
        margin-bottom: calc(30 / 1024 * 100 * 1vw);
    }
    .p-topEquipments__catchcopy {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
        margin: 0 0 calc(15 / 1024 * 100 * 1vw) 0;
    }

    /* aboutus */
    .p-topAbout {
        padding: calc(30 / 1024 * 100 * 1vw) 0 0 0;
    }
    .p-topAbout__wrap.-all {
        width: 100%;
        height: calc(345 / 1024 * 100 * 1vw);
        background: url("../images/bg_top_pc_about.jpg") no-repeat center center;
        background-size: cover;
        padding-top: 0;
        padding-bottom: 0;
    }
    .p-topAbout__wrap.-inner {
        width: 100%;
        max-width: calc(900 / 1024 * 100 * 1vw);
        margin: 0 auto;
    }
    .p-topAbout__wrap.-text {
        width: calc(210 / 1024 * 100 * 1vw);
        padding-top: calc(140 / 1024 * 100 * 1vw);
        margin-left: auto;
        position: relative;
    }
    .p-topAbout__title {
        width: calc(230 / 1024 * 100 * 1vw);
        font-size: calc(73.4 / 1024 * 100 * 1vw);
        font-family: 'Sacramento', cursive;
        color: #fff;
        transform: rotate(-25deg);
        position: absolute;
        top: calc(30 / 1024 * 100 * 1vw);
        left: calc(10 / 1024 * 100 * -1vw);
    }
    .p-topAbout__leadcopy {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
        font-family: 'Noto Serif JP', serif;
        font-weight: 700;
        text-align: right;
        color: #fff;
        margin-bottom: calc(10 / 1024 * 100 * 1vw);
    }
    .p-topAbout__text {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
        font-family: 'Noto Serif JP', serif;
        font-weight: 400;
        line-height: 1.5;
        color: #fff;
        margin-bottom: calc(15 / 1024 * 100 * 1vw);
    }

    /* news */
    .p-topNews {
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(45 / 1024 * 100 * 1vw) 0;
    }
    .p-topNews__list {
        max-width: calc(750 / 1024 * 100 * 1vw);
        margin: 0 auto calc(30 / 1024 * 100 * 1vw) auto;
        display: flex;
        justify-content: space-between;
    }
    .p-topNews__item {
        width: 33.333%;
        min-height: calc(81 / 1024 * 100 * 1vw);
        padding: calc(22 / 1024 * 100 * 1vw) calc(22 / 1024 * 100 * 1vw) 0 calc(22 / 1024 * 100 * 1vw);
        border-right: 1px dashed #a9a9a9;
    }
    .p-topNews__item:first-child {
        border-left: 1px dashed #a9a9a9;
        padding: calc(22 / 1024 * 100 * 1vw) calc(22 / 1024 * 100 * 1vw) 0 calc(22 / 1024 * 100 * 1vw);
    }
    .p-topNews__date {
        font-size: calc(10.5 / 1024 * 100 * 1vw);
        margin-bottom: calc(10 / 1024 * 100 * 1vw);
    }
    .p-topNews__title {
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    .p-topNews__item:hover .p-topNews__title a {
        padding-bottom: calc(5 / 1024 * 100 * 1vw);
    }

}

@media screen and (min-width: 1366px) {

    /* loading */
    .p-topLoading__illust {
        width: 61px;
        height: 61px;
    }

    /* hero */
    .p-topHero__catchcopy {
        width: 165px;
        right: 80px;
        bottom: 190px;
    }
    .p-topHero__logo {
        width: 420px;
        right: 80px;
        bottom: 60px;
    }

    /* products */
    .p-topProducts {
        padding: 40px 0 60px 0;
    }
    .p-topProducts__catchcopy {
        font-size: 1.125rem;
        margin: 0 0 30px 0;
    }
    .p-topProducts__list {
        width: 1000px;
        margin: 0 auto 40px auto;
    }
    .p-topProducts__item {
        width: 176px;
        font-size: 0.875rem;
        padding: 12px 0;
    }
    /* products slide */
    .p-topProducts__img {
        width: 100%;
        margin-left: -50%;
        height: 192px;
        margin-bottom: 30px;
    }

    /* equipments */
    .p-topEquipments {
        padding: 40px 0 60px 0;
    }
    .p-topEquipments__wrap.-all {
        max-width: 1200px;
    }
    .p-topEquipments__wrap.-img {
        max-width: 890px;
    }
    .p-topEquipments__img {
        max-width: 270px;
    }
    .p-topEquipments__img:nth-child(1),
    .p-topEquipments__img:nth-child(2),
    .p-topEquipments__img:nth-child(4),
    .p-topEquipments__img:nth-child(5) {
        margin-right: 40px;
    }
    .p-topEquipments__img:nth-child(1),
    .p-topEquipments__img:nth-child(2),
    .p-topEquipments__img:nth-child(3) {
        margin-bottom: 40px;
    }
    .p-topEquipments__wrap.-text {
        max-width: 280px;
        top: -102px;
    }
    .p-topEquipments__eyecatch {
        margin-bottom: 35px;
    }
    .p-topEquipments__catchcopy {
        font-size: 1.125rem;
        margin: 0 0 20px 0;
    }

    /* aboutus */
    .p-topAbout {
        padding: 40px 0 0 0;
    }
    .p-topAbout__wrap.-all {
        height: 460px;
    }
    .p-topAbout__wrap.-inner {
        max-width: 1200px;
    }
    .p-topAbout__wrap.-text {
        width: 280px;
        padding-top: 185px;
    }
    .p-topAbout__title {
        width: 300px;
        font-size: 6.125rem;
        top: 50px;
        left: -12px;
    }
    .p-topAbout__leadcopy {
        font-size: 1.125rem;
        margin-bottom: 20px;
    }
    .p-topAbout__text {
        font-size: 1.125rem;
        margin-bottom: 20px;
    }

    /* news */
    .p-topNews {
        padding: 40px 0 60px 0;
    }
    .p-topNews__list {
        max-width: 1000px;
        margin: 0 auto 40px auto;
    }
    .p-topNews__item {
        min-height: 108px;
        padding: 30px 30px 0 30px;
    }
    .p-topNews__item:first-child {
        padding: 30px 30px 0 30px;
    }
    .p-topNews__date {
        font-size: 0.875rem;
        margin-bottom: 15px;
    }
    .p-topNews__title {
        font-size: 1rem;
    }
    .p-topNews__item:hover .p-topNews__title a {
        padding-bottom: 10px;
    }

}

/* Products
----------------------------------------------------------------------------- */

.p-products {
    padding-top: calc(60 / 375 * 100 * 1vw);
}

.p-products__wrap.-intro {
    background: url("../images/bg_products_sp_intro.png") no-repeat top left;
    background-size: 100%;
    padding: calc(30 / 375 * 100 * 1vw) 0 calc(20 / 375 * 100 * 1vw) 0;
}
.p-productsNav {
    margin-bottom: calc(60 / 375 * 100 * 1vw);
}
.p-productsNav__list {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 0 auto;
    padding: 0;
}
.p-productsNav__item {
    width: calc(158 / 375 * 100 * 1vw);
    font-size: calc(13 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    list-style: none;
    background: #fff;
    border: 1px dashed #4d4d4d;
    text-align: center;
    margin: calc(20 / 375 * 100 * 1vw) 0 0 0;
    padding: calc(10 / 375 * 100 * 1vw) 0;
    transition: .3s;
    cursor: pointer;
    position: relative;
}
.p-productsNav__item:nth-child(1),
.p-productsNav__item:nth-child(2) {
    margin: 0;
}
.p-productsNav__item a {
    text-decoration: none;
    transition: .3s;
}
.p-productsNav__item a::before {
    display: block;
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.p-productsNav__item:hover {
    background: #00acb7;
}
.p-productsNav__item:hover a {
    color: #fff;
}

.p-productsItem {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: calc(30 / 375 * 100 * 1vw) auto;
}
.p-productsItem__wrap.-info {
    width: 100%;
}
.p-productsItem__subtitle {
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: calc(15.75 / 375 * 100 * 1vw);
    padding: 0 0 0 calc(50 / 375 * 100 * 1vw);
    margin: 0 0 calc(10 / 375 * 100 * 1vw) 0;
    position: relative;
}
.p-productsItem__subtitle::before {
    content: '';
    width: calc(43.75/ 375 * 100 * 1vw);
    height: 1px;
    background: #4d4d4d;
    position: absolute;
    left: 0;
    top: 50%;
}
.p-productsItem__text {
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    margin: 0 0 calc(15 / 375 * 100 * 1vw) 0;
    padding: 0;
}
.p-productsItemList {
    border: 1px solid #00acb7;
    box-sizing: border-box;
    padding: calc(17 / 375 * 100 * 1vw);
    margin-bottom: calc(20 / 375 * 100 * 1vw);
}
.p-productsItemList__title {
    color: #00acb7;
    font-size: calc(14 / 375 * 100 * 1vw);
    font-weight: 700;
    margin: 0 0 calc(8 / 375 * 100 * 1vw) 0;
    padding: 0;
}
.p-productsItemList__list {
    margin: 0;
    padding: 0;
}
.p-productsItemList__item {
    color: #00acb7;
    margin: 0;
    list-style: none;
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    padding: 0 0 0 1.4em;
    text-indent: -1.4em;
    letter-spacing: 0.05em;
}
.p-productsItemList__item + .p-productsItemList__item {
    margin-top: calc(3 / 375 * 100 * 1vw);
}
.p-productsItem__wrap.-img {
    width: 100%;
}
.p-productsItem__link {
    font-weight: 700;
    font-size: calc(14 / 375 * 100 * 1vw);
    margin-top: calc(15 / 375 * 100 * 1vw);
    padding-top: calc(50 / 375 * 100 * 1vw);
    position: relative;
    text-align: center;
    letter-spacing: -0.04em;
}
.p-productsItem__link::before {
    content: '';
    width: calc(28.5 / 375 * 100 * 1vw);
    height: calc(35 / 375 * 100 * 1vw);
    background: url("../images/ico_pdf_sp.png") no-repeat;
    background-size: contain;
    position: absolute;
    top: 0;
    left: 50%;
    margin-left: calc(14.25 / 375 * 100 * -1vw);
}
.p-productsItem__link a {
    border-bottom: 1px solid #4d4d4d;
    display: inline-block;
    text-decoration: none;
    padding-bottom: calc(3 / 375 * 100 * 1vw);
    transition: .3s;
}

@media screen and (min-width: 1024px) {

    .p-products {
        padding-top: 0;
        padding-bottom: calc(15 / 1024 * 100 * 1vw);
    }

    .p-products__wrap.-intro {
        background: url("../images/bg_products_pc_intro.png") no-repeat top left;
        background-size: contain;
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(40 / 1024 * 100 * 1vw) 0;
    }
    .p-productsNav {
        margin-bottom: calc(25 / 1024 * 100 * 1vw);
    }
    .p-productsNav__list {
        max-width: calc(750 / 1024 * 100 * 1vw);
    }
    .p-productsNav__item {
        width: calc(133 / 1024 * 100 * 1vw);
        font-size: calc(10.5 / 1024 * 100 * 1vw);
        margin: 0;
        padding: calc(8 / 1024 * 100 * 1vw) 0;
    }

    .p-productsItem {
        max-width: calc(750 / 1024 * 100 * 1vw);
        margin: calc(30 / 1024 * 100 * 1vw) auto;
        display: flex;
        justify-content: space-between;
    }
    .p-productsItem__wrap.-info {
        max-width: calc(360 / 1024 * 100 * 1vw);
    }
    .p-productsItem__subtitle {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
        padding: 0 0 0 calc(45 / 1024 * 100 * 1vw);
        margin: 0 0 calc(10 / 1024 * 100 * 1vw) 0;
    }
    .p-productsItem__subtitle::before {
        width: calc(37.5 / 1024 * 100 * 1vw);
    }
    .p-productsItem__text {
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin: 0 0 calc(10 / 1024 * 100 * 1vw) 0;
    }
    .p-productsItemList {
        padding: calc(15 / 1024 * 100 * 1vw);
        margin-bottom: calc(20 / 1024 * 100 * 1vw);
    }
    .p-productsItemList__title {
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin: 0 0 calc(8 / 1024 * 100 * 1vw) 0;
    }
    .p-productsItemList__item {
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    .p-productsItemList__item + .p-productsItemList__item {
        margin-top: calc(3 / 1024 * 100 * 1vw);
    }
    .p-productsItem__wrap.-img {
        max-width: calc(360 / 1024 * 100 * 1vw);
    }
    .p-productsItem__link {
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin-top: calc(15 / 1024 * 100 * 1vw);
        padding-top: calc(40 / 1024 * 100 * 1vw);
        text-align: left;
        letter-spacing: 0;
    }
    .p-productsItem__link::before {
        width: calc(24.5 / 1024 * 100 * 1vw);
        height: calc(30 / 1024 * 100 * 1vw);
        background: url("../images/ico_pdf_pc.png") no-repeat;
        background-size: contain;
        left: 0;
        margin-left: 0;
    }
    .p-productsItem__link a {
        padding-bottom: calc(3 / 1024 * 100 * 1vw);
    }
    .p-productsItem__link a:hover {
        padding-bottom: calc(10 / 1024 * 100 * 1vw);
    }

}

@media screen and (min-width: 1366px) {

    .p-products {
        padding-bottom: 20px;
    }

    .p-products__wrap.-intro {
        background: url("../images/bg_products_pc_intro.png") no-repeat top left;
        background-size: contain;
        padding: 40px 0 50px 0;
    }
    .p-productsNav {
        margin-bottom: 35px;
    }
    .p-productsNav__list {
        max-width: 1000px;
    }
    .p-productsNav__item {
        width: 176px;
        font-size: 0.875rem;
        padding: 10px 0;
    }

    .p-productsItem {
        max-width: 1000px;
        margin: 40px auto;
    }
    .p-productsItem__wrap.-info {
        max-width: 480px;
    }
    .p-productsItem__subtitle {
        font-family: 'Noto Serif JP', serif;
        font-size: 1.125rem;
        padding: 0 0 0 60px;
        margin: 0 0 15px 0;
    }
    .p-productsItem__subtitle::before {
        width: 50px;
    }
    .p-productsItem__text {
        font-size: 1rem;
        margin: 0 0 15px 0;
    }
    .p-productsItemList {
        padding: 20px;
        margin-bottom: 25px;
    }
    .p-productsItemList__title {
        font-size: 1rem;
        margin: 0 0 10px 0;
    }
    .p-productsItemList__item {
        font-size: 1rem;
    }
    .p-productsItemList__item + .p-productsItemList__item {
        margin-top: 5px;
    }
    .p-productsItem__wrap.-img {
        max-width: 480px;
    }
    .p-productsItem__link {
        font-size: 1rem;
        margin-top: 20px;
        padding-top: 55px;
    }
    .p-productsItem__link::before {
        width: 32px;
        height: 40px;
    }
    .p-productsItem__link a {
        padding-bottom: 5px;
    }
    .p-productsItem__link a:hover {
        padding-bottom: 15px;
    }

}

/* Equipments
----------------------------------------------------------------------------- */

.p-equipments {
    padding-top: calc(60 / 375 * 100 * 1vw);
}
.p-equipmentsIntro__wrap.-intro {
    padding: calc(30 / 375 * 100 * 1vw) 0;
}
.p-equipmentsIntro__wrap.-intro .p-pageLead__text {
    letter-spacing: 0;
}
.p-equipmentsIntroEyecatch {
    background: #00b4be;
    padding: calc(30 / 375 * 100 * 1vw) 0;
    margin-bottom: calc(30 / 375 * 100 * 1vw);
}
.p-equipmentsIntroEyecatch__wrap {
    width: 100%;
    max-width: 1366px;
}
.p-equipmentsIntroEyecatch__item.-illust {
    width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto calc(20 / 375 * 100 * 1vw) auto;
}
.p-equipmentsIntroEyecatch__item.-photo {
    width: calc(200 / 375 * 100 * 1vw);
    margin: 0 auto;
}
.p-equipmentsIntroEyecatch__item.-illust img {
    width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto;
}
.p-equipmentsIntroThumb {
    margin-bottom: calc(30 / 375 * 100 * 1vw);
}
.p-equipmentsIntroThumb__wrap {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto;
}
.p-equipmentsIntroThumb__item {
    line-height: 0;
    display: block;
    vertical-align: bottom;
}
.p-equipmentsIntroThumb__item + .p-equipmentsIntroThumb__item {
    margin-top: calc(20 / 375 * 100 * 1vw);
}
.p-equipmentsIntroInfo {
    width: 100%;
    padding-top: calc(30 / 375 * 100 * 1vw);
}
.p-equipmentsIntroInfo__wrap.-text {
    width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto calc(30 / 375 * 100 * 1vw) auto;
    background: #00acb7;
    box-sizing: border-box;
    padding: calc(20 / 375 * 100 * 1vw);
}
.p-equipmentsIntroInfo__title {
    color: #fff;
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: calc(18.375 / 375 * 100 * 1vw);
    margin-bottom: calc(10 / 375 * 100 * 1vw);
}
.p-equipmentsIntroInfo__text {
    color: #fff;
    font-size: calc(15.75 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    line-height: 1.5;
    hanging-punctuation: allow-end;
}
.p-equipmentsIntroInfo__wrap.-img {
    width: 100%;
}
.p-equipments__wrap.-item {
    padding: calc(30 / 375 * 100 * 1vw) 0;
}
.p-equipmentsItem {
    width: 100%;
}
.p-equipments__wrap.-item section + section {
    margin-top: calc(30 / 375 * 100 * 1vw);
}
.p-equipments__wrap.-item .c-title03 {
    max-width: calc(335 / 375 * 100 * 1vw);
    margin-left: auto;
    margin-right: auto;
}
.p-equipmentsItem__wrap {
    width: calc(355 / 375 * 100 * 1vw);
    overflow: auto;
    white-space: nowrap;
    margin-left: calc(20 / 375 * 100 * 1vw);
}
.p-equipmentsItem__3rows,
.p-equipmentsItem__4rows {
    border-collapse: collapse;
    border-top: 1px solid #a9a9a9;
    border-left: 1px solid #a9a9a9;
    box-sizing: border-box;
}
.p-equipmentsItem__3rows { width: calc(335 / 375 * 100 * 1vw); }
.p-equipmentsItem__3rows.-pt1 { width: calc(410 / 375 * 100 * 1vw); }
.p-equipmentsItem__4rows { width: calc(450 / 375 * 100 * 1vw); }
.p-equipmentsItem__4rows.-pt1 { width: calc(450 / 375 * 100 * 1vw); }
.p-equipmentsItem__4rows.-pt2 { width: calc(495 / 375 * 100 * 1vw); }
.p-equipmentsItem__4rows.-pt3 { width: calc(495 / 375 * 100 * 1vw); }
.p-equipmentsItem__4rows.-pt4 { width: calc(445 / 375 * 100 * 1vw); }
.p-equipmentsItem__4rows.-pt5 { width: calc(540 / 375 * 100 * 1vw); }

.p-equipmentsItem__3rows th,
.p-equipmentsItem__4rows th {
    color: #fff;
    background: #00acb7;
    border-right: 1px solid #a9a9a9;
    border-bottom: 1px solid #a9a9a9;
    font-weight: 700;
    font-size: calc(12 / 375 * 100 * 1vw);
    text-align: center;
    box-sizing: border-box;
    padding: calc(8 / 375 * 100 * 1vw) 0;
}
.p-equipmentsItem__3rows td,
.p-equipmentsItem__4rows td {
    font-size: calc(12 / 375 * 100 * 1vw);
    font-weight: 400;
    border-right: 1px solid #a9a9a9;
    border-bottom: 1px solid #a9a9a9;
    box-sizing: border-box;
    padding: calc(10 / 375 * 100 * 1vw) calc(20 / 375 * 100 * 1vw);
}
.p-equipmentsItem__3rows tr:nth-child(odd) td,
.p-equipmentsItem__4rows tr:nth-child(odd) td {
    background: #e8e8e8;
}

/* table 4rows size */
.p-equipmentsItem__4rows td:nth-child(2) { width: calc(68 / 375 * 100 * 1vw); }
.p-equipmentsItem__4rows td:nth-child(2),
.p-equipmentsItem__4rows td:nth-child(3) {
    text-align: center;
}

/* table 3rows size */
.p-equipmentsItem__3rows td:nth-child(1) { width: calc(95 / 375 * 100 * 1vw); }
.p-equipmentsItem__3rows td:nth-child(2) { width: calc(68 / 375 * 100 * 1vw); }
.p-equipmentsItem__3rows td:nth-child(3) { width: auto; }
.p-equipmentsItem__3rows td:nth-child(2) {
    text-align: center;
}

.p-equipmentsItem__subtitle {
    width: calc(335 / 375 * 100 * 1vw);
    font-size: calc(13.5 / 375 * 100 * 1vw);
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    color: #00acb7;
    margin: 0 auto calc(10 / 375 * 100 * 1vw) auto;
    padding: 0;
}
.c-title03 + .p-equipmentsItem__subtitle {
    margin-top: calc(5 / 375 * 100 * -1vw);
}
.p-equipmentsItem__wrap + .p-equipmentsItem__subtitle {
    margin-top: calc(15 / 375 * 100 * 1vw);
}

@media screen and (min-width: 1024px) {

    .p-equipments {
        padding-top: 0;
    }
    .p-equipmentsIntro {
        padding-bottom: calc(30 / 1024 * 100 * 1vw);
    }
    .p-equipmentsIntro__wrap.-intro {
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(20 / 1024 * 100 * 1vw) 0;
    }
    .p-equipmentsIntro__wrap.-intro .p-pageLead__text {
        text-align: center;
    }
    .p-equipmentsIntroEyecatch {
        padding: 0;
        margin: 0;
    }
    .p-equipmentsIntroEyecatch__wrap {
        max-width: 1366px;
        display: flex;
        margin: 0 auto;
    }
    .p-equipmentsIntroEyecatch__item {
        width: 50%;
        line-height: 0;
        display: block;
        vertical-align: bottom;
    }
    .p-equipmentsIntroEyecatch__item.-illust {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 50%;
        margin: 0;
    }
    .p-equipmentsIntroEyecatch__item.-photo {
        width: 50%;
        margin: 0;
    }
    .p-equipmentsIntroEyecatch__item.-illust img {
        width: calc(358 / 1024 * 100 * 1vw);
        margin: 0;
    }
    .p-equipmentsIntroThumb {
        background: #00b4be;
        margin-bottom: calc(30 / 1024 * 100 * 1vw);
    }
    .p-equipmentsIntroThumb__wrap {
        max-width: 1366px;
        display: flex;
    }
    .p-equipmentsIntroThumb__item + .p-equipmentsIntroThumb__item {
        margin-top: 0;
    }
    .p-equipmentsIntroInfo {
        max-width: calc(750 / 1024 * 100 * 1vw);
        margin: 0 auto;
        padding-top: 0;
        position: relative;
    }
    .p-equipmentsIntroInfo__wrap.-text {
        width: calc(375 / 1024 * 100 * 1vw);
        position: absolute;
        top: 0;
        right: 0;
        padding: calc(20 / 1024 * 100 * 1vw) calc(15 / 1024 * 100 * 1vw) calc(15 / 1024 * 100 * 1vw) calc(15 / 1024 * 100 * 1vw);
        margin: 0;
    }
    .p-equipmentsIntroInfo__title {
        font-size: calc(15.75 / 1024 * 100 * 1vw);
        margin-bottom: calc(8 / 1024 * 100 * 1vw);
    }
    .p-equipmentsIntroInfo__text {
        font-size: calc(13.5 / 1024 * 100 * 1vw);
    }
    .p-equipmentsIntroInfo__wrap.-img {
        max-width: calc(513 / 1024 * 100 * 1vw);
        padding-top: calc(60 / 1024 * 100 * 1vw);
    }
    .p-equipments__wrap.-item {
        padding: calc(25 / 1024 * 100 * 1vw) 0 calc(45 / 1024 * 100 * 1vw) 0;
    }
    .p-equipmentsItem {
        max-width: calc(750 / 1024 * 100 * 1vw);
        margin: 0 auto;
    }
    .p-equipments__wrap.-item section + section {
        margin-top: calc(30 / 1024 * 100 * 1vw);
    }
    .p-equipmentsItem__wrap {
        width: 100%;
        margin-left: 0;
    }
    .p-equipmentsItem__3rows,
    .p-equipmentsItem__4rows {
        width: 100%;
    }
    .p-equipmentsItem__3rows.-pt1,
    .p-equipmentsItem__4rows.-pt1,
    .p-equipmentsItem__4rows.-pt2,
    .p-equipmentsItem__4rows.-pt3,
    .p-equipmentsItem__4rows.-pt4,
    .p-equipmentsItem__4rows.-pt5 {
        width: 100%;
    }
    .p-equipmentsItem__3rows th,
    .p-equipmentsItem__4rows th {
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(8 / 1024 * 100 * 1vw) 0;
    }
    .p-equipmentsItem__3rows td,
    .p-equipmentsItem__4rows td {
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(8 / 1024 * 100 * 1vw) 0;
    }

    /* table 4rows size */
    .p-equipmentsItem__4rows td:nth-child(1) { width: calc(210 / 1024 * 100 * 1vw); }
    .p-equipmentsItem__4rows td:nth-child(2) { width: calc(90 / 1024 * 100 * 1vw); }
    .p-equipmentsItem__4rows td:nth-child(3) { width: calc(150 / 1024 * 100 * 1vw); }
    .p-equipmentsItem__4rows td:nth-child(4) { width: auto; }
    .p-equipmentsItem__4rows td:nth-child(1),
    .p-equipmentsItem__4rows td:nth-child(4) {
        padding-left: calc(20 / 1024 * 100 * 1vw);
    }
    .p-equipmentsItem__4rows td:nth-child(2),
    .p-equipmentsItem__4rows td:nth-child(3) {
        text-align: center;
    }

    /* table 3rows size */
    .p-equipmentsItem__3rows td:nth-child(1) { width: calc(210 / 1024 * 100 * 1vw); }
    .p-equipmentsItem__3rows td:nth-child(2) { width: calc(90 / 1024 * 100 * 1vw); }
    .p-equipmentsItem__3rows td:nth-child(3) { width: auto; }
    .p-equipmentsItem__3rows td:nth-child(1),
    .p-equipmentsItem__3rows td:nth-child(3) {
        padding-left: calc(20 / 1024 * 100 * 1vw);
    }
    .p-equipmentsItem__3rows td:nth-child(2) {
        text-align: center;
    }

    .p-equipmentsItem__subtitle {
        width: auto;
        font-size: calc(13.5 / 1024 * 100 * 1vw);
        margin: 0 0 calc(10 / 1024 * 100 * 1vw) 0;
    }
    .c-title03 + .p-equipmentsItem__subtitle {
        margin-top: calc(5 / 1024 * 100 * -1vw);
    }
    .p-equipmentsItem__wrap + .p-equipmentsItem__subtitle {
        margin-top: calc(15 / 1024 * 100 * 1vw);
    }

}

@media screen and (min-width: 1366px) {

    .p-equipmentsIntro {
        padding-bottom: 40px;
    }
    .p-equipmentsIntro__wrap.-intro {
        padding: 40px 0 25px 0;
    }
    .p-equipmentsIntroEyecatch__item.-illust img {
        width: 477px;
    }
    .p-equipmentsIntroThumb {
        margin-bottom: 40px;
    }
    .p-equipmentsIntroInfo {
        max-width: 1000px;
    }
    .p-equipmentsIntroInfo__wrap.-text {
        width: 500px;
        padding: 30px 20px 20px 20px;
    }
    .p-equipmentsIntroInfo__title {
        font-size: 1.3125rem;
        margin-bottom: 10px;
    }
    .p-equipmentsIntroInfo__text {
        font-size: 1.125rem;
    }
    .p-equipmentsIntroInfo__wrap.-img {
        max-width: 685px;
        padding-top: 80px;
    }
    .p-equipments__wrap.-item {
        padding: 40px 0 60px 0;
    }
    .p-equipmentsItem {
        max-width: 1000px;
    }
    .p-equipments__wrap.-item section + section {
        margin-top: 35px;
    }
    .p-equipmentsItem__3rows th,
    .p-equipmentsItem__4rows th {
        font-size: 1rem;
        padding: 10px 0;
    }
    .p-equipmentsItem__3rows td,
    .p-equipmentsItem__4rows td {
        font-size: 1rem;
        padding: 10px 0;
    }

    /* table 4rows size */
    .p-equipmentsItem__4rows td:nth-child(1) { width: 280px; }
    .p-equipmentsItem__4rows td:nth-child(2) { width: 120px; }
    .p-equipmentsItem__4rows td:nth-child(3) { width: 200px; }
    .p-equipmentsItem__4rows td:nth-child(1),
    .p-equipmentsItem__4rows td:nth-child(4) {
        padding-left: 30px;
    }

    /* table 3rows size */
    .p-equipmentsItem__3rows td:nth-child(1) { width: 280px; }
    .p-equipmentsItem__3rows td:nth-child(2) { width: 120px; }
    .p-equipmentsItem__3rows td:nth-child(1),
    .p-equipmentsItem__3rows td:nth-child(3) {
        padding-left: 30px;
    }

    .p-equipmentsItem__subtitle {
        font-size: 1.125rem;
        margin: 0 0 15px 0;
    }
    .c-title03 + .p-equipmentsItem__subtitle {
        margin-top: -5px;
    }
    .p-equipmentsItem__wrap + .p-equipmentsItem__subtitle {
        margin-top: 20px;
    }

}

/* About us
----------------------------------------------------------------------------- */

.p-aboutus {
    padding-top: calc(60 / 375 * 100 * 1vw);
}
.p-aboutus__wrap.-intro {
    padding: calc(30 / 375 * 100 * 1vw) 0 calc(20 / 375 * 100 * 1vw) 0;
}
/* ご挨拶 */
.p-aboutusGreet {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto calc(30 / 375 * 100 * 1vw) auto;
}
.p-aboutusGreet__text {
    margin: 0 0 calc(10 / 375 * 100 * 1vw) 0;
    padding: 0;
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    hanging-punctuation: allow-end;
}
.p-aboutusGreet__name {
    text-align: right;
    font-family: 'Noto Serif JP', serif;
    font-weight: 700;
    font-size: calc(18 / 375 * 100 * 1vw);
    letter-spacing: 0.2em;
}
.p-aboutusGreet__name span {
    font-weight: 400;
    font-size: calc(14 / 375 * 100 * 1vw);
    letter-spacing: 0.1em;
    margin-right: calc(10 / 375 * 100 * 1vw);
}
.p-aboutusGreet__wrap.-img {
    margin-bottom: calc(15 / 375 * 100 * 1vw);
}
.p-aboutusGreet__wrap.-img.-pc {
    display: none;
}
/* 品質方針・環境方針 */
.p-aboutusQuality,
.p-aboutusEco {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin-left: auto;
    margin-right: auto;
}
.p-aboutusQuality {
    margin-top: calc(30 / 375 * 100 * 1vw);
    margin-bottom: calc(30 / 375 * 100 * 1vw);
}
.p-aboutusEco {
    margin-bottom: calc(30 / 375 * 100 * 1vw);
}
.p-aboutusQuality__warp.-text,
.p-aboutusEco__warp.-text {
    margin-bottom: calc(20 / 375 * 100 * 1vw);
}
.p-aboutusQuality__text,
.p-aboutusEco__text {
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    margin: 0 0 calc(15 / 375 * 100 * 1vw) 0;
    padding: 0;
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
}
.p-aboutusQuality__list,
.p-aboutusEco__list {
    margin: 0;
    padding: 0 0 0 1em;
}
.p-aboutusQuality__item,
.p-aboutusEco__item {
    margin: 0;
    padding: 0;
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    font-weight: 400;
}
.p-aboutusQuality__item + .p-aboutusQuality__item,
.p-aboutusEco__item + .p-aboutusEco__item {
    margin-top: calc(15 / 375 * 100 * 1vw);
}
.p-aboutusEco__warp.-img.-pc {
    display: none;
}

/* 会社概要 */
.p-aboutusData {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: calc(30 / 375 * 100 * 1vw) auto;
}
.p-aboutusData table {
    width: 100%;
    box-sizing: border-box;
    border-bottom: 1px solid #a9a9a9;
    margin-bottom: calc(20 / 375 * 100 * 1vw);
}
.p-aboutusData table th {
    width: 100%;
    box-sizing: border-box;
    border-top: 1px solid #a9a9a9;
    border-bottom: 1px dashed #a9a9a9;
    text-align: left;
    font-weight: 700;
    font-size: calc(14 / 375 * 100 * 1vw);
    padding: calc(8 / 375 * 100 * 1vw) 0;
    line-height: 1.5;
    display: block;
}
.p-aboutusData table td {
    width: 100%;
    box-sizing: border-box;
    font-size: calc(14 / 375 * 100 * 1vw);
    padding: calc(8 / 375 * 100 * 1vw) 0 calc(8 / 375 * 100 * 1vw) 0;
    line-height: 1.5;
    display: block;
}
.p-aboutusData__head span {
    color: #00acb7;
    margin-right: calc(3 / 375 * 100 * 1vw);
}
.p-aboutusData__list {
    margin: 0;
    padding: 0;
}
.p-aboutusData__item {
    margin: 0;
    padding: 0 0 0 1.2em;
    text-indent: -1.2em;
    list-style: none;
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    letter-spacing: -0.03em;
}
.p-aboutusData__item + .p-aboutusData__item {
    margin-top: calc(5 / 375 * 100 * 1vw);
}
.p-aboutusData__img {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto;
}

/* 沿革 */
.p-aboutusHistory {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto calc(30 / 375 * 100 * 1vw) auto;
}
.p-aboutusHistory table {
    width: 100%;
    box-sizing: border-box;
    border-bottom: 1px solid #a9a9a9;
}
.p-aboutusHistory table th {
    width: 100%;
    box-sizing: border-box;
    border-top: 1px solid #a9a9a9;
    border-bottom: 1px dashed #a9a9a9;
    text-align: left;
    font-weight: 700;
    font-size: calc(14 / 375 * 100 * 1vw);
    padding: calc(8 / 375 * 100 * 1vw) 0;
    line-height: 1.5;
    display: block;
}
.p-aboutusHistory table td {
    width: 100%;
    box-sizing: border-box;
    font-size: calc(14 / 375 * 100 * 1vw);
    padding: calc(8 / 375 * 100 * 1vw) 0;
    line-height: 1.5;
    display: block;
}

/* アクセス */
.p-aboutusMap {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto calc(30 / 375 * 100 * 1vw) auto;
}
.p-aboutusMap__wrap.-item + .p-aboutusMap__wrap.-item {
    margin-top: calc(30 / 375 * 100 * 1vw);
}
.p-aboutusMap__googlemap {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 75%;
    overflow: hidden;
    margin-bottom: calc(10 / 375 * 100 * 1vw);
}
.p-aboutusMap__googlemap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.p-aboutusMapAccess__title {
    font-weight: 700;
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
}
.p-aboutusMapAccess__text {
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
}

/*SDGs*/
.p-sdgs_first {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto calc(30 / 375 * 100 * 1vw) auto;
}
.p-sdgs {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto calc(30 / 375 * 100 * 1vw) auto;
}
.p-sdgs__wrap.-intro {
    padding: calc(30 / 375 * 100 * 1vw) 0 calc(20 / 375 * 100 * 1vw) 0;
}

@media screen and (min-width: 1024px) {

    .p-aboutus {
        padding-top: 0;
    }
    .p-aboutus__wrap.-intro {
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(20 / 1024 * 100 * 1vw) 0;
    }
    .p-aboutus .p-pageLead {
        text-align: center;
    }

    /* ご挨拶 */
    .p-aboutusGreet {
        max-width: calc(750 / 1024 * 100 * 1vw);
        margin: 0 auto calc(30 / 1024 * 100 * 1vw) auto;
        display: flex;
        justify-content: space-between;
    }
    .p-aboutusGreet__wrap.-text {
        width: calc(360 / 1024 * 100 * 1vw);
    }
    .p-aboutusGreet__text {
        margin: 0;
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    .p-aboutusGreet__name {
        font-size: calc(15.75 / 1024 * 100 * 1vw);
    }
    .p-aboutusGreet__name span {
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin-right: calc(8 / 1024 * 100 * 1vw);
    }
    .p-aboutusGreet__wrap.-img {
        width: calc(360 / 1024 * 100 * 1vw);
        margin-bottom: 0;
    }
    .p-aboutusGreet__wrap.-img.-sp { display: none; }
    .p-aboutusGreet__wrap.-img.-pc { display: block; }

    /* 品質方針・環境方針 */
    .p-aboutusQuality,
    .p-aboutusEco {
        max-width: calc(750 / 1024 * 100 * 1vw);
        display: flex;
        justify-content: space-between;
    }
    .p-aboutusQuality {
        margin-top: calc(30 / 1024 * 100 * 1vw);
        margin-bottom: calc(30 / 1024 * 100 * 1vw);
    }
    .p-aboutusEco {
        margin-bottom: calc(30 / 1024 * 100 * 1vw);
    }
    .p-aboutusQuality__warp.-text,
    .p-aboutusEco__warp.-text {
        width: calc(360 / 1024 * 100 * 1vw);
        margin-bottom: 0;
    }
    .p-aboutusQuality__text,
    .p-aboutusEco__text {
        margin: 0 0 calc(15 / 1024 * 100 * 1vw) 0;
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    .p-aboutusQuality__item,
    .p-aboutusEco__item {
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    .p-aboutusQuality__item + .p-aboutusQuality__item,
    .p-aboutusEco__item + .p-aboutusEco__item {
        margin-top: calc(8 / 1024 * 100 * 1vw);
    }
    .p-aboutusQuality__warp.-img,
    .p-aboutusEco__warp.-img {
        width: calc(360 / 1024 * 100 * 1vw);
    }
    .p-aboutusEco__warp.-img.-sp { display: none; }
    .p-aboutusEco__warp.-img.-pc { display: block; }

    /* 会社概要 */
    .p-aboutusData {
        width: 100%;
        max-width: calc(750 / 1024 * 100 * 1vw);
        margin: calc(30 / 1024 * 100 * 1vw) auto;
    }
    .p-aboutusData table {
        border-top: 1px dashed #a9a9a9;
        border-bottom: none;
        margin-bottom: calc(20 / 1024 * 100 * 1vw);
    }
    .p-aboutusData table th {
        width: 50%;
        border-top: none;
        border-right: 1px dashed #a9a9a9;
        border-bottom: 1px dashed #a9a9a9;
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(8 / 1024 * 100 * 1vw) 0;
        vertical-align: top;
        display: table-cell;
    }
    .p-aboutusData table td {
        width: 50%;
        border-bottom: 1px dashed #a9a9a9;
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(8 / 1024 * 100 * 1vw) 0 calc(8 / 1024 * 100 * 1vw) calc(20 / 1024 * 100 * 1vw);
        display: table-cell;
    }
    .p-aboutusData__head {
        padding-left: calc(245 / 1024 * 100 * 1vw);
    }
    .p-aboutusData__head span {
        margin-right: calc(2 / 1024 * 100 * 1vw);
    }
    .p-aboutusData__item {
        font-size: calc(12 / 1024 * 100 * 1vw);
        line-height: 1.3125;
        letter-spacing: 0;
    }
    .p-aboutusData__item + .p-aboutusData__item {
        margin-top: calc(3 / 1024 * 100 * 1vw);
    }
    .p-aboutusData__img {
        max-width: calc(450 / 1024 * 100 * 1vw);
    }

    /* 沿革 */
    .p-aboutusHistory {
        max-width: calc(750 / 1024 * 100 * 1vw);
        margin: 0 auto calc(30 / 1024 * 100 * 1vw) auto;
    }
    .p-aboutusHistory table {
        border-top: 1px dashed #a9a9a9;
        border-bottom: none;
    }
    .p-aboutusHistory table th {
        width: 50%;
        border-top: none;
        border-right: 1px dashed #a9a9a9;
        border-bottom: 1px dashed #a9a9a9;
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(8 / 1024 * 100 * 1vw) 0;
        vertical-align: top;
        display: table-cell;
    }
    .p-aboutusHistory table td {
        width: 50%;
        border-bottom: 1px dashed #a9a9a9;
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(8 / 1024 * 100 * 1vw) 0 calc(8 / 1024 * 100 * 1vw) calc(20 / 1024 * 100 * 1vw);
        display: table-cell;
    }
    .p-aboutusHistory__head {
        padding-left: calc(245 / 1024 * 100 * 1vw);
    }

    /* アクセス */
    .p-aboutusMap {
        max-width: calc(750 / 1024 * 100 * 1vw);
        margin: 0 auto calc(45 / 1024 * 100 * 1vw) auto;
    }
    .p-aboutusMap__wrap.-all {
        display: flex;
        justify-content: space-between;
    }
    .p-aboutusMap__wrap.-item {
        width: calc(360 / 1024 * 100 * 1vw);
    }
    .p-aboutusMap__wrap.-item + .p-aboutusMap__wrap.-item {
        margin-top: 0;
    }
    .p-aboutusMap__googlemap {
        margin-bottom: calc(10 / 1024 * 100 * 1vw);
    }
    .p-aboutusMapAccess__title {
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    .p-aboutusMapAccess__text {
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
	
	/*sdgs*/
	.p-sdgs {
        padding-top: 0;
    }
    .p-sdgs__wrap.-intro {
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(20 / 1024 * 100 * 1vw) 0;
    }

}

@media screen and (min-width: 1366px) {

    .p-aboutus__wrap.-intro {
        padding: 40px 0 25px 0;
    }
    /* ご挨拶 */
    .p-aboutusGreet {
        max-width: 1000px;
        margin: 0 auto 40px auto;
    }
    .p-aboutusGreet__wrap.-text {
        width: 480px;
    }
    .p-aboutusGreet__text {
        font-size: 1rem;
    }
    .p-aboutusGreet__name {
        font-size: 1.3125rem;
    }
    .p-aboutusGreet__name span {
        font-size: 1rem;
        margin-right: 10px;
    }
    .p-aboutusGreet__wrap.-img {
        width: 480px;
    }
    /* 品質方針・環境方針 */
    .p-aboutusQuality,
    .p-aboutusEco {
        max-width: 1000px;
    }
    .p-aboutusQuality {
        margin-top: 40px;
        margin-bottom: 40px;
    }
    .p-aboutusEco {
        margin-bottom: 40px;
    }
    .p-aboutusQuality__warp.-text,
    .p-aboutusEco__warp.-text {
        width: 480px;
    }
    .p-aboutusQuality__text,
    .p-aboutusEco__text {
        margin: 0 0 20px 0;
        font-size: 1rem;
    }
    .p-aboutusQuality__item,
    .p-aboutusEco__item {
        font-size: 1rem;
    }
    .p-aboutusQuality__item + .p-aboutusQuality__item,
    .p-aboutusEco__item + .p-aboutusEco__item {
        margin-top: 10px;
    }
    .p-aboutusQuality__warp.-img,
    .p-aboutusEco__warp.-img {
        width: 480px;
    }

    /* 会社概要 */
    .p-aboutusData {
        max-width: 1000px;
        margin: 40px auto;
    }
    .p-aboutusData table {
        margin-bottom: 30px;
    }
    .p-aboutusData table th {
        font-size: 1rem;
        padding: 10px 0;
    }
    .p-aboutusData table td {
        font-size: 1rem;
        padding: 10px 0 10px 25px;
    }
    .p-aboutusData__head {
        padding-left: 330px;
    }
    .p-aboutusData__head span {
        margin-right: 3px;
    }
    .p-aboutusData__item {
        font-size: 1rem;
    }
    .p-aboutusData__item + .p-aboutusData__item {
        margin-top: 5px;
    }
    .p-aboutusData__img {
        max-width: 600px;
    }

    /* 沿革 */
    .p-aboutusHistory {
        max-width: 1000px;
        margin: 0 auto 40px auto;
    }
    .p-aboutusHistory table th {
        font-size: 1rem;
        padding: 10px 0;
    }
    .p-aboutusHistory table td {
        font-size: 1rem;
        padding: 10px 0 10px 25px;
    }
    .p-aboutusHistory__head {
        padding-left: 330px;
    }

    /* アクセス */
    .p-aboutusMap {
        max-width: 1000px;
        margin: 0 auto 60px auto;
    }
    .p-aboutusMap__wrap.-item {
        width: 480px;
    }
    .p-aboutusMap__googlemap {
        margin-bottom: 10px;
    }
    .p-aboutusMapAccess__title {
        font-size: 1rem;
    }
    .p-aboutusMapAccess__text {
        font-size: 1rem;
    }
	
	/*SDGs*/
	.p-sdgs_first {
		max-width: 1000px;
        margin: 0 auto 40px auto;
    }
	.p-sdgs {
		max-width: 1000px;
        margin: 40px auto;
    }

}

/* News
----------------------------------------------------------------------------- */

.p-news {
    padding-top: calc(60 / 375 * 100 * 1vw);
    margin-bottom: calc(30 / 375 * 100 * 1vw);
}
.p-news__wrap.-intro {
    padding: calc(30 / 375 * 100 * 1vw) 0 calc(10 / 375 * 100 * 1vw) 0;
    margin: 0;
}
.p-news .c-title03 {
    text-align: left;
    line-height: 1.35;
    margin-bottom: calc(15 / 375 * 100 * 1vw);
}
.p-newsArticle {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    margin: 0 auto;
    padding-bottom: calc(45 / 375 * 100 * 1vw);
    position: relative;
}
.p-newsArticle::after {
    content: '';
    width: 100%;
    height: calc(14 / 375 * 100 * 1vw);
    position: absolute;
    left: 0;
    bottom: 0;
    background-image: repeating-linear-gradient(-45deg, #29a1d8 0px, #29a1d8 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
    background-size: calc(14 / 375 * 100 * 1vw) calc(14 / 375 * 100 * 1vw);
}
.p-newsArticle + .p-newsArticle {
    margin-top: calc(25 / 375 * 100 * 1vw);
}
.p-newsArticle__wrap.-img {
    margin-top: calc(20 / 375 * 100 * 1vw);
}
.p-newsArticle__date {
    font-size: calc(14 / 375 * 100 * 1vw);
    letter-spacing: 0.05em;
    margin-bottom: calc(15 / 375 * 100 * 1vw);
}
.p-newsArticle__body {
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    hanging-punctuation: allow-end;
}
.p-newsArticle__body p:first-child {
    margin: 0;
    padding: 0;
}

@media screen and (min-width: 1024px) {

    .p-news {
        padding-top: 0;
        margin-bottom: calc(45 / 1024 * 100 * 1vw);
    }
    .p-news__wrap.-intro {
        padding: calc(30 / 1024 * 100 * 1vw) 0 calc(25 / 1024 * 100 * 1vw) 0;
    }
    .p-news .c-title03 {
        margin: 0 0 calc(22 / 1024 * 100 * 1vw) 0;
    }
    .p-newsArticle {
        max-width: calc(750 / 1024 * 100 * 1vw);
        padding-bottom: calc(40 / 1024 * 100 * 1vw);
    }
    .p-newsArticle::after {
        width: calc(743 / 1024 * 100 * 1vw);
        height: calc(12 / 1024 * 100 * 1vw);
        background-image: repeating-linear-gradient(-45deg, #29a1d8 0px, #29a1d8 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
        background-size: calc(12 / 1024 * 100 * 1vw) calc(12 / 1024 * 100 * 1vw);
    }
    .p-newsArticle.-img {
        display: flex;
        justify-content: space-between;
    }
    .p-newsArticle + .p-newsArticle {
        margin-top: calc(40 / 1024 * 100 * 1vw);
    }
    .p-newsArticle__wrap {
        width: calc(360 / 1024 * 100 * 1vw);
    }
    .p-newsArticle__wrap.-img {
        margin-top: 0;
    }
    .p-newsArticle__date {
        font-size: calc(10.5 / 1024 * 100 * 1vw);
        margin-bottom: calc(10 / 1024 * 100 * 1vw);
    }
    .p-newsArticle__body {
        font-size: calc(12 / 1024 * 100 * 1vw);
    }

}

@media screen and (min-width: 1366px) {

    .p-news {
        margin-bottom: 60px;
    }
    .p-news__wrap.-intro {
        padding: 40px 0;
    }
    .p-news .c-title03 {
        margin: 0 0 25px 0;
    }
    .p-newsArticle {
        max-width: 1000px;
        padding-bottom: 55px;
    }
    .p-newsArticle::after {
        width: 991px;
        height: 16px;
        background-image: repeating-linear-gradient(-45deg, #29a1d8 0px, #29a1d8 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
        background-size: 16px 16px;
    }
    .p-newsArticle + .p-newsArticle {
        margin-top: 50px;
    }
    .p-newsArticle__wrap {
        width: 480px;
    }
    .p-newsArticle__date {
        font-size: 0.875rem;
        margin-bottom: 15px;
    }
    .p-newsArticle__body {
        font-size: 1rem;
    }

}

/* Contact us
----------------------------------------------------------------------------- */

.p-contact {
    padding-top: calc(60 / 375 * 100 * 1vw);
}
.p-contactForm {
    padding: calc(45 / 375 * 100 * 1vw) 0;
    background: #f6f7f7;
}
.p-contactForm__wrap {
    width: 100%;
    max-width: calc(335 / 375 * 100 * 1vw);
    background: #fff;
    margin: 0 auto;
    padding: calc(30 / 375 * 100 * 1vw) calc(20 / 375 * 100 * 1vw);
    box-sizing: border-box;
}
.p-contactForm__text {
    font-size: calc(16 / 375 * 100 * 1vw);
    padding: 0;
    margin: 0 0 calc(20 / 375 * 100 * 1vw) 0;
    line-height: 1.5;
    text-align: center;
}
.p-contactFormStep {
    margin: 0 0 calc(30 / 375 * 100 * 1vw) 0;
    padding: 0;
}
.p-contactFormStep__item {
    width: 100%;
    font-size: calc(14 / 375 * 100 * 1vw);
    margin: 0;
    padding: calc(10 / 375 * 100 * 1vw) 0;
    border: 1px solid #4d4d4d;
    text-align: center;
    list-style: none;
    position: relative;
}
.p-contactFormStep__item + .p-contactFormStep__item {
    margin-top: calc(30 / 375 * 100 * 1vw);
}
.p-contactFormStep__item + .p-contactFormStep__item::before {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: calc(10 / 375 * 100 * 1vw) calc(6 / 375 * 100 * 1vw) 0 calc(6 / 375 * 100 * 1vw);
    border-color: #4d4d4d transparent transparent transparent;
    position: absolute;
    top: calc(18 / 375 * 100 * -1vw);
    left: 50%;
    margin-top: calc(4 / 375 * 100 * -1vw);
    margin-left: calc(6 / 375 * 100 * -1vw);
}
.p-contactForm table {
    width: 100%;
    margin-bottom: calc(15 / 375 * 100 * 1vw);
    border-collapse: collapse;
}
.p-contactForm table th {
    width: 100%;
    text-align: left;
    font-size: calc(16 / 375 * 100 * 1vw);
    font-weight: 700;
    vertical-align: top;
    line-height: 1.5;
    padding: calc(10 / 375 * 100 * 1vw) 0 calc(6 / 375 * 100 * 1vw) 0;
    display: block;
}
.p-contactForm table th span {
    width: calc(45 / 375 * 100 * 1vw);
    text-align: center;
    color: #fff;
    background: #00acb7;
    padding: calc(2 / 375 * 100 * 1vw) 0;
    margin: 0 calc(8 / 375 * 100 * 1vw) 0 0;
    font-size: calc(12.25 / 375 * 100 * 1vw);
    display: inline-block;
}
.p-contactForm table td {
    line-height: 1.5;
    padding: calc(6 / 375 * 100 * 1vw) 0 calc(10 / 375 * 100 * 1vw) 0;
    display: block;
}
.p-contactForm__privacy {
    width: 100%;
    height: calc(180 / 375 * 100 * 1vw);
    border: 1px solid #a9a9a9;
    overflow-y: scroll;
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    box-sizing: border-box;
    padding: calc(20 / 375 * 100 * 1vw);
    margin-bottom: calc(30 / 375 * 100 * 1vw);
}
.p-contactForm__privacy p:first-child {
    margin: 0;
    padding: 0;
}
.p-contactForm__agree  {
    font-size: calc(14 / 375 * 100 * 1vw);
    text-align: center;
    margin-bottom: calc(25 / 375 * 100 * 1vw);
}

.p-contactForm__inputMedium,
.p-contactForm__inputLarge,
.p-contactForm__textarea {
    background: #f0f0f1;
    border: none;
    outline: none;
    box-sizing: border-box;
    padding: calc(6 / 375 * 100 * 1vw) 0;
    font-size: calc(16 / 375 * 100 * 1vw);
    box-shadow: none;
    border-radius: 0;
}
.p-contactForm__inputMedium,
.p-contactForm__inputLarge,
.p-contactForm__textarea {
    width: 100% !important;
    max-width: 100% !important;
    line-height: 1.5;
}
.p-contactForm__textarea {
    height: calc(180 / 375 * 100 * 1vw) !important;
}
.p-contactForm__message {
    font-size: calc(14 / 375 * 100 * 1vw);
    line-height: 1.5;
    text-align: center;
}

/* mailformpro */
div.mfp_err {
    font-size: calc(14 / 375 * 100 * 1vw) !important;
    background-image: none !important;
    padding: calc(5 / 375 * 100 * 1vw) 0 0 0 !important;
}
div#mfp_phase_confirm_inner h4 {
    font-size: calc(16 / 375 * 100 * 1vw);
    font-weight: 700;
}
#mfp_confirm_table {
    width: 100% !important;
    margin: 0 0 calc(20 / 375 * 100 * 1vw) 0 !important;
}
#mfp_confirm_table th,
#mfp_confirm_table td {
    width: 100% !important;
    background: #fff !important;
    font-size: calc(16 / 375 * 100 * 1vw) !important;
    border: none !important;
    display: block !important;
}
#mfp_confirm_table th {
    font-weight: 700 !important;
    padding: calc(10 / 375 * 100 * 1vw) 0 calc(3 / 375 * 100 * 1vw) 0 !important;
}
#mfp_confirm_table td {
    font-weight: 400 !important;
    padding: calc(3 / 375 * 100 * 1vw) 0 calc(15 / 375 * 100 * 1vw) 0 !important;
}
div.mfp_buttons {
    width: 100% !important;
}

@media screen and (min-width: 1024px) {

    .p-contact {
        padding-top: 0;
    }
    .p-contactForm {
        padding: calc(45 / 1024 * 100 * 1vw) 0;
    }
    .p-contactForm__wrap {
        max-width: calc(750 / 1024 * 100 * 1vw);
        padding: calc(40 / 1024 * 100 * 1vw);
    }
    .p-contactForm__text {
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin: 0 0 calc(30 / 1024 * 100 * 1vw) 0;
        text-align: left;
    }
    .p-contactFormStep {
        margin: 0 0 calc(25 / 1024 * 100 * 1vw) 0;
        padding: 0;
        display: flex;
        justify-content: space-between;
    }
    .p-contactFormStep__item {
        width: calc(165 / 1024 * 100 * 1vw);
        font-size: calc(10.5 / 1024 * 100 * 1vw);
        padding: calc(10 / 1024 * 100 * 1vw) 0;
    }
    .p-contactFormStep__item + .p-contactFormStep__item {
        margin-top: 0;
    }
    .p-contactFormStep__item + .p-contactFormStep__item::before {
        border-style: solid;
        border-width: calc(5 / 1024 * 100 * 1vw) 0 calc(5 / 1024 * 100 * 1vw) calc(8 / 1024 * 100 * 1vw);
        border-color: transparent transparent transparent #4d4d4d;
        top: 50%;
        left: calc(50 / 1024 * 100 * -1vw);
        margin-top: calc(5 / 1024 * 100 * -1vw);
        margin-left: 0;
    }
    .p-contactForm table {
        margin-bottom: calc(15 / 1024 * 100 * 1vw);
    }
    .p-contactForm table th {
        width: calc(170 / 1024 * 100 * 1vw);
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(15 / 1024 * 100 * 1vw) 0 0 0;
        display: table-cell;
    }
    .p-contactForm table th span {
        width: calc(45 / 1024 * 100 * 1vw);
        padding: calc(2 / 1024 * 100 * 1vw) 0;
        margin: 0 calc(8 / 1024 * 100 * 1vw) 0 0;
        font-size: calc(10.5 / 1024 * 100 * 1vw);
    }
    .p-contactForm table td {
        padding: calc(10 / 1024 * 100 * 1vw) 0;
        display: table-cell;
    }
    .p-contactForm__privacy {
        height: calc(120 / 1024 * 100 * 1vw);
        font-size: calc(12 / 1024 * 100 * 1vw);
        padding: calc(20 / 1024 * 100 * 1vw);
        margin-bottom: calc(20 / 1024 * 100 * 1vw);
    }
    .p-contactForm__agree  {
        font-size: calc(12 / 1024 * 100 * 1vw);
        margin-bottom: calc(20 / 1024 * 100 * 1vw);
    }

    .p-contactForm__inputMedium,
    .p-contactForm__inputLarge,
    .p-contactForm__textarea {
        padding: calc(6 / 1024 * 100 * 1vw) 0;
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    .p-contactForm__inputMedium {
        width: calc(280 / 1024 * 100 * 1vw) !important;
    }
    .p-contactForm__textarea {
        height: calc(130 / 1024 * 100 * 1vw) !important;
    }
    .p-contactForm__message {
        font-size: calc(12 / 1024 * 100 * 1vw);
    }

    /* mailformpro */
    div.mfp_err {
        font-size: calc(12 / 1024 * 100 * 1vw) !important;
        padding: calc(5 / 1024 * 1vw) 0 0 0 !important;
    }
    div#mfp_phase_confirm_inner h4 {
        font-size: calc(12 / 1024 * 100 * 1vw);
    }
    #mfp_confirm_table {
        margin: 0 0 calc(20 / 1024 * 100 * 1vw) 0 !important;
    }
    #mfp_confirm_table th,
    #mfp_confirm_table td {
        font-size: calc(12 / 1024 * 100 * 1vw) !important;
        padding: calc(12 / 1024 * 100 * 1vw) 0 !important;
        display: table-cell !important;
    }
    #mfp_confirm_table th {
        width: calc(170 / 1024 * 100 * 1vw) !important;
    }
    #mfp_confirm_table td {
        width: auto !important;
    }
    div.mfp_buttons {
        width: calc(450 / 1024 * 100 * 1vw) !important;
        margin: 0 auto !important;
        display: flex;
        justify-content: space-between;
    }

}

@media screen and (min-width: 1366px) {

    .p-contactForm {
        padding: 60px 0;
    }
    .p-contactForm__wrap {
        max-width: 1000px;
        padding: 50px;
    }
    .p-contactForm__text {
        font-size: 1rem;
        margin: 0 0 40px 0;
    }
    .p-contactFormStep {
        margin: 0 0 40px 0;
    }
    .p-contactFormStep__item {
        font-size: 0.875rem;
        width: 220px;
        padding: 12px 0;
    }
    .p-contactFormStep__item + .p-contactFormStep__item::before {
        border-width: 7px 0 7px 10px;
        border-color: transparent transparent transparent #4d4d4d;
        left: -65px;
        margin-top: -7px;
    }
    .p-contactForm table {
        margin-bottom: 20px;
    }
    .p-contactForm table th {
        width: 225px;
        padding: 20px 0 0 0;
        font-size: 1rem;
    }
    .p-contactForm table th span {
        width: 60px;
        padding: 3px 0;
        margin: 0 10px 0 0;
        font-size: 0.875rem;
    }
    .p-contactForm table td {
        padding: 15px 0;
    }
    .p-contactForm__privacy {
        height: 160px;
        font-size: 1rem;
        padding: 30px;
        margin-bottom: 30px;
    }
    .p-contactForm__agree  {
        font-size: 1rem;
        margin-bottom: 30px;
    }

    .p-contactForm__inputMedium,
    .p-contactForm__inputLarge,
    .p-contactForm__textarea {
        padding: 8px 0;
        font-size: 1rem;
    }
    .p-contactForm__inputMedium {
        width: 370px !important;
    }
    .p-contactForm__inputLarge,
    .p-contactForm__textarea {
        width: 100% !important;
    }
    .p-contactForm__textarea {
        height: 160px !important;
    }
    .p-contactForm__message {
        font-size: 1rem;
    }

    /* mailformpro */
    div.mfp_err {
        font-size: 0.875rem !important;
        padding: 5px 0 0 0 !important;
    }
    div#mfp_phase_confirm_inner h4 {
        font-size: 1rem;
    }
    #mfp_confirm_table {
        margin: 0 0 30px 0 !important;
    }
    #mfp_confirm_table th,
    #mfp_confirm_table td {
        font-size: 1rem !important;
        padding: 15px 0 !important;
    }
    #mfp_confirm_table th {
        width: 225px !important;
    }
    div.mfp_buttons {
        width: 600px !important;
    }

}

/* -----------------------------------------------------------------------------

	Object => Utility

----------------------------------------------------------------------------- */

.u-cf:before, .u-cf:after { content: ""; display: block; }
.u-cf:after { clear: both; }
.u-cf { zoom: 1; }

.u-ta_c { text-align: center; }

@media screen and (max-width : 1023px) {
    .u-dp_1023 { display: none; }
}

@media screen and (min-width : 1024px) {
    .u-dp1024_ { display: none; }
}

.txt-center { text-align: center; }
.p-sdgs-wrap { padding: 0;}
.sdgs-box { line-height: 1.5; width: 100%; margin: 80px 0;}
.sdgs-inner { padding:0 50px; }
.sdgs_title {
  border-left: solid 5px #00acb7;
  line-height: 1;
  padding: 7px 0 7px 18px;
	font-size: calc(18 / 375 * 100 * 1vw);
}


.sdgs_list { margin:20px 0; padding: 2%; background-color: #f0f0f0;}
.sdgs_list li {
    padding: 10px 0 5px 25px;
    position: relative;
	list-style-type: none;
	font-size: calc(16 / 375 * 100 * 1vw);
}
.sdgs_list li:before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #00acb7;
    position: absolute;
    top: 17px;
    left: 7px;
}

.sdgs_icon { display: flex; flex-wrap: wrap; margin: 0; padding: 0; }
.sdgs_icon li { list-style: none; padding-right: 2%; }
.sdgs_icon li img { width: 125px; height: auto;}



.lite_gr { color: #00acb7; }
.bold { font-weight:900;}

@media screen and (max-width : 480px) {
	.smp { display: none; }
	.p-toggleNav__logo { margin: 0 auto calc(35 / 375 * 100 * 1vw) auto!important; }
	.p-toggleNav__item + .p-toggleNav__item { margin-top: calc(20 / 375 * 100 * 1vw)!important; }
	
	.p-adgs_first div.sdgs-box { line-height: 1.5; width: 100%; margin: 0 0 40px 0!important;}
	.sdgs-inner { padding:0; }
	.sdgs_list li {	padding: 10px 0 5px 25px; }
	.sdgs_list li:before {
    content: '';
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #00acb7;
    position: absolute;
    top: 17px;
    left: 7px;
	}
	
	.sdgs_icon li { width : calc(100% / 3) ; list-style: none; padding: 1%; box-sizing: border-box; }
	.sdgs_icon li img { width: 100%; vertical-align:top; }
	
	.sdgs_img { width: 100%; margin: 0 auto; }
	
}

@media screen and (min-width : 481px) and (max-width : 1023px) {
	.sdgs_list li {	padding: 10px 0 5px 45px; }
	.sdgs_list li:before {
    content: '';
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background-color: #00acb7;
    position: absolute;
    top: 30px;
    left: 7px;
	}
	.sdgs_icon li { width : calc(100% / 4) ; list-style: none; padding: 1%; box-sizing: border-box; }
	.sdgs_icon li img { width: 100%; vertical-align:top; }
}
@media screen and (min-width: 1024px){
	.pc { display: none; }
	.p-sdgs-wrap { padding: 0;}
	.sdgs_title { font-size: calc(15.75 / 1024 * 100 * 1vw); text-align: left; }
	.sdgs_list li {	padding: 10px 0 5px 25px; font-size: calc(13.5 / 1024 * 100 * 1vw); }
}
@media screen and (min-width: 1366px) {
	.sdgs_img { width: 750px; margin: 0 auto; }
	.p-sdgs_first div.sdgs-box { line-height: 1.5; width: 100%; margin: 0 0 40px 0!important;}
	.sdgs_title { font-size: 1.3125rem; }
	.sdgs_list li {	padding: 10px 0 5px 25px; font-size: 1.125rem; }
}
