@charset "utf-8";
.pc{display:block;}
.sp{display:none;}
.slick-slide{
    height: auto!important;
    -webkit-backface-visibility: hidden;
    -webkit-transform-style: preserve-3d;
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    vertical-align: baseline
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block
}
html {
  scroll-behavior: smooth;
}

body {
    line-height: 1
}

ol,
ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

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

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

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

select {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    text-indent: 0.01px;
    text-overflow: '';
    border-radius: 0;
    border: 0;
    margin: 0;
    padding: 0;
    background: none transparent;
    vertical-align: middle;
    color: inherit;
    box-sizing: content-box
}

select::-ms-expand {
    display: none
}

input,
textarea {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    border-radius: 0
}

input:focus,
textarea:focus {
    box-shadow: none;
    outline: none
}

em {
    font-style: normal
}

main {
    display: block
}

html,
body {
    height: 100%;
    width: 100%
}

html {
    font-size: 62.5%
}

body {
    min-width: 1100px;
    background: #fff;
    font-size: 1.6rem;
    font-weight: 400;
    color: #111;
    line-height: 1.75;
    -moz-text-size-adjust: none;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

* {
    box-sizing: border-box
}

img {
    vertical-align: bottom
}

#pagetop {
    width: 100%
}

.wrapper {
    width: 1100px;
    margin: 0 auto
}

h1 {
    max-width: 1500px;
    margin: 0 auto;
}

h1 img {
    width: 100%;
}

.header {
    padding-top: 0;
    padding-right: 0;
    padding-bottom: 0;
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
}

.nav {
    position: sticky;
    top: 0;
    width: 100%;
    background: #002395;
    z-index: 99
}

.nav ul {
    width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0
}

.nav ul li {
    border-right: #6d8dde 1px solid;
    flex-grow: 1
}

.nav ul li:first-child {
    border-left: #6d8dde 1px solid
}

/*.nav ul li:first-child a:hover::after {
    content: "\f0d8";
    bottom: auto;
    top: 0
}*/

.nav ul li a {
    padding: 10px 40px;
    text-align: center;
    color: #fff;
    text-decoration: none;
    font-size: 1.6rem;
    font-weight: 700;
    display: block;
    position: relative
}

.nav ul li a:hover {
    color: #6d8dde;
}

/*.nav ul li a:hover::after {
    font-size: 1.4rem;
    line-height: 1;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f0d7";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    color: #2c52b5
}*/

.outline {
    width: 900px;
    margin: -40px auto 0;
    padding: 110px 0 0;
}

.outline__text {
    width: 100%;
    margin-bottom: 70px;
    font-size: 1.8rem;
    line-height: 2 !important;
    font-weight: 500;
    text-align: justify;
    text-justify: inter-ideograph;
    font-feature-settings: "palt"
}

.outline__text .quote {
    margin-top: 15px;
    background: #f7f7f7;
    padding: 25px 40px;
    width:80%;
    margin: 40px auto;
    display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}

.outline__text .quote .quote__qr img {
height:160px;
}

.double {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: stretch;
    width: 1100px;
    margin: 0 auto;
    padding-bottom: 50px;
}

.title {
    color: #000;
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.2;
    padding:10px 0;
    position: relative;
    display: inline-block;
    
    margin:0 auto 50px;
    display:block;
    text-align:center;
}

.title::before {
    content: '';
    position: absolute;
    bottom: -15px;
    display: inline-block;
    width: 60px;
    height: 5px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #ed2939;
    border-radius: 2px;
}

.column .title {
    width: 600px
}

.title span {
    font-size: 1.4rem
}

.workList {
    padding-top: 80px;
    margin-top: -40px
}

.workList .wrapper {
    padding-bottom: 0
}

.workList__outer {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: stretch;
    width: 1100px;
    margin: 0 auto
}

.workList__inner {
    width: 47%
}

.workList__inner__w {
    width: 100% !important
}

.workList__inner:first-child {
    width: 47%
}

.workList__inner .workList__item:first-child {
    margin-top: 0
}

.workList__item {
    margin: 30px auto 50px
}

.workList__item .list_credit {
    width: 100%
}

.workList__title {
    font-size: 1.8rem;
    font-weight: 400;
    color: #000;
    line-height: 1;
    padding-bottom: 10px;
    border-bottom: #000 1px solid
}

.workList__sub {
    margin-top: 10px
}

.workList__title2 {
    font-size: 1.4rem;
    font-weight: 400;
    color: #000;
    line-height: 1
}

.workList__title2::before {
    content: "ー";
    padding-right: 5px
}

.workList .list {
    margin-top: 10px
}

.workList .list li {
    line-height: 1.5;
    font-size: 1.6rem;
    font-weight: 700
}

.workList .list li span {
    font-size: 1.2rem;
    font-weight: 400
}

.profile {
    width: 100%;
    padding-top: 0;
    margin: 0 auto 0;
}

.profile p {
    font-size: 1.4rem;
    line-height: 1.4
}

