@charset "utf-8";

@media (max-width: 1500px) {
	:root {
		--slide-arrow : 64px;
		--font-size-18 : 17px;
		--font-size-20 : 19px;
		--font-size-22 : 20px;
		--font-size-24 : 22px;
		--font-size-26 : 24px;
		--font-size-28 : 24px;
		--font-size-40 : 35px;
		--font-size-50 : 40px;
		--section-padding : 80px 0;
		--main-section-padding : 80px 0;
	}

	/* header */
	.sitelogo img {height: 40px;}
	#gnb > ul > li {padding:0 40px;}
	.top-links ul li i {width: 20px; height: 20px; margin: 0 5px;}
	.top-btn-donate, .top-links {margin-left: 20px;}
	.top-links {font-size: 16px;}

	/* main */
	.main-visual .caption .txt2 img {height: 64px;}
	.main-visual .caption .txt1 {font-size: 24px;}
	.main-visual .caption .txt2 {margin-top: 50px;}
	.main-visual .caption .txt3 {margin-top: 40px; font-size: 40px;}
	.main-visual .caption .txt4 {margin-top: 25px; font-size: 24px;}
	.main-visual .caption .btn {margin-top: 45px; font-size: 18px;}
	.main-visual .obj {right: -60px; bottom: -20px;}

	.main-banner .wrap .img img {width: 250px;}
	.main-banner:before {height: calc(100% - 255px); top: 175px;}
	.main-banner .wrap {padding-top: 95px;}

	.main-business .contain>.wrap {gap: 60px;}
	.business-cnt .txt {padding: 40px 35px; width: 44.89%;}
	.business-cnt .photo {margin-left: -40px; margin-bottom: 100px;}

	.main-support:before {width: 220px; height: 283px; top: -141px;}
	.main-support .item .icon img {width: 54px;}
	.main-support .items {gap: 30px;}

	.video-controls {width: 80px; height: 80px; margin-top: -40px; margin-left: -40px;}

}

@media (max-width: 1280px) {
	:root {
		--lnb-height: 60px;
		--slide-arrow : 50px;
		--font-size-14 : 13px;
		--font-size-18 : 16px;
		--font-size-20 : 16px;
		--font-size-22 : 18px;
		--font-size-24 : 20px;
		--font-size-26 : 22px;
		--font-size-28 : 22px;
		--font-size-30 : 24px;
		--font-size-35 : 28px;
		--font-size-38 : 30px;
		--font-size-42: 32px;
		--font-size-45 : 34px;
		--font-size-50 : 35px;
		--font-size-55 : 42px;
		--font-size-70 : 50px;
	}
	/* header */
	#gnb {display:none;}
	.btn-m-menu {display:block; margin-left: 40px;}
	.mobile-navigation {display:block;}
	.top-btn-donate, .top-links {margin-left: 25px;}

	/* main */
	.main-visual .obj {height: 100%;}
	.main-visual .obj img {max-height: 100%;}

	.main-visual .caption .txt1 {padding: 15px 30px; font-size: 22px;}
	.main-visual .caption .txt2 img {height: 50px;}
	.main-visual .caption .txt2 {margin-top: 40px;}
	.main-visual .caption .txt3 {font-size: 35px;}
	.main-visual .caption .txt4 {font-size: 22px;}
	.main-visual .caption .btn {margin-top: 35px; padding: 15px 40px;}

	.main-greetings .chairman {right: -95px; width: 55%;}

	.main-banner .txt {padding: 75px 0; margin-left: 250px;}
	.main-banner .wrap .img img {width: 200px;}
	.main-banner .wrap {padding-top: 0;}
	.main-banner:before {height: calc(100% - 180px); top: 100px;}
	.main-banner .wrap .img {top: -70px;}
	.btn-detail {padding: 5px 24px;}

	.business-cnt .txt {padding: 25px; width: 50%;}
	.business-cnt .photo {padding-bottom: 42%;}
	.main-business .contain>.wrap {gap: 40px;}
	.mb-menu li .icon img {width: 36px;}
	.mb-menu a {padding: 25px 15px; height: auto;}
	.mb-menu p {line-height: 1.3em;}

	.main-support:before {width: 160px; height: 206px; top: -103px;}
	.main-support .items {gap: 15px;}
	.main-support .item .icon img {width: 44px;}
	.main-support .item {padding: 35px 15px;}

	.news-cnt .btn-plus {margin-left: 25px;}
	.news-cnt .btn-plus img {width: 16px; margin-top: -.3em;}
	.news-cnt ul li a {padding: 20px;}


	.mgb30 {margin-bottom: 23px !important;}
	.mgb35 {margin-bottom: 25px !important;}
	.mgb40 {margin-bottom: 20px !important;}
	.mgb55 {margin-bottom: 50px !important;}
	.mgb70 {margin-bottom: 50px !important;}

	/* footer */
	.foot-links {padding: 15px 0;}
	.foot-wrap {padding: 30px 0;}
	.foot-wrap .contain {flex-wrap: wrap;}
	.foot-comp {width: 100%; margin-bottom: 30px;}
	.foot-comp .copyright {margin-top: 10px;}
	#footer h4 {margin-bottom: 15px;}

	/* layout */
	.sub-visual {height: 340px;}
	.sub-visual h2:before {width: 35px; height: 35px; margin-top: -18px;}

	.lnb-wrap {margin-top: 0;}

	/* content */
	.about .photo {padding: 100px 15px;}
	.quotes:before, .quotes:after, .business-txt h2:before, .business-txt h2:after {width: 24px; height: 22px;}
	.about .desc {padding: 50px 0;}
	.value-items .icon img {width: 120px;}
	.value-items .item {gap: 30px;}

	.greetings .txt {padding-right: 30px;}
	.greetings .photo:before {width: calc(100% - 75px);}
	.desc p:not(:last-child) {margin-bottom: 16px;}

	.executives .item .img {width: 19%;}
	.executives .item .txt {width: 81%; padding-left: 100px; padding-right: 50px;}
	.executives .item:nth-child(even) .txt {padding-left: 50px; padding-right: 100px;}
	.executives .item:not(:last-child) {margin-bottom: 35px;}

	.history .item {padding-bottom: 45px;}
	.history-year {margin-bottom: 20px; font-size: 30px;}
	.history .item:after {top: 3px; right: -12px; width: 24px; height: 24px; border-width: 6px;}
	.history .item:nth-child(even):after {left: -12px;}
	.history .item:before {width: 54px; height: 54px; right: -27px;}

	.management .photo {width: 31%;}
	.management .wrap {padding: 40px 35px;}
	.management .item:before {width: 22px; height: 19px; top: 3px;}

	.tousa .txt-center img {max-width: 630px;}

	/* board */
	.table-wrap table colgroup col {width: auto !important;}

}

