@charset "UTF-8";
/*!
Theme Name: TRINITY
Template:   cocoon-master
*/
@import url('https://fonts.googleapis.com/css2?family=Albert+Sans:ital,wght@0,100..900;1,100..900&family=Noto+Sans+JP:wght@100..900&display=swap');

abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
ul,
var,
video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: 0 0;
    list-style: none;
}

p,
h1,
h2,
h3,
a {
    position: relative;
    z-index: 0;
}

p {
    line-height: 2;
}

html {
    font-size: 62.5%;
    scroll-padding-top: 100px;
}

img {
    display: block;
    max-width: 100%;
    height: auto;
}

body {
    font-family: "Noto Sans JP", sans-serif;
    color: #202020;
    margin: 0;
    padding: 0;
    font-size: 1.6rem;
}

section {
    overflow: hidden;
}

a {
    transition: .25s;
    text-decoration: none;
}

a:hover {
    opacity: .7;
}

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

.en {
    font-family: "Albert Sans", sans-serif;
}

.pc {
    display: block;
}

.sp {
    display: none;
}

.flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.wrap {
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
}

.wrap_sec {
    max-width: 1100px;
    margin: 0 auto;
    width: 100%;
}

.contents .wrap {
    max-width: 1000px;
}

.top_ttl {
    font-weight: 700;
}

.top_ttl span {
    display: block;
    font-size: 1.6rem;
    font-family: "Albert Sans", sans-serif;
}

.top_ttl h2 {
    font-size: 8.4rem;
    font-family: "Albert Sans", sans-serif;
    line-height: 1;
    margin: 0 0 10px;
}

.top_ttl p {
    letter-spacing: 1px;
}

.btn {
    display: block;
    text-align: center;
    margin: 0 auto;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 2.6;
    width: 30%;
    min-width: 190px;
    position: relative;
    font-family: "Albert Sans", sans-serif;
    background: transparent;
    border-radius: 50px;
    padding: 10px 20px;
    color: #202020;
}

.btn::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50px;
    padding: 1px;
    background: linear-gradient(90deg, #ED0D18, #0E55CE, #4EC716);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: exclude;
    mask-composite: exclude;
    pointer-events: none;
}

.btn:hover,
#contact .btn:hover {
    background: #000;
    color: #fff;
    opacity: 1;
}

header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100px;
    z-index: 99;
    transition: box-shadow 0.4s ease-in-out;
}

.scrolled {
    box-shadow: 0 0px 8px #BED0D4;
}

.logo {
    margin-left: 4%;
}

.logo img {
    max-width: 170px;
}

nav {
    width: 60%;
    margin-right: 4%;
}

header ul {
    align-items: center;
}

nav a {
    font-size: 1.4rem;
    color: #202020;
    font-weight: 600;
}

.service_list {
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
    position: absolute;
    background: white;
    z-index: 10;
    width: 400%;
    padding: 3% 15%;
}

.service_list.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(30px);
}

.service_list ul li {
    margin: 0 0 10px;
}

main {
    margin: 100px 0 0;
}

#mv {
    padding: 40px 0 0;
}

#mv h2 {
    font-size: 7.2rem;
    font-weight: 500;
    width: 45%;
}

#mv h2 span {
    border: solid 4px #202020;
    background: #fff;
    padding: 10px 20px 20px;
    line-height: 1;
    display: inline-block;
    margin: 0 0 30px;
}

#mv h2 .adust {
    margin: 0 0 0 15%;
}

.mv_icon {
    width: 50%;
    align-content: center;
}

.mv_slide {
    top: -50px;
    z-index: -1;
}

.mv_slide img {
    width: 100%;
}

.top_slide img {
    width: 100%;
}

#company {
    padding: 60px 0 100px;
}

.company_l,
.news_l {
    width: 40%;
}

.company_r {
    width: 50%;
}

.company_r h3 {
    font-weight: 500;
    font-size: 5rem;
    letter-spacing: 2px;
    margin: 0 0 20px;
}

.company_r p {
    font-size: 1.8rem;
}

.company_r .btn {
    margin: 40px 0 0;
}

.mv_slide img {
    width: 100%;
}

#service {
    padding: 80px 0 100px;
}

#service .top_ttl,
#cases .top_ttl,
#contact .top_ttl {
    width: fit-content;
    margin: 0 auto;
}

#service .top_ttl h2,
#service .top_ttl p,
#cases .top_ttl h2,
#contact .top_ttl h2,
#cases .top_ttl p,
#contact .top_ttl p {
    text-align: center;
}

#service ul {
    margin: 60px 0 0;
}

#service ul li {
    width: 27%;
    margin: 0 0 6px;
    padding: 40px 3% 45px;
    color: #fff;
    text-align: center;
}

#service ul li:first-child {
    width: 100%;
    padding: 60px 5% 50px;
    text-align: left;
    background: url(./img/service1.jpg) center / cover no-repeat;
}

#service ul li:nth-child(2) {
    background: url(./img/service2.jpg) center / cover no-repeat;
}

