@charset "UTF-8";

:root {
	--bg01: #f6f6f6;
	--main01: #6f0fdb;
	--mainL01: #ae7cf4;
	--black: #000;
	--white: #fff;
	--gray01: #aaa;
	--gray02: #666;
	--gray03: #8a8a8a;
}

::-moz-selection {
	background: var(--mainL01);
	color: var(--white);
}

::selection {
	background: var(--mainL01);
	color: var(--white);
}

::-moz-selection {
	background: var(--mainL01);
	color: var(--white);
}

.loading {
	position: fixed;
	width: 100%;
	height: 100vh;
	z-index: 9999;
	top: 0;
	left: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: var(--white);
}

.loading > div {
	position: relative;
	width: 130px;
	height: 130px;
}

.loading .icon {
	animation: rotation-y 2.5s ease infinite;
}

.loading .icon svg {
	fill: var(--gray03);
	width: 130px;
	height: 130px;
}

.loading span {
	text-align: center;
	display: block;
	position: absolute;
	left: 0;
	bottom: -10px;
	font-family: "Poppins", sans-serif;
	font-size: 18px;
	letter-spacing: 0.08em;
	text-align: center;
	color: var(--gray03);
	width: 100%;
}

.l-container {
	position: relative;
	padding-top: 80px;
	padding-bottom: 80px;
	box-sizing: border-box;
}

.l-inner {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	padding-left: 40px;
	padding-right: 40px;
	position: relative;
	box-sizing: border-box;
}

.g-wrapper {
	overflow: hidden;
}

.g-main {
	background: var(--bg01);
	border-radius: 90px;
	border: 30px solid var(--white);
	overflow: hidden;
	box-sizing: border-box;
}

/*ヘッダー*/

.g-header.is-active .g-header__state .trigger span:nth-of-type(1) {
	top: 50%;
	transform: rotate(-45deg);
}

.g-header.is-active .g-header__state .trigger span:nth-of-type(2) {
	bottom: 50%;
	transform: rotate(45deg);
	width: 100%;
}

.g-header.is-active .g-header__panel {
	pointer-events: all;
	opacity: 1;
}

.g-header.is-active .g-header__panel:after {
	opacity: 0.95;
}

.g-header__logo {
	display: none;
}

.g-header__state .text {
	display: none;
}

.g-header__panel {
	width: 270px;
	height: 100%;
	position: fixed;
	left: 0;
	top: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 989;
	background: var(--white);
}

.g-header__panel .scroll {
	width: 100%;
	height: 100%;
	overflow-y: scroll;
	scrollbar-width: none;
	-ms-overflow-style: none;
}

.g-header__panel .scroll::-webkit-scrollbar {
	display: none;
}

.g-header__panel .inner {
	padding-top: 130px;
	padding-left: 30px;
	box-sizing: border-box;
	width: 100%;
}

.g-header__panel .name {
	font-size: 28px;
	font-weight: bold;
	margin-bottom: 30px;
	line-height: 1.4;
	font-family: "Poppins", sans-serif;
}

.g-header__panel .name span {
	display: block;
	font-size: 10px;
}

.g-header__panel .name a {
	transition: 0.3s;
	text-decoration: none !important;
}

.g-header__panel .navi {
	position: relative;
	box-sizing: border-box;
	margin-bottom: 30px;
	padding: 35px 0;
}

.g-header__panel .navi:after,
.g-header__panel .navi:before {
	content: "";
	width: 30px;
	height: 1px;
	background: var(--gray01);
	position: absolute;
	left: 0;
}

.g-header__panel .navi:before {
	top: 0;
}

.g-header__panel .navi:after {
	bottom: 0;
}

.g-header__panel .navi__item {
	margin-bottom: 25px;
}

.g-header__panel .navi__item:last-child {
	margin-bottom: 0;
}

.g-header__panel .navi__item a {
	transition: 0.3s;
	font-weight: bold;
	font-size: 16px;
	letter-spacing: 0.05em;
	text-decoration: none !important;
}

