@charset "UTF-8";
/* CSS Document */

/* 基本-モバイルファースト ======================================================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap');
/* 印刷時の余白幅指定 */
@page {
margin: 12.7mm 9.7mm;
}
html {
-webkit-font-smoothing: antialiased;
}
body{
text-align: center;
width: 100%;
font-family: "Zen Kaku Gothic New", sans-serif;
font-weight: 500;
font-style: normal;
line-height: 1.8;
color: #555;
line-break: strict;
word-wrap: break-word;
overflow-wrap: break-word;
text-decoration-skip-ink: none;
}
body,
table,
input,
textarea{
font-size: 14px;
}

/* テキスト選択時のハイライト */
::selection {
background: #DDD;
}
::-moz-selection {
 background: #DDD;
}

a,
a:link,
a:visited {
color: #555;
}

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

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
textarea{
padding: 5px;
margin: 0px;
box-sizing: border-box;
border: 1px solid #AAA;
border-radius: 5px;
}
input[type="text"]:hover,
input[type="email"]:hover,
input[type="tel"]:hover,
input[type="password"]:hover,
textarea:hover{
border: 1px solid #666;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
textarea:focus{
background-color: #F3F3F3;
}
input[type="radio"],
input[type="checkbox"]{
-webkit-appearance: none;
background-color: #FFF;
background-image: url(../images/checkbox_bg_off.svg);
background-repeat: no-repeat;
background-position: center center;
width: 20px;
height: 20px;
margin: 0 5px 0 0;
-webkit-border-radius: 20px;
-moz-border-radius: 20px;
border-radius: 20px;
display: inline-block;
vertical-align: middle;
border: solid 1px #CCC;
box-sizing: border-box;
}
input[type="checkbox"]{
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
}
input[type="radio"]:checked,
input[type="checkbox"]:checked{
background-image: url(../images/checkbox_bg_on.svg);
background-color: #cb261e;
border: none;
}
label:hover{
cursor: pointer;
}

.opct{}

/* googleリマーケティングタグの隙間回避 */
iframe[name="google_conversion_frame"] { position:absolute; top: 0; left: 0; }

.mt05{ margin-top: 5px; }
.mt10{ margin-top: 10px; }
.mt15{ margin-top: 15px; }
.mt20{ margin-top: 20px; }
.mt30{ margin-top: 30px; }
.mt40{ margin-top: 40px; }
.mr05{ margin-right: 5px; }
.mr10{ margin-right: 10px; }
.mr15{ margin-right: 15px; }
.mr20{ margin-right: 20px; }
.mr30{ margin-right: 30px; }
.mr40{ margin-right: 40px; }
.mb05{ margin-bottom: 5px; }
.mb10{ margin-bottom: 10px; }
.mb15{ margin-bottom: 15px; }
.mb20{ margin-bottom: 20px; }
.mb30{ margin-bottom: 30px; }
.mb40{ margin-bottom: 40px; }
.ml05{ margin-left: 5px; }
.ml10{ margin-left: 10px; }
.ml15{ margin-left: 15px; }
.ml20{ margin-left: 20px; }
.ml30{ margin-left: 30px; }
.ml40{ margin-left: 40px; }
.pt05{ padding-top: 5px; }
.pt10{ padding-top: 10px; }
.pt15{ padding-top: 15px; }
.pt20{ padding-top: 20px; }
.pt30{ padding-top: 30px; }
.pt40{ padding-top: 40px; }
.pr05{ padding-right: 5px; }
.pr10{ padding-right: 10px; }
.pr15{ padding-right: 15px; }
.pr20{ padding-right: 20px; }
.pr30{ padding-right: 30px; }
.pr40{ padding-right: 40px; }
.pb05{ padding-bottom: 5px; }
.pb10{ padding-bottom: 10px; }
.pb15{ padding-bottom: 15px; }
.pb20{ padding-bottom: 20px; }
.pb30{ padding-bottom: 30px; }
.pb40{ padding-bottom: 40px; }
.pl05{ padding-left: 5px; }
.pl10{ padding-left: 10px; }
.pl15{ padding-left: 15px; }
.pl20{ padding-left: 20px; }
.pl30{ padding-left: 30px; }
.pl40{ padding-left: 40px; }

.f_right{ float: right; }
.f_left{ float: left; }
.pc_float_none{}
.pc_f_right{}
.pc_f_left{}

.table{ display: table; }
.table_cell{ display: table-cell; }
.pc_display_block{}
.pc_table{}
.pc_table_cell{}

.ta_right{ text-align: right; }
.ta_center{ text-align: center; }
.ta_left{ text-align: left; }

.va_top{ vertical-align: top; }
.va_middle{ vertical-align: middle; }
.va_bottom{ vertical-align: bottom; }

.sp_tel{}

.font10px{ font-size: 10px; }
.font11px{ font-size: 11px; }
.font12px{ font-size: 12px; }
.font14px{ font-size: 14px; }
.font16px{ font-size: 16px; }
.font18px{ font-size: 18px; }
.font20px,
.font22px,
.font24px,
.font26px,
.font28px{ font-size: 20px; }
.font30px{ font-size: 22px; }

.font_bold{ font-weight: bold; }

.font_color_red{ color: #cb261e; }
.font_color_01{ color: #e66b21; }
.font_color_02{ color: #218ce6; }

.clear{
display: block;
float: none;
clear: both;
}

.css_arrow{
position: relative;
display: inline-block;
padding: 0 15px 0 0;
vertical-align: middle;
}
.css_arrow::before{
content: "";
vertical-align: middle;
position: absolute;
top: 0;
bottom: 0;
right: 3px;
margin: auto;
border-top: 1px solid #555;
border-right: 1px solid #555;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

.ca_5::before{ width: 5px; height: 5px; }
.ca_7::before{ width: 7px; height: 7px; }
.ca_10::before{ width: 10px; height: 10px; }
.ca_15::before{ width: 15px; height: 15px; }

.common_btn{
text-align: center;
margin-top: 20px;
}
.common_btn a,
.common_btn .a{
display: block;
text-decoration: none;
font-size: 16px;
padding: 15px;
text-align: left;
color: #fff;
background: #CB261E;
background: linear-gradient(125deg, #D91A62 0%, #CB261E 33%, #e76c0d 66%, #CB261E 100%);
background-position: 0% 50%;
background-size: 300% auto;
position: relative;
}
.common_btn a::before,
.common_btn .a::before{
content: "";
display: block;
width: 8px;
height: 8px;
position: absolute;
top: 0;
bottom: 0;
right: 13px;
margin: auto;
border-top: 1px solid #fff;
border-right: 1px solid #fff;
transform: rotate(45deg);
}


a.target_blank::after{
content: "";
background-image: url(../images/icon-blank.svg);
background-repeat: no-repeat;
background-position: left top;
background-size: 100%;
display: inline-block;
width: 12px;
height: 9px;
margin-left: 3px;
}


/* ヘッダー======================================================================================================== */
#header{
width: 100%;
background-color: rgba(255, 255, 255, 0.7);
position: fixed;
top: 0;
left: 0;
z-index: 10000;
}
#header_logo{
text-align: left;
margin: 10px;
}
#header_logo a{
display: inline-block;
text-decoration: none;
line-height: 1px;
}
#header_logo a .icon{
display: inline-block;
vertical-align: middle;
}
#header_logo a .icon img{
height: 40px;
}
#header_logo a p{
display: inline-block;
vertical-align: middle;
font-size: 5vw;
font-weight: 700;
margin-left: 0.25em;
}
#header_logo a p .c{
color: #cb261e;
}

