@charset "utf-8";
/* CSS Document */

body {
 margin-top: 122px;
 padding: 0;
 overflow-x: hidden;
 font-family: -apple-system, BlinkMacSystemFont, YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
 -webkit-text-size-adjust: none;/* iPhoneでの文字サイズ自動修正を使わない*/
 font-feature-settings: "palt";
 color: #030303;
 font-size: 16px;
 line-height: 200%;
 letter-spacing: 1px;
}
a:hover {
 opacity: 0.6;
 filter: alpha(opacity=60);
 -ms-filter: "alpha(opacity=60)";
}
a img {
 border-style: none;
}
.pc_none {
 display: none;
}
.sp_none {
 display: inline;
}
img {
 vertical-align: bottom;
}
a {
 color: #2e7bbe;
}
.wordbreak {
 word-break: break-all;
 overflow-wrap: break-all;
}
table {
  border-collapse:collapse;
  border-spacing:0;
}
input, select {
  vertical-align:middle;
}
input, select, textarea {
  width: 100%;
}
/*---------------------------
warning
---------------------------*/
.warning {
  color: red;
}
/*---------------------------
Notes
---------------------------*/
.notes {
  color: #c71585;
}

/*---------------------------
haeader
---------------------------*/
.header {
 width: 100%;
 height: 64px;
 padding: 6px 20px 0 20px;
 margin: 0 auto;
 overflow: hidden;
 zoom: 1;
 z-index: 99;
 position: fixed;
 top: 0;
 left: 0;
 background: #fff;
}
.header p {
 margin: 0;
}
.header_link {
 float: right;
 margin-top: 8px;
 margin-right: 50px;
}
#logo {
 float: left;
 width: 260px;
 margin-top: 6px;
}
.cb {
 clear:both;
}

/*---------------------------
h
---------------------------*/
h1 {
 text-align: center;
 border-bottom: 1px solid #030303;
 padding: 10px 0 0 0;
 margin: 0;
 font-size: 28px;
 color: #ff6633;
}
h2 {
 text-align: center;
 background: #ff9966;
 margin: 0;
 border-top-left-radius: 5px;
 border-top-right-radius: 5px;
 font-size: 24px;
 font-weight: bold;
 line-height: 200%;
 color: #fff;
}
h3 {
 margin: 20px 20px 0 20px;
 padding: 0;
 height: 20px;
// border-bottom: 1px solid #ff6633;
}
h3 .icon {
 float: left;
 width: 18px;
 height: 18px;
 background: #ff9966;
 display: block;
 margin: 0;
}
h3 .title {
 float: left;
 font-size: 18px;
 font-weight: bold;
 margin-left: 4px;
 padding: 0;
 line-height: 100%;
 color: #009999;
}

/*---------------------------
contents_navi
---------------------------*/

.contents_navi {
 width: 100%;
 background: #ff6633;
 padding: 10px 0 0 0;
 position: fixed;
 top: 70px;
 left: 0;
 z-index: 98;
}
.contents_navi_main {
 width: 750px;
 margin: 0 auto;
 overflow: hidden;
 zoom: 1;
}
.contents_navi_main a {
 color: #fff;
 text-decoration: none;
 text-align: center;
 font-size: 18px;
 line-height: 40px;
}
.contents_navi1 {
 float: left;
 border-top-left-radius: 5px;
 border-top-right-radius: 5px;
 display: block;
 width: 180px;
 height: 40px;
 background: #ff9966;
 margin: 0 7px 0 0;
 font-weight: bold;
}
.contents_navi1_on {
 float: left;
 border-top-left-radius: 5px;
 border-top-right-radius: 5px;
 display: block;
 width: 180px;
 height: 40px;
 background: #fff;
 margin: 0 7px 0 0;
 text-align: center;
 font-size: 18px;
 line-height: 40px;
 font-weight: bold;
 color: #ff6633;
}
/*---------------------------
contents
---------------------------*/
.contents_main {
 width: 100%;
 margin: 0 auto 0 auto;
 padding: 0 0 24px 0;
 display: inline-block;
}
.contents_main_left {
 width: 30%;
 margin: 0;
 float: left;
}
.contents_main_right {
 width: 70%;
 margin: 0;
 float: right;
}
.main_visual {
 padding: 20px;
}
.contents_main_titletext {
 margin: 20px;
 color: #009999;
 font-size: 24px;
 line-height: 200%;
 font-weight: bold;
 letter-spacing: 0;
}
.contents_main_read {
 margin: 0 20px;
 font-size: 18px;
 line-height: 130%;
}
.contents_main_note {
 margin: 10px 20px 0 20px;
 font-size: 18px;
 line-height: 130%;
 color: #c71585;
}
.contents_b {
 width: 100%;
 background: #edf5e9;
 margin: 0 auto 0 auto;
 padding: 40px 0;
 display: block;
}


