@charset "UTF-8";

/**LOGOSWARE CSS*****************
module.css
Version: 1.4：
********************************/

/* =========================================================
1.CSS Hack
========================================================= */

.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

.clearfix {
	display: inline-block;
}

/* Hides from IE-mac \*/
* html .clearfix {
	height: 1%;
}

.clearfix {
	display: block;
}

/* End hide from IE-mac */


/* =========================================================
2.layout
========================================================= */

.right {
	text-align: right;
}

.center {
	text-align: center;
}

.floatL {
	float: left;
}

.floatR {
	float: right;
}

/*まわりこみ解除*/
.cl {
	clear: both;
}

.c_left {
	clear: left;
}

.c_right {
	clear: right;
}

.ss {
	font-size: 0.8em;
}

.LL {
	font-size: 1.5em;
}

/* 2カラム */
.column2L,
.column2R {
	width: 330px;
	margin: 0;
}

.column2L {
	float: left;
}

.column2R {
	float: right;
}


/************************************************
2-1.行間調整クラス
margin-bottomはクラスに指定が入っているため、
調整はmargin-topで行う
**********************************************/

.ex-topSp-5 {
	margin-top: -5px !important;
}

.ex-topSp10 {
	margin-top: 10px !important;
}

.ex-topSp20 {
	margin-top: 20px !important;
}

.ex-topSp30 {
	margin-top: 30px !important;
}

.ex-topSp40 {
	margin-top: 40px !important;
}

.ex-topSp50 {
	margin-top: 50px !important;
}

.ex-topSp60 {
	margin-top: 60px !important;
}

.ex-topSp70 {
	margin-top: 70px !important;
}

.ex-topSp80 {
	margin-top: 80px !important;
}

.ex-topSp90 {
	margin-top: 90px !important;
}

.ex-topSp100 {
	margin-top: 100px !important;
}

.mt-4r {
	margin-top: 4rem !important;
}

.mt-6r {
	margin-top: 6rem !important;
}

.mt-8r {
	margin-top: 8rem !important;
}

.mt-10r {
	margin-top: 10rem !important;
}

.mt-12r {
	margin-top: 12rem !important;
}


/**********************************************
marginでは指定できないときのpadding
**********************************************/

.ex-topPd10 {
	margin: 0;
	padding-top: 10px;
}

.ex-topPd20 {
	margin: 0;
	padding-top: 20px;
}

.ex-topPd30 {
	margin: 0;
	padding-top: 30px;
}


/**********************************************
2-2 回り込み
mod-leftImg <div><img><p><p></div>で使用する。
**********************************************/

/*------------------------------------------------------------
画像左回り込み
------------------------------------------------------------*/

.mod-leftImg div {
	float: right;
	width: 340px;
}

.mod-leftImg>div {
	width: calc(50% - 10px) !important;
}

.mod-leftImg img {
	display: block;
	float: left;
	width: calc(50% - 10px) !important;
	margin-right: 20px;
	margin-bottom: 20px;
}

/*------------------------------------------------------------
画像右回り込み
------------------------------------------------------------*/
.mod-rightImg {
	margin-bottom: 20px;
}

.mod-rightImg div {
	float: left;
	width: 340px;
}

.mod-rightImg>div {
	width: calc(50% - 10px) !important;
}

.mod-rightImg img {
	display: block;
	float: right;
	width: calc(50% - 10px) !important;
	margin-left: 20px;
	margin-bottom: 20px;
}

/*見出し調整*/
.mod-leftImg h3,
.mod-leftImg h4,
.mod-rightImg h3,
.mod-rightImg h4 {
	margin-top: 0;
	padding-top: 0;
}

/*------------------------------------------------------------
コラム回り込みdiv
------------------------------------------------------------*/

.mod-float_box .leftBox {
	float: left;
	width: 55%;
}

.mod-float_box .rightBox {
	width: 42%;
	float: right;
}


/***************************************************************
2-3 複数カラムレイアウト
***************************************************************/

/*------------------------------------------------------------
リスト利用2カラムモジュール
------------------------------------------------------------*/

.mod-itemBox2 {
	width: 100%;
}

.mod-itemBox2 {
	padding: 0 0 10px;
	margin-left: 0;
	display: inline-block;
}

ul.mod-itemBox2,
.mod-itemBox2 ul {
	display: flex;
	column-gap: 40px;
	margin-left: 0;
}

.mod-itemBox2 li {
	display: block;
	width: 50%;
}

.mod-itemBox2 li img {
	width: 100%;
}

.mod-itemBox2 li p {
	font-size: 0.9em !important;
}

.mod-itemBox2 h5 {
	font-size: 1.7rem;
}

.mod-rightImg .mod-movie_box div {
	width: 250px;
}

.mod-itemBox2 .fixHeightChildBtn {
	margin-bottom: 1rem;
}


/*------------------------------------------------------------
リスト利用3カラムモジュール
------------------------------------------------------------*/

.mod-itemBox3 {
	width: 100%;
	margin-bottom: 10px;
}

.mod-itemBox3 ul,
.mod-itemBox3 li {
	margin-left: 0;
}

.mod-itemBox3 ul {
	display: flex;
	column-gap: 40px;
}

.mod-itemBox3 .item {
	display: block;
	width: 33.3333%;
}

.mod-itemBox3 .item:first-child {
	margin-left: 0px;
}

.mod-itemBox3 .item h5 {
	font-size: 1.6rem;
}

.mod-itemBox3 .item p {
	font-size: 1.2rem;
}

.mod-itemBox3 .item img {
	width: 100%;
}

.mod-itemBox3 .item img+h5 {
	margin-top: 10px;
}

.mod-itemBox3 .item li {
	margin-left: 1.3em;
}


/*------------------------------------------------------------
リスト利用２カラムモジュール背景つき
------------------------------------------------------------*/