#fixed_btn{
width: 100%;
position: fixed;
right: 0;
bottom: 0;
}
#fixed_btn a{
display: flex;
align-items: center;
justify-content: center;
text-decoration: none;
height: 10vw;
clip-path: polygon(0 0,90vw 0,100% 100%,100% 100%,0 100%);
box-sizing: border-box;
color: #fff;
background-color: #cb261e;
border-top: solid 1px #fff;
position: relative;
}
#fixed_btn a::after{
content: "";
display: block;
width: calc(10vw * 1.41421356);
height: 1px;
background-color: #fff;
position: absolute;
left: 90vw;
bottom: calc( 10vw - 1px);
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
transform-origin:left top;
z-index: 10;
}
#fixed_btn a .icon{
line-height: 1px;
}
#fixed_btn a .icon img{
height: 3vh;
}
#fixed_btn a p{
font-size: 3vh;
line-height: 1;
font-weight: 700;
margin-left: 2vh;
}


/* グローバルメニュー=============================================== */
#global_menu{
}
#global_menu_inner{
width: 100%;
height: 100vh;
background-color: rgba(0, 0, 0, 0.8);
position: absolute;
top: 0;
left: 0;
z-index: 9999;
display: none;
}
#global_menu ul{
height: 100vh;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
#global_menu ul li{
width: 80%;
}
#global_menu ul li a{
display: block;
text-decoration: none;
color: #fff;
border-bottom: solid 1px rgba(255, 255, 255, 0.1);
padding: 10px;
position: relative;
}
#global_menu ul li a::after{
content: "";
vertical-align: middle;
width: 5px;
height: 5px;
position: absolute;
top: 0;
bottom: 0;
right: 23px;
margin: auto;
border-top: 1px solid #fff;
border-right: 1px solid #fff;
transform: rotate(45deg);
}