#service ul li:nth-child(3) {
    background: url(./img/service3.jpg) center / cover no-repeat;
}

#service ul li:nth-child(4) {
    background: url(./img/service4.jpg) center / cover no-repeat;
}

#service ul li h3 {
    font-size: 3.2rem;
    font-weight: 700;
}

#service ul li small {
    display: block;
    font-size: 1.8rem;
    font-weight: 400;
}

#service ul li:first-child h3 {
    font-size: 4rem;
}

#service ul li span {
    display: block;
    font-weight: 700;
    font-size: 1.4rem;
    line-height: 1.4;
    margin: 20px 0 30px;
}

#service ul li p {
    font-size: 1.4rem;
    line-height: 1.6;
    margin: 0 0 20px;
}

#service ul li:first-child p {
    font-size: 1.6rem;
    line-height: 2;
    margin: 0;
}

.service_l {
    width: 55%;
}

.service_r {
    width: 40%;
    align-content: end;
}

#service ul li .btn {
    color: #fff;
    background: rgba(100, 100, 100, .7);
}

#service ul li .btn:hover {
    background: #000;
}

#service ul li:first-child .btn {
    margin: 0 0 0 auto;
}

#service ul li .cs_btn,
#service ul li .cs_btn:hover {
    background: #BCBCBC;
    color: #000;
}

#service ul li .cs_btn::before {
    display: none;
}

#cases {
    padding: 80px 0;
    background: url(./img/bg_case.jpg) center / cover no-repeat;
}

.case_slide {
    margin: 60px 0;
}

#cases .slick-list {
    overflow: unset;
}

#cases ul li {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    margin: 0 .2%;
    padding: 20px 20px 30px;
}

#cases ul li a {
    color: #202020;
}

#cases a:hover {
    opacity: 1;
    color: #fff;
}

#cases ul li .flex {
    justify-content: right;
    margin: 20px 0 0;
}

#cases ul li img {
    border-radius: 12px;
    width: 100%;
    height: 20rem;
    margin: 0 auto 10px;
    object-fit: cover;
}

.case_img img {
    height: 20rem;
    border-radius: 12px;
    object-fit: cover;
}

#cases .slick-track {
    display: flex;
}

#cases .slick-slide {
    height: auto !important;
}

#cases ul li h3,
#cases ul li h2 {
    font-size: 1.8rem;
    font-weight: 500;
}

#cases .btn,
.contents .btn {
    max-width: 190px;
}

#news {
    padding: 80px 0 100px;
}

#news .btn {
    margin: 60px 0 0;
}

.news_list ul li {
    border-top: solid 1px #E3E3E3;
    padding: 20px 0;
}

.news_list ul li:last-child {
    border-bottom: solid 1px #E3E3E3;
}

.news_list ul li a {
    color: #202020;
    position: relative;
    padding: 20px 3% 20px 0;
}

.news_list ul li a::after {
    content: "";
    position: absolute;
    width: 2%;
    height: 100%;
    top: 0;
    bottom: 0;
    right: 0;
    background: url(./img/arrow.png) center / contain no-repeat;
}

.date {
    font-size: 1.4rem;
    font-weight: 500;
    font-family: "Albert Sans", sans-serif;
}

.news_r {
    width: 58%;
}

.news_list ul li .date {
    width: 15%;
}

.news_list ul li h3,
.news_list ul li h2 {
    width: 85%;
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.4;
}

#recruit {
    background: url(./img/bg_recruit.jpg) center / cover no-repeat;
    padding: 90px 0 80px;
}

#recruit .flex {
    align-items: center;
}

.recruit_box {
    padding: 50px 5% 60px;
    border-radius: 20px;
    background: rgba(999, 999, 999, .85);
}

.recruit_l {
    width: 40%;
}

.recruit_r {
    width: 55%;
}

.recruit_r h3 {
    font-size: 2.3rem;
    font-weight: 500;
    margin: 0 0 30px;
}

#recruit .btn {
    margin: 40px 0 0;
}

#contact {
    background: url(./img/bg_contact.jpg) center / cover no-repeat;
    padding: 90px 0;
    color: #fff;
    text-align: center;
}

#contact a {
    color: #fff;
}

.contact_txt {
    font-size: 2rem;
    margin: 60px 0 30px;
}

.tel {
    font-size: 3.5rem;
    font-weight: 500;
    position: relative;
    letter-spacing: 2px;
}

.tel::before {
    content: "";
    position: absolute;
    width: 24px;
    height: 100%;
    top: 0;
    bottom: 0;
    left: -15%;
    background: url(./img/tel.png) center / contain no-repeat;
}

#contact .btn {
    background: rgba(999, 999, 999, .3);
    margin: 40px auto 0;
    max-width: 190px;
}

footer {
    background: #4A4A4A;
    padding: 60px 0 80px;
    color: #fff;
}

.footer_l {
    width: 25%;
}

.footer_r {
    width: 55%;
}

.footer_l img {
    max-width: 200px;
}

.footer_l p {
    font-weight: 500;
    margin: 40px 0 10px;
    letter-spacing: 2px;

}

