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

/*==============================*/
/* フォント設定 */
/*==============================*/
html { font-family: "Noto Sans JP","メイリオ", "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HiraKakuPro-W3", "Verdana", "Arial", "Helvetica", "ＭＳ Ｐゴシック", "MS PGothic", "Osaka", sans-serif; margin: 0; padding: 0; overflow-y: scroll; color: #46403B; }

@media(min-width: 768px){ html *{ font-size: 16px; line-height: 1.8em; font-weight: 500; letter-spacing: -0.02em; } }
@media(max-width: 767px){ html *{ font-size: 15px; line-height: 1.618em; } }

body{
	background: #F6F6F6;
}


/*==============================*/
/* フォーム ブラウザ設定 */
/*==============================*/
input[type="submit"],
button,
select {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	color: #000;
}
select {
  line-height: 2;
  color: #333;
  box-shadow: none;
  padding: 0 24px 0 8px;
  background: #fff url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M5%206l5%205%205-5%202%201-7%207-7-7%202-1z%22%20fill%3D%22%23555%22%2F%3E%3C%2Fsvg%3E) no-repeat right 5px top 55%;
  background-size: 16px 16px;
  cursor: pointer;
}


/*==============================*/
/* フォームタグ共通設定 */
/*==============================*/
input[type="text"],
input[type="tel"],
input[type="password"],
select,
textarea{ min-height: 2.5em;}

input[type="text"],
input[type="tel"],
input[type="password"],
input[type="date"],
select,
textarea{
	color: #444;
	border-radius: 3px;
	border: 1px solid #ccc;
	max-width: 100%;
}

input[type="radio"],
input[type="checkbox"]{ 
	position: relative; top: 1px;
	margin-right: 6px;
}

label:has(input:disabled),
input:disabled + label {
  opacity: 0.4;
  cursor: normal;
}


/*  */
[type="text"] {
	width: 100%;
	padding: 6px 8px 5px 8px;
}

/*  */
input[type="password"] {
	width: 100%;
	padding: 7px 8px 5px 8px;
}

/*  */
input[type="tel"] {
	width: 100%!important;
	padding: 4px 10px 2px 10px;
}

/*  */
select { min-height: 2.5em;}

/*  */
textarea{
	padding: 7px 8px 5px 8px;
}


	/* ======= SP =======*/
	@media (max-width: 743px){
		select { width: 100%; }
		
		/* スマホ　ズームバグ修正 */
		input,
		select,
		textarea{ font-size: 16px;  }
	}


/*==============================*/
/* Header 上書き設定 */
/*==============================*/
header.toolHeader{
	padding: 16px 24px;
	box-shadow: 0 4px 6px -3px rgba(153,153,153,0.7);
}
header.toolHeader h2{ width: auto; }
header.toolHeader ul{
	justify-content: flex-start;
	width: 712px;
	gap: 6px;
}
header.toolHeader ul li{
	position: relative;
	width: calc(calc(100% - 6px * 4) / 5);
	height: auto;
	border-radius: 5px;
}
header.toolHeader ul li:after{
	display: none;
}
header.toolHeader ul li a{
	height: auto;
	padding: 8px 0 9px 0;
	font-size: 14px;
	line-height: 1.3em;
}

header.toolHeader ul li a span{
	display: block;
	font-size: 12px;
	font-weight: 300;
	line-height: 1.25em;
}
header.toolHeader ul li:nth-child(1){ background: #30AF70; }
header.toolHeader ul li:nth-child(2){ background: #71BC4E; }
header.toolHeader ul li:nth-child(3){ background: #36AE90; }
header.toolHeader ul li:nth-child(4){ background: #009DC5; }
header.toolHeader ul li:nth-child(5){ background: #17B8F3; }
header.toolHeader ul li:hover{ opacity: 0.8;}

	/* ======= SP =======*/
	@media (max-width: 1200px) {
		header{
			position: fixed; top: 0;
			width: 100%;
			padding: 16px 16px;
			background: #fff;
		}
		header form{ display: none!important;}
		header h2{ width: 200px; }
		header ul{ display: none;}
	}


/*==============================*/
/* Header 上書き設定 */
/*==============================*/
.subVisual{
	padding-top: 78px;
	padding-bottom: 74px;
}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		.subVisual{
			padding-top: 64px;
			padding-bottom: 64px;
		}
	}


/*==============================*/
/* sideMenu */
/*==============================*/

:root{
	--side-w: 312px;          /* サイドの幅 */
	--tr: 260ms ease;         /* トランジション */
	--header-h: 73px;         /* ヘッダー高さ */
}

html,
body{
	height: 100%;
	margin: 0;
	overflow: hidden;
}

div.contentLayout{
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0;
	align-items: stretch;
	margin: 0 auto;
	position: relative;
	height: calc(100dvh - var(--header-h));
	min-height: calc(100dvh - var(--header-h));
	overflow: hidden;
}

/*---------------------------------
   メインカラム
---------------------------------*/
.main{
	background: transparent;
	min-width: 0;
	min-height: 0;
	height: calc(100dvh - var(--header-h));
	overflow-x: auto;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

/*---------------------------------
   サイドカラム
---------------------------------*/
div.sideCol{
	position: relative;
	width: var(--side-w);
	min-width: 0;
	height: calc(100dvh - var(--header-h));
	min-height: 0;
	transition: width var(--tr), margin-right var(--tr), transform var(--tr);
	overflow: visible;
	will-change: width, margin-right, transform;
	isolation: isolate;
	border-top: 1px solid #E3E3E3;
	box-shadow: 4px 4px 6px -3px rgba(153,153,153,0.5);
	background: #fff;
	z-index: 2000;
}

body.side-collapsed div.sideCol{
	width: 0;
	margin-right: 0;
}

.sideNav{
	height: 100%;
	min-height: 0;
	background: #fff;
	overflow-x: hidden;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior: contain;
	transition: opacity 200ms ease;
	contain: content paint;
	will-change: opacity;
	overflow-anchor: none;
	padding: 0 24px 40px 24px;
}

body.side-collapsed .sideNav{
	opacity: 0;
}

.nav-acc{ position: relative; z-index: 2; }
.nav-sub{ position: relative; z-index: 1; }

.sideNav .sideNav-body{
	position: relative;
	border-top: 1px solid #E3E3E3;
}
.sideNav .sideNav-body::before{
	position: absolute; top: 0px; left: 0;
	content: "";
	width: 100%;
	height: 1px;
	background: #E3E3E3;
}

/*-- 見出し
------------------------- */
.sideNav p.sideTitle{
	position: relative;
	padding: 72px 0 60px 0;
	color: #000;
	font-size: 28px;
	font-weight: 700;
	font-family: "Inter", sans-serif;
	line-height: 1.3em;
	letter-spacing: 0.01em;
	text-align: center;
}
.sideNav p.sideTitle::before{
	position: absolute; top: 36px; left: 50%;
	content: "";
	width: 200px;
	aspect-ratio: 200/126;
	background: url(/common/img/tool/bg-side-logo.svg);
	background-size: contain;
	z-index: -1;
	transform: translateX(-50%);
}
.sideNav p.sideTitle a{
	font-size: 28px;
	font-weight: 700;
	line-height: 1.3em;
	letter-spacing: 0.01em;
}
.sideNav p.sideTitle a span{
	color: #29AAE3;
	font-size: 28px;
	font-weight: 700;
	vertical-align: baseline;
	letter-spacing: 0.01em;
	line-height: 1.3em;
}
.sideNav p.sideTitle a small{
	display: block;
	padding-top: 4px;
	font-size: 15px;
	font-weight: 500;
	font-family: "Noto Sans JP";
	letter-spacing: -0.02em;
	line-height: 1.5em;
}

/*-- 通常リンク
------------------------- */
.nav-link a{
	position: relative;
	display: block;
	padding: 14px 20px 14px 8px;
	border-bottom: 1px solid #E3E3E3;
	cursor: pointer;
	color: #46403B;
	text-align: left;
	font-size: 16px;
}

.nav-link a::before{
	position: absolute; top: 50%; right: 8px;
	content: "";
	width: 8px;
	height: 8px;
	border-top: 2px solid #29AAE3;
	border-right: 2px solid #29AAE3;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	transition: transform var(--tr);
	margin-top: -4px;
}


/* クリック出来ない状態 */
.nav-link.nav-link-disabled a{
	color: #B1B1B1;
	background: #8F8F8F;
	pointer-events: none;
}
.nav-link.nav-link-disabled a::before{
	border-top: 2px solid #B1B1B1;
	border-right: 2px solid #B1B1B1;
}

/*-- メニュー開閉ボタン
------------------------- */
li.Disclaimer{
	padding: 14px 8px;
}
li.Disclaimer h4{
	font-size: 14px;
	font-weight: 500;
	color: #257E9E;
}
li.Disclaimer p{
	font-size: 12px;
	line-height: 16px;
}

/*-- メニュー 開閉ボタン
------------------------- */
button.nav-acc{
	position: relative;
	display: block;
	width: 100%;
	padding: 18px 20px 18px 64px;
	background: #fff;
	cursor: pointer;
	color: #46403B;
	text-align: left;
	font-size: 15px;
	line-height: 1.414em;
	transition: background-color 180ms ease, color 180ms ease, box-shadow 200ms ease;
	will-change: background-color, color, box-shadow;
}
button.nav-acc::before{
	position: absolute; top: 50%; left: 0;
	content: "";
	width: 52px;
	height: 52px;
	background: #ccc;
	border-radius: 50%;
	transform: translateY(-50%);
}
li.nav-item:nth-child(1) button.nav-acc::before{ background: url(/common/img/tool/icon-text.svg); background-size: cover;}
li.nav-item:nth-child(2) button.nav-acc::before{ background: url(/common/img/tool/icon-design.svg); background-size: cover;}
li.nav-item:nth-child(3) button.nav-acc::before{ background: url(/common/img/tool/icon-business.svg); background-size: cover;}
li.nav-item:nth-child(4) button.nav-acc::before{ background: url(/common/img/tool/icon-accounting.svg); background-size: cover;}
li.nav-item:nth-child(5) button.nav-acc::before{ background: url(/common/img/tool/icon-development.svg); background-size: cover;}

button.nav-acc:hover{
	color: #000;
	font-weight: 700;
}
button.nav-acc:hover small{
	color: #000;
	font-weight: 500;
}

button.nav-acc small{
	display: block;
	color: #B9B9B9;
	font-family: "Inter", sans-serif;
	letter-spacing: 0.01em;
	font-size: 13px;
	font-weight: 300;
	line-height: 1.3em;
}

button.nav-acc::after{
	position: absolute; top: 50%; right: 4px;
	content: "";
	width: 8px;
	height: 8px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	transition: transform var(--tr);
	margin-top: -2px;
	border-top: 2px solid #29AAE3;
	border-right: 2px solid #29AAE3;
}

.nav-item.is-close button.nav-acc::after{
	transform: rotate(135deg);
	margin-top: -6px;
	border-top: 2px solid #46403B;
	border-right: 2px solid #46403B;
}

.nav-item{
	position: relative;
	border-bottom: 1px solid #E3E3E3;
}
.nav-item:not(.is-close) button.nav-acc{
	color: #000;
	font-weight: 700;
}
.nav-item:not(.is-close) button.nav-acc small{
	color: #000;
	font-weight: 500;
}

/*-- プルダウンメニュー
------------------------- */
ul.nav-sub{
	display: grid;
	gap: 6px;
	overflow: hidden;
	height: auto;
	opacity: 1;
	transition: height var(--tr), opacity 200ms ease;
	will-change: height, opacity;
	box-sizing: border-box;
	contain: layout paint;
	overflow-anchor: none;
}

.nav-item.is-close ul.nav-sub{
	opacity: 0;
}

ul.nav-sub div.nav-sub-inner{
	padding: 0px 0px 18px 20px;
}
ul.nav-sub li a{
	position: relative;
	display: block;
	padding: 10px;
	color: #46403B;
	font-size: 14px;
	border-radius: 5px;
}
ul.nav-sub li a:hover{
	color: #29AAE3;
	background: #EBF2F4;
}
ul.nav-sub li a img{
	margin-right: 12px;
}

/* クリック出来ない状態 */
ul.nav-sub div.nav-sub-inner li.nav-sub-disabled{
	opacity: 0.5;
}
ul.nav-sub div.nav-sub-inner li.nav-sub-disabled a{
	pointer-events: none;
}
ul.nav-sub div.nav-sub-inner li.nav-sub-disabled a:hover{
	text-decoration: none;
}

/*-- メニュー開閉ボタン
------------------------- */
.sideToggle{
	position: absolute;
	top: 76px;
	left: var(--side-w);
	z-index: 3000;
	width: 36px;
	height: 64px;
	background: #2885A3;
	color: #fff;
	font-size: 20px;
	line-height: 64px;
	border-radius: 0 5px 5px 0;
	text-align: center;
	cursor: pointer;
	border: 1px solid #fff;
	border-left: none;
	transition: left var(--tr), transform var(--tr);
}

/* 閉じたときは今まで通り左端 */
body.side-collapsed .sideToggle{
	left: 0;
}

/*---------------------------------
   TB・SP：メニューを重ねる
---------------------------------*/
@media (max-width: 1024px){

	div.contentLayout{
		grid-template-columns: 1fr;
		height: calc(100dvh - var(--header-h));
		min-height: calc(100dvh - var(--header-h));
	}

	.main{
		grid-column: 1 / -1;
		width: 100%;
		min-width: 0;
		height: calc(100dvh - var(--header-h));
	}

	div.sideCol{
		position: fixed;
		top: var(--header-h);
		left: 0;
		width: min(312px, 86vw);
		height: calc(100dvh - var(--header-h));
		margin-right: 0;
		border-top: none;
		box-shadow: 4px 4px 12px rgba(0,0,0,0.15);
		transform: translateX(0);
	}

	body.side-collapsed div.sideCol{
		width: min(312px, 86vw);
		margin-right: 0;
		transform: translateX(-100%);
	}

	.sideNav{
		height: 100%;
		min-height: 0;
	}

	.sideToggle{
		position: fixed;
		top: var(--header-h);
		left: min(312px, 86vw);
	}

	body.side-collapsed .sideToggle{
		left: 0;
	}
}




/*==============================*/
/* シングルレイアウト（サイド無し） */
/*==============================*/
div.singleLayout{
	overflow-x: scroll;
	min-height: 100vh;
}

/*==============================*/
/* コンテンツフレーム */
/*==============================*/
div.contentWrap{
	padding: 80px;
}
	/* ======= TB =======*/
	@media screen and (min-width: 1300px) and (max-width: 1600px) {
		div.contentWrap{
			padding: 64px;
		}
	}
	/* ======= TB =======*/
	@media screen and (min-width: 1025px) and (max-width: 1300px) {
		div.contentWrap{
			padding: 56px;
		}
	}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		div.contentWrap{
			padding: 64px 40px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.contentWrap{
			padding: 24px;
		}
	}


/*==============================*/
/* ツール枠 */
/*==============================*/
div.toolContent-wrap{
	width: min(920px,100%);
	margin: 0 auto;
	padding: 64px 72px 68px 72px;
	background: #fff;
	border-radius: 10px;
	box-shadow: 4px 4px 6px -3px rgba(153,153,153,0.5);
}

	/* ======= TB =======*/
	@media screen and (min-width: 1025px) and (max-width: 1350px) {
		div.toolContent-wrap{
			padding: 72px 56px;
		}
	}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		div.toolContent-wrap{
			padding: 64px 40px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.toolContent-wrap{
			padding: 40px 24px 40px 24px;
			border-radius: 8px;
		}
	}