.sp-hamburger {
display: block;
text-align: center;
z-index: 10000;
position: absolute;
top: 5px;
right: 0px;
box-sizing: border-box;
width: 50px;
height: 50px;
padding: 0 10px;
-webkit-transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
-webkit-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
border: 0;
outline: 0;
background-color: transparent;
}
.sp-hamburger:hover {
cursor: pointer;
}
.sp-hamburger-icon {
position: relative;
display: block;
margin-top: 0px;
}
.sp-hamburger-icon,
.sp-hamburger-icon:before,
.sp-hamburger-icon:after {
width: 100%;
height: 1px;
-webkit-transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
background-color: #111;
border-radius: 5px;
}
.sp-hamburger-icon:before,
.sp-hamburger-icon:after {
position: absolute;
top: -10px;
left: 0;
content: '';
}
.sp-hamburger-icon:after {
top: 10px;
}
.sp_menu-open .sp-hamburger-icon {
background-color: transparent;
}
.sp_menu-open .sp-hamburger-icon:before,
.sp_menu-open .sp-hamburger-icon:after {
top: 0;
background-color: #fff;
}
.sp_menu-open .sp-hamburger-icon:before {
-webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
        transform: rotate(45deg);
}
.sp_menu-open .sp-hamburger-icon:after {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}



/* コンテンツ======================================================================================================== */
#container {
overflow: hidden;
}
#contents {
margin-top: 40px;
margin-bottom: 80px;
}
.contents_size{
margin-left: 5vw;
margin-right: 5vw;
display: block;
text-align: left;
}

#page_title{
position: relative;
}
#page_title .en{
display: block;
font-size: 12vw;
line-height: 1;
font-weight: 300;
color: #ddd;
white-space: nowrap;
-ms-writing-mode: tb-rl;
writing-mode: vertical-rl;
position: absolute;
top: 50px;
right: -3vw;
z-index: 5;
/* mix-blend-mode:difference; */
}
#page_title h1{
color: #fff;
padding-left: 5vw;
font-size: 6vw;
letter-spacing: .25em;
padding-left: 2vw;
letter-spacing: .1em;
margin-top: 30px;
background-color: #cb261e;
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
-webkit-transform: translateY(-50%);
margin: auto 0;
}
#page_title h1::after{
content: "";
display: block;
width: .5em;
height: 100%;
background-color: #cb261e;
clip-path: polygon(0 0,100% 0,50% 100%,0 100%);
position: absolute;
right: -.5em;
top: 0;
}
#page_title .bg{
position: relative;
width: 100%;
z-index: -10;
}
#page_title .bg img{
width: 100%;
height: 40vw;
object-fit: cover;
}


#topic_path{
background-color: #f3f3f3;
padding: 1vw 5vw;
font-size: 10px;
text-align: left;
position: relative;
z-index: -10;
}
#topic_path a::after{
content: "";
display: inline-block;
vertical-align: middle;
width: 5px;
height: 5px;
margin: 0 5px 0 0;
border-top: 1px solid #111;
border-right: 1px solid #111;
transform: rotate(45deg);
}

.common_title{
margin-bottom: 5vw;
}
.common_title .en{
display: block;
font-size: 12vw;
line-height: 1;
font-weight: 300;
color: #ddd;
margin-bottom: 2vw;
}
.common_title .en + *,
.common_title h2,
.common_title h3{
font-size: 8vw;
}

.sub_title{
}

.sub_title_mk{
margin-bottom: 20px;
}
.sub_title_mk span{
display: inline-block;
color: #fff;
font-size: 24px;
line-height: 1.4;
margin-top: .25em;
background-color: #cb261e;
position: relative;
}

.sub_title_mk span:first-child{
margin-top: 0;
}
.sub_title_mk span::before,
.sub_title_mk span::after{
content: "";
display: block;
width: .5em;
height: 100%;
background-color: #cb261e;
position: absolute;
top: 0;
}
.sub_title_mk span::before{
clip-path: polygon(50% 0,100% 0,100% 100%,0 100%);
left: -.5em;
}
.sub_title_mk span::after{
clip-path: polygon(0 0,100% 0,50% 100%,0 100%);
right: -.5em;
}


/* .marker{
background: linear-gradient(transparent 40%, #ffef64 0%);
display: inline;
padding: 0 2px 4px;
} */

