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

 初期化

============================================*/
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: top;
    background: transparent; }

body {
    line-height: 1; }

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

nav ul {
    list-style: none; }

blockquote, q {
    quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none; }

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    color: #333;
    vertical-align: baseline;
    background: transparent; }

/* change colours to suit your needs */
ins {
    background-color: #ff9;
    color: #000;
    text-decoration: none; }

/* change colours to suit your needs */
mark {
    background-color: #ff9;
    color: #000;
    font-style: italic;
    font-weight: bold; }

del {
    text-decoration: line-through; }

abbr[title], dfn[title] {
    border-bottom: 1px dotted;
    cursor: help; }

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

/* change border colour to suit your needs */
hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #D0D9D0;
    margin: 1em 0;
    padding: 0; }

input, select {
    vertical-align: middle; }
    
/* chtml5doctorから変更
--------------------------------------*/
ol li, ul li {
    list-style-type: none; }

*,
*::before,
*::after {
    -webkit-box-sizing: border-box;
            box-sizing: border-box; }

/* clerfix
--------------------------------------*/
.clear:after {
    content: "";
    clear: both;
    display: block; }

/* 追加
--------------------------------------*/
sup {
    /* sup位置調整 */
    line-height: 1;
    vertical-align: text-top;
    font-size: 1.1rem; }

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

 色指定メモ

 ============================================*/
/*
基本色 （紺色）


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

フォント

============================================*/
@font-face{ 
	font-family: 'mame'; 
	src: url('../font/mameh4.eot'); /* IE9以上用 */
	src: url('../font/mameh4.eot?#iefix') format('embedded-opentype'), /* IE8以前用 */
		url('../font/mameh4.woff2') format('woff'), /* モダンブラウザ用 */
		url('../font/mameh4.otf') format('opentype'); /* iOS, Android用 */
	font-weight: 400; /* 念の為指定しておきます */
	font-style: normal;
  }

@font-face{ 
	font-family: 'mame3_5'; 
	src: url('../font/mameh3_5.eot'); /* IE9以上用 */
	src: url('../font/mameh3_5.eot?#iefix') format('embedded-opentype'), /* IE8以前用 */
		url('../font/mameh3_5.woff2') format('woff'), /* モダンブラウザ用 */
		url('../font/mameh3_5.otf') format('opentype'); /* iOS, Android用 */
	font-weight: 400; /* 念の為指定しておきます */
	font-style: normal;
}

@font-face{ 
	font-family: 'mame4'; 
	src: url('../font/mameh4.eot'); /* IE9以上用 */
	src: url('../font/mameh4.eot?#iefix') format('embedded-opentype'), /* IE8以前用 */
		url('../font/mameh4.woff2') format('woff'), /* モダンブラウザ用 */
		url('../font/mameh4.otf') format('opentype'); /* iOS, Android用 */
	font-weight: 400; /* 念の為指定しておきます */
	font-style: normal;
}

@font-face{ 
	font-family: 'mame5'; 
	src: url('../font/mameh5.eot'); /* IE9以上用 */
	src: url('../font/mameh5.eot?#iefix') format('embedded-opentype'), /* IE8以前用 */
		url('../font/mameh5.woff2') format('woff'), /* モダンブラウザ用 */
		url('../font/mameh5.otf') format('opentype'); /* iOS, Android用 */
	font-weight: 400; /* 念の為指定しておきます */
	font-style: normal;
}



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

 共通のスタイル

============================================*/
html {
  height: 100%;
  font-size: 62.5%; 
}

body {
  margin: 0px;
  padding: 0px;
  min-height: 100%;
  color: #2B332B;
  line-height: 1.8;
  font-size: 1.7rem;
  font-family: -apple-system, "游ゴシック", "Yu Gothic", "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
  font-weight: 400;
  position: relative;
  -webkit-text-size-adjust: 100%; 
}


/*--------------------------------------
 全体のボックス
--------------------------------------*/
header {
    width: 100%;
    margin: 0 auto;
    padding: 5rem 0;
    background: #28325E;
}
header img{
	max-width: 100%;
}
header p{
    text-align: center;
    margin: 0 auto;
}
main {
    width: 100%;
    margin: 0;
    padding: 0; }

main div.content {
    width: 1120px;
    min-height: 500px;
    margin: 6rem auto;
    overflow: hidden; }
    
main .content-free {
    margin: 0 0 6rem;
}
main .content-free > section{
    width: 1120px;
    margin-left: auto;
    margin-right: auto;
}
aside {
    position: relative;
    width: 100%;
    margin: 0;
    padding: 0; }

footer {
    position: relative;
    width: 100%;
    margin: 0;
    padding: 1rem;
    text-align: center;
    background-color: #FFF; }

#wrap {
    width: 1120px;
    margin: 0 auto; }

@media screen and (max-width: 767px) {
    header {
         }
	header img{
		max-width: 90%;
	}
    main {
        width: 100%;
        padding-top: 56px; }
    main div.content {
        width: 95%;
        margin: 6rem auto; }
    main .content-free {
        margin: 0 0 6rem;
    }
    main .content-free > section{
        width: inherit;
        margin-left: 2rem;
        margin-right: 2rem;
    }
    .wrap {
        width: 100%;
        margin: 0 auto; } }

#container {
    min-width: 1184px;
    min-height: 100vh;
}
#introduction{
    width: 1100px;
    margin: 0 auto 50px;
}

body {
    width: 100%; }

@media all and (max-width: 767px) {
    #container {
        min-width: 100%;
        }
    #introduction {
        max-width: 90%;
        }
    #main {
        padding-top: 0; }
}

