@charset "UTF-8";
@font-face {
  font-family: Montserrat;
  font-style: normal;
  font-weight: 400;
  src: local("Montserrat-Regular"), url(https://fonts.gstatic.com/s/montserrat/v7/zhcz-_WihjSQC0oHJ9TCYC3USBnSvpkopQaUR-2r7iU.ttf) format("truetype");
}
a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, font, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, meter, nav, object, ol, output, p, pre, progress, q, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: 0 0;
  box-sizing: border-box;
}

body {
  line-height: 1;
}

article, aside, blockquote, dialog, figure, footer, header, hgroup, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

ol {
  list-style: decimal;
}

ul {
  list-style: disc;
}
ul ul {
  list-style: circle;
}

blockquote, q {
  quotes: none;
}

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

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

ins {
  text-decoration: underline;
}

del {
  text-decoration: line-through;
}

mark {
  background: 0 0;
}

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

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

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

button {
  padding: 0 !important;
  margin: 0 !important;
}

input[type=submit], input[type=button] {
  padding: 0 !important;
  margin: 0 !important;
}

a img, input, select {
  vertical-align: middle;
}

.floatRight {
  float: right;
  text-align: left;
}

.floatLeft {
  float: left;
  text-align: left;
}

.center {
  margin: 0 auto;
  text-align: center;
}

.img-circle {
  border-radius: 50%;
}

.img-responsive {
  display: block;
  width: 100%;
  height: auto;
}

.margin0 {
  margin: 0;
}

.padding0 {
  padding: 0;
}

#main:after, .clearfix:after {
  display: block;
  clear: both;
  content: '';
}

body {
  font-family: YuGothic,'游ゴシック Medium','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro',Osaka,'メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
  -webkit-text-size-adjust: 100%;
}

.serif {
  font-family: YuMincho, "游明朝", serif !important;
}

.fz-small {
  font-size: 85%;
}

.fz14 {
  font-size: 14px;
  font-size: 1rem;
}

.fz20 {
  font-size: 20px;
  font-size: 1.428571428571429rem;
}

.lh14 {
  line-height: 1.4em;
}

