@charset "utf-8";
/* http://jigsaw.w3.org/css-validator/ */

/* body */

html,body{
	margin: 0;
	padding: 0;
	scroll-behavior: smooth;
	overscroll-behavior: none;
}
:root{
	--basecolor:rgb(0, 82, 147);
	--linecolor:#02112E;
	--textcolor:#02112E;
}


ul li::marker{
	color: var(--basecolor);
}
ul,ol{
	padding:0;
	padding-left: 1.5rem;
}

#container
{
	width: 100%;
	font-family: "Noto Sans JP", sans-serif;
	color: var(--textcolor);
	background-color: #fff;
	word-break: break-all;
	-webkit-text-size-adjust: 100%;
}
:is(#sb_instagram, .sbi_lightbox) a:focus img { opacity: .7 !important }
body:not(.wp-admin) *
{
	font-family: "Noto Sans JP", sans-serif;
    box-sizing: border-box;
	position: relative;
	line-height: 1.8;
}
a{
	transition: 0.3s;
}

body:not(.wp-admin) strong,
body:not(.wp-admin) em
{
	color: #e00;
	font-style: normal;
}

strong strong
{
	border-bottom: 3px #aaa double;
}

u
{
	text-decoration: none;
	background: linear-gradient(transparent 70%, #EAD67980 0);
	border-bottom: 1px solid #EAD67980;
}

img,
iframe,
figure
{
	max-width: 100%;
	display: block;
}
img
{
	height: auto;
	border: none;
}
.nd{
	display: none !important;
}
.skip{
	position: absolute !important;
	left: -9000px;
}
.pc
{
		display: block !important;
}
.sp
{
		display: none !important;
}
.center{
	text-align: center;
}

/* container */
#container {
	width: 100%;
	display: flex;
	flex-wrap: nowrap;
}
#container>*{
	display: block;
	height: 100%;
}
#container>.bgbox{
	z-index: 0;
	width: 100%;
	height: 100dvh;
	position: fixed;
}
.bgbox img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position:top left;
}


#container > #site-header {
	width: 50vw;
	order:1;
}

#container>#menubox{
	width: 13vw;
	min-width: 120px;
	min-height: 640px;
	order:3;
	position: relative;

}
#container>#site-content{
	background: #fff;
	width: 37vw;
	max-width: 480px;
	min-width: 400px;
	order:2;
	box-shadow: 5px 0 10px rgba(0, 0, 0, 0.05), -5px 0 10px rgba(0, 0, 0, 0.05);
	min-height: calc(100vh + 20px);
	margin: -10px 0;
}
header,
#mainmenu{
	display: flex;
	align-items: center;
	flex-direction: column;
	justify-content: space-between;
}
.pageedit{
	clear: both;
	display: block;
}

.snsbt{
	margin: 0 auto;
	width: fit-content;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem 25px;
	justify-content: center;
	align-items: center;
	border-radius: 5px;
}
header .snsbt{
	position: fixed;
	bottom: 2rem;
	left: 4vw;
	background: #fff;
	padding: 1rem;
}
section .snsbt{
	flex-direction: column-reverse;
}
.snsbt span{
	display: flex;
	flex-wrap: nowrap;
	gap: 1rem 25px;
}
.snsbt a:hover{
	opacity: 0.6;
}
 .snsbt img{
	height: 36px;
	max-height: 36px;
}
#site-header .snsbt img{
	max-height: 28px;
}
#mainmenu{
	min-height: 640px !important;
}
#mainmenu h1{
	font-size: 1.6rem;
	position: fixed;
	margin: 0 auto;
	top: 5rem;
	justify-content: center;
	text-align: flex-start;
}
#mainmenu h1 span{
	display: block;
	font-size: 1rem;
}
#mainmenu ul{
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 1rem;
	display: block;
	align-items: center;
	position: fixed;
	bottom: 1rem;
}
#mainmenu ul li {
	display: block;
	margin-top: 0.5rem;
}
#mainmenu ul li a{
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	border-radius: 100px;
	color: #fff;
	text-decoration: none;
	background:rgba(1, 60, 147, 0.8);
	width: 6em;
	height: 6em;
}

#mainmenu ul li a:hover{
	background: rgba(1, 60, 147,  1);
}