.mod-itemBox2c {
	margin-top: 50px;
	padding-top: 25px;
	width: 100%;
	margin-bottom: 20px;
	background-color: #f5f5f5;
}

.mod-itemBox2c ul {
	display: flex;
	column-gap: 40px;
	width: 100%;
	margin-left: 0;
}

.mod-itemBox2c li {
	display: block;
	width: 50%;
}

.mod-itemBox2c h4 {
	margin: 0 20px;
	font-weight: normal;
	font-size: 2.4em;
}

.mod-itemBox2c h5 {
	color: #333;
	margin: 8px 0 0;
	font-size: 1.7rem;
}

.mod-itemBox2c li p {
	margin: 0.5em auto;
	font-size: 0.9em !important;
}

/*例外1カラム
------------------------------------------------------------*/
.mod-itemBox2c li.one-column {
	width: 640px;
}

.mod-itemBox2c li.one-column img {
	width: 640px;
}

/*製品情報用数字つき見出し指定
------------------------------------------------------------*/
.mod-itemBox2c h4.num {
	margin: 0 0 0 20px;
	padding: 0;
	background: none;
	font-weight: normal;
}

.mod-itemBox2c h4.num:first-letter,
.productsBox h4.num:first-letter {
	margin-right: 0.4em;
	padding: 0em 10px;
	color: #fff;
	font-size: 0.9em;
	line-height: 36px;
	background: url(../images/old/dropcap_maru.png) center center no-repeat;
}

/*ドロップキャップ*/
.dropcaps.square {
	font-weight: normal;
	padding: 0.1rem 0.5rem;
	margin-right: 0.5rem;
	border-radius: 2px;
	color: #fff;
}


/*------------------------------------------------------------
リスト利用3カラムモジュール背景グレー
------------------------------------------------------------*/

.mod-itemBox3c {
	width: 100%;
	margin-bottom: 20px;
	background-color: #eee;
}

.mod-itemBox3c ul {
	margin-left: 0;
	margin-bottom: 0;
	padding: 15px 10px;
	display: inline-block;
}

.mod-itemBox3c li {
	float: left;
	display: block;
	width: 210px;
	margin: 5px;
	padding-top: 30px;
	padding-bottom: 15px;
	text-align: center;
	border: 1px solid #ccc;
	background-color: #fff;
}

.mod-itemBox3c li p {
	margin: 1em auto;
	font-size: 1em !important;
}

/*リストの中のボタン。suite製品表示などに利用*/
.mod-itemBox3c .btnBase {
	width: 130px;
	margin: 0 auto;
	padding-left: 35px;
	background-image: url(../images/old/btn_arrow_white.png);
	background-repeat: no-repeat;
	background-position: 8px center;
}


/*------------------------------------------------------------
リスト利用4カラムモジュール
------------------------------------------------------------*/

.mod-itemBox4 {
	width: 100%;
	margin-bottom: 10px;
}

.mod-itemBox4 ul,
.mod-itemBox4 li {
	margin-left: 0;
}

.mod-itemBox4 .item {
	float: left;
	display: block;
	width: 160px;
	margin-left: 15px;
}

.mod-itemBox4 .item:first-child {
	margin-left: 0px;
}

.mod-itemBox4 .item h5 {
	font-size: 1.6rem;
}

.mod-itemBox4 .item p {
	font-size: 1.2rem;
}

.mod-itemBox4 .item img+h5 {
	margin-top: 10px;
}

.mod-itemBox4 .item li {
	margin-left: 1.3em;
}


/* =========================================================
3.font
========================================================= */

/**********************************************
font調整クラス：本文用
**********************************************/

/**サイズ指定…あまり使えない*********/

.ex-fontS {
	font-size: 0.9em;
	line-height: 0.9;
}

.ex-fontSS {
	font-size: 0.6em;
	line-height: 0.9;
	font-weight: normal;
}

.w_normal {
	font-weight: normal !important;
}

/*注意書き*/
p.note {
	font-size: 1.1em;
}

.c-w {
	color: #fff !important;
}


/* =========================================================
4.その他汎用クラス
========================================================= */

/*------------------------------------------------------------
イメージ置き換えテキスト ※見出し画像などに利用
------------------------------------------------------------*/

.ex-imgReplace {
	text-indent: -9999px;
	background-position: 0 0;
	background-repeat: no-repeat;
	width: 100%;
}

/*------------------------------------------------------------
大見出し
------------------------------------------------------------*/

/* 上下ボーダーつき：野呂さん作のクラスを移動
----------------------------*/
h3.simple_large {
	color: #333;
	border-top: 2px solid #000;
	border-bottom: 1px solid #000;
	font-size: 2.6em;
	font-weight: normal;
	padding: 30px 5px;
}

/* 機能タイトル横のオプション表示 */
h5 img.optionLabel {
	margin: 1px 0 0 10px;
}


/*------------------------------------------------------------
四角囲み数字見出し
------------------------------------------------------------*/

.mod-numH:first-letter {
	margin-right: 0.5em;
	padding: 0 0.5em;
	color: #fff;
	font-weight: normal;
	border-radius: 2px;
}


/*------------------------------------------------------------
販売プラン／価格 オプション表示 →色はdomain指定
------------------------------------------------------------*/
span.red {
	border-width: 1px;
	border-style: solid;
	border-color: #D83500;
	/*デフォ*/
	font-size: 1rem;
	padding: 0.3em;
}


/**********************************************
ボタン類
**********************************************/

.btnBase {
	display: block;
	padding: 5px;
	-webkit-transition: border-color 0.3s ease-out, background-color 0.3s ease-out;
	-moz-transition: border-color 0.3s ease-out, background-color 0.3s ease-out;
	transition: border-color 0.3s ease-out, background-color 0.3s ease-out;
	color: #333;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
	background-color: #D83300;
}

a.btnBase {
	margin: 0 auto;
	text-align: center;
	color: #fff;
	text-decoration: none;
}

.btnBase:hover {
	background-color: #D83300;
}

