@charset "utf-8";

@font-face {
	font-family: 'Oswald-Medium';
	font-style: normal;
	src: url('../font/Oswald/Oswald-Medium.ttf') format('truetype');
}

* {
	margin: 0;
	padding: 0;
	vertical-align: top;
	font-family: "Yu Gothic Medium", "游ゴシック Medium", "Yu Gothic", YuGothic, "游ゴシック", "メイリオ", Meiryo, "ヒラギノ角ゴPro W3", "Hiragino Kaku Gothic Pro", sans-serif;
}

body {
	line-height: 1;
	color: #444;
	/*font-size: 14px;*/
	-webkit-text-size-adjust: 100%;
}

p, h1, h2, h3, h4, th, td, li, dt, dd, figcaption {
	/*font-size: 14px;
	line-height: 1.8;*/
	font-weight: normal;
}

img {
	border: none;
}
img.fit {
	width: 100%;
}

a {
	color: #444;
	text-decoration: none;
}
a:hover {
	text-decoration: none;
}

ul, ol {
	list-style-type: none;
}

.hidden-parts {
	display: none;
}

#cboxLoadedContent img {
	max-width: 100%;
	height: auto;
}

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

/* -------------------------------------------------
	headline
------------------------------------------------- */

.h-style1 {
	color: #444;
	text-align: center;
}
.h-style1.margin-top {
	margin-top: 100px;
}
.h-style1 > span {
	font-family: 'Oswald-Medium';
	font-family: 'Source Sans Pro', sans-serif;
	letter-spacing: 0.3em;
	line-height: 1;
	display: block;
}
.h-style1 .small {
	font-size: 24px;
}
.h-style1 .large {
	margin-top: 37px;
	font-size: 42px;
}

.h-style2 {
	color: #444;
	text-align: left;
	display: block;
}
.h-style2 > span {
	font-family: 'Source Sans Pro', sans-serif;
	letter-spacing: 0.3em;
	display: block;
}
.h-style2 .large {
	font-size: 32px;
	line-height: 1.5;
}
.h-style2 .small {
	margin-top: 13px;
	font-size: 13px;
	line-height: 1;
    letter-spacing: 0.2em;
}
.h-style2 .small span {
	font-size: 10px;
    vertical-align: baseline;
}

@media screen and (max-width:767px) {
	.h-style1.margin-top {
		margin-top: calc(70 / 750 * 100vw);
	}
	.h-style1 .small {
		font-size: calc(27 / 750 * 100vw);
	}
	.h-style1 .large {
		margin-top: calc(40 / 750 * 100vw);
		font-size: calc(47 / 750 * 100vw);
	}
	
	.h-style2 .large {
		font-size: calc(35 / 750 * 100vw);
	}
	.h-style2 .small {
		margin-top: 1em;
		font-size: calc(15 / 750 * 100vw);
	}
}

/* -------------------------------------------------
	link
------------------------------------------------- */

.link-style1 {
	text-align: center;
}
.link-style1 a {
	padding: 0 0 15px;
	font-size: 22px;
	color: #444;
	display: inline-block;
	border-bottom: solid 1px #444;
	line-height: 1;
     font-family: 'Source Sans Pro', sans-serif;
	letter-spacing: 0.2em;
}

@media screen and (max-width:767px) {
	.link-style1 a {
		padding: 0 0 0.5em;
		font-size: calc(30 / 750 * 100vw);
	}
}

/* -------------------------------------------------
	contents
------------------------------------------------- */

#main {
	display: block;
}

.cont-wrapper {
	margin-left: 20px;
	margin-right: 20px;
}
.cont1360 {
	max-width: 1360px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}

@media screen and (max-width:767px) {
	.cont-wrapper {
		margin: 0;
	}
	.cont-sp {
		margin-left: calc(55 / 750 * 100%);
		margin-right: calc(55 / 750 * 100%);
	}
}

/* -------------------------------------------------
	gnav
------------------------------------------------- */

