@charset "UTF-8";
/* ============================================================
  reset css
============================================================ */
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-style: normal; font-weight: normal; vertical-align: baseline; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }

html { overflow-y: scroll; min-height: 100%; box-sizing: border-box;}

body { min-height: 100%; -webkit-text-size-adjust: 100%; }

blockquote, q { quotes: none; }

blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }

input, textarea { margin: 0; padding: 0; }

ol, ul { list-style: none; }

table { border-collapse: collapse; border-spacing: 0; }

caption, th { text-align: left; }

object, embed { border: 0; vertical-align: bottom; outline: none; }

img { border: none; vertical-align: middle; }

a { outline: 0; display: inline-block; -webkit-tap-highlight-color: transparent; }

a img { border: none; text-decoration: none; outline: 0; }

a:focus { outline: none; }

body { font: 13px/1.231 arial, helvetica, clean, sans-serif; }

select, input, button, textarea { font: 99% arial, helvetica, clean, sans-serif; -webkit-appearance: none; appearance: none; }

table { font-size: inherit;  }

pre, code, kbd, samp, tt { font-family: monospace; line-height: 100%; }

button { border: 0px; background: transparent; margin: 0; padding: 0; font-family: inherit; outline: none; }

*, *::before, *::after {  box-sizing: inherit;}

/* clearfix */
.cf:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; }

.cf { display: inline-block; }

* html .cf { height: 1%; }

.cf { display: block; }

img {
  max-width: 100%;
}

.c-img img {
  height: auto;
}

/* End clearfix */
div, dl, dt, dd, li, ul, ol, p, h1, h2, h3, h4, h5, h6, a, strong, span { max-height: 999999px; }

strong, span { display: inline-block; }

/* ============================================================
  utility css
============================================================ */
:root {
  --space-magnification: 1;
  --primary-color: #E60013;
}
@media screen and (min-width: 768px) {
  :root {
    --space-magnification: 1.25; 
  }
}
.mt-0 {margin-top: calc( 1rem * 0 * var(--space-magnification));}
.mt-1 {margin-top: calc( 1rem * 0.25 * var(--space-magnification));}
.mt-2 {margin-top: calc( 1rem * 0.5 * var(--space-magnification));}
.mt-3 {margin-top: calc( 1rem * 0.75 * var(--space-magnification));}
.mt-4 {margin-top: calc( 1rem * 1 * var(--space-magnification));}
.mt-5 {margin-top: calc( 1rem * 1.25 * var(--space-magnification));}
.mt-6 {margin-top: calc( 1rem * 1.5 * var(--space-magnification));}
.mt-7 {margin-top: calc( 1rem * 1.75 * var(--space-magnification));}
.mt-8 {margin-top: calc( 1rem * 2 * var(--space-magnification));}
.mt-9 {margin-top: calc( 1rem * 2.25 * var(--space-magnification));}
.mt-10 {margin-top: calc( 1rem * 2.5 * var(--space-magnification));}
.mt-11 {margin-top: calc( 1rem * 2.75 * var(--space-magnification));}
.mt-12 {margin-top: calc( 1rem * 3 * var(--space-magnification));}
.mt-14 {margin-top: calc( 1rem * 3.5 * var(--space-magnification));}
.mt-16 {margin-top: calc( 1rem * 4 * var(--space-magnification));}
.mt-20 {margin-top: calc( 1rem * 5 * var(--space-magnification));}
.mt-24 {margin-top: calc( 1rem * 6 * var(--space-magnification));}
.mt-28 {margin-top: calc( 1rem * 7 * var(--space-magnification));}
.mt-32 {margin-top: calc( 1rem * 8 * var(--space-magnification));}
.mt-36 {margin-top: calc( 1rem * 9 * var(--space-magnification));}
.mt-40 {margin-top: calc( 1rem * 10 * var(--space-magnification));}
.mt-44 {margin-top: calc( 1rem * 11 * var(--space-magnification));}
.mt-48 {margin-top: calc( 1rem * 12 * var(--space-magnification));}
.mt-52 {margin-top: calc( 1rem * 13 * var(--space-magnification));}
.mt-56 {margin-top: calc( 1rem * 14 * var(--space-magnification));}
.mt-60 {margin-top: calc( 1rem * 15 * var(--space-magnification));}
.mt-64 {margin-top: calc( 1rem * 16 * var(--space-magnification));}
.mt-72 {margin-top: calc( 1rem * 18 * var(--space-magnification));}
.mt-80 {margin-top: calc( 1rem * 20 * var(--space-magnification));}
.mt-96 {margin-top: calc( 1rem * 24 * var(--space-magnification));}
.mb-0 {margin-bottom: calc( 1rem * 0 * var(--space-magnification));}
.mb-1 {margin-bottom: calc( 1rem * 0.25 * var(--space-magnification));}
.mb-2 {margin-bottom: calc( 1rem * 0.5 * var(--space-magnification));}
.mb-3 {margin-bottom: calc( 1rem * 0.75 * var(--space-magnification));}
.mb-4 {margin-bottom: calc( 1rem * 1 * var(--space-magnification));}
.mb-5 {margin-bottom: calc( 1rem * 1.25 * var(--space-magnification));}
.mb-6 {margin-bottom: calc( 1rem * 1.5 * var(--space-magnification));}
.mb-7 {margin-bottom: calc( 1rem * 1.75 * var(--space-magnification));}
.mb-8 {margin-bottom: calc( 1rem * 2 * var(--space-magnification));}
.mb-9 {margin-bottom: calc( 1rem * 2.25 * var(--space-magnification));}
.mb-10 {margin-bottom: calc( 1rem * 2.5 * var(--space-magnification));}
.mb-11 {margin-bottom: calc( 1rem * 2.75 * var(--space-magnification));}
.mb-12 {margin-bottom: calc( 1rem * 3 * var(--space-magnification));}
.mb-14 {margin-bottom: calc( 1rem * 3.5 * var(--space-magnification));}
.mb-16 {margin-bottom: calc( 1rem * 4 * var(--space-magnification));}
.mb-20 {margin-bottom: calc( 1rem * 5 * var(--space-magnification));}
.mb-24 {margin-bottom: calc( 1rem * 6 * var(--space-magnification));}
.mb-28 {margin-bottom: calc( 1rem * 7 * var(--space-magnification));}
.mb-32 {margin-bottom: calc( 1rem * 8 * var(--space-magnification));}
.mb-36 {margin-bottom: calc( 1rem * 9 * var(--space-magnification));}
.mb-40 {margin-bottom: calc( 1rem * 10 * var(--space-magnification));}
.mb-44 {margin-bottom: calc( 1rem * 11 * var(--space-magnification));}
.mb-48 {margin-bottom: calc( 1rem * 12 * var(--space-magnification));}
.mb-52 {margin-bottom: calc( 1rem * 13 * var(--space-magnification));}
.mb-56 {margin-bottom: calc( 1rem * 14 * var(--space-magnification));}
.mb-60 {margin-bottom: calc( 1rem * 15 * var(--space-magnification));}
.mb-64 {margin-bottom: calc( 1rem * 16 * var(--space-magnification));}
.mb-72 {margin-bottom: calc( 1rem * 18 * var(--space-magnification));}
.mb-80 {margin-bottom: calc( 1rem * 20 * var(--space-magnification));}
.mb-96 {margin-bottom: calc( 1rem * 24 * var(--space-magnification));}

.pt-0 {padding-top: calc( 1rem * 0 * var(--space-magnification));}
.pt-1 {padding-top: calc( 1rem * 0.25 * var(--space-magnification));}
.pt-2 {padding-top: calc( 1rem * 0.5 * var(--space-magnification));}
.pt-3 {padding-top: calc( 1rem * 0.75 * var(--space-magnification));}
.pt-4 {padding-top: calc( 1rem * 1 * var(--space-magnification));}
.pt-5 {padding-top: calc( 1rem * 1.25 * var(--space-magnification));}
.pt-6 {padding-top: calc( 1rem * 1.5 * var(--space-magnification));}
.pt-7 {padding-top: calc( 1rem * 1.75 * var(--space-magnification));}
.pt-8 {padding-top: calc( 1rem * 2 * var(--space-magnification));}
.pt-9 {padding-top: calc( 1rem * 2.25 * var(--space-magnification));}
.pt-10 {padding-top: calc( 1rem * 2.5 * var(--space-magnification));}
.pt-11 {padding-top: calc( 1rem * 2.75 * var(--space-magnification));}
.pt-12 {padding-top: calc( 1rem * 3 * var(--space-magnification));}
.pt-14 {padding-top: calc( 1rem * 3.5 * var(--space-magnification));}
.pt-16 {padding-top: calc( 1rem * 4 * var(--space-magnification));}
.pt-20 {padding-top: calc( 1rem * 5 * var(--space-magnification));}
.pt-24 {padding-top: calc( 1rem * 6 * var(--space-magnification));}
.pt-28 {padding-top: calc( 1rem * 7 * var(--space-magnification));}
.pt-32 {padding-top: calc( 1rem * 8 * var(--space-magnification));}
.pt-36 {padding-top: calc( 1rem * 9 * var(--space-magnification));}
.pt-40 {padding-top: calc( 1rem * 10 * var(--space-magnification));}
.pt-44 {padding-top: calc( 1rem * 11 * var(--space-magnification));}
.pt-48 {padding-top: calc( 1rem * 12 * var(--space-magnification));}
.pt-52 {padding-top: calc( 1rem * 13 * var(--space-magnification));}
.pt-56 {padding-top: calc( 1rem * 14 * var(--space-magnification));}
.pt-60 {padding-top: calc( 1rem * 15 * var(--space-magnification));}
.pt-64 {padding-top: calc( 1rem * 16 * var(--space-magnification));}
.pt-72 {padding-top: calc( 1rem * 18 * var(--space-magnification));}
.pt-80 {padding-top: calc( 1rem * 20 * var(--space-magnification));}
.pt-96 {padding-top: calc( 1rem * 24 * var(--space-magnification));}
.pb-0 {padding-bottom: calc( 1rem * 0 * var(--space-magnification));}
.pb-1 {padding-bottom: calc( 1rem * 0.25 * var(--space-magnification));}
.pb-2 {padding-bottom: calc( 1rem * 0.5 * var(--space-magnification));}
.pb-3 {padding-bottom: calc( 1rem * 0.75 * var(--space-magnification));}
.pb-4 {padding-bottom: calc( 1rem * 1 * var(--space-magnification));}
.pb-5 {padding-bottom: calc( 1rem * 1.25 * var(--space-magnification));}
.pb-6 {padding-bottom: calc( 1rem * 1.5 * var(--space-magnification));}
.pb-7 {padding-bottom: calc( 1rem * 1.75 * var(--space-magnification));}
.pb-8 {padding-bottom: calc( 1rem * 2 * var(--space-magnification));}
.pb-9 {padding-bottom: calc( 1rem * 2.25 * var(--space-magnification));}
.pb-10 {padding-bottom: calc( 1rem * 2.5 * var(--space-magnification));}
.pb-11 {padding-bottom: calc( 1rem * 2.75 * var(--space-magnification));}
.pb-12 {padding-bottom: calc( 1rem * 3 * var(--space-magnification));}
.pb-14 {padding-bottom: calc( 1rem * 3.5 * var(--space-magnification));}
.pb-16 {padding-bottom: calc( 1rem * 4 * var(--space-magnification));}
.pb-20 {padding-bottom: calc( 1rem * 5 * var(--space-magnification));}
.pb-24 {padding-bottom: calc( 1rem * 6 * var(--space-magnification));}
.pb-28 {padding-bottom: calc( 1rem * 7 * var(--space-magnification));}
.pb-32 {padding-bottom: calc( 1rem * 8 * var(--space-magnification));}
.pb-36 {padding-bottom: calc( 1rem * 9 * var(--space-magnification));}
.pb-40 {padding-bottom: calc( 1rem * 10 * var(--space-magnification));}
.pb-44 {padding-bottom: calc( 1rem * 11 * var(--space-magnification));}
.pb-48 {padding-bottom: calc( 1rem * 12 * var(--space-magnification));}
.pb-52 {padding-bottom: calc( 1rem * 13 * var(--space-magnification));}
.pb-56 {padding-bottom: calc( 1rem * 14 * var(--space-magnification));}
.pb-60 {padding-bottom: calc( 1rem * 15 * var(--space-magnification));}
.pb-64 {padding-bottom: calc( 1rem * 16 * var(--space-magnification));}
.pb-72 {padding-bottom: calc( 1rem * 18 * var(--space-magnification));}
.pb-80 {padding-bottom: calc( 1rem * 20 * var(--space-magnification));}
.pb-96 {padding-bottom: calc( 1rem * 24 * var(--space-magnification));}

