
/* Style for PCs */
@media screen and (min-width: 1025px) {

/* TopSection
----------------------------------------------------------------*/
.topsection {
  width:100%;
  height: 100%;
  display: block;
  aspect-ratio: 8 / 5;
  overflow: hidden;
  position: relative;
  background-image: url(../img/index/topimage-pc.webp);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.ts_cov {
    width:100%;
  height: 100%;
  display: block;
  background-image: url(../img/index/tscov.webp);
  background-repeat: no-repeat;
  background-position: 0 100.1%;
  background-size: 100% auto;
}

.ts_cc {
  width:100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding-bottom: 15%;
  margin:0 auto;
}
.ts_cc h2 {
  font-size: clamp(50px, 4vw, 200px);
  color:var(--color-white);
  font-weight: 800;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  order:2;
}
.ts_cc h3 {
  font-size: clamp(36px, 3vw, 200px);
  color:var(--color-white);
  font-weight: 500;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  line-height: 1.2em;
  margin-bottom:0;
  order:1;
}
.ts_cc h4 {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: baseline;
  font-size: clamp(50px, 3vw, 200px);
  color:var(--color-white);
  font-weight: 300;
  line-height: 1em;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin-bottom:0.3em;
  order:4;
}
.ts_cc h4 span.tsdatetxt {
  font-size: clamp(80px, 3vw, 200px);
}
.ts_cc h4 span.tsdate_s_txt {
  font-size: clamp(35px, 3vw, 100px);
}
.ts_cc h5 {
  font-size: clamp(32px, 3vw, 200px);
  color:var(--color-white);
  font-weight: 300;
  line-height: 1.5em;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin:0 0 0.2em 0;
  order:3;
}
.ts_cc p {
  font-size: clamp(26px, 2vw, 200px);
  color:var(--color-white);
  font-weight: 300;
  letter-spacing: 0em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin-bottom:0em;
  order:5;
}


/* Intro
----------------------------------------------------------------*/
.intromm {
  width:100%;
  height: auto;
  display: block;
  background-image: url(../img/index/intro_bg.webp);
  background-repeat: no-repeat;
  background-position: center 100.1%;
  background-size: 100% auto;
}
.introbody {
  width:100%;
  max-width:1920px;
  height: auto;
  display: block;
  margin:0 auto;
  padding:80px 5% 20% 5%;
}
.introbody h2 {
  font-size: clamp(22px, 1.5vw, 100px);
  font-weight: 400;
  line-height: 1.5em;
  text-align: center;
  color: var(--color-black);
  margin-bottom: 1em;
}
.introbody h2 span {
  font-weight: 700;
  color:var(--color-1st);
}

.eventspec {
  width:80%;
  height: auto;
  display: flex;
  flex-wrap: wrap;
  margin:0 auto 50px;
}
.eventspec dt {
  width:29.9%;
  height: auto;
  display: block;
  text-align: left;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  color:var(--color-1st);
  background-color: rgba(255,255,255,0.5);
  padding:1em 0.5em;
  margin:0.05%;
  box-shadow: 0px 1px 5px rgba(0,0,0,0.1);
}
.eventspec dd {
  width:69.9%;
  height: auto;
  display: block;
  text-align: left;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  color:var(--color-black);
  background-color: rgba(255,255,255,0.5);
  padding:1em 0.5em;
  margin:0.05%;
  box-shadow: 0px 1px 5px rgba(0,0,0,0.1);
}

.eventtable {
  width:80%;
  border-collapse: collapse;
  background-color:  rgba(255,255,255,0.7);
  border:1px solid rgba(0, 0, 0, 0.3);
  margin:0 auto 50px;
}
.eventtable th {
  width:auto;
  padding:10px 0px;
  font-size:14px;
  font-weight: 400;
  line-height: 1.5em;
  color: var(--color-white);
  background-color: var(--color-1st);
  border:1px solid rgba(0, 0, 0, 0.3);
}
.eventtable td {
  width:auto;
  padding:10px 15px;
  font-size:14px;
  font-weight: 400;
  line-height: 1.5em;
  color: var(--color-black);
  border:1px solid rgba(0, 0, 0, 0.3);
}
.eventtable td br {
  display: none;
}

.introbn {
width:80%;
height: auto;
display: flex;
justify-content: center;
margin:0 auto;
}
.introbn li {
  flex:1;
  margin:0 1%;
}
.introbn li a {
  width:100%;
  height: auto;
  display: block;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  text-decoration: none;
  line-height: 1em;
  color: var(--color-white);
  padding:1em 2em 1em 1em;
  border-radius: 5px;
  background-color: var(--color-black);
  background-image: url(../img/header/ic-ar_hr_w.webp);
  background-repeat: no-repeat;
  background-position: 98% center;
  background-size: auto 25px;
  transition: .4s all;
}
.introbn li a:hover {
  background-color: var(--color-1st);
}


/* News
----------------------------------------------------------------*/
.newsmm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
}
.nwbody {
  width:100%;
  max-width:1920px;
  height: auto;
  display: block;
  margin:0 auto;
  padding:10px 5%;
}
.nwtitle {
  width:100%;
  max-width:1920px;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.nwtitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.nwtitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}

/* Galllery
----------------------------------------------------------------*/
.gallerymm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
  background-color: var(--color-fa);
}

