/* Scss Document */
@media screen and (min-width: 768px) {
  header h1 {
    bottom: auto;
    top: 580px;
  }
}
/*
main {
  pointer-events: none;
  height: 100vh;
  opacity: 0;
}
.showBd main {
  pointer-events: auto;
  height: auto;
  opacity: 1;
}
.bd_poster main, .bd_poster main * {
  pointer-events: none;
}
*/

.show-opening main {
   pointer-events: none;
  height: 100vh;
  opacity: 0;
}
.show-opening #overlay .logo-in ,.show-opening  #overlay .skip ,.show-opening #overlay .overlay-logo-inner  {
  opacity: 0;
} 
#overlay {
  background:url("../img/shared/pt_bg.jpg") repeat center 0;;
  position: fixed;
  top: 0;
  right: 0;
bottom: -20px;
  left: 0;
  z-index: 999999999999;
  transition: all 1s ease;
  -moz-transition: all 1s ease;
  -webkit-transition: all 1s ease;

  
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
#overlay .overlay-logo-inner {
  height: 105%;
  position: relative;
  background: url("../img/shared/open_bg_sp.jpg") no-repeat 0 bottom/100%;
/*  opacity: 0;*/
  transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -webkit-transition: all 0.5s ease;
  opacity: 1;
}
#overlay .logo-in {
  width: 55%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