/* CSSのみでリアルな蛍光マーカーを表現する 
https://doctor-martin.blog/2021/04/17/css-highlighter-pen-effect/ */
.marker_b {
text-shadow: 0 3px 5px rgba(163, 226, 252, .6);
line-height: normal;
font-weight: bold;
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(163, 226, 252, .6) 0);
}
.marker_b::before, .marker_b::after {
display: inline-block;
content: "\A";
white-space: pre;
width: 0.41em;
clip-path: inset(1px 0);
transform-origin: bottom left;
transform: skewX(-15deg) translateX(-0.1em);
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(163, 226, 252, .6) 0);
}
.marker_b::after {
filter: blur(.03em);
transform: skewX(-15deg);
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(163, 226, 252, .95) 0);
}

.marker_y {
text-shadow: 0 3px 5px rgba(255, 255, 100, .6);
line-height: normal;
font-weight: bold;
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(247, 247, 36, .5) 0);
}
.marker_y::before, .marker_y::after {
display: inline-block;
content: "\A";
white-space: pre;
width: 0.41em;
clip-path: inset(1px 0);
transform-origin: bottom left;
transform: skewX(-15deg) translateX(-0.1em);
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(247, 247, 36, .5) 0);
}
.marker_y::after {
filter: blur(.03em);
transform: skewX(-15deg);
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(247, 247, 36, .9) 0);
}

.marker_r {
text-shadow: 0 3px 5px rgba(255, 206, 206, 0.6);
line-height: normal;
font-weight: bold;
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(255, 172, 172, 0.6) 0);
}
.marker_r::before, .marker_r::after {
display: inline-block;
content: "\A";
white-space: pre;
width: 0.41em;
clip-path: inset(1px 0);
transform-origin: bottom left;
transform: skewX(-15deg) translateX(-0.1em);
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(246, 148, 148, 0.6) 0);
}
.marker_r::after {
filter: blur(.03em);
transform: skewX(-15deg);
background: linear-gradient(rgba(0,0,0,0) 60%, rgba(246, 148, 148, .95) 0);
}




.accordion_title{
padding-right: 15px;
position: relative;
cursor: pointer;
}
.accordion_title::before{
content: "";
display: inline-block;
vertical-align: middle;
width: 20px;
height: 3px;
background-color: #cb261e;
position: absolute;
top: 0;
bottom: 0;
right: 3px;
margin: auto;
transition: all 0.2s ease;
}
.accordion_title::after{
content: "";
display: inline-block;
vertical-align: middle;
width: 3px;
height: 20px;
background-color: #cb261e;
position: absolute;
top: 0;
bottom: 0;
right: 11.5px;
margin: auto;
transition: all 0.2s ease;
}
.accordion_title.open::after{
transform: rotate(-90deg);
}
.accordion_title + *{
display: none;
}

form{
margin: 0px;
padding: 0px;
}
/* 通常テーブルパターン */
table.normal{
width: 100%;
border-collapse:collapse;
border-spacing: 0;
}
table.normal th,
table.normal td{
border-bottom: 1px solid #DDD;
box-sizing: border-box;
}
table.normal th{
padding: 20px 0px;
font-weight: bold;
text-align: center;
white-space: nowrap;
}
form table.normal th{
text-align: left;
vertical-align: top;
}
table.normal td{
padding: 20px 0px 20px 20px;
}
table.sp_tableflat{}
form .must{
display: block;
background-color: #C00;
padding: 5px;
font-size: 10px;
line-height: 10px;
color: #FFF;
float: right;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
border-radius: 5px;
}
form .cap{
font-size: 10px;
color: #C00;
}
.form_address li{
margin: 5px 0 0;
}
.form_address li.post{
margin: 0;
}
.form_preferred_date{
display: flex;
flex-wrap: wrap;
align-items: center;
}
.form_preferred_date dt{
width: 4.5em;
}
.form_preferred_date dd{
width: calc(100% - 4.5em);
}
form #submit_box,
.mfp_buttons{
margin-top: 30px;
text-align: center;
}
form #submit_box p{
margin: 0 0 10px;
}
form #submit_box button,
.mfp_buttons button{
font-size: 20px;
margin: 0 10px;
padding: 15px 40px;
min-width: 200px;
cursor:pointer;
display: inline-block;
-webkit-appearance: none;
border: none;
border-radius: 5px;
}
form #submit_box button[type="reset"]{ background-color: #CCC; }
form #submit_box button[type="submit"]{ background-color: #C00; color: #FFF; }
form #submit_box button[type="reset"]:hover{ background-color: #BBB; }
form #submit_box button[type="submit"]:hover{ background-color: #9A0002; }
.mfp_buttons button#mfp_button_send{ background-color: #C00; color: #FFF; }
.mfp_buttons button#mfp_button_cancel{ background-color: #CCC; }
.mfp_buttons button#mfp_button_send:hover{ background-color: #9A0002; }
.mfp_buttons button#mfp_button_cancel:hover{ background-color: #BBB; }