/* ============================================================
  component css
============================================================ */
.c_tc {text-align: center !important;}
.c_tl {text-align: left !important;}
.c_tr {text-align: right !important;}
.c_fl {float: left !important;}
.c_fr {float: right !important;}
.p_fl { float: left !important; }
.p_fr { float: right !important; }

.fz-12 { font-size: 1.2rem; }
.fz-13 { font-size: 1.3rem }
.fz-14 { font-size: 1.4rem; }
.fz-15 { font-size: 1.5rem; }
.fz-16 { font-size: 1.6rem; }
.fz-18 { font-size: 1.8rem; }
.fz-20 { font-size: 2.0rem; }
.fz-24 { font-size: 2.4rem; }

.text-xs { font-size: calc(1.5rem * 0.8);} /* 12px */
.text-sm { font-size: calc(1.5rem * 0.933);} /* 13.995px */
.text-base { font-size: calc(1.5rem * 1);} /* 15px */
.text-lg { font-size: calc(1.5rem * 1.2);} /* 18px */
.text-xl { font-size: calc(1.5rem * 1.333);} /* 19.995px */
.text-2xl { font-size: calc(1.5rem * 1.6);} /* 24px */
.text-3xl { font-size: calc(1.5rem * 2);} /* 30px */
.text-4xl { font-size: calc(1.5rem * 2.4);} /* 36px */
.text-5xl { font-size: calc(1.5rem * 2.8);} /* 42px */
.text-6xl { font-size: calc(1.5rem * 3.2);} /* 48px */
.text-7xl { font-size: calc(1.5rem * 4);} /* 60px */
.text-8xl { font-size: calc(1.5rem * 4.8);} /* 72px */
.text-9xl { font-size: calc(1.5rem * 6.4);} /* 96px */

/* タイトルタグは倍率計算、PC時拡大する */
:root {
  --fz-magnification: 1;
  --page-width: 117rem;
}
@media screen and (min-width: 768px) {
  :root {
    --fz-magnification: 1.4; 
  }
}
.c_title { line-height: 1.2;}
.c_title.text-lg { font-size: calc(1.5rem * 1.2 * var(--fz-magnification) );}
.c_title.text-xl { font-size: calc(1.5rem * 1.333 * var(--fz-magnification) );}
.c_title.text-2xl { font-size: calc(1.5rem * 1.6 * var(--fz-magnification) );}
.c_title.text-3xl { font-size: calc(1.5rem * 2 * var(--fz-magnification) );}
.c_title.text-4xl { font-size: calc(1.5rem * 2.4 * var(--fz-magnification) );}
.c_title.text-5xl { font-size: calc(1.5rem * 2.8 * var(--fz-magnification) );}
.c_title.text-6xl { font-size: calc(1.5rem * 3.2 * var(--fz-magnification) );}
.c_title.text-7xl { font-size: calc(1.5rem * 4 * var(--fz-magnification) );}
.c_title.text-8xl { font-size: calc(1.5rem * 4.8 * var(--fz-magnification) );}
.c_title.text-9xl { font-size: calc(1.5rem * 6.4 * var(--fz-magnification) );}

.c_title_noto{ color: #252525; font-weight: 100;}

.c_title_category {
  display: inline-block;
  line-height: 1.2;
}
.c_title_category + .c_title {
  display: inline-block;
  font-size: calc(1.5rem * 1.2 * var(--fz-magnification) );
  font-weight: 600;
}
.c_title_category + .c_title:before {
  content: "/ ";
  margin: 0 .4em 0 0;
}

/* svg icon */
.c_icomoon {
  display: inline-block;
  width: 1em;
  height: 1em;
  stroke-width: 0;
  stroke: currentColor;
  fill: currentColor;
  vertical-align: middle;
  margin-right: 0.3em;
}

/* webfont icon */
@font-face {
  font-family: "icomoon";
  src: url("../images/common/icon/font/icomoon.eot?1kq7ia");
  src: url("../images/common/icon/font/icomoon.eot?1kq7ia#iefix")
      format("embedded-opentype"),
    url("../images/common/icon/font/icomoon.ttf?1kq7ia") format("truetype"),
    url("../images/common/icon/font/icomoon.woff?1kq7ia") format("woff"),
    url("../images/common/icon/font/icomoon.svg?1kq7ia#icomoon")
      format("svg");
  font-weight: normal;
  font-style: normal;
}

.c_linkicon_red:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e910";
  color: #e60012;
  margin-right: 10px;
}
.c_arrow_red:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e915";
  color: #e60012;
}
.c_ru {
  font-style: oblique;
  font-family: helvetica, arial, "hiragino kaku gothic pro", Monaco, Menlo,
    Consolas, "Courier New", monospace;
  font-weight: lighter;
}

/* .c_inner {
  padding: 0 20px;
  margin: 0 auto;
  max-width: 1150px;
} */
.page-width,
.c_inner {
  max-width: var(--page-width);
  margin: 0 auto;
  padding: 0 1.2rem;
}

.c_ir {
  display: block;
  text-align: left;
  text-indent: -100%;
  overflow: hidden;
}

/* PC用 */
@media screen and (min-width: 768px) {
  .c_sp {
    display: none;
  }
}

/* SP用 */
@media screen and (max-width: 767px) {
  .c_pc {
    display: none;
  }
}
.c_sec {
  margin-bottom: calc(80px * var(--space-magnification));
}

.c_head1,
.c_head1_type2,
.c_head1_type3,
.c_head1_type4,
.c_head1_type5,
.c_head1_type6 {
  margin-bottom: 50px;
}
.c_head1 img + img,
.c_head1_type2 img + img,
.c_head1_type3 img + img,
.c_head1_type4 img + img,
.c_head1_type5 img + img,
.c_head1_type6 img + img {
  display: block;
  margin-top: 10px;
  padding-left: 30px;
  background: url(../images/common/parts/slash.svg) no-repeat left center;
}

.c_head2,
.c_head2_type2 {
  margin: 0 -1.2rem 50px;
  padding: 12px 20px;
  font-size: 1.6rem;
  line-height: 1.4em;
  font-weight: bold;
  color: #e60012;
  padding-bottom: 6px;
  border-bottom: 1px solid #e60012;
  font-style: oblique;
}

.c_head2_type2 {
  padding-left: 60px;
}
.c_head2_type2:before {
  content: "Q.";
  width: 40px;
  display: inline-block;
  margin-left: -40px;
  font-style: oblique;
  letter-spacing: 3px;
}

.c_head3 {
  margin-bottom: 30px;
  padding-bottom: 10px;
  line-height: 1.4em;
  font-size: 1.5rem;
  font-weight: bold;
  border-bottom: 1px dotted #252525;
  font-style: oblique;
}

.c_head4 {
  font-size: 1.5rem;
  font-weight: bold;
  color: #e60012;
  margin-bottom: 24px;
}

.c_head5 {
  font-size: 1.5rem;
  font-weight: bold;
  color: #e60012;
  border-bottom: 1px solid #e60012;
  margin-bottom: 50px;
  padding-bottom: 12px;
}

.c_head6 {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.4em;
  margin-bottom: 10px;
}

.c_foblique {
  font-style: oblique;
  letter-spacing: 0.04em;
  font-weight: inherit;
}

.c_a:before {
  content: "A.";
  display: block;
  font-weight: bold;
  font-style: oblique;
  letter-spacing: 3px;
}
.c_a a {
  display: inline;
  color: #e60012;
  text-decoration: underline;
}

.c_notes {
  display: inline-block;
  margin-top: 20px;
  color: #999999;
  font-size: 1.3rem;
  line-height: 1.8em;
}

.c_button1,
.c_button2,
.c_button1_type2,
.c_button2_type2,
.c_button1_type3,
.c_button2_type3,
.c_button3,
.c_button7,
.c_button8,
.c_submit_type2 {
  text-decoration: none;
  color: #252525;
  font-style: oblique;
}
.c_button1 img,
.c_button2 img,
.c_button1_type2 img,
.c_button2_type2 img,
.c_button1_type3 img,
.c_button2_type3 img,
.c_button3 img,
.c_button7 img,
.c_button8 img,
.c_submit_type2 img {
  margin-bottom: 4px;
}

.c_button1,
.c_button2,
.c_button1_type2,
.c_button2_type2,
.c_button1_type3,
.c_button2_type3 {
  display: block;
  padding: 1em 3em;
  text-align: center;
  border: 2px solid #d7d7d7;
  position: relative;
  color: #252525;
  text-decoration: none;
}
.c_button1:before,
.c_button2:before,
.c_button1_type2:before,
.c_button2_type2:before,
.c_button1_type3:before,
.c_button2_type3:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  position: absolute;
  top: calc(50% - 0.4em);
  transition: .2s;
  color: #e60012;
}

.c_button1:before,
.c_button1_type2:before,
.c_button1_type3:before {
  content: "\e917";
  left: 20px;
}

.c_button2:before,
.c_button2_type2:before,
.c_button2_type3:before {
  content: "\e915";
  right: 18px;
}

.c_button1_type2,
.c_button2_type2 {
  border: 2px solid #e60012;
}

.c_button1_type3,
.c_button2_type3 {
  background: #f8f8f8;
  color: #e60012;
}

.c_button3 {
  display: block;
  padding: 0 40px;
  text-align: center;
  line-height: 96px;
  border: 2px solid #252525;
}
.c_button3:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e908";
  color: #e60012 !important;
  font-size: 1.6rem;
  margin-right: 12px;
}

.c_button4,
.c_button4_type2 {
  display: block;
  padding: 10px 10px 6px;
  text-align: center;
  border: 2px solid #252525;
  vertical-align: middle;
}
.c_button4 .number,
.c_button4 .text,
.c_button4_type2 .number,
.c_button4_type2 .text {
  display: block;
  line-height: 40px;
}
.c_button4 .number,
.c_button4_type2 .number {
  font-size: 1.9rem;
}
.c_button4 .number:before,
.c_button4_type2 .number:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  content: "\e90c";
  color: #e60012;
  margin-right: 12px;
  line-height: 1em;
}
.c_button4 .text,
.c_button4_type2 .text {
  padding: 8px 0;
  line-height: 1.2;
  font-size: 1.2rem;
}

