@charset "UTF-8";
/* Reset
----------------------------------------------------------*/
@import "https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700,900";
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

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

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

/* Margin
----------------------------------------------------------*/
.mt_0 {
  margin-top: 0px !important;
}

.mr_0 {
  margin-right: 0px !important;
}

.mb_0 {
  margin-bottom: 0px !important;
}

.ml_0 {
  margin-left: 0px !important;
}

.mt_10 {
  margin-top: 10px !important;
}

.mr_10 {
  margin-right: 10px !important;
}

.mb_10 {
  margin-bottom: 10px !important;
}

.ml_10 {
  margin-left: 10px !important;
}

.mt_20 {
  margin-top: 20px !important;
}

.mr_20 {
  margin-right: 20px !important;
}

.mb_20 {
  margin-bottom: 20px !important;
}

.ml_20 {
  margin-left: 20px !important;
}

.mt_30 {
  margin-top: 30px !important;
}

.mr_30 {
  margin-right: 30px !important;
}

.mb_30 {
  margin-bottom: 30px !important;
}

.ml_30 {
  margin-left: 30px !important;
}

.mt_40 {
  margin-top: 40px !important;
}

.mr_40 {
  margin-right: 40px !important;
}

.mb_40 {
  margin-bottom: 40px !important;
}

.ml_40 {
  margin-left: 40px !important;
}

.mt_50 {
  margin-top: 50px !important;
}

.mr_50 {
  margin-right: 50px !important;
}

.mb_50 {
  margin-bottom: 50px !important;
}

.ml_50 {
  margin-left: 50px !important;
}

.mt_60 {
  margin-top: 60px !important;
}

.mr_60 {
  margin-right: 60px !important;
}

.mb_60 {
  margin-bottom: 60px !important;
}

.ml_60 {
  margin-left: 60px !important;
}

.mt_70 {
  margin-top: 70px !important;
}

.mr_70 {
  margin-right: 70px !important;
}

.mb_70 {
  margin-bottom: 70px !important;
}

.ml_70 {
  margin-left: 70px !important;
}

.mt_80 {
  margin-top: 80px !important;
}

.mr_80 {
  margin-right: 80px !important;
}

.mb_80 {
  margin-bottom: 80px !important;
}

.ml_80 {
  margin-left: 80px !important;
}

.mt_90 {
  margin-top: 90px !important;
}

.mr_90 {
  margin-right: 90px !important;
}

.mb_90 {
  margin-bottom: 90px !important;
}

.ml_90 {
  margin-left: 90px !important;
}

.mt_100 {
  margin-top: 100px !important;
}

.mr_100 {
  margin-right: 100px !important;
}

.mb_100 {
  margin-bottom: 100px !important;
}

.ml_100 {
  margin-left: 100px !important;
}

/* Padding
----------------------------------------------------------*/
.pt_0 {
  padding-top: 0px !important;
}

.pr_0 {
  padding-right: 0px !important;
}

.pb_0 {
  padding-bottom: 0px !important;
}

.pl_0 {
  padding-left: 0px !important;
}

.pt_10 {
  padding-top: 10px !important;
}

.pr_10 {
  padding-right: 10px !important;
}

.pb_10 {
  padding-bottom: 10px !important;
}

.pl_10 {
  padding-left: 10px !important;
}

.pt_20 {
  padding-top: 20px !important;
}

.pr_20 {
  padding-right: 20px !important;
}

.pb_20 {
  padding-bottom: 20px !important;
}

.pl_20 {
  padding-left: 20px !important;
}

.pt_30 {
  padding-top: 30px !important;
}

.pr_30 {
  padding-right: 30px !important;
}

.pb_30 {
  padding-bottom: 30px !important;
}

.pl_30 {
  padding-left: 30px !important;
}

.pt_40 {
  padding-top: 40px !important;
}

.pr_40 {
  padding-right: 40px !important;
}

.pb_40 {
  padding-bottom: 40px !important;
}

.pl_40 {
  padding-left: 40px !important;
}

.pt_50 {
  padding-top: 50px !important;
}

.pr_50 {
  padding-right: 50px !important;
}

.pb_50 {
  padding-bottom: 50px !important;
}

.pl_50 {
  padding-left: 50px !important;
}

.pt_60 {
  padding-top: 60px !important;
}

.pr_60 {
  padding-right: 60px !important;
}

.pb_60 {
  padding-bottom: 60px !important;
}

.pl_60 {
  padding-left: 60px !important;
}

.pt_70 {
  padding-top: 70px !important;
}

.pr_70 {
  padding-right: 70px !important;
}

.pb_70 {
  padding-bottom: 70px !important;
}

.pl_70 {
  padding-left: 70px !important;
}

.pt_80 {
  padding-top: 80px !important;
}

.pr_80 {
  padding-right: 80px !important;
}

.pb_80 {
  padding-bottom: 80px !important;
}

.pl_80 {
  padding-left: 80px !important;
}

.pt_90 {
  padding-top: 90px !important;
}

.pr_90 {
  padding-right: 90px !important;
}

.pb_90 {
  padding-bottom: 90px !important;
}

