*,
::before,
::after {
  box-sizing: border-box;
  background-repeat: no-repeat
}

::before,
::after {
  text-decoration: inherit;
  vertical-align: inherit
}

:where(:root) {
  cursor: default;
  line-height: 1.5;
  overflow-wrap: break-word;
  -moz-tab-size: 4;
  -o-tab-size: 4;
  tab-size: 4;
  -webkit-tap-highlight-color: transparent;
  -webkit-text-size-adjust: 100%
}

:where(body) {
  margin: 0
}

:where(h1) {
  font-size: 2em;
  margin: .67em 0
}

:where(dl, ol, ul) :where(dl, ol, ul) {
  margin: 0
}

:where(hr) {
  color: inherit;
  height: 0
}

:where(nav) :where(ol, ul) {
  list-style-type: none;
  padding: 0
}

:where(nav li)::before {
  content: "​";
  float: left
}

:where(pre) {
  font-family: monospace, monospace;
  font-size: 1em;
  overflow: auto
}

:where(abbr[title]) {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

:where(b, strong) {
  font-weight: bolder
}

:where(code, kbd, samp) {
  font-family: monospace, monospace;
  font-size: 1em
}

:where(small) {
  font-size: 80%
}

:where(audio, canvas, iframe, img, svg, video) {
  vertical-align: middle
}

:where(iframe) {
  border-style: none
}

:where(svg:not([fill])) {
  fill: currentColor
}

:where(table) {
  border-collapse: collapse;
  border-color: inherit;
  text-indent: 0
}

:where(button, input, select) {
  margin: 0
}

:where(button, [type=button i], [type=reset i], [type=submit i]) {
  -webkit-appearance: button
}

:where(fieldset) {
  border: 1px solid #a0a0a0
}

:where(progress) {
  vertical-align: baseline
}

:where(textarea) {
  margin: 0;
  resize: vertical
}

:where([type=search i]) {
  -webkit-appearance: textfield;
  outline-offset: -2px
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto
}

::-webkit-input-placeholder {
  color: inherit;
  opacity: .54
}

::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

:where(dialog) {
  background-color: white;
  border: solid;
  color: black;
  height: -moz-fit-content;
  height: -webkit-fit-content;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: -moz-fit-content;
  width: -webkit-fit-content;
  width: fit-content
}

:where(dialog:not([open])) {
  display: none
}

:where(details>summary:first-of-type) {
  display: list-item
}

:where([aria-busy=true i]) {
  cursor: progress
}

:where([aria-controls]) {
  cursor: pointer
}

:where([aria-disabled=true i], [disabled]) {
  cursor: not-allowed
}

:where([aria-hidden=false i][hidden]) {
  display: initial
}

:where([aria-hidden=false i][hidden]:not(:focus)) {
  clip: rect(0, 0, 0, 0);
  position: absolute
}

body {
  color: #143a60;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-size: 13px;
  line-height: 1.4;
  letter-spacing: .04em
}

@media screen and (min-width: 1025px) {
  body {
    font-size: 16px
  }
}

main {
  position: relative
}

h1,
h2,
h3,
h4,
h5 {
  margin: 0;
  padding: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold
}

p {
  margin: 0
}

a {
  text-decoration: none;
  transition: all .5s
}

@media screen and (min-width: 600px) {
  a[href^="tel:"] {
    pointer-events: none;
    color: #333
  }
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: text-bottom
}

@media screen and (min-width: 1025px) {
  img {
    vertical-align: middle
  }
}

input,
button,
select,
textarea {
  font-family: inherit;
  font-size: 100%
}

input,
button {
  border: none
}

input {
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

input:focus-visible {
  outline: none
}

input[type=checkbox] {
  width: 12px;
  height: 12px;
  margin-right: 8px
}

input[type=checkbox]::before {
  content: "";
  height: 12px;
  width: 12px;
  display: block;
  border: 1px solid #143a60;
  border-radius: 2px
}

input[type=checkbox]:checked::before {
  background-color: #143a60;
  background-image: url(../img/check-icon.svg);
  background-position: center
}

button {
  border-radius: 100px;
  cursor: pointer;
  font-size: 12px;
  transition: all .5s
}

ul,
ol {
  list-style: none;
  padding: 0;
  margin: 0
}

figure {
  margin: 0
}

address,
em {
  font-style: normal
}

iframe {
  width: 100%;
  height: 100%
}

.container {
  padding: 40px 20px
}

@media screen and (min-width: 1025px) {
  .container {
    padding: 80px 20px
  }
  .footer.container {
    padding: 40px 20px
  }
}

.inner {
  max-width: 1120px;
  margin: 0 auto
}

.bg-gray {
  background-color: #f5f4f0
}

.title {
  font-size: 22px
}

@media screen and (min-width: 1025px) {
  .title {
    font-size: 34px
  }
}

.orange-btn {
  background-color: #f0821e;
  color: #fff;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold
}

@media screen and (min-width: 1025px) {
  .orange-btn:hover {
    background-color: rgba(240, 130, 30, .7)
  }
}

.orange-outline-btn {
  background-color: rgba(0, 0, 0, 0);
  color: #f0821e;
  border: 1px solid #f0821e;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold
}

.primary-btn {
  background-color: #143a60;
  color: #fff;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold
}

@media screen and (min-width: 1025px) {
  .primary-btn:hover {
    background-color: rgba(20, 58, 96, .7)
  }
}

.primary-outline-btn {
  background-color: rgba(0, 0, 0, 0);
  color: #143a60;
  border: 1px solid #143a60;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold
}

@media screen and (min-width: 1025px) {
  .primary-outline-btn:hover {
    background-color: #143a60;
    color: #fff
  }
}

.outline-btn {
  background-color: #fff;
  border-radius: 3px;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold;
  font-size: 12px;
  padding: 6px 0;
  width: 100%
}

.square-btn {
  border-radius: 10px
}

.pc-layout {
  display: none !important
}

@media screen and (min-width: 1025px) {
  .pc-layout {
    display: block !important
  }
}

@media screen and (min-width: 1025px) {
  .sp-layout {
    display: none !important
  }
}

.mt-0 {
  margin-top: 0 !important
}

@media screen and (min-width: 1025px) {
  .pc-mt-80 {
    margin-top: 80px !important
  }
}

.header-wrapper {
  background-color: #fff;
  height: 86px;
  line-height: 86px;
  text-align: center;
}

.header-wrapper .logo {
  font-size: 12px;
  vertical-align: middle;
  display: inline-block;
  line-height: normal;
  font-weight: bold;
}

.header-wrapper .logo img {
  display: block;
  margin: 0 auto;
  width: 161px;
  margin-bottom: 10px
}

@media screen and (min-width: 1025px) {
  .header-wrapper {
    height: 135px;
    line-height: 135px;
  }

  .header-wrapper .logo {
    font-size: 16px;
  }

  .header-wrapper .logo img {
    width: 283px;
  }
}

/* search */
.search {
  background-image: url(../img/search-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  padding: 56px 30px
}

@media screen and (min-width: 1025px) {
  .search {
    background-image: none;
    padding: 0
  }
}

.search-container {
  position: relative;
  background-color: #fff;
  border-radius: 30px;
  padding: 30px 20px;
  max-width: 1000px;
  text-align: center;
  margin: 0 auto;
  z-index: 2
}

@media screen and (min-width: 1025px) {
  .search-container {
    padding: 0
  }
}

.search-block {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto
}

.search-block input {
  background-color: #eee;
  width: 50%;
  padding: 15px 10px;
  font-size: 11px
}

.search-block input:first-of-type {
  border-radius: 5px 0 0 5px;
  border-right: 1px solid #ccc
}

.search-block input:nth-of-type(2) {
  border-radius: 0 5px 5px 0
}

.search-block button {
  display: block;
  padding: 10px 0;
  margin: 0 auto;
  width: 100%;
  max-width: 300px;
  margin-top: 12px;
  font-size: 16px
}

.search-block button img {
  margin-right: 10px;
  vertical-align: sub;
  height: 19px;
  padding: 0 0 3px
}

.search-block .orange-outline-btn img {
  width: 10px;
  padding-bottom: 0
}

@media screen and (min-width: 600px) {
  .search-block input {
    height: 46px;
    padding-left: 20px;
    width: calc(50% - 50px)
  }

  .search-block input:first-of-type {
    border-radius: 10px 0 0 10px
  }

  .search-block .top-search {
    border-radius: 0 10px 10px 0
  }

  .search-block .orange-btn {
    width: 100px;
    margin-top: 0
  }

  .search-block .primary-btn {
    margin-top: 30px
  }

  .search-block .sp-layout {
    max-width: 300px;
    width: 100%
  }
}

@media screen and (min-width: 1025px) {
  .search-block {
    max-width: 880px
  }

  .search-block input {
    font-size: 16px;
    height: 64px;
    padding-left: 20px;
    max-width: 370px
  }

  .search-block input:first-of-type {
    border-radius: 10px 0 0 10px
  }

  .search-block input:nth-of-type(2) {
    border-radius: 0
  }

  .search-block .orange-btn {
    width: 140px;
    border-radius: 0 10px 10px 0;
    font-size: 20px;
    margin-top: 0
  }

  .search-block .primary-btn {
    margin-top: 30px;
    font-size: 18px
  }
}

.tag {
  text-align: center;
  padding-top: 30px;
  padding-bottom: 0
}

@media screen and (min-width: 600px) {
  .tag {
    padding-bottom: 30px
  }
}

@media screen and (min-width: 1025px) {
  .tag {
    padding-bottom: 0
  }
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 6px;
  margin-top: 20px;
  overflow: hidden;
  max-height: 137px;
  padding: 0;
  font-size: 12px;
  transition: all .3s
}

@media screen and (min-width: 1025px) {
  .tag-list {
    margin-top: 30px;
    max-height: none;
    gap: 10px
  }
}

.tag-item {
  border: 1px solid #143a60;
  border-radius: 100px;
  transition: all .5s
}

@media screen and (min-width: 1025px) {
  .tag-item:hover {
    background-color: #143a60
  }
}

.tag-item a {
  display: inline-block;
  padding: 8px 10px;
  color: #143a60;
  font-size: 11px
}

@media screen and (min-width: 1025px) {
  .tag-item a {
    font-size: 14px;
    padding: 10px 18px
  }
}

@media screen and (min-width: 1025px) {
  .tag-item a:hover {
    color: #fff
  }
}

.orange-tag {
  justify-content: flex-start
}

.orange-tag .tag-item {
  border: 1px solid #f0821e
}

.orange-tag .tag-item a {
  color: #f0821e
}

@media screen and (min-width: 1025px) {
  .orange-tag .tag-item:hover {
    background-color: #f0821e
  }

  .orange-tag .tag-item:hover a {
    color: #fff
  }
}

.swiper-container {
  position: relative;
  padding: 15px 0;
  margin-bottom: 50px
}

@media screen and (min-width: 1025px) {
  .swiper-container {
    padding: 20 0
  }
}

.swiper-container .swiper {
  width: 305px
}

@media screen and (min-width: 1025px) {
  .swiper-container .swiper {
    width: 100%
  }
}

.swiper-container .swiper a {
  transition: all .5s
}

@media screen and (min-width: 1025px) {
  .swiper-container .swiper a:hover {
    opacity: .7
  }
}

.swiper-container .swiper-pagination {
  bottom: -15px !important
}

.swiper-container .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #f0821e !important
}

@media screen and (min-width: 1025px) {
  .swiper-container .swiper-pagination:hover {
    opacity: .8
  }
}

.swiper-container .swiper-button-prev,
.swiper-container .swiper-button-next {
  color: #f0821e;
  background-color: #fff;
  border-radius: 50%;
  box-shadow: 0 0 6px rgba(0, 0, 0, .16);
  width: 30px;
  height: 30px;
  margin-top: 0;
  transform: translateY(-50%);
  transition: all .5s
}

.swiper-container .swiper-button-prev::after,
.swiper-container .swiper-button-next::after {
  font-size: 14px
}

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

  .swiper-container .swiper-button-prev:hover,
  .swiper-container .swiper-button-next:hover {
    opacity: .9
  }
}

.swiper-container .swiper-button-prev {
  left: calc(50% - 168px)
}

.swiper-container .swiper-button-next {
  right: calc(50% - 168px)
}

@media screen and (min-width: 1025px) {
  .swiper-container {
    padding-top: 60px
  }

  .swiper-container .swiper {
    width: 100%
  }

  .swiper-container .swiper-button-prev,
  .swiper-container .swiper-button-next {
    width: 40px;
    height: 40px;
    top: calc(50% + 25px)
  }

  .swiper-container .swiper-button-prev {
    left: 30px
  }

  .swiper-container .swiper-button-next {
    right: 30px
  }
}

.scroll-list {
  display: flex;
  width: 100%;
  overflow-y: hidden;
  margin-top: 25px
}

@media screen and (min-width: 1025px) {
  .scroll-list {
    margin-top: 40px;
    gap: 30px
  }
}

.scroll-item {
  width: 280px;
  flex-shrink: 0;
  padding-right: 20px;
  margin-bottom: 10px
}

.scroll-item:first-of-type {
  margin-left: 20px
}

@media screen and (min-width: 600px) {
  .scroll-item {
    max-width: 350px;
    width: 100%
  }
}

@media screen and (min-width: 1025px) {
  .scroll-item {
    padding-right: 0
  }

  .scroll-item:first-of-type {
    margin-left: 0
  }
}

.scroll-item a .scroll-img {
  overflow: hidden;
  border-radius: 20px
}

.scroll-item a .scroll-img img {
  transition: all .6s;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  height: 175px
}

@media screen and (min-width: 600px) {
  .scroll-item a .scroll-img img {
    height: 222px
  }
}

@media screen and (min-width: 1025px) {
  .scroll-item a .scroll-img img {
    height: 235px
  }
}

.scroll-item a time {
  display: block;
  color: #f0821e;
  font-size: 14px;
  margin-top: 18px
}

.scroll-item a h4 {
  color: #333;
  font-size: 14px;
  margin-top: 16px;
  transition: all .4s
}

@media screen and (min-width: 1025px) {
  .scroll-item a h4 {
    font-size: 20px
  }
}

.scroll-item a p {
  color: #797979;
  margin: 20px 0 10px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3
}

@media screen and (min-width: 1025px) {
  .scroll-item a:hover .scroll-img img {
    transform: scale(1.1)
  }

  .scroll-item a:hover h4 {
    color: #f0821e
  }
}

.recent-check {
  padding: 40px 0 30px
}

@media screen and (min-width: 1025px) {
  .recent-check {
    padding: 80px 20px 70px
  }
}

.recent-check .title {
  margin-bottom: 30px;
  margin-left: 20px
}

@media screen and (min-width: 1025px) {
  .recent-check .title {
    margin-left: 0
  }
}

.recent-check-item {
  width: 160px
}

.recent-check .scroll-list figure {
  padding-bottom: 10px;
  overflow: hidden
}

@media screen and (min-width: 1025px) {
  .recent-check .scroll-list figure {
    padding-bottom: 0
  }
}

.recent-check .scroll-list figure .scroll-img {
  border-radius: 10px
}

@media screen and (min-width: 1025px) {
  .recent-check .scroll-list figure .scroll-img {
    border-radius: 20px
  }
}

.recent-check .scroll-list figure .scroll-img img {
  height: 94px
}

@media screen and (min-width: 600px) {
  .recent-check .scroll-list figure .scroll-img img {
    height: 159px
  }
}

@media screen and (min-width: 1025px) {
  .recent-check .scroll-list figure .scroll-img img {
    height: 173px
  }
}

.recent-check .scroll-list figcaption {
  position: relative;
  padding: 10px 10px 0 0;
  color: #797979;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold;
  transition: all .4s
}

.recent-check .scroll-list figcaption::after {
  content: "";
  width: 6px;
  height: 10px;
  display: block;
  background-image: url(../img/chevron-right-icon-orange.svg);
  position: absolute;
  top: 15px;
  right: 0
}

@media screen and (min-width: 1025px) {
  .recent-check .scroll-list figcaption::after {
    width: 7px;
    height: 12px;
    top: 17px
  }
}

@media screen and (min-width: 1025px) {
  .recent-check .scroll-list a:hover img {
    transform: scale(1.1)
  }

  .recent-check .scroll-list a:hover figcaption {
    color: #f0821e
  }
}

@media screen and (min-width: 600px) {
  .recent-check .scroll-item {
    max-width: 257px;
    width: 100%
  }
}

.recent-check .tag-block {
  margin-left: 20px;
  margin-bottom: 10px
}

@media screen and (min-width: 1025px) {
  .recent-check .tag-block {
    margin-left: 0
  }
}

.recent-check .tag-block .tag-title {
  font-size: 14px;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold;
  margin-top: 20px
}

.recent-check .tag-block .tag-title:first-of-type {
  margin-top: 10px
}

@media screen and (min-width: 1025px) {
  .recent-check .tag-block .tag-title {
    font-size: 18px;
    margin-top: 30px
  }

  .recent-check .tag-block .tag-title:first-of-type {
    margin-top: 40px
  }
}

.recent-check .tag-block .tag-title+.tag-list {
  margin-top: 10px
}

.recent-check .tag-block .tag-list {
  max-height: none
}

.footer {
  font-size: 12px;
  background-color: #f0821e;
  color: #fff
}

.footer-title {
  font-size: 18px
}

@media screen and (min-width: 1025px) {
  .footer-title {
    font-size: 30px;
    text-align: center
  }
}

.footer-list {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 10px;
  column-gap: 10px;
  border-bottom: 4px solid rgba(255, 255, 255, .2);
  padding-bottom: 40px
}

@media screen and (min-width: 1025px) {
  .footer-list {
    -moz-column-gap: 16px;
    column-gap: 16px;
    padding-bottom: 60px;
    margin-top: 30px;
    justify-content: center
  }
}

.footer-item a {
  color: #fff;
  font-size: 12px
}

.footer-item a::after {
  content: "|";
  margin-left: 12px
}

@media screen and (min-width: 1025px) {
  .footer-item a {
    font-size: 14px
  }

  .footer-item a::after {
    margin-left: 18px
  }
}

@media screen and (min-width: 1025px) {
  .footer-item a:hover {
    text-decoration: underline
  }
}

.footer-item:last-child a::after {
  content: ""
}

.footer a {
  display: inline-block;
  padding: 5px
}

.company {
  margin: 0 0;
  text-align: center
}

.company-nav {
  display: flex;
  justify-content: center;
  gap: 15px
}

.company-nav a {
  color: #fff;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold
}

@media screen and (min-width: 1025px) {
  .company-nav a:hover {
    opacity: .7
  }
}

.company .footer-note-modal {
  padding: 5px;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold;
  display: block;
  transition: all .5s;
  cursor: pointer
}

@media screen and (min-width: 1025px) {
  .company .footer-note-modal:hover {
    opacity: .7
  }
}

@media screen and (min-width: 1025px) {
  .company {
    font-size: 14px
  }
}

.company .copyright {
  margin-top: 20px;
  color: #fce6d1
}

.breadcrumb {
  font-size: 10px;
  margin-bottom: 20px
}

@media screen and (min-width: 600px) {
  .breadcrumb {
    font-size: 12px
  }
}

@media screen and (min-width: 1025px) {
  .breadcrumb {
    margin-bottom: 40px
  }
}

.breadcrumb ol {
  display: flex;
  margin-top: 5px
}

.breadcrumb ol li {
  color: #797979
}

.breadcrumb ol li a {
  color: #797979;
  text-decoration: underline
}

@media screen and (min-width: 1025px) {
  .breadcrumb ol li a:hover {
    color: rgba(121, 121, 121, .7)
  }
}

.breadcrumb ol li:not(:last-of-type)::after {
  content: "";
  background-image: url(../img/chevron-right-icon-gray.svg);
  width: 5px;
  height: 8px;
  display: inline-block;
  margin: 0 8px
}

@media screen and (min-width: 1025px) {
  .breadcrumb ol li:not(:last-of-type)::after {
    margin: 0 10px
  }
}

.list-container {
  padding: 20px 20px 50px
}

.list-search .search-container {
  text-align: left;
  box-shadow: 0 6px 0 #ddd
}

.list-search .title {
  font-size: 16px
}

.list-search .search-block button {
  width: 100%;
  margin-top: 15px
}

@media screen and (min-width: 1025px) {
  .list-search .search-block button {
    margin-top: 20px
  }
}

.list-search .search-block button:disabled {
  background-color: #797979;
  pointer-events: none
}

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

  .list-search .search-block .primary-btn,
  .list-search .search-block .orange-btn,
  .list-search .search-block h2 {
    font-size: 20px
  }

  .list-search .search-block .orange-outline-btn {
    text-align: left;
    padding: 12px 20px;
    position: relative;
    border-width: 2px
  }

  .list-search .search-block .orange-outline-btn img {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    cursor: pointer
  }

  .list-search .search-block .search-area {
    border-top: 2px solid #ddd;
    margin-top: 30px;
    padding-top: 30px;
    width: 100%
  }

  .list-search .search-block .search-category {
    margin-top: 30px;
    border-top: 2px solid #ddd;
    padding-top: 30px;
    width: 100%
  }

    .list-search .search-block .search-address {
      margin-top: 40px;
    }
}