.c_button4_type2 .number {
  line-height: 80px;
}
.c_button4_type2 .number:before {
  content: "\e927";
}

.c_button5,
.c_button5_type2 {
  display: block;
  padding: 0 20px;
  text-align: left;
  line-height: 86px;
  border: 2px solid #e60012;
  position: relative;
}
.c_button5:after,
.c_button5_type2:after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  color: #e60012;
  content: "\e915";
  position: absolute;
  right: 20px;
  line-height: 86px;
}

.c_button5_type2:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  content: "\e90c";
  color: #e60012;
  margin-right: 12px;
  line-height: 1em;
}

.c_button6 {
  margin-bottom: 0px;
  text-align: right;
}
.c_button6 a {
  position: relative;
  color: #252525;
  text-decoration: none;
}
.c_button6 a:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 2.6rem;
  content: "\e910";
  color: #e60012;
  margin-right: 12px;
  line-height: inherit;
  vertical-align: top;
}

.c_button7 {
  display: block;
  text-align: center;
  text-decoration: none;
  line-height: 96px;
  border: 2px solid #d7d7d7;
  background: #f8f8f8;
  color: #e60012;
}

button.c_button7 {
  width: 100%;
  margin-top: 50px;
}

.c_button8 {
  display: block;
  padding: 0 40px;
  text-align: center;
  line-height: 96px;
  border: 2px solid #252525;
}
.c_button8:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e926";
  color: #e60012 !important;
  font-size: 1.6rem;
  margin-right: 12px;
}

.c_back {
  margin: 0 20px calc(100px * var(--space-magnification));
}

.c_pagetop {
  text-align: center;
  padding: 40px 20px 20px;
  margin: 0px auto !important;
  line-height: 0;
  max-width: var(--page-width);
}
.c_pagetop a {
  position: relative;
  color: inherit;
  text-decoration: none;
  font-size: 1.6rem;
}
.c_pagetop a:after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  content: "\e918";
  position: absolute;
  left: 50%;
  top: -1.5em;
  margin-left: -16px;
  line-height: 1em;
  color: #e60012;
}