.g-header__panel .c-sns {
	margin-bottom: 30px;
}

.g-header__panel .c-schedule {
	margin-bottom: 30px;
	padding-top: 15px;
}

.g-header__panel .c-schedule .c-schedule__title {
	font-size: 14px;
	margin-bottom: 15px;
}

.g-header__panel .c-schedule .c-schedule__title span {
	font-size: 10px;
}

.g-header__panel .c-schedule .c-schedule__table dt {
	font-size: 12px;
	padding: 10px 5px;
}

.g-header__panel .c-schedule .c-schedule__table dd {
	font-size: 14px;
	padding: 10px 5px;
}

.g-header__panel .c-schedule .c-schedule__table dd span {
	font-size: 12px;
}

/*フッター*/

.g-footer {
	box-sizing: border-box;
	padding-top: 40px;
	padding-bottom: 40px;
	font-size: 12px;
	line-height: 1.6;
	color: var(--gray03);
}

.g-footer .l-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.g-footer .copy {
	font-family: "Poppins", sans-serif;
}

.c-sns {
	display: flex;
}

.c-sns li {
	margin-right: 18px;
}

.c-sns li:last-child {
	margin-right: 0;
}

.c-sns li a {
	display: inline-block;
}

.c-sns li svg {
	width: 25px;
	height: 25px;
	fill: var(--gray02);
	transition: 0.3s;
}

.c-schedule {
	box-sizing: border-box;
	background: rgba(0, 0, 0, 0.05);
	padding: 20px 10px 10px;
	box-sizing: border-box;
	border-radius: 5px;
}

.c-schedule__title {
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 20px;
}

.c-schedule__title span {
	margin-left: 5px;
	font-size: 14px;
}

.c-schedule__table > div {
	display: flex;
	justify-content: space-between;
	width: 100%;
	text-align: center;
	margin-bottom: 2px;
}

.c-schedule__table > div.__end {
	opacity: 0.55;
}

.c-schedule__table dt {
	background: var(--white);
	width: 45%;
	margin-right: 2px;
	padding: 15px 5px;
	box-sizing: border-box;
	font-size: 16px;
}

.c-schedule__table dd {
	background: var(--white);
	width: 55%;
	padding: 15px 5px;
	box-sizing: border-box;
	font-size: 18px;
	font-weight: bold;
}

.c-schedule__table dd span {
	font-size: 14px;
	margin-left: 5px;
}

.c-schedule .update {
	font-size: 75%;
	text-align: right;
	margin-top: 12px;
	padding-bottom: 3px;
	opacity: 0.6;
}

.c-headline01 {
	line-height: 1;
	margin-bottom: 60px;
	position: relative;
	display: flex;
	align-items: center;
	padding: 10px 0;
	box-sizing: border-box;
}

.c-headline01:after {
	content: "";
	width: 8px;
	height: 100%;
	position: absolute;
	left: -40px;
	top: 0;
	z-index: 1;
	background: var(--black);
}

.c-headline01 .s01 {
	order: 2;
	font-weight: bold;
	letter-spacing: 0.05em;
	padding-top: 10px;
	margin-left: 25px;
	font-size: 18px;
	color: var(--gray02);
}

.c-headline01 .s02 {
	order: 1;
	font-weight: normal;
	letter-spacing: 0.03em;
	font-size: 60px;
	font-family: "Poppins", sans-serif;
	color: var(--black);
}

.c-headline02 span {
	font-size: 18px;
	font-weight: bold;
	position: relative;
	display: inline-block;
	letter-spacing: 0.03em;
	padding-left: 25px;
}

.c-headline02 span:after {
	content: "";
	width: 14px;
	height: 14px;
	border-radius: 9999px;
	box-sizing: border-box;
	border: 4px solid var(--black);
	position: absolute;
	left: 0;
	top: 4px;
}

.c-headline03 {
	font-size: 32px;
	font-weight: bold;
	line-height: 1.6;
	letter-spacing: 0.07em;
	margin-bottom: 40px;
	margin-top: -40px;
	padding-top: 40px;
	padding-bottom: 30px;
	color: var(--black);
	position: relative;
}