/* ボックス横並び display: flex　関連
--------------------------------------*/
.grid-box {
    margin: 0 auto 2rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.grid-box.left-start {
    justify-content: flex-start;
    margin-left: -16px;
    margin-right: -16px;
}
.grid-box.reverse {
    flex-direction: row-reverse;
}
.grid-box > div {
    margin-bottom: 4rem;
}
.grid-box.left-start > div {
    margin-left: 16px;
    margin-right: 16px;
}
.grid-box .grid-01 img,
.grid-box .grid-02 img,
.grid-box .grid-03 img,
.grid-box .grid-04 img,
.grid-box .grid-05 img,
.grid-box .grid-06 img,
.grid-box .grid-07 img,
.grid-box .grid-09 img,
.grid-box .grid-10 img,
.grid-box .grid-11 img,
.grid-box .grid-12 img {
    width: auto;
    max-width: 100%;
    vertical-align: bottom;
}
@media screen and (max-width: 767px) {
    .grid-box {
        display: block;
    }
    .grid-box.left-start {
        margin-left: 0;
        margin-right: 0;
    }
    .grid-box.left-start > div {
        margin-left: 0;
        margin-right: 0;
    }
    .grid-reverse{/*レスポンシブで画像を上にしたい時などに使用*/
        flex-direction: column-reverse;
    }
}
.grid-01 {
	width: 64px;
}
.grid-02 {
	width: 160px;
}
.grid-03 {
	width: 256px;
}
.grid-04 {
	width: 352px;
}
.grid-05 {
	width: 448px;
}
.grid-06 {
	width: 544px;
}
.grid-07 {
	width: 640px;
}
.grid-08 {
	width: 736px;
}
.grid-09 {
	width: 832px;
}
.grid-10 {
	width: 932px;
}
.grid-11 {
	width: 1024px;
}
.grid-12 {
	width: 1120px;
}
@media screen and (max-width: 767px) {
    .grid-01,
    .grid-02,
    .grid-03,
    .grid-04,
    .grid-05,
    .grid-06,
    .grid-07,
    .grid-08,
    .grid-09,
    .grid-10,
    .grid-11,
    .grid-12 {
        width: 100%;
        margin-bottom: 1.5rem;
    }
}

/* ボックス横並び display: table　関連
--------------------------------------*/
.box-wrap-table {
    margin: 0 auto 2rem;
    display: table;
}
.box-wrap-table .box-01,
.box-wrap-table .box-02,
.box-wrap-table .box-03,
.box-wrap-table .box-04,
.box-wrap-table .box-05,
.box-wrap-table .box-06,
.box-wrap-table .box-07,
.box-wrap-table .box-08,
.box-wrap-table .box-09,
.box-wrap-table .box-10,
.box-wrap-table .box-11,
.box-wrap-table .box-12{
        display: table-cell;
}
.box-wrap-table-line {/*スマホで横並びを崩したくない時に使う*/
		width: calc(100% + 5px);
}
.box-wrap-table-line .box{
        display: table-cell;
		padding: 0 5px;
}
.box-wrap-table-line .box:first-child img{
	margin-left: -5px;
}

@media screen and (max-width: 767px) {
    .box-wrap-table {
	display: flex;
        flex-direction: column;
    }
    .box-wrap-table-line {/*スマホで横並びを崩したくない時に使う*/
	display: table;
    }
}


/*--------------------------------------
 見出し関連
--------------------------------------*/
/*タイトル
--------------------------------------*/
.headline {
    margin-top: 6rem;
    margin-bottom: 6rem;
    padding-bottom: 2rem;
    border-bottom: 1px #28325E solid;
    font-size: 3.2rem;
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
}
.subheading-01 {
    margin-top: 4rem;
    margin-bottom: 4rem;
    font-size: 2.8rem;
    font-weight: 800;
    line-height: 1.2;
    position: relative;
    padding: 1rem 0;
    border-bottom: 2px solid #D8DAED;
}

.subheading-02 {
    margin-bottom: 2rem;
    color: #2A335B;
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
}

.subheading-03 {
    margin-bottom: 2rem;
    color: #6D757F;
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
}
.headline span,
.subheading-01 span,
.subheading-02 span,
.subheading-03 span {
    position: relative;
    margin-right: 1rem;
    display: inline-block;
    background: #28325E;
    border-radius: 2rem;
    color: #FFFFFF;
}
.headline span {
    padding: 0.4rem 1rem 0.2rem;
    bottom: 0.2rem;
    font-size: 2rem;
}
.subheading-01 span {
    padding: 0.4rem 0.8rem 0.2rem;
    bottom: 0.1rem;
    font-size: 1.6rem;
}
.subheading-02 span,
.subheading-03 span {
    padding: 0.4rem 0.6rem 0.2rem;
    bottom: 0.1rem;
    font-size: 1.4rem;
    font-weight: 100;
}
.subheading-03 span {
    background: #6D757F;
}
.headline span:nth-child(n+2),
.subheading-01 span:nth-child(n+2),
.subheading-02 span:nth-child(n+2),
.subheading-03 span:nth-child(n+2){
    margin-left: 0.5rem;
}


@media screen and (max-width: 767px) {
    .headline {
	margin: -70px 0 40px;
	padding: 70px 0 0;
	font-size: 2.2rem;
    }
    .subheading-01 {
        font-size: 2rem;
    }
    .subheading-02 {
        font-size: 2rem;
    }
    .subheading-03 {
        font-size: 2rem;
    }
}
/*画像つきタイトル
--------------------------------------*/
.main-header { /* テキスト入りメインヘッダー */
    position: relative;
    width: 1120px;
    height: 260px;
    margin: 0 auto 8rem;
    background-repeat: no-repeat;
}
.main-header p {
    position: absolute;
    top: 50%;
    left: 35px;
    transform: translateY(-50%) translateX(0);
    -webkit- transform: translateY(-50%) translateX(0);
    color: #FFF;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.4;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
    .main-header {
        background-repeat: no-repeat;
        background-size: 100% auto;
    }
}

@media screen and (max-width: 767px) {
    .main-header { /* テキスト入りメインヘッダーSP */
        width: 95%;
        height: 59vw;
        margin: 0 auto 3rem;
        background-repeat: no-repeat;
        background-size: 100% auto;
    }
    .main-header p {
        top: 0;
        left: 0;
        transform: translateY(0) translateX(0);
        -webkit- transform: translateY(0) translateX(0);
        padding: 1em;
        font-size: 1.6rem;
    }
}

/*ページタイトル
--------------------------------------*/
.head_area{
    width: 1000px;
    position: relative;
    margin: 30px auto 30px;
}
.head_area .eyecatch{
    width: 100%;
    margin-bottom: 50px;
}

.main-title{ /* ページタイトル */
    color: #28325E;
    font-size: 3.2rem;
    line-height: 1.2;
    font-family: 'mame5';
    text-align: center;
    -moz-font-feature-settings: "palt";
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}
@media screen and (max-width: 767px) {
	.head_area{
		width: 100%;
	}
	
    .main-title{ /* ページタイトルSP */
        margin-bottom: 2rem;
        padding: 2.2rem 0.6rem;
        font-size: 2.4rem;
    }
    .main-title span {
        width: inherit;
    }
}

.main-header-title,
.main-header-title-ib { /* ページタイトル（幅100%） */
    display: flex;
    width: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    overflow: hidden;
}
.main-header-title {
    align-items: center;
    height: 300px;
}
.main-header-title-ib {
    height: 320px;
}
.main-header-title > div,
.main-header-title-ib > div {
    width: 1120px;
	margin: 0 auto;
}
.main-header-title-ib > div {
    position: relative;
}
.main-header-title > div h1,
.main-header-title-ib > div h1,
.main-header-title-ib > div p {
    color: #fff;
    vertical-align : middle;
    line-height: 1.3;
    text-shadow: 2px 2px 1px #333;
}
.main-header-title > div h1 {
    font-size: 4rem;
}
.main-header-title-ib > div h1 {
    padding: 3rem 0 0;
    font-size: 3.6rem;
}
.main-header-title-ib > div p {
    padding: 1rem 0 0;
    font-size: 2rem;
    line-height: 1.4;
}
.main-header-title-ib > div h1 span {
    display: block;
    font-size: 2.6rem;
}
.main-header-title-ib > div ul {
    position: absolute;
    top: 2rem;
    right: 0;
}
.main-header-title-ib > div ul li {
    padding: 0 0 1rem;
}
.main-header-title-ib > div ul li img {
    width: 325px;
    vertical-align: top;
}

@media screen and (max-width: 767px) {
    .main-header-title > div { /* 中ページメインヘッダーsp */
        width: inherit;
        margin: 0 2rem;
    }
    .main-header-title-ib {
        height: inherit;
        background: none !important;
    }
    .main-header-title-ib > div > div {
        height: 110vw;
        padding: 2rem;
        background-size: 100%;
        background-size: cover;
        background-repeat: no-repeat;
        background-position: center center;   
    }
    .main-header-title-ib > div > div h1 {
        padding: 0;
    }
    .main-header-title-ib > div ul {
        position: static;
        padding: 1rem 1rem 0;
        background: #2F82C8;
    }
    .main-header-title-ib > div ul li img {
        width: 100%;
    }
    .main-header-title-ib > div h1 {
        font-size: 2.2rem;
    }
    .main-header-title-ib > div p {
        font-size: 1.5rem;
    }
    .main-header-title-ib > div h1 span {
        font-size: 1.6rem;
    }
}

/*--------------------------------------
 p,ul,ol 基本設定
--------------------------------------*/
.content p,
.content ul,
.content ol,
.content dl{
    margin: 0 0 3rem;
}
.content ul li,
.content ol li{
    margin-bottom: 3rem;
}
.content ul.bottom-reset-li li,
.content ol.bottom-reset-li li,
.inquire-wrap ul.bottom-reset-li li{
    margin-bottom: 0;
}
ul.normal > li{
    position: relative;
    margin: 0 0 1.5rem 0;
    padding-left: 1.6rem;
    
}
ul.normal-big > li{
    position: relative;
    margin: 0 0 2rem 0;
    padding-left: 2.1rem;
    
}
ul.normal > li:before{
    position: absolute;
    left: 0;
    top: 1rem;
    content: "";
    display: inline-block;
    width: 0.8rem;
    height: 0.8rem;
    vertical-align: middle;
    background: #014DA0;
    border-radius: 8px;
}
ul.normal > li.blank:before{
    background: none;
}
@media screen and (max-width: 767px) {
    ul.normal > li.blank{
        display: none;
    }
}
ul.normal-big > li:before{
    position: absolute;
    left: 0;
    top: 1rem;
    content: "";
    display: inline-block;
    width: 1.5rem;
    height: 1.5rem;
    vertical-align: middle;
    background: #014DA0;
    border-radius: 8px;
}
ol.normal > li{
    margin: 0 0 1.5rem 2rem;
    padding-left: 1rem;
    list-style-type: decimal;
}
ul.reset > li{
    all: initial;
}
ol.reset > li{
    list-style-type: none;
}
ul.inline li,
ol.inline li{
    padding-right: 30px;
    float: left;
    list-style-position: outside;
}

/*--------------------------------------
 余白設定
--------------------------------------*/
.reset,
.content .reset{
    margin: 0;
}
.top-reset,
.content .top-reset{
    margin-top: 0;
}
.bottom-reset,
.content .bottom-reset{
    margin-bottom: 0;
}
.bottom-reset li:last-child,
.content .bottom-reset li:last-child{
    margin-bottom: 0;
}
.rightleft-reset,
.content .rightleft-reset{
    margin-right: 0;
    margin-left: 0;
}
.indent-reset,
.content .indent-reset{
    text-indent: 0;
}
.indent-reset,
.content .topbottom-space-01{
    margin-top: 1.5rem;
    margin-bottom: 1.5rem; 
}
.topbottom-space-02,
.content .topbottom-space-02{
    margin-top: 3rem;
    margin-bottom: 3rem; 
}
.topbottom-space-03,
.content .topbottom-space-03{
    margin-top: 1.5rem;
    margin-bottom: 6rem; 
}
.bottom-space-01,
.content .bottom-space-01,
.inquire-wrap .bottom-space-01{
    margin-bottom: 1.5rem;
}
.bottom-space-02,
.content .bottom-space-02,
.inquire-wrap .bottom-space-02{
    margin-bottom: 3rem;
}
.bottom-space-03,
.content .bottom-space-03,
.inquire-wrap .bottom-space-03{
    margin-bottom: 6rem;
}
.bottom-space-04,
.content .bottom-space-04,
.inquire-wrap .bottom-space-04{
    margin-bottom: 10rem;
}
.top-space-01,
.content .top-space-01{
    margin-top: 1.5rem;
}
.top-space-02,
.content .top-space-02{
    margin-top: 3rem;
}
.top-space-03,
.content .top-space-03{
    margin-top: 6rem;
}

/*--------------------------------------
 テーブル
--------------------------------------*/
.table-caption { /* テーブル上部右寄せキャプション */
    padding-bottom: 0.2rem;
    text-align: right;
}

.table-set{
    margin: 0 auto;
}
.table-set th,
.table-set td{
    padding: 1.5rem;
}

.table-set-nest{
    margin: 0;
}
.table-set-nest th,
.table-set-nest td{
    padding: 0.5rem 0.5rem 0.5rem 0;
}

/* レイアウト
--------------------------------------*/
.table-outline-01{
    border-collapse: collapse;
}
.table-outline-01 th,
.table-outline-01 td,
.table-outline-02 th,
.table-outline-02 td{
    border: 1px solid #D0D9D0;
}
.table-outline-01 thead th{
    background-color: #CACBDC;
    text-align: center;
}
.table-outline-01 th,
.table-outline-02 th{
    background-color: #F3F3F3;
}
.table-outline-03,
.table-outline-04{
    border-collapse: separate;
    border-spacing: 0.8rem;
}
.table-outline-03 th,
.table-outline-03 td,
.table-outline-04 th,
.table-outline-04 td{
    padding-top: 0.7rem;
    border-bottom: 1px dotted #9AA1AA;  
}
.table-outline-05{
    margin: 0;
}
.table-outline-05 th,
.table-outline-05 td{
    border: none;
    background: none;
}

/* テーブル内テーブル */
.table-outline-05.innertable th{
    padding: 0 1.5rem 1.5rem 0;
}
.table-outline-05.innertable td{
    padding: 0 0 1.5rem 1.5rem;
}
.innertable tr:last-child td,
.innertable tr:last-child th{
    padding-bottom: 0;
}
@media screen and (max-width: 767px) {
    .innertable th,
    .innertable tr:last-child th{
        padding: 0 0 1.5rem 0;
    }
    .innertable td,
    .table-outline-05.innertable td{
        padding: 1.5rem 0 2rem;
    }
}

@media screen and (max-width: 767px) {
    /* スクロールバー用 */
    .sp-scroll{
        overflow-x: auto;
    }
    .sp-scroll table.table-layout-01{
        width: 740px;
    }
    /* レスポンシブ用　2列 */
    .table-layout-02 th,
    .table-layout-02 td{
        display: block;
        width: 100%;
    }
    .table-outline-02{
        border-top: 1px solid #9AA1AA;
    }
    .table-outline-02 tr th,
    .table-outline-02 tr td{
        border-top: none;
        border-right: 1px solid #9AA1AA;
        border-bottom: 1px solid #9AA1AA;
        border-left: 1px solid #9AA1AA;
    }
    .table-outline-04 tr th{
        border-bottom: 1px dotted #9AA1AA; 
    } 
    .table-outline-04 tr td{
        border-bottom: none; 
    }
    .table-outline-05 tr th{
        border-top: none;
        border-right: none;
        border-bottom: 2px solid #9AA1AA;
        border-left: none;
    }
    .table-outline-05 tr td{
        border: none;
    }
    /* レスポンシブ用　3列以上 */
    .table-layout-03{
        width: 95%;
    }
    .table-layout-03 tr th,
    .table-layout-03 tr td{
        border: none;
    }
    /* 入れこ */
    .table-layout-02 .table-layout-01 th,
    .table-layout-02 .table-layout-01 td{
        display: inline;
    }
    .table-layout-02 .table-outline-01 th,
    .table-layout-02 .table-outline-01 td{
        border-top: 1px solid #9AA1AA;
        display: table-cell;
        width: inherit;
    }
    .table-set .table-outline-05 th{
        border: none;
    }
}
/* 文字位置
--------------------------------------*/
.table-text-01 th{
    text-align: center;
}
.table-text-01 td{
    text-align: left;
}
.table-text-02 th,
.table-text-02 td{
    text-align: center;
}
.table-text-03 th,
.table-text-03 td{
    text-align: left;
}
.table-text-04 th{
    text-align: center;
}
.table-text-04 td{
    text-align: right;
}
.table-text-05 th{
    text-align: left;
}
.table-text-05 td{
    text-align: right;
}
.table-text-06 th{
    text-align: left;
}
.table-text-06 td{
    text-align: center;
}
.table-text-07 th{
    text-align: center;
}
.table-text-07 td{
    text-align: left;
}
.table-text-07 td:last-child{
    text-align: center;
}
.table-text-08 th{/*イベント一覧など、縦横中央*/
    text-align: center;
    vertical-align: middle;
}
.table-text-08 td{
    text-align: center;
    vertical-align: middle;
}

/* 文字位置 個別
--------------------------------------*/
.table-set .align-01 {
    text-align: right;
}
.table-set .align-02 {
    text-align: center;
}
.table-set .align-03 {
    text-align: left;
}
.table-set .v_align-01 {
    vertical-align: top;
}
.table-set .v_align-02 {
    vertical-align: baseline;
}
.table-set .v_align-03 {
    vertical-align: middle;
}
/* 色個別
--------------------------------------*/
.table-set .gray {
    background-color: #DDE3DD;
}

 個別
--------------------------------------*/
/* 横幅
--------------------------------------*/
.size-05{
	width: 5%;
}
.size-08{
	width: 5%;
}
.size-10{
	width: 10%;
}
.size-13{
	width: 13%;
}
.size-15{
	width: 15%;
}
.size-20{
	width: 20%;
}
.size-22{
	width: 22%;
}
.size-25{
	width: 25%;
}
.size-28{
	width: 25%;
}
.size-30{
	width: 30%;
}
.size-33{
	width: 33.33333% ;
}
.size-35{
	width: 35%;
}
.size-40{
	width: 40%;
}
.size-45{
	width: 45%;
}
.size-50{
	width: 50%;
}
.size-55{
	width: 55%;
}
.size-60{
	width: 60%;
}
.size-65{
	width: 65%;
}
.size-70{
	width: 70%;
}
.size-75{
	width: 75%;
}
.size-80{
	width: 80%;
}
.size-90{
	width: 90%;
}
.size-93{
	width: 93%;
}
.size-95{
	width: 95%;
}
.size-97{
	width: 97%;
}
.size-100{
	width: 100%;
}

/*--------------------------------------
 パーツ
--------------------------------------*/
/* ヘッダ
--------------------------------------*/
.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    min-width: 1184px;
    height: auto;
    background-color: #fff; 
    }
