/*--------------------------------------------------------
 スタイルリセット
-------------------------------------------------------*/
ul {
margin: 0;
padding: 0;
}

li {
list-style: none;
}

select {
padding: 4px 6px;
max-width: 100%;
border: 1px solid #ccc;
border-radius: 2px;
}

/*------------------------------------------------------------
 共通
-------------------------------------------------------------*/
* {
box-sizing: border-box;
}

html {
font-size: 10px;
}

body {
font-family: "FP-ヒラギノ角ゴ ProN W3","ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,"Helvetica Neue",Helvetica,Arial,sans-serif !important;
color: #111;
font-size: 1.6rem;
}

h1,h2,h3,h4 {
line-height: 1.2;
}

p {
margin: 0 0 0.6rem;
font-size: 1.4rem;
line-height: 1.4;
color: #192538;
text-align: left;
}

p:last-child {
margin-bottom: 0;
}

a {
color: #018ada;
text-decoration: none;
}

a:hover {
color: #097388;
text-decoration: underline;
}

a:visited, a:active {
color: #018ada;
}

/* placeholder */
::-webkit-input-placeholder {
  color: #bbb;
  font-weight: normal;
  font-size: 0.9em;
}

::-moz-placeholder {
  color: #bbb;
  font-weight: normal;
  font-size: 0.9em;
  opacity: 1;
}

:-ms-input-placeholder {
  color: #bbb;
  font-weight: normal;
  font-size: 0.9em;
}

/*------------------------------------------------------------
 共通スタイル
-------------------------------------------------------------*/
a.logo-block {
display: block;
text-decoration: none;
}

.logo {
font-size: 20px;
font-family: "Open Sans",Helvetica,Arial,sans-serif;
color: #00abcd;
display: block;
float: left;
}

.beta {
margin: 4px 0 0 8px;
float: right;
display: block;
font-size: 12px;
color: #bbb;
}

strong.marker {
font-weight: bold;
color: #F4F922;
}

.note {
color: #92acb1;
font-size: 0.85em;
}

.kiyaku {
margin: 20px 0;
width: 100%;
}

.kiyaku-left {
padding: 10px 8px;
}

.kiyaku-right {
padding: 10px 8px;
}

/* mform.cssのチェックボックスのmarginを調整 */
.kiyaku .option {
margin-right: 0px !important;
vertical-align: inherit !important;
}

.kiyaku .checkbox {
border: 2px solid #bbb !important;
}

/* 入力項目での入力補助tooltip */
.helptip {
padding: 8px 12px;
display: none;
position: absolute;
bottom: -20px;
left: 0;
background: #333;
border-radius :6px;
color: #fff;
font-size: 1.2rem;
}

.helptip:after {
position: absolute;
top: -20px;
left: 35px;
content: "";
width: 0;
height: 0;
border-style: solid;
border: 14px solid transparent;
border-bottom: 10px solid #333;
z-index: 1;
}

/* 必須 
.required:after {
margin-left: 5px;
content: '*';
color: #e8436b;
}*/

/* チェックリスト */
ul.checklist {

}

ul.checklist li {
margin-bottom: 10px;
padding: 0 0 0 36px;
background: url(/img/checkbox.png) no-repeat left center;
background-size: contain;
font-size: 1.8rem;
font-weight: bold;
text-align: left;
}

ul.checklist .checkbox {
margin: 0;
padding: 2px;
background: #fff;
border: 2px solid #ccc;
width: 24px;
height: 24px;
display: inline-block !important;
position: relative;
}

ul.checklist .checkbox svg {
width: 18px;
height: 18px;
position: absolute;
top: 0;
left: 0;
}

#cont .logo {
color: #fff;
}

.service-cms {
margin-top: 20px;
padding-bottom: 30px;
text-align: center;
width: 100%;
}

.service-cms .service-item {
margin-bottom:30px;
padding: 10px 10px 20px;
border-bottom: 1px solid #eee;
}

.service-cms .service-icon {
margin: 0 auto 20px;
width: 100px;
height: 100px;
background: #fff;
border: 10px solid #ececec;
border-radius: 50%;
position: relative;
text-align: center;
-webkit-transition: all 0.2s ease-in-out;
transition: all 0.2s ease-in-out;
}