.btnBase.w50 {
	width: 40px;
	padding: 0 5px;
}

.btnBase.w150 {
	width: 140px;
}

.btnBase.w200 {
	width: 190px;
}

.btnBase.w300 {
	width: 290px;
}

.btnBase.w400 {
	width: 390px;
}

.btnBase.white {
	color: #fff;
}

.btnBase.disable {
	background-color: #ccc;
	pointer-events: none;
	cursor: default;
}


/*------------------------------------------------------------
ボタンデザインオプション
------------------------------------------------------------*/

/*矢印つき*/
.ex-arrow {
	background-image: url(../images/old/btn_arrow_white.png);
	background-repeat: no-repeat;
	background-position: 3% center;
}

/* 矢印つき（下向き） */
.ex-downarrow {
	background-image: url(../images/old/icon_downarrow_white.png);
	background-repeat: no-repeat;
	background-position: 3% center;
}

/*ダウンロード*/
.ex-dl {
	background-image: url(../images/old/icon_download.png);
	background-repeat: no-repeat;
	background-position: 3% center;
}

/*ウインドウつき*/
.ex-window {
	background-image: url(../images/old/website_icon.gif) !important;
	background-repeat: no-repeat;
	background-position: 3% center;
}

/*youtube*/
.ex-youtube {
	background-image: url(../images/old/icon_youtube.png) !important;
	background-repeat: no-repeat;
	background-position: 3% center;
}

/*外部*/
.ex-out {
	background-image: url(../images/old/icon_outbound.png) !important;
	background-repeat: no-repeat;
	background-position: 3% center;
}

/*ムービー*/
.ex-movie {
	background-image: url(../images/old/icon_movie.gif) !important;
	background-repeat: no-repeat;
	background-position: 3% center;
}

/*下矢印 追加読み込み用ボタン*/
.ex-downMore {
	background-image: url(../images/old/arrow_more_down.png);
	background-repeat: no-repeat;
	background-position: 56% 48%;
}

/*小さいの*/
.ex-mini {
	display: inline;
	padding: 0.3em 0.8em;
	font-weight: normal;
	font-size: 1.1rem;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
}

/* 白いの */
.ex-bgwhite {
	background-color: #FFF !important;
	color: #333 !important;
	box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.5);
}

.ex-bgwhite.ex-downarrow {
	background-image: url(../images/old/icon_downarrow.png);
	background-size: 21px 21px;
}

.ex-bgwhite.ex-downarrow:hover {
	background-image: url(../images/old/icon_downarrow_on.png);
	background-size: 21px 21px;
}

/* 白いの（角のあるフラット版） */
.btnBase.ex-white-flat {
	border: 2px solid #ccc;
	margin: 10px 0 0 0;
	padding: 8px 15px;
	font-weight: bold;
	color: #666;
	background-color: #fff;
	border-radius: 0;
}

.btnBase.ex-white-flat:hover {
	background-color: #D83300;
	color: #fff;
}

/* 大きいの */
.ex-large {
	padding: 0.75em 1.5em;
	font-weight: normal;
	font-size: 1.6rem;
	background-size: 24px 24px;
}

.ex-large:hover {
	background-size: 24px 24px;
}

.ex-large strong {
	font-weight: bold;
	font-size: 2.1rem;
}

/* アイコン右側 */
.ex-iconright {
	background-position: 90% center;
	padding-right: 15%;
}


/******************************************************
ユーザーアクションリンク
********************************************************/

a.play {
	padding: 1px 0 0 20px;
	background: url(../images/old/icon_play_04c.png) no-repeat left top;
	color: #04C;
}

a.play:hover {
	color: #0053F9;
}

a.more {
	padding: 0 14px 0 0;
	background: url(../images/old/icon_more_04c.png) no-repeat right 4px;
	color: #04C;
}

a.more:hover {
	color: #0053F9;
}

a.download {
	padding: 1px 0 0 20px;
	background: url(../images/old/icon_download_04c.png) no-repeat left top;
	color: #04C;
}

.num_section a.download:hover {
	color: #0053F9;
}


/*****************************
調整用hr
******************************/

hr {
	border-top: solid #ccc;
	border-width: 1px 0 0 0;
	margin: 40px 0;

}

hr.space {
	margin: 60px 0 70px;
	border: none;
	border-top: 1px solid #ccc;
	clear: both;
}

hr.invisible {
	margin: 40px 0;
	border: none;
	clear: both;
}

hr.dot {
	border-top: 1px dotted #ccc;
}


/*****************************
ボックス型画像ナビ。
画像設定はドメイン.cssで行う
******************************/
.mod-boxNav {
	margin-bottom: 40px;
	border: 1px solid #ccc;
}

.mod-boxNav ul {
	margin: 15px 0;
	padding-left: 0;
	list-style-type: none;
}

.mod-boxNav li a {
	display: block;
	float: left;
}


/*****************************
2列リスト
******************************/
.mod-list2 ul {
	width: 50%;
	margin-left: 0;
	float: left;
}

/*マーカー削除してアイコン使う場合*/
.mod-list2 ul.no-marker li {
	list-style-type: none;
	line-height: 2;
}

.mod-list2 ul h4 {
	margin-top: 0;
}


/*------------------------------------------------------------
movieコラム欄
------------------------------------------------------------*/

.mod-movie_box {
	padding: 20px;
	margin-bottom: 30px;
	background-color: #f5f5e7;
}

.mod-movie_box h5 {
	font-size: 2rem;
	line-height: 1.4;
}

.mod-movie_box .movie iframe {
	border: 1px solid #ccc;
}

.mod-movie_box .movie {
	width: 250px;
}

/*画像が左の場合 .movieLeft*/
.movieLeft .movie {
	float: left;
}

.movieLeft .textBox {
	float: right;
	margin-left: 20px;
	width: 380px;
}

/*画像が右の場合 .movieRight*/
.movieRight .movie {
	float: right;
}

