@charset "utf-8";
/* CSS Document */
/* 20250521 作成　ver.1.0.0 */

/*-------------------
製品ページ　請求書　発行機能TOPページ用CSS
/seikyu/seller/index.asp
-------------------*/
#seikyu {
	font-size: 16px;
}
.contents {
	width: 90%;
	max-width: 64em;
	margin: auto;
}
.btn a:hover{
	opacity: 0.85;
	cursor : pointer;
}
/* SE対応サイズ ~352px(16×22em) */
@media screen and (max-width:22em) {
}
/* タブレット縦サイズ 768px(16×48em)~ smサイズ */
@media screen and (min-width:48em){
}
/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
}
/* ノートPC以上のサイズ 1200px(16×75em)~ lgサイズ */
@media screen and (min-width:75em) {
}

/*-----------------
 *メインビジュアル
-----------------*/
#seikyu .main-v { 
	padding-top: 50px;
	padding-bottom: 35px;
	width: 100%;
	height: auto;
	min-height: 24em;
	position: relative;
	overflow: hidden;
	background-image: url("/web/jp/seikyu/images/top_main-v_02.jpg");
	background-size: cover;
	background-position: center;
}
#seikyu h1 {
	margin: 80px auto 24px;
	font-size: 2em;
	line-height: 1.3;
	font-weight: bold;
	text-align: center;
}
#seikyu h1 span {
	margin-top: 1em;
	font-size: 0.5em;
	font-weight: 400;
	line-height: 1.3;
	display: inline-block;
	margin-bottom:1em;
}

/* タブレット縦サイズ 768px(16×48em)~ smサイズ */
@media screen and (min-width:48em){
	#seikyu .main-v {
		padding-bottom: 10px;
	}
	#seikyu h1 {
		margin-top: 80px;
	}
	#seikyu h1 span {
		display: block;
		font-size: 0.6em;
	}
}
/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
	#seikyu .main-v {
		min-height: 24em;	
	}
	#seikyu h1 {
		margin-top: 100px;
		font-size: 38px;
	}
	#seikyu h1 span {
		font-size: 0.5em;
		display: block;
	}
}

/*-----------------
 *各section　上下の余白設定
-----------------*/
#sec-about {
	padding: 4em 0;
}
#sec-reason,
#sec-function,
#sec-effect,
#sec-handle {
	padding: 4em 0;
	background: linear-gradient(-20deg, #D1EFD5 0%, #F5FFF7 100%);
}

#sec-function-flow{
	padding: 4em 0;
}


#sec-cnv{
	padding: 5em 0 5em;
}
#sec-cnv_2{
	padding: 4em 0;
	background-color: #f0f0f0;
	margin: 3em auto 0;
}
/*-----------------
 *見出し　デザイン設定
-----------------*/
#seikyu h2 {
	font-size: 1.5em;
	font-weight: bold;
	margin-bottom: 1.5em;
	text-align: center;
	color: #333;
	line-height: 1.7;
}
#seikyu h2 img.seikyu_logo02 {
	padding-right: 5px;
	width: 85%;
	vertical-align: text-bottom;
}
#seikyu h2 img.seikyu_logo02.adjust {
	padding-top: 5px;
}
/* タブレット縦サイズ 768px(16×48em)~ smサイズ */
@media screen and (min-width:48em){
	#seikyu h2 img.seikyu_logo02 {
		width: 450px;
	}
}
.btn-cta-microcopy {
	color: #297f3a;
	text-align: center;
	font-size: 18px;
	font-weight: 700;
	padding-bottom: 8px;
	margin: 0 !important;
}
/*-----------------
 *sec-about　請求書発行機能
-----------------*/
#sec-about h2 {
	color: #267C3A;
}
#sec-about p {
	line-height: 1.3;
}
#sec-about .sec-about_img01 {
	width: 100%;
	border: solid 1px #D9D9D9;
	margin: 30px auto 0;
	display: flex;
	justify-content: center;
}
#sec-about .sec-about_img01 img {
	width: 90%;
	padding: 20px 0;
}
/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
	#sec-about .sec-about_img01 {
		width: 900px;
	}
	#sec-about .sec-about_img01 img {
		width: 600px;
	}
}

