@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
html {
  margin-top: 0 !important;
  scroll-behavior: smooth;
}

article, aside, details, figcaption, figure, footer, header, hgroup, nav, section, summary {
  display: block;
}

audio, canvas, video {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

[hidden] {
  display: none;
}

body {
  margin: 0;
  padding: 0;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

a {
  outline: 0;
  box-sizing: border-box;
}

li {
  margin: 0;
  padding: 0;
  list-style-position: inside;
  list-style-type: none;
  line-height: 150%;
}

dl, menu, ol, ul {
  margin: 0;
  padding: 0;
}

dt, dd {
  margin: 0;
  padding: 0;
  line-height: 150%;
}

nav ul, nav ol {
  list-style: none;
  list-style-image: none;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

figure {
  margin: 0;
  padding: 0;
}

form {
  margin: 0;
  padding: 0;
}

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0;
  padding: 0;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  white-space: normal;
  padding: 0;
}

button, input, select, textarea {
  padding: 0;
}

button, input {
  line-height: normal;
}

button, html input[type=button] {
  -webkit-appearance: button;
}

button[disabled], input[disabled] {
  cursor: default;
}

input[type=checkbox], input[type=radio] {
  box-sizing: border-box;
}

input[type=search] {
  -webkit-appearance: textfield;
  -webkit-box-sizing: content-box;
}

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

input[type=reset],
input[type=submit] {
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
}

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
}

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

th, td {
  line-height: 150%;
}

body {
  color: #333;
  font-family: "Noto Sans JP", serif;
}

h1, h2, h3, h4, h5, h6, p, li, th, td, dt, dd, pre, code, input, textarea, button, select, option, blockquote, q {
  font-feature-settings: "palt";
  -webkit-font-feature-settings: palt;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

div, section, header, footer, nav, figure, ul, dl, table {
  box-sizing: border-box;
}

select {
  width: 100%;
  padding: 10px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 1px solid #ccc;
  background: #E7E7E7;
  border-radius: 10px;
}

#wpadminbar {
  position: relative;
}

@media (width > 1200px) {
  .row {
    display: flex;
    align-items: stretch;
    justify-content: start;
  }
}
.row .col {
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: auto;
}

.cover {
  position: relative;
  min-height: 100px;
}
.cover .bg img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  object-fit: cover;
  object-position: center;
  z-index: 1;
}
.cover .content {
  position: relative;
  z-index: 5;
}

@media (width > 1200px) {
  .group0 {
    padding-left: 60px;
    padding-right: 60px;
  }
}
@media (width <= 1200px) {
  .group0 {
    padding-left: 30px;
    padding-right: 30px;
  }
}

.group1 {
  max-width: 1260px;
  padding-left: 30px;
  padding-right: 30px;
  justify-self: center;
  margin-left: auto;
  margin-right: auto;
}

.media-text {
  display: flex;
}
@media (width <= 1200px) {
  .media-text {
    flex-flow: wrap;
  }
}
@media (width <= 1200px) {
  .media-text .media {
    order: 1;
  }
}
.media-text .media img {
  max-width: 100%;
  display: block;
}
@media (width <= 1200px) {
  .media-text .content {
    order: 2;
  }
}
@media (width <= 1200px) {
  .media-text.reverse .media {
    order: 2;
  }
}
@media (width <= 1200px) {
  .media-text.reverse .content {
    order: 1;
  }
}

.spacer5 {
  display: block;
}
@media (width > 782px) {
  .spacer5 {
    height: 5px;
  }
}
@media (width <= 782px) {
  .spacer5 {
    height: 2px;
  }
}

.op0 {
  opacity: 0;
}

.spacer10 {
  display: block;
}
@media (width > 782px) {
  .spacer10 {
    height: 10px;
  }
}
@media (width <= 782px) {
  .spacer10 {
    height: 4px;
  }
}

.op5 {
  opacity: 0.05;
}

.spacer15 {
  display: block;
}
@media (width > 782px) {
  .spacer15 {
    height: 15px;
  }
}
@media (width <= 782px) {
  .spacer15 {
    height: 6px;
  }
}

.op10 {
  opacity: 0.1;
}

.spacer20 {
  display: block;
}
@media (width > 782px) {
  .spacer20 {
    height: 20px;
  }
}
@media (width <= 782px) {
  .spacer20 {
    height: 8px;
  }
}

.op15 {
  opacity: 0.15;
}

.spacer25 {
  display: block;
}
@media (width > 782px) {
  .spacer25 {
    height: 25px;
  }
}
@media (width <= 782px) {
  .spacer25 {
    height: 10px;
  }
}

.op20 {
  opacity: 0.2;
}

.spacer30 {
  display: block;
}
@media (width > 782px) {
  .spacer30 {
    height: 30px;
  }
}
@media (width <= 782px) {
  .spacer30 {
    height: 12px;
  }
}

.op25 {
  opacity: 0.25;
}

