@charset "UTF-8";
/* wrapper
--------------------------- */
#wrapper {
  padding: 4em 0 0 0;
  min-height: 100%; }

/* stage
--------------------------- */
.stage {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  text-align: center; }

/* panel
--------------------------- */
.panel1 {
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  max-width: 1000px; }

.panel, .panel2 {
  position: relative;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  max-width: 1000px; }

/* Floatバグ回避用
--------------------------- */
.clearfix:after {
  content: "";
  display: block;
  clear: both; }

/* タイトルスタイル
--------------------------- */
.ttl-type01 {
  padding: 3.5em 0.5em 1em;
  font-size: 2.4em;
  line-height: 1.2em;
  font-weight: 300;
  border-bottom: 1px solid rgba(0, 0, 0, 0.2); }

/* toTop
--------------------------- */
#toTop {
  position: fixed;
  right: 5%;
  bottom: 3%;
  opacity: 0;
  z-index: 1000;
  text-align: center;
  transition: all 0.4s ease-in-out;
  z-index: 8887; }

.to-top-on #toTop {
  bottom: 2%;
  opacity: 1; }

#toTop a {
  display: block;
  width: 60px;
  height: 60px;
  color: rgba(41, 49, 47, 0.8);
  font-size: 24px;
  line-height: 60px;
  text-decoration: none;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.5);
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2);
  cursor: default; }

.to-top-on #toTop a {
  cursor: pointer; }

#toTop a:hover {
  background-color: rgba(255, 255, 255, 0.8); }

#pos {
  position: absolute;
  left: -9999px;
  top: -9999px;
  height: 0;
  visibility: hidden; }

@media screen and (min-width: 0\0 ) and (min-resolution: 72dpi) {
  /*IE9-11用ハック*/
  body {
    padding: 0 0 0; }

  #wrapper {
    padding: 0; } }
input[type="checkbox"] {
  display: none; }

header#glHeader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 8888; }
  header#glHeader::before {
    content: "";
    display: block;
    width: 100%;
    height: 4rem;
    background: #29312f; }

body {
  font-family: 'Noto Sans','Noto Sans JP', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif; }

