:root {
  --color-orange: #faa74a;
  --color-mint: #00b6ad;
}

.font25 {
  --fontsize: 2.5rem;
  font-size: var(--fontsize);
}

.font28 {
  --fontsize: 2.8rem;
  font-size: var(--fontsize);
}

.font34 {
  --fontsize: 3.4rem;
  font-size: var(--fontsize);
}

.font45 {
  --fontsize: 4.5rem;
  font-size: var(--fontsize);
}

.font50 {
  --fontsize: 5.0rem;
  font-size: var(--fontsize);
}

.font60 {
  --fontsize: 6.0rem;
  font-size: var(--fontsize);
}

@media screen and (max-height: 800px){
	#news,
	#fullpage .community,
	#notice
	{ 
		padding: 80px 0;
	}
}

@media (max-width: 1860px) {
  .w1800,
  .w1400,
  #fp-nav ul,
  #fullpage .visual .visualBox {
    padding: 0 20px;
  }
  #subContents .business ul li {
    column-gap: 20px;
  }
  #subContents .information.classification .contents {
    gap: 0 60px;
  }
}

@media screen and (max-width: 1700px){
	header .sns{
	  margin-left: 0;
    }
}

@media (max-width: 1640px) {
  :root{
	--headerH: 90px;
  }
  header .logo{
	width: 220px;
  }
  header nav {
    --before: 150px;
    --after: 180px;
	margin-right: 0;
  }
  header .depth1 > li > a{
	font-size: 18px;
  }
  header .depth2{
	padding-top: calc(var(--headerH) + 10px);
	padding-bottom: 10px;
  }
  header .depth2 > li > a{ 
	font-size: 16px;
	padding: 10px 5px;
  }
  header .depth3 > li > a{
	font-size: 15px;
  }
  .allMenu {
    max-width: calc(100% - 40px);
  }
  #fullpage .community .mapBox {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .topButton{
	bottom: 20px;
	right: 20px;
  }
}

@media (max-width: 1600px) {
  footer .buttonBox{
	margin-top: 100px;
  }
  /* main */
  #visual .content .link .grid .item{
    padding: 30px;
  }
  #visual .content .link .grid .item p{
	font-size: 18px;
  }
  #visual .content .link .grid .item .icon img{ 
    height: 65px;
  }
  #news .tabMenu ul li{
    font-size: 18px;
	padding: 8px 20px;
  }
  #news .btns *{
	font-size: 18px;
  }
  #news .swiper-slide a{
	padding: 25px;
  }
  #news .swiper-slide span{
	font-size: 15px;
  }
  #news .swiper-slide dl{
	margin: 10px 0 20px;
  }
  #news .swiper-slide dl dt{ 
	font-size: 22px;
  }
  #news .swiper-slide dl dd{
	font-size: 16px;
	margin-top: 10px;
  }
  #notice .tit h6{
	font-size: 20px;
  }
  #notice .tit a{
	font-size: 16px;
  }
  #notice .event .text{
	padding: 25px;
  }
  #notice .event .text span{
	font-size: 14px;
	padding: 5px 11px;
  }
  #notice .event .text h6{
	font-size: 20px;
  }
  #notice .news .text{ 
	padding: 25px;
	padding-top: 20px;
  }
  #notice .news .text h6{
	font-size: 18px;
  }

  /* sub */
  #subContents .promotion .necessity .itemBox {
    gap: 0 20px;
  }
  #subContents .promotion .necessity dl dt span {
    font-size: 5rem;
  }
  #subContents .location .infoBox dl dt {
    max-width: 240px;
  }
  #subContents .newsView .related {
    padding: 0;
  }
  #subContents .newsView .related .relatedSlideBox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 20px 0;
    margin: 0;
  }
  #subContents .newsView .related .tagBox {
    margin: 20px 0 0;
    position: relative;
    left: auto;
    bottom: auto;
  }
  #subContents .newsView .related .buttonBox {
    width: 100%;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    gap: 0 10px;
    position: relative;
    top: auto;
    left: auto;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@media (max-width: 1500px) {
	header nav{
		--before: 130px;
		--after: 160px;
	}
	header .sns ul li a{
		padding: 7px;
	}
	header .popupButton{
		font-size: 14px;
		margin: 0 10px;
		padding: 10px;
	}
}

@media (max-width: 1400px) {
  :root{
	--headerH: 80px;
  }
  .font50,
  .font60,
  .font70{
    font-size: calc(var(--fontsize) * 0.86);
  }
  .topButton {
    right: 20px;
    bottom: 20px;
  }
	
  header .logo{
	width: 200px;
  }

  .allMenu .flexBox {
    padding: 80px 40px 40px;
  }
  .allMenu #snb .depth2 {
    padding: 30px 0 0;
  }
  #fullpage .community .infoBox {
    padding: 40px 20px 0 0;
  }
  .subFlexRow {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px 0;
  }
  .subFlexRow h2 br,
  .subFlexRow h3 br {
    display: none;
  }
  .subFlexRow > *:last-child {
    max-width: 100%;
  }
  #subContents .greetings .itemBox {
    gap: 0 40px;
  }
  #subContents .greetings .img {
    width: 40%;
  }
  #subContents .ci .tabTitle {
    max-width: 100%;
  }
  #subContents .location .infoBox {
    padding: 40px;
    right: 20px;
  }
  #subContents .location .infoBox ul {
    gap: 20px 0;
  }
  #subContents .location .counsel {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 30px 0;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  #subContents .information.classification .mapBox {
    display: none;
  }
  #subContents .information.news .galleryBox {
	gap: 60px 20px;
  }
  #subContents .promotion .necessity .itemBox {
    -ms-grid-columns: (minmax(auto, 320px))[2];
        grid-template-columns: repeat(2, minmax(auto, 320px));
    gap: 40px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #subContents .promotion .necessity .item {
    height: auto;
    padding: 40px 0;
  }
  #subContents .business ul {
    gap: 0 20px;
  }
  #subContents .heart.checkup .grayBox {
    padding: 40px;
  }
  #subContents .heart.type .itemBox {
    gap: 0 20px;
  }
  #subContents .heart.tools .itemBox label {
    padding: 30px 20px;
  }
  #subContents .heart.list .checkupList ul li > div {
    padding: 20px 25px;
  }
  #subContents .heart.results .checkupList ul li > div {
    padding: 0 40px 20px;
  }
  #subContents .heart.apply .form {
    gap: 0 40px;
  }
  #subContents .heart.apply .form .checklistBox {
    width: 440px;
  }
  #subContents .heart.apply .form .checklist {
    padding: 40px 20px;
  }
  #subContents .heart.apply .form .calendar td > div {
    padding: 10px;
  }
  #subContents .participation.application .item {
    padding: 30px 30px 50px;
  }
  #subContents .participation.application table.typeResult .col3 {
    width: 15%;
  }
  #subContents .participation.application table.typeResult .col4 {
    width: 19%;
  }
  #subContents .participation.eventList .eventSlideBox {
    gap: 0 40px;
  }
  #subContents .participation.eventList .eventImgSlideBox,
  #subContents .participation.eventList .eventTextSlideBox {
    width: 50%;
    max-width: inherit;
  }

  .introduce-new .listbox > dl > dt {
    width: 100%;
  }
  .introduce-new .listbox > dl > dt br {
    display: none;
  }
  .introduce-new .listbox > dl > dd {
    width: 100%;
    margin-top: 40px;
  }

  footer .copy {
    font-size: 1.3rem;
  }

  .floating{
	bottom: 20px;
	right: 20px;
  }
  .floating ul li:not(:last-of-type){
	margin-bottom: 10px;
  }
  .floating button{
    width: 50px;
	height: 50px;
	padding: 12px;
	border-radius: 20px;
  }
  .floating .link > div{
	padding-bottom: 60px;
  }
  .floating .call .icon{
	padding: 12px;
  }
}