.header .header-wrap {
    width: 1184px;
    margin: 0 auto; 
    }


/* ヘッダSP
--------------------------------------*/
@media screen and (max-width: 767px) {
    .header {
    min-width: auto; 
    }
    .header .header-wrap {
    width: 100%; 
    }
}

/* パンくずリスト
--------------------------------------*/
.breadcrumb {
    padding: 0.3em 0;
    background: #F3F5F3;
}
_:-ms-lang(x)::-ms-backdrop, .breadcrumb { /* IE11のみ */
    padding: 0.5em 0 0.2em;
}
.breadcrumb ul {
  display: flex;
  flex-wrap:wrap;
  width: 1120px;
  margin: 0 auto;
  font-size: 1.2rem;
}
.breadcrumb ul li {
    position: relative;
    padding-right: 2.4em;
    vertical-align: top;
}
.breadcrumb ul li:last-child {
    padding-right: 0;
}
.breadcrumb ul li:after {
    position: absolute;
    right: 1rem;
    top: 0.5rem;
    width: 6px;
    height: 10px;
    background: url("/common/img/icon_arrow_left_gr_normal.svg") no-repeat;
    background-size: 6px 10px;
    content: '';
}
_:-ms-lang(x)::-ms-backdrop, .breadcrumb ul li:after { /* IE11のみ */
    top: 0.3rem;
}
.breadcrumb ul li:last-child:after {
    position: static;
    content: '';
}
.breadcrumb ul li a {
    text-decoration: none;
}
.breadcrumb ul li a:hover {
    text-decoration: underline;
}
@media screen and (max-width: 767px) {
    .breadcrumb {
		display: none;
	}

}




/* フッタ
--------------------------------------*/
.footer {
}

/* フッタSP
--------------------------------------*/
@media screen and (max-width: 767px) {
    .footer .footer-wrap .footer-primary {
        display: block;
        max-width: 100%;
        padding: 20px 13px;
        padding-bottom: 35px; }
    }
        	

/*--------------------------------------
  リンク
--------------------------------------*/
p a{
	color: #0F2EB6;
}
.hover {
    display: inline-block;
    -webkit-transition: all 0.2s linear;
    transition: all 0.2s linear; }
    .hover:hover {
        opacity: 0.6; }

.ulink {
    position: relative;
    display: inline-block;
    -webkit-transition: all 0.2s linear;
    transition: all 0.2s linear; }
    .ulink:hover {
        opacity: 0.8; }
	
/*--------------------------------------
  アイコン
--------------------------------------*/
.icon {
    position: relative;
    display: inline-block;
    padding-left: 20px; }
    .icon:before {
        position: absolute;
        top: 50%;
        left: -0;
        display: inline-block;
        content: "";
        -webkit-transform: translate(0, -50%);
                transform: translate(0, -50%);
        background-repeat: no-repeat;
        background-size: 100% auto; }
    .icon.icon-arrow::before {
        top: 30%;
        width: 12px;
        height: 9px;
        -webkit-transform: rotate(-90deg);
                transform: rotate(-90deg);
        background-image: url("/common/img/icon_arrow_w.svg");
        background-repeat: no-repeat; }
    .icon.icon-blank::before {
        top: 11px;
        width: 14px;
        height: 14px;
        background-image: url("/common/img/icon_blank_w.svg");
        background-size: 14px 14px; }
    .icon.icon-pdf::before {
        top: 4px;
        left: -0px;
        width: 15px;
        height: 18px;
        background-image: url("/common/img/icon_pdf.svg");
	-webkit-transform: inherit;
	transform: inherit;}
	
/*--------------------------------------
 注釈関連
--------------------------------------*/

ul.note-01,
ol ul.note-01 { /* 注記 ※ */
    margin-top: 1rem;
    padding: 0 0 0 1.4em;
    font-size: 1.4rem;
    counter-reset: number;
}
ul.note-01 li,
ol ul.note-01 li {
	position: relative;
	list-style: none;
}
ul.note-01 li:before,
ol ul.note-01 li:before {
	counter-increment: number;
	content: "※";
	position: absolute;
	left: -1.4em;
	width: 1.4em;
	height: 1em;
	background: initial;
	border: initial;
	border-radius: initial;
	text-align: initial;
}
.align-center ul.note-01 li {
	display: inline-block;
}
.align-center ul.note-01 li:before {
	top: 0;
}

ul.note-02,
ol ul.note-02 { /* 注記 ＊ */
    margin-top: 1rem;
    padding: 0 0 0 1.4em;
    font-size: 1.4rem;
    counter-reset: number;
}
ul.note-02 li,
ol ul.note-02 li {
	position: relative;
	list-style: none;
}
ul.note-02 li:before,
ol ul.note-02 li:before {
	counter-increment: number;
	content: "＊";
	position: absolute;
	top: -0.1em;
	left: -1.4em;
	width: 1.4em;
	height: 1em;
	background: initial;
	border: initial;
	border-radius: initial;
    font-size: initial;
	text-align: initial;
}
.note-03 { /* 注記 ※1 */
    margin-top: 1rem;
    padding: 0 0 0 2em;
    font-size: 1.4rem;
	counter-reset: number;
}
.note-03 li{
	position: relative;
	list-style: none;
}
.note-03 li:before {
	counter-increment: number;
	content: "※"counter(number)"";
	position: absolute;
	top: 0;
	left: -2em;
	width: 3em;
	height: 1em;
}
.note-04 { /* 注記（注1） */
    margin-top: 1rem;
    padding: 0 0 0 3em;
    font-size: 1.4rem;
	counter-reset: number;
}
.note-04 li{
	position: relative;
	list-style: none;
}
.note-04 li:before {
	counter-increment: number;
	content: "（注"counter(number)"）";
	position: absolute;
	top: 0;
	left: -3.4em;
	width: 3.6em;
	height: 1em;
    white-space: nowrap;
}

