@charset "UTF-8";

/* =========================================================
  link color
========================================================= */
a {
  color: var(--a-color);
  text-decoration: none;
}

a:hover {
  color: var(--a-hover-color);
  text-decoration: underline;
}

a:visited {
  color: var(--a-visited-color);
}

/* =========================================================
  site layout
========================================================= */
#container {
  position: relative;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  overflow-x: hidden;
}

#pageHeader {
  position: relative;
  width: 100%;
}

#main {
  flex-grow: 1;
  width: 100%;
  max-width: var(--site-width);
  margin: 0 auto 20px;
}

/* body
----------------------------------------------- */
.body p,
.summary p {
  margin: 0 0 1rem;
}

.body table {
  margin-bottom: 1rem;
  border: 1px solid var(--mono-color-6);
}

/* button
----------------------------------------------- */
#back,
.back {
  text-align: center;
}

#back a,
.back a {
  display: inline-block;
  padding: 10px 47px 10px 57px;
  border: 1px solid var(--mono-color-10);
  background: url("../images/ic-back.svg") no-repeat 15px center;
  color: var(--mono-color-1);
  text-decoration: none;
}

#back a:hover,
.back a:hover {
  border-color: var(--mono-color-4);
  background-color: var(--mono-color-17);
}

@media screen and (min-width: 960px) {

  #back,
  .back {
    margin: 60px 0 0;
  }
}

@media screen and (max-width: 959px) {

  #back,
  .back {
    margin: 30px 0;
  }
}

/* pageTop
----------------------------------------------- */
#pageTop {
  position: fixed;
  left: 50%;
  bottom: 55px;
  margin-left: calc(var(--site-width) / 2 - 112px);
  z-index: 1000;
}

#pageTop a {
  display: flex;
  align-items: center;
  gap: 0 6px;
  color: var(--mono-color-1);
  font-size: 0.875rem;
  text-decoration: none;
}

#pageTop a:hover,
#pageTop a:focus {
  opacity: 0.75;
}

@media screen and (max-width: 959px) {
  #pageTop {
    display: none;
  }
}

/* sp pc switch
----------------------------------------------- */
#spSwitch {
  width: 100%;
  border: 2px solid var(--main-color-5);
  background-color: var(--main-color-10);
  text-align: center;
}

#spView {
  display: block;
  position: relative;
  width: 100%;
  padding: 0 20px 10px;
  border: none;
  background-color: transparent;
  font-size: 1.25rem;
}

#spView::before {
  content: "";
  width: 32px;
  display: inline-block;
  height: 32px;
  left: -4px;
  top: 8px;
  position: relative;
  background-image: url("../images/ic-spview.png");
  background-repeat: no-repeat;
  background-position: center center;
}

#pcSwitch {
  display: none;
}

#pcView {
  width: 200px;
  padding: 8px 12px 8px 40px;
  border: none;
  background-color: var(--main-color-5);
  background-image: url("../images/ic-pcview.png");
  background-repeat: no-repeat;
  background-position: 30px center;
  color: var(--mono-color-9);
}

/* header-menu
----------------------------------------------- */
#headerMenu {
  display: block;
  position: relative;
  z-index: 1000;
}

#headerMenu button {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1.2;
  background-color: var(--main-color-1);
  color: var(--mono-color-9);
  font-weight: bold;
  white-space: nowrap;
}

#headerMenu button::before {
  content: "";
  display: block;
  height: 26px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}

#headerMenu button.accessibilityTool::before {
  width: 19px;
  background-image: url("../images/ic-accessibility.svg");
}

#headerMenu button.search::before {
  width: 24px;
  background-image: url("../images/ic-search.svg");
}

#headerMenu button.globalNavi::before {
  width: 26px;
  height: 26px;
  margin-bottom: 8px;
}

#headerMenu .accessibilityTool::before {
  background-image: url("../images/ic-accessibility.svg");
}

#headerMenu .search::before {
  background-image: url("../images/ic-search.svg");
}

#headerMenu .globalNavi::before {
  background-image: url("../images/ic-menu.svg");
}

#headerMenu .chatbot::before {
  background-image: url("../images/ic-chatbot_sp.svg");
  background-size: auto 26px;
}

#headerMenu .pagetop::before {
  background-image: url("../images/ic-pagetop_sp.svg");
  background-size: 26px auto;
}

#headerMenu button.active {
  position: relative;
  color: var(--mono-color-1);
  background-color: var(--mono-color-9);
  z-index: 100;
}

#headerMenu button:not(.globalNavi).active {
  border-color: transparent;
}

#headerMenu button.globalNavi.active {
  border-right-color: transparent;
  border-bottom-color: transparent;
}

#headerMenu button.active::before {
  background-image: url("../images/ic-close.svg");
}

@media screen and (min-width: 960px) {
  #headerMenu {
    position: absolute;
    top: 0;
    right: 0;
  }

  #headerMenu .pc {
    display: flex;
  }

  #headerMenu .sp {
    display: none;
  }

  #headerMenu li:first-child {
    margin-right: 8px;
  }

  #headerMenu li:last-child {
    margin-left: 12px;
  }

  #headerMenu button {
    width: 64px;
    height: 64px;
    margin-top: 7px;
    border: 1px solid var(--main-color-1);
    border-radius: 50%;
    font-size: 0.75rem;
  }

  #headerMenu button.globalNavi {
    width: 80px;
    height: 80px;
    margin-top: 0;
    border-radius: 0;
    font-size: 1rem;
  }

  #headerMenu button:hover,
  #headerMenu button:focus {
    background-color: var(--mono-color-9);
    color: var(--mono-color-1);
  }

  #headerMenu button::before {
    margin-bottom: 4px;
  }

  #headerMenu .accessibilityTool:not(.active):hover::before,
  #headerMenu .accessibilityTool:not(.active):focus::before {
    background-image: url("../images/ic-accessibility_hover.svg");
  }

  #headerMenu .globalNavi:not(.active):hover::before,
  #headerMenu .globalNavi:not(.active):focus::before {
    background-image: url("../images/ic-menu_hover.svg");
  }

  #headerMenu .search:not(.active):hover::before,
  #headerMenu .search:not(.active):focus::before {
    background-image: url("../images/ic-search_hover.svg");
  }
}