@media (max-width: 1100px) {
	/* header */
	#gnb {margin-right:20px;}
}

/* Landscape tablet */
@media (max-width: 1024px) {
	:root {
		--header-height : 80px;
		--lnb-height: 50px;
		--slide-arrow : 40px;
		--slide-arrow-2 : 36px;
		--font-size-14 : 13px;
		--font-size-18 : 16px;
		--font-size-20 : 18px;
		--font-size-22 : 18px;
		--font-size-26 : 22px;
		--font-size-30 : 24px;
		--font-size-35 : 28px;
		--font-size-38 : 30px;
		--font-size-40 : 32px;
		--font-size-45 : 34px;
		--font-size-55 : 42px;
		--font-size-70 : 50px;
		--section-padding: 60px 0;
	}

	body, input, textarea, select, button, table {font-size:15px;}

	/* header */

	/* main */
	.main-visual .caption .txt1 {font-size:50px;}
	.main-visual .caption .txt2 {font-size:30px;}
	.main-visual .slick-dots {bottom:30px;}
	.main-visual .slick-dots li {margin:0 5px;}
	.main-visual .slick-dots li button {width:12px; height:12px;}

	.main-gallery .slide-btn {width: 44px; height: 44px;}
	.main-gallery .slide-btn svg {width: 18px;}

	.m-head {margin-bottom:40px;}

	.main-work:before {background-size:400px auto;}
	.main-work:after {background-size:800px auto;}
	.main-work .item .txt {padding:20px;}
	.main-work .item .txt:after {width:40px; margin:0 10px 10px 10px; background-size:contain;}

	.main-comm:before {height:400px;}
	.main-comm .m-head {margin-bottom:60px;}

	.main-greetings .chairman {right: -136px;}

	.main-banner .wrap .img img {width: 125px;}
	.main-banner .txt {margin-left: 130px; padding: 60px 0;}
	.main-banner:before {top: 80px; height: calc(100% - 160px);}

	.main-business h2 {font-size: 20px;}
	.mb-menu a {flex-direction: column-reverse; gap: 10px; padding: 15px 25px; align-items: flex-start;}
	.mb-menu p {margin-top: 5px;}
	.mb-menu li .icon img {width: 30px;}
	.business-cnt .wrap {flex-direction: column-reverse; }
	.business-cnt .txt {width: 100%;  max-width: none; border-radius: 0 0 20px 20px;}
	.business-cnt .photo {width: 100%; margin: 0; border-radius: 20px 20px 0 0;}
	.main-business h2 {margin-bottom: 10px !important;}
	.business-cnt .txt .tag {margin-bottom: 15px !important;}
	.main-support:before {width: 120px; height: 154px; top: -77px;}

	.main-support .items {flex-wrap: wrap;}
	.main-support .item {flex: 1 0 auto;width: 45%; padding: 20px 15px;}
	.main-support .item .icon img {width: 33px;}

	.video-controls {width: 60px; height: 60px; margin-top: -30px; margin-left: -30px;}
	.main-video .mv-arrows>div {width: 19px; height: 35px; margin-top: -17px;}

	.mgb15 {margin-bottom: 10px !important;}
	.mgb35 {margin-bottom: 20px !important;}
	.mgb45 {margin-bottom: 35px !important;}
	.mgb50 {margin-bottom: 40px !important;}

	.fz20 {line-height: 1.6em;}

	/* layout */
	.sub-visual {height:240px;}
	.sub-visual h2:before {width: 30px; height: 30px; margin-top: -15px;}

	.lnb ul li {padding:0 25px;}

	.dotate-menu ul li a {padding: 8px 35px; font-size: 16px;}

	.sub-title {padding:45px 0 40px;}

	.real-cont {padding-bottom:80px;}

	/* content */
	.doc-cnt.esg-cnt:not(:last-child) {margin-bottom:90px;}

	.doc-tit {margin-bottom:15px;}
	.doc-tit:before {top:3px;}

	.doc-sub-tit {margin-bottom:15px;}

	.history .tit {width:25%;}

	.img-cnt-between .group:not(:last-child) {margin-bottom:60px;}
	.img-cnt-between .cnt {width:calc(50% - 40px); padding:0;}

	.esg-strategies .group {gap:40px;}
	.esg-strategies .group:not(:last-child) {margin-bottom:60px;}

	.esg-strategies .group:nth-child(even) .cnt {padding-left:15px;}
	.esg-strategies .check {grid-template-columns:unset; gap:4px 0; margin-top:25px;}

	.works .tit {width:180px; padding:0 15px;}

	.about .photo {padding: 85px 15px;}
	.quotes {padding: 0 40px;}
	.quotes:before, .quotes:after, .business-txt h2:before, .business-txt h2:after {top: -8px; width: 20px; height: 18px;}
	.about .desc {padding: 35px 0;}

	.value-items .icon img {width: 90px;}
	.value-items .item {gap: 25px;}

	.greetings .photo {width: 50%;}
	.greetings .photo .img {margin-right: -65px;}
	.greetings .photo .name {bottom: 20px; padding-left: 65px;}
	.greetings .photo .logo img {width: 30px;}
	.greetings .photo:before {width: calc(100% - 35px);}

	.executives .item .img {padding-bottom: 60px;}
	.executives .item .txt {padding: 43px 0; padding-left: 10%; padding-right: 5%;}
	.executives .item:nth-child(even) .txt {padding-left: 5%; padding-right: 10%;}
	.executives .item:nth-child(1) .txt:before {right: -12px; top: -18px; width: 55px; height: 58px;}
	.executives .item:nth-child(2) .txt:before {top: -34px; width: 54px; height: 54px;}
	.executives .item:nth-child(3) .txt:before {top: -22px; width: 58px; height: 35px;}
	.executives .item:nth-child(5) .txt:before {top: -30px; right: -10px;width: 54px; height: 54px;}

	.history-year {font-size: 24px; margin-bottom: 15px;}
	.history .item:after {top: 0;}
	.history .item:before {top: -14px;}

	.management .photo {width: 27%;}
	.management .wrap {gap: 35px; padding: 35px 15px;}
	.management .item {padding-left: 31px;}
	.management .item:before {top: 4px; width: 19px; height: 16px;}

	.business-txt br {display: none;}
	.business-txt .btn-link {padding: 12px 24px;}

	/* board */
	.input {padding:5px 14px; height:40px;}
	textarea.input {padding:12px 14px;}

	.board-search .search input.input {width:240px;}

	.table-wrap table thead th, .table-wrap table tbody td {height: 45px;}

	.gallery-list ul {margin: 0 -10px;}
	.gallery-list ul li {padding: 0 10px; margin-bottom: 35px;}
	.gallery-list ul li .date {margin-top: 10px;}

	.business-gallery ul {margin: 0 -10px -35px;}
	.business-gallery li {padding: 0 10px 35px;}
	.business-gallery .thumb {margin-bottom: 17px;}

	.board-list colgroup col {width:auto !important;}
	.board-list table thead th {font-size:15px;}
	.board-list table tbody td {font-size:15px;}
	.board-list.st2 table tbody td {height:60px;}

	.gallery-list ul li .thumb {margin-bottom:15px;}

	.news-list .thumb {width:200px;}
	.news-list .tit {font-size:17px;}
	.news-list .txt {font-size:14px;}
	.news-list .date {font-size:13px;}

	.event-list ul li .tit {font-size:15px;}

	.faq .tit {font-size:15px;}
	.faq .tit a {padding:9px 60px 9px 12px;}
	.faq .tit a:after {top:14px;}
	.faq .q {flex:0 0 32px; width:32px; height:32px; font-size:16px; line-height:32px;}
	.faq .cnt {padding:18px 25px 18px 60px;}

	.calendar-head h3 {font-size:28px; margin:0 30px;}
	.calendar-head .cal-btn {width:40px; height:40px;}
	.calendar table th {font-size:15px;}
	.calendar table td {height:110px; font-size:14px;}
	.calendar ul li:before {top:7px;}

	.board-white table {font-size:15px;}

	.board-form table {font-size:15px;}
	.board-form .check-items {margin:0 -15px;}
	.board-form .check-items .item {min-width:83px; padding:5px 15px;}

	.files-upload-text .upfiles-alt {font-size:14px;}

	.board-view-tit {padding:14px 6px;}
	.board-view-tit h3 {font-size:18px;}
	.board-view-info {padding:13px 6px; font-size:13px;}
	.board-view-cnt {padding:15px 6px 40px;}

	.board-prev-next {font-size:14px;}

	.btn-pack.medium {height:40px; padding:0 16px; font-size:15px; line-height:38px;}
	.btn-pack.large {min-width:140px; height:50px; font-size:18px; line-height:48px;}

	.store-search {padding:22px 5%;}
	.store-search .map-area {width:280px;}
	.store-search .map-img .local {padding:0 10px; font-size:13px; line-height:22px;}

	.result-group .gall li {width:25%;}

}


