@charset "utf-8";

/*-----スタイルシート　1910--------------------------------------------*/
/*HTML5 Doctor Reset Stylesheet*/

@import url("rest.css");

/*-------------------------------------------------*/
/*全体設定*/


:root{
--ac1:#fde207;
--ac2:#1625b9;
--tx1:#111109;
--f-not:"Noto Sans JP", sans-serif;
--f-acl: adobe-caslon-pro, serif;
--f-beb: bebas-neue, sans-serif;
--f-cen: century-gothic, sans-serif;
}

h1,h2,h3,h4,h5,h6 {
font-weight: normal;
}
/*--------------------*/



.sp_only { display:none;}
#wrapper {
width:100%;
font-family: var(--f-not);
font-weight: 500;
font-size: 20px;
color: var(--tx1);
}
#contents {
width:100%;
margin:0 auto;
}
div[class$="_box"],section[class$="_box"]{
width: 1100px;
margin-left: auto;
margin-right: auto;
}
div,section {
justify-content: space-between;
flex-wrap: wrap;
}
p {
line-height: 1.5em;
letter-spacing: 0.06em;
}



/*-------------------------------------------------*/
/*ヘッダー*/
header{
width: 100%;
min-width: 1100px;
z-index: 50;
display: flex;
position: fixed;
z-index: 20;
justify-content: space-between;
}

header::after{
background: rgba(0,0,0,0.0);
content: "";
width: 100%;
height: 80px;
position: fixed;
z-index: -1;
transition: 0.35s ease-in-out;
}
header.active::after{
background: rgba(0,0,0,0.4);
content: "";
width: 100%;
height: 80px;
position: fixed;
z-index: -1;
}

.logo{
}
.logo img{
width: 295px;
margin: 9px;
}
.header_nav {
}

.header_nav ul{
display: flex;
align-items:center;
}
.header_nav ul li{
margin: 0px 0px;
font-size: 19px;
font-weight: 600;
position: relative;
}
.header_nav ul li a{
text-align: center;
}
.header_nav ul li a span{
display: block;
font-family: var(--f-cen);
font-weight: 400;
font-size: 14px;
margin-top: 5px;
letter-spacing: 0.07em;
transition: 0.15s ease-in-out;
}
.header_nav ul li a:not(.hd_icon){
font-size: 19px;
font-weight: 400;
color: #fff;
padding: 6px 0 22px;
}
.header_nav ul li:nth-of-type(-n+4) {
margin-right: 48px;
}
.header_nav ul li:nth-of-type(-n+4)::after {
content: "";
width: 1px;
height: 70px;
background: rgba(255,255,255,0.7);
position: absolute;
right: -21px;
top: -14px;
transform: rotate(45deg);
}
.header_nav ul li a:not(.hd_icon):hover span{
color: var(--ac1);
}
.header_nav ul li a.hd_icon{
display: block;
text-align: center;
font-size: 32px;
padding: 24px 0 4px;
width: 80px;
height: 80px;
margin-left: 22px;
transition: 0.15s ease-in-out;
background: var(--ac1);
color: var(--ac2);
}
.header_nav ul li a.hd_icon:hover{
background: #fef083;
}

.pagetop {
position: fixed;
padding: 20px 14px;
right: 10px;
bottom: -110px;
z-index: 101;
background: #4551c7;
border-radius: 5px;
color: var(--ac1);
font-family: var(--f-beb);
font-size: 22px;
text-align: center;
letter-spacing: 0.04em;
transition: 0.7s;
}
.pagetop.act {
bottom: 10px;
}


/*-----フェードアニメーション-----*/
.fade-in {
opacity: 0;
transition-duration: 500ms;
transition-property: opacity, transform;
}
.fade-in-up {
transform: translate(0, 50px);
}

.fade-in-down {
transform: translate(0, -50px);
}

.fade-in-left {
transform: translate(-50px, 0);
}