@media (max-width: 1300px) {
	header .sns{ display: none; }

	footer .buttonBox{ 
		flex-direction: column-reverse;
		align-items: flex-start;
		margin-top: 60px;
	}
	footer .buttonBox .family{
		margin-bottom: 20px;
	}

	#notice .item i{ 
		width: 60px; height: 60px; 
	}
	#notice .item i::before{
		width: 25px; height: 25px;
	}
}

@media (max-width: 1200px) {
  :root{
	--headerH: 70px;
  }
  html,
  body {
    font-size: 56.25%;
  }
  .font50,
  .font60,
  .font70 {
    font-size: calc(var(--fontsize) * 0.78);
  }
  .font45 {
    font-size: calc(var(--fontsize) * 0.80);
  }
  .font34 {
    font-size: calc(var(--fontsize) * 0.90);
  }
  .font28 {
    font-size: calc(var(--fontsize) * 0.92);
  }
  header nav {
    display: none;
  }
  header .social {
    margin: 0 40px 0 auto;
  }
  .allMenu .flexBox {
    padding: 40px;
  }
  .allMenu #snb .pc{
	display: none !important;
  }
  .allMenu #snb .mobile{
	display: flex;
  }
  .allMenu #snb > ul {
    width: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: relative;
  }
  .allMenu #snb a {
    height: 60px;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .allMenu #snb > ul > li {
    text-align: left;
    position: revert;
  }
  .allMenu #snb > ul > li > a {
    font-size: 2.2rem;
  }
  .allMenu #snb .cover {
    width: 100%;
    height: 0;
    position: absolute;
    top: 0;
    left: 100%;
    overflow: hidden;
  }
  .allMenu #snb .cover.off {
    height: auto;
    overflow: inherit;
  }
  .allMenu #snb .depth2 {
    padding: 0 0 0 40px;
  }
  .allMenu #snb .depth2 > li {
    padding: 0;
    -webkit-transform: translateX(40px);
            transform: translateX(40px);
  }
  .allMenu #snb .depth2.on > li {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  .allMenu .point {
    width: 56%;
  }
  .allMenu .social {
    height: 50px;
  }
  .allMenu .social li {
    width: 170px;
  }

   /* main */
   #fullpage .ptH{
	 display: none;
   }
   #visual .content h2{
     margin-bottom: 50px;
   }
   #visual .content .flex-box > div{
	  width: calc((100% - 15px) / 2);
   }
   #visual .content .vp .video button{
	  width: 55px;
	  height: 55px;
   }
   #visual .content .vp .dots{
	  bottom: 15px;
   }
   #visual .content .vp .dots span{
      width: 8px;
	  height: 8px;
   }
   #visual .content .vp .dots span:not(:last-child){
      margin-right: 10px;
   }
   #visual .content .link .grid .item{
	  padding: 20px;
   }
   #visual .content .link .grid .item p{
	  font-size: 16px;
   }
   #visual .content .link .grid .item p::after{
	  width: 5px;
   }
   #visual .content .link .grid .item .icon img{
	  height: 55px;
   }
   #news{ 
	  padding: 80px 0;
	}
	#news .title{
	  flex-direction: column;
	  margin-bottom: 20px;
	}
	#news .title .tit{
	  width: 100%;
	  margin-bottom: 40px;
	}
	#news .tabMenu ul li{
		font-size: 16px;
		padding: 8px 15px;
	}
	#news .btns *{
		font-size: 16px;
	}
	#news .btns button{
	  width: 45px;
	  height: 45px;
	}
	#news .btns a{
	  padding: 0 20px;
	}
	#news .swiper-slide a{
		padding: 20px;
	}
	#news .swiper-slide span{
		font-size: 14px;
		padding: 6px 10px;
	}
	#news .swiper-slide dl{
	  margin: 5px 0 20px;
	}
	#news .swiper-slide dl dt{
		font-size: 20px;
	}
	#news .swiper-slide dl dd{ 
	  margin-top: 5px;
	}
  #fullpage .community {
  	padding: 80px 0;
    background: #f5f5f5;
  }
  #fullpage .community .box{
	padding: 0;
  }
  #fullpage .community .infoBox {
    width: 100%;
    padding: 0;
  }
  #fullpage .community .infoBox .text {
    text-align: center;
  }
  #fullpage .community .infoBox .text h2 br {
    display: none;
  }
  #fullpage .community .communitySlideBox {
    margin: 0;
  }
  #fullpage .community .communitySlideBox .item .info {
    padding: 30px 20px;
  }
  #fullpage .community .mapBox {
    display: none;
  }
  #fullpage .community .map {
    width: 50%;
    margin: 60px auto 40px;
  }
  #notice{
	padding: 80px 0;
  }
  #notice .plusTit{
	margin-bottom: 30px;
  }
  #notice .tit{ 
	margin-bottom: 20px;
  }
  #notice .tit h6{
	font-size: 18px;
  }
  #notice .event .img span{ 
    width: 25px; 
	height: 25px;
	font-size: 15px;
	line-height: 25px;
	top: 10px;
	left: 10px;
  }
  #notice .event .text{  
	padding: 20px;
  }
  #notice .event .text span{
	font-size: 13px;
	padding: 5px 10px;
	margin-bottom: 10px;
  }
  #notice .event .text h6{ 
	font-size: 18px;
	margin-bottom: 10px;
  }
  #notice .news .text{ 
	padding: 20px;
  }
  #notice .news .text h6{
	font-size: 16px;
  }

 
  .paddingBox {
    padding: 80px 0;
  }
  .paddingBox.paddingTopX {
    padding: 0 0 80px;
  }
  .paddingBox.paddingBottomX {
    padding: 80px 0 0;
  }
  .marginTop90 {
    margin-top: 60px;
  }
  .subFlexColumn.gap140 {
    gap: 80px 0;
  }
  #sv {
    height: 520px;
  }
  #sv #lnb li a .simpleBus {
    width: 220px;
  }
  #subContents .greetings .itemBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px 0;
  }
  #subContents .greetings .img,
  #subContents .greetings .item {
    width: 100%;
    max-width: 580px;
    margin: 0 auto;
  }
  #subContents .brand .inner {
    gap: 20px 0;
  }
  #subContents .brand .line {
    width: 56px;
  }
  #subContents .brand .center {
    width: 34%;
    padding: 17% 0;
  }
  #subContents .brand .center .inner {
    gap: 30px 0;
  }
  #subContents .brand .center .logo {
    width: 180px;
  }
  #subContents .brand .logoBox .text p span{
	display: block;
  }
  #subContents .brand .flexBox dl{
	padding: 30px;
  }
  #subContents .brand .logoBox .text p{
    margin-top: 20px;
  }
  #subContents .ci .introduce .plus ul li {
    width: 180px;
  }
  #subContents .location .itemBox {
    height: auto;
  }
  #subContents .location #map {
    height: 580px;
  }
  #subContents .location #map > div:first-child::before {
    display: none;
  }
  #subContents .location .infoBox {
    padding: 0 20px;
    margin: 60px 0 0;
    position: relative;
    top: auto;
    right: auto;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  #subContents .location .counsel dl dt {
    font-size: 3.4rem;
    margin: 0 0 20px;
  }
  #subContents .location .counsel ul li {
    width: auto;
    height: auto;
    padding: 10px 20px;
  }
  #subContents .business .icon {
    width: 100px;
    height: 100px;
  }
  #subContents .business ul li {
    height: auto;
    gap: 0 30px;
    padding: 40px 0;
  }
  #subContents .business dl {
    margin: 0;
  }
  #subContents .information.understanding .info p br {
    display: none;
  }
  #subContents .information.understanding .itemBottomBox .item {
    padding: 20px;
  }
  #subContents .information.understanding .itemBottomBox p br {
    display: none;
  }
  #subContents .information.understanding ul.radiusBox p br {
    display: none;
  }
  #subContents .information.depression .info .listBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .information.unrest .treatment > p br {
    display: none;
  }
  #subContents .information.statistics .chartBorder {
    padding: 40px 20px;
  }
  #subContents .information.statistics .infoBox ul {
    gap: 0 20px;
  }
  #subContents .heart.checkup .checkupTab {
    gap: 0 20px;
  }
  #subContents .heart.checkup .checkupTab a {
    padding: 25px 10px;
  }
  #subContents .heart.type label {
    height: 300px;
    padding: 20px 0;
  }
  #subContents .heart.tools .itemBox {
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
  }
  #subContents .heart.tools .itemBox label {
    padding: 20px;
  }
  #subContents .heart.list .checkupList ul li > div {
    padding: 0 20px 25px;
  }
  #subContents .heart.list .listBox colgroup,
  #subContents .heart.list .listBox thead {
    display: none;
  }
  #subContents .heart.list .listBox caption {
    color: #333333;
    font-size: 1.7rem;
    line-height: 1.2;
    margin: 0 0 10px;
  }
  #subContents .heart.list .listBox tr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 20px 5px;
    background: #ffffff;
    border-bottom: 1px solid #e0e0e0;
    padding: 20px;
  }
  #subContents .heart.list .listBox tr.bg,
  #subContents .heart.list .listBox tr.bg > * {
    background: #f9f9f9;
  }
  #subContents .heart.list .listBox th,
  #subContents .heart.list .listBox td {
    border-bottom: none;
    font-size: 1.6rem;
    padding: 0;
  }
  #subContents .heart.list .listBox th:not(:last-child),
  #subContents .heart.list .listBox td:not(:last-child) {
    border-right: none;
  }
  #subContents .heart.list .listBox th {
    width: 18px;
    background: #ffffff;
  }
  #subContents .heart.list .listBox td {
    width: 100%;
  }
  #subContents .heart.list .listBox td.subject {
    width: calc(100% - 30px);
  }
  #subContents .heart.list .listBox td.none {
    display: block;
    font-weight: 500;
  }
  #subContents .heart.list .listBox label span {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0 4px;
  }
  #subContents .heart.list .listBox label span br {
    display: none;
  }
  #subContents .heart.results .textBox,
  #subContents .heart.results .dlBox {
    padding: 20px;
  }
  #subContents .heart.results .textBox {
    gap: 0;
  }
  #subContents .heart.results .bottom ul {
    gap: 0 20px;
  }
  #subContents .heart.apply .form {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px 0;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #subContents .heart.apply .form .checklistBox {
    width: auto;
  }
  #subContents .heart.apply .form .list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
    gap: 40px;
  }
  #subContents .heart.apply .form .simpleButton {
    position: relative;
    left: auto;
    bottom: auto;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  #subContents .heart.apply .form .calendar em {
    font-size: 1.4rem;
  }
  #subContents .heart.apply .form .stateBox span {
    font-size: 1.4rem;
  }
  #subContents .participation.application .itemBox {
    gap: 20px;
  }
  #subContents .participation.application .item {
    width: calc(50% - 10px);
    padding: 30px 30px 80px;
  }
  #subContents .participation.application table.typeResult colgroup,
  #subContents .participation.application table.typeResult thead,
  #subContents .participation.application table.typeResult td:first-child,
  #subContents .participation.application table.typeResult br {
    display: none;
  }
  #subContents .participation.application table.typeResult tr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 15px 0;
    border-bottom: 1px solid #e0e0e0;
    padding: 20px;
  }
  #subContents .participation.application table.typeResult td {
    border-bottom: none;
    padding: 0;
  }
  #subContents .participation.application table.typeResult td.left {
    width: 100%;
  }
  #subContents .participation.application table.typeResult td.after::after {
    content: "|";
    color: #999999;
    font-size: 1.4rem;
    margin: 0 10px;
  }
  #subContents .participation.eventList .eventSlideBox a {
    margin: 60px 0 0;
  }
  #subContents .participation.eventList .item a {
    gap: 0 40px;
  }

  .introduce-new .top {
    flex-wrap: wrap;
    justify-content: center;
  }
  .introduce-new .top .img {
    position: relative;
    width: 100%;
    max-width: 620px;
    left: unset;
  }
  .introduce-new .top .txtbox {
    margin: -8% 0 0;
    max-width: 1100px;
    width: 100%;
  }
  .introduce-new .schedule-box {
    margin-top: 40px;
  }
  .introduce-new .schedule-box .calendar-box,
  .introduce-new .schedule-box .schedule-list {
    width: 100%;
    padding: 20px;
  }
  .introduce-new .schedule-box .schedule-list {
    margin-top: 20px;
  }
  .introduce-new h4.tit {
    font-size: 3.0rem;
    padding-left: 34px;
  }
  .introduce-new h4.tit::before {
    top: 8px;
    width: 23px;
    height: 23px;
  }
  .introduce-new .listbox > dl > dd .txtbox li div p span{
    width: 90px;
  }

  footer .buttonBox .family > div:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: -1;
    grid-area: 1/3/2/2;
  }
  footer .buttonBox .family > div:nth-child(2) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    grid-area: 2/1;
  }
  footer .buttonBox .family > div:nth-child(3) {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
    grid-area: 2/2;
  }

   .floating .link a{
	padding: 12px 17px;
   }
  .floating .link a::after{
	width: 15px;
	height: 15px;
	margin-left: 5px;
	transform: translateY(-1px);
  }
}