.profile__name {
    font-size: 2rem;
    font-weight: 700;
    color: #000;
    line-height: 1
}

.profile__shoulder {
    margin-top: 0;
    margin-bottom: 10px;
    font-size: 1.2rem;
    color: #000;
    line-height: 1
}

.profile__text {
    margin-top: 20px;
    font-size: 1.6rem;
    color: #000;
    text-align: justify;
    text-justify: inter-ideograph;
    font-feature-settings: "palt"
}

.profile__text a {
    color: #2c52b5
}

.profile__text a:hover {
    text-decoration: none
}

.profile__btn {
    margin-top: 15px;
    font-size: 1.6rem
}

.profile__btn a {
    color: #000;
    text-decoration: none;
    font-weight: 500
}

.profile__btn a:hover {
    text-decoration: underline
}

.tour {
    width: 1100px;
    margin: 0 auto 30px;
    padding: 0;
}

.tour__table {
    width: 100%;
    margin-top: 30px
}

.tour__table thead th {
    background: #f2f2f2;
    font-size: 1.2rem;
    padding: 5px 15px;
    /*text-align: left*/
}

.tour__table tbody td {
    border-bottom: #ccc 1px solid;
    font-size: 1.8rem;
    padding: 30px 10px
}

.tour__table tbody td:first-child {
    white-space: nowrap
}

.tour__table tbody td a {
    background: #000;
    border: #000 2px solid;
    color: #fff;
    border-radius: 100px;
    display: block;
    text-decoration: none;
    text-align: center;
    font-size: 1.2rem;
    padding: 5px;
    width: 150px;
    margin: 0 auto;
    transition: background 0.2s ease;
    white-space: nowrap
}

.tour__table tbody td a:hover {
    background: #fff;
    color: #000
}

.tour__table tbody td a.nolink {
    border-color: #ccc;
    background: #ccc;
    pointer-events: none
}

.works {
    width: 1100px;
    margin: 40px auto 0;
    padding: 0 0 50px;
}

.works .description {
    margin: 30px 0 40px;
}

.works__section:first-of-type .works__program {
    margin-top: 0
}

.works__program {
    font-size: 2.2rem;
    font-weight: 700;
    color: #002395;
    margin-top: 60px;
    border-bottom: #2c52b5 2px solid;
    line-height: 1.5;
    margin-bottom: 20px;
    padding: 10px 5px
}

.works__program__sub {
    font-size: 1.6rem;
    font-weight: 700;
    color: #111;
    margin-top: 20px;
    background: #f2f2f2;
    padding: 5px 10px
}

.works .workinfo {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: stretch;
    margin-top: 20px;
    padding-bottom: 20px;
    border-bottom: #ccc 1px solid
}

.works .workinfo__img {
    width: 450px
}

.works .workinfo__img img {
    width: 100%;
    height: auto
}

.works .workinfo__img figcaption {
    font-size: 1rem
}

.works .workinfo__textArea {
    width: 620px
}

.works .workinfo__textArea p {
    margin-top: 10px;
    text-align: justify;
    text-justify: inter-ideograph;
    font-feature-settings: "palt";
    line-height: 1.5
}

.works .workinfo__title {
    font-size: 2.4rem;
    font-weight: 700;
    color: #002395;
    line-height: 1.1;
}

.works .workinfo__title span {
    vertical-align: middle;
}

.works .workinfo__title__eng {
    font-size: 1.4rem;
    font-style: italic;
    margin-top: 10px;
    margin-bottom: 0px;
    color: #666
}

.works .workinfo__data {
    font-size: 1.2rem;
    line-height: 1.5;
    margin-bottom: 15px
}

.works .workinfo__profile {
    padding: 25px;
    background: #f7f7f7
}

.works .workinfo__profile__name {
    font-size: 1.6rem;
    font-weight: 700;
    color: #111
}

.works .workinfo__profile__name span {
    font-size: 1.2rem;
    padding-left: 0.5em
}

.works .workinfo__profile p {
    font-size: 1.4rem
}

.works .workinfo__profile .quote {
    margin: 20px 0 20px;
    background: #f7f7f7;
    padding: 30px 40px 20px;
    font-size: 1.4rem
}

.works .workinfo__profile .quote__name {
    margin-top: 10px;
    text-align: right
}

.works .workinfo .quote {
    margin-top: 15px;
    background: #f7f7f7;
    padding: 15px 20px;
    font-size: 1.3rem
}

.works .workinfo .quote__name {
    margin-top: 5px;
    text-align: right
}

.works .workinfo__note {
    font-size: 1.2rem;
    margin-top: 1em
}

.column {
    width: 800px;
    margin: -40px auto 0;
    padding: 80px 0 50px
}

.column__name {
    margin: 10px 0 40px;
    font-size: 2rem;
    font-weight: 700;
    text-align: right;
    padding-right: 10px
}

.column__text {
    line-height: 2em
}

.column__text p:not(:first-child) {
    margin-top: 2em
}

.footer {
    background: #002395;
    padding: 60px 0 100px
}

