@charset "UTF-8";
/* --------------------------------------------------------- */
/* index.css */
/* --------------------------------------------------------- */
#wrap { background: url(../img/bg.jpg) repeat-y top center; background-size: 100% auto; position: relative; overflow: hidden; }

.section { width: 100%; margin: 0 auto; }

.content { width: 100%; margin: 0 auto; }

.layer { width: 100%; max-width: 960px; margin: 0 auto; }

.sp { display: none; }

a { display: block; color: inherit; }

span { color: inherit; }

img { width: 100%; height: auto; }

/* KV
----------------------- */
/* メイン
----------------------- */
#mainContents { width: calc(100% - 30px); max-width: 980px; margin: 0 auto; padding: 0 15px; }
#mainContents * { color: #474747; }

/* title */
#goTopBtn { position: fixed; right: 10px; bottom: 10px; z-index: 100; display: none; }
#goTopBtn a { width: 80px; height: 40px; display: block; background: #474747; color: #FFF; border-radius: 50%; text-align: center; vertical-align: bottom; text-decoration: none; font-size: 12px; font-weight: bold; padding-top: 40px; }
#goTopBtn a:after { content: ""; position: absolute; right: 0; left: 0; top: 20px; margin: auto; display: block; width: 10px; height: 10px; border-top: 2px solid #FFF; border-right: 2px solid #FFF; transform: rotate(-45deg); }

#goHomeBtn { text-align: center; }
#goHomeBtn a { width: 200px; display: block; border: 1px solid #707070; border-radius: 26px; line-height: 46px; margin: 0 auto; position: relative; font-size: 18px; font-weight: bold; text-decoration: none; padding-left: 20px; }
#goHomeBtn a img { position: absolute; width: 20px; top: 13px; left: 36px; }
#goHomeBtn a:hover, #goHomeBtn a:focus { background: #FFF; color: #036666; transition: 1s; }