.spacer35 {
  display: block;
}
@media (width > 782px) {
  .spacer35 {
    height: 35px;
  }
}
@media (width <= 782px) {
  .spacer35 {
    height: 14px;
  }
}

.op30 {
  opacity: 0.3;
}

.spacer40 {
  display: block;
}
@media (width > 782px) {
  .spacer40 {
    height: 40px;
  }
}
@media (width <= 782px) {
  .spacer40 {
    height: 16px;
  }
}

.op35 {
  opacity: 0.35;
}

.spacer45 {
  display: block;
}
@media (width > 782px) {
  .spacer45 {
    height: 45px;
  }
}
@media (width <= 782px) {
  .spacer45 {
    height: 18px;
  }
}

.op40 {
  opacity: 0.4;
}

.spacer50 {
  display: block;
}
@media (width > 782px) {
  .spacer50 {
    height: 50px;
  }
}
@media (width <= 782px) {
  .spacer50 {
    height: 20px;
  }
}

.op45 {
  opacity: 0.45;
}

.spacer55 {
  display: block;
}
@media (width > 782px) {
  .spacer55 {
    height: 55px;
  }
}
@media (width <= 782px) {
  .spacer55 {
    height: 22px;
  }
}

.op50 {
  opacity: 0.5;
}

.spacer60 {
  display: block;
}
@media (width > 782px) {
  .spacer60 {
    height: 60px;
  }
}
@media (width <= 782px) {
  .spacer60 {
    height: 24px;
  }
}

.op55 {
  opacity: 0.55;
}

.spacer65 {
  display: block;
}
@media (width > 782px) {
  .spacer65 {
    height: 65px;
  }
}
@media (width <= 782px) {
  .spacer65 {
    height: 26px;
  }
}

.op60 {
  opacity: 0.6;
}

.spacer70 {
  display: block;
}
@media (width > 782px) {
  .spacer70 {
    height: 70px;
  }
}
@media (width <= 782px) {
  .spacer70 {
    height: 28px;
  }
}

.op65 {
  opacity: 0.65;
}

.spacer75 {
  display: block;
}
@media (width > 782px) {
  .spacer75 {
    height: 75px;
  }
}
@media (width <= 782px) {
  .spacer75 {
    height: 30px;
  }
}

.op70 {
  opacity: 0.7;
}

.spacer80 {
  display: block;
}
@media (width > 782px) {
  .spacer80 {
    height: 80px;
  }
}
@media (width <= 782px) {
  .spacer80 {
    height: 32px;
  }
}

.op75 {
  opacity: 0.75;
}

.spacer85 {
  display: block;
}
@media (width > 782px) {
  .spacer85 {
    height: 85px;
  }
}
@media (width <= 782px) {
  .spacer85 {
    height: 34px;
  }
}

.op80 {
  opacity: 0.8;
}

.spacer90 {
  display: block;
}
@media (width > 782px) {
  .spacer90 {
    height: 90px;
  }
}
@media (width <= 782px) {
  .spacer90 {
    height: 36px;
  }
}

.op85 {
  opacity: 0.85;
}

.spacer95 {
  display: block;
}
@media (width > 782px) {
  .spacer95 {
    height: 95px;
  }
}
@media (width <= 782px) {
  .spacer95 {
    height: 38px;
  }
}

.op90 {
  opacity: 0.9;
}

.spacer100 {
  display: block;
}
@media (width > 782px) {
  .spacer100 {
    height: 100px;
  }
}
@media (width <= 782px) {
  .spacer100 {
    height: 40px;
  }
}

.op95 {
  opacity: 0.95;
}

.row {
  display: flex;
  align-items: stretch;
  justify-content: start;
}

.media-text {
  display: flex;
}
@media (width > 782px) {
  .media-text {
    flex-flow: nowrap;
  }
}
@media (width <= 782px) {
  .media-text {
    flex-flow: wrap;
  }
}

@media (width <= 782px) {
  img {
    max-width: 100%;
  }
}

@media (width <= 1200px) {
  body {
    padding-top: 40px;
  }
}

body.home,
body.default {
  background: #f2f2f2;
}

header {
  width: 100%;
  max-width: 1110px;
  padding-left: 30px;
  padding-right: 30px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  top: -1px;
}
@media (width > 1200px) {
  header {
    margin-bottom: 30px;
  }
}
header > ul {
  align-items: stretch;
  justify-content: end;
  gap: 11px;
}
@media (width > 1200px) {
  header > ul {
    display: flex;
  }
}
@media (width <= 1200px) {
  header > ul {
    display: none;
  }
}
@media (width > 1200px) {
  header > ul li {
    width: 200px;
  }
}
@media (width <= 1200px) {
  header > ul li {
    flex: 0 0 fit-content;
  }
}
header > ul a {
  display: block;
  background: #F15A24;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(20px,2.0952380952vw,22px);
  text-decoration: none;
  border-radius: 0 0px 10px 10px;
  border: 1px solid #fff;
  border-top: none !important;
  transition: all 0.3s ease 0s;
}
@media (width > 1200px) {
  header > ul a {
    height: 83px;
  }
}
header > ul a:hover {
  background: #f7931e;
}
header li.home {
  margin-right: auto;
  margin-left: 0;
  display: none;
}
header li.home a {
  background: #fff;
  border-color: #F15A24;
  color: #F15A24;
}