.footer_l small {
    display: block;
    font-size: 1.4rem;
}

footer a {
    color: #fff;
}

footer ul {
    align-items: center;
    margin: 0 0 50px;
}

footer ul li a {
    font-size: 1.4rem;
    font-weight: 600;
}

.privacy_link {
    font-size: 1.3rem;
}

.mv_low {
    background: #202020;
    color: #fff;
    text-align: center;
    padding: 60px 0 40px;
}

.mv_low p {
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 1.6;
}

.mv_low h1,
.mv_low div {
    font-size: 1.4rem;
    font-weight: 500;
}

.outdoor {
    padding: 50px 0 60px;
    color: #fff;
    text-align: center;
    background: url(./img/bg_event.jpg) center / cover no-repeat;
}

.outdoor h2 {
    font-size: 2.4rem;
    font-weight: 500;
    margin: 0 0 20px;
}

.outdoor p {
    font-weight: 500;
}

.outdoor_r {
    margin: 8% 0 0;
}

.outdoor .flex {
    align-items: flex-start;
}

.outdoor .flex div {
    padding: 50px 2% 60px;
    width: 43%;
    border-radius: 16px;
    position: relative;
    background: linear-gradient(90deg, rgba(237, 13, 24, 0.8), rgba(14, 85, 206, 0.8), rgba(78, 199, 22, 0.8));
}

.outdoor .flex div::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle, rgba(32, 32, 32, .3) 0%, rgba(32, 32, 32, 0) 100%);
}

.page {
    padding: 80px 0 100px;
}

.page_head {
    text-align: center;
}

.page_head span {
    font-size: 2.8rem;
    font-weight: 700;
    display: block;
    margin: 0 0 10px;
}

.page_head h2 {
    font-size: 1.4rem;
    font-weight: 500;
}

.page_head h3 {
    font-size: 3rem;
    font-weight: 500;
    margin: 50px 0 40px;
}

.page_head p {
    font-size: 1.8rem;
}

.feature ul {
    margin: 80px 0 0;
}

.feature ul li {
    margin: 0 0 70px;
}

.feature ul li:nth-child(even) {
    flex-direction: row-reverse;
}

.feature_l,
.feature_r {
    width: 45%;
}

.ttl_icon img {
    width: 5%;
    min-width: 25px;
    display: inline-block;
}

.recruit .ttl_icon img {
    width: 2%;
}

.feature_l h4,
.recruit_wrap h3 {
    font-weight: 500;
    font-size: 3rem;
    margin: 15px 0 25px;
}

.ttl_icon span {
    font-family: "Albert Sans", sans-serif;
    font-style: italic;
    font-size: 2rem;
    font-weight: 600;
    letter-spacing: 1px;
}

.feature_l p {
    font-weight: 500;
}

.feature_l .btn {
    margin: 30px 0 0;
}

.fadein {
    opacity: 0;
    transform: translate(0, 100px);
    transition: all 1s;
}

.fadein.active {
    opacity: 1;
    transform: translate(0, 0);
}

.fadeUp {
    animation-name: fadeUpAnime;
    animation-duration: 0.8s;
    animation-fill-mode: forwards;
    opacity: 0;
}