.fade-in-right {
transform: translate(50px, 0);
}

.scroll-in {
opacity: 1;
transform: translate(0, 0);
}
.delay1{
transition-delay: 0.4s;
}

.delay2{
transition-delay: 0.8s;
}
/*-----スクロールアニメーション-----*/
.scr_act {
/*transition: 0.8s ease-in-out;*/
}
/*-------------------------------------------------*/
/*フッター*/


footer {
background: var(--ac2);
padding: 100px 0 50px;
color: #fff;
overflow: hidden;
position: relative;
}
footer::after {
position: absolute;
content: "";
width: 120%;
height: 280px;
background: var(--ac1);
transform: rotate(-17.5deg);
bottom: -220px;
left: -10%;
z-index: 2;
}
.foot_box {
width: 1100px;
margin: 0 auto;
display: flex;
position: relative;
z-index: 3;
}
.foot_info {
width: 450px;
}
.foot_info img {
width: 100%;
margin-bottom: 22px;
}
.foot_info p {
font-size: 20px;
font-weight: 300;
margin-bottom: 15px;
}
.foot_info a {
vertical-align: bottom;
font-size: 31px;
font-family: var(--f-cen);
font-weight: 800;
letter-spacing: 0.094em;
}
.foot_info a i {
color: var(--ac1);
font-size: 30px;
display: inline-block;
margin-right: 7px;
vertical-align: bottom;
}
.foot_right {
width: 450px;
}

.foot_right img {
width: 450px;
display: block;
margin-left: 50px;
margin-right: -50px;margin-top: -30px;
animation: trakx 3.13s ease-in-out infinite;
}
.foot_right .imgbox {
animation:traky 0.91s ease-in-out infinite;
}
@keyframes trakx{
0%{transform: translateX(0) rotate(0deg); }
50%{transform: translateX(6px) rotate(-0.3deg); }
100%{transform: translateX(0) rotate(0deg); }
}
@keyframes traky{
0%{transform: translateY(0) rotate(0deg); }
50%{transform: translateY(1px) rotate(0.10deg); }
100%{transform: translateY(0) rotate(0deg); }
}

#copyright {
font-size: 15px;
font-weight: 300;
color: rgba(0,0,0,0.6);
text-align: right;
margin-left: 30px;
margin-right: -30px;
}


/*-------------------------------------------------*/
/*コンテンツ*/

/*◆◆◆◆◆◆◆◆◆*/
/*◆◆　TOP　◆◆*/

/*--////　main_visual　////--*/
#main_visual{
width: 100%;
min-width: 1100px;
height:90vh;
position: relative;
color: #fff;
background: rgba(0,0,0,0.1);
z-index: -2;
}
#main_visual::before{
width: 100%;
height:100%;
background:url("../images/mov_bg2.png");
content: "";
position: absolute;
top: 0;
left: 0;
opacity: 0.25;
z-index: 0;
}
#main_visual::after{
width: 100%;
height:100%;
background:rgba(0,0,0,0.3);
content: "";
position: absolute;
top: 0;
left: 0;
z-index: -1;
}
#main_visual video{
width: 100%;
height: 100%;
object-fit: cover;
}

#main_visual h1{
position: absolute;
font-size: 65px;
font-weight: 700;
line-height: 1.5em;
top:50%;
left: 50%;
transform: translate(calc(-50% + 0.3em),calc(-50% - 50px));
text-align: center;
letter-spacing: 0.14em;
width: 10em;
}
#main_visual h1::after{
position: absolute;
content: "";
width: 80px;
height: 15px;
background: var(--ac1);
left: 50%;
top: 50%;
transform: translate(calc(-50% - 0.3em),calc(-50% + 137px));
}
#main_visual h2{
position: absolute;
font-size: 40px;
top:50%;
left: 50%;
transform: translate(-50%,calc(-50% + 160px));
font-family:var(--f-acl);
letter-spacing: 0.05em;
}