.pl_90 {
  padding-left: 90px !important;
}

.pt_100 {
  padding-top: 100px !important;
}

.pr_100 {
  padding-right: 100px !important;
}

.pb_100 {
  padding-bottom: 100px !important;
}

.pl_100 {
  padding-left: 100px !important;
}

/* Float
----------------------------------------------------------*/
/*.alignleft {
	float: left;
}

.alignright {
	float: right;
}

.aligncenter {
	display: block;
	margin: 0px auto;
	clear: both;
}

img {
	
	&.alignleft {
		margin: 0 1em 1em 0;
	}
	
	&.alignright {
		margin: 0 0 1em 1em;
	}
}*/
/* Font
----------------------------------------------------------*/
/* font-size */
.fs_10 {
  font-size: 10px !important;
  font-size: 1rem !important;
}

.fs_11 {
  font-size: 11px !important;
  font-size: 1.1rem !important;
}

.fs_12 {
  font-size: 12px !important;
  font-size: 1.2rem !important;
}

.fs_13 {
  font-size: 13px !important;
  font-size: 1.3rem !important;
}

.fs_14 {
  font-size: 14px !important;
  font-size: 1.4rem !important;
}

.fs_15 {
  font-size: 15px !important;
  font-size: 1.5rem !important;
}

.fs_16 {
  font-size: 16px !important;
  font-size: 1.6rem !important;
}

.fs_17 {
  font-size: 17px !important;
  font-size: 1.7rem !important;
}

.fs_18 {
  font-size: 18px !important;
  font-size: 1.8rem !important;
}

.fs_19 {
  font-size: 19px !important;
  font-size: 1.9rem !important;
}

.fs_20 {
  font-size: 20px !important;
  font-size: 2rem !important;
}

.fs_21 {
  font-size: 21px !important;
  font-size: 2.1rem !important;
}

.fs_22 {
  font-size: 22px !important;
  font-size: 2.2rem !important;
}

.fs_23 {
  font-size: 23px !important;
  font-size: 2.3rem !important;
}

.fs_24 {
  font-size: 24px !important;
  font-size: 2.4rem !important;
}

.fs_25 {
  font-size: 25px !important;
  font-size: 2.5rem !important;
}

.fs_26 {
  font-size: 26px !important;
  font-size: 2.6rem !important;
}

.fs_27 {
  font-size: 27px !important;
  font-size: 2.7rem !important;
}

.fs_28 {
  font-size: 28px !important;
  font-size: 2.8rem !important;
}

.fs_29 {
  font-size: 29px !important;
  font-size: 2.9rem !important;
}

.fs_30 {
  font-size: 30px !important;
  font-size: 3rem !important;
}

.fs_31 {
  font-size: 31px !important;
  font-size: 3.1rem !important;
}

.fs_32 {
  font-size: 32px !important;
  font-size: 3.2rem !important;
}

.fs_33 {
  font-size: 33px !important;
  font-size: 3.3rem !important;
}

.fs_34 {
  font-size: 34px !important;
  font-size: 3.4rem !important;
}

.fs_35 {
  font-size: 35px !important;
  font-size: 3.5rem !important;
}

.fs_36 {
  font-size: 36px !important;
  font-size: 3.6rem !important;
}

.fs_37 {
  font-size: 37px !important;
  font-size: 3.7rem !important;
}

.fs_38 {
  font-size: 38px !important;
  font-size: 3.8rem !important;
}

.fs_39 {
  font-size: 39px !important;
  font-size: 3.9rem !important;
}

.fs_40 {
  font-size: 40px !important;
  font-size: 4rem !important;
}

/* font-weight */
.fw_b {
  font-weight: bold !important;
}

.fw_n {
  font-weight: normal !important;
}

/* line-height */
.lh_10 {
  line-height: 1 !important;
}

.lh_11 {
  line-height: 1.1 !important;
}

.lh_12 {
  line-height: 1.2 !important;
}

.lh_13 {
  line-height: 1.3 !important;
}

.lh_14 {
  line-height: 1.4 !important;
}

.lh_15 {
  line-height: 1.5 !important;
}

.lh_16 {
  line-height: 1.6 !important;
}

.lh_17 {
  line-height: 1.7 !important;
}

.lh_18 {
  line-height: 1.8 !important;
}

.lh_19 {
  line-height: 1.9 !important;
}

.lh_20 {
  line-height: 2 !important;
}

/* text-align */
.ta_left {
  text-align: left !important;
}

.ta_right {
  text-align: right !important;
}

.ta_center {
  text-align: center !important;
}

/* vertical-align */
.va_top {
  vertical-align: top !important;
}

.va_bottom {
  vertical-align: bottom !important;
}

.va_middle {
  vertical-align: middle !important;
}

/* Form
----------------------------------------------------------*/
button,
input,
select,
textarea {
  max-width: 100%;
  box-sizing: border-box;
  font-size: 100%;
  vertical-align: baseline;
  border: 1px solid #CCC;
  border-radius: 5px;
}

