@charset "utf-8";

body {
	background: url('imgs/bg.png');
	font-size: 14px;
	font-family: Arial, Helvetica, sans-serif;
	color: #fff;
}

body,
div,
li,
ul,
p,
h1,
h2,
h3,
h4,
h5 {
	margin: 0;
	padding: 0;
}

header,
footer,
main,
div,
li,
a,
ul {
	box-sizing: border-box;
}

.flex {
	display: flex;
	justify-content: space-between;
}

a {
	color: #fff;
}

nav a,
.nav a {
	text-decoration: none;
	font-size: 1.05rem;
	font-family: "凸版文久見出しゴシック";
	font-weight: lighter;
}

nav a:hover,
.nav a:hover {
	color: #2891ca;
}

.nav a {
	color: #222;
	margin: 0 auto;
}

nav span,
.nav span {
	display: block;
	font-size: 0.7rem;
	margin: auto;
	font-family: Arial, Helvetica, sans-serif;
}

nav li {
	margin: 10px 0;
}


li {
	list-style: none;
}

header {
	position: absolute;
	width: 500px;
	padding: 60px;
	right: 0;
}

.bg {
	width: 10%;
	background-color: #88888822;
	height: 100%;
	position: fixed;
	left: 50%;
	transform: translateX(-50%);
	z-index: -1;
}

.border-w {
	border: #fff 1px solid;
	margin: 30px 40px;
	height: calc(100% - 62px);
}

.border-wt {
	border: #ffffff96 1px solid;
	z-index: -1;
}

.visual {
	width: calc(100% - 160px);
	height: calc(100vh - 70px);
	background: url(imgs/visual.jpg) center / cover no-repeat;
	margin-left: auto;
}

.left {
	width: 160px;
	/* position: fixed; */
}

.catch {
	position: absolute;
	/* width: 600px; */
	width: 660px;
	font-family: "ヒラギノ角ゴ Std";
	font-weight: bold;
	font-size: 24px;
	line-height: 24px;
	bottom: calc(12% + 70px);
	color: #222;
}

.catch .bg_blue {
	background-color: #004d76e8;
	width: 100%;
	height: 80px;
	z-index: 10;
}

.catch .bg_white {
	background-color: #ffffffce;
	margin-left: 160px;
	height: 120px;
	margin-bottom: -80px;
}

.catch p {
	margin-left: 210px;
	/* background-color: #fff; */
	bottom: 90px;
	position: absolute;
	display: flex;
}

.catch span {
	font-size: 5em;
	display: block;
	align-items: center;
}

nav {
	display: flex;
	flex-direction: column;
	justify-content: center;
	height: 360px;
	width: fit-content;
	margin: auto;
	/* position: fixed; */
	margin-left: 40px;
}


.logo h1 {
	height: 80px;
}

.logo {
	border-top: 20px solid #666;
	border-bottom: 20px solid #666;
	border-right: 1px solid #666;
}

.logo img {
	width: 100%;
	margin-left: auto;
}

.switch {
	height: 70px;
}

main {
	width: calc(100% - 300px);
	margin-left: 160px;
}

section {
	margin: 100px 0 160px;
}

h2 {
	font-size: 3.6rem;
	position: relative;
	margin-top: -25px;
	font-family: "凸版文久見出しゴシック";
	line-height: 1;
	width: fit-content;
	height: fit-content;
}

h2 span,
h3 span {
	position: absolute;
	font-size: 1rem;
	font-family: Arial, Helvetica, sans-serif;
	font-weight: normal;
	width: max-content;
}

.contents {
	background: url('imgs/bg.png');
	width: 200px;
	height: fit-content;
}

#about {
	justify-content: left;
	align-items: flex-end;
}

#about .img {
	background: url(imgs/about.jpg) center / cover no-repeat;
	width: 300px;
	height: calc(100% - 120px);
	margin-left: auto;
	margin-top: 34px;
}

#about .border-wt {
	width: 760px;
	height: 260px;
	justify-content: left;
}

#about .contents {
	margin-top: 30px;
	margin-left: -25px;
	height: fit-content;
}

#about h2 span {
	left: -60px;
	top: 5px;
}

#about h2 {
	margin-left: 60px;
}

#works {
	position: relative;
	width: 96%;
	margin: 100px auto;
}

#works h2 {
	margin-left: auto;
}

#works h2 span {
	/* bottom: 0; */
	display: block;
	right: 0;
}

#works .border-wt {
	width: 100%;
	height: 400px;
	position: absolute;
}

#works .contents {
	margin-top: 28px;
	margin-right: 70px;
	margin-left: 6px;
}

.art_wp {
	width: 690px;
	padding-top: 90px;
	margin-left: 110px;
}

.img_wp {
	width: 400px;
	background: #fff;
	border: 1px solid #ffffffd6;
}

h3 {
	font-size: 1.4rem;
	transform: rotate(90deg);
	transform-origin: 0 100%;
	width: fit-content;
	height: fit-content;
	margin-top: -26px;
	background: url(imgs/bg.png);
}

h3 span {
	font-size: 0.6em;
	margin-left: 4px;
}

.contents_sub {
	width: 200px;
	font-size: 13px;
	padding-right: 10px;
	background: url(imgs/bg.png);
}

article {
	margin: 20px 0;
}

.movie,
.restaurant {
	justify-content: left;
	flex-direction: row-reverse;
	display: flex;
}

.d_main {
	flex-direction: row-reverse;
	justify-content: left;
}

.d_sub {
	margin-left: 200px;
	width: 410px;
}

.d_sub>div {
	width: 50%;
}

.d_sub>div:first-of-type {
	padding-right: 6px;
}

h4 {
	font-size: 1.2rem;
	margin-top: 6px;
}

.movie .img_wp {
	background: url(imgs/movie.jpg) center / cover no-repeat;
}

.restaurant .img_wp {
	background: url(imgs/restaurant.jpg) center / cover no-repeat;
}

.img_space_d {
	width: 50%;
	height: 100%;
	background: url(imgs/space.jpg) center / cover no-repeat;
}

.img_web_d {
	width: 50%;
	height: 100%;
	background: url(imgs/web.jpg) center / cover no-repeat;
}

.img_wp:hover,
.img_space_d:hover,
.img_web_d:hover {
	background-image: none;
	background: #ffffffd6;
	cursor: pointer;
}

footer {
	background: #222;
	/* height: 160px; */
	border-top: 1px solid #ffffff96;
}

.button {
	border: 1px solid #ffffff96;
	font-size: 13px;
	height: fit-content;
	margin-left: 30px;
}

.button:hover {
	background: #004d76e8;
}

.button a {
	text-decoration: none;
	padding: 10px 30px;
	display: block;
}

main {
	padding-bottom: 100px;
}

.copyright {
	text-align: center;
	font-size: 1rem;
	padding: 0 0 20px;
}

footer .nav {
	width: 400px;

}

footer .nav a {
	color: #fff;
}

footer>.flex {
	width: 700px;
	margin: 30px auto 0;
}

footer .logo {
	width: 180px;
	border: none;
}