@media screen and (max-width: 959px) {
  #headerMenu {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: var(--mono-color-9);
  }

  #headerMenu ul {
    gap: 1px;
  }

  #headerMenu .pc {
    display: none;
  }

  #headerMenu .sp {
    display: flex;
  }

  #headerMenu li {
    flex: 1;
  }

  #headerMenu button {
    width: 100%;
    height: 80px;
    border: 0;
    font-size: 1rem;
  }

  #headerMenu button::before {
    width: 100%;
    margin-bottom: 10px;
  }
}

/* accessibility-tool
----------------------------------------------- */
#accessibilityTool .pieceBody {
  display: none;
  position: relative;
  width: 1005px;
  max-width: 100%;
  margin: 25px 16px 0 auto;
  padding: 24px;
  border: 1px solid var(--main-color-12);
  background-color: var(--mono-color-9);
  font-size: 1rem;
  font-weight: bold;
}

#accessibilityTool .pieceBody::before {
  content: "";
  position: absolute;
  top: 0;
  right: 139px;
  border-style: solid;
  border-width: 0 38px 34px 0;
  border-color: transparent transparent var(--main-color-12);
  translate: -50% -100%;
  transform: skew(-25deg);
  transform-origin: bottom;
}

#accessibilityTool .pieceBody::after {
  content: "";
  position: absolute;
  top: 0;
  right: 142px;
  border-style: solid;
  border-width: 0 35.5px 31.8px 0;
  border-color: transparent transparent var(--mono-color-9);
  translate: calc(-50% - 0.2px) -100%;
  transform: skew(-25deg);
  transform-origin: bottom;
}

#accessibilityTool ul,
#accessibilityTool li {
  display: flex;
  align-items: center;
  margin: 0;
}

#accessibilityTool .pieceBody>ul:first-child {
  margin-bottom: 24px;
}

#accessibilityTool li ul {
  gap: 8px;
}

#accessibilityTool .pieceBody>ul>li:not(:first-child) {
  margin-left: 19px;
  padding-left: 19px;
  border-left: 1px dotted var(--mono-color-7);
}

#accessibilityTool a,
#accessibilityTool span {
  display: inline-block;
  line-height: 1;
}

#accessibilityTool a {
  min-height: 46px;
  line-height: 46px;
  border: 1px solid var(--mono-color-13);
  border-radius: 4px;
  color: var(--mono-color-1);
  text-align: center;
}

#accessibilityTool a:not(#navigationRuby):hover,
#accessibilityTool a:not(#navigationRuby):focus {
  border-color: var(--mono-color-4) !important;
  background-color: var(--mono-color-17) !important;
  color: var(--mono-color-1) !important;
  text-decoration: none;
}

#accessibilityTool .fontSize,
#accessibilityTool .themeColor {
  flex-basis: 340px;
  justify-content: space-between;
}

#accessibilityTool .fontSize span,
#accessibilityTool .themeColor span {
  width: 5.5em;
  text-align: right;
}

#accessibilityTool .fontSize a,
#accessibilityTool .zoom a,
#accessibilityTool .themeColor a.white {
  min-width: 72px;
}

#accessibilityTool .themeColor a:not(.white) {
  min-width: 46px;
}

#accessibilityTool .ruby a {
  min-width: 96px;
}

#accessibilityTool .translation a {
  padding: 0 20px 0 60px;
  background: url("../images/ic-translation.svg") no-repeat 14px center;
}

#accessibilityTool .zoom span,
#accessibilityTool #navigationRuby {
  margin-right: 19px;
}

#accessibilityTool .talk a {
  padding: 0 20px 0 60px;
  background: url("../images/ic-talk.svg") no-repeat 14px center;
}

#accessibilityTool #navigationRuby:not(.rubyOn) {
  border-color: transparent;
  background-color: transparent;
}

#accessibilityTool a.rubyOff {
  margin-right: -4px;
}

#accessibilityTool a.rubyOn {
  margin-right: 4px;
}

#accessibilityTool #navigationTalkPlayer {
  position: absolute;
  top: 74px;
}

#navigationTalkCreatingFileNotice,
#navigationTalkPlayer audio {
  position: relative;
  width: 450px;
  padding: 4px;
  background-color: var(--mono-color-9);
}

#navigationNotice {
  padding: 24px;
  border: 1px solid var(--main-color-12);
  background-color: var(--mono-color-9);
  font-weight: bold;
}

#accessibilityTool #themeYellow,
#accessibilityTool #themeBlue,
#accessibilityTool #themeBlack {
  border-color: transparent;
}

#accessibilityTool #themeYellow {
  background-color: #ff0;
}

#accessibilityTool #themeBlue {
  background-color: #00f;
  color: var(--mono-color-9);
}

#accessibilityTool #themeBlack {
  background-color: #000;
  color: var(--mono-color-9);
}

/*
@media screen and (max-width: 1200px) {
  #accessibilityTool .pieceBody {
    padding: 5px 20px;
  }
}
*/

/* joruri-search-box
---------------------- */
.criteriaBox .criteriaBasic {
  width: 340px;
}

.criteriaBox .criteriaBasic,
.criteriaBox .criteriaKeyword {
  background: none;
}