/* テキスト・テキストエリア */
input[type="text"], input[type="email"], input[type="tel"], input[type="url"], input[type="password"], input[type="search"] {
  padding: 5px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

textarea {
  padding: 5px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/* ボタン */
button {
  padding: 10px 20px;
  color: #fff;
  border: 1px solid #000;
  background: #000;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
button:hover {
  opacity: .7;
}

input[type="button"], input[type="submit"] {
  padding: 10px 20px;
  color: #fff;
  border: 1px solid #000;
  background: #000;
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
input[type="button"]:hover, input[type="submit"]:hover {
  opacity: .7;
}
input[type="reset"] {
  padding: 10px 20px;
  color: #999;
  border: 1px solid #CCC;
  background: #fff;
  cursor: pointer;
}
input[type="reset"]:hover {
  opacity: .7;
}

input[type="button"][disabled], input[type="reset"][disabled], input[type="submit"][disabled] {
  opacity: .7;
}

label {
  cursor: pointer;
}

/* Column
----------------------------------------------------------*/
.row {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  margin: 0 -20px;
}
@media screen and (max-width: 768px) {
  .row {
    display: block;
  }
}
.row.middle {
  -webkit-box-align: center;
          align-items: center;
}
.row.reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
          flex-direction: row-reverse;
}

.col-1 {
  width: calc(8.33333% - 40px);
}

.col-2 {
  width: calc(16.666666% - 40px);
}

.col-3 {
  width: calc(24.99999% - 40px);
}

.col-4 {
  width: calc(33.33333% - 40px);
}

.col-5 {
  width: calc(41.66666% - 40px);
}

.col-6 {
  width: calc(49.99999% - 40px);
}

.col-7 {
  width: calc(58.33333% - 40px);
}

.col-8 {
  width: calc(66.66666% - 40px);
}

.col-9 {
  width: calc(74.99999% - 40px);
}

.col-10 {
  width: calc(83.33333% - 40px);
}

.col-11 {
  width: calc(91.66666% - 40px);
}

.col-1,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8,
.col-9,
.col-10,
.col-11,
.col-12 {
  margin: 40px 20px 0;
}
@media screen and (max-width: 768px) {
  .col-1,
  .col-2,
  .col-3,
  .col-4,
  .col-5,
  .col-6,
  .col-7,
  .col-8,
  .col-9,
  .col-10,
  .col-11,
  .col-12 {
    width: auto;
  }
}

/* Clearfix
----------------------------------------------------------*/
.clearfix:after {
  content: ".";
  display: block;
  visibility: hidden;
  height: 0.1px;
  font-size: 0.1em;
  line-height: 0;
  clear: both;
}

.clear {
  clear: both;
}

/* フォント
----------------------------------------------------------*/
@font-face {
  font-family: 'webfont';
  src: url("../fonts/webfont.eot?s6qt3q");
  src: url("../fonts/webfont.eot?s6qt3q#iefix") format("embedded-opentype"), url("../fonts/webfont.ttf?s6qt3q") format("truetype"), url("../fonts/webfont.woff?s6qt3q") format("woff"), url("../fonts/webfont.svg?s6qt3q#webfont") format("svg");
  font-weight: normal;
  font-style: normal;
}
[class^="icn_"], [class*=" icn_"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'webfont' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icn_facebook:before {
  content: "\ea90";
}

.icn_instagram:before {
  content: "\ea92";
}

.icn_twitter:before {
  content: "\ea96";
}

.icn_youtube:before {
  content: "\ea9d";
}

/* 全体
----------------------------------------------------------*/
* {
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
}

body {
  font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.6em;
  letter-spacing: .1em;
  line-height: 1.8;
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 60px;
  font-weight: bold;
}
h1:nth-child(1),
h2:nth-child(1),
h3:nth-child(1),
h4:nth-child(1),
h5:nth-child(1),
h6:nth-child(1) {
  margin-top: 0;
}

p,
ul,
ol,
dl,
table,
blockquote,
iframe {
  margin-top: 30px;
}
p:nth-child(1),
ul:nth-child(1),
ol:nth-child(1),
dl:nth-child(1),
table:nth-child(1),
blockquote:nth-child(1),
iframe:nth-child(1) {
  margin-top: 0;
}

strong {
  font-weight: bold;
}

sup,
sub {
  font-size: 10px;
  height: 0;
  line-height: 1;
  position: relative;
  vertical-align: baseline;
}

sup {
  bottom: 1ex;
}

sub {
  top: .5ex;
}

hr {
  margin: 30px 0;
  border: none;
  border-top: 1px solid #ddd;
}

a {
  color: #ed6e00;
  text-decoration: underline;
}
a:hover {
  opacity: .7;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .sp {
    display: block;
  }
}

.container {
  position: relative;
  max-width: 1200px;
  margin: auto;
  padding: 0 20px;
}

.flex {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
}

#wrapper {
  position: relative;
}

/* ヘッダー
----------------------------------------------------------*/
#header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  padding: 30px 0;
}
@media screen and (max-width: 768px) {
  #header {
    padding: 15px 0;
  }
}
#header .flex {
  -webkit-box-pack: justify;
          justify-content: space-between;
}

@media screen and (max-width: 768px) {
  #header_logo {
    width: 161px;
  }
}

