@charset "UTF-8";
/*====================================

	----------------------------------
		Structure
	----------------------------------

	0. General
	1. Header
	2. Main
	3. Footer
	4. Page

	----------------------------------
		Change Log
	----------------------------------

	-2021/03/01	Fixed all

====================================*/


@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');

/*====================================

	0. General

====================================*/
html { font-size: 62.5%; }
body { position: relative; background: #ffffff; color: #202020; font-weight: 500; font-size: 1.0rem; font-family: 'Noto Sans JP', sans-serif; }
img { width: 100%; height: auto; vertical-align: bottom; }
a { color: #202020; text-decoration: none; cursor: pointer; }
	a:hover { opacity: 0.8; }
input[type=submit] { cursor: pointer; }
ul,
ol { list-style: none; }
.pcOnly { display: none !important; }
#page-top { position: fixed; right: 5vw; bottom: 5vw; z-index: 3; }
#page-top a { display: block; width: 10vw; height: 10vw; background: url("/common/img/icon_pagetop.png") no-repeat 0 0 / 10vw auto; text-align: center; text-indent: -9999px; }


/*====================================

	1. Header

====================================*/
header { position: relative; height: 22vw; }
#l-header_logo { padding: 3vw 0 0 3vw; }
#l-header_logo img { width: 76vw; height: auto; }
#panel-btn { position: absolute; top: 5vw; right: 4vw; z-index: 2000; display: inline-block; width: 11vw; height: 11vw; background: #026093; text-indent: -9999px; } 
#panel-btn.cls { background: #ffffff; }
#panel-btn-icon { position: absolute; top: 50%; left: 50%; display: block; margin: -0.3vw 0 0 -2.3vw; width: 4.6vw; height: 0.6vw; background: #ffffff; transition: .2s; } 
#panel-btn-icon:before,
#panel-btn-icon:after { position: absolute; top: 50%; left: 0; display: block; width: 4.6vw; height: 0.6vw; background: #ffffff; content: ""; transition: .3s; } 
#panel-btn-icon:before { margin-top: -2.1vw; }
#panel-btn-icon:after { margin-top: 1.8vw; } 
#panel-btn .close { background: transparent; }
#panel-btn .close:before,
#panel-btn .close:after { margin-top: 0; } 
#panel-btn .close:before { -webkit-transform: rotate(-45deg); transform: rotate(-45deg); } 
#panel-btn .close:after { -webkit-transform: rotate(-135deg); transform: rotate(-135deg); } 
.gnav { position: absolute; top: 22vw; z-index: 1000; display: none; width: 100%; background: #fff; font-size: 4vw; padding: 5vw; box-shadow: 0 0 5px rgba(0,0,0,0.5); }
#l-header_cmn {}
#l-header_cmn > ul > li { border-bottom: 0.2vw solid #000; }
#l-header_cmn > ul > li > a { display: block; padding: 3vw 0; }
#l-header_sub { text-align: center; }
#l-header_sub ul { margin: 10vw 0; }
#l-header_sub li { margin-top: 4vw; }
#l-header_sub .button { display: block; }
#l-header_sub p img { width: 70vw; }



/*====================================

	2. Main

====================================*/
main { position: relative; font-size: 3.8vw; line-height: 1.4; }
main.tile { background: url("/common/img/bg_tile.png") repeat 0 0 / 20vw auto; padding-bottom: 8vw; }
main a { text-decoration: underline; }
main a:hover { text-decoration: none; }



/*====================================

	3. Footer

====================================*/
footer { padding: 5vw; background: #f0f0f0; font-size: 3.4vw; }
.leftBlock { }
.leftBlock dl { padding-top: 12px; border-top: 0.2vw solid #000; }
.leftBlock dt { float: left; }
.leftBlock dd { margin-bottom: 12px; padding: 0 0 12px 120px; border-bottom: 0.2vw solid #000; }
.rightBlock { }
.rightBlock ul { display: -webkit-flex; display: flex; margin: 1em 0; flex-wrap: wrap; }
.rightBlock li { margin-right: 1.5em; }
.rightBlock p { }
#footerLogo img { margin-bottom: 3vw; height: auto; }
#l-footer_sub ul { margin: 0; }
#l-footer_sub li:nth-child(1),
#l-footer_sub li:nth-child(2){ margin-right: 3vw; width: 42vw; }
#l-footer_sub li:nth-child(3) { margin-top: 1em; }
#l-footer_sub .button { display: block; }



/*====================================

	4. page

====================================*/

/*-----------------------------------------------------
Common
------------------------------------------------------*/
/*
	Title
------------------------------------------------------*/
.title00 { display: -webkit-flex; display: flex; margin-bottom: 5vw; padding: 5vw 5vw; height: 40vw; background: #000 url("/common/img/bg_title.png") repeat-x 50% 100% / cover; color: #fff; box-shadow: 0 1vw 1vw 0 rgba(0,0,0,0.2) inset; text-align: center; font-weight: 700; font-size: 7vw; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
.title00L { background: #000 url("/common/img/bg_title_l.png") no-repeat 50% 50% / cover; height: 60vw; padding: 15vw 5vw 0; text-align: center; }
.title01 { border-bottom: 0.4vw solid #026093; }
.title01 span { display: inline-block; padding: 0.2em 0.8em; background: #026093; color: #fff; font-size: 5vw; }
.title02 { font-weight: 700; font-size: 4vw; }
.title03 { font-weight: 700; font-size: 4.2vw;; }
.title03:before { color: #026093; content: "■"; }
.titleBB { padding-bottom: 0.2em; border-bottom: 0.4vw solid #026093; }
/*
	Text
------------------------------------------------------*/
main p { margin: 1em 0; line-height: 1.6; }
main small { font-size: 80% !important; }
.komeTxt { padding-left: 1em; text-indent: -1em; }
.komeNumTxt { padding-left: 2em; text-indent: -2em; }
.kakkoTxt { padding-left: 3em; list-style: none inside; text-indent: -3em; }
.taR { text-align: right !important; }
.taL { text-align: left !important; }
.taC { text-align: center !important; }
.fwB { font-weight: 900; }
.block { display: block !important; }
.c_white { color: #fff; }
.c_red { color: #e60012; }
.required { display: inline-block; margin-right: 0.6em; padding: 1vw 3vw; background: #e60012; color: #fff; font-size: 2.8vw; }
.optional { display: inline-block; margin-right: 0.6em; padding: 1vw 3vw; background: #026093; color: #fff; font-size: 2.8vw; }
/*
	Image
------------------------------------------------------*/
figure { margin: 0.5em 0; text-align: center; }
figure.gray { padding: 5vw; background: #f0f0f0; }
figure.bBlue { padding: 5vw 3vw; border: 0.6vw solid #026093; background: #fff; }
figure img { max-width: 100%; height: auto; }
/*
	List
------------------------------------------------------*/
main ol,
main ul { margin: 1em 0; }
.discList { margin: 1em 0; list-style: none; }
.discList > li { position: relative; padding-left: 1em; }
.discList > li:before { position: absolute; top: 0; left: 0; content: "・"; }
.decimalList { margin: 1em 0 1em 1.5em; list-style: decimal; }
.circleList { margin: 1em 0 1em 1.5em; list-style: circle; }
.alphaUList { margin: 1em 0 1em 1.5em; list-style: upper-alpha; }
.alphaLList { margin: 1em 0 1em 1.5em; list-style: lower-alpha; }
.squareLList { margin: 1em 0 1em 1.5em; list-style: square; }
.katakanaList { margin: 1em 0 1em 1.5em; list-style: katakana; }
.irohaList { margin: 1em 0 1em 1.5em; list-style: katakana-iroha; }
.romanList { margin: 1em 0 1em 1.5em; list-style: upper-roman; }
.kakkoList { margin: 1em 0; padding-left: 2.5em; list-style: none inside; text-indent: -2.5em; }
	.kakkoList > li { counter-increment: cnt; }
	.kakkoList > li:before { display: marker; content: "（" counter(cnt) "）"; }
	.kakkoList > li * { text-indent: 0; }
.komeList { margin: 1em 0; text-indent: 0; }
	.komeList > li { padding-left: 1em; text-indent: -1em; }
.komeNumList { margin: 1em 0; }
	.komeNumList > li { padding-left: 2em; text-indent: -2em; }
	.komeNumList > li * { text-indent: 0; }
main ol ol,
main ol ul,
main ul ol,
main ul ul { margin-top: 0 !important; margin-bottom: 0 !important; }
/*
	Icon
------------------------------------------------------*/
.icon { position: relative; display: inline-block; padding-left: 1.5em; text-decoration: none; }
.icon:before { position: absolute; top: 0; left: 0; width: 1.4em; height: 1.4em; content: ""; }

.icon.arrowBlue:before { background: url("/common/img/icon_arrow_blue.png") no-repeat 0 0 / auto 1.2em; }
.icon.arrowBlueBottom:before { background: url("/common/img/icon_arrow_blue.png") no-repeat 0 0 / auto 1.2em; transform: rotate(90deg); }
/*
	Button
------------------------------------------------------*/
.btnBlock { margin: 8vw 0; text-align: center; }

.button { position: relative; display: inline-block; text-align: center; text-decoration: none; line-height: 1.1; }
.button:before { position: absolute; top: 0; right: 1em; bottom: 0; margin: auto; width: 1.4em; height: 1.4em; content: ""; }
.button.green,
.button.orange,
.button.blue { padding: 1vw; background: -webkit-linear-gradient(90deg, rgba(201,201,201,1) 0%, rgba(255,255,255,1) 50%, rgba(201,201,201,1) 100%); background: linear-gradient(90deg, rgba(201,201,201,1) 0%, rgba(255,255,255,1) 50%, rgba(201,201,201,1) 100%); }
.button.green span { display: block; padding: 3vw; background: #009c74; color: #fff; font-weight: 700; font-size: 1.5rem; }
.button.orange span { display: block; padding: 3vw; background: #ef7c00; color: #fff; font-weight: 700; font-size: 1.5rem; }
.button.blue { margin: 0 2vw; }
.button.blue span { position: relative; display: inline-block; padding: 5vw 14vw; background: #026093; color: #fff; font-weight: 700; font-size: 5vw; }
.button.blue span:before { position: absolute; top: 0; right: 1em; bottom: 0; margin: auto; width: 5vw; height: 5vw; background: url("/common/img/icon_arrow.png") no-repeat 0 0 / 5vw auto; content: ""; }
.button.blue.back span:before { position: absolute; top: 0; right: auto; bottom: 0; left: 1em; margin: auto; width: 5vw; height: 5vw; background: url("/common/img/icon_arrow.png") no-repeat 0 0 / 5vw auto; content: ""; transform: rotate(180deg); }
.button.blank span:before { position: absolute; top: 0; right: 1em; bottom: 0; margin: auto; width: 5vw; height: 5vw; background: url("/common/img/icon_blank.png") no-repeat 0 0 / 5vw auto; content: ""; }

/*
	Marker
------------------------------------------------------*/
marker { }
marker.lightYellow { background: linear-gradient(transparent 80%, #ffcc00 80%); }
marker.thinRed { background: linear-gradient(transparent 90%, #e60012 90%); }
marker.red { background: linear-gradient(transparent 0%, #e60012 0%); color: #fff; }
/*
	Table
------------------------------------------------------*/
table { margin: 1em 0; width: 100%; border-collapse: collapse; }
table ol,
table ul { margin: 0; }
/*
	Columns
------------------------------------------------------*/
.column.sp { display: -webkit-flex; display: flex; flex-wrap: wrap; }
.column.sp.space-between { -webkit-justify-content: space-between; justify-content: space-between; }
.column.sp.justify-center { -webkit-justify-content: center; justify-content: center; }
.column.sp.align-items-center { -webkit-align-items: center; align-items: center; }


/*
	Block
------------------------------------------------------*/
section { margin: 0 5vw; }

.checkBlock { margin-top: 10vw; }
.checkBlock dl { border: 0.4vw solid #e60012; background: #fff; }
.checkBlock dt { margin: -4vw 0 0 -0.4vw; font-weight: 700; font-size: 4.2vw; line-height: 1; }
.checkBlock dt span { position: relative; display: inline-block; padding: 2.8vw 1vw 2.8vw 13vw; background: #e60012; color: #fff; }
.checkBlock dt span:before { position: absolute; top: 0; bottom: 0; left: 2vw; margin: auto; width: 10vw; height: 10vw; background: url("/common/img/icon_check.png") no-repeat 50% 50% / 10vw auto; content: ""; }
.checkBlock dt span:after { position: absolute; top: 0; right: -5vw; bottom: 0; margin: auto; width: 0; height: 0; border-top: 5vw solid transparent; border-bottom: 5vw solid transparent; border-left: 5vw solid #e60012; content: ""; }
.checkBlock dd { padding: 4vw; }
.checkBlock dd em { font-weight: 700; font-style: normal; font-size: 4.2vw; display: inline-block; margin-bottom: 0.4em; }
.checkBlock dd figure { margin-top: 5vw; }


/*-----------------------------------------------------
Top
------------------------------------------------------*/
.topBlock01 { margin-top: -12vw; }
.topBlock01 h2 { margin-bottom: 3vw; }
.topBlock01 h3 { margin-bottom: 6vw; }
.topBlock01 h3 span { border-bottom: 5px solid #f08300; display: inline-block; font-size: 5vw; }
.topBlock01 .arrow { position: relative; font-weight: 700; font-size: 5vw; padding-top: 8vw; text-align: center; }
.topBlock01 .arrow:before { position: absolute; top: 0; right: 0; left: 0; margin: auto; width: 0; height: 0; border-top: 7vw solid #f08300; border-right: 7vw solid transparent; border-left: 7vw solid transparent; content: ""; }

.topBlock01 dl { border: 0.2vw solid #000; background: #fff; margin: 6vw 0 8vw; }
.topBlock01 dt { background: #dcdddd; padding: 5vw; font-size: 4.4vw; text-align: center; }
.topBlock01 dd { padding: 5vw; text-align: center; }
.topBlock02 .btnBlock li { margin-top: 3vw; }
.topBlock02 .button.blue span { width: 80vw; }


/*-----------------------------------------------------
threat
------------------------------------------------------*/
.threatBlock01 { margin-bottom: 10vw; }
.threatBlock01 .graph { text-align: center; }
.threatBlock01 .graph dt { margin-bottom: 2vw; color: #026093; font-size: 5vw; }
.threatBlock01 .graph dd { padding: 3vw; border: 0.4vw solid #026093; background: #fff; }
.threatBlock01 .arrow { position: relative; font-weight: 700; font-size: 5vw; padding-top: 8vw; text-align: center; }
.threatBlock01 .arrow:before { position: absolute; top: 0; right: 0; left: 0; margin: auto; width: 0; height: 0; border-top: 7vw solid #f08300; border-right: 7vw solid transparent; border-left: 7vw solid transparent; content: ""; }
.threatBlock02 .example { margin-bottom: 5vw; }
.threatBlock02 .example dt { margin-bottom: 3vw; padding: 2vw 4vw; border-left: 1vw solid #026093; background: #f0f0f0; font-size: 5vw; }
.threatBlock02 .example dd { line-height: 1.6; }
.threatBlock02 .example figure { margin-bottom: 2vw; }
.threatBlock02 td { padding: 2vw; border-bottom: 0.2vw solid #9fa0a0; }
.threatBlock02 .sum td { border-top: 3px solid #9fa0a0; border-bottom: none; font-weight: 700; }
.threatBlock02 .type01 { margin: 5vw 0; padding: 2vw 5vw; background: #f0f0f0; line-height: 1.6; }
.threatBlock02 .type02 { margin: 5vw 0 10vw; padding: 2vw 5vw; border: 0.8vw solid #e60012; background: #fff; text-align: center; line-height: 1.6; }
.threatBlock02 .type02 em { margin: 0 0.2em; font-weight: 700; font-style: normal; font-size: 6vw; }



/*-----------------------------------------------------
comparison
------------------------------------------------------*/
.comparisonBlock02 { padding: 5vw; background: #f0f0f0; }
.comparisonBlock02 h2 { margin-bottom: 0.6em; text-align: center; font-size: 5vw; }
.comparisonBlock02 .cyber01 { border: 0.5vw solid #009c74; margin-bottom: 5vw; }
.comparisonBlock02 .cyber01 dt { background: #009c74; }
.comparisonBlock02 .cyber02 { border: 0.5vw solid #026093; }
.comparisonBlock02 .cyber02 dt { background: #026093; }
.comparisonBlock02 dt { padding: 3vw; text-align: center; color: #fff; font-weight: 700; font-size: 5vw; line-height: 1.3; }
.comparisonBlock02 dd { padding: 5vw; text-align: center; }
.comparisonBlock02 figure { margin-top: 3vw; }
.comparisonBlock02 .button.green span { position: relative; display: inline-block; padding: 3vw 12vw 3vw 5vw; background: #009c74; color: #fff; font-weight: 700; font-size: 4vw; }


/*-----------------------------------------------------
about
------------------------------------------------------*/
.aboutBlock01 { margin-bottom: 8vw; }
.aboutBlock01 .cyber { border: 0.5vw solid #026093; }
.aboutBlock01 .cyber dt { text-align: center; color: #fff; background: #026093; font-weight: 700; font-size: 5vw; line-height: 1.3; padding: 3vw; }
.aboutBlock01 .cyber dd { padding: 5vw; text-align: center; }
.aboutBlock01 .cyber figure { margin-top: 3vw; }
.aboutBlock02 { margin-bottom: 8vw; }
.aboutBlock03 { margin-bottom: 8vw; }
.aboutBlock03 .point { margin: 5vw 0; padding: 5vw; background: #f0f0f0; }
.aboutBlock03 .point dt { font-size: 5vw; }
.aboutBlock03 .point dd { margin-top: 3vw; }
.aboutBlock03 .point figure { margin-top: 3vw; }
.aboutBlock04 { margin-bottom: 8vw; }


/*-----------------------------------------------------
content
------------------------------------------------------*/
.contentBlock01 .example { border: 0.4vw solid #026093; border-radius: 2vw; background: #fff; margin-bottom: 3vw; }
.contentBlock01 .example dt { padding: 0.4em; background: #026093; color: #fff; text-align: center; font-size: 5vw; }
.contentBlock01 .example dd { position: relative; padding: 0.2em 1em; color: #026093; font-size: 4.4vw; line-height: 1.6; }
.contentBlock01 .example dd:after { position: absolute; right: 4.4vw; bottom: 1em; content: "など"; }


/*-----------------------------------------------------
accident
------------------------------------------------------*/
.accidentBlock01 { }


/*-----------------------------------------------------
Request
------------------------------------------------------*/
.tableForm { width: 90vw; }
.tableForm th,
.tableForm td { display: block; }
.tableForm th { padding: 3vw; border: 0.2vw solid #9fa0a0; background: #f0f0f0; text-align: left; font-weight: normal; margin-top: -0.2vw;}
.tableForm td { padding: 3vw; border: 0.2vw solid #9fa0a0; vertical-align: middle; margin-top: -0.2vw; }
.tableForm input[type="text"],
.tableForm input[type="email"],
.tableForm input[type="tel"],
.tableForm input[type="url"] { padding: 2vw; width: 100%; border: 0.2vw solid #9fa0a0; }
.tableForm input.short { width: 180px; }
.tableForm label { margin-right: 1em; }
.tableForm textarea { margin: 0 !important; }
.tableForm .add_check{margin: .3em 0 .5em 1em; font-size: 90%;}
.tableForm .txt_atten{margin: 0 0 0 1em; font-size: 90%; text-indent: -1em;}

.formBlock01 { margin-top: 10vw; }
.formBlock01 textarea { margin: 1vw 0 !important; width: 100%; height: 30vw; border: 0.2vw solid #9fa0a0; }
.formBlock01 textarea.heightMin { height: 3em; }

.tableForm02 { }
.tableForm02 th,
.tableForm02 td { display: table-cell !important; }
.tableForm02 th { background: #e5eff4; text-align: center; }
.tableForm02 .noborder { border: none; }
#quote { display: none; }

.requestTelBlock{ margin:0 0 1em; padding: 2vw 3vw; border: 0.2vw solid #026093; }


/*-----------------------------------------------------
PDF DL
------------------------------------------------------*/
.pdfDlBox .pdfDlBox_item + .pdfDlBox_item{margin-top: 30px; padding-top: 30px; border-top: 1px dashed #ccc;}
.pdfDlBox .itemImg img{width: auto; max-width: 100%; border: 1px solid #ccc;}
.pdfDlBox .itemImg-pamphlet img{width: 140px;}
.pdfDlBox .itemImg-ppt{margin-top: 0;}
.pdfDlBox p{margin-bottom: 1.5em; line-height: 1.6; text-align: center;}
.pdfDlBox > p{text-align: left;}
.pdfDlBox .pdfDlBtn{position: relative; display: flex; align-items: center; justify-content: center; width: 265px; margin: 0 auto; padding: 15px 28px 15px 72px; border-radius: 10px; background: -webkit-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); color: #fff; font-size: 18px; font-weight: bold; text-decoration: none;}
.pdfDlBox .pdfDlBtn::before{ content: ""; position: absolute; top: 50%; left: 16px; transform: translateY(-50%); display: block; width: 42px; height: 42px; background: url(/common/img/icon_pdf-w.png); background-size: contain;}