.list-search .no-option {
  margin-top: 20px
}

@media screen and (min-width: 1025px) {
  .list-search .no-option {
    margin-top: 30px
  }
}

.list-search .tag-block {
  margin-top: 30px;
  padding-top: 30px;
  border-top: 2px solid #ddd
}

@media screen and (min-width: 1025px) {
  .list-search .tag-block {
    padding-top: 30px
  }
}

.list-search .tag-list {
  margin-top: 15px;
  justify-content: flex-start
}

.displayed-number {
  margin: 40px 0 10px
}

@media screen and (min-width: 1025px) {
  .displayed-number {
    position: absolute;
    top: -35px;
    right: 0;
    margin: 0
  }
}

.search-number {
  text-align: center;
  color: #797979;
  font-size: 14px
}

.search-number .total-number {
  color: #f0821e;
  font-size: 18px;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold
}

.items {
  padding: 25px 20px;
  background-color: #fff;
  border-radius: 30px;
  box-shadow: 0 4px 0 #ddd
}

@media screen and (min-width: 1025px) {
  .items {
    box-shadow: 0 6px 0 #ddd;
    padding: 40px
  }
}

@media screen and (min-width: 1025px) {
  .items>a:hover {
    opacity: .7
  }
}

.items .title {
  font-size: 20px;
  text-decoration: underline;
  color: #143a60;
  display: inline-block;
  margin-bottom: 8px
}