#header_link {
  font-size: 14px;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  #header_link {
    display: none;
  }
}
#header_link ul {
  display: -webkit-box;
  display: flex;
}
#header_link ul li {
  width: 200px;
  margin-left: 15px;
}
#header_link ul li a {
  display: block;
  padding: 10px;
  color: #000;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  border-bottom: 2px solid #000;
}
#header_link ul li a:hover {
  color: #004098;
  border-color: #004098;
  opacity: 1;
}

/* キービジュアル
----------------------------------------------------------*/
#kv {
  position: relative;
  padding-top: 25px;
  overflow: hidden;
  background: #f8f8f8;
}
@media screen and (max-width: 1200px) {
  #kv {
    padding-top: 100px;
  }
}
@media screen and (max-width: 768px) {
  #kv {
    padding-top: 70px;
  }
}
#kv:before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  width: 580px;
  height: 720px;
  background: #ed6e00;
  -webkit-transform: translateX(-50%) skewX(-30deg);
          transform: translateX(-50%) skewX(-30deg);
}
@media screen and (max-width: 768px) {
  #kv:before {
    width: 100%;
    height: 100%;
  }
}
#kv .flex {
  -webkit-box-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  #kv .flex {
    display: block;
  }
}

#kv_content {
  width: 34.82758%;
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  #kv_content {
    display: none;
  }
}

#kv_image {
  position: relative;
  width: 29.48275%;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #kv_image {
    width: auto;
    padding: 0 0 0 32vw;
  }
}
#kv_image:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: none;
  width: 36vw;
  height: 100%;
  background: url(../images/index/txt_kv02.svg) no-repeat 50% 50%;
  background-size: auto 90%;
}
@media screen and (max-width: 768px) {
  #kv_image:before {
    display: block;
  }
}

/* グローバルナビ
----------------------------------------------------------*/
#gnavi_trigger {
  position: fixed;
  top: 2px;
  right: 0;
  z-index: 200;
  display: none;
}
@media screen and (max-width: 768px) {
  #gnavi_trigger {
    display: block;
  }
}
#gnavi_trigger a {
  position: relative;
  display: block;
  width: 60px;
  height: 60px;
  padding-top: 40px;
  color: #004098;
  font-size: 10px;
  font-size: 1rem;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  line-height: 1;
}
#gnavi_trigger a:hover {
  opacity: 1;
}
#gnavi_trigger a span {
  position: absolute;
  top: 24px;
  left: 20px;
  display: block;
  width: 22px;
  height: 2px;
  background: #004098;
}
#gnavi_trigger a:before {
  content: "";
  position: absolute;
  top: 17px;
  left: 20px;
  display: block;
  width: 22px;
  height: 2px;
  background: #004098;
  -webkit-transition: all .4s;
  transition: all .4s;
}
#gnavi_trigger a:after {
  content: "";
  position: absolute;
  top: 31px;
  left: 20px;
  display: block;
  width: 22px;
  height: 2px;
  background: #004098;
  -webkit-transition: all .4s;
  transition: all .4s;
}
#gnavi_trigger a.active {
  color: #fff;
}
#gnavi_trigger a.active span {
  opacity: 0;
}
#gnavi_trigger a.active:before {
  background: #fff;
  -webkit-transform: translateY(7px) rotate(-45deg);
          transform: translateY(7px) rotate(-45deg);
}
#gnavi_trigger a.active:after {
  background: #fff;
  -webkit-transform: translateY(-7px) rotate(45deg);
          transform: translateY(-7px) rotate(45deg);
}

#gnavi {
  padding: 25px 0;
  background: #004098;
  -webkit-transition: .5s;
  transition: .5s;
}
@media screen and (max-width: 768px) {
  #gnavi {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    display: none;
    width: 100%;
    height: 100%;
    padding: 70px 0 20px;
    -webkit-transition: 0s;
    transition: 0s;
  }
}
#gnavi a {
  color: #fff;
  text-decoration: none;
}
#gnavi #gnavi_main {
  display: -webkit-box;
  display: flex;
  border-left: 1px solid #fff;
}
@media screen and (max-width: 768px) {
  #gnavi #gnavi_main {
    display: block;
    border: none;
  }
}
#gnavi #gnavi_main li {
  width: 25%;
  border-right: 1px solid #fff;
}
@media screen and (max-width: 768px) {
  #gnavi #gnavi_main li {
    width: auto;
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  }
}
#gnavi #gnavi_main li a {
  display: block;
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #gnavi #gnavi_main li a {
    padding: 15px;
  }
}
#gnavi #gnavi_sub {
  display: none;
}
@media screen and (max-width: 768px) {
  #gnavi #gnavi_sub {
    display: -webkit-box;
    display: flex;
    margin: 20px -5px 0;
  }
}
@media screen and (max-width: 768px) {
  #gnavi #gnavi_sub li {
    width: calc(50% - 10px);
    margin: 0 5px;
  }
}
#gnavi #gnavi_sub li a {
  display: block;
  padding: 10px;
  color: #fff;
  font-size: 12px;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  border-bottom: 2px solid #fff;
}