.movieRight .textBox {
	float: left;
	margin-right: 20px;
	width: 380px;
}

.movieRight p {
	text-align: left;
}

.movieRight p a.btnBase,
.movieLeft p a.btnBase {
	margin-left: 0;
	width: 356px;
}

/*地味バージョン 2017/07/07****aside利用*/
aside.movie2 {
	border: 1px dotted #ccc;
	padding: 20px;
}

aside.movie2 h1 {
	font-size: 1.6em;
	font-weight: bold;
	margin-bottom: 0.5em;
}

aside.movie2 h1 i {
	float: left;
	font-size: 2em;
	line-height: 32px;
	padding: 5px 10px 5px 0;
}

aside.movie2 .btnBase {
	background-color: #eee;
	color: #333;
}

aside.movie2 .btnBase:hover {
	background-color: #d83300;
	color: #fff;
}


/* =========================================================
5.テーブル
========================================================= */

/**********************************************
mod-tableBase：テーブルデザインベース、横ラインのみのもの
＋スキンクラスで見た目調整

テーブル関連で使う部品
見出し＋.num：テーブル内数字つき見出し
mod-sup_info：テーブル下補足枠

縦ボーダー調整クラス
rBorderDot：右ドットボーダー
rBorderNone：右ボーダー消去

テーブルスキン
table-border：全セルボーダー囲み
table-border2：横ドットボーダー
table-noborder：ボーダーなし
table-striped：しましま
table-colorLeftTH：縦罫アリ／左一列のみ色つきテーブル
table-narrow：セル上下が狭いもの（ネストテーブルなどに利用）
table-fontL：フォント大きい版（通常1.2→1.3に）ー
table-frame2px：外枠二重線
table-bdc9：ボーダーの色が#999
**********************************************/

.mod-tableBase {
	width: 100%;
	background-color: #fff;
	border-bottom: 1px solid #ddd;
	border-top: 1px solid #ddd;
}

.mod-tableBase td,
.mod-tableBase th {
	padding: 8px;
}

/*hover指定は別クラスにすべきか？*/
.mod-tableBase tr:hover {
	background: #f5f5f5;
	-o-transition: all 0.2s ease-in-out;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-ms-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}

.mod-tableBase thead>tr>th {
	vertical-align: bottom;
	border-bottom: 2px solid #ddd;
}

.mod-tableBase tbody>tr>td,
.mod-tableBase tbody>tr>th {
	line-height: 1.8;
	vertical-align: top;
	border-top: 1px solid #ddd;
	/* font-size: 1.2rem; */
}

.mod-tableBase:last-child {
	margin-bottom: 0;
}

.mod-tableBase tbody>tr>th.bg_p_color2 {
	padding-top: 5px;
	padding-bottom: 5px;
}

.mod-tableBase tbody>tr>td.center,
.mod-tableBase tbody>tr>th.center {
	text-align: center;
	vertical-align: middle;
}

/*trにセンター指定した場合、TDにのみ適用*/
.mod-tableBase tbody>tr.center>td {
	text-align: center;
	vertical-align: middle;
}


/*------------------------------------------------------------
テーブル内見出しの数字タイトル
------------------------------------------------------------*/

.mod-tableBase .num {
	line-height: 1.4;
}

.mod-tableBase .num:first-letter {
	margin-right: 0.4em;
	padding: 0 0.2em;
	background: #666;
	color: #fff;
	font-size: 0.8em;
	font-weight: normal;
}


/*------------------------------------------------------------
テーブル下の補足枠
------------------------------------------------------------*/
.mod-sup_info {
	margin: 0 10px;
}

.mod-sup_info p,
.mod-sup_info li {
	line-height: 1.7;
}

.mod-sup_info p:first-child {
	margin-top: -10px;
}

.ex-note {
	line-height: 1.7em;
}

.ex-14 {
	font-size: 1.4em;
}

/*アスタリスク＋番号つきリスト ※補足枠以外で使うと文字が揃わない*/
ol.asterisk {
	counter-reset: number;
	list-style: none;
	/* text-indent: -3em; */
	/* padding-left: 0.5em; */
	padding-left: 0;
}

ol.asterisk li:before {
	counter-increment: number;
	content: "＊" counter(number)"　";
}


/**********************************************
オプション：縦ボーダー調整クラス colに指定して利用
**********************************************/

.rBorderDot {
	border-right: 1px dotted #ddd;
}

.rBorderNone {
	border-right: none;
}


/**********************************************
テーブルスキン
**********************************************/

/*------------------------------------------------------------
table-border：全セルボーダー囲み
table-border2：横ドットボーダー
------------------------------------------------------------*/

.table-border,
.table-border2 {
	border-bottom: 1px solid #ccc;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
}

.table-border thead>tr>th,
.table-border thead>tr>td,
.table-border2 thead>tr>th,
.table-border2 thead>tr>td {
	border-top: 1px solid #ccc;
	border-bottom: 2px solid #ccc;
	vertical-align: bottom;
}

.table-border tr>th,
.table-border tr>td {
	border-right: 1px solid #ddd;
}

.table-border2 tr>th,
.table-border2 tr>td {
	border-right: 1px dotted #ddd;
}

.table-border tbody>tr>th:last-child,
.table-border tbody>tr>td:last-child .table-border2 tbody>tr>th:last-child,
.table-border2 tbody>tr>td:last-child {
	border-right: 1px solid #ccc;
}


/*------------------------------------------------------------
table-noborder：ボーダーなし
------------------------------------------------------------*/

.table-noborder {
	border-top: none;
	border-bottom: none;
}

.table-noborder thead>tr>th,
.table-noborder thead>tr>td {
	border: none;
}

.table-noborder tr>th,
.table-noborder tr>td {
	border: none;
}

.table-noborder tbody>tr>td,
.table-noborder tbody>tr>th {
	border: none;
}