/* PC用 */
@media screen and (min-width: 768px) {
  .c_button1, .c_button2, .c_button1_type2, .c_button2_type2, .c_button1_type3, .c_button2_type3 {
    display: block;
    width: 384px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    border: 1px solid #d7d7d7;
    position: relative;
    color: #252525;
    font-size: 18px;
    text-decoration: none;
  }
  .c_button1 img, .c_button2 img, .c_button1_type2 img, .c_button2_type2 img, .c_button1_type3 img, .c_button2_type3 img, .c_button3 img, .c_button7 img, .c_button8 img, .c_submit img, .c_submit_type2 img { width: auto; height: 18px !important; margin-bottom: 2px; }
  .c_button1:hover, .c_button2:hover, .c_button1_type2:hover, .c_button2_type2:hover, .c_button1_type3:hover, .c_button2_type3:hover, .c_button3:hover, .c_button7:hover, .c_button8:hover, .c_submit:hover, .c_submit_type2:hover { color: #252525; }

  .c_button1:before, .c_button2:before, .c_button1_type2:before, .c_button2_type2:before, .c_button1_type3:before, .c_button2_type3:before { font-family: 'icomoon' !important; font-weight: normal !important; font-style: normal !important; text-indent: 0px; display: inline-block; vertical-align: middle; letter-spacing: 0px; line-height: initial; font-size: 24px; position: absolute; color: #e60012; line-height: 58px; 
        top: calc(50% - 29px);}
  .c_button1:hover, .c_button2:hover, .c_button1_type2:hover, .c_button2_type2:hover, .c_button1_type3:hover, .c_button2_type3:hover { border: 1px solid #e60012; }

  .c_button1:before, .c_button1_type2:before, .c_button1_type3:before { content: '\e917'; left: 18px; -moz-transition: all 200ms; -o-transition: all 200ms; -webkit-transition: all 200ms; transition: all 200ms; }
  .c_button1:hover:before, .c_button1_type2:hover:before, .c_button1_type3:hover:before { left: 12px; }

  .c_button2:before, .c_button2_type2:before, .c_button2_type3:before { content: '\e915'; right: 18px; -moz-transition: all 200ms; -o-transition: all 200ms; -webkit-transition: all 200ms; transition: all 200ms; }
  .c_button2:hover:before, .c_button2_type2:hover:before, .c_button2_type3:hover:before { right: 12px; }

  .c_button1_type2, .c_button2_type2 { border: 1px solid #252525; }

  .c_button1_type3, .c_button2_type3 { background: #f8f8f8; color: #e60012; }

  .c_button3 { display: block; width: 392px; text-align: center; font-size: 18px;line-height: 58px; border: 1px solid #252525; }
  .c_button3:before { font-family: 'icomoon' !important; font-weight: normal !important; font-style: normal !important; text-indent: 0px; display: inline-block; vertical-align: middle; letter-spacing: 0px; line-height: initial; content: '\e908'; color: #e60012 !important; margin-right: 12px; font-size: 20px; }

  .c_button4, .c_button4_type2 { display: block; width: 392px; padding: 11px 0 7px; text-align: center; font-size: 18px; line-height: 40px; border: 1px solid #252525; vertical-align: middle; }
  .c_button4 .number, .c_button4 .text, .c_button4_type2 .number, .c_button4_type2 .text { display: block; }
  .c_button4 .number, .c_button4_type2 .number { line-height: 20px; font-size: 19px; font-style: oblique; }
  .c_button4 .number:before, .c_button4_type2 .number:before { font-family: 'icomoon' !important; font-weight: normal !important; font-style: normal !important; text-indent: 0px; display: inline-block; vertical-align: middle; letter-spacing: 0px; line-height: initial; content: '\e90c'; color: #e60012 !important; display: inline-block; margin-right: 12px; font-size: 20px; vertical-align: middle; }
  .c_button4 .text, .c_button4_type2 .text { padding-top: 4px; line-height: 16px; font-size: 12px;}

  .c_button4_type2 .number:before { content: '\e927'; }

  .c_button6 { margin-bottom: 0px; }
  .c_button6 a { position: relative; color: #252525; padding-left: 18px; line-height: 1em;  }

  .c_button7 { margin: 0 auto; text-align: center; width: 400px; color: #e60012; font-size: 18px; line-height: 58px; border: 1px solid #d7d7d7; background: #f8f8f8; }
  .c_button7:hover { border: 1px solid #e60012; }

  .c_button8 { display: block; width: 392px; padding: 9px 0; text-align: center; font-size: 18px; line-height: 40px; border: 1px solid #252525; vertical-align: middle; }
  .c_button8:before { font-family: 'icomoon' !important; font-weight: normal !important; font-style: normal !important; text-indent: 0px; display: inline-block; vertical-align: middle; letter-spacing: 0px; line-height: initial; content: '\e926'; color: #e60012 !important; display: inline-block; margin-right: 12px; font-size: 20px; vertical-align: middle; margin-bottom: 2px; }

  .c_hover img { -moz-transition: all 200ms; -o-transition: all 200ms; -webkit-transition: all 200ms; transition: all 200ms; }
  .c_hover:hover { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); opacity: 0.8; }

  .c_back { margin: 150px 0 100px !important; }

  .c_pagetop { clear: both; text-align: right; padding-bottom: 30px; line-height: 17px; }
  .c_pagetop a { position: relative; padding-left: 20px; }
  .c_pagetop a img { width: 74px; }
  .c_pagetop a:before { font-family: 'icomoon' !important; font-weight: normal !important; font-style: normal !important; text-indent: 0px; display: inline-block; vertical-align: middle; letter-spacing: 0px; line-height: initial; font-size: 1.2rem; content: '\e91c'; color: #e60012; position: absolute; left: 2px; top: 50%; margin-top: -6px; -moz-transition: all 200ms; -o-transition: all 200ms; -webkit-transition: all 200ms; transition: all 200ms; }
  .c_pagetop a:hover:before { margin-top: -10px; }
  .c_pagetop a:after {display: none;}

  .c_button1:hover, .c_button2:hover, .c_button1_type2:hover, .c_button2_type2:hover, .c_button1_type3:hover, .c_button2_type3:hover { border: 1px solid #e60012; }
  .c_button1:hover:before, .c_button1_type2:hover:before, .c_button1_type3:hover:before { left: 12px; }
  .c_button2:hover:before, .c_button2_type2:hover:before, .c_button2_type3:hover:before { right: 12px; }
  .c_button7:hover { border: 1px solid #e60012; }
  .c_hover:hover { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80); opacity: 0.8; }
  .c_pagetop a:hover:before { margin-top: -10px; }
  .c_banner1 a:hover { color: #252525; }
  .c_banner1 a:hover .headbutton:after, .c_banner1 a:hover .headbutton2:after, .c_banner1 a:hover .headbutton3:after { right: -6px; }
  .c_banner2 a:hover { color: #252525; }
  .c_banner2 a:hover .headbutton:after, .c_banner2 a.headbutton:hover:after { right: -6px; }
}

.c_contact_us {
  margin-top: 50px;
}
.c_contact_us dt {
  margin-bottom: 10px;
  text-align: center;
}

.c_banner1 {
  margin-left: 20px;
  margin-right: 20px;
  margin-bottom: 100px !important;
  border: 1px solid #e60012;
}
.c_banner1 a {
  display: block;
  padding: 50px 40px;
}
.c_banner1 .headbutton,
.c_banner1 .headbutton2,
.c_banner1 .headbutton3 {
  padding-right: 46px;
  display: inline-block;
  position: relative;
  margin-bottom: 20px;
  line-height: 1;
}
.c_banner1 .headbutton:after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  color: #e60012;
  content: "\e915";
  position: absolute;
  bottom: 52px;
  right: 0px;
}
.c_banner1 .headbutton2:after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  color: #e60012;
  content: "\e915";
  position: absolute;
  bottom: 35px;
  right: 0px;
}
.c_banner1 .headbutton3:after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  color: #e60012;
  content: "\e915";
  position: absolute;
  bottom: 0px;
  right: 0px;
}
.c_banner1 .headbutton img + img {
  margin-top: 12px;
}
.c_banner1 .headbutton2 img + img {
  margin-top: 12px;
  display: block;
}
.c_banner1 .img img {
  max-width: 100%;
}
.c_banner1 .text p {
  margin: 0 0 30px;
  font-size: 2.4rem;
  line-height: 1.6;
}
.h30 {
  height: 30px !important;
}
.h26 {
  height: 26px !important;
}

.c_banner2 {
  margin-left: 20px;
  margin-right: 20px;
  margin-bottom: 100px !important;
  border: 1px solid #e60012;
}
.c_banner2 a {
  display: block;
  padding: 50px 40px;
}
.c_banner2 .headbutton {
  padding-right: 36px;
  display: block;
  position: relative;
  margin-bottom: 20px;
  line-height: 1.4;
  font-size: 1.5rem;
}
.c_banner2 .headbutton:after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  color: #252525;
  content: "\e915";
  position: absolute;
  top: 50%;
  right: -8px;
  margin-top: -16px;
}
.c_banner2 .img img {
  max-width: 100%;
}
.c_banner2 .text p {
  margin: 0 0 30px;
  font-size: 2.4rem;
  line-height: 1.6;
}

.c_list1 {
  margin-bottom: 100px;
}
.c_list1 li {
  line-height: 1.8em;
}
.c_list1 li:not(:first-of-type) {
  margin-bottom: 50px;
}
.c_list2 {
  margin-bottom: 100px;
}
.c_list2 li {
  line-height: 1.8em;
}
.c_list2 li:not(:first-of-type) {
  margin-bottom: 30px;
}

.c_list3 {
  margin-bottom: 50px;
}
.c_list3 li {
  line-height: 1.8em;
}
.c_list3 li:not(:first-of-type) {
  margin-bottom: 20px;
}

.c_listdisc,
.c_listdisc_type2 {
  padding-left: 1.4em;
  margin-bottom: 100px;
}
.c_listdisc li,
.c_listdisc_type2 li {
  list-style-type: disc;
  list-style-position: outside;
  line-height: 1.8em;
}

.c_listdecimal,
.c_listdecimal_type2 {
  padding-left: 1.6em;
  margin-bottom: 100px;
}
.c_listdecimal li,
.c_listdecimal_type2 li {
  list-style-type: decimal;
  list-style-position: outside;
  line-height: 1.8em;
}

.c_listdisc_type2 li:not(:first-of-type),
.c_listdecimal_type2 li:not(:first-of-type) {
  margin-bottom: 20px;
}

.c_listdecimal_type4 {
  margin-bottom: 100px;
}
.c_listdecimal_type4 li {
  line-height: 1.8em;
}
.c_listdecimal_type4 li dt {
  font-weight: bold;
}
.c_listdecimal_type4 li:not(:first-of-type) {
  margin-bottom: 20px;
}

.c_newslist dt .date {
  font-family: "Avenir Medium", "Avenir", "Avenir Roman", "Helvetica";
  font-style: oblique;
  display: inline-block;
  vertical-align: middle;
  font-size: 2.4rem;
}
.c_newslist dd {
  line-height: 1.8em;
}
.c_newslist li:not(:first-of-type) {
  margin-bottom: 40px;
}

.c_nav1 li {
  position: relative;
  padding-left: 40px;
}
.c_nav1 li a {
  line-height: 1.6em;
  text-indent: -38px;
}
.c_nav1 li a:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e910";
  color: #e60012;
  line-height: inherit;
  vertical-align: top;
  margin-right: 0.3em;
}
.c_nav1 li:not(:first-of-type) {
  margin-bottom: 10px;
}

.c_nav2 li {
  position: relative;
  padding-left: 40px;
}
.c_nav2 li a {
  line-height: 1.6em;
  text-indent: -38px;
}
.c_nav2 li a:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.2rem;
  content: "\e911";
  color: #e60012;
  line-height: inherit;
  vertical-align: top;
  margin-right: 0.3em;
}
.c_nav2 li:not(:first-of-type) {
  margin-bottom: 40px;
}

.c_nav3_type2 {
  margin: 0 -1.2rem;
  border-top: 1px solid #d7d7d7;
}
.c_nav3_type2 li {
  border-bottom: 1px solid #d7d7d7;
}
.c_nav3_type2 li .works-item {
  padding: 26px 70px 26px 20px;
  display: table-cell;
  width: 600px;
  vertical-align: middle;
  position: relative;
}
.c_nav3_type2 li .works-item:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.6rem;
  color: #e60012;
  content: "\e915";
  position: absolute;
  top: 50%;
  right: 32px;
  margin-top: -16px;
}

.c_nav4,
.c_nav4_type2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  position: relative;
}
.c_nav4 li,
.c_nav4_type2 li {
  display: inline-block;
  vertical-align: top;
  letter-spacing: normal;
  font-size: inherit;
}
.c_nav4 li a,
.c_nav4_type2 li a {
  display: block;
}
.c_nav4 li p,
.c_nav4 li dt,
.c_nav4_type2 li p,
.c_nav4_type2 li dt {
  margin: 0;
  padding: 1em 1em 1em 1.3em;
  position: relative;
  display: block;
  font-style: oblique;
  letter-spacing: 0.04em;
  line-height: 1.2em;
}
.c_nav4 li p.c_blank:after,
.c_nav4 li dt.c_blank:after,
.c_nav4_type2 li p.c_blank:after,
.c_nav4_type2 li dt.c_blank:after {
  margin-left: 8px;
  vertical-align: middle;
}
.c_nav4 li dl,
.c_nav4_type2 li dl {
  position: relative;
}
.c_nav4 li dl dt,
.c_nav4_type2 li dl dt {
  display: block;
  padding-bottom: 14px;
  font-style: oblique;
  letter-spacing: 0.04em;
  line-height: 1.2em;
}
.c_nav4 li dl dt.c_blank:after,
.c_nav4_type2 li dl dt.c_blank:after {
  margin-left: 8px;
  vertical-align: middle;
}
.c_nav4 li dl dd,
.c_nav4_type2 li dl dd {
  padding: 0 20px 20px;
  line-height: 1.4em;
}
.c_nav4 li p,
.c_nav4 li dt,
.c_nav4_type2 li p,
.c_nav4_type2 li dt {
  position: relative;
}
.c_nav4 li p:before,
.c_nav4 li dt:before,
.c_nav4_type2 li p:before,
.c_nav4_type2 li dt:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e910";
  color: #e60012;
  position: absolute;
  left: 16px;
  font-size: 1.2rem;
  margin-top: 0.3em;
}
@media screen and (max-width: 767px) {
  .c_nav4,
  .c_nav4_type2 {
    margin: 0 -1.2rem;
    grid-template-columns: repeat(2, 1fr);
    border-bottom: 1px solid #d7d7d7;
  }
  .c_nav4:after,
  .c_nav4_type2:after {
    content: "";
    position: absolute;
    top: 0px;
    width: 0px;
    height: 100%;
    border-left: 1px solid #d7d7d7;
    left: 50%;
  }
  .c_nav4 li,
  .c_nav4_type2 li {
    line-height: 0;
    border-bottom: 1px solid #d7d7d7;
    border-top: 1px solid #d7d7d7;
  }
  .c_nav4 li p,
  .c_nav4 li dt,
  .c_nav4_type2 li p,
  .c_nav4_type2 li dt {
    padding: 1em 1em 1em 3em;
    position: relative;
    display: block;
    font-style: oblique;
    letter-spacing: 0.04em;
    line-height: 1.2em;
  }
  .c_nav4 li p.c_blank:after,
  .c_nav4 li dt.c_blank:after,
  .c_nav4_type2 li p.c_blank:after,
  .c_nav4_type2 li dt.c_blank:after {
    margin-left: 8px;
    vertical-align: middle;
  }
}

@media screen and (min-width: 768px) {
  .c_nav4,
  .c_nav4_type2 {
      grid-template-columns: repeat(3, 1fr);
      gap: 3em;
      margin: 0;
  }
  .c_nav4:after,
  .c_nav4_type2:after {
      display: none;
  }
}

.c_tnav {
  font-size: 1.3rem;
}
.c_tnav a {
  display: block;
  padding: 14px 9px 14px 9px;
  color: #252525;
  text-decoration: none;
  position: relative;
}
.c_tnav a:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  letter-spacing: 0px;
  line-height: initial;
  vertical-align: baseline;
}
.c_tnav p {
  margin-bottom: 0;
}
.c_tnav p a:before {
  font-size: 2.4rem;
  content: "\e912";
  margin-right: 12px;
}
.c_tnav ul {
  letter-spacing: -0.4em;
  text-align: right;
}
.c_tnav ul li {
  display: inline-block;
  letter-spacing: 0px;
}
.c_tnav ul li a:before {
  font-size: 8px;
  content: "\e919";
  margin-right: 6px;
  color: #252525;
}
.c_tnav .c_foblique {
  display: none;
}

.c_pankuzu {
  margin: 0 auto;
  padding: 1em 20px;
  letter-spacing: -0.4em;
  font-size: 1.3rem;
  max-width: var(--page-width);
  width: 100%;
}
.top .c_pankuzu {
  display: none;
}
.c_pankuzu li {
  letter-spacing: 0px;
  display: inline;
  line-height: 34px;
  background: url(../images/common/parts/spacer.gif) no-repeat;
}
.c_pankuzu li a {
  color: #e60012;
  display: inline;
}
/* SP用 */
@media screen and (max-width: 767px) {
  .c_tnav {
    border-top: 1px solid #d7d7d7;
    border-bottom: 1px solid #d7d7d7;
    background: #fff;
    position: relative;
    padding: 0 20px;
    margin-top: 60px;
  }
  .c_tnav ul {
    display: flex;
    flex-wrap: nowrap; /* 折り返させない */
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; /* iOSスムーズスクロール */
    gap: 0.5rem; /* 必要に応じて余白調整 */
  }
  .c_tnav li {
    flex: 0 0 auto; /* 横幅を自動に、折り返さない */
  }
  .c_tnav a {
    display: block;
    white-space: nowrap; /* 改行しない */
  }
  .c_pankuzu {
    border-top: 1px solid #d7d7d7;
    background: #f8f8f8;
  }
  .c_pankuzu li + li:before {
    font-family: "icomoon" !important;
    font-weight: normal !important;
    font-style: normal !important;
    text-indent: 0px;
    display: inline-block;
    vertical-align: middle;
    letter-spacing: 0px;
    line-height: initial;
    font-size: 13px;
    content: "\e919";
    color: #d7d7d7;
    padding: 0 12px;
    line-height: 24px;
    vertical-align: baseline;
  }
}
/* PC用 */
@media screen and (min-width: 768px) {
  .c_pankuzu { position: absolute; top: 101px; left: 0; padding: 20px 1.2rem !important; }
  .c_pankuzu li { letter-spacing: 0px; display: inline; line-height: 1em; }
  .c_pankuzu li a { color: #e60012; display: inline; }
  .c_pankuzu li + li { position: relative; padding-left: 20px; background: url(../images/common/icon/pc/arrow4.svg) no-repeat 9px center; }
}
@media screen and (min-width: 1170px) {
  .c_pankuzu {
    left: calc(50% - (var(--page-width) / 2));
  }
}

.c_icon1 {
  display: inline-block;
  border: 1px solid #e60012;
  color: #e60012;
  font-size: 0.71429em;
  padding: 4px 10px;
  line-height: 1em;
}

.c_icon2 {
  display: inline-block;
  border: 1px solid #e60012;
  color: #e60012;
  font-weight: bold;
  font-size: 0.71429em;
  padding: 4px 10px;
  margin-left: 12px;
  line-height: 1em;
  text-indent: 0;
}

.c_blank {
  font-weight: inherit;
}
.c_blank:after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e909";
  color: #e60012 !important;
  margin-left: 8px;
  vertical-align: baseline;
}

.c_icons,
.c_icons_type2,
.c_icons_type3 {
  margin-bottom: 80px;
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
}
.c_icons th,
.c_icons_type2 th,
.c_icons_type3 th {
  font-size: 32px !important;
}
.c_icons td,
.c_icons_type2 td,
.c_icons_type3 td {
  font-size: 20px !important;
}

.c_icons_type2 th {
  font-size: 16px !important;
}

.c_icons_type3 th {
  font-size: 15px !important;
}

.c_mapArea {
  background: #dddddd;
  width: 600px;
  height: 240px;
  margin-bottom: 50px;
}
.c_mapArea iframe {
  width: 600px;
  height: 240px;
}

.c_img1 {
  margin-bottom: 100px;
}
.c_img1 img {
  width: 100%;
  height: auto;
}
.c_img1 p {
  text-align: center;
  margin: 20px 0 0;
  font-size: 2.4rem;
}

.c_img2 {
  margin: 0 -1.2rem 50px;
}
.c_img2 img {
  width: 100%;
  height: auto;
}

.c_img4 {
  margin-bottom: 50px;
}

.c_img5 .img {
  width: 100%;
}
.c_img5 .img img {
  width: 100%;
  height: auto;
  margin-bottom: 44px;
}

.c_accordionbox {
  margin: -1px -1.2rem 0;
}
.c_accordionbox .title {
  padding: 26px 80px 26px 20px;
  color: #e60012;
  border-top: 1px solid #d7d7d7;
  border-bottom: 1px solid #d7d7d7;
  position: relative;
}
.c_accordionbox .title:before,
.c_accordionbox .title:after {
  content: "";
  position: absolute;
  right: 33px;
  top: 50%;
  width: 30px;
  height: 0px;
}
.c_accordionbox .title:before {
  border-top: 2px solid #e60012;
  -moz-transition: all 300ms;
  -o-transition: all 300ms;
  -webkit-transition: all 300ms;
  transition: all 300ms;
}
.c_accordionbox .title:after {
  border-bottom: 2px solid #e60012;
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  -moz-transition: all 300ms;
  -o-transition: all 300ms;
  -webkit-transition: all 300ms;
  transition: all 300ms;
  backface-visibility: hidden;
}
.c_accordionbox .title.active:before,
.c_accordionbox .title.active:after {
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}
.c_accordionbox .inbox {
  display: none;
  padding: 50px 20px;
}
.c_accordionbox .type1 {
  padding: 0 20px;
}

.c_readbox {
  margin-bottom: 100px;
}
.c_readbox.addline {
  margin: 0 -1.2rem 50px;
  padding: 50px 20px;
  border-top: 2px solid #d7d7d7;
  border-bottom: 2px solid #d7d7d7;
}
.c_readbox .moreBtn {
  margin: 46px 0 0;
}
.c_readbox .moreBtn a {
  display: block;
  color: #e60012;
  line-height: 96px;
  text-align: center;
  border: 2px solid #d7d7d7;
  background: #f8f8f8;
  position: relative;
  text-decoration: none;
  font-style: oblique;
}
.c_readbox .moreBtn a:before,
.c_readbox .moreBtn a:after {
  content: "";
  position: absolute;
  right: 33px;
  top: 50%;
  width: 30px;
  height: 0px;
}
.c_readbox .moreBtn a:before {
  border-top: 2px solid #e60012;
  -moz-transition: all 300ms;
  -o-transition: all 300ms;
  -webkit-transition: all 300ms;
  transition: all 300ms;
}
.c_readbox .moreBtn a:after {
  border-bottom: 2px solid #e60012;
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  -moz-transition: all 300ms;
  -o-transition: all 300ms;
  -webkit-transition: all 300ms;
  transition: all 300ms;
  backface-visibility: hidden;
}
.c_readbox .moreBtn a.active:before,
.c_readbox .moreBtn a.active:after {
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}
.c_readbox .moreBtn a img {
  margin-bottom: 3px;
}
.c_readbox .moreBox {
  display: none;
  padding-bottom: 1px;
}

.c_messagebox {
  margin-bottom: 100px;
  margin: 0 -1.2rem 50px;
  padding: 50px 20px;
  border-top: 2px solid #d7d7d7;
  border-bottom: 2px solid #d7d7d7;
}

.c_browsermessage {
  margin: 40px auto;
  padding: 40px 20px;
  border: 2px solid #e60012;
  background: #ffffff;
  text-align: center;
}
.c_browsermessage dt {
  font-size: 1.5rem;
  color: #e60012;
  margin-bottom: 16px;
}
.c_browsermessage dd {
  font-size: 2.4rem;
  line-height: 1.8em;
}

.c_box1 {
  display: -webkit-flex;
  -webkit-justify-content: flex-start;
  -webkit-flex-wrap: wrap;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.c_box1 .box {
  width: 46.6%;
  display: inline-block;
  margin-top: 100px;
}
.c_box1 .box:nth-child(odd) {
  margin-right: 3.4%;
}
.c_box1 .box:nth-child(even) {
  margin-left: 3.4%;
}
.c_box1 .box:nth-child(1),
.c_box1 .box:nth-child(2) {
  margin-top: 0;
}
.c_box1 .box .c_head5,
.c_box1 .box p {
  margin-bottom: 24px;
}

.c_box2 {
  overflow: hidden;
  
}
.c_box2 .c_fl {
  margin: 10px 20px 10px 0;
}
.c_box2 .c_fr {
  margin: 10px 0 10px 20px;
}

@media screen and (min-width: 767px) {
  .c_box1, .c_box1_type2 { overflow: hidden; display: flex; flex-wrap: wrap; }
  .c_box1 .box, .c_box1_type2 .box { width: 375px; display: inline-block; }
  .c_box1 .box .c_head5, .c_box1 .box p, .c_box1_type2 .box .c_head5, .c_box1_type2 .box p { margin-bottom: 24px; }
  .c_box1 .box .c_img1, .c_box1_type2 .box .c_img1 { margin-bottom: 0; }
  .c_box1 .box .c_img1 p, .c_box1_type2 .box .c_img1 p { margin: 0; }
  .c_box1 .box .c_img1 img, .c_box1_type2 .box .c_img1 img { max-width: 100%; height: auto; }

  .c_box1 { margin: 0 -50px -50px 0; }
  .c_box1 .box { width: 375px; padding: 0 50px 50px 0; }

  .c_box2 { overflow: hidden; }
  .c_box2 .c_fl { margin: 0 60px 30px 0; }
  .c_box2 .c_fr { margin: 0 0 30px 60px; }

  .c_box3, .c_box4 { margin-bottom: 60px; overflow: hidden; display: flex; gap: 20px;}
  .c_box3 .img ul li + li, .c_box4 .img ul li + li { margin-top: 60px; }
  .c_box3 .text, .c_box4 .text { width: 486px; }
  .c_box3 .img, .c_box4 .img {
    width: 300px;
  }
  .c_box4 {
    flex-direction: row-reverse;
  }

  .c_img2 { margin: 0 0 40px; }
  .c_img2 img { width: 100%; height: auto; }

  .c_img4 { margin-bottom: 30px; }

  .c_img5 { position: relative; overflow: hidden; }
  .c_img5 .img { width: 320px; }
  .c_img5 .img img { width: 100%; height: auto; margin-bottom: 22px; }
  .c_img5 .img.w350 { width: 350px; }
  .c_img5 .text { width: 400px; }
}

.c_leftcolumn {
  margin: 0 -1.2rem;
  background: #f8f8f8;
}
.c_leftcolumn .titlelink {
  display: none;
}
.c_leftcolumn .titlelink a {
  color: inherit;
  text-decoration: none;
}
.c_leftcolumn .scnav-title {
  color: #e60012;
  padding: .3em 18px 0;
}
.c_leftcolumn .list {
  margin-right: -1px;
  overflow: hidden;
  
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 60px;
}
.c_leftcolumn .list li {
  width: 50%;
  border: 1px solid #d7d7d7;
  border-left: 0px;
}
.c_leftcolumn .list li a {
  position: relative;
  padding: 1em 16px 1em 34px;
  width: 100%;
  display: block;
  font-style: oblique;
  font-size: 1.3rem;
}
.c_leftcolumn .list li a:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e910";
  color: #e60012;
  position: absolute;
  left: 16px;
  top: 50%;
  margin-top: -0.5em;
  font-size: 0.8em;
}

.c_leftcolumn .list p {
  text-align: center;
}

.c_table1,
.c_table1_type2,
.c_table2,
.c_table3 {
  width: 100%;
  border: 1px solid #d7d7d7;
}
.c_table1 th,
.c_table1 td,
.c_table1_type2 th,
.c_table1_type2 td,
.c_table2 th,
.c_table2 td,
.c_table3 th,
.c_table3 td {
  border: 1px solid #d7d7d7;
  padding: 15px;
  vertical-align: middle;
  line-height: 1.6em;
}
.c_table1 th,
.c_table1_type2 th,
.c_table2 th,
.c_table3 th {
  background: #f8f8f8;
}

.c_table1_type2 th {
  text-align: center;
}

.c_table2 th {
  vertical-align: top;
}

.c_table3 th {
  text-align: center;
  background: none;
}
.c_table3 th,
.c_table3 td {
  padding-top: 30px;
  padding-bottom: 30px;
}

.c_input1,
.c_input1_type2 input[type="text"],
.c_input2 {
  width: 564px;
  line-height: 86px;
  border: 2px solid #ffffff;
  padding: 0 16px;
  font-size: 1.6rem;
}
.c_input1:focus,
.c_input1_type2 input[type="text"]:focus,
.c_input2:focus {
  outline: none;
}

.c_input1_type2 {
  position: relative;
}
.c_input1_type2 .clear {
  display: block;
  text-align: left;
  text-indent: -9999px;
  overflow: hidden;
  position: absolute;
  right: 30px;
  top: 50%;
  margin-top: -15px;
  width: 30px;
  height: 30px;
}
.c_input1_type2 .clear:before {
  position: absolute;
  right: 0px;
  top: 0px;
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.5rem;
  content: "\e914";
  color: #bbbbbb;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #fff;
}
.c_input1_type2.error input[type="text"] {
  border: 2px solid #e60012;
  background: #fff1f2;
}

.c_input2 {
  width: 264px;
  padding: 0 16px;
}

.c_input1.error,
.c_input2.error {
  border: 2px solid #e60012;
  background: #fff1f2;
}

.c_radio input[type="radio"],
.c_radio_type2 input[type="radio"],
.c_checkbox input[type="checkbox"],
.c_checkbox_type2 input[type="checkbox"] {
  outline: none;
  width: 28px;
  height: 28px;
  background: #fff;
  position: relative;
  vertical-align: middle;
}
.c_radio input[type="radio"]:checked:after,
.c_radio_type2 input[type="radio"]:checked:after,
.c_checkbox input[type="checkbox"]:checked:after,
.c_checkbox_type2 input[type="checkbox"]:checked:after {
  content: "";
  display: block;
  position: absolute;
}

.c_radio,
.c_radio_type2 {
  letter-spacing: -0.4em;
}
.c_radio li,
.c_radio_type2 li {
  display: inline-block;
  letter-spacing: 0;
}
.c_radio input[type="radio"],
.c_radio_type2 input[type="radio"] {
  border: 3px solid #dddddd;
  border-radius: 50%;
  margin-right: 4px;
}
.c_radio input[type="radio"]:checked,
.c_radio_type2 input[type="radio"]:checked {
  border: 3px solid #e60012;
  background: #e60012;
}
.c_radio input[type="radio"]:checked:after,
.c_radio_type2 input[type="radio"]:checked:after {
  width: 10px;
  height: 10px;
  background: #e60012;
  left: 50%;
  top: 50%;
  border-radius: 50%;
  border: 4px solid #ffffff;
  margin-left: -9px;
  margin-top: -9px;
}
.c_radio label,
.c_radio_type2 label {
  vertical-align: middle;
  font-weight: bold;
}

.c_radio li {
  margin-right: 50px;
}

.c_radio_type2 li {
  margin-right: 140px;
}

.c_checkbox,
.c_checkbox_type2 {
  margin-bottom: 70px;
}
.c_checkbox li,
.c_checkbox_type2 li {
  display: block;
  position: relative;
}
.c_checkbox li + li,
.c_checkbox_type2 li + li {
  margin-top: 40px;
}
.c_checkbox input[type="checkbox"],
.c_checkbox_type2 input[type="checkbox"] {
  position: absolute;
  left: 0px;
  top: 2px;
  background: #f8f8f8;
  border: 2px solid #c2c2c2;
  border-radius: 2px;
}
.c_checkbox input[type="checkbox"]:checked,
.c_checkbox_type2 input[type="checkbox"]:checked {
  border: 2px solid #e60012;
}
.c_checkbox input[type="checkbox"]:checked:after,
.c_checkbox_type2 input[type="checkbox"]:checked:after {
  width: 12px;
  height: 6px;
  border-bottom: 4px solid #e60012;
  border-left: 4px solid #e60012;
  left: 4px;
  top: 6px;
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.c_checkbox input[type="checkbox"] + label,
.c_checkbox_type2 input[type="checkbox"] + label {
  display: block;
  padding-left: 52px;
  font-weight: normal;
}
.c_checkbox input[type="checkbox"]:checked + label,
.c_checkbox_type2 input[type="checkbox"]:checked + label {
  color: #e60012;
}
.c_checkbox input[type="checkbox"]:checked + label .c_supbox,
.c_checkbox_type2 input[type="checkbox"]:checked + label .c_supbox {
  color: #252525;
}

.c_supbox,
.c_supbox_type2 {
  display: inline-block;
  vertical-align: top;
  margin-left: 4px;
  cursor: pointer;
  border: 1px solid #d7d7d7;
  border-radius: 50%;
  position: relative;
  -moz-transition: all 200ms;
  -o-transition: all 200ms;
  -webkit-transition: all 200ms;
  transition: all 200ms;
  width: 30px;
  height: 30px;
}
.c_supbox:before,
.c_supbox_type2:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e923";
  color: #999999;
  text-align: center;
  position: absolute;
  left: 0px;
  top: 0px;
  -moz-transition: all 200ms;
  -o-transition: all 200ms;
  -webkit-transition: all 200ms;
  transition: all 200ms;
}
.c_supbox p,
.c_supbox_type2 p {
  display: none;
  opacity: 0;
  width: 304px;
  padding: 16px;
  color: #e60012;
  border: 1px solid #e60012;
  background: #f8f8f8;
  line-height: 1.6em;
  font-size: 2.4rem;
  position: absolute;
  z-index: 100;
  top: 45px;
  left: -152px;
}
.c_supbox p:after,
.c_supbox_type2 p:after {
  content: "";
  position: absolute;
  top: -11px;
  left: 50%;
  margin-left: -8px;
  width: 16px;
  height: 11px;
  background: url(/assets/images/common/icon/pc/balloon.png) no-repeat center;
}
.c_supbox:hover,
.c_supbox_type2:hover {
  border-color: #e60012;
}
.c_supbox:hover:before,
.c_supbox_type2:hover:before {
  color: #e60012;
}
.c_supbox:hover p,
.c_supbox_type2:hover p {
  display: block;
  opacity: 1;
}

/*.c_supbox, .c_supbox_type2 { padding: 24px 0 30px; font-size: 2.4rem; }
.c_supbox p, .c_supbox_type2 p { margin: 0; }*/

.c_select,
.c_select_type2 {
  position: relative;
}
.c_select:after,
.c_select_type2:after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 1.5rem;
  content: "\e916";
  color: #e60012;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 30px;
  height: 30px;
  margin-top: -15px;
  pointer-events: none;
}
.c_select select,
.c_select_type2 select {
  width: 100%;
  height: 90px;
  border: 0px;
  padding: 0 4%;
  background: #ffffff;
  font-size: 1.6rem;
}
.c_select select:focus,
.c_select_type2 select:focus {
  outline: none;
}
.c_select.error,
.c_select_type2.error {
  border: 2px solid #e60012;
}
.c_select.error select,
.c_select_type2.error select {
  background: #fff1f2;
}

.c_select_type2 select {
  color: #e60012;
  font-weight: bold;
  background: #ffffff;
}
.c_select_type2 select option + option {
  color: #252525;
  font-weight: normal;
}

.c_textarea textarea {
  height: 278px;
  width: 564px;
  line-height: 1.8em;
  border: 2px solid #ffffff;
  padding: 16px;
  resize: vertical;
  font-size: 1.6rem;
}
.c_textarea textarea:focus {
  outline: none;
}
.c_textarea.error textarea {
  border: 2px solid #e60012;
  background: #fff1f2;
}

.c_submit,
.c_submit_type2,
.c_submit_type3,
.c_submit_type4,
.c_submit_type5 {
  border: 2px solid #252525;
  background: #ffffff;
  text-align: center;
  line-height: 86px;
  width: 100%;
  font-family: "Avenir Medium", "Avenir", "Avenir Roman", "Helvetica";
  font-style: oblique;
}
.c_submit img,
.c_submit_type2 img,
.c_submit_type3 img,
.c_submit_type4 img,
.c_submit_type5 img {
  margin-bottom: 6px;
}

.c_submit,
.c_submit_type2 {
  margin-top: 50px;
}

.c_submit_type2,
.c_submit_type3 {
  margin-top: 50px;
}
.c_submit_type2:before,
.c_submit_type3:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 36px;
  font-size: 1.28571em;
  content: "\e905";
  color: #e60012;
  margin-right: 8px;
  line-height: 1em;
}

.c_submit_type4 {
  border: 1px solid #e60012;
  line-height: 88px;
  background: #ffffff;
  width: 280px;
  margin-left: 20px;
}

.c_submit_type5 {
  border-color: #d7d7d7;
}

.c_finline {
  overflow: hidden;
  
}
.c_finline div {
  float: left;
  width: 50%;
}
.c_finline div.c_input1_type2 input[type="text"] {
  width: 264px;
  padding: 0 16px;
}

.c_attention {
  border: 4px solid #e60012;
  background: #ffffff;
  padding: 50px 30px 45px;
  margin-top: 100px;
}
.c_attention h3 {
  color: #e60012;
  text-align: center;
  font-weight: bold;
  margin-bottom: 50px;
}
.c_attention h3:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e90d";
  color: #e60012;
  font-size: 1.6rem;
  line-height: 1em;
  vertical-align: text-bottom;
  margin-right: 6px;
}
.c_attention ul {
  margin-bottom: 0;
}
.c_attention ul li {
  position: relative;
}
.c_attention ul li a {
  text-decoration: underline;
  line-height: 1.6em;
  text-decoration: none;
  color: #e60012;
  font-size: 2.4rem;
  padding-left: 40px;
  text-indent: -40px;
}
.c_attention ul li a:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  font-size: 2.6rem;
  content: "\e911";
  color: #e60012;
  width: 40px;
  line-height: inherit;
  vertical-align: top;
}
.c_attention ul li + li {
  margin-top: 34px;
}

.c_error {
  color: #e60012;
  margin-top: 4px;
  margin-bottom: 0px !important;
}

.c_error_type2 input[type="text"] {
  border: 2px solid #e60012;
  background: #fff1f2;
}
.c_error_type2 input[type="radio"] {
  background: #fff1f2;
}
.c_error_type2 input[type="radio"]:checked {
  border: 3px solid #e60012;
  background: #e60012;
}
.c_error_type2 input[type="radio"]:checked:after {
  background: #e60012;
}
.c_error_type2 input[type="checkbox"] {
  background: #fff1f2;
}

.c_form1 {
  margin: 0 -1.2rem;
  padding: 1px 20px 100px;
  background: #eeeeee;
}
.c_form1 .c_head5 {
  padding-top: 100px;
}
.c_form1 .c_icon1 {
  background: #ffffff;
  font-weight: normal;
  vertical-align: bottom;
}
.c_form1 dl dt {
  font-weight: bold;
  margin: 50px 0 26px;
}
.c_form1 .box1 {
  margin-top: 50px;
  background: #ffffff;
  padding: 40px 40px 80px;
}

@media screen and (min-width: 768px) {
  
  .c_list1 { overflow: hidden; margin-bottom: 60px; }
  .c_list1 li { width: 50%; float: left; font-size: 1.6rem; line-height: 1.8em; }

  .c_list2 { width: 400px; margin: 0 auto; }
  .c_list2 li { line-height: 1.8em; }
  .c_list2 li img { max-width: 400px; height: auto; }
  .c_list2 li + li { margin-top: 30px; }

  .c_list3 { margin-bottom: 50px; }
  .c_list3 li { line-height: 1.8em; }
  .c_list3 li + li { margin-top: 20px; }

  .c_listdisc, .c_listdisc_type2 { padding-left: 1.8em; margin-left: -0.6em; }
  .c_listdisc li, .c_listdisc_type2 li { list-style-type: disc; list-style-position: outside; line-height: 1.8em; }

  .c_listdecimal, .c_listdecimal_type2 { padding-left: 1.6em; }
  .c_listdecimal li, .c_listdecimal_type2 li { list-style-type: decimal; list-style-position: outside; line-height: 1.8em; }

  .c_listdisc_type2 li + li, .c_listdecimal_type2 li + li { margin-top: 20px; }

  .c_listdecimal_type4 { margin-bottom: 100px; }
  .c_listdecimal_type4 li { line-height: 1.8em; }
  .c_listdecimal_type4 li dt { font-weight: bold; }
  .c_listdecimal_type4 li + li { margin-top: 20px; }


  .c_nav1 { clear: both; }
  .c_nav1 li + li { margin-top: 10px; }

  .c_nav2 { overflow: hidden; margin-bottom: 70px; }
  .c_nav2 li { width: 50%; float: left; margin-bottom: 30px !important; }
  .c_nav2 li a { padding-left: 18px; }

  .c_nav3_type2 li + li { margin-top: 30px; }

  .c_nav4, .c_nav4_type2 { display: flex; flex-wrap: wrap;  }
  .c_nav4 li, .c_nav4_type2 li { width: 350px; }
  .c_nav4 li a, .c_nav4_type2 li a { display: block;  }
  .c_nav4 li .img img, .c_nav4_type2 li .img img { width: 100%; height: auto; }
  .c_nav4 li dl, .c_nav4_type2 li dl { padding: 14px 0 0; }
  .c_nav4 li dl dt, .c_nav4_type2 li dl dt { display: block; margin-bottom: 20px; font-style: oblique; line-height: 1.4em; letter-spacing: 0.04em; }
  .c_nav4 li dl dt.c_blank:after, .c_nav4_type2 li dl dt.c_blank:after { margin-left: 4px; }
  .c_nav4 li dl dd, .c_nav4_type2 li dl dd { font-size: 1.2rem; line-height: 1.4em; }
  .c_nav4 li p:before, .c_nav4 li dt:before, .c_nav4_type2 li p:before, .c_nav4_type2 li dt:before {
    left: 0;
  }

  .c_nav4 li p { margin: 14px 0 0; padding-left: 16px; line-height: 1.4em; display: block; line-height: 1.4em; font-style: oblique; letter-spacing: 0.04em; }
  .c_nav4 li p.c_blank:after { margin-left: 4px; }

}


/* ============================================================
  style
============================================================ */
:root {
  --font-body-scale: 1.0;
}
html {
  font-size: calc(var(--font-body-scale) * 62.5%);
  scroll-behavior: smooth;
}
body {
  background-color: #fff;
  font-family: "Avenir Medium", "Avenir", "Avenir Roman", "Helvetica";
  color: #000;
  font-size: 1.5em;
}
body a {
  display: inline-block;
  text-decoration: none;
  color: #252525;
}
body strong {
  font-weight: bold !important;
}
body p {
  line-height: 1.8em;
  /* margin-bottom: 50px; */
}
body p a {
  color: #e60012;
  text-decoration: underline;
}

#wrapper {
  margin: 0 auto;
}
#contents {
  padding-top: 50px;
}
@media screen and (min-width: 768px) {
  #contents {
    padding-top: 141px;
  }
}
/* 
#contents p {
  margin-block-start: 1em;
  margin-block-end: 1em;
} */

