@charset "UTF-8";

/* =========================================================
  top
========================================================= */
/* =========================================================
　　Flex Layout top 2column
========================================================= */
#content {
  flex-basis: 50%;
  margin-right: 40px;

}

#links {
  flex-basis: 50%;
}

#main .piece:not(#posterSlider) {
  margin-bottom: 30px;
}

#recentDocsTab {
  margin-bottom: 50px!important;
}

@media only screen and (max-width: 959px) {
  #content {
    flex-basis: 100%;
    margin-right: 0;
  }

  #links {
    flex-basis: 100%;
  }

  #links #lifeScene,
  #links #lifeGuide {
    margin-top: 0;
    margin-bottom: 0;
  }

  #links #lifeScene .pieceBody,
  #links #lifeGuide .pieceBody {
    margin-bottom: 30px;
  }
}

/* main-slider, poster-slider, banner slider
----------------------------------------------- */
div[id$="Slider"] .pieceBody {
  position: relative;
}

#mainSlider {
  margin: 0;
}

#mainSlider .pieceBody {
  width: 100%;
  margin: 0 auto;
}

#mainSlider .slick-slide {
  margin: 0;
}

#mainSlider .slick-arrow {
  display: none!important;
}

div[id$="Slider"] .bannerImages {
  display: none;
}

div[id$="Slider"] .slick-initialized {
  display: block;
}

.slick-track {
  display: flex;
}

#posterSlider .slick-track {
  align-items: center;
}

.slick-arrow {
  margin-top: 0;
}

#posterSlider .slick-arrow {
  transform: none;
  -ms-transform: none;
  -webkit-transform: none;
}
#posterSlider .slick-prev {
  left: 1.2%!important;
}
#posterSlider .slick-next {
  right: 1.2%!important;
}

.slick-arrow {
  top: 54%;
}

.piece:not(#posterSlider) .slick-next {
  right: -22px;
}

.piece:not(#posterSlider) .slick-prev {
  left: -22px;
}

.slick-dots li button {
  border: 2px solid var(--main-color-4);
}

.slick-dots li button:hover,
.slick-dots li button:focus {
  background-color: var(--main-color-4);
}

.slick-dots li.slick-active button {
  background-color: var(--main-color-4);
}

.slick-control button {
  background-color: var(--main-color-4);
}

.regular.slider {
  width: calc(100% - 40px)!important;
  margin-bottom: 30px;
}


/* poster-slider
----------------------------------------------- */
#posterSlider {
  width: 50vw;
  max-width: calc((var(--site-width) / 2) - 20px);
  padding-top: 18px;
  margin-bottom: 30px;
  border: solid 1px #4479c3;
}

#posterSlider .slick-list {
  width: 90%;
  margin: 0 auto;
}

@media only screen and (max-width: 959px) {
  #posterSlider {
    width: 100%;
    max-width: calc(100vw - 20px);
    margin-bottom: 30px;
  }
}

/* piece
----------------------------------------------- */
div[id^="life"] .pieceContainer,
#topicsDocs .pieceContainer,
#pickup .pieceContainer,
#eventList .pieceContainer,
#snsTimeline .pieceContainer,
#recentDocs .pieceContainer,
#feedDocs .pieceContainer {
  position: relative;
  padding: 10px 20px 20px;
  background-color: var(--mono-color-9);
}
#topicsDocs .pieceContainer,
#pickup .pieceContainer,
#eventList .pieceContainer,
#snsTimeline .pieceContainer,
#recentDocs .pieceContainer,
#feedDocs .pieceContainer {
  border: 1px solid var(--mono-color-6);
  border-top: 0;
}

#topicsDocs .pieceContainer {
  border: 0;
  border-radius: 20px;
  box-shadow: 2px 2px 10px rgba(0,0,0,.2);
}

div[id^="life"] .pieceContainer {
  margin-top: 34px;
  margin-bottom: 64px;
}