/*-----------------
 *sec-reason　選ばれる理由
-----------------*/
#sec-reason h2 {
	color: #267C3A;
}

#sec-reason .reason_box_wrap {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px;
}
#sec-reason .reason_box {
	width: 90%;
	max-width: 400px;
	text-align: center;
	padding: 25px 20px 30px;
	background-color: #ffffff;
	border-radius: 8px;
	display: flex;
	flex-direction: column;
	transition: .3s cubic-bezier(0.5, 1, 0.89, 1);
}
#sec-reason .reason_box:hover {
	background-color: #F5FFF7;
	transform: scale(1.03);
}
#sec-reason .reason_box img {
	width: 125px;
	height: 125px;
	margin: 0 auto;
	padding: 15px 0;
}
#sec-reason .reason_box a {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
}
#sec-reason .reason_box a:hover {
	cursor : pointer;
}
#sec-reason .reason_box h3 {
	font-size: 1.2em;
	font-weight: 700;
	line-height: 1.2;
	height: 2.8em;
	display: flex;
	justify-content: space-around;
	align-items: center;
	padding-top: 8px;
}
#sec-reason .reason_box .reason_point {
	width: 84px;
	height: 84px;
	border-radius: 50%;
	font-weight: 700;
	font-size: 17px;
	background-color: #4EC169;
	color: #ffffff;
	display: flex;
    flex-direction: column;
    align-items: center;
    justify-content:center;
	flex: 0 0 84px;
}
#sec-reason .reason_box .reason_point span {
	display: inline-block;
	font-size: 35px;
	padding-top: 8px;
}

#sec-reason .reason_box .reason_ttl_wrap{
	display: flex;
	justify-content: center;
    align-items: center;
    gap: 15px;
}
#sec-reason .reason_box .reason_p {
	line-height: 1.2;
	font-size: 15px;
	text-align: left;
	padding: 10px 10px 30px 10px;
}
#sec-reason .reason_box .reason_btn {
	color: #ffffff;
	background-color: #4EC169;
	font-weight: 700;
	border-radius: 8px;
	height: 45px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: auto;
	position: relative;
}
#sec-reason .reason_box .reason_btn::after {
	content: '>';
	position: absolute;
	right: 0.625em;
	top: 50%;
	transform: translateY(-57%) scale(0.5, 1.0);
	display: inline-block;
	font-size: 1.5em;
	font-weight: normal;
	line-height: 1.5em;
}

/* タブレット縦サイズ 768px(16×48em)~ smサイズ */
@media screen and (min-width:48em){
	#sec-reason .reason_box_wrap {
	gap: 15px;
}
	#sec-reason .reason_box {
		width: 40%;
}
}
/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
#sec-reason .reason_box_wrap {
	gap: 30px;
}

#sec-reason .reason_box {
		width: 50%;
	}
}

/*-----------------
 *sec-function 主な機能 フロー版
-----------------*/

#sec-function-flow h2 {
	color: #267C3A;
}

#sec-function-flow h2 span{
	display: inline-block;
	margin-bottom: 10px;
}

#sec-function-flow .function-flow_h3wrap{
	border-bottom:2px dotted #267C3A;
	padding: 15px 15px 15px 0;
}

#sec-function-flow h3{
	font-size: 1.5em;
    font-weight: bold;
	color: #267C3A;
	padding: 3px 3px 3px 15px;
	border-left: 5px solid #267C3A;

}

#sec-function-flow .flow_outer{
	display: flex;
	width: 100%;
	margin: 30px auto 25px;
}