.criteriaBox .criteriaKeyword {
  display: flex;
  position: relative;
  justify-content: flex-end;
}

.criteriaBox .criteriaKeyword>*+* {
  margin-left: 12px;
}

.criteriaBox .criteriaKeyword .keyword {
  width: 100%;
  padding: 1rem;
  border: none;
}

.criteriaBox .criteriaKeyword .keyword:focus {
  outline: none;
}

.criteriaBox .criteriaKeyword input[name="commit"] {
  margin-left: 0;
  background: url("../images/ic-search.svg") no-repeat center center/ 29px 29px;
}

.criteriaBox .criteriaKeyword input[type="submit"] {
  flex-basis: 80px;
  height: 56px;
  padding: 0;
  color: var(--mono-color-9);
  background-color: var(--mono-color-13);
  border: none;
  border-radius: 0;
  cursor: pointer;
}

.criteriaBox .criteriaKeyword input[name="clear"] {
  flex-basis: 32px;
  height: 54px;
  font-weight: bold;
  background-color: var(--mono-color-9);
  border-style: none;
  color: var(--main-color-8);
  outline: none;
}

.criteriaBox .criteriaKeyword input[name="clear"]:hover {
  color: var(--main-color-4);
}

.criteriaBox .criteriaKeyword .keywordDescription {
  display: none;
}

.criteriaBox .criteriaKeyword .keywordField {
  display: inherit;
  flex-basis: calc(100% - 80px);
  height: 56px;
  border: 1px solid var(--mono-color-13);
  border-radius: 0;
  background-color: var(--mono-color-9);
}

.criteriaBox #criteria_keyword {
  border-style: none;
  border-radius: 0;
}

.criteriaBox #criteria_keyword:focus {
  outline: none;
}

.criteriaBox .criteriaBasic {
  width: 100%;
}

.criteriaBox {
  display: none;
  position: relative;
  max-width: 100%;
  background-color: var(--mono-color-9);
}

@media screen and (min-width: 960px) {
  .criteriaBox {
    width: 460px;
    margin: 25px 12px 0 auto;
    padding: 20px;
    border: 1px solid var(--main-color-12);
  }

  .criteriaBox::before {
    content: "";
    position: absolute;
    top: 0;
    left: 350px;
    border-style: solid;
    border-width: 0 38px 34px 0;
    border-color: transparent transparent var(--main-color-12);
    translate: -50% -100%;
    transform: skew(-25deg);
    transform-origin: bottom;
  }

  .criteriaBox::after {
    content: "";
    position: absolute;
    top: 0;
    left: 350px;
    border-style: solid;
    border-width: 0 35.5px 31.8px 0;
    border-color: transparent transparent var(--mono-color-9);
    translate: calc(-50% - 0.2px) -100%;
    transform: skew(-25deg);
    transform-origin: bottom;
  }
}

@media screen and (max-width: 959px) {
  .criteriaBox {
    position: fixed;
    left: 0;
    bottom: 80px;
    width: 100%;
    padding: 30px 25px;
    z-index: 999;
  }
}

/* custom-search
----------------------------------------------- */
#customSearch fieldset {
  margin: 0 0 3px;
  padding: 0;
  border: 0;
}

#customSearch fieldset::after {
  content: "";
  clear: both;
  display: block;
}

#customSearch fieldset legend,
#customSearch fieldset label {
  display: inline-block;
  width: auto;
  margin: 0 0.5rem 0 0;
}

#customSearch fieldset legend {
  float: left;
}

#search-box {
  width: calc(100% - 70px);
  height: 40px;
  border: 1px solid var(--mono-color-6) !important;
}

#search-button {
  height: 40px;
  margin-left: -4px;
  padding: 8px 20px;
  background-color: var(--main-color-4);
  overflow: hidden;
  cursor: pointer;
}

.gsc-selected-option-container {
  max-width: 100% !important;
}

@media screen and (max-width: 959px) {
  #customSearch .pieceBody {
    display: none;
    position: absolute;
    top: 65px;
    left: 0;
    z-index: 999;
    width: 100%;
    padding: 16px 20px;
    background-color: var(--mono-color-9);
    border-bottom: 1px solid var(--main-color-4);
  }
}

/* global-navi
----------------------------------------------- */
#globalNavi .pieceBody {
  display: none;
}

#globalNavi ul {
  display: flex;
  flex-wrap: wrap;
}

#globalNavi li {
  display: flex;
}

#globalNavi li a {
  display: block;
  width: 100%;
  line-height: 1;
  color: var(--mono-color-1);
  font-weight: bold;
  text-decoration: none;
}

/* navi */
#globalNavi .navi li a {
  padding: 16px 0 16px 20px;
  background: url("../images/ic-arrow_blue.svg") no-repeat left center;
}

#globalNavi .navi li a.cur,
#globalNavi .navi li a:focus {
  border-color: var(--main-color-1);
  box-shadow: 0 2px 0 -1px var(--main-color-1);
}

/* guide */
#globalNavi .guide {
  padding: 15px;
}

#globalNavi .guide li a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  background-color: var(--mono-color-9);
}

#globalNavi .guide li a.cur,
#globalNavi .guide li a:focus {
  border-color: var(--main-color-1);
  box-shadow: inset 0 0 0 1px var(--main-color-1);
}

#globalNavi .guide li a .icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 8px;
}

#globalNavi .guide li a .icon img {
  max-height: 100%;
  object-fit: contain;
}

/* search */
#globalNavi .search li a {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--mono-color-9);
}

#globalNavi .search li a span {
  display: inline-block;
  position: relative;
}

#globalNavi .search li a span::after {
  content: "";
  display: block;
  position: absolute;
  left: 0.5em;
  bottom: -10px;
  width: calc(100% - 1em);
  height: 2px;
}