.bottom-caution {
    padding-top: 1rem;
}
/* -----------
枠線 
------------*/

.outer-01 { /* 枠線付きボックス（グレー） */
    border: 1px #9EA79E solid;
    border-radius: 10px;
    padding: 2rem;
    margin: 0 auto;
}
.outer-02 { /* 背景付きボックス（グレー） */
    background: #9EA79E;
    border-radius: 10px;
    padding: 2rem;
    color: #FFF;
    margin: 0 auto;
}
.outer-03 { /* 背景付きボックス（ブルー） */
    background: #F3F3F3;
    border-radius: 10px;
    padding: 2rem;
    margin: 0 auto;
}
.outer-04 { /* 枠線付きボックス（ブルー4px） */
    border: 4px #F3F9E3 solid;
    border-radius: 10px;
    padding: 2rem;
    margin: 0 auto;
}
.outer-05 { /* 枠線付きボックス（ブルー2px） */
    border: 2px #154218 solid;
    border-radius: 10px;
    padding: 2rem;
    margin: 0 auto;
}

.outer-bg-01 { /* 背景付き幅100%ボックス（ブルー） */
    background: #F3F9E3;
    padding: 5rem 0 6rem;
}
.outer-bg-01 .section-01 {
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
    .outer-bg-01 { /* 背景付き幅100%ボックス（ブルー）SP */
        padding: 3rem 2rem 4rem;
    }
    .outer-01,
    .outer-02,
    .outer-03,
    .outer-04,
    .outer-05{
        width: 100%;
    }
}




/*--------------------------------------
 リスト
--------------------------------------*/
ul.list-disc,
ol ul.list-disc { /* 丸リスト */
    counter-reset: number;
}
ul.list-disc > li,
ol ul.list-disc > li {
	position: relative;
    margin: 0 0 1.5rem;
	padding: 0 0 0 20px;
    text-indent: 0;
}
ul.list-disc > li:last-child,
ol ul.list-disc > li:last-child {
	margin: 0;
}
ul.list-disc > li:before,
ol ul.list-disc > li:before {
	display: none;
}
ul.list-disc > li:after,
ol ul.list-disc > li:after {
	content: '';
	display: block;
	position: absolute;
	background: #154218;
	width: 5px;
	height: 5px;
	top: 1rem;
	left: 0.6rem;
	border-radius: 4px;
}
ul.list-disc > li .note,
ol ul.list-disc > li .note {
	margin: 1rem 0;
}

ol.number-list-01,
ol.number-list-02,
ol.number-list-03,
ol.number-list-04,
ol.number-list-05,
ol.number-list-06,
ol.number-list-07,
ol.number-list-08 {
    padding: 0 0 0 2em;
}
ol.number-list-01 li,
ol.number-list-02 li,
ol.number-list-03 li,
ol.number-list-04 li,
ol.number-list-05 li,
ol.number-list-06 li,
ol.number-list-07 li,
ol.number-list-08 li {
	margin: 0 auto 1.5rem;
}
ol.number-list-01 {
	counter-reset: number;
}
ol.number-list-01 li{
	position: relative;
	list-style: none;
}
ol ol ol ol.number-list-01 li:before,
ol ol ol.number-list-01 li:before,
ol ol.number-list-01 li:before,
ol.number-list-01 li:before {
	counter-increment: number;
	content: counter(number)". ";
	position: absolute;
	top: 0;
	left: -1.5em;
	width: 3em;
	height: 1em;
	font-size: inherit;
	background: inherit;
	border: inherit;
	border-radius: inherit;
	text-align: inherit;
}

ol.number-list-02 {
	counter-reset: number;
}
ol.number-list-02 li {
	position: relative;
	list-style: none;
}
ol ol ol ol.number-list-02 li:before,
ol ol ol.number-list-02 li:before,
ol ol.number-list-02 li:before,
ol.number-list-02 li:before{
	counter-increment: number;
	content: "("counter(number)")";
	font-size: inherit;
	background: inherit;
	color: #555;
	position: absolute;
	top: 0;
	left: -2em;
	width: 4em;
	height: 1em;
	border: inherit;
	border-radius: inherit;
	text-align: inherit;
}

ol.number-list-03 {
	counter-reset: number;
}
ol.number-list-03 li {
	position: relative;
	list-style: none;
}
ol ol ol ol.number-list-03 li:before,
ol ol ol.number-list-03 li:before,
ol ol.number-list-03 li:before,
ol.number-list-03 li:before {
    counter-increment: number;
    content: counter(number);
    font-size: 0.75em;
    background:#fff;
    color:#222;
    position: absolute;
    top: 0.4em;
    left: -2em;
    width: 1.4em;
    height: 1.4em;
    border: 1px solid #222;
    border-radius: 50%;
    text-align: center;
    line-height: 1.5;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
}
_:-ms-lang(x)::-ms-backdrop, ol ol ol ol.number-list-03 li:before,
_:-ms-lang(x)::-ms-backdrop, ol ol ol.number-list-03 li:before,
_:-ms-lang(x)::-ms-backdrop, ol ol.number-list-03 li:before,
_:-ms-lang(x)::-ms-backdrop, ol.number-list-03 li:before { /* IE11のみ */
    font-size: 1.2em;
    top: 0.1em;
    line-height: 1.7;
}

ol.number-list-04 {
	counter-reset: number;
}
ol.number-list-04 li{
	position: relative;
	list-style: none;
}
ol ol ol ol.number-list-04 li:before,
ol ol ol.number-list-04 li:before,
ol ol.number-list-04 li:before,
ol.number-list-04 li:before {
	counter-increment: number;
	content: counter(number, lower-alpha)". ";
	position: absolute;
	top: 0;
	left: -1.5em;
	width: 3em;
	height: 1em;
	font-size: inherit;
	background: inherit;
	border: inherit;
	border-radius: inherit;
	text-align: inherit;
}

ol.number-list-05 {
	counter-reset: number;
}
ol.number-list-05 li{
	position: relative;
	list-style: none;
}
ol ol ol ol.number-list-05 li:before,
ol ol ol.number-list-05 li:before,
ol ol.number-list-05 li:before,
ol.number-list-05 li:before {
	counter-increment: number;
	content: counter(number, upper-alpha)". ";
	position: absolute;
	top: 0;
	left: -1.5em;
	width: 3em;
	height: 1em;
	font-size: inherit;
	background: inherit;
	border: inherit;
	border-radius: inherit;
	text-align: inherit;
}

ol.number-list-06 {
	counter-reset: number;
}
ol.number-list-06 li{
	position: relative;
	list-style: none;
}
ol ol ol ol.number-list-06 li:before,
ol ol ol.number-list-06 li:before,
ol ol.number-list-06 li:before,
ol.number-list-06 li:before {
	counter-increment: number;
	content: "（"counter(number, lower-alpha)"）";
	position: absolute;
	top: 0;
    left: -2.4em;
	width: 4em;
	height: 1em;
	font-size: inherit;
	background: inherit;
	border: inherit;
	border-radius: inherit;
	text-align: inherit;
    white-space: nowrap;
}

ol.number-list-07 {
	counter-reset: number;
}
ol.number-list-07 li {
	position: relative;
	list-style: none;
}
ol ol ol ol.number-list-07 li:before,
ol ol ol.number-list-07 li:before,
ol ol.number-list-07 li:before,
ol.number-list-07 li:before {
	font-size: inherit;
	background: inherit;
	color: #555;
	position: absolute;
	top: 0.1em;
	left: -1.8em;
	width: 1em;
	height: 1em;
	border: inherit;
	border-radius: inherit;
	text-align: inherit;
    white-space: nowrap;
}
ol.number-list-07 li.no-01:before {
    content: "イ.";
}
ol.number-list-07 li.no-02:before {
    content: "ロ.";
}
ol.number-list-07 li.no-03:before {
    content: "ハ.";
}
ol.number-list-07 li.no-04:before {
    content: "ニ.";
}
ol.number-list-07 li.no-05:before {
    content: "ホ.";
}
ol.number-list-07 li.no-06:before {
    content: "ヘ.";
}
ol.number-list-07 li.no-07:before {
    content: "ト.";
}

ol.number-list-08 {
	counter-reset: number;
    padding: 0 0 0 2.4em;
}
ol.number-list-08 li {
	position: relative;
	list-style: none;
}
ol ol ol ol.number-list-08 li:before,
ol ol ol.number-list-08 li:before,
ol ol.number-list-08 li:before,
ol.number-list-08 li:before {
	font-size: inherit;
	background: inherit;
	color: #555;
	position: absolute;
	top: 0.1em;
	left: -2.8em;
	width: 2.8em;
	height: 1em;
	border: inherit;
	border-radius: inherit;
	text-align: inherit;
    white-space: nowrap;
}
ol.number-list-08 li.no-01:before {
    content: "（ア）";
}
ol.number-list-08 li.no-02:before {
    content: "（イ）";
}
ol.number-list-08 li.no-03:before {
    content: "（ウ）";
}
ol.number-list-08 li.no-04:before {
    content: "（エ）";
}
ol.number-list-08 li.no-05:before {
    content: "（オ）";
}