div[id^="life"] .pieceContainer::after,
#pickup .pieceContainer::after,
#eventList .pieceContainer::after,
#snsTimeline .pieceContainer::after,
#recentDocs .pieceContainer::after,
#feedDocs .pieceContainer::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 4px;
  background-color: var(--main-color-4);
}

#pickup .pieceHeader,
#eventList .pieceHeader,
#snsTimeline .pieceHeader,
#recentDocs .pieceHeader,
#feedDocs .pieceHeader {
  position: relative;
  padding: 15px 10px 15px 26px;
}

div[id^="life"] .pieceHeader,
#lifeBusiness .pieceHeader {
  position:  absolute;
  top: -34px;
  left: 0;
  height: 34px;
  color: #ffffff;
  line-height: 38px;
  border-radius: 8px 8px 0 0;
  padding: 0 16px;
  white-space: nowrap;
}
div[id^="life"] .pieceHeader h2,
#lifeBusiness .pieceHeader h2 {
  line-height: 40px;
  white-space: nowrap;
}
#topicsDocs .pieceHeader {
  position: relative;
  padding-bottom: 12px;
  margin-bottom: 14px;
}

#topicsDocs .pieceHeader:before {
  content: "";
  position: absolute;
  left: -20px;
  bottom: 0;
  display: block;
  width: calc(100% + 40px);
  height: 4px;
  background-color: var(--ac-color-red-1);
}

#topicsDocs .pieceHeader h2 {
  color: #d50000;
}

#pickup .pieceHeader::before,
#eventList .pieceHeader::before,
#snsTimeline .pieceHeader::before,
#recentDocs .pieceHeader::before,
#feedDocs .pieceHeader::before {
  content: "";
  position: absolute;
  top: 16px;
  left: 0;
  width: 12px;
  height: 12px;
  background-color: var(--main-color-4);
}

#pickup .pieceHeader::after,
#eventList .pieceHeader::after,
#snsTimeline .pieceHeader::after,
#recentDocs .pieceHeader::after,
#feedDocs .pieceHeader::after {
  content: "";
  position: absolute;
  top: 28px;
  left: 12px;
  width: 8px;
  height: 8px;
  background-color: var(--main-color-6);
}

/* 色分け */
#lifeGuide .pieceHeader,
#lifeGuide .pieceContainer::after,
#lifeGuide .pieceBody ul li a:hover {
  background-color: #84bb42!important;
}

#lifeScene .pieceHeader,
#lifeScene .pieceContainer:after,
#lifeScene .pieceBody ul li a:hover {
  background-color: #ee9334!important;
}

#lifeBusiness .pieceHeader {
  background-color: var(--main-color-4);
}

#lifeBusiness .pieceHeader,
#lifeBusiness .pieceContainer:after,
#lifeBusiness .pieceBody ul li a:hover {
  background-color: var(--main-color-4)!important;
}

#lifeGuide .pieceContainer {
  background-color: #dfeed3;
}
#lifeScene .pieceContainer {
  background-color: #ffefd9;
}
#lifeBusiness .pieceContainer {
  background-color: var(--main-color-9);
}
body[id^="page-index"] div[id^="life"] a {
  background-color: #ffffff!important;
}

/* life-guide, life-scene, life-business
----------------------------------------------- */
body[id^="page-index"] div[id^="life"] ul {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  flex-direction: row;
}

body[id^="page-index"] div[id^="life"] a:hover,
body[id^="page-index"] div[id^="life"] a:focus {
  background-color: var(--main-color-4);
  color: var(--mono-color-9);
}

body[id^="page-index"] div[id^="life"] a:hover img {
  filter: brightness(10);
}

body[id^="page-index"] div[id^="life"] .pieceContainer {
  padding: 15px;
}

body[id^="page-index"] div[id^="life"] .pieceBody {
  padding: 0;
}