.footer__img {
    text-align: center;
    width:400px;
    margin:0 auto;
}

.footer .share {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    line-height: 0;
    font-size: 1.4rem;
    color: #fff;
    margin-bottom: 40px
}

.footer .share li {
    margin: 0 8px
}

.footer .share li img {
    width: 60px
}

/*add 20211002*/

.tour h2.move-mv {
    font-size: 2.4rem;
    font-weight: 700;
    margin: 50px 0 0;
    font-feature-settings: 'palt' 1;
}

.profile__link {
    margin-top: 25px;
    text-align: center
}

.profile__link a {
    display: inline-block;
    width: 400px;
    max-width: 90%;
    height: 60px;
    line-height: 56px;
    color: #fff;
    font-size: 1.6rem;
    text-align: center;
    border-radius: 100px;
    text-decoration: none;
    border: 2px solid
}

.profile__link a:hover {
    background: #fff !important
}

.profile__link a.mdlc03 {
    background: #000;
    border-color: #000
}

.profile__link a.mdlc03:hover {
    color: #000
}

.profile__textArea {
    margin: 15px 0;
    font-size: 1.4rem;
    line-height: 1.75;
    padding: 25px 0
}

.profile .title {
    width: 100%;
}

.works .workinfo__profile {
    border: #ccc 1px solid;
    margin: 50px 0;
    padding: 30px 40px;
    background: #fff;
}

.montserrat {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.4rem;
    color: #999;
    letter-spacing: 0.15em;
}

.program {
    background: #fff;
    color: #002395;
    border: 1px solid #002395;
    font-size: 1rem !important;
    padding: 2px 5px;
    margin-left: 1em;
    margin-right: 8px;
}

.program__bg {
    background: #002395;
    color: #fff;
    border: 1px solid #002395;
}

.workList .list .program {
    background: #fff;
    color: #002395;
    border: 1px solid #002395;
    font-size: 1.0rem !important;
    padding: 2px 5px;
    margin-right: 5px;
}

.workList .list .program__bg {
    background: #002395;
    color: #fff;
    border: 1px solid #002395;
}

.flex {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}

.workinfo__profile .flex {
    flex-direction: row-reverse;
}

.works .workinfo__profile .flex p {
    width: 90%;
}

.workinfo__profile.top_intro {
    border: #ccc 1px solid;
    margin: 0 -20px 0;
    padding: 18px 32px;
    background: #fff;
}

.workinfo__profile.top_intro .workinfo__profile__name {
    font-size: 1.6rem;
    font-weight: 700;
    color: #111
}

.credit {
    background: #fff;
    color: #000;
    border: 1px solid #000;
    font-size: 1rem !important;
    line-height: 1.4;
    padding: 1px 3px;
    margin-right: 8px;
}

.list_credit {
    font-size: 1.2rem !important;
}

.footer .workList__item {
    color: #fff;
    width: 470px;
    margin: 0;
}

.footer .workList__item .list_credit {
    width: 100% !important;
}

.footer .credit {
    background: transparent;
    color: #fff;
    border: 1px solid #fff;
    font-size: 1rem !important;
    line-height: 1.4;
    padding: 1px 3px;
    margin-right: 8px;
}


.pagetop {
position:relative;
z-index:1;
}
.button-wrap {
position:absolute;
z-index:999;
bottom:40px;
right: calc(50% - 630px); /* 画面の中心から右に20pxの位置 */
  transform: translate(-50%, -50%); /* 要素自身の幅・高さの50%分、左上方向に移動して中央揃え */
}

.circular-button {
    display: flex; /* Flexboxを使って中央揃え */
    justify-content: center;
    align-items: center;
    width: 150px; /* ボタンの幅 */
    height: 150px; /* ボタンの高さ */
    border-radius: 50%; /* 円形にする */
    background-color: #000;
    color: #fff;
    text-decoration: none;
    text-align: center; /* テキストを中央揃え */
    font-size: 2.2rem;
    font-weight: bold;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s ease, transform 0.2s ease;
    overflow: hidden;
    padding: 10px;
    box-sizing: border-box;
    line-height: 1.4;
    flex-direction: column; /* テキストを縦に並べる */
}

.circular-button:hover {
    background-color: #ed2939; /* ホバー時の背景色 */
    transform: translateY(-2px); /* 少し上に移動 */
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
}

.circular-button span {
    display: block; /* 各行をブロック要素にする */
    white-space: nowrap; /* テキストの折り返しを防ぐ */
}

.footer__sponsorship {
margin-bottom:40px;
display: -webkit-flex;
display: flex;
-webkit-justify-content: center;
justify-content: center;
-webkit-align-items: center;
	align-items: center;
}
.footer__sponsorship_logo {
text-align:center;
margin-left:20px;
}
.footer__sponsorship_logo img {
width:77px;
margin:4px 0;
}
.footer__logo {
text-align:center;
margin-bottom:30px;
}
.footer__logo img {
height:100px;
margin:0 8px;
}

.w90 {
    width: 90%;
    margin: 0 auto;
}