#sec-function-flow .flow_outer .flow-ttl, #sec-function-flow .flow_outer .flow-ttl_rect{
	padding:15px 10px;
	background-color:#4EC169 ;
	position: relative;
	width:72px;
}


#sec-function-flow .flow_outer .flow-ttl::before {
    content: "";
    width: 100%;
    position: absolute;
    bottom: -25px;
    left: 0;
	height: 25px;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
    background-color: #4EC169;
}

#sec-function-flow .flow_outer .flow-ttl p, #sec-function-flow .flow_outer .flow-ttl_rect p{
	color: #267C3A;
	text-align: center;
	font-size: 16px;
	line-height: 1.3;
	font-weight: bold;
	padding: 10px;
    background: #ffffff;
    border-radius: 5px;
}

#sec-function-flow .flow_outer .flow-wrap{
	background-color: #EEEDEC;
	padding: 15px;
	flex:1;
}

#sec-function-flow .flow_outer .flow-wrap .flow-lead{
	font-size: 16px;
	text-align: center;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 20px;
}


#sec-function-flow .function_box_wrap {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 15px;
}

#sec-function-flow .function_box a{
	display: flex;
	flex-direction: column;
    width:100%;
	height: 100%;
	text-align: center;
	background-color: #ffffff;
	padding: 15px;
	box-sizing: border-box;
	border-radius: 8px;
	transition: .3s cubic-bezier(0.5, 1, 0.89, 1);
}

#sec-function-flow .function_box .no-link{
	display: flex;
	flex-direction: column;
    width:100%;
	height: 100%;
	text-align: center;
	background-color: #ffffff;
	padding: 20px 20px 25px;
	box-sizing: border-box;
	border-radius: 8px;
}

#sec-function-flow .function_box a:hover {
	background-color: #F5FFF7;
	transform: scale(1.03);
}
#sec-function-flow .function_box img {
	height: 100px;
	margin: 0 auto 24px;
	display: block;
}

#sec-function-flow .function_box a:hover {
	cursor : pointer;
}
#sec-function-flow .function_box p {
  	line-height: 1.6;
	text-align: justify;
}

#sec-function-flow .function_box .function_txt {
  padding-bottom: 16px;
}

#sec-function-flow .function_box .function_ttl_wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
	height: 50px;
}
#sec-function-flow .function_box .function_ttl_wrap .function_ttl {
	color: #333;
	font-size: 18px;
	font-weight: bold;
	display: block;
	text-align: center;
	line-height: 1.3;
}

#sec-function-flow .function_box .function_ttl_wrap .function_ttl  span{
	font-size: 16px;
}


#sec-function-flow .function_box .function_ttl_wrap .icon-webfont-01 {
  display: none;
}

.cnv_btn_function {
  display: flex;
  align-items: center;
  border-radius: 9999px;
  border: 2px solid #4EC169;
  color: #4EC169;
  font-size: 13px;
  font-weight: 600;
  padding: .6em 1.2em .6em 2em;
  margin: auto auto 0;
  width: fit-content;
  background-color: #4EC169;
}
.cnv_btn_function p {
  color: #fff;
}
.cnv_btn_function .icon-webfont-01 {
  margin-left: 20px;
  font-weight: bold;
  font-size: 13px;
}

.ttl-br {
    display: none;
}

/* タブレット縦サイズ 768px(16×48em)~ smサイズ */
@media screen and (min-width:48em){
#sec-function-flow .flow_outer{
	display: flex;
	width: 100%;
	margin: 30px auto 40px;
}

#sec-function-flow .flow_outer .flow-ttl, #sec-function-flow .flow_outer .flow-ttl_rect {
    width: 100px;
}

#sec-function-flow .flow_outer .flow-ttl p, #sec-function-flow .flow_outer .flow-ttl_rect p{
	font-size: 20px;
	padding: 10px;
}

#sec-function-flow .flow_outer .flow-wrap .flow-lead {
    font-size: 20px;
}