/*--////　top_topics　////--*/
#top_topics {
min-width: 1100px;
padding: 100px 0;
display: flex;
overflow: hidden;
justify-content: flex-start;
align-items: center;
gap:60px;
}
.boxtit {
text-align: center;
padding-top: 14px;
padding-bottom: 18px;
border: 5px solid var(--ac2);
font-weight: 700;
color: var(--ac2);
width: calc(50% - 375px);
}
.boxtit span {
display: block;
font-family: var(--f-beb);
font-size: 60px;
font-weight: 400;
}
#top_topics h2 {
padding-left: calc(50% - 580px);
margin-left: -6px;
}

.tpicslist {
border-left: 5px solid var(--ac1);
padding-left: 45px;
width: calc(30% + 455px);
}
.tpicslist li {
padding: 8px 0px;
}
.tpicslist li a {
border-radius: 10px;
width: 100%;
display: block;
transition: 0.3s ease-in-out 0.05s;
}
.tpicslist li a:hover {
background: rgba(190,200,240,0.27);
}
.tpicslist li h4 {
padding: 10px 10px;
width: 160px;
display: inline-block;
font-family: var(--f-cen);
font-size: 24px;
vertical-align: baseline;
color: var(--ac2);
}

/*--////　top_policy　////--*/
#top_policy {
width: 100%;
min-width: 1100px;
position: relative;
padding-bottom: 70px;
padding-top: 130px;
}
#top_policy h2 {
padding-right: calc(50% - 580px);
position: absolute;
right: 0;
top: 0;
border-right: none;
}
#top_policy img {
width: calc(50% + 170px);
height: 690px;
object-fit: cover;
position: absolute;
left: 0;
top: 0;
}
#top_policy div {
position: relative;
width: calc(50% - 50px);
background: #fff;
padding: 60px 90px;
margin-left: 50%;
box-shadow: 50px 50px 0 var(--ac1);
}

#top_policy div h3 {
font-size: 36px;
font-weight: 700;
margin-bottom: 40px;
letter-spacing: 0.08em;
}
#top_policy div p {
line-height: 1.9em;
}

/*--////　top_forte　////--*/
#top_forte {
position: relative;
padding: 60px 0;
}
#top_forte::after {
position: absolute;
width: 100%;
height: 50%;
bottom: 0;
content: "";
background: var(--ac1);
z-index: -1;
}
#top_forte h2 {
font-size: 40px;
text-align: center;
font-weight: 800;
margin-bottom: 60px;
letter-spacing: 0.1em;
}
#top_forte ul {
width: 1100px;
margin: 0 auto;
display: flex;
justify-content: space-between;
}
#top_forte ul li {
width: 340px;
}
#top_forte ul li img {
width: 100%;
height: 270px;
object-fit: cover;
margin-bottom: 18px;
}
#top_forte ul li h3 {
text-align: center;
color: var(--ac2);
font-weight: 800;
margin-bottom: 12px;
font-size: 26px;
letter-spacing: 0.08em;
}
#top_forte ul li p {
line-height: 1.9em;
}

/*--////　top_works　////--*/
#top_works {
min-width: 1100px;
padding: 120px 0;
position: relative;
overflow: hidden;
}
.backsl-u {
position: absolute;
background: #e8e9f8;
height: 10px;
top: -20px;
left: -10%;
width: 120%;
z-index: -1;
}
.backsl-u.active {
animation: bku 0.8s ease-out 0.1s forwards;
transform-origin: 85% 100%;
}
@keyframes bku{
0%{transform: rotate(0deg); height: 10px;top: -20px;}
100%{transform: rotate(-17.5deg); height: 750px;top: -750px;}
}

