@charset "UTF-8";
/* CSS Document */


/* ////////////////////////////////////////////////////////////////////////////////

	Common

//////////////////////////////////////////////////////////////////////////////// */
@font-face {
  font-family: 'sns_ico';
  src:
    url('../fonts/sns_ico.ttf?z7sza2') format('truetype'),
    url('../fonts/sns_ico.woff?z7sza2') format('woff'),
    url('../fonts/sns_ico.svg?z7sza2#sns_ico') format('svg');
  font-weight: normal;
  font-style: normal;
}

i.snsIcon {
  font-family: 'sns_ico' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  
	color: #000;
}

.icon-search:before { content: "\e908";}
.icon-arrow1_left:before { content: "\e90c";}
.icon-arrow1_bottom:before { content: "\e90d";}
.icon-arrow1_right:before { content: "\e90e";}
.icon-arrow1_top:before { content: "\e90f";}
.icon-arrow2_left:before { content: "\e910";}
.icon-arrow2_bottom:before { content: "\e911";}
.icon-arrow2_right:before { content: "\e912";}
.icon-arrow2_top:before { content: "\e913";}
.icon-link:before { content: "\e914";}
.icon-note:before { content: "\e915";}
.icon-ap:before { content: "\e900";}
.icon-blo:before { content: "\e901";}
.icon-fb:before { content: "\e902";}
.icon-hp:before { content: "\e903";}
.icon-in:before { content: "\e904";}
.icon-line:before { content: "\e905";}
.icon-spo:before { content: "\e906";}
.icon-tt:before { content: "\e907";}
.icon-yt:before { content: "\e909";}
.icon-x:before { content: "\e90a";}
.icon-wb:before { content: "\e90b";}
.icon-arrow3_top:before { content: "\ea3a";}
.icon-arrow3_right:before { content: "\ea3c";}
.icon-arrow3_bottom:before { content: "\ea3e";}
.icon-arrow3_left:before { content: "\ea40";}


html {
	scroll-behavior: smooth;
}
body {
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
	font-size: min(3.4vw, 16px);
  letter-spacing: 0.06em;
	line-height: 1.8;
	-webkit-text-size-adjust: 100%;
  background: url("../images/bg_content.jpg") repeat center top;
  background-size: 724px auto;
}

img {
	max-width: 100%;
	height: auto;
}
ul { list-style: none;}

.anim {
	opacity: 0;
	transition: all .6s ease-out;
}
.anim.on {
	opacity: 1;
}

.contentWrap {
  max-width: 1220px;
  margin: 0 auto;
  padding: 0 min(6vw, 60px);
}