.c-headline03:before {
	content: "";
	width: 30px;
	height: 1px;
	background: var(--gray01);
	position: absolute;
	left: 0;
	bottom: 0;
}

.c-button01 {
	font-weight: bold;
	display: flex;
	justify-content: center;
	align-items: center;
	text-decoration: none;
	margin: 0 auto;
	width: 100%;
	height: 80px;
	letter-spacing: 0.05em;
	font-size: 20px;
	padding: 0 35px;
	box-sizing: border-box;
	border: 1px solid var(--gray01);
	position: relative;
	z-index: 1;
	transition: 0.5s;
	border-radius: 90px;
	word-wrap: break-word;
	word-break: break-all;
}

.c-button01.__email {
	font-family: "Poppins", sans-serif;
	padding: 0;
}

.c-button01.__email:after {
	display: none;
}

.c-button01.__en {
	font-family: "Poppins", sans-serif;
}

.c-button01:after {
	content: "";
	position: absolute;
	right: 30px;
	top: 50%;
	margin-top: -5px;
	width: 8px;
	height: 8px;
	transform: rotate(-135deg);
	border-left: 2px solid var(--black);
	border-bottom: 2px solid var(--black);
	transition: 0.5s;
}

.c-text01 p {
	margin-bottom: 25px;
	line-height: 1.8;
	letter-spacing: 0.05em;
}

.c-text01 p:last-child {
	margin-bottom: 0;
}

.c-link01 {
	font-weight: bold;
	color: var(--main01);
	text-decoration: underline;
}

.p-gallery__category {
	width: 100%;
	margin-bottom: 60px;
	box-sizing: border-box;
}

.p-gallery__category .c-headline02 {
	font-family: "Poppins", sans-serif;
	width: 190px;
}

.p-gallery__category .c-headline02 span {
	font-size: 22px;
}

.p-gallery__category .box {
	width: 100%;
	display: flex;
	justify-content: space-between;
	margin-bottom: 25px;
}

.p-gallery__category ul {
	width: calc(100% - 190px);
	display: flex;
	flex-wrap: wrap;
}

.p-gallery__category ul li {
	line-height: 1;
	font-size: 17px;
	margin-right: 28px;
	margin-bottom: 10px;
}

.p-gallery__category ul li a {
	letter-spacing: 0.03em;
}

.p-gallery__category ul li a:before {
	font-family: "Poppins", sans-serif;
	content: "#";
	font-weight: normal;
	opacity: 0.5;
}

.p-gallery__category ul li.is-active a {
	color: var(--main01);
}

.p-gallery__list {
	display: flex;
	flex-wrap: wrap;
	box-sizing: border-box;
	margin-right: -2%;
}

.p-gallery__list li {
	width: 31.3%;
	margin-right: 2%;
	margin-bottom: 20px;
}

.p-gallery__list li a {
	overflow: hidden;
	display: block;
	position: relative;
	box-shadow: 4px 4px 10px 0px rgba(0, 0, 0, 0.15);
}

.p-gallery__list li img {
	opacity: 1 !important;
	transform: scale(1);
	transition: 0.5s;
	width: 100%;
	max-width: none;
	display: block;
}

.p-contact .c-button01 {
	margin: 35px 0;
}

/* pagenavi */

.wp-pagenavi {
	margin-top: 30px;
	clear: both;
	text-align: center;
}

.wp-pagenavi a,
.wp-pagenavi span {
	font-size: 16px;
	width: 40px;
	height: 40px;
	padding-top: 2px;
	box-sizing: border-box;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	font-family: "Poppins", sans-serif;
	text-decoration: none;
	margin: 0 4px;
	transition: 0.5s;
	border-radius: 9999px;
	border: 1px solid #cacaca;
}

.wp-pagenavi a:hover,
.wp-pagenavi span.current {
	color: var(--main01);
}

.post_text {
	overflow: hidden;
	padding-bottom: 30px;
}