#site-content {

}
section,
footer{
	padding: 2rem;
}
section h1{
	border-bottom: 3px solid #005293;
	display: block;
	width: fit-content;
	font-size: 1.2rem;
	margin: 3rem auto;
	padding: 0 0 0.5rem;
	text-align: center;
	font-weight: 900;
}
section .catch{
	text-align: center;
	color: var(--basecolor);
	font-size: 1.9rem;
	margin: 3rem auto;
	font-weight: 900;
}
section .catch span{
	font-size: 1.3rem;
	color: var(--textcolor);
	display: block;
	margin-top: -0.5rem;
}
section .catch span span{
	display: inline-block;
	font-size: 1.1rem;
}
section h2{
	font-size: 1.6rem;
	text-align: center;
	color: var(--basecolor);
	margin: 3rem auto;
	font-weight: 900;
}

section h3{
	text-align: center;
	color: var(--basecolor);
	font-size: 1.4rem;
	margin: 3rem auto 1rem;
}

.youtubebox{
	aspect-ratio: 16/9;
	display: block;
	margin: 1rem auto;
}
.youtubebox iframe{
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
}
details{
	margin: 0 auto 1rem;
}
summary{
	display: flex;
	text-decoration: none;
	padding: 1rem 2rem;
	border-radius: 2rem;
	width: 100%;
	justify-content: space-between;
	align-items: center;
	font-weight: bold;
	color: var(--basecolor);
	background: rgba(0, 82, 147,0.05);
}
summary::after{
	content: url('../images/linkmark.svg');
}
details[open] summary::after{
	transform: rotate(180deg);
}
details img{
	margin: 1rem  1.5rem;
	width: calc(100% - 3rem);
}
#sb_instagram{
	margin-bottom:3rem;
}

/* policy */

.message{
	font-weight: bold;
	font-size: 1.1rem;
	line-height: 2rem;
	margin: 0 auto 3rem;
}
#policy {
	dt,dd{
		margin: 0 auto;
		padding: 0;
	}
	dt{
		font-weight: bold;
		color: #005293;
		font-size: 1.4rem;
		z-index: 2;
		padding-right: 3rem;
	}
	dd{
		margin-bottom: 1rem;
		padding: 0.5rem 0 1rem;
		border-bottom: 1px solid #ccc;
		z-index: 3;
	}
	dt::before{
		content: '';
		position: absolute;
		font-size: 4rem;
		font-family: "Barlow Condensed", serif;
		font-weight: 600;
		line-height: 1;
		color: rgba(0, 82, 147, 0.2);
		right: 0;
		top: -1rem;
		z-index: 1;
	}
	dt:nth-of-type(1)::before{
		content: '1';
	}
	dt:nth-of-type(2)::before{
		content: '2';
	}
	dt:nth-of-type(3)::before{
		content: '3';
	}
	dt:nth-of-type(4)::before{
		content: '4';
	}
	dt:nth-of-type(5)::before{
		content: '5';
	}
	dt:nth-of-type(6)::before{
		content: '6';
	}
	dt:nth-of-type(7)::before{
		content: '7';
	}
	dt:nth-of-type(8)::before{
		content: '8';
	}
	dt:nth-of-type(9)::before{
		content: '9';
	}
}

/* profile */
#profile {
	.catch{
		font-size: 2.1rem;
	}
	.catch+p{
		font-weight: bold;
	}
	table{
		margin: 2rem auto;
		border-collapse: collapse;
		border-bottom: 1px solid var(--linecolor);
	}
	th,td{
		padding: 0.5rem;
		border-top: 1px solid var(--linecolor);;
	}
	th{
		padding: 0.5rem 0.75rem ;
		background: rgba(0, 82, 147,0.05);
		text-align: left;
	}
	dt,dd{
		padding: 0 0 0 1.25em ;
		margin: 0 auto;
	}
	dt{
		font-weight: bold;
	}
	dd{
		padding-bottom: 0.5rem;
	}
	dt::before{
		content: '●';
		position: absolute;
		color: var(--basecolor);
		left: 0;
		top: 0;
		z-index: 5;
	}
	dt::after,dd::after{
		content: '';
		position: absolute;
		left: 0.5em;
		top: 0.5em;
		width: 1px;
		height: 100%;
		z-index: 2;
		background: rgba(2, 17, 46, 0.2);
	}
	dt:last-of-type::after,
	dd:last-of-type::after{
		display: none;
	}
	.download ul,
	.episode ul{
		padding-left: 1rem;
	}
}