/* ============================================================
  header / footer
============================================================ */

@media screen and (max-width: 767px) {
  #header {
    background: #ffffff;
    position: relative;
    z-index: 90000;
    position: fixed;
    top: 0;
    width: 100%;
  }
  #header .c_inner {
    margin: 0px -1.2rem;
  }
  #header #nav_smenu {
    position: relative;
    z-index: 89999;
    background: #ffffff;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  #header #nav_smenu .logo a {
    padding: 0 .6em;
    line-height: 0;
  }
  #header #nav_smenu .logo a img {
    width: 100px;
    height: 17.44px;
  }
  #header #nav_smenu .nav_buttongroup {
    display: flex;
  }
  #header #nav_smenu .nav_buttongroup li {
    float: left;
    width: 60px;
    height: 60px;
  }
  #header #nav_smenu .nav_buttongroup li.hide {
    visibility: visible;
    filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
    opacity: 1;
    -moz-transition: all 200ms;
    -o-transition: all 200ms;
    -webkit-transition: all 200ms;
    transition: all 200ms;
  }
  #header #nav_smenu .nav_buttongroup li.hide.open {
    visibility: hidden;
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
    opacity: 0;
  }
  #header #nav_smenu .nav_buttongroup li .button_open {
    background: url(../images/common/gnav/menu_s.svg) no-repeat left top / cover;
    width: 60px;
    height: 60px;
    overflow: hidden;
    position: relative;
  }
  #header #nav_smenu .nav_buttongroup li .button_open span,
  #header #nav_smenu .nav_buttongroup li .button_open span:before,
  #header #nav_smenu .nav_buttongroup li .button_open span:after {
    display: block;
    width: 100%;
    height: 1px;
    background: #252525;
    -moz-transition: all 300ms;
    -o-transition: all 300ms;
    -webkit-transition: all 300ms;
    transition: all 300ms;
    backface-visibility: hidden;
  }
  #header #nav_smenu .nav_buttongroup li .button_open span {
    position: absolute;
    top: 3px;
    left: calc(50% - 9px);
    margin: 14px 0 0;
    text-align: left;
    text-indent: -9999px;
    width: 18px;
  }
  #header #nav_smenu .nav_buttongroup li .button_open span:before,
  #header #nav_smenu .nav_buttongroup li .button_open span:after {
    position: absolute;
    content: "";
  }
  #header #nav_smenu .nav_buttongroup li .button_open span:before {
    top: -6px;
  }
  #header #nav_smenu .nav_buttongroup li .button_open span:after {
    top: 6px;
  }
  #header #nav_smenu .nav_buttongroup li .button_open.selected span:before {
    -moz-transform: translate(0px, 11px) rotate(90deg);
    -ms-transform: translate(0px, 11px) rotate(90deg);
    -webkit-transform: translate(0px, 11px) rotate(90deg);
    transform: translate(0px, 11px) rotate(90deg);
    top: -11px;
  }
  #header #nav_smenu .nav_buttongroup li .button_open.selected span:after {
    -moz-transform: translate(0px, -11px) rotate(90deg);
    -ms-transform: translate(0px, -11px) rotate(90deg);
    -webkit-transform: translate(0px, -11px) rotate(90deg);
    transform: translate(0px, -11px) rotate(90deg);
    opacity: 0;
  }
  #header #nav_smenu .nav_buttongroup li .button_open.selected span {
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  #header #nav_smenu .nav_buttongroup li img {
    width: 100%;
    height: 100%;
  }
  #header #nav_sopen {
    position: absolute;
    z-index: 89998;
    padding-bottom: 50px;
    background: #ffffff;
    width: 100%;
    visibility: hidden;
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
    opacity: 0;
    -moz-transform: translateY(-40px);
    -ms-transform: translateY(-40px);
    -webkit-transform: translateY(-40px);
    transform: translateY(-40px);
    -moz-transition: all 200ms;
    -o-transition: all 200ms;
    -webkit-transition: all 200ms;
    transition: all 200ms;
  }
  #header #nav_sopen.open {
    visibility: visible;
    filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
    opacity: 1;
    -moz-transform: translateY(0px);
    -ms-transform: translateY(0px);
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
    overflow-y: scroll;
    height: calc(100vh - 60px);
  }
  #header #nav_sopen a {
    position: relative;
    padding: 1.3em 20px;
    display: block;
  }
  #header #nav_sopen .nav_main > ul {
    border-top: 1px solid #d7d7d7;
  }
  #header #nav_sopen .nav_main a {
    font-style: oblique;
    line-height: 1.4;
  }
  #header #nav_sopen .nav_main li:not(:last-child) {
    border-bottom: 1px solid #d7d7d7;
  }
  #header #nav_sopen .nav_main .drop {
    -moz-transition: all 300ms;
    -o-transition: all 300ms;
    -webkit-transition: all 300ms;
    transition: all 300ms;
  }
  #header #nav_sopen .nav_main .drop:before,
  #header #nav_sopen .nav_main .drop:after {
    content: "";
    position: absolute;
    right: 24px;
    top: 50%;
    width: 1em;
    height: 0px;
  }
  #header #nav_sopen .nav_main .drop:before {
    border-top: 1px solid #252525;
    -moz-transition: all 300ms;
    -o-transition: all 300ms;
    -webkit-transition: all 300ms;
    transition: all 300ms;
  }
  #header #nav_sopen .nav_main .drop:after {
    border-bottom: 1px solid #252525;
    -moz-transition: all 300ms;
    -o-transition: all 300ms;
    -webkit-transition: all 300ms;
    transition: all 300ms;
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    backface-visibility: hidden;
  }
  #header #nav_sopen .nav_main .drop.open {
    color: #e60012;
  }
  #header #nav_sopen .nav_main .drop.open:before,
  #header #nav_sopen .nav_main .drop.open:after {
    -moz-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
  #header #nav_sopen .nav_main .dropbox {
    display: none;
    font-size: 0.85714em;
    border-top: 1px solid #d7d7d7;
    background: #f8f8f8;
    padding: 0 3em;
  }
  #header #nav_sopen .nav_main .dropbox .link {
    padding: 1em 0;
    border-top: 1px solid #fff;
  }
  #header #nav_sopen .nav_main .dropbox li a,
  #header #nav_sopen .nav_main .dropbox dd a {
    position: relative;
    display: flex;
    align-items: center;
  }
  #header #nav_sopen .nav_main .dropbox li a .c_blank,
  #header #nav_sopen .nav_main .dropbox dd a .c_blank {
    font-style: oblique;
  }
  #header #nav_sopen .nav_main .dropbox li {
    border-top: 1px solid #fff;
  }
  #header #nav_sopen .nav_main .dropbox li a {
    padding: 1em 0;
  }
  #header #nav_sopen .nav_main .dropbox dd a {
    padding: 1em 1em;
  }
  #header #nav_sopen .nav_main .nav2 .dropbox li {
    border: 0px;
  }
  #header #nav_sopen .nav_main .nav2 dl {
    border-top: 1px solid #fff;
  }
  #header #nav_sopen .nav_main .nav2 dl dt {
    padding: 1em 0;
    font-style: oblique;
  }
  #header #nav_sopen .nav_main .nav5 .dropbox li .c_blank {
    line-height: 1.4em;
    display: inline-block;
    vertical-align: middle;
  }
  #header #nav_sopen .nav_main .nav5 .dropbox li a {
    display: table;
    width: 100%;
    box-sizing: border-box;
  }
  #header #nav_sopen .nav_main .nav5 .dropbox li a:before {
    display: table-cell;
    vertical-align: middle;
    margin-right: 0;
    padding-right: 16px;
  }
  #header #nav_sopen .nav_main .nav5 .dropbox li .text {
    display: table-cell;
    width: 100%;
  }
  #header #nav_sopen .button_close {
    margin: 30px 17px 0;
    border: 1px solid #252525;
    display: block;
  }
  #header #nav_language_pc {
    display: none;
  }

  #header_overlay {
    position: fixed;
    width: 100%;
    height: 100vh;
    left: 0px;
    top: 0px;
    background: #fff;
    z-index: 80000;
    visibility: hidden;
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
    opacity: 0;
    -moz-transition: all 200ms;
    -o-transition: all 200ms;
    -webkit-transition: all 200ms;
    transition: all 200ms;
  }
  #header_overlay.open {
    visibility: visible;
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
    opacity: 0.8;
  }
}