.gallerytitle {
  width:100%;
  max-width:1920px;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.gallerytitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.gallerytitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}
.galleryslide li {
  margin:0 0.05%!important;
}
.galleryslide li a {
  width:100%;
  height: auto;
  display: block;
  text-decoration: none;
}
.galleryslide li a .galleryinfo {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: column;
  padding:1.5em 2em 2em 2em;
  background-color: var(--color-white);
}
.galleryslide li a .galleryinfo h3 {
  font-size: clamp(14px, 1.25vw, 40px);
  font-weight: 400;
  line-height: 1.4em;
  color:var(--color-black);
  margin-bottom: 0.5em;
}
.galleryslide li a .galleryinfo p.gal_date {
  font-size: clamp(12px, 1vw, 16px)!important;
  font-weight: 400;
  line-height: 1.25em;
  color:var(--color-1st);
  margin-bottom: 0em;
}
.slide-dots {
  margin: 0 0.5% 0 0;
  padding: 0;
  text-align: center;
}
.slide-dots li {
  display: inline-block;
  margin: 0 0px;
}
.slide-dots li button {
  position: relative;
  text-indent: -9999px;
}
.slide-dots li button::before {
  background-image: url(../img/header/ic-slidedot02.webp);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  cursor: pointer;
  height: 13.5px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 24px;
  width: 30px;
}
.slide-dots li.slick-active button::before {
  background-image: url(../img/header/ic-slidedot01.webp);
}
button {
  background: none;
  border: none;
  outline: none;
  padding: 0 10px;
}

/* Outline
----------------------------------------------------------------*/
.outlinemm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
}
.otbody {
  width:100%;
  max-width:1920px;
  height: auto;
  display: block;
  margin:0 auto;
  padding:10px 5%;
}
.ottitle {
  width:100%;
  max-width:1920px;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.ottitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.ottitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}

ul.linkbanner {
  width:80%;
  height: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin:0 auto;
}
ul.linkbanner li {
  width:30.3333333333%;
  height: auto;
  display: block;
  text-align: center;
  margin:0 1.5% 2%;
}
ul.linkbanner li a {
  width:100%;
  height: auto;
  display: block;
  text-align: center;
  text-decoration: none;
  font-size:16px;
  text-shadow: 0px 2px 5px rgba(0,0,0,0.5);
  font-weight: 500;
  color:var(--color-white);
  line-height: 1.25em;
  padding:1.5em 0em;
  border-radius: 5px;
  box-shadow:0px 5px 10px rgba(0,0,0,0.2)
}
ul.linkbanner li:nth-child(1) a {
background: #090979;
background: linear-gradient(90deg, rgba(9, 9, 121, 1) 0%, rgba(0, 212, 255, 1) 100%);
}
ul.linkbanner li:nth-child(2) a {
background: #2A7B9B;
background: linear-gradient(90deg, rgba(42, 123, 155, 1) 0%, rgba(87, 199, 133, 1) 100%);
}
ul.linkbanner li:nth-child(3) a {
background: #833AB4;
background: linear-gradient(90deg, rgba(131, 58, 180, 1) 0%, rgba(253, 29, 29, 1) 100%);
}
ul.linkbanner li:nth-child(4) a {
background: #02a7c4;
background: linear-gradient(270deg, rgba(2, 167, 196, 1) 0%, rgba(0, 168, 106, 1) 100%);
}
ul.linkbanner li:nth-child(5) a {
background: #7100b3;
background: linear-gradient(90deg, rgba(113, 0, 179, 1) 0%, rgba(0, 181, 154, 1) 100%);
}

}