#globalNavi .search li a.cur span::after,
#globalNavi .search li a:focus span::after {
  background-color: var(--main-color-1);
}

@media screen and (min-width: 960px) {
  #globalNavi .pieceBody {
    max-width: calc(var(--site-width) + 25px);
    margin: 0 0 0 auto;
    padding: 50px 80px 36px 43px;
    border: 1px solid var(--main-color-1);
    border-right: 0;
    background-color: var(--mono-color-9);
  }

  #globalNavi .navi {
    margin-bottom: 30px;
    gap: 30px 20px;
  }

  #globalNavi .navi li {
    flex-basis: calc(33.33% - 13.33px);
  }

  #globalNavi .navi li a {
    border-bottom: 1px solid var(--mono-color-5);
    font-size: 1.5rem;
  }

  #globalNavi .navi li a:hover {
    border-color: var(--main-color-1);
    box-shadow: 0 2px 0 -1px var(--main-color-1);
  }

  #globalNavi .guide {
    gap: 15px;
    margin-bottom: 25px;
    background-color: var(--mono-color-8);
  }

  #globalNavi .guide li {
    flex-basis: calc(25% - 11.25px);
  }

  #globalNavi .guide li a {
    padding: 20px;
    border: 1px solid var(--mono-color-5);
    font-size: 1.5rem;
  }

  #globalNavi .guide li a:hover {
    border-color: var(--main-color-1);
    box-shadow: inset 0 0 0 1px var(--main-color-1);
  }

  #globalNavi .guide li a .icon {
    height: 57px;
  }

  #globalNavi .guide li a .icon img {
    max-width: 59px;
  }

  #globalNavi .search {
    gap: 15px;
  }

  #globalNavi .search li {
    flex-basis: calc(25% - 11.25px);
  }

  #globalNavi .search li a {
    padding: 20px;
    border: 1px solid var(--mono-color-5);
    border-radius: 4px;
    font-size: 1.25rem;
  }

  #globalNavi .search li a:hover span::after {
    background-color: var(--main-color-1);
  }
}

@media screen and (max-width: 959px) {
  #globalNavi .pieceBody {
    position: fixed;
    bottom: 80px;
    left: 0;
    width: 100%;
    height: calc(100dvh - 80px);
    background-color: var(--mono-color-14);
    overflow-y: auto;
    z-index: 999;
  }

  #globalNavi .navi {
    padding: 0 15px 25px;
    background-color: var(--mono-color-9);
  }

  #globalNavi .navi li {
    flex-basis: 100%;
  }

  #globalNavi .navi li a {
    border-bottom: 1px solid var(--mono-color-15);
    font-size: 1.25rem;
  }

  #globalNavi .guide {
    gap: 8px;
    background-color: var(--mono-color-14);
  }

  #globalNavi .guide li {
    flex-basis: calc(33.33% - 5.33px);
  }

  #globalNavi .guide li a {
    padding: 15px 0;
    border: 1px solid var(--mono-color-16);
    border-radius: 2px;
    font-size: 0.9375rem;
  }

  #globalNavi .guide li a .icon {
    height: 41px;
  }

  #globalNavi .guide li a .icon img {
    max-width: 56px;
  }

  #globalNavi .search {
    padding: 15px;
  }

  #globalNavi .search li {
    flex-basis: 50%;
    border-right: 1px solid var(--mono-color-16);
    border-bottom: 1px solid var(--mono-color-16);
  }

  #globalNavi .search li:nth-child(odd) {
    border-left: 1px solid var(--mono-color-16);
  }

  #globalNavi .search li:nth-child(-n+2) {
    border-top: 1px solid var(--mono-color-16);
  }

  #globalNavi .search li a {
    padding: 18px 0;
  }

  #pcView {
    width: 200px;
    padding: 8px 12px 8px 40px;
    border: 0;
    background: var(--main-color-3) url("../images/ic-pcview.png") no-repeat 30px center;
    color: var(--mono-color-9);
  }
}

/* breadCrumbs
----------------------------------------------- */
#breadCrumbs .pieceBody {
  max-width: var(--site-width);
  margin: 0 auto;
  padding: 16px 0 20px;
}

#breadCrumbs ol,
#breadCrumbs li {
  list-style: none;
}

#breadCrumbs li {
  display: inline-block;
}

#breadCrumbs li:not(:first-child)::before {
  content: ">";
  margin: 0 5px;
}

#breadCrumbs a {
  color: var(--mono-color-2);
  font-size: 0.75rem;
}

.bc-more {
  margin-top: 4px;
}

.bc-more a {
  display: inline-block;
  padding: 0 0 0 16px;
  background: url("../images/ic-breadcrumbs.svg") no-repeat left center;
}

.bc-more a.active {
  background-image: url("../images/ic-breadcrumbs_active.svg");
}

@media screen and (max-width: 959px) {
  #breadCrumbs {
    display: none;
  }
}

/* subHeader
----------------------------------------------- */
#subHeader {
  width: 100%;
  max-width: var(--site-width);
  margin: 16px auto;
}

#subHeader .pieceBody {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  margin-bottom: 20px;
  padding: 20px 10px 20px 25px;
  border: 1px solid #999;
  background: linear-gradient(to bottom, #fff, #f2f2f2);
}

#subHeader .pieceBody>* {
  flex-shrink: 1;
}

#subHeader .pieceBody h2 {
  font-size: 2rem;
}

#subHeader .pieceBody {
  padding: 0 0 0 40px;
}