#gnavi.fixed {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  padding: 15px 0;
}
@media screen and (max-width: 768px) {
  #gnavi.fixed {
    padding: 70px 0 20px;
  }
}

/* コンテンツ
----------------------------------------------------------*/
#contents {
  padding: 80px 0 120px;
}
@media screen and (max-width: 768px) {
  #contents {
    padding: 40px 0 60px;
  }
}

.contents_margin {
  margin-top: 80px;
}
@media screen and (max-width: 768px) {
  .contents_margin {
    margin-top: 12.5vw;
  }
}

.txt_contents01 {
  position: relative;
  padding: 0 40px;
  font-size: 32px;
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .txt_contents01 {
    font-size: 24px;
    font-size: 2.4rem;
  }
}
.txt_contents01:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  z-index: -10;
  width: 100%;
  height: 1px;
  background: #ddd;
}
.txt_contents01 span.bg {
  display: inline-block;
  padding: 0 15px;
  background: #fff;
}
.txt_contents01 span.mini {
  font-size: 50%;
}

.txt_contents02 {
  position: relative;
  padding-left: 40px;
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.4;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .txt_contents02 {
    font-size: 20px;
    font-size: 2rem;
  }
}
.txt_contents02:before {
  content: "";
  position: absolute;
  top: .7em;
  left: 0;
  display: block;
  width: 30px;
  height: 2px;
  background: #ed6e00;
}

.txt_contents03 {
  font-size: 20px;
  font-size: 2rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .txt_contents03 {
    font-size: 18px;
    font-size: 1.8rem;
  }
}

.txt_contents04 {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
}

.btn_contents01 {
  display: inline-block;
  min-width: 260px;
  padding: 15px;
  color: #fff;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  background: #ed6e00;
}

/* フッター
----------------------------------------------------------*/
#footer_banner {
  display: -webkit-box;
  display: flex;
}
@media screen and (max-width: 768px) {
  #footer_banner {
    display: block;
  }
}

.footer_banner_item {
  -webkit-box-flex: 1;
          flex: 1;
}
.footer_banner_item a {
  position: relative;
  display: block;
  padding: 20px;
  overflow: hidden;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
}
.footer_banner_item a:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  -webkit-transition: .5s;
  transition: .5s;
}
.footer_banner_item a > div {
  position: relative;
  padding-top: 75%;
  border: 1px solid #fff;
}
@media screen and (max-width: 768px) {
  .footer_banner_item a > div {
    padding-top: 56.25%;
  }
}
.footer_banner_item a .footer_banner_text {
  position: absolute;
  top: 50%;
  left: 50%;
  line-height: 1.4;
  text-align: center;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.footer_banner_item a .footer_banner_arrow {
  position: absolute;
  bottom: -1px;
  right: -1px;
  width: 40px;
  height: 40px;
  background-image: url(../images/common/img_footer_arrow01.svg);
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: 40px 80px;
}
.footer_banner_item a:hover {
  opacity: 1;
}
.footer_banner_item a:hover:before {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}
.footer_banner_item a:hover .footer_banner_arrow {
  background-position: 0 bottom;
}

#footer_banner01 a:before {
  background: url(../images/common/pic_banner01.jpg) no-repeat 50% 50%;
  background-size: cover;
}
#footer_banner01 a .footer_banner_text {
  font-size: 2.38095vw;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  #footer_banner01 a .footer_banner_text {
    font-size: 28px;
    font-size: 2.8rem;
  }
}
#footer_banner01 a .footer_banner_text span {
  font-size: 50%;
}

#footer_banner02 a:before {
  background: url(../images/common/pic_banner02.jpg) no-repeat 50% 50%;
  background-size: cover;
}
#footer_banner02 a .footer_banner_text {
  font-size: 2.38095vw;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  #footer_banner02 a .footer_banner_text {
    font-size: 28px;
    font-size: 2.8rem;
  }
}
#footer_banner02 a .footer_banner_text span {
  font-size: 50%;
}

#footer_banner03 a:before {
  background: url(../images/common/pic_banner03.jpg) no-repeat 50% 50%;
  background-size: cover;
}
#footer_banner03 a .footer_banner_text {
  font-size: 1.42857vw;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  #footer_banner03 a .footer_banner_text {
    font-size: 20px;
    font-size: 2rem;
  }
}

#footer_info {
  position: relative;
  padding: 80px 0;
  color: #333;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.6;
  background: #f8f8f8;
}
@media screen and (max-width: 768px) {
  #footer_info {
    padding: 40px 0;
  }
}
#footer_info .flex {
  margin: 0 -20px;
}
@media screen and (max-width: 768px) {
  #footer_info .flex {
    display: block;
  }
}

@media screen and (max-width: 768px) {
  #footer_logo {
    width: 161px;
  }
}

#footer_info_office {
  width: calc(50% - 40px);
  margin: 40px 20px 0;
}
@media screen and (max-width: 768px) {
  #footer_info_office {
    width: auto;
  }
}
#footer_info_office p {
  margin-top: 20px;
}
#footer_info_office p:nth-child(1) {
  margin-top: 0;
}