@font-face {
  font-family: hrsg;
  src: url(../fonts/hrsg.eot?o7tb6t);
  src: url(../fonts/hrsg.eot?#iefixo7tb6t) format("embedded-opentype"), url(../fonts/hrsg.ttf?o7tb6t) format("truetype"), url(../fonts/hrsg.woff?o7tb6t) format("woff"), url(../fonts/hrsg.svg?o7tb6t#hrsg) format("svg");
  font-weight: 400;
  font-style: normal;
}
.item a:before, [class*=" icon-"] i, [class^=icon-] i {
  font-family: hrsg;
  speak: none;
  font-style: normal;
  font-weight: 400;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-search-plus:before {
  content: "\f00e";
}

.icon-arrow-up i:before {
  content: "\f062";
}

.icon-bars i:before {
  content: "\f0c9";
}

.container {
  margin-right: auto;
  margin-left: auto;
  padding-left: 15px;
  padding-right: 15px;
  max-width: 544px;
}
.container:after, .container:before {
  content: " ";
  display: table;
}
.container:after {
  clear: both;
}

@media (min-width: 768px) {
  .container {
    width: 750px;
    max-width: none;
  }
}
@media (min-width: 992px) {
  .container {
    width: 970px;
  }
}
@media (min-width: 1200px) {
  .container {
    width: 1170px;
  }
}
.container-fluid {
  margin-right: auto;
  margin-left: auto;
  padding-left: 15px;
  padding-right: 15px;
}
.container-fluid:after, .container-fluid:before {
  content: " ";
  display: table;
}
.container-fluid:after {
  clear: both;
}

.row {
  margin-left: -15px;
  margin-right: -15px;
}
.row:after, .row:before {
  content: " ";
  display: table;
}
.row:after {
  clear: both;
}

.col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-xs-1, .col-xs-10, .col-xs-11, .col-xs-12, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9 {
  position: relative;
  min-height: 1px;
  padding-left: 15px;
  padding-right: 15px;
}

.col-xs-1, .col-xs-10, .col-xs-11, .col-xs-12, .col-xs-2, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9 {
  float: left;
}

.col-xs-1 {
  width: 8.33333%;
}

.col-xs-2 {
  width: 16.66667%;
}

.col-xs-3 {
  width: 25%;
}

.col-xs-4 {
  width: 33.33333%;
}

.col-xs-5 {
  width: 41.66667%;
}

.col-xs-6 {
  width: 50%;
}

.col-xs-7 {
  width: 58.33333%;
}

.col-xs-8 {
  width: 66.66667%;
}

.col-xs-9 {
  width: 75%;
}

.col-xs-10 {
  width: 83.33333%;
}

.col-xs-11 {
  width: 91.66667%;
}

.col-xs-12 {
  width: 100%;
}

.col-xs-pull-0 {
  right: auto;
}

.col-xs-pull-1 {
  right: 8.33333%;
}

.col-xs-pull-2 {
  right: 16.66667%;
}

.col-xs-pull-3 {
  right: 25%;
}

.col-xs-pull-4 {
  right: 33.33333%;
}

.col-xs-pull-5 {
  right: 41.66667%;
}

.col-xs-pull-6 {
  right: 50%;
}

.col-xs-pull-7 {
  right: 58.33333%;
}

.col-xs-pull-8 {
  right: 66.66667%;
}

.col-xs-pull-9 {
  right: 75%;
}

.col-xs-pull-10 {
  right: 83.33333%;
}

.col-xs-pull-11 {
  right: 91.66667%;
}

.col-xs-pull-12 {
  right: 100%;
}

.col-xs-push-0 {
  left: auto;
}

.col-xs-push-1 {
  left: 8.33333%;
}

.col-xs-push-2 {
  left: 16.66667%;
}

.col-xs-push-3 {
  left: 25%;
}

.col-xs-push-4 {
  left: 33.33333%;
}

.col-xs-push-5 {
  left: 41.66667%;
}

.col-xs-push-6 {
  left: 50%;
}

.col-xs-push-7 {
  left: 58.33333%;
}

.col-xs-push-8 {
  left: 66.66667%;
}

.col-xs-push-9 {
  left: 75%;
}

.col-xs-push-10 {
  left: 83.33333%;
}

.col-xs-push-11 {
  left: 91.66667%;
}

.col-xs-push-12 {
  left: 100%;
}

.col-xs-offset-0 {
  margin-left: 0;
}

.col-xs-offset-1 {
  margin-left: 8.33333%;
}

.col-xs-offset-2 {
  margin-left: 16.66667%;
}

.col-xs-offset-3 {
  margin-left: 25%;
}

.col-xs-offset-4 {
  margin-left: 33.33333%;
}

.col-xs-offset-5 {
  margin-left: 41.66667%;
}

.col-xs-offset-6 {
  margin-left: 50%;
}

.col-xs-offset-7 {
  margin-left: 58.33333%;
}

.col-xs-offset-8 {
  margin-left: 66.66667%;
}

.col-xs-offset-9 {
  margin-left: 75%;
}

.col-xs-offset-10 {
  margin-left: 83.33333%;
}

.col-xs-offset-11 {
  margin-left: 91.66667%;
}

.col-xs-offset-12 {
  margin-left: 100%;
}

@media (min-width: 768px) {
  .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9 {
    float: left;
  }

  .col-sm-1 {
    width: 8.33333%;
  }

  .col-sm-2 {
    width: 16.66667%;
  }

  .col-sm-3 {
    width: 25%;
  }

  .col-sm-4 {
    width: 33.33333%;
  }

  .col-sm-5 {
    width: 41.66667%;
  }

  .col-sm-6 {
    width: 50%;
  }

  .col-sm-7 {
    width: 58.33333%;
  }

  .col-sm-8 {
    width: 66.66667%;
  }

  .col-sm-9 {
    width: 75%;
  }

  .col-sm-10 {
    width: 83.33333%;
  }

  .col-sm-11 {
    width: 91.66667%;
  }

  .col-sm-12 {
    width: 100%;
  }

  .col-sm-pull-0 {
    right: auto;
  }

  .col-sm-pull-1 {
    right: 8.33333%;
  }

  .col-sm-pull-2 {
    right: 16.66667%;
  }

  .col-sm-pull-3 {
    right: 25%;
  }

  .col-sm-pull-4 {
    right: 33.33333%;
  }

  .col-sm-pull-5 {
    right: 41.66667%;
  }

  .col-sm-pull-6 {
    right: 50%;
  }

  .col-sm-pull-7 {
    right: 58.33333%;
  }

  .col-sm-pull-8 {
    right: 66.66667%;
  }

  .col-sm-pull-9 {
    right: 75%;
  }

  .col-sm-pull-10 {
    right: 83.33333%;
  }

  .col-sm-pull-11 {
    right: 91.66667%;
  }

  .col-sm-pull-12 {
    right: 100%;
  }

  .col-sm-push-0 {
    left: auto;
  }

  .col-sm-push-1 {
    left: 8.33333%;
  }

  .col-sm-push-2 {
    left: 16.66667%;
  }

  .col-sm-push-3 {
    left: 25%;
  }

  .col-sm-push-4 {
    left: 33.33333%;
  }

  .col-sm-push-5 {
    left: 41.66667%;
  }

  .col-sm-push-6 {
    left: 50%;
  }

  .col-sm-push-7 {
    left: 58.33333%;
  }

  .col-sm-push-8 {
    left: 66.66667%;
  }

  .col-sm-push-9 {
    left: 75%;
  }

  .col-sm-push-10 {
    left: 83.33333%;
  }

  .col-sm-push-11 {
    left: 91.66667%;
  }

  .col-sm-push-12 {
    left: 100%;
  }

  .col-sm-offset-0 {
    margin-left: 0;
  }

  .col-sm-offset-1 {
    margin-left: 8.33333%;
  }

  .col-sm-offset-2 {
    margin-left: 16.66667%;
  }

  .col-sm-offset-3 {
    margin-left: 25%;
  }

  .col-sm-offset-4 {
    margin-left: 33.33333%;
  }

  .col-sm-offset-5 {
    margin-left: 41.66667%;
  }

  .col-sm-offset-6 {
    margin-left: 50%;
  }

  .col-sm-offset-7 {
    margin-left: 58.33333%;
  }

  .col-sm-offset-8 {
    margin-left: 66.66667%;
  }

  .col-sm-offset-9 {
    margin-left: 75%;
  }

  .col-sm-offset-10 {
    margin-left: 83.33333%;
  }

  .col-sm-offset-11 {
    margin-left: 91.66667%;
  }

  .col-sm-offset-12 {
    margin-left: 100%;
  }
}
@media (min-width: 992px) {
  .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9 {
    float: left;
  }

  .col-md-1 {
    width: 8.33333%;
  }

  .col-md-2 {
    width: 16.66667%;
  }

  .col-md-3 {
    width: 25%;
  }

  .col-md-4 {
    width: 33.33333%;
  }

  .col-md-5 {
    width: 41.66667%;
  }

  .col-md-6 {
    width: 50%;
  }

  .col-md-7 {
    width: 58.33333%;
  }

  .col-md-8 {
    width: 66.66667%;
  }

  .col-md-9 {
    width: 75%;
  }

  .col-md-10 {
    width: 83.33333%;
  }

  .col-md-11 {
    width: 91.66667%;
  }

  .col-md-12 {
    width: 100%;
  }

  .col-md-pull-0 {
    right: auto;
  }

  .col-md-pull-1 {
    right: 8.33333%;
  }

  .col-md-pull-2 {
    right: 16.66667%;
  }

  .col-md-pull-3 {
    right: 25%;
  }

  .col-md-pull-4 {
    right: 33.33333%;
  }

  .col-md-pull-5 {
    right: 41.66667%;
  }

  .col-md-pull-6 {
    right: 50%;
  }

  .col-md-pull-7 {
    right: 58.33333%;
  }

  .col-md-pull-8 {
    right: 66.66667%;
  }

  .col-md-pull-9 {
    right: 75%;
  }

  .col-md-pull-10 {
    right: 83.33333%;
  }

  .col-md-pull-11 {
    right: 91.66667%;
  }

  .col-md-pull-12 {
    right: 100%;
  }

  .col-md-push-0 {
    left: auto;
  }

  .col-md-push-1 {
    left: 8.33333%;
  }

  .col-md-push-2 {
    left: 16.66667%;
  }

  .col-md-push-3 {
    left: 25%;
  }

  .col-md-push-4 {
    left: 33.33333%;
  }

  .col-md-push-5 {
    left: 41.66667%;
  }

  .col-md-push-6 {
    left: 50%;
  }

  .col-md-push-7 {
    left: 58.33333%;
  }

  .col-md-push-8 {
    left: 66.66667%;
  }

  .col-md-push-9 {
    left: 75%;
  }

  .col-md-push-10 {
    left: 83.33333%;
  }

  .col-md-push-11 {
    left: 91.66667%;
  }

  .col-md-push-12 {
    left: 100%;
  }

  .col-md-offset-0 {
    margin-left: 0;
  }

  .col-md-offset-1 {
    margin-left: 8.33333%;
  }

  .col-md-offset-2 {
    margin-left: 16.66667%;
  }

  .col-md-offset-3 {
    margin-left: 25%;
  }

  .col-md-offset-4 {
    margin-left: 33.33333%;
  }

  .col-md-offset-5 {
    margin-left: 41.66667%;
  }

  .col-md-offset-6 {
    margin-left: 50%;
  }

  .col-md-offset-7 {
    margin-left: 58.33333%;
  }

  .col-md-offset-8 {
    margin-left: 66.66667%;
  }

  .col-md-offset-9 {
    margin-left: 75%;
  }

  .col-md-offset-10 {
    margin-left: 83.33333%;
  }

  .col-md-offset-11 {
    margin-left: 91.66667%;
  }

  .col-md-offset-12 {
    margin-left: 100%;
  }
}
@media (min-width: 1200px) {
  .col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9 {
    float: left;
  }

  .col-lg-1 {
    width: 8.33333%;
  }

  .col-lg-2 {
    width: 16.66667%;
  }

  .col-lg-3 {
    width: 25%;
  }

  .col-lg-4 {
    width: 33.33333%;
  }

  .col-lg-5 {
    width: 41.66667%;
  }

  .col-lg-6 {
    width: 50%;
  }

  .col-lg-7 {
    width: 58.33333%;
  }

  .col-lg-8 {
    width: 66.66667%;
  }

  .col-lg-9 {
    width: 75%;
  }

  .col-lg-10 {
    width: 83.33333%;
  }

  .col-lg-11 {
    width: 91.66667%;
  }

  .col-lg-12 {
    width: 100%;
  }

  .col-lg-pull-0 {
    right: auto;
  }

  .col-lg-pull-1 {
    right: 8.33333%;
  }

  .col-lg-pull-2 {
    right: 16.66667%;
  }

  .col-lg-pull-3 {
    right: 25%;
  }

  .col-lg-pull-4 {
    right: 33.33333%;
  }

  .col-lg-pull-5 {
    right: 41.66667%;
  }

  .col-lg-pull-6 {
    right: 50%;
  }

  .col-lg-pull-7 {
    right: 58.33333%;
  }

  .col-lg-pull-8 {
    right: 66.66667%;
  }

  .col-lg-pull-9 {
    right: 75%;
  }

  .col-lg-pull-10 {
    right: 83.33333%;
  }

  .col-lg-pull-11 {
    right: 91.66667%;
  }

  .col-lg-pull-12 {
    right: 100%;
  }

  .col-lg-push-0 {
    left: auto;
  }

  .col-lg-push-1 {
    left: 8.33333%;
  }

  .col-lg-push-2 {
    left: 16.66667%;
  }

  .col-lg-push-3 {
    left: 25%;
  }

  .col-lg-push-4 {
    left: 33.33333%;
  }

  .col-lg-push-5 {
    left: 41.66667%;
  }

  .col-lg-push-6 {
    left: 50%;
  }

  .col-lg-push-7 {
    left: 58.33333%;
  }

  .col-lg-push-8 {
    left: 66.66667%;
  }

  .col-lg-push-9 {
    left: 75%;
  }

  .col-lg-push-10 {
    left: 83.33333%;
  }

  .col-lg-push-11 {
    left: 91.66667%;
  }

  .col-lg-push-12 {
    left: 100%;
  }

  .col-lg-offset-0 {
    margin-left: 0;
  }

  .col-lg-offset-1 {
    margin-left: 8.33333%;
  }

  .col-lg-offset-2 {
    margin-left: 16.66667%;
  }

  .col-lg-offset-3 {
    margin-left: 25%;
  }

  .col-lg-offset-4 {
    margin-left: 33.33333%;
  }

  .col-lg-offset-5 {
    margin-left: 41.66667%;
  }

  .col-lg-offset-6 {
    margin-left: 50%;
  }

  .col-lg-offset-7 {
    margin-left: 58.33333%;
  }

  .col-lg-offset-8 {
    margin-left: 66.66667%;
  }

  .col-lg-offset-9 {
    margin-left: 75%;
  }

  .col-lg-offset-10 {
    margin-left: 83.33333%;
  }

  .col-lg-offset-11 {
    margin-left: 91.66667%;
  }

  .col-lg-offset-12 {
    margin-left: 100%;
  }
}
@-ms-viewport {
  width: device-width;
}
.visible-xs, .visible-sm, .visible-md, .visible-lg, .visible-lg-block, .visible-lg-inline, .visible-lg-inline-block, .visible-md-block, .visible-md-inline, .visible-md-inline-block, .visible-sm-block, .visible-sm-inline, .visible-sm-inline-block, .visible-xs-block, .visible-xs-inline, .visible-xs-inline-block, .visible-print, .visible-print-block, .visible-print-inline, .visible-print-inline-block {
  display: none !important;
}

@media (max-width: 767px) {
  .visible-xs {
    display: block !important;
  }

  table.visible-xs {
    display: table !important;
  }

  tr.visible-xs {
    display: table-row !important;
  }

  td.visible-xs, th.visible-xs {
    display: table-cell !important;
  }
}
@media (max-width: 767px) {
  .visible-xs-block {
    display: block !important;
  }
}
@media (max-width: 767px) {
  .visible-xs-inline {
    display: inline !important;
  }
}
@media (max-width: 767px) {
  .visible-xs-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm {
    display: block !important;
  }

  table.visible-sm {
    display: table !important;
  }

  tr.visible-sm {
    display: table-row !important;
  }

  td.visible-sm, th.visible-sm {
    display: table-cell !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-block {
    display: block !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-inline {
    display: inline !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md {
    display: block !important;
  }

  table.visible-md {
    display: table !important;
  }

  tr.visible-md {
    display: table-row !important;
  }

  td.visible-md, th.visible-md {
    display: table-cell !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md-block {
    display: block !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md-inline {
    display: inline !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg {
    display: block !important;
  }

  table.visible-lg {
    display: table !important;
  }

  tr.visible-lg {
    display: table-row !important;
  }

  td.visible-lg, th.visible-lg {
    display: table-cell !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg-block {
    display: block !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg-inline {
    display: inline !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg-inline-block {
    display: inline-block !important;
  }
}
@media (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .hidden-sm {
    display: none !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .hidden-md {
    display: none !important;
  }
}
@media (min-width: 1200px) {
  .hidden-lg {
    display: none !important;
  }
}
@media print {
  .visible-print {
    display: block !important;
  }

  table.visible-print {
    display: table !important;
  }

  tr.visible-print {
    display: table-row !important;
  }

  td.visible-print, th.visible-print {
    display: table-cell !important;
  }
}
@media print {
  .visible-print-block {
    display: block !important;
  }
}
@media print {
  .visible-print-inline {
    display: inline !important;
  }
}
@media print {
  .visible-print-inline-block {
    display: inline-block !important;
  }
}
@media print {
  .hidden-print {
    display: none !important;
  }
}
html {
  font-size: 14px;
  overflow-y: scroll;
}

body {
  line-height: 1.6;
  color: #333;
  background: #fff;
}

a {
  color: #d94562;
}
a:link, a:visited {
  color: #d94562;
}
a:hover {
  color: #ea9aa9;
}
a:active {
  color: #d94562;
}

#header #gnavi ul li.active a {
  color: #fff;
  background-color: #d94f6b;
}

.container {
  margin: auto;
}

#header {
  margin-bottom: 4em;
}
#header .head {
  padding: 2em 0;
}
#header h1 img {
  width: 100%;
}
#header p {
  font-size: 14px;
  font-size: 1rem;
}
#header .headerIMG {
  width: 100%;
  margin-bottom: 1.5em;
}
#header .headerIMG img {
  width: 100%;
}
#header p {
  font-size: 20px;
  line-height: 1.6;
  margin-bottom: 1em;
}
#header p.note {
  background: #f2d4ce;
  text-align: center;
  color: #bb0031;
  font-size: 18px;
  padding: 10px 15px;
}
#header #gnavi {
  text-align: right;
}
#header #gnavi ul {
  margin-top: 10px;
}
#header #gnavi ul li {
  display: inline-block;
}
#header #gnavi ul li a {
  line-height: 1.5;
  display: block;
  margin-right: 2px;
  padding: 10px 15px;
  text-decoration: none;
  color: #333;
  border-radius: 4px;
}
#header #gnavi ul li a.official:hover {
  background-color: #d94f6b;
}
#header #gnavi ul li a:hover {
  color: #fff;
  background-color: rgba(217, 79, 107, 0.7);
}
#header #hnavi {
  display: none;
  background-color: #fff;
}
#header #hnavi li {
  font-size: 17px;
  font-size: 1.21429rem;
  margin-bottom: 1px;
}
#header #hnavi li:first-child {
  margin-top: 10px;
}
#header #hnavi li a {
  display: block;
  padding: .4em 1em;
  text-decoration: none;
  color: #fff;
  border-radius: 8px;
  background-color: rgba(217, 79, 107, 0.7);
}
#header .hamburger {
  margin-top: 10px;
  cursor: pointer;
  text-align: right;
}
#header .hamburger i {
  font-size: 33px;
  font-size: 2.35714rem;
}