.border1 {
 border-bottom: 3px solid #edefef;
}
.contents_box {
 width: 100%;
 margin: 0 auto 30px auto;
 padding: 0 0 30px 0;
}
.contents_title {
 text-align: center;
 background: #151358;
 color: #fff;
 font-size: 19px;
 font-weight: bold;
 margin: 0 0 0 0;
 padding: 8px 0;
}
.contents_list {
 width: 98%;
 border-top: 1px solid #555555;
 border-right: 1px solid #555555;
 margin: 20px auto;
}
.contents_list th {
 width: 60px;
 padding: 10px;
 border-left: 1px solid #555555;
 border-bottom: 1px solid #555555;
}
.contents_list td {
 padding: 10px;
 border-left: 1px solid #555555;
 border-bottom: 1px solid #555555;
}
.contents_list_link a {
 text-decoration: none;
}
/*---------------------------
sub_contents
---------------------------*/
.sub_contents {
 width: 96%;
 margin: 0 auto 30px auto;
 padding: 0 0 30px 0;
 border-radius: 5px;        /* CSS3草案 */
 -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
 -moz-border-radius: 5px;   /* Firefox用 */
 background: #FFFFFF;
 overflow: hidden;
 zoom: 1;
}
.sub_contents_text {
 padding: 10px 28px 0 28px;
 margin: 0 0 20px 0;
// font-size: 14px;
}
.sub_contents_icon {
 margin: 28px 0 0 295px;
}
.sub_contents_icon img {
 width: 100px;
 margin: 0 50px 0 0;
}
.sub_contents_linkbox {
 text-align: center;
}
.sub_contents_banner_l {
 float: left;
}
.sub_contents_banner_r {
 float: left;
}
.sub_contents_btn {
 width: 96%;
 margin: 0 auto 30px auto;
}
/*---------------------------
material
---------------------------*/
.material {
 width: 96%;
 margin: 5px auto;
}
.material_box {
 width: 310px;
 float: left;
 background: #F0F8FF;
 margin: 5px 10px 5px 0;
 border-radius: 5px;        /* CSS3草案 */
 -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
 -moz-border-radius: 5px;   /* Firefox用 */
 padding: 0 0 14px 0;
 border: 1px solid #36a5d3;
}
.material_box1 {
 width: 310px;
 float: left;
 background: #F0F8FF;
 margin: 5px 0;
 border-radius: 5px;        /* CSS3草案 */
 -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
 -moz-border-radius: 5px;   /* Firefox用 */
 padding: 0 0 14px 0;
 border: 1px solid #36a5d3;
}
.material_box p {
 margin: 0;
}
.material_box1 p {
 margin: 0;
}
.material_box_title {
 background: #F0F8FF;
 border-top-left-radius: 5px;
 border-top-right-radius: 5px;
 overflow: hidden;
 zoom: 1;
 padding: 10px 10px 5px 10px;
// height: 98px;
 border-bottom: 1px solid #36a5d3;
 font-weight: bold;
}
.material_box_title_l {
 float: left;
 width: 300px;
 line-height: 150% !important;
}
.material_box_title_r {
 float: right;
 width: 208px;
 color: #fff;
 font-size: 14px;
 line-height: 150%;
}
.material_box_text {
 padding: 10px 10px 0 10px;
 font-size: 14px;
 line-height: 150%;
 height: auto;
}
.material_box_text img {
 width: 290px;
 height: 290px;
 margin-bottom: 5px;
}
.material_box_btn {
 overflow: hidden;
 zoom: 1;
 margin-top: 5px;
 padding: 0 14px;
 height: 50px;
}
.material_box_btn_l {
 float: left;
}
.material_box_btn_r {
 float: right;
}
.material_box_more {
 background: #ff9999;
 color: #fff;
 text-decoration: none;
 border-radius: 30px;        /* CSS3草案 */
 -webkit-border-radius: 30px;    /* Safari,Google Chrome用 */
 -moz-border-radius: 30px;   /* Firefox用 */
 display: block;
 font-size: 18px;
 line-height: 200%;
 padding: 2% 10px;
 font-weight: bold;
 width:200px;
 text-align: center;
}
.material_demo_icon {
 border-radius: 60px;        /* CSS3草案 */
 -webkit-border-radius: 60px;    /* Safari,Google Chrome用 */
 -moz-border-radius: 60px;   /* Firefox用 */
 background: #dc143c;
 color: #fff;
 font-size: 12px;
 line-height: 200%;
 padding: 3px 5px;
}