@media (max-width: 1024px) {
  .cursor {
    display: none;
  }
  #subContents .brand .logoBox{
	width: 300px;
  }
  #subContents .brand .logoBox::before,
  #subContents .brand .logoBox::after{
	display: none;
  }
  #subContents .brand .logoBox .cc{
	margin: 30px 0 40px;
  }
  #subContents .brand .logoBox .cc::before{
	border-width: 10px;
	padding-bottom: calc(100% - 20px);
  }
  #subContents .brand .logoBox .cc::after{
	display: none;
  }
  #subContents .brand .logoBox img{
	width: 120px;
  }
  #subContents .brand .logoBox .text{
	padding: 0 50px;
  }
  #subContents .brand .flexBox dl{
	width: 100%;
	padding: 10px 20px 20px;
	position: relative;
  }
  #subContents .brand .flexBox dl::before{
	content: "";
	width: 1px;
	height: 40px;
	border-right: 4px dotted var(--color-orange);
	-webkit-border-right: 4px dotted var(--color-orange);
	position: absolute;
	top: 0;
	left: 50%;
	z-index: -1;
	transform: translateY(-100%);
  }
  #subContents .brand .flexBox dl dt{
	margin-bottom: 10px;
  }
  #subContents .brand .flexBox dl .img{
	height: 60px;
	margin-bottom: 10px;
  }
  #subContents .brand .flexBox dl dt p{
	padding-bottom: 5px;
  }
}