@media screen and (max-width: 959px) {
  #subHeader .pieceBody {
    margin: 0 0 10px;
    padding: 15px 15px 20px;
    border-left: none;
    border-right: none;
  }

  #subHeader .pieceBody h2 {
    flex-shrink: 0;
    font-size: 1.5rem;
  }

  #subHeader .pieceBody {
    padding: 0 0 0 15px;
  }

  #subHeader .pieceBody h2 {
    margin-right: 25px;
  }
}

@media screen and (max-width: 559px) {
  #subHeader .pieceBody h2 {
    font-size: 1.25rem;
  }
}

/* page-title
----------------------------------------------- */
#pageTitle {
  margin-bottom: 30px;
  padding: 24px 20px;
  background-color: var(--main-color-13);
  background-image: url("../images/ic-pagetitle_left.svg"), url("../images/ic-pagetitle_right.svg");
  background-repeat: no-repeat;
  background-position: left -20px bottom -24px, right -10px top -10px;
}

#pageTitle h1 {
  color: var(--mono-color-9);
  font-size: 2rem;
  font-weight: bold;
}

/* commonFooter
----------------------------------------------- */
#pageFooter {
  background-color: var(--mono-color-11);
}

#pageFooter a {
  color: var(--mono-color-1);
}

#commonFooter {
  display: flex;
  font-size: 1rem;
}

#commonFooter .pieceContainer {
  width: 100%;
  max-width: var(--site-width);
  margin: 0 auto;
}

#commonFooter .pieceBody {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
}

#commonFooter address {
  display: flex;
  gap: 1rem;
}

#commonFooter h2 {
  margin-bottom: 15px;
}

#commonFooter ul {
  display: flex;
  align-items: center;
}

#commonFooter .menu {
  gap: 8px;
  margin-bottom: 22px;
}

#commonFooter .menu a {
  display: inline-block;
  line-height: 1;
  border: 1px solid var(--mono-color-12);
  background-color: var(--mono-color-9);
  text-decoration: none;
}

#commonFooter .menu a:focus {
  border-color: var(--mono-color-4);
  background-color: var(--mono-color-17);
}

#commonFooter .access a {
  padding: 10px;
}

#commonFooter .contact a {
  padding: 10px 25px;
}

#commonFooter .sns {
  gap: 27px;
  margin-bottom: 10px;
}

#commonFooter .sns a:focus {
  opacity: 0.75;
}

#commonFooter .location-map {
  margin-bottom: -48px;
}

@media screen and (min-width: 560px) {
  #commonFooter {
    padding: 57px 0 30px;
  }

  #commonFooter .pieceBody,
  #commonFooter address {
    align-items: flex-end;
  }

  #commonFooter .menu a:hover {
    border-color: var(--mono-color-4);
    background-color: var(--mono-color-17);
  }

  #commonFooter .sns a:hover {
    opacity: 0.75;
  }
}

@media screen and (max-width: 1200px) {
  #pageFooter {
    padding: 0 18px;
  }

  #commonFooter .menu {
    flex-wrap: wrap;
  }
}

@media screen and (max-width: 559px) {
  #pageFooter {
    padding: 32px 18px 30px;
  }

  #commonFooter .pieceBody,
  #commonFooter address {
    flex-direction: column;
  }

  #commonFooter .location-map {
    display: none;
  }
}

/* footerNavi
----------------------------------------------- */
#footerNavi .pieceContainer {
  margin: 0 auto;
}

#footerNavi ul {
  display: flex;
  flex-wrap: wrap;
  line-height: 1;
}

#footerNavi li:not(:last-child) {
  padding-right: 1rem;
  border-right: 1px solid var(--mono-color-1);
}

@media screen and (min-width: 960px) {
  #footerNavi .pieceContainer {
    max-width: var(--site-width);
    padding-bottom: 67px;
  }

  #footerNavi ul {
    gap: 0 1rem;
  }
}

@media screen and (max-width: 959px) {
  #footerNavi .pieceContainer {
    padding: 20px 0 30px;
  }

  #footerNavi ul {
    gap: 1rem;
  }
}

/* copyright
----------------------------------------------- */
#copyright {
  text-align: center;
}

#copyright small {
  font-size: 0.875rem;
}

@media screen and (min-width: 960px) {
  #copyright {
    padding: 8px;
    background-color: var(--main-color-2);
    color: var(--mono-color-9);
  }
}

@media screen and (max-width: 959px) {
  #copyright {
    padding: 0 18px 85px;
  }
}

/* feedDocs
----------------------------------------------- */
#feedDocs .feedBlock {
  display: flex;
  gap: 6px 1rem;
  flex-basis: 100%;
}

#feedDocs .feedBlock:not(:last-child) {
  margin-bottom: 4px;
}

#feedDocs .category {
  min-width: 7rem;
  padding: 0 6px;
  background-color: #e5f2ff;
  text-align: center;
}

/* ranking
----------------------------------------------- */
#ranking .pieceBody {
  padding: 12px;
}

#ranking li {
  display: flex;
  margin-bottom: 6px;
}

#ranking li span,
#ranking li a {
  display: inline-block;
  vertical-align: top;
}

#ranking li .rank {
  flex-basis: 20px;
  height: 20px;
  margin: 2px 10px 0 0;
  background-color: #bfe4f3;
  font-size: 0.875rem;
  text-align: center;
}

#ranking li a {
  flex: 1;
}

#ranking li .count {
  margin-left: auto;
}

#ranking .ranking1 .rank {
  background-color: #fbc93b;
}

#ranking .ranking2 .rank {
  background-color: var(--mono-color-6);
}

#ranking .ranking3 .rank {
  background-color: #c7b299;
}

/* relation-word
----------------------------------------------- */
#relationWord .pieceBody {
  padding: 12px;
}

#relationWord .pieceBody li {
  margin-left: 1.5rem;
  list-style-type: disc;
}