body[id^="page-index"] div[id^="life"] li {
  width: calc(25% - 3px);
  padding: 0;
}

body[id^="page-index"] div[id^="life"] li:nth-child(4n) {
  margin-right: 0;
}

body[id^="page-index"] div[id^="life"] a {
  display: flex;
  flex-direction: column;
  padding: 10px 0;
  background-color: var(--main-color-9);
  border-radius: 6px;
  color: var(--mono-color-1);
  text-align: center;
  text-decoration: none;
}

body[id^="page-index"] div[id^="life"] a img {
  display: block;
  width: 50px;
  margin: 10px auto 20px;
}

body[id^="page-index"] div[id^="life"] a span {
  line-height: inherit;
}

body[id^="page-index"] div[id^="life"] .external {
  display: none;
}

@media only screen and (max-width: 959px) {
  body[id^="page-index"] div[id^="life"] li {
    width: calc(50% - 2.5px);
    border: none;
  }

  body[id^="page-index"] div[id^="life"] li:nth-child(even) {
    margin-right: 0;
  }

  body[id^="page-index"] div[id^="life"] a img {
    width: 48px;
  }
}

/* event-block
----------------------------------------------- */
.event-block {
  display: flex;
  flex-wrap: wrap;
}
.event-block > div {
  flex-basis: 48%;
}
.event-block > div:not(:first-child) {
  margin-left: auto;
}

@media only screen and (max-width: 559px) {
  .event-block > div {
    flex-basis: 100%;
    margin: 0 0 30px 0;
  }
}

/* event-list
----------------------------------------------- */
.calendarEvents table {
  width: 100%;
}

.calendarEvents th {
  padding: 8px 15px;
  background-color: var(--main-color-9);
  font-weight: normal;
  text-align: center;
}

.calendarEvents th:first-child {
  width: 10rem;
}

.calendarEvents th:not(:last-child) {
  border-right: 1px solid var(--main-color-8);
}

.calendarEvents td {
  padding: 8px;
  border-bottom: 1px solid var(--mono-color-6);
  vertical-align: middle;
}

.calendarEvents .image,
.calendarEvents .date {
  text-align: center;
}

.calendarEvents .image {
  width: 90px;
  text-align: center;
}

/* relation link
----------------------------------------------- */
#relationLink .pieceHeader {
  margin-bottom: 12px;
  padding: 2px 6px 2px 8px;
  border-left: 4px solid var(--main-color-4);
  background: none;
}

#relationLink .pieceContainer {
  padding: 0;
  border: none;
}

#relationLink .pieceContainer::after {
  background: none;
}

#relationLink ul {
  display: flex;
  gap: 12px;
  justify-content: flex-start;
  flex-wrap: wrap;
}

#relationLink li {
  display: flex;
  flex-basis: calc((100% - 12px) / 2);
}

#relationLink li a {
  position: relative;
  display: flex;
  align-items: center;
  line-height: 1.4;
  width: 100%;
  padding: 8px 16px;
  color: var(--mono-color-1);
  text-decoration: none;
  border: 1px solid var(--main-color-8);
  border-radius: 6px;
}

#relationLink li.shinsei {
  flex-basis: 100%;
}

#relationLink li.shinsei a {
  justify-content: center;
}

#relationLink li.shinsei a:before {
  content: "";
  display: block;
  width: 46px;
  height: 46px;
  background-image: url(/_themes/site/images/ic_shinsei.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-right: 12px;
}

#relationLink li a:hover,
#relationLink li a:focus {
  border-color: var(--main-color-6);
  color: var(--main-color-5);
}

@media only screen and (max-width: 559px) {
  #relationLink li {
    flex-basis: 100%;
  }

  #relationLink li:not(:nth-child(3n)) {
    margin-right: 0;
  }
}