@media (max-width: 960px) {
  .font50,
  .font60,
  .font70 {
    font-size: calc(var(--fontsize) * 0.64);
  }
  .font45 {
    font-size: calc(var(--fontsize) * 0.66);
  }
  .font34 {
    font-size: calc(var(--fontsize) * 0.74);
  }
  .allMenu .social {
    height: auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 10px 0;
  }
  .allMenu .social li {
    height: 50px;
  }
  .visualTitle {
    font-size: 8.2rem;
  }
  .subFlexColumn {
    gap: 60px 0;
  }
  .tag {
    width: auto;
    /* max-width: 64px; */
    height: 28px;
    border-radius: 14px;
    padding: 0 10px;
  }
  table.typeForm colgroup {
    display: none;
  }
  table.typeForm tr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  table.typeForm th,
  table.typeForm td {
    width: 100%;
    height: auto;
    padding: 15px 20px;
  }
  table.typeForm th {
    text-align: left;
  }
  table.typeForm td > div {
    height: 50px;
  }
  .comment .name {
    width: 100px;
  }
  .comment .date {
    margin: 0;
  }
  
  /* main */
  #fullpage .plusTit::after{
	width: 16px; 
	height: 16px;
  }
  #visual .content{
	min-height: auto;
	padding: calc(var(--headerH) + 40px) 0 80px;
   }
  #visual .content h2{
	--fontsize: 6.5rem;
  }
  #visual .content .flex-box{
	flex-direction: column;
	align-items: center;
  }
  #visual .content .flex-box > div{
    width: 100%;
	max-width: 520px;
  }
  #visual .content .flex-box > div:not(:last-of-type){
	 margin-bottom: 20px;
   }
   #news .title .tit{
	  flex-direction: column;
	  align-items: flex-start;
   }
   #news .tabMenu{
     margin-top: 20px;
	 margin-left: 0;
   }
   #notice .flex-box{
	 flex-direction: column;
	 align-items: center;
   }
   #notice .flex-box > div{
	width: 100%;
	max-width: 520px;
   }
    #notice .flex-box > div:not(:last-of-type){
		margin-bottom: 20px;
	}
	#notice .news .text{
		padding: 15px;
	}
	#notice .item i{ 
		width: 50px; height: 50px; 
	}
	#notice .item i::before{
		width: 25px; height: 25px;
	}

  #sv #lnb li a {
    font-size: 1.6rem;
  }
  #sv #lnb li a .simpleBus {
    width: 180px;
  }
  #subContents .brand .circle {
    width: 24%;
    padding: 12% 0;
  }
  #subContents .brand .line {
    width: 32px;
  }
  #subContents .brand .logo {
    height: 50px;
  }
  #subContents .brand .center {
    width: 40%;
    padding: 20% 0;
  }
  #subContents .brand .center .logo {
    width: 140px;
  }
  #subContents .ci .introduce .plus {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 20px 0;
  }
  #subContents .ci .introduce .plus ul {
    width: 100%;
  }
  #subContents .ci .introduce .plus ul li {
    width: calc((100% - 40px) / 3);
    padding: 30px 20px;
  }
  #subContents .ci .introduce .plus ul li:not(.plusIcon) {
    height: 280px;
  }
  #subContents .ci .introduce .plus .plusIcon {
    margin: 0 -8px;
  }
  #subContents .ci .introduce .plus .logo {
    width: calc(100% - 87px);
    height: 260px;
  }
  #subContents .ci .introduce .rule ul li {
    gap: 0 20px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 30px 0;
  }
  #subContents .ci .introduce .rule dl,
  #subContents .ci .introduce .rule p {
    padding: 0;
  }
  #subContents .ci .introduce .rule p br {
    display: none;
  }
  #subContents .ci .download .gridBg {
    height: 260px;
    gap: 0 80px;
    padding: 40px;
  }
  #subContents .promotion .history em {
    font-size: 3.2rem;
    text-align: left;
  }
  #subContents .promotion .history .bar {
    left: 0;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  #subContents .promotion .history .list {
    width: 100%;
    padding: 0 30px;
  }
  #subContents .promotion .history .list.left{
	text-align: left;
  }
  #subContents .promotion .history .list.right {
    margin: 0;
  }
  #subContents .promotion .history .list.left,
  #subContents .promotion .history .list.left dl {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        /* -ms-flex-direction: row;
            flex-direction: row; */
  }
  #subContents .promotion .history .list.left dl{
	flex-direction: row;
  }
  #subContents .business ul {
    -ms-grid-columns: (1fr)[1];
        grid-template-columns: repeat(1, 1fr);
    gap: 0;
  }
  #subContents .business ul li {
    border-top: 1px solid #e5e5e5;
    border-bottom: none;
  }
  #subContents .information.understanding ul.radiusBox.typeList li {
    padding: 20px;
  }
  #subContents .information.understanding ul.radiusBox.typeList li.clickOn > div {
    padding: 20px;
  }
  #subContents .information.understanding ul.radiusBox.typeImg li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .information.understanding ul.radiusBox.typeImg .text {
    padding: 0;
  }
  #subContents .information.understanding ul.radiusBox.typeIcon li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 30px 0;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 20px;
  }
  #subContents .information.understanding .tagBox .tag {
    max-width: inherit;
  }
  #subContents .information.statistics .infoBox ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 30px 0;
  }
  #subContents .information.statistics .infoBox p br {
    display: none;
  }
  #subContents .information.classification .topTitle .simpleBus {
	height: 50px;
  }
  #subContents .information.classification .tableBox {
    overflow-x: scroll;
  }
  #subContents .information.classification .tableBox table {
    width: 920px;
  }
  #subContents .heart.type .itemBox {
    gap: 20px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #subContents .heart.type label {
    width: calc(50% - 10px);
  }
  #subContents .heart.results .graph {
    height: 50px;
    margin: 40px 0 30px;
  }
  #subContents .heart.results .textBox .icon {
    width: 80px;
    height: 80px;
  }
  #subContents .heart.results .textBox .icon img {
    width: 28px;
  }
  #subContents .heart.results .bottom .tag {
    max-width: inherit;
  }
  #subContents .heart.results .bottom ul li {
    height: 120px;
  }
  #subContents .heart.introduce .use .itemBox {
    gap: 10px 0;
  }
  #subContents .heart.apply .form .checklistBox {
    gap: 20px 0;
  }
  #subContents .heart.apply .form .list {
    -ms-grid-columns: (1fr)[1];
        grid-template-columns: repeat(1, 1fr);
    gap: 30px 0;
  }
  #subContents .heart.apply .form .month {
    gap: 0 20px;
    margin: 0 0 20px;
  }
  #subContents .participation.application .itemBox {
    gap: 20px 0;
  }
  #subContents .participation.application .item {
    width: 100%;
  }
  #subContents .participation.eventList .eventSlideBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px 0;
  }
  #subContents .participation.eventList .eventImgSlideBox,
  #subContents .participation.eventList .eventTextSlideBox {
    width: 100%;
  }
  #subContents .participation.eventList .item {
    padding: 30px 0;
  }
  #subContents .participation.eventList .item a {
    gap: 0 20px;
  }

  .introduce-new h4.tit {
    font-size: 2.4rem;
    padding-left: 26px;
  }
  .introduce-new .cont {
    margin-top: 60px;
  }
  .introduce-new .bgCont {
    margin-top: 80px;
    padding:80px 0 120px;
  }
  .introduce-new .bgCont .cont {
    margin-top: 80px;
  }
  .introduce-new h4.tit::before {
    top: 6px;
    width: 18px;
    height: 18px;
  }
  .introduce-new .schedule-box {
    margin-top: 20px;
  }

  .introduce-new .schedule-box .calendar-top { 
    gap: 0 20px;
  }
  .introduce-new .schedule-box .calendar-top a { 
    width: 38px;
    height: 38px;
  }
  .introduce-new .schedule-box .calendar-top strong { 
    font-size: 2.6rem;
  }
  .introduce-new .schedule-box .infobox { 
    margin-top: 20px;
  }
  .introduce-new .schedule-box .infobox ul { 
    gap: 5px 12px;
  }
  .introduce-new .schedule-box .infobox ul li { 
    gap: 0 5px;
  }
  .introduce-new .schedule-box .calendar-body { 
    margin-top: 20px;
    border-top: 1px solid #e0e0e0 !important;
  }
  .introduce-new .schedule-box .calendar-body tbody td { 
    padding: 8px;
    height: 55px;
  }