@keyframes fadeUpAnime {
    from {
        opacity: 0;
        transform: translateY(80px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.delay-time02 {
    animation-delay: 0.2s;
}

.delay-time04 {
    animation-delay: 0.4s;
}

.recruit .page_head {
    margin: 0 0 60px;
}

.recruit_wrap {
    margin: 0 0 70px;
}

table {
    width: 80%;
    margin: 50px auto 0;
    border-collapse: collapse;
}

th,
td {
    padding: 20px 3%;
    text-align: left;
    border-bottom: solid 1px #E3E3E3;
    border-top: solid 1px #E3E3E3;
    font-weight: 500;
    vertical-align: middle;
}

th {
    width: 20%;
}

td {
    width: 80%;
}

.sec_ttl {
    margin: 0 0 60px;
}

.sec_ttl img {
    width: 2.2%;
    min-width: 23px;
    display: inline-block;
}

.sec_ttl p {
    font-size: 2.8rem;
    font-weight: 600;
    margin: 0 .5%;
    font-family: "Albert Sans", sans-serif;
    display: inline-block;
}

.sec_ttl h2 {
    font-size: 1.4rem;
    font-weight: 500;
    display: inline-block;
}

.sec_ttl div {
    margin: 20px 0 0;
}

.company_cont {
    margin: 0 0 70px;
}

.company_cont h3 {
    font-size: 3rem;
    font-weight: 500;
    margin: 0 0 30px;
}

.company_cont p {
    font-size: 1.8rem;
    line-height: 2;
    margin: 0 0 30px;
}

.sign {
    text-align: end;
    font-weight: 600;
}

.contents_head {
    margin: 0 0 40px;
    padding: 0 0 20px;
    border-bottom: solid 1px #E3E3E3;
}

.contents_head h1 {
    font-size: 2.5rem;
    font-weight: 500;
}

.main_contents {
    margin: 0 0 70px;
}

.main_contents p {
    margin: 10px 0 20px;
}

.main_contents a {
    color: #0E55CE;
}

.main_contents img {
    margin: 20px auto;
    display: block;
}

.main_contents h2 {
    color: #fff;
    background: #202020;
    font-size: 2.2rem;
    font-weight: 500;
    padding: 1% 2%;
    margin: 20px 0 30px;
}

.main_contents h3 {
    border-left: solid 5px #202020;
    font-size: 2rem;
    font-weight: 500;
    padding: 0 1%;
    margin: 20px 0;
}

a.cat_link {
    font-size: 1.1rem;
    padding: 1% 2%;
    font-weight: 600;
    width: fit-content;
    min-width: 70px;
    text-align: center;
    border: solid 1px #202020;
}

.cat_link:hover {
    background: #202020;
    color: #fff;
    opacity: 1;
}

.case_inner .flex {
    align-items: center;
    justify-content: right;
    margin: 0 0 10px;
}

.cat_btns ul {
    align-items: center;
}

.cat_btns ul li {
    width: 18%;
}

.cat_btns ul li a {
    text-align: center;
    border: solid 1px #202020;
    color: #202020;
    font-size: 1.8rem;
    line-height: 2.8;
    display: block;
    font-weight: 500;
}

.cat_btns ul li a:hover {
    background: #202020;
    color: #fff;
    opacity: 1;
}

.cases_list {
    margin: 60px 0 0;
}

.cases_list ul li a {
    color: #202020;
}

.cases_list ul li {
    margin: 0 0 30px;
    padding: 0 0 20px;
    border-bottom: solid 1px #E3E3E3;
}

.cases_list ul li.flex {
    align-items: center;
}

.case_img {
    width: 30%;
}

.case_img img {
    display: block;
    width: 100%;
}

.case_txt {
    width: 67%;
}

.case_txt .flex {
    align-items: center;
    justify-content: unset;
    margin: 0 0 10px;
}

.cases_list a.cat_link {
    width: fit-content;
    padding: .5% 2%;
}

.cases_list ul li h2 {
    font-size: 2.2rem;
    margin: 0 0 10px;
}

.pager {
    text-align: center;
    margin: 60px 0 0;
}

.page-numbers {
    border: solid 1px #202020;
    color: #202020;
    padding: .5% 1%;
    margin: 0 .3%;
    font-weight: 500;
    font-size: 1.4rem;
}

.page-numbers.current,
.page-numbers:hover {
    color: #fff;
    background: #202020;
}

.contents_head .flex {
    justify-content: unset;
    align-items: center;
    margin: 0 0 15px;
}

.contents_head .cat_link {
    color: #202020;
    width: 10%;
    padding: .5%;
}

.contents_head .cat_link:hover {
    color: #fff;
}

.eye {
    margin: 0 0 30px;
}

.eye img {
    width: 70%;
    display: block;
    margin: 0 auto;
}

.form .wrap {
    max-width: 780px;
}

.form_area p {
    margin: 20px 0;
    font-weight: 500;
}

.form_cont {
    width: 47%;
}

.mwform-tel-field {
    display: block;
}

.must {
    font-size: 1.4rem;
    color: #fff;
    background-color: #5E5E5E;
    padding: 0 4px;
    margin-left: 5px;
    font-weight: 400;
}

.c_wrap input.wpcf7-text,
.mw_wp_form input,
.mw_wp_form select,
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 select {
    width: 100%;
    background-color: #F7F7F7;
    border: none;
    height: 50px;
    padding: 0 10px;
    margin: 10px 0 40px;
    font-size: 1.6rem;
}

.form_area textarea.wpcf7-textarea,
.mw_wp_form textarea,
.wpcf7 textarea {
    width: 100%;
    border: none;
    background-color: #F7F7F7;
    padding: 10px;
    margin: 10px 0 40px;
}

.wpcf7-checkbox input .spam1,
.mw_wp_form input[type="checkbox"] {
    width: 20px;
    height: 20px;
    vertical-align: middle;
    margin: 0;
    cursor: pointer;
}

.check {
    text-align: center;
}

.mw_wp_form input[type="submit"],
.wpcf7 input[type="submit"] {
    background: #202020;
    color: #fff;
    margin: 30px auto 0;
    max-width: 250px;
    padding: 0;
    height: 55px;
    cursor: pointer;
    border: solid 1px #202020;
    width: 100%;
}

.mw_wp_form input[type="submit"].previous {
    background: #fff;
    color: #202020;
}

.list_parent {
    margin: 0 0 100px;
}

.item_list .cat_box {
    width: 23%;
    margin: 0 0 40px;
    display: flex;
    flex-direction: column;
}

.cat_box h3 {
    font-size: 1.8rem;
    font-weight: 700;
    margin: 0 0 15px;
}

.cat_box h3 span {
    color: #fff;
    background: #202020;
    font-size: 1.4rem;
    margin-right: 2%;
    padding: 0 .6rem;
    font-weight: 500;
}

.list_child {
    padding: 20px 3% 30px;
    background: #F8F8F8;
    flex-grow: 1;
}

.list_child li {
    margin: 0 0 10px;
    position: relative;
}

.list_child li::before {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
    left: 0;
    width: .6rem;
    height: .6rem;
    border-top: 1px solid #585858;
    border-right: 1px solid #585858;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.list_child li a {
    color: #585858;
    padding: 0 0 0 6%;
}

.taxonomy_rental {
    padding: 80px 0 100px;
}

.taxonomy_list li {
    margin: 0 0 40px;
    width: 48.5%;
    align-items: center;
    background: #F8F8F8;
}

.item_img {
    width: 30%;
}

.item_img img {
    width: 100%;
    height: 15rem;
    margin: 0 auto;
    object-fit: cover;
}

.item_txt {
    width: 64%;
    padding: 0 3%;
}

.item_txt a {
    color: #585858;
}

.item_txt h3 {
    font-size: 1.6rem;
}

.item_txt p {
    margin: 5px 0;
    font-size: 1.4rem;
}

.item_txt span {
    display: block;
    margin: 0 0 0 auto;
    width: fit-content;
    font-size: 1.2rem;
    position: relative;
    padding: 0 3% 0 0;
}

.item_txt span::before {
    position: absolute;
    top: 7%;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
    right: 0;
    width: .4rem;
    height: .4rem;
    border-top: 1px solid #585858;
    border-right: 1px solid #585858;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.bread ul {
    justify-content: normal;
    margin: 10px auto;
}

.bread ul li {
    margin: 0 0 0 2%;
    position: relative;
}

.bread ul li:first-child {
    margin: 0;
}

.bread ul li::before {
    position: absolute;
    top: 20%;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
    right: -15%;
    width: .4rem;
    height: .4rem;
    border-top: 1px solid #585858;
    border-right: 1px solid #585858;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.bread ul li a {
    color: #585858;
    font-size: 1.2rem;
}

.rental_main {
    margin: 0 0 70px;
}

.rental_cont {
    width: 65%;
}

.rental_cont .caution {
    color: #F50A0A;
    font-size: 1.6rem;
    line-height: 1.6;
    margin: 10px 0;
}

.rental_cont h1 {
    font-size: 2.3rem;
    padding: 0 10px 15px;
}

.rental_ttl {
    margin: 0 0 20px;
    border-bottom: solid 1px #E3E3E3;
}

.rental_img {
    width: 30%;
}

.r_btn {
    margin: 30px auto 0;
    text-align: center;
    display: block;
    border: solid 1px #202020;
    background: #202020;
    color: #fff;
    font-size: 1.4rem;
    line-height: 3.5;
    width: 80%;
    border-radius: 30px;
    position: relative;
    font-weight: 500;
}

.r_btn::before {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
    right: 15%;
    width: .4rem;
    height: .4rem;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.r_btn:hover {
    color: #202020;
    background: #fff;
    opacity: 1;
}

.r_btn:hover::before {
    border-top: 1px solid #202020;
    border-right: 1px solid #202020;
}

.rental_img img {
    width: 100%;
}

.rental_img p {
    line-height: 1.6;
    font-size: 1.2rem;
    color: #585858;
    margin: 10px 0 0;
}

.price_sec {
    margin: 0 0 30px;
}

.price_sec p {
    font-size: 1.8rem;
    font-weight: 500;
}

.price_other {
    margin: 10px 0 0;
}

.price_other span {
    color: #fff;
    background: #4A4A4A;
    font-size: 1.4rem;
    padding: .3rem 1.5rem;
    ;
}

.imp_sec {
    padding: 35px 3% 20px;
    background: #F8F8F8;
    font-size: 1.4rem;
    font-weight: 500;
    margin: 40px 0 0;
    position: relative;
}

.imp_sec::before {
    content: "CHECK";
    background: #4A4A4A;
    color: #fff;
    left: 0;
    top: 0;
    position: absolute;
    padding: 0 2rem;
    line-height: 2;
    font-family: "Albert Sans", sans-serif;
}

.rental_cont table {
    width: 100%;
    margin: 30px auto 20px;
}

.rental_cont table td {
    width: auto;
    font-size: 1.4rem;
    padding: 10px 1%;
    border: solid 1px #E3E3E3;
}

.rental_cont table tr:first-child td {
    background: #4A4A4A;
    color: #fff;
}

.rental_img_wrap {
    position: relative;
    transition: all 0.25s ease;
    opacity: 1;
    transform: translateY(20px);
}

.rental_img_wrap.fix {
    position: fixed;
    top: 110px;
    left: 15%;
    width: 300px;
    z-index: 30;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.rental_img_wrap.fade-out {
    opacity: 0 !important;
    transform: translateY(20px) !important;
    transition: opacity 0.25s ease, transform 0.25s ease;
}

.equipment-form {
    margin: 10px 0 30px;
}

.equipment-form label {
    display: block;
    cursor: pointer;
}

.equipment-form {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.equipment-form label {
    width: 25%;
    margin: 0 0 10px;
}

.child-group {
    margin: 15px 0 0;
    background-color: #F7F7F7;
    padding: 15px 3% 5px;
    width: 100%;
}

.child-group p {
    border-bottom: solid 1px #4A4A4A;
    padding: 0 5px 5px;
    font-weight: 700;
    margin: 0 0 20px;
    font-size: 1.8rem;
    display: flex;
    align-items: center;
}

.child-group p small {
    font-size: 1.2rem;
    margin-left: 3%;
    font-weight: 400;
}

.child-group label {
    font-size: 1.4rem;
    display: flex;
    align-items: center;
    width: 100%;
}

.child-group input[type="checkbox"] {
    width: 13px;
    height: 13px;
    margin: 0 .5% 0 0;
}

.items {
    padding: 0 3% 5px;
}

.child-group input[type="text"] {
    background: #fff;
    height: 3rem;
    width: 5rem;
    margin: 5px 0 10px;
}

.child-group span {
    font-size: 1.2rem;
    margin: 0 0 0 4%;
}

.child-group .item_cat {
    font-weight: 500;
    font-size: 1.6rem;
    width: 100%;
}

#confirm-btn {
    height: 50px;
    width: 250px;
    margin: 0 auto 30px;
    display: block;
}

.wpcf7-spinner {
    display: block;
}

.submit_area {
    text-align: center;
}

@media screen and (min-width: 1920px) {
    html {
        font-size: 90%;
    }

    .wrap,
    .wrap_sec,
    .contents .wrap {
        max-width: 1680px;
    }

    .mv_slide {
        top: -80px;
    }

    .logo img {
        max-width: 240px;
    }

    .footer_l img {
        max-width: 280px;
    }

    .tel::before {
        width: 34px;
    }

    #cases .btn,
    .contents .btn {
        max-width: 220px;
    }

    .outdoor .flex div {
        padding: 50px 1% 60px;
        width: 44%;
    }
}

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

    .wrap,
    .wrap_sec,
    .contents .wrap {
        max-width: 96%;
    }

    .form .wrap {
        max-width: 780px;
    }

    #cases ul li img {
        height: 27rem;
    }

    .rental_img_wrap.fix {
        left: 2%;
        width: 28%;
    }
}

@media screen and (max-width: 1150px) {
    html {
        font-size: 50.5%;
    }

    #mv h2 {
        width: 50%;
    }

    #mv h2 .adust {
        margin: 0 0 0 10%;
    }

    #mv h2 span {
        padding: 5px 10px 10px;
        margin: 0 0 20px;
    }

    #cases ul li {
        padding: 20px 10px 30px;
    }

    header .btn {
        line-height: 2.2;
        min-width: 140px;
    }

    .form .wrap {
        max-width: 90%;
    }

    .list_parent {
        justify-content: center;
    }

    .item_list .cat_box {
        width: 30%;
        margin: 0 1% 40px;
    }
}

