@charset "UTF-8";
* {
  box-sizing: border-box;
}

a {
  color: #336699;
}

section {
  margin: 0;
}

.caption {
  font-size: 0.8125rem;
  margin-top: 0.25em;
}

img {
  max-width: 100%;
  height: auto;
}

table {
  font-size: inherit;
  border-collapse: collapse;
}
table td,
table th {
  padding: 0.25em 0.5em;
  font-weight: normal;
}
table td.bg-white,
table th.bg-white {
  background-color: white;
}
table td.bg-cyan,
table th.bg-cyan {
  background-color: rgba(0, 160, 233, 0.175);
}
table td.bg-magenta,
table th.bg-magenta {
  background-color: rgba(228, 0, 127, 0.175);
}
table.border-horizontal {
  border: 0;
}
table.border-horizontal td,
table.border-horizontal th {
  min-width: 2em;
  border: 0;
  border-collapse: collapse;
  border-top: 1px solid rgba(0, 0, 0, 0.125);
  border-bottom: 1px solid rgba(0, 0, 0, 0.125);
}
table.no-border {
  background: transparent;
  border: 0;
}
table.no-border th,
table.no-border td {
  padding: 0.25em 0;
  border: 0;
  background: transparent;
}
table.default-table {
  background: #fff;
  border: none;
  line-height: 1.25;
}
table td,
table th {
  border: 1px solid rgba(0, 0, 0, 0.125);
  padding: 0.55em 0.25em 0.45em;
}
table th {
  background-color: rgb(245, 244, 239);
}
table thead th {
  color: #fff;
  background: #00994c;
  border: 1px solid rgba(0, 0, 0, 0.125);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: #333;
  line-height: 1.25;
  margin: 2.5em 0 0.75em;
  font-feature-settings: "pkna";
  letter-spacing: 0.0125em;
  font-weight: 500;
}
h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child,
h6:first-child {
  margin-top: 0;
}

h2 + h3,
h3 + h4,
h4 + h5,
h5 + h6 {
  margin-top: 0.75em;
}

h1 {
  font-size: 1.25rem;
  text-align: center;
  color: #444;
}

h2 {
  color: #fff;
  background-color: #ff771d;
  font-size: 1.0625rem;
  padding: 0.33em 0.5em 0.2em;
  margin-bottom: 0.75em;
}

h3 {
  font-size: 1rem;
  padding: 0 0 0.25em 18px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
  position: relative;
}

h3::before {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  background-color: #ff6300;
  border-radius: 3px;
  top: 4px;
  left: 4px;
}

h4 {
  font-size: 0.9375rem;
  padding-left: 1em;
  margin: 1em 0 -0.25em;
  position: relative;
}

h4::before {
  content: "";
  position: absolute;
  width: 0.5em;
  height: 0.5em;
  background-color: #ff6300;
  border-radius: 0.5em;
  top: 0.3333em;
  left: 0.25em;
  transform: translateY(0);
}

h5 {
  font-size: 1rem;
}

h6 {
  font-size: 0.9375rem;
}

h1.no-style,
h2.no-style,
h3.no-style,
h4.no-style,
h5.no-style,
h6.no-style {
  margin: 1.25em 0 0.25em;
  border: 0;
  padding: 0;
}

h1.no-style::before,
h2.no-style::before,
h3.no-style::before,
h4.no-style::before,
h5.no-style::before,
h6.no-style::before {
  display: none;
}

p {
  margin: 0.66em 0;
}

p:first-child {
  margin-top: 0;
}

p:last-child {
  margin-bottom: 0;
}

ul {
  padding-left: 1.5em;
  margin: 0.5em 0;
}

.alignleft {
  float: left;
  margin: 0 0.75rem 0.25rem 0;
}

.alignright {
  float: right;
  margin: 0 0 0.25rem 0.75rem;
}

.aligncenter {
  display: block;
  margin: 0 auto 0.25rem;
}

.text-alignleft {
  text-align: left;
}

.text-alignright {
  text-align: right;
}

.text-aligncenter {
  text-align: center;
}

.text-alignjustify {
  text-align: justify;
}

.fc-red {
  color: #c00;
}

.link-icon::before {
  display: inline-block;
  color: #00994c;
  content: "▶";
  font-size: 66.66%;
  text-decoration: none;
  vertical-align: 0.075em;
}

section.h2 {
  margin: 2.5rem 0 0;
}

section.h3 {
  margin: 1.5rem 0 0;
}

h2 + section.h3,
h3 + section.h4,
h4 + section.h5,
h5 + section.h6 {
  margin-top: 0;
}

h4 + .gallery {
  margin-top: 0.25em;
}

.row {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  margin: 0;
}
@media screen and (min-width: 600px) {
  .row {
    flex-direction: row;
    margin: 0 -15px;
  }
}
.row.v-aligncenter {
  align-items: center;
}