/*hoverなし*/
.table-noborder thead>tr:hover,
.table-noborder tbody>tr:hover {
	background-color: transparent;
}


/*------------------------------------------------------------
しましま
------------------------------------------------------------*/

.table-striped tbody tr:nth-child(odd) td,
.table-striped tbody tr:nth-child(odd) th {
	background-color: #ecf0f1;
}


/*------------------------------------------------------------
縦罫アリ／左一列のみ色つきテーブル
**機能一覧／お知らせ等に利用
------------------------------------------------------------*/

.table-colorLeftTH {
	border-left: 1px solid #ddd;
	border-right: 1px solid #ddd;
}

.table-colorLeftTH tbody>tr>td,
.table-colorLeftTH tbody>tr>th,
.table-colorLeftTH thead>tr>th {
	border-left: 1px dotted #ddd;
}

.table-colorLeftTH tbody>tr>th,
.table-colorLeftTH thead>tr>th:first-child {
	background-color: #f7eaea;
}


/*------------------------------------------------------------
セルの高さが低いもの（ネストテーブルなどに利用）
------------------------------------------------------------*/

.table-narrow td,
.table-narrow th {
	padding: 3px 8px;
}


/*------------------------------------------------------------
フォント大きい版
------------------------------------------------------------*/

.table-fontL tbody>tr>td,
.table-fontL tbody>tr>th,
.table-fontL thead>tr>th {
	font-size: 1rem;
}


/*------------------------------------------------------------
価格用（外枠2px）：新テーマ時に修正 2014/07/30 16:36
------------------------------------------------------------*/

.table-frame2px {
	border-width: 2px;
	border-color: #ccc;
	margin-bottom: 5px;
}

.table-frame2px+.mod-sup_info {
	margin-top: 20px;
}


/*------------------------------------------------------------
ボーダーの色#999
------------------------------------------------------------*/

.mod-tableBase.table-bdc9,
.mod-tableBase.table-bdc9 td,
.mod-tableBase.table-bdc9 th {
	border-color: #999;
}


.mod-tableBase.table-bdc9 {
	border-left: 1px solid #999;
	border-right: 1px solid #999;
}


/*------------------------------------------------------------
グレード表
------------------------------------------------------------*/

table.table-mark>thead>tr>th,
table.table-mark>tbody>tr>td {
	text-align: center;
	vertical-align: middle;
}


/*------------------------------------------------------------
hoverなし
------------------------------------------------------------*/

.table-noHover thead>tr:hover,
.table-noHover tbody>tr:hover {
	background-color: transparent;
}


/*------------------------------------------------------------
セルに斜線
------------------------------------------------------------*/

.mod-tableBase tr>th.right_up_border {
	background-image: linear-gradient(to top right,
			transparent 49.5%,
			#DDD 49.5%,
			#DDD 50%,
			transparent 50%,
			transparent);
}


/* =========================================================
ページフォーマット
========================================================= */

/***************************************************************
複数ページ共通スタイル
***************************************************************/

/*------------------------------------------------------------
ナンバーセクション
------------------------------------------------------------*/

.num_section {
	margin-top: 40px;
	padding-top: 60px;
	background: url(../images/old/separate_gradation.png) no-repeat center 0;
}

.num_section h4 {
	margin: 20px 0 1em -3px;
	font-size: 2.8em;
	font-weight: normal;
	color: #333;
}

.num_section h4.num:first-letter {
	margin-right: 0.5em;
	padding: 0 0.5em 0.2em;
	color: #fff;
	font-size: 0.9em;
	background: url(../images/old/dropcap_maru_l.png) center center no-repeat;
}

.num_section .mainimg {
	float: right;
	margin: 8px 0 25px 30px;
}

.num_block {
	margin: 40px 0;
}

.num_block h5 {
	margin: 0 0 10px 0;
	color: #333;
	font-size: 1.9rem;
	line-height: 1.4;
}


/*------------------------------------------------------------
★ナンバーセクションを１階層下で利用する場合
	セパレート画像なし／フォントサイズ小さめ
	例：トップ大見出しの内容 等
------------------------------------------------------------*/

.child_section .num_section,
.child_section .num_block {
	margin: 0 0 20px 0;
	padding-top: 20px;
	background: none;
}

.child_section .num_section h4 {
	margin: 20px 0 0 -3px;
	font-size: 2.4em;
	font-weight: normal;
	color: #333;
}

.child_section .num_section h4.num:first-letter {
	background: url(../images/old/dropcap_maru_m.png) center center no-repeat;
}

.child_section .num_section .mainimg {
	float: right;
	margin: 8px 0 0 30px;
}


/*------------------------------------------------------------
シンプルナンバーセクション：見出しに丸つき数字がつくだけ
------------------------------------------------------------*/

.simple_num_section h4 {
	font-size: 2.4em;
	font-weight: normal;
	margin: 0 0 0.5em -3px;
}

.simple_num_section h4:first-letter {
	margin-right: 0.4em;
	padding: 2px 10px;
	color: #fff;
	font-size: 0.95em;
	background: url(../images/old/dropcap_maru.png) center center no-repeat;
}

.simple_num_section p+h4 {
	margin-top: 1em;
}


/*------------------------------------------------------------
体験版誘導ボタン
------------------------------------------------------------*/

.toTrial .btnBase {
	padding: 15px;
	font-size: 1.8em;
}

.toTrial .btnBase strong {
	color: #fff;
}

.toTrial .ex-arrow2 {
	background-image: url(../images/old/base_arrow.svg);
	background-repeat: no-repeat;
	background-position: 95% center;
}

.toTrial .ex-arrow2.size30 {
	-webkit-background-size: 30px 30px;
	background-size: 30px 30px;
}


/*------------------------------------------------------------
TOPの新着表示
------------------------------------------------------------*/

.update_area {
	margin-right: 20px;
	padding: 40px;
	border: 1px solid #ddd;
}

.news_area {
	float: right;
	width: 85%;
}

