@charset "utf-8";
/*-----------------------------------------------------

  BASE

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

body {
	width: 100%;
	text-align: left;
	font-size: 14px;
	line-height: 1.7;
	color: #000;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	-webkit-font-feature-settings: "palt";
	font-feature-settings: "palt";
	letter-spacing: 0.05em;
}

body::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	background: #fff;
	z-index: 99999999;
	animation: loading2 0.8s ease forwards;
	animation-delay: .4s;
}

@keyframes loading2 {
	0% {
		opacity: 1;
		z-index: 99999999;
	}

	99% {
		opacity: 0;
		z-index: 99999999;
	}

	100% {
		opacity: 0;
		z-index: -100;
	}
}

img {
	vertical-align: bottom;
	max-width: 100%;
	height: auto;
	width: auto;
}

* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	transition: .15s;
}

/* ==================
   ここから追加 ↓
================== */

body {
	font-family: 'Zen Kaku Gothic Antique', 'Kozuka Gothic Pro', sans-serif;
	letter-spacing: .1em;
	background-color: #F2F2F2;
}

.wrapper {
	overflow: clip;
}

content {
	position: relative;
}

content > div {
	padding: 0 10%;
	display: block;
	max-width: 1600px;
	margin: 0 auto;
	width: 100%;
}

@media screen and (max-width:1100px) {
	content > div {
		padding: 0 9%;
	}
}

@media screen and (max-width: 640px) {
	content > div {
		padding: 0 8%;
	}

	body {
		font-size: 13px;
	}
}


/* ==================
   HEADER
================== */
header {
	position: fixed;
	width: 100%;
	z-index: 999999;
}

.sp_nav {
	display: none;
}

.header-box {
	position: relative;
	margin: 20px 23px;
}

.header-logo {
	color: #A3A3A3;
}

.pc_nav {
	position: absolute;
	top: 10px;
	right: 0;
}

.pc_nav li {
	writing-mode: vertical-rl;
	margin-bottom: 30px;
}

@media screen and (max-width: 768px) {
	.pc_nav {
		display: none;
	}

	/* --- SP HEADER --- */
	.sp_nav {
		display: block;
	}

	/* icon */
	.hamburger {
		position: absolute;
		right: 0px;
		top: 6px;
		width: 23px;
		height: 40px;
		cursor: pointer;
		z-index: 300;
	}

	.hamburger__line {
		position: absolute;
		width: 23px;
		height: 2px;
		right: 0;
		background-color: #000;
		transition: all 0.5s;
	}

	.hamburger__line--1 {
		top: 1px;
	}

	.hamburger__line--2 {
		top: 9px;
	}

	.hamburger__line--3 {
		top: 18px;
	}

	/* icon click */
	.open .hamburger__line--1 {
		transform: rotate(-45deg);
		top: 11px;
	}

	.open .hamburger__line--2 {
		opacity: 0;
	}

	.open .hamburger__line--3 {
		transform: rotate(45deg);
		top: 11px;
	}

	/* sp-nav */
	.sp-nav {
		position: fixed;
		right: -240px;
		top: 0;
		width: 240px;
		height: 100vh;
		background-color: #fff;
		transition: all 0.5s;
		z-index: 200;
		overflow-y: auto;
	}

	.open .sp-nav {
		right: 0;
	}

	.nav-wrapper .sp-nav > ul {
		padding: 80px 35px;
	}

	.sp-nav a {
		padding: 10px 0;
		width: 100%;
		display: block;
		font-size: 15px;
	}

	.side-menu-sp a {
		padding: 9px 0px;
		padding-left: 25px;
		position: relative;
		margin-left: 1px;
	}

	.side-menu-sp a::before {
		content: "";
		width: 13px;
		height: 0.1em;
		background: #c1c1c1;
		position: absolute;
		top: 50%;
		left: 0%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
	}

	.home .side-menu-sp a.top::before {
		background: #000000;
	}

	.category-web .side-menu-sp a.web::before {
		background: #000000;
	}

	.category-banner .side-menu-sp a.banner::before {
		background: #000000;
	}

	.category-logo .side-menu-sp a.identity::before {
		background: #000000;
	}

	.category-flyer_dm .side-menu-sp a.flyer_dm::before {
		background: #000000;
	}

	.category-other .side-menu-sp a.other::before {
		background: #000000;
	}

	/* black-bg */
	.black-bg {
		position: fixed;
		left: 0;
		top: 0;
		width: 100vw;
		height: 100vh;
		z-index: 5;
		background-color: #000;
		opacity: 0;
		visibility: hidden;
		transition: all 0.5s;
		cursor: pointer;
		z-index: 100;
	}

	.open .black-bg {
		opacity: 0.55;
		visibility: visible;
	}
}