.post_text p {
	margin-bottom: 20px;
	line-height: 1.8;
}

.post_text img {
	max-width: 100%;
	height: auto;
}

.post_text img.alignright {
	float: right;
	margin: 0 0 15px 15px;
	display: block;
}

.post_text img.alignleft {
	float: left;
	margin: 0 15px 15px 0;
	display: block;
}

.post_text img.aligncenter {
	display: block;
	margin: 0 auto 15px;
}

.post_text h1,
.post_text h2 {
	font-size: 20px;
	font-weight: bold;
	position: relative;
	display: inline-block;
	padding-left: 25px;
	margin: 30px 0 15px;
}

.post_text h1:after,
.post_text h2:after {
	content: "";
	width: 14px;
	height: 14px;
	border-radius: 9999px;
	box-sizing: border-box;
	border: 4px solid var(--black);
	position: absolute;
	left: 0;
	top: 3px;
}

.post_text td {
	padding: 10px;
	border: 1px solid;
}

.post_text table {
	margin-bottom: 25px;
}

.post_text ul,
.post_text ol {
	padding-left: 1.3em;
	margin-bottom: 25px;
}

.post_text li {
	list-style-type: inherit;
}

.post_text ul li {
	margin-bottom: 10px;
	line-height: 1.4;
}

.post_text ol li {
	margin-bottom: 10px;
	line-height: 1.4;
}

.post_text a {
	text-decoration: underline;
	color: var(--main01);
}

.post_text a[target=_blank] {
	position: relative;
	padding-right: 19px;
	display: inline-block;
}

.post_text a[target=_blank]:after {
	content: "";
	position: absolute;
	right: 0;
	top: 8px;
	width: 12px;
	height: 12px;
	background: url(../img/cmn/window.png) no-repeat center center;
	background-size: 100%;
}

.post_text .movie {
	position: relative;
	width: 100%;
	padding-bottom: 54.5%;
}

.post_text .movie video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/*----------------------------------------

top

-----------------------------------------*/

.q-top-mv {
	width: 100%;
	height: 100vh;
	min-height: 600px;
	margin: 0 auto 60px;
	position: relative;
	z-index: 1;
	overflow: hidden;
}

.q-top-mv__visual {
	margin: 0 auto;
	max-width: 800px;
	width: 100%;
	height: 100%;
	position: relative;
	z-index: 10;
}

.q-top-mv__visual > div {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	overflow: hidden;
}

.q-top-mv__visual video {
	position: absolute;
	top: 50%;
	left: 50%;
	-o-object-fit: cover;
	object-fit: cover;
	transform: translate(-50%, -50%);
	width: 100%;
	height: 100%;
}

.q-top-mv__catch {
	position: absolute;
	right: 0;
	bottom: 8vh;
	z-index: 20;
	text-align: right;
	border-right: 10px solid var(--white);
	padding-right: 15px;
	color: var(--white);
}

.q-top-mv__catch .strong {
	font-family: "Poppins", sans-serif;
	font-size: 50px;
	display: block;
	line-height: 1.3;
	margin-bottom: 18px;
	letter-spacing: 0.05em;
	text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.3);
}

.q-top-mv__catch .small {
	font-size: 16px;
	font-weight: bold;
	display: block;
	line-height: 1.6;
	letter-spacing: 0.1em;
	text-shadow: 0px 0px 15px rgba(0, 0, 0, 0.8);
}

.q-top-gallery {
	overflow: hidden;
}

.q-top-gallery .more {
	margin-top: 30px;
}

.q-top-profile {
	overflow: hidden;
}

.q-top-profile .q-top-profile__box {
	z-index: 1;
	position: relative;
	width: 100%;
}

.q-top-profile .flex01 {
	display: flex;
	width: 100%;
	margin-bottom: 40px;
	padding-bottom: 25px;
	border-bottom: 1px solid var(--gray01);
}

.q-top-profile .flex01__name {
	margin-right: 40px;
}