#footer_info_navi {
  display: -webkit-box;
  display: flex;
  align-content: flex-start;
  flex-wrap: wrap;
  width: calc(50% - 40px);
  margin: 40px 20px 0;
}
@media screen and (max-width: 768px) {
  #footer_info_navi {
    display: block;
    width: auto;
  }
}
#footer_info_navi ul {
  width: 50%;
  margin: 0 0 40px 0;
}
@media screen and (max-width: 768px) {
  #footer_info_navi ul {
    width: auto;
    margin: 15px 0 0 0;
  }
}
#footer_info_navi ul li a {
  text-decoration: none;
}
#footer_info_navi ul li.arrow {
  position: relative;
  padding-left: 1.5em;
}
#footer_info_navi ul li.arrow + li {
  margin-top: 15px;
}
#footer_info_navi ul li.arrow:before {
  content: "▶";
  position: absolute;
  top: .5em;
  left: 0;
  color: #ed6e00;
  font-size: 10px;
  font-size: 1rem;
  -webkit-transform: scale(0.8);
          transform: scale(0.8);
}
#footer_info_navi ul li.arrow a {
  color: #333;
}
#footer_info_navi ul li.arrow a:hover {
  text-decoration: underline;
  opacity: 1;
}
#footer_info_navi ul li.sns {
  display: inline-block;
}
#footer_info_navi ul li.sns + li {
  margin-left: 5px;
}
#footer_info_navi ul li.sns a {
  display: block;
  width: 40px;
  height: 40px;
  color: #000;
  font-size: 20px;
  font-size: 2rem;
  letter-spacing: normal;
  line-height: 40px;
  text-align: center;
  border-radius: 100%;
}
#footer_info_navi ul li.fb a {
  background: #3c5b9b;
}
#footer_info_navi ul li.tw a {
  background: #1da1f3;
}

#footer_info_top {
  position: absolute;
  bottom: 0;
  right: 0;
}
@media screen and (max-width: 768px) {
  #footer_info_top {
    width: 40px;
  }
}

#footer_copy {
  padding: 20px 0;
  color: #999;
  font-size: 12px;
  font-size: 1.2rem;
  text-align: center;
}

/* ホーム
----------------------------------------------------------*/
body.home #kv {
  padding-top: 100px;
}
@media screen and (max-width: 768px) {
  body.home #kv {
    padding-top: 70px;
  }
}
body.home #kv .flex {
  -webkit-box-pack: justify;
          justify-content: space-between;
}
body.home #kv_content {
  width: 50%;
}
body.home #kv_image {
  width: 50%;
}
@media screen and (max-width: 768px) {
  body.home #kv_image {
    width: auto;
  }
}

.index_info {
  display: table;
  width: 100%;
  border: 1px solid #ed6e00;
}
@media screen and (max-width: 768px) {
  .index_info {
    display: block;
  }
}

.index_info_title {
  display: table-cell;
  width: 260px;
  color: #fff;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  background: #ed6e00;
}
@media screen and (max-width: 768px) {
  .index_info_title {
    display: block;
    width: auto;
    padding: 10px;
  }
}

.index_info_item {
  display: table-cell;
  padding: 15px 30px;
}
@media screen and (max-width: 768px) {
  .index_info_item {
    display: block;
    padding: 15px;
  }
}
.index_info_item .date {
  margin-right: 1em;
  color: #666;
}
@media screen and (max-width: 768px) {
  .index_info_item .date {
    display: block;
  }
}
.index_info_item a {
  color: #ed6e00;
}

.index_sns {
  margin: 0 -20px;
}
@media screen and (max-width: 768px) {
  .index_sns {
    display: block;
  }
}

.index_sns_item {
  margin-top: 80px;
  padding: 40px;
  border: 1px solid #ddd;
}
@media screen and (max-width: 768px) {
  .index_sns_item {
    width: auto;
    margin: 40px 20px 0;
    padding: 20px;
  }
}
.index_sns_item h2 {
  margin: -52px 0 40px;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .index_sns_item h2 {
    margin: -32px 0 20px;
  }
}
.index_sns_item h2 span {
  padding: 0 15px;
  background: #fff;
}
@media screen and (max-width: 768px) {
  .index_sns_item .fb-page > span,
  .index_sns_item iframe,
  .index_sns_item #twitter-widget-0 {
    height: 240px !important;
  }
}

.index_policy .row {
  -webkit-box-align: center;
          align-items: center;
}
@media screen and (max-width: 768px) {
  .index_policy .row {
    display: block;
  }
}

.index_policy_content ul {
  color: #333;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .index_policy_content ul {
    font-size: 18px;
    font-size: 1.8rem;
  }
}
.index_policy_content ul li {
  position: relative;
  margin-top: .5em;
  padding-left: 1.5em;
}
.index_policy_content ul li:before {
  content: "◎";
  position: absolute;
  top: 0;
  left: 0;
  color: #ed6e00;
}

/* 基本政策
----------------------------------------------------------*/
.txt_policy01 {
  font-family: '游明朝', 'YuMincho', "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
  font-size: 48px;
  font-size: 4.8rem;
}
@media screen and (max-width: 768px) {
  .txt_policy01 {
    font-size: 24px;
    font-size: 2.4rem;
  }
}