h1 { font-size: 36px; font-weight: bold; color: #FFF !important; padding: 15px 10px; background: #036666; position: relative; vertical-align: middle; border-radius: 50px; text-align: center; margin: 130px 0 30px; }
h1 span { position: absolute; left: 16px; top: 16px; width: 50px; height: 50px; display: inline-block; color: #036666 !important; background: #FFF; text-align: center; line-height: 50px; font-size: 0.80em; vertical-align: text-top; border-radius: 50%; }

/* ACTION */
#pageNavi ul { display: flex; flex-wrap: wrap; flex-direction: row; justify-content: space-between; }
#pageNavi ul.flexcenter { justify-content: center; }
#pageNavi ul.flexcenter li { margin-right: 4%; }
#pageNavi ul.flexcenter li:nth-child(2) { margin-right: 0; }
#pageNavi ul li { width: 21%; }
#pageNavi ul li .compName { font-size: 14px; margin-bottom: 20px; height: 4em; display: flex; justify-content: center; align-items: center; text-align: center; font-weight: bold; }
#pageNavi ul li a { width: 100%; padding-top: 100%; display: block; background: #FFF; position: relative; border-radius: 50%; box-shadow: 3px 6px 10px #CCC; }
#pageNavi ul li a img { width: 60%; position: absolute; top: 0; bottom: 0; left: 0; right: 0; margin: auto; transition: 1s; }
#pageNavi ul li a:after { content: ""; position: absolute; right: 0px; left: 0; bottom: 20px; margin: auto; display: block; width: 8px; height: 8px; border-top: 2px solid #999999; border-right: 2px solid #999999; transform: rotate(135deg); }
#pageNavi ul li a:hover img { transform: translateY(-10px) scale(1.1); transition: 1s; }
#pageNavi ul li a:hover:after { border-top: 2px solid #036666; border-right: 2px solid #036666; transition: 1s; }

.action-container { background: #FFF; padding: 180px 60px 60px; position: relative; margin-top: 220px; }
.action-container .company-logo { position: absolute; top: -120px; left: 0; right: 0; margin: 0 auto; width: 240px; height: 240px; display: flex; align-items: center; background: #FFF; border-radius: 50%; box-shadow: 3px 6px 10px #CCC; }
.action-container .company-logo img { width: 60%; margin: auto; }
.action-container h2 { text-align: center; font-size: 36px; margin-bottom: 30px; }
.action-container .action-catch { text-align: center; font-size: 24px; margin-bottom: 30px; }
.action-container .action-movie { margin-bottom: 40px; width: 100%; aspect-ratio: 16 / 9; }
.action-container .action-movie iframe { width: 100%; height: 100%; }
.action-container iframe { border: none; }
.action-container .interview { display: flex; margin-bottom: 40px; font-size: 18px; }
.action-container .interview .interview-txt { width: calc(100% - 360px); margin-right: 40px; }
.action-container .interview .interview-txt .question { color: #036666 !important; margin-bottom: 1em; font-weight: bold; }
.action-container .interview .interview-txt .answer { line-height: 2.0; }
.action-container .interview .interview-img { width: 320px; }
.action-container .interview .interview-img img { width: 100%; height: auto; margin-bottom: 10px; }
.action-container .interview .interview-img .img-caption { text-align: center; }
.action-container .interview.caseStudy { display: block; }
.action-container .interview.caseStudy .interview-txt { width: 100%; margin-right: 0px; }
.action-container .interview.caseStudy .interview-txt .question { margin-bottom: 0; }
.action-container:last-child { margin-bottom: 100px; }

/* 他の取り組み */
#otherActionList { width: calc(100% - 40px); max-width: 1240px; padding: 20px; margin: 30px auto; }
#otherActionList h2 { font-size: 24px; text-align: center; margin-bottom: 40px; }

#action-list-navi { margin-bottom: 40px; }
#action-list-navi ul { display: flex; flex-wrap: wrap; flex-direction: row; justify-content: space-between; }
#action-list-navi ul li { border-radius: 20px; width: 31%; margin-bottom: 30px; }
#action-list-navi ul li a { display: block; padding: 0 5px; color: #FFF; position: relative; font-size: 19px; text-decoration: none; font-weight: bold; line-height: 40px; vertical-align: middle; border: 1px solid #036666; background: #036666; border-radius: 20px; transition: all 1s ease; }
#action-list-navi ul li a:after { content: ""; position: absolute; right: 18px; top: 0; bottom: 0; margin: auto; display: block; width: 8px; height: 8px; border-top: 2px solid #FFF; border-right: 2px solid #FFF; transform: rotate(45deg); transition: all 1s ease; }
#action-list-navi ul li a.active, #action-list-navi ul li a:hover, #action-list-navi ul li a:focus { color: #036666; background: #FFF; }
#action-list-navi ul li a.active:after, #action-list-navi ul li a:hover:after, #action-list-navi ul li a:focus:after { border-top: 2px solid #036666; border-right: 2px solid #036666; }
#action-list-navi ul li a.active span, #action-list-navi ul li a:hover span, #action-list-navi ul li a:focus span { color: #FFF; background: #036666; }
#action-list-navi ul li a.active { cursor: default; }
#action-list-navi ul li a.active:after { display: none; }
#action-list-navi ul li a.casestudise { padding: 0 48px; }
#action-list-navi ul li span { font-size: 0.9em; width: 30px; height: 30px; display: inline-block; background: #FFF; color: #036666; margin-right: 10px; text-align: center; line-height: 30px; border-radius: 50%; transition: all 1s ease; }

/* 県民のみなさまへのメッセージ */
#message { background: #188295; /*21b0c9*/ position: relative; }
#message:after { content: ''; display: block; width: 100%; max-width: 1200px; padding-top: 670px; background: url(../img/bg-message.png) no-repeat bottom center; background-size: 100% auto; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); z-index: 0; }
#message h2 { width: 64.48%; margin: 0 auto; padding: 7.292% 0 4.167%; }
#message .txt { width: calc(100% + 1em); margin-left: -0.5em; padding-bottom: 12.5%; color: #fff; font-size: 2rem; line-height: 220%; position: relative; z-index: 1; }

#kids { width: 100%; margin: 0; position: relative; z-index: 1; }
#kids p { width: 100%; margin: 0; }

#carousel { position: relative; z-index: 1; }
#carousel .carousel-sp { display: none; }

/* フッター
----------------------- */
#footer { background: #2d2d2d; }
#footer a:focus { border: 1px solid #fff; }
#footer .layer:before { content: ''; display: block; padding-top: 2.084%; }
#footer .policywrap { padding: 3.125%; box-sizing: border-box; background: #525252; }
#footer .policy { height: 130px; overflow-y: scroll; }
#footer .policy p, #footer .policy li { color: #fff; font-size: 1.5rem; padding-left: 1em; box-sizing: border-box; position: relative; }
#footer .policy p span, #footer .policy li span { position: absolute; left: 0; }
#footer .policy a { display: inline; word-break: break-all; text-decoration: underline; }
#footer .policy a:hover { text-decoration: none; }
#footer .policy .head { margin-top: 1em; font-weight: bold; }
#footer .policy .head:first-of-type { margin-top: 0; }
#footer .sitepolicy { padding: 2.084% 0; font-size: 1.6rem; line-height: 100%; text-align: center; }
#footer .sitepolicy a { display: inline; color: #fff; text-align: center; text-decoration: underline; }
#footer .sitepolicy a:hover { text-decoration: none; }
#footer .accessibility { width: 100%; padding: 2.084% 3.125%; border: 1px dotted #fff; box-sizing: border-box; }
#footer .accessibility .head { color: #fff; font-size: 1.5rem; font-weight: bold; line-height: 146%; text-align: center; }
#footer .accessibility .txt { margin-top: 0.5em; color: #fff; font-size: 1.5rem; line-height: 146%; }
#footer .accessibility .txt a { display: inline; word-break: break-all; }
#footer .last { padding: 1.563% 0; display: flex; flex-wrap: wrap; justify-content: space-between; }
#footer .post { color: #fff; font-size: 1.2rem; }
#footer .cr { color: #fff; font-size: 1.2rem; }
#footer .sns { width: 100%; margin-top: 1.563%; text-align: center; }
#footer .sns li { width: 3.125%; display: inline-block; margin: 0 0.3125%; }

@media screen and (max-width: 1300px) { .layer { width: 92%; }
  #action-list-navi ul li a { font-size: 16px; }
  /* 県民のみなさまへのメッセージ */
  #message:after { padding-top: 51.539%; }
  #message .txt { font-size: 1.539vw; }
  /* フッター ----------------------- */
  #footer .policy p, #footer .policy li { font-size: 1.154vw; }
  #footer .policy a:hover { text-decoration: none; }
  #footer .sitepolicy { font-size: 1.231vw; }
  #footer .accessibility .head { font-size: 1.154vw; }
  #footer .accessibility .txt { font-size: 1.154vw; }
  #footer .post, #footer .cr { font-size: 0.924vw; } }
@media screen and (max-width: 1200px) { #movie #company #action-list-navi ul li { width: 48%; } }
@media screen and (max-width: 750px) { .pc { display: none; }
  .sp { display: block; }
  /* KV ----------------------- */
  /* メイン ----------------------- */
  h1 { font-size: 14px; padding: 5px 10px; line-height: 30px; margin: 50px 0 25px; }
  h1 span { width: 32px; height: 32px; line-height: 32px; top: 4px; left: 4px; }
  #pageNavi { max-width: 500px; width: 100%; margin: 0 auto; justify-content: space-around; }
  #pageNavi ul li { width: 48%; margin-bottom: 40px; }
  #pageNavi ul li a { width: 85%; padding-top: 85%; margin: 0 auto; }
  #pageNavi ul li .compName { font-size: 13px; margin-bottom: 10px; }
  .action-container { padding: 30vw 30px 30px; margin-top: 30vw; }
  .action-container .company-logo { width: 40vw; height: 40vw; top: -20vw; }
  .action-container h2 { font-size: 24px; margin-bottom: 10px; }
  .action-container .action-catch { font-size: 18px; }
  .action-container .interview { display: block; }
  .action-container .interview .interview-txt { width: 100%; margin-right: 0; margin-bottom: 20px; }
  .action-container .interview .interview-txt .question, .action-container .interview .interview-txt .answer { font-size: 18px; }
  .action-container .interview .interview-img { width: 80%; margin: 0 auto 30px; }
  .action-container:last-child { margin-bottom: 30vw; }
  #action-list-navi ul li a { font-size: 16px; }
  /* 県民のみなさまへのメッセージ */
  #message:after { width: 100%; padding-top: 80%; background-image: url(../img/sp-bg-message.png); }
  #message h2 { width: 100.435%; margin: 0 auto -0.2175; padding: 10.145% 0 4.348%; }
  #message .txt { width: 100%; padding-bottom: 7.247%; font-size: 4.267vw; line-height: 192%; }
  #carousel .carousel-pc { display: none; }
  #carousel .carousel-sp { display: block; }
  /* フッター ----------------------- */
  #footer .layer:before { padding-top: 7.247%; }
  #footer .policy { height: 34.667vw; }
  #footer .policy p, #footer .policy li { font-size: 2.934vw; }
  #footer .policy a:hover { text-decoration: underline; }
  #footer .policywrap { padding: 4.348%; }
  #footer .sitepolicy { padding: 1em 0; font-size: 2.934vw; }
  #footer .accessibility { padding: 4.348%; border-width: 4px; border-left: none; position: relative; }
  #footer .accessibility:before { content: ''; display: block; width: 4px; height: calc(100% + 8px); border-right: 4px dotted #fff; position: absolute; top: -4px; left: 0; box-sizing: border-box; }
  #footer .accessibility .head { font-size: 2.934vw; }
  #footer .accessibility .txt { font-size: 2.934vw; line-height: 163%; }
  #footer .last { padding: 4.348% 0; justify-content: center; }
  #footer .post { font-size: 2.667vw; text-align: center; }
  #footer .cr { font-size: 2.667vw; text-align: center; }
  #footer .sns { margin-top: 4.348%; }
  #footer .sns li { width: 8.696%; margin: 0 1.16%; } }
@media screen and (max-width: 980px) { #action-list-navi ul li { width: 48%; } }
@media screen and (max-width: 750px) { #action-list-navi ul li { width: 100%; font-size: 16px; margin-bottom: 15px; } }
@media screen and (max-width: 580px) { #action-list-navi ul { max-width: 290px; margin: 0 auto; }
  #action-list-navi ul li { margin-bottom: 10px; }
  #action-list-navi ul li a { font-size: 12px; line-height: 30px; }
  #action-list-navi ul li span { width: 24px; height: 24px; line-height: 24px; font-size: 12px; } }