body.default header li.home {
  display: block;
}

body.local-government {
  background: #fbb03b;
}

body.introduction {
  background: #0071bc;
}

body.construction {
  background: #c69c6d;
}

body.medical {
  background: #009245;
}

.site-title {
  margin-top: clamp(30px,5.7142857143vw,60px);
}
.site-title h1 {
  font-size: clamp(30px,4.7619047619vw,50px);
  color: #F15A24;
  margin-bottom: clamp(25px,4.2857142857vw,45px);
  line-height: 140%;
  text-align: center;
}

.lower-site-title .label {
  font-size: clamp(18px,2.2857142857vw,24px);
  display: block;
  width: fit-content;
  line-height: 100%;
  border: 1px solid #fff;
  color: #fff;
  padding: 6px 15px;
  margin-bottom: 30px;
}
@media (width > 1200px) {
  .lower-site-title .label {
    margin-top: calc(clamp(40px,7.619047619vw,80px) * -1);
  }
}
.lower-site-title h1 {
  font-size: clamp(24px,3.8095238095vw,40px);
  text-align: left;
  color: #fff;
}

footer {
  width: 100%;
  max-width: 1110px;
  padding-left: 30px;
  padding-right: 30px;
  margin-left: auto;
  margin-right: auto;
  margin-top: clamp(30px,6.6666666667vw,70px);
}
footer .main-navigation h2 {
  font-size: clamp(20px,3.4285714286vw,36px);
  text-align: center;
  color: #F15A24;
}
footer .sticky {
  position: fixed;
  left: 0;
  width: 100%;
  transition: all 0.3s ease 0s;
}
@media (width > 782px) {
  footer .sticky {
    top: -100px;
  }
  footer .sticky.intersected {
    top: 0;
  }
}
@media (width <= 782px) {
  footer .sticky {
    bottom: -100px;
  }
  footer .sticky.intersected {
    bottom: 0;
  }
}
footer .sticky nav {
  max-width: 1050px;
  margin-left: auto;
  margin-right: auto;
}
footer .sticky nav ul {
  display: flex;
  align-items: stretch;
  justify-content: center;
  flex-flow: wrap;
}
footer .sticky nav li {
  flex: 1;
}
@media (width <= 782px) {
  footer .sticky nav li {
    flex: 0 0 50%;
  }
}
footer .sticky nav a {
  font-size: clamp(14px,1.7142857143vw,18px);
}
@media (width > 782px) {
  footer .sticky nav a {
    height: 60px;
  }
}
@media (width <= 782px) {
  footer .sticky nav a {
    padding: 3px 0;
  }
}
footer .bottom nav {
  margin-top: clamp(15px,2.8571428571vw,30px);
}
footer .bottom nav ul {
  display: flex;
  flex-direction: row;
  flex-flow: wrap;
  align-items: stretch;
  justify-content: center;
}
@media (width > 782px) {
  footer .bottom nav ul {
    gap: 25px 60px;
  }
}
@media (width <= 782px) {
  footer .bottom nav ul {
    gap: 5px;
  }
}
@media (width > 782px) {
  footer .bottom nav li {
    flex: 0 0 calc((100% - 60px) / 2);
  }
}
@media (width <= 782px) {
  footer .bottom nav li {
    flex: 0 0 calc((100% - 5px) / 2);
  }
}
footer .bottom nav a {
  border: 2px solid #fff;
  font-size: clamp(20px,3.4285714286vw,36px);
}
@media (width > 782px) {
  footer .bottom nav a {
    border-radius: 20px;
    height: 100px;
  }
}
@media (width <= 782px) {
  footer .bottom nav a {
    border-radius: 10px;
    padding: 20px 10px;
    line-height: 100%;
  }
}
footer nav a {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-decoration: none;
  transition: all 0.3s ease 0s;
}
footer nav li.bg-local-government a {
  background: #fbb03b;
}
footer nav li.bg-local-government a:hover {
  background: #FBCC8E;
}
footer nav li.bg-introduction a {
  background: #0071bc;
}
footer nav li.bg-introduction a:hover {
  background: #0287EC;
}
footer nav li.bg-construction a {
  background: #c69c6d;
}
footer nav li.bg-construction a:hover {
  background: #D7B99D;
}
footer nav li.bg-medical a {
  background: #009245;
}
footer nav li.bg-medical a:hover {
  background: #02C75A;
}
footer .rights {
  font-size: clamp(13px,1.3333333333vw,14px);
  margin-top: clamp(25px,4.7619047619vw,50px);
  margin-bottom: clamp(30px,5.7142857143vw,60px);
  text-align: center;
}