@media screen and (max-width: 768px) {
  .policy_item {
    margin-top: 60px;
  }
}

.policy_item_content .txt_contents02 {
  padding-left: 0;
  letter-spacing: .05em;
}
@media screen and (max-width: 768px) {
  .policy_item_content .txt_contents02 {
    padding-left: 40px;
  }
}
.policy_item_content .txt_contents02:before {
  left: -70px;
  width: 60px;
}
@media screen and (max-width: 768px) {
  .policy_item_content .txt_contents02:before {
    left: 0;
    width: 30px;
  }
}

.reverse .policy_item_content .txt_contents02 {
  text-align: right;
}
@media screen and (max-width: 768px) {
  .reverse .policy_item_content .txt_contents02 {
    text-align: left;
  }
}
.reverse .policy_item_content .txt_contents02:before {
  left: auto;
  right: -70px;
}
@media screen and (max-width: 768px) {
  .reverse .policy_item_content .txt_contents02:before {
    left: 0;
    right: auto;
  }
}

/* プロフィール
----------------------------------------------------------*/
.profile_image01 {
  margin-top: 60px;
  padding: 0 20px;
  text-align: center;
  background: #fafafa;
}
@media screen and (max-width: 768px) {
  .profile_image01 {
    margin-top: 30px;
  }
}

.profile_margin {
  margin-top: 60px;
}
.profile_margin p + p {
  margin-top: 0;
}

.tbl_profile01 {
  width: 100%;
}
.tbl_profile01 tr {
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}
.tbl_profile01 th, .tbl_profile01 td {
  padding: 15px 0;
}
@media screen and (max-width: 768px) {
  .tbl_profile01 th, .tbl_profile01 td {
    display: block;
  }
}
.tbl_profile01 th {
  width: 22.41379%;
  padding-right: 10px;
  text-align: left;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  .tbl_profile01 th {
    padding-bottom: 0;
  }
}
@media screen and (max-width: 768px) {
  .tbl_profile01 td {
    padding-top: 0;
  }
}

.dl_profile01 dt {
  margin-top: 30px;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
}
.dl_profile01 dd {
  position: relative;
  padding-left: 1.5em;
}
.dl_profile01 dd:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
  color: #ed6e00;
  font-weight: bold;
}

.dl_profile02 dt {
  margin-top: 30px;
  @incllude fontsize(18);
  font-weight: bold;
}

.ul_profile01 li {
  position: relative;
  padding-left: 1.5em;
}
.ul_profile01 li:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
  color: #ed6e00;
  font-weight: bold;
}

/* 国会へ行こう！
----------------------------------------------------------*/
.txt_kokkai01 {
  padding: 30px;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  border: 1px solid #ddd;
}
@media screen and (max-width: 768px) {
  .txt_kokkai01 {
    padding: 20px;
    text-align: left;
  }
}

.ul_kokkai01 li {
  position: relative;
  padding-left: 2em;
}
.ul_kokkai01 li span {
  position: absolute;
  top: 0;
  left: 0;
}

.kokkai_contact {
  margin-top: 20px;
  padding: 30px;
  border: 1px solid #ddd;
}
@media screen and (max-width: 768px) {
  .kokkai_contact {
    padding: 15px;
  }
}

.dl_kokkai01 dt {
  float: left;
  clear: both;
}
.dl_kokkai01 dd {
  margin-left: 7em;
}

/* 応援する
----------------------------------------------------------*/
.assist_item {
  margin-top: 30px;
  padding: 40px;
  border: 1px solid #ddd;
}
@media screen and (max-width: 768px) {
  .assist_item {
    padding: 30px;
  }
}
.assist_item .txt_contents02 {
  margin-left: -40px;
}

/* 新潟県第2選挙区について
----------------------------------------------------------*/
.dl_zone01 {
  letter-spacing: normal;
}
.dl_zone01 dt {
  margin-top: 30px;
  font-weight: bold;
}
.dl_zone01 dt:nth-child(1) {
  margin-top: 0;
}
.dl_zone01 dd {
  margin-left: 1em;
}

/* お知らせ・活動アーカイブ
----------------------------------------------------------*/
.post_single {
  padding: 40px 0;
  border-top: 1px solid #ddd;
}
@media screen and (max-width: 768px) {
  .post_single {
    padding: 20px 0;
  }
}

.post_single:nth-child(1) {
  border: none;
}

.post_single_title h2 {
  color: #ed6e00;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .post_single_title h2 {
    font-size: 20px;
    font-size: 2rem;
  }
}

.post_single_date {
  margin-top: 10px;
  color: #999;
  font-size: 14px;
  font-size: 1.4rem;
}

.post_single_image {
  margin-top: 30px;
}

.post_single_content {
  margin-top: 30px;
  word-wrap: break-word;
}
.post_single_content img {
  display: block;
  margin: 20px 0;
}

.post_single_pdf {
  margin-top: 30px;
}

.post_pager {
  padding-top: 20px;
  overflow: hidden;
  border-top: 1px solid #ddd;
}