#gnav #nav-btn {
	width: 80px;
	height: 80px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 110;
}
#gnav #nav-btn img {
	width: 30px;
	height: auto;
}
#gnav #nav-btn img.open,
#gnav.on #nav-btn img.close {
	display: block;
}
#gnav #nav-btn img.close,
#gnav.on #nav-btn img.open {
	display: none;
}

/*#nav-btn {
	display: block;
	width: 40px;
	height: 40px;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
}*/
#gnav #nav-btn span {
	display: block;
	background: #444;
	width: 30px;
	height: 1px;
	position: absolute;
	left: 25px;
	-webkit-transition: all 0.4s;
	transition: all 0.4s;
}
#gnav #nav-btn p {
	-webkit-transition: all 0.4s;
	transition: all 0.4s;
	-webkit-transition-delay: 0.5s;
	transition-delay: 0.5s;
}

#gnav #nav-btn span:first-child { top: 35px;}
#gnav #nav-btn span:nth-child(2) { bottom: 35px;}
#gnav.on #nav-btn span:first-child {
	-webkit-transform: translateY(5px) rotate(45deg);
	transform: translateY(5px) rotate(45deg);
}
#gnav.on #nav-btn span:nth-child(2) {
	-webkit-transform: translateY(-4px) rotate(-45deg);
	transform: translateY(-4px) rotate(-45deg);
}


#gnav #menu-base {
	width: 100%;
	height: 100%;
	background: #ccc;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 100;
	display: none;
	opacity: 0.7;
}
#gnav #menu-panel {
	width: 480px;
	height: 100%;
	background: #fff;
	position: fixed;
	left: -480px;
	top: 0;
	z-index: 105;
	overflow: auto;
	transition-property: left;
	transition-duration: 0.4s;
	transition-timing-function: ease-in-out;
}
#gnav.on #menu-panel {
	left: 0 !important;
}
#gnav #menu-panel .inner {
	padding: 160px 120px 0 120px;
}
#gnav #menu-panel p,
#gnav #menu-panel a {
    font-family: 'Source Sans Pro', sans-serif;
}
#gnav #menu-panel a {
	font-size: 19px;
	letter-spacing: 0.2em;
}
#gnav #menu-panel .group1 li {
	margin-top: 20px;
}
#gnav #menu-panel .group2 {
	margin-top: 30px;
	padding-top: 30px;
	border-top: solid 1px #444;
}
#gnav #menu-panel .group2 .title {
	color: #c8c8c8;
	font-size: 14px;
	letter-spacing: 0.2em;
}
#gnav #menu-panel .group2 li {
	margin-top: 15px;
}
#gnav #menu-panel .logo {
	margin-top: 60px;
	text-align: center;
}
#gnav #menu-panel .logo img {
	height: auto;
	opacity: 0.4;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
#gnav #menu-panel .logo .logo1 {
	width: 30px;
}
#gnav #menu-panel .logo .logo2 {
	width: 90px;
	height: auto;
	margin-top: 25px;
}

@media print, screen and (min-width:768px) {
	#gnav #menu-panel a {
		transition-property: all;
		transition-duration: 0.2s;
		transition-timing-function: linear;
	}
	#gnav #menu-panel a:hover {
		color: #ccc;
	}
	#gnav #nav-btn {
		transition-property: opacity;
		transition-duration: 0.2s;
		transition-timing-function: linear;
	}
	#gnav #nav-btn:hover {
		opacity: 0.6;
	}
}