.text_narrow_x {
 transform: scale(0.8,1);
 transform-origin: top left;
 width:125%;
}

/*---------------------------
contact form
---------------------------*/
.p-container--contact {
  margin: 20px;
  padding: 10px;
  background: #fff;
}
.p-container--contact table{
  width:100%;
}
.p-container--contact th{
  font-size: 1rem;
  font-weight: normal;
  vertical-align: middle;
  border: #eaeaea 1px solid;
  background: #f9F9f9;
  text-align: left;
  padding-left: 2rem;
  width:40%;
}
.p-container--contact td {
  font-size: 1rem;
  font-weight: normal;
  border: #eaeaea 1px solid;
  padding: 10px 20px;
  width:60%;
}
.p-form--contact__btn {
  text-align: right;
  margin-top: 20px;
}
.p-form--contact__btn button[type="submit"] {
  width: 80px;
  height: 30px;
  background: #dcDAda;
  font-size: 1rem;
  line-height: 1;
  color: #6c6866;
}

/*---------------------------
footer
---------------------------*/
footer {
 width: 100%;
}
.footer_link {
 width: 100%;
 margin: 0;
 overflow: hidden;
 background: #ff6633;
 zoom: 1;
}
.footer_link a {
 color: #fff;
}
.footer_link_l {
 float: left;
 padding-top: 16px;
 padding-left: 20px;
 font-size: 14px;
 line-height: 42px;
}
.footer_link_r {
 float: left;
 padding-top: 16px;
 padding-left: 20px;
 font-size: 14px;
 line-height: 42px;
}
.copy {
 float: left;
 color: #fff;
 padding: 20px 0 20px 5px;
 font-size: 12px;
}
.cp_box input {
 display: none;
}
/*---------------------------
pagetop
---------------------------*/

#page-top {
 position: fixed;
 bottom: 10px;
 right: 10px;
 font-size: 77%;
}
#page-top a {
 text-decoration: none;
 width: 50px;
 padding: 0;
 display: block;
}
#page-top a:hover {
 text-decoration: none;
}

/*---------------------------
instagram
---------------------------*/
.instagram_box {
 width: 320px;
 margin: 10px;
 padding: 30px 0 30px 30px;
 background: #fff;
}
.instagram_icon {
 width: 60px;
 float:left;
 background: #fff;
}
.instagram_p {
// float:right;
 margin-left: 80px;
// width: 100%;
 background: #fff;
}

