@charset "shift-jis";
/* --------------------------------------------------------------------
  Financial Academy

  Style Info      : /event/festival/css/style.css
  Reference File  : /event/festival/index.html
-------------------------------------------------------------------- */
*,*::before,*::after {
  box-sizing: border-box;
}
body {
  font-size: 16px;
}
@media screen and (max-width: 599px) {
  body {
    font-size: 14px;
  }
}

img {
  max-width: 100%;
}

.pc {
  display: inherit;
}
.tab {
  display: none;
}
.sp {
  display: none;
}
.sp_tab {
  display: none;
}
@media screen and (min-width: 600px) {
  .tab_pc {
    display: inherit;
  }
}
@media screen and (max-width: 999px) {
  .pc {
    display: none;
  }
  .tab {
    display: inherit;
  }
  .sp {
    display: none;
  }
  .sp_tab {
    display: inherit;
  }
}
@media screen and (max-width: 599px) {
  .pc {
    display: none;
  }
  .tab {
    display: none ;
  }
  .sp {
    display: inherit;
  }
  .tab_pc {
    display: none;
  }
}

section .inner {
  width: 92%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 80px 0;
}
@media screen and (max-width: 599px) {
  section .inner {
    padding: 50px 0;
  }
}

/* heading_01 */
.heading_01 {
  margin-bottom: 1em;
  color: #1c2569;
  font-size: 45px;
  font-weight: normal;
  text-align: center;
  letter-spacing: 0.1em;
}
.heading_01 .txt_s {
  font-size: 40px;
}
.heading_01 .en {
  display: block;
  font-family: 'Josefin Slab', serif;
  font-size: 40px;
}
@media screen and (max-width: 599px) {
  .heading_01 {
    font-size: 32px;
  }
  .heading_01 .txt_s {
    font-size: 20px;
  }
  .heading_01 .en {
    font-size: 20px;
  }
}

/* button */
.btn_01 {
  display: block;
  position: relative;
  width: 100%;
  max-width: 460px;
  padding: 0.5em 0.5em 0.5em 1.8em;
  background: #4f5cc6;
  border-radius: 10px;
  color: #fff;
  text-align: center;
  letter-spacing: 0.1em;
}
.btn_01::before {
  position: absolute;
  top: 50%;
  left: 1em;
  transform: translateY(-50%);
  content: '>>';
}
.btn_01:hover {
  text-decoration: none;
  opacity: 0.7;
}

/* ------------------------------
mv
------------------------------ */
.mv {
  position: relative;
  min-height: 500px;
  background: url(/event/festival/img/mv.jpg) no-repeat center / cover;
  color: #fff;
  font-family: "Hiragino Mincho ProN W3", "ƒqƒ‰ƒMƒm–¾’© ProN W3", "Hiragino Mincho ProN", "HG–¾’©E", "Ÿà–¾’©", YuMincho, "‚l‚r ‚o–¾’©", "‚l‚r –¾’©", serif;
}
.mv .mv_inner {
  position: absolute;
  top: 50%;
  right: 47.5%;
  transform: translateY(-54%);
}
.mv h1 {
  font-size: 80px;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
.mv h1 .txt_s {
  font-size: 70px;
}
.mv .sub {
  margin-bottom: 0.4em;
  font-size: 40px;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1199px) {
  .mv {
    background-position: center right 15%;
  }
  .mv .mv_inner {
    right: auto;
    left: 2%;
  }
}
@media screen and (max-width: 629px) {
  .mv h1 {
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 599px) {
  .mv {
    min-height: 300px;
  }
  .mv .mv_inner {
    left: 4%;
  }
  .mv h1 {
    font-size: 48px;
  }
  .mv h1 .txt_s {
    font-size: 38px;
  }
  .mv .sub {
    font-size: 25px;
  }
  
}

/* ------------------------------
intro
------------------------------ */
.intro {
  position: relative;
}
.intro::before,
.intro::after {
  position: absolute;
  left: 0;
  width: 100%;
  height: 10px;
  background-image: linear-gradient(to right, rgba(68,161,197,1) 0%,rgba(68,161,197,1) 15%,rgba(94,118,167,1) 15%,rgba(94,118,167,1) 29%,rgba(126,103,141,1) 29%,rgba(126,103,141,1) 43%,rgba(195,99,128,1) 43%,rgba(195,99,128,1) 57%,rgba(225,111,78,1) 57%,rgba(225,111,78,1) 71%,rgba(215,186,65,1) 71%,rgba(215,186,65,1) 85%,rgba(138,159,85,1) 85%,rgba(138,159,85,1) 100%);
  content: '';
}
.intro::before {
  top: 0;
}
.intro::after {
  bottom: 0;
}
.intro p {
  font-size: 20px;
  line-height: 2.5;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 599px) {
  .intro::before,
  .intro::after {
    height: 8px;
  }
  .intro p {
    font-size: 16px;
    line-height: 2;
  }
}

/* ------------------------------
band
------------------------------ */
.band img {
  width: 100%;
}

/* ------------------------------
event_history
------------------------------ */
.event_history {
  background: rgba(28, 37, 105, 0.1);
}
.event_history p {
  letter-spacing: 0.1em;
  line-height: 2.4;
}
.event_history .history_list li + li {
  margin-top: 70px;
}
.event_history .history_list .year {
  font-family: 'Josefin Slab', serif;
  color: #1c2569;
  font-size: 70px;
  line-height: 1;
  letter-spacing: 0.1em;
}
.event_history .history_box {
  padding: 50px 3% 40px;
  background: #fff;
  border: 3px solid #1c2569;
  border-radius: 30px;
  color: #1c2569;
}
.event_history .history_box .img img {
  width: 100%;
  margin-bottom: 10px;
}
.event_history .history_box .link {
  text-decoration: underline;
  color: #1c2569;
  font-weight: bold;
}
.event_history .history_box .link:hover {
  text-decoration: none;
  opacity: 0.8;
}
.event_history .history_box .btn_01 {
  margin-top: 20px;
}
@media screen and (min-width: 600px) {
  .event_history .history_box {
    display: flex;
    justify-content: space-between;
  }
  .event_history .history_box .img {
    width: 43.5%;
  }
  .event_history .history_box .txt {
    width: 53%;
  }
}
@media screen and (max-width: 599px) {
  .event_history .history_list li + li {
    margin-top: 50px;
  }
  .event_history .history_list .year {
    font-size: 50px;
  }
  .event_history .history_box {
    padding: 30px 4% 25px;
  }
  .event_history .history_box .txt {
    margin-top: 0.6em;
  }
}

/* ------------------------------
tail_area
------------------------------ */
.tail_area h2 {
  padding: 0.5em;
  background: #1c2569;
  color: #fff;
  font-size: 20px;
  font-weight: normal;
  text-align: center;
}
.tail_area .cont04 {
  padding: 50px 3%;
  border: 1px solid #1c2569;
  background: #fff;
}
.tail_area p#btn01 a {
  margin: 20px 0 20px;
  background-color: #ea5520;
}
.tail_area .list02 {
  border-top: 1px solid #ACCCE0;
  margin-top: 10px;
  text-align: left;
}
.tail_area .list02 li {
  border-bottom: 1px solid #b4d6eb;
  background: url(/img/fes/parts03.png) no-repeat 0.5em 0.8em;
  background-size:12px;
  padding: 5px 0.5em 5px 2em;
}
@media screen and (max-width: 599px) {
  .tail_area .ar_img {
    display: flex;
  }
  .tail_area .cont04 {
    padding: 30px 2%;
  }
}