@media screen and (max-width:767px) {
	#gnav #nav-btn {
		width: 50px;
		height: 50px;
	}
	#gnav #nav-btn span {
		width: 20px;
		left: 15px;
	}
	#gnav #nav-btn span:first-child {
		top: 20px;
	}
	#gnav #nav-btn span:nth-child(2) {
		bottom: 20px;
	}
	#gnav #nav-btn img {
		width: calc(40 / 750 * 100vw);
		height: auto;
	}
	#gnav #menu-panel {
		width: 100%;
		left: -100%;
	}
	#gnav #menu-panel .inner {
		padding: calc(120 / 1300 * 100vh) calc(90 / 750 * 100vw) 0 calc(130 / 750 * 100vw);
	}
	#gnav #menu-panel a {
		font-size: calc(32 / 1300 * 100vh);
	}
	#gnav #menu-panel .group1 li {
		margin-top: calc(45 / 1300 * 100vh);
	}
	#gnav #menu-panel .group2 {
		margin-top: calc(60 / 1300 * 100vh);
		padding-top: calc(50 / 1300 * 100vh);
	}
	#gnav #menu-panel .group2 .title {
		font-size: calc(22 / 1300 * 100vh);
	}
	#gnav #menu-panel .group2 li {
		margin-top: calc(35 / 1300 * 100vh);
	}
	#gnav #menu-panel .logo {
		margin-top: calc(70 / 1300 * 100vh);
	}
	#gnav #menu-panel .logo .logo1 {
		width: auto;
		height: calc(45 / 1300 * 100vh);
	}
	#gnav #menu-panel .logo .logo2 {
		width: auto;
		height: calc(16 / 1300 * 100vh);
		margin-top: calc(40 / 1300 * 100vh);
	}
}

/* -------------------------------------------------
	header
------------------------------------------------- */

#header {
	height: 80px;
	position: relative;
	background: #fff;
}
#header.top-header {
	height: 0;
}
#header .logo {
	width: 40px;
	height: 40px;
	display: inline-block;
	position: absolute;
	left: 50%;
	top: 50%;
	margin: -20px 0 0 -20px;
	z-index: 10;
	opacity: 0.4;
}
#header .logo img {
	width: 100%;
	height: auto;
}
#header .store {
	width: 80px;
	height: 80px;
	display: flex;
	justify-content: center;
	align-items: center;
	/*color: #444;
	font-size: 17px;
    font-family: 'Source Sans Pro', sans-serif;
	letter-spacing: 0.2em;*/
	background: url(../images/paper-bag.png) no-repeat center center;
	background-size: 30px;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 90;
	transition-property: opacity;
    transition-duration: 0.2s;
    transition-timing-function: linear;
}
#header .store:hover {
	opacity: 0.5;
}

@media screen and (max-width:767px) {
	#header {
		height: calc(100 / 750 * 100vw);
	}
	#header .logo {
		width: calc(56 / 750 * 100vw);
		height: calc(56 / 750 * 100vw);
		margin: calc(-28 / 750 * 100vw) 0 0 calc(-28 / 750 * 100vw);
	}
	#header .store {
		width: 50px;
		height: 50px;
		font-size: calc(17 / 750 * 100vw);
    	background-size: 20px;
	}
}

/* -------------------------------------------------
	footer
------------------------------------------------- */

#footer {
	padding: 140px 0 100px;
	text-align: center;
    position: relative;
    z-index: 2;
    background-color: #fff;
}
#footer .sns a {
	margin: 0 25px;
	display: inline-block;
}
#footer .sns a img {
	height: 26px;
}
#footer .copyright {
	margin-top: 100px;
	font-size: 12px;
	font-family: 'Source Sans Pro', sans-serif;
	letter-spacing: 0.2em;
}

@media screen and (max-width:767px) {
	#footer {
		padding: calc(120 / 750 * 100vw) 0 calc(140 / 750 * 100vw);
	}
	#footer .sns a {
		margin: calc(25 / 750 * 100vw);
	}
	#footer .sns a img {
		width: auto;
		height: calc(35 / 750 * 100vw);
	}
	#footer .copyright {
		margin-top: calc(90 / 750 * 100vw);
		font-size: calc(18 / 750 * 100vw);
	}
}

/* -------------------------------------------------
	other
------------------------------------------------- */

/* for responsive */

@media print, screen and (min-width:768px) {
	.pc-none {
		display: none !important;
	}
}

@media screen and (max-width:767px) {
	.sp-none {
		display: none !important;
	}
}

/* float */

.l-side {
	float: left;
}
.r-side {
	float: right;
}