.tysm {
  font-family: "Times New Roman", Times, Georgia, serif;
  background: linear-gradient(90deg, #345e58 0%, #9fb1af 20%, #e1c6b4 50%, #345e58 60%, #9fb1af 80%, #e1c6b4 100%);
  background-size: 400% 400%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  width: fit-content;
  font-style: italic;
  
  animation: waveGradient 6s ease infinite;
}
@keyframes waveGradient {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.btnBlack {
  display: block;
  width: fit-content;
  background-color: #000;
  color: #fff;
  text-decoration: none;
  padding: min(1vw, 5px) min(6vw, 30px) min(1.2vw, 6px);
  border-radius: 100px;
  font-size: min(3.2vw, 14px);
}

@media screen and (min-width: 821px) {
	
	.sp { display: none !important;}
	
	a { transition: all 0.3s ease-out;}
	a:hover { opacity: 0.5;}
	
}
@media screen and (max-width: 820px) {
	
	.pc { display: none !important;}
	
}

.opYT {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #222;
	display: flex;
	justify-content: center;
	align-items: center;
	overflow: hidden;
	transition: all 1s cubic-bezier(0.33, 1, 0.68, 1);
    z-index: 9998;
}
.opYT .ytWrap {
    width: 100%;
	padding-top: 56.25%;
	position: relative;
}
.opYT .ytWrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.opYT .ytClose {
	position: absolute;
    bottom: 17px;
    left: 50%;
	transform: translateX(-50%);
    width: 40px;
    height: 40px;
	z-index: 10;
}

.opYT.close {
	transform: translateY(-100%);
}

/* ////////////////////////////////////////////////////////////////////////////////

	Main visual

//////////////////////////////////////////////////////////////////////////////// */
#mainVisual {
  position: relative;
  background-color: #000;
  line-height: 0;
  overflow: hidden;
  height: 100vh;
}

.mainSlide {
  position: relative;
  opacity: 0;
}
.mainSlide::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: url("../images/mv_mask.png") repeat center top;
  background-size: 33px;
}
.mainSlide li {
  width: 100vw;
  height: 100vh;
  line-height: 0;
}
.mainSlide li img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mainTitle {
  position: absolute;
  top: 5%;
  left: 50%;
  transform: translate(-50%, 0%);
  z-index: 10;
  max-width: 1280px;
  width: 90%;
}
.mainTitle .mainTitle01 {
  line-height: 0;
  width: 74%;
  margin: 0 auto min(2vw, 10px);
  
  transform: translateY(-30px);
  opacity: 0;
  animation: op01 1.5s cubic-bezier(0.33, 1, 0.68, 1) 0.6s forwards;
}
@keyframes op01 {
  0% { transform: translateY(-30px); opacity: 0;}
  100% { transform: translateY(0px); opacity: 1;}
}
.mainTitle .mainTitle02 {
  line-height: 0;
  width: 100%;
  margin: 0 auto;
  
  opacity: 0;
  animation: op02 1.5s cubic-bezier(0.33, 1, 0.68, 1) 0.6s forwards;
}
@keyframes op02 {
  0% { opacity: 0;}
  100% { opacity: 1;}
}
.mainTitle .mainTitle03 {
  line-height: 0;
  width: 37%;
  margin: min(2vw, 5px) auto 0;
  
  transform: translateY(30px);
  opacity: 0;
  animation: op03 1.5s cubic-bezier(0.33, 1, 0.68, 1) 0.6s forwards;
}
@keyframes op03 {
  0% { transform: translateY(30px); opacity: 0;}
  100% { transform: translateY(0px); opacity: 1;}
}

@media screen and (max-width: 820px) {
	
  #mainVisual {
    height: 132vw;
  }
  
  .mainTitle {
    top: 6%;
    transform: translate(-50%, 0%);
  }
  .mainSlide li {
    height: 132vw;
  }
  .mainSlide li img {
    object-position: center bottom;
  }
  
  .mainTitle .mainTitle01 {
    width: 66%;
  }
  .mainTitle .mainTitle03 {
    width: 60%;
    margin: min(2vw, 10px) auto 0;
  }
	
}

/* ////////////////////////////////////////////////////////////////////////////////

	About

//////////////////////////////////////////////////////////////////////////////// */
#about {
  padding-bottom: min(10vw, 80px);
}
#about .scrollTxt {
  padding: min(10vw, 80px) 0;
  overflow: hidden;
  
  opacity: 0;
  animation: op02 1.5s cubic-bezier(0.33, 1, 0.68, 1) 0.5s forwards;
}
#about .scrollInner {
  display: flex;
}
#about .scrollTxt p {
  font-size: 9vw;
  font-style: italic;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1;
  white-space: nowrap;
  -webkit-font-smoothing: antialiased;
  padding-right: 0.8em;
  animation: scroll-left 20s linear infinite;
  background: linear-gradient(90deg, #345e58 0%, #9fb1af 40%, #e1c6b4 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin: 0;
}
@keyframes scroll-left {
  0% { transform: translateX(0);}
  100% { transform: translateX(-100%);}
}

.movie {
  max-width: 860px;
  width: 100%;
  aspect-ratio: 100/56.25;
  margin: min(8vw, 60px) auto;
}
.movie iframe {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#about h3 {
  text-align: center;
  font-size: min(4.6vw, 36px);
  font-weight: 600;
  margin-bottom: 0.3em;
}
#about .aboutLead {
  text-align: center;
  font-size: min(3.6vw, 18px);
  font-weight: 500;
/*
  margin-bottom: 3em;
  border-bottom: #beb4a6 solid 1px;
  padding-bottom: 2em;
*/
}
#about p {
  line-height: 2;
  letter-spacing: 0.04em;
}
#about p + p {
  margin-top: min(6vw, 35px);
}

#intro {
  padding: min(4vw, 20px) 0 min(10vw, 80px);
}
#intro p {
  line-height: 2;
  letter-spacing: 0.04em;
}
#intro p + p {
  margin-top: min(6vw, 35px);
}
@media screen and (max-width: 820px) {

  #about .scrollTxt p {
    font-size: 18vw;
    letter-spacing: 0;
    font-weight: 600;
  }
  
  #about .aboutLead {
    line-height: 1.8;
  }
  
}