.service-cms .fa {
margin: 32px auto 0;
display: block;
text-align: center;
font-size: 54px;
}

.service-cms p {
font-size: 1.2rem;
color: #9a9999;
line-height: 1.5;
display: inline-block;
text-align: left;
}

.service-cms a {
padding: 6px 8px;
/*border: 1px solid #ddd;
border-radius: 6px;*/
list-style: none;
display: block;
font-size: 1.1rem;
color: #2794AD;
text-align: center;
}

.service-cms h3 {
margin: 0 auto 20px;
display: inline-block;
text-align: left;
line-height: 1.2;
font-size: 1.7rem;
color: #000;
font-weight: normal;
}

.service-cms hr {
margin: 0 auto 16px;
width: 145px;
border-width: 2px;
border-color: #58BED5;
}

.secondview p {
margin: 0;
line-height: 1.5rem;
text-align: center;
}

/*キャッチコピー（h1）*/
#home .firstview img {
display: block;
padding-left: 30px;
}

#home .catchcopy {
margin: 20px 0 16px;
font-size: 3.5rem;
color: #fff;
line-height: 1.2;
text-align: left;
display: inline-block;
}

#category .catchcopy {
margin: 20px 0 16px;
font-size: 3.6rem;
color: #fff;
line-height: 1.2;
}

#plan .catchcopy {
margin: 42px 0 16px;
font-size: 3.8rem;
color: #fff;
line-height: 1.2;
text-align: center;
text-shadow: 0px 0px 8px #000;
}

#cont .catchcopy {
margin: 8px 0;
font-size: 34px;
color: #fff;
}

/*タグライン*/
.tagline {
margin-bottom: 24px;
font-size: 1.4rem;
display: inline-block;
text-align: left;
}

#category .tagline {
display: block;
text-align: center;
color: #555;
}

/*メインコピー（h2）*/
#home .maincopy {
font-size: 2.3rem;
color: #fff;
text-align: center;
}

#cont .maincopy {
margin: 0;
padding-bottom: 16px;
border-bottom: 1px solid #ddd;
font-size: 3.8rem;
color: #192538;
}

/*フォントアイコン*/
.reason i {
display: block;
text-align: center;
color: #0F8493;
}

.reason {
margin: 20px 0 20px;
}

.reason-box {
margin-bottom: 40px;
padding: 0.2rem 0;
background: #fff;
font-size: 1.4rem;
}

.reason-box p {
font-size: 1.4rem;
text-align: left;
}

.reason-lsit {
padding: 6px 30px 0;
}

.reason-box li {
margin-bottom: 6px;
list-style: none;
}

/*理由（h3）*/
.reasoncopy {
margin: 0.5rem 0;
text-align: center;
color: #fff;
}

.reason-closing {
margin: 20px 0 10px;
font-size: 2rem;
line-height: 1.4rem;
text-align: center;
}

.reason-closing strong {
-webkit-box-shadow: 0 -7px 0 #D0F3FF inset;
box-shadow: 0 -7px 0 #D0F3FF inset;
font-weight: bold;
}


.riyuu {
margin-right: 1rem;
color: #0F8493;
}

section.odd {
background: #F5F3F1;
}

/*大見出し・中央寄せ*/
.headline {
margin: 40px 0 6px;
font-size: 3.6rem;
color: #364044;
text-align: center;
clear: both;
line-height: 1.3;
}

/*大見出し白文字バージョン*/
.note-section .headline {
color: #fff;
}

p.headline-sub {
margin: 0 0 34px;
text-align: left;
color: #808080;
font-size: 1.4rem;
line-height: 1.2;
display: inline-block;
}

.headline-border {
padding: 20px 40px;
border: 4px solid #333;
}

/*中見出し（h3）*/
.sub-headline {
font-size: 1.5rem;
color: #333;
}

/* 帯見出し */
.obi-content {
margin-bottom: 50px;
padding: 50px 30px 30px;
clear: both;
background: #f8f8f8;
border-radius: 20px;
position: relative;
}

.obi {
position: absolute;
top: -36px;
left: -24px;
padding: 10px 20px;
background: #525d61;
font-size: 1.6rem;
color: #fff;
}