@media screen and (max-width : 768px) {
body {
 font-size: 90%;
 line-height: 200%;
 margin-top: 100px;
}
.pc_none {
 display: inline;
}
.sp_none {
 display: none;
}
input, select, textarea {
  width: 98%;
}
/*---------------------------
haeader
---------------------------*/
.header {
 width: 96%;
 padding: 5px 2%;
 margin: 0 auto;
 height: 44px;
 position: fixed;
 background: #fff;
 top: 0;
 left: 0;
}
.header_link {
// display: none;
}
#logo {
 float: left;
 width: 200px;
 margin-top: 4px;
}
/*---------------------------
h
---------------------------*/
h1 {
 padding: 0 0 2% 0;
 font-size: 150%;
}
h2 {
 font-size: 120%;
}
h3 {
 margin: 2% 4% 0 4%;
 height: 20px;
}
h3 .icon {
 width: 16px;
 height: 16px;
}
h3 .title {
 font-size: 100%;
 line-height: 100%;
 width: 92%;
}
/*---------------------------
contents_navi
---------------------------*/

.contents_navi {
 width: 100%;
 background: #ff6633;
 padding: 10px 0 0 0;
 top: 50px;
}
.contents_navi_main {
 width: 98%;
 margin: 0 auto;
 overflow: hidden;
 zoom: 1;
}
.contents_navi_main a {
 color: #fff;
 text-decoration: none;
 text-align: center;
 font-size: 90%;
 line-height: 130%;
}
.contents_navi1 {
 float: left;
 border-top-left-radius: 5px;
 border-top-right-radius: 5px;
 display: block;
 width: 22%;
 height: 36px;
 background: #ff9966;
 margin: 0 1%;
}
.contents_navi1 span {
 line-height: 40px;
}
.contents_navi1_on {
 float: left;
 border-top-left-radius: 5px;
 border-top-right-radius: 5px;
 display: block;
 width: 22%;
 height: 36px;
 background: #fff;
 margin: 0 1%;
 text-align: center;
 font-size: 90%;
 line-height: 130%;
}
.contents_navi1_on span {
 line-height: 40px;
}
/*---------------------------
contents
---------------------------*/
.contents_main {
 width: 96%;
 margin: 0 auto 0 auto;
 padding: 0 0 2% 0;
}
.main_visual {
 position: relative;
 padding: 0 0 2% 0;
}
.main_visual p {
 position: absolute;
 color: #4b0082;
 top: 0;
 left: 2%;
 font-size: 86%;
 line-height: 120%;
 font-weight: bold;
}
.contents_main_titletext {
 margin: 2% 4% 0 4%;
 font-size: 110%;
 line-height: 140%;
}
.contents_main_read {
 margin: 0 4%;
 font-size: 100%;
}
.contents_main_note {
 margin: 4%;
 font-size: 100%;
}
.contents_b {
 margin: 0;
 padding: 20px 0;
}
.contents_box {
 width: 96%;
 margin: 0 0 10% 0;
}
.contents_title {
 font-size: 100%;
 margin: 0 0 5% 0;
 padding: 10px 0;
}
.contents_list {
 width: 98%;
 font-size: 90%;
 margin: 0 auto;
}
.contents_list th {
 padding: 2% 2%;
}
.contents_list td {
 padding: 2% 2%;
}
/*---------------------------
material
---------------------------*/
.material {
 width: 100%;
}
.material_box {
 width: 90%;
 float: none;
 margin: 0 auto 5% auto;
 padding: 0 0 4% 0;
}
.material_box1 {
 width: 90%;
 float: none;
 margin: 0 auto 5% auto;
 padding: 0 0 4% 0;
}
.material_box_title {
 padding: 5%;
 height: inherit;
 overflow: hidden;
 zoom: 1;
}
.material_box_title_l {
 width: 78%;
}
.material_box_title_r {
 width: 78%;
}
.material_box_text {
 padding: 14px 14px 0 14px;
 font-size: 14px;
 line-height: 150%;
 height: auto;
}
.material_box_btn {
 padding: 0 14px;
 height: 30px;
}
.material_box_btn_l {
 float: left;
}
.material_box_btn_r {
 float: right;
}
.material_demo_icon {
 border-radius: 60px;        /* CSS3草案 */
 -webkit-border-radius: 60px;    /* Safari,Google Chrome用 */
 -moz-border-radius: 60px;   /* Firefox用 */
 background: #5d9d26;
 color: #fff;
 font-size: 12px;
 line-height: 200%;
 padding: 2% 10px;
}
.material_box_more {
 background: #ff9999;
 color: #fff;
 text-decoration: none;
 border-radius: 30px;        /* CSS3草案 */
 -webkit-border-radius: 30px;    /* Safari,Google Chrome用 */
 -moz-border-radius: 30px;   /* Firefox用 */
 display: block;
 font-size: 16px;
 line-height: 100%;
 padding: 2% 10px;
 font-weight: bold;
 text-align: center;
}