/* ////////////////////////////////////////////////////////////////////////////////

	Photo

//////////////////////////////////////////////////////////////////////////////// */
#photo2 {
  padding: min(8vw, 60px) 0;
}

.photoBlock01 {
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  margin-bottom: min(4vw, 60px);
}
.photoBlock02 {
  display: flex;
  justify-content: space-between;
}
.photoBlock03 {
  display: flex;
  justify-content: space-between;
}

.photoBlock01 .tysmWrap,
.photoBlock02 .tysmWrap,
.photoBlock03 .tysmWrap {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  width: 12.5%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2.6vw;
}
.photoBlock01 .tysm,
.photoBlock02 .tysm,
.photoBlock03 .tysm {
  background: linear-gradient(180deg, #345e58 0%, #9fb1af 20%, #e1c6b4 50%, #345e58 60%, #9fb1af 80%, #e1c6b4 100%);
  background-size: 400% 400%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: waveGradientV 6s ease infinite;
}
@keyframes waveGradientV {
  0%   { background-position: 50% 0%; }
  50%  { background-position: 50% 100%; }
  100% { background-position: 50% 0%; }
}
.photoPanel {
  width: 87.5%;
  padding-top: 54.17%;
  position: relative;
}
.photoPanel > div {
  position: absolute;
  line-height: 0;
  border: #fff solid 1px;
  width: calc(100% / 3);
  background-color: #000;
}
.photoPanel > div img {
  width: 100%;
  transition: opacity 0.3s ease;
  opacity: 1;
}
.photoPanel > div img.fade-out {
  opacity: 0;
}
.photoPanel .photo01 {
  top: 0;
  left: 0;
}
.photoPanel .photo02 {
  top: 53.8%;
  left: 0;
}
.photoPanel .photo03 {
  top: 0;
  left: calc(100% / 3);
}
.photoPanel .photo04 {
  top: 38.5%;
  left: calc(100% / 3);
  width: calc(100% / 3 / 2);
}
.photoPanel .photo05 {
  top: 38.5%;
  left: calc(100% / 3 + 100% / 3 / 2);
  width: calc(100% / 3 / 2);
}
.photoPanel .photo06 {
  top: 69.23%;
  left: calc(100% / 3);
}
.photoPanel .photo07 {
  top: 0;
  left: calc(100% / 3 * 2);
}
.photoPanel .photo18 {
  top: 30.9%;
  left: calc(100% / 3 * 2);
}
.photoPanel .photo08 {
  top: 61.8%;
  left: calc(100% / 3 * 2);
}
.photoPanel .photo09 {
  top: 0;
  left: 0;
}
.photoPanel .photo10 {
  top: 53.8%;
  left: 0;
}
.photoPanel .photo11 {
  top: 0;
  left: calc(100% / 3);
  width: calc(100% / 3 * 2 / 3 );
}
.photoPanel .photo12 {
  top: 0;
  left: calc(100% / 3 + 100% / 3 * 2 / 3);
  width: calc(100% / 3 * 2 / 3 );
}
.photoPanel .photo13 {
  top: 0;
  left: calc(100% / 3 + 100% / 3 * 2 / 3 * 2);
  width: calc(100% / 3 * 2 / 3 );
}
.photoPanel .photo14 {
  top: 30.77%;
  left: calc(100% / 3);
}
.photoPanel .photo15 {
  top: 69.23%;
  left: calc(100% / 3);
  width: calc(100% / 3 / 2);
}
.photoPanel .photo16 {
  top: 69.23%;
  left: calc(100% / 3 + 100% / 3 / 2);
  width: calc(100% / 3 / 2);
}
.photoPanel .photo17 {
  top: 61.63%;
  left: calc(100% / 3 * 2);
}
.photoPanel .photo19 {
  top: 30.77%;
  left: calc(100% / 3 * 2);
}

@media screen and (max-width: 820px) {
  
  .photoBlock01 .tysmWrap,
  .photoBlock02 .tysmWrap,
  .photoBlock03 .tysmWrap {
    font-size: 5.8vw;
  }
  
  .photoBlock02 {
    display: flex;
  }
  
  .photoPanel {
    padding-top: 119.25%;
  }
  .photoPanel > div {
    width: 50%;
  }
  
  .photoPanel .photo01 {
    aspect-ratio: 100 / 85.9;
    overflow: hidden;
  }
  .photoPanel .photo01 img {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
  }
  .photoPanel .photo02 {
    top: 0;
    left: 50%;
  }
  .photoPanel .photo03 {
    top: 31.5%;
    left: 50%;
  }
  .photoPanel .photo04 {
    top: 57.9%;
    left: 50%;
    width: 25%;
  }
  .photoPanel .photo05 {
    top: 57.9%;
    left: 75%;
    width: 25%;
  }
  .photoPanel .photo06 {
    top: 78.73%;
    left: 50%;
  }
  .photoPanel .photo07 {
    top: 31.5%;
    left: 0;
  }
  .photoPanel .photo18 {
    top: 52.5%;
    left: 0;
  }
  .photoPanel .photo08 {
    top: 73.6%;
    left: 0;
  }
  .photoPanel .photo09 {
    top: 0;
    left: 0;
    aspect-ratio: 100 / 86;
    overflow: hidden;
  }
  .photoPanel .photo10 {
    top: 0%;
    left: 50%;
  }
  .photoPanel .photo11 {
    top: 31.5%;
    left: 0;
    width: calc(100% / 3);
  }
  .photoPanel .photo12 {
    top: 31.5%;
    left: calc(100% / 3);
    width: calc(100% / 3);
  }
  .photoPanel .photo13 {
    top: 31.5%;
    left: calc(100% / 3 * 2);
    width: calc(100% / 3);
  }
  .photoPanel .photo14 {
    top: 52.4%;
    left: 0;
  }
  .photoPanel .photo15 {
    top: 78.73%;
    left: 0;
    width: 25%;
  }
  .photoPanel .photo16 {
    top: 78.73%;
    left: 25%;
    width: 25%;
  }
  .photoPanel .photo19 {
    top: 52.4%;
    left: 50%;
  }
  .photoPanel .photo17 {
    top: 73.53%;
    left: 50%;
  }
}


/* ////////////////////////////////////////////////////////////////////////////////

	News

//////////////////////////////////////////////////////////////////////////////// */
#news {
  display: flex;
  justify-content: space-between;
  padding: min(10vw, 80px) 0;
}
.newsTtl {
  font-size: 4vw;
  line-height: 0.6;
  color: #345e58;
  padding-top: min(4vw, 20px);
}
.newsMain {
  width: 87.4%;
}
.newsMain .newsList {
  margin-right: auto;
  margin-bottom: min(6vw, 40px);
  max-width: 1140px;
  padding-right: min(6vw, 60px);
}
.newsMain .newsList li {
  padding: min(4vw, 20px) 0;
  border-bottom: #beb4a6 solid 1px;
}
.newsMain .newsList li .date {
  font-size: min(3.2vw, 14px);
  margin-bottom: 0.5em;
}
.newsMain .newsList li h3 {
  font-size: min(3.2vw, 14px);
}
.newsMain .newsList li h3 a {
  color: #000;
  text-decoration: none;
}