@media screen and (min-width: 768px) {
  .c_tnav {
    background: #fff;
    position: fixed;
    padding: 0 20px;
    width: 100%;
    z-index: 2000;
  }
  #header { background: #ffffff; position: fixed; left: 0; top: 44px; width: 100%; z-index: 2000; }
  #header .c_inner { position: relative; background: #ffffff; display: flex; justify-content: space-between;}
  #header #nav_smenu .logo { margin: 0 14px 0 0; }
  #header #nav_smenu .logo a { padding: 16px 0 21px; width: 130px; height: 23px; display: block; }
  #header #nav_smenu .logo a img { display: block;}
  #header #nav_smenu .nav_buttongroup { display: none; }
  #header .nav_main > ul {display: flex; gap: 50px;}
  #header .nav_main > ul > li > a { color: #252525; padding: 0; font-size: 1.7rem; line-height: 60px; position: relative; display: block; white-space: nowrap; }
  #header .nav_main > ul > li > a:after { content: ''; display: block; position: absolute; height: 1px; width: 0px; background: #252525; bottom: 16px; left: 50%; -moz-transition: all 200ms; -o-transition: all 200ms; -webkit-transition: all 200ms; transition: all 200ms; }
  #header .nav_main > ul > li > a.current:after,
  #header .nav_main > ul > li > a:hover:after { left: 0; width: 100%; }
  #header .nav_main > ul > li .dropbox { visibility: hidden; opacity: 0; z-index: 1; position: absolute; top: 60px; padding: 30px; font-size: 0.85714em; border: 1px solid #252525; background: #ffffff; -moz-transition: all 200ms ease; -o-transition: all 200ms ease; -webkit-transition: all 200ms ease; transition: all 200ms ease; }
  #header .nav_main > ul > li .dropbox:before, #header .nav_main > ul > li .dropbox:after { content: ''; position: absolute; left: 50%; margin-left: -8px; width: 0; height: 0; z-index: 2010; border: 6px solid transparent; }
  #header .nav_main > ul > li .dropbox:before { top: -14px; border-bottom: 8px solid #252525; }
  #header .nav_main > ul > li .dropbox:after { top: -12px; border-bottom: 8px solid #fff; }
  #header .nav_main > ul > li .dropbox li + li { margin-top: 10px; }
  #header .nav_main > ul > li .dropbox li a { display: flex; padding: 2px 0 2px 0; font-style: oblique; }
  #header .nav_main > ul > li .dropbox li a span { display: inline-block; }
  #header .nav_main > ul > li:hover { -moz-transition: all 500ms ease; -o-transition: all 500ms ease; -webkit-transition: all 500ms ease; transition: all 500ms ease; }
  #header .nav_main > ul > li:hover .dropbox { visibility: visible; opacity: 1; }
  #header .nav_main > ul > li.nav2 .dropbox { margin-left: -13em; }
  #header .nav_main > ul > li.nav2 .dropbox dt { font-weight: inherit; font-style: oblique; margin-bottom: 6px; font-size: 1.2em; }
  #header .nav_main > ul > li.nav2 .dropbox dd ul { margin-bottom: 8px; padding-left: 14px; }
  #header .nav_main > ul > li.nav3 .dropbox { margin-left: -5em; }
  #header .nav_main > ul > li.nav4 .dropbox { margin-left: -4em; }
  #header .nav_main > ul > li.nav5 .dropbox { margin-left: -78px; width: 310px; }
  #header .nav_main > ul > li.nav6 .dropbox { margin-left: -10em; }
  #header .nav_main > ul > li.nav7 .dropbox { width: 18em; right: 10px; }
  #header .nav_main > ul > li.nav7 .dropbox:before, #header .nav_main > ul > li.nav7 .dropbox:after { left: 86%; }
  #header .nav_sub { display: none; }
  #header #nav_language_pc { background: #fff; }
  #header #nav_language_pc dl { max-width: 1150px; margin: 0 auto; padding: 20px 20px 2px; text-align: right; }
  #header #nav_language_pc dl dt, #header #nav_language_pc dl dd, #header #nav_language_pc dl li { display: inline-block; letter-spacing: -0.4em; height: 19px; vertical-align: middle; }
  #header #nav_language_pc dl dt { padding-right: 12px; line-height: 19px; }
  #header #nav_language_pc dl dd { padding-left: 16px; background: url(../images/common/icon/pc/dot1.svg) no-repeat left center; }
  #header #nav_language_pc dl dd li + li { padding-left: 20px; }
  #header #nav_language_pc dl dd a { padding: 2px 0 2px 18px; line-height: 14px; background: url(../images/common/icon/pc/arrow2.svg) no-repeat left center; }
  #header #nav_language_pc dl dd a .text { position: relative; display: inline-block; }
  #header #nav_language_pc dl dd a .text:before { content: ''; position: absolute; left: 0px; bottom: -2px; display: block; width: 100%; height: 1px; background: #fff; }
  #header #nav_language_pc dl dd a:after { margin-bottom: -1px; }
  #header #nav_language_pc dl dd a:hover .text:before { background: #e60012; }
  #header .nav_main > ul > li.nav2 .dropbox:before,
  #header .nav_main > ul > li.nav2 .dropbox:after {
    left: 26%;
  }
  #header .nav_main > ul > li.nav2 .dropbox {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  
  #header .nav_main > ul > li.nav2 .dropbox dl:nth-of-type(2) {
    grid-row: 2;
  }
  #header .nav_main > ul > li.nav2 .dropbox dl:nth-of-type(3) {
    grid-row: 1 / 3;
  }

  /* 簡体語版 */
  html[lang="zh-CN"] #header .nav_main > ul > li.nav2 .dropbox {
    margin-left: -15em;
  }
  html[lang="zh-CN"] #header .nav_main > ul > li.nav4 .dropbox {
    margin-left: -7em;
  }
  html[lang="zh-CN"] #header .nav_main > ul > li.nav5 .dropbox {
    margin-left: -9em;
  }
  html[lang="zh-CN"] #header .nav_main > ul > li.nav6 .dropbox {
    margin-left: -6em;
  }
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
  #nav_sopen {
    overflow-x: scroll;
  }
}