/*
  .introduce-new .schedule-box .calendar-body tbody td { 
    height: auto;
    text-align: left;
    vertical-align: top;
    padding: 8px;
    display: block;
    flex-direction: row-reverse;
    justify-content: flex-end;
    gap: 0 5px;
    border-right: none;
  }
  .introduce-new .schedule-box .calendar-body thead,
  .introduce-new .schedule-box .calendar-body tbody td.off { 
    display: none 
  }
  .introduce-new .schedule-box .calendar-body tbody td .day-label { 
    display: inline-block; 
  }
*/
  .introduce-new .schedule-box .calendar-body tbody td .stxt { 
    display: none 
  }
  .introduce-new .schedule-box .schedule-list .tit {
    font-size: 2.2rem;
  }
  .introduce-new .schedule-box .schedule-list .list {
    margin-top: 20px;
    max-height: 480px;
    height: auto;
  }
  .introduce-new .schedule-box .schedule-list .list .box {
    padding: 20px 10px 20px 20px;
  }
  .introduce-new .schedule-box .schedule-list .list .box dt {
    font-size: 2.0rem;
  }
  .introduce-new .schedule-box .schedule-list .list .box dd {
  margin-top: 15px;
  }
  .introduce-new .schedule-box .schedule-list .list .box dd li:not(:last-child) { 
  margin-bottom: 8px;
  }
  .introduce-new .listbox > dl > dd {
    margin-top: 20px;
  }
  .introduce-new .listbox .sbox {
    padding: 20px;
  }
  .introduce-new .listbox > dl > dd .img-list ul {
    gap: 10px;
  }
  .introduce-new .listbox > dl > dd .img-list ul li {
    width: calc((100% - 10px) / 2);
  }
  .introduce-new .listbox > dl > dd .step-box .box {
    justify-content: center;
    text-align: center;
  }
  .introduce-new .listbox > dl > dd .step-box .box .step { 
    width: 180px;
    height: 90px;
  }
  .introduce-new .listbox > dl > dd .step-box .box .txt { 
    width: 100%;
    padding-left: 0;
    margin-top: 20px;
  }

  footer {
    padding: 60px 0;
  }
  footer .infoBox{
	flex-direction: column;
	align-items: flex-start;
  }
  footer .infoBox .line{
	margin-left: -12px;
  }
  footer .infoBox .line li.address{
	width: 100%;
  }
  footer .contactBox{
	margin: 20px 0;
  }
  footer .buttonBox{
	margin-top: 0;
  }
}