#sec-function-flow .flow_outer .flow-wrap {
    padding: 30px;
}

#sec-function-flow .function_box .function_ttl_wrap .function_ttl {
    font-size: 23px;
}

#sec-function-flow .function_box a {
    padding: 20px 20px 25px;
}

#sec-function-flow .function_box {
  width: calc((100% - 15px) / 2);
}

.ttl-br {
    display: block;
}

#sec-function-flow .flow_outer .flow-ttl::before{
	height: 40px;
}

#sec-function-flow .flow_outer .flow-ttl::before {
    bottom: -39px;
}

.cnv_btn_function {
    font-size: 16px;
}
}
/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
}

/*-----------------
 *sec-handle こんな帳票にも対応！
-----------------*/

#sec-handle .handle-box_wrap{
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}

#sec-handle .h2-wrap{
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
}

#sec-handle .h2-wrap img{
	display: inline-block;
	width:105px;
}

#sec-handle .h2-wrap h2.sec-handle{
	font-size:26px ;
	color:#267C3A;
	padding:15px 25px;
	border-radius: 60px;
	border:3px solid #267C3A;
	background: #ffffff;
	position: relative;
}

#sec-handle .h2-wrap h2.sec-handle::before {
    content: "";
    position: absolute;
    transform: rotate(-45deg);
    background-color: #267C3A;
    bottom: 16px;
    left: -10px;
    width: 25px;
    height: 2px;
}

#sec-handle .handle_box{
	margin: -12px auto 0;
	background-color: #ffffff;
	border: 2px solid #4EC169;
	border-radius: 10px;
	transition: .3s cubic-bezier(0.5, 1, 0.89, 1);
}

#sec-handle .handle_box a{
	width: 100%;
	height: 100%;
	display: flex;
	flex-wrap: wrap;
	align-content: space-between;
	padding: 10px 30px 30px;
	box-sizing: border-box;
}

#sec-handle .handle_box .handle_ttl_wrap{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 20px;
	margin-bottom: 15px;
}

#sec-handle .handle_box img{
	display: inline-block;
	width: 100px;
}

#sec-handle .handle_box .handle_ttl{
	font-size: 26px;
	font-weight: 700;
	line-height: 1.3;
}

#sec-handle .handle_box .handle_txt{
	font-size: 16px;
    line-height: 1.6;
    text-align: justify;
	margin-bottom: 20px;
}

#sec-handle .handle_box .cnv_btn_function{
	padding: .9em 1.2em .9em 2em;
}

#sec-handle .handle_box:hover {
	background-color: #F5FFF7;
	transform: scale(1.03);
}

#sec-handle .handle_box .handle_ttl .text-line{
	border-bottom:solid;
	border-color:#F6CD45;
	border-width:5px;
}

/* タブレット縦サイズ 768px(16×48em)~ smサイズ */
@media screen and (min-width:48em){
#sec-handle .handle-box_wrap{
	flex-wrap: nowrap;
}

#sec-handle .handle_box{
	width: calc((100% - 30px) / 2);
}

#sec-handle .handle_box .handle_ttl_wrap{
	flex-direction:row ;
}
}