@media (max-width: 992px) {
  #header p {
    font-size: 16px;
    font-size: 1.14286rem;
  }
  #header p.note {
    text-align: left;
    font-size: 14px;
    padding: 10px 15px;
  }
}
@media (max-width: 1200px) {
  #header #gnavi ul {
    margin-top: 5px;
  }
}
@media (max-width: 992px) {
  #header #hnavi li {
    font-size: 14px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  #header .hamburger {
    margin-top: 0;
  }
}
@media (max-width: 768px) {
  #header .hamburger i {
    font-size: 20px;
    font-size: 1.42857rem;
  }
}
#main {
  margin-top: 2em;
  background: #fff;
}
#main section {
  margin-bottom: 100px;
}
#main section header {
  width: 100%;
  height: 23px;
  margin-bottom: 60px;
  content: '&nbsp;';
  border-bottom: 1px solid #000;
}
#main section header h2 {
  font-size: 22px;
  font-size: 1.57143rem;
  font-family: YuMincho, "游明朝", serif !important;
  font-weight: 400;
  width: 13em;
  margin: auto;
  padding: .2em 0;
  text-align: center;
  color: #fff;
  background-color: #000;
}
#main section dl {
  margin-bottom: 1em;
}
#main section dl dt {
  font-weight: 700;
  float: left;
  width: 8em;
  text-align: left;
}
#main section dl dd {
  padding-left: 10em;
}
#main section dl dd ul {
  margin-left: 1.5em;
}
#main section .button {
  font-family: Roboto,sans-serif;
  display: inline-block;
  margin: 1em 0;
  padding: 1.5em 40px 1.5em 40px;
  transition: background .2s ease;
  text-decoration: none;
  letter-spacing: 1px;
  color: #fff;
  border: 3px solid #e04e71;
  background: #e04e71;
}
#main section .button:hover {
  color: #e04e71;
  background: #fff;
}
#main section .button.btn-pamphlet {
  width: 100%;
  padding-top: 1em;
  padding-bottom: 1em;
  text-align: center;
  color: #e04e71;
  background: #fff;
}
#main section .button.btn-pamphlet:hover {
  color: #fff;
  background: #e04e71;
}
#main #outline .pdf {
  margin-bottom: 1em;
  text-align: center;
}
#main #outline .pdf img {
  width: 100%;
  margin: auto;
}
#main #outline dl {
  font-size: 18px;
  font-size: 1.28571rem;
}
#main #outline dl dd span {
  display: inline-block;
}
#main #past .row {
  margin-right: -5px;
  margin-left: -5px;
  display: flex;
  flex-wrap: wrap;
}
#main #past .col {
  padding: 0 5px;
}
#main #past a:hover {
  opacity: .7;
}
#main #past a img {
  width: 100%;
  margin-bottom: 1em;
  border: 1px solid #ccc;
}