/* side-menu
----------------------------------------------- */
#sideMenu .pieceBody {
  padding: 12px;
}

#sideMenu h3 {
  font-size: 1rem;
  font-weight: normal;
}

#sideMenu h3,
#sideMenu li {
  padding: 0 0 0 16px;
  background: url("../images/ic-arrow.svg") left center no-repeat;
}

#sideMenu section:not(:last-child) h3,
#sideMenu section:not(:last-child) li {
  margin: 0 0 5px;
}

#sideMenu br {
  display: none;
}

@media screen and (max-width: 959px) {

  #sideMenu h3,
  #sideMenu li {
    margin: 0;
    padding: 6px 12px;
  }

  #sideMenu section:not(:last-child) h3,
  #sideMenu section:not(:last-child) li {
    border-bottom: 1px solid var(--mono-color-1);
  }

  #sideMenu a {
    display: block;
  }
}

/* calendar
----------------------------------------------- */
#calendar .pieceContainer,
#eventSearch .pieceContainer {
  position: relative;
  padding: 15px 12px 12px;
  border: 1px solid var(--mono-color-6);
  border-top: 4px solid var(--main-color-4);
  background-color: var(--mono-color-9);
}

#calendar .pieceContainer::after,
#eventSearch .pieceContainer::after {
  background-image: none;
  background-color: var(--main-color-4);
}

#calendar .pieceHeader,
#eventSearch .pieceHeader {
  padding: 0;
  background: none;
}

#calendar h2,
#eventSearch h2 {
  margin-bottom: 10px;
  padding: 12px;
  background: var(--main-color-16);
  font-size: 1.25rem;
  font-weight: bold;
  text-align: center;
}

#calendar h3,
#eventSearch h3 {
  margin-bottom: 8px;
  text-align: center;
}

#calendar table,
#eventSearch table {
  width: 100%;
  margin-bottom: 10px;
}

#calendar th,
#calendar td,
#eventSearch th,
#eventSearch td {
  padding: 2px 0;
  text-align: center;
}

#calendar table a,
#eventSearch table a {
  display: block;
  width: 1.6rem;
  line-height: 1.6rem;
  margin: 0 auto;
  background-color: var(--main-color-6);
  color: var(--mono-color-9);
  border-radius: 50%;
  text-decoration: none;
}

#calendar table a:hover,
#eventSearch table a:hover {
  opacity: 0.9;
}

@media screen and (max-width: 959px) {
  #calendar .pieceContainer #eventSearch .pieceContainer {
    max-width: 480px;
    margin: 0 auto;
  }
}

/* simple_tabs(todaysEvent)
----------------------------------------------- */
#simple_tabs {
  display: flex;
  flex-wrap: nowrap;
}

#simple_tabs li {
  flex-grow: 1;
  flex-basis: 0;
  padding: 8px 4px 7px;
  border-top: 1px solid var(--main-color-8);
  border-right: 1px solid var(--main-color-8);
  border-bottom: 1px solid var(--main-color-4);
  background: linear-gradient(to bottom, var(--mono-color-9), var(--main-color-10));
  color: var(--mono-color-1);
  font-weight: bold;
  text-align: center;
}

#simple_tabs li:first-child {
  border-left: 1px solid var(--main-color-8);
}

#simple_tabs li.current {
  padding-top: 7px;
  border-top: 2px solid var(--main-color-4);
  border-bottom: 0;
  background: linear-gradient(to bottom, var(--main-color-10), var(--mono-color-9));
}

#simple_tabs li:not(.current) {
  cursor: pointer;
}

#simple_tabs li:first-child.current {
  border-left: 1px solid var(--main-color-4);
}

#simple_tabs li:last-child.current {
  border-right: 1px solid var(--main-color-4);
}

#simple_tabs li a {
  text-decoration: none;
  color: inherit;
}

#simple_tab_panels>div {
  padding: 10px;
  border-style: solid;
  border-width: 0 1px 1px;
  border-color: var(--main-color-4);
}

#simple_tab_panels ul {
  list-style: inside disc;
}

#simple_tab_panels li {
  padding-left: 10px;
}

#simple_tab_panels li:not(:last-child) {
  margin: 0 0 5px;
}

/* feedback
----------------------------------------------- */
#feedback {
  margin-top: 40px;
}

#feedback .pieceHeader h2 {
  min-height: 0;
  padding: 5px 15px;
  border-color: var(--mono-color-6);
  background-color: var(--mono-color-6);
  color: inherit;
  font-size: 1.125rem;
  font-weight: bold;
}

#feedback .pieceHeader h2::before {
  display: none;
}

#feedback .pieceBody {
  padding: 15px;
  border: 1px solid var(--mono-color-6);
}

#feedback .pieceBody iframe {
  border: none;
}

@media screen and (max-width: 959px) {
  #feedback .pieceHeader h2 {
    font-size: 1rem;
  }

  #feedback .pieceBody {
    padding: 10px;
  }
}

/* archive
----------------------------------------------- */
#links .piece:not(:last-child) {
  margin-bottom: 30px;
}

#links .piece:not(#calendar):not(#eventSearch):not(#holidayCalendar) h2 {
  padding: 12px 12px 12px 46px;
  background: var(--main-color-16) url("../images/ic-similar.svg") no-repeat 15px center;
  font-size: 1.25rem;
  font-weight: bold;
}

#holidayCalendar .pieceHeader h2 {
  padding: 12px 12px 12px 46px;
  background: var(--main-color-16) url("../images/ic-similar.svg") no-repeat 15px center;
  font-size: 1.25rem;
  font-weight: bold;
}

#archive ul {
  padding: 0 0 0 1rem;
}

#archive li a {
  display: inline-block;
  position: relative;
  line-height: 1.5;
  padding: 8px 0 8px 16px;
  text-decoration: underline;
}