/*-----------------
 *sec-effect　導入効果
-----------------*/
#sec-effect h2 {
	color: #267C3A;
}
#sec-effect p {
	line-height: 1.3;
	font-weight: 700;
}
#sec-effect .sec-effect_img01 img {
	width: 100%;
	margin: 30px auto 0;
	display: flex;
	justify-content: center;
}
@media screen and (min-width:48em){
	#sec-effect .sec-effect_img01 img {
		width: 500px;
	}
}
/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
	#sec-effect .sec-effect_img01 img {
		width: 750px;
	}
}
/*-----------------
 *sec-option law 税法対応
-----------------*/
.law{
	border: 1px solid #40a83e;
	text-align: center;
	/*margin-bottom: 48px;*/
}
#seikyu .law h2{
	font-size: 1.3em;
    margin: 24px auto 24px;
}
.law img{
	width: 70%;
	max-width: 16em;
    height: 5.5em;
	margin: 0 auto 24px;
}
.law p{
    margin: 0 auto 24px;
	line-height: 1.5em;
}
/*-----------------
 *sec-cnv　CVエリア
-----------------*/
.section_lead{
	text-align: center;
	margin-bottom: 32px;
	font-size: 1.3em;
	line-height: 1.3em;
	font-weight: bold;
}
ul.cnv-merit{
	margin: 0 auto 40px;
	max-width: 24em;
}
ul.cnv-merit li{
	margin-bottom: 0.5em;
	line-height: 1.5em;
	padding-left: 2em;
	text-indent: -2em;
}
ul.cnv-merit li span.icon-webfont-19{
	padding-right: 1em;
}
ul.cnv-merit li span.marker{
	background: -webkit-linear-gradient(transparent 88%, #ff7f7f 88%);
	background: -o-linear-gradient(transparent 88%, #ff7f7f 88%);
	background: linear-gradient(transparent 88%, #ff7f7f 88%);
    font-weight: bold
}

.g-grey{
	background-color: #f0f0f0;
}
/*-----------------
 *CVボタン
-----------------*/
.cnv-btn {
	width: 90%;
	max-width: 32em;
	margin: auto;
	text-align: center;
}
.cnv-btn a {
	padding: 20px;
	background-color: #2d67a3;
	border-radius: 6px;
	color: #fff;
	font-size: 1.3em;
	font-weight: bold;
	line-height: 1.3em;
	display: block;
	position: relative;
}
.cnv-btn a::after { 
	content: '>';
	position: absolute;
	right: 0.625em;
	-webkit-transform: scale(0.5, 1.0);
       -moz-transform: scale(0.5, 1.0);
    	-ms-transform: scale(0.5, 1.0);
			transform: scale(0.5, 1.0);
	display: inline-block;
	font-size: 1.5em;
	font-weight: normal;
}
.bcolor_o a{
	background-color: #fd7822;
}
/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
	.cnv-btn a::after {
		top: 0.65em;
	}
	.cnv-btn a:hover{
		background-color: #2d67a3;
	}
	.bcolor_o a:hover{
		background-color: #fd7822;
	}
}
/*-----------------
 *CVボタン修正　
-----------------*/
.box-center {
    margin: 0 auto;
    text-align: center;
}
.btn-cta {
    display: inline-block;
    position: relative;
    overflow: hidden;
    width: 513px;
    border: 1px solid #fff;
    border-radius: 4px;
    background-color: #ff7800;
    box-shadow: 0 5px 12px rgb(0 0 0 / 40%);
    text-decoration: none;
    outline: none;
    text-align: center;
    transition: ease .2s;
}
.btn-cta a {
    display: block;
	padding: 24px 0;
}
.btn-cta span {
    position: relative;
    z-index: 3;
    color: #fff;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.1em;
    display: block;
}
.btn-cta span::after {
    content: "";
    position: absolute;
    right: 1.25em;
    width: 0.6em;
    height: 0.6em;
    top: 50%;
    margin-top: -0.32em;
    border-top-width: 3px;
    border-top-style: solid;
    border-right-width: 3px;
    border-right-style: solid;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.btn-cta:hover, .btn-online:hover {
    opacity: 0.7;
}

@media (max-width: 767px) {
	.btn-cta, .btn-online {
		display: block;
		width: 90%;
		margin: 0 auto;
	}

	.btn-cta a {
		display: block;
		padding: 20px 0;
	}
}
/*-----------------
 *他ボタン
-----------------*/
.cnd-btn {
	width: 90%;
	max-width: 20em;
	margin: 0 auto;
	text-align: center;
}
.cnd-btn a {
	padding: 1.25em 1em 1.25em;
	background-color: #40a83e;
	border-radius: 6px;
	color: #fff;
	font-size: 1em;
	font-weight: bold;
	line-height: 0.85em;
	display: block;
	position: relative;
}
.cnd-btn a::after { 
	content: '>';
	position: absolute;
	right: 0.625em;
	top: 0.75em;
	-webkit-transform: scale(0.5, 1.0);
	-moz-transform: scale(0.5, 1.0);
	-ms-transform: scale(0.5, 1.0);
	transform: scale(0.5, 1.0);
	display: inline-block;
	font-size: 1.5em;
	font-weight: normal;
}

/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
	.cnd-btn a {
		padding: 1.25em 1em 1em;
	}
	.cnd-btn a::after {
		top: 0.8em;
	}
}
/*-----------------
 *他ボタン　サブ
-----------------*/
.cnd-btn-sub {
	width: 90%;
	max-width: 14em;
	margin: 0 auto;
	text-align: center;
	float: right;
}
.cnd-btn-sub a {
	padding: 1.25em 1em 1.25em;
	background-color: #777;
	border-radius: 6px;
	color: #fff;
	font-size: 1em;
	line-height: 0.85em;
	display: block;
	position: relative;
}
.cnd-btn-sub a::after { 
	content: '>';
	position: absolute;
	right: 0.625em;
	top: 0.75em;
	-webkit-transform: scale(0.5, 1.0);
	-moz-transform: scale(0.5, 1.0);
	-ms-transform: scale(0.5, 1.0);
	transform: scale(0.5, 1.0);
	display: inline-block;
	font-size: 1.5em;
	font-weight: normal;
}

/* タブレット横サイズ 1024px(16×64em)~ mdサイズ */
@media screen and (min-width:64em){
	.cnd-btn-sub a {
		padding: 1.25em 1em 1em;
	}
	.cnd-btn-sub a::after {
		top: 0.8em;
	}
}
/* ヘッダーボタンの背景色変更 20180802 */
a.cv_btn_header{ background-color: #2d67a3;}


/*-----------------
 *右サイド　フローティングサブメニュー
-----------------*/

.contents-ttl{
  scroll-margin-top: 80px; /* 固定ヘッダーの高さに合わせて調整 */
}

#sub_sidebar {
    position: fixed;
    top: 100px;
    right: -80px; /* 初期状態は少し隠す */
    background-color: #d5f1dc;
    padding: 15px 10px;
    transition: right 0.3s;
    z-index: 99;
    border: solid 1px #267c3a;
    border-radius: 5px;

}
@media (min-width: 1366px) {
    #sub_sidebar {
        right: 0;
    }
}
.sub_sidebar_title {
    font-size: 14px;
    font-weight: 700;
    padding-bottom: 10px;
    color: #267c3a;
}

.sub_sidebar_p {
   margin-bottom: 10px;
   position: relative;
   padding-left: 10px;
}

.sub_sidebar_p:before {
    content: "";
    position: absolute;
    top: .35em;
    left: 0;
    width: 0;
    height: 0;
    border-width: 5px;
    border-style: solid;
    border-color: transparent transparent transparent #777;
  }


.sub_sidebar_p a {
    font-size: 13px;
    font-weight: 700;
    line-height: 1.3;
    color: #267c3a;
}
.sub_sidebar_p:hover {
    opacity: 0.7;
    text-decoration: none;
}
.hotzone {
    position: fixed;
    top: 100px;
    right: 0;
    width: 80px;
    height: 100px;
    z-index: 98;
}
.hotzone:hover + #sub_sidebar,
    #sub_sidebar:hover {
        right: 0; /* ホバー時にサイドバーを表示 */
    }
@media (max-width: 1200px) {
    .hotzone, #sub_sidebar {
    display: none;
    }
}

/*-----------------
 *インククルード箇所の前後の余白調整
-----------------*/
#sec-introduction{
	margin: 80px 0;
}

#sec-law{
	margin-bottom:140px;
}