@charset "UTF-8";

@import url(/css/sanitize.css);
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@100;200;300;400;500;600&display=swap');

html,
body {
	width: 100%;
	height: 100%;
	font-family: 'Montserrat', ryo-gothic-plusn, sans-serif;
	letter-spacing: 0.25em;
	line-height: 2.25;
	font-weight: 100;
	font-feature-settings: "palt";
	text-align: justify;
}
.top {
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #0000ff;
}
.lp {
	background-color: white;
}
.about {
	background-image: url(/images/about_bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
}
h1 {
	color: #0000ff;
	font-weight: 100;
	font-size: 2.25em;
	line-height: 1em;
}
.lb {
	font-weight: 300;
	font-style: normal;
	color: #0000ff;
	font-size: 1.125em;
}
a:hover {
	opacity: .7;
}
.effect-fade {
	opacity : 0;
	transform : translate(0, 15px);
	transition : all 1500ms;
}
.effect-fade.effect-scroll {
	opacity : 1;
	transform : translate(0, 0);
}
/*　ハンバーガーボタン　*/
#nav-toggle {
	position: fixed;
	top: 3.75%;
	right: 3.75%;
	height: 32px;
	cursor: pointer;
}
#nav-toggle > div {
	position: relative;
	width: 40px;
}
#nav-toggle span {
	width: 100%;
	height: 1px;
	left: 0;
	display: block;
	background: white;
	position: absolute;
	transition: transform 0.6s ease-in-out, top 0.5s ease;
}
#nav-toggle span:nth-child(1) {
	top: 0;
}
#nav-toggle span:nth-child(2) {
	top: 14px;
}
#nav-toggle span:nth-child(3) {
	top: 28px;
}
#nav-toggle:hover span:nth-child(1) {
	top: 4px;
}
#nav-toggle:hover span:nth-child(3) {
	top: 23px;
}
.open #nav-toggle span {
	background: #0000ff;
}
.open #nav-toggle span:nth-child(1) {
	top: 15px;
	transform: rotate(45deg);
}
.open #nav-toggle span:nth-child(2) {
	top: 15px;
	width: 0;
	left: 50%;
}
.open #nav-toggle span:nth-child(3) {
	top: 15px;
	transform: rotate(-45deg);
}
/* z-index */
#nav-toggle {
	z-index: 1000;
}

#container {
	z-index: 900;
}
#gloval-nav {
	background: white;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 990;
    display: flex;
    visibility: hidden;
    flex-direction: column;
    letter-spacing: 0.25em;
    opacity: 0;
    transition: opacity 0.6s ease, visibility 0.6s ease;
    width: 50%;
    font-size: 1.75em;
    line-height: 0.5em;
    padding-left: 10%;
    justify-content: center;
}
#gloval-nav a {
	display: block;
	text-decoration: none;
	padding: 20px 0;
	color: #0000ff;
}
#gloval-nav a:hover {
	color: #0000ff;
}
#gloval-nav ul {
	list-style: none;
}
#gloval-nav ul li {
	opacity: 0;
	transform: translateX(200px);
	transition: transform 0.6s ease, opacity 0.2s ease;
}
#gloval-nav ul li:nth-child(2) {
	transition-delay: 0.15s;
}
#gloval-nav ul li:nth-child(3) {
	transition-delay: 0.3s;
}
#gloval-nav ul li:nth-child(4) {
	transition-delay: 0.45s;
}
#gloval-nav ul li:nth-child(5) {
	transition-delay: 0.6s;
}
/* open */
.open {
	overflow: hidden;
}
.open #gloval-nav {
	visibility: visible;
	opacity: 1;
}
.open #gloval-nav li {
	opacity: 1;
	transform: translateX(0);
	transition: transform 1s ease, opacity 0.9s ease;
}
/*　下層ハンバーガーボタン　*/
#nav-toggle_lp {
	position: fixed;
	top: 3.75%;
	right: 3.75%;
	height: 32px;
	cursor: pointer;
}
#nav-toggle_lp > div {
	position: relative;
	width: 40px;
}
#nav-toggle_lp span {
	width: 100%;
	height: 1px;
	left: 0;
	display: block;
	background: #0000ff;
	position: absolute;
	transition: transform 0.6s ease-in-out, top 0.5s ease;
}
#nav-toggle_lp span:nth-child(1) {
	top: 0;
}
#nav-toggle_lp span:nth-child(2) {
	top: 14px;
}
#nav-toggle_lp span:nth-child(3) {
	top: 28px;
}
#nav-toggle_lp:hover span:nth-child(1) {
	top: 4px;
}
#nav-toggle_lp:hover span:nth-child(3) {
	top: 23px;
}
.open #nav-toggle_lp span {
	background: white;
}
.open #nav-toggle_lp span:nth-child(1) {
	top: 15px;
	transform: rotate(45deg);
}
.open #nav-toggle_lp span:nth-child(2) {
	top: 15px;
	width: 0;
	left: 50%;
}
.open #nav-toggle_lp span:nth-child(3) {
	top: 15px;
	transform: rotate(-45deg);
}
/* z-index */
#nav-toggle_lp {
	z-index: 1000;
}