/* portrait tablet */
@media (max-width: 900px) {
	:root {
		--header-height: 70px;
		--main-section-padding: 60px 0;
	    --font-size-18: 15px;
	    --font-size-20: 16px;
	    --font-size-22: 17px;
		--font-size-24: 18px;
	    --font-size-26: 18px;
	    --font-size-28: 18px;
		--font-size-40: 28px;
		--font-size-42: 28px;
	    --font-size-45: 28px;
		--font-size-50: 30px;
	}

	.only-desktop {display:none;}
	.only-tablet {display:block;}

	/* header */
	.header {justify-content:space-between;}
	#header .top-links {display: none;}
	.mobile-navigation>.top-links {padding: 15px 15px 15px 15px; margin-left: 0;}
	.mobile-navigation .donate-link {padding: 15px 20px;}
	.nav-donate .top-btn-donate {margin-left: 20px;}
	.top-btn-donate {height: 42px;}
	.top-btn-donate svg {width: 24px;}
	.mobile-navigation .top-links {display: block;}

	/* main */
	.main-visual,
	.main-visual .item {height:500px;}
	.main-visual .caption {padding:0 40px;}
	.main-visual .caption .txt1 {font-size: 35px;}
	.main-visual .caption .txt2 img {height: auto;}
	.main-visual .caption .txt3 {font-size: 30px; font-weight: 800; text-shadow: 0 0 3px rgba(0,0,0,.5)}
	.main-visual .obj {height: 52%;}

	.main-work .items {gap:20px;}
	.main-work .item:first-child,
	.main-work .item:first-child .img img,
	.main-work .item:first-child .img:after {border-radius:30px 0 0 0;}
	.main-work .item:last-child,
	.main-work .item:last-child .img img,
	.main-work .item:last-child .img:after {border-radius:0 0 30px 0;}

	.main-comm .item {padding:30px 25px;}
	.main-comm .item:first-child {border-radius:30px 0 0 0;}
	.main-comm .item:last-child {border-radius:0 0 30px 0;}


	.main-gallery .swiper-slide:nth-child(odd) {margin-top: 20px; padding-top: 0;}
	.main-gallery .slide-btn {width: 40px; height: 40px;}
	.main-gallery .item .thumb {margin-bottom: 15px;}
	.main-gallery .item .date {margin-top: 10px;}

	.main-greetings .wrap {display: flex; flex-direction: column-reverse; gap: 15px;}
	.main-greetings .chairman {position: relative; right:auto; top: auto;}
	.main-greetings .name {padding-right: 0; line-height: 1.5em;}

	.main-banner:before {top: 100px; height: calc(100% - 160px);}
	.main-banner .wrap {padding-top: 60px;}
	.main-banner .wrap .img img {width: 80px;}
	.main-banner .txt {margin-left: 0; padding: 40px 0;}
	.main-banner .flex-wrap {flex-direction: column; align-items: flex-start; gap: 20px;}
	.main-banner .wrap .img {top: -15px;}

	.main-business .contain>.wrap {flex-direction: column; gap: 30px;}
	.mb-menu {width: 100%; max-width: none;}
	.mb-menu ul {flex-direction: row;}
	.mb-menu li {width: fit-content; border-bottom: 0; border-right: 1px solid #ddd; height: auto;}
	.mb-menu li:last-child {border-right: 0;}
	.mb-menu a {padding: 15px 20px;}
	.main-business h2 {margin-bottom: 5px !important;font-size: 18px;}
	.business-cnt .wrap {flex-direction: row; align-items: center;}
	.business-cnt .txt {width: 50%; border-radius: 20px;}
	.business-cnt .photo {margin-left: -30px; border-radius: 20px;}

	.main-support p {line-height: 1.5em;}
	.main-video .swiper-slide {width: 70%;}
	.main-video .swiper-button-prev {left: 9%;}
	.main-video .swiper-button-next {right: 9%;}

	.mn-menu {position: relative; top: auto; margin-bottom: 20px;}
	.news-cnt ul {gap: 10px 0;}
	.news-cnt ul li {width: 100%;}
	.news-cnt ul li a {padding: 15px;}
	.news-cnt .date {font-size: 14px;}

	.mgb12 {margin-bottom: 7px !important;}
	.mgb20 {margin-bottom: 15px !important;}
	.mgb70 {margin-bottom: 40px !important;}

	/* footer */
	.foot-links {display:block;}
	.foot-links ul {justify-content:flex-start;}

	/* layout */
	.sub-visual {height: 200px;}
	.sub-visual h2 {padding-left: 40px;}

	.lnb ul li {flex: 1 0 auto; width: auto;}

	/* content */
	.company-overview .img {height:240px;}
	.company-overview .tit {margin-left:30px; margin-bottom:30px;}
	.company-overview .cnt {margin:0 30px;}

	.history .group {display:block;}
	.history .tit {width:auto; min-width:unset; margin-bottom:27px;}
	.history .tit br {display:none; }
	.history .cnt {width:auto;}

	.img-cnt-between .group {align-items:flex-start;}

	.subsidiary .cnt {margin-left:30px; margin-right:30px;}

	.esg-strategy {width:100%;}

	.esg-principles {gap:20px;}
	.esg-principles .item {padding:40px 15px;}

	.esg-strategies .group {align-items:flex-start;}

	.about .photo {padding: 50px 15px;}
	.about .photo .fz22.mgb30 {margin-bottom: 15px !important;}
	.about .desc {padding: 20px 0;}
	.value-items {flex-direction: column; width: fit-content; margin: 0 auto;}

	.greetings {flex-direction: column;}
	.greetings .txt {padding-left: 30px; width: 100%; margin-top: -30px;}
	.greetings .photo {width: 85%;}
	.greetings .photo:before {bottom: 80px; height: 190px;}
	.greetings .photo .wrap {display: flex; align-items: center;}
	.greetings .photo .img {min-width: 80%; margin-right: -85px; margin-left: -85px;}
	.greetings .photo .name {position: relative; top: 30px; right: 30px; bottom: auto; padding-left: 0;}

	.executives .item {gap: 40px; align-items: flex-start;}
	.executives .item .img {padding-bottom: 0;}
	.executives .item .txt, .executives .item:nth-child(even) .txt {flex: 1;width: auto;background: #fff; border: 3px solid #fe4101; padding: 20px 25px; border-radius: 20px;}

	.history:before {left: 0;}
	.history .item {width: 100%; text-align: left; padding-right: 0; padding-left: 65px;}
	.history .item:before {right: auto; left: -27px;}
	.history .item:after {right: auto; left: -12px;}
	.history-year:before {right: auto; left: -38px;}
	.history .item:nth-child(odd) ul li {flex-direction: row;}

	.management .wrap {flex-direction: column;}
	.management .photo {width: 37%;}
	.management .photo img {position: relative; top: auto; transform: none;}
	.management .item.mgb50 {margin-bottom: 30px !important;}

	.tousa .txt-center img {width: 100%;}

	/* board */
	.table-wrap {overflow-x: auto; position: relative; width:100%;}
	.table-wrap table {width:1000px;}
	.table-wrap table thead th, .table-wrap table tbody td {font-size: 15px;}

	.gallery-list ul {margin:0 -10px;}
	.gallery-list ul li {width:33.33333333%; padding:0 10px;}

	.event-list ul li {width:50%;}

	.store-search {padding:30px; margin-bottom:30px;}
	.store-search .map-area {display:none;}
	.store-search .search-area h3 {text-align:center; margin-bottom:30px;}

	.product-list {grid-template-columns:unset; gap:30px;}

	.product-summary {grid-template-columns:46% auto;}
	.product-info .tit {padding-bottom:15px;}
	.product-info .txt {padding:15px 0;}
	.product-info .btns {gap:10px; margin-top:25px;}
}

/* Landscape phone */
@media (max-width: 640px) {
	:root {
		--header-height: 60px;
		--section-padding: 60px 0;
		--lnb-height: 44px;
		--slide-arrow : 24px;
		--slide-arrow-2 : 24px;
		--font-size-18: 14px;
		--font-size-20: 16px;
		--font-size-22: 16px;
		--font-size-24 : 17px;
		--font-size-26: 18px;
		--font-size-30: 20px;
		--font-size-35: 23px;
		--font-size-38: 23px;
	    --font-size-40: 24px;
		--font-size-42: 23px;
		--font-size-45: 24px;
		--font-size-50 : 23px;
		--font-size-55 : 32px;
		--font-size-70 : 40px;
		--padding-contain: 16px;
	}

	[data-aos=fade-up] {transform: translate3d(0,30px,0);}

	body, input, textarea, select, button, table {font-size:14px;}
	.only-desktop-tablet {display:none;}
	.only-tablet {display:none;}
	.only-mobile {display:block;}

	.contain {padding-left:16px; padding-right:16px;}

	/* header */
	.sitelogo img {height:33px;}

	.top-btn-donate {margin-left: 20px; font-size: 15px; padding: 0 15px;}

	.btn-m-menu {margin-left: 20px;}
	.mobile-navigation {width:280px;}
	.mobile-navigation .home {padding:0 20px;}
	.mobile-navigation .home img {height:33px;}
	.mobile-navigation .close {top:20px; width:20px; height:20px;}
	.mobile-navigation .close:before, .mobile-navigation .close:after {top:9px; height:2px;}
	.top-links {font-size: 15px;}

	/* main */
	.main-visual,
	.main-visual .item {height:330px;}
	.main-visual .slick-prev {left:5px;}
	.main-visual .slick-next {right:5px;}
	.main-visual .caption {padding:0 20px;}
	.main-visual .caption .txt1 {font-size:16px; padding: 12px 24px;}
	.main-visual .caption .txt2 {margin-bottom: 20px; margin-top: 20px;font-size:18px;}
	.main-visual .caption .txt3 {font-size: 18px; margin-top: 20px;}
	.main-visual .caption .txt4 {font-size: 16px; margin-top: 15px;}
	.main-visual .caption .btn {margin-top: 20px; font-size: 15px; padding: 12px 24px;}
	.main-visual .obj {height: 60%;}
	.main-visual .slick-dots {bottom:25px;}
	.main-visual .slick-dots li {margin:0 4px;}
	.main-visual .slick-dots li button {width:10px; height:10px;}

	.m-head {margin-bottom:25px;}

	.main-work:before {background-size:160px auto; background-position:105% 5px;}
	.main-work:after {background-size:500px auto;}
	.main-work .items {grid-template-columns:unset; gap:20px; padding:0 20px;}
	.main-work .item .txt:after {width:30px; margin:0 10px 6px 10px;}
	.main-work .item .img img {box-shadow:0px 3px 20px 0px rgba(0, 0, 0, 0.4);}

	.main-comm:before {height:320px;}
	.main-comm .m-head {margin-bottom:40px;}
	.main-comm .items {grid-template-columns:unset;}
	.main-comm .item {padding:25px 30px;}
	.main-comm .item .tit {margin-bottom:12px;}
	.main-comm .item .txt {min-height:auto; font-size:14px;}
	.main-comm .item .ico {width:38px;}
	.main-comm .item .more {bottom:-5px;}

	.main-gallery .arrows {position: relative; margin-top: 20px; justify-content: flex-end;}
	.main-gallery .swiper-slide:nth-child(odd) {margin-top: 0;}

	.main-greetings .chairman {width: 100%;}
	.main-banner h2 {line-height: 1.5em;}
	.main-banner .wrap .img {top: 0;}
	.main-banner .wrap .img img {width: 65px;}

	.business-cnt .wrap {flex-direction: column-reverse;}
	.business-cnt .photo {margin-left: 0;border-radius: 20px 20px 0 0;}
	.business-cnt .txt {width: 100%;border-radius: 0 0 20px 20px;}

	.main-business h2 {font-size: 16px;}
	.mb-menu ul {flex-direction: column; transform: translate3d(0,0,0) !important}
	.mb-menu li {border-right: 0; border-bottom: 1px solid #ddd; width: 100%;}
	.mb-menu a {flex-direction: row; align-items: center;}

	.main-support:before {width: 100px; height: 118px; top: -59px;}
	.main-support .item {width: 100%;}

	.main-video .swiper-slide {width: 80%;}
	.main-video .mv-arrows>div {width: 14px; height: 28px; margin-top: -14px;}
	.main-video .swiper-button-prev {left: 15px;}
	.main-video .swiper-button-next {right: 15px;}
	.video-controls {width: 46px; height: 46px; margin-top: -23px; margin-left: -23px;}

	.mgb45 {margin-bottom: 30px !important;}

	/* footer */
	#footer {font-size:13px;}

	.foot-links .contain {flex-direction: column; gap: 10px;}
	.foot-links dl {gap:10px 20px;}

	.foot-info address {margin-right:-16px;}
	.foot-info address span {margin-right:18px;}
	.foot-info .group {margin-bottom:15px;}
	.foot-info .group span:last-child {margin-right:0;}
	.foot-info .copyright {margin-top:15px; font-size:11px;}

	#footer h4 {font-size: 15px;}
	.foot-sns {margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid rgba(255,255,255,.3); width: 100%;}
	.foot-bank {margin-left: 0; padding-left: 0;}
	.foot-bank:before {content: none;}

	/* layout */
	.sub-visual {height:140px;}

	.lnb ul {width: max-content; min-width: 100%;}
	.lnb ul li {flex:1 0 auto; padding:0 20px; width: fit-content;}
	.lnb ul li a {white-space:nowrap; font-size:14px;}

	.sub-title {padding:35px 0 30px;}

	.real-cont {padding-bottom:60px; min-height:250px;}

	/* content */
	.doc-tit {margin-bottom:12px; padding-left:25px;}
	.doc-tit:before {top:3px; width:17px; height:17px;}

	.doc-sub-tit {margin-bottom:12px;}
	.doc-sub-tit.mgb20 {margin-bottom:15px !important;}

	.doc-cnt:not(:last-child) {margin-bottom:60px;}
	.doc-cnt.esg-cnt:not(:last-child) {margin-bottom:60px;}

	.company-overview .img {height:180px; border-radius:16px; background-position:20% 50%;}
	.company-overview .img p {padding:40px 20px; font-size:13px;}
	.company-overview .img p br {display:none;}
	.company-overview .tit {margin:-16px 0 25px 20px;}
	.company-overview .cnt {margin:0 0 0 20px;}

	.history .group:not(:last-child) {margin-bottom:50px;}
	.history .tit {margin-bottom:17px;}
	.history .item {position:relative; display:block;}
	.history .item .year {position:static; width:auto; margin:0 0 12px; padding-left:28px;}
	.history .item .year:before {top:5px; left:7px; right:auto;}
	.history .item .year:after {top:5px; left:0; right:auto; width:14px; height:14px; border-width:4px;}
	.history .item ul {width:auto; padding:0 0 40px 28px;}
	.history .item ul li .month {min-width:50px;}

	.img-cnt-between .group {display:block;}
	.img-cnt-between .group:not(:last-child) {margin-bottom:50px;}
	.img-cnt-between .img {width:100%; margin-bottom:20px;}
	.img-cnt-between .img img {width:100%;}
	.img-cnt-between .cnt {width:100%;}

	.works .item {display:block; min-height:auto; padding:25px 10px;}
	.works .tit {display:flex; align-items:center; width:auto; padding:0; margin-bottom:12px; text-align:left;}
	.works .tit img {width:36px; margin-right:10px;}
	.works .tit h3 {margin-top:0;}
	.works .cnt {width:auto;}

	.reference-timeline .group {display:grid; gap:15px; padding-left:28px; padding-bottom:40px;}
	.reference-timeline .group:before {top:5px; left:7px;}
	.reference-timeline .group:after {top:5px; left:0; width:14px; height:14px; margin:0; border-width:4px;}
	.reference-timeline .group:nth-child(even) {text-align:left;}
	.reference-timeline .group:nth-child(even) ul li {flex-direction:row;}
	.reference-timeline .cnt {width:auto;}
	.reference-timeline .img {width:auto; padding-top:0;}
	.reference-timeline .img .last {margin-left:0;}
	.reference-timeline .year {margin-bottom:12px;}
	.reference-timeline ul li .month {min-width:50px;}
	.reference-timeline .group:nth-child(even) ul li .month {min-width:50px;}

	.subsidiary .img {overflow:hidden;}
	.subsidiary .img img {width:140%; max-width:140%; margin-left:-20%;}
	.subsidiary .cnt {margin:-17px 10px 0 10px; font-size:14px;}
	.subsidiary h2 {margin-bottom:20px;}
	.subsidiary .lg-txt {font-size:17px;}

	.btn-visit {font-size:14px;}

	.homepage-url {padding:18px; margin-bottom:30px;}

	.photo-slider .item {height:60vw;}

	.photo-slider-2 .slick-dots {bottom:20px;}

	.esg-strategy {padding-top:5px;}
	.esg-strategy .item {width:32%;}
	.esg-strategy .tit {margin-bottom:25px;}
	.esg-strategy .tit .in {top:12px; right:12px; bottom:12px; left:12px; box-shadow:20px 20px 30px rgba(0,0,0,.3);}
	.esg-strategy .tit:after {margin-left:-10px; border-left-width:10px; border-right-width:10px; border-top-width:20px;}
	.esg-strategy .tit img {width:36px;}
	.esg-strategy h4 {min-height:auto; margin-top:5px; font-size:13px; line-height:1.2em;}
	.esg-strategy .line .bullet {min-width:18px; height:18px; margin:0 5px; border-width:5px;}
	.esg-strategy .txt {font-size:12px; line-height:1.5em;}

	.esg-principles {grid-template-columns:unset; gap:12px;}
	.esg-principles .item {display:flex; align-items:center; padding:15px 15px;}
	.esg-principles .ico {width:60px; height:60px; margin:0 20px 0 0;}
	.esg-principles .ico img {width:36px;}
	.esg-principles .cnt {flex:1 1 auto; min-width:0; width:1%; text-align:left;}
	.esg-principles h4 {margin-top:0;}

	.esg-strategies .group {display:block;}
	.esg-strategies .group:not(:last-child) {margin-bottom:50px;}
	.esg-strategies .img {width:100%; margin-bottom:20px;}
	.esg-strategies .img img {width:100%;}
	.esg-strategies .cnt {width:100%; padding-left:15px;}
	.esg-strategies .check {margin-top:20px;}
	.esg-strategies .check li {padding-left:22px;}
	.esg-strategies .check li:before {top:2px; width:16px; height:16px;}

	.about .photo {padding: 40px 15px;}
	.quotes {padding: 0 30px;}
	.quotes:before, .quotes:after, .business-txt h2:before, .business-txt h2:after {width: 16px; height: 16px;}
	.about .desc br {display: none;}

	.about .section.bgc1 .txt-center br {display: none;}
	.value-items .item {flex-direction: column; gap: 15px; text-align: center;}

	.greetings .photo {width: 100%; padding-right: 0;}
	.greetings .photo .img {margin-left: -45px; z-index: -1;}
	.greetings h2 {margin-bottom: 25px !important;}

	.executives .item {flex-direction: column; gap: 20px;}
	.executives .item:nth-child(even) {flex-direction: column; gap: 20px; align-items: flex-end;}
	.executives .item .img {width: 30%;}

	.history .item {padding-left: 40px !important; padding-bottom: 28px;}
	.history .item ul {padding: 0;}
	.history .item:after {width: 20px; height: 20px; left: -10px;}
	.history-year {font-size: 20px;}
	.history-year:before, .history .item:nth-child(even) .history-year:before {width: 14px; left: -24px;}
	.history .item:before {width: 46px; height: 46px; top: -12px;}

	.management .photo {width: 212px;}

	/* board */
	.input {font-size:14px; padding:0 10px; height:38px;}
	select.input {padding-right:26px; background-image:url("/images/bbs/select_x2.png"); background-position:right 8px center; background-size:12px auto;}
	textarea.input {padding:7px 10px;}

	.checkbox input:checked + label:before {background-image:url("/images/bbs/checkbox_x2.png"); background-size:11px auto;}

	.board-search {display:flex; flex-direction:column; margin-bottom:10px;}
	.board-search .total-page {order:3; float:none; font-size:13px;}
	.board-search .cate {float:none; order:1; margin-left:0; margin-bottom:5px;}
	.board-search .cate .input {display:block; width:100%;}
	.board-search .search {float:none; order:2; display:flex;}
	.board-search .search .input {flex:1 1 auto; min-width:0; width:1%;}

	.board-list {display:none;}
	.board-list-m {display:block;}

	.business-gallery ul {margin: 0 -7px 0;}
	.business-gallery li {width: 50%; padding: 0 7px 27px;}

	.gallery-list {padding-top:15px;}
	.gallery-list ul {margin:0 -7px;}
	.gallery-list ul li {width:50%; padding:0 7px; margin-bottom:27px;}
	.gallery-list ul li .thumb {margin-bottom:10px;}
	.gallery-list ul li .tit {font-size:14px;}
	.gallery-list ul li .date {font-size:12px; margin-top:4px;}

	.news-list ul li {padding:17px 0;}
	.news-list .thumb {width:38%; margin-right:14px;}
	.news-list .tit {font-size:15px; max-height:2.8em; white-space:normal; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;}
	.news-list .txt {font-size:13px; margin-top:3px; max-height:3em; -webkit-line-clamp:2;}
	.news-list .date {display:none;}

	.event-list {padding-top:20px;}
	.event-list ul li {width:100%; margin-bottom:32px;}
	.event-list ul li .thumb {margin-bottom:10px;}
	.event-list ul li .tit {font-size:15px;}
	.event-list ul li .date {font-size:12px; margin-top:4px;}

	.faq .tit a {padding:7px 0 7px 5px;}
	.faq .tit a:after {display:none;}
	.faq .q {flex:0 0 26px; width:26px; height:26px; font-size:15px; line-height:26px; margin-right:10px;}
	.faq .cnt {padding:12px 12px 12px 15px;}

	.calendar-head {margin-bottom:15px;}
	.calendar-head h3 {font-size:20px; margin:0 17px;}
	.calendar-head .cal-btn {width:34px; height:34px; background-size:9px auto;}
	.calendar-head .cal-prev {background-image:url("/images/bbs/cal_prev_x2.png");}
	.calendar-head .cal-next {background-image:url("/images/bbs/cal_next_x2.png");}
	.calendar table th {padding:6px 4px; font-size:14px;}
	.calendar table td {height:60px; padding:5px 4px; font-size:12px;}
	.calendar ul li {padding-left:0; margin-bottom:6px;}
	.calendar ul li:before {display:none;}
	.calendar .cal-date {font-size:10px; margin-bottom:8px;}

	.board-white table {display:block; border-top:0; border-bottom:0; font-size:14px;}

	.board-white table tbody {display:block;}
	.board-white table tr {display:block; padding:12px 0;}
	.board-white table th {display:block; border:0; text-align:left; padding:0; margin-bottom:7px; font-size:16px; background:none;}
	.board-white table td {display:block; border:0; padding:0;}
	.board-white .editor {padding:0; margin-top:-12px;}
	.board-white .item {margin:3px 12px 3px 0;}
	.board-white #user_name {max-width:100% !important;}
	.board-white + .buttons {margin-top:30px;}

	.board-form table tbody {display:block;}
	.board-form table tr {display:block; padding:12px 0;}
	.board-form table th {display:block; border:0; text-align:left; padding:0; margin-bottom:7px; font-size:16px; background:none;}
	.board-form table td {display:block; border:0; padding:0;}
	.board-form .help-text {font-size:12px;}
	.board-form .check-items {margin:0 -10px;}
	.board-form .check-items .item {min-width:50px; padding:5px 10px;}
	.board-form + .buttons {margin-top:30px;}

	.form-agree {margin:30px 0 30px;}
	.form-agree h3 {font-size:16px;}
	.form-agree .scroll-box {font-size:12px; max-height:110px; overflow:auto;}
	.form-agree .check {margin-top:12px; font-size:14px;}

	.bbs-top-txt {font-size:14px;}

	.board-view-tit h3 {font-size:17px;}
	.board-view-info {font-size:12px;}

	.board-prev-next dl {padding:10px 6px;}
	.board-prev-next dt {width:70px}

	.buttons {margin:15px 0;}

	.btn-pack.small {height:26px; padding:0 8px; font-size:11px; line-height:24px;}
	.btn-pack.medium {height:38px; padding:0 14px; font-size:14px; line-height:36px;}
	.btn-pack.large {min-width:120px; height:42px; padding:0 18px; font-size:15px; line-height:40px;}
	.btn-pack.xlarge {min-width:120px; height:50px; padding:0 22px; font-size:16px; line-height:48px;}
	.btn-pack.comment {width:80px; height:32px; font-size:14px;}

	.paginate {margin-top:20px;}
	.paginate a,
	.paginate strong{margin:0 1px;width:30px;height:30px;font-size:14px;line-height:30px;}
	.paginate a.direction {margin:0; background-size:11px;}
	.paginate a.direction.first {background-image:url("/images/bbs/btn_first_x2.png");}
	.paginate a.direction.prev {background-image:url("/images/bbs/btn_prev_x2.png"); margin-right:14px;}
	.paginate a.direction.next {background-image:url("/images/bbs/btn_next_x2.png"); margin-left:14px;}
	.paginate a.direction.last {background-image:url("/images/bbs/btn_last_x2.png");}

	.comment-area {margin-top:37px;}
	.comment-total {font-size:14px; margin-bottom:12px;}
	.comment-write {position:relative; padding:10px;}
	.comment-write .byte {position:absolute; bottom:15px; left:12px; font-size:12px;}
	.comment-write .write {display:block;}
	.comment-write .write textarea {display:block; width:100%; height:65px; margin-right:0;}
	.comment-write .write .btn {text-align:right; margin-top:6px;}
	.comment-item {padding:17px 4px;}
	.comment-item.comment-reply {padding-left:25px; background-image:url("/images/bbs/icon_reply_x2.png"); background-position:3px 18px; background-size:auto 13px;}
	.comment-info {font-size:14px;}
	.comment-info .name {margin-right:5px;}
	.comment-info .date {font-size:11px;}
	.comment-ctr {font-size:12px;}
	.comment-ctr .bar {vertical-align:middle; margin:-.2em 4px 0;}
	.comment-txt {font-size:14px;}
	.comment-link {font-size:13px;}
	.comment-input {padding:10px;}
	.comment-input textarea {height:48px;}

	.board-password {padding:30px 20px;}

	.store-search {padding:0;}
	.store-search .search-area h3 {font-size:16px; padding:15px 25px; margin-bottom:20px; background:#f4f4f4;}
	.store-search .search-area dl {display:block; padding:0 15px; margin:20px 0;}
	.store-search .search-area dl dt {width:auto; margin-bottom:6px; font-size:15px;}
	.store-search .search-area dl dd {width:auto;}
	.store-search .search-area input.input {width:calc(100% - 74px); margin-right:4px;}
	.store-search .search-area select.input {width:calc(50% - 39px); margin-right:4px;}
	.store-search .search-area .btn-pack.medium {width:70px;}

	.result-top {font-size:18px;}
	.result-group .gall {margin:0 -7px;}
	.result-group .gall li {width:50%; padding:0 7px;}
	.result-group dl dt {font-size:15px;}
	.result-group dl dd {font-size:13px;}
	.result-group dl dd.date {font-size:12px;}

}

/* Landscape phones and down */
@media (max-width: 420px) {


}