/*  opacity: 0;*/
  transition: all 1s ease 0.5s;
  -moz-transition: all 1s ease 0.5s;
  -webkit-transition: all 1s ease 0.5s;
  opacity: 1;
}
#overlay img {
  width: 100%;
  height: auto;
}
#overlay .skip {
  color: #4d4d4d;
  text-align: right;
  background: url("../img/index/skip.png") no-repeat right center;
  padding-right: 30px;
  position: absolute;
  right: 10vw;
  bottom: calc(50px + 15vw);
  z-index: 1;
  opacity: 1;
    transition: all 1s ease 0.5s;
  -moz-transition: all 1s ease 0.5s;
  -webkit-transition: all 1s ease 0.5s;
}
#overlay.firts .overlay-logo-inner {
  opacity: 1;
}
#overlay.firts .logo-in {
  opacity: 1;
}
#overlay.hide {
  transform: translateY(-120%);
}
@media screen and (min-width: 768px) {
  #overlay .overlay-logo-inner {
    background: url("../img/shared/onpen_bg.jpg") no-repeat 0 bottom;
  }
  #overlay .logo-in {
    width: 414px;
  }
  #overlay .skip {
    right: 10%;
    bottom: 10%;
    cursor: pointer;
    padding-right: 40px;
  }
  #overlay .skip:hover {
    opacity: 0.6;
  }
}
.overlay-logo.active {
  transform: translateY(-120%);
}
.sec-key-top {
  padding-top: 110vh;
}
section {
  background: url("../img/shared/bd_bg.jpg") repeat center 0;
}
#key {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
}
#key .js-key .object-fit-cover {
  height: 100vh;
}
@media screen and (min-width: 768px) {
  #key .js-key .object-fit-cover {
    height: 100vh;
    display: block !important;
  }
}
#sec1 {
  background: url("../img/index/sec1_bg_sp.jpg") no-repeat 0 0/100%;
  padding: 25vw 0 10vw;
}
#sec1 .wrap {
  padding: 0;
}
#sec1 h2 {
  font-size: 6vw;
  line-height: 1.4;
  padding-bottom: 10vw;
  letter-spacing: 0.24em;
}
#sec1 h2 span {
  font-size: 6.5vw;
}
#sec1 h2 span.t {
  font-size: 7vw;
}
#sec1 .txt p {
  padding-bottom: 15px;
}
#sec1 .photo {
  width: 30%;
  margin: 0 auto 5vw;
}
@media screen and (min-width: 768px) {
  #sec1 {
    background: url("../img/index/sec1_bg.png") no-repeat 0 0/100%;
    padding: 233px 0 311px;
  }
  #sec1 h2 {
    font-size: 28px;
    padding-bottom: 67px;
  }
  #sec1 h2 span {
    font-size: 32px;
    letter-spacing: 0.24em;
  }
  #sec1 h2 span.t {
    font-size: 42px;
  }
  #sec1 .txt p {
    padding-bottom: 0px;
  }
  #sec1 .photo {
    width: 224px;
    margin: 0 auto 20px;
  }
  #sec1 .photo img {
    width: 100%;
    height: auto;
  }
}
#news {
  padding: 10vw 3% 5vw;
  border-top: 1px solid #8a8a8a;
  border-bottom: 1px solid #8a8a8a;
}
#news h2 {
  font-size: 6vw;
  line-height: 1.5;
  letter-spacing: 0.2em;
  padding-bottom: 5vw;
}
#news #feed dl {
  display: table;
  width: 100%;
  margin-bottom: 10px;
}
#news #feed dl dt, #news #feed dl dd {
  display: table-cell;
  box-sizing: border-box;
}
#news #feed dt {
  width: 90px;
  color: #8a8a8a;
}
#news .link {
  padding: 5vw 10%;
}
#news .bnr-shared {
  margin-bottom: 10px;
}
#news .bnr-shared img {
  width: 30px;
  height: auto;
}
@media screen and (min-width: 768px) {
  #news {
    max-width: 1250px;
    margin: 0 auto;
    padding: 66px 0 82px;
    min-height: 322px;
    box-sizing: border-box;
  }
  #news .wrap {
    padding-top: 1px;
  }
  #news h2 {
    font-size: 28px;
    padding-bottom: 0;
    position: absolute;
    top: 00px;
    left: 8px;
  }
  #news #feed {
    margin: 18px 0 0 228px;
  }
  #news #feed dl {
    margin-bottom: 10px;
  }
  #news #feed dd {
    letter-spacing: 0.2em;
  }
  #news #feed dt {
    width: 130px;
    font-size: 15px;
  }
  #news .link {
    padding: 0;
    position: absolute;
    top: 78px;
    left: 0;
    width: 145px;
  }
  #news .bnr-shared {
    margin-bottom: 17px;
  }
  #news .bnr-shared a {
    padding: 3px 0 4px;
  }
  #news .bnr-shared img {
    width: 25px;
    height: auto;
    position: relative;
    top: -2px;
  }
}
#sec2 {
  background: url("../img/index/sec2_deco_sp.png") no-repeat 0 15vw/50%;
  padding: 25vw 0 5vw;
  letter-spacing: 0.05em;
}
#sec2 .logo {
  width: 34%;
  margin: 0 auto 17vw;
}
#sec2 h2 {
  font-size: 8vw;
  line-height: 1.8;
  letter-spacing: 0.24em;
  margin-bottom: 5vw;
}
#sec2 h2 span {
  letter-spacing: 0.24em;
}
#sec2 h2 .txt-vertical {
  text-align: left;
}
#sec2 h2 .txt-vertical span {
  font-size: 6.5vw;
}
#sec2 h2 span.t {
  font-size: 4vw;
  position: relative;
  margin-bottom: 10vw;
  display: inline-block;
}
#sec2 h2 span.t:before {
  content: '';
  border-left: 1px solid #7c7c7c;
  height: 7vw;
  position: absolute;
  right: 1vw;
  bottom: -2vw;
  transform: rotate(46deg);
}
#sec2 .photo1 {
  margin: 0 -5vw;
}
#sec2 .info1 {
  padding: 15vw 0;
}
#sec2 .info1 dt {
  font-size: 13px;
  padding-bottom: 20px;
}
#sec2 .info1 dd .f_cl1 {
  font-size: 16px;
}
#sec2 .photo2 {
  margin: 0 -5vw;
}
#sec2 .photo2 li:nth-child(1) {
  margin: 0 0 0vw 59%;
}
#sec2 .photo2 li:nth-child(2) {
  width: 36%;
  margin: -17vw 0 12vw 11vw;
}
#sec2 .photo2 li:nth-child(3) {
  width: 73%;
}
#sec2 .info2 {
  padding: 20vw 3%;
}
#sec2 .info2 h3 {
  font-size: 6.5vw;
  line-height: 1.8;
  letter-spacing: 0.2em;
  margin-bottom: 5vw;
}
#sec2 .info2 h3 span {
  letter-spacing: 0.2em;
  font-size: 7.5vw;
}
@media screen and (min-width: 768px) {
  #sec2 {
    background: url("../img/index/sec2_deco.png") no-repeat 0 530px;
    padding: 234px 0 0;
    letter-spacing: 0.1em;
  }
  #sec2 .wrap {
    max-width: 1500px;
  }
  #sec2 h2 {
    font-size: 38px;
    line-height: 70px;
    margin: 0;
    position: absolute;
    top: 13px;
    right: calc(50% + 193px);
  }
  #sec2 h2 .txt-vertical span {
    font-size: 28px;
  }
  #sec2 h2 span.t {
    font-size: 16px;
    margin-bottom: 35px;
  }
  #sec2 h2 span.t:before {
    height: 30px;
    right: 10px;
    bottom: 12px;
    transform: rotate(56deg);
  }
  #sec2 .logo {
    width: auto;
    margin: 0 auto 263px;
    text-align: center;
  }
  #sec2 .photo1 {
    margin: 0 0 146px;
    height: 500px;
    margin-left: calc(50% + 50px);
  }
  #sec2 .info1 {
    padding: 0;
    position: absolute;
    top: 409px;
    right: calc(50% + 84px);
  }
  #sec2 .info1 dt {
    font-size: 11px;
    padding: 0 12px 47px;
    text-align: right;
    letter-spacing: 0.1em;
  }
  #sec2 .info1 dd {
    height: 482px;
    line-height: 43px;
  }
  #sec2 .info1 dd .f_cl1 {
    font-size: 18px;
  }
  #sec2 .photo2 {
    margin: 0 0;
    position: relative;
  }
  #sec2 .photo2 li:nth-child(1) {
    margin: 0 0 0;
    margin-left: calc(50% + 224px);
  }
  #sec2 .photo2 li:nth-child(2) {
    width: auto;
    margin: 0;
    margin-left: calc(50% - 46px);
  }
  #sec2 .photo2 li:nth-child(3) {
    width: auto;
    height: 322px;
    position: absolute;
    left: 0;
    top: 594px;
    width: calc(50% - 30px);
    max-width: 541px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
  #sec2 .photo2 li:nth-child(3) {
    width: calc(50% - 60px);
  }
}
@media screen and (min-width: 768px) {
  #sec2 .info2 {
    padding: 0;
    max-width: 1000px;
    margin: 0px auto;
    position: relative;
    height: 718px;
  }
  #sec2 .info2 h3 {
    font-size: 28px;
    line-height: 70px;
    letter-spacing: 0.24em;
    margin-bottom: 0;
    position: absolute;
    top: 49px;
    right: 33px;
  }
  #sec2 .info2 h3 span {
    letter-spacing: 0.24em;
    font-size: 38px;
  }
  #sec2 .info2 .txt {
    height: 430px;
    position: absolute;
    top: 272px;
    right: 221px;
    line-height: 43px;
  }
}
#sec2 .photo3 {
  margin-right: calc(50% - 539px);
  height: 500px;
}
#sec3 {
  background: url("../img/index/sec3_bg_sp.jpg") no-repeat center 0/100%, url("../img/index/bg1.jpg") repeat center 0;
  padding: 45vw 0 0;
}
#sec3 .lead {
  padding-bottom: 15vw;
}
#sec3 .lead h2 {
  font-size: 6vw;
  line-height: 1.6;
  letter-spacing: 0.24em;
  padding-bottom: 15vw;
}
#sec3 .lead h2 span {
  letter-spacing: 0.24em;
  font-size: 7vw;
}
#sec3 .lead h2 .eng {
  font-size: 3vw;
  letter-spacing: 0.1em;
}
#sec3 .js {
  background: url("../img/index/sec3_js_sp.jpg") no-repeat center/cover;
  padding: 25vw 15%;
}
#sec3 .js .banner {
  gap: 20vw;
}
#sec3 .js .banner li {
  width: 100%;
  position: relative;
}
#sec3 .js .banner li:before, #sec3 .js .banner li:after {
  position: absolute;
  content: '';
  top: 0;
  width: 15vw;
  border-top: 1px solid #2a2a2a;
  right: 5vw;
  z-index: 3;
}
#sec3 .js .banner li:after {
  top: auto;
  bottom: -1px;
  right: auto;
  left: 5vw;
}
#sec3 .js .banner li a {
  display: block;
  position: relative;
}
#sec3 .js .banner li a .arrow {
  position: absolute;
  left: 50%;
  bottom: -5vw;
  width: 15vw;
  aspect-ratio: 1;
  border-radius: 50%;
  z-index: 5;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #000000;
}
#sec3 .js .banner li a .arrow:before {
  position: absolute;
  content: '';
  top: -4px;
  left: -4px;
  right: -4px;
  bottom: -4px;
  border: 1px solid #fff;
  border-radius: 50%;
}
#sec3 .js .banner li a .arrow img {
  width: 3vw;
  height: auto;
}
#sec3 .js .banner li a i {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  color: #fff;
  font-size: 6vw;
  line-height: 1.4;
  letter-spacing: 0.1em;
  z-index: 1;
}
#sec3 .js .banner li a i span {
  font-size: 7.5vw;
}
#sec3 .js .banner li a:before {
  border: 1px solid #adadad;
  content: '';
  position: absolute;
  width: calc(100% - 1px);
  height: calc(100% - 1px);
  top: 0;
  left: 0;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  #sec3 {
    background: url("../img/index/bg1.jpg") repeat center 0;
    padding: 0;
  }
  #sec3 .lead {
    background: url("../img/index/sec3_bg.jpg") repeat-x center 0/100%;
    padding: 350px 0 165px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1500px) {
  #sec3 .lead {
    background-size: auto;
  }
}
@media screen and (min-width: 768px) {
  #sec3 .lead h2 {
    font-size: 24px;
    line-height: 50px;
    padding-bottom: 40px;
    padding-top: 160px;
  }
  #sec3 .lead h2 span {
    font-size: 28px;
  }
  #sec3 .lead h2 .eng {
    font-size: 11px;
    position: relative;
    top: -12px;
  }
  #sec3 .js {
    background: url("../img/index/sec3_js_bg.jpg") no-repeat center/cover;
    padding: 228px 20px 274px;
    position: relative;
  }
  #sec3 .js .object-fit-cover-pc {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 0;
    transition: opacity .3s ease;
    -moz-transition: opacity .3s ease;
    -webkit-transition: opacity .3s ease;
  }
  #sec3 .js .object-fit-cover-pc.active {
    opacity: 1;
  }
  #sec3 .js .banner {
    max-width: 1260px;
    margin: 0 auto;
    gap: 0;
    position: relative;
    z-index: 1;
  }
  #sec3 .js .banner img {
    width: 100%;
    height: auto;
  }
  #sec3 .js .banner li {
    width: calc((100% - 50px)/3);
    max-width: 400px;
  }
  #sec3 .js .banner li:before, #sec3 .js .banner li:after {
    right: 30px;
    width: 70px;
  }
  #sec3 .js .banner li:after {
    top: auto;
    bottom: -1px;
    right: auto;
    left: 30px;
  }
  #sec3 .js .banner li a img {
    opacity: 1 !important;
  }
  #sec3 .js .banner li a .arrow {
    bottom: -40px;
    width: 78px;
  }
  #sec3 .js .banner li a .arrow img {
    width: auto;
  }
  #sec3 .js .banner li a i {
    font-size: 26px;
    line-height: 55px;
    letter-spacing: 0.16em;
  }
  #sec3 .js .banner li a i span {
    font-size: 32px;
  }
  #sec3 .js .banner li a:before {
    border: 1px solid #adadad;
    content: '';
    position: absolute;
    width: calc(100% - 1px);
    height: calc(100% - 1px);
    top: 0;
    left: 0;
    z-index: 1;
  }
  #sec3 .js .banner li a .line {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: 2;
  }
  #sec3 .js .banner li a .line:before, #sec3 .js .banner li a .line:after {
    content: '';
    position: absolute;
    width: 0;
    height: 0;
    border: 1px solid transparent;
  }
  #sec3 .js .banner li a .line:before {
    top: 0;
    left: 0;
  }
  #sec3 .js .banner li a .line:after {
    bottom: 0;
    right: 0;
  }
  #sec3 .js .banner li a:hover:before {
    opacity: 0;
  }
  #sec3 .js .banner li a:hover .line:before, #sec3 .js .banner li a:hover .line:after {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
  }
  #sec3 .js .banner li a:hover .line:before {
    border-top-color: #adadad;
    border-right-color: #adadad;
    transition: width 0.25s ease-out 0.25s, height 0.25s ease-out 0.5s;
  }
  #sec3 .js .banner li a:hover .line:after {
    border-bottom-color: #adadad;
    border-left-color: #adadad;
    transition: border-color 0s ease-out 0.5s, width 0.25s ease-out 0.75s, height 0.25s ease-out 1s;
  }
}
#sec5 {
  padding: 20vw 0;
}
#sec5 h2 {
  font-size: 6vw;
  line-height: 1.5;
  letter-spacing: 0.24em;
  padding-bottom: 10vw;
}
#sec5 .lead {
  text-align: center;
}
#sec5 .logo {
  width: 25%;
  margin: 0 auto 5vw;
}
#sec5 .contact {
  padding: 10vw 10%;
}
#sec5 .contact .tel {
  margin-bottom: 20px;
}
#sec5 .contact .tel .num {
  background: url("../img/shared/tel2_sp.png") no-repeat 0 bottom/20px;
  letter-spacing: 0.1em;
  font-size: 32px;
  padding-left: 27px;
  display: inline-block;
}
#sec5 .contact .bnr-shared {
  width: 90%;
  margin: 0 auto;
}
#sec5 .contact .bnr-shared a {
  border: 1px solid #000000;
  border-bottom: 2px solid #000000;
}
#sec5 .tbl-info {
  padding: 0 5%;
  margin-bottom: 15vw;
}
#sec5 .tbl-info dl {
  display: table;
  width: 100%;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
  text-align: left;
  letter-spacing: 0;
  font-size: 12px;
  line-height: 24px;
  padding: 10px 0;
}
#sec5 .tbl-info dl dt, #sec5 .tbl-info dl dd {
  display: table-cell;
  box-sizing: border-box;
}
#sec5 .tbl-info dl dt {
  width: 92px;
}
#sec5 #gmap .link {
  padding: 10vw 20%;
}
#sec5 .map {
  filter: grayscale(100%);
  line-height: 0;
}
#sec5 .map iframe {
  line-height: 0;
}
#sec5 .photo {
  padding: 0 15%;
}
#sec5 .tit {
  letter-spacing: 0;
}