/* shinsei link
----------------------------------------------- */
.shinsei-link {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-bottom: 40px;
}
.shinsei-link a {
  width: 100%;
  padding: 10px;
  display: flex;
  gap: 16px;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  color: var(--mono-color-9);
  font-size: 16px;
  border-radius: 12px;
  border: 1px solid var(--main-color-8);
  background-color: var(--main-color-4);
  margin-bottom: 20px;
}
.shinsei-link a:before {
  content: "";
  display: block;
  width: 60px;
  height: 60px;
  background-image: url(/_themes/site/images/ic_shinsei_w.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat!important;
  margin-right: 8px;
}
.shinsei-link a:hover {
  box-shadow: none;
  border-color: var(--main-color-4);
}
.shinsei-link .external {
    filter: grayscale(1) brightness(2)
}

/* about-mibu
----------------------------------------------- */
#about-mibu {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  position: relative;
  width: calc(100% + 240px);
  padding: 20px 120px 10px;
  background-color: var(--main-color-9);
  margin-left: -120px;
  margin-bottom: 30px;
}

#about-mibu > p {
  width: 100%;
  font-size: 22px;
  font-weight: bold;
  color: #333333;
  text-align: center;
  margin-bottom: 10px;
}

#about-mibu > p > img {
  width: 40px;
}

#about-mibu > p > span {
  display: block;
}

.about-menu {
  width: 52%;
}

.about-menu .btn-area {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
}

.character {
  width: 42%;
}

.about-menu ul {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.about-menu a {
  color: #333333;
  font-size: 15px;
  background-color: #ffffff;
  text-decoration: none;
}

@media only screen and (max-width: 389px) {
  .about-list li.mayer,
  .about-list li.council {
    width: 100%;
  }
}

@media only screen and (max-width: 959px) {
  #about-mibu {
    display: block;
    width: calc(100% + 20px);
    margin-left: -10px;
    padding: 20px;
  }
  .about-menu,
  .character {
     width: 100%;
 }
  .about-menu {
    margin-bottom: 40px;
  }
  .character {
    background-size: 60%!important;
    background-position: top center;
    padding-top: 13%!important;
  }
  .character ul {
    flex-wrap: nowrap!important;
  }
  .character li {
    width: auto!important;
    min-width: initial!important;
  }
  .character img {
    border-radius: 160px!important;
  }
  .character a:hover img {
    transform: unset!important;
  }
}

@media only screen and (max-width: 559px) {
  .character {
    background-size: 80%!important;
  }
}

@media only screen and (max-width: 499px) {
  .about-menu li a {
    font-size: 0.7em;
    text-align: center;
  }
  .about-menu .mayer img,
  .about-menu .summary img,
  .about-menu .council img {
    width: 70px;
  }
}

/* ようこそ町長室へ・壬生町議会 */
.about-menu li.mayer,
.about-menu li.summary,
.about-menu li.council {
  width: calc(33.333% - 4px);
  text-align: center;
}

.about-menu .mayer a,
.about-menu .summary a,
.about-menu .council a {
  display: block;
  align-items: center;
  border: 1px solid #ffffff;
  border-radius: 8px;
  padding: 8px;
}

.about-menu .mayer a:hover,
.about-menu .summary a:hover,
.about-menu .council a:hover {
  border-color: var(--main-color-6);
}

.about-menu .mayer a span:not(.image),
.about-menu .summary a span:not(.image),
.about-menu .council a span:not(.image) {
  white-space: nowrap;
}

.about-menu .mayer span:not(.image),
.about-menu .summary span:not(.image),
.about-menu .council span:not(.image) {
  display: block;
  text-align: center;
}

.about-menu .mayer img,
.about-menu .summary img,
.about-menu .council img {
  justify-content: center;
  align-items: center;
  max-width: 86px;
  height: auto;
  border-radius: 50px;
  border: 2px solid var(--main-color-9);
  background-color: #ffffff;
  object-fit: cover;
}