/*---------------------------
contact form
---------------------------*/
.p-container--contact th {
  border: none;
  border-right: #eaeaea 1px solid;
  border-left: #eaeaea 1px solid;
}
.p-container--contact th,
.p-container--contact td {
  display: block;
  width: 90%;
  padding: 10px 20px;
}

/*---------------------------
footer
---------------------------*/
footer {
 margin: 0;
 width: 100%;
}
.footer_link {
 width: 100%;
 margin: 5% auto;
}
.footer_link_l {
 float: none;
 text-align: center;
 width: 100%;
// padding: 0 20px 0 0;
 padding-top: 16px;
 padding-left: 20px;
 font-size: 14px;
 line-height: 42px;
}
.footer_link_r {
 float: left;
 padding-top: 16px;
 padding-left: 20px;
 line-height: 42px;
}
.copy p {
 float: left;
 color: #fff;
 padding: 20px 0 20px 5px;
 font-size: 12px;
}
.cp_box *, .cp_box *:before, .cp_box *:after {
 -webkit-box-sizing: border-box;
 box-sizing: border-box;
}
.cp_box {
 position: relative;
}
.cp_box label {
 position: absolute;
 z-index: 1;
 bottom: 0;
 width: 100%;
 height: 140px; /* グラデーションの高さ */
 cursor: pointer;
 text-align: center;
 /* 以下グラデーションは背景を自身のサイトに合わせて設定してください */
 background: linear-gradient(to bottom, rgba(237, 239, 239, 0) 0%, rgba(237, 239, 239, 0.95) 100%);
}
.cp_box input:checked + label {
 background: inherit; /* 開いた時にグラデーションを消す */
 height: 70px;
}
.cp_box label:after {
 line-height: 2.5rem;
 position: absolute;
 z-index: 2;
 bottom: 20px;
 left: 50%;
 width: 10rem;
 /*font-family: 'Font Awesome 5 Free';*/
 content: '＋もっと見る';
 transform: translate(-50%, 0);
 letter-spacing: 0.05em;
 color: #ffffff;
 border-radius: 5px;
 background-color: #1c70b9;
 font-weight: 900;
}
.cp_box input {
 display: none;
}
.cp_box .cp_container {
 overflow: hidden;
 height: 1500px; /* 開く前に見えている部分の高さ */
 transition: all 0.5s;
}
.cp_box input:checked + label {
/* display: none ; 閉じるボタンを消す場合解放 */
}
.cp_box input:checked + label:after {
 /*font-family: 'Font Awesome 5 Free';*/
 content: '－ 閉じる';
 font-weight: 900;
}
.cp_box input:checked ~ .cp_container {
 height: auto;
 padding-bottom: 80px; /* 閉じるボタンのbottomからの位置 */
 transition: all 0.5s;
}
/*---------------------------
pagetop
---------------------------*/

#page-top {
 position: fixed;
}
#page-top a {
 text-decoration: none;
 width: 80%;
 padding: 0;
 display: block;
}
#page-top a:hover {
 text-decoration: none;
}

}

@media screen and (max-width : 480px) {
h1 {
 font-size: 120%;
}
.contents_main_titletext {
 font-size: 100%;
 line-height: 140%;
}
.contents_main_read {
 font-size: 100%;
 line-height: 140%;
}
.main_visual p {
 font-size: 60%;
}
.material_box_text img {
 width: 100%;
}

}
