@charset "UTF-8";
/*
Theme Name: CAT
Author: 株式会社ステップワン
Author URI: https://www.step1.cc/
Version: 1.1
*/

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

*, *::before, *::after {
-webkit-box-sizing: border-box;
box-sizing: border-box;
}

html {
font-size: 62.5%;
width: 100%;
}

body {
font-family: 'Noto Sans JP', sans-serif;
color: #000;
font-size: 1.6rem;
font-weight: 400;
line-height: 1.7;
-webkit-text-size-adjust: 100%;
text-size-adjust: 100%; /* スマホでの文字拡大を防止 */
width: 100%;
margin: 0;
padding: 0;
background-color: #fff;
overflow-x: hidden;
}

img{
max-width: 100%;
height: auto;
vertical-align: top;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
display:block;
}

ul, ol {
list-style: none;
}

table {
border-collapse: collapse;
border-spacing: 0;
}

blockquote, q {
quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content:'';
content:none;
}

a {
vertical-align:baseline;
text-decoration: none;
color: #1558d6;
}
a:hover{
color: #660099;
}

ins {
background-color:#ff9;
color:#000;
text-decoration:none;
}

/* IE用の游ゴシック適応の設定 */
_:lang(x)::-ms-backdrop, .selector {
font-family: "Segoe UI", Meiryo, sans-serif;
}

/*******************************
共通
********************************/
.pc{display: block;}
.sp{display: none;}

/*******************************
フォント装飾
********************************/