@media screen and (min-width: 1025px) {
  .items .title {
    font-size: 30px
  }
}

.items .transportation-access,
.items address {
  padding-left: 18px;
  margin-top: 7px;
  color: #797979;
  font-size: 10px;
  position: relative
}

.items .transportation-access img,
.items address img {
  position: absolute;
  left: 0;
  top: 2px
}

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

  .items .transportation-access,
  .items address {
    font-size: 12px
  }
}

.items .nearest-station {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block
}

.items .breadcrumb {
  display: flex;
  margin-top: 4px;
  margin-bottom: 0;
  font-size: 10px
}

@media screen and (min-width: 1025px) {
  .items .breadcrumb {
    font-size: 12px
  }
}

.items .breadcrumb img {
  margin-right: 3px
}

.items em {
  font-size: 14px;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold;
  color: #333;
  margin-top: 15px;
  display: inline-block
}

@media screen and (min-width: 1025px) {
  .items em {
    font-size: 20px;
    margin-top: 20px
  }
}

.items .item-img {
  margin-top: 15px;
  text-align: center;
  display: block
}

@media screen and (min-width: 600px) {
  .items .item-img {
    width: 100%;
    margin-top: 0
  }
}

.items .item-img img {
  transition: all .4s;
  border-radius: 20px;
  width: 100%;
  max-width: 340px
}