/* Style for iPad Pro */
@media screen and (min-width: 769px) and (max-width: 1024px) {

/* TopSection
----------------------------------------------------------------*/
.topsection {
  width:100%;
  height: 100%;
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  position: relative;
  background-image: url(../img/index/topimage-pc.webp);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.ts_cov {
    width:100%;
  height: 100%;
  display: block;
  background-image: url(../img/index/tscov.webp);
  background-repeat: no-repeat;
  background-position: 0 100.1%;
  background-size: 100% auto;
}

.ts_cc {
  width:100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding-bottom: 20%;
  margin:0 auto;
}
.ts_cc h2 {
  font-size: 36px;
  color:var(--color-white);
  font-weight: 800;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin-bottom:0.2em;
  order:2;
}
.ts_cc h3 {
  font-size: 28px;
  color:var(--color-white);
  font-weight: 700;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  line-height: 1.2em;
  margin-bottom:0.1em;
  order:1;
}
.ts_cc h4 {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: baseline;
  font-size: 32px;
  color:var(--color-white);
  font-weight: 700;
  line-height: 1em;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin-bottom:0.3em;
  order:4;
}
.ts_cc h4 span.tsdatetxt {
  font-size: 50px;
}
.ts_cc h4 span.tsdate_s_txt {
  font-size: 26px;
  margin-right:0.2em;
}
.ts_cc h5 {
  font-size: 26px;
  color:var(--color-white);
  font-weight: 700;
  line-height: 1.5em;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin:0 0 0.2em 0;
  order:3;
}
.ts_cc p {
  font-size: 22px;
  color:var(--color-white);
  font-weight: 700;
  letter-spacing: 0em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin-bottom:0em;
  order:5;
}


/* Intro
----------------------------------------------------------------*/
.intromm {
  width:100%;
  height: auto;
  display: block;
  background-image: url(../img/index/intro_bg.webp);
  background-repeat: no-repeat;
  background-position: center 100.1%;
  background-size: 100% auto;
}
.introbody {
  width:100%;
  height: auto;
  display: block;
  margin:0 auto;
  padding:80px 5% 20% 5%;
}
.introbody h2 {
  font-size: clamp(22px, 1.5vw, 100px);
  font-weight: 400;
  line-height: 1.5em;
  text-align: center;
  color: var(--color-black);
  margin-bottom: 1em;
}
.introbody h2 span {
  font-weight: 700;
  color:var(--color-1st);
}

.eventspec {
  width:100%;
  height: auto;
  display: flex;
  flex-wrap: wrap;
  margin:0 auto 50px;
}
.eventspec dt {
  width:29.9%;
  height: auto;
  display: block;
  text-align: left;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  color:var(--color-1st);
  background-color: rgba(255,255,255,0.5);
  padding:1em 0.5em;
  margin:0.05%;
  box-shadow: 0px 1px 5px rgba(0,0,0,0.1);
}
.eventspec dd {
  width:69.9%;
  height: auto;
  display: block;
  text-align: left;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  color:var(--color-black);
  background-color: rgba(255,255,255,0.5);
  padding:1em 0.5em;
  margin:0.05%;
  box-shadow: 0px 1px 5px rgba(0,0,0,0.1);
}

.eventtable {
  width:100%;
  border-collapse: collapse;
  background-color:  rgba(255,255,255,0.7);
  border:1px solid rgba(0, 0, 0, 0.3);
  margin:0 auto 50px;
}
.eventtable th {
  width:auto;
  padding:10px 0px;
  font-size:14px;
  font-weight: 400;
  line-height: 1.5em;
  color: var(--color-white);
  background-color: var(--color-1st);
  border:1px solid rgba(0, 0, 0, 0.3);
}
.eventtable td {
  width:auto;
  padding:10px 15px;
  font-size:14px;
  font-weight: 400;
  line-height: 1.5em;
  color: var(--color-black);
  border:1px solid rgba(0, 0, 0, 0.3);
}
.eventtable td br {
  display: none;
}

.introbn {
width:80%;
height: auto;
display: flex;
justify-content: center;
margin:0 auto;
}
.introbn li {
  flex:1;
  margin:0 1%;
}
.introbn li a {
  width:100%;
  height: auto;
  display: block;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  text-decoration: none;
  line-height: 1em;
  color: var(--color-white);
  padding:1em 2em 1em 1em;
  border-radius: 5px;
  background-color: var(--color-black);
  background-image: url(../img/header/ic-ar_hr_w.webp);
  background-repeat: no-repeat;
  background-position: 98% center;
  background-size: auto 25px;
  transition: .4s all;
}
.introbn li a:hover {
  background-color: var(--color-1st);
}


/* News
----------------------------------------------------------------*/
.newsmm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
}
.nwbody {
  width:100%;
  max-width:1920px;
  height: auto;
  display: block;
  margin:0 auto;
  padding:10px 5%;
}
.nwtitle {
  width:100%;
  max-width:1920px;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.nwtitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.nwtitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}

/* Galllery
----------------------------------------------------------------*/
.gallerymm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
  background-color: var(--color-fa);
}