@media (max-width: 768px) {
  .font50,
  .font60,
  .font70 {
    font-size: calc(var(--fontsize) * 0.52);
  }
  .font45 {
    font-size: calc(var(--fontsize) * 0.56);
  }
  .topButton {
    width: 40px;
    height: 40px;
  }
  header {
    height: 72px;
  }
  header .logo {
    width: 168px;
    height: 32px;
  }
  header .menuButton{
    width: 42px;
    height: 42px;
  }
  header .menuButton span {
    width: 16px;
  }
  .allMenu .flexBox {
    height: calc(100% - 144px);
  }
  .allMenu #snb > ul > li > a {
    font-size: 2.0rem;
  }
  .visualTitle {
    font-size: 6.6rem;
  }
  #fullpage .community .infoBox .text p {
    font-size: 1.8rem;
  }
  #fullpage .community .map {
    width: 80%;
  }
  table.typeForm .inputRegion select {
    width: 200px;
  }
  .infoText h5,
  .smallTitle {
    font-size: 2.1rem;
  }
  .grayBox {
    padding: 40px 0;
  }
  #sv {
    height: 380px;
  }
  #sv .title {
    gap: 20px 0;
    padding: 40px 0 0;
  }
  #sv .lnbBox,
  #sv .lnbBox button,
  #sv .lnbBox button li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #sv .lnbBox {
    height: 60px;
    background: transparent;
  }
  #sv .lnbBox button {
    height: 100%;
    position: relative;
  }
  #sv .lnbBox button > li {
    height: 100%;
    gap: 0 40px;
    background: #ffffff;
    border-top-right-radius: 10px;
    font-size: 1.6rem;
    padding: 0 20px;
    position: relative;
    z-index: 2;
  }
  #sv .lnbBox button > li a {
    color: #222222;
  }
  #sv .lnbBox button > li a .simpleBus,
  #sv #lnb li a .simpleBus {
    width: 140px;
  }
  #sv .home {
    width: 60px;
    height: 100%;
    color: #ffffff;
    font-size: 2.4rem;
    background: var(--color-orange);
    border-top-left-radius: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #sv #lnb {
    display: block;
    height: auto;
    background: #ffffff;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    -webkit-box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
            box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
    padding: 10px 20px;
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 2;
    display: none;
  }
  #sv #lnb li {
    height: auto;
  }
  #sv #lnb li:not(:last-child)::after {
    display: none;
  }
  #sv #lnb li a {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    text-align: left;
    padding: 10px 0;
  }
  .noText {
    padding: 40px 20px;
  }
  #subContents .greetings .img {
    max-width: 340px;
  }
  #subContents .greetings .text {
    gap: 30px 0;
  }
  #subContents .greetings h3 span {
    height: 30px;
  }
  #subContents .greetings p br {
    display: none;
  }
  #subContents .brand .br768 {
    display: block;
  }
  #subContents .brand .circleBox {
    gap: 0 20px;
    margin: 40px 0 0;
  }
  #subContents .brand .circle {
    width: 26%;
    padding: 13% 0;
  }
  #subContents .brand .center {
    width: 40%;
    padding: 20% 0;
  }
  #subContents .brand .center .inner {
    gap: 10px 0;
  }
  #subContents .brand .logo {
    height: 40px;
  }
  #subContents .brand .line {
    display: none;
  }
  #subContents .ci .introduce .rule ul li {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 20px;
  }
  #subContents .ci .introduce .rule p {
    width: 100%;
    margin: 0;
  }
  #subContents .promotion .necessity .icon {
    height: 60px;
  }
  #subContents .promotion .necessity .itemBox {
    gap: 20px;
  }
  #subContents .promotion .necessity dl dd em {
    margin: 0;
  }
  #subContents .location #map {
    height: 460px;
  }
  #subContents .location .counsel dl dt {
    font-size: 2.8rem;
  }
  #subContents .location .counsel ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .location .counsel ul li {
    gap: 0 10px;
  }
  #subContents .business .contents > p br {
    display: none;
  }
  #subContents .business .note {
    padding: 20px;
  }
  #subContents .business ul {
    margin: 40px 0 0;
  }
  #subContents .information.understanding .info .pBox {
    gap: 20px 0;
  }
  #subContents .information.understanding .tagBox .tag.big {
    height: inherit;
    border-radius: 100px;
    line-height: 1.2;
    padding: 12px 20px;
  }
  #subContents .information.understanding .itemBottomBox {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 20px !important;
  }
  #subContents .information.understanding .itemBottomBox .item {
    width: calc(50% - 10px);
    height: auto !important;
  }
  #subContents .information.depression .info .listBox dl dt {
    width: 180px;
    height: 44px;
  }
  #subContents .information.depression .symptom .top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .information.depression .symptom .itemBottomBox {
    height: 200px;
  }
  #subContents .information.depression .symptom .optionBox {
    margin: 0 0 0 auto;
  }
  #subContents .information.stress .definition .point {
    gap: 0;
  }
  #subContents .information.manic .info .point dl dt {
    width: 180px;
    height: 44px;
    margin: 0 auto -22px;
  }
  #subContents .information.manic .info .point dl dd {
    padding: 40px 20px 25px;
  }
  #subContents .information.manic .info .point ul {
    gap: 0;
    -ms-flex-pack: distribute;
        justify-content: space-around;
  }
  #subContents .information.manic .info .point ul span {
    height: 48px;
  }
  #subContents .information.classification .tab {
    gap: 10px;
  }
  #subContents .information.classification .tab li {
    width: calc((100% - 40px) / 5);
  }
  #subContents .heart.checkup .grayBox {
    padding: 30px 20px;
  }
  #subContents .heart.checkup .checkupTab {
    gap: 20px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #subContents .heart.checkup .checkupTab::before {
    display: none;
  }
  #subContents .heart.checkup .checkupTab li {
    width: calc((100% - 40px) / 3);
  }
  #subContents .heart.checkup .checkupList ul li > p {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 10px 0;
    padding: 20px;
  }
  #subContents .heart.checkup .checkupList ul li > p > * {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  #subContents .heart.checkup .checkupList ul li > p em {
    display: block;
    width: calc(100% - 16px);
    text-align: left;
  }
  #subContents .heart.checkup .checkupList ul li > p .tag {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
  #subContents .heart.tools .itemBox {
    gap: 10px;
  }
  #subContents .heart.tools .itemBox label {
    gap: 0 10px;
    padding: 20px 10px;
  }
  #subContents .heart.tools .itemBox .check {
    width: 20px;
    height: 20px;
  }
  #subContents .heart.list .checkupList ul li > div, #subContents .heart.results .checkupList ul li > div {
    padding: 0 20px 20px;
  }
  #subContents .heart.list .listBox caption br {
    display: none;
  }
  #subContents .heart.results .graph > div {
    font-size: 1.4rem;
  }
  #subContents .heart.results .detail h4 {
    font-size: 2.4rem;
  }
  #subContents .heart.results .textBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .heart.results .dlBox {
    padding: 0;
  }
  #subContents .heart.results .bottom ul {
    gap: 0 10px;
  }
  #subContents .heart.introduce .info .more {
    font-size: 1.6rem;
    margin-left: 5px;
	transform: translateY(0.15em);
  }
  #subContents .heart.introduce .info .more img {
	width: 14px;
	height: 14px;
	transform: translateY(0.15em);
  }
  #subContents .heart.introduce .picture .item p {
    font-size: 1.8rem;
  }
  #subContents .heart.introduce .use .item {
    gap: 0 20px;
  }
  #subContents .heart.introduce .use .step,
  #subContents .heart.introduce .use .arrow {
    width: 180px;
  }
  #subContents .heart.introduce .picture .imgBox {
    -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2, 1fr);
  }
  #subContents .heart.apply .form .checklistBox dl dt {
    font-size: 1.6rem;
    margin: 0 0 10px;
  }
  #subContents .heart.apply .form .checklistBox dl dd {
    font-size: 1.5rem;
  }
  #subContents .heart.apply .form .list {
    margin: 30px 0 0;
  }
  #subContents .heart.apply .form .month button {
    width: 40px;
    height: 40px;
  }
  #subContents .heart.apply .form .month .center {
    font-size: 2.1rem;
  }
  #subContents .heart.apply .form .calendar tr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #subContents .heart.apply .form .calendar th,
  #subContents .heart.apply .form .calendar td.empty {
    display: none;
  }
  #subContents .heart.apply .form .calendar td {
    width: 100%;
    height: auto;
    border: none;
    border-bottom: 1px solid #e0e0e0;
  }
  #subContents .heart.apply .form .calendar td > div {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 10px 20px;
  }
  #subContents .heart.apply .form .calendar em {
    width: 40px;
    font-size: 1.4rem;
  }
  #subContents .participation.application .grayBox {
    gap: 20px 0;
    margin: 0 0 30px;
  }
  #subContents .participation.eventList .item a {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 30px 0;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  #subContents .participation.eventList .item .img {
    width: 60%;
    padding: 18.572% 0;
  }
  footer .logo {
    width: 176px;
    height: 48px;
  }
  footer .buttonBox .link a {
    height: 50px;
  }
}