.q-top-profile .flex01__name .name {
	line-height: 1.8;
	font-size: 36px;
	font-family: "Poppins", sans-serif;
	letter-spacing: 0.05em;
	font-weight: bold;
}

.q-top-profile .flex01__text p {
	margin-bottom: 10px;
}

.q-top-profile .flex02__box {
	width: 100%;
	margin-bottom: 30px;
	display: flex;
	justify-content: space-between;
}

.q-top-profile .flex02__box:last-child {
	margin-bottom: 0;
}

.q-top-profile .flex02__box .c-headline02 {
	width: 140px;
	margin-top: 2px;
}

.q-top-profile .flex02__box .content {
	width: calc(100% - 140px);
	margin-top: 5px;
}

.q-top-profile .flex02__box .content div {
	margin-bottom: 25px;
}

.q-top-profile .flex02__box .content div:last-child {
	margin-bottom: 0;
}

.q-top-profile .flex02__box .content div dt {
	font-weight: bold;
	font-size: 20px;
	font-family: "Poppins", sans-serif;
	margin-bottom: 10px;
	color: var(--gray02);
}

.q-top-profile .flex02__box .content div dd {
	line-height: 1.8;
	letter-spacing: 0.05em;
	font-size: 14px;
}

/*----------------------------------------

work

-----------------------------------------*/

.q-gallery-archive .c-headline03 {
	font-family: "Poppins", sans-serif;
}

.q-gallery-single .post_text {
	margin-top: 50px;
}

.q-gallery-single__picture {
	text-align: center;
	width: 100%;
}

.q-gallery-single__picture img {
	margin: 0 auto;
	display: block;
}

.q-gallery-single__head {
	margin-top: -20px;
	margin-bottom: 50px;
}

.q-gallery-single__head .headline {
	font-size: 28px;
	font-weight: bold;
	line-height: 1.6;
	word-wrap: break-word;
}

.q-gallery-single__head .category {
	margin-bottom: 10px;
}

.q-gallery-single__head .category li {
	margin-right: 10px;
	font-family: "Poppins", sans-serif;
	font-size: 18px;
	display: inline-block;
	color: var(--gray02);
}

.q-gallery-single__head .category li:before {
	content: "#";
	font-weight: normal;
}

.q-gallery-single__back {
	margin-top: 50px;
}

.q-gallery-single__back .c-button01 {
	font-size: 16px;
	max-width: 300px;
}

/*----------------------------------------

request

-----------------------------------------*/

.q-request__anchor {
	display: flex;
	width: 100%;
	margin: 80px auto 80px;
	flex-wrap: wrap;
}

.q-request__anchor li {
	margin-right: 30px;
	margin-bottom: 22px;
}

.q-request__anchor a {
	width: 100%;
	display: flex;
	align-items: center;
	position: relative;
	font-weight: bold;
	box-sizing: border-box;
	font-size: 17px;
	letter-spacing: 0.05em;
	transition: 0.5s;
	padding: 0 30px 20px 5px;
	border-bottom: 1px solid var(--gray01);
}

.q-request__anchor a:after {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	margin-top: -15px;
	width: 8px;
	height: 8px;
	transform: rotate(-45deg);
	border-left: 2px solid var(--black);
	border-bottom: 2px solid var(--black);
	transition: 0.5s;
}

.q-request__contact {
	margin-bottom: 100px;
}

.q-request__contact .c-schedule {
	margin: 0 0 70px;
}

.q-request__contact .c-button01 {
	margin: 35px 0 45px;
}

.q-request__price {
	margin-bottom: 100px;
}

.q-request__price .c-text01 {
	margin-bottom: 30px;
}

.q-request__price table {
	width: 100%;
	table-layout: fixed;
	border-right: 1px solid var(--gray01);
}

.q-request__price table:first-child {
	border-top: 1px solid var(--gray01);
}

.q-request__price table tr {
	border-bottom: 1px solid var(--gray01);
}

.q-request__price table .col01 {
	width: 20%;
	background: var(--gray02);
	color: var(--white);
}