#recruit{
	background: rgba(0, 82, 147,0.05);
	margin-bottom: -6rem;
	padding-bottom: 6rem;
	.catch{
		font-size: 1.8rem;
	}
}
#recruit a:hover img{
	opacity: 0.7;

}
#pagetop{
	z-index: 10;
    position: sticky;
	bottom: 2rem;
	padding: 0 2rem;
	margin: 0 auto;
	text-align: right;

}

#pagetop a{
	width: 4rem;
	display: inline-block;
	background:rgba(1, 60, 147, 0.8);
	border-radius: 4rem;
}
#pagetop a:hover{
	background:rgba(1, 60, 147, 1);
}
.fullimg{
	display: block;
	margin: 5rem auto -2rem;
	z-index: 5;
}
#message+.fullimg{
	display: none;
}
.out{
	display: flex;
	gap: 0.5rem;
	align-items: center;
	justify-content: flex-start;
}
.out::after{
	content: url('../images/out.svg');
	transform: translateY(2px);
}

/* footer */
footer {
	text-align: left;
}
footer h2{
	font-size: 3rem;
	margin-bottom: 0;
}
.copyright{
	font-size: 0.8rem;
}
#footmenu{
	margin-left: -0.75rem;}
#footmenu ul{
	list-style: none;
	margin: 1code herem auto;
	padding: 0;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
}
#footmenu li{
	padding: 0 0.75rem ;
}
#footmenu a{
	padding: 0;
}
#footmenu li:first-child{
	border-right: 1px solid #ccc;
}

/* content */

/* for wp */
.aligncenter
{
	display: block;
	margin: 0 auto;
}
.alignleft
{
	text-align: left;
}
.alignright
{
	text-align: right;
}
img.alignleft
{
	float: left;
	margin-right: 1rem;
}
img.alignright
{
	float: right;
	margin-left: 1rem;
}
.gallery-columns-2{
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0 1rem;
	flex-wrap: wrap;
}
.gallery-columns-2>*{
	width: calc((100% - 1rem) / 2);
}
.gallery-icon{
	width: 100%;
	aspect-ratio: 1/1;
	position: absolute;
	border: 1px solid #DEE0E3;
	transition: 0.3s;
}
.gallery-icon:hover{
	background: #F2F6F9;
}
.gallery-icon img{
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	padding: 0.5rem;
}

.ls_h640{
	display: none;
}
.snsbt{
	flex-direction: column-reverse;
}
/* メディアクエリ */

@media all and (max-width: 1000px){
	.bgbox img{
		object-fit:contain;
		object-position: top left;
	}
}