@media screen and (max-width:460px) {
	.hamburger {
		top: 1px;
	}

	.header-box {
		margin: 20px 6%;
	}

	.nav-wrapper .sp-nav > ul {
		padding: 75px 25px;
	}
}

/* safariハック */
_:lang(x) + _:-webkit-full-screen-document,
.pc_nav {
	right: 23px;
}

/* ==================
   PAGETOP
================== */
#page-top {
	bottom: 0;
	padding: 0px;
	max-width: unset;
	margin: unset;
	width: 96%;
	display: flex;
	position: absolute;
	right: 30px;
	height: 100%;
	align-items: flex-end;
	z-index: 999;
	display: flex;
	justify-content: flex-end;
	pointer-events: none;
}

#page-top .topgo {
	bottom: 0;
	position: sticky;
	right: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-bottom: 50px;
	pointer-events: all;
}

#page-top .topgo img {
	width: 27px;
	margin-bottom: 5px;
}

#page-top .topgo p {
	font-size: 14px;
}

@media screen and (max-width:1100px) {
	#page-top {
		right: 25px;
	}

	#page-top .topgo p {
		font-size: 12px;
	}

	#page-top .topgo img {
		width: 26px;
		margin-bottom: 4px;
	}
}

@media screen and (max-width:460px) {
	#page-top .topgo p {
		color: #fff;
		font-size: 11px;
	}

	#page-top {
		width: 100%;
		padding-right: 0px;
		right: 20px;
	}

	#page-top .topgo {
		background: #000;
		width: 56px;
		height: 56px;
		justify-content: center;
		margin-bottom: 20px;
		padding-bottom: 2px;
		bottom: 20px;
	}

	#page-top .topgo img {
		-webkit-filter: brightness(0) invert(1);
		filter: brightness(0) invert(1);
	}

	#page-top .topgo img {
		width: 20px;
		margin-bottom: 2px;
		margin-top: 4px;
	}
}

/* safariハック */
_:lang(x) + _:-webkit-full-screen-document,
#page-top {
	position: -webkit-sticky;
	position: sticky;
}

_:lang(x) + _:-webkit-full-screen-document,
#page-top .topgo {
	padding-bottom: 50px;
}


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

	_:lang(x) + _:-webkit-full-screen-document,
	#page-top {
		padding-right: 20px;
	}

	_:lang(x) + _:-webkit-full-screen-document,
	#page-top .topgo {
		padding-bottom: 4px;
	}
}

/* ==================
   FOOTER
================== */
footer .footer-box {
	background-color: #fff;
	height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
}

footer .footer-box p {
	text-align: center;
	font-size: clamp(11px, 3.2vw, 18px);
	letter-spacing: 0.2em;
}

@media screen and (max-width:460px) {
	footer .footer-box {
		height: 150px;
	}

	footer .footer-box p {
		padding-bottom: 6px;
	}
}

/* ==================
   アニメーション
================== */
/* その場で */
.fadeIn {
	animation-name: fadeInAnime;
	animation-duration: 2s;
	animation-fill-mode: forwards;
	opacity: 0;
	animation-delay: 0.08s;
}

@keyframes fadeInAnime {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

.fadeInTrigger {
	opacity: 0;
}


/* single.php スリック最後のdiv非表示 */
.single .slick-initialized .slick-track > div:last-child {
	display: none！important;
}

/* 自動で入ってるcdpを非表示 */
#cdp-copy-loader-overlay,
#cdp-copy-alert-success,
#cdp-copy-modal-global,
.cdp-modal-content,
.cdp-text-overlay {
	display: none！important;
	position: fixed;
	opacity: 0;
}

.cdp-text-overlay h1,
.cdp-text-overlay p,
.cdp-text-overlay span {
	display: none！important;
	position: fixed;
	opacity: 0;
}