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

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

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

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

  -2021/11/10	 Fixed all

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

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

  0. General

====================================*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');
@keyframes fadeIn {
    0% {opacity: 0; }
    100% {opacity: 1; }
}
@-webkit-keyframes fadeIn {
    0% {opacity: 0; }
    100% {opacity: 1; }
}


html { font-size: 62.5%; }
body { -webkit-animation: fadeIn 1s ease 0s 1 normal; animation: fadeIn 1s ease 0s 1 normal; background: #fff; color: #202020; font-family: 'Noto Sans JP', sans-serif; font-size: 1.0rem; line-height: 1.5; position: relative; }

img { vertical-align: bottom; }
a { color: #036EB8; cursor: pointer; text-decoration: underline; }
a:hover { opacity: 0.8; text-decoration: none; }
input:hover { opacity: 0.8; }
ul, ol { list-style: none; }

div.inner { display: block; margin: 0 auto; overflow: hidden; position: relative; width: 1000px; zoom: 1; }
.spOnly { display: none !important; }
#page-top { bottom: 20px; position: fixed; right: 20px; z-index: 100; }
#page-top a { background: url("/common/img/icon_gototop.png") no-repeat 0 0; display: block; height: 60px; text-indent:-9999px; width: 60px; }

#page-nav { margin-top: -180px; position: fixed; right: 0; top: 50%; z-index: 100; }
#page-nav li:nth-child(1) a { background: url("/common/img/btn_request.png") no-repeat 0 0; display: block; height: 174px; text-indent:-9999px; width: 73px; }
#page-nav li:nth-child(1) { margin-bottom: 12px; }
#page-nav li:nth-child(2) a { background: url("/common/img/btn_contact.png") no-repeat 0 0; display: block; height: 174px; text-indent:-9999px; width: 73px; }



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

  1. Header

====================================*/
header { line-height: 1; position: relative; }
.l-header__lead { background: #f0f0f0; font-size: 1.4rem; padding: 0 calc(50% - 500px); }
.l-header__lead p { line-height: 1.3; }
header .inner { align-items: center; display: flex; justify-content: flex-start; padding: 22px 0; }
.l-header__h1 {}
.l-header__h2 { border-left: 1px solid #b3b3b3; margin-left: 20px; padding-left: 20px; }
.l-header__tel { margin-left: auto; }
header nav { background-image: -moz-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); background-image: -webkit-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); background-image: -ms-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); font-size: 1.8rem; }
header nav > ul { display: flex; margin: 0 auto; width: 1000px; }
header nav > ul > li { position: relative; }
header nav > ul > li:nth-child(1) { width: 370px; }
header nav > ul > li:nth-child(2) { width: 210px; }
header nav > ul > li:nth-child(3) { width: 250px; }
header nav > ul > li:nth-child(4) { width: 170px; }
header nav > ul > li > a { color: #fff; display: block; font-weight: 700; padding: 24px 0 24px 57px; position: relative; text-decoration: none; }
header nav > ul > li > a:before { background: url("/common/img/icon_nav_bottom.png"); content: ""; height: 24px; left: 26px; margin-top: -12px; position: absolute; top: 50%; width: 24px; }
header nav > ul > li.notDown > a:before { background: url("/common/img/icon_nav_right.png"); content: ""; height: 24px; left: 26px; margin-top: -12px; position: absolute; top: 50%; width: 24px; }
header nav > ul > li ul.more { display: none; }
header nav > ul > li:nth-child(1) ul.more { width: 480px; }
header nav > ul > li:nth-child(2) ul.more { width: 400px; }
header nav > ul > li:nth-child(3) ul.more { width: 380px; }
header nav > ul > li:hover ul.more { background-image: -moz-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); background-image: -webkit-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); background-image: -ms-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); display: block; left: 26px; padding: 15px 30px 30px; position: absolute; }
ul.more li { border-bottom: 1px solid rgba(255,255,255,0.3); padding: 15px 0; }
ul.more a { color: #fff; display: inline-block; font-size: 1.6rem; font-weight: 700; padding-left: 25px; position: relative; text-decoration: none; }
ul.more a:before { background: url("/common/img/icon_nav_right.png") no-repeat 0 0 / 19px auto; content: ""; height: 19px; left: 0; margin-top: -10px; position: absolute; top: 50%; width: 19px; }

header div.glossary { font-size: 1.4rem; left: 50%; margin-left: 445px; position: absolute; top: 22px;  }
header div.glossary a { color: #202020; position: relative; text-decoration: none; }
header div.glossary a:before { background: url("/common/img/icon_help.png") no-repeat 50% 50%; content: ""; height: 20px; left: -25px; margin-top: -10px; position: absolute; top: 50%; width: 20px; }


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

  2. Main

====================================*/
main { background: #fff; display: block; font-size: 1.6rem; min-width: 1000px; overflow: hidden; }
div.topPage { background: url("/common/img/bg_tile.png"); }

/*====== [MODULE] tytle style ======*/
.titleStyleH1 { background: url("/common/img/bg_title.png") 50% 50% / cover; padding: 15px; }
.titleStyleH1 > span { border: 1px solid rgba(255,255,255,0.6); color: #fff; display: block; font-size: 4rem; padding: 45px 0 42px; text-align: center; }
.titleStyleH1 span.fsS { font-size: 2rem; }
.titleStyleH2 { border-bottom: 3px solid #005685; font-size: 2.4rem; line-height: 1; margin: 40px 0 15px; padding-bottom: 13px; vertical-align: middle; }
.titleStyleH2 span { font-size: 1.8rem; }
.titleStyleH2 em { display: inline-block; font-size: 1.4rem; font-style: normal; font-weight: normal; margin-left: 15px; padding: 5px 8px; vertical-align: middle; }
.titleStyleH2 em.comp { background: #c00; color: #fff; font-weight: 700; }
.titleStyleH3 { font-size: 2rem; font-weight: 700; line-height: 1; margin-top: 40px; }
.titleStyleH4 { font-size: 3rem; font-weight: 700; line-height: 1.2; margin: 40px 0; text-align: center; }


/*====== [MODULE] text style ======*/
small { font-size: 80% !important; }
.taR { text-align: right !important; }
.taC { text-align: center !important; }
.taL { text-align: left !important; }
.komeTxt { display: block; padding-left: 1em; text-indent: -1em; }
.kanaTxt { display: block; padding-left: 1.5em; text-indent: -1.5em; }
.komekakkoTxt { padding-left: 3em; text-indent: -3em; }
.komeNumkakkoTxt { padding-left: 3.5em; text-indent: -3.5em; }
.fwB { font-weight: 700; }
.fcBlue { color: #005685; }


/*====== [MODULE] list style ======*/
.list > li { padding-left: 1em; position: relative; }
.list > li:before { content: "・"; left: 0; position: absolute; top: 0; }
.numList { list-style: decimal; margin-left: 1.5em; }
.komeList { list-style: none; }
.komeList > li { padding-left: 1em; text-indent: -1em; }
.komeNumList { list-style: none; }
.komeNumList > li { padding-left: 3.5em; text-indent: -3.5em; }
.kanaList > li { padding-left: 1.5em; text-indent: -1.5em; }
.hiraganaList { list-style: hiragana; margin-left: 1.5em; }
.romanList { list-style: lower-roman; margin-left: 1.5em; }
.alphaList { list-style: lower-alpha; margin-left: 1.5em; }
.maruNnumList { counter-reset: my-counter; list-style: none; padding: 0; }
.maruNnumList > li { padding-left: 1.4em; position: relative; }
.maruNnumList > li:before { border: 1px solid #999; border-radius: 50%; color: #333; content: counter(my-counter); counter-increment: my-counter; display: block; font-size: 1.4rem; height: 1.2em; left: 0; line-height: 1.2; position: absolute; text-align: center; top: 0.2em; width: 1.2em; }
.etc { margin-bottom: 1em; position: relative; }
.etc:after { bottom: -1em; content: "等"; position: absolute; right: 0; }


/*====== [MODULE] table style ======*/
table { border-collapse: collapse; width: 100%; }
table th,
table td { border: 1px solid #ccc; }
table td p,
table td ul,
table td ol { margin-bottom: 0 !important; margin-top: 0 !important; }
table.plan th { background: #666666; color: #fff; }
table.plan .fsSS { font-size: 1.2rem; }
table.plan .fsS { font-size: 1.4rem; }
table.plan .fsM { font-size: 1.6rem; }
table.plan .gray { background: #e6e6e6; color: #202020; font-weight: 700; text-align: center; }
table.plan .nostyle { background: none !important; color: #202020; font-weight: normal; }
table .rl { line-height: 1em; margin: 0 auto; text-orientation: upright; white-space: nowrap; width: 1em;  writing-mode: tb-rl; writing-mode: vertical-rl; }
table .economy { background: #05807c !important; color: #fff; font-weight: 700; vertical-align: top; }
table .standard,
table .basic { background: #143d91 !important; color: #fff; font-weight: 700; vertical-align: top; }
table .premium,
table .wide { background: #117fc7 !important; color: #fff; font-weight: 700; vertical-align: top; }
table .itOption { background: #d77413 !important; color: #fff; font-weight: 700; vertical-align: top; }
.txtEconomy { color: #05807c !important; }
.txtStandard,.txtBasic { color: #143d91 !important; }
.txtPremium,.txtWide { color: #117fc7 !important; }
.solidBasic { background: #143d91; color: #fff; display: inline-block; font-size: 1.4rem; margin-bottom: 10px; padding: 5px 0; text-align: center; width: 160px; }
.solidWide { background: #117fc7; color: #fff; display: inline-block; font-size: 1.4rem; margin-bottom: 10px; padding: 5px 0; text-align: center; width: 160px; }
.solidEconomy { background: #05807c; color: #fff; display: inline-block; font-size: 1.4rem; margin-bottom: 10px; padding: 5px 0; text-align: center; width: 160px; }


/*====== [MODULE] btn style ======*/
.btn { background-image: -moz-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); background-image: -webkit-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); background-image: -ms-linear-gradient( -90deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); border: 3px solid #dcdcdc; border-radius: 5px; color: #fff; display: block; font-weight: 700; line-height: 1; position: relative; text-align: center; text-decoration: none; }
.btn:before { background: url("/common/img/icon_nav_right.png"); content: ""; height: 24px; margin-top: -12px; position: absolute; top: 50%; width: 24px; }


/*====== [MODULE] column style ======*/
.flex { display: flex; flex-wrap: wrap; }
.flex.space-between { justify-content: space-between; }

/*====== [MODULE] background style ======*/
.bgTile { background: url("/common/img/bg_tile.png"); display: block; overflow: hidden; }
.bgGradeBlue { background-image: -moz-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); background-image: -ms-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); }
.bgGradeGray { background-image: -moz-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -ms-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); }
.bgWhite { background: #fff; }


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

  3. Footer

====================================*/
footer { font-size: 1.4rem; line-height: 1; }
footer a { color: #202020; }
.l-foot_contact { background: url("/common/img/bg_tile.png"); font-weight: 700; min-width: 1000px; padding: 25px 0 10px; text-align: center; }
.l-foot_contact p { font-family: "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif; font-size: 2.4rem; line-height: 1.7; margin-bottom: 20px; }
.l-foot_contact p.top { color: #03496f; font-size: 3rem; }
.l-foot_contact p.top em { border-bottom: 3px solid #ff6000; font-style: normal; }
.l-foot_contact ul { display: flex; line-height: 1; margin: 0 auto 30px; width: 960px; }
.l-foot_contact li { margin: 0 20px; width: 440px; }
.l-foot_contact li a { border-radius: 10px; color: #fff; display: block; font-size: 2.6rem; padding: 33px 0; text-decoration: none; }
.requestBtn { background-image: -moz-linear-gradient( -90deg, rgb(245,121,20) 0%, rgb(239,75,24) 100%); background-image: -webkit-linear-gradient( -90deg, rgb(245,121,20) 0%, rgb(239,75,24) 100%); background-image: -ms-linear-gradient( -90deg, rgb(245,121,20) 0%, rgb(239,75,24) 100%); border: 3px solid #dcdcdc; }
.requestBtn span { display: inline-block; padding-left: 45px; position: relative; }
.requestBtn span:before { background: url("/common/img/icon_resume.png") no-repeat; content: ""; height: 50px; left: 0; margin-top: -25px; position: absolute; top: 50%; width: 39px; }
.contactBtn { background-image: -moz-linear-gradient( -90deg, rgb(50,158,65) 0%, rgb(14,101,26) 100%); background-image: -webkit-linear-gradient( -90deg, rgb(50,158,65) 0%, rgb(14,101,26) 100%); background-image: -ms-linear-gradient( -90deg, rgb(50,158,65) 0%, rgb(14,101,26) 100%); border: 3px solid #dcdcdc; }
.contactBtn span { display: inline-block; padding-left: 58px; position: relative; }
.contactBtn span:before { background: url("/common/img/icon_contact.png") no-repeat; content: ""; height: 36px; left: 0; margin-top: -18px; position: absolute; top: 50%; width: 51px; }

.l-foot { padding: 40px 0; }
.l-foot_right { float: right; width: 520px; }
.l-foot_left { float: left; width: 440px; }
.l-foot ul { display: block; margin-bottom: 20px; overflow: hidden; padding-top: 5px; }
.l-foot ul li { float: left; margin: 0 22px 15px 0; }
.l-foot ul a { background: url("/common/img/icon_newopen.png") no-repeat 0 50%; padding-left: 20px; }
.l-foot p { line-height: 1.5; }
.l-foot h1 { font-size: 2.4rem; margin-bottom: 18px; }
.l-foot h1 em { display: block; font-size: 1.6rem; font-style: normal; margin-bottom: 5px; }
.l-foot dl { border-top: 1px solid #ccc; margin-bottom: 25px; }
.l-foot dt { float: left; padding-top: 12px; }
.l-foot dd { border-bottom: 1px solid #ccc; padding: 12px 0 12px 130px; }
.l-foot address { font-style: normal; }




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

  4. Contents

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

/*---------------------
  top
---------------------*/
.topBlock01 h1 { background: url("/common/img/bg_top_title.png") 50% 50% / cover; padding: 15px; }
.topBlock01 span { border: 1px solid rgba(255,255,255,0.6); color: #fff; display: block; font-size: 6rem; line-height: 1.3; padding: 195px 0 265px 145px; }

.topBlock02 { background-image: -moz-linear-gradient( 0deg, rgb(210,210,210) 0%, rgb(246,246,246) 50%, rgb(210,210,210) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(210,210,210) 0%, rgb(246,246,246) 50%, rgb(210,210,210) 100%); background-image: -ms-linear-gradient( 0deg, rgb(210,210,210) 0%, rgb(246,246,246) 50%, rgb(210,210,210) 100%); margin: -85px auto 0; padding: 15px; position: relative; width: 1030px; z-index: 3; }
.topBlock02 div { background-image: -moz-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); background-image: -ms-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); padding: 35px 0; }
.topBlock02 h2 { color: #fff; font-size: 2.8rem; text-align: center; }
.topBlock02 ol { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 40px auto 25px; width: 950px; }
.topBlock02 ol li { background-image: -moz-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -ms-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); margin-top: 1px; position: relative; width: 316px; }
.topBlock02 ol li:nth-child(1),
.topBlock02 ol li:nth-child(2),
.topBlock02 ol li:nth-child(3) { padding-bottom: 20px; }
.topBlock02 ol li:before { content: ""; height: 88px; left: 50%; margin-left: -44px; position: absolute; top: -25px; width: 88px; }
.topBlock02 ol li:nth-child(1):before { background: url("/common/img/feature_img09.png") no-repeat; }
.topBlock02 ol li:nth-child(2):before { background: url("/common/img/feature_img10.png") no-repeat; }
.topBlock02 ol li:nth-child(3):before { background: url("/common/img/feature_img11.png") no-repeat; }
.topBlock02 ol li:nth-child(4):before { background: url("/common/img/feature_img12.png") no-repeat; }
.topBlock02 ol li:nth-child(5):before { background: url("/common/img/feature_img13.png") no-repeat; }
.topBlock02 ol li:nth-child(6):before { background: url("/common/img/feature_img14.png") no-repeat; }
.topBlock02 dl { margin: 18px; }
.topBlock02 dt { font-size: 2rem; font-weight: 700; margin-bottom: 10px; text-align: center; }
.topBlock02 dd { font-size: 1.4rem; line-height: 1.6; margin-top: 10px; }
.topBlock02 ul { font-size: 1.8rem; text-align: center; }
.topBlock02 ul li { display: inline-block; margin: 0 30px; }
.topBlock02 ul a { color: #fff; position: relative; }
.topBlock02 ul a:before { background: url("/common/img/icon_nav_right.png") 0 0 / 20px auto; content: ""; height: 20px; left: -25px; margin-top: -10px; position: absolute; top: 50%; width: 20px; }
.topBlock02 .basicPlan { background: #143d91; color: #fff; display: inline-block; margin: 0 2px; padding: 2px 0; text-align: center; width: 128px; }
.topBlock02 .widePlan { background: #117fc7; color: #fff; display: inline-block; margin: 0 2px; padding: 2px 0; text-align: center; width: 128px; }

.topBlock03 { background: #000 url("/common/img/bg_top_cyber.png") no-repeat 0 0 / 100% auto; margin-top: -125px; padding: 125px 0 50px; position: relative; z-index: 1; }
.topBlock03 h2 { color: #fff; font-size: 3.2rem; margin: 50px 0 35px; text-align: center; }
.topBlock03 figure { margin-top: 35px; text-align: center; }
.topBlock03 h3 { color: #fff; font-size: 2.4rem; line-height: 1; margin: 0 auto; padding: 15px 0; text-align: center; width: 1000px; }
.topBlock03 h3.compensation { background: #0e6b33; }
.topBlock03 h3.cost { background: #005685; }
.topBlock03 ul { background: #fff; display: flex; flex-wrap: wrap; margin: 0 auto; padding: 0 0 25px 40px; width: 1000px; }
.topBlock03 ul li { border-bottom: 1px solid #666; font-size: 2.2rem; line-height: 1; margin-right: 40px; padding: 18px 0; width: 440px; }
.topBlock03 dl { display: flex; justify-content: space-between; }
.topBlock03 p { color: #fff; font-size: 1.4rem; margin-top: 10px; text-align: center; }
.topBlock03 .link { font-size: 1.8rem; margin-top: 10px; text-align: center; }
.topBlock03 .link a { color: #fff; position: relative; }
.topBlock03 .link a:before { background: url("/common/img/icon_nav_right.png") 0 0 / 20px auto; content: ""; height: 20px; left: -25px; margin-top: -10px; position: absolute; top: 50%; width: 20px; }





/*---------------------
  feature
---------------------*/
.featureBlock01 { display: block; overflow: hidden; padding: 0 0 45px; text-align: center; }
.featureBlock01 h2 { font-size: 3rem; margin: 55px 0 20px; }
.featureBlock01 em { border-bottom: 4px solid #ff6000; font-size: 4.2rem; font-style: normal; font-weight: 700; }
.featureBlock01 ul { margin: 0 auto 60px; text-align: left; width: 920px; }
.featureBlock01 ul li { background: #fff; margin-top: 30px; padding: 15px 20px 30px; width: 440px; }
.featureBlock01 ul dt { border-bottom: 3px solid #005685; font-size: 1.8rem; font-weight: 700; padding-bottom: 10px; }
.featureBlock01 ul dt .fsL { font-size: 2.4rem; }
.featureBlock01 ul dd { margin-top: 15px; }
.featureBlock01 p { color: #025883; font-size: 2.4rem; }

.featureBlock02 { background: url("/common/img/bg_top_cyber.png") no-repeat 50% 0% / cover; padding: 55px 0; position: relative; text-align: center; }
.featureBlock02:before { border-bottom: 1px solid transparent; border-left: 34px solid transparent; border-right: 34px solid transparent; border-top: 62px solid #ff6000; content: ""; height: 0; left: 50%; margin-left: -34px; position: absolute; top: -20px; width: 0; }
.featureBlock02 h2 { color: #fff; font-size: 3rem; margin: 0 auto 25px; position: relative; width: 280px; }
.featureBlock02 h2:before { background: #fff; content: ""; height: 1px; left: -320px; position: absolute; top: 20px; width: 320px; }
.featureBlock02 h2:after { background: #fff; content: ""; height: 1px; position: absolute; right: -320px; top: 20px; width: 320px; }
.featureBlock02 > ul { margin: 0 auto; width: 920px; }
.featureBlock02 > ul > li { background: #fff; border: 5px solid #025883; border-radius: 10px; position: relative; width: 440px; }
.featureBlock02 > ul > li:after { bottom: 10px; color: #025883; content: "等"; font-size: 2rem; font-weight: 700; position: absolute; right: 34px; }
.featureBlock02 dt { background: #025883; color: #fff; font-size: 2rem; font-weight: 700; padding: 8px 0 13px; text-align: center; }
.featureBlock02 ul ul { padding: 15px 34px 50px; }
.featureBlock02 ul ul li { border-bottom: 1px solid #025883; color: #025883; font-size: 2rem; font-weight: 700; line-height: 1; padding: 13px 0; text-align: center; width: 160px; }
.featureBlock02 ul ul li.last { margin-left: 202px; }
.featureBlock02 p { background: url("/common/img/parts_arrow.png") no-repeat 50% 10px; color: #fff; font-size: 3rem; font-weight: 700; padding-top: 50px; }
.featureBlock02 p em { font-size: 5rem; font-style: normal; }

.featureBlock03 { margin: 30px auto 60px; width: 1000px; }
.featureBlock03 h2 { font-size: 2.8rem; font-weight: normal; line-height: 1.8; margin: 35px 0 0; text-align: center; }
.featureBlock03 figure { margin-top: 30px; }
.featureBlock03 hr { border-top: 1px solid #ccc; height: 1px; margin-top: 40px; }
.featureBlock03 ul { margin-top: 30px; }
.featureBlock03 li { width: 333px; }
.featureBlock03 dt { color: #fff; font-size: 2.2rem; font-weight: 700; text-align: center; }
.featureBlock03 dd { font-size: 1.8rem; padding: 15px 22px; }
.featureBlock03 li:nth-child(1) { background: #d7fffe; border: 5px solid #05807c; }
.featureBlock03 li:nth-child(2) { background: #ebf1fd; border: 5px solid #143d91; }
.featureBlock03 li:nth-child(3) { background: #dbeffc; border: 5px solid #117fc7; }
.featureBlock03 li:nth-child(1) dt { background: #05807c; }
.featureBlock03 li:nth-child(2) dt { background: #143d91; }
.featureBlock03 li:nth-child(3) dt { background: #117fc7; }
.featureBlock03 li:nth-child(1) dd { color: #05807c; }
.featureBlock03 li:nth-child(2) dd { color: #143d91; }
.featureBlock03 li:nth-child(3) dd { color: #117fc7; }
.featureBlock03 p { margin-top: 10px; }
.featureBlock03 .link { margin-top: 30px; }
.featureBlock03 .btn { font-size: 2.2rem; margin: 0 auto; padding: 29px 0 29px 45px; width: 475px; }
.featureBlock03 .btn:before { left: 45px; }

.featureBlock04 { background-image: -moz-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); background-image: -ms-linear-gradient( 0deg, rgb(0,62,96) 0%, rgb(2,96,147) 50%, rgb(0,62,96) 100%); padding: 35px 0 40px; }
.featureBlock04 h2 { color: #fff; font-size: 2.8rem; text-align: center; }
.featureBlock04 ol { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 40px auto 0; width: 950px; }
.featureBlock04 li { background-image: -moz-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -ms-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); margin-top: 1px; position: relative; width: 316px; }
.featureBlock04 li:nth-child(1),
.featureBlock04 li:nth-child(2),
.featureBlock04 li:nth-child(3) { padding-bottom: 20px; }
.featureBlock04 li:before { content: ""; height: 88px; left: 50%; margin-left: -44px; position: absolute; top: -25px; width: 88px; }
.featureBlock04 li:nth-child(1):before { background: url("/common/img/feature_img09.png") no-repeat; }
.featureBlock04 li:nth-child(2):before { background: url("/common/img/feature_img10.png") no-repeat; }
.featureBlock04 li:nth-child(3):before { background: url("/common/img/feature_img11.png") no-repeat; }
.featureBlock04 li:nth-child(4):before { background: url("/common/img/feature_img12.png") no-repeat; }
.featureBlock04 li:nth-child(5):before { background: url("/common/img/feature_img13.png") no-repeat; }
.featureBlock04 ol li:nth-child(6):before { background: url("/common/img/feature_img14.png") no-repeat; }
.featureBlock04 dl { margin: 18px; }
.featureBlock04 dt { font-size: 2rem; font-weight: 700; margin-bottom: 10px; text-align: center; }
.featureBlock04 dd { font-size: 1.4rem; line-height: 1.6; margin-top: 10px; }
.featureBlock04 .basicPlan { background: #143d91; color: #fff; display: inline-block; margin: 0 2px; padding: 2px 0; text-align: center; width: 128px; }
.featureBlock04 .widePlan { background: #117fc7; color: #fff; display: inline-block; margin: 0 2px; padding: 2px 0; text-align: center; width: 128px; }


/*---------------------
  compensation
---------------------*/
.catchTxt { font-size: 1.8rem; margin: 40px auto; width: 1000px; }
.tab { align-items: flex-end; border-bottom: 8px solid #03547c; display: flex; height: 90px; justify-content: space-between; padding: 0 calc(50% - 500px); }
.tab.tab3 li { width: calc(1000px / 3); }
.tab.tab4 li { width: calc(1000px / 4); }
.tab.tab5 li { width: calc(1000px / 5); }
.tab li { flex-grow: 1; margin: 0 1px; }
.tab li a { align-items: center; background: -webkit-linear-gradient( 90deg, rgb(45,51,52) 0%, rgb(143,154,158) 0%, rgb(213,218,220) 99%); border-top-left-radius: 10px; border-top-right-radius: 10px; color: #fff; display: flex; font-weight: 700; height: 60px; justify-content: center; text-align: center; text-decoration: none; width: 100%; }
.tab li.active a { background: linear-gradient( 180deg, rgb(0,115,177) 0%, rgb(3,83,123) 100%); height: 80px }
.area { display: none; opacity: 0; }
.area.is-active { animation-duration: 2s; animation-fill-mode: forwards; animation-name: displayAnime; display: block; }
@keyframes displayAnime{
  from { opacity: 0; }
  to { opacity: 1; }
}
.compensationBlock01 { display: block; overflow: hidden; padding: 0 0 40px;; text-align: center; }
.compensationBlock01 h2 { font-size: 3rem; margin: 50px 0 30px; }
.compensationBlock01 p { font-size: 1.8rem; margin: 30px auto 0; width: 1000px; }
.compensationBlock01 p small { display: block; font-size: 1.4rem; margin-top: 15px; text-align: left; }
.compensationBlock01 span { color: #d77413; }
.compensationBlock01 figure { margin: 60px auto 0; position: relative; width: 1000px; }
.compensationBlock01 figcaption { bottom: 70px; font-size: 1.4rem; position: absolute; right: 20px; }
.compensationBlock01 figcaption a { background: url("/common/img/icon_arrrow.png") no-repeat 0 50%; color: #fff; display: inline-block; padding-left: 16px; }
.compensationBlock01 .link { margin-top: 20px; }
.compensationBlock01 .btn { font-size: 2.2rem; margin: 0 auto; padding: 29px 0 29px 45px; width: 475px; }
.compensationBlock01 .btn:before { left: 45px; }
.compensationOption { background: #fff; margin: 30px auto; padding: 25px 40px 40px; width: 1000px; }
.compensationOption h2 { font-size: 2.6rem !important; margin: 0 0 30px; text-align: center; }
.compensationOption p { font-size: 1.8rem; }
.compensationOption2 { background: #fff1e4; margin: 30px auto; padding-bottom: 30px; width: 1000px; }
.compensationOption2 h2 { background: #d77413; color: #fff; font-size: 1.8rem; padding: 10px 0; text-align: center; }
.compensationOption2 figure { text-align: center; }
.compensationOption2 figcaption { margin: 20px 40px 0; text-align: left; }

.compensationBlock02 { border-bottom: 1px solid #ccc; margin: 60px auto 0; padding-bottom: 60px; position: relative; width: 1000px; }
.compensationBlock02 h1 { font-size: 3rem; margin-top: 50px; text-align: center; }
.compensationBlock02 p { margin: 20px auto 0; }
.compensationBlock02 p.subTxt { font-size: 1.8rem; margin: 1em auto; }
.compensationBlock02 p + .komeList { margin-top: 20px; }
.compensationBlock02 table { margin-top: 40px; }
.compensationBlock02 figure { margin-top: 40px; }
.compensationBlock02 caption { font-size: 2rem; font-weight: 700; line-height: 1; margin-bottom: 10px; text-align: left; }
.compensationBlock02 th { padding: 8px 4px; }
.compensationBlock02 td { font-size: 1.4rem; padding: 8px 10px; }
.compensationBlock02 small { font-size: 1.4rem; }
.compensationBlock02 ul { margin-bottom: 1em; }
.compensationBlock02 ul.anchor { margin: 25px 0; text-align: center; }
.compensationBlock02 ul.anchor li { display: inline-block; margin: 0 30px; }
.compensationBlock02 ul.anchor a { color: #202020; display: inline-block; position: relative; }
.compensationBlock02 ul.anchor a:before { background: url("/common/img/icon_arrrow.png") no-repeat 50% 50%; content: ""; height: 10px; left: -20px; margin-top: -5px; position: absolute; top: 50%; width: 10px;; }
.compensationBlock02 dl.flL { float: left; width: 215px; }
.compensationBlock02 dl.border { border-right: 1px solid #ddd; margin-right: 8px; padding-right: 8px; }
.compensationBlock02 td small { font-size: 1.2rem; }
.compensationBlock02 .link { margin-top: 20px; }
.compensationBlock02 .btn { font-size: 2.2rem; margin: 0 auto; padding: 29px 0 29px 45px; width: 475px; }
.compensationBlock02 .btn:before { left: 45px; }
.compensationBlock02 .planLabel { display: flex; left: 0; position: absolute; top: 5px; }
.compensationBlock02 .basicPlan { background: #143d91; color: #fff; padding: 5px 0; text-align: center; width: 180px; }
.compensationBlock02 .widePlan { background: #117fc7; color: #fff; padding: 5px 0; text-align: center; width: 180px; }

.compensationBlock03 { font-size: 1.4rem; margin: 40px auto 80px; width: 1000px; }
.compensationBlock03 h2 { font-size: 3rem; line-height: 1; margin-bottom: 30px; text-align: center; }
.compensationBlock03 h3 { border-bottom: 1px solid #005685; font-size: 2rem; line-height: 1; margin: 30px 0 20px; padding-bottom: 13px; }
.compensationBlock03 h4 { font-size: 1.4rem; margin-top: 10px; }
.compensationBlock03 p small { display: block; font-size: 1.2rem; margin-top: 30px; }
.compensationBlock03 p,
.compensationBlock03 ul,
.compensationBlock03 ol { line-height: 1.6; }


/*---------------------
  terms
---------------------*/
.termsBlock { margin: 0 auto 60px; width: 1000px; }
.termsBlock h2 { margin-bottom: 20px; }
.termsBlock ul,
.termsBlock ol,
.termsBlock p,
.termsBlock table { margin: 0 0 10px; }
.termsBlock th { padding: 8px 4px; }
.termsBlock td { font-size: 1.4rem; padding: 8px 10px; }
.termsBlock p small { display: block; font-size: 1.4rem; margin-top: -10px; }


/*---------------------
  service
---------------------*/
.serviceBlock { display: block; overflow: hidden; padding: 0 0 40px; text-align: center; }
.serviceBlock h2 { font-size: 3rem; margin: 50px 0 30px; }
.serviceBlock p { font-size: 1.8rem; margin: 30px 0 0; }

.serviceListBlock { padding: 40px 0; }
.serviceListBlock ul { display: flex; justify-content: space-between; margin: 0 auto; width: 950px; }
.serviceListBlock li { background-image: -moz-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -ms-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); position: relative; width: 316px; }
.serviceListBlock dl { margin: 18px 18px 0; padding-bottom: 95px; }
.serviceListBlock dt { font-size: 2rem; font-weight: 700; margin-bottom: 10px; text-align: center; }
.serviceListBlock dd { font-size: 1.4rem; line-height: 1.6;}
.serviceListBlock dd.link { bottom: 25px; left: 20px; position: absolute; width: 276px; }
.serviceListBlock .btn { font-size: 1.6rem; padding: 15px 0 15px 25px; }
.serviceListBlock .btn:before { background: url("/common/img/icon_nav_right.png") 0 0 / 17px 17px; content: ""; height: 17px; left: 71px; margin-top: -9px; position: absolute; top: 50%; width: 17px; }

.serviceInfoBlock { display: block; font-size: 1.8rem; margin: 0 auto 40px; overflow: hidden; width: 1000px; }
.serviceInfoBlock h2 { margin-bottom: 30px; }
.serviceInfoBlock figure { float: left; margin-top: 30px; }
.serviceInfoBlock p { margin: 30px 0 0; }
.serviceInfoBlock p.txtR { margin-left: 520px; }
.serviceInfoBlock ul.komeList { font-size: 1.4rem; margin: 15px 0 0 520px; }
.serviceFlowBlock { background: #f6f6f6; display: block; margin: 0 auto 40px; overflow: hidden; padding: 25px 40px 40px; width: 1000px; }
.serviceFlowBlock h2 { border-bottom: 1px solid #005685; font-size: 2rem; line-height: 1; margin-bottom: 30px; padding-bottom: 20px; text-align: center; }
.serviceFlowBlock figure { display: block; text-align: center; }
.serviceFlowBlock ol.numList { counter-reset: my-counter; list-style: none; margin: -15px 0 15px; padding: 0; }
.serviceFlowBlock ol.numList li { border-bottom: 1px solid #ccc; padding: 15px 0 15px 35px; position: relative; }
.serviceFlowBlock ol.numList li:before { background: #005685; border-radius: 50%; color: #fff; content: counter(my-counter); counter-increment: my-counter; display: block; float: left; font-family: "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif; font-size: 1.8rem; font-style: italic; height: 25px; line-height: 1.5; margin-bottom: 20px; margin-left: -35px; text-align: center; text-indent: -0.15em; width: 25px; }
.serviceFlowBlock div.sample { background: #fff; display: block; margin-top: 30px; overflow: hidden; padding: 30px 40px; }
.serviceFlowBlock div.sample dl { float: right; width: 400px; }
.serviceFlowBlock div.sample dt { font-weight: 700; margin-bottom: 15px; }
.serviceFlowBlock div.sample dd { font-size: 1.4rem; margin-top: 10px; }
.serviceFlowBlock div.sample dd.mail { border: 1px solid #ccc; padding: 10px 15px; }
.serviceFlowBlock div.sample em { color: #c00; font-style: normal; }
.serviceFlowBlock div.sample figure { float: left; width: 400px; }
.serviceFlowBlock div.sample figcaption { font-weight: 700; margin-bottom: 15px; text-align: left; }
.serviceFlowBlock ul.squareList { border-bottom: 1px solid #ccc; display: flex; margin-bottom: 25px; padding-bottom: 25px; }
.serviceFlowBlock ul.squareList li { margin-right: 30px; }
.serviceFlowBlock ul.squareList li:before { color: #005685; content: "■"; }
.serviceFlowBlock ul.komeList { font-size: 1.4rem; }
.serviceFlowBlock small { font-size: 1.4rem; }
.serviceFlowBlock .flL600 { float: left; width: 600px; }
.serviceFlowBlock .flR { float: right; }
.serviceFlowBlock .flR figcaption { font-size: 1.4rem; font-weight: 700; margin-bottom: 10px; }
.serviceFlowBlock hr { border: none; border-top: 1px solid #ccc; height: 1px; margin: 10px 0; }


/*---------------------
  urgent
---------------------*/
.urgentBlock01 { display: block; overflow: hidden; padding: 0 0 60px; text-align: center; }
.urgentBlock01 h2 { font-size: 2.8rem; font-weight: normal; line-height: 1.8; margin: 50px 0 30px; }
.urgentBlock01 figure.graph { background: #fff; border: 2px solid #025883; display: block; margin: 0 auto; padding: 55px 0 30px; width: 1000px; }
.urgentBlock01 figcaption { margin-top: 20px; }
.urgentBlock01 p { font-size: 1.8rem; line-height: 1.7; margin: 0 auto; width: 1000px; }
.urgentBlock01 h3 { font-size: 3rem; margin-top: 35px; }
.urgentBlock01 ul { margin: 0 auto; text-align: left; width: 920px; }
.urgentBlock01 ul li { background: #fff; margin-top: 30px; padding: 15px 20px 30px; width: 440px; }
.urgentBlock01 ul dt { border-bottom: 3px solid #005685; font-size: 1.8rem; font-weight: 700; padding-bottom: 10px; }
.urgentBlock01 ul dt .fsL { font-size: 2.4rem; }
.urgentBlock01 ul dd { margin-top: 15px; }

.urgentBlock02 { background: url("/common/img/bg_top_cyber.png") no-repeat 50% -100px / cover; padding: 55px 0; position: relative; text-align: center; }
.urgentBlock02:before { border-bottom: 1px solid transparent; border-left: 34px solid transparent; border-right: 34px solid transparent; border-top: 62px solid #ff6000; content: ""; height: 0; left: 50%; margin-left: -34px; position: absolute; top: -20px; width: 0; }
.urgentBlock02 h2 { color: #fff; font-size: 2.8rem; font-weight: normal; line-height: 1.8; margin: 0 0 25px; }
.urgentBlock02 h2 em { color: #ff6000; font-style: normal; }
.urgentBlock02 ul { background: #fff; display: flex; margin: 0 auto 40px; padding: 30px 0 40px 40px; width: 1000px; }
.urgentBlock02 li { border-bottom: 2px solid #ff6000; color: #025883; font-size: 2.2rem; font-weight: 700; line-height: 1;  margin-right: 40px; padding-bottom: 15px; width: 200px; }
.urgentBlock02 .btn { font-size: 2.2rem; margin: 0 auto; padding: 29px 0 29px 45px; width: 522px; }
.urgentBlock02 .btn:before { left: 45px; }


/*---------------------
  example
---------------------*/
.exampleBlock { border-bottom: 1px solid #ccc; margin: 0 auto 25px; padding-bottom: 40px; width: 1000px; }
.exampleBlock p { margin-top: 30px; }
.exampleBlock li { width: 480px; }
.exampleBlock li:nth-child(odd) { margin-right: 40px; }
.exampleBlock dt { margin-top: 25px; }
.exampleBlock dd { margin-top: 25px; }

.exampleFeeBlock { margin: 0 auto 65px; width: 1000px; }
.exampleFeeBlock dt { background: #f0f0f0; font-size: 1.8rem; margin-top: 20px; padding: 30px 40px; }
.exampleFeeBlock dt em { color: #c00; font-style: normal; font-weight: 700; }
.exampleFeeBlock dd { margin-top: 20px; }
.exampleFeeBlock table { font-size: 1.8rem; }
.exampleFeeBlock table caption { font-size: 2rem; font-weight: 700; margin-bottom: 10px; text-align: left; }
.exampleFeeBlock table caption:before { color: #005685; content: "■"; }
.exampleFeeBlock th,
.exampleFeeBlock td { border-width: 0 0 1px; padding: 10px 5px; }
.exampleFeeBlock th { font-weight: normal; text-align: left; }
.exampleFeeBlock tr:last-child th,
.exampleFeeBlock tr:last-child td { border-color: #666; border-width: 2px 0 0; font-weight: 700; }
.exampleFeeBlock tr:last-child td { color: #c00; }
.exampleFeeBlock small { display: block; font-size: 1.4rem; margin: 10px 0 40px; }
.exampleFeeBlock p.judgment { border: 3px solid #c00; font-size: 2.4rem; font-weight: 700; margin-top: 25px; padding: 40px; text-align: center; }
.exampleFeeBlock p.judgment em { color: #c00; font-style: normal; }
.exampleFeeBlock p.notice { margin-top: 25px; text-align: center; }


/*---------------------
  riskmanagement
---------------------*/
.riskBlock01 { padding: 50px 0 60px; text-align: center; }
.riskBlock01 h2 { font-size: 2.8rem; font-weight: normal; line-height: 1.8; margin-bottom: 50px; }

.riskBlock02 { color: #ccc; padding: 50px 0; text-align: center; }
.riskBlock02 p { font-size: 1.8rem; font-weight: 700; line-height: 1.7; margin-bottom: 35px; }
.riskBlock02 em { font-size: 2.4rem; font-style: normal; }
.riskBlock02 span { background: linear-gradient(transparent 90%, #ff6000 90%); font-size: 4.2rem; line-height: 2; }


/*---------------------
  fee
---------------------*/
.feeCaseBlock { background: #f6f6f6; margin: 25px auto; padding: 30px 40px; width: 1000px; }
.feeCaseBlock h2{ font-size: 2.4rem; text-align: center; }
.feeCaseBlock dl { margin-top: 30px; }
.feeCaseBlock dt { border-bottom: 1px solid #005685; font-size: 2rem; font-weight: 700; line-height: 1; margin-bottom: 10px; padding-bottom: 10px; }
.feeCaseBlock dd { font-size: 1.8rem; }
.feeCaseBlock li { font-size: 1.8rem; }
.feeCaseBlock li:before { color: #005685; content: "■"; }
.feeBlock { margin: 0 auto 80px; width: 1000px; }
.feeBlock h1 { font-size: 2.8rem; font-weight: normal; padding-top: 55px; position: relative; text-align: center; }
.feeBlock h1:before { border-bottom: 1px solid transparent; border-left: 20px solid transparent; border-right: 20px solid transparent; border-top: 35px solid #005685; content: ""; height: 0; left: 50%; margin-left: -20px; position: absolute; top: 0; width: 0; }
.feeBlock table { margin-top: 15px;  }
.feeBlock table caption { font-size: 1.6rem; font-weight: 700; margin-bottom: 10px; text-align: left; }
.feeBlock table .nostyle { background: url("../img/bg_table.svg") no-repeat 0 50% / 100% auto !important; }
.feeBlock th,
.feeBlock td { padding: 8px; }
.feeBlock th[scope="row"] { background: #eee; font-weight: normal; }
.feeBlock td { text-align: center; width: 240px; }
.feeBlock p small { display: block; font-size: 1.6rem; margin-top: 50px; }
.feeBlock .flex { display: flex; flex-wrap: wrap; justify-content: space-between; }
.feeBlock .flex > * { width: 480px; }


/*---------------------
  glossary
---------------------*/
.glossaryBlock { margin: 0 auto 80px; width: 1000px; }
.glossaryBlock p { line-height: 1.6; margin-top: 17px; }


/*---------------------
  sitepolicy
---------------------*/
.sitepolicyBlock { margin: 80px auto; width: 1000px; }
.sitepolicyBlock p { line-height: 1.6; margin-top: 17px; }


/*---------------------
  contact
---------------------*/
.formBlock { margin: 0 auto 60px; width: 1000px; }
.formBlock em.required { background: #ca3131; color: #fff; display: inline-block; font-size: 1.2rem; font-style: normal; font-weight: normal; line-height: 1; padding: 3px 6px; }
.formBlock em.optional { background: #0d58a6; color: #fff; display: inline-block; font-size: 1.2rem; font-style: normal; font-weight: normal; line-height: 1; padding: 3px 6px; }
.formBlock h2 { margin-bottom: 20px; }
.formBlock h3 { margin-bottom: 10px; margin-top: 40px; }
.formBlock h3 em { margin-right: 10px; }
.formBlock p { margin-bottom: 1.5em; }
.formBlock .btnBlock { margin-top: 50px; text-align: center; }
.formBlock .btn { display: inline-block; font-size: 2.2rem; margin: 0 10px; padding: 29px 0 29px 45px; white-space: normal; width: 400px; line-height: 1.5;}
.formBlock .btn:before { left: 30px; }
.formBlock .btn:hover{ opacity: 0.8;}
.formBlock small { display: block; margin-top: 5px; font-size: 1.2rem; font-weight: normal; }

.formType01 { border-collapse: collapse; margin-bottom: 20px; }
.formType01 th { background: #f0f0f0; border: 1px solid #ccc; padding: 10px 20px; text-align: left; }
.formType01 th em { margin-right: 10px; }
.formType01 td { border: 1px solid #ccc; padding: 10px 20px; }
.formType01 td input[type=text],
.formType01 td input[type=email],
.formType01 td input[type=tel],
.formType01 td input[type=url] { border: 1px solid #ccc; padding: 5px; width: 470px; }
.formType01 td textarea { border: 1px solid #ccc; height: 160px; padding: 5px; width: 700px; }
.formType01 label { display: inline-block; margin-right: 25px; }
.formType01 input[type=radio],
.formType01 input[type=checkbox] { margin-right: 5px; }

.formType02 {  border-collapse: collapse; margin: 25px 0; }
.formType02 th { background: #f0f0f0; border: 1px solid #ccc; padding: 10px 20px; text-align: left; }
.formType02 td { border: 1px solid #ccc; padding: 10px 15px; }
.formType02 td input[type=text] { border: 1px solid #ccc; margin: 0 5px; padding: 3px 5px; width: 70px; }
.formType02 td input[type=text].w-470 { width: 470px; }
.formType02 td input[type=text].w-per100 { width: 100%; }
.formType02 td input[type=text].w-140 { width: 140px; }

.formType03 { border-collapse: collapse; font-size: 1.4rem; margin: 25px 0; }
.formType03 th { background: #f0f0f0; border: 1px solid #ccc; padding: 6px 20px; }
.formType03 td { border: 1px solid #ccc; padding: 6px 40px; }

.formType04 { border-collapse: collapse; margin-bottom: 20px; }
.formType04 th { border: 1px solid #ccc; padding: 10px 20px; text-align: left; }
.formType04 th[colspan] { background: #ccc; }
.formType04 th.num { background: #f0f0f0; }
.formType04 th em { margin-right: 10px; }
.formType04 td { border: 1px solid #ccc; font-size: 1.4rem; padding: 10px 0 10px 30px; }
.formType04 td[colspan] { padding: 10px 5px 10px 20px; }
.formType04 label { display: inline-block; margin-right: 25px; }
.formType04 input[type=radio],
.formType04 input[type=checkbox] { margin-right: 5px; }
.formType04 .note{ font-size: 12px;}

.formType05 { border-collapse: collapse; font-size: 1.4rem; margin: 25px 0 10px; }
.formType05 th { background: #f0f0f0; border: 1px solid #ccc; padding: 6px 15px; }
.formType05 td { border: 1px solid #ccc;height: 34px; padding: 6px 15px; }

.formType05 td input[type=text] { border: 1px solid #ccc; margin: 0 5px; padding: 3px 5px; width: 70px; }
.formType05 td input[type=text] { width: 96%; }
.formType05 td select { background: url(/common/img/icon_arrrow_b.png) no-repeat 100% 50%; border: 1px solid #ccc; padding: 5px 30px 5px 5px; width: 100%; }
.formType05 td textarea { border: 1px solid #ccc; padding: 3px 5px; width: 100%; }
.ui-datepicker-year { background: url(/common/img/icon_arrrow_b.png) no-repeat 110% 50% #fff; border: 1px solid #aaaaaa; margin-right: 5px !important; padding: 0 0 0 5px; width: 100%; }
.formType05 .payment_block div { display: flex; margin: 5px 0; }
.formType05 .payment_block div .reason { width: 90px; }
.formType05 .payment_block div input { width: 150px; }
.formType05_Box .add_row { margin-bottom: 25px; text-align: right; }
.formType05_Box .add_row a { background: #ca3131; border-radius: 10px; color: #fff; font-size: 1.4rem; padding: 5px 10px; text-decoration: none; }

.formDoneBlock { background: #f0f0f0; margin: 60px auto 80px; padding: 40px 0 20px; text-align: center; width: 1000px; }
.formDoneBlock p { line-height: 1.6; margin-bottom: 1.5em; }

.error_box{ background-color: #f2dede; border: 1px solid transparent; border-color: #ebccd1; border-radius: 4px; color: #a94442;font-size: 14px; margin: 20px 0; padding: 15px 15px 15px 30px;}
.error_box li{ list-style-type: disc;margin-bottom: 3px;}

.request_notice{ font-weight: bold;margin: 20px 0;}

.requestTelBlock { display: block; overflow: hidden; margin: 0 auto 40px; padding: 25px 40px; width: 1000px; background: #f6f6f6; }


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


/*---------------------
  telework
---------------------*/
.teleworkBlock01 { display: block; overflow: hidden; padding: 0 0 45px; text-align: center; }
.teleworkBlock01 h2 { font-size: 3rem; line-height: 1.8; margin: 55px 0 25px; }
.teleworkBlock01 p { color: #025883; font-size: 2.4rem; line-height: 1.8; margin-top: 23px; }
.teleworkBlock01 em { border-bottom: 4px solid #ff6000; font-size: 4.2rem; font-style: normal; font-weight: 700; }
.teleworkBlock01 h3 { font-size: 3rem; margin-top: 35px; }
.teleworkBlock01 ul { margin: 0 auto; text-align: left; width: 920px; }
.teleworkBlock01 ul li { background: #fff; margin-top: 30px; padding: 15px 20px 30px; width: 440px; }
.teleworkBlock01 ul dt { border-bottom: 3px solid #005685; font-size: 1.8rem; font-weight: 700; padding-bottom: 10px; }
.teleworkBlock01 ul dt .fsL { font-size: 2.4rem; }
.teleworkBlock01 ul dd { margin-top: 15px; }

.teleworkBlock02 { font-size: 1.8rem; margin: 60px auto 80px; width: 1000px; }
.teleworkBlock02 h2 { font-size: 3rem; line-height: 1.8; margin-bottom: 25px; text-align: center; }
.teleworkBlock02 h3 { background: #fff; font-size: 2rem; margin: -15px 100px 20px; text-align: center; }
.teleworkBlock02 h4 { font-size: 1.8rem; margin: 0 60px 20px; padding: 6px 0; text-align: center; }
.teleworkBlock02 h4.typeBlue { border: 2px solid #036eb6; color: #036eb6; }
.teleworkBlock02 h4.typeRed { border: 2px solid #e40012; color: #e40012; }
.teleworkBlock02 .flex { display: flex; justify-content: space-between; margin: 60px 0 40px; position: relative; }
.teleworkBlock02 .flex:before { border-bottom: 54px solid transparent; border-left: 48px solid #005685; border-right: 1px solid transparent; border-top: 54px solid transparent; bottom: 50%; content: ""; height: 0; left: 50%; margin: auto auto auto -20px; position: absolute; right: 50%; top: 50%; width: 0; }
.teleworkBlock02 .flex > div { border: 1px solid #9d9d9e; padding: 0 40px 40px; width: 460px; }
.teleworkBlock02 .flex p { font-size: 1.6rem; }
.teleworkBlock02 .link { margin-top: 30px; }
.teleworkBlock02 .btn { font-size: 2.2rem; margin: 0 auto; padding: 29px 0 29px 45px; width: 475px; }
.teleworkBlock02 .btn:before { left: 45px; }

.teleworkBlock03 { font-size: 1.8rem; margin: 60px auto 40px; width: 1000px; }
.teleworkBlock03 h2 { font-size: 3rem; line-height: 1.8; margin-bottom: 25px; text-align: center; }
.teleworkBlock03 .flex { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 60px 0 40px; }
.teleworkBlock03 .flex > div { background: #f6f6f6; margin-bottom: 40px; padding: 40px; width: 480px; }
.teleworkBlock03 h4 { border-bottom: 1px solid #005685; font-size: 1.8rem; height: 4em; margin: 0 0 15px; padding-bottom: 13px; text-align: center; vertical-align: middle; }
.teleworkBlock03 p { font-size: 1.6rem; }
.teleworkBlock03 .result { border: 2px solid #e40012; font-size: 2.2rem; font-weight: 700; margin-top: 20px; padding: 8px 0; text-align: center; }
.teleworkBlock03 .fcRed { color: #e40012; }
.teleworkBlock03 .fcBlue { color: #005685; font-size: 2.4rem; }
.teleworkBlock03 .flex > div:nth-child(5) { margin: 50px auto 40px; position: relative; width: 740px; }
.teleworkBlock03 .flex > div:nth-child(5):before { background: #005685; content: ""; height: 3px; left: 0; margin: auto; position: absolute; right: 0; top: -46px; width: 50px; }
.teleworkBlock03 .flex > div:nth-child(5):after { background: #005685; content: ""; height: 50px; left: 0; margin: auto; position: absolute; right: 0; top: -70px; width: 3px; }


/*---------------------
  leak-contract
---------------------*/
.leak-contractBlock01 { padding: 50px calc(50% - 500px) 60px; }
.leak-contractBlock01 .titleStyleH4 { line-height: 1.8; margin-top: 0; }
.leak-contractBlock01 .txt01 { background: #fff; font-size: 2.2rem; font-weight: 700; padding: 25px; text-align: center; }

.leak-contractBlock02 { background: #000b10 url("/common/img/leak-contract_img03.png") no-repeat 50% 0; padding: 10px 0 40px; text-align: center; }
.leak-contractBlock02 .titleStyleH4 { color: #fff; }
.leak-contractBlock02 .mt60 { margin-top: 60px; }

.leak-contractBlock03 { padding: 30px 0; text-align: center; }
.leak-contractBlock03 h2 { font-size: 4.2rem; }
.leak-contractBlock03 p { font-size: 2.6rem; font-weight: 700; margin: 30px 0; }
.leak-contractBlock03 .markerThin { background: linear-gradient(transparent 94%, #ff6000 0%); }

.leak-contractBlock04 { padding: 5px 0 40px; }
.leak-contractBlock04 h2 { color: #fff; }
.leak-contractBlock04 ol { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 40px auto 0; width: 950px; }
.leak-contractBlock04 li { background-image: -moz-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -webkit-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); background-image: -ms-linear-gradient( 0deg, rgb(230,230,230) 0%, rgb(255,255,255) 50%, rgb(230,230,230) 100%); margin-top: 1px; position: relative; width: 316px; }
.leak-contractBlock04 li:nth-child(1),
.leak-contractBlock04 li:nth-child(2),
.leak-contractBlock04 li:nth-child(3) { padding-bottom: 20px; }
.leak-contractBlock04 li:before { content: ""; height: 88px; left: 50%; margin-left: -44px; position: absolute; top: -25px; width: 88px; }
.leak-contractBlock04 li:nth-child(1):before { background: url("/common/img/feature_img09.png") no-repeat; }
.leak-contractBlock04 li:nth-child(2):before { background: url("/common/img/feature_img10.png") no-repeat; }
.leak-contractBlock04 li:nth-child(3):before { background: url("/common/img/feature_img11.png") no-repeat; }
.leak-contractBlock04 li:nth-child(4):before { background: url("/common/img/feature_img12.png") no-repeat; }
.leak-contractBlock04 li:nth-child(5):before { background: url("/common/img/feature_img13.png") no-repeat; }
.leak-contractBlock04 li:nth-child(6):before { background: url("/common/img/feature_img14.png") no-repeat; }
.leak-contractBlock04 dl { margin: 18px; }
.leak-contractBlock04 dt { font-size: 1.8rem; font-weight: 700; margin-bottom: 10px; text-align: center; }
.leak-contractBlock04 dd { font-size: 1.4rem; line-height: 1.6; margin-top: 10px; }

.leak-contractBlock05 { margin: 80px auto; width: 1000px; }
.leak-contractBlock05 .box01 { background: #fff1e4; }
.leak-contractBlock05 .box01 .title { background: #d77413; color: #fff; font-size: 1.8rem; font-weight: 700; padding: 10px; text-align: center; }
.leak-contractBlock05 .box01 .flex { padding: 20px 80px 30px; }
.leak-contractBlock05 .box01 dl { background: #fff; border: 2px solid #d77413; width: 400px; }
.leak-contractBlock05 .box01 dt { background: #d77413; color: #fff; font-size: 1.8rem; font-weight: 700; padding: 10px; text-align: center; }
.leak-contractBlock05 .box01 dd { padding: 15px 25px; }
.leak-contractBlock05 .box02 { background: #ebebeb; margin-top: 30px; padding: 20px 40px; width: 480px; }
.leak-contractBlock05 .box02 dt { font-size: 2.2rem; font-weight: 700; margin-bottom: 10px; }

.leak-contractBlock06 { font-size: 1.8rem; margin: 30px auto 80px; width: 1000px; }
.leak-contractBlock06 ul { display: flex; flex-wrap: wrap; }
.leak-contractBlock06 li { width: 480px; }
.leak-contractBlock06 li:nth-child(odd) { margin-right: 40px; }
.leak-contractBlock06 dt { margin-top: 25px; }
.leak-contractBlock06 dd { margin-top: 15px; }


/*---------------------
  it-contract
---------------------*/
.it-contractBlock01 { padding: 30px calc(50% - 500px) 60px; }
.it-contractBlock01 .titleStyleH4 { line-height: 1.8; }
.it-contractBlock01 p { color: #025883; font-size: 2.4rem; margin-top: 40px; }
.it-contractBlock01 .fsL { font-size: 4.2rem; }
.it-contractBlock01 .markerThin { background: linear-gradient(transparent 94%, #ff6000 0%); }
.it-contractBlock01-1 { background: #000b11 url("/common/img/it-contract_img02.png") 50% 0; padding: 0 calc(50% - 500px) 40px; position: relative; }
.it-contractBlock01-1 figure img { margin-top: -30px; }

.it-contractBlock02 { font-size: 1.8rem; margin: 30px auto 80px; width: 1000px; }
.it-contractBlock02 .box01 { background: #fff1e4; margin: 30px 0; text-align: center; }
.it-contractBlock02 .box01 dt { background: #d77413; color: #fff; font-size:  1.8rem; font-weight: 700; padding: 10px; }
.it-contractBlock02 .box01 dd { padding: 20px; }
.it-contractBlock02 .box01 small { display: block; margin-top: 15px; }
.it-contractBlock02 table { margin-top: 30px; }
.it-contractBlock02 table caption { font-size: 2rem; font-weight: 700; margin-bottom: 10px; text-align: center; }
.it-contractBlock02 table th[scope="col"] { background: #666; color: #fff; font-size: 1.6rem; padding: 10px 0; }
.it-contractBlock02 table th[scope="col"]:first-child { font-size: 1.4rem; width: 90px; }
.it-contractBlock02 table th[scope="row"] { background: #d77413; color: #fff; font-size: 1.6rem; }
.it-contractBlock02 table .vertical { display: inline-block; height: 7em; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; }
.it-contractBlock02 table td { font-size: 1.4rem; padding: 10px 15px; }
.it-contractBlock02 table .basicBox { border: 2px solid #143d91; border-radius: 14px; padding: 10px; width: 260px; }
.it-contractBlock02 table .wideBox { border: 2px solid #117fc7; border-radius: 14px; padding: 10px; width: 260px; }

.it-contractBlock03 { font-size: 1.4rem; margin: 30px auto 80px; width: 1000px; }
.it-contractBlock03 .komeList >* { margin-bottom: 0.5em; }

.it-contractBlock04 { font-size: 1.8rem; margin: 30px auto; width: 1000px; }
.it-contractBlock04 .acciBox { background: #f6f6f6; line-height: 1.6; margin: 25px 0; padding: 25px 40px; }
.it-contractBlock04 .acciBox h3 { border-bottom: 1px solid #005685; font-size: 2rem; padding-bottom: 10px; text-align: center; }
.it-contractBlock04 .acciBox figure { margin: 20px 0; text-align: center; }
.it-contractBlock04 .acciBox dl { background: #fff; border: 1px solid #005685; margin: 20px 0; padding: 20px 40px; text-align: center; }
.it-contractBlock04 .acciBox dt span { font-size: 2.4rem; }
.it-contractBlock04 .acciBox dd { margin-top: 15px; }
.it-contractBlock04 .exampleBox { margin-bottom: 60px; width: 480px; }
.it-contractBlock04 .exampleBox dt { border-bottom: 4px solid #005685; font-weight: 700; margin-bottom: 15px; padding-bottom: 5px; }
.it-contractBlock04 .exampleBox dd { font-size: 1.6rem; line-height: 1.6; }
.it-contractBlock04 .exampleBox dd.border { border-top: 1px solid #000; margin-top: 20px; padding-top: 20px; }


/*---------------------
  it-contract
---------------------*/
.option-contractBlock01 { padding: 0 calc(50% - 500px) 30px; }
.option-contractBlock01 .bgWhite { padding: 20px 30px; }
.option-contractBlock01 table th[scope="col"] { background: #666; color: #fff; padding: 6px; }
.option-contractBlock01 table td { padding: 6px 15px; }
.option-contractBlock01 table .planset { background: #e6e6e6; }
.option-contractBlock01 table .option { background: #d77413; color: #fff; }
.option-contractBlock01 table caption { caption-side: bottom; font-size: 1.4rem; margin-top: 10px; text-align: left; }

.option-contractBlock02 { margin: 30px auto 80px; width: 1000px; }
.option-contractBlock02 hr { border: none; border-top: 1px solid #ccc; height: 1px; margin: 40px 0; }
.option-contractBlock02 .box01 { background: #fff1e4; margin: 0 auto 20px; width: 680px; }
.option-contractBlock02 .box01.w100 { width: 1000px; }
.option-contractBlock02 .box01 > dt { background: #d77413; color: #fff; font-size: 1.8rem; font-weight: 700; margin-bottom: 30px; padding: 10px; text-align: center; }
.option-contractBlock02 .box01 > dd { padding: 0 80px 30px; }
.option-contractBlock02 .box01 > dd.padNone { padding: 0 0 30px; }
.option-contractBlock02 .box02 { background: #fff; border: 2px solid #d77413; }
.option-contractBlock02 .box02 dt { background: #d77413; color: #fff; font-size: 1.8rem; font-weight: 700; padding: 10px; text-align: center; }
.option-contractBlock02 .box02 dd { padding: 20px 40px; }
.option-contractBlock02 .box02 figure { margin-top: 20px; }
.option-contractBlock02 .box02 hr { border: none; border-top: 2px solid #d77413; height:2px; margin: 20px 0; }
.option-contractBlock02 table { margin-top: 30px; }
.option-contractBlock02 table caption { font-size: 2rem; font-weight: 700; margin-bottom: 10px; text-align: center; }
.option-contractBlock02 table th[scope="col"] { background: #666; color: #fff; font-size: 1.6rem; padding: 10px 0; }
.option-contractBlock02 table th[scope="row"] { font-size: 1.6rem; padding: 10px 15px; text-align: left; }
.option-contractBlock02 table th[scope="row"] ul { display: flex; justify-content: center; }
.option-contractBlock02 table th[scope="row"] li { width: 160px; }
.option-contractBlock02 table td { font-size: 1.4rem; padding: 10px 15px; }
.option-contractBlock02 .link { margin: 60px 0; }
.option-contractBlock02 .btn { font-size: 2.2rem; margin: 0 auto; padding: 29px 0 29px 45px; width: 475px; }
.option-contractBlock02 .btn:before { left: 45px; }
.option-contractBlock02 table .btn { font-size: 1.6rem; margin: 5px auto 0 0; padding: 12px 0 12px 45px; width: 380px; }
.option-contractBlock02 table .btn:before { left: 20px; }


/*---------------------
  見た目追加
---------------------*/
/* １行上に余白 */
.mt-1line{ margin-top: 1em; }

/* 売上高ブロック */
small + .sales-block{ margin-top: 10px; }
.sales-block input{ width: 100px; }
.inputNumber::placeholder{ color: #ccc; }
.sales-heading{ font-size: 17px; font-weight: bold; }
.sales-body{ margin-top: 10px; }
.sales-block + .sales-block{ margin-top: 25px; padding-top: 25px; border-top: 1px dashed #dcdcdc; }

/* 1年間の売上高 */
.salesView{ margin-top: 15px; padding: 18px; border: 1px solid #d6d6d6; border-radius: 5px; background: #fafafa; }
.salesView_txt{ color: #444; font-size: 36px; font-weight: bold; line-height: 1; }

.sales-block + .sales-note{ margin-top: 10px!important; }

/* 注釈 */
.attenNote{ margin-top: 25px; padding: 15px 18px; border: 1px solid #e1d1d1; border-radius: 5px; background: #faf7f7; color: #333; }

.attenNote_heading{ position: relative; padding-left: 27px; font-size: 18px; line-height: 1.3; }
.attenNote_heading span{ position: absolute; top: 50%; left: 0; transform: translateY(-50%); display: flex; align-items: center; justify-content: center; width: 22px; height: 22px; padding: 0 0 2px; border-radius: 50%; background: #c74545; color: #fff;  font-size: 16px; }
.attenNote_list{ margin: 8px 0 0 !important; }
.attenNote_list li,
.attenNote_text{ margin-left: 1em; text-indent: -1em; }