body.lower footer {
  margin-top: 30px;
  margin-bottom: 30px;
}
body.lower footer .main-navigation {
  display: none;
}
body.lower .rights {
  color: #fff;
}

body.default .rights {
  color: #333;
}

.tl {
  text-align: left;
}

.tc {
  text-align: center;
}

.tr {
  text-align: right;
}

.gird {
  display: grid;
}

.row {
  display: flex;
  align-items: stretch;
  justify-content: start;
}
@media (width > 782px) {
  .row {
    gap: 20px;
  }
  .row.minimum .col {
    flex: 0 1 fit-content;
  }
}
@media (width <= 782px) {
  .row {
    gap: 0px;
    flex-flow: wrap;
  }
  .row.minimum .col {
    flex: 1 0 fit-content;
  }
}

.fit-content {
  width: fit-content;
}

.list01 {
  padding-left: 24px;
}
.list01 li {
  list-style-type: disc;
  list-style-position: outside;
}

.some-list01 {
  padding-left: 20px;
}
.some-list01 li {
  text-indent: -18px;
}

.color-orange {
  color: #F15A24;
}

.color-local-government {
  color: #fbb03b;
}

.color-introduction {
  color: #0071bc;
}

.color-construction {
  color: #c69c6d;
}

.color-medical {
  color: #009245;
}

.intersection-target {
  position: absolute;
  width: 10px;
  height: 100%;
  z-index: 100;
  top: calc(100vh + 300px);
  left: 0;
}