#archive li a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: var(--main-color-2);
}

#archive li a:hover,
#archive li a:focus {
  text-decoration: none;
}

@media only screen and (max-width: 959px) {
  #links li {}
}

/* sns parts
----------------------------------------------- */
#snsParts {
  margin: 30px 0;
}

#snsParts .pieceBody {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}

#snsParts .pieceBody>*:not(:first-child) {
  margin-left: 1rem;
}

#snsParts .fb-wrapper,
#snsParts .pocket-wrapper {
  margin-top: 1px;
}

.fb_iframe_widget {
  display: flex !important;
  align-items: flex-start;
}

/* gnavDocs / articleHeader
----------------------------------------------- */
#gnavDocs h2,
.articleHeader h2 {
  position: relative;
  padding-bottom: 10px;
  border-bottom: 3px solid transparent;
  border-image-source: linear-gradient(to right, var(--main-color-14) 0%, var(--main-color-14) 20px, var(--main-color-15) 20px, var(--main-color-15));
  border-image-slice: 1;
  font-size: 1.75rem;
  font-weight: bold;
}

@media screen and (min-width: 960px) {}

@media screen and (max-width: 959px) {}

/* =========================================================
  docs
========================================================= */
.docs-all li,
.docs_1 li,
.docs_kubun li,
ul.docs li,
.content li,
#similarDocs li,
#feedDocs li,
.entries li,
.dir-tags #content li,
.contentTagTag li,
.contentGpCategoryCategory .docs_1 ul:not(.feed) li,
.contentOrganizationGroupDepartment ul:not(.feed) li,
.contentOrganizationGroupUnit ul:not(.feed) li,
.dir-gomi-search .docs li,
.contentGpArticleDocs .docs li {
  display: flex;
  align-items: center;
  gap: 0 1rem;
  flex-wrap: wrap;
  line-height: 1.5;
  padding: 20px 0;
}

#similarDocs li,
.docs_1 li,
.docs_kubun li,
.dir-tags #content li,
.contentTagTag li,
.contentOrganizationGroupDepartment ul:not(.feed) li,
.contentOrganizationGroupUnit ul:not(.feed) li,
ul.docs li,
.content li,
.dir-gomi-search .docs li,
.contentGpArticleDocs .docs li {
  border-bottom: 1px dotted var(--mono-color-7);
}

.soshikiCategoryList div[id^="category"] ul.docs li {
  padding: 0;
}

.soshikiCategoryList div[id^="category"] ul.docs li,
#pickup ul.docs li {
  border: 0;
}

.docs-all li a,
.docs_1 li a,
.docs_kubun li a,
ul.docs li a,
.content li a,
#similarDocs li a,
#feedDocs li a,
.entries li a,
.dir-tags #content li a,
.contentTagTag li a,
.contentGpCategoryCategory .docs_1 ul:not(.feed) li a,
.contentOrganizationGroupDepartment ul:not(.feed) li a,
.contentOrganizationGroupUnit ul:not(.feed) li a,
.contentGpArticleDocs .docs li a {
  color: var(--mono-color-1);
}

.content li span[class^="title"] {
  font-size: 1rem;
}

#important .docs li {
  border: 0;
}

#important .docs li span[class^="title"] {
  font-size: 1.25rem;
}

#similarDocs li span[class$="date"] {
  color: var(--mono-color-2);
  font-size: 0.875rem;
}

.contentOrganizationGroupDepartment ul:not(.feed) li span[class$="date"],
.contentOrganizationGroupUnit ul:not(.feed) li span[class$="date"],
.dir-tags #content li span[class$="date"],
.contentTagTag li span[class$="date"],
.docs_1 li span[class$="date"],
.content li span[class$="date"],
.docs li span[class$="date"],
.docs_kubun li span[class$="date"],
.contentGpArticleDocs li span[class$="date"] {
  color: var(--mono-color-2);
  font-size: 1rem;
}

.docs+.more {
  text-align: right;
}

.articleHeader+ul+.more,
.articleHeader+ul+div .more {
  margin: 20px 0 0 auto;
  text-align: center;
}

.contentOrganization .articleHeader+ul+.more {
  margin-top: 30px;
}

.contentGpArticleDocs,
.contentGpCategory,
.contentOrganization,
.contentPortalEntries {
  position: relative;
}

.more a {
  color: var(--mono-color-1);
}

.contentOrganization .more a,
.contentGpCategory a.more,
.links .more a {
  display: inline-block;
  border: 1px solid var(--mono-color-10);
  color: var(--mono-color-1);
}

.feed {
  display: flex;
  align-items: center;
}

.links {
  position: relative;
  margin-top: 20px;
}

.links .feed {
  position: absolute;
  right: 0;
  top: calc(50% - 15px);
}

.feed li {
  min-height: 30px;
  line-height: 30px;
  border: 0;
}

.feed li:first-child {
  margin-right: 0.5rem;
  padding-left: 34px;
  background: url("../images/ic-rss.svg") no-repeat left center;
}

.feed a {
  color: var(--mono-color-1);
  text-decoration: underline;
}

.feed a:hover,
.feed a:focus {
  text-decoration: none;
}

.new_mark {
  display: inline-block;
  margin-left: 8px;
  background-color: #c000c0;
  padding: 2px 4px;
  font-size: 0.875rem;
  line-height: 1;
  color: #fff;
  border-radius: 2px;
}

@media screen and (min-width: 560px) {
  #important .docs li:last-child {
    padding-bottom: 0;
  }

  .links .more {
    text-align: center;
  }

  .contentOrganization .more a,
  .links .more a {
    padding: 10px 94px;
  }

  .contentOrganization .more a:hover,
  .contentOrganization .more a:focus,
  .contentGpCategory a.more:hover,
  .contentGpCategory a.more:focus,
  .links .more a:hover,
  .links .more a:focus {
    border-color: var(--mono-color-4);
    background-color: var(--mono-color-17);
    text-decoration: none;
  }
}