@media screen and (min-width: 1025px) {
  .items .item-img img:hover {
    opacity: .7
  }
}

.items .reservation-block {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 15px;
  width: 100%
}

@media screen and (min-width: 1025px) {
  .items .reservation-block {
    display: block;
    margin-top: 0
  }
}

.items .reservation-block button {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 6px 0;
  width: 50%;
  font-size: 12px
}

@media screen and (min-width: 600px) {
  .items .reservation-block button {
    width: 100%;
    margin: 0 auto 20px;
    max-width: 300px
  }

  .items .reservation-block button img {
    width: 20px;
    height: 20px;
    margin-right: 10px
  }

  .items .reservation-block button img.tel-icon {
    margin-right: 6px
  }
}

@media screen and (min-width: 1025px) {
  .items .reservation-block button {
    padding: 23px 0;
    font-size: 16px;
    white-space: nowrap
  }
}

.items .reservation-block button .brackets {
  font-size: 10px;
  display: block
}

@media screen and (min-width: 1025px) {
  .items .reservation-block button .brackets {
    font-size: 13px;
    display: inline
  }
}

.items .tel-note {
  position: relative;
  text-align: center;
  margin-top: 10px
}

.items .tel-note span {
  color: #797979;
  font-size: 12px;
  text-decoration: underline
}