/* それ以外 */
.about-menu li:not(.mayer):not(.summary):not(.council) {
  width: calc(33.333% - 4px);
  min-height: 90px;
}

.about-menu li:not(.mayer):not(.summary):not(.council) a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 100%;
  border-radius: 8px;
  border: 1px solid #ffffff;
  text-align: center;
  padding: 8px 6px;
}

.about-menu li a {
  width: 100%;
  text-decoration: none;
  box-shadow: 2px 2px 4px rgba(186,186,186,.4);
}

.about-menu li a:hover {
  box-shadow: none;
}

.about-menu ul:last-child li:first-child a:hover {
  border-color: var(--main-color-4);
}

.about-menu ul:last-child li:nth-child(2) a:hover {
  border-color: #84bb42;
}

.about-menu ul:last-child li:last-child a:hover {
  border-color: #ed5389;
}

.about-menu li:not(.mayer):not(.summary):not(.council) .image {
  display: block;
  height: 36px;
  margin: 0 auto 8px;
}

.about-menu li:not(.mayer):not(.summary):not(.council) .image img {
  height: 100%;
}

.about-menu li:not(.mayer):not(.summary):not(.council) a span:not(.image) {
  display: block;
  width: 100%;
  line-height: 1.3;
}

.about-menu .benrichou .external {
    display: none;
}

/* population
----------------------------------------------- */
.population {
  position: relative;
  padding: 10px 15px;
  background-color: #ffffff;
}

.ppl-ttl {
  margin-bottom: 20px;
}
.ppl-ttl span {
  font-size: 14px;
}

.population ul {
  display: flex;
  flex-wrap: wrap;
}
.population li {
  display: flex;
  align-items: center;
  width: calc(50% - 4px)!important;
  min-height: initial!important;
}
.population li p {
  font-size: 15px;
}
.population li p:first-child {
  width: 76px;
  text-align: center;
  border-radius: 4px;
  padding: 4px 12px;
  margin-right: 10px;
}
.population li:first-child p:first-child {
  background-color: #f5efaa;
}
.population li:nth-child(2) p:first-child {
  background-color: #d4eec2;
}
.population li:nth-child(3) p:first-child {
  background-color: #f6d8de;
}
.population li:last-child p:first-child {
  background-color: #c1dbf5;
}

/* related-organization
----------------------------------------------- */
#relatedOrganization ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#relatedOrganization li {
  width: calc((100% - 24px) / 2);
  margin-bottom: 12px;
}

#relatedOrganization li a {
  display: flex;
  align-items: center;
  line-height: 1.4;
  border: 1px solid var(--mono-color-6);
  border-radius: 5px;
  background: linear-gradient(to bottom, var(--mono-color-9), var(--mono-color-8));
  color: var(--mono-color-1);
  text-decoration: none;
  overflow: hidden;
}

#relatedOrganization li a:hover,
#relatedOrganization li a:focus {
  background: linear-gradient(to bottom, var(--mono-color-8), var(--mono-color-9));
}

#relatedOrganization li .image {
  flex-basis: 64px;
  padding: 10px 0;
  border-right: 1px solid var(--mono-color-6);
  text-align: center;
}

#relatedOrganization li svg {
  fill: var(--main-color-4);
}

#relatedOrganization li a span + span {
  flex-basis: calc(100% - 64px);
  padding: 8px 12px;
}

@media only screen and (max-width: 559px) {
  #relatedOrganization li {
    width: 100%;
  }
}

/* sns-timeline
----------------------------------------------- */
#snsTimeline .pieceBody {
  text-align: center;
}