#container_lp {
	z-index: 900;
}
#gloval-nav_lp {
	background: #0000ff;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 990;
    display: flex;
    visibility: hidden;
    flex-direction: column;
    letter-spacing: 0.25em;
    opacity: 0;
    transition: opacity 0.6s ease, visibility 0.6s ease;
    width: 50%;
    font-size: 1.75em;
    line-height: 0.5em;
    padding-left: 10%;
    justify-content: center;
}
#gloval-nav_lp a {
	display: block;
	text-decoration: none;
	padding: 20px 0;
	color: white;
}
#gloval-nav_lp a:hover {
	color: white;
}
#gloval-nav_lp ul {
	list-style: none;
}
#gloval-nav_lp ul li {
	opacity: 0;
	transform: translateX(200px);
	transition: transform 0.6s ease, opacity 0.2s ease;
}
#gloval-nav_lp ul li:nth-child(2) {
	transition-delay: 0.15s;
}
#gloval-nav_lp ul li:nth-child(3) {
	transition-delay: 0.3s;
}
#gloval-nav_lp ul li:nth-child(4) {
	transition-delay: 0.45s;
}
#gloval-nav_lp ul li:nth-child(5) {
	transition-delay: 0.6s;
}
/* open */
.open {
	overflow: hidden;
}
.open #gloval-nav_lp {
	visibility: visible;
	opacity: 1;
}
.open #gloval-nav_lp li {
	opacity: 1;
	transform: translateX(0);
	transition: transform 1s ease, opacity 0.9s ease;
}
/* コンテンツ領域 */
content {
	width: 80%;
	margin: auto;
}
/* aboutコンテンツ領域 */
.about_inner {
	width: 90%;
	margin: 0 auto;
}
/* リンク文字色 */
a {
	color: white;
	text-decoration: none;
}
/*　ロゴ　*/
.logo img {
	width: 100%;
	margin-bottom: 5%;
}
/*　下層ロゴ　*/
.lp .logo img {
	width: 320px;
    margin: 3.75%;
}
/*　大テキスト　*/
.txt {
	font-size: 2.5vw;
    color: white;
    line-height: 3.75vw;
}
/*　下層大テキスト色　*/
.lp .txt {
    color: #0000ff;
}
/*　下層大テキストリンク色　*/
.lp .txt a {
    color: #0000ff;
}
/*　プロフィール　*/
.profile {
	margin-top: 10%;
    margin-bottom: 5%;
    display: flex;
    justify-content: flex-start;
}
.profile_photo {
	width: 250px;
	margin-right: 50px;
    margin-top: 25px;
}
.profile_photo img {
	width: 100%;
}
/*　works　*/
.works_inner {
	width: 100%;
	margin: 0 auto;
	display: grid;
    grid-template-columns: 1fr 1fr 1fr;
}
.grid-item {
	position: relative;
	overflow: hidden;
}
.grid-item img {
	width: 100%;
}
.caption {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	width: 100%;
	height: 100%;
	background: rgba(255,255,255,.85);
	-webkit-transition: .3s;
	transition: .3s;
	opacity: 0;
	display: grid;
    place-items: center;
}
.grid-item:hover .caption {
	opacity: 1;
}
.caption h3 {
	color: #0000ff;
    font-size: 1.5vw;
    text-align: center;
    font-weight: 200;
	line-height: 1.375;
}
/*　works詳細　*/
.works_lp_inner {
	width: 900px;
	margin: 0 auto;
	color: #0000ff;
	font-weight: 300;
}
.works_lp_inner h2 {
	font-weight: 200;
}
.works_lp_inner img {
	width: 100%;
}
.feed {
	margin: 2.5% auto 0 auto;
    display: flex;
    justify-content: space-between;
    width: 75%;
}
.feed a {
	color: #0000ff;
}
/*　フッター　*/
footer {
	margin: 0 auto;
}
.top_footer p {
	color: white;
	margin-bottom: -5%;
}
footer p {
	font-size: 0.75em;
    margin: 5% 0;
    text-align: center;
    color: #0000ff;
    padding-bottom: 2.5%;
	line-height: 1.5em;
	letter-spacing: 0.15em;
	font-weight: 300;
}
@media screen and (min-width: 1025px){
.sp_only {
	display: none;
}
.tab_only {
	display: none;
}
}
@media screen and (max-width: 599px){
.pc_only {
	display: none;
}
.tab_only {
	display: none;
}
.caption {
	display: none;
}
html,
body {
	font-weight: 200;
}
/*　ハンバーガーボタン　*/
#gloval-nav {
	background: white;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 990;
    display: flex;
    visibility: hidden;
    text-align: center;
    flex-direction: column;
    letter-spacing: 0.25em;
    opacity: 0;
    transition: opacity 0.6s ease, visibility 0.6s ease;
    font-size: 1.75em;
    line-height: 0.5em;
	width: 100%;
	padding-left: 0;
}
/*　下層ハンバーガーボタン　*/
#gloval-nav_lp {
	background: #0000ff;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 990;
    display: flex;
    visibility: hidden;
    text-align: center;
    flex-direction: column;
    letter-spacing: 0.25em;
    opacity: 0;
    transition: opacity 0.6s ease, visibility 0.6s ease;
    font-size: 1.75em;
    line-height: 0.5em;
    width: 100%;
    padding-left: 0;
}
/*　下層ロゴ　*/
.lp .logo img {
    width: 70vw;
    margin: 5%;
}
/*　コンテンツ領域　*/
content {
	width: 90%;
}
/*　大テキスト　*/
.txt {
    font-size: 6.5vw;
    line-height: 10vw;
}
/*　works　*/
.works_inner {
    grid-template-columns: 1fr;
}
.caption h3 {
    font-size: 5vw;
}
.works_lp_inner {
    width: 100%;
}
.works_lp_inner h2 {
	width: 90%;
	margin: 0 auto;
	line-height: 1.375;
}
.works_lp_inner p {
	width: 90%;
    margin: 0 auto 10% auto;
    font-size: 0.85em;
}
/*　プロフィール　*/
.profile {
	margin-top: 20%;
    margin-bottom: 5%;
    display: flex;
	flex-wrap: wrap;
}
.profile_photo {
	width: 100%;
    margin-top: 5%;
    margin-right: 0;
    order: 1;
}
.profile_photo img {
	width: 100%;
}
.feed {
    width: 90%;
}
}
@media screen and (max-width: 1024px) and (min-width: 600px){
.pc_only {
	display: none;
}
.sp_only {
	display: none;
}
.caption {
	display: none;
}
html,
body {
	font-weight: 200;
}
/*　ハンバーガーボタン　*/
#gloval-nav {
	background: white;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 990;
    display: flex;
    visibility: hidden;
    text-align: center;
    flex-direction: column;
    letter-spacing: 0.25em;
    opacity: 0;
    transition: opacity 0.6s ease, visibility 0.6s ease;
    font-size: 1.75em;
    line-height: 0.5em;
    padding-top: 10%;
	width: 100%;
}
/*　下層ハンバーガーボタン　*/
#gloval-nav_lp {
	background: #0000ff;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 990;
    display: flex;
    visibility: hidden;
    text-align: center;
    flex-direction: column;
    letter-spacing: 0.25em;
    opacity: 0;
    transition: opacity 0.6s ease, visibility 0.6s ease;
    font-size: 1.75em;
    line-height: 0.5em;
    padding-top: 10%;
	width: 100%;
}
/*　下層ロゴ　*/
.lp .logo img {
    width: 70vw;
    margin: 5%;
}
/*　コンテンツ領域　*/
content {
	width: 80%;
}
/* aboutコンテンツ領域 */
.about_inner {
	width: 85%;
	margin: 0 auto;
}
/*　大テキスト　*/
.txt {
    font-size: 4vw;
    line-height: 7.5vw;
}
.works_lp_inner {
    width: 85%;
}
/*　プロフィール　*/
.profile {
	margin-top: 10%;
    margin-bottom: 5%;
    display: flex;
	flex-wrap: wrap;
}
.profile_photo {
	width: 35%;
    margin-top: 5%;
	order: 1;
}
.profile_photo img {
	width: 100%;
}
}
.works_lp_inner a {
	color: #0000ff !important;
}
h1 a {
	color: #0000ff !important;
}
/*　デザイン筋トレ　*/
.bgMuscle {
	background-color: #0000ff;
}
.white {
	color: white;
}
.txtC {
	text-align: center;
}
.bold {
	font-weight: bold;
}
.bgMuscle h1 {
	font-size: 10vw;
	margin-bottom: 5vw;
}
.bgMuscle h1:first-line {
	line-height: 1.5em;
}
.artworkWrap {
    width: 85vw;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
	margin-bottom: 15vw;
}
.artwork {
	width: 100%;
}
.artwork img {
	width: 100%;
}
.muscleTxt {
	font-size: 1.5em;
}
@media screen and (max-width: 1025px){
.bgMuscle h1 {
	font-size: 12vw;
}
}