.update_area .product_ver {
	color: #D83500;
}

.update_area p {
	font-size: 1.6rem;
	font-weight: bold;
}

.update_area .update_sbj {
	float: left;
	margin-left: 0.5em;
}

.update_area .update_sbj li {
	list-style-type: none;
	line-height: 2;
}

.update_area .update_sbj i {
	margin-right: 0.5em;
}


/*------------------------------------------------------------
トップヘッダ
------------------------------------------------------------*/

#solutionTop_header {
	position: relative;
	height: 100%;
	background-size: cover !important;
}

#solutionTop_header .headerContent {
	display: flex;
	column-gap: 30px;
	height: 100%;
	padding-top: 75px;
	background-size: cover !important;
}

#solutionTop_header .headerTitle h2 {
	margin-top: 20px;
}

#solutionTop_header .headerTitle p {
	margin-top: 20px;
	font-size: 1.4em;
	color: #FFF;
}

#solutionTop_header .headerTxt {
	margin-left: 0 !important;
	padding-top: 50px;
	color: #fff;
}

#solutionTop_header .headerTxt dl dt {
	float: left;
	width: 80px;
	margin-top: 5px;
	margin-right: 12px;
	padding: 1.1em 0;
	text-align: center;
	background-color: #fff;
	font-size: 14px;
	font-weight: bold;
}

#solutionTop_header .headerTxt dl dd h3 {
	font-size: 19px !important;
	font-weight: bold;
	vertical-align: top;
	line-height: 1.75;
}

#solutionTop_header .headerTxt dl dd {
	margin-bottom: 1.2em;
}

#solutionTop_header .headerTxt dl dd p {
	font-size: 15px;
}

#solutionTop_header .headerImg .headerTxt p.dfBtn {
	text-align: right;
	margin-top: 15px;
}

#storm-maker .headerTxt dl dd {
	color: #333;
}

#storm-maker .headerTxt dl dt {
	background-color: #333;
	color: #fff;
}


/*------------------------------------------------------------
ふきだし
------------------------------------------------------------*/

.voice-balloon-bottom,
.voice-balloon {
	position: relative;
	display: inline-block;
	margin-bottom: 10px;
	padding: 20px;
	width: auto;
	line-height: 1.4;
	color: #19283C;
	background: #ddefd8;
	z-index: 0;
	border-radius: 20px;
}

.voice-balloon.bottom:after {
	content: "";
	position: absolute;
	bottom: -10px;
	left: 50%;
	margin-left: -10px;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 10px 10px 0 10px;
	border-color: #ddefd8 transparent transparent transparent;
	z-index: -1;
}

.voice-balloon.left:after {
	content: "";
	position: absolute;
	top: 50%;
	left: -10px;
	margin-top: -10px;
	display: block;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 10px 10px 10px 0;
	border-color: transparent #ddefd8 transparent transparent;
}

.voice-balloon-bottom p:last-child,
.voice-balloon p:last-child {
	margin-bottom: 0;
}

.voice-balloon-bottom .photo img,
.voice-balloon .photo img {
	width: 60px;
	height: 60px;
	border-radius: 50%;
	float: left;
	margin: 0 15px 0 0;
}


/**********************************************
丸い画像
**********************************************/

img.circle {
	width: 60px;
	height: 60px;
	border-radius: 50%;
	border: 1px solid #CCC;
}


/**********************************************
なにかが終了するときのメッセージ欄
**********************************************/

.close {
	border: 5px solid #ffb3b3;
	padding: 1rem 1rem 0.5rem 1rem;
	margin-bottom: 20px;
	font-size: 1.4em;
}


/**********************************************
プランごとの色指定
**********************************************/

.colorS {
	color: #A8C57C;
}

.bgS {
	background-color: #e4edd6;
}

.colorM {
	color: #87B4AE;
}

.bgM {
	background-color: #dde9e8;
}

.colorL {
	color: #E9B1AB;
}

.bgL {
	background-color: #fae0e0;
}

.colorXL {
	color: #BEA3D4;
}

.bgXL {
	background-color: #e1cfee;
}

.colorXXL {
	color: #E8B46B;
}

.bgXXL {
	background-color: #FFDEAD;
}

.bg_p_color2 {
	background-color: #f7eaea;
}


/**********************************************
Webフォント
**********************************************/

.wf-hannari {
	font-family: "Hannari";
}


/**********************************************
Bootstrap風
**********************************************/

/* グリッドシステム */
.row {
	display: flex;
	flex-wrap: wrap;
}

.align-items-start {
	align-items: flex-start;
}

.align-items-center {
	align-items: center;
}

.align-items-end {
	align-items: flex-end;
}

.align-items-stretch {
	align-items: stretch;
}

.col-1 {
	-ms-flex: 0 0 8.333333%;
	flex: 0 0 8.333333%;
	max-width: 8.333333%;
	width: 8.333333%;
}

.col-2 {
	-ms-flex: 0 0 16.666667%;
	flex: 0 0 16.666667%;
	max-width: 16.666667%;
	width: 16.666667%;
}

.col-3 {
	-ms-flex: 0 0 25%;
	flex: 0 0 25%;
	max-width: 25%;
	width: 25%;
}

.col-4 {
	-ms-flex: 0 0 33.333333%;
	flex: 0 0 33.333333%;
	max-width: 33.333333%;
	width: 33.333333%;
}

.col-5 {
	-ms-flex: 0 0 41.666667%;
	flex: 0 0 41.666667%;
	max-width: 41.666667%;
	width: 41.666667%;
}

.col-6 {
	-ms-flex: 0 0 50%;
	flex: 0 0 50%;
	max-width: 50%;
	width: 50%;
}

.col-7 {
	-ms-flex: 0 0 58.333333%;
	flex: 0 0 58.333333%;
	max-width: 58.333333%;
	width: 58.333333%;
}