.clear {
	clear: both;
}
.clearfix::after {
	clear: both;
	content: "";
	height: 0;
	display: block;
}

/* -------------------------------------------------
	print
------------------------------------------------- */

@media print {
	body {
		width: 980px !important;
	}
}


/* -------------------------------------------------
	opening
------------------------------------------------- */

#op {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 9999;
	background-color: #fff;
}
#op svg {
	width: 220px;
	height: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
#op path {
    stroke:#444;
    fill: transparent;
    stroke-width:1;
    stroke-dasharray: 3000;
    stroke-dashoffset:3000;
    -webkit-animation:DASH 1.5s ease-in 0.5s forwards;
    animation:DASH 1.5s ease-in 0.5s forwards;
    -webkit-transition:all .3s ease-in;
    transition:all .3s ease-in;    
}
@keyframes DASH{
    0%  {stroke-dashoffset:3000;fill:transparent;}
    80% {stroke-dashoffset:2000;fill:transparent;}
    100%{stroke-dashoffset:0;fill:#444;}
}
@-webkit-keyframes DASH{
    0%  {stroke-dashoffset:3000;fill:transparent;}
    80% {stroke-dashoffset:2000;fill:transparent;}
    100%{stroke-dashoffset:0;fill:#444;}
}

@media screen and (max-width:767px) {
	#op svg {
		width: 160px;
	}
}



/* ■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■
	
	以下、各ページ
	
■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ */

/* -------------------------------------------------
	コレクション部分（トップ、コレクションページ共通スタイル）
------------------------------------------------- */

#collection .js-para {
	transition-property: transform;
	transition-duration: 1s;
	transition-timing-function: ease-out;
}

@media print, screen and (min-width:768px) {
	#collection {
		padding: 160px 0 0;
		background: url(../images/top/bg_01.jpg) no-repeat right top / 50% auto;
		
		position: relative;
		z-index: 2;
	}
	/*#pageID-top #collection {
		margin-top: 100vh;
	}*/
	#collection .item .pic.large {
		width: calc(750 / 1360 * 100%);
		height: auto;
	}
	#collection .item .pic.small {
		width: calc(420 / 1360 * 100%);
		height: auto;
	}
	#collection .item {
		position: relative;
	}
	
	/* item.i1, 7 */
	
	#collection .item.i1,
	#collection .item.i7 {
		margin-top: 195px;
	}
	#collection .item.i1 .p2,
	#collection .item.i7 .p2{
		margin: 42% 0 0 -9%;
	}
	#collection .item.i1 .title {
		position: absolute;
		right: 2%;
		top: 22%;
	}
	#collection .item.i7 .title {
		position: absolute;
		right: 2%;
		top: 18%;
	}
	#collection .item.i7 .h-style2 + .h-style2 {
		margin-top: 25px;
	}
	
	/* item.i2, 5, 11 */
	
	#collection .item.i2,
	#collection .item.i5,
	#collection .item.i8 {
		margin-top: 335px;
	}
	#collection .item.i2 .p1,
	#collection .item.i5 .p1,
	#collection .item.i8 .p1 {
		margin-left: calc(85 / 1360 * 100%);
	}
	#collection .item.i2 .title,
	#collection .item.i5 .title,
	#collection .item.i8 .title {
		position: absolute;
		left: calc(600 / 1360 * 100%);
		top: 4%;
	}
	#collection .item.i8 .h-style2 + .h-style2 {
		margin-top: 25px;
	}
	
	/* item.i3, 6 */
	
	#collection .item.i3,
	#collection .item.i6 {
		margin-top: -95px;
		text-align: right;
	}
	#collection .item.i3 .p1,
	#collection .item.i6 .p1 {
		margin-right: calc(80 / 1360 * 100%);
	}
	#collection .item.i3 .title,
	#collection .item.i6 .title {
		position: absolute;
		right: calc(590 / 1360 * 100%);
		bottom: 1.5%;
	}
	
	/* item.i1, 4 */
	
	#collection .item.i4 {
		margin-top: 528px;
		text-align: right;
	}
	#collection .item.i4 .cont1360 {
		padding-bottom: 27%;
		background: url(../images/top/bg_02.jpg) no-repeat center bottom / 92% auto;
	}
	#collection .item.i4 .p2 {
		margin: -86% calc(690 / 1360 * 100%) 0 0;
	}
	#collection .item.i4 .title {
		position: absolute;
		left: 0;
		top: 45%;
	}
}