@media (orientation: landscape) and (max-height: 700px) {
	#mainmenu h1 img{
		display: none;
	}
	#mainmenu h1{
		right: 0;
		top: 1rem;
		z-index: 200;
		border-radius: 0 0 0 10px;
		padding: 20px;
		display: block;
		background: rgba(255,255,255,0.9);
		box-shadow: 5px 0 10px rgba(0, 0, 0, 0.05), -5px 0 10px rgba(0, 0, 0, 0.05);
	}
	#mainmenu h1 img.ls_h640{
		display: block;
		max-width: 200px;
	}
}
@media all and (max-width: 860px)
{
	#container > .bgbox{
		width: 100%;
		height: auto;
		min-height: 90px;
		position: relative;
		left: auto;
		top: auto;
	}

	#container > #site-header{
		height: auto;
		position: absolute;
		top: 0;
	}
	header .snsbt{
		position: absolute;
		left: 2rem;
	}
	#container{
		flex-wrap: wrap;
	}
	#container > #site-header{
			width: 100%;
		}
	#container > #site-content{
		width: calc(100vw - 170px);
		max-width: calc(100vw - 170px);
		margin: 0 auto 0 0;
	}
	#container > #menubox{
		width: 170px;
		margin-left: auto;
	}

}
@media all and (max-width: 640px)
{

	#container>#site-content{
		box-shadow: none;
	}
	.pc
	{
		display: none !important;
	}
	.sp
	{
		display: block !important;
	}
	.home #site-header,
	.home .bgbox picture{
		display: block !important;
	}
	#site-header,
	.bgbox picture{
		display: none !important;
	}
	#container > .bgbox{
		width: 100%;
		height: 100dvh;
	}

	.home #container #site-content{
		margin: 0 auto;
	}
	#container #site-content{
		margin: calc(-100dvh + 100px) auto 0;
	}
	#container > *{
		min-height: auto;
	}
	#menubox2{
		position: absolute;
		top: 0;
		width: 100%;
		height: auto;
		background: #fff;
		z-index: 400;
	}
	#menubox2 h1{
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 0 1rem;
		height: 90px;
		margin: 0 auto;
	}
	#ocbt{
		flex-direction: column;
		width: 70px;
		height: 70px;
		background: var(--basecolor);
		color: #fff;
		text-decoration: none;
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 1.5rem;
		font-size: 0.6rem;
		padding: 1.2rem 1rem 1rem;
		border-radius: 4rem;
	}
	#ocbt span.bar,
	#ocbt span::before,
	#ocbt span::after{
		content: '';
		display: block;
		background: #fff;
		width: 30px;
		height: 4px;
		border-radius: 3px;
		transform-origin: center center;
		transition: 0.3s;
	}
	#ocbt em{
		color: #fff;
		margin: 0 -0.5rem;
	}
	#ocbt em:nth-of-type(1){
		display: block;
	}
	#ocbt em:nth-of-type(2){
		display: none;
	}
	.menuopen #ocbt em:nth-of-type(1){
		display: none;
	}
	.menuopen #ocbt em:nth-of-type(2){
		display: block;
	}
	#ocbt span::before{
		margin-top: 11px;
	}
	#ocbt span::after{
		margin-top: 8px;
	}
	#mainmenu_sp{
		display: none;
		width: 100%;
	}
	.menuopen{
		position: fixed;
		top: 0;
	}
	.menuopen #ocbt span{
		background: transparent;
		transform: translateY(5px);
	}
	.menuopen #ocbt span::before{
		transform: rotate(45deg);
		margin-top: 4px;
	}
	.menuopen #ocbt span::after{
		transform: rotate(-45deg);
		margin-top: -4px;
	}
	.menuopen #menubox2{
		height: 100dvh;
		z-index: 300;
		background: #fff;
		position: fixed;
		top: 0;
	}
	.menuopen #mainmenu_sp{
		display: block;
	}
	#mainmenu_sp ul{
		list-style: none;
		margin: 2rem auto;
		padding: 0  1rem;
		background: rgba(0, 82, 147,0.05);
	}
	#mainmenu_sp ul li a{
		border-top: 1px solid #ccc;
		padding: 1rem 1rem 1rem 0;
		color: var(--textcolor);
		text-decoration: none;
		display: flex;
		width: 100%;
		gap: 0.5rem;
		justify-content: flex-start;
		align-items: center;
	}
	#mainmenu_sp ul li a::before{
		content: url('../images/linkmark.svg');
		transform: rotate(-90deg);
	}

	#mainmenu_sp ul li:first-child a{
		border-top: none;
	}
	#mainmenu_sp .snsbt{
		flex-wrap: wrap;
		justify-content: center;
		gap:  1rem;
		padding: 1rem;
		width: 100%;
	}

	#container > #site-content{
		max-width: 100%;
		width: 100%;
		min-width: inherit;
	}
	#container>#site-header{
		height: 167vw;
	}
}

/* block editor */

.tare-sample-classname
{
	background-color: #900;
	color: #fff;
	padding: 20px;
	font-size: 150%;
}

/* #sousaisen2025内でのみ適用される変数 */
#sousaisen2025 {
	--basecolor:rgba(0,30,130,1); /* 例：新しいベースカラー */
	--subcolor:rgba(0,135,205,1);
	--subcolor2:rgba(0,95,180,1);
	--linecolor:#333333; /* 例：新しいラインカラー */
	--textcolor:#333333; /* 例：新しいテキストカラー */
}

#sousaisen2025 .snsbt span{
	display: flex;
	flex-wrap: nowrap;
	gap: 1rem 20px;
}
#sousaisen2025 #site-header .snsbt img{
	max-height: 30px;
}

#sousaisen2025 #container > #site-header{
	height: calc(100dvh);

}
#sousaisen2025 #container >.bgbox,
#sousaisen2025 #container >.bgbox picture {
	height: calc(100dvh);
	max-height: 66vw;
}