.gallerytitle {
  width:100%;
  max-width:1920px;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.gallerytitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.gallerytitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}
.galleryslide li {
  margin:0 0.05%!important;
}
.galleryslide li a {
  width:100%;
  height: auto;
  display: block;
  text-decoration: none;
}
.galleryslide li a .galleryinfo {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: column;
  padding:1.5em 2em 2em 2em;
  background-color: var(--color-white);
}
.galleryslide li a .galleryinfo h3 {
  font-size: clamp(14px, 1.25vw, 40px);
  font-weight: 400;
  line-height: 1.4em;
  color:var(--color-black);
  margin-bottom: 0.5em;
}
.galleryslide li a .galleryinfo p.gal_date {
  font-size: clamp(12px, 1vw, 16px)!important;
  font-weight: 400;
  line-height: 1.25em;
  color:var(--color-1st);
  margin-bottom: 0em;
}
.slide-dots {
  margin: 0 0.5% 0 0;
  padding: 0;
  text-align: center;
}
.slide-dots li {
  display: inline-block;
  margin: 0 0px;
}
.slide-dots li button {
  position: relative;
  text-indent: -9999px;
}
.slide-dots li button::before {
  background-image: url(../img/header/ic-slidedot02.webp);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  cursor: pointer;
  height: 13.5px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 24px;
  width: 30px;
}
.slide-dots li.slick-active button::before {
  background-image: url(../img/header/ic-slidedot01.webp);
}
button {
  background: none;
  border: none;
  outline: none;
  padding: 0 10px;
}

/* Outline
----------------------------------------------------------------*/
.outlinemm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
}
.otbody {
  width:100%;
  height: auto;
  display: block;
  margin:0 auto;
  padding:10px 5%;
}
.ottitle {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.ottitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.ottitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}

ul.linkbanner {
  width:100%;
  height: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin:0 auto;
}
ul.linkbanner li {
  width:30.3333333333%;
  height: auto;
  display: block;
  text-align: center;
  margin:0 1.5% 2%;
}
ul.linkbanner li a {
  width:100%;
  height: auto;
  display: block;
  text-align: center;
  text-decoration: none;
  font-size:14px;
  text-shadow: 0px 2px 5px rgba(0,0,0,0.5);
  font-weight: 600;
  color:var(--color-white);
  line-height: 1.25em;
  padding:1.5em 0em;
  border-radius: 5px;
  box-shadow:0px 5px 10px rgba(0,0,0,0.2)
}
ul.linkbanner li:nth-child(1) a {
background: #090979;
background: linear-gradient(90deg, rgba(9, 9, 121, 1) 0%, rgba(0, 212, 255, 1) 100%);
}
ul.linkbanner li:nth-child(2) a {
background: #2A7B9B;
background: linear-gradient(90deg, rgba(42, 123, 155, 1) 0%, rgba(87, 199, 133, 1) 100%);
}
ul.linkbanner li:nth-child(3) a {
background: #833AB4;
background: linear-gradient(90deg, rgba(131, 58, 180, 1) 0%, rgba(253, 29, 29, 1) 100%);
}
ul.linkbanner li:nth-child(4) a {
background: #02a7c4;
background: linear-gradient(270deg, rgba(2, 167, 196, 1) 0%, rgba(0, 168, 106, 1) 100%);
}
ul.linkbanner li:nth-child(5) a {
background: #7100b3;
background: linear-gradient(90deg, rgba(113, 0, 179, 1) 0%, rgba(0, 181, 154, 1) 100%);
}

}

