@charset "UTF-8";
.common-btn-type1 a {
  display: inline-block;
  width: 200px;
  height: 50px;
  border-radius: 40px;
  position: relative;
  transition: .5s; }
  @media (min-width: 1024px) {
    .common-btn-type1 a {
      width: 240px;
      height: 54px; } }
  .common-btn-type1 a.long {
    width: 260px;
    height: 60px; }
    @media (min-width: 1024px) {
      .common-btn-type1 a.long {
        width: 400px;
        height: 80px; } }
  .common-btn-type1 a.color1 {
    background-color: #fff;
    border: 2px solid #F7F7F7; }
    .common-btn-type1 a.color1 svg #ya {
      fill: none;
      stroke: #fff;
      stroke-width: 2px; }
    .common-btn-type1 a.color1 svg #maru {
      fill: #bc1b21; }
  .common-btn-type1 a.color2 {
    background-color: #BC1B21;
    border: 2px solid #BC1B21; }
    .common-btn-type1 a.color2 svg #ya {
      fill: none;
      stroke: #bc1b21;
      stroke-width: 2px; }
    .common-btn-type1 a.color2 svg #maru {
      fill: #fff; }
  .common-btn-type1 a:hover.color1 {
    background-color: #BC1B21; }
    .common-btn-type1 a:hover.color1 #ya {
      stroke: #BC1B21; }
    .common-btn-type1 a:hover.color1 #maru {
      fill: #fff; }
  .common-btn-type1 a:hover p.color1 {
    color: #fff; }
  .common-btn-type1 a:hover.color2 {
    background-color: #fff; }
    .common-btn-type1 a:hover.color2 #ya {
      stroke: #fff; }
    .common-btn-type1 a:hover.color2 #maru {
      fill: #BC1B21; }
  .common-btn-type1 a:hover p.color2 {
    color: #BC1B21; }
  .common-btn-type1 a p {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 0.85em;
    font-weight: 700;
    line-height: 1.0em;
    color: #BC1B21;
    display: flex;
    align-items: center;
    height: 100%;
    padding-left: 30px; }
    @media (min-width: 1024px) {
      .common-btn-type1 a p {
        font-size: 1.0em; } }
    .common-btn-type1 a p.color1 {
      color: #BC1B21; }
    .common-btn-type1 a p.color2 {
      color: #fff; }
  .common-btn-type1 a svg {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 8px;
    display: flex;
    align-items: center;
    height: 100%;
    transition: .5s;
    width: 38px; }

.common-btn-type2 a {
  display: flex;
  align-items: center; }
  .common-btn-type2 a:hover .txt::after {
    transform-origin: left top;
    transform: scale(1, 1); }
  .common-btn-type2 a .txt {
    display: flex;
    align-items: center;
    position: relative; }
    .common-btn-type2 a .txt.alalink {
      color: #BC1B21; }
      .common-btn-type2 a .txt.alalink::after {
        background: #BC1B21; }
    .common-btn-type2 a .txt.white {
      color: #fff; }
      .common-btn-type2 a .txt.white::after {
        background: #fff; }
    .common-btn-type2 a .txt.black {
      color: #000; }
      .common-btn-type2 a .txt.black::after {
        background: #000; }
    .common-btn-type2 a .txt p {
      font-size: 0.9em;
      font-weight: 700;
      line-height: 1.2em;
      position: relative; }
    .common-btn-type2 a .txt img {
      width: 15px; }
    .common-btn-type2 a .txt::after {
      position: absolute;
      bottom: 0;
      left: 0;
      content: '';
      width: 100%;
      height: 1px;
      transform: scale(0, 1);
      transform-origin: right top;
      transition: transform .3s; }
  .common-btn-type2 a img {
    width: 15px;
    margin-left: 6px; }

.news-common-title {
  display: flex;
  width: 350px; }
  .news-common-title h2 {
    font-family: "Anton", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2.0em;
    line-height: 1.0em;
    color: #BC1B21; }
    @media (min-width: 1024px) {
      .news-common-title h2 {
        font-size: 4.25em; } }
  .news-common-title .archive {
    display: flex;
    align-items: center;
    margin: 4px 0 0 10px; }
    @media (min-width: 768px) {
      .news-common-title .archive {
        margin: 8px 0 0 10px; } }
    @media (min-width: 1024px) {
      .news-common-title .archive {
        margin: 26px 0 0 10px; } }
    .news-common-title .archive h3 {
      font-size: 1.25em;
      line-height: 1.2em;
      color: #BC1B21; }
      @media (min-width: 1024px) {
        .news-common-title .archive h3 {
          font-size: 1.56em; } }
    .news-common-title .archive .common-btn-type2 {
      margin: 4px 0 0 10px; }

.common-midashi.white {
  color: #fff; }
.common-midashi.alared {
  color: #BC1B21; }
.common-midashi h1 {
  font-size: 2.0em;
  line-height: 1.0em; }
  @media (min-width: 1024px) {
    .common-midashi h1 {
      font-size: 2.5em; } }
  @media (min-width: 1250px) {
    .common-midashi h1 {
      font-size: 3.0em; } }
.common-midashi h2 {
  font-family: "Anton", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.5em;
  line-height: 1.0em; }
  @media (min-width: 1024px) {
    .common-midashi h2 {
      font-size: 3.0em; } }
  @media (min-width: 1250px) {
    .common-midashi h2 {
      font-size: 4.25em; } }
.common-midashi h6 {
  font-size: 0.7em;
  color: #C7BDB6;
  margin-top: 2px; }
  @media (min-width: 1024px) {
    .common-midashi h6 {
      font-size: 0.8em; } }
.common-midashi h3 {
  font-size: 1.1em;
  margin-top: 2px; }
  @media (min-width: 1024px) {
    .common-midashi h3 {
      font-size: 1.25em; } }
  @media (min-width: 1250px) {
    .common-midashi h3 {
      font-size: 1.5em;
      margin-top: 5px; } }
.common-midashi h4 {
  font-size: 0.8em;
  margin-top: 4px; }
  @media (min-width: 1024px) {
    .common-midashi h4 {
      font-size: 1.125em;
      margin-top: 0; } }
@media (min-width: 1024px) {
  .common-midashi .txt {
    display: flex;
    align-items: flex-end; } }

.post-data {
  display: flex;
  align-items: center; }
  .post-data h4 {
    color: #fff;
    display: inline-block;
    text-align: center;
    font-size: 0.8em;
    border-radius: 50px;
    padding: 4px 10px 4px;
    background-color: #BC1B21;
    margin-right: 6px; }
  .post-data h5 {
    font-family: "Anton", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.125em;
    color: #BC1B21;
    margin-top: 2px; }

/*
---------------------------------------------------------------------------------------------------------------------
右下スクロールで表示するボタン
---------------------------------------------------------------------------------------------------------------------
*/
#you-come {
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 99;
  opacity: 0;
  transform: translateY(100px); }
  #you-come a {
    background: linear-gradient(100deg, #C65F3A, #A61A1D);
    width: 230px;
    height: 60px;
    border-top-left-radius: 20px;
    display: flex;
    position: relative; }
    @media (min-width: 768px) {
      #you-come a {
        height: 80px;
        width: 275px; } }
    @media (min-width: 1250px) {
      #you-come a {
        height: 100px; } }
    #you-come a .entry-btn {
      display: flex;
      align-items: center; }
      #you-come a .entry-btn .entry-btn-in {
        color: #fff;
        padding-left: 20px; }
        #you-come a .entry-btn .entry-btn-in p {
          font-size: 0.8em;
          font-weight: bold; }
          @media (min-width: 768px) {
            #you-come a .entry-btn .entry-btn-in p {
              font-size: 0.9em; } }
        #you-come a .entry-btn .entry-btn-in h2 {
          font-size: 1.25em;
          font-weight: bold;
          margin-top: 0; }
          @media (min-width: 768px) {
            #you-come a .entry-btn .entry-btn-in h2 {
              font-size: 1.5em;
              margin-top: 5px; } }
    #you-come a img {
      position: absolute;
      top: 0;
      bottom: 0;
      right: 10px;
      width: 12px;
      margin: auto;
      vertical-align: bottom;
      transition: .5s; }
    #you-come a:hover img {
      right: 5px; }

#you-come.UpMove {
  animation: UpAnime 0.5s forwards; }

@keyframes UpAnime {
  from {
    opacity: 0;
    transform: translateY(60px); }
  to {
    opacity: 1;
    transform: translateY(0); } }
@media (min-width: 768px) {
  @keyframes UpAnime {
    from {
      opacity: 0;
      transform: translateY(100px); }
    to {
      opacity: 1;
      transform: translateY(0); } } }
/*　下に下がる動き　*/
#you-come.DownMove {
  animation: DownAnime 0.5s forwards; }

@keyframes DownAnime {
  from {
    opacity: 1;
    transform: translateY(0); }
  to {
    opacity: 1;
    transform: translateY(60px); } }
@media (min-width: 768px) {
  @keyframes DownAnime {
    from {
      opacity: 1;
      transform: translateY(0); }
    to {
      opacity: 1;
      transform: translateY(100px); } } }
/*
---------------------------------------------------------------------------------------------------------------------
お知らせ
---------------------------------------------------------------------------------------------------------------------
*/
#news {
  margin: auto;
  padding: 0 0 40px; }
  @media (min-width: 1024px) {
    #news {
      padding: 60px 0 120px; } }
  #news .news-common-title {
    padding: 0 0 0 4%;
    margin-bottom: 15px;
    width: auto; }
    @media (min-width: 768px) {
      #news .news-common-title {
        padding: 0 0 0 3%;
        margin-bottom: 20px; } }
  #news .news-card {
    padding: 0 0 0 4%;
    position: relative;
    overflow: hidden;
    width: 100%; }
    @media (min-width: 768px) {
      #news .news-card {
        padding: 0 0 0 3%; } }
    #news .news-card .common-post-box a:hover .iCatch > img {
      transform: scale(1.04); }
    #news .news-card .common-post-box a:hover .txt > h3 {
      color: #BC1B21; }
    #news .news-card .common-post-box a .iCatch {
      position: relative;
      border-radius: 10px;
      overflow: hidden;
      display: block;
      z-index: 1; }
      #news .news-card .common-post-box a .iCatch img {
        border-radius: 10px;
        transition-duration: 0.8s;
        transform: scale(1); }
    #news .news-card .common-post-box a .txt {
      margin-top: 10px; }
      @media (min-width: 1250px) {
        #news .news-card .common-post-box a .txt .post-data-1 {
          display: flex;
          align-items: center; } }
      #news .news-card .common-post-box a .txt .post-data-1 .category {
        font-size: 0.7em;
        font-weight: 500;
        color: #BB9F7F; }
        @media (min-width: 1024px) {
          #news .news-card .common-post-box a .txt .post-data-1 .category {
            font-size: 0.8em;
            margin-left: 10px; } }
      #news .news-card .common-post-box a .txt h3 {
        font-size: 1.0em;
        line-height: 1.4em;
        font-feature-settings: "palt";
        letter-spacing: 0.08em;
        margin-top: 4px;
        transition: .5s;
        word-break: break-all;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden; }
        @media (min-width: 768px) {
          #news .news-card .common-post-box a .txt h3 {
            font-size: 1.125em;
            margin-top: 10px; } }