#glhWrapper {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  padding: 0;
  width: 100%;
  height: 4rem;
  transition: 0.3s;
  overflow: hidden;
  z-index: 8889; }
  #glhWrapper #divMenuClose {
    display: block;
    width: 100%;
    height: 0;
    overflow: hidden;
    background: rgba(41, 49, 47, 0.8);
    transition: 0.3s; }
    #glhWrapper #divMenuClose label {
      display: block;
      width: 100%;
      height: 100%; }
  #glhWrapper h1, #glhWrapper p {
    position: absolute;
    top: 0;
    display: block;
    width: 50%;
    height: 4rem;
    background: #29312f;
    z-index: 8891; }
    #glhWrapper h1 a, #glhWrapper h1 label, #glhWrapper p a, #glhWrapper p label {
      display: block;
      width: 4rem;
      height: 100%;
      padding: 1.2rem 0;
      text-align: center;
      cursor: pointer; }
      #glhWrapper h1 a img, #glhWrapper h1 label img, #glhWrapper p a img, #glhWrapper p label img {
        margin: 0 auto;
        width: auto;
        height: 1.6rem; }
      #glhWrapper h1 a #imgGlhOpen, #glhWrapper h1 label #imgGlhOpen, #glhWrapper p a #imgGlhOpen, #glhWrapper p label #imgGlhOpen {
        display: block; }
      #glhWrapper h1 a #imgGlhClose, #glhWrapper h1 label #imgGlhClose, #glhWrapper p a #imgGlhClose, #glhWrapper p label #imgGlhClose {
        display: none; }
      #glhWrapper h1 a:hover, #glhWrapper h1 label:hover, #glhWrapper p a:hover, #glhWrapper p label:hover {
        background: rgba(255, 255, 255, 0.1); }
        #glhWrapper h1 a:hover img, #glhWrapper h1 label:hover img, #glhWrapper p a:hover img, #glhWrapper p label:hover img {
          opacity: 1; }
  #glhWrapper h1 {
    left: 0;
    text-align: left; }
  #glhWrapper p {
    right: 0; }
    #glhWrapper p label {
      float: right; }
  #glhWrapper dl {
    position: relative;
    width: 100%;
    transition: 0.2s;
    background: rgba(41, 49, 47, 0.9);
    overflow: hidden; }
    #glhWrapper dl dt {
      position: relative;
      display: flex;
      width: 100%;
      height: 0;
      font-size: 1.1rem;
      overflow: hidden; }
      #glhWrapper dl dt a {
        position: relative;
        padding: 0 1rem;
        width: 100%;
        color: white;
        line-height: 4rem;
        text-align: left;
        opacity: 1; }
        #glhWrapper dl dt a:hover {
          background: rgba(255, 255, 255, 0.1); }
        #glhWrapper dl dt a::before {
          content: "\f138";
          font-family: "Font Awesome 5 free";
          font-weight: 900;
          display: inline-block;
          padding-right: 1em; }
      #glhWrapper dl dt label {
        width: 4rem;
        height: 4rem;
        color: white;
        transition: 0.2s;
        overflow: hidden;
        cursor: pointer; }
        #glhWrapper dl dt label:hover {
          background: rgba(255, 255, 255, 0.2); }
        #glhWrapper dl dt label figure {
          font-size: 1rem;
          line-height: 4rem; }
          #glhWrapper dl dt label figure.fig-ctg-open {
            display: block; }
          #glhWrapper dl dt label figure.fig-ctg-close {
            display: none; }
    #glhWrapper dl dd {
      width: 100%;
      overflow: hidden;
      background: rgba(41, 49, 47, 0.6); }
      #glhWrapper dl dd h2, #glhWrapper dl dd h3 {
        display: none;
        padding: 0 1rem;
        width: 100%;
        font-size: 1.6rem;
        font-weight: 300;
        opacity: 0; }
        #glhWrapper dl dd h2 a, #glhWrapper dl dd h2 span, #glhWrapper dl dd h3 a, #glhWrapper dl dd h3 span {
          display: block;
          width: 100%;
          color: #29312f;
          line-height: 4rem;
          border-radius: 0.8em;
          background: rgba(255, 255, 255, 0.6); }
        #glhWrapper dl dd h2 a:hover, #glhWrapper dl dd h3 a:hover {
          background: rgba(255, 255, 255, 0.9); }
      #glhWrapper dl dd ul {
        display: flex;
        flex-wrap: wrap;
        margin: 0 auto;
        padding: 0 0.5rem;
        width: 100%; }
      #glhWrapper dl dd li {
        padding: 0 0.5rem;
        width: 50%;
        height: 0;
        font-size: 0.9rem;
        transition: 0.2s;
        opacity: 0;
        overflow: hidden; }
        #glhWrapper dl dd li a {
          position: relative;
          display: block;
          padding: 1.4rem 1.5rem 1.4rem 0.6rem;
          color: white;
          height: 100%;
          text-align: left;
          line-height: 1.2rem;
          border-radius: 1rem;
          border: 1px solid rgba(255, 255, 255, 0.7); }
          #glhWrapper dl dd li a:hover {
            background: rgba(255, 255, 255, 0.3); }
          #glhWrapper dl dd li a::after {
            display: block;
            content: "\f054";
            font-family: "Font Awesome 5 free";
            font-weight: 900;
            position: absolute;
            top: 0;
            right: 0;
            bottom: 0;
            width: 1.5rem;
            height: 4rem;
            font-size: 0.8em;
            line-height: 4rem;
            text-align: center; }

#cbxGlhMenu:checked ~ header #glhWrapper {
  position: fixed;
  padding: 4rem 0 0;
  height: 100vh;
  overflow-y: auto;
  z-index: 9999; }
  #cbxGlhMenu:checked ~ header #glhWrapper #divMenuClose {
    height: calc(100% - 24rem); }
  #cbxGlhMenu:checked ~ header #glhWrapper h1 a #imgGlhOpen, #cbxGlhMenu:checked ~ header #glhWrapper h1 label #imgGlhOpen, #cbxGlhMenu:checked ~ header #glhWrapper p a #imgGlhOpen, #cbxGlhMenu:checked ~ header #glhWrapper p label #imgGlhOpen {
    display: none; }
  #cbxGlhMenu:checked ~ header #glhWrapper h1 a #imgGlhClose, #cbxGlhMenu:checked ~ header #glhWrapper h1 label #imgGlhClose, #cbxGlhMenu:checked ~ header #glhWrapper p a #imgGlhClose, #cbxGlhMenu:checked ~ header #glhWrapper p label #imgGlhClose {
    display: block; }
  #cbxGlhMenu:checked ~ header #glhWrapper dt {
    height: 4rem;
    border-bottom: 1px solid rgba(41, 49, 47, 0.3); }