.obi::before {
position: absolute;
content: '';
top: 100%;
left: 0;
border: none;
border-bottom: solid 8px transparent;
border-right: solid 24px rgb(181, 189, 191);
}

/*コピー*/
.copy {
font-size: 2.5rem;
color: #333;
text-align: center;
}

/*フッターリンク*/
.footer-link {
padding: 20px;
text-align: center;
}

.footer-link li {
margin: 0 8px;
display: inline-block;
  list-style: none;
  font-size: 12px;
  line-height: 20px;
}

.footer-link li a {
color: #eee;
text-decoration: none;
font-size: 1.2rem;
}

.footer-link li a:hover {
  text-decoration: underline;
}

/*------------------------------------------------------------
 スマートフォン特有
-------------------------------------------------------------*/
.sp-nav-bar {
font-size: 2em !important;
color: #00abcd;
}

/*------------------------------------------------------------
 グローバルナビ
-------------------------------------------------------------*/
.gnav-r {
display: flex;
}

.gnav-r li {
margin-left: 10px;
display: inline-block;
}

.gnav-r a {
padding: 6px 12px;
border: 1px solid #00BDAF;
border-radius: 4px;
display: block;
text-decoration: none;
font-size: 1.2rem;
color: #00BDAF;
transition: 0.15s;
}

.gnav-r a:hover {
background: #00BDAF;
color: #fff;
}

#cont .gnav-r a {
border: 1px solid #fff;
color: #fff;
}

.gnav-l {
margin-left: 40px;
display: flex;
}

.gnav-l li {
list-style: none;
display: inline-block;
}

.gnav-l a {
padding: 6px 18px;
text-decoration: none;
font-size: 1.4rem;
color: #192538;
}

.gnav-l a:hover {
background: #f8f8f8;
border-radius: 8px;
text-decoration: none;
color: #000;
}

.gnav-l i {
margin: 0 10px;
color: #ccc;
font-size: 11px;
}

#cont .gnav-l a {
color: #bbb;
}

#designer .gnav-l {
text-align: right;
}

#designer .gnav-l a {
color: #fff;
}

/* 隠れサブメニュー */
.gnav-menu:hover .gnav-submenu {
visibility: visible;
opacity: 1;
box-shadow: 0 0 5px #777;
}

.gnav-submenu {
padding: 10px;
position: absolute;
top: 61px;
width: 300px;
background: #fff;
-webkit-transition: all .1s ease;
transition: all .1s ease;
visibility: hidden;
opacity: 0;
z-index: 1;
}
/*
.gnav-submenu:before {
position: absolute;
top: -28px;
left: 34px;
content: "";
width: 0;
height: 0;
border-style: solid;
border: 20px solid transparent;
border-bottom: 10px solid #fff;
z-index: 1;
}
*/
.gnav-submenu li {
padding: 8px 0;
display: block;
border-bottom: 1px dotted #eee;
}

.gnav-submenu a.link {
margin: 0 auto;
padding: 8px 4px;
display: block;
width: 100%;
font-size: 1.3rem;
font-weight: normal;
text-align: left;
line-height: 1.3;
}

/*------------------------------------------------------------
 右ナビ
-------------------------------------------------------------*/
.sidebar {
margin: 0 0 30px;
padding: 0 27.83px;/* .nav-blockの幅を300pxにする */
border-left: 1px solid #ddd;
height: 100%;
min-height: 500px;
position: relative;
font-size: 1.4rem;
}

.nav-block {
margin-bottom: 30px;
padding: 20px 0;
}

.nav-block i {
margin-right: 10px;
}

.nav-block a {
margin-bottom: 10px;
padding-bottom: 10px;
display: block;
border-bottom: 1px solid #ddd;
text-decoration: none;
}

.nav-block img {
margin-right: 10px;
width: 60px;
display: block;
float: left;
}

.nav-cate {
margin: 0 0 16px;
padding: 10px 0;
border-radius: 4px;
color: #ccc;
font-family: Helvetica, Arial, sans-serif;
}

.nav-title {
margin: 0;
font-size: 1.5rem;
font-weight: bold;
color: #192538;
}

.nav-block a:hover .nav-title,
.nav-block a:active .nav-title {
text-decoration: underline;
}

.nav-subtitle {
color: #999;
font-size: 1.2rem;
}