/* Style for Smartphone */
@media screen and (max-width: 768px) {

/* TopSection
----------------------------------------------------------------*/
.topsection {
  width:100%;
  height: 100%;
  display: block;
  aspect-ratio: 9 / 16;
  overflow: hidden;
  position: relative;
  background-image: url(../img/index/topimage-pc.webp);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.ts_cov {
    width:100%;
  height: 100%;
  display: block;
  background-image: url(../img/index/tscov.webp);
  background-repeat: no-repeat;
  background-position: 0 100.1%;
  background-size: 100% auto;
}

.ts_cc {
  width:100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding-bottom: 55%;
  margin:0 auto;
}
.ts_cc h2 {
  font-size: 30px;
  color:var(--color-white);
  font-weight: 800;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin-bottom:0.4em;
  order:2;
}
.ts_cc h3 {
  font-size: 24px;
  color:var(--color-white);
  font-weight: 500;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  line-height: 1.2em;
  margin-bottom:0.4em;
  order:1;
}
.ts_cc h4 {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: baseline;
  font-size: 24px;
  color:var(--color-white);
  font-weight: 600;
  line-height: 1em;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin-bottom:0.5em;
  order:4;
}
.ts_cc h4 span.tsdatetxt {
  font-size: 36px;
}
.ts_cc h4 span.tsdate_s_txt {
  font-size: 20px;
}
.ts_cc h5 {
  font-size: 24px;
  color:var(--color-white);
  font-weight: 600;
  line-height: 1.5em;
  letter-spacing: -0.02em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin:0 0 0.4em 0;
  order:3;
}
.ts_cc p {
  font-size: 24px;
  color:var(--color-white);
  font-weight: 700;
  letter-spacing: 0em;
  text-shadow: 0px 0px 8px rgba(0,0,0,0.5);
  margin-bottom:0em;
  order:5;
}

/* Intro
----------------------------------------------------------------*/
.intromm {
  width:100%;
  height: auto;
  display: block;
  background-image: url(../img/index/intro_bg.webp);
  background-repeat: no-repeat;
  background-position: center 100.1%;
  background-size: 100% auto;
}
.introbody {
  width:100%;
  height: auto;
  display: block;
  margin:0 auto;
  padding:80px 5% 30% 5%;
}
.introbody h2 {
  font-size: 20px;
  font-weight: 400;
  line-height: 1.5em;
  text-align: left;
  color: var(--color-black);
  margin-bottom: 1em;
}
.introbody h2 span {
  font-weight: 700;
  color:var(--color-1st);
}
.introbody h2 br {
  display: none;
}

.eventspec {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: column;
  margin:0 auto 50px;
}
.eventspec dt {
  width:100%;
  height: auto;
  display: block;
  text-align: left;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  color:var(--color-1st);
  padding:0 0 5px 0;
  margin:0.05%;
}
.eventspec dd {
  width:100%;
  height: auto;
  display: block;
  text-align: left;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  color:var(--color-black);
  padding:0 0 1em 0;
  border-bottom: 1px dotted var(--color-999);
  margin:0 0 1em 0;
}

.eventtable {
  width:100%;
  border-collapse: collapse;
  background-color:  rgba(255,255,255,0.7);
  border:1px solid rgba(0, 0, 0, 0.3);
  margin:0 auto 50px;
}
.eventtable th {
  width:auto;
  padding:10px 0px;
  font-size:12px;
  font-weight: 400;
  line-height: 1.5em;
  color: var(--color-white);
  background-color: var(--color-1st);
  border:1px solid rgba(0, 0, 0, 0.3);
}
.eventtable td {
  width:auto;
  padding:10px 5px;
  font-size:12px;
  font-weight: 400;
  line-height: 1.5em;
  color: var(--color-black);
  border:1px solid rgba(0, 0, 0, 0.3);
}
.eventtable tr>td:first-child {
  white-space: nowrap;
}

.introbn {
width:100%;
height: auto;
display: flex;
flex-direction: column;
margin:0 auto;
}
.introbn li {
  width:100%;
  height: auto;
  display: block;
  margin:0 0 10px 0;
}
.introbn li a {
  width:100%;
  height: auto;
  display: block;
  font-size: clamp(14px, 1.25vw, 20px);
  font-weight: 400;
  line-height: 1.5em;
  text-decoration: none;
  line-height: 1em;
  color: var(--color-white);
  padding:1em 2em 1em 1em;
  border-radius: 5px;
  background-color: var(--color-black);
  background-image: url(../img/header/ic-ar_hr_w.webp);
  background-repeat: no-repeat;
  background-position: 98% center;
  background-size: auto 25px;
  transition: .4s all;
}
.introbn li a:hover {
  background-color: var(--color-1st);
}


/* News
----------------------------------------------------------------*/
.newsmm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
}
.nwbody {
  width:100%;
  max-width:1920px;
  height: auto;
  display: block;
  margin:0 auto;
  padding:10px 5%;
}
.nwtitle {
  width:100%;
  max-width:1920px;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.nwtitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.nwtitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}

/* Galllery
----------------------------------------------------------------*/
.gallerymm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
  background-color: var(--color-fa);
}