.column {
  padding: 15px;
  box-sizing: border-box;
}

.mat {
  padding: 1.25em;
}

.bg-white {
  background-color: white;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.075) inset;
}

.gallery {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -5px;
}
.gallery .gallery-item {
  box-sizing: border-box;
  width: 25%;
  padding: 5px;
  margin: 0;
}
.gallery .gallery-item {
  box-sizing: border-box;
  padding: 5px;
  margin: 0;
  box-sizing: border-box;
}
.gallery .gallery-item .gallery-caption {
  font-size: 0.75rem;
  line-height: 1.25;
  margin: 0.25em 0 0;
}
.gallery .gallery-icon {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

.gallery-col1 .gallery-item {
  width: 100%;
}

.gallery-col2 .gallery-item {
  width: 50%;
}

.gallery-col3 .gallery-item,
.gallery-col4 .gallery-item,
.gallery-col5 .gallery-item,
.gallery-col6 .gallery-item,
.gallery-col7 .gallery-item,
.gallery-col8 .gallery-item,
.gallery-col9 .gallery-item {
  width: 33.3333%;
}

@media screen and (min-width: 600px) {
  .gallery.gallery-col1 .gallery-item,
  .w-full {
    width: 100%;
  }
  .gallery.gallery-col2 .gallery-item,
  .w-1-2,
  .w-half {
    width: 50%;
  }
  .gallery.gallery-col3 .gallery-item,
  .w-1-3 {
    width: 33.3333%;
  }
  .gallery.gallery-col4 .gallery-item,
  .w-1-4 {
    width: 25%;
  }
  .gallery.gallery-col5 .gallery-item,
  .w-1-5 {
    width: 20%;
  }
  .gallery.gallery-col6 .gallery-item,
  .w-1-6 {
    width: 16.6666%;
  }
  .gallery.gallery-col7 .gallery-item,
  .w-1-7 {
    width: 14.2857142857%;
  }
  .gallery.gallery-col8 .gallery-item,
  .w-1-8 {
    width: 12.5%;
  }
  .gallery.gallery-col9 .gallery-item,
  .w-1-9 {
    width: 11.1111%;
  }
  .w-1-10 {
    width: 10%;
  }
  .w-2-3 {
    width: 66.6666%;
  }
  .w-3-4 {
    width: 75%;
  }
  .w-2-5 {
    width: 40%;
  }
  .w-3-5 {
    width: 60%;
  }
  .w-4-5 {
    width: 80%;
  }
  .w-6-11 {
    width: 54.5454%;
  }
  .w-5-11 {
    width: 45.4545%;
  }
  .w-7-12 {
    width: 58.3333%;
  }
  .w-5-12 {
    width: 41.6666%;
  }
}
html {
  font-size: 1rem;
  margin: 0;
  padding: 0;
  font: 100%/1.5 "BIZ UDPGothic", "Hiragino Sans", sans-serif;
  font-weight: 300;
}

body {
  color: #333;
  font-size: 0.9375rem;
  padding: 0;
  margin: 0;
  background: #fdfde9 url(images/bg-title.png) no-repeat left top;
  background-size: 320px auto;
  position: relative;
}
@media screen and (min-width: 600px) {
  body {
    background-size: 376px auto;
  }
}

header.site-header {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  padding: 20px 15px;
  display: flex;
  gap: 20px;
  align-items: flex-start;
  justify-content: space-between;
}
@media screen and (min-width: 600px) {
  header.site-header {
    padding: 25px 20px;
  }
}
header.site-header .header-title .site-title {
  margin: 0;
}
header.site-header .header-title .site-title img {
  display: block;
  width: 168px;
  height: auto;
}
@media screen and (min-width: 600px) {
  header.site-header .header-title .site-title img {
    width: 210px;
    height: 70px;
  }
}
header.site-header .header-title .phone {
  font-size: 0.8125rem;
  line-height: 1;
  font-weight: 500;
  margin: 0.5em 0 0;
}
header.site-header .header-title .phone .label {
  font-weight: normal;
  margin-right: 0.25em;
}
header.site-header .main-menu {
  font-size: 0.875rem;
}
@media screen and (min-width: 600px) {
  header.site-header .main-menu {
    font-size: 1.125rem;
  }
}
header.site-header .main-menu ul {
  padding: 0;
  margin: -8px 0 0;
  list-style: none;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  flex-wrap: wrap;
}
@media screen and (min-width: 600px) {
  header.site-header .main-menu ul {
    margin: -4px 0 0;
  }
}
header.site-header .main-menu ul li {
  padding: 0 0.25em;
  margin-bottom: 3px;
}
@media screen and (min-width: 600px) {
  header.site-header .main-menu ul li {
    padding: 0 0.5em;
  }
}
header.site-header .main-menu ul li a {
  color: #444;
  font-weight: 500;
  letter-spacing: 0.025em;
  padding: 0.3em 0;
  display: block;
  text-decoration: none;
  position: relative;
  white-space: nowrap;
}
@media screen and (min-width: 600px) {
  header.site-header .main-menu ul li a {
    padding: 0.4em 0;
  }
}
header.site-header .main-menu ul li a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background-color: rgba(0, 0, 0, 0.125);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.075) inset, 0 1px 0 white;
  border-radius: 2px;
}
header.site-header .main-menu ul li a:hover {
  text-decoration: none;
}
header.site-header .main-menu ul li a:hover::after {
  background-color: rgba(255, 124, 0, 0.6);
}
header.site-header .main-menu ul li.current a::after {
  background-color: #ff7c00;
}
@media screen and (min-width: 600px) {
  header.site-header .main-menu ul li.home {
    margin-top: 0.25em;
    font-size: 80%;
  }
}