.col-8 {
	-ms-flex: 0 0 66.666667%;
	flex: 0 0 66.666667%;
	max-width: 66.666667%;
	width: 66.666667%;
}

.col-9 {
	-ms-flex: 0 0 75%;
	flex: 0 0 75%;
	max-width: 75%;
	width: 75%;
}

.col-10 {
	-ms-flex: 0 0 83.333333%;
	flex: 0 0 83.333333%;
	max-width: 83.333333%;
	width: 83.333333%;
}

.col-11 {
	-ms-flex: 0 0 91.666667%;
	flex: 0 0 91.666667%;
	max-width: 91.666667%;
	width: 91.666667%;
}

.col-12 {
	-ms-flex: 0 0 100%;
	flex: 0 0 100%;
	max-width: 100%;
	width: 100%;
}

/* Sizing */
.w-25 {
	width: 25% !important;
}

.w-50 {
	width: 50% !important;
}

.w-75 {
	width: 75% !important;
}

.w-100 {
	width: 100% !important;
}

.w-auto {
	width: auto !important;
}

/* Spacing */
.mt-0 {
	margin-top: 0 !important;
}

.mt-1 {
	margin-top: 0.25rem !important;
}

.mt-2 {
	margin-top: 0.5rem !important;
}

.mt-3 {
	margin-top: 0.75rem !important;
}

.mt-4 {
	margin-top: 1.5rem !important;
}

.mt-5 {
	margin-top: 3rem !important;
}

.mb-0 {
	margin-bottom: 0 !important;
}

.mb-1 {
	margin-bottom: 0.25rem !important;
}

.mb-2 {
	margin-bottom: 0.5rem !important;
}

.mb-3 {
	margin-bottom: 0.75rem !important;
}

.mb-4 {
	margin-bottom: 1.5rem !important;
}

.mb-5 {
	margin-bottom: 3rem !important;
}

.ml-0 {
	margin-left: 0 !important;
}

.ml-1 {
	margin-left: 0.25rem !important;
}

.ml-2 {
	margin-left: 0.5rem !important;
}

.ml-3 {
	margin-left: 0.75rem !important;
}

.ml-4 {
	margin-left: 1.5rem !important;
}

.ml-5 {
	margin-left: 3rem !important;
}

.mr-0 {
	margin-right: 0 !important;
}

.mr-1 {
	margin-right: 0.25rem !important;
}

.mr-2 {
	margin-right: 0.5rem !important;
}

.mr-3 {
	margin-right: 0.75rem !important;
}

.mr-4 {
	margin-right: 1.5rem !important;
}

.mr-5 {
	margin-right: 3rem !important;
}

.mx-0 {
	margin-right: 0 !important;
	margin-left: 0 !important;
}

.mx-1 {
	margin-right: 0.25rem !important;
	margin-left: 0.25rem !important;
}

.mx-2 {
	margin-right: 0.5rem !important;
	margin-left: 0.5rem !important;
}

.mx-3 {
	margin-right: 0.75rem !important;
	margin-left: 0.75rem !important;
}

.mx-4 {
	margin-right: 1.5rem !important;
	margin-left: 1.5rem !important;
}

.mx-5 {
	margin-right: 3rem !important;
	margin-left: 3rem !important;
}

