@charset "UTF-8";

html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  background-image: url("../hoshi2025/img/bg_grid.png");
  background-repeat: repeat;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden],
template {
  display: none;
}

a {
  background-color: transparent;
}

a:active,
a:hover {
  outline: 0;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b,
strong {
  font-weight: bold;
}

dfn {
  font-style: italic;
}

h1 {
  margin: 0;
}

mark {
  background: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

sub,
sup {
  vertical-align: baseline;
  line-height: 0;
  position: relative;
  font-size: 75%;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

figure {
  margin: 1em 40px;
}

hr {
  height: 0;
  -moz-box-sizing: content-box;
  box-sizing: content-box;
}

pre {
  overflow: auto;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

button,
input,
optgroup,
select,
textarea {
  margin: 0;
  color: inherit;
  font: inherit;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0;
}

input {
  line-height: normal;
}

input[type="checkbox"],
input[type="radio"] {
  padding: 0;
  box-sizing: border-box;
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

input[type="search"] {
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  -webkit-appearance: textfield;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

fieldset {
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
  border: 1px solid #c0c0c0;
}

legend {
  padding: 0;
  border: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

/*------------------------------------------------------------
賢威テンプレートの共通設定
-------------------------------------------------------------*/

html {
  overflow-y: scroll;
}

body {
  font-family: Verdana, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
}
.main-body .font-min {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.main-body .font-yu {
  font: bold 1.1em/100% "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}
a {
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  color: #03c;
  color: #222;
}

a:hover,
a:active,
a:focus {
  color: #f60;
}

address,
caption,
cite,
code,
dfn,
var,
h1,
h2,
h3,
h4,
h5,
h6 {
  font-style: normal;
  font-weight: normal;
}

q {
  quotes: none;
}

q:before,
q:after {
  content: "";
  content: none;
}

img {
  vertical-align: bottom;
}

div {
  word-wrap: break-word;
}

pre {
  overflow: auto;
  white-space: pre-wrap;
  word-wrap: break-word;
}

form {
  margin: 0;
}

button,
input,
select,
textarea,
optgroup,
option {
  vertical-align: baseline;
}

textarea {
  min-height: 100px;
  vertical-align: top;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  margin: 0;
}

table {
  width: 100%;
  word-break: break-all;
  word-wrap: break-word;
  border-spacing: 0;
}

caption {
  text-align: left;
}

img {
  height: auto;
  max-width: 100%;
}

img.photo {
  padding: 10px;
  background-color: #fff;
}

p,
.p {
  margin: 0 0 2.5em;
  line-height: 2.5em;
  background: transparent;
  border: none;
  color: #222;
}

ul,
ol {
  margin-left: 40px;
  padding-left: 0;
}

li {
  padding-top: 0.4em;
}

/*引用*/
blockquote {
  position: relative;
  margin: 2em 0;
  padding: 115px 45px 80px;
  background: #eeeeee;
}

blockquote p:last-child {
  margin-bottom: 0;
}

blockquote:before {
  position: absolute;
  top: 40px;
  left: 30px;
  width: 58px;
  height: 45px;
  content: url(../img/icon/icon-laquo.png);
}

blockquote:after {
  position: absolute;
  right: 30px;
  bottom: 20px;
  width: 58px;
  height: 45px;
  content: url(../img/icon/icon-raquo.png);
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  blockquote:before {
    display: inline-block;
    width: 58px;
    height: 45px;
    vertical-align: middle;
    background: url(../img/icon/icon-laquo@2x.png);
    -webkit-background-size: 58px 45px;
    background-size: 58px 45px;
    content: " ";
  }

  blockquote:after {
    display: inline-block;
    width: 58px;
    height: 45px;
    vertical-align: middle;
    background: url(../img/icon/icon-raquo@2x.png);
    -webkit-background-size: 58px 45px;
    background-size: 58px 45px;
    content: " ";
  }
}

blockquote a {
  color: #15a5e6;
}

blockquote a:hover,
blockquote a:active,
blockquote a:focus {
  color: #f60;
}

q {
  background: #ccc;
}

table.table-block {
  width: 100%;
  margin: 1em 0;
  padding: 0;
  border-top: 1px solid #cfcfcf;
  border-left: 1px solid #cfcfcf;
}

.table-block th,
.table-block td {
  padding: 1.25em 1em;
  border-right: 1px solid #cfcfcf;
  border-bottom: 1px solid #cfcfcf;
}

table.table-block01 {
  width: 100%;
  margin: 0;
  padding: 0;
}

.table-block01 th,
.table-block01 td {
  padding: 0;
}

th {
  background-color: #e9e9e9;
  font-weight: bold;
  text-align: left;
}

thead th {
  background-color: #909090;
  color: #fff;
  text-align: center;
}

dd {
  margin-left: 0;
  padding-left: 1em;
}

figure {
  margin: 1em 0;
}

/*--------------------------------------------------------
テンプレートレイアウト
--------------------------------------------------------*/

.site-header-in,
.global-nav-in,
.main-image-in,
.main-image-in-text,
.main-image-in-text-cont,
.main-body-in,
.site-footer-in {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 1200px; /*サイトの横幅。これより小さければレスポンシブ*/
  margin: auto;
}

.main-image-in img {
  width: 100%;
}

.main-image-in.wide,
.main-image-in-text.wide {
  width: 100%;
}

/*1カラムレイアウト*/
.col1 .main-body-in {
  width: 100%;
}

.col1 .breadcrumbs {
  width: 1200px;
  margin-right: auto;
  margin-left: auto;
}

/*2カラムレイアウト*/
.col2 .main-conts {
  float: left;
  width: 65%;
}

.col2 .sub-conts {
  float: right;
  width: 30%;
}

/*2カラムレイアウト（リバース）*/
.col2r .main-conts {
  float: right;
  width: 65%;
}

.col2r .sub-conts {
  float: left;
  width: 30%;
}

/*--------------------------------------------------------
ヘッダー
--------------------------------------------------------*/

.site-header-conts {
  display: table;
  width: 100%;
  padding: 30px 0;
}

/*ヘッダーロゴ*/
.site-title {
  margin: 30px auto 0;
  text-align: center;
}

.site-title a {
  color: #333;
  text-decoration: none;
}

.site-title a:hover,
.site-title a:active,
.site-title a:focus {
  text-decoration: underline;
}

.normal-screen .site-title {
  font-size: 3em;
}

.normal-screen .lp-catch {
  font-size: 1.5em;
}

/*ヘッダー右側の要素*/
.header-box {
  display: table-cell;
  text-align: right;
}

/*ヘッダーの全画面表示*/
.full-screen {
  color: #fff;
}

.full-screen .site-header-in {
  display: table;
}

.full-screen .site-header-conts {
  display: table-cell;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  width: 100%;
  padding: 1em;
  text-align: center;
  vertical-align: middle;
  text-shadow: 1px 1px 8px #666;
}

.full-screen .site-title {
  display: block;
}

.contact-btn {
  margin-bottom: 0;
}

.full-screen .site-header-conts h1 {
  width: auto;
  margin: 0;
}

.full-screen .site-header-conts p,
.full-screen .site-header-conts .p {
  font-size: 2em;
}

.full-screen .site-header-conts p a,
.full-screen .site-header-conts .p a {
  color: #fff;
  text-decoration: none;
}

/*--------------------------------------------------------
グローバルナビ
--------------------------------------------------------*/
.global-nav {
  padding: 0;
  background: #8f8f8f;
}

/*グローバルナビの開閉用ボタン*/
.global-nav-panel {
  display: none;
  font-size: 12px;
}

.global-nav-panel span {
  display: block;
  min-height: 20px;
  line-height: 20px;
}

.icon-gn-menu {
  padding-left: 25px;
  background: url(../img/icon/icon-gn-menu.png) left center no-repeat;
}

.icon-gn-close {
  padding-left: 25px;
  background: url(../img/icon/icon-gn-close.png) left center no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-gn-menu {
    background: url(../img/icon/icon-gn-menu@2x.png) left center no-repeat;
    -webkit-background-size: 20px 20px;
    background-size: 20px 20px;
  }

  .icon-gn-close {
    background: url(../img/icon/icon-gn-close@2x.png) left center no-repeat;
    -webkit-background-size: 20px 20px;
    background-size: 20px 20px;
  }
}

.global-nav .show-menu,
.global-nav .show-menu li ul {
  display: block !important;
}

.global-nav-in ul {
  display: table;
  width: 100%;
  margin: 0;
  padding: 0;
  border-left: 1px solid #bcbcbc;
  table-layout: fixed; /*メニューの幅を均等に*/
}

.global-nav-in li {
  display: table-cell;
  list-style: none;
  position: relative;
  vertical-align: middle;
  margin: 0;
  border-right: 1px solid #bcbcbc;
  text-align: center;
}

.global-nav-in li a {
  display: block;
  min-height: 1.5em; /*メニュー毎に高さが変わるときに調整*/
  padding: 1em; /*画像をメニューにする場合は値を0に*/
  background-color: #8f8f8f;
  color: #fff;
  text-decoration: none;
}

.global-nav-in li a:hover,
.global-nav-in li a:active,
.global-nav-in li a:focus {
  background-color: #eee;
  color: #333;
}

.global-nav-in li ul {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 10;
  width: 100%;
  border-left: 0;
}

/*ドロップダウンメニューのデザイン*/
.global-nav li ul li {
  display: list-item;
  width: 100%;
  margin: 0;
  padding: 0;
  border-top: 0;
  border-right: 0;
  white-space: normal;
}

.global-nav li ul li a {
  display: block;
  padding: 0.8em 2em;
}

.global-nav-in li ul ul {
  top: 0;
  left: 100%;
}

/*--------------------------------------------------------
メインビジュアル
--------------------------------------------------------*/

.main-image {
  margin-bottom: 2em;
}

.main-image-in-text {
  background-repeat: no-repeat;
  background-size: cover;
}

.main-image-in-text-cont {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 3em;
}

.main-image-in-text.wide .main-image-in-text-cont {
  width: 1200px;
}

.main-image-in-text p:last-child {
  margin-bottom: 0;
}

.main-copy {
  margin-bottom: 20px;
  font-size: 3em;
  text-align: center;
}

.sub-copy {
  font-size: 1.5em;
  text-align: center;
}

/*--------------------------------------------------------
メインボディ
--------------------------------------------------------*/

.main-body {
  margin-top: 2em;
  padding-bottom: 30px;
}

.no-gn .main-body {
  margin-top: 0;
}

.lp.no-gn .main-body {
  margin-top: 2em;
}

/*--------------------------------------------------------
パンくずリスト
--------------------------------------------------------*/

.breadcrumbs-in {
  margin: 2em 0;
  padding: 0;
  color: #999;
}

.no-gn .breadcrumbs-in {
  margin-top: 0;
}

.breadcrumbs-in a {
  color: #999;
}

.breadcrumbs-in a:hover,
.breadcrumbs-in a:active,
.breadcrumbs-in a:focus {
  color: #f60;
}

.breadcrumbs-in li {
  display: inline;
  list-style: none;
  position: relative;
  margin-right: 1em;
  padding-right: 25px;
  background: url(../img/icon/icon-brc.gif) right center no-repeat;
}

.breadcrumbs-in li:before {
  content: url(../img/icon/icon-folder-brc.png);
}

.breadcrumbs-in li.bcl-first:before {
  content: url(../img/icon/icon-home-brc.png);
}

.breadcrumbs-in li.bcl-last {
  background: none;
}

.breadcrumbs-in li.bcl-last:before {
  content: "";
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .breadcrumbs-in li {
    background: url(../img/icon/icon-brc@2x.gif) right center no-repeat;
    -webkit-background-size: 5px 9px;
    background-size: 5px 9px;
  }

  .breadcrumbs-in li:before {
    width: 12px;
    height: 12px;
    background: url(../img/icon/icon-folder-brc@2x.png);
  }

  .breadcrumbs-in li.bcl-first:before {
    width: 12px;
    height: 12px;
    background: url(../img/icon/icon-home-brc@2x.png);
  }

  .breadcrumbs-in li:before,
  .breadcrumbs-in li.bcl-first:before {
    display: inline-block;
    vertical-align: middle;
    -webkit-background-size: contain;
    background-size: contain;
    content: " ";
  }

  .breadcrumbs-in li.bcl-last:before {
    width: 0;
    height: 0;
    background: none;
    content: "";
  }
}

/*--------------------------------------------------------
メインコンテンツ
--------------------------------------------------------*/
.switch {
  visibility: hidden;
}

.main-conts {
  line-height: 1.8;
}

.col1 .main-conts {
  margin-bottom: 40px;
}

/*コンテンツの基本単位（「section-wrap」＋「section-in」でコンテンツを覆う）*/

.section-wrap {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin-bottom: 30px;
  padding: 40px;
  background-color: #fff;
  border: 1px solid #eaedf0;
}

.section-wrap.wide {
  border-right: 0;
  border-left: 0;
}

.section-wrap .section-in,
.float-area {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.float-area {
  margin-bottom: 10px;
}

.sub-conts .section-wrap .section-in .section-title,
.sub-conts .section-wrap .article-header .section-title {
  margin: 0 0 30px;
  padding: 0 0 11px;
  border-bottom: 1px solid #ccc;
  font-weight: normal;
  font-size: 1.125em;
}

/*サイトのページ幅はここで変更*/
.col1 .section-wrap,
.col1 .float-area {
  width: 1000px;
  margin-right: auto;
  margin-left: auto;
}

.col1 .section-wrap {
  padding: 40px 80px;
}

.col1 .section-wrap.wide {
  width: 100%;
  padding: 40px 0;
}

.col1 .section-wrap.wide .section-in {
  width: 1200px;
  margin-right: auto;
  margin-left: auto;
  padding: 30px 0;
}

/*--------------------------------------------------------
サブコンテンツ
--------------------------------------------------------*/
.sub-conts .section-wrap {
  margin: 0 auto;
  padding: 0;
  border: none;
}

.sub-conts .section-wrap .section-in {
  padding: 0 20px 30px;
}

.col1 .sub-conts .section-wrap .section-in {
  padding: 0 80px 30px;
}

/*サブコンテンツ用メニューのデザイン*/
.sub-conts .link-menu {
  margin-left: 0;
  padding-left: 0;
}

.sub-conts .link-menu li {
  list-style: none;
  margin-bottom: 1em;
  padding-left: 13px;
  background: url(../img/icon/icon-list-arw.png) left 6px no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .sub-conts .link-menu li {
    background: url(../img/icon/icon-list-arw@2x.png) left 6px no-repeat;
    -webkit-background-size: 7px 10px;
    background-size: 7px 10px;
  }
}

.sub-conts .link-menu ul {
  margin-top: 1em;
  margin-left: 10px;
  padding-left: 0;
}

/*--------------------------------------------------------
フッター
--------------------------------------------------------*/
.site-footer {
  background: #8f8f8f;
  color: #fff;
  text-align: center;
}

.site-footer-in a {
  color: #fff;
}

.site-footer-in a:hover,
.site-footer-in a:active,
.site-footer-in a:focus {
  color: #f60;
}

/*フッターナビ*/
.site-footer-nav {
  margin: 0 auto;
  padding: 1em 0;
  text-align: center;
}

.site-footer-nav li {
  display: inline;
  list-style: none;
  margin-left: 50px;
  padding: 0 0 0 13px;
  background: url(../img/icon/icon-arw-next02.png) left center no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .site-footer-nav li {
    background: url(../img/icon/icon-arw-next02@2x.png) left center no-repeat;
    -webkit-background-size: 7px 10px;
    background-size: 7px 10px;
  }
}

.site-footer-nav li:first-child {
  margin-left: 0;
}

/*コピーライト*/
.copyright {
  margin: 0;
  padding: 15px 0;
  background: #333;
  color: #fff;
  text-align: center;

  padding-bottom: 58px;
}
.copyright p {
  color: #fff;
}

.copyright small {
  font-size: 100%;
}

/*ページトップボタン*/
.page-top {
  display: none;
  position: fixed;
  right: 20px;
  bottom: 8px;
  z-index: 99;
  line-height: 1.2;
  margin-bottom: 0;
}

/*--------------------------------------------------------
見出し
--------------------------------------------------------*/

.section-in > h1:first-child,
.section-in > h2:first-child,
.section-in > h3:first-child,
.section-in > h4:first-child,
.section-in > h5:first-child,
.section-in > h6:first-child {
  margin-top: 0;
}

.main-body h2,
.main-body .h2 {
  margin: 40px 0 30px;
  padding: 10px 18px 5px 18px;
  color: #232323;
  text-align: center;
}

.main-body h3 {
  font-size: 1.3em;
  color: #232323;
  font-weight: bold;
  text-align: center;
  margin: 0 0 30px 0;
}
.main-body h3 span {
  border-right: 15px solid #eddf9e;
  border-left: 15px solid #eddf9e;
  padding: 0 10px;
}
@media only screen and (max-width: 375px) {
  .main-body h3 span {
    border-right: none;
    border-left: none;
  }
}

.main-body h4 {
  border-bottom: solid 2px #cdbc62;
  color: #232323;
  font-weight: bold;
  font-size: 1.2em;
  padding: 0;
  margin-bottom: 30px;
}
.main-body .voice-box h4 {
  border-bottom: solid 2px #fedebc;
}

.main-body h5,
.main-body .h5 {
  font-size: 1em;
  font-weight: bold;
  border-left: 15px solid #feecc8;
  padding-left: 10px;
}

.main-body h6 {
  background: #f5deb3;
  color: #666666;
  font-size: 13pt;
  width: 95%;
  border: 2px dashed #fff;
  border-radius: 5px;
  box-shadow: 0 0 3px 3px #f5deb3;
  text-shadow: 0px 0px 5px #fff;
  padding: 10px;
}

.main-body .p,
.main-body .p a {
  margin: 0 0 1em;
  font-size: 16px;
  background: transparent;
  border: none;
  color: #222;
}

/*画像を使う場合などに見出しのデザインを解除*/
.main-body .img-title {
  padding: 0;
  border: none;
  background: none;
  border-radius: 0;
  box-shadow: none;
  font-weight: normal;
  font-size: 1em;
}

.main-body h1 a,
.main-body h2 a,
.main-body .h2 a {
  color: #fff;
}

.main-body h1 a:hover,
.main-body h2 a:hover,
.main-body h1 a:active,
.main-body h2 a:active,
.main-body h1 a:focus,
.main-body h2 a:focus {
  color: #f60;
}

/*コンテンツの外にある見出し*/
.main-body .archive-title {
  margin: 0 0 0px;
}

.col1 .main-body .archive-title {
  max-width: 1200px;
  margin-right: auto;
  margin-left: auto;
}

/*記事タイトルや基本単位毎の最初の見出し*/
.section-wrap .section-title {
  line-height: 1.5;
  margin: 0 0 1em;
  padding: 0;
  border: none;
  background: transparent;
  color: #333;
  font-size: 2.125em;
}

.main-body .section-title a {
  color: #333;
  text-decoration: none;
}

.main-body .section-title a:hover,
.main-body .section-title a:active,
.main-body .section-title a:focus {
  color: #f60;
  text-decoration: underline;
}

.sub-conts .section-wrap .section-in .section-title,
.sub-conts .section-wrap .article-header .section-title {
  margin: 0 -20px 30px;
  padding: 0 0 11px;
  border-bottom: 1px solid #ccc;
  font-weight: normal;
  font-size: 1.125em;
}

/*--------------------------------------------------------
パーツ毎のスタイル
--------------------------------------------------------*/

/*最新情報*/
.news .news-date {
  margin-right: 1em;
}

.news-item {
  padding: 1em;
  border-bottom: 1px dotted #ccc;
}

.news-item:first-child {
  padding-top: 0;
}

.news-item:last-child {
  border-bottom: 0;
}

.news .news-thumb {
  float: left;
  margin-right: 15px;
  margin-bottom: 15px;
}

.main-body .news-title {
  margin-top: 20px;
  padding: 0;
  border: none;
  background: none;
  font-weight: normal;
  font-size: 1.5em;
}

.main-body .news-item:first-child .news-title {
  margin-top: 0;
}

.news .news-date,
.news .news-cat {
  display: inline-block;
  margin-bottom: 10px;
}

.cat {
  display: inline-block;
  margin-right: 0.5em;
  margin-bottom: 5px;
  padding: 0.1em 0.5em;
  border-bottom: none;
  color: #fff;
  font-size: 0.875em;
  word-break: break-all;
  border-radius: 3px;
}

.cat a {
  display: inline-block;
  margin: -0.1em -0.5em;
  padding: 0.1em 0.5em;
  color: #fff;
  text-decoration: none;
}

.cat001 {
  background: #4fc3f7;
}
.cat002 {
  background: #ff8a65;
}
.cat003 {
  background: #4db6ac;
}
.cat004 {
  background: #ba68c8;
}
.cat005 {
  background: #90a4ae;
}

.news .news-cont {
  margin-bottom: 0.5em;
}

/*記述リスト 横並び*/
.dl-style01 dt,
.dl-style01 dd {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 20px;
}

.dl-style01 dt {
  display: block;
  float: left;
  width: 240px;
  font-weight: bold;
}

.dl-style01 dd {
  padding-left: 250px;
  /*	border-bottom: 1px dotted #909090;*/
}
.dl-chat dt,
.dl-chat dd {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 10px 3px;
}
.dl-chat dt {
  display: block;
  float: left;
  width: 40px;
  /*	font-weight: bold;*/
}
.dl-chat dd {
  padding-left: 45px;
}

/*記述リスト 縦並び*/
.dl-style02 dt,
.dl-style02 dd {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 20px;
  border-bottom: 1px solid #fff;
}

.dl-style02 dt {
  display: block;
  background: #909090;
  color: #fff;
}

.dl-style02 dd {
  background: #e9e9e9;
}

/*テーブル（横幅がはみ出る場合にテーブルを囲む要素に設定）*/
.table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.table-comparison {
  margin: 3em 0;
  border-top: 0;
}

.table-comparison th,
.table-comparison td {
  padding: 10px;
  text-align: center;
}

.table-comparison .highlight span {
  display: block;
  margin: -11px;
}

.table-comparison .highlight span {
  display: block;
  padding: 11px;
}

.table-comparison thead .highlight span {
  margin-top: -25px;
  padding-top: 25px;
  border: 1px solid #cfcfcf;
  border-radius: 8px 8px 0 0;
}

.table-comparison th.highlight,
.table-comparison th.highlight span {
  background: #ffcc80;
}

.table-comparison tfoot td,
.table-comparison tfoot td span {
  background: #f2f2f2;
}

/*カテゴリー*/
.category-list {
  margin-left: 0;
  padding-left: 0;
}

.category-list li {
  list-style: none;
  margin-bottom: 1em;
  padding-left: 15px;
  background: url(../img/icon/icon-tag.png) left 6px no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .category-list li {
    background: url(../img/icon/icon-tag@2x.png) left 6px no-repeat;
    -webkit-background-size: 12px 12px;
    background-size: 12px 12px;
  }
}

.category-list ul {
  margin-top: 1em;
  margin-left: 10px;
  padding-left: 0;
}

/*タグクラウド*/
.tagcloud a {
  margin-right: 10px;
  padding-left: 15px;
  background: url(../img/icon/icon-tag.png) left bottom no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .tagcloud a {
    background: url(../img/icon/icon-tag@2x.png) left bottom no-repeat;
    -webkit-background-size: 12px 12px;
    background-size: 12px 12px;
  }
}

/*カレンダー*/
.calendar {
  background: #fff;
  font-size: 0.875em;
}

.calendar caption {
  font-weight: bold;
}

.calendar th,
.calendar td {
  padding: 10px 0;
  text-align: center;
}

.calendar tfoot td {
  padding: 10px;
  border-right-width: 0;
  text-align: left;
}

.calendar tfoot td:last-child {
  border-right-width: 1px;
  text-align: right;
}

.calendar td a {
  display: block;
  margin: -10px 0;
  padding: 10px 0;
}

/*段組*/
.col4-wrap,
.col3-wrap,
.col2-wrap {
  margin: 0 0 1em;
}

.col4-wrap .col,
.col4-wrap .col_2of4,
.col4-wrap .col_3of4,
.col3-wrap .col,
.col3-wrap .col_2of3,
.col2-wrap .col {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  float: left;
  margin-left: 2%;
}

.col4-wrap .col:first-child,
.col4-wrap .col_2of4:first-child,
.col4-wrap .col_3of4:first-child,
.col3-wrap .col:first-child,
.col3-wrap .col_2of3:first-child,
.col2-wrap .col:first-child {
  margin-left: 0;
}

.col4-wrap .col {
  width: 23.5%;
}

.col4-wrap .col_2of4 {
  width: 49%;
}

.col4-wrap .col_3of4 {
  width: 74.5%;
}

.col3-wrap .col {
  width: 32%;
}

.col3-wrap .col_2of3 {
  width: 66%;
}

.col2-wrap .col {
  width: 49%;
}

.col-link {
  border: 1px solid #ccc;
}

.col-link a {
  display: block;
  color: #333;
  text-decoration: none;
}

.col-link a:hover,
.col-link a:active,
.col-link a:focus {
  background: #eee;
}

/*バナーエリア*/
.banner-list {
  margin-left: 0;
}

.banner-list li {
  list-style: none;
}

.col1 .banner-list {
  text-align: center;
}

.col1 .banner-list li,
.main-conts .banner-list li {
  display: inline-block;
  margin-bottom: 1em;
  margin-left: 1em;
}

.col1 .banner-list li:first-child,
.main-conts .banner-list li:first-child {
  margin-left: 0;
}

/*引用元へのリンク*/
.link-ref {
  text-align: right;
}

/*動画などのレスポンシブ対応*/
embed,
iframe,
object,
video {
  max-width: 100%;
}

/*ボタン*/
.btn {
  margin: 0px auto 5px;
  display: inline-block;
  padding: 1em;
  border: 0;
  background: #ccc;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
  box-shadow: 4px 4px 0px #e9e9e9;
}

.btn:hover,
.btn:active,
.btn:focus {
  margin: 5px auto 0px;
  background: #eee;
  color: #fff;
  box-shadow: 4px 4px 0px #d0d0d0;
  cursor: pointer;
}

.btn-green {
  padding: 25px 50px;
  background: #75c53b;
  font-size: 1.25em;
  box-shadow: 4px 4px 0px #58942c;
}

.btn-green:hover,
.btn-green:active,
.btn-green:focus {
  background: #bae29d;
  box-shadow: 4px 4px 0px #acca96;
  cursor: pointer;
}

.btn-blue {
  padding: 25px 50px;
  background: #1f8ae5;
  font-size: 1.25em;
  box-shadow: 4px 4px 0px #1767ac;
}

.btn-blue:hover,
.btn-blue:active,
.btn-blue:focus {
  background: #8fc5f2;
  box-shadow: 4px 4px 0px #8bb3d6;
  cursor: pointer;
}

.btn-orange {
  padding: 10px 30px 7px 30px;
  background: #fe7200;
  font-size: 1.2em;
  box-shadow: 0px 6px 0px #cc5a04;
}

.btn-orange:hover,
.btn-orange:active,
.btn-orange:focus {
  background: #fbba83;
  box-shadow: 0px 1px 0px #cc5a04;
  cursor: pointer;
}

.btn-yellow {
  padding: 10px 30px 7px 30px;
  background: #ff9e00;
  font-size: 1.2em;
  box-shadow: 0px 6px 0px #dd8900;
}

.btn-yellow:hover,
.btn-yellow:active,
.btn-yellow:focus {
  background: #ff9e00;
  box-shadow: 0px 1px 0px #dd8900;
  cursor: pointer;
}

.btn-red {
  padding: 15px 50px 10px 50px;
  background: #f93d9a;
  font-size: 1.2em;
  box-shadow: 0px 5px 0px #ae023f;
}

.btn-red:hover,
.btn-red:active,
.btn-red:focus {
  background: #fd5993;
  box-shadow: 0px 1px 0px #f9035c;
  cursor: pointer;
}

.btn .free {
  font-size: 0.8em;
  margin: 0px 0px 5px 5px;
  padding: 3px;
  border: 1px solid #fff;
  border-radius: 3px;
}

.btn-form01 {
  padding: 25px 50px;
  background: #e53935;
  font-size: 1.25em;
}

.btn-form01 span {
  padding-left: 20px;
  background: url(../img/icon/icon-btn-arw01.png) left center no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .btn-form01 span {
    background: url(../img/icon/icon-btn-arw01@2x.png) left center no-repeat;
    -webkit-background-size: 10px 14px;
    background-size: 10px 14px;
  }
}

.btn-form02 {
  padding: 20px 30px;
  background: #c9c9c9;
  font-size: 1.125em;
  color: #666666;
}

.btn-form02 span {
  padding-left: 18px;
  background: url(../img/icon/icon-btn-arw02.png) left center no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .btn-mail span {
    background: url(../img/icon/icon-btn-arw02@2x.png) left center no-repeat;
    -webkit-background-size: 10px 14px;
    background-size: 10px 14px;
  }
}

.btn-mail {
  padding: 12px 32px;
  background: #909090;
}

.btn-mail span {
  padding-left: 30px;
  background: url(../img/icon/icon-btn-mail.png) left center no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .btn-mail span {
    background: url(../img/icon/icon-btn-mail@2x.png) left center no-repeat;
    -webkit-background-size: 24px 18px;
    background-size: 24px 18px;
  }
}

.btn-detail {
  background: #909090;
}

.btn-detail span {
  padding-left: 20px;
  background: url(../img/icon/icon-btn-arw01.png) left center no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .btn-detail span {
    background: url(../img/icon/icon-btn-arw01@2x.png) left center no-repeat;
    -webkit-background-size: 10px 14px;
    background-size: 10px 14px;
  }
}

/*チェックリスト*/
.check-list,
.check-list-l {
  margin-left: 0;
}

.voice-content a:link {
  color: #333;
  text-decoration: none;
}

.voice-content a:hover {
  color: #f93;
  text-decoration: underline;
}

.check-list li,
.check-list-l li {
  list-style: none;
}

.check-list li {
  margin-bottom: 1.5em;
  padding-left: 32px;
  background: url(../img/icon/icon-check-list.png) left 10px no-repeat;
}

.check-list-l li {
  margin-bottom: 2em;
  padding: 10px 0 10px 55px;
  background: url(../img/icon/icon-check-list-l.png) left 3px no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .check-list li {
    background: url(../img/icon/icon-check-list@2x.png) left 10px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .check-list-l li {
    background: url(../img/icon/icon-check-list-l@2x.png) left 3px no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*Q&A*/
.qa-list dt {
  display: block;
  margin-bottom: 30px;
  padding: 15px 0 15px 65px;
  background: url(../img/icon/icon-q.png) left 3px no-repeat;
  font-size: 1.25em;
}

.qa-list dd {
  margin-left: 0;
  margin-bottom: 70px;
  padding: 10px 0 10px 65px;
  background: url(../img/icon/icon-a.png) left 3px no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .qa-list dt {
    background: url(../img/icon/icon-q@2x.png) left 3px no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }

  .qa-list dd {
    background: url(../img/icon/icon-a@2x.png) left 3px no-repeat;
    -webkit-background-size: 48px 49px;
    background-size: 48px 49px;
  }
}

/*フロー図*/
.flow-chart {
  margin-left: 0;
}

.flow-chart li {
  list-style: none;
  margin-bottom: 20px;
  padding-bottom: 60px;
  background: url(../img/icon/icon-arrow-b-chart.png) center bottom no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .flow-chart li {
    background: url(../img/icon/icon-arrow-b-chart@2x.png) center bottom no-repeat;
    -webkit-background-size: 161px 40px;
    background-size: 161px 40px;
  }
}

.flow-chart li.end,
.flow-chart li:last-child {
  padding-bottom: 0;
  background: none;
}

.flow-chart .process-box {
  padding: 10px;
  background-color: #cccccc;
  color: #000;
}

/*予告エリア*/
.info-box {
  background-image: url(../img/cmmn_lp/wall4-light.png);
  padding-top: 30px;
  padding-right: 45px;
  padding-bottom: 30px;
  padding-left: 45px;
  margin: 30px;
}

.trailer-text {
  font-weight: bold;
  font-size: 1.25em;
}

.trailer-text-l {
  font-weight: bold;
  font-size: 1.5em;
}

/*関連記事*/
.related-thumb {
  overflow: hidden;
  width: 100%;
}

.related-thumb img {
  max-width: none;
}

.related-articles-thumbs01 ul {
  margin-left: 0;
}

.related-articles-thumbs01 li {
  list-style: none;
}

.related-articles-thumbs01 img {
  width: auto;
  max-height: 100px;
}

.related-articles-thumbs01 .related-thumb {
  float: left;
  width: 100px;
  margin-right: 20px;
  margin-bottom: 20px;
}

.related-articles-thumbs02 ul {
  overflow: hidden;
  margin-left: 0;
}

.related-articles-thumbs02 li {
  list-style: none;
  float: left;
  width: 30%;
  margin-left: 5%;
}

.related-articles-thumbs02 li:first-child {
  margin-left: 0;
}

.related-articles-thumbs02 img {
  width: auto;
  max-height: 160px;
}

/*お客様の声*/

.voice-box {
  padding: 30px;
  background: #fefeed;
}

.voice-content {
  overflow: hidden;
}

/*画像とテキストの組み合わせ*/
.col-onimage > .col {
  position: relative;
  overflow: hidden;
}

.col-onimage > .col .text-onimage {
  position: absolute;
  bottom: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 10px;
  background-color: rgba(0, 0, 0, 0.5);
  color: #fff;
}

.col-onimage02 > .col {
  background-position: center center;
  background-size: cover;
}

.col-onimage02 > .col .text-onimage {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 20px;
  background-color: rgba(0, 0, 0, 0.5);
  color: #fff;
}

.col-onimage > .col .text-onimage a,
.col-onimage02 > .col a {
  color: #fff;
}

.col-onimage > .col .text-onimage a:hover,
.col-onimage > .col .text-onimage a:active,
.col-onimage > .col .text-onimage a:focus,
.col-onimage02 > .col a:hover,
.col-onimage02 > .col a:active,
.col-onimage02 > .col a:focus {
  color: #f60;
}

/*ページ送り*/
.link-next {
  text-align: right;
}

.blog .article-body .link-next,
.archive .article-body .link-next,
.search .article-body .link-next {
  margin-bottom: 0;
}

.link-next a {
  padding-left: 13px;
  background: url(../img/icon/icon-arw-next.png) left 6px no-repeat;
}

.link-back a {
  padding-left: 13px;
  background: url(../img/icon/icon-arw-prev.png) left 6px no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .link-next a {
    background: url(../img/icon/icon-arw-next@2x.png) left 6px no-repeat;
    -webkit-background-size: 7px 10px;
    background-size: 7px 10px;
  }

  .link-back a {
    background: url(../img/icon/icon-arw-prev@2x.png) left 6px no-repeat;
    -webkit-background-size: 7px 10px;
    background-size: 7px 10px;
  }
}

.page-nav ol {
  margin-left: 0;
  text-align: center;
}

.page-nav li {
  display: inline-block;
  margin-right: 10px;
  padding: 4px 8px;
  border: 1px solid #c1c1c1;
}

.page-nav li:last-child {
  margin-right: 0;
}

.page-nav li a {
  display: block;
  margin: -4px -8px;
  padding: 4px 8px;
  color: #333;
  text-decoration: none;
}

.current,
.page-nav li a:hover,
.page-nav li a:active,
.page-nav li a:focus {
  background: #c1c1c1;
  color: #fff;
}

.page-nav-bf ul {
  margin-left: 0;
}

.page-nav-bf li {
  list-style: none;
}

.page-nav-next {
  float: right;
  padding-right: 13px;
  background: url(../img/icon/icon-arw-next.png) right center no-repeat;
}

.page-nav-prev {
  float: left;
  padding-left: 13px;
  background: url(../img/icon/icon-arw-prev.png) left center no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .page-nav-next {
    background: url(../img/icon/icon-arw-next@2x.png) right center no-repeat;
    -webkit-background-size: 7px 10px;
    background-size: 7px 10px;
  }

  .page-nav-prev {
    background: url(../img/icon/icon-arw-prev@2x.png) left center no-repeat;
    -webkit-background-size: 7px 10px;
    background-size: 7px 10px;
  }
}

/*--------------------------------------------------------
デザイン調整用のスタイル
--------------------------------------------------------*/

/*注記*/
.note {
  display: block;
  padding-left: 1em;
  text-indent: -1em;
}

.note2 {
  display: block;
  padding-left: 2em;
  text-indent: -2em;
}

/*必須項目・警告・エラーの文字色*/
.warning,
.error {
  color: #e53935 !important;
}

required {
  display: inline-block;
  color: #e53935 !important;
}

/*傍点*/
.dot {
  position: relative;
  padding-top: 5px;
}

.dot:before {
  position: absolute;
  top: 0;
  left: 50%;
  width: 0.2em;
  height: 0.2em;
  margin-left: -0.1em;
  background: #333;
  border-radius: 50%;
  content: "";
}

/*装飾*/
.shadow {
  box-shadow: 4px 4px 0px #e9e9e9;
}

.shadow02 {
  box-shadow: 0px 0px 4px #666;
}

.outline {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: 1px solid #ccc;
}

.frame {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 95%;
  padding: 8px;
  background: #fff;
  box-shadow: 0px 0px 8px #666;
}

.border {
  border: 1px solid #ccc;
}

/*画像のサイズ調整*/
img.resize10 {
  height: auto;
  max-width: 10%;
}

img.resize20 {
  height: auto;
  max-width: 20%;
}

img.resize30 {
  height: auto;
  max-width: 30%;
}

img.resize40 {
  height: auto;
  max-width: 40%;
}

img.resize50 {
  height: auto;
  max-width: 50%;
}

img.resize60 {
  height: auto;
  max-width: 60%;
}

img.resize70 {
  height: auto;
  max-width: 70%;
}

img.resize80 {
  height: auto;
  max-width: 80%;
}

img.resize90 {
  height: auto;
  max-width: 90%;
}

/*円*/
.circle {
  border-radius: 50%;
}

/*角丸*/
.rc4 {
  border-radius: 4px;
}
.rc4-tl {
  border-top-left-radius: 4px;
}
.rc4-tr {
  border-top-right-radius: 4px;
}
.rc4-bl {
  border-bottom-left-radius: 4px;
}
.rc4-br {
  border-bottom-right-radius: 4px;
}

.rc8 {
  border-radius: 8px;
}
.rc8-tl {
  border-top-left-radius: 8px;
}
.rc8-tr {
  border-top-right-radius: 8px;
}
.rc8-bl {
  border-bottom-left-radius: 8px;
}
.rc8-br {
  border-bottom-right-radius: 8px;
}

.rc12 {
  border-radius: 12px;
}
.rc12-tl {
  border-top-left-radius: 12px;
}
.rc12-tr {
  border-top-right-radius: 12px;
}
.rc12-bl {
  border-bottom-left-radius: 12px;
}
.rc12-br {
  border-bottom-right-radius: 12px;
}

/*角丸長方形
※高さ100pxまで*/
.rc50 {
  border-radius: 50px;
}

/*回り込み
※モバイル時にも解除されない*/
.fl-l {
  float: left;
  margin: 0 1em 1em 0;
}

.fl-r {
  float: right;
  margin: 0 0 1em 1em;
}

.fl-c {
  clear: both;
}

/*回り込み
※モバイル時には回り込み解除*/
.left {
  float: left;
  margin: 0 1em 1em 0;
}

.right {
  float: right;
  margin: 0 0 1em 1em;
}

#free .right {
  width: 320px;
  box-sizing: border-box;
  margin-left: 0;
}
#free .left {
  width: calc(100% - 320px);
  box-sizing: border-box;
  margin-right: 0;
}

.voice-headshot.right {
  min-width: 380px;
  box-sizing: border-box;
  margin-left: 0;
}

.left.voice-content {
  width: calc(100% - 380px);
  margin-right: 0;
  box-sizing: border-box;
}
/*文字の横位置*/
.al-l {
  text-align: left;
}
.al-r {
  text-align: right;
}
.al-c {
  text-align: center;
}

/*文字の縦位置*/
.vl-t {
  vertical-align: top !important;
} /*上寄せ*/
.vl-m {
  vertical-align: middle !important;
} /*中央寄せ*/
.vl-b {
  vertical-align: bottom !important;
} /*下寄せ*/

/*周りのブロックからの距離（margin）*/
.m0 {
  margin: 0 !important;
} /*周りからのmarginを0に*/
.m0-t {
  margin-top: 0 !important;
} /*上からのmarginを0に*/
.m0-r {
  margin-right: 0 !important;
} /*右からのmarginを0に*/
.m0-b {
  margin-bottom: 0 !important;
} /*下からのmarginを0に*/
.m0-l {
  margin-left: 0 !important;
} /*左からのmarginを0に*/

.m5 {
  margin: 5px !important;
}
.m5-t {
  margin-top: 5px !important;
}
.m5-r {
  margin-right: 5px !important;
}
.m5-b {
  margin-bottom: 5px !important;
}
.m5-l {
  margin-left: 5px !important;
}

.m10 {
  margin: 10px !important;
}
.m10-t {
  margin-top: 10px !important;
}
.m10-r {
  margin-right: 10px !important;
}
.m10-b {
  margin-bottom: 10px !important;
}
.m10-l {
  margin-left: 10px !important;
}

.m15 {
  margin: 15px !important;
}
.m15-t {
  margin-top: 15px !important;
}
.m15-r {
  margin-right: 15px !important;
}
.m15-b {
  margin-bottom: 15px !important;
}
.m15-l {
  margin-left: 15px !important;
}

.m20 {
  margin: 20px !important;
}
.m20-t {
  margin-top: 20px !important;
}
.m20-r {
  margin-right: 20px !important;
}
.m20-b {
  margin-bottom: 20px !important;
}
.m20-l {
  margin-left: 20px !important;
}

.m25 {
  margin: 25px !important;
}
.m25-t {
  margin-top: 25px !important;
}
.m25-r {
  margin-right: 25px !important;
}
.m25-b {
  margin-bottom: 25px !important;
}
.m25-l {
  margin-left: 25px !important;
}

.m30 {
  margin: 30px !important;
}
.m30-t {
  margin-top: 30px !important;
}
.m30-r {
  margin-right: 30px !important;
}
.m30-b {
  margin-bottom: 30px !important;
}
.m30-l {
  margin-left: 30px !important;
}

.m40 {
  margin: 40px !important;
}
.m40-t {
  margin-top: 40px !important;
}
.m40-r {
  margin-right: 40px !important;
}
.m40-b {
  margin-bottom: 40px !important;
}
.m40-l {
  margin-left: 40px !important;
}

.m50 {
  margin: 50px !important;
}
.m50-t {
  margin-top: 50px !important;
}
.m50-r {
  margin-right: 50px !important;
}
.m50-b {
  margin-bottom: 50px !important;
}
.m50-l {
  margin-left: 50px !important;
}

.m60 {
  margin: 60px !important;
}
.m60-t {
  margin-top: 60px !important;
}
.m60-r {
  margin-right: 60px !important;
}
.m60-b {
  margin-bottom: 60px !important;
}
.m60-l {
  margin-left: 60px !important;
}

.m70 {
  margin: 70px !important;
}
.m70-t {
  margin-top: 70px !important;
}
.m70-r {
  margin-right: 70px !important;
}
.m70-b {
  margin-bottom: 70px !important;
}
.m70-l {
  margin-left: 70px !important;
}

.m80 {
  margin: 80px !important;
}
.m80-t {
  margin-top: 80px !important;
}
.m80-r {
  margin-right: 80px !important;
}
.m80-b {
  margin-bottom: 80px !important;
}
.m80-l {
  margin-left: 80px !important;
}

.m90 {
  margin: 90px !important;
}
.m90-t {
  margin-top: 90px !important;
}
.m90-r {
  margin-right: 90px !important;
}
.m90-b {
  margin-bottom: 90px !important;
}
.m90-l {
  margin-left: 90px !important;
}

.m100 {
  margin: 100px !important;
}
.m100-t {
  margin-top: 100px !important;
}
.m100-r {
  margin-right: 100px !important;
}
.m100-b {
  margin-bottom: 100px !important;
}
.m100-l {
  margin-left: 100px !important;
}

.m120 {
  margin: 120px !important;
}
.m120-t {
  margin-top: 120px !important;
}
.m120-r {
  margin-right: 120px !important;
}
.m120-b {
  margin-bottom: 120px !important;
}
.m120-l {
  margin-left: 120px !important;
}

.m150 {
  margin: 150px !important;
}
.m150-t {
  margin-top: 150px !important;
}
.m150-r {
  margin-right: 150px !important;
}
.m150-b {
  margin-bottom: 150px !important;
}
.m150-l {
  margin-left: 150px !important;
}

.m200 {
  margin: 200px !important;
}
.m200-t {
  margin-top: 200px !important;
}
.m200-r {
  margin-right: 200px !important;
}
.m200-b {
  margin-bottom: 200px !important;
}
.m200-l {
  margin-left: 200px !important;
}

.m300 {
  margin: 300px !important;
}
.m300-t {
  margin-top: 300px !important;
}
.m300-r {
  margin-right: 300px !important;
}
.m300-b {
  margin-bottom: 300px !important;
}
.m300-l {
  margin-left: 300px !important;
}

/*周りのブロックからの距離（padding）*/
.p0 {
  padding: 0 !important;
}
.p0-t {
  padding-top: 0 !important;
}
.p0-r {
  padding-right: 0 !important;
}
.p0-b {
  padding-bottom: 0 !important;
}
.p0-l {
  padding-left: 0 !important;
}

.p5 {
  padding: 5px !important;
}
.p5-t {
  padding-top: 5px !important;
}
.p5-r {
  padding-right: 5px !important;
}
.p5-b {
  padding-bottom: 5px !important;
}
.p5-l {
  padding-left: 5px !important;
}

.p10 {
  padding: 10px !important;
}
.p10-t {
  padding-top: 10px !important;
}
.p10-r {
  padding-right: 10px !important;
}
.p10-b {
  padding-bottom: 10px !important;
}
.p10-l {
  padding-left: 10px !important;
}

.p15 {
  padding: 15px !important;
}
.p15-t {
  padding-top: 15px !important;
}
.p15-r {
  padding-right: 15px !important;
}
.p15-b {
  padding-bottom: 15px !important;
}
.p15-l {
  padding-left: 15px !important;
}

.p20 {
  padding: 20px !important;
}
.p20-t {
  padding-top: 20px !important;
}
.p20-r {
  padding-right: 20px !important;
}
.p20-b {
  padding-bottom: 20px !important;
}
.p20-l {
  padding-left: 20px !important;
}

.p25 {
  padding: 25px !important;
}
.p25-t {
  padding-top: 25px !important;
}
.p25-r {
  padding-right: 25px !important;
}
.p25-b {
  padding-bottom: 25px !important;
}
.p25-l {
  padding-left: 25px !important;
}

.p30 {
  padding: 30px !important;
}
.p30-t {
  padding-top: 30px !important;
}
.p30-r {
  padding-right: 30px !important;
}
.p30-b {
  padding-bottom: 30px !important;
}
.p30-l {
  padding-left: 30px !important;
}

.p40 {
  padding: 40px !important;
}
.p40-t {
  padding-top: 40px !important;
}
.p40-r {
  padding-right: 40px !important;
}
.p40-b {
  padding-bottom: 40px !important;
}
.p40-l {
  padding-left: 40px !important;
}

.p50 {
  padding: 50px !important;
}
.p50-t {
  padding-top: 50px !important;
}
.p50-r {
  padding-right: 50px !important;
}
.p50-b {
  padding-bottom: 50px !important;
}
.p50-l {
  padding-left: 50px !important;
}

.p60 {
  padding: 60px !important;
}
.p60-t {
  padding-top: 60px !important;
}
.p60-r {
  padding-right: 60px !important;
}
.p60-b {
  padding-bottom: 60px !important;
}
.p60-l {
  padding-left: 60px !important;
}

.p70 {
  padding: 70px !important;
}
.p70-t {
  padding-top: 70px !important;
}
.p70-r {
  padding-right: 70px !important;
}
.p70-b {
  padding-bottom: 70px !important;
}
.p70-l {
  padding-left: 70px !important;
}

.p80 {
  padding: 80px !important;
}
.p80-t {
  padding-top: 80px !important;
}
.p80-r {
  padding-right: 80px !important;
}
.p80-b {
  padding-bottom: 80px !important;
}
.p80-l {
  padding-left: 80px !important;
}

.p90 {
  padding: 90px !important;
}
.p90-t {
  padding-top: 90px !important;
}
.p90-r {
  padding-right: 90px !important;
}
.p90-b {
  padding-bottom: 90px !important;
}
.p90-l {
  padding-left: 90px !important;
}

.p100 {
  padding: 100px !important;
}
.p100-t {
  padding-top: 100px !important;
}
.p100-r {
  padding-right: 100px !important;
}
.p100-b {
  padding-bottom: 100px !important;
}
.p100-l {
  padding-left: 100px !important;
}

/*フォントの装飾*/
.b {
  font-weight: bold !important;
} /*太字*/
.normal {
  font-weight: normal !important;
} /*太字を解除*/

/*フォントサイズの設定*/
.big {
  font-size: 1.2em !important;
}
.big2 {
  font-size: 1.5em !important;
}
.big3 {
  font-size: 1.8em !important;
}
.small {
  font-size: 0.8em !important;
}

.f08em {
  font-size: 0.8em;
}
.f09em {
  font-size: 0.9em;
}
.f10em {
  font-size: 1em;
}
.f11em {
  font-size: 1.1em;
}
.f12em {
  font-size: 1.2em;
}
.f13em {
  font-size: 1.3em;
}
.f14em {
  font-size: 1.4em;
}
.f15em {
  font-size: 1.5em;
}
.f16em {
  font-size: 1.6em;
}
.f17em {
  font-size: 1.7em;
}
.f18em {
  font-size: 1.8em;
}
.f19em {
  font-size: 1.9em;
}
.f20em {
  font-size: 2em;
}
.f21em {
  font-size: 2.1em;
}
.f22em {
  font-size: 2.2em;
}
.f23em {
  font-size: 2.3em;
}
.f24em {
  font-size: 2.4em;
}
.f25em {
  font-size: 2.5em;
}
.f26em {
  font-size: 2.6em;
}
.f27em {
  font-size: 2.7em;
}
.f28em {
  font-size: 2.8em;
}
.f29em {
  font-size: 2.9em;
}
.f30em {
  font-size: 3em;
}

.f8pt {
  font-size: 8.5pt;
}
.f9pt {
  font-size: 9pt;
}
.f10pt {
  font-size: 10pt;
}
.f11pt {
  font-size: 11pt;
}
.f12pt {
  font-size: 12pt;
}
.f13pt {
  font-size: 13pt;
}
.f14pt {
  font-size: 14pt;
}
.f15pt {
  font-size: 15pt;
}
.f16pt {
  font-size: 16pt;
}
.f17pt {
  font-size: 17pt;
}
.f18pt {
  font-size: 18pt;
}
.f19pt {
  font-size: 19pt;
}
.f20pt {
  font-size: 20pt;
}
.f21pt {
  font-size: 21pt;
}
.f22pt {
  font-size: 22pt;
}
.f23pt {
  font-size: 23pt;
}
.f24pt {
  font-size: 24pt;
}

/*フォントの色設定*/
.red {
  color: #ee3300 !important;
} /*赤*/
.red2 {
  color: #e53935 !important;
} /*赤*/
.blue {
  color: #0000dd !important;
} /*青*/
.green {
  color: #4caf50 !important;
} /*緑*/
.yellow {
  color: #ffff00 !important;
} /*黄*/
.navy {
  color: #3f51b5 !important;
} /*紺*/
.orange {
  color: #ff9800 !important;
} /*橙*/
.pink {
  color: #ec407a !important;
} /*ピンク*/
.purple {
  color: #9c27b0 !important;
} /*紫*/
.olive {
  color: #808000 !important;
} /*オリーブ*/
.lime {
  color: #00ff00 !important;
} /*黄緑*/
.aqua {
  color: #00bcd4 !important;
} /*水色*/
.black {
  color: #000 !important;
} /*黒*/
.gray {
  color: #ccc !important;
} /*灰*/
.white {
  color: #fff !important;
} /*白*/
.brown {
  color: #6d4c33 !important;
} /*茶*/

/*色枠ボックス*/
.box-yellow,
.box-orange,
.box-pink,
.box-lime,
.box-white,
.box-gray {
  padding: 20px;
  margin: 20px 0;
}

.box-yellow {
  border: 1px solid #eddf9e;
} /*黄*/
.box-orange {
  background-color: #f90;
} /*橙*/
.box-pink {
  background-color: #ffccff;
} /*ピンク*/
.box-lime {
  background-color: #9f9;
} /*黄緑*/
.box-white {
  background-color: #fff;
} /*白*/
.box-gray {
  background-color: #ccc;
} /*灰*/

.box-yellow ul,
.box-orange ul,
.box-pink ul,
.box-lime ul,
.box-white ul,
.box-gray ul {
  margin-left: 20px;
}

/*行間の設定*/
.lh10 {
  line-height: 1 !important;
}
.lh11 {
  line-height: 1.1 !important;
}
.lh12 {
  line-height: 1.2 !important;
}
.lh13 {
  line-height: 1.3 !important;
}
.lh14 {
  line-height: 1.4 !important;
}
.lh15 {
  line-height: 1.5 !important;
}
.lh16 {
  line-height: 1.6 !important;
}
.lh17 {
  line-height: 1.7 !important;
}
.lh18 {
  line-height: 1.8 !important;
}
.lh19 {
  line-height: 1.9 !important;
}
.lh20 {
  line-height: 2 !important;
}

/*横幅を指定*/
.w05 {
  width: 5%;
}
.w10 {
  width: 10%;
}
.w15 {
  width: 15%;
}
.w20 {
  width: 20%;
}
.w25 {
  width: 25%;
}
.w30 {
  width: 30%;
}
.w35 {
  width: 35%;
}
.w40 {
  width: 40%;
}
.w45 {
  width: 45%;
}
.w50 {
  width: 50%;
}
.w55 {
  width: 55%;
}
.w60 {
  width: 60%;
}
.w65 {
  width: 65%;
}
.w70 {
  width: 70%;
}
.w75 {
  width: 75%;
}
.w80 {
  width: 80%;
}
.w85 {
  width: 85%;
}
.w90 {
  width: 90%;
}
.w95 {
  width: 95%;
}
.w100 {
  width: 100%;
}

/*下線や取消線の設定*/
.underline {
  text-decoration: underline !important;
}
.del {
  text-decoration: line-through;
}
.noborder {
  border: 0 !important;
} /*枠線を無くす*/

/*重なりの優先度*/
.z1 {
  z-index: 1 !important;
}
.z2 {
  z-index: 2 !important;
}
.z3 {
  z-index: 3 !important;
}
.z4 {
  z-index: 4 !important;
}
.z5 {
  z-index: 5 !important;
}
.z10 {
  z-index: 10 !important;
}
.z20 {
  z-index: 20 !important;
}
.z30 {
  z-index: 30 !important;
}
.z40 {
  z-index: 40 !important;
}
.z50 {
  z-index: 50 !important;
}

/*横並びリスト*/
.inline {
  margin: 1em 0;
  padding: 0;
}
.inline li {
  display: inline;
  list-style-type: none;
}

/*マーカー無しのリスト*/
.none {
  margin: 1em 0;
  padding: 0;
}
.none li {
  list-style-type: none;
}

/*------------------------------------------------------------
文字列の前にアイコン
-------------------------------------------------------------*/

/*ポイントアイコンアイコン*/
.icon-point {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-point.png) left 3px no-repeat;
}

.icon-point-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-point-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-point {
    background: url(../img/icon/icon-point@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-point-l {
    background: url(../img/icon/icon-point-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*注意アイコン*/
.icon-caution {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-caution.png) left 3px no-repeat;
}

.icon-caution-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-caution-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-caution {
    background: url(../img/icon/icon-caution@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-caution-l {
    background: url(../img/icon/icon-caution-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*NEWアイコン*/
.icon-new {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-new.png) left 3px no-repeat;
}

.icon-new-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-new-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-new {
    background: url(../img/icon/icon-new@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-new-l {
    background: url(../img/icon/icon-new-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*初心者アイコン*/
.icon-wakaba {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-wakaba.png) left 3px no-repeat;
}

.icon-wakaba-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-wakaba-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-wakaba {
    background: url(../img/icon/icon-wakaba@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-wakaba-l {
    background: url(../img/icon/icon-wakaba-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*別ウインドウアイコン*/
.icon-blank {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-blank.png) left 3px no-repeat;
}

.icon-blank-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-blank-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-blank {
    background: url(../img/icon/icon-blank@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-blank-l {
    background: url(../img/icon/icon-blank-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*矢印上アイコン*/
.icon-arrow-t {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-arrow-t.png) left 3px no-repeat;
}

.icon-arrow-t-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-arrow-t-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-arrow-t {
    background: url(../img/icon/icon-arrow-t@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-arrow-t-l {
    background: url(../img/icon/icon-arrow-t-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*矢印右アイコン*/
.icon-arrow-r {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-arrow-r.png) left 8px no-repeat;
}

li a span.icon-arrow-r {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-arrow-r.png) left -3px no-repeat;
  margin-left: 10px;
}
.icon-arrow-r-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-arrow-r-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-arrow-r {
    background: url(../img/icon/icon-arrow-r@2x.png) left 8px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-arrow-r-l {
    background: url(../img/icon/icon-arrow-r-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*矢印下アイコン*/
.icon-arrow-b {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-arrow-b.png) left 3px no-repeat;
}

.icon-arrow-b-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-arrow-b-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-arrow-b {
    background: url(../img/icon/icon-arrow-b@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-arrow-b-l {
    background: url(../img/icon/icon-arrow-b-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*矢印左アイコン*/
.icon-arrow-l {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-arrow-l.png) left 3px no-repeat;
}

.icon-arrow-l-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-arrow-l-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-arrow-l {
    background: url(../img/icon/icon-arrow-l@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-arrow-l-l {
    background: url(../img/icon/icon-arrow-l-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*ダウンロード用PDアイコン*/
.icon-dl {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-dl.png) left 3px no-repeat;
}

.icon-dl-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-dl-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-dl {
    background: url(../img/icon/icon-dl@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-dl-l {
    background: url(../img/icon/icon-dl-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*PDFアイコン*/
.icon-pdf {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-pdf.png) left 3px no-repeat;
}

.icon-pdf-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-pdf-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-pdf {
    background: url(../img/icon/icon-pdf@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-pdf-l {
    background: url(../img/icon/icon-pdf-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*Zipアイコン*/
.icon-zip {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-zip.png) left 3px no-repeat;
}

.icon-zip-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-zip-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-zip {
    background: url(../img/icon/icon-zip@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-zip-l {
    background: url(../img/icon/icon-zip-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*メールアイコン*/
.icon-mail {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-mail.png) left 3px no-repeat;
}

.icon-mail-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-mail-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-mail {
    background: url(../img/icon/icon-mail@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-mail-l {
    background: url(../img/icon/icon-mail-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*ショッピングカートアイコン*/
.icon-cart {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-cart.png) left 3px no-repeat;
}

.icon-cart-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-cart-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-cart {
    background: url(../img/icon/icon-cart@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-cart-l {
    background: url(../img/icon/icon-cart-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*虫めがねアイコン*/
.icon-search {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-search.png) left 3px no-repeat;
}

.icon-search-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-search-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-search {
    background: url(../img/icon/icon-search@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-search-l {
    background: url(../img/icon/icon-search-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*ホームアイコン*/
.icon-home {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-home.png) left 3px no-repeat;
}

.icon-home-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-home-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-home {
    background: url(../img/icon/icon-home@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-home-l {
    background: url(../img/icon/icon-home-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*フォルダアイコン*/
.icon-folder {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-folder.png) left 3px no-repeat;
}

.icon-folder-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-folder-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-folder {
    background: url(../img/icon/icon-folder@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-folder-l {
    background: url(../img/icon/icon-folder-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*時計アイコン*/
.icon-time {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-time.png) left 3px no-repeat;
}

.icon-time-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-time-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-time {
    background: url(../img/icon/icon-time@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-time-l {
    background: url(../img/icon/icon-time-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*カレンダーアイコン*/
.icon-calendar {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-calendar.png) left 3px no-repeat;
}

.icon-calendar-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-calendar-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-calendar {
    background: url(../img/icon/icon-calendar@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-calendar-l {
    background: url(../img/icon/icon-calendar-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*RSSアイコン*/
.icon-rss {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-rss.png) left 3px no-repeat;
}

.icon-rss-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-rss-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-rss {
    background: url(../img/icon/icon-rss@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-rss-l {
    background: url(../img/icon/icon-rss-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*ビルアイコン*/
.icon-building {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-building.png) left 3px no-repeat;
}

.icon-building-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-building-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-building {
    background: url(../img/icon/icon-building@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-building-l {
    background: url(../img/icon/icon-building-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

/*マップアイコン*/
.icon-map {
  padding: 0 0 0 30px;
  background: url(../img/icon/icon-map.png) left 3px no-repeat;
}

.icon-map-l {
  padding: 10px 0 10px 60px;
  background: url(../img/icon/icon-map-l.png) left top no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .icon-map {
    background: url(../img/icon/icon-map@2x.png) left 3px no-repeat;
    -webkit-background-size: 24px 24px;
    background-size: 24px 24px;
  }

  .icon-map-l {
    background: url(../img/icon/icon-map-l@2x.png) left top no-repeat;
    -webkit-background-size: 48px 48px;
    background-size: 48px 48px;
  }
}

.outbound {
  padding: 3px;
  padding-left: 15px;
  background: url(../img/icon/icon-outbound-link.png) left center no-repeat;
}

/*Retina（高解像度）ディスプレイ用*/
@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  .outbound {
    background: url(../img/icon/icon-outbound-link@2x.png) left center no-repeat;
    -webkit-background-size: 12px 13px;
    background-size: 12px 13px;
  }
}

/*--------------------------------------------------------
floatの回り込みを解除
--------------------------------------------------------*/
.site-header-conts:after,
.main-body-in:after,
.article-body:after,
.section-in:after,
.col4-wrap:after,
.col3-wrap:after,
.col2-wrap:after,
.news-item:after,
.related-articles-thumbs01 li:after,
.btn-area:after,
.page-nav-bf:after,
.clearfix:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
}

.main-body .small-link {
  font-size: 80%;
  text-align: right;
  background: transparent;
  color: initial;
  color: #222;
}
.main-body .small-link a {
  color: #222;
}

#mobile-head img {
  max-height: 100%;
  width: auto;
}

/*-----------------------------------------------------------
受講者の声
------------------------------------------------------------*/
.customers-box .left,
.customers-box .right {
  box-sizing: border-box;
}
.customers-voice.voice-box p {
  margin: 0;
}
.customers-box .img-box {
  width: 200px;
  text-align: center;
  margin: 0;
}
.customers-box .img-box p {
  text-align: center;
  padding: 0;
  font-size: 80%;
  font-weight: bold;
  line-height: 1.3em;
}
.customers-box .img-box img {
  width: 60%;
  position: relative;
  top: -10px;
}
.customers-box .voice-box {
  width: calc(100% - 250px);
  background: #fefceb; /*
		margin-top: 15px;*/
  margin-right: 15px;
  margin-left: 15px;
  margin-bottom: 16px;
}
.customers-voice.voice-box {
  position: relative;
}
.customers-voice.voice-box:after,
.customers-voice.voice-box:before {
  content: " ";
  height: 0;
  position: absolute;
  width: 0;
  border: solid transparent;
}
.customers-box-l .customers-voice.voice-box:after,
.customers-box-l .customers-voice.voice-box:before {
  right: 100%;
}

.customers-box-l .customers-voice.voice-box:after {
  border-width: 10px;
  border-right-color: #fefceb;
  top: 60px;
}
.customers-box-l .customers-voice.voice-box:before {
  border-width: 11px;
  border-right-color: #ccc;
  top: 59px;
}
.customers-box-r .customers-voice.voice-box:after,
.customers-box-r .customers-voice.voice-box:before {
  left: 100%;
}

.customers-box-r .customers-voice.voice-box:after {
  border-width: 10px;
  border-left-color: #fefceb;
  top: 60px;
}
.customers-box-r .customers-voice.voice-box:before {
  border-width: 11px;
  border-left-color: #ccc;
  top: 59px;
}

.fix-bottom-link {
  position: fixed;
  bottom: 0;
  text-align: center;
  right: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.7);
  padding: 10px;
}
.fix-bottom-link .btn-orange,
.fix-bottom-link .btn-yellow {
  padding: 5px 30px;
}

form#UserItemForm {
  width: 100% !important;
}
.input.text.required {
  width: 100%;
  box-sizing: border-box;
  padding-left: 15px;
}
input#Username1,
input#Username2,
input#Usermail,
input#Userzip {
  margin: 0;
  max-width: 98% !important;
  width: 100% !important;
  box-sizing: border-box;
}

.align_center {
  text-align: center;
}
.thumb_circle {
  border-radius: 50%;
}

.section-wrap.section-cut {
  margin-top: -20px !important;
}

body.iframe {
  background: white;
  color: #333;
  margin-top: 0;
}
body.iframe p,
body.iframe .h5 {
  color: #333;
}
body.iframe h2 {
  margin-top: 0;
}

.border-boxb {
  padding: 20px;
  border: solid 2px #960;
}

/*---------------------------------------------------------------------
	generated by Keni Template Maker Ver.7.0 on 2015-12-04 15:35:14
----------------------------------------------------------------------*/
.content_title h2 {
  font-size: 1em !important;
  padding: 0 !important;
}
.iframe-wrapper {
  margin: 5px 0 0 0;
  width: 100%;
  height: 300px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  display: inline-block;
}
.iframe {
  width: 100%;
  width: 100%;
  border: none;
  display: block;
}
.column span {
  display: inline-block;
}
.box_inner {
  width: 100%;
  max-width: 600px;
  margin: 20px auto;
}
#pageTop {
  position: fixed;
  bottom: 25px;
  right: 0px;
}
#pageTop a {
  display: block;
  z-index: 999;
  padding: 0px;
  text-decoration: none;
  text-align: center;
  -webkit-filter: drop-shadow(0px 2px 2px rgba(0, 0, 0, 0.5));
}
#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}
hr.grayhr {
  background-color: #fff;
  border-top: 2px dotted #eee;
}