@media screen and (min-width: 600px) {
  .items .tel-note span:hover+.note-dialog {
    display: block
  }
}

.items .tel-note .note-dialog {
  display: none;
  color: #fff;
  background-color: rgba(51, 51, 51, .95);
  padding: 17px 15px;
  border-radius: 20px;
  width: 275px;
  font-size: 12px;
  text-align: left;
  position: absolute;
  top: -145px;
  left: 50%;
  transform: translateX(-50%)
}

.items .tel-note .note-dialog::after {
  content: "";
  position: absolute;
  bottom: -21px;
  left: 50%;
  transform: translateX(-50%);
  border: 11px solid rgba(0, 0, 0, 0);
  border-top: 10px solid rgba(51, 51, 51, .95)
}

.items .tel-note .note-dialog.is-show {
  display: block
}

@media screen and (min-width: 600px) {
  .items .flex-block {
    display: flex;
    margin-top: 20px
  }
}

.items .flex-block .right-block {
  width: 100%
}

@media screen and (min-width: 600px) {
  .items .flex-block .right-block {
    margin-left: 30px
  }
}

.items .availability {
  margin-top: 20px
}

@media screen and (min-width: 600px) {
  .items .availability {
    width: 100%;
    max-width: 944px
  }
}

@media screen and (min-width: 1025px) {
  .items .availability {
    margin-top: 30px;
    width: 100%
  }
}

.items .availability-title {
  display: flex;
  align-items: center
}

.items .availability-title img {
  margin-right: 8px
}

.items .availability-title h3 {
  font-size: 14px
}

@media screen and (min-width: 1025px) {
  .items .availability-title h3 {
    font-size: 20px
  }
}

.items .availability-block {
  margin-top: 15px
}

@media screen and (min-width: 1025px) {
  .items .availability-block {
    margin-top: 30px
  }
}