.my-0 {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

.my-1 {
	margin-top: 0.25rem !important;
	margin-bottom: 0.25rem !important;
}

.my-2 {
	margin-top: 0.5rem !important;
	margin-bottom: 0.5rem !important;
}

.my-3 {
	margin-top: 0.75rem !important;
	margin-bottom: 0.75rem !important;
}

.my-4 {
	margin-top: 1.5rem !important;
	margin-bottom: 1.5rem !important;
}

.my-5 {
	margin-top: 3rem !important;
	margin-bottom: 3rem !important;
}

.pt-0 {
	padding-top: 0 !important;
}

.pt-1 {
	padding-top: 0.25rem !important;
}

.pt-2 {
	padding-top: 0.5rem !important;
}

.pt-3 {
	padding-top: 0.75rem !important;
}

.pt-4 {
	padding-top: 1.5rem !important;
}

.pt-5 {
	padding-top: 3rem !important;
}

.pb-0 {
	padding-bottom: 0 !important;
}

.pb-1 {
	padding-bottom: 0.25rem !important;
}

.pb-2 {
	padding-bottom: 0.5rem !important;
}

.pb-3 {
	padding-bottom: 0.75rem !important;
}

.pb-4 {
	padding-bottom: 1.5rem !important;
}

.pb-5 {
	padding-bottom: 3rem !important;
}

.pl-0 {
	padding-left: 0 !important;
}

.pl-1 {
	padding-left: 0.25rem !important;
}

.pl-2 {
	padding-left: 0.5rem !important;
}

.pl-3 {
	padding-left: 0.75rem !important;
}

.pl-4 {
	padding-left: 1.5rem !important;
}

.pl-5 {
	padding-left: 3rem !important;
}

.pr-0 {
	padding-right: 0 !important;
}

.pr-1 {
	padding-right: 0.25rem !important;
}

.pr-2 {
	padding-right: 0.5rem !important;
}

.pr-3 {
	padding-right: 0.75rem !important;
}

.pr-4 {
	padding-right: 1.5rem !important;
}

.pr-5 {
	padding-right: 3rem !important;
}

.px-0 {
	padding-right: 0 !important;
	padding-left: 0 !important;
}

.px-1 {
	padding-right: 0.25rem !important;
	padding-left: 0.25rem !important;
}

.px-2 {
	padding-right: 0.5rem !important;
	padding-left: 0.5rem !important;
}

.px-3 {
	padding-right: 0.75rem !important;
	padding-left: 0.75rem !important;
}

.px-4 {
	padding-right: 1.5rem !important;
	padding-left: 1.5rem !important;
}

.px-5 {
	padding-right: 3rem !important;
	padding-left: 3rem !important;
}

.py-0 {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

.py-1 {
	padding-top: 0.25rem !important;
	padding-bottom: 0.25rem !important;
}

.py-2 {
	padding-top: 0.5rem !important;
	padding-bottom: 0.5rem !important;
}

.py-3 {
	padding-top: 0.75rem !important;
	padding-bottom: 0.75rem !important;
}

.py-4 {
	padding-top: 1.5rem !important;
	padding-bottom: 1.5rem !important;
}

.py-5 {
	padding-top: 3rem !important;
	padding-bottom: 3rem !important;
}

/*------------------------------------------------------------
フォントユーティリティ
------------------------------------------------------------*/

/*フォントサイズ*/
.fz-12r {
	/* font-size: 1.2rem !important; */
	font-size: 0.75rem !important;
}

.fz-14r {
	/* font-size: 1.4rem !important; */
	font-size: 0.875rem !important;
}

.fz-16r {
	/* font-size: 1.6rem !important; */
	font-size: 1rem !important;
}

.fz-18r {
	/* font-size: 1.8rem !important; */
	font-size: 1.125rem !important;
}

.fz-20r {
	/* font-size: 2.0rem !important; */
	font-size: 1.25rem !important;
}

.fz-24r {
	/* font-size: 2.4rem !important; */
	font-size: 1.4rem !important;
}

.fz-28r {
	/* font-size: 2.8rem !important; */
	font-size: 1.75rem !important;
}

.fz-32r {
	/* font-size: 3.2rem !important; */
	font-size: 2rem !important;
}

.fz-40r {
	/* font-size: 4rem !important; */
	font-size: 2.5rem !important;
}

/*line-height*/
.lh-15 {
	line-height: 1.5 !important;
}

/*ウェイト*/
.fw-bold {
	font-weight: bold !important;
}

.fw-normal {
	font-weight: normal !important;
}

/*セリフ*/
.ff-serif {
	font-family: 游明朝, YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", HG明朝E, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}


/****************************************************
装飾
****************************************************/

/*後ろに線
--------------------------------*/

.after-line {
	display: inline-block;
	position: relative;
	padding: 0 2rem 0 0;
	background-color: #fff;
}

.after-line-wrap {
	position: relative;
}

.after-line-wrap:before {
	display: block;
	width: 100%;
	height: 1px;
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	content: '';
	background-color: #999;
}

/*丸R用に
--------------------------------*/
.maruR {
	vertical-align: sub;
	font-size: 0.8em;
}


/****************************************************
パーツ
****************************************************/
/* ナビゲーション */
.nav {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	padding-left: 0;
	margin-bottom: 0;
	list-style: none;
}

.nav-link {
	display: block;
	padding: 0.75rem 1.5rem;
}

a.nav-link,
.nav-link:hover,
.nav-link:focus {
	text-decoration: none;
}

.nav-link.disabled {
	color: #6c757d;
	pointer-events: none;
	cursor: default;
}

/* タブ */
ul.nav-tabs {
	margin-left: 0;
}

.nav-tabs {
	border-bottom: 1px solid #dee2e6;
}

.nav-tabs .nav-item {
	margin-bottom: -1px;
}

.nav-tabs .nav-link {
	border: 1px solid transparent;
	border-color: #e9ecef #e9ecef #dee2e6;
	border-top-left-radius: 0.4rem;
	border-top-right-radius: 0.4rem;
	background-color: #efefef;
}

.nav-tabs .nav-link:hover,
.nav-tabs .nav-link:focus {
	border-color: #e9ecef #e9ecef #dee2e6;
}

.nav-tabs .nav-link.disabled {
	color: #6c757d;
	background-color: transparent;
	border-color: transparent;
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
	color: #495057;
	background-color: #fff;
	border-color: #dee2e6 #dee2e6 #fff;
}

.nav-tabs .dropdown-menu {
	margin-top: -1px;
	border-top-left-radius: 0;
	border-top-right-radius: 0;
}


/**********************************************
丸R用に
**********************************************/

.maruR {
	vertical-align: sub;
	font-size: 0.8em;
}


/**********************************************
Call to Action エリア
**********************************************/

.cta {
	margin: 50px auto;
	padding: 80px 0;
	background: url(../images/old/separate_gradation.png) no-repeat center top, url(../images/old/separate_gradation_bottom.png) no-repeat center bottom;
	text-align: center;
}

.cta .btnBase.accent {
	padding-top: 1.2em;
	padding-bottom: 1.3em;
	background-color: #e62802;
	line-height: 1.4;
}

.cta .btnBase.accent:hover {
	background-color: #fa3c07;
}


/**********************************************
追加
**********************************************/

.l-content p {
	line-height: var(--lw-line-height-lg);
}

.l-content em {
	color: #D83300;
	font-weight: normal;
}

.l-content img {
	display: unset;
}

.l-content .p_color {
	color: #576790;
}

.l-content .marker3 {
	background: linear-gradient(transparent 60%, #F0F27E 40%);
}

/*引用デザイン*/
.l-content blockquote {
	position: relative;
	padding: 4rem 2rem 2rem 2rem;
	border: 1px dotted #ccc;
	color: #666;
	/* font-size: 1.4rem; */
	margin-bottom: 2rem;
	line-height: 1.8;
}

.l-content blockquote:before {
	font-family: "Font Awesome 5 Free";
	content: "\f10d";
	display: inline-block;
	position: absolute;
	top: 12px;
	left: 2rem;
	color: #ddd;
	font-size: 20px;
	font-weight: 600;
	line-height: 1;
}

.l-content blockquote:after {
	font-family: "Font Awesome 5 Free";
	content: "\f10e";
	display: inline-block;
	position: absolute;
	bottom: 15px;
	right: 2rem;
	color: #ddd;
	font-size: 20px;
	font-weight: 600;
	line-height: 1;
}

.l-content blockquote cite {
	font-size: 13px;
	text-align: left;
	color: #666;
	font-style: italic;
}