@media screen and (max-width:767px) {
	#collection {
		padding: calc(140 / 750 * 100vw) 0 0;
		background: url(../images/top/bg_01_sp.jpg) no-repeat right top / 50% auto;
		position: relative;
		z-index: 2;
	}
	#top #collection {
		margin-top: 100vh;
	}
	#collection .item::after {
		content: "";
		display: block;
		clear: both;
		height: 0;
	}
	#collection .item .pic.large {
		width: 100%;
		height: auto;
	}
	#collection .item .pic.small {
		width: 66%;
		height: auto;
	}
	
	#collection .item.i1 .pic.small,
	#collection .item.i4 .pic.small,
	#collection .item.i7 .pic.small {
		width: calc(330 / 750 * 100vw);
		float: right;
		margin: calc(-370 / 750 * 100vw) -5.5% 0 0;
		position: relative;
		z-index: 5;
	}
	#collection .item.i1 .title,
	#collection .item.i4 .title,
	#collection .item.i7 .title {
		margin-top: calc(180 / 750 * 100vw);
	}
	
	#collection .item.i2,
	#collection .item.i3,
	#collection .item.i5,
	#collection .item.i6,
	#collection .item.i8 {
		text-align: center;
	}
	#collection .item.i2 .title,
	#collection .item.i3 .title,
	#collection .item.i5 .title,
	#collection .item.i6 .title,
	#collection .item.i8 .title {
		margin: 1.1em 0 0 17%;
	}
	
	#collection .item .title p + p {
		margin-top: calc(40 / 750 * 100vw);
	}
	
	#collection .item.i1 {
		margin-top: calc(140 / 750 * 100vw);
	}
	#collection .item.i3,
	#collection .item.i6 {
		margin-top: calc(120 / 750 * 100vw);
	}
	#collection .item.i2,
	#collection .item.i4,
	#collection .item.i7,
	#collection .item.i8 {
		margin-top: calc(180 / 750 * 100vw);
	}
	
	#collection .item.i4 {
		padding-bottom: calc(530 / 750 * 100vw);
		background: url(../images/top/bg_02_sp.jpg) no-repeat center bottom / 100% auto;
	}
	
	#collection .item.i5 {
		margin-top: calc(-230 / 750 * 100vw);
	}
}

/* -------------------------------------------------
	トップ
------------------------------------------------- */

/*#header.top-header::after {
	width: 50%;
	height: 100%;
	content: "";
	display: block;
	position: absolute;
	left: 50%;
	top: 0;
	background: #f4f4f4;
}
#header#header.top-header .store {
	background: #f4f4f4;
}*/

/* main-visual */

#pageID-top .main-visual {
	position: relative;
	overflow: hidden;
}
#pageID-top .main-visual.movie {
	height: 100vh;
    width: 100%;
    opacity: 0.5;
    position: fixed;
    top: 0;
    left: 0;
	z-index: 0;
}
#pageID-top .main-visual.movie .js-youtube-fullscreen {
	position: relative;
}


.topBnr {
	position: absolute;
	right: 20px;
	bottom: 20px;
	max-width: 400px;
    line-height: 0;
	box-shadow: 0 5px 10px 0 rgba(0,0,0,0.1);
}
.topBnr img {
	max-width: 100%;
	height: auto;
}

#pageID-top .main-visual .pic {
	width: 100%;
	height: auto;
	position: relative;
	z-index: 5;
}
#pageID-top .main-visual .headline {
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	z-index: 10;
	left: 0;
	top: 0;
}
#pageID-top .main-visual .headline img {
	width: calc(350 / 1600 * 100%);
	height: auto;
}