@media (max-width: 992px) {
  #main section dl dt {
    float: none;
  }
}
@media (max-width: 992px) {
  #main section dl dt {
    display: block;
  }
}
@media (max-width: 992px) {
  #main section dl dd {
    padding: 0;
  }
}
@media (max-width: 768px) {
  #main section .button.btn-pamphlet {
    width: 80%;
  }
}
@media (max-width: 768px) {
  #main #outline .pdf img {
    width: 70%;
  }
}
@media (max-width: 992px) {
  #main #outline dl {
    font-size: 14px;
    font-size: 1rem;
  }
}
@media (max-width: 768px) {
  #main #past a:hover {
    opacity: 1;
  }
}
.pagetop {
  position: fixed;
  right: 40px;
  bottom: 40px;
  display: none;
}
.pagetop a {
  font-size: 30px;
  font-size: 2.14286rem;
  line-height: 60px;
  display: block;
  width: 60px;
  height: 60px;
  text-align: center;
  text-decoration: none;
  color: #fff;
  border-radius: 45px;
  background-color: #d94f6b;
}
.pagetop a:hover {
  opacity: .5;
}

@media (max-width: 768px) {
  .pagetop {
    right: 10px;
    bottom: 10px;
  }
}
@media (max-width: 768px) {
  .pagetop a:hover {
    opacity: 1;
  }
}
#footer {
  margin-top: -30px;
  padding-top: 30px;
  padding-bottom: 30px;
  background: #f3f3ee;
}
@media print, screen and (min-width: 768px) {
  #footer {
    margin-top: 80px;
    padding-top: 80px;
    padding-bottom: 30px;
  }
}
#footer .site-logo {
  max-width: 280px;
  margin: 0 auto 20px;
}
@media print, screen and (min-width: 768px) {
  #footer .site-logo {
    max-width: 477px;
  }
}
#footer .contact {
  margin-top: 30px;
  text-align: center;
  font-size: 1rem;
  line-height: 2em;
}
@media print, screen and (min-width: 768px) {
  #footer .contact {
    margin-top: 60px;
    font-size: 1.14286rem;
  }
}
#footer .sns {
  margin-top: 30px;
}
#footer .sns .footer_row {
  display: flex;
  justify-content: center;
}
#footer .sns .col {
  width: 50px;
  margin: 0 15px;
}
@media print, screen and (min-width: 768px) {
  #footer .sns {
    margin-top: 60px;
  }
  #footer .sns .col {
    width: 70px;
    margin: 0 15px;
  }
}
#footer .sns a img {
  transition: transform .3s;
}
#footer .sns a:hover img {
  transform: scale(1.1);
}
#footer .footer-links {
  margin-top: 30px;
  font-size: 0.85714rem;
}
@media print, screen and (min-width: 768px) {
  #footer .footer-links {
    margin-top: 60px;
    font-size: 1.28571rem;
  }
}
#footer .footer-links .footer_row {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
#footer .footer-links .col {
  padding: 0 15px;
  flex: 0 0 auto;
  width: auto;
  border-left: 1px solid #000000;
  list-style:none;
}
#footer .footer-links .col:first-of-type {
  border-left: none;
}
#footer .footer-links a:link, a:visited{
  color: #231815;text-decoration: none;
}
#footer .footer-links a:hover{
  color: #231815;text-decoration: underline;
}
#footer .copyright {
  margin-top: 30px;
  text-align: center;
  font-size: 0.78571rem;
}
@media print, screen and (min-width: 768px) {
  #footer .copyright {
    margin-top: 60px;
    font-size: 1rem;
  }
}