.gallerytitle {
  width:100%;
  max-width:1920px;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.gallerytitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.gallerytitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}
.galleryslide li {
  margin:0 0.05%!important;
}
.galleryslide li a {
  width:100%;
  height: auto;
  display: block;
  text-decoration: none;
}
.galleryslide li a .galleryinfo {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: column;
  padding:1.5em 2em 2em 2em;
  background-color: var(--color-white);
}
.galleryslide li a .galleryinfo h3 {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4em;
  color:var(--color-black);
  margin-bottom: 0.5em;
}
.galleryslide li a .galleryinfo p.gal_date {
  font-size: 11px;
  font-weight: 400;
  line-height: 1.25em;
  color:var(--color-1st);
  margin-bottom: 0em;
}
.slide-dots {
  margin: 0 0.5% 0 0;
  padding: 0;
  text-align: center;
}
.slide-dots li {
  display: inline-block;
  margin: 0 0px;
}
.slide-dots li button {
  position: relative;
  text-indent: -9999px;
}
.slide-dots li button::before {
  background-image: url(../img/header/ic-slidedot02.webp);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  cursor: pointer;
  height: 13.5px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 24px;
  width: 30px;
}
.slide-dots li.slick-active button::before {
  background-image: url(../img/header/ic-slidedot01.webp);
}
button {
  background: none;
  border: none;
  outline: none;
  padding: 0 10px;
}

/* Outline
----------------------------------------------------------------*/
.outlinemm {
  width:100%;
  height: auto;
  display: block;
  padding:80px 0 100px;
}
.otbody {
  width:100%;
  height: auto;
  display: block;
  margin:0 auto;
  padding:10px 5%;
}
.ottitle {
  width:100%;
  height: auto;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding:0 5%;
  margin:0 auto 30px;
}
.ottitle h2 {
font-size: clamp(14px, 1.5vw, 40px);
color:var(--color-1st);
margin-bottom: 0em;
order:2;
}
.ottitle p {
font-size: clamp(30px, 3vw, 200px);
font-family: var(--font-en);
font-weight: 700;
color:var(--color-black);
letter-spacing: -0.05em;
margin-bottom: 0.1em;
order:1;
}

ul.linkbanner {
  width:100%;
  height: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin:0 auto;
}
ul.linkbanner li {
  width:100%;
  height: auto;
  display: block;
  text-align: center;
  margin:0 0 10px;
}
ul.linkbanner li a {
  width:100%;
  height: auto;
  display: block;
  text-align: center;
  text-decoration: none;
  font-size:14px;
  text-shadow: 0px 1px 5px rgba(0,0,0,0.5);
  font-weight: 600;
  color:var(--color-white);
  line-height: 1.25em;
  padding:1em 0em;
  border-radius: 3px;
  box-shadow:0px 2px 6px rgba(0,0,0,0.2)
}
ul.linkbanner li:nth-child(1) a {
background: #090979;
background: linear-gradient(90deg, rgba(9, 9, 121, 1) 0%, rgba(0, 212, 255, 1) 100%);
}
ul.linkbanner li:nth-child(2) a {
background: #2A7B9B;
background: linear-gradient(90deg, rgba(42, 123, 155, 1) 0%, rgba(87, 199, 133, 1) 100%);
}
ul.linkbanner li:nth-child(3) a {
background: #833AB4;
background: linear-gradient(90deg, rgba(131, 58, 180, 1) 0%, rgba(253, 29, 29, 1) 100%);
}
ul.linkbanner li:nth-child(4) a {
background: #02a7c4;
background: linear-gradient(270deg, rgba(2, 167, 196, 1) 0%, rgba(0, 168, 106, 1) 100%);
}
ul.linkbanner li:nth-child(5) a {
background: #7100b3;
background: linear-gradient(90deg, rgba(113, 0, 179, 1) 0%, rgba(0, 181, 154, 1) 100%);
}


}