.news-card {
  /* 前へ次への矢印カスタマイズ */ }
  .news-card .swiper-slide {
    width: 220px;
    margin: 0 15px 0 0; }
    @media (min-width: 768px) {
      .news-card .swiper-slide {
        width: 255px; } }
    @media (min-width: 1250px) {
      .news-card .swiper-slide {
        width: 330px;
        margin: 0 30px 0 0; } }
    .news-card .swiper-slide:last-child {
      margin-right: 3%; }
  .news-card .swiper-button-prev,
  .news-card .swiper-button-next {
    top: 30%; }
    @media (min-width: 768px) {
      .news-card .swiper-button-prev,
      .news-card .swiper-button-next {
        top: 28%; } }
    @media (min-width: 1250px) {
      .news-card .swiper-button-prev,
      .news-card .swiper-button-next {
        top: 33%; } }

/*
---------------------------------------------------------------------------------------------------------------------
高橋翼が語る
---------------------------------------------------------------------------------------------------------------------
*/
#top-talk {
  padding-top: 40px; }
  @media (min-width: 1024px) {
    #top-talk {
      display: flex; } }
  #top-talk .top-talk-title {
    background-color: #BC1B21;
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 90%;
    padding: 14px; }
    @media (min-width: 1024px) {
      #top-talk .top-talk-title {
        width: 210px; } }
    #top-talk .top-talk-title .top-talk-title-in {
      display: flex;
      align-items: center;
      justify-content: center; }
      @media (min-width: 1024px) {
        #top-talk .top-talk-title .top-talk-title-in {
          display: block; } }
      #top-talk .top-talk-title .top-talk-title-in .title {
        width: 80px;
        text-align: center; }
        @media (min-width: 1024px) {
          #top-talk .top-talk-title .top-talk-title-in .title {
            width: 120px; } }
      #top-talk .top-talk-title .top-talk-title-in h3 {
        font-size: 1.25em;
        color: #fff;
        margin: 0 0 0 20px; }
        @media (min-width: 1024px) {
          #top-talk .top-talk-title .top-talk-title-in h3 {
            font-size: 1.75em;
            writing-mode: vertical-rl;
            margin: 60px auto 0; } }
        #top-talk .top-talk-title .top-talk-title-in h3 .border {
          border-bottom: 3px solid  #fff; }
          @media (min-width: 1024px) {
            #top-talk .top-talk-title .top-talk-title-in h3 .border {
              border-bottom: none;
              border-right: 3px solid  #fff; } }
  #top-talk .talk-card {
    padding: 0 0 0 40px;
    position: relative;
    overflow: hidden;
    margin-top: 20px;
    /* 前へ次への矢印カスタマイズ */ }
    @media (min-width: 1024px) {
      #top-talk .talk-card {
        margin-top: 0; } }
    #top-talk .talk-card .swiper-button-prev,
    #top-talk .talk-card .swiper-button-next {
      top: 50%; }
    #top-talk .talk-card .swiper-slide {
      width: 240px;
      margin: 0 15px 0 0; }
      @media (min-width: 1024px) {
        #top-talk .talk-card .swiper-slide {
          width: 260px; } }
      @media (min-width: 1250px) {
        #top-talk .talk-card .swiper-slide {
          width: 360px;
          margin: 0 30px 0 0; } }
      #top-talk .talk-card .swiper-slide:last-child {
        margin-right: 3%; }
    @media (min-width: 1024px) {
      #top-talk .talk-card {
        width: calc(100% - 210px); } }
    #top-talk .talk-card .talk-box {
      position: relative;
      background-color: #BC1B21;
      border-radius: 10px;
      padding: 20px 0 0 0; }
      @media (min-width: 1024px) {
        #top-talk .talk-card .talk-box {
          padding: 30px 0 0 0; } }
      #top-talk .talk-card .talk-box a .talk-ue h3 {
        font-size: 1.0em;
        text-align: center;
        color: #fff; }
        @media (min-width: 1024px) {
          #top-talk .talk-card .talk-box a .talk-ue h3 {
            font-size: 1.25em; } }
        #top-talk .talk-card .talk-box a .talk-ue h3 .border {
          border-bottom: 3px solid  #fff; }
      #top-talk .talk-card .talk-box a .talk-ue .title {
        width: 90%;
        margin: 20px auto 0; }
      #top-talk .talk-card .talk-box a .talk-ue .video-play-button {
        position: relative;
        top: inherit;
        margin-top: 20px; }
        @media (min-width: 1024px) {
          #top-talk .talk-card .talk-box a .talk-ue .video-play-button {
            margin-top: 40px; } }
      #top-talk .talk-card .talk-box a .talk-ue h6 {
        font-size: 0.7em;
        line-height: 1.2em;
        text-align: center;
        color: #fff; }
        @media (min-width: 1024px) {
          #top-talk .talk-card .talk-box a .talk-ue h6 {
            padding-top: 10px; } }
      #top-talk .talk-card .talk-box a .photo {
        width: 80%;
        margin: auto; }
      #top-talk .talk-card .talk-box .common-btn-type1 {
        position: absolute;
        bottom: 20px;
        left: 0;
        right: 0;
        text-align: center; }
        @media (min-width: 1024px) {
          #top-talk .talk-card .talk-box .common-btn-type1 {
            bottom: 40px; } }