.dl-ctg-set dt label figure.fig-ctg-open, #cbxGlhCtg01:checked ~ header #glhWrapper #dlCtg01 dt label figure.fig-ctg-open,
#cbxGlhCtg02:checked ~ header #glhWrapper #dlCtg02 dt label figure.fig-ctg-open,
#cbxGlhCtg03:checked ~ header #glhWrapper #dlCtg03 dt label figure.fig-ctg-open,
#cbxGlhCtg04:checked ~ header #glhWrapper #dlCtg04 dt label figure.fig-ctg-open,
#cbxGlhCtg05:checked ~ header #glhWrapper #dlCtg05 dt label figure.fig-ctg-open,
#cbxGlhCtg06:checked ~ header #glhWrapper #dlCtg06 dt label figure.fig-ctg-open {
  display: none; }
.dl-ctg-set dt label figure.fig-ctg-close, #cbxGlhCtg01:checked ~ header #glhWrapper #dlCtg01 dt label figure.fig-ctg-close,
#cbxGlhCtg02:checked ~ header #glhWrapper #dlCtg02 dt label figure.fig-ctg-close,
#cbxGlhCtg03:checked ~ header #glhWrapper #dlCtg03 dt label figure.fig-ctg-close,
#cbxGlhCtg04:checked ~ header #glhWrapper #dlCtg04 dt label figure.fig-ctg-close,
#cbxGlhCtg05:checked ~ header #glhWrapper #dlCtg05 dt label figure.fig-ctg-close,
#cbxGlhCtg06:checked ~ header #glhWrapper #dlCtg06 dt label figure.fig-ctg-close {
  display: block; }
.dl-ctg-set dd h3, #cbxGlhCtg01:checked ~ header #glhWrapper #dlCtg01 dd h3,
#cbxGlhCtg02:checked ~ header #glhWrapper #dlCtg02 dd h3,
#cbxGlhCtg03:checked ~ header #glhWrapper #dlCtg03 dd h3,
#cbxGlhCtg04:checked ~ header #glhWrapper #dlCtg04 dd h3,
#cbxGlhCtg05:checked ~ header #glhWrapper #dlCtg05 dd h3,
#cbxGlhCtg06:checked ~ header #glhWrapper #dlCtg06 dd h3 {
  margin: 1.5rem 0 0;
  display: inline-block;
  opacity: 1; }
.dl-ctg-set dd ul, #cbxGlhCtg01:checked ~ header #glhWrapper #dlCtg01 dd ul,
#cbxGlhCtg02:checked ~ header #glhWrapper #dlCtg02 dd ul,
#cbxGlhCtg03:checked ~ header #glhWrapper #dlCtg03 dd ul,
#cbxGlhCtg04:checked ~ header #glhWrapper #dlCtg04 dd ul,
#cbxGlhCtg05:checked ~ header #glhWrapper #dlCtg05 dd ul,
#cbxGlhCtg06:checked ~ header #glhWrapper #dlCtg06 dd ul {
  padding: 1rem 0.5rem;
  border-bottom: 1px solid rgba(41, 49, 47, 0.3); }
.dl-ctg-set dd li, #cbxGlhCtg01:checked ~ header #glhWrapper #dlCtg01 dd li,
#cbxGlhCtg02:checked ~ header #glhWrapper #dlCtg02 dd li,
#cbxGlhCtg03:checked ~ header #glhWrapper #dlCtg03 dd li,
#cbxGlhCtg04:checked ~ header #glhWrapper #dlCtg04 dd li,
#cbxGlhCtg05:checked ~ header #glhWrapper #dlCtg05 dd li,
#cbxGlhCtg06:checked ~ header #glhWrapper #dlCtg06 dd li {
  padding: 0.5rem;
  height: 5rem;
  opacity: 1; }

main {
  padding: 4rem 0 0;
  min-height: 50vh;
  background: "#FFF"; }

/*スマホに適用するスタイルを書く*/
@media screen and (min-width: 600px) {
  #glhWrapper dl dd li {
    width: 33.33%;
    font-size: 1.1rem; }
    #glhWrapper dl dd li a {
      padding: 1.4rem 1.8rem 1.4rem 0.9rem; }
      #glhWrapper dl dd li a::after {
        width: 1.8rem; } }