.newsImg {
  width: 45.8%;
}
.newsImg .tysm {
  margin-bottom: min(7vw, 40px);
  margin-right: min(6vw, 30px);
  margin-left: auto;
  font-size: 2.8vw;
}

@media screen and (min-width: 821px) {
  
  .newsTtl {
    width: 8.6%;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
  
  
}
@media screen and (max-width: 820px) {
	
  #news {
    display: block;
    padding-left: min(6vw, 60px);
    padding-right: min(6vw, 60px);
  }
  .newsTtl {
    font-size: min(6.8vw, 36px);
    padding-top: 0;
    line-height: 1.2;
    margin-bottom: min(3vw, 15px);
  }
  .newsMain {
    width: 100%;
    margin-bottom: min(8vw, 60px);
  }
  .btnBlack {
    margin:  0 auto;
  }
  
  .newsImg {
    width: 100%;
  }
  .newsImg .tysm {
    margin-bottom: min(6vw, 60px);
    margin-right: 0;
    margin-left: auto;
    font-size: 5.4vw;
  }
	
}

/* ////////////////////////////////////////////////////////////////////////////////

	Bnr Area

//////////////////////////////////////////////////////////////////////////////// */
#bnrArea {
  background: url("../images/bg_content_bottom.jpg") no-repeat center bottom;
  background-size: 100%;
  padding: min(10vw, 80px) 0 min(12vw, 100px);
}