.q-request__price table .col02 {
	width: 35%;
}

.q-request__price table .col03 {
	width: 45%;
}

.q-request__price table th {
	border-right: 1px solid var(--gray01);
	vertical-align: middle;
	padding: 15px;
	line-height: 1.6;
	box-sizing: border-box;
	font-weight: bold;
}

.q-request__price table th span {
	font-weight: normal;
	font-size: 11px;
	display: block;
}

.q-request__price table td {
	vertical-align: middle;
	padding: 15px;
	line-height: 1.6;
	box-sizing: border-box;
}

.q-request__flow ol {
	width: 100%;
	margin: 0 auto;
}

.q-request__flow ol li {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	margin-bottom: 50px;
	line-height: 1.6;
}

.q-request__flow ol li .headline {
	margin-bottom: 15px;
	font-weight: bold;
	font-size: 20px;
}

.q-request__flow ol li .headline > span {
	margin-right: 25px;
	font-weight: bold;
	font-family: "Poppins", sans-serif;
	display: inline-block;
	color: var(--gray02);
}

.q-request__flow ol li .box {
	padding-left: 95px;
	box-sizing: border-box;
}

.q-request__flow ol li .box .small {
	margin-top: 10px;
	display: block;
	font-size: 14px;
	line-height: 1.4;
}

.q-request__flow ol li .c-button01 {
	margin-top: 25px;
	line-height: 1.4;
	width: calc(100% - 95px);
	margin-right: 0;
	margin-left: auto;
}

.q-request__flow ol li:last-child {
	margin-bottom: 0;
}

@media (max-width: 1080px) {

.p-gallery__list {
	margin-right: 0;
	width: 100%;
	justify-content: space-between;
}

.p-gallery__list li {
	width: 48.25%;
	margin-right: 0;
}

}

@media (max-width: 960px) {

.post_text img {
	float: none;
	margin: 0 auto;
	display: block;
}

.post_text img.emoji {
	display: inline !important;
}

.post_text table {
	width: 100% !important;
}

}