.number-list-01.column-list,
.number-list-02.column-list,
.number-list-03.column-list,
.number-list-04.column-list { /* リスト一部ボールド */
    font-weight: bold;
}
.number-list-01.column-list .font-normal,
.number-list-02.column-list .font-normal,
.number-list-03.column-list .font-normal,
.number-list-04.column-list .font-normal { /* リスト一部ボールド（ボールド解除） */
    display: block;
    font-weight: normal;
}
.number-list-01.column-list table,
.number-list-02.column-list table,
.number-list-03.column-list table,
.number-list-04.column-list table,
.number-list-01.column-list div,
.number-list-02.column-list div,
.number-list-03.column-list div,
.number-list-04.column-list div,
.number-list-01.column-list ul,
.number-list-02.column-list ul,
.number-list-03.column-list ul,
.number-list-04.column-list ul,
.number-list-01.column-list ol,
.number-list-02.column-list ol,
.number-list-03.column-list ol,
.number-list-04.column-list ol,
.number-list-01.column-list p,
.number-list-02.column-list p,
.number-list-03.column-list p,
.number-list-04.column-list p {
    font-weight: normal;
}

.indent-list-01 > li { /* 汎用 */
    display: table;
    margin: 3rem 0 0;
}
.indent-list-01.space-0 > li { /* スペースなし */
    margin: 0;
}
.indent-list-01.space-01 > li { /* スペース少 */
    margin: 1rem 0 0;
}
.indent-list-01 > li > span {
    display: table-cell;
    vertical-align: top;
    text-indent: 0;
}
.indent-list-01 > li > span:first-of-type {
    white-space: nowrap;
}

.indent-list-01 table {
    margin-bottom: 2rem !important;
}
.indent-list-01 > li:first-child {
    margin: 1rem 0 0;
}
ol ol ol ol.indent-list-01 li,
ol ol ol.indent-list-01 li,
ol ol.indent-list-01 li,
ol.indent-list-01 li {
	margin-left: 0;
}

ul.list-disc > li .indent-text01 {
    display: block;
    padding-left: 1.3rem;
}
dl.list-disc { /* 丸リスト+インデントテキスト */
    padding-left: 4rem;
}
dl.list-disc dt {
    margin-left: -4rem;
}
dl.list-disc dd {
    position: relative;
	padding: 0 0 1rem 20px;
}
dl.list-disc dd:before {
	content: '';
	height: 0;
	width: 90%;
	display: block;
	position: absolute;
	top: 18px;
	left: 0;
}
dl.list-disc dd:after {
	content: '';
	display: block;
	position: absolute;
	background: #154218;
	width: 5px;
	height: 5px;
	top: 1rem;
	left: 0.6rem;
	border-radius: 4px;
}

dl.list-nodisc dd { /* 丸なしリスト+インデントテキスト（1）、（2）等 */
    margin-left: 4rem;
}

ol.list-decimal {
    padding: 1rem 0 0 2.5rem;
}
ol.list-decimal > li {
    padding: 0 0 1rem;
    list-style: decimal outside;
}