#movBtnWrap {
	position: relative;
	width: 100%;
	height: 100vh;
}
#movBtnWrap .movBtn {
    position: absolute;
    top: 64%;
    left: 50%;
	margin-left: -110px;
}
.movBtn {
	width: 220px;
}
.movBtn a {
    font-family: 'Source Sans Pro', sans-serif;
	display: block;
	border: #fff solid 1px;
	font-size: 20px;
	color: #fff;
	line-height: 60px;
	letter-spacing: 2px;
	text-indent: 2px;
	text-align: center;
	text-decoration: none;
	-webkit-transition: all 0.3s ease-out;
	transition: all 0.3s ease-out;
}
.movBtn a:hover {
	color: #888;
	border: #888 solid 1px;
}

.ftrBg {
	position: relative;
}
.ftrBg .movBtn {
    position: absolute;
    top: 54%;
    left: 50%;
	margin-left: -110px;
    z-index: 3;
}


@media screen and (max-width:767px) {
	#pageID-top .main-visual .headline img {
		width: calc(350 / 750 * 100%);
	}
	#pageID-top .main-visual.movie {
		height: 100vh;
	}
	
	#movBtnWrap .movBtn {
		top: 52%;
		margin-left: -90px;
	}
	.ftrBg .movBtn {
		top: 54vw;
		margin-left: -90px;
	}
	.movBtn {
		width: 180px;
	}
	.movBtn a {
		font-size: 16px;
		line-height: 50px;
	}
	.topBnr {
		right: 0vw;
    	bottom: 36vw;
		width: 64vw;
		box-shadow: 0 3px 6px 0 rgb(0 0 0 / 10%);
	}
	
}

/* view-all */

.view-all {
	margin-top: 240px;
}

@media screen and (max-width:767px) {
	.view-all {
		margin-top: calc(180 / 750 * 100vw);
	}
}

/* instagram */

#pageID-top #instagram {
	position: relative;
	z-index: 10;
}

#pageID-top #instagram .two-col .headline {
	font-family: 'Source Sans Pro', sans-serif;
	color: #444;
	letter-spacing: 0.2em;
	font-size: 24px;
}
#pageID-top #instagram .two-col p {
	margin-top: 35px;
}
#pageID-top #instagram .two-col p a {
	font-family: 'Source Sans Pro', sans-serif;
	color: #444;
	letter-spacing: 0.2em;
}

#pageID-top #instagram .two-col .right a {
	display: block;
	width: 55.8%;
    padding-top: 55.8%;
	margin: 0 auto;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}


@media print, screen and (min-width:768px) {
	#pageID-top #instagram .two-col {
		margin-top: 150px;
		background: #fff;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	#pageID-top #instagram .two-col > * {
		width: 50%;
		padding: 120px 0;
		text-align: center;
	}
	#pageID-top #instagram .two-col img {
		width: 55.8%;
		height: auto;
	}
}

@media screen and (max-width:767px) {
	#pageID-top #instagram .two-col .headline {
		font-size: calc(32 / 750 * 100vw);
	}
	#pageID-top #instagram .two-col .left {
		margin-bottom: 35px;
	}
	#pageID-top #instagram .two-col p {
		margin-top: calc(40 / 750 * 100vw);
	}
	#pageID-top #instagram .two-col p a {
		font-size: calc(24 / 750 * 100vw);
	}
	#pageID-top #instagram .two-col {
		margin-top: calc(315 / 750 * 100vw);
     	padding-top: calc(110 / 750 * 100vw);
		padding-bottom: calc(110 / 750 * 100vw);
		text-align: center;
		background: #fff;
	}
	#pageID-top #instagram .two-col .right a {
		width: 62%;
		padding-top: 62%;
	}
	#pageID-top #instagram .two-col img {
		width: 62%;
		height: auto;
		margin-top: calc(105 / 750 * 100vw);
	}
}

/* bottom-image */

#pageID-top .bottom-image {
	width: 100%;
	height: auto;
	margin-top: -18%;
    position: relative;
    z-index: 2;
}