#page-container {
  width: 100%;
  max-width: 360px;
  padding: 160px 0 40px;
  margin: 0 auto;
}
@media screen and (min-width: 600px) {
  #page-container {
    max-width: 640px;
  }
}
#page-container h1.page-title {
  font-size: 1.25rem;
  padding: 0.25em 0.5em;
  margin: 0 0 0.75em;
  background-color: #ff971d;
  border-radius: 1em;
  color: #fff;
}
@media screen and (min-width: 600px) {
  #page-container h1.page-title {
    margin: 0 -0.75em 0.75em;
  }
}

body.home header.site-header {
  display: none;
}
@media screen and (min-width: 600px) {
  body.home #page-container {
    max-width: 680px;
  }
}
body.home #page-container .row {
  min-height: 560px;
  padding-bottom: 20px;
  margin: 0 auto;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 599px) {
  body.home #page-container .row {
    justify-content: center;
    gap: 40px;
  }
}
body.home #page-container .title {
  position: relative;
}
body.home #page-container .title::before {
  content: "";
  background: url(images/bg-site-title-top.png) no-repeat center center;
  background-size: contain;
  width: 375px;
  height: 80px;
  position: absolute;
  top: -40px;
  left: -15px;
  right: -15px;
}
@media screen and (min-width: 600px) {
  body.home #page-container .title::before {
    background-size: contain;
    top: -45px;
    left: -30px;
  }
}
body.home #page-container .title::after {
  content: "";
  background: url(images/bg-site-title-bottom.png) no-repeat;
  background-size: contain;
  width: 48px;
  height: 28px;
  position: absolute;
  bottom: -12px;
  left: 48%;
  transform: translateX(-50%);
}
@media screen and (min-width: 600px) {
  body.home #page-container .title::after {
    width: 54px;
    height: 36px;
  }
}
body.home #page-container .title .site-title {
  width: 320px;
  height: 108px;
  margin: 0 auto;
  text-align: left;
  position: relative;
}
body.home #page-container .title .site-title img {
  display: block;
  margin: -2px -2px;
}
body.home #page-container .title .address {
  font-size: 0.9375rem;
  line-height: 1.5;
  margin: 0.65em 0 0.35em;
}
body.home #page-container .title .counter {
  line-height: 1;
}
body.home #page-container .buttons {
  width: 100%;
}
@media screen and (min-width: 600px) {
  body.home #page-container .buttons {
    width: 320px;
  }
}
body.home #page-container .buttons ul.nav {
  padding: 0;
  margin: 0;
  list-style: none;
}
body.home #page-container .buttons ul.nav li {
  font-size: 1.25rem;
  line-height: 1.25;
  margin: 0;
}
body.home #page-container .buttons ul.nav li + li {
  margin-top: 12px;
}
body.home #page-container .buttons ul.nav li a {
  color: #fff;
  font-weight: 500;
  letter-spacing: 0.05em;
  padding: 0.3em 0.6em;
  background-color: #fa7d29;
  border-radius: 2em;
  display: block;
  text-align: center;
  text-shadow: 0 2px 1px rgba(0, 0, 0, 0.125);
  text-decoration: none;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.125);
}
body.home #page-container .buttons ul.nav li a:hover {
  position: relative;
  top: 1px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.125);
}

.shinryo-setsubi {
  font-size: 0.8125rem;
}
.shinryo-setsubi .row .col-img {
  width: 240px;
}
.shinryo-setsubi .row .col-img .image-container {
  display: block;
  background-color: rgba(0, 0, 0, 0.75);
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.shinryo-setsubi .row .col-img .image-container img {
  display: block;
}
.shinryo-setsubi .row .col-txt {
  width: 100%;
  max-width: 420px;
}

@media screen and (min-width: 600px) {
  body.oshirase #page-container {
    width: 100%;
    max-width: 560px;
  }
}

@media screen and (min-width: 600px) {
  body.access #page-container {
    width: 100%;
    max-width: 840px;
  }
}/*# sourceMappingURL=common.css.map */