#bnrArea .roundBnr {
  width: min(42vw, 240px);
  line-height: 0;
  margin: 0 auto min(10vw, 60px);
}

#bnrArea .bnrList {
  max-width: 680px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: min(6vw, 30px);
  line-height: 0;
}

@media screen and (max-width: 820px) {
	
  
	
}


/* ////////////////////////////////////////////////////////////////////////////////

	Detail

//////////////////////////////////////////////////////////////////////////////// */
#detail {
  padding: min(8vw, 60px) 0;
}
.detailHead {
  padding: 0 5vw;
  margin-bottom: min(8vw, 60px);
  position: relative;
}
.detailHead .tysm {
  font-size: 8.5vw;
  line-height: 1;
  padding-right: 0.1em;
}

.discTtl {
  margin-bottom: min(6vw, 60px);
}
.discTtl .name {
  font-size: min(4.2vw, 24px);
  font-weight: 800;
  margin-bottom: 0.4em;
}
.discTtl h3 {
  font-family: "Times New Roman", Times, Georgia, serif;
  font-size: min(5.4vw, 36px);
  font-weight: 400;
  font-feature-settings: "palt";
  line-height: 1.3;
  letter-spacing: 0.06em;
  margin-bottom: 0.1em;
}
.discTtl h3 span {
  display: block;
  font-size: min(3.8vw, 20px);
  margin-bottom: 0.3em;
  letter-spacing: 0.06em;
}
.discTtl .date {
  font-size: min(3.8vw, 20px);
}

.introTxt {
  margin-bottom: min(8vw, 60px);
}
.introTxt p {
  line-height: 2;
  letter-spacing: 0.04em;
}
.introTxt p + p {
  margin-top: min(6vw, 30px);
}

.discType {
  border-top: #beb4a6 solid 1px;
}
.discType > li {
  padding: min(6vw, 30px) 0;
  border-bottom: #beb4a6 solid 1px;
}

.discType > li h4 {
  font-size: min(4.2vw, 20px);
  font-weight: 500;
  line-height: 1.6;
  margin-bottom: 1em;
}
.discType > li h4:last-child {
  margin-bottom: 0;
}
.discType > li h4 span {
  display: block;
  font-size: 0.6em;
  margin-top: 0.5em;
}
.discType > li h5 {
  font-size: min(3.8vw, 18px);
  font-weight: 500;
  margin-bottom: 0.8em;
}

.discType > li .trackWrap {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: min(4vw, 20px);
}
.discType > li .trackWrap .trackList {
  background-color: rgba(255,255,255,0.50);
  border: #b5bdb8 solid 1px;
  width: calc(50% - 10px);
  padding: min(4vw, 20px) min(4vw, 20px) min(4vw, 20px) min(11vw, 60px);
  font-size: min(3.2vw, 14px);
}
.discType > li .trackWrap .whiteBox {
  background-color: rgba(255,255,255,0.50);
  border: #b5bdb8 solid 1px;
  width: calc(50% - 10px);
  padding: min(4vw, 20px);
}
.discType > li .trackWrap .whiteBox h6 {
  text-align: center;
  font-size: min(3.8vw, 18px);
  padding-bottom: min(3vw, 15px);
  margin-bottom: min(3vw, 15px);
  border-bottom: #beb4a6 solid 1px;
}
.discType > li .trackWrap .whiteBox .btnBlack {
  margin: 0 auto;
}
.discType > li .trackWrap .whiteBox .price {
  font-size: min(3.2vw, 14px);
}

.discType > li p {
  margin-bottom: min(3vw, 15px);
}
.discType > li p:last-child {
  margin-bottom: 0;
}
.discType > li p.note {
  font-size: 0.8em;
}