#mfp_phase_confirm{
clear: both;
padding-top: 40px;
}
#mfp_phase_confirm h4{
font-weight: bold;
margin-bottom: 10px;
}
table#mfp_confirm_table{
width: 100%;
}
table#mfp_confirm_table tr th, table#mfp_confirm_table tr td{
border-top: none;
border-bottom: solid 1px #ddd;
padding: 8px;
}
table#mfp_confirm_table tr.mfp_colored{
background-color: transparent;
}
table#mfp_confirm_table tr th{
font-weight: bold;
}

#thanks_page{
padding: 60px 0;
text-align: center;
}
#thanks_page h3{
font-weight: bold;
font-size: 18px;
}

.raf{
text-align: center;
}
.raf .full img{
width: 100%;
}


#common_under_btn li{
margin-bottom: 5vw;
}
#common_under_btn li a{
display: block;
text-decoration: none;
color: #fff;
padding: 8vw 5vw;
position: relative;
}
#common_under_btn li.entry a{
background-color: #cb261e;
text-align: right;
}
#common_under_btn li.interview a{
background-color: #857e7a;
text-align-last: left;
}
#common_under_btn li em{
display: block;
font-size: 12vw;
font-weight: 300;
line-height: 1;
}
#common_under_btn li p{
font-size: 4vw;
}
#common_under_btn li .photo{
width: auto;
height: 40vw;
position: absolute;
bottom: 0;
}
#common_under_btn li.entry .photo{ left: 5vw; }
#common_under_btn li.interview .photo{ right: -2vw; }
#common_under_btn li .photo img{
width: auto;
height: 100%;
}


/* main_bottom======================================================================================================== */
#main_bottom{
margin-bottom: 10vw;
}
#main_bottom #mb_qa a{
display: flex;
flex-wrap: wrap;
align-items: center;
justify-content: center;
text-decoration: none;
background-color: #cb261e;
background-image: url(../images/bg_red.png);
background-image: -webkit-image-set(url(../images/bg_red.png) 1x, url(../images/bg_red@2x.png) 2x);
background-repeat: no-repeat;
background-position: -20% 10%;
background-size: 120vw auto;
color: #fff;
padding: 20px;
position: relative;
}
#main_bottom #mb_qa a::before{
content: "";
display: block;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, .1);
clip-path: polygon(60% 0%, 100% 0%, 100% 100%, 40% 100%);
position: absolute;
top: 0;
left: 0;
z-index: 5;
}
#main_bottom #mb_qa a > *{
position: relative;
z-index: 10;
}
#main_bottom #mb_qa .icon img{
height: 80px;
}
#main_bottom #mb_qa em{
font-size: 50px;
position: relative;
padding-left: 30px;
}
#main_bottom #mb_qa em span{
display: block;
font-size: 20px;
line-height: 1;
color: #cb261e;
background-color: #fff;
padding: .25em .5em;
white-space: nowrap;
-webkit-transform: rotate(-15deg);
transform: rotate(-15deg);
position: absolute;
top: 5px;
left: 10px;
}
#main_bottom #mb_qa p{
width: 100%;
}


/* フッター======================================================================================================== */
#footer {
background-color: #eee;
padding-top: 40px;
padding-bottom: calc(20px + 8vh);
position: relative;
}
#footer::after{
content: "";
display: block;
background-image: url(../images/footer_tree.png);
background-image: -webkit-image-set(url(../images/footer_tree.png) 1x, url(../images/footer_tree@2x.png) 2x);
background-repeat: no-repeat;
background-position: left bottom;
background-size: auto 100%;
width: 45vw;
height: 60vw;
/* aspect-ratio: 437 / 458; */
position: absolute;
right: 0;
bottom: 8vw;
}

#footer_link{
margin-bottom: 40px;
}
#footer_link li{
display: flex;
align-items: center;
margin-bottom: 10px;
}
#footer_link li:last-child{
margin-bottom: 0px;
}
#footer_link li ul{
display: flex;
}
#footer_link li ul li{
margin-bottom: 0;
font-size: 12px;
}
#footer_link li ul li::before{
content: "\FF5C";
}
#footer_link li ul li:first-child:before{
content: "-";
margin: 0 .5em;
}

