@charset "utf-8";
 #kanagawa-100-selection a, #referrel-section a {
position: relative;
max-width: 450px;
display: flex;
justify-content: center;
align-items: center;
margin: 0 auto;
}
#kanagawa-100-selection a:after, #referrel-section a:after {
content: "";
width: 100%;
height: 100%;
background: #0B5796;
opacity: .2;
top: 10px;
left: 10px;
position: absolute;
transition: .3s;
z-index: -1;
}
#kanagawa-100-selection a img, #referrel-section a img {
border: 1px solid #0B5796;
background: #fff;
}
#kanagawa-100-selection a:hover, #referrel-section a:hover {
opacity: 1;
}
#kanagawa-100-selection a:hover:after, #referrel-section a:hover:after {
top: 0;
left: 0;
}
@media only screen and ( max-width : 767px ) {
#kanagawa-100-selection, #referrel-section {
margin-bottom: 60px;
}
#kanagawa-100-selection a, #referrel-section a {
max-width: 70vw;
}
}
@media print, screen and ( min-width : 768px ) {
#kanagawa-100-selection, #referrel-section {
margin-bottom: 100px;
}
} #covid19 a {
display: flex;
align-items: center;
justify-content: center;
background: #0B5796;
color: #fff;
margin: 0 auto;
position: relative;
}
#covid19 a:after {
content: "";
width: 100%;
height: 100%;
background: #0B5796;
opacity: .2;
top: 10px;
left: 10px;
position: absolute;
z-index: 1;
transition: .3s;
}
#covid19 a span {
border-bottom: 1px solid #fff;
position: relative;
z-index: 2;
}
#covid19 a:hover {
opacity: 1;
}
#covid19 a:hover:after {
top: 0;
left: 0;
}
@media only screen and ( max-width : 767px ) {
#covid19 {
margin-bottom: 60px;
}
#covid19 a {
width: 100%;
height: 70px;
}
}
@media print, screen and ( min-width : 768px ) {
#covid19 {
margin-bottom: 100px;
}
#covid19 a {
width: 550px;
height: 80px;
font-size: 18px;
}
} #mv .slide_target {
pointer-events: none;
}
#mv {
position: relative;
}
.mv_copy {
position: absolute;
color: #fff;
z-index: 10;
width: 100%;
height: 100%;
top: 0;
left: 0;
transition: 2s;
}
.mv_copy .mv_title {
width: 100%;
}
.mv_copy p {
text-align: center;
line-height: 1.8em;
text-shadow: 0 0 10px rgba(0,0,0,.75);
}
.slider li img {
width: 100%;
}
.scrolldown {
display: inline-block;
position: absolute;
left: 50%;
bottom: 0;
z-index: 2;
padding: 10px 10px 80px;
overflow: hidden;
color: #fff;
font-size: 13px;
line-height: 1;
text-transform: uppercase;
text-decoration: none;
transform: translateX(-50%);
}
.scrolldown::after {
content: '';
position: absolute;
bottom: 0;
left: 50%;
width: 1px;
height: 70px;
background: #0B5796;
}
.scrolldown::after {
animation: sdl 2s cubic-bezier(1, 0, 0, 1) infinite;
}
@keyframes sdl {
0% {
transform: scale(1, 0);
transform-origin: 0 0;
}
30% {
transform: scale(1, 1);
transform-origin: 0 0;
}
70% {
transform: scale(1, 1);
transform-origin: 0 100%;
}
100% {
transform: scale(1, 0);
transform-origin: 0 100%;
}
}
.main_movie {
position: relative;
width: 100vw;
height: 100vh;
overflow: hidden;
}
.main_movie:before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0,0,0,.37);
z-index: 1;
}
.main_movie video {
display: block;
position: absolute;
top: 50%;
left: 50%;
transform: translateX(-50%) translateY(-50%);
min-width: 100%;
min-height: 100%;
}
@media only screen and ( max-width : 991px ) {
}
@media only screen and ( max-width : 767px ) {
#mv .main_movie {
display: none;
}
.main_movie video {
width: 110%;
}
.main_movie {
height: 62vw;
}
.mv_copy .mv_title {
padding: 0 20px 40px;
text-align: left;
}
.mv_copy .mv_title img {
max-width: 70%;
}
.slider li img {
}
.scrolldown {
padding: 10px 10px 25px;
font-size: 10px;
}
.scrolldown::after {
height: 25px;
}
}
@media only screen and ( max-width : 767px ) and ( max-height: 1100px ) {
}
@media only screen and ( max-width : 320px ) {
}
@media only screen and ( max-width : 375px ) and ( max-height: 580px ) {
}
@media print, screen and ( min-width : 768px ) {
#mv .slider {
display: none;
}
.mv_copy .mv_title {
padding-bottom: 100px;
padding-right: 40px;
}
.mv_copy .mv_title {
text-align: right;
}
.mv_copy .mv_title img {
max-width: 54%;
}
}
@media print, screen and ( min-width : 992px ) {
.slider li img {
height: 100vh;
}
}
@media print, screen and ( min-width : 1200px ) {
.mv_copy .mv_title {
padding-right: 100px;
}
} #vision .container {
position: relative;
}
.vision_content { display: flex;
align-items: center;
justify-content: center;
position: relative;
z-index: 11;
}
.vision_content.fadein__active {
transition-delay: 4s;
}
.vision_txt {
background: rgba(11,87,150,.2);
}
.vision_txt h2 {
color: #0B5796;
text-align: center;
letter-spacing: .15em;
}
.vision_txt .vision_lead {
text-align: center;
letter-spacing: .2em;
line-height: 1.4em;
}
.vision_txt .vision_lead span {
display: block;
letter-spacing: .05em;
line-height: 1;
margin-top: .8em;
}
.vision_txt .viewmore {
text-align: center;
font-size: 13px;
}
.top_vision_photo {
position: absolute;
}
.top_vision_photo01 {
top: 0;
left: 0;
width: 30%;
z-index: 1;
}
.top_vision_photo02 {
left: 23%;
top: 8%;
width: 18%;
z-index: 2;
}
.top_vision_photo03 {
left: 54%;
width: 14%;
top: 0;
z-index: 4;
}
.top_vision_photo04 {
width: 26%;
z-index: 3;
right: 0;
top: 0;
}
.top_vision_photo05 {
width: 16%;
z-index: 2;
left: 68%;
top: 16%;
z-index: 4;
}
.top_vision_photo06 {
left: 12%;
bottom: 28%;
width: 18%;
z-index: 3;
}
.top_vision_photo07 {
width: 24%;
left: 0;
bottom: 2%;
z-index: 2;
}
.top_vision_photo08 {
width: 18%;
left: 28%;
bottom: 2%;
z-index: 4;
}
.top_vision_photo09 {
width: 30%;
bottom: 0;
right: 16%;
z-index: 4;
}
.top_vision_photo10 {
z-index: 5;
width: 18%;
right: 0;
bottom: 8%;
}
.vision_white_mask {
background: rgba(255,255,255,.65);
position: absolute;
top: -10%;
left: -10%;
width: 120%;
height: 120%;
z-index: 6;
}
.vision_white_mask.fadein__active {
transition-delay: 3s;
}
@media only screen and ( max-width : 991px ) {
#vision .container {
padding-top: 14vw;
padding-bottom: 14vw;
}
}
@media only screen and ( max-width : 767px ) {
#vision .container {
padding-top: 8vw;
padding-bottom: 8vw;
}
.top_vision_photo06 {
bottom: 20%;
}
.vision_txt {
width: 80%;
padding: 30px 20px;
}
.vision_txt h2 {
font-size: 14px;
margin-bottom: 30px;
}
.vision_txt .vision_lead {
font-size: 18px;
margin-bottom: 30px;
}
.vision_txt .vision_lead span {
font-size: 13px;
}
.vision_txt .viewmore {
font-size: 13px;
width: 160px;
}
}
@media print, screen and ( min-width : 768px ) {
.vision_txt {
padding: 6vw;
width: 76%;
}
.vision_txt h2 {
font-size: 2vw;
margin-bottom: 6vw;
}
.vision_txt .vision_lead {
font-size: 3vw;
margin-bottom: 6vw;
}
.vision_txt .vision_lead span {
font-size: 2.2vw;
}
}
@media print, screen and ( min-width : 992px ) {
#vision .container {
max-width: 960px;
padding-top: 100px;
padding-bottom: 100px;
}
}
@media print, screen and ( min-width : 1300px ) {
.vision_txt {
padding: 60px 50px 100px;
width: 60%;
}
.vision_txt h2 {
font-size: 16px;
margin-bottom: 50px;
}
.vision_txt .vision_lead {
font-size: 28px;
margin-bottom: 50px;
}
.vision_txt .vision_lead span {
font-size: 18px;
}
} #service {
position: relative;
}
#service .container {
position: relative;
z-index: 10;
}
#service:after {
content: "";
width: 100%;
left: 0;
bottom: 0;
background: #0B5796;
z-index: 1;
position: absolute;
}
#service .menu {
display: flex;
flex-wrap: wrap;
}
#service .menu .sub-menu {
display: none;
}
#service li a {
color: #fff;
display: block;
position: relative;
border-bottom: 1px solid #fff;
padding-bottom: .3em;
}
#service li a::before,
#service li a::after {
position: absolute;
top: 50%;
right: .2em;
content: '';
margin-top: -5px;
border: 7px solid transparent;
border-top-width: 5px;
border-bottom-width: 5px;
border-left-color: #fff;
}
#service li a::after {
opacity: 0;
right: 1em;
}
#service li a:hover::before {
animation: arrowbefore .5s;
}
#service li a:hover::after {
animation: arrowafter .5s;
}
@keyframes arrowbefore {
100% {
right: -.4em;
opacity: 0;
}
}
@keyframes arrowafter {
99% {
right: .2em;
opacity: 1;
}
100% {
opacity: 0;
}
}
@media only screen and ( max-width : 767px ) {
#service {
padding-bottom: 50px;
}
#service:after {
height: 70%;
}
#service picture {
margin-top: 20px;
margin-bottom: 20px;
}
#service li {
width: 48%;
margin-right: 4%;
margin-top: 10px;
}
#service li:nth-child(2n) {
margin-right: 0;
}
}
@media print, screen and ( min-width : 768px ) {
#service {
padding-bottom: 100px;
}
#service:after {
height: 60%;
}
#service picture {
margin-top: 50px;
margin-bottom: 50px;
position: relative;
margin-right: calc(50% - 50vw);
}
#service li {
width: 48%;
margin-right: 2%;
margin-top: 2%;
font-size: 1.4vw;
}
#service li:last-child {
margin-right: 0;
}
.servicemenu {
margin-right: calc(50% - 50vw);
padding-right: 25px;
}
}
@media print, screen and ( min-width : 992px ) {
#service li {
font-size: 14px;
}
}
@media print, screen and ( min-width : 1200px ) {
.servicemenu {
padding-right: 50px;
}
} .stre_txt {
background: #000;
color: #fff;
position: relative;
display: flex;
align-items: flex-end;
}
.stre_txt h2 {
-ms-writing-mode: tb-rl;
writing-mode: vertical-rl;
letter-spacing: .1em;
position: absolute;
}
@media only screen and ( max-width : 991px ) {
.stre_txt h2 {
font-size: 24px;
top: 30px;
right: 20px;
}
.stre_txt {
min-height: 400px;
padding: 40px 30px;
}
.stre_txt p {
margin-bottom: 20px;
}
}
@media only screen and ( max-width : 767px ) {
.stre_txt h2 {
font-size: 24px;
}
.stre_txt {
min-height: 250px;
}
}
@media print, screen and ( min-width : 768px ) {
.stre_txt h2 {
font-size: 48px;
}
}
@media print, screen and ( min-width : 992px ) {
.stre_ph {
width: 56%;
}
.stre_txt {
width: 44%;
padding: 40px 30px;
}
.stre_txt h2 {
font-size: 48px;
top: 40px;
right: 30px;
}
.stre_txt p {
margin-bottom: 30px;
}
}
@media print, screen and ( min-width : 1200px ) {
.stre_txt h2 {
top: 60px;
right: 50px;
}
.stre_txt {
padding: 60px 50px;
}
} @media only screen and ( max-width : 767px ) {
}
@media print, screen and ( min-width : 768px ) {
}