dl.news-list dd { /* ニュース一覧 */
    margin: -1.7em 0 2rem;
    padding: 0 0 2rem 20rem;
    border-bottom: 1px #D0D9D0 solid;
}
ul.news-list li { /* ニュース一覧 */
    margin: 0 0 2rem;
    padding: 0 0 2rem;
    border-bottom: 1px #D0D9D0 solid;
}
.news-list a {
    position: relative;
    padding: 0 0 0 1.5rem;
    text-decoration: none;
}
.news-list a:before {
    position: absolute;
    top: 1rem;
    left: 0;
    display: block;
    width: 11px;
    height: 7px;
    content: '';
    -webkit-transform: rotate(-90deg);
            transform: rotate(-90deg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
.news-list a.link-blank { /* 別窓アイコン */
    position: relative;
    padding: 0 0 0 2.5rem;
    text-decoration: none;   
}
.news-list a.link-blank:before {
    position: absolute;
    top: 0.3em;
    left: 0;
    display: block;
    width: 14px;
    height: 14px;
    background: url("/common/img/icon_blank.svg") no-repeat;
    -webkit-transform: rotate(0);
            transform: rotate(0);
    background-size: 100% 100%;
    content: '';
}
.news-list a.link-pdf { /* PDFアイコン */
    position: relative;
    padding: 0 0 0 2.5rem;
    text-decoration: none;   
}
.news-list a.link-pdf:before {
    position: absolute;
    top: 0.2rem;
    left: 0;
    display: block;
    width: 18px;
    height: 20px;
    background: url("/common/img/icon_pdf.svg") no-repeat;
    -webkit-transform: rotate(0);
            transform: rotate(0);
    background-size: 100% auto;
    content: '';
}
@media screen and (max-width: 767px) {
    dl.news-list dd { /* ニュース一覧SP */
        position: static;
        margin: 0 0 1rem;
        padding: 0 0 1rem;
        border-bottom: 1px #D0D9D0 solid;
    }
}

.link-blank-box { /* 別窓アイコン（背景ブルー） */
    display: inline-block;
    position: relative;
    padding: 0.6rem 0.8rem 0.4rem 3rem;
    background: #154218;
    border-radius: 4px;
    color: #FFF;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
}
.link-blank-box:before {
    position: absolute;
    top: 50%;
    left: 1rem;
    display: block;
    width: 14px;
    height: 14px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    background: url("/common/img/icon_blank_w.svg") no-repeat;
    background-size: 100% auto;
    content: '';
}

.anchor-link-list-01 { /* アンカーリンクリスト */
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 -4px 6rem;
}
.anchor-link-list-01 li {
    display: flex;
    align-items: stretch;
    width: 274px;
    margin: 0 4px 8px;
}
.anchor-link-list-01 li a {
    display: flex;
    align-items: center;
    position: relative;
    width: 274px;
    padding: 1rem 1rem 1rem 4rem;
    border: 1px #154218 solid;
    border-radius: 4px;
    text-decoration: none;
}
.anchor-link-list-01 li a:before {
    position: absolute;
    top: 50%;
    left: 1.5rem;
    width: 11px;
    height: 7px;
    content: '';
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
.anchor-link-list-02,
.anchor-link-list-03 {
    margin: 0 0 6rem;
}
.anchor-link-list-02 li {
    margin: 0 0 1rem;
}
.anchor-link-list-02 li:last-child {
    margin: 0;
}
.anchor-link-list-03 {
    display: flex;
    flex-wrap: wrap;
}
.anchor-link-list-03 li {
    margin: 0 3rem 0 0;
}
.anchor-link-list-02 li a,
.anchor-link-list-03 li a {
    position: relative;
    padding-left: 2rem;
    text-decoration: none;
}
.anchor-link-list-02 li a:before,
.anchor-link-list-03 li a:before {
    position: absolute;
    top: 0.9rem;
    left: 0;
    display: block;
    width: 11px;
    height: 7px;
    content: '';
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
@media screen and (max-width: 767px) {
    .anchor-link-list-01 { /* 横並び4列（SP1列） */
        justify-content: flex-start;
        margin: 0 0 4rem;
    }
    .anchor-link-list-01 li {
        width: 100%;
        margin: 0 0 2%;
    }
    .anchor-link-list-01 li a {
        width: 100%;
    }
}

/*--------------------------------------
 注意書き
--------------------------------------*/

.att-circle {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40' width='40' height='40' preserveAspectRatio='xMinYMid'%3E%3Cpath fill='%23F29801' d='M20,0 C8.96,0 0,8.96 0,20 C0,31.0400009 8.96,40 20,40 C31.0400009,40 40,31.0400009 40,20 C40,8.96 31.0400009,0 20,0 C12.64,0 12.64,0 20,0 Z M22,26 L22,30 L18,30 L18,26 L22,26 Z M22,10 L22,22 L18,22 L18,10 L22,10 Z' /%3E%3C/svg%3E");
    background-repeat:  no-repeat;
    display: block;
}
.att-triangle {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 42 37' width='42px' height='37px' preserveAspectRatio='xMinYMid'%3E%3Cpath fill='%23B21717' d='M22.7307682,0.99377429 L41.261879,33.0020523 C42.0338058,34.3353844 41.0716896,36.0041237 39.5310249,36.0041237 L2.46881413,36.0041237 L2.46881413,36.0041237 C0.92814922,36.0041237 -0.03397027,34.3353882 0.7379587,33.0020561 L19.2690678,0.99377996 C20.0393963,-0.33679003 21.9604397,-0.33679569 22.7307682,0.99377429 Z M22.999918,26 L18.999918,26 L18.999918,30 L20.8704147,30 C20.9132309,30.002737 20.9564133,30.0041256 20.999918,30.0041256 C21.0434265,30.0041256 21.0866089,30.002737 21.129425,30 L21.129425,30 L22.999918,30 L22.999918,26 Z M22.9999199,12.0041256 L18.9999199,12.0041256 L18.9999199,22.0041256 L22.9999199,22.0041256 L22.9999199,12.0041256 Z' /%3E%3C/svg%3E");
    background-repeat:  no-repeat;
    display: block;
}
.att-small{
    background-size: 30px 30px;
    padding-left: 80px;
    background-position: 2rem 0.5rem;
}
.outer-01.att-small,
.outer-02.att-small,
.outer-03.att-small{
    padding-left: 70px;
    background-position: 2rem 2.5rem;
}
.att-large{
    background-size: 50px;
    padding-left: 80px;
    background-position: 1rem 0.5rem;
    min-height: calc(50px + 0.5rem);
}
.outer-01.att-large,
.outer-02.att-large,
.outer-03.att-large{
    padding-left: 150px;
    background-position: 5rem center;
}
.subheading-01.att-circle,
.subheading-01.att-triangle{
    background-size: 25px;
    padding-left: 55px;
    background-position: 2rem 1.5rem;
}
.subheading-02.att-circle,
.subheading-03.att-circle,
.subheading-02.att-triangle,
.subheading-03.att-triangle{
    background-size: 18px;
    padding-left: 25px;
    background-position: 0 0;
}

@media screen and (max-width: 767px) {
    .att-large,
    .outer-01.att-large,
    .outer-02.att-large,
    .outer-03.att-large{
        background-size: 50px;
        padding-left: 2rem;
        padding-top: 90px;
        background-position: center 2rem;
    }
    .headline.att-circle,
    .headline.att-triangle{
        background-size: 32px;
        padding-left: 45px;
        background-position: 0 6.5rem;
    }
}

/*--------------------------------------
 ドットリーダー
--------------------------------------*/
.dotleader{
    align-items: center;
    display: flex;
    justify-content: center;
    margin-bottom: 0.5rem;
}
.dotleader div:nth-child(2){
    border-bottom:1px dotted rgba(0,0,0,.3);
    flex:1 1 0%;
    margin:0 10px;
}
.dotleader:last-child{
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
    .dotleader{
        width: 100%;
    }
}

/*--------------------------------------
 ボタン
--------------------------------------*/
.content .btn-link-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-left: -16px;
    margin-right: -16px;
}
.btn-link-list.left-start {
    justify-content: flex-start;
}
.btn-link-list li {
    display: flex;
    margin-left: 16px;
    margin-right: 16px;
    margin-bottom: 16px;
}
.btn-link-list li a,
.btn-link-list li input {
    display: flex;
    align-items: center;
    width: 100%;
    cursor: pointer;
}
@media screen and (max-width: 767px) {
    .content .btn-link-list {
        display: block;
        margin-left: 0;
        margin-right: 0;
        margin-bottom: 4rem;
    }
    .content .btn-link-list li {
        margin-left: 0;
        margin-right: 0;
        margin-bottom: 16px;
    }
}
a.btn-link-01,
input.btn-link-01,
a.btn-link-02,
input.btn-link-02,
a.btn-link-03,
input.btn-link-03 { /* 背景ブルー */
    display: block;
    position: relative;
    background-color: #28325E;
    border: none;
    border-radius: 4px;
    text-align: center;
    color: #FFF;
    font-weight: bold;
    text-decoration: none;
    outline: 0;
    justify-content: center;
}
a.btn-link-01,
input.btn-link-01 {
    padding: 1rem 3.2rem;
}
a.btn-link-02,
input.btn-link-02 {
    padding: 2rem 3.2rem;
    font-size: 1.8rem;
}
a.btn-link-03,
input.btn-link-03 {
    padding: 2.4rem 3.2rem;
    font-size: 2.2rem;
}
a.btn-link-01:before,
input.btn-link-01:before,
a.btn-link-02:before,
input.btn-link-02:before,
a.btn-link-03:before,
input.btn-link-03:before {
    position: absolute;
    top: 50%;
    left: 1.5rem;
    width: 12px;
    height: 8px;
    content: '';
    -webkit-transform: translateY(-50%) rotate(-90deg);
            transform: translateY(-50%) rotate(-90deg);
    background-image: url("/common/img/icon_arrow_w.svg");
    background-repeat: no-repeat;
    background-size: 100% auto;
}
a.btn-link-01.link-blank:before,
input.btn-link-01.link-blank:before,
a.btn-link-02.link-blank:before,
input.btn-link-02.link-blank:before,
a.btn-link-03.link-blank:before,
input.btn-link-03.link-blank:before {
    position: absolute;
    width: 14px;
    height: 14px;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background-image: url("/common/img/icon_blank_w.svg");
    background-repeat: no-repeat;
    background-size: 100% auto;
}
a.btn-link-04,
input.btn-link-04 { /* （罫線ブルー） */
    display: block;
    position: relative;
    padding: 1rem 3.2rem;
    border: 1px #154218 solid;
    border-radius: 4px;
    text-decoration: none;
}
a.btn-link-04:before,
input.btn-link-04:before {
    position: absolute;
    top: 50%;
    left: 1.5rem;
    width: 12px;
    height: 8px;
    content: '';
    -webkit-transform: translateY(-50%) rotate(-90deg);
            transform: translateY(-50%) rotate(-90deg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
a.btn-link-04.link-anchor:before,
input.btn-link-04.link-anchor:before {
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
}
a.btn-link-04.link-blank:before,
input.btn-link-04.link-blank:before {
    left: 1.3rem;
    width: 14px;
    height: 14px;
    background: url("/common/img/icon_blank.svg") no-repeat;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background-size: 100% 100%;
}
a.btn-link-01.link-pdf:before,
input.btn-link-01.link-pdf:before,
a.btn-link-02.link-pdf:before,
input.btn-link-02.link-pdf:before,
a.btn-link-03.link-pdf:before,
input.btn-link-03.link-pdf:before,
a.btn-link-04.link-pdf:before,
input.btn-link-04.link-pdf:before {
    left: 1.3rem;
    width: 18px;
    height: 20px;
    background: url("/common/img/icon_pdf.svg") no-repeat;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background-size: 100% auto;
}
a.btn-link-01.link-xls:before,
input.btn-link-01.link-xls:before,
a.btn-link-02.link-xls:before,
input.btn-link-02.link-xls:before,
a.btn-link-03.link-xls:before,
input.btn-link-03.link-xls:before,
a.btn-link-04.link-xls:before,
input.btn-link-04.link-xls:before {
    left: 1.3rem;
    width: 17px;
    height: 20px;
    background: url("/common/img/icon_xls.svg") no-repeat;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background-size: 100% auto;
}

/*--------------------------------------
 リンク
--------------------------------------*/
.content .link-list li { /* リンクリスト（下マージン付） */
    margin-bottom: 1rem;
}
.content .link-list li:last-child {
    margin-bottom: 0;
}
.content .link-list-2eq,
.content .link-list-3eq { /* リンクリスト（2、3等分） */
    display: flex;
    justify-content: space-between;
}
.content .link-list-2eq ul {
    width: 49%;
}
.content .link-list-3eq ul {
    width: 32%;
}
.content .link-list-3eq ul.link-list-2x {
    width: 66%;
}
.content .link-list-2eq ul li,
.content .link-list-3eq ul li {
    margin-bottom: 1rem;
}
.content .link-list-2eq ul li:last-child,
.content .link-list-3eq ul li:last-child {
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
.content .link-list-2eq,
.content .link-list-3eq { /* リンクリスト（2、3等分） */
    display: block;
}
.content .link-list-2eq ul,
.content .link-list-3eq ul {
    width: inherit;
}
.content .link-list-2eq ul li:last-child,
.content .link-list-3eq ul li:last-child {
    margin-bottom: 1rem;
}
.content .link-list-2eq ul:last-of-type li:last-child,
.content .link-list-3eq ul:last-of-type li:last-child {
    margin-bottom: 1rem;
}
}

.link-arrow { /* 通常リンクアイコン */
    position: relative;
    padding: 0 0 0 2.5rem;
    text-decoration: none;
    text-indent: 0;
}
.link-arrow:before {
    position: absolute;
    top: 0.5em;
    left: 0.5rem;
    display: block;
    width: 11px;
    height: 7px;
    content: '';
    -webkit-transform: rotate(-90deg);
            transform: rotate(-90deg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
.link-blank { /* 別窓アイコン */
    position: relative;
    padding: 0 0 0 2.5rem;
    text-decoration: none;   
}
.link-blank:before {
    position: absolute;
    top: 0.3em;
    left: 0;
    display: block;
    width: 14px;
    height: 14px;
    -webkit-transform: rotate(0);
            transform: rotate(0);
    background: url("/common/img/icon_blank.svg") no-repeat;
    background-size: 100% auto;
    content: '';
}

.link-pdf { /* PDFアイコン */
    position: relative;
    padding: 0 0 0 2.5rem;
    text-decoration: none;   
}
.link-pdf:before {
    position: absolute;
    top: 0.1em;
    left: 0;
    display: block;
    width: 18px;
    height: 20px;
    background: url("/common/img/icon_pdf.svg") no-repeat;
    background-size: 100% auto;
    content: '';
}

.link-xls { /* Excelアイコン */
    position: relative;
    padding: 0 0 0 2.5rem;
    text-decoration: none;   
}
.link-xls:before {
    position: absolute;
    top: 0.1em;
    left: 0;
    display: block;
    width: 17px;
    height: 20px;
    background: url("/common/img/icon_xls.svg") no-repeat;
    background-size: 100% auto;
    content: '';
}

.link-doc { /* Wordアイコン */
    position: relative;
    padding: 0 0 0 2.5rem;
    text-decoration: none;   
}
.link-doc:before {
    position: absolute;
    top: 0.1em;
    left: 0;
    display: block;
    width: 17px;
    height: 20px;
    background: url("/common/img/icon_doc.svg") no-repeat;
    background-size: 100% auto;
    content: '';
}

.box-text-link-01,
.box-text-link-01-hi { /* ボタン1つ中央（背景ブルー） */
    width: 35rem;
    margin: 0 auto;
}
ul.box-text-link-01,
ul.box-text-link-01-hi { /* ボタン2つ中央（背景ブルー） */
    display: flex;
    justify-content: center;
}
ul.box-text-link-01 li,
ul.box-text-link-01-hi li {
    width: 35rem;
    margin: 0 1.5rem;
}
ul.box-text-link-01 li.other-link {
    padding: 0 0 0 3rem;
    border-left: 1px #707070 solid;
}
ul.box-text-link-01 li.other-link a {
    width: 25rem;
}
.box-text-link-01 a,
.box-text-link-01 button,
.btn-link-list li button,
p.box-text-link-01-hi a,
ul.box-text-link-01 li a,
ul.box-text-link-01 li input,
ul.box-text-link-01-hi li a {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    background: #154218;
    border: none;
    border-radius: 4px;
    text-align: center;
    color: #FFF;
    font-weight: bold;
    text-decoration: none;
    outline: 0;
    box-sizing: border-box;
    cursor: pointer;
}
.box-text-link-01 a,
.box-text-link-01 button,
.btn-link-list li button,
ul.box-text-link-01 li a,
ul.box-text-link-01 li input {
    width: 100%;
    padding: 2rem;
}
.box-text-link-01-hi a,
ul.box-text-link-01-hi a {
    padding: 2.4rem 1rem;
    font-size: 2.2rem;
}
.box-text-link-01 button.is-disable,
.btn-link-list li button.is-disable {
    opacity: 50%;
    background: #666666;
    cursor: default;
}
.box-text-link-01 a:before,
.box-text-link-01 button:before,
.btn-link-list li button:before,
p.box-text-link-01-hi a:before,
ul.box-text-link-01 li a:before,
ul.box-text-link-01 li input:before,
ul.box-text-link-01-hi li a:before {
    position: absolute;
    top: 50%;
    left: 1.5rem;
    width: 12px;
    height: 8px;
    content: '';
    -webkit-transform: translateY(-50%) rotate(-90deg);
            transform: translateY(-50%) rotate(-90deg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow_w.svg");
}
.box-text-link-01 a.link-blank:before,
.box-text-link-01 button.link-blank:before,
.btn-link-list li button.link-blank:before,
p.box-text-link-01-hi a.link-blank:before,
ul.box-text-link-01 li a.link-blank:before,
ul.box-text-link-01-hi li a.link-blank:before {
    position: absolute;
    width: 14px;
    height: 14px;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background: url("/common/img/icon_blank_w.svg") no-repeat;
    background-size: 100% auto;
}
ul.box-text-link-02 li { /* 罫線角丸リンクリスト */
    margin-bottom: 1rem;
}
ul.box-text-link-02 li a {
    display: flex;
    align-items: center;
    position: relative;
    padding: 1rem 1rem 1rem 4rem;
    border: 1px #154218 solid;
    border-radius: 4px;
    text-decoration: none;
}
_:-ms-lang(x)::-ms-backdrop, ul.box-text-link-02 li a { /* IE11のみ */
    padding: 1.5rem 1rem 1rem 4rem;
}
ul.box-text-link-02 li a:before {
    position: absolute;
    top: 50%;
    left: 1.5rem;
    width: 12px;
    height: 8px;
    content: '';
    -webkit-transform: translateY(-50%) rotate(-90deg);
            transform: translateY(-50%) rotate(-90deg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
ul.box-text-link-02 li a.link-anchor:before {
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
}
ul.box-text-link-02 li a.link-blank:before {
    left: 1.3rem;
    width: 14px;
    height: 14px;
    background: url("/common/img/icon_blank.svg") no-repeat;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background-size: 100% 100%;
}
ul.box-text-link-02 li a.link-pdf:before {
    left: 1.3rem;
    width: 18px;
    height: 20px;
    background: url("/common/img/icon_pdf.svg") no-repeat;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background-size: 100% auto;
}
ul.box-text-link-03 { /* 横並び4列（SP1列） */
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 6rem;
}
ul.box-text-link-03 li {
    display: flex;
    align-items: stretch;
    width: 274px;
    margin: 0 8px 8px 0;
}
ul.box-text-link-03 li:nth-child(4n) {
    margin: 0 0 8px;
}
ul.box-text-link-03 li a {
    width: 274px;
}
ul.box-text-link-03 li a,
ul.box-text-link-04 li a,
ul.box-text-link-05 li a {
    display: flex;
    align-items: center;
    position: relative;
    padding: 1rem 1rem 1rem 4rem;
    border: 1px #154218 solid;
    border-radius: 4px;
    text-decoration: none;
}
ul.box-text-link-03 li a:before,
ul.box-text-link-04 li a:before,
ul.box-text-link-05 li a:before {
    position: absolute;
    top: 50%;
    left: 1.5rem;
    width: 12px;
    height: 8px;
    content: '';
    -webkit-transform: translateY(-50%) rotate(-90deg);
            transform: translateY(-50%) rotate(-90deg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
ul.box-text-link-03 li a.link-anchor:before,
ul.box-text-link-04 li a.link-anchor:before,
ul.box-text-link-05 li a.link-anchor:before {
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
}
ul.box-text-link-03 li a.link-blank:before,
ul.box-text-link-04 li a.link-blank:before,
ul.box-text-link-05 li a.link-blank:before {
    left: 1.3rem;
    width: 14px;
    height: 14px;
    background: url("/common/img/icon_blank.svg") no-repeat;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background-size: 100% 100%;
}
ul.box-text-link-03 li a.link-pdf:before {
    left: 1.3rem;
    width: 18px;
    height: 20px;
    background: url("/common/img/icon_pdf.svg") no-repeat;
    -webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
    background-size: 100% auto;
}
ul.box-text-link-04 { /* 横並び4列（SP2列） */
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 6rem;
}
ul.box-text-link-04 li {
    display: flex;
    align-items: stretch;
    width: 274px;
    margin: 0 8px 8px 0;
}
ul.box-text-link-04 li:nth-child(4n) {
    margin: 0 0 8px;
}
ul.box-text-link-05 { /* 横並び2列 */
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 5rem;
}
ul.box-text-link-05 li {
    display: flex;
    position: relative;
    width: 552px;
    padding-bottom: 1rem;
}
ul.box-text-link-04 li a {
    width: 274px;
}
ul.box-text-link-05 li a {
    width: 552px;
}
@media screen and (max-width: 767px) {
    p.box-text-link-01,
    p.box-text-link-01-hi { /* ボタン1つ中央（背景ブルー）SP */
        width: 100%;
        margin: 0;
    }
    ul.box-text-link-01,
    ul.box-text-link-01-hi { /* ボタン2つ中央（背景ブルー）SP */
        flex-wrap: wrap;
    }
    ul.box-text-link-01 li,
    ul.box-text-link-01-hi li {
        width: 46%;
        margin: 0 2%;
    }
    ul.box-text-link-01 li.other-link {
        width: 96%;
        margin: 4% 0 0;
        padding: 4% 0 0;
        border-left: none;
        border-top: 1px #707070 solid;
    }
    ul.box-text-link-01 li.other-link a {
        width: 46%;
        margin: 0 auto;
    }
    p.box-text-link-01 a:before,
    p.box-text-link-01 button:before,
    p.box-text-link-01-hi a:before,
    ul.box-text-link-01 li a:before,
    ul.box-text-link-01 li input:before,
    ul.box-text-link-01-hi li a:before {
        left: 1rem;
    }
    ul.box-text-link-03 { /* 横並び4列（SP1列） */
        margin-bottom: 4rem;
    }
    ul.box-text-link-03 li {
        width: 100%;
        margin: 0 0 2% 0;
        padding: 0;
    }
    ul.box-text-link-03 li a {
        width: 100%;
    }
    ul.box-text-link-03 li:nth-child(2n) {
        margin: 0 0 2%;
    }
    ul.box-text-link-04,
    ul.box-text-link-05 { /* 横並び4列（SP2列） */
        margin-bottom: 4rem;
    }
    ul.box-text-link-04 li,
    ul.box-text-link-05 li {
        width: 100%;
        margin: 0 0 2% 0;
        padding: 0;
    }
    ul.box-text-link-04 li a,
    ul.box-text-link-05 li a {
        width: 100%;
    }
    ul.box-text-link-04 li:nth-child(2n),
    ul.box-text-link-05 li:nth-child(2n) {
        margin: 0 0 2%;
    }
}


.link-column-01,
.link-column-02 { /* コラムリンク（角丸リンク付き） */
    display: flex;
}
.link-column-01 > a,
.link-column-02 > a,
.link-column-01 > div {
    display: block;
    width: 100%;
    box-sizing: border-box;
    border: 2px #154218 solid;
    border-radius: 4px;
    background: #FFF;
    text-decoration: none;
}
.link-column-01 > a.link-blank,
.link-column-02 > a.link-blank {
    position: static;
    padding: 0;
}
.link-column-01 > a.link-blank:before,
.link-column-02 > a.link-blank:before {
    position: static;
    background: none;
}
.link-column-01 > a .column-headline,
.link-column-01 > div .column-headline {
    display: flex;
    position: relative;
     width: 100%;
    height: 10rem;
    padding: 0 2.5rem;
    background: #F3F9E3;
    border-bottom: 2px #154218 solid;
    box-sizing: border-box;
    color: #154218;
    font-size: 1.6rem;
    line-height: 1.4;
    align-items: center;
}
.link-column-01 > a .column-headline span,
.link-column-01 > div .column-headline span {
    position: relative;
    top: -0.2em;
    margin: 0 0.6em 0 0;
    padding: 0.5em 0.5em 0.2em;
    background: #154218;
    color: #FFF;
    font-size: 1.4rem;
    line-height: 1;
}
.link-column-01 > a .column-headline:after, 
.link-column-01 > a.link-blank .column-headline:after{
    position: absolute;
    top: 50%;
    right: 1.8rem;
    width: 16px;
    margin-top: -5px;
    content: '';
    background-repeat: no-repeat;
}
.link-column-01 > a .column-headline:after{
    width: 12px;
    height: 8px;
    -webkit-transform: rotate(-90deg);
            transform: rotate(-90deg);
    background-image: url("/common/img/icon_arrow.svg");
    background-size: 100% auto;
}
.link-column-01 > a.link-blank .column-headline:after {
    width: 16px;
    height: 16px;
	-webkit-transform: rotate(0);
            transform: rotate(0);
    background: url("/common/img/icon_blank.svg") no-repeat;
	background-size: 100% auto;
}
.link-column-01 > a .column-text-01,
.link-column-01 > div .column-text-01 {
    padding: 2.5rem;
}
.link-column-02 > a {
    background: #F3F9E3;
}
.link-column-02 > a .column-details-01 {
    padding: 2.5rem 1rem;
    background: #ffffff;
    border-bottom: 2px #154218 solid;
    box-sizing: border-box;
    text-align: center;
}
.link-column-02 > a .column-details-01 p {
    margin-bottom: 0;
}
.link-column-02 > a .column-details-01 h3 {
    margin-bottom: 1rem;
    color: #154218;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.4;
}
.link-column-02 > a .column-text-01,
.link-column-02 > a .column-text-02 {
    display: flex;
    position: relative;
    width: 100%;
    margin-bottom: 0;
    padding: 0 2.5rem;
    box-sizing: border-box;
    color: #154218;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.4;
    align-items: center;
}
.link-column-02 > a .column-text-01 {
    height: 10rem;
}
.link-column-02 > a .column-text-02 {
    height: 13.2rem;
}
.link-column-02 > a .column-text-01 img,
.link-column-02 > a .column-text-02 img {
    max-width: 100% !important;
    width: auto !important;
    padding-right: 2rem;
}
.link-column-02 > a .column-text-01:after,
.link-column-02 > a .column-text-02:after {
    position: absolute;
    top: 50%;
    right: 1.8rem;
    width: 12px;
    height: 8px;
    margin-top: -5px;
    content: '';
    -webkit-transform: rotate(-90deg);
            transform: rotate(-90deg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
.link-column-02 > a.link-anchor {
    padding: 0;
}
.link-column-02 > a.link-anchor:before {
    background: none;
}
.link-column-02 > a.link-anchor .column-text-01:after {
    margin-top: 0;
	-webkit-transform: translateY(-50%) rotate(0);
            transform: translateY(-50%) rotate(0);
}

.link-column-03 { /* リンク2つ用（個別調整） */
    border: 2px #154218 solid;
    border-radius: 4px;
    background: #fffbe6;
}
.link-column-03 a.link-blank {
    position: static;
    padding: 0;
}
.link-column-03 a.link-blank:before {
    position: static;
    background: none;
}
.link-column-03 .column-details-01 {
    padding: 2.5rem 1rem;
    background: #ffffff;
    border-bottom: 2px #ff5611 solid;
    box-sizing: border-box;
    text-align: center;
}
.link-column-03 .column-details-01 h3 {
    margin-bottom: 1rem;
    color: #154218;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.4;
}
.link-column-03 .column-text-01 {
    padding: 0 0 1.5rem;
}
.link-column-03 .column-text-01 p {
	padding: 1.8rem 1.8rem 0 2.5rem ;
}
.link-column-03 .column-text-01 p a {
    display: flex;
    width: 100%;
    position: relative;
    color: #154218;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.1;
    align-items: center;
    text-decoration: none;
}
.link-column-03 .column-text-01 p a img {
    max-width: 100% !important;
    width: auto !important;
    padding-right: 2rem;
}
.link-column-03 .column-text-01 p a:after {
    position: absolute;
    top: 50%;
    right: 0;
    width: 12px;
    height: 8px;
    margin-top: -5px;
    content: '';
    -webkit-transform: rotate(-90deg);
            transform: rotate(-90deg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-image: url("/common/img/icon_arrow.svg");
}
@media screen and (max-width: 767px) {
    .link-column-01 { /* 枠囲み3コラム（角丸リンク付き）SP */
        display: block;
        margin: 0 0 3rem !important;
    }
    .link-column-01:last-of-type {
        margin: 0 !important;
    }
    .link-column-01 > a,
    .link-column-01 > div {
        width: inherit;
    }
    .link-column-01 > a .column-headline,
    .link-column-01 > div .column-headline {
        width: inherit;
    }
    .link-column-01 > a .column-text-01,
    .link-column-01 > div .column-text-01 {
        padding: 1.5rem;
    }
    .link-column-02 > a .column-text-01 img {
        max-width: 100% !important;
        width: auto !important;
        padding-right: 3vw;
    }
    .link-column-03 > a .column-text-01 {
        height: 10rem;
    }
}



/*--------------------------------------
 画像
--------------------------------------*/
.img-100 { /* 画像幅100% */
    width: 100%;
}
.img-95 { /* 画像幅95% */
    width: 95%;
}

/*--------------------------------------
 テキスト装飾関連
--------------------------------------*/
strong{/* 重要な事 */
    font-size: 110%;
    padding: 0.6rem 1rem;
    margin: 0 0.5rem;
    font-weight: 700;
    position: relative;
    vertical-align: baseline;
}
strong::after {
  content: "";
  display: block;
  width: 100%;
  height: 40%;
  left: 0;
  bottom: 10px;
  background: rgba(255, 234, 73, 0.86);
  padding: 0.6rem 1rem;
  position: absolute;
  z-index: -1;
}
em{/* 強調 */
    font-size: 110%;
    font-weight: bold;
    font-style: normal;
    padding: 0 0.2rem;
    color: #F29801;
    vertical-align: baseline;
}
.text-deco-bold {
    font-weight: bold;
}
.text-deco-normal {
    font-weight: normal;
}
.text-deco-normal-font {
    font-weight: normal;
    font-size: 1.6rem;
    color: #333;
}
.text-deco-uline {
    text-decoration: underline;
}
.text-deco-uline-dot {
	border-bottom: 1px dotted #2B332B;
}
.text-deco-black {
    color: #333;
}
.text-blue {
    color: #28325E;
}
.text-red {
    color: #C53D43;
}
.text-small {
    font-size: 1.3rem;
}
.text-smaller {
    font-size: 1rem;
    font-weight: normal;
}
.text-big {
    font-size: 2.2rem;
}
.text-bigger {
    font-size: 2.8rem;
}
.text-box {
    display: block;
}
.text-deco-frame{
	padding: 3px 5px 0;
	margin: 0 2px 3px;
	color: #154218;
	border: 1px solid #154218;
	display: inline-block;
}
.text-01 {
    font-size: 1.8rem;
}
.text-02 {
    font-size: 2rem;
}
.text-03 {
    font-size: 2.2rem;
}
.text-04 {
    font-size: 2.4rem;
}
.text-05 {
    font-size: 2.6rem;
}
.text-06 {
    font-size: 2.8rem;
}
.text-07 {
    font-size: 3rem;
}
.text-08 {
    font-size: 4rem;
}

.box-text-01 { /* 背景囲み（ブルー） */
    padding: 1rem;
    background: #154218;
    font-size: 2.5rem;
    color: #FFF;
    font-weight: bold;
    text-align: center;
}
.box-text-02 {
    padding: 0.5rem;
    background: #154218;
    color: #FFF;
    font-weight: bold;
    text-align: center;
}
.box-text-03 { /* 背景囲み（薄ブルー） */
    padding: 2.4rem 3rem;
    background: #F3F9E3;
    border-radius: 4px;
}
.box-text-06 { /* ボーダー囲み（グレー） */
    display: table;
    margin: 0 auto;
    padding: 3rem;
    border: 2px #B6C2C8 solid;
    border-radius: 4px;
    box-sizing: border-box;
}
@media screen and (max-width: 767px) {
    .box-text-06 {
        width: inherit;
    }
}

/* 文字位置
--------------------------------------*/
.align-01 {
    text-align: right;
}
.align-02 {
    text-align: center;
}
.align-03 {
    text-align: left;
}
.v_align-01 {
    vertical-align: top;
}
.v_align-02 {
    vertical-align: baseline;
}
.v_align-03 {
    vertical-align: middle;
}
@media screen and (max-width: 767px) { 
    .align-01-sp {
        text-align: right;
    }
    .align-02-sp {
        text-align: center;
    }
    .align-03-sp {
        text-align: left;
    }
}
/* 限定表示
--------------------------------------*/
.sp-none{
    display: run-in;
}
.pc-none{
    display: none;	
}
@media screen and (max-width: 767px) {
    .sp-none{
        display: none;
	}
    .pc-none {
        display: run-in;
    }
}
/* 改行
--------------------------------------*/
br.pc { 
    display:block;
}
br.sp { 
    display:none;
}
@media screen and (max-width: 767px) { 
    br.pc { 
        display:none;
    }
    br.sp {
        display:block;
    }
}
/*--------------------------------------
 画像関連
--------------------------------------*/
img.photo-01 {
    padding: 4px;
    border: 1px solid #ececec;
    background-color: #fff;
}
img.photo-02 {
    padding: 1px;
    border: 1px solid #ececec;
    background-color: #fff;
}
img.photo-03 {
    border: 1px solid #ececec;
}
img.text {
	padding: 0 5px;
    vertical-align: middle;
}
figure,
figure figcaption{
    text-align: center;
}
figure figcaption{
	font-size: 1.5rem;
	padding-top: 1.5rem;
	color: #28325E;
}
@media screen and (max-width: 767px) {
    img.rwd-100{
        width: 100%;
    }
    img.rwd-90{
        width: 90%;
    }
    img.rwd-80{
        width: 80%;
    }
    img.rwd-70{
        width: 70%;
    }
    img.rwd-60{
        width: 60%;
    }
    img.rwd-50{
        width: 50%;
    }
    .content img,
    .content-free img {
        width: 100%;
        vertical-align: top;
    }
    img.inherit-img {
        max-width: 100% !important;
        width: auto !important;
    }
}

/* 角丸 */
.kadomaru {
  img {
    border-radius: 10px;
  }
}

figure + figure {
  margin-top: 3rem;
}






/*--------------------------------------
 ドットリーダー
--------------------------------------*/
.dotleader{
    align-items: center;
    display: flex;
    justify-content: center;
    margin-bottom: 0.5rem;
}
.dotleader div:nth-child(2){
    border-bottom:1px dotted rgba(0,0,0,.3);
    flex:1 1 0%;
    margin:0 10px;
}
.dotleader:last-child{
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
    .dotleader{
        width: 100%;
    }
}


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

 印刷用

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

@media print {
    .container {
        display: block; }
    .header {
        position: absolute; }
    .header .gnavi-upper {
        display: none !important; }
    .header .gnavi-lower {
        border-top: 1px solid #333333;
        border-bottom: 0px solid #333333; }
    .header .gnavi-middle .middle-secondary {
        display: none !important; }
    .header .gnavi-lower .header-wrap {
        display: none !important; }
    .footer {
        border-top: 1px solid #333333; }
    .footer .footer-wrap {
        display: none !important; }
    .footer .footer-secondary {
        display: none !important; }
    .footer .footer-copyright {
        background-color: #fff;
        color: #000; }
    .pagetop {
        display: none; } }