#footer_company{
}
#footer_logo{
text-align: left;
}
#footer_logo a{
display: inline-block;
text-decoration: none;
}
#footer_logo a .icon{
display: inline-block;
vertical-align: middle;
}
#footer_logo a .icon img{
height: 40px;
}
#footer_logo a p{
display: inline-block;
vertical-align: middle;
font-size: 5vw;
font-weight: 700;
margin-left: 0.25em;
}
#footer_logo a p .c{
color: #cb261e;
}
#footer_company dd{
font-size: 12px;
margin-top: 1em;
}

#copy_right{
font-size: 10px;
margin-top: 20px;
}



/* スマホのみ======================================================================================================== */
@media screen and (max-width: 750px){

.pc_only{ display: none; }
.sp_only{ }

.sp_float_reset{ float: none; }
.sp_block{ display: block; }

.mt50,.mt60,.mt70,.mt80,.mt90{ margin-top: 40px; } .mt100,.mt150,.mt200{ margin-top: 60px; }
.mr50,.mr60,.mr70,.mr80,.mr90{ margin-right: 40px; } .mr100,.mr150,.mr200{ margin-right: 60px; }
.mb50,.mb60,.mb70,.mb80,.mb90{ margin-bottom: 40px; } .mb100,.mb150,.mb200{ margin-bottom: 60px; }
.ml50,.ml60,.ml70,.ml80,.ml90{ margin-left: 40px; } .ml100,.ml150,.ml200{ margin-left: 60px; }

.pt30,.pt40,.pt50,.pt60{ padding-top: 20px; }
.pr30,.pr40,.pr50,.pr60{ padding-right: 20px; }
.pb30,.pb40,.pb50,.pb60{ padding-bottom: 20px; }
.pl30,.pl40,.pl50,.pl60{ padding-left: 20px; }

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
textarea {
width: 100%;
}
.form_sp_half{
display: flex;
justify-content: space-between;
}
.form_sp_half input{
width: 49%;
}
input.form_sp_90{
width: 90%;
}
.form_address li{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
align-items: center;
}
.form_address li.post{
display: block;
}
.form_address li span{
width: 5em;
}
.form_address li select,
.form_address li input{
flex: 1;
text-align: left;
}
.form_address li .mfp_err{
width: 100%;
}

input.input_sp_auto{
width: auto !important;
}
form #submit_box button,
.mfp_buttons button{
margin: 0 5px;
padding: 15px 30px;
min-width: 150px;
}

.sp_tableflat th,
.sp_tableflat td,
table#mfp_confirm_table tr th,
table#mfp_confirm_table tr td{
display: block;
}
.sp_tableflat th,
table#mfp_confirm_table tr th{
border-bottom: none !important;
padding: 8px 0px 0px !important;
text-align: left !important;
}
.sp_tableflat td,
table#mfp_confirm_table tr td{
padding: 0px 0px 8px !important;
}



}