.main-content {
  width: 100%;
  max-width: 1110px;
  margin-left: auto;
  margin-right: auto;
}
@media (width > 782px) {
  .main-content {
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media (width <= 782px) {
  .main-content {
    padding-left: 10px;
    padding-right: 10px;
  }
}
.main-content img {
  max-width: 100%;
}

.content-area {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
}
@media (width > 1200px) {
  .content-area {
    padding-left: 40px;
    padding-right: 40px;
    padding-top: 20px;
    padding-bottom: 30px;
  }
}
@media (width <= 1200px) {
  .content-area {
    padding-left: 20px;
    padding-right: 20px;
    padding-top: 20px;
    padding-bottom: 30px;
  }
}
.content-area + .content-area {
  margin-top: 30px;
}
.content-area section {
  float: none;
  clear: both;
}
.content-area section:after {
  content: "";
  display: block;
  float: none;
  clear: both;
}
.content-area section + section {
  margin-top: clamp(25px,4.7619047619vw,50px);
}
.content-area p, .content-area li, .content-area th, .content-area td, .content-area dt, .content-area dd {
  font-size: clamp(16px,1.7142857143vw,18px);
  line-height: 180%;
}
.content-area a {
  color: inherit;
  text-decoration: none;
}
@media (width > 782px) {
  .content-area .fright {
    margin-bottom: 40px;
    margin-left: 40px;
  }
}
@media (width <= 782px) {
  .content-area .fright {
    margin-bottom: 20px;
  }
}
.content-area .fleft {
  margin-bottom: 40px;
}
@media (width > 782px) {
  .content-area .fleft {
    margin-right: 40px;
  }
}
.content-area .base-content {
  float: none;
  clear: both;
}
.content-area .base-content + .base-content {
  margin-top: clamp(30px,5.7142857143vw,60px);
}

.main-visual {
  text-align: center;
  padding-bottom: 0;
}
.main-visual img {
  display: block;
}

.heading01 {
  color: #F15A24;
  font-size: clamp(22px,3.4285714286vw,36px);
  margin-bottom: 25px;
  text-align: center;
  font-weight: bold;
}

.heading02 {
  color: #f7931e;
  font-size: clamp(20px,2.0952380952vw,22px);
  font-weight: normal;
  margin-bottom: 20px;
}

.heading03 {
  color: #f7931e;
  font-size: clamp(20px,2.8571428571vw,30px);
  text-align: center;
  margin-bottom: 20px;
}

.heading04 {
  color: #F15A24;
  font-size: clamp(15px,2vw,21px);
  text-align: center;
  margin-bottom: 10px;
  font-weight: normal;
}

.heading05 {
  color: #1b1464;
  margin-bottom: clamp(10px,2.8571428571vw,30px);
}
.heading05 span.label {
  background: #1b1464;
  color: #fff;
  display: inline-block;
  line-height: 100%;
  padding: 10px 20px;
  margin-right: 30px;
  font-size: clamp(16px,2.2857142857vw,24px);
}
@media (width <= 782px) {
  .heading05 .title {
    display: block;
  }
}

.heading06 {
  color: #F15A24;
  font-size: clamp(18px,2.4761904762vw,26px);
  text-align: center;
  margin-bottom: 20px;
}

.heading07 {
  color: #0071bc;
  font-size: clamp(20px,2.8571428571vw,30px);
  margin-bottom: 20px;
}

.heading08 {
  color: #1b1464;
  text-align: center;
  margin-bottom: 20px;
  font-size: clamp(16px,1.9047619048vw,20px);
  font-weight: normal;
}

.heading09 {
  color: #0071bc;
  text-align: center;
  margin-bottom: 20px;
  font-size: clamp(22px,3.4285714286vw,36px);
}

.heading10 {
  background: #2e3192;
  color: #fff;
  text-align: center;
  margin-bottom: 30px;
  font-size: clamp(20px,2.0952380952vw,22px);
  padding: 10px;
  line-height: 100%;
  border-radius: 15px;
}

.heading11 {
  font-size: clamp(16px,1.9047619048vw,20px);
  color: #1b1464;
  margin-bottom: 15px;
  font-weight: normal;
}

.heading12 {
  font-size: clamp(16px,1.9047619048vw,20px);
  color: #F15A24;
  margin-bottom: 15px;
  font-weight: normal;
}

.heading13 {
  font-size: clamp(20px,2.0952380952vw,22px);
  color: #29abe2;
  margin-bottom: clamp(10px,1.9047619048vw,20px);
  font-weight: normal;
}

.heading14 {
  font-size: clamp(14px,1.7142857143vw,18px);
  background: #4d4d4d;
  color: #fff;
  width: fit-content;
  padding: 10px 20px;
  margin-bottom: 20px;
  line-height: 100%;
}

.heading15 {
  font-size: clamp(20px,2.8571428571vw,30px);
  background: #F15A24;
  color: #fff;
  border-radius: 20px;
  padding: 10px;
  text-align: center;
  margin-bottom: 40px;
}

.heading16 {
  color: #a67c52;
  text-align: center;
  margin-bottom: 20px;
  font-size: clamp(20px,2.8571428571vw,30px);
}

.heading17 {
  color: #a67c52;
  font-size: clamp(16px,2vw,21px);
  margin-bottom: 10px;
  font-weight: normal;
}

.heading18 {
  color: #009245;
  text-align: center;
  margin-bottom: 20px;
  font-size: clamp(22px,3.4285714286vw,36px);
}

.heading19 {
  color: #009245;
  font-size: clamp(20px,2.0952380952vw,22px);
  margin-bottom: 10px;
  font-weight: normal;
}

.tbl01 {
  width: 100%;
}
@media (width > 782px) {
  .tbl01 th, .tbl01 td {
    padding: 5px;
    text-align: left;
    font-weight: normal;
    vertical-align: top;
  }
  .tbl01 th {
    width: 30%;
  }
}
@media (width <= 782px) {
  .tbl01 {
    display: block;
  }
  .tbl01 tbody, .tbl01 tr, .tbl01 th, .tbl01 td {
    display: block;
    text-align: left;
  }
  .tbl01 tr {
    padding: 5px 0;
    border-bottom: 1px dotted #666;
  }
}

.news-content01 .date {
  font-size: clamp(13px,1.3333333333vw,14px);
  line-height: 100%;
  margin-bottom: 5px;
}

.button-link01 {
  margin-top: 30px;
}
.button-link01 a {
  display: block;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0071bc;
  border-radius: 15px;
  font-size: clamp(16px,1.9047619048vw,20px);
  color: #fff;
  position: relative;
  transition: all 0.3s ease 0s;
  width: 100%;
  max-width: 375px;
}
@media (width > 782px) {
  .button-link01 a {
    height: 56px;
  }
}
@media (width <= 782px) {
  .button-link01 a {
    padding: 15px 10px;
  }
}
.button-link01 a:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent transparent #fff transparent;
  transform: rotate(-45deg);
  position: absolute;
  right: clamp(15px,2.8571428571vw,30px);
}
@media (width > 782px) {
  .button-link01 a:before {
    border-width: 0 0 16px 16px;
  }
}
@media (width <= 782px) {
  .button-link01 a:before {
    border-width: 0 0 10px 10px;
  }
}
.button-link01 a:hover {
  background: #29abe2;
}

.button-link02 a {
  display: block;
  width: 100%;
  height: 56px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: start;
  padding-left: clamp(10px,1.9047619048vw,20px);
  background: #F15A24;
  border-radius: 15px;
  font-size: clamp(16px,1.9047619048vw,20px);
  color: #fff;
  position: relative;
}
.button-link02 a:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent transparent #fff transparent;
  transform: rotate(-45deg);
  position: absolute;
  right: clamp(15px,2.8571428571vw,30px);
}
@media (width > 782px) {
  .button-link02 a:before {
    border-width: 0 0 16px 16px;
  }
}
@media (width <= 782px) {
  .button-link02 a:before {
    border-width: 0 0 10px 10px;
  }
}