#sousaisen2025 #container{
	background: #fff;
}
#sousaisen2025 #mainmenu ul li a,
#sousaisen2025 .pagetop a{
	background: rgba(0,30,130,0.8);
}
#sousaisen2025 #mainmenu ul li a:hover{
	background: var(--basecolor);
}
#sousaisen2025 header img.sousaisenbt{
	display: block !important;
	position: fixed;
	left: 4vw;
	bottom: auto;
	top: 45vw;
}
#sousaisen2025 header .snsbt{
	bottom: auto;
	top: calc(45vw + 80px);
}
@media all and (max-width: 1200px){
	#sousaisen2025 .bgbox img{
		object-fit:cover;
		object-position: top left;
		transform: translateX(-1rem);
	}
	#sousaisen2025 .bgbox{
		width: calc(100% + 1rem);
	}

}

@media all and (max-width: 1000px){
	#sousaisen2025 .bgbox img{
		object-fit:cover;
		object-position: top left;
		transform: translateX(-2rem);
	}
	#sousaisen2025 .bgbox{
		width: calc(100% + 2rem);
	}

}
@media all and (max-width: 860px){

	#sousaisen2025 .bgbox{
		width: calc(100%);
	}
	#sousaisen2025 #container >.bgbox,
	#sousaisen2025 #container >.bgbox picture {
		height: calc(100dvh);
		max-height: 80vw;
	}
	#sousaisen2025 .bgbox img{
		transform: translateX(0);
	}
	#sousaisen2025 header img.sousaisenbt{
		bottom: auto;
		position: absolute;
		top: 60vw;
	}
	#sousaisen2025 header .snsbt{
		bottom: auto;
		top: calc(60vw);
		left: 120px;

	}
}
@media all and (max-width: 640px)
{
	#sousaisen2025 .bgbox img{
		padding-top: 90px;
	}
	#sousaisen2025 #container > #site-header,
	#sousaisen2025 #container >.bgbox,
	#sousaisen2025 #container >.bgbox picture {
		min-height: 640px;
		height: calc(100dvh);
		max-height: 180vw;
	}
	#sousaisen2025 .bgbox img{
		object-fit: cover;
	}
	#sousaisen2025 header img.sousaisenbt{
		top: auto;
		bottom: calc(2rem + 130px);
		left: 2rem;
	}
	#sousaisen2025 header .snsbt{
		top: auto;
		bottom: 2rem;
		position: absolute;
		left :2rem;

	}
	#sousaisen2025 section,
	#sousaisen2025 footer {
		padding: 1.5rem;
	}

}

section .sousaisen_policy h2{
	text-align: left;
	width: 100%;
/*	padding: 2rem 1.5rem 0 0 !important; */
	padding: 2rem 0 0 0 !important;
	min-height:2rem;
	position: relative;
	border-top: 1px solid rgba(2, 17, 46, 0.2);
}
section .sousaisen_policy h2:nth-of-type(1){
	border-top: none
}
section .sousaisen_policy h2::before{
	position: absolute;
    font-family: "Barlow Condensed", serif;
    font-weight: 600;
    line-height: 1;
	color: rgba(0, 95, 180, 0.2);
    right: 0px;
    top: 0;
    z-index: 1;
	opacity: 0.5;
	font-size: 5rem;
}
/*
section .sousaisen_policy h2:nth-of-type(1):before{
	content: '1';
}
section .sousaisen_policy h2:nth-of-type(2):before{
	content: '2';
}
section .sousaisen_policy h2:nth-of-type(3):before{
	content: '3';
}
section .sousaisen_policy h2:nth-of-type(4):before{
	content: '4';
}
section .sousaisen_policy h2:nth-of-type(5):before{
	content: '5';
}
section .sousaisen_policy h2:nth-of-type(6):before{
	content: '6';
}
section .sousaisen_policy h2:nth-of-type(7):before{
	content: '7';
}
section .sousaisen_policy h2:nth-of-type(8):before{
	content: '8';
}
section .sousaisen_policy h2:nth-of-type(9):before{
	content: '9';
}
*/
section .sousaisen_policy h3{
	text-align: left;
}
.sousaisen_policy h2{
	margin-bottom: 0;
}
/*
.sousaisen_policy h2+ul{
	margin: 1rem auto 0;
	padding: 0;
	list-style: none;
}
*/
.sousaisen_policy h2+ol li{
	font-size: 0.9rem;
	margin: 0 auto;
}
section .sousaisen_policy h3{
	font-size: 1.2rem;
}