@media screen and (max-width: 820px) {
	
  .detailHead .tysm {
    font-size: 10.4vw;
  }
  
  .discType > li .trackWrap {
    flex-direction: column;
    gap: 0;
  }
  .discType > li .trackWrap .trackList {
    width: 100%;
  }
  .discType > li .trackWrap .trackList:nth-child(1) {
    padding-bottom: 0;
    border-bottom: none;
  }
  .discType > li .trackWrap .trackList:nth-child(2) {
    padding-top: 0;
    border-top: none;
  }
  
  
  .discType > li h4 span {
    font-size: 0.74em;
  }
  
  .discType > li .trackWrap .whiteBox {
    width: 100%;
  }
  .discType > li .trackWrap .whiteBox + .whiteBox {
    margin-top: min(4vw, 20px);
  }
  .discType > li p.note {
    font-size: 0.8em;
    letter-spacing: 0;
  }
	
}

/* ////////////////////////////////////////////////////////////////////////////////

	Footer

//////////////////////////////////////////////////////////////////////////////// */
footer {
  font-family: "source-han-sans-japanese", sans-serif;
	background-color: #000;
	color: #fff;
	position: relative;
}
footer .ftrSns {
	display: flex;
	border-bottom: #333 solid 1px;
}
footer .ftrSns li {
	width: 20%;
}
footer .ftrSns li + li {
	border-left: #333 solid 1px;
}
footer .ftrSns li a {
	color: #fff;
	text-decoration: none;
	font-size: 12px;
	font-weight: 500;
	line-height: 1.6;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	padding: 25px 30px;
	height: 100%;
}
footer .ftrSns li a i.snsIcon {
	color: #fff;
	font-size: 24px;
	margin-right: 20px;
}
footer .ftrSns li a span {
    width: 45px;
	line-height: 0;
	margin-right: 20px;
}

footer .ftrMain {
	padding: min(6vw, 60px) min(6vw, 60px) min(10vw, 100px);
}
footer .ftrMain .copyWrap {
	display: flex;
	align-items: center;
	width: 82%;
	max-width: 880px;
	margin: auto;
}
footer .ftrMain .copyWrap .logo {
	width: 540px;
	margin-right: 30px;
}
footer .ftrMain .copyWrap p {
	font-size: 12px;
	font-weight: 200;
}
footer .ftrMain .copyright {
	font-size: 10px;
	text-align: center;
	margin-top: 30px;
	font-weight: 200;
}


footer .ftrMain .ftrNav {
	width: 50%;
	display: flex;
}
footer .ftrMain .ftrNav ul {
	width: 50%;
	border-left: #333 solid 1px;
	padding: 0 6%;
}
footer .ftrMain .ftrNav li + li {
	margin-top: 8px;
}
footer .ftrMain .ftrNav a {
	color: #fff;
	text-decoration: none;
	font-size: 14px;
}
footer .ftrMain .ftrSubNav {
	width: 25%;
	border-left: #333 solid 1px;
	padding: 0 3%;
}
footer .ftrMain .ftrSubNav li + li {
	margin-top: 8px;
}
footer .ftrMain .ftrSubNav a {
	color: #fff;
	text-decoration: none;
	font-size: 14px;
}

@media screen and (max-width: 820px) {

	footer .ftrSns {
		display: flex;
		flex-wrap: wrap;
	}
	footer .ftrSns li {
		width: 50%;
	}
	footer .ftrSns li:last-child {
		width: 100%;
	}
	footer .ftrSns li + li {
		border-left: none;
	}
	footer .ftrSns li:nth-child(even) {
		border-left: #333 solid 1px;
	}
	footer .ftrSns li:nth-child(n+3) {
		border-top: #333 solid 1px;
	}

	footer .ftrSns li a {
    	font-size: min(2.6vw, 12px);
		padding: min(4vw, 25px) min(5vw, 30px);
	}
	footer .ftrSns li a i.snsIcon {
		font-size: min(6vw, 24px);
		margin-right: min(3vw, 20px);
	}
	footer .ftrSns li a span {
		width: min(14vw, 45px);
		margin-right: min(4vw, 20px);
	}
	footer .ftrSns li:last-child a {
		justify-content: center;
	}

	footer .ftrMain {
	  padding: min(6vw, 60px) min(6vw, 60px) min(22vw, 100px);
	}
	footer .ftrMain .copyWrap {
		flex-direction: column;
	}
	footer .ftrMain .copyWrap .logo {
    width: 68%;
    max-width: 240px;
    margin: 0 auto min(5vw, 25px);
    
	}
	footer .ftrMain .copyWrap p {
		font-size: min(3vw, 12px);
	}
	footer .ftrMain .copyright {
		font-size: min(2.2vw, 10px);
		margin-top: min(8vw, 30px);
	}

}