@media screen and (max-width: 559px) {

  .docs-all li,
  .docs_1 li,
  .docs_kubun li,
  ul.docs li,
  .content li,
  #similarDocs li,
  #feedDocs li,
  .entries li,
  .dir-tags #contentBody li,
  .contentTagTag li,
  .contentGpCategoryCategory .docs_1 ul:not(.feed) li,
  .contentOrganizationGroupDepartment ul:not(.feed) li,
  .contentOrganizationGroupUnit ul:not(.feed) li,
  .contentGpArticleDocs .docs li {
    line-height: 1.5;
    padding: 10px 0;
  }

  .docs li span[class^="title"] {
    font-size: 1.125rem;
  }

  .contentOrganization .more a,
  .contentGpCategory a.more,
  .links .more a {
    width: calc(100% - 130px);
    padding: 10px 0;
    text-align: center;
  }
}

/* contentGpArticleDocs, contentPortalEntries
----------------------------------------------- */
.contentGpArticleDocs .feed,
.contentPortalEntries .feed {
  position: absolute;
  right: 0;
  top: 1rem;
  z-index: 1;
}

.contentGpArticleDocs h2.date,
.contentPortalEntries h2.date {
  position: relative;
  padding: 0 126px 10px 0;
  border-bottom: 3px solid transparent;
  border-image-source: linear-gradient(to right, var(--main-color-14) 0%, var(--main-color-14) 20px, var(--main-color-15) 20px, var(--main-color-15));
  border-image-slice: 1;
  font-size: 1.75rem;
  font-weight: bold;
}

/* category-list
----------------------------------------------- */
div[id^="categoryList"] .pieceBody {
  padding: 12px;
}

div[id^="categoryList"] h3 {
  font-size: 1rem;
  font-weight: normal;
}

div[id^="categoryList"] h3,
div[id^="categoryList"] li {
  padding: 0 0 0 16px;
  background: url("../images/ic-arrow.svg") left center no-repeat;
}

div[id^="categoryList"] section:not(:last-child) h3,
div[id^="categoryList"] li:not(:last-child) {
  margin: 0 0 5px;
}

div[id^="categoryList"] br {
  display: none;
}

@media screen and (max-width: 959px) {
  div[id^="categoryList"] .pieceBody {
    padding: 0;
  }

  div[id^="categoryList"] h3,
  div[id^="categoryList"] li {
    margin: 0;
    padding: 11px 12px;
    background: none;
  }

  div[id^="categoryList"] section:not(:last-child) h3,
  div[id^="categoryList"] section:not(:last-child) li {
    border-bottom: 1px solid var(--mono-color-6);
  }

  div[id^="categoryList"] a {
    display: block;
  }
}

/* free-input-area
----------------------------------------------- */
#freeInputArea h2 {
  margin: 2rem 0 1rem;
  padding: 8px;
  background-color: var(--main-color-9);
  font-size: 1.25rem;
}

#freeInputArea h3 {
  margin: 1.5rem 0 1rem;
  padding: 4px 1rem;
  border: 1px solid var(--mono-color-3);
  font-size: 1.125rem;
}

#freeInputArea p {
  margin: 0 0 1rem;
}

/* biz-calendar piece
----------------------------------------------- */
#links #workHours .pieceBody,
#links #holidayList .pieceBody,
#links #holidayCalendar .pieceBody {
  padding: 12px;
}

#links #workHours .pieceBody .location+.location,
#links #holidayList .pieceBody .location+.location {
  margin-top: 10px;
}

#links #workHours .pieceBody .name,
#links #holidayList .pieceBody .name {
  font-weight: bold;
}

/* holidayCalendar
----------------------------------------------- */
#holidayCalendar .pieceHeader {
  padding: 0;
  background: none;
}

#holidayCalendar section h2 {
  text-align: center;
}

#holidayCalendar table {
  width: 100%;
  margin-bottom: 10px;
}

#holidayCalendar th,
#holidayCalendar td {
  padding: 2px 0;
  text-align: center;
}

#holidayCalendar table a {
  display: block;
  width: 1.6rem;
  line-height: 1.6rem;
  margin: 0 auto;
  background-color: var(--main-color-4);
  color: var(--mono-color-9);
  border-radius: 50%;
  text-decoration: none;
}

#holidayCalendar table a:hover {
  opacity: 0.9;
}

.calendarHolidays td.sat,
#holidayCalendar .sat {
  background-color: inherit;
}

.calendarHolidays td.sun,
.calendarHolidays td.holiday,
#holidayCalendar .sun,
#holidayCalendar .holiday {
  background-color: inherit;
}

.calendarHolidays td.normal,
.calendarHolidays td.closed,
.calendarHolidays td.extra,
#holidayCalendar .normal,
#holidayCalendar .closed,
#holidayCalendar .extra {
  background-color: #ffe6f1;
}

@media screen and (max-width: 959px) {
  #holidayCalendar .pieceContainer {
    max-width: 480px;
    margin: 0 auto;
  }
}

.calendarHolidays .attributeList {
  display: none;
}

/* receptionList
----------------------------------------------- */
#receptionList .pieceBody {
  padding: 12px;
}

#receptionList .courses li+li {
  margin: 12px 0 0;
}

#receptionList .courses .category span {
  display: inline-block;
  margin: 0 0 2px;
  padding: 0 2px;
  background-color: var(--main-color-9);
}

#receptionList .courses li>span+span {
  margin-left: 1rem;
}