/* PCのみ======================================================================================================== */
@media print, screen and (min-width: 751px){
body,
table,
input,
textarea{
font-size: 18px;
}
a,
a:link,
a:visited {
-webkit-transition: all 0.2s ease;
-moz-transition: all 0.2s ease;
-o-transition: all 0.2s ease;
-ms-transition: all 0.2s ease;
transition: all 0.2s ease;
}
a:hover {
color: #555;
}
a:active {
color: #555;
}
.opct a:hover,
a.opct:hover,
a:hover img.opct{
opacity: 0.8;
}

.pc_only{ }
.sp_only{ display: none; }

.sp_tel:visited,
.sp_tel:link,
.sp_tel{pointer-events: none; text-decoration: none; }

.pc_float_none{ float: none; }
.pc_f_right{ float: right; }
.pc_f_left{ float: left; }

.pc_display_block{ display: block; }
.pc_table{ display: table; }
.pc_table_cell{ display: table-cell; }

.mt50{ margin-top: 50px; }
.mt60{ margin-top: 60px; }
.mt70{ margin-top: 70px; }
.mt80{ margin-top: 80px; }
.mt90{ margin-top: 90px; }
.mt100{ margin-top: 100px; }
.mt150{ margin-top: 150px; }
.mt200{ margin-top: 200px; }

.mr50{ margin-right: 50px; }
.mr60{ margin-right: 60px; }
.mr70{ margin-right: 70px; }
.mr80{ margin-right: 80px; }
.mr90{ margin-right: 90px; }
.mr100{ margin-right: 100px; }
.mr150{ margin-right: 150px; }
.mr200{ margin-right: 200px; }

.mb50{ margin-bottom: 50px; }
.mb60{ margin-bottom: 60px; }
.mb70{ margin-bottom: 70px; }
.mb80{ margin-bottom: 80px; }
.mb90{ margin-bottom: 90px; }
.mb100{ margin-bottom: 100px; }
.mb150{ margin-bottom: 150px; }
.mb200{ margin-bottom: 200px; }

.ml50{ margin-left: 50px; }
.ml60{ margin-left: 60px; }
.ml70{ margin-left: 70px; }
.ml80{ margin-left: 80px; }
.ml90{ margin-left: 90px; }
.ml100{ margin-left: 100px; }
.ml150{ margin-left: 150px; }
.ml200{ margin-left: 200px; }

.pt50{ padding-top: 50px; }
.pt60{ padding-top: 60px; }

.pr50{ padding-right: 50px; }
.pr60{ padding-right: 60px; }

.pb50{ padding-bottom: 50px; }
.pb60{ padding-bottom: 60px; } 

.pl50{ padding-left: 50px; }
.pl60{ padding-left: 60px; }

.font20px{ font-size: 20px; }
.font22px{ font-size: 22px; }
.font24px{ font-size: 24px; }
.font26px{ font-size: 26px; }
.font28px{ font-size: 28px; }
.font30px{ font-size: 30px; }


.common_btn{
margin-top: 40px;
}
.common_btn a{
display: inline-block;
font-size: 20px;
min-width: 300px;
z-index: 10;
}
.common_btn a:hover{
color: #fff;
background-position: 100% 50%;
transform: scale(1.05);
}


/* 中身 */
#header{
display: flex;
justify-content: space-between;
align-items: center;
}
#header_logo{
margin: 1vw;
}
#header_logo a .icon img{
height: 3vw;
}
#header_logo a p{
font-size: 1.6vw;
}


#fixed_btn{
width: auto;
position: fixed;
bottom: inherit;
top: 50%;
transform: translateY(-50%);
-webkit-transform: translateY(-50%);
margin: auto 0;
}
#fixed_btn a{
flex-direction: column;
align-items: center;
justify-content: center;
width: 60px;
height: 200px;
padding-bottom: 30px;
margin-bottom: 5px;
clip-path: polygon(0 0,100% 0,100% 100%,100% 100%,0 170px);
border-left: solid 1px #fff;
}
#fixed_btn a:hover{
width: 70px;
height: 205px;
padding-bottom: 35px;
margin-bottom: 0px;
padding-right: 10px;
background-color: #e76c0d;
}
#fixed_btn a::after{
width: 67.977937597429px;
left: calc(100% - 60px);
bottom: 30px;
-webkit-transform: rotate(26.188110697481deg);
transform: rotate(26.188110697481deg);
transition: all 0.2s ease;
}
#fixed_btn a:hover::after{
width: 78.262379212493px;
left: calc(100% - 70px);
bottom: 35px;
-webkit-transform: rotate(26.565051177078deg);
transform: rotate(26.565051177078deg);
}
#fixed_btn a .icon img{
width: 28px;
height: auto;
}
#fixed_btn a p{
font-size: 28px;
margin-left: 4px;
margin-top: 10px;
-ms-writing-mode: tb-rl;
writing-mode: vertical-rl;
}




/* グローバルメニュー */
#global_menu{
}
#global_menu_inner{
display: block;
width: auto;
height: auto;
background-color: transparent;
position: inherit;
top: inherit;
left: inherit;
}
#global_menu ul{
height: auto;
flex-direction: row;
}
#global_menu ul li{
width: auto;
font-size: min(1vw,18px);
}
#global_menu ul li a{
border-bottom: none;
padding: 0 1em;
display: grid;
place-items: center;
height: 5vw;
color: rgba(0, 0, 0, .6);
border-left: solid 1px rgba(0, 0, 0, .1);
}
#global_menu ul li a::before{
content: "";
display: block;
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
transition: all 0.2s ease;
z-index: -1;
}
#global_menu ul li a::after{
display: none;
}
#global_menu ul li a:hover{
}
#global_menu ul li a:hover::before{
height: 110%;
background-color: #cb261e;
}
#global_menu ul li a span{
transition: all 0.2s ease;
}
#global_menu ul li a:hover span{
transform: scale(1.1);
color: #fff;
/* text-shadow:0px 0px 10px #fff, 0px 0px 10px #fff, 0px 0px 10px #fff, 0px 0px 10px #fff, 0px 0px 10px #fff; */
}