@media (max-width: 700px) {
	footer .buttonBox .family{
		width: 100%;
	}
	footer .buttonBox .family > div{
		width: calc((100% - 20px) / 3);
	}
	footer .buttonBox .family button{
		width: 100%;
	}
}

@media (max-width: 640px) {
  .font50,
  .font60,
  .font70 {
    font-size: calc(var(--fontsize) * 0.48);
  }
  .font45 {
    font-size: calc(var(--fontsize) * 0.50);
  }
  .font34 {
    font-size: calc(var(--fontsize) * 0.66);
  }
  .font28 {
    font-size: calc(var(--fontsize) * 0.74);
  }
  .font25 {
    font-size: calc(var(--fontsize) * 0.78);
  }
  header .social {
    margin: 0 20px 0 auto;
  }
  .allMenu .flexBox {
    padding: 20px;
  }
  .allMenu #snb a {
    height: 52px;
  }
  .allMenu #snb > ul > li > a {
    font-size: 1.8rem;
  }
  .allMenu #snb .depth2 {
    padding: 0 0 0 20px;
  }
  .allMenu .point {
    width: 52%;
  }
  .allMenu .social li {
    width: 150px;
  }
  .visualTitle {
    font-size: 5.8rem;
  }
  #fullpage .community .map {
    width: 100%;
  }
  .paddingBox {
    padding: 60px 0;
  }
  .paddingBox.paddingTopX {
    padding: 0 0 60px;
  }
  .paddingBox.paddingBottomX {
    padding: 60px 0 0;
  }
  .marginTop90,
  .marginTop60 {
    margin-top: 40px;
  }
  .subFlexRow {
    gap: 20px 0;
  }
  table.typeForm th,
  table.typeForm td {
    padding: 15px 10px;
  }
  table.typeForm td > div {
    height: 40px;
  }
  table.typeForm td > div.heightAuto {
    height: auto;
  }
  table.typeForm td > div.heightAuto input[type=text],
  table.typeForm td > div.heightAuto input[type=password] {
    height: 40px;
  }
  table.typeForm .flexBox {
    gap: 10px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  table.typeForm .flexBox.nowrap {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
  .topTitle {
    gap: 20px 0;
  }
  .topTitle * {
	line-height: 1.3;
  }
  .topTitle > p {
    font-size: 1.6rem;
  }
  .tabTitle {
    height: 45px;
  }
  .tabTitle li a,
  .tabTitle li button {
    font-size: 1.5rem;
  }
  .infoText {
    margin: 0 0 30px;
  }
  .infoText h5 {
    font-size: 1.9rem;
    margin: 0 0 10px;
  }
  .infoText p br {
    display: none;
  }
  .comment .item {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 15px 0;
    padding: 20px 0;
  }
  .comment p {
    width: 100%;
  }
  #sv .path li:not(:last-child)::after {
    margin: 0 10px;
  }
  #sv .lnbBox {
    height: 50px;
  }
  #sv .home {
    width: 50px;
    font-size: 1.8rem;
  }
  .noText {
    font-size: 1.6rem;
    padding: 30px 10px;
  }
  #subContents .greetings .itemBox {
    gap: 20px 0;
  }
  #subContents .greetings .img {
    max-width: 200px;
  }
  #subContents .greetings p {
    font-size: 1.8rem;
  }
  #subContents .brand .br640 {
    display: block;
  }
  #subContents .brand .circleBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .brand .circle {
    width: 62%;
    padding: 31% 0;
  }
  #subContents .brand .center {
    width: 70%;
    padding: 35% 0;
  }
  #subContents .ci .tabTitle {
    margin: 0 0 60px;
  }
  #subContents .ci .introduce .plus {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #subContents .ci .introduce .plus ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #subContents .ci .introduce .plus ul li:not(.plusIcon) {
    width: 100%;
    height: auto;
  }
  #subContents .ci .introduce .plus .plusIcon {
    margin: -10px 0;
  }
  #subContents .ci .introduce .plus .point {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin: 0;
  }
  #subContents .ci .introduce .plus .point span.line {
    width: 1px;
    height: 40px;
  }
  #subContents .ci .introduce .plus .logo {
    width: 100%;
    height: auto;
    gap: 20px 0;
    padding: 30px 20px;
  }
  #subContents .ci .introduce .plus .logo .img {
    width: 180px;
  }
  #subContents .ci .introduce .slogan {
    gap: 30px 0;
    padding: 50px 20px;
  }
  #subContents .ci .introduce .slogan .logo {
    width: 280px;
  }
  #subContents .ci .introduce .slogan p {
    font-size: 2.0rem;
    text-align: center;
  }
  #subContents .ci .introduce .slogan p br {
    display: block;
  }
  #subContents .ci .download .itemBox,
  #subContents .ci .download .gridBg {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .ci .download .item > p {
    text-align: center;
    margin: 20px 0 0;
    position: relative;
    left: auto;
    bottom: auto;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  #subContents .ci .download .gridBg {
    height: auto;
  }
  #subContents .ci .download hr {
    width: 100%;
    height: 1px;
    position: relative;
    top: auto;
    left: auto;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  #subContents .promotion .necessity .itemBox {
    -ms-grid-columns: (minmax(auto, 320px))[1];
        grid-template-columns: repeat(1, minmax(auto, 320px));
    gap: 20px 0;
  }
  #subContents .promotion .necessity dl dt span {
    font-size: 4.2rem;
  }
  #subContents .promotion .necessity dl dt h6 {
    font-size: 1.8rem;
  }
  #subContents .promotion .history em {
    font-size: 2.6rem;
  }
  #subContents .promotion .history .list {
    padding: 0 0 0 20px;
  }
  #subContents .location #map {
    height: 360px;
  }
  #subContents .location .infoBox {
    margin: 40px 0 0;
  }
  #subContents .location .infoBox ul li {
    gap: 0 10px;
  }
  #subContents .location .infoBox .icon {
    width: 34px;
    height: 34px;
  }
  #subContents .location .counsel dl dt {
    font-size: 2.2rem;
    margin: 0 0 10px;
  }
  #subContents .location .counsel ul {
    gap: 10px 0;
  }
  #subContents .business ul li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 30px 0;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 30px 20px;
  }
  #subContents .business dl dt {
    font-size: 1.8rem;
  }
  #subContents .business dl dd * {
    font-size: 1.6rem;
  }
  #subContents .information.understanding .itemBottomBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0 !important;
  }
  #subContents .information.understanding .itemBottomBox .item {
    width: 100%;
  }
  #subContents .information.depression .info .listBox dl {
    padding: 20px;
  }
  #subContents .information.depression .info .listBox dl p {
    line-height: 1.2;
  }
  #subContents .information.stress .definition .point {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #subContents .information.stress .definition .point .bg {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  #subContents .information.manic .info .point ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .information.manic .info .point ul span {
    display: none;
  }
  #subContents .information.statistics .chartBorder {
    gap: 30px 0;
    padding: 30px 20px;
  }
  #subContents .information.statistics .chartBorder .flexBox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .information.statistics .chartBorder .centerText {
    gap: 0 12px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: relative;
    top: auto;
    left: auto;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  #subContents .information.statistics .chartBorder .centerText li {
    gap: 0 5px;
  }
  #subContents .information.statistics .recognitionTable .tableBox {
    overflow-x: scroll;
  }
  #subContents .information.statistics .recognitionTable table {
    width: 600px;
  }
  #subContents .information.classification .topTitle .simpleBus {
	height: 35px;
  }
  #subContents .information.classification .tab li {
    width: calc((100% - 30px) / 4);
    height: 45px;
  }
  #subContents .information.news .galleryBox {
	gap: 60px 0;
	margin-top: 60px;
  }
  #subContents .newsView .buttonBox button {
    width: 40px;
    height: 40px;
  }
  #subContents .newsView .related .relatedSlideBox {
    gap: 10px 0;
  }
  #subContents .newsView .related .tagBox {
    margin: 10px 0 0;
  }
  #subContents .newsView .related .buttonBox {
    gap: 0 5px;
  }
  #subContents .heart.checkup .checkupTab {
    gap: 10px;
  }
  #subContents .heart.checkup .checkupTab li {
    width: calc((100% - 20px) / 3);
  }
  #subContents .heart.checkup .checkupTab a {
    padding: 20px 10px;
  }
  #subContents .heart.checkup .checkupTab h6 {
    font-size: 1.7rem;
    margin: 10px 0 0;
  }
  #subContents .heart.type .itemBox {
    gap: 10px;
  }
  #subContents .heart.type label {
    width: calc(50% - 5px);
  }
  #subContents .heart.tools .itemBox {
    -ms-grid-columns: (1fr)[1];
        grid-template-columns: repeat(1, 1fr);
  }
  #subContents .heart.results .graph {
    height: auto;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 10px 0;
  }
  #subContents .heart.results .graph > div {
    border-radius: 10px !important;
    font-size: 1.5rem;
    text-align: center;
    padding: 15px 0;
  }
  #subContents .heart.results .detail h4 {
    font-size: 2.0rem;
  }
  #subContents .heart.results .bottom ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .heart.introduce .info .dot {
	position: relative;
  }
  #subContents .heart.introduce .info .more {
    margin-left: 0;
  }
  #subContents .heart.introduce .use .itemBox {
    gap: 20px 0;
  }
  #subContents .heart.introduce .use .item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px 0;
  }
  #subContents .heart.introduce .use .arrow {
    width: 100%;
  }
  #subContents .heart.introduce .use dl {
    text-align: center;
  }
  #subContents .participation.application .item {
    padding: 40px 20px;
  }
  #subContents .participation.application .item .formButton {
    margin: 30px 0 0 auto;
    position: relative;
    right: auto;
    bottom: auto;
  }
  #subContents .participation.application .grayBox {
    gap: 10px 0;
    padding: 30px 10px;
  }
  #subContents .participation.eventList h5 {
    margin: 10px 0 20px;
  }
  #subContents .participation.eventList .eventSlideBox p {
    font-size: 1.5rem;
  }
  #subContents .participation.eventList .eventSlideBox a {
    margin: 40px 0 0;
  }
  #subContents .participation.eventList .category {
    margin: 40px 0 10px;
  }
  #subContents .participation.eventList .item {
    padding: 20px 0;
  }
  #subContents .participation.eventList .item .arrow {
    width: 40px;
    height: 40px;
  }
  .introduce-new .cont {
    margin-top: 30px;
  }
  .introduce-new .bgCont {
    margin-top: 60px;
    padding:60px 0 100px;
  }
  .introduce-new .bgCont .cont {
    margin-top: 60px;
  }
  .introduce-new .top .txtbox {
    margin-top: -15%;
  }
  .introduce-new .top .txtbox .txt-1 img {
    height: 46px;
  }

  footer .buttonBox .family button {
    padding: 0 12px 0 15px;
  }
  footer .buttonBox .family ul {
    padding: 10px 12px 10px 15px;
  }
  footer .copy br {
    display: block;
  }
}

@media (max-width: 550px){
	footer{
		padding: 30px 0 60px;
	}
	footer .buttonBox .family{
		flex-wrap: wrap;
		gap: 10px;
	}
	footer .buttonBox .family > div{
		width: 100%;
	}
}

@media (max-width: 420px) {
  html,
  body {
    font-size: 50%;
  }

  #visual .content .link .grid .item p{
	font-size: 15px;
  }
  #news .swiper-slide span{
	font-size: 13px;
	padding: 4px 8px;
  }
  #news .swiper-slide dl dt{
	font-size: 18px;
  }
  #news .swiper-slide dl dd{
	font-size: 15px;
  }
  #news .swiper-slide p{ 
    font-size: 14px;
  }
  #notice .tit a{
	font-size: 15px;
  }
  #notice .tit a::after{
	font-size: 15px;
  }
  #notice .event .text span{
	  font-size: 12px;
	  padding: 4px 8px;
  }
  #notice .event .text h6{
     font-size: 15px;
  }
  #notice .event .text dl{
	 font-size: 14px;
  }
  #notice .event .text dl dd{
	font-size: 13px;
  }
  #notice .news .text h6{
     font-size: 14px;
  }
  #notice .news .text p{
     font-size: 13px;
  }
}