.c_linkicon_gray:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e915";
  color: #252525;
  position: absolute;
  right: 0;
}
.linkicon_red a {
    display: flex;
    align-items: center;
}
.linkicon_red a:before {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e910";
  color: #e60012;
  margin-right: 10px;
}

@media screen and (max-width: 767px) {
  #footer {
    background: #f8f8f8;
    padding: 0 0 50px;
  }
  #footer .c_inner {
    margin: 0;
    padding: 0 0;
  }
  #footer .nav_box1 {
    display: none;
  }
  #footer .bottom {
    clear: both;
    position: relative;
    display: flex;
    gap: 1em;
    padding: 54px 20px 0;
  }
  #footer .bottom .logo {
    right: 15px;
    bottom: 6px;
    margin-bottom: 0px;
    line-height: 0;
    height: 28px;
  }
  #footer .bottom .logo img {
    width: 161px;
    height: 28px;
  }
  #footer .bottom .copyright {
    margin-bottom: 0px;
  }

  /* sp用サブリンク（ヘッダーフッター共用） */
  .nav_sub dl dt {
    display: none;
  }
  .nav_sub .button {
    overflow: hidden;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    border-top: 1px solid #d7d7d7;
  }
  .nav_sub .button li {
    border-bottom: 1px solid #d7d7d7;
  }
  .nav_sub .button li:nth-of-type(odd) {
    border-right: 1px solid #d7d7d7;
  }
  .nav_sub .button li a {
    padding: 0.9em 0 .9em 1.6em;
    font-size: 1.3rem;
    height: 100%;
    align-items: center;
  }
  .nav_sub .button li a span {
    display: inline;
  }
  .social {
    margin-bottom: -1px;
  }
  .social dd a {
    font-style: oblique;
  }
  .social a {
    display: flex;
    align-items: center;
    gap: 0.5em;
  }
}
@media screen and (min-width: 768px) {
  #footer { background: #f8f8f8; padding: 0 0 46px; font-size: 1.3rem; }
  #footer .c_inner { overflow: hidden; position: relative; padding-top: 50px; display: flex; }
  #footer .c_blank:after { margin-left: 0.2em; }
  #footer .nav_box1 {
    display: grid;
    grid-template-columns: 1fr 300px 250px;
    gap: 30px;
  }
  #footer .nav_box1 dt, #footer .nav_sub dt { font-weight: bold; margin-bottom: 20px; }
  #footer .nav_box1 dt a, #footer .nav_sub dt a { font-weight: bold; }
  #footer .nav_box1 dd a, #footer .nav_sub dd a { font-style: oblique; }
  #footer .nav_box1 dl { display: inline-block; vertical-align: top;}
  #footer .nav_box1 dd p { font-weight: 900; margin-bottom: 8px; }
  #footer .nav_box1 dd p .c_foblique { font-size: 13px; font-size: 0.92857em; }
  #footer .nav_box1 dd dt { font-weight: inherit; font-style: oblique; margin-bottom: 6px; }
  #footer .nav_box1 dd dd ul { margin-bottom: 8px; padding-left: 14px; }
  #footer .nav_box1 dd + dd { margin-top: 40px; }
  #footer .nav_box1 li + li { margin-top: 8px; }
  #footer .nav_box1 .mt { margin-top: 48px; }
  #footer .nav_box1 .information { width: 300px; }
  #footer .nav_box1 dl dl {
    margin-bottom: 1em;
  }
  #footer .nav_sub { margin-bottom: 70px; }
  #footer .nav_sub .social { margin-bottom: 48px; }
  #footer .nav_sub .social dd a { font-style: oblique; }
  #footer .nav_sub .button li + li { margin-top: 10px; }
  #footer .nav_sub .button a { display: block; line-height: 28px; font-style: normal; text-align: center; width: 198px; border: 1px solid #252525; }
  #footer .nav_sub .button a:hover { border: 1px solid #e60012; }
  #footer .nav_sub .button a.c_blank:after { line-height: 28px; }
  #footer .bottom { position: absolute; right: 0px; bottom: 0px; width: 400px; padding-bottom: 30px; }
  #footer .bottom p { margin-bottom: 0px; }
  #footer .bottom .copyright { position: absolute; right: 114px; bottom: 0px; }
  #footer .bottom .copyright img { height: 12px; width: 222px; vertical-align: bottom; }
  #footer .bottom .logo { position: absolute; right: 0px; bottom: 2px; line-height: 0; }
  #footer .bottom .logo img { width: 100px; height: 17px; }
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
  #footer .c_inner {
    flex-direction: column;
    gap: 5em;
  }
  .nav_sub {
    display: flex;
    gap: 4em;
  }
}