@media (max-width: 768px) {

.l-inner {
	padding-left: 20px;
	padding-right: 20px;
}

.g-main {
	margin-top: 25px;
	border-width: 20px;
	border-radius: 45px;
}

.g-header__logo {
	position: fixed;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 990;
	left: 12px;
	top: 10px;
	width: 70px;
	height: 70px;
}

.g-header__logo svg {
	transition: 0.5s;
	fill: var(--black);
	width: 70px;
	height: 70px;
}

.g-header__state {
	width: 70px;
	height: 70px;
	position: fixed;
	right: 0;
	top: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	cursor: pointer;
	box-sizing: border-box;
	z-index: 990;
	border-radius: 0 0 0 45px;
	padding: 0 0 7px 7px;
	background: var(--black);
}

.g-header__state .trigger {
	position: relative;
	width: 35px;
	height: 13px;
}

.g-header__state .trigger span {
	position: absolute;
	right: 0;
	height: 2px;
	background-color: var(--white);
	margin-top: -2px;
	transform-origin: center center;
	transition: 0.5s;
}

.g-header__state .trigger span:nth-of-type(1) {
	top: 0%;
	width: 100%;
}

.g-header__state .trigger span:nth-of-type(2) {
	bottom: 0%;
	width: 80%;
}

.g-header__panel {
	width: 100%;
	opacity: 0;
	pointer-events: none;
	transition: 0.5s;
}

.g-header__panel .inner {
	padding-top: 100px;
	padding-right: 30px;
	text-align: center;
}

.g-header__panel .navi:after,
.g-header__panel .navi:before {
	margin: 0 auto;
	left: 0;
	right: 0;
}

.g-header__panel .c-sns {
	justify-content: center;
}

.g-footer {
	padding-top: 0;
}

.g-footer .l-inner {
	flex-direction: column;
	justify-content: center;
	text-align: center;
}

.g-footer .copy {
	text-align: center;
}

.g-footer .caution {
	margin-bottom: 10px;
}

.u-pc {
	display: none !important;
}

.c-sns li {
	margin-right: 32px;
}

.c-headline01 {
	margin-bottom: 40px;
}

.c-headline01:after {
	left: -20px;
	width: 6px;
}

.c-headline01 .s01 {
	font-size: 14px;
	margin-left: 12px;
	letter-spacing: 0.03em;
}

.c-headline01 .s02 {
	font-size: 40px;
}

.c-headline03 {
	margin-top: -100px;
	padding-top: 100px;
	font-size: 28px;
}

.c-button01.__email {
	font-size: 17px;
}

.c-button01 {
	font-size: 18px;
	height: 70px;
}

.c-button01:after {
	margin-top: -6px;
}

.p-gallery__category .c-headline02 {
	width: 100%;
	margin-bottom: 15px;
}

.p-gallery__category .box {
	flex-direction: column;
}

.p-gallery__category ul {
	width: 100%;
}

.p-gallery__category ul li a:before {
	font-size: 22px;
}

.p-gallery__list li {
	width: 100%;
	margin-bottom: 30px;
}

.wp-pagenavi a,
.wp-pagenavi span {
	width: 50px;
	height: 50px;
}

.q-top-mv {
	height: 85vh;
	min-height: 0;
	padding-top: 10px;
	margin-bottom: 0;
}

.q-top-mv__catch {
	bottom: 30px;
	border-right-width: 7px;
	padding-right: 8px;
}

.q-top-mv__catch .strong {
	font-size: 40px;
}

.q-top-mv__catch .small {
	font-size: 12px;
}

.q-top-profile .flex01 {
	flex-direction: column;
}

.q-top-profile .flex01__name {
	margin-right: 0;
}

.q-top-profile .flex01__name .name {
	font-size: 30px;
}

.q-top-profile .flex02__box {
	flex-direction: column;
}

.q-top-profile .flex02__box .c-headline02 {
	width: 100%;
	margin-bottom: 20px;
}

.q-top-profile .flex02__box .content {
	width: 100%;
	line-height: 1.6;
	font-size: 14px;
}

.q-gallery-single__head {
	margin-bottom: 30px;
}

.q-gallery-single__head .headline {
	font-size: 22px;
}

.q-request__anchor {
	margin-top: 60px;
	flex-wrap: nowrap;
	flex-direction: column;
}

.q-request__anchor li {
	margin-right: 0;
	width: 100%;
}

.q-request__anchor a:after {
	width: 8px;
	height: 8px;
}

.q-request__price table {
	border: none;
	margin-bottom: 30px;
}

.q-request__price table tr {
	display: flex;
	flex-wrap: wrap;
}

.q-request__price table .col01 {
	display: block;
	width: 100%;
}

.q-request__price table .col02 {
	display: block;
	width: 40%;
}

.q-request__price table .col03 {
	display: block;
	width: 60%;
}

.q-request__flow ol li .c-button01 {
	width: 100%;
	margin-left: 0;
	margin-right: 0;
	margin-top: 30px !important;
}

}

@media not all and (max-width: 768px) {

.g-main {
	width: calc(100% - 270px);
	margin-left: auto;
}

.g-header__panel .name a:hover {
	color: var(--main01);
}

.g-header__panel .navi__item a:hover {
	color: var(--main01);
}

.u-sp {
	display: none !important;
}

.c-sns li svg:hover {
	fill: var(--main01);
}

.c-button01:hover {
	color: var(--main01);
	border-color: var(--main01);
}

.c-button01:hover:after {
	border-color: var(--main01);
}

.p-gallery__category ul li a:hover {
	color: var(--main01);
}

.p-gallery__list li a:hover img {
	transform: scale(1.2);
}

.q-request__anchor a:hover {
	color: var(--main01);
	border-color: var(--main01);
}

.q-request__anchor a:hover:after {
	border-color: var(--main01);
}

}

@keyframes rotation-y {

0% {
	transform: rotateY(0deg);
}

100% {
	transform: rotateY(360deg);
}

}