/*タブレットに適用するスタイルを書く*/
@media screen and (min-width: 960px) {
  #glhWrapper {
    top: 0;
    display: flex;
    margin-left: auto !important;
    margin-right: auto !important;
    flex-wrap: wrap;
    padding: 0 0 0 4rem !important;
    box-sizing: border-box !important;
    height: 4rem;
    max-width: 1100px; }
    #glhWrapper #divMenuClose {
      display: none;
      top: 0;
      height: 0; }
    #glhWrapper h1, #glhWrapper p {
      top: 0;
      width: 4rem; }
      #glhWrapper h1 a #imgGlhOpen, #glhWrapper h1 label #imgGlhOpen, #glhWrapper p a #imgGlhOpen, #glhWrapper p label #imgGlhOpen {
        display: none; }
      #glhWrapper h1 a #imgGlhClose, #glhWrapper h1 label #imgGlhClose, #glhWrapper p a #imgGlhClose, #glhWrapper p label #imgGlhClose {
        display: none; }
    #glhWrapper h1 {
      position: absolute; }
    #glhWrapper p {
      display: none; }
    #glhWrapper dl {
      width: 16.66%;
      height: 4rem;
      background: rgba(41, 49, 47, 0); }
      #glhWrapper dl dt {
        height: 4rem;
        border-bottom: none;
        overflow: hidden; }
        #glhWrapper dl dt a {
          padding: 0;
          text-align: center; }
          #glhWrapper dl dt a::before {
            display: none; }
        #glhWrapper dl dt label {
          display: none; }
      #glhWrapper dl dd {
        position: fixed;
        top: 4rem;
        right: 0;
        left: 0;
        padding: 0 4rem;
        width: 100%;
        height: 0;
        background: rgba(41, 49, 47, 0.9);
        transition: 0.2s;
        z-index: 8890;
        opacity: 0; }
        #glhWrapper dl dd h2, #glhWrapper dl dd h3 {
          display: none;
          opacity: 1; }
        #glhWrapper dl dd ul {
          display: flex;
          flex-wrap: wrap;
          margin: 0 auto;
          width: 100%;
          opacity: 0; }
        #glhWrapper dl dd li {
          width: 25%;
          height: 0;
          transition: .2s;
          overflow: hidden; }
      #glhWrapper dl:hover dd {
        padding: 3rem 4rem;
        height: 31rem;
        opacity: 1; }
        #glhWrapper dl:hover dd h2, #glhWrapper dl:hover dd h3 {
          display: inline-block;
          opacity: 1; }
        #glhWrapper dl:hover dd h3 {
          margin: 5rem 0 0; }
        #glhWrapper dl:hover dd h3:first-child {
          margin: 0; }
        #glhWrapper dl:hover dd ul {
          padding: 0.5rem;
          opacity: 1;
          border-bottom: none; }
        #glhWrapper dl:hover dd li {
          height: auto;
          min-height: 5rem;
          padding: 0.5rem;
          opacity: 1; }

  #cbxGlhCtg01:checked ~ #glhWrapper #dlCtg01 dd h3:first-child,
  #cbxGlhCtg02:checked ~ #glhWrapper #dlCtg02 dd h3:first-child,
  #cbxGlhCtg03:checked ~ #glhWrapper #dlCtg03 dd h3:first-child,
  #cbxGlhCtg04:checked ~ #glhWrapper #dlCtg04 dd h3:first-child,
  #cbxGlhCtg05:checked ~ #glhWrapper #dlCtg05 dd h3:first-child,
  #cbxGlhCtg06:checked ~ #glhWrapper #dlCtg06 dd h3:first-child {
    margin: 0; }
  #cbxGlhCtg01:checked ~ #glhWrapper #dlCtg01 dd ul,
  #cbxGlhCtg02:checked ~ #glhWrapper #dlCtg02 dd ul,
  #cbxGlhCtg03:checked ~ #glhWrapper #dlCtg03 dd ul,
  #cbxGlhCtg04:checked ~ #glhWrapper #dlCtg04 dd ul,
  #cbxGlhCtg05:checked ~ #glhWrapper #dlCtg05 dd ul,
  #cbxGlhCtg06:checked ~ #glhWrapper #dlCtg06 dd ul {
    border-bottom: none; }

  #cbxGlhMenu:checked ~ #glhWrapper {
    height: 4rem; }
    #cbxGlhMenu:checked ~ #glhWrapper #divMenuClose {
      height: 0;
      display: none; } }
/*PCに適用するスタイルを書く*/


/*PCに適用するスタイルを書く*/
/***layout***/
#gheader, #gnav {
  position: absolute; }

/*ADD*/
#glhWrapper a {
  text-decoration: none;
}