.post_pager_prev {
  float: left;
}
.post_pager_prev:before {
  content: "＜";
  color: #ed6e00;
}

.post_pager_next {
  float: right;
}
.post_pager_next:after {
  content: "＞";
  color: #ed6e00;
}

.widget {
  font-size: 14px;
  font-size: 1.4rem;
}
.widget h3 {
  margin: 0 0 15px;
  font-size: 16px;
  font-size: 1.6rem;
}
.widget ul {
  margin: 0 0 0 1em;
  list-style-type: disc;
}
.widget ul li + li {
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  .widget .fb-page > span,
  .widget iframe,
  .widget #twitter-widget-0 {
    width: 100% !important;
  }
}

.widget + .widget {
  margin-top: 20px;
}

.widget.bg {
  padding: 20px;
  color: #333;
  background: #f8f8f8;
}

/* メルマガ
----------------------------------------------------------*/
.mail_iframe {
  -webkit-overflow-scrolling: touch;
}
@media screen and (max-width: 768px) {
  .mail_iframe {
    margin-top: 30px;
  }
}

/* お問い合わせ
----------------------------------------------------------*/
.contact_office {
  display: -webkit-box;
  display: flex;
  margin: 30px -20px 0;
}
@media screen and (max-width: 768px) {
  .contact_office {
    display: block;
  }
}

.contact_office_text {
  width: calc(50% - 40px);
  margin: 0 20px;
}
@media screen and (max-width: 768px) {
  .contact_office_text {
    width: auto;
  }
}

.contact_office_map {
  width: calc(50% - 40px);
  margin: 0 20px;
}
@media screen and (max-width: 768px) {
  .contact_office_map {
    width: auto;
    margin-top: 15px;
  }
}
.contact_office_map .map {
  position: relative;
  padding-top: 63.63636%;
}
.contact_office_map .map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*add taguchi 20260119*/
/* PCのみ改行するクラス */
.pc-br {
  display: block;
}
.sp-br {
  display: none;
}

/* 画面幅が768px以下（スマホ・タブレット）のときの指定 */
@media screen and (max-width: 768px) {
  /* PC用改行を消す */
  .pc-br {
    display: none;
  }
  /* スマホ用改行を表示させる */
  .sp-br {
    display: block;
  }
}

/* index secound img*/
.head-2-img {
  width: 80%;           /* PCは80% */
  border-radius: 12px;  /* 角丸12px */
  
  /* 【推奨】PCで幅80%にした際、画像を画面中央に寄せたい場合は以下2行を追加 */
  display: block;
  margin: 0 auto;
  margin-top: 30px;
}

/* スマホ・タブレット（768px以下）の設定 */
@media screen and (max-width: 768px) {
  .head-2-img {
    width: 90%;        /* スマホは100% */
  }
}

/**/
.sns-description{
    margin-bottom: 20px;
}

/* --- ボタンリストの親要素 --- */
.sns-button-list {
    display: flex;
    flex-direction: column; /* 縦並びにする */
    gap: 15px; /* ボタン同士の間隔 */
}

/* --- 各SNSボタンの共通設定 --- */
.sns-btn {
    display: flex;          /* 横並びにする */
    align-items: center;    /* 垂直方向の中央揃え */
    width: 100%;            /* 横幅いっぱい */
    padding: 15px;
    border: 1px solid #cccccc; /* グレーの枠線 */
    border-radius: 8px;     /* 角丸 */
    background-color: #ffffff;
    text-decoration: none;  /* リンクの下線を消す */
    color: #333333;         /* 文字色 */
    box-sizing: border-box; /* パディングを含めた幅計算 */
    transition: background-color 0.2s; /* ホバー時の動きを滑らかに */
}

/* マウスを乗せたときの色変化 */
.sns-btn:hover {
    background-color: #f5f5f5;
    opacity: 0.9;
}

/* --- アイコンエリア（画像の幅を固定して文字位置を揃える） --- */
.sns-icon-area {
    width: 80px;  /* ここを固定することで、下の文字の開始位置が揃います */
    display: flex;
    justify-content: center; /* アイコンを中央配置 */
    align-items: center;
    margin-right: 15px;      /* 画像と文字の隙間 */
    flex-shrink: 0;          /* 画面が狭くなっても画像エリアを縮めない */
}

/* 正方形アイコン（LINE, X, TikTok）のサイズ */
.icon-square {
    width: 40px;
    height: auto;
    display: block;
}

/* 横長アイコン（YouTube）のサイズ */
.icon-wide {
    width: 100%; /* 親の80pxに合わせて最大化 */
    max-width: 80px;
    height: auto;
    display: block;
}

/* --- テキスト部分 --- */
.sns-name {
    font-size: 16px;
    font-weight: bold;
    line-height: 1.4;
}

/* --- スマホ対応（画面幅が狭いとき） --- */
@media screen and (max-width: 768px) {
    .sns-btn {
        padding: 12px;
    }
    .sns-icon-area {
        width: 60px; /* スマホではアイコンエリアを少し狭く */
        margin-right: 10px;
    }
    .icon-square {
        width: 32px;
    }
    .sns-name {
        font-size: 14px;
    }
}