/* character
----------------------------------------------- */
.character {
  position: relative;
  text-align: center;
  padding: 6.5% 0 10px;
  background-image: url(https://www.town.mibu.tochigi.jp/_themes/site/images/character_bg.png);
  background-repeat: no-repeat;
  background-size: contain;
}

.character ul {
  display: flex;
  justify-content: center;
  align-content: center;
  flex-wrap: wrap;
  gap: 2%;
}

.character li {
  width: 28%;
  min-width: 124px;
}

.character a:hover img {
  transform: scale(1.1);
}
.character img {
  object-fit: cover;
  transition: all .2s;
  -webkit-transition: all .2s;
  -ms-transition: all .2s;
  border: 2.5px solid #b8dfed;
  border-radius: 100px;
}

@media only screen and (max-width: 559px) {
  .character ul {
    flex-wrap: wrap!important;
  }
  .character li {
    width: 32%!important;
  }
  .character img {
    width: 100%;
    max-width: initial;
  }
}

/* information
----------------------------------------------- */
#information {
  display: flex;
  justify-content: space-between;
}

#information .pieceContainer {
  height: 100%;
  border: 3px solid var(--main-color-8);
  border-radius: 10px;
}

#information .pieceHeader {
  padding: 8px;
  background-color: var(--main-color-8);
  text-align: center;
  border-radius: 6px 6px 0 0;
}

#information .pieceBody {
  padding: 10px;
}

#information .piece {
  flex-basis: 32%;
}

#information .piece li {
  display: flex;
  align-items: center;
  padding: 4px 0;
  border-bottom: 1px dashed var(--mono-color-6);
}

#information .piece:not(#ranking) li:before {
  content: "";
  width: 12px;
  height: 12px;
  background-color: var(--main-color-8);
  border-radius: 6px;
  margin-right: 8px;
  display: block;
}

#information .piece a {
  text-decoration: none;
}

@media only screen and (max-width: 959px) {
  div[id^="life"] .pieceContainer {
    margin-top: 10px;
  }

  #information {
    flex-wrap: wrap;
  }

  #information .piece {
    flex-basis: 49%;
  }

  #information .piece:nth-child(even) {
    margin-right: 0;
  }

  #information .pieceBody {
    padding: 0 8px;
  }

  #information ul {
    display: flex;
    flex-direction: column;
  }

  #information li {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    margin-bottom: 0;
    border-bottom: 1px dashed var(--mono-color-6);
  }

  #information li:last-child {
    border-bottom: 0!important;
  }

  #information .piece:not(#ranking) li {
    background-position: 16px center;
  }

  #information a {
    display: block;
    width: 100%;
  }

  #information .piece:not(#ranking) a {
    padding: 4px 0;
  }

  #information #ranking li {
    margin-bottom: 0;
  }

  #information #ranking span {
    margin: 0 10px;
  }

  #information  #ranking .pieceBody {
    padding: 6px 8px;
  }

  #ranking .more a {
    margin-top: 2px;
  }
}

@media only screen and (max-width: 559px) {
  #information .piece {
    flex-basis: 100%;
    margin: 0 0 20px;
  }
}

/* more button
----------------------------------------------- */
.piece:not(#ranking) .more {
  flex-basis: unset!important;
  margin-top: 0;
  width: 76px;
  text-align: left;
  border: 0;
  padding: 0;
  margin: 14px 0 0 auto;
}

.piece:not(#ranking) .more a {
  display: flex!important;
  justify-content: space-between!important;
  align-items: center!important;
  position: relative;
  color: var(--main-color-1)!important;
  border: 0!important;
  margin: 0!important;
  padding: 0!important;
}

.piece:not(#ranking) .more a:hover {
  background-color: transparent!important;
  color: var(--main-color-4)!important;
}

.piece:not(#ranking) .more a:hover:before {
  background-color: var(--main-color-4)!important;
}

.piece:not(#ranking) .more a:before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  display: block;
  width: 20px;
  height: 20px;
  background-color: var(--main-color-1);
  border-radius: 10px;
}

.piece:not(#ranking) .more a:after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-top: 2px solid #ffffff;
  border-right: 2px solid #ffffff;
  transform: rotate(45deg);
  -werbkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  margin-right: 7px;
}