.items .availability-block .sat .week {
  background-color: #b7d6e5
}

.items .availability-block .sun .week {
  background-color: #f8cdcd
}

.items .availability-block .week {
  background-color: #e8e4d5;
  border-radius: 2px;
  padding: 4px 0;
  text-align: center;
  font-size: 11px
}

@media screen and (min-width: 1025px) {
  .items .availability-block .week {
    font-size: 16px
  }
}

.items .availability .availability-list {
  border-top: 1px solid #ddd;
  border-left: 1px solid #ddd;
  display: flex;
  flex-wrap: wrap
}

.items .availability .availability-list li {
  width: 14.2857142857%;
  border-bottom: 1px solid #ddd
}

.items .availability .availability-list li.event-invalid {
  pointer-events: none
}

.items .availability .availability-list .reservation-link {
  padding: 3px 3px 5px;
  display: block;
  color: #333
}

@media screen and (min-width: 1025px) {
  .items .availability .availability-list .reservation-link {
    padding: 5px 4px 8px
  }
}

.items .availability .availability-list .reservation-link:last-child {
  border-right: 1px solid #ddd
}

@media screen and (min-width: 1025px) {
  .items .availability .availability-list .reservation-link:hover {
    background-color: #f5f4f0
  }
}

.items .availability .availability-list .reservation-link .date {
  font-size: 11px;
  padding: 5px 0;
  text-align: center
}

@media screen and (min-width: 1025px) {
  .items .availability .availability-list .reservation-link .date {
    font-size: 12px
  }
}

.items .availability .availability-list .reservation-link .ok::before {
  content: "";
  display: block;
  margin: 0 auto;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid #f0821e
}

@media screen and (min-width: 1025px) {
  .items .availability .availability-list .reservation-link .ok::before {
    width: 20px;
    height: 20px
  }
}

.items .availability .availability-list .reservation-link .ng::before,
.items .availability .availability-list .reservation-link .rest::before,
.items .availability .availability-list .reservation-link .question::before {
  display: block;
  text-align: center;
  color: #797979;
  font-size: 11px;
  font-weight: 500
}

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

  .items .availability .availability-list .reservation-link .ng::before,
  .items .availability .availability-list .reservation-link .rest::before,
  .items .availability .availability-list .reservation-link .question::before {
    font-size: 16px
  }
}

.items .availability .availability-list .reservation-link .ng::before {
  content: "-"
}

.items .availability .availability-list .reservation-link .rest::before {
  content: "休"
}

.items .availability .availability-list .reservation-link .question::before {
  content: "問";
  color: #f0821e
}

.items .availability-text {
  color: #797979;
  font-size: 12px;
  margin-top: 10px;
  text-indent: -1em;
  padding: 1em
}

@media screen and (min-width: 1025px) {
  .items .availability-text {
    margin-top: 15px
  }
}

.items table {
  color: #333;
  margin-top: 15px
}

@media screen and (min-width: 1025px) {
  .items table {
    margin-top: 30px
  }
}

.items table tr {
  border-bottom: 1px solid #e8e4d5
}

.items table tr:first-of-type {
  border-top: 1px solid #e8e4d5
}

.items table th,
.items table td {
  display: block;
  text-align: left;
  padding-bottom: 10px;
  line-height: 1.6
}

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

  .items table th,
  .items table td {
    display: table-cell;
    padding: 16px 0
  }
}

.items table th {
  display: flex;
  align-items: center;
  padding-top: 10px
}

@media screen and (min-width: 600px) {
  .items table th {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    padding: 16px 50px 0 0
  }
}

.items table th img {
  margin-right: 8px
}

.list-items {
  margin-bottom: 20px
}

.list-items a {
  display: inline-flex;
  align-items: flex-start
}

.list-items:last-of-type {
  margin-bottom: 40px
}

@media screen and (min-width: 1025px) {
  .list-items {
    margin-bottom: 50px
  }

  .list-items:last-of-type {
    margin-bottom: 45px
  }
}

@media screen and (min-width: 1025px) {
  .list-items .availability-block .week {
    font-size: 12px
  }
}

.list-crown {
  display: inline-block;
  position: relative;
  width: 36px;
  flex-shrink: 0;
  font-size: 20px;
  color: #fff;
  text-align: center;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold;
  z-index: 0;
  margin-right: 10px
}

.list-crown::before {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 0;
  height: 0;
  border: 18px solid rgba(0, 0, 0, 0);
  border-bottom-width: 30px;
  z-index: -1
}

.list-crown::after {
  content: "";
  position: absolute;
  bottom: 2px;
  left: 0;
  width: 0;
  height: 0;
  pointer-events: none;
  display: inline;
  border: 18px solid rgba(0, 0, 0, 0);
  border-top-width: 9px;
  z-index: -1
}

.list-crown.list-crown1::before {
  border-bottom-color: #fcca41
}

.list-crown.list-crown1::after {
  border-color: #fdbe10;
  border-top-color: rgba(0, 0, 0, 0)
}

.list-crown.list-crown2::before {
  border-bottom-color: #b9b8b8
}

.list-crown.list-crown2::after {
  border-color: #adadad;
  border-top-color: rgba(0, 0, 0, 0)
}

.list-crown.list-crown3::before {
  border-bottom-color: #b6826b
}

.list-crown.list-crown3::after {
  border-color: #b87251;
  border-top-color: rgba(0, 0, 0, 0)
}

.list-crown.list-crown0 {
  width: auto;
  min-width: 34px;
  height: 28px;
  padding: 0 5px;
  background-color: #797979;
  border-radius: 15px
}