@media (width > 782px) {
  .fright {
    float: right;
  }
}
@media (width <= 782px) {
  .fright {
    display: block;
    margin-left: auto;
    margin-right: auto;
  }
}

@media (width > 782px) {
  .fleft {
    float: left;
  }
}
@media (width <= 782px) {
  .fleft {
    display: block;
    margin-left: auto;
    margin-right: auto;
  }
}

.media-text {
  gap: clamp(20px,5.7142857143vw,60px);
  position: relative;
}
.media-text .text-content {
  position: relative;
  flex: 0 1 100%;
}
.media-text figure.media {
  position: relative;
}
@media (width > 782px) {
  .media-text figure.media {
    flex: 1 0 auto;
  }
}
.media-text.media-left .text-content {
  order: 2;
}
.media-text.media-left figure.media {
  order: 1;
}
.media-text.media-right .text-content {
  order: 1;
}
.media-text.media-right figure.media {
  order: 2;
}
p.caption {
  font-size: clamp(13px,1.3333333333vw,14px);
}

ul + p.caption {
  margin-top: 10px;
}

p.caption.caption01 {
  color: #0071bc;
}

.spbtn {
  width: 40px;
  height: 40px;
  background: #333;
  position: fixed;
  top: 0;
  right: 0;
  box-sizing: border-box;
  padding: 10px;
  z-index: 300;
}
@media (width > 1200px) {
  .spbtn {
    display: none;
  }
}
.spbtn span {
  display: block;
  width: 100%;
  height: 2px;
  background: #fff;
  position: relative;
  transition: all 0.25s ease-out 0s;
}
.spbtn .l1 {
  top: 1px;
}
.spbtn .l2 {
  top: 6px;
}
.spbtn .l3 {
  top: 11px;
}
.spbtn.active .l1 {
  left: 0;
  top: 9px;
  transform: rotate(135deg);
}
.spbtn.active .l2 {
  opacity: 0;
}
.spbtn.active .l3 {
  left: 0;
  top: 5px;
  transform: rotate(-135deg);
}

.sp-navigation {
  width: 100%;
  z-index: 50;
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #e0dccc;
  z-index: 100;
  align-items: center;
  justify-content: center;
  height: 0;
}
.sp-navigation.active {
  overflow: auto;
}
@media (width > 1200px) {
  .sp-navigation {
    display: none;
  }
}
@media (width <= 1200px) {
  .sp-navigation {
    display: flex;
  }
}
.sp-navigation .wrapper {
  max-width: calc(100% - 40px);
}
.sp-navigation nav {
  padding: 30px 0;
}
.sp-navigation section + section {
  margin-top: 20px;
}
.sp-navigation section {
  background: #fff;
  padding: 18px 20px;
  transition: all 0.3s ease 0s;
  overflow: hidden;
}
.sp-navigation section h3 {
  position: relative;
  font-size: 16px;
}
.sp-navigation section h3:after {
  content: "+";
  position: absolute;
  right: 10px;
}
.sp-navigation section ul {
  margin-top: 10px;
}
.sp-navigation section li {
  font-size: 13px;
}
.sp-navigation section a {
  display: block;
  text-decoration: none;
  color: #666;
  padding: 5px 5px 5px 15px;
  text-indent: -10px;
}
.sp-navigation section a:before {
  content: "- ";
}
.sp-navigation section:not(.class-toggled) {
  height: 60px !important;
}
.sp-navigation section.class-toggled h3:after {
  content: "-";
}
.sp-navigation .other {
  margin-top: 20px;
}
.sp-navigation .other ul {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 0px;
}
.sp-navigation .other li {
  font-size: 12px;
}
.sp-navigation .other a {
  color: #333;
  font-weight: bold;
}
.sp-navigation.active {
  animation-name: naActive;
  animation-duration: 0.3s;
  animation-timing-function: ease-out;
  animation-delay: 0s;
  animation-iteration-count: 1;
  animation-direction: normal;
  animation-fill-mode: forwards;
  animation-play-state: running;
}
.sp-navigation.hide {
  animation-name: naHide;
  animation-duration: 0.3s;
  animation-timing-function: ease-out;
  animation-delay: 0s;
  animation-iteration-count: 1;
  animation-direction: normal;
  animation-fill-mode: forwards;
  animation-play-state: running;
}