.backsl-d {
position: absolute;
background: #e8e9f8;
height: 10px;
bottom: -20px;
left: -10%;
width: 120%;
z-index: -1;
}
.backsl-d.active {
animation: bkd 0.8s ease-out 0.1s forwards;
transform-origin: 15% 0%;
}
@keyframes bkd{
0%{transform: rotate(0deg); height: 10px;bottom: -20px;}
100%{transform: rotate(-17.5deg); height: 750px;bottom: -850px;}
}


#top_works h2 {
padding-left: calc(50% - 580px);
margin-left: -6px;
}
#top_works p {
line-height: 2em;
}
#top_works img {
width: 520px;
}
.top_works_a,
.top_works_b, 
.top_works_c{
width: 1100px;
margin: 0 auto;
display: flex;
align-items: flex-end;
}
.top_works_a {
margin-top: -122px;
}
.top_works_b {
align-items: center;
flex-flow: row-reverse;
margin-bottom: -10px;
}
.top_works_c {
}




#top_works h3 {
font-weight: 800;
font-size: 36px;
letter-spacing: 0.14em;
line-height: 1.5em;
margin-bottom: 35px;
}
#top_works > div > div {
width: 520px;
}
.top_works_a img {
width: calc(50vw - 30px)!important;
height: 500px;
object-fit: cover;
margin-right: calc(550px - 50vw);
}

.top_works_c div p span {
color: var(--ac2);
}


/*--////　top_rec　////--*/
#top_rec {
background: var(--ac1);
width: 100%;
min-width: 1100px;
padding: 70px 0;
position: relative;
}
#top_rec h2 {
padding-right: calc(50% - 580px);
position: absolute;
right: 0;
top: 70px;
border-right: none;
}
#top_rec > div {
margin: 0 auto;
width: 1100px;
display: flex;
align-items: flex-end;
justify-content: flex-end; /* pを右端に配置 */
gap: 60px;
position: relative;
}
#top_rec img {
position: absolute;
top: 0px;
right: 580px;
width: max(calc(50vw - 100px), 520px);
height: 530px;
object-fit: cover;
}
#top_rec > div > div {
padding-top: 80px;
width: 520px;
}
#top_rec > div > div h3 {
font-size: 36px;
font-weight: 800;
letter-spacing: 0.15em;
margin-bottom: 40px;
line-height: 1.5em;
}
#top_rec > div > div p {
line-height: 2em;
margin-bottom: 30px;
}
#top_rec > div > div h4 {
border: 5px solid #fff;
padding: 10px 0;
text-align: center;
font-weight: 700;
color: #fff;
letter-spacing: 0.1em;
}

/*--////　top_about　////--*/

#top_about {
width: 100%;
min-width: 1100px;
padding: 200px 0 100px;
position: relative;
overflow: hidden;
}
#top_about h2 {
padding-left: calc(50% - 580px);
margin-left: -6px;
}
/*--/top_about_info/--*/
.top_about_info {
display: flex;
width: 1100px;
margin: -122px auto 0;
align-items: flex-end;
}
.top_about_info div {
width: 520px;
}
.top_about_info div h3 {
font-size: 36px;
font-weight: 800;
margin-bottom: 90px;
letter-spacing: 0.08em;
position: relative;
}
.top_about_info div h3::after {
position: absolute;
content: "";
width: 65px;
height: 10px;
background: var(--ac1);
bottom: -40px;
left: 0;
}
.top_about_info div dl {
display: flex;
gap:28px;
flex-wrap: wrap;
}
.top_about_info div dl dt {
width: 90px;
}
.top_about_info div dl dd {
width: 400px;
}
.top_about_info img {
width: max(calc(50vw - 80px),520px);
margin-right: min(calc(609px - 50vw),0px);
height: 610px;
object-fit: cover;
box-shadow: 50px 50px 0 var(--ac1);
}

/*--/top_about_map/--*/
.top_about_map {
padding: 140px 0 80px;
}
.top_about_map h3 {
text-align: center;
font-size: 36px;
font-weight: 800;
margin-bottom: 70px;
letter-spacing: 0.08em;
position: relative;
}
.top_about_map h3::after {
position: absolute;
content: "";
width: 65px;
height: 10px;
background: var(--ac1);
bottom: -40px;
left: calc(50% - 32px);
}