.list-crown.list-crown0::before {
  content: none
}

.list-crown.list-crown0::after {
  content: none
}

@media screen and (min-width: 1025px) {
  .list-crown {
    width: 42px;
    margin-top: 8px;
    font-size: 24px
  }

  .list-crown::before {
    bottom: 8px;
    border-width: 21px;
    border-bottom-width: 33px
  }

  .list-crown::after {
    border-width: 21px;
    border-top-width: 12px
  }

  .list-crown.list-crown0 {
    min-width: 42px;
    height: 34px
  }
}

.fixed-menu .footer {
  padding-bottom: 106px
}

@media screen and (min-width: 600px) {
  .fixed-menu .footer {
    padding-bottom: 40px
  }
}

.fixed-block {
  background-color: rgba(232, 228, 213, .9);
  position: fixed;
  bottom: 0;
  display: flex;
  justify-content: space-between;
  width: 100%;
  padding: 18px;
  z-index: 1
}

.fixed-block button {
  font-size: 13px;
  padding: 13px 0;
  width: 50%;
}

.fixed-block button:first-of-type {
  margin-right: 10px;
}

.fixed-block button img {
  margin-right: 8px;
  width: 18px;
}

.reservation-fixed-menu .footer {
  padding-bottom: 106px;
}

@media screen and (min-width: 1025px) {
  .reservation-fixed-menu .footer {
    padding-bottom: 120px
  }
}

.reservation-fixed-block {
  justify-content: center
}

.reservation-fixed-block button {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 18px;
  padding: 6.5px 0;
  max-width: 490px
}

.reservation-fixed-block button .brackets {
  display: block;
  font-size: 14px
}

.reservation-fixed-block .orange-outline-btn {
  background-color: #fff
}

@media screen and (min-width: 1025px) {
  .reservation-fixed-block button {
    font-size: 24px;
    padding: 11px 0
  }

  .reservation-fixed-block button .brackets {
    font-size: 18px;
    display: inline
  }

  .reservation-fixed-block button img {
    width: 20px;
    height: 20px
  }
}

.filter .title {
  font-size: 16px
}

@media screen and (min-width: 1025px) {
  .filter .title {
    font-size: 20px
  }
}

.filter .picky-list,
.filter .trouble-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 0;
  margin-top: 20px
}

.filter .picky-list {
  gap: 9px 0
}

.filter .picky-item,
.filter .trouble-item {
  width: 50%;
  flex-basis: 1
}

.filter .picky-item label,
.filter .picky-item a,
.filter .trouble-item label,
.filter .trouble-item a {
  font-size: 14px;
  color: #143a60
}

.filter .picky-item a::before,
.filter .trouble-item a::before {
  content: "";
  background-image: url(../img/chevron-right-icon-orange.svg);
  width: 6px;
  height: 10px;
  display: inline-block;
  margin-right: 8px
}

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

  .filter .picky-item a:hover,
  .filter .trouble-item a:hover {
    text-decoration: underline
  }
}

.filter .picky-item {
  width: 48%
}

.modal,
.footer-modal {
  display: none;
  min-height: 100vh;
  min-height: -webkit-fill-available;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  margin: auto;
  z-index: 100
}

.modal-bg {
  background: rgba(51, 51, 51, .85);
  height: 100vh;
  position: absolute;
  width: 100%
}

.modal-close-btn {
  cursor: pointer;
  position: absolute;
  top: 20px;
  right: 20px
}

@media screen and (min-width: 1025px) {
  .modal-close-btn {
    top: 30px;
    right: 30px
  }
}

.modal-inner {
  background: #fff;
  left: 50%;
  position: absolute;
  top: 50px;
  transform: translateX(-50%);
  width: calc(100% - 40px);
  max-width: 1000px;
  height: calc(100% - 70px);
  border-radius: 20px;
  box-shadow: 0 0 20px rgba(51, 51, 51, .2)
}

@media screen and (min-width: 1025px) {
  .modal-inner {
    width: 90%;
    height: 600px;
    top: 50%;
    transform: translate(-50%, -50%)
  }
}

.modal-inner .modal-content {
  position: relative;
  padding: 30px 30px 104px;
  height: 100%;
  overflow-y: scroll;
  text-align: left
}

@media screen and (min-width: 1025px) {
  .modal-inner .modal-content {
    padding: 60px
  }
}

@media screen and (min-width: 1025px) {
  .modal-inner .modal-content .search-block input {
    width: calc(50% - 70px)
  }
}

.modal-inner .modal-content .search-block button:disabled {
  background-color: #797979;
  pointer-events: none
}

.modal-inner .modal-content .fixed-search-btn {
  justify-content: center;
  position: fixed;
  bottom: 0;
  width: calc(100% - 60px);
  padding-bottom: 30px;
  background-color: #fff
}

@media screen and (min-width: 1025px) {
  .modal-inner .modal-content .fixed-search-btn {
    position: static;
    width: 100%;
    padding-bottom: 0
  }
}

.modal-inner .modal-content input:disabled {
  opacity: .5
}

.modal-inner .modal-content .primary-btn {
  margin-top: 20px
}

@media screen and (min-width: 1025px) {
  .modal-inner .modal-content .primary-btn {
    margin-left: 0;
    margin-top: 30px;
    font-size: 18px;
    padding: 14px 0
  }
}

.modal-inner .modal-content .orange-btn {
  margin-top: 30px
}