/* 入口までの行き方 */
#sec5 .howto {
  text-align: center;
}
#sec5 .howto h3 {
  font-size: 5.8vw;
  line-height: 1.4;
  padding-bottom: 2vw;
}
#sec5 .howto .box {
  position: relative;
  padding: 74px 5% 25vw;
}
#sec5 .howto .box dt {
  padding-bottom: 15px;
}
#sec5 .howto .js-step {
  position: absolute;
  top: 0;
  left: 10px;
  z-index: 9;
  text-align: left;
  font-size: 17px;
}
#sec5 .howto .js-step .slick-list, #sec6 .howto .js-step .slick-track {
  transform: none !important;
  width: 100% !important;
  width: 100px;
  margin-left: 0px;
}
#sec5 .howto .js-step .slick-track {
  flex-wrap: wrap;
  display: flex;
  flex-wrap: nowrap;
  margin: 20px 60px 0;
  text-align: center;
}
#sec5 .howto .js-step .slick-slide {
  display: block;
  width: 90px;
}
#sec5 .howto .js-step li {
  color: #adadad;
}
#sec5 .howto .js-step .slick-current li {
  color: #1a4472;
}
@media screen and (min-width: 768px) {
  #sec5 .howto .js-step .slick-track {
    flex-wrap: wrap;
    display: flex;
    flex-direction: column;
  }
  #sec5 .howto .js-step .slick-slide {
    display: block;
    width: 100px;
  }

  #sec5 {
    position: relative;
    padding: 83px 0 186px;
  }
  #sec5 .col-r {
    margin-left: 50%;
  }
  #sec5 .col-l {
    position: absolute;
    top: 0;
    left: 0;
    height: 100vh;
    width: 50%;
    z-index: 1;
  }
  #sec5 .col-l .photo {
    padding: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
  #sec5.fixed .col-l {
    position: fixed;
  }
  #sec5 h2 {
    font-size: 26px;
    padding-bottom: 30px;
  }
  #sec5 .logo {
    width: 103px;
    margin: 0 auto 0px;
  }
  #sec5 .logo img {
    width: 100%;
    height: auto;
  }
  #sec5 .contact {
    padding: 26px 0 60px;
  }
  #sec5 .contact .tel {
    font-size: 13px;
    margin-bottom: 17px;
    line-height: 30px;
  }
  #sec5 .contact .tel .t {
    letter-spacing: 0.2em;
  }
  #sec5 .contact .tel .num {
    background-size: 18px;
    font-size: 32px;
    padding: 0 5px 0 27px;
  }
  #sec5 .contact .bnr-shared {
    width: 220px;
    margin: 0 auto;
  }
  #sec5 .tit {
    font-size: 14px;
  }
  #sec5 .tbl-info {
    padding: 0;
    max-width: 530px;
    margin: 0 auto 65px;
  }
  #sec5 .tbl-info dl {
    font-size: 14px;
    line-height: 29px;
    padding: 14px 0 15px;
  }
  #sec5 .tbl-info dl dt {
    width: 165px;
    padding-left: 7px;
  }
  #sec5 #gmap {
    max-width: 530px;
    margin: 0 auto;
  }
  #sec5 #gmap .map iframe {
    height: 330px !important;
  }
  #sec5 #gmap .link {
    text-align: center;
    width: 220px;
    padding: 24px 0 0;
    text-align: center;
    font-size: 12px;
    float: right;
  }
  #sec5 #gmap .link .gmap_print a {
    text-decoration: underline;
  }
  #sec5 #gmap .link .gmap_print a:hover {
    text-decoration: none;
  }
  #sec5 .map iframe {
    line-height: 0;
  }

  /* 入口までの行き方 */
  #sec5 .howto {
    margin-bottom: 115px;
  }
  #sec5 .howto h3 {
    font-size: 28px;
    padding-bottom: 34px;
  }
  #sec5 .howto .box {
    padding: 0;
  }
  #sec5 .howto .box dt {
    padding-bottom: 15px;
  }
  #sec5 .howto .js-step {
    width: 150px;
    top: 31px;
    left: auto;
    right: calc(50% + 210px);
    text-align: left;
    font-size: 24px;
    line-height: 1.4;
  }
  #sec5 .howto .js-step li {
    padding-bottom: 20px;
      cursor: pointer;
  }
  #sec5 .howto .js-step li:hover {
        color: #fff;
    }
  #sec5 .howto .js-step .slick-list, #sec6 .howto .js-step .slick-track {
      width: 100px;
      margin-left: -10px;
}
}
@media screen and (min-width: 768px) {
  footer {
    position: relative;
    z-index: 9;
    padding: 100px 0 0;
  }
  footer .tog-nav {
    margin-bottom: 62px;
  }
}

.news_box {
	background-color: rgba(0, 0, 0, 0.4);
    width: 100%;
    margin: 50px auto;
    line-height: 2em;
    padding-bottom:69px;
}
.news_box .ttl {
	color: #fff;
    padding: 69px 50px 10px;
    text-align: center;
    font-size: 24px;
    width: 660px;
    border-bottom: 1px solid #fff;
    margin: 0 auto;
}
.news_box .txt {
	color: #fff;
	padding: 20px 50px 0;
	text-align: center;
	font-size: 16px;
}

@media only screen and (max-width: 768px) {
.news_box {
    width: 100%;
    margin: 20px auto;
}
.news_box .ttl {
    padding: 39px 10px 10px;
    font-size: 18px;
    width: 70%;
}
.news_box .txt {
	padding: 20px 10px 0;
	font-size: 14px;
}
}