.map-embed {
width: 100% ;
height: 580px;
margin: 15px 0px 1px;
padding: 0 0 px ;
overflow: hidden ;
position: relative ;
top: 0 ;
left: 0 ;
background:#CCC;
}
.map-embed > div {
position: absolute ;
top: 0 ;
left: 0 ;
width: 100% ;
height: 100% ;
margin: 0 ;
padding: 0 ;
}
.map-embed img {
max-width: none ;
}

/*--/top_about_history/--*/
.top_about_history {
width: 1100px;
margin: 0 auto;
padding: 30px 0;
display: flex;
}
.top_about_history div {
width: 520px;
}
.top_about_history div h3 {
font-size: 36px;
font-weight: 800;
margin-bottom: 90px;
letter-spacing: 0.08em;
position: relative;
}
.top_about_history div h3::after {
position: absolute;
content: "";
width: 65px;
height: 10px;
background: var(--ac1);
bottom: -40px;
left: 0;
}
.top_about_history div dl {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
gap:26px 10px;
}
.top_about_history div dl dt {
width: 152px;
font-family: var(--f-cen);
color: var(--ac2);
letter-spacing: 0.02em;
font-weight: 800;
font-size: 28px;
}
.top_about_history div dl dd{
width: 350px;
line-height: 1.4em;
margin-top: -2px;
}
.top_about_history div dl dd img{
height: 21px;
display: inline-block;
vertical-align: middle;
margin-top: -4px;
}

.top_about_history .imgset img{
width: 520px;
}
.top_about_history .imgset p{
text-align: center;
font-size: 15px;
}


/*--////　contact　////--*/

#contact {
min-width: 1100px;
background: #e8e9f8;
padding: 140px 0;
}
#contact h2 {
padding-left: calc(50% - 580px);
margin-left: -6px;
}

/*
<section id="contact">

<div class="contact_in">
<h2 class="boxtit"><span>CONTACT</span>お問い合わせ</h2>
*/

/*------------------form.php---------------------*/

.contact_in {
width: 1100px;
margin: -121px auto 0;
position: relative;
display: flex;
flex-flow: row-reverse;
}


.formstyle div:not(.formbotarea){
margin: 0 0 18px;
}
.formstyle label {
width: 250px;
display: inline-block;
margin: 15px 0;
font-size: 20px;
vertical-align: top;
margin-right: 0.5em;
text-align: right;
}
.formstyle label span {
color:#C8178A;
font-size: 70%;
display: inline-block;
vertical-align: top;
line-height: 0;
margin-left: 4px;
}

.hissu span {
display: inline-block;
color:#C8178A;
font-size: 70%;
vertical-align: top;
margin-top: -3px;
margin-right: 4px;
}
.formstyle input:not(.imbot),
.formstyle textarea,
.formstyle select{
width: 630px;
border:none;
padding: 10px 15px;
border-radius: 7px;
font-family:var(--f-not);
font-weight: 300!important;
font-size: 20px;
background: rgba(255,255,255,0.71);
border: 1px solid rgba(50,50,50,0.18);
}
.formstyle textarea{
font-family:var(--f-not);
font-weight: 300!important;
font-size: 20px;
font-size: 18px;
height: 12em;
}
.formstyle select{
width: 500px;
padding: 14px 15px;
-webkit-appearance: none;
appearance: none;
}
.formstyle .selectdiv{
position: relative;
}
.formstyle .selectarr{
position: absolute;
z-index: 10;
right: 150px;
top: 50%;
line-height: 0;
font-size: 12px;
opacity: 0.5;
}
.formbotarea  {
display: flex;
width: 700px;
margin: 0 auto;
justify-content: center;
padding-top: 40px;
}
.formbotarea p  {
text-align: center;
margin: 0px auto 5px;
width: 100%;
}
.fmbota_cen {
width: 350px;
margin: 0 auto;
}
.formbotarea .submitbtn {
color: #fff;
background: var(--ac2);
padding: 20px 0;
border: none;
font-size: 20px;
width: 240px;
margin: 0 10px;
line-height: 1em;
cursor: pointer;
}