/*
---------------------------------------------------------------------------------------------------------------------
採用情報はこちら
---------------------------------------------------------------------------------------------------------------------
*/
#recruit {
  position: relative;
  background: linear-gradient(90deg, #C65F3A, #A61A1D);
  width: 90%;
  margin: auto;
  padding-top: 40px;
  overflow: hidden;
  border-radius: 20px;
  height: 340px; }
  @media (min-width: 768px) {
    #recruit {
      width: 94%;
      height: auto;
      padding-top: 20px; } }
  @media (min-width: 1250px) {
    #recruit {
      padding-top: 60px; } }
  #recruit .photo {
    position: absolute;
    bottom: 0;
    z-index: 10; }
    @media (min-width: 768px) {
      #recruit .photo {
        position: relative; } }
    #recruit .photo ul {
      display: flex;
      justify-content: space-evenly; }
      #recruit .photo ul li {
        width: 50%; }
        @media (min-width: 1250px) {
          #recruit .photo ul li {
            width: 35%; } }
        #recruit .photo ul li:first-child {
          padding-left: 15px; }
          @media (min-width: 768px) {
            #recruit .photo ul li:first-child {
              padding: 0 60px 0 0; } }
        #recruit .photo ul li:last-child {
          padding-right: 15px; }
          @media (min-width: 768px) {
            #recruit .photo ul li:last-child {
              padding: 0 0 0 60px; } }
  #recruit #Scroll {
    position: absolute;
    bottom: 17%;
    display: flex; }
    @media (min-width: 768px) {
      #recruit #Scroll {
        top: -12%;
        bottom: 0; } }
    @media (min-width: 1450px) {
      #recruit #Scroll {
        top: 0; } }
    #recruit #Scroll .YokoScroll {
      display: flex;
      align-items: center; }
      #recruit #Scroll .YokoScroll ul {
        display: flex;
        animation: loop-slide 200s infinite linear 1s both; }
        #recruit #Scroll .YokoScroll ul li {
          width: 800px; }
          @media (min-width: 1024px) {
            #recruit #Scroll .YokoScroll ul li {
              width: 1800px; } }