@media screen and (max-width: 780px) {
    .pc {
        display: none;
    }

    .sp {
        display: block;
    }

    html {
        font-size: 62.5%;
        scroll-padding-top: 65px;
    }

    header {
        height: 65px;
    }

    header .logo {
        width: 100%;
        min-width: 180px;
    }

    main {
        margin: 65px 0 0;
    }

    body {
        font-size: 1.4rem;
    }

    .wrap,
    .wrap_sec,
    .item_single .wrap {
        max-width: 75%;
    }

    .logo img {
        max-width: 150px;
    }

    .sp-menu {
        position: absolute;
        top: 65px;
        left: 0;
        width: 100%;
        height: 100vh;
        z-index: 999;
        background-color: rgba(0, 0, 0, 0.85);
        transform: scaleY(0);
        transform-origin: top;
        transition: transform 0.3s ease-in-out;
    }

    .sp-menu ul {
        margin: 30px 0 20%;
    }

    .sp-menu ul li {
        padding: 12px 3%;
        border-bottom: solid 1px #E3E3E3;
    }


    ul.sub_menu li {
        border: none;
        padding: 10px 3%;
    }

    nav a {
        font-size: 2rem;
        color: #fff;
    }

    nav a small {
        padding-left: 3%;
        font-size: 1.2rem;
    }

    .menu-btn:checked~.sp-menu {
        transform: scaleY(1);
        overflow-y: auto;
    }

    .menu-icon {
        cursor: pointer;
        position: absolute;
        top: 50%;
        right: 10px;
        height: 30px;
        width: 40px;
    }

    .navicon,
    .close-icon {
        background: #202020;
        display: block;
        height: 2px;
        width: 40px;
        position: relative;
        margin: 0 auto;
        z-index: 99999;
    }

    .menu-btn {
        display: none;
    }

    .navicon::before {
        content: "";
        display: block;
        height: 100%;
        width: 80%;
        bottom: 9px;
        position: absolute;
        background: #202020;
        transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s;
    }

    .navicon::after {
        content: "";
        display: block;
        height: 100%;
        width: 80%;
        top: 9px;
        position: absolute;
        background: #202020;
        transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s;
    }

    .menu-btn:checked~.menu-icon .navicon:before {
        transform: rotate(-45deg);
        bottom: 0;
    }

    .menu-btn:checked~.menu-icon .navicon:after {
        transform: rotate(45deg);
        top: 0;
    }

    .menu-btn:checked~.menu-icon .navicon {
        background: 0;
    }

    .menu-btn:checked~.menu-icon .close-icon:before,
    .menu-btn:checked~.menu-icon .close-icon:after {
        background: #fff;
    }

    .menu-btn:checked~.menu-icon .close-icon:before {
        transform: rotate(45deg);
    }

    .menu-btn:checked~.menu-icon .close-icon:after {
        transform: rotate(-45deg);
    }

    ul.sub_menu {
        margin: 15px 0 0;
    }

    .sub_menu li a {
        font-size: 1.6rem;
    }

    .sub_menu li a small {
        font-size: 1rem;
    }

    #mv h2 {
        width: 70%;
        font-size: 4.5rem;
    }

    .mv_icon {
        width: 100%;
        margin: 30px 0 0;
    }

    .mv_slide {
        top: 0;
        margin: 30px 0 0;
    }

    #company {
        padding: 80px 0;
    }

    .company_l,
    .news_l {
        width: 100%;
    }

    .top_ttl h2 {
        font-size: 5.2rem;
        margin: 0 0 5px;
    }

    .company_r {
        width: 100%;
        margin: 40px 0 0;
    }

    .company_r h3 {
        font-size: 3.2rem;
    }

    .company_r p {
        font-size: 1.6rem;
    }

    .company_r .btn {
        margin: 40px auto 0;
    }

    #service .top_ttl,
    #cases .top_ttl,
    #contact .top_ttl {
        width: 100%;
    }

    #service .top_ttl h2,
    #service .top_ttl p,
    #cases .top_ttl h2,
    #contact .top_ttl h2,
    #cases .top_ttl p,
    #contact .top_ttl p {
        text-align: left;
    }

    #service ul li:first-child {
        padding: 40px 3% 40px;
    }

    .service_l,
    .service_r {
        width: 100%;
    }

    #service ul li:first-child .btn {
        margin: 30px auto 0;
    }

    #service ul li:first-child h3 {
        font-size: 3.4rem;
    }

    #service ul li {
        width: 100%;
        padding: 40px 3% 40px;
        text-align: left;
    }

    #service ul li:first-child p {
        font-size: 1.4rem;
        line-height: 1.6;
    }

    #service ul li p {
        margin: 0 0 30px;
    }

    #cases ul li {
        padding: 20px 10px 30px;
    }

    #cases ul li h3,
    #cases ul li h2 {
        font-size: 1.6rem;
    }

    .news_r {
        width: 100%;
        margin: 50px 0 0;
    }

    #news .btn {
        margin: 60px auto 0;
    }

    .news_list ul li {
        padding: 10px 0;
    }

    .news_list ul li a {
        padding: 10px 5% 10px 0;
    }

    .news_list ul li .date {
        width: 100%;
    }

    .news_list ul li h3,
    .news_list ul li h2 {
        width: 100%;
        font-size: 1.4rem;
    }

    .date {
        font-size: 1.2rem;
    }

    .news_list ul li a::after {
        width: 4%;
    }

    .recruit_l {
        width: 100%;
    }

    #recruit .btn {
        margin: 40px auto 0;
    }

    .recruit_r {
        width: 100%;
        margin: 30px 0 0;
    }

    .recruit_r h3 {
        font-size: 2rem;
        margin: 0 0 10px;
        text-align: center;
    }

    #contact {
        padding: 70px 0;
    }

    .contact_txt {
        font-size: 1.8rem;
        margin: 40px 0 20px;
    }

    .tel {
        font-size: 3.2rem;
    }

    .tel::before {
        width: 18px;
        left: -11%;
    }

    .footer_l {
        width: 100%;
    }

    .footer_r {
        width: 100%;
        margin: 0 0 50px;
    }

    .footer_main {
        flex-direction: column-reverse;
    }

    footer ul li a {
        font-size: 1.3rem;
    }

    footer ul {
        margin: 0 0 20px;
    }

    .privacy_link {
        font-size: 1.2rem;
        display: block;
        text-align: center;
    }

    .footer_l img {
        max-width: 170px;
        margin: 0 auto;
    }

    .footer_l p {
        margin: 20px 0 10px;
        text-align: center;
    }

    .footer_l small {
        font-size: 1.2rem;
        text-align: center;
    }

    .mv_low p {
        font-size: 2.8rem;
    }

    .outdoor .flex div {
        padding: 40px 3%;
        width: 80%;
    }

    .outdoor_l {
        margin: 0 auto 0 0;
    }

    .outdoor_r {
        margin: 30px 0 0 auto;
    }

    .outdoor h2 {
        font-size: 1.6rem;
        margin: 0 0 10px;
    }

    .outdoor p {
        font-size: 1.2rem;
        text-align: left;
    }

    .feature {
        padding: 80px 0 50px;
    }

    .page_head h3 {
        font-size: 2.3rem;
    }

    .page_head p {
        font-size: 1.6rem;
    }

    .feature_l,
    .feature_r {
        width: 100%;
    }

    .feature_r {
        margin: 0 0 20px;
    }

    .feature_l h4 {
        font-size: 2.5rem;
        margin: 10px 0 20px;
    }

    .sec_ttl p {
        font-size: 2.4rem;
    }

    .sec_ttl h2 {
        font-size: 1.3rem;
    }

    .sec_ttl img {
        min-width: 21px;
    }

    .sec_ttl {
        margin: 0 0 40px;
    }

    .company_cont h3 {
        font-size: 2.5rem;
        margin: 0 0 20px;
    }

    .company_cont p {
        font-size: 1.4rem;
        margin: 0 0 20px;
    }

    table {
        width: 100%;
    }

    th,
    td {
        padding: 15px 2%;
    }

    th {
        width: 25%;
    }

    .recruit_wrap h3 {
        font-size: 2.5rem;
        margin: 10px 0 25px;
    }

    .contents_head h1 {
        font-size: 2.2rem;
    }

    .main_contents h2 {
        font-size: 2rem;
        padding: 2% 3%;
    }

    .main_contents h3 {
        font-size: 1.8rem;
        padding: 0 3%;
    }

    .cat_btns ul li a {
        font-size: 1.4rem;
        line-height: 2.4;
    }

    .page-numbers {
        padding: 1% 2%;
    }

    .cat_btns ul li {
        width: 48%;
        margin: 0 0 10px;
    }

    .c_wrap input.wpcf7-text,
    .wpcf7 input[type="text"],
    .wpcf7 input[type="email"],
    .wpcf7 input[type="tel"],
    .wpcf7 select,
    .form_area textarea.wpcf7-textarea {
        width: 90%;
        font-size: 1.6rem;
    }

    .feature_l .btn {
        margin: 30px auto 0;
    }

    .feature ul li,
    .feature ul li:nth-child(even) {
        flex-direction: column-reverse;
    }

    .list_parent {
        justify-content: space-between;
    }

    .item_list .cat_box {
        width: 48%;
        margin: 0 0 40px;
    }

    .taxonomy_list li {
        width: 100%;
    }

    .rental_img {
        width: 100%;
        margin: 0 0 60px;

    }

    .rental_cont {
        width: 100%;
    }

    .rental_cont table tr:first-child td {
        font-size: 1.2rem;
    }

    .bread ul li::before {
        right: -10%;
    }

    .bread ul li {
        margin: 0 0 0 5%;
    }

    .child-group input[type="text"] {
        height: 3rem;
        width: 5rem;
        margin: 0 0 30px;
    }
}

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

    .wrap,
    .wrap_sec,
    .item_single .wrap {
        max-width: 96%;
    }

    #mv h2 {
        width: 100%;
    }

    .case_img {
        width: 100%;
    }

    .case_txt {
        width: 100%;
        margin: 20px 0 0;
    }

    .cases_list ul li h2 {
        font-size: 2rem;
    }

    .eye img {
        width: 100%;
    }

    #cases ul li img,
    .case_img img {
        height: 17rem;
    }

    .list_child li a {
        padding: 0 0 0 3%;
        font-size: 1.3rem;
    }

    .item_list .cat_box {
        width: 49%;
    }

    .list_child li::before {
        left: -3%;
        width: .4rem;
        height: .4rem;
    }

    .cat_box h3 {
        font-size: 1.6rem;
        margin: 0 0 10px;
    }

    .cat_box h3 span {
        font-size: 1.2rem;
        margin-right: 1%;
        padding: 0 .5rem;
    }

    .item_txt h3 {
        font-size: 1.4rem;
    }

    .taxonomy_list li {
        margin: 0 0 25px;
    }

    .item_txt p {
        margin: 5px 0 10px;
        font-size: 1.4rem;
        line-height: 1.4;
    }

    .item_txt {
        width: 65%;
        padding: 0 2%;
    }

    .item_img img {
        height: 13rem;
    }

    .item_single {
        padding: 40px 0 90px;
    }

    .item_single .wp-block-table {
        overflow-x: scroll;
    }

    .item_single .wp-block-table table {
        min-width: 560px;
    }

    .rental_cont h1 {
        font-size: 2rem;
        padding: 0 5px 10px;
    }

    .item_txt span {
        padding: 0 5% 0 0;
    }

    .price_other span {
        font-size: 1.2rem;
    }

    .form_cont {
        width: 100%;
    }

    .equipment-form label {
        width: 45%;
    }

    .child-group p {
        font-size: 1.8rem;
        margin: 5px 0 25px;
        display: block;
    }

    .child-group p small {
        display: block;
        margin: 0;
    }

    .child-group input[type="checkbox"] {
        width: 13px;
        height: 13px;
        margin: 0 2% 0 0;
    }

    .child-group label {
        width: 100%;
    }
}

header h1,
header a.logo {
	font-weight:700;
	    color: #000;
    font-size: 2.7rem;
}