/* コンテンツ */
#container {
}
#contents {
margin-top: 6vw;
margin-bottom: 12vw;
}
.contents_size{
/* width: 1100px; */
margin-left: 12vw;
margin-right: 12vw;
}

#page_title .en{
font-size: 8vw;
right: -2vw;
}
#page_title h1{
font-size: 3vw;
margin-top: 2.5vw;
}
#page_title .bg img{
height: 25vw;
}

#topic_path{
padding: 5px 5vw;
}

.common_title{
margin-bottom: 2vw;
}
.common_title .en{
font-size: 8vw;
margin-bottom: 2vw;
}
.common_title .en + *,
.common_title h2,
.common_title h3{
font-size: 3vw;
}

.sub_title_mk span{
font-size: 40px;
}



#common_under_btn ul{
display: flex;
justify-content: space-between;
}
#common_under_btn li{
margin-bottom: 0;
width: calc(50% - 1.1vw);
}
#common_under_btn li a{
padding: 6vw 3vw;
position: relative;
}
#common_under_btn li a::before{
content: "";
display: block;
width: 4vw;
height: 100%;
position: absolute;
top: 0;
transition: all 0.2s ease;
}
#common_under_btn li.entry a::before{
background-color: #cb261e;
clip-path: polygon(0 0,100% 0,50% 100%,0 100%);
right: -2vw;
}
#common_under_btn li.interview a::before{
background-color: #857e7a;
clip-path: polygon(50% 0,100% 0,100% 100%,0 100%);
left: -2vw;
}
#common_under_btn li a > *{
transition: all 0.2s ease;
}
#common_under_btn li.entry a .text{ transform-origin: right center; }
#common_under_btn li.entry a .photo{ transform-origin: left bottom; }
#common_under_btn li.interview a .text{ transform-origin: left center; }
#common_under_btn li.interview a .photo{ transform-origin: right bottom; }

#common_under_btn li.entry a:hover,
#common_under_btn li.entry a:hover::before{ background-color: #e76c0d; }
#common_under_btn li.interview a:hover,
#common_under_btn li.interview a:hover::before{ background-color: #aa8976; }

#common_under_btn li a:hover > *{
transform: scale(1.1);
}
#common_under_btn li em{
font-size: 5vw;
}
#common_under_btn li p{
font-size: 1.5vw;
}
#common_under_btn li .photo{
width: auto;
height: 25vw;
position: absolute;
bottom: 0;
}
#common_under_btn li.entry .photo{ left: 3vw; }
#common_under_btn li.interview .photo{ right: -1vw; }




/* main_bottom */
#main_bottom{
margin-bottom: 6vw;
}
#main_bottom #mb_qa{
text-align: center;
}
#main_bottom #mb_qa a{
display: inline-block;
padding: 30px;
background-position: 200% 25%;
background-size: 90% auto;
}
#main_bottom #mb_qa a > *{
display: inline-block;
vertical-align: middle;
}
#main_bottom #mb_qa .icon img{
height: 100px;
}
#main_bottom #mb_qa em{
font-size: 5vw;
padding-right: 30px;
}
#main_bottom #mb_qa em span{
font-size: 2vw;
}
#main_bottom #mb_qa p{
width: auto;
font-size: max(1.2vw,16px);
}



/* フッター */
#footer {
padding-top: 60px;
padding-bottom: 60px;
}
#footer::after{
width: 24vw;
height: 30vw;
bottom: 0;
}

#footer .contents_size{
display: flex;
justify-content: space-between;
align-items: flex-end;
}

#footer_link{
margin-bottom: 0px;
}
#footer_link li{
}

#footer_company{
text-align: right;
margin-right: 14vw;
}
#footer_company dd{
font-size: 14px;
}

#footer_logo a .icon img{
height: 50px;
}
#footer_logo a p{
font-size: 28px;
}

#copy_right{
margin-top: 40px;
}





}


/* GSAP印刷用======================================================================================================== */
@media print{

@page {
	margin: 0mm 5mm;
	size: A4 portrait; /* 横の場合はlandscape */
}
body {
/* zoom: 0.6;
-webkit-print-color-adjust: exact; */
}
#header{
position: absolute;
}
#main_slider h1{
zoom: 0.4;
-webkit-print-color-adjust: exact;
}
.gsap_fade-in,
.gsap_fade-in-bounce,
.gsap_fade-up,
.gsap_fade-up-scrub,
.gsap_fade-down,
.gsap_fade-down-scrub,
.gsap_fade-left,
.gsap_fade-left-scrub,
.gsap_fade-right,
.gsap_fade-right-scrub{
transform: translate(0px, 0px) !important;
opacity: 1 !important;
}

}