@keyframes naActive {
  0% {
    height: 100%;
    opacity: 0;
    transform: scale(0.8);
  }
  100% {
    height: 100%;
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes naHide {
  0% {
    height: 100%;
    opacity: 1;
    transform: scale(1);
  }
  99% {
    height: 100%;
    opacity: 0;
    transform: scale(0.8);
  }
  100% {
    height: 0%;
  }
}
.contact-content01 .media-text {
  align-items: center;
}
@media (width > 782px) {
  .contact-content01 .media-text {
    padding-left: 30px;
  }
}
@media (width <= 782px) {
  .contact-content01 .media-text {
    gap: 30px;
  }
}
@media (width > 782px) {
  .contact-content01 .media-text .text-content .contact-panel {
    padding-left: 25px;
  }
}
.contact-content01 .media-text .text-content .contact-panel p.mail,
.contact-content01 .media-text .text-content .contact-panel p.tel {
  font-size: clamp(20px,2.8571428571vw,30px);
  line-height: 100%;
  margin-top: 10px;
}
.contact-content01 .media-text .text-content .contact-panel p.mail a,
.contact-content01 .media-text .text-content .contact-panel p.tel a {
  color: #1b1464;
}
.contact-content01 .media-text figure.media {
  text-align: center;
}
@media (width > 782px) {
  .contact-content01 .media-text figure.media {
    flex: 0 0 350px;
  }
  .contact-content01 .media-text figure.media img {
    margin-right: 0;
    margin-left: auto;
  }
}
@media (width <= 782px) {
  .contact-content01 .media-text figure.media {
    width: 100%;
  }
  .contact-content01 .media-text figure.media img {
    margin-left: auto;
    margin-right: auto;
  }
}
.contact-content01 h3 {
  color: #29abe2;
}
@media (width <= 782px) {
  .contact-content01 h3 {
    margin-bottom: 15px;
  }
}

.contact-content02 .media-text {
  display: block;
}
.contact-content02 .media-text h3 {
  display: none;
}
.contact-content02 .media-text .text-content {
  text-align: center;
}
.contact-content02 .media-text .text-content a {
  color: #1b1464;
}
.contact-content02 .media-text .text-content p.tel,
.contact-content02 .media-text .text-content p.mail {
  font-size: clamp(20px,2.8571428571vw,30px);
  line-height: 100%;
  margin-top: 10px;
}
.contact-content02 .media-text figure.media {
  text-align: center;
  margin-top: clamp(20px,3.8095238095vw,40px);
}
.contact-content02 .media-text figure.media img {
  margin-left: auto;
  margin-right: auto;
}

.sitemap-content01 section {
  padding-left: 40px;
  padding-right: 40px;
}
.sitemap-content01 section + section {
  margin-top: 0;
}
.sitemap-content01 h3 {
  color: #F15A24;
  margin-bottom: 15px;
}
.sitemap-content01 ul {
  padding-left: 25px;
}
.sitemap-content01 li {
  list-style-type: disc;
  list-style-position: outside;
  color: #0000ff;
}

@media (width > 782px) {
  .sitemap-grid {
    display: grid;
    grid-template-rows: auto auto;
    grid-template-columns: auto auto;
    align-items: start;
    gap: 40px;
  }
}
@media (width <= 782px) {
  .sitemap-grid section + section {
    margin-top: 20px;
  }
}

.lower-content-area {
  padding-top: clamp(25px,4.7619047619vw,50px);
  padding-bottom: clamp(20px,3.8095238095vw,40px);
}

.local-government-content01 .media-text01 figure.media {
  flex: 0 1 280px;
}
.local-government-content01 .media-text02 figure.media {
  flex: 0 1 390px;
}
.local-government-content01 .row {
  gap: clamp(10px,2.8571428571vw,30px);
}

.local-government-content02 .media-text {
  border: 1px solid #999;
  padding: 25px;
  display: flex;
  gap: 30px;
  align-items: center;
}
@media (width > 782px) {
  .local-government-content02 .media-text .media {
    margin-top: -25px;
  }
}
@media (width <= 782px) {
  .local-government-content02 .media-text .media {
    text-align: center;
  }
  .local-government-content02 .media-text .media img {
    margin-left: auto;
    margin-right: auto;
  }
}
.local-government-content02 .name {
  margin-top: 15px;
}
.local-government-content02 section {
  margin-top: 30px !important;
}
.local-government-content02 .caption {
  margin-top: 20px;
}

.local-government-content03 .row {
  display: flex;
  align-items: end;
  gap: clamp(20px,5.7142857143vw,60px);
}
.local-government-content03 .col:nth-of-type(1) {
  flex: 0 1 906px;
}
.local-government-content03 .col:nth-of-type(2) {
  flex: 0 1 652px;
}
.local-government-content03 img {
  width: 100%;
}

.local-government-content04 .media-text {
  align-items: end;
}
.local-government-content04 .media-text .text-content {
  text-align: center;
}

.detail01 {
  background: rgba(251, 176, 59, 0.5);
  padding: 30px;
  text-align: left;
  margin-top: 30px;
}

.local-government-content05 .detail p {
  font-size: clamp(16px,2.2857142857vw,24px);
}
.local-government-content05 .caption {
  font-size: clamp(13px,1.3333333333vw,14px);
}
.local-government-content05 .beside-image {
  position: absolute;
  bottom: 0;
  right: 0;
}
@media (width <= 782px) {
  .local-government-content05 .beside-image {
    display: none;
  }
}
@media (width > 782px) {
  .local-government-content05 .under-image {
    display: none;
  }
}
@media (width <= 782px) {
  .local-government-content06 .detail01 {
    margin-top: 0;
  }
}

.introduction-content01 ul + h3 {
  margin-top: 30px;
}
.introduction-content01 ul {
  padding-left: 20px;
}
.introduction-content01 ul li {
  text-indent: -18px;
}

.construction-content02 .media-text {
  align-items: center;
}

.construction-content03 {
  margin-top: clamp(20px,3.8095238095vw,40px) !important;
}

.medical-content01 .interview01 {
  background: rgba(0, 146, 69, 0.1);
}

p.label01 {
  font-size: clamp(16px,1.9047619048vw,20px);
  color: #F15A24;
}

.profile01 {
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

.link01 {
  color: #0000ff !important;
}

.interview01 {
  background: rgba(251, 176, 59, 0.1);
}
@media (width > 1200px) {
  .interview01 {
    width: calc(100% + 80px);
    margin-left: -40px;
    padding: 40px;
  }
}
@media (width <= 1200px) {
  .interview01 {
    width: calc(100% + 40px);
    margin-left: -20px;
    padding: 20px;
  }
}
.interview01 + .interview01 {
  margin-top: 30px;
}
.interview01:last-of-type {
  margin-bottom: 30px;
}
.interview01 .media-text {
  align-items: center;
}
@media (width > 782px) {
  .interview01 .media-text {
    gap: 60px;
  }
}
@media (width <= 782px) {
  .interview01 .media-text {
    gap: 20px;
  }
}
@media (width <= 782px) {
  .interview01 .media-text .text-content {
    order: 1;
  }
}
.interview01 .media-text figure.media {
  flex: 0 0 170px;
}
@media (width <= 782px) {
  .interview01 .media-text figure.media {
    order: 2;
    margin-left: auto;
    margin-right: 0;
  }
}
.interview01 .media-text figure.media figcaption {
  color: #1b1464;
  text-align: center;
  margin-top: 25px;
  font-size: clamp(13px,1.3333333333vw,14px);
}
@media (width > 782px) {
  .interview01 .media-text.media-left {
    padding-left: clamp(30px,8.5714285714vw,90px);
  }
}
@media (width <= 782px) {
  .interview01 .media-text.media-left {
    padding-left: 0px;
  }
}
.interview01 .caption02 {
  margin-top: clamp(25px,4.7619047619vw,50px);
}
.interview01 ul {
  padding-left: 22px;
}
.interview01 ul li {
  list-style-type: disc;
  list-style-position: outside;
}

img[src*="img02.jpg"] {
  width: 330px;
}

img[src*="img03.jpg"] {
  width: 200px;
}

img[src*="img04.jpg"] {
  width: 270px;
}

img[src*="img09.jpg"] {
  width: 290px;
}

img[src*="img13.jpg"] {
  width: 375px;
}

.color-orange {
  color: #F15A24;
}

.color-yellow-orange {
  color: #f7931e;
}

.lower-navigation {
  margin-bottom: clamp(30px,5.7142857143vw,60px);
}
@media (width <= 1200px) {
  .lower-navigation {
    display: none;
  }
}
.lower-navigation ul {
  display: flex;
  flex-direction: row;
  flex-flow: wrap;
  align-items: stretch;
  justify-content: start;
  gap: 15px 20px;
}
.lower-navigation li {
  flex: 0 0 calc((100% - 60px) / 4);
}
.lower-navigation a {
  width: 100%;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.7);
  font-size: clamp(16px,1.9047619048vw,20px);
  text-decoration: none;
  text-align: center;
  transition: all 0.3s ease 0s;
}
.lower-navigation a:hover {
  background: white;
}
.lower-navigation li.active a {
  background: white;
}
.lower-navigation.active-1 ul li:nth-of-type(2) a, .lower-navigation.active-2 ul li:nth-of-type(3) a, .lower-navigation.active-3 ul li:nth-of-type(4) a, .lower-navigation.active-4 ul li:nth-of-type(5) a, .lower-navigation.active-5 ul li:nth-of-type(6) a, .lower-navigation.active-6 ul li:nth-of-type(7) a, .lower-navigation.active-7 ul li:nth-of-type(8) a, .lower-navigation.active-8 ul li:nth-of-type(9) a {
  background: white;
}

.local-government-navigation a {
  color: #f7931e;
}

.introduction-navigation a {
  color: #0071bc;
}

.construction-navigation a {
  color: #a67c52;
}

.medical-navigation a {
  color: #009245;
}

@media (width <= 782px) {
  .merit-flex01 {
    display: block !important;
    width: calc(100% - 60px);
    max-width: 280px;
    margin-left: auto;
    margin-right: auto;
  }
  .merit-flex01 .col + .col {
    margin-top: 20px;
  }
}

/*# sourceMappingURL=styles.css.map */