#newslist p a[target="_blank"]::after,
#news_list p a[target="_blank"]::after {
  font-family: "icomoon" !important;
  font-weight: normal !important;
  font-style: normal !important;
  text-indent: 0px;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0px;
  line-height: initial;
  content: "\e909";
  font-size: 2.6rem;
  line-height: 1em;
  color: #e60012 !important;
  margin-left: 8px;
  vertical-align: baseline;
}

@media screen and (max-width: 767px) {
  .inc_youtube {
    width: 100%;
    height: calc((100vw - 40px) * 0.58);
  }
}

/* swiper slider */
.swiper-container {
  width: 100%;
  overflow: hidden;
}
.swiper {
  width: 100%;
  max-width: 1170px;
  height: auto;
  overflow: visible !important;
}
.swiper-pagination {
  position: relative !important;
  text-align: right !important;
  bottom: 0 !important;
  margin: 1.3em 0 3em;
}
.swiper-pagination-bullet {
  background-color: #e60012 !important;
  margin: 0 .5em !important;
}
.swiper-button-next, .swiper-button-prev {
  color: #fff !important;
}
.swiper-button-next:after, .swiper-button-prev:after {
  font-size: 1.8em !important;
}
@media screen and (max-width: 1169px) {
  .swiper {
    max-width: 100%;
    width: 100%;
  }
}

@media screen and (min-width: 767px) {
  .c_columns_grid {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 40px;
  }
  .c_rightcolumn {
    grid-column: 2;
    grid-row: 1;
  }
  .c_leftcolumn {
    grid-column: 1;
    grid-row: 1;
    margin: 0;
    background-color: transparent;
  }
  .c_leftcolumn .titlelink {
    display: block;
  }
  .c_leftcolumn .titlelink a {
    display: block;
    padding: 0 18px;
    line-height: 58px;
    position: relative;
  }
  .c_leftcolumn .list, .c_leftcolumn .list_type2 {
    display: block;
    padding: 24px 18px;
    margin-bottom: 0;
  }
  .c_leftcolumn .list li, .c_leftcolumn .list_type2 li {
    width: 100%;
    border: none;
  }
  .c_leftcolumn .list p, .c_leftcolumn .list_type2 p {
    text-align: left;
  }
  .c_leftcolumn .current a {
    color: #e60012;
  }
  .sticky-wrapper {
    position: sticky;
    top: 104px;
    border: 1px solid #d7d7d7;
  }
  .c_leftcolumn .titlelink {
    border-bottom: 1px solid #d7d7d7;
  }
  .c_leftcolumn .titlelink a:before { font-family: 'icomoon' !important; font-weight: normal !important; font-style: normal !important; text-indent: 0px; display: inline-block; vertical-align: middle; letter-spacing: 0px; line-height: initial; font-size: 24px; color: #252525; line-height: 1em; content: '\e915'; position: absolute; top: 50%; margin-top: -12px; right: 14px; -moz-transition: all 200ms; -o-transition: all 200ms; -webkit-transition: all 200ms; transition: all 200ms; }
  .c_leftcolumn .titlelink a:hover:before { right: 8px; }
  .scroll-y .list {
    overflow-y: scroll;
    height: calc(100vh - 200px);
    margin-right: 1px;
    scrollbar-width: thin;
  }
  .scroll-y .list::-webkit-scrollbar {
    width: 8px; /* Chrome, Safari用: お好みで4px～8px程度に */
    background: #fff;
  }
  .scroll-y .list::-webkit-scrollbar-thumb {
    background: #5a5a5a;
    border-radius: 8px;
  }
}

#newslist a {
  color: #252525;
}

/* 一時処理 */
#nav_sopen .nav2 dt,
#footer .nav_box1 dl:first-of-type dl dt {
  display: none;
}