.index-sec-ttl {
  text-align: center;
  margin-bottom: 50px; }
  .index-sec-ttl-main {
    font-size: 4.8rem;
    font-weight: bold;
    line-height: 1.3; }
  .index-sec-ttl-sub {
    font-weight: bold;
    font-size: 2.1rem;
    margin-top: 5px;
    letter-spacing: 0.2em;
    line-height: 1.6; }

@media screen and (max-width: 768px) {
  .index-sec-ttl {
    margin-bottom: 30px; }
    .index-sec-ttl-main {
      font-size: 3.3em; }
    .index-sec-ttl-sub {
      font-size: 1.8rem; } }
@media screen and (max-width: 576px) {
  .index-sec-ttl-main {
    font-size: 2.2em; }
  .index-sec-ttl-sub {
    font-size: 1.6rem;
    letter-spacing: 0.1em; } }
@media screen and (min-width: 769px) {
  .index-main .slick-slide img.pc_none {
    display: none; } }
.index-main {
  position: relative; }
  .index-main .slick-dotted.slick-slider {
    margin-bottom: 0; }
  .index-main .scroll {
    position: absolute;
    bottom: 0;
    left: 50%;
    margin-left: -15px;
    z-index: 2;
    display: inline-block;
    text-decoration: none;
    color: #fff;
    font-size: 1.2rem; }
  .index-main .scroll span {
    display: block;
    height: 53px;
    width: 1px;
    background: #fff;
    margin: 5px auto 0;
    position: relative; }
    .index-main .scroll span::after {
      content: "";
      width: 5px;
      height: 13px;
      background: #fff;
      display: block;
      position: absolute;
      top: 5px;
      left: -2px;
      animation: sdb 1.5s infinite; }
  .index-main .slick-next, .index-main .slick-prev {
    background: #1f2c5c;
    z-index: 1;
    padding: 20px 5px;
    width: auto;
    margin-top: -50px; }
    .index-main .slick-next::before, .index-main .slick-prev::before {
      font-family: FontAwesome;
      font-size: 3.6rem;
      line-height: inherit;
      opacity: 1; }
  .index-main .slick-next {
    right: 2.5%; }
    .index-main .slick-next::before {
      content: "\f105"; }
  .index-main .slick-prev {
    left: 2.5%; }
    .index-main .slick-prev::before {
      content: "\f104"; }
  .index-main .slick-dots li {
    width: 12px;
    height: 12px;
    margin: 0 10px; }
    .index-main .slick-dots li button {
      width: 12px;
      height: 12px;
      background: #808080; }
      .index-main .slick-dots li button::before, .index-main .slick-dots li button::after {
        display: none; }
    .index-main .slick-dots li.slick-active button {
      background: #1f2c5c; }

.mainslide-item {
  font-size: 0; }
  .mainslide-item a {
    display: block; }
  .mainslide-item-img {
    width: 100%;
    height: 26vw;
    object-fit: cover;
    font-family: 'object-fit: cover;'; }

@media screen and (max-width: 768px) {
  .index-main .slick-slide img.sp_none {
    display: none; }

  .mainslide-item-img {
    height: 40vw; } }
@media screen and (max-width: 576px) {
  .index-main .scroll span {
    height: 30px; }
    .index-main .scroll span::after {
      width: 3px;
      height: 7px;
      top: 2px;
      left: -1px; }

  .mainslide-item-img {
    height: 80vw; } }
.sec-event {
  background: #f1efda; }

.event-list {
  max-width: 655px;
  margin: 0 auto;
  padding: 0; }
  .event-list .slick-list {
    overflow: visible; }
  .event-list .slick-slide {
    padding: 0 60px; }
  .event-list .slick-prev, .event-list .slick-next {
    width: 118px;
    height: 18px;
    z-index: 1; }
    .event-list .slick-prev::before, .event-list .slick-prev::after, .event-list .slick-next::before, .event-list .slick-next::after {
      content: "";
      position: absolute;
      top: 0;
      bottom: 0;
      border-bottom: solid 2px #000;
      height: 0;
      margin: auto; }
    .event-list .slick-prev::before, .event-list .slick-next::before {
      width: 118px; }
    .event-list .slick-prev::after, .event-list .slick-next::after {
      width: 25px; }
  .event-list .slick-next::before, .event-list .slick-next::after {
    right: 0; }
  .event-list .slick-next::after {
    transform: rotate(45deg);
    transform-origin: right; }
  .event-list .slick-prev::before, .event-list .slick-prev::after {
    left: 0; }
  .event-list .slick-prev::after {
    transform: rotate(-45deg);
    transform-origin: left; }

.event-item {
  max-width: 655px;
  width: 100%;
  background-size: contain; }
  .event-item a {
    display: block; }
  .event-item a:hover {
    opacity: 0.5; }
    .event-item a:hover .event-item-img img {
      transform: scale(1.2); }
  .event-item-body {
    border: 1px solid #1f2c5c;
    background: #fff;
    padding: 40px 30px; }
  .event-item-cat {
    text-align: center;
    position: relative;
    z-index: 1;
    margin-bottom: 20px; }
  .event-item-tag {
    display: inline-block;
    color: #fff;
    font-size: 2.1rem;
    font-weight: bold;
    padding: 10px 15px;
    text-align: center;
    min-width: 185px; }
    .event-item-tag.tag-event {
      background: #af8900; }
  .event-item-ttl {
    font-size: 2.8rem;
    line-height: 1.6;
    font-weight: bold;
    color: #1f2c5c;
    position: relative;
    overflow: hidden;
    height: 3em; }
    .event-item-ttl::before, .event-item-ttl::after {
      position: absolute;
      background: #fff; }
    .event-item-ttl::before {
      content: "...";
      bottom: 0;
      right: 0;
      padding: 0 0.2em; }
    .event-item-ttl::after {
      content: "";
      height: 100%;
      width: 100%; }
  .event-item-data {
    font-size: 1.8rem;
    margin: 20px auto;
    display: block; }
  .event-item-day, .event-item-time {
    font-weight: bold;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    height: 1em; }
  .event-item-day {
    margin-bottom: 8px; }
    .event-item-day span {
      font-weight: bold;
      font-size: 3.6rem; }
  .event-item-img {
    overflow: hidden; }
    .event-item-img img {
      width: 100%;
      height: 320px;
      object-fit: cover;
      font-family: 'object-fit: cover;';
      transition: 0.4s; }
  .event-item-place {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 20px auto 0; }
    .event-item-place.lead {
      font-size: 16px;
      line-height: 1.6;
      display: -webkit-box;
      -webkit-line-clamp: 4;
      -webkit-box-orient: vertical;
      overflow: hidden;
      height: 6.5em; }
    .event-item-place-head {
      background: #1f2c5c;
      color: #fff;
      width: 90px;
      padding: 10px 0;
      text-align: center;
      font-size: 1.8rem;
      font-weight: bold; }
    .event-item-place-body {
      width: 100%;
      padding: 0 0 0 1em;
      font-size: 1.8rem;
      font-weight: bold;
      color: #1f2c5c;
      position: relative;
      overflow: hidden;
      height: 1em; }
      .event-item-place-body::before, .event-item-place-body::after {
        position: absolute;
        background: #fff; }
      .event-item-place-body::before {
        content: "...";
        bottom: 0;
        right: 0;
        padding: 0 0.2em; }
      .event-item-place-body::after {
        content: "";
        height: 100%;
        width: 100%; }

@media screen and (min-width: 1141px) {
  .event-list {
    max-width: 770px; }

  .event-item {
    max-width: 770px; } }
@media screen and (max-width: 768px) {
  .event-list {
    max-width: 400px; }
    .event-list .slick-slide {
      padding: 0 20px; }
    .event-list .slick-prev {
      left: -70px; }
    .event-list .slick-next {
      right: -70px; }

  .event-item {
    max-width: 400px; }
    .event-item-tag {
      font-size: 1.4rem;
      padding: 7px 15px;
      min-width: 175px; }
    .event-item-ttl {
      font-size: 2.2rem;
      height: 3.3em; }
    .event-item-data {
      font-size: 1.6rem; }
    .event-item-day span {
      font-size: 2.8rem; }
    .event-item-img img {
      height: 170px; }
    .event-item-place-head {
      font-size: 1.4rem;
      width: auto;
      min-width: 65px; }
    .event-item-place-body {
      font-size: 1.6rem; } }
@media screen and (max-width: 576px) {
  .event-list {
    max-width: 300px; }
    .event-list .slick-slide {
      padding: 0 20px; }
    .event-list .slick-prev, .event-list .slick-next {
      width: 40px;
      height: 18px; }
      .event-list .slick-prev::before, .event-list .slick-next::before {
        width: 40px; }
      .event-list .slick-prev::after, .event-list .slick-next::after {
        width: 15px; }
    .event-list .slick-prev {
      left: -5px; }
    .event-list .slick-next {
      right: -5px; }

  .event-item {
    max-width: 300px; }
    .event-item-body {
      padding: 20px 4%; }
    .event-item-cat {
      margin-bottom: 10px; }
    .event-item-tag {
      font-size: 1.2rem;
      padding: 5px 15px;
      min-width: 125px; }
    .event-item-ttl {
      font-size: 1.8rem; }
    .event-item-data {
      font-size: 1.4rem;
      margin: 10px auto; }
    .event-item-day span {
      font-size: 2.2rem; }
    .event-item-img img {
      height: 140px; }
    .event-item-place-body {
      font-size: 1.4rem; } }
.sec-lead {
  color: #1f2c5c; }
  .sec-lead-inner {
    display: flex;
    justify-content: space-between;
    color: #1f2c5c; }
    .sec-lead-inner:hover .sec-lead-img img {
      transform: scale(1.2); }
    .sec-lead-inner:hover .btn-more_lead {
      background-position: -99% 0; }
  .sec-lead-img, .sec-lead-cts {
    width: 48%;
    overflow: hidden; }
  .sec-lead-img img {
    transition: 0.4s; }
  .sec-lead-txt {
    font-size: 1.8rem;
    line-height: 2; }
    .sec-lead-txt p {
      font-weight: bold; }
  .sec-lead .btn-more_lead {
    transition: 0.4s;
    display: block;
    max-width: 320px;
    width: 100%;
    margin: 80px auto 0;
    padding: 30px 2%;
    text-align: center;
    color: #fff;
    font-size: 1.4rem;
    font-weight: bold;
    letter-spacing: 0.1em;
    background-image: linear-gradient(to right, #1f2c5c 50%, #6170a8 50%);
    background-position: 0 0;
    background-size: 201% auto; }
    .sec-lead .btn-more_lead .arwW {
      display: inline-block;
      margin-left: 0.5em; }

@media screen and (min-width: 769px) {
  .sec-lead-cts {
    padding-right: 2.5%; } }
@media screen and (max-width: 768px) {
  .sec-lead-inner {
    display: block; }
  .sec-lead-img, .sec-lead-cts {
    width: 100%; }
  .sec-lead-img {
    background: url(../img/index/img-lead.jpg) no-repeat center center;
    background-size: cover;
    padding-top: 65vw; }
    .sec-lead-img img {
      display: none; }
  .sec-lead-cts {
    background: rgba(255, 255, 255, 0.8);
    padding: 30px 2.5% 0;
    margin: -40px auto 0;
    width: 95%; }
  .sec-lead .btn-more_lead {
    margin: 60px auto 0; } }
@media screen and (max-width: 576px) {
  .sec-lead-txt {
    font-size: 1.6rem; }
  .sec-lead .btn-more_lead {
    margin: 40px auto 0; } }
.works-list {
  max-width: 720px;
  margin: 0 auto;
  padding: 0; }
  .works-list .slick-list {
    overflow: visible; }
  .works-list .slick-slide {
    padding: 0 25px; }
  .works-list .slick-next, .works-list .slick-prev {
    background: #1f2c5c;
    z-index: 1;
    padding: 20px 5px;
    width: auto;
    margin-top: -50px; }
    .works-list .slick-next::before, .works-list .slick-prev::before {
      font-family: FontAwesome;
      font-size: 3.6rem;
      line-height: inherit;
      opacity: 1; }
  .works-list .slick-next::before {
    content: "\f105"; }
  .works-list .slick-prev::before {
    content: "\f104"; }

.works-item {
  max-width: 720px;
  width: 100%;
  margin: 0 auto; }
  .works-item a {
    display: block; }
  .works-item a:hover {
    opacity: 0.5; }
    .works-item a:hover .works-item-img img {
      transform: scale(1.2); }
  .works-item-img {
    overflow: hidden; }
    .works-item-img img {
      width: 100%;
      height: 480px;
      object-fit: cover;
      font-family: 'object-fit: cover;';
      transition: 0.4s; }
  .works-item-cat {
    display: flex;
    flex-wrap: wrap; }
  .works-item .works-tag {
    display: inline-block;
    padding: 10px 20px;
    font-size: 1.8rem;
    font-weight: bold;
    color: #fff;
    margin-top: 20px; }
    .works-item .works-tag.tag-house {
      background: #1f2c5c; }
    .works-item .works-tag.tag-reform {
      background: #2a3b42; }
  .works-item .works-item-cat .works-tag:not(:last-child) {
    margin-right: 15px; }
  .works-item-ttl {
    margin-top: 20px;
    font-size: 2.1rem;
    font-weight: bold;
    color: #1f2c5c;
    line-height: 1.6;
    position: relative;
    overflow: hidden;
    height: 3.2em; }
    .works-item-ttl::before, .works-item-ttl::after {
      position: absolute;
      background: #fff; }
    .works-item-ttl::before {
      content: "...";
      bottom: 0;
      right: 0;
      padding: 0 0.2em; }
    .works-item-ttl::after {
      content: "";
      height: 100%;
      width: 100%; }

@media screen and (max-width: 768px) {
  .works-list {
    max-width: 420px; }

  .works-item {
    max-width: 420px; }
    .works-item-img img {
      height: 245px; }
    .works-item .works-tag {
      padding: 7px 10px;
      font-size: 1.4rem;
      margin-top: 10px; }
    .works-item .works-item-cat .works-tag:not(:last-child) {
      margin-right: 10px; }
    .works-item-ttl {
      font-size: 1.8rem; } }
@media screen and (max-width: 576px) {
  .works-list {
    max-width: 350px; }
    .works-list .slick-next {
      right: 0; }
    .works-list .slick-prev {
      left: 0; }

  .works-item {
    max-width: 350px; }
    .works-item-img img {
      height: 195px; }
    .works-item .works-tag {
      padding: 7px 7px;
      font-size: 1.2rem; }
    .works-item .works-item-cat .works-tag:not(:last-child) {
      margin-right: 5px; }
    .works-item-ttl {
      margin-top: 10px; } }
      
      
.sec-Rmenu {
background-color: #1f2c5c;
color: #fff;
margin-top: 40px;
padding: 50px 0 70px 0;
  }
  .sec-Rmenu-inner {
    padding: 0 20px; }
    @media screen and (max-width: 1920px) {
      .sec-Rmenu-inner {
        padding: 0 2%; } }
    @media screen and (max-width: 576px) {
      .sec-Rmenu-inner {
        padding: 0 4%; } }
.sec-Rmenu .index-sec-ttl {
/* color: #1f2c5c;*/
}
.Rmenu-list {
  display: flex;
  justify-content: space-between;
 flex-wrap:wrap;
}
.Rmenu-item {
  width: 18%; max-width: 239px;/*5分割*/
  /*width: 23%; 4分割*/
  text-align: center;
  }
.Rmenu-item a.btn {
  position: relative;
  display: block;
  padding: 1.5rem 1.5rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  color: #1f2c5c;
  border-radius: 0.5rem;
}
.Rmenu-item a.btn-flat {
  overflow: hidden;
  padding: 1.5rem auto;
  border-radius: 0;
  background: #FFF;
}
.Rmenu-item a span {
  position: relative;
}
.Rmenu-item a::after { 
  content: "\f105";
  display: inline-block;
  font: bold normal normal 1.6rem/1 FontAwesome;
  line-height: 1;
  font-size: inherit;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: absolute;
  right: 1rem;
  top: calc(50% - .8rem);
  text-align: center;
  width: 15px;
  margin: 0;
  padding: 0;
  color: #1f2c5c;
}
.Rmenu-item a:hover {
  background: #FFF;
  color: #1f2c5c;
  position: relative;
}
.Rmenu-item a:hover::after {
  color: #1f2c5c;
}
.Rmenu-item a b {
 font-size: 2.2rem;
  line-height:1.2;  
 font-weight: bold;
}
.Rmenu-item a small {
 font-size: 1.2rem;
 font-weight: bold;
 letter-spacing: -1px;
}	
    .Rmenu-item a img {
      transition: .3s; }
    .Rmenu-item a:hover img {
      transform: scale(1.1); }

@media screen and (min-width: 769px) and (max-width: 920px) {
.Rmenu-item a b {
 font-size: 1.8rem;
}
.Rmenu-item a small {
 font-size: 1rem;
}
}
@media screen and (max-width: 768px) {
		.sec-Rmenu {
		  padding: 35px 0 20px 0;
		}
		.Rmenu-item {
		  width: 45%;
		  margin: 0 auto 20px auto;
		  }
		.Rmenu-item a b {
		 font-size: 1.5rem;
		  line-height:1.2;  
		}
		.Rmenu-item a b small {
		 font-size: 0.9rem;
		}
}
@media screen and (max-width: 359px) {
		.Rmenu-item a b {
		 font-size: 1.3rem;
		  line-height:1.2;  
		}
		.Rmenu-item a small {
		 font-size: 0.8rem;
		}
}
.voice-list .slick-slide {
  margin: 0 1%;
  max-width: 1025px; }
.voice-list .slick-prev, .voice-list .slick-next {
  width: 85px;
  height: 18px;
  z-index: 1; }
  .voice-list .slick-prev::before, .voice-list .slick-prev::after, .voice-list .slick-next::before, .voice-list .slick-next::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    border-bottom: solid 2px #000;
    height: 0;
    margin: auto; }
  .voice-list .slick-prev::before, .voice-list .slick-next::before {
    width: 85px; }
  .voice-list .slick-prev::after, .voice-list .slick-next::after {
    width: 25px; }
.voice-list .slick-next::before, .voice-list .slick-next::after {
  right: 0; }
.voice-list .slick-next::after {
  transform: rotate(45deg);
  transform-origin: right; }
.voice-list .slick-prev::before, .voice-list .slick-prev::after {
  left: 0; }
.voice-list .slick-prev::after {
  transform: rotate(-45deg);
  transform-origin: left; }

.voice-item {
  max-width: 485px;
  width: 100%; }
  .voice-item a {
    display: block; }
    .voice-item a:hover .voice-item-img img {
      opacity: 1;
      transform: scale(1.2); }
  .voice-item-ttl {
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    z-index: 1; }
    .voice-item-ttl_txt {
      font-size: 2.4rem;
      font-weight: bold;
      color: #fff;
      line-height: 1.8;
      max-width: 360px;
      width: 100%; }
  .voice-item-img {
    position: relative;
    background: #000;
    overflow: hidden; }
    .voice-item-img img {
      width: 100%;
      height: 275px;
      object-fit: cover;
      font-family: 'object-fit: cover;';
      transition: 0.4s;
      opacity: 0.5; }
  .voice-item-cat {
    display: flex;
    flex-wrap: wrap; }
    .voice-item-cat .voice-item-tag:not(:last-child) {
      margin-right: 15px; }
  .voice-item-tag {
    display: inline-block;
    padding: 10px 20px;
    font-size: 1.8rem;
    font-weight: bold;
    color: #fff;
    margin-top: 20px; }
    .voice-item-tag.tag-house {
      background: #1f2c5c; }
    .voice-item-tag.tag-reform {
      background: #2a3b42; }
    .voice-item-tag.tag-point {
      background: #292929; }

@media screen and (max-width: 1240px) {
  .voice-list .slick-prev, .voice-list .slick-next {
    width: 65px; }
    .voice-list .slick-prev::before, .voice-list .slick-next::before {
      width: 65px; }
    .voice-list .slick-prev::after, .voice-list .slick-next::after {
      width: 25px; }
  .voice-list .slick-prev {
    left: 10px; }
  .voice-list .slick-next {
    right: 10px; } }
@media screen and (max-width: 1140px) {
  .voice-item-ttl {
    padding: 0 4%; }
    .voice-item-ttl_txt {
      font-size: 2.5vw; }
  .voice-item-img img {
    height: 25vw; }
  .voice-item-cat .voice-item-tag:not(:last-child) {
    margin-right: 10px; }
  .voice-item-tag {
    font-size: 1.4rem;
    padding: 7px 10px; } }
@media screen and (max-width: 576px) {
  .voice-list .slick-prev, .voice-list .slick-next {
    width: 30px;
    height: 15px; }
    .voice-list .slick-prev::before, .voice-list .slick-prev::after, .voice-list .slick-next::before, .voice-list .slick-next::after {
      content: "";
      position: absolute;
      top: 0;
      bottom: 0;
      border-bottom: solid 2px #000;
      height: 0;
      margin: auto; }
    .voice-list .slick-prev::before, .voice-list .slick-next::before {
      width: 30px; }
    .voice-list .slick-prev::after, .voice-list .slick-next::after {
      width: 15px; }

  .voice-item-ttl {
    padding: 0 6%; }
    .voice-item-ttl_txt {
      font-size: 4.5vw; }
  .voice-item-img img {
    height: 48vw; } }
.sec-column {
  background: #f1efda; }
  .sec-column-inner {
    padding: 0 20px; }
    @media screen and (max-width: 1920px) {
      .sec-column-inner {
        padding: 0 2%; } }
    @media screen and (max-width: 576px) {
      .sec-column-inner {
        padding: 0 4%; } }

.column-item {
  border: 1px solid #1f2c5c;
  background: #fff; }
  .column-list .column-item:not(:last-child) {
    margin-bottom: 40px; }
  .column-item a {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
    padding: 25px 2.5%; }
    .column-item a:hover {
      opacity: 0.5; }
      .column-item a:hover .column-item-img img {
        transform: scale(1.2); }
  .column-item-head {
    width: 58%; }
  .column-item-body {
    width: 40%; }
  .column-item-ttl {
    color: #1f2c5c;
    font-size: 2.1rem;
    font-weight: bold;
    line-height: 1.8; }
  .column-item-img {
    overflow: hidden; }
    .column-item-img img {
      width: 100%;
      height: 21vw;
      object-fit: cover;
      font-family: 'object-fit: cover;';
      transition: 0.4s; }
  .column-item-cat {
    width: 100%;
    margin: 20px auto 0; }
  .column-item-tag {
    border: 1px solid #1f2c5c;
    background: #fff;
    font-size: 1.8rem;
    font-weight: bold;
    color: #1f2c5c;
    padding: 10px;
    display: inline-block; }

@media screen and (min-width: 769px) {
  .column-list .column-item {
    float: right;
    width: 47%; }
    .column-list .column-item:not(:last-child) {
      margin-bottom: 40px; }
    .column-list .column-item:first-child {
      float: left; }
      .column-list .column-item:first-child a {
        display: block;
        padding: 35px 35px 40px; }
      .column-list .column-item:first-child .column-item-head, .column-list .column-item:first-child .column-item-body {
        width: 100%; }
      .column-list .column-item:first-child .column-item-body {
        display: flex;
        flex-direction: column-reverse; }
      .column-list .column-item:first-child .column-item-ttl {
        position: relative;
        overflow: hidden;
        height: 3.5em; }
        .column-list .column-item:first-child .column-item-ttl::before, .column-list .column-item:first-child .column-item-ttl::after {
          position: absolute;
          background: #fff; }
        .column-list .column-item:first-child .column-item-ttl::before {
          content: "...";
          bottom: 0;
          right: 0;
          padding: 0 0.2em; }
        .column-list .column-item:first-child .column-item-ttl::after {
          content: "";
          height: 100%;
          width: 100%; }
      .column-list .column-item:first-child .column-item-cat {
        margin: 35px auto 35px; }
    .column-list .column-item:nth-of-type(2) a, .column-list .column-item:nth-of-type(3) a {
      padding: 15px 2.5%; }
    .column-list .column-item:nth-of-type(2) .column-item-head, .column-list .column-item:nth-of-type(3) .column-item-head {
      width: 48%; }
    .column-list .column-item:nth-of-type(2) .column-item-body, .column-list .column-item:nth-of-type(3) .column-item-body {
      width: 47%; }
    .column-list .column-item:nth-of-type(2) .column-item-ttl, .column-list .column-item:nth-of-type(3) .column-item-ttl {
      position: relative;
      overflow: hidden;
      height: 5.3em; }
      .column-list .column-item:nth-of-type(2) .column-item-ttl::before, .column-list .column-item:nth-of-type(2) .column-item-ttl::after, .column-list .column-item:nth-of-type(3) .column-item-ttl::before, .column-list .column-item:nth-of-type(3) .column-item-ttl::after {
        position: absolute;
        background: #fff; }
      .column-list .column-item:nth-of-type(2) .column-item-ttl::before, .column-list .column-item:nth-of-type(3) .column-item-ttl::before {
        content: "...";
        bottom: 0;
        right: 0;
        padding: 0 0.2em; }
      .column-list .column-item:nth-of-type(2) .column-item-ttl::after, .column-list .column-item:nth-of-type(3) .column-item-ttl::after {
        content: "";
        height: 100%;
        width: 100%; }
    .column-list .column-item:nth-of-type(2) .column-item-img img, .column-list .column-item:nth-of-type(3) .column-item-img img {
      height: 11vw; }
    .column-list .column-item:nth-of-type(2) {
      margin-bottom: 60px; } }
@media screen and (min-width: 1141px) {
  .column-item-img img {
    height: 243px; }
  .column-list .column-item:nth-of-type(2) .column-item-img img, .column-list .column-item:nth-of-type(3) .column-item-img img {
    height: 130px; } }
@media screen and (max-width: 1140px) {
  .column-item-ttl {
    font-size: 1.8rem; }
  .column-item-tag {
    font-size: 1.4rem; } }
@media screen and (max-width: 576px) {
  .column-list .column-item:not(:last-child) {
    margin-bottom: 20px; }
  .column-item a {
    display: block;
    padding: 15px 4%; }
  .column-item-head, .column-item-body {
    width: 100%; }
  .column-item-ttl {
    position: relative;
    overflow: hidden;
    height: 3.5em;
    margin-bottom: 10px; }
    .column-item-ttl::before, .column-item-ttl::after {
      position: absolute;
      background: #fff; }
    .column-item-ttl::before {
      content: "...";
      bottom: 0;
      right: 0;
      padding: 0 0.2em; }
    .column-item-ttl::after {
      content: "";
      height: 100%;
      width: 100%; }
  .column-item-img img {
    height: 48vw; }
  .column-item-cat {
    margin: 10px auto 0; }
  .column-item-tag {
    font-size: 1.3rem; } }