.past .mb3em {
  margin-bottom: 3em;
}
.past h3 {
  font-size: 18px;
  font-size: 1.28571rem;
  margin: 1em 0 2em;
  padding: .3em;
  text-align: center;
  background-color: #e6e6e6;
}
.past .item {
  padding-bottom: 2em;
  text-align: center;
}
.past .item.text {
  padding-bottom: 0;
  text-align: left;
}
.past .item.text p {
  font-size: 12px;
  font-size: .85714rem;
}
.past .item a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.past .item a:hover {
  opacity: .9;
}
.past .item a:hover:before {
  display: block;
}
.past .item a:before {
  font-size: 24px;
  font-size: 1.71429rem;
  line-height: 50px;
  position: absolute;
  top: -15px;
  right: 0;
  bottom: 0;
  left: 0;
  display: none;
  width: 50px;
  height: 50px;
  margin: auto;
  content: '\f00e';
  color: #fff;
  border-radius: 50px;
  background-color: rgba(0, 0, 0, 0.7);
}
.past .item a img {
  margin-bottom: 16px;
}
.past .item h4 {
  font-size: 18px;
  font-size: 1.28571rem;
  margin-bottom: .2em;
}
.past .item p {
  font-size: 12px;
  font-size: .85714rem;
}
.past .item p.name {
  font-size: 14px;
  font-size: 1rem;
  font-weight: 700;
}

@media (max-width: 768px) {
  .past .item a:hover {
    opacity: 1;
  }
}
@media (max-width: 768px) {
  .past .item a:hover:before {
    display: none;
  }
}
.pb3em {
  padding-bottom: 3em;
}

strong {
  font-weight: 700;
}