.formbotarea .submitbtn:hover {
opacity: 0.8;
}
.formbotarea .submitbtn_op {
background: #888;
}

/*--- フォーム確認画面・最終画面 ----*/

#formWrap {
width: 1100px;
margin: 0px auto;
padding: 150px 0 150px;
}
#rec_kakunin {
}

.kakunin_err {
width: 700px;
margin: 0 auto;
}
.kakunin_err h4 {
text-align: center;
font-size: 22px;
line-height: 1.4em;
margin-bottom: 65px;
}
.error_messe {
width: 490px;
margin: 15px auto;
color:darkred;
}
.formTable {
border-collapse: collapse;
width: 700px;
margin: 50px auto;
}
.formTable th,
.formTable td{
border: 1px solid #aaa;
padding: 12px;
}
.formTable th{
background: #ddd;
width: 180px;
}

.kakunin_ok {
text-align: center;
font-size: 22px;
line-height: 1.4em;
}

.f_kanryo {
width: 700px;
margin: 0px auto;
padding: 150px 0 150px;
}
.f_kanryo p {
margin: 70px 0;
font-size: 22px;
}

/*◆◆◆◆◆◆◆◆◆*/
/*◆◆　サブページ共通　◆◆*/

#sub_visual {
width: 100%;
min-width: 1100px;
height: 340px;
overflow: hidden;
}
#sub_visual h1 {
padding-left: calc(50% - 580px);
text-align: center;
padding-top: 14px;
padding-bottom: 18px;
border: 5px solid #fff;
font-weight: 700;
color: #fff;
width: calc(50% - 375px);
margin-left: -5px;
margin-top: 160px;
font-size: 23px;
}
#sub_visual h1 span {
display: block;
font-family: var(--f-beb);
font-size: 60px;
font-weight: 400;
}
/*◆◆◆◆◆◆◆◆◆*/
/*◆◆　TOPICS　◆◆*/

/*--////　sub_topics　////--*/

.sub_topics {
background: url("../images/sub_topics.webp");
background-size: cover;
}

/*--////　topics_kiji　////--*/
.topics_kiji_set {
display: flex;
min-width: 1100px;
position: relative;
}
#topics_kiji {
width: 1100px;
margin: 0 auto;
padding: 100px 300px 100px 0;
}

#topics_kiji img {
width: 100%;
margin-bottom: 20px;
}

#topics_kiji h3 {
font-family: var(--f-cen);
color: var(--ac2);
font-size: 27px;
margin-bottom: 8px;
font-weight: 600;
}
#topics_kiji h2 {
margin-bottom: 60px;
font-weight: 600;
font-size: 30px;
}

#topics_kiji h4 {
padding-top: 45px;
margin-bottom: 25px;
position: relative;
font-weight: 700;
font-size: 27px;
}
#topics_kiji h4::after {
position: absolute;
bottom: -5px;
left: 0;
content: "";
width: 100%;
height: 9px;
background: #e8e9f8;
z-index: -1;
}
#topics_kiji h5 {
padding-top: 35px;
margin-bottom: 15px;
font-weight: 700;
font-size: 21px;
color: var(--ac2);
}
#topics_kiji p {
font-weight: 400;
font-size: 20px;
margin-bottom: 20px;
}

.topics_kiji_bg {
position: absolute;
height: 100%;
width: max(calc(50% - 370px),180px);
right: 0;
top: 0;
background: #e8e9f8;
}

/*--////　sub_form　////--*/

.sub_form {
background: url("../images/sub_form.webp");
background-size: cover;
}