@media screen and (max-width:767px) {
	#pageID-top .bottom-image {
		margin-top: calc(-410 / 750 * 100vw);
	}
}

/* -------------------------------------------------
	about
------------------------------------------------- */

#pageID-about #about {
	text-align: center;
}
#pageID-about #about .logo {
	margin-top: 120px;
}
#pageID-about #about .logo .logo1 {
	display: block;
	margin: 0 auto;
    width: 220px;
	height: auto;
}
#pageID-about #about .logo .logo2 {
	display: block;
	margin: 45px auto 0;
    width: 300px;
	height: auto;
}
#pageID-about #about .logo .name {
	margin: 40px auto 0;
	font-size: 16px;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 0.1em;
}
#pageID-about #about .message {
	padding: 60px 0;
	line-height: 2.3;
	font-size: 18px;
}

@media screen and (max-width:767px) {
	#pageID-about #about .logo {
		margin-top: 60px;
	}
	#pageID-about #about .logo .logo1 {
		width: 120px;
		height: auto;
	}
	#pageID-about #about .logo .logo2 {
		width: auto;
		height: calc(20 / 750 * 100vw);
		margin: calc(30 / 750 * 100vw) auto 0;
	}
	#pageID-about #about .logo .name {
		margin: 20px auto 0;
		font-size: calc(22 / 750 * 100vw);
	}
	#pageID-about #about .message {
		padding: 4em 0;
		font-size: calc(24 / 750 * 100vw);
		white-space: nowrap;
	}
}

/* -------------------------------------------------
	company
------------------------------------------------- */

#pageID-company .profile-table dd {
	word-break: break-all;
}
#pageID-company .profile-table dd a {
	color: #777;
	text-decoration: underline;
}
#pageID-company .profile-table .nowrap {
	white-space: nowrap;
}
#pageID-company .profile-table dd dl {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
    padding: 10px 0;
}
#pageID-company .profile-table dd dl dt {
	width: 110px;
	margin-bottom: 10px;
	line-height: 1.8;
	position: relative;
}
#pageID-company .profile-table dd dl dt::before {
	content: "";
	height: 1px;
	width: 100%;
	position: absolute;
	background-color: #ccc;
	top: 50%;
	left: 0;
	z-index: 1;
}
#pageID-company .profile-table dd dl dt span {
	background-color: #fff;
	display: inline-block;
	padding-right: 15px;
	position: relative;
	z-index: 2;
}
#pageID-company .profile-table dd dl dd {
	width: calc(100% - 125px);
	margin-bottom: 10px;
	line-height: 1.8;
}

@media print, screen and (min-width:768px) {
	#pageID-company .profile-table {
		max-width: 980px;
		margin: 80px auto 0;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	#pageID-company .profile-table dt,
	#pageID-company .profile-table dd {
		line-height: 3;
		font-size: 15px;
	}
	#pageID-company .profile-table dt {
		width: 14em;
	}
	#pageID-company .profile-table dd {
		width: calc(100% - 14em);
	}
	#pageID-company .profile-table .address-text {
		padding-right: 3em;
	}
}

@media screen and (max-width:767px) {
	#pageID-company .profile-table {
		margin-top: calc(80 / 750 * 100vw);
	}
	#pageID-company .profile-table dt,
	#pageID-company .profile-table dd {
		line-height: 2;
	}
	#pageID-company .profile-table dt {
		font-size: calc(26 / 750 * 100vw);
    	font-weight: bold;
	}
	#pageID-company .profile-table dd + dt {
		margin-top: 1.5em;
	}
	#pageID-company .profile-table dd {
		padding-left: 0;
     	padding-bottom: 10px;
		font-size: calc(26 / 750 * 100vw);
	}
	
	#pageID-company .profile-table dd dl dt {
		margin-top: 0;
		margin-bottom: 10px;
		font-weight: normal;
	}
	#pageID-company .profile-table dd dl dd {
		margin-bottom: 10px;
     	padding-bottom: 0;
	}
}