/*******************************
ヘッダー
********************************/
#header{width: 100%; height: 60px; position: fixed; top: 0; left: 0; z-index: 99;}
.header__inner{width: 100%; display: flex; justify-content: space-between; align-items: center; padding-left: 3%;}
.header__logo{max-width: 150px; width: 20%; max-height: 64px;}
.header__logo img{max-width: 150px; max-height: 64px; display: block; margin: auto;}
.header__logo__text{width: 30%; font-size: 1.4rem; font-weight: bold;}
.header__logo__text h1{font-size: 1.4rem !important;}
.header__logo__text a{color: var(--main-color);}
.header__logo__text a:hover{color: var(--hover-color);}
.header__menu{width: 90%; display: flex; justify-content: flex-end; align-items: center;}
.header__menu-list{display: flex; justify-content: flex-end; font-size: 1.4rem;}
.header__menu-list > li {padding: 10px; position: relative;}
.header__menu-list li a{color: #000; display: inline-block; width: 100%; padding: 10px; position: relative;}
.header__menu-list li a:hover{text-decoration: none;}
.header__menu-list li > ul{position: absolute; left: -52px; top: 60px; width: 200px; opacity: .3; transform: translateY(-300px); transition: .3s; z-index: -1;}
.header__menu-list > li:hover > ul{opacity: 1; transform: translateY(0);}
.header__menu-list li > ul > li{text-align: center;}
.header__menu-list li > ul > li:last-child{border: none;}
.header__menu-list li > ul > li a{background-color: var(--header-bg-color); display: inline-block; width: 100%; padding: 10px; border-bottom: 1px solid #eee;}

.header__cv{text-align: center; width: 16%; max-width: 220px; min-width: 200px; margin-left: 20px;}
.header__cv a{display: inline-block; background-color: var(--main-color); width: 100%; padding: 2rem; color: #fff; font-size: 1.4rem; transition: .3s;}
.header__cv a:hover{background-color: var(--hover-color); text-decoration: none;}

/*******************************
ヒーロー
********************************/
.hero__inner{padding-left: 2%; position: relative;}
.hero__img{width: 100%;}
.hero__img img{width: 100%; height: 897px; object-fit: cover; object-position: 50% 0;}
.hero__cover{position: absolute; top: 0; right: 0; width: 98%; height: 100%; background-color: #000; opacity: 0;}
.hero__content{position: absolute; left: 10%; bottom: 20%;}
.hero__main-text{font-size: 8rem; font-weight: bold; letter-spacing: 0.6px;}

/*******************************
SEC01
********************************/
.sec01__inner{padding: 50px 0;}
.sec01__main{position: relative;}
.sec01__img{width: 100%; max-width: 960px;}
.sec01__img img{width: 100%; height: 483px; object-fit: cover;}
.sec01__content{position: absolute; left: 40%; bottom: -16%; background-color: #fff; max-width: 825px; padding: 60px 90px;}
.sec01__content p{line-height: 2;}
.sec01__title{margin-bottom: 30px;}
.sec01__title h2{font-size: 3rem; margin-bottom: 8px;}
.sec01__title .sub-title{display: block; margin: 0; padding: 0; line-height: 0; font-weight: bold; letter-spacing: 1px;}

/*******************************
SEC02
********************************/
#sec02{background-color: #fbfbfb;} /*#0a338a*/
.sec02__inner{max-width: 1220px; margin: 0 auto; padding: 150px 0 100px; display: flex; flex-direction: row-reverse; justify-content: space-between;}
.sec02__img{width: 580px; height: 700px; margin-left: -100px;}
.sec02__img img{width: 580px; height: 100%; object-fit: cover;}
.sec02__content{width: 780px; position: relative;}
.sec02__title{margin-bottom: 50px;}
.sec02__title h2{font-size: 3rem; margin-bottom: 8px;}
.sec02__title .sub-title{display: block; margin: 0; padding: 0; line-height: 0; font-weight: bold; letter-spacing: 1px;}
.sec02__box{display: flex; background-color: #fff; margin: 20px 0; padding: 50px 20px;}
.sec02__box-number{font-size: 2rem; font-family: Lora, serif; color: var(--main-color); position: relative; width: 120px; margin: auto; text-align: center;}
.sec02__box-number:before{position: absolute; top: -22px; left: 18px; content: ""; width: 80px; height: 80px; border: 1px solid var(--main-color); border-radius: 50%;}
.sec02__box-text{width: 85%;}
.sec02__box-text p{line-height: 2;}
.sec02__box-title{color: var(--main-color); font-weight: bold; font-size: 1.2em; margin-bottom: 10px;}
.sec02__link{margin: 50px 0;text-align: right;}
.sec02__link a{padding: 0 25px 5px 10px; color: #000; position: relative; transition: .3s;}
.sec02__link a:before{font-family: Lora, serif; content: ">"; color: var(--main-color); position: absolute; top: -1px; right: 0;}
.sec02__link a:after{content: ""; border: 1px solid var(--main-color); position: absolute; top: -1px; right: -9px; width: 28px; height: 28px; border-radius: 50%;}
.sec02__link a:hover{text-decoration: none; color: #888; transition: .3s;}
.sec02__link a:hover:before{color: var(--hover-color);}
.sec02__link a:hover:after{border: 1px solid var(--hover-color);}

/*******************************
SEC03
********************************/
.sec03__inner{max-width: 1220px; margin: 0 auto; padding: 100px 0;}
.sec03__title-flex{display: flex; justify-content: space-between; align-items: center;}
.sec03__title{margin-bottom: 50px; width: 50%;}
.sec03__title h2{font-size: 3rem; margin-bottom: 8px;}
.sec03__title .sub-title{display: block; margin: 0; padding: 0; line-height: 0; font-weight: bold; letter-spacing: 1px;}
.sec03__link{width: 50%; text-align: right;}
.sec03__link a{padding: 0 25px 5px 10px; color: #000; position: relative; transition: .3s;}
.sec03__link a:before{font-family: Lora, serif; content: ">"; color: var(--main-color); position: absolute; top: -1px; right: 0;}
.sec03__link a:after{content: ""; border: 1px solid var(--main-color); position: absolute; top: -1px; right: -9px; width: 28px; height: 28px; border-radius: 50%;}
.sec03__link a:hover{text-decoration: none; color: #888; transition: .3s;}
.sec03__link a:hover:before{color: var(--hover-color);}
.sec03__link a:hover:after{border: 1px solid var(--hover-color);}
.sec03__inner ul{max-width: 1000px; margin: 0 auto;}
.sec03__inner ul li{border-bottom: 1px solid #e6e6e6; padding: 20px 0; display: flex; position: relative; color: #000; transition: .3s;}
.sec03__inner ul li:hover{background-color: #fafafa;}
.sec03__inner ul li:hover > a{position: absolute; left: 0; top: 0; width: 100%;height: 100%}
.sec03__inner ul li a:hover{text-decoration: none;}
.sec03__news-catname{width: 16%; text-align: center; margin-top: -.2rem; position: relative; z-index: 2;}
.sec03__news-catname a{color: var(--main-color); border: 1px solid var(--main-color); border-radius: 25px; display: inline-block; font-size: 1rem; width: 120px; padding: .5rem;}
.sec03__news-catname a:hover{color: var(--hover-color); border: 1px solid var(--hover-color);}
.sec03__news-data{width: 10%; min-width: 95px; margin-left: 10px; padding-top: 2px; font-size: 1.4rem;}
.sec03__news-title{width: 72%; margin-left: 5px;}

/*******************************
SEC04
********************************/
#sec04{background-color: #fbfbfb;}
.sec04__inner{max-width: 1220px; margin: 0 auto; padding: 100px 0;}
.sec04__title{margin-bottom: 50px; width: 50%;}
.sec04__title h2{font-size: 3rem; margin-bottom: 8px;}
.sec04__title .sub-title{display: block; margin: 0; padding: 0; line-height: 0; font-weight: bold; letter-spacing: 1px;}
.sec04__flex{display: flex; justify-content: space-between;}
.sec04__box{width: 50%; max-width: 562px; position: relative;}
.sec04__box img{width: 100%; height: 300px; object-fit: cover;}
.sec04__box-link{position: absolute; left: 0; bottom: 0; z-index: 1; background-color: #fff; width: 100%; height: 20%; text-align: right; padding: 15px 30px;}
.sec04__box-link .link-name{padding: 0 25px 5px 10px; color: #000; position: relative; transition: .3s;}
.sec04__box-link .link-name:before{font-family: Lora, serif; content: ">"; color: var(--main-color); position: absolute; top: -1px; right: 0;}
.sec04__box-link .link-name:after{content: ""; border: 1px solid var(--main-color); position: absolute; top: -1px; right: -9px; width: 28px; height: 28px; border-radius: 50%;}
.sec04__box-link .link-name:hover{text-decoration: none; color: #888; transition: .3s;}
.sec04__box-link .link-name:hover:before{color: var(--hover-color);}
.sec04__box-link .link-name:hover:after{border: 1px solid var(--hover-color);}
.sec04__box a{position: absolute; left: 0; top: 0; width: 100%; height: 100%; z-index: 2; transition: .3s;}
.sec04__box a:hover{background-color: var(--main-color);}
.sec04__box a:hover:before{content: "VIEW MORE →"; font-size: 2rem; font-weight: bold; letter-spacing: .6px; color: #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);}

/*******************************
SEC05
********************************/
.sec05__inner{max-width: 1220px; margin: 0 auto; padding: 100px 0;}
.sec05__title-flex{display: flex; justify-content: space-between; align-items: center;}
.sec05__title{margin-bottom: 50px; width: 50%;}
.sec05__title h2{font-size: 3rem; margin-bottom: 8px;}
.sec05__title .sub-title{display: block; margin: 0; padding: 0; line-height: 0; font-weight: bold; letter-spacing: 1px;}
.sec05__link{width: 50%; text-align: right;}
.sec05__link a{padding: 0 25px 5px 10px; color: #000; position: relative; transition: .3s;}
.sec05__link a:before{font-family: Lora, serif; content: ">"; color: var(--main-color); position: absolute; top: -1px; right: 0;}
.sec05__link a:after{content: ""; border: 1px solid var(--main-color); position: absolute; top: -1px; right: -9px; width: 28px; height: 28px; border-radius: 50%;}
.sec05__link a:hover{text-decoration: none; color: #888; transition: .3s;}
.sec05__link a:hover:before{color: var(--hover-color);}
.sec05__link a:hover:after{border: 1px solid var(--hover-color);}
.sec05__box{width: 30%; margin-right: 20px; position: relative;}
.sec05__box-img{width: 100%;}
.sec05__box-img img{width: 100%; height: 200px; object-fit: cover;}
.sec05__box-data{font-size: 1.2rem; font-weight: bold; color: #9b9b9b; margin: 5px 0;}
.sec05__box-title{font-weight: bold;}
.sec05__box a{position: absolute; width: 100%; height: 100%; top: 0; left: 0; z-index: 2; transition: .3s;}
.sec05__box a:before{content: "VIEW MORE →"; font-size: 2rem; font-weight: bold; letter-spacing: .6px; color: #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); opacity: 0; transition: 0.3s;}
.sec05__box a:hover{background-color: var(--main-color);}
.sec05__box a:hover:before{opacity: 1; transition-delay: 0.4s;}
.cat-slick.slick-prev:before,
.cat-slick.slick-next:before{color: var(--main-color);}

/*******************************
SEC06
********************************/
.sec06__img{width: 98%; height: 390px; position: relative;}
.sec06__img img{width: 100%; height: 390px; object-fit: cover;}
.sec06__img-cover{position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: #000; opacity: .4;}
.sec06__inner{max-width: 1220px; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); color: #fff;}
.sec06__title{margin-bottom: 30px;}
.sec06__title h2{font-size: 3rem; margin-bottom: 8px;}
.sec06__title .sub-title{display: block; margin: 0; padding: 0; line-height: 1; font-weight: bold; letter-spacing: 1px;}
.sec06__btn-posi{margin-top: 20px;}
.sec06__btn{display: inline-block; border: 1px solid #fff; text-align: center; padding: 1rem 5rem; color: #fff; font-size: 1.4rem; transition: .3s;}
.sec06__btn:hover{background-color: #fff; color: #000; text-decoration: none;}

/*******************************
FOOTER
********************************/
.footer__inner{max-width: 1220px; margin: 0 auto; padding: 70px 0;}
#footer__nav ul{display: flex; justify-content: center; font-size: 1.4rem;}
#footer__nav ul li{padding: 0 1%;}
#footer__nav ul li a{color: #000;}
.footer__logo,.footer__logo__text{text-align: center; margin-top: 10px;}
.footer__logo img{max-width: 150px;}
.footer__logo__text{font-size: 1.8rem; font-weight: bold;}
.footer__logo__text a{color: #000;}
.footer__cp{background-color: var(--main-color); text-align: center; font-size: 1.2rem; font-weight: bold; color: #fff; padding: 1rem;}

/*******************************
パンくずリスト
********************************/
#breadcrumbs{background-color: #fbfbfb;}
.breadcrumbs__inner{width: 100%; max-width: 1240px; margin: 0 auto; padding: 10px 1%; font-size: 1.4rem; color: #000;}
.breadcrumbs__inner a{color: #000;}
.breadcrumbs__inner ul{display: flex;}
.breadcrumbs__inner ul li{margin-right: 20px;}
.breadcrumbs__inner ul li:after{content: ">"; position: relative; right: -10px;}
.breadcrumbs__inner ul li:last-child:after{display: none;}

/*******************************
固定ページ
********************************/
.page__inner{max-width: 1240px; margin: 0 auto; padding: 70px 1%;}
.page__inner p{margin-bottom: 2em;}
.page__inner h1{text-align: center;}
.page__inner h2{border-left: 5px solid var(--main-color); padding: 5px 20px; margin: 50px 0 20px; font-size: 2.2rem; line-height: 1.4;}
.page__inner h3{border-left: 2px dotted var(--main-color); padding: 5px 20px 5px 25px; margin: 20px 0; font-size: 1.8rem;}
.page__inner h4{border-left: 2px dotted var(--main-color); padding: 1px 20px 1px 26px; margin: 20px 0; font-size: 1.6rem;}
.page__inner h5{color: var(--main-color); padding: 1px 20px 1px 28px; margin: 20px 0;}
.page__inner ul{list-style: disc;}
.page__inner ol{list-style: decimal;}
.page__inner ul,.page__inner ol{margin-left: 20px;}
.page__inner li{margin-bottom: 10px;}
.page__inner ul + p,.page__inner ol + p{margin-top: 2em;}

.page__info{margin-bottom: 40px;}
.page__date{text-align: right; font-size: 1.2rem;}
.page__thum{text-align: center; width: 100%; margin: 40px 0 0;}

.page__hero{width: 100%; position: relative;}
.page__hero-img{width: 100%;}
.page__hero-img img{width: 100%; height: 500px; object-fit: cover;}
.page__hero-cover{position: absolute; top: 0; right: 0; width: 100%; height: 100%; background-color: #000; opacity: 0;}
.page__hero-content{position: absolute; left: 18.5%; top: 30%; width: 100vw; max-width: 1240px;}
.page__hero-content h1{font-size: 4rem;}
.page__hero-subcontent{margin-top: -5px;}

.page__hero-content.middle{width: auto; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center;}

/*******************************
SERVICE（固定ページ）
********************************/
.service__first-title h2{border: none; text-align: center;}
.service__first-text{text-align: center;}
.service__sec02,.service__sec04,.service__sec05{background-color: #fbfbfb;}
.service__sec04,.service__sec05{margin-top: 50px;}
.service__inner{max-width: 1240px; margin: 0 auto; padding: 100px 1%;}
.service__inner p{margin-bottom: 2em;}
.service__inner h2{margin-bottom: 25px; border-left: none; color: var(--main-color);}
.service__flex{display: flex; justify-content: space-between; margin-top: 50px;}
.service__box.half{width: calc(50% - 10px);}
.service__box-img{width: 100%; height: 315px; margin-bottom: 20px;}
.service__box-img img{width: 100%; height: 315px; object-fit: cover;}
.service__box-title h3{margin-bottom: 5px; font-size: 1.92rem;}
.service__sec03{margin-bottom: 100px;}
.service__sec03 h2{color: #000; text-align: right;}
.service__sec03 .service__inner{padding-bottom: 50px;}
.service__box.one-third{width: calc(100% / 3 - 10px);}
.service__sec03 .service__box{position: relative; text-align: center; font-weight: bold;}
.service__sec03 .service__box:first-child .service__box-img{border-left: 1px solid var(--main-color);}
.service__sec03 .service__box:nth-child(2) .service__box-img{border-left: 1px solid var(--main-color); border-right: 1px solid var(--main-color);}
.service__sec03 .service__box:last-child .service__box-img{border-right: 1px solid var(--main-color);}
.service__sec03 .service__box-img{height: 400px; padding-top: 50px;}
.service__box-en{width: 100%; position: absolute; top: 0; text-align: center; font-size: min(4vw,6rem); color: var(--main-color); opacity: .2; z-index: -1;}
.service__sec03-last{max-width: 1600px; width: 100%; height: 550px; margin: 0 auto;}
.service__sec03-last img{width: 100%; height: 550px; object-fit: cover;}

/*******************************
MESSAGE（固定ページ）
********************************/
.message__flex{display: flex; align-items: center;}
.message__content{width: 50%;}
.message__title{font-size: 3.2rem; font-weight: bold; margin-bottom: 20px;}
.message__name{text-align: right; font-family: "游明朝体", "Yu Mincho", YuMincho, 'Noto Serif JP', serif; font-weight: bold;}
.message_position{display: block; font-size: 1.2rem;}
.message__img{width: 50%; text-align: center;}
.message__img img{width: 560px; object-fit: cover;}

/*******************************
COMPANY（固定ページ）
********************************/
.company-profile{margin-bottom: 50px;}
.company-profile h2{text-align: center; border: none; font-size: 32px;}
.company-profile__table{width: 96%; max-width: 756px; margin: 0 auto;}
.company-profile__table tr{border-top: 1px solid #d5d5d5; border-bottom: 1px solid #d5d5d5;}
.company-profile__table th{background-color: #fbfbfb; font-weight: 400; padding: 20px; text-align: left;}
.company-profile__table td{padding: 20px;}
.company-story{background-color: #fbfbfb; padding: 50px 0;}
.company-story h2{text-align: center; border: none; font-size: 32px;}
.company-story__inner{width: 96%; max-width: 756px; margin: 30px auto 0;}
.company-story__inner p{margin-bottom: 1em;}
.company-access{padding-bottom: 50px;}
.company-access h2{text-align: center; border: none; font-size: 32px;}
.company-map iframe{width: 100%; height: 500px;}

/*******************************
個別ページ
********************************/
.my-single{padding: 100px 0;}
.single .breadcrumbs{padding: 0;}
.single__content{padding: 0 1%; display: flex; justify-content: center;}
.single__inner{padding: 20px 50px 20px 0; max-width: 880px; width: 75%; min-height: 500px;}
.single__inner p{margin-bottom: 2em;}
.single__inner h2{border-left: 5px solid var(--main-color); padding: 5px 20px; margin: 50px 0 20px; font-size: 2.2rem; line-height: 1.4;}
.single__inner h3{border-left: 2px dotted var(--main-color); padding: 5px 20px 5px 25px; margin: 20px 0; font-size: 1.8rem;}
.single__inner h4{border-left: 2px dotted var(--main-color); padding: 1px 20px 1px 26px; margin: 20px 0; font-size: 1.6rem;}
.single__inner h5{color: var(--main-color); padding: 1px 20px 1px 28px; margin: 20px 0;}
.single__inner ul{list-style-type: disc; margin: 20px;}
.single__inner ol{list-style-type: decimal; margin: 20px;}
.single__inner table th{background-color: #fafafa; border: 1px solid #c7c7c7; padding: 15px;}
.single__inner table td{border: 1px solid #c7c7c7; padding: 15px;}
.single__inner .wp-block-table{margin: 2em 0;}
.wp-block-quote{background-color: #fafafa; padding: 40px;}
.wp-block-quote cite{display: block; font-size: 1.2rem; text-align: right;}

.single__date{font-size: 1.2rem;}
.single__thum{margin: 20px 0; text-align: center;}
.single__sidebar{padding: 40px 20px; margin-left: 1%; max-width: 310px; width: 25%;}
.single__sidebar h2{font-size: 1.8rem; line-height: 1.4;}
.single__sidebar ul{list-style-type: none; padding: 0; font-size: 1.4rem;}
.single__sidebar ul > li{border-bottom: 1px solid #ddd; padding: 10px 0;}
.single__sidebar ul > li a{display: block; color: #333;}
.single__sidebar ul > li a:hover{color: #cfcfcf;}
.single__sidebar .widget-title{border-bottom: 2px solid $main-color; padding-bottom: 5px;}
.single__sidebar .widget,.widget_block{margin-bottom: 40px;}
.single__sidebar .form404 input{width: 75%; font-size: 1.2rem;}
.single__sidebar .form404 button{width: 25%; font-size: 1.1rem;}

/*******************************
カテゴリーページ
********************************/
.cate{padding: 100px 0;}
.cate .breadcrumbs{padding: 0;}
.cate__content{padding: 0 1%; display: flex; justify-content: center;}
.cate__inner{padding: 20px 50px 20px 0; max-width: 880px; width: 75%; min-height: 500px;}
.cate__inner h1{font-size: 3rem;}
.cate__inner .no-contents{text-align: center;}
.cate__box{width: 100%; min-height: 220px; padding: 20px 0; display: flex; position: relative; transition: .3s;}
.cate__box:hover{background-color: #fafafa;}
.cate__box:hover > a{position: absolute; left: 0; top: 0; width: 100%;height: 100%}
.cate__thum{width: 40%;}
.cate__box-content{width: 60%; padding-left: 15px;}
.cate__title h2{font-size: 2.2rem; line-height: 1.4;}
.cate__name{font-size: 1.4rem; margin-right: 15px; display: inline; position: relative; z-index: 2;}
.cate__name a{color: #333;}
.cate__date{font-size: 1.4rem; display: inline;}
.cate__text{margin-top: 10px;}
.cate__sidebar{padding: 40px 20px; margin-left: 1%; max-width: 310px; width: 25%;}
.cate__sidebar h2{font-size: 1.8rem; line-height: 1.4;}
.cate__sidebar ul{list-style-type: none; padding: 0; font-size: 1.4rem;}
.cate__sidebar ul > li{border-bottom: 1px solid #ddd; padding: 10px 0;}
.cate__sidebar ul > li a{color: #333;}
.cate__sidebar ul > li a:hover{color: #cfcfcf; text-decoration: none;}
.cate__sidebar .widget-title{border-bottom: 2px solid $main-color; padding-bottom: 5px;}
.cate__sidebar .widget,.widget_block{margin-bottom: 40px;}

/*******************************
お知らせ一覧ページ
********************************/
.cate__inner.news{padding: 20px 0; max-width: 1000px; width: 100%; min-height: 500px;}
.cate__inner.news h1{margin: 50px 0; text-align: center;}
.cate__inner.news .cate__box{min-height: auto; border-bottom: 1px solid #e6e6e6; align-items: flex-start;}
.cate__inner.news .cate__name{border: 1px solid var(--main-color); border-radius: 25px; display: inline-block; width: 120px; min-width: 120px; padding: .5rem; font-size: 1rem; text-align: center;}
.cate__inner.news .cate__name a{color: var(--main-color);}
.cate__inner.news .cate__name:hover{color: var(--hover-color); border: 1px solid var(--hover-color);}
.cate__inner.news .cate__date{padding-top: 3px; margin-right: 15px;}
.cate__inner.news .cate__title h2{padding-top: 3px; font-size: 1.6rem; font-weight: 400;}

/*******************************
ページネーション
********************************/
.pagination{margin-top:40px;}
.nav-links{display:flex; justify-content: center;}
.pagination .page-numbers{background-color:#fff; display:inline-block; border: 1px solid var(--main-color); margin-right: 5px; padding: 5px 10px; color: var(--main-color); font-size: 1.2rem; transition: .3s;}
.pagination .page-numbers:hover{background-color: var(--main-color); text-decoration: none; color: #fff;}
.pagination .current{background-color: var(--main-color); padding: 5px 10px; color:#fff;}
.pagination .prev,
.pagination .next{background:transparent; box-shadow:none;}

/*******************************
Contact Form 7
********************************/
.wpcf7-form{background-color: #fafafa; max-width: 1000px; margin: 0 auto; padding: 5%;}
.wpcf7-form input[type="text"],.wpcf7-form input[type="tel"],.wpcf7-form input[type="email"],.wpcf7-form input[type="number"],.wpcf7-form input[type="url"]{width: 100%; height: 40px; margin-top: 5px; padding: 16px 10px 15px; border: 1px solid #ccc; font-size: 1.4rem;}
.wpcf7-form ::placeholder{opacity: .6;}
.wpcf7-form select,.wpcf7-form input[type="date"]{width: 30%; height: 40px; border: 1px solid #ccc; font-size: 1.4rem; font-family: 'Noto Sans JP', sans-serif;}
.cat-cf7-dropdown,.cat-cf7-checkbox,.cat-cf7-radiobtn{margin-bottom: 5px;}
.wpcf7-form textarea{width: 100%; margin-top: 5px; padding: 16px 10px 15px; border: 1px solid #ccc; font-family: 'Noto Sans JP', sans-serif;}
.wpcf7-form input[type="submit"]{display: block; background-color: var(--main-color); width: 80%; margin: 0 auto; padding: 16px; border: none; font-size: 1.6rem; color: #fff; font-family: 'Noto Sans JP', sans-serif; cursor: pointer; transition: .3s;}
.wpcf7-form input[type="submit"]:hover{background-color: var(--hover-color);}

/*******************************
404
********************************/
.form404{display: flex; width: 100%; max-width: 500px; margin: 40px auto 0;}
.form404 input{width: 80%; height: 40px; padding: 16px 10px 15px; border: 1px solid #ccc; font-size: 1.4rem;}
.form404 button{width: 20%; background-color: var(--main-color); border: none; color: #fff; font-family: 'Noto Sans JP', sans-serif; cursor: pointer; transition: .3s; font-size: 1rem;}
.form404 button:hover{background-color: var(--hover-color);}

/*******************************
ハンバーガーメニュー
********************************/
#navHam nav{display: block; position: fixed; top: 0; left: -300px; bottom: 0; width: 300px; background: #fff; overflow-x: hidden; overflow-y: auto; -webkit-overflow-scrolling: touch; transition: all .5s;
 z-index: 3; opacity: 0;}
#navHam.open nav{left: 0; opacity: 1;}
#navHam nav .inner{padding: 25px 0;}
#navHam nav .inner ul{list-style: none; margin: 0; padding: 0;}
#navHam nav .inner ul li{position: relative; margin: 0; padding: 0; border-bottom: 1px solid #ccc;}
#navHam nav .inner ul li a{display: inline-block; background-color: var(--header-bg-color); font-size: 1.4rem; padding: 10px 25px; text-decoration: none; transition-duration: 0.2s;}
#navHam nav .inner ul li a:hover{background: #e4e4e4;}
#navHam nav .inner ul li ul{border-top: 1px solid #ccc;}
#navHam nav .inner ul li ul li{padding-left: 30px; position: relative;}
#navHam nav .inner ul li ul li:before{content: ""; width: 12px; height: 0.2px; background-color: #333; position: absolute; top: 50%; left: 35px; transform: translateY(-50%); z-index: 2;}
#navHam nav .inner ul li ul li:last-child{border-bottom: none;}
#navHam .header__menu-list{display: block;}
@media screen and (max-width: 767px) {
  #navHam nav {left: -220px; width: 220px;}
}
/*== .toggle_btn ==*/
.toggle_btn{display: block; position: relative; top: 0; right: 20px; width: 30px; height: 30px; transition: all .5s; cursor: pointer; z-index: 3;}
.toggle_btn span{display: block; position: absolute; left: 0; width: 30px; height: 2px; background-color: #333;border-radius: 4px; transition: all .5s;}
.toggle_btn span:nth-child(1){top: 4px;}
.toggle_btn span:nth-child(2){top: 14px;}
.toggle_btn span:nth-child(3){bottom: 4px;}
.open .toggle_btn span{background-color: #fff;}
.open .toggle_btn span:nth-child(1){-webkit-transform: translateY(10px) rotate(-315deg); transform: translateY(10px) rotate(-315deg);}
.open .toggle_btn span:nth-child(2){opacity: 0;}
.open .toggle_btn span:nth-child(3) {-webkit-transform: translateY(-10px) rotate(315deg); transform: translateY(-10px) rotate(315deg);}
/*== #mask ==*/
#mask{display: none; transition: all .5s;}
.open #mask{display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #000; opacity: .8; z-index: 2; cursor: pointer;}

/*******************************
レスポンシブ
********************************/
@media screen and (max-width: 1280px) {
	.page__hero-content{left: 5%;}
	.breadcrumbs__inner,.sec02__inner,.sec03__inner,.sec04__inner,.sec05__inner,.page__inner,.service__inner,.company-story__inner,.cate__inner.news{padding-left: 5%; padding-right: 5%;}
}
@media screen and (max-width: 1024px) {
	.hero__content{left: 6%;}
	.service__box-img img{height: 270px;}
}
@media screen and (max-width: 896px) {
    .pc{display: none;}
    .sp{display: block;}
	.header__inner{height: 64px;}
	.header__logo__text{width: 70%;}
	.header__cv{width: 100%; max-width: 100%; min-width: auto; margin-left: 0;}
	.header__menu-list li > ul{position: relative; top: 0; left: 0; width: 100%; border-top: 1px solid #000; opacity: 1; transform: translateY(0); z-index: 0;}
	.header__menu-list li > ul > li{padding-left: 14px; text-align: left;}
	.header__menu-list li > ul > li a{border-bottom: none;}
	
	.hero__img img{height: 812px;}
    .hero__main-text{font-size: 6rem; line-height: 1; margin-bottom: 20px;}
	.sec01__inner{padding-bottom: 0;}
    .sec01__img img{height: 360px;}
    .sec01__content{position: relative; top: -50px; left: 0; bottom: 0; width: 90%; margin: 0 auto; padding: 50px;}
    .sec01__title h2,.sec02__content h2,.sec03__title h2,.sec04__title h2,.sec05__title h2,.sec06__title h2{font-size: 2.4rem;}
    .sec01__title .sub-title,.sec02__title .sub-title,.sec03__title .sub-title,.sec04__title .sub-title,.sec05__title .sub-title,.sec06__title .sub-title{font-size: 1.4rem;}
    .sec02__inner{flex-direction: column-reverse; padding-top: 100px; padding-bottom: 0;}
    .sec02__title{margin-bottom: 40px;}
    .sec02__box{flex-direction: column;}
    .sec02__box-number:before{left: 20px;}
    .sec02__box-text{width: 100%; margin-top: 50px;}
    .sec02__content{width: 100%;}
    .sec02__img{width: 40%; height: auto; margin: 0; position: relative; top: -160px; left: -20px; z-index: 2;}
    .sec02__img img{object-fit: contain;}
	.sec03__inner ul li{flex-wrap: wrap;}
	.sec03__news-catname{width: 120px; margin-bottom: 10px;}
	.sec03__news-title{width: 100%;}
	.sec04__flex{flex-direction: column;}
	.sec04__box{width: 100%; margin-bottom: 20px;}
	.sec06__inner{width: 60%; left: 50%; transform: translate(-50%, -50%); padding: 0;}
	#footer__nav ul{flex-wrap: wrap; margin-bottom: 20px; padding-left: 5%; padding-right: 5%;}
	#footer__nav ul li{width: calc(100% / 3); margin-bottom: 10px;}
	#footer__nav ul li a{display: block;}
	
	.page__hero-img img{height: 427px;}
	.service__inner{padding-top: 70px; padding-bottom: 40px;}
	.service__flex{flex-direction: column;}
	.service__box{margin-bottom: 30px;}
	.service__box.half,.service__box.one-third{width: 100%;}
	.service__box-img{height: 270px;}
	.service__sec03 h2{line-height: 1.4;}
	.service__sec03 .service__box:first-child .service__box-img,
	.service__sec03 .service__box:nth-child(2) .service__box-img,
	.service__sec03 .service__box:last-child .service__box-img{border: none;}
	.service__sec03 .service__box:nth-child(2){border-top: 1px solid #0A338A; border-bottom: 1px solid #0A338A; padding-bottom: 30px; margin-bottom: 0;}
	.service__sec03 .service__box-img{height: 420px; margin-bottom: 80px;}
	.service__sec03 .service__box-img img{height: 420px;}
	.service__box-en{font-size: min(15vw,6rem)}
	.service__box-title{font-size: 1.8rem;}
	.service__sec03-last,.service__sec03-last img{height: 390px;}
	
	.message__flex{flex-direction: column;}
	.message__content{width: 100%; margin-bottom: 50px;}
	.message__img{width: 100%;}
	
	.single__content{flex-direction: column;}
	.single__inner{width: 100%; padding: 25px 5%;}
	.single__sidebar{width: 100%; max-width: 100%; padding: 0 5%; margin-left: 0;}
	.single__sidebar .form404{max-width: 100%;}
	
	.cate__content{flex-direction: column;}
	.cate__inner{width: 100%; padding: 25px 5%;}
	.cate__box{flex-direction: column;}
	.cate__thum{width: 100%;}
	.cate__box-content{width: 100%; margin-top: 20px; padding-left: 0;}
	.cate__sidebar{width: 100%; max-width: 100%; padding: 0 5%;}
	
	.cate__inner.news .cate__box{flex-wrap: wrap; flex-direction: row;}
	.cate__inner.news .cate__date{width: 20%;}
	.cate__inner.news .cate__title{width: 100%; margin: 4px 4px 10px;}
}
@media screen and (max-width: 480px) {
	body{font-size: 1.4rem;}
	.hero__inner{padding-left: 0;}
	.sec01__img img{height: 240px;}
	.sec01__content{padding: 35px;}
	.sec02__link a:before{top: 0px; right: 1px;}
	.sec02__link a:after{top: -2px;}	
	.sec03__title{width: 40%;}
	.sec03__link{width: 60%;}
	.sec03__link a:before{top: 0px; right: 1px;}
	.sec03__link a:after{top: -2px;}
	.sec03__news-catname{font-size: 1.2rem;}
	.sec03__news-catname a{width: auto; min-width: 120px; padding: 0.5em 2em;}
	.sec04__box-link .link-name:before{top: 0; right: 1px;}
	.sec04__box-link .link-name:after{top: -2px;}
	.slick-top{padding-left: 5%; padding-right: 5%;}
	.sec05__title{width: 40%;}
	.sec05__link{width: 60%;}
	.sec05__link a:before{top: 0px; right: 1px;}
	.sec05__link a:after{top: -2px;}
	.sec05__box{margin-right: 0;}
	.sec05__box-data{margin: 10px 0 0;}
	.cat-slick.slick-prev{left: -5px;}
	.cat-slick.slick-next{right: -5px;}
	.sec06__inner{width: 90%;}
	.sec06__btn-posi{text-align: center;}
	#footer__nav ul li{width: 50%;}
	.footer__cp{font-size: 0.8rem;}
	
	.my-page{padding-top: 60px;}
	.breadcrumbs__inner{font-size: 1.2rem;}
	.page__hero-content h1{font-size: 2.6rem;}
	.page__hero-img img{height: 200px;}
	.page__hero-content.middle{width: 90%; text-align: center;}
	.page__hero-content.middle h1{font-size: 2.6rem;}
	.page__inner{padding-top: 40px;}
	.service__box-title h3{font-size: 1.8rem; line-height: 1.4; margin-bottom: 10px;}
	.service__sec03 .service__box-img,
	.service__sec03 .service__box-img img{height: 240px;}
	.service__box-title{font-size: 1.4rem;}
	.service__box-en{font-size: 5rem;}
	.service__sec03-last, .service__sec03-last img{height: 240px;}
	
	.company-profile h2,.company-story h2,.company-access h2{font-size: 2.4rem;}
	.company-profile__table tr{border: none}
	.company-profile__table th,.company-profile__table td{display: block; padding: 10px;}
	.company-profile__table td{margin-bottom: 20px;}
	.company-profile__table tr:last-child td{margin-bottom: 0;}
	.company-map iframe{height: 270px;}
	
	.message__title{font-size: 2.4rem;}
	
	.wpcf7-form{padding-top: 35px;}
	.wpcf7-form input[type="text"],.wpcf7-form input[type="tel"],.wpcf7-form input[type="email"],.wpcf7-form input[type="number"],.wpcf7-form input[type="url"]{font-size: 1.4rem;}
	.wpcf7-form select,.wpcf7-form input[type="date"]{width: 100%; font-size: 1.4rem;}
	.wpcf7-form input[type="submit"]{width: 100%; margin-top: 50px; padding: 2rem 1rem;}
	
	.form404 input{width: 100%; font-size: 1.2rem;}
	.form404 button{min-width: 70px; margin-left: auto; font-size: 1.2rem;}
	
	.cate__inner h1{font-size: 2.4rem; margin-bottom: 20px;}
	.cate__box{padding: 0; margin-bottom: 20px;}
	.cate__thum img{width: 100%; height: 220px; object-fit: cover;}
	.cate__box-content{margin-top: 14px;}
	.cate__title h2{font-size: 1.8rem;}
	.cate__inner.news h1{margin: 25px 0 40px; font-size: 2.4rem;}
}