/*------------------------------------------------------------
 TOPページ（home）
-------------------------------------------------------------*/
.home-price {
margin: 0 auto;
padding: 20px;
background: #fff;
display: table;
max-width: 640px;
width: 96%;
}

.home-price-inner {
padding: 0 10px;
display: table-cell;
width: 50%;
}

.home-price-headline {
margin: 0;
padding: 12px 24px;
background: #eee;
font-size: 1.8rem;
}

.home-price p {
margin-top: 14px;
font-size: 1.6rem;
text-align: center;
color: #192538;
}

/*------------------------------------------------------------
 プラン・価格
-------------------------------------------------------------*/
#plan .entry-step {
margin: 20px auto;
padding: 30px 20px;
display: table;
background: #f0f8ff;
border-radius: 10px;
max-width: 720px;
width: 100%;
position: relative;
}

#plan .entry-step:not(:last-child):after {
position: absolute;
bottom: -20px;
left: 35px;
content: "";
width: 0;
height: 0;
border-style: solid;
border: 10px solid transparent;
border-top: 10px solid #f0f8ff;
z-index: 1;
}

#plan .entry-step-left {
padding: 0 20px 0 0;
display: table-cell;
width: 100px;
}

#plan .entry-step-right {
display: table-cell;
width: 100%;
}

.entry-step h3 {
margin: 0 0 3px 0;
padding: 0;
text-align: left;
font-size: 23px;
font-weight: normal;
}

#plan .entry-step p {
padding: 12px 20px;
background: #fff;
border-radius: 10px;
}

#plan .entry-step-number {
font-size: 24px;
color: #7caeda;
line-height: 1.2;
text-shadow: 1px 1px 1px #fff;
font-family: Impact, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo;
}

/*------------------------------------------------------------
 コンテンツ
-------------------------------------------------------------*/
.contents {
margin: 0 auto;
padding: 20px 0 40px;
max-width: 720px;
}

.contents_meta {
padding: 16px 0;
}

.contents_author, .contents_posted, .contents_updated {
margin: 0 10px 0 0;
display: inline-block;
font-size: 11px;
font-weight: normal;
color: #aaa;
}

/* 目次 */
.contents-link {
text-align: left;
}

.contents-link h3 {
margin: 0 auto 10px;
padding: 8px;
background: #f8f8f8;
text-align: center;
font-size: 1.6rem;
font-weight: normal;
}

.contents-link ol {
margin: 6px 6px 6px 40px;
padding: 0;
}

.contents-link a {
font-size: 1.6rem;
}


/*------------------------------------------------------------
 機能・サービス
-------------------------------------------------------------*/
.service-link {

}

.service-link .service-link-headline {
margin: 25px auto 10px;
padding: 8px;
background: #fff;
text-align: center;
font-size: 1.6rem;
font-weight: normal;
}

.service-link .link {
margin: 0 auto;
padding: 8px 8px;
display: block;
border-bottom: 1px solid #ddd;
color: #097388;
font-size: 1.2rem;
font-weight: normal;
text-align: left;
line-height: 1.1;
}

.service-link .fa {
margin-right: 6px;
}

/*------------------------------------------------------------
 テーブル
-------------------------------------------------------------*/
table.msp-table {
margin: 20px auto;
width: 100%;
font-size: 14px;
}

table.msp-table th,
table.msp-table td {
padding: 20px 30px;
border-bottom: 1px solid #ddd;
}

table.msp-table th {
padding-left: 2rem;
width: 30%;
max-width: 200px;
text-align: left;
color: #01103A;
font-size: 1.8rem;
}

/*------------------------------------------------------------
 タブ
-------------------------------------------------------------*/
.tab {
margin: 20px 0 -14px;
}

.tab-nav {
margin: 0 auto;
display: block;
text-align: center;
}

.tab-nav .item {
margin: 0 20px;
display: inline-block;
font-size: 1.4rem;
}

.tab-nav .item a {
padding: 8px 20px 6px;
color: #192538;
}

.tab-nav .item.active a {
border-bottom: 4px solid #192538;
}

.tab-nav .item a:hover {
color: #192538;
border-bottom: 4px solid #192538;
text-decoration: none;
}

.tab-content {
padding: 30px 0;
}

.tab-panel {

}