@keyframes loop-slide {
  from {
    transform: translateX(0); }
  to {
    transform: translateX(-100%); } }
  #recruit .recruit-btn {
    text-align: center;
    z-index: 10; }
    @media (min-width: 768px) {
      #recruit .recruit-btn {
        position: absolute;
        bottom: 12%;
        left: 0;
        right: 0; } }
    @media (min-width: 1250px) {
      #recruit .recruit-btn {
        bottom: 15%; } }
    #recruit .recruit-btn h3 {
      font-size: 1.56em;
      color: #fff; }
    #recruit .recruit-btn .common-btn-type1 {
      margin-top: 20px; }
      @media (min-width: 1024px) {
        #recruit .recruit-btn .common-btn-type1 {
          margin-top: 30px; } }

/*
---------------------------------------------------------------------------------------------------------------------
動画ボタン
---------------------------------------------------------------------------------------------------------------------
*/
.video-play-button {
  position: absolute;
  z-index: 10;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  box-sizing: content-box;
  display: block;
  padding: 18px 20px 18px 28px;
  transition: 0.5S; }

.video-play-button:before {
  content: "";
  position: absolute;
  z-index: 0;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  display: block;
  width: 40px;
  height: 40px;
  background-color: #fff;
  border-radius: 50%;
  animation: pulse-border 1500ms ease-out infinite; }
  @media (min-width: 768px) {
    .video-play-button:before {
      width: 60px;
      height: 60px; } }

.video-play-button:after {
  content: "";
  position: absolute;
  z-index: 1;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  display: block;
  width: 40px;
  height: 40px;
  background-color: #fff;
  border-radius: 50%;
  transition: all 200ms;
  transition: .5s; }
  @media (min-width: 768px) {
    .video-play-button:after {
      width: 60px;
      height: 60px; } }

.video-play-button img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 6px;
  right: 0;
  z-index: 3;
  width: 20px;
  height: auto;
  margin: auto;
  border-radius: 0; }

.video-play-button span {
  display: block;
  position: relative;
  z-index: 3;
  width: 0;
  height: 0;
  border-left: 32px solid #0b198c;
  border-top: 22px solid transparent;
  border-bottom: 22px solid transparent; }

@keyframes pulse-border {
  0% {
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1);
    opacity: 1; }
  100% {
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1.5);
    opacity: 0; } }