@media screen and (min-width: 1025px) {
  .modal-inner .modal-content .orange-btn {
    margin-top: 0;
    width: 140px;
    border-radius: 0 10px 10px 0
  }
}

.modal-inner .modal-content .title {
  margin-top: 30px
}

@media screen and (min-width: 1025px) {
  .modal-inner .modal-content .title {
    margin-top: 40px;
    font-size: 20px
  }
}

.modal-inner .modal-content .tag-list,
.modal-inner .modal-content .picky-list,
.modal-inner .modal-content .trouble-list {
  border-top: 1px solid #ddd;
  margin-top: 10px;
  padding-top: 15px;
  justify-content: flex-start
}

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

  .modal-inner .modal-content .tag-list,
  .modal-inner .modal-content .picky-list,
  .modal-inner .modal-content .trouble-list {
    margin-top: 15px;
    padding-top: 20px
  }
}

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

  .modal-inner .modal-content .picky-item,
  .modal-inner .modal-content .trouble-item {
    width: auto;
    margin-right: 30px
  }
}

@media screen and (min-width: 1025px) {
  .note-block {
    text-align: left
  }
}

.note-block .note-modal {
  display: inline-block;
  color: #797979;
  font-size: 13px;
  text-decoration: underline;
  margin-top: 20px;
  cursor: pointer
}

@media screen and (min-width: 1025px) {
  .note-block .note-modal {
    font-size: 14px;
    margin-top: 40px
  }
}

.note-block cite {
  display: block;
  margin-top: 20px
}

@media screen and (min-width: 1025px) {
  .note-block cite {
    margin-top: 12px
  }
}

.note-modal-content {
  color: #143a60
}

.note-modal-content .modal-content_title {
  display: block;
  font-size: 16px;
  padding-bottom: 15px;
  border-bottom: 1px solid #ddd;
  text-align: center;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", YuGothic, Meiryo, sans-serif;
  font-weight: bold
}

@media screen and (min-width: 1025px) {
  .note-modal-content .modal-content_title {
    text-align: left;
    font-size: 20px
  }
}

.note-modal-content p {
  margin-top: 20px
}

@media screen and (min-width: 1025px) {
  .note-modal-content p {
    margin-top: 30px;
    font-size: 14px
  }
}

.sitemap-header {
  border-bottom: 1px solid #ddd
}

.sitemap-container {
  padding: 20px 20px 0
}

.sitemap-container .breadcrumb {
  margin-bottom: 0
}

.sitemap {
  max-width: 1000px;
  padding: 10px;
  margin: 0 auto
}

@media screen and (min-width: 1025px) {
  .sitemap {
    padding: 40px
  }
}

.sitemap h1 {
  font-size: 15px;
  color: #ef841b
}

@media screen and (min-width: 1025px) {
  .sitemap h1 {
    font-size: 25px
  }
}

.sitemap h2 {
  margin-top: 15px;
  padding: 5px;
  color: #494949;
  font-size: 10px;
  background: #fffaf4;
  border-left: solid 5px #ffaf58
}

@media screen and (min-width: 1025px) {
  .sitemap h2 {
    margin-top: 30px;
    padding: 8px;
    font-size: 16px
  }
}

.sitemap li {
  position: relative
}

.sitemap li a {
  color: #000
}

.sitemap li>h3 {
  margin-top: 15px;
  padding-left: 10px;
  border-bottom: double 5px #b0b0b0
}

.sitemap li>h3 a {
  font-size: 10px;
  color: #ef841b
}

@media screen and (min-width: 1025px) {
  .sitemap li>h3 a {
    font-size: 16px
  }
}

.sitemap li::before {
  content: "";
  position: absolute;
  left: 0;
  width: 0;
  height: 0;
  border-width: 5px;
  border-style: solid;
  border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #ffaf58
}

.sitemap li.genre-large::before {
  top: 8px
}

@media screen and (min-width: 1025px) {
  .sitemap li.genre-large::before {
    top: 10px
  }
}

.sitemap li h4 {
  padding-left: 10px;
  font-size: 10px;
  display: inline-block;
  border-bottom: 1px solid #333
}

@media screen and (min-width: 1025px) {
  .sitemap li h4 {
    font-size: 15px
  }
}

.sitemap li.genre-medium {
  margin-top: 10px;
  width: 100%
}

.sitemap li.genre-medium::before {
  top: 5px
}

@media screen and (min-width: 1025px) {
  .sitemap li.genre-medium::before {
    top: 7px
  }
}

.sitemap li .prefectures {
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 5px 10px
}

@media screen and (min-width: 1025px) {
  .sitemap li .prefectures {
    margin: 0 0 5px 20px
  }
}

.sitemap li.genre-small {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  justify-content: center;
  margin: 15px 15px 0 0;
  padding-left: 10px;
  width: auto;
  font-size: 10px;
  border-bottom: dashed 1px #ccc
}

@media screen and (min-width: 1025px) {
  .sitemap li.genre-small {
    margin: 5px 0 5px 5px;
    width: 158px;
    height: 40px;
    font-size: 13px
  }
}

.sitemap li.genre-small::before {
  top: 2px
}

@media screen and (min-width: 1025px) {
  .sitemap li.genre-small::before {
    top: 14px
  }
}

.sitemap .area-all h3 {
  border-bottom: 1px solid #000
}

.sitemap .area-all .genre-small {
  width: 20%
}

@media screen and (min-width: 1025px) {
  .sitemap .area-all .genre-small {
    width: 158px
  }
}

.no-search-result {
  margin-top: 10px;
  color: #333
}
