@charset "UTF-8";
:root {
  --breakpoint: 768px;
  --font-weight: 500;
  --pc-letter-spacing: 0.06em;
  --pc-line-height: 2;
  --color-base-txt: #333;
  --color-base-txt-rgb: 51 51 51;
  --color-base-bg: #fff;
  --color-base-bg-rgb: 255 255 255;
  --color-main: #005d55;
  --color-main-rgb: 0 93 85;
  --color-main-vbrt: #159886;
  --color-main-soft: #67c0af;
  --color-main-lite: #c1e2d2;
  --color-main-pale: #f6fbea;
  --color-sub: #d1a43e;
  --color-sub-rgb: 209 164 62;
  --color-sub-vbrt: #d58d00;
  --color-sub-soft: #e3d0a3;
  --color-sub-pale: #fcfadf;
  --color-acnt: #84b400;
  --color-acnt-rgb: 132 180 0;
  --color-acnt-vbrt: #c7cc2b;
  --color-acnt-mute: #e6eed1;
  --color-acnt-pale: #f5ffd8;
  --color-acnt-pale2: #f8fbe6;
  --color-top-txt: #2a2a2a;
  --color-overview-bg: #fafbea;
  --color-overview-line: #b4b4b4;
  --color-nav-border: #c1c1c1;
  --color-border: #ccc;
  --color-attention: #d43540;
  --color-highlight: #fff5af;
  --color-shadow: rgb(0 0 0/0.16);
  --color-black: #000;
  --color-black-rgb: 0 0 0;
  --color-dgray: #696969;
  --color-dgray-rgb: 105 105 105;
  --color-gray: #ababab;
  --color-gray-rgb: 171 171 171;
  --color-lgray: #dbdbdb;
  --color-lgray-rgb: 219 219 219;
  --color-ghost: #f1f1f1;
  --color-ghost-rgb: 241 241 241;
  --color-white: #fff;
  --color-white-rgb: 255 255 255;
}

@font-face {
  font-weight: normal;
  src: url("fontello/font/fontello.woff2") format("woff2");
  font-family: "fontello";
  font-display: swap;
}
*:focus:not(:focus-visible),
*::before:focus:not(:focus-visible),
*::after:focus:not(:focus-visible) {
  outline: none;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0s !important;
    animation-delay: 0s !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition: none !important;
  }
}
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:where([hidden]:not([hidden=until-found])) {
  display: none !important;
}

:where(html) {
  -webkit-text-size-adjust: 100%;
  color-scheme: dark light;
  -moz-tab-size: 2;
  -o-tab-size: 2;
  scrollbar-gutter: stable;
  tab-size: 2;
  interpolate-size: allow-keywords;
  line-height: 1.5;
}

:where(html:has(dialog:modal[open])) {
  overflow: clip;
}

@media (prefers-reduced-motion: no-preference) {
  :where(html:focus-within) {
    scroll-behavior: smooth;
  }
}
:where(body) {
  line-height: inherit;
  -webkit-font-smoothing: antialiased;
}

:where(input, button, textarea, select) {
  color: inherit;
  font: inherit;
  font-variation-settings: inherit;
  font-feature-settings: inherit;
  letter-spacing: inherit;
  word-spacing: inherit;
}

:where(textarea) {
  resize: vertical;
  resize: block;
}

:where(button, label, select, summary, [role=button], [role=option]) {
  cursor: pointer;
}

:where(button, [type=button], [type=reset], [type=submit]) {
  touch-action: manipulation;
}

:where(:disabled, label:has(> :disabled, + disabled)) {
  cursor: not-allowed;
}

:where(a) {
  color: inherit;
  text-underline-offset: 0.22em;
}

:where(ul, ol) {
  list-style: none;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block;
}

:where(img, picture, svg, video) {
  max-inline-size: 100%;
  block-size: auto;
}

:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
}

:where(h1, h2, h3) {
  line-height: calc(1em + 0.5rem);
}

:where(hr) {
  border: none;
  -webkit-border-before: 1px solid;
  block-size: 0;
  overflow: visible;
  border-block-start: 1px solid;
  color: inherit;
}

:where(dialog, [popover]) {
  max-width: unset;
  max-height: unset;
  inset: unset;
  overflow: unset;
  border: none;
  background: none;
  color: inherit;
}

:where(dialog:not([open], [popover]), [popover]:not(:popover-open)) {
  display: none !important;
}

:where(:focus-visible) {
  outline: 2px solid LinkText;
  outline-offset: 1px;
  box-shadow: 0 0 0 5px Canvas;
}

:where(:focus-visible, :target) {
  scroll-margin-block: 8vh;
}

:where(.visually-hidden:not(:focus-within, :active)) {
  -webkit-clip-path: inset(50%) !important;
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  border: 0 !important;
  white-space: nowrap !important;
  clip-path: inset(50%) !important;
  -webkit-user-select: none !important;
  user-select: none !important;
}

:where(a) {
  color: inherit;
  text-decoration: none;
}

:where(button) {
  border: none;
  background: transparent;
}

:where(em) {
  font-style: normal;
  font-weight: bold;
}

:where(i) {
  font-style: normal;
}

:where(iframe) {
  max-width: 100%;
  height: 100%;
  border: none;
}

:where(img) {
  height: auto;
  border: none;
  -o-object-fit: contain;
  object-fit: contain;
}

:where(p) {
  margin: 0 0 1em;
}

:where(*) {
  letter-spacing: var(--sp-letter-spacing, normal);
}
:where(*):before, :where(*)::after {
  letter-spacing: normal;
}

html {
  font-size: 2.7777777778vw;
  scroll-padding-top: var(--sp-header-height, 0);
}

body {
  font-weight: var(--font-weight, normal);
  font-size: 1.4rem;
  font-family: "Zen Kaku Gothic New", "Hiragino Sans", "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
  word-wrap: break-word;
  background-color: var(--color-base-bg);
  color: var(--color-base-txt);
}
body.spnav_modal {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

main {
  line-height: var(--sp-line-height, inherit);
}

@media screen and (width >= 768px), print {
  :where(*) {
    letter-spacing: var(--pc-letter-spacing, normal);
  }
  html {
    font-size: 62.5%;
    scroll-padding-top: var(--pc-header-height, 0);
  }
  body {
    font-size: 1.8rem;
  }
  a, button {
    transition: 0.3s;
  }
  a:before, a::after, button:before, button::after {
    transition: inherit;
  }
  main {
    line-height: var(--pc-line-height, inherit);
  }
}
@media screen and (width < 767px) {
  .header_wrap:has(+ .js-sticky) .logo {
    z-index: 1;
    position: fixed;
    inset: 0 0 auto;
    transition: transform 0.5s;
  }
  .header_wrap:has(+ .js-sticky.is_hide) .logo {
    transform: translateY(-100%);
  }
}
#global_header .header_wrap {
  padding-top: 6.6rem;
}
#global_header .header_wrap .logo {
  width: 100%;
  height: 6.6rem;
  padding: 0.7rem 7.4rem 0.7rem 1rem;
  border-top: 3px solid var(--color-main);
  background-color: var(--color-white);
}
#global_header .header_wrap .logo a {
  display: block;
}
#global_header .header_wrap .mininfo {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  padding: 0.8rem 1rem 0.6rem;
  gap: 0.4rem 1rem;
  background-color: var(--color-overview-bg);
  color: var(--color-main);
}
#global_header .header_wrap .mininfo li.dept {
  padding: 0.1rem 1em 0.2rem;
  border-radius: 2em;
  background-color: var(--color-main);
  color: var(--color-white);
  text-align: center;
}
#global_header .header_wrap .mininfo li.dept em {
  font-weight: 500;
  font-size: 1.3rem;
  letter-spacing: 0.1em;
}
#global_header .header_wrap .mininfo li.adr {
  font-size: 1.5rem;
  letter-spacing: 0.05em;
}
#global_header .header_wrap .mininfo li.tel {
  font-weight: 500;
  font-size: 2.4rem;
  line-height: 1;
  font-family: "Poppins", sans-serif;
}
#global_header .header_wrap .mininfo li.tel::before {
  display: inline-block;
  margin-right: 0.1em;
  content: "TEL.";
  font-size: 83%;
}

@media screen and (width < 767px) {
  body:not(#page_index) #global_header .header_wrap .mininfo {
    display: none;
  }
}
@media screen and (width >= 768px), print {
  #global_header {
    padding-top: 10px;
    border-top: 4px solid var(--color-main);
    background-color: var(--color-base-bg);
    color: var(--color-base-txt);
  }
  #global_header .header_wrap {
    display: flex;
    justify-content: space-between;
    max-width: 1200px;
    max-height: 100px;
    margin-inline: auto;
    padding-top: 10px;
    padding-inline: clamp(0px, 264px + -22 * 1vw, 2%);
    gap: 0 20px;
  }
  #global_header .header_wrap .logo {
    aspect-ratio: 23/4;
    width: clamp(400px, 293.333px + 13.889vw, 460px);
    height: auto;
    padding: 0;
    border-top: 0 none;
  }
  #global_header .header_wrap .mininfo {
    display: block;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0;
    padding: 0;
    background-color: transparent;
    color: var(--color-main);
    text-align: right;
  }
  #global_header .header_wrap .mininfo li.dept {
    display: inline-block;
    width: clamp(110px, -64.222px + 22.685vw, 208px);
    padding: 2px 0;
  }
  #global_header .header_wrap .mininfo li.dept em {
    font-size: clamp(1.4rem, 0.5111rem + 1.157vw, 1.9rem);
  }
  #global_header .header_wrap .mininfo li.adr {
    display: inline-block;
    margin-left: clamp(0px, -17.778px + 2.315vw, 10px);
    font-size: clamp(1.8rem, 1.4444rem + 0.463vw, 2rem);
    letter-spacing: 0.1em;
  }
  #global_header .header_wrap .mininfo li.tel {
    margin-top: clamp(4px, -10.222px + 1.852vw, 12px);
    font-size: clamp(2.4rem, 1.3333rem + 1.389vw, 3rem);
    letter-spacing: 0.03em;
  }
  #global_header .header_wrap .mininfo li.tel::before {
    font-size: 84%;
    letter-spacing: 0.04em;
  }
}
@media print {
  #global_header .header_wrap {
    margin-bottom: 0 !important;
  }
}
@media screen and (width < 767px) {
  .js-sp_modal {
    z-index: 2;
    position: fixed;
    top: 0;
  }
  .js-sp_modal::before {
    z-index: -10;
    position: fixed;
    width: 100vw;
    height: 100vh;
    inset: 6.8rem 0 0;
    transition: all 0.5s;
  }
  .js-sp_modal.js-sticky #sp_btn {
    transition: transform 0.5s;
  }
  .js-sp_modal.js-sticky.is_hide #sp_btn {
    transform: translateY(-6rem);
  }
  .js-sp_modal.is_overlay::before {
    z-index: 0;
    background: rgb(var(--color-white-rgb)/0.6);
    -webkit-backdrop-filter: blur(0.5rem);
    backdrop-filter: blur(0.5rem);
    content: "";
  }
  .js-sp_box {
    visibility: hidden;
    height: 0;
    transform: translateY(-3rem);
    opacity: 0;
    transition: 0.5s ease;
  }
  .js-sp_box.is_open {
    visibility: visible;
    height: auto;
    transform: translateY(0);
    opacity: 1;
  }
}
@media screen and (width >= 768px), print {
  .js-sticky {
    position: static;
  }
  .js-sticky.is_sticky {
    z-index: 5;
    position: fixed;
    width: 100%;
    inset: 0 0 auto;
  }
}
@media print {
  .js-pc_sticky.is_sticky {
    position: relative !important;
  }
}
@media screen and (width < 767px) {
  #global_nav {
    width: 100%;
  }
  #global_nav #sp_btn {
    position: fixed;
    top: 1rem;
    right: 1rem;
    width: 4.8rem;
    height: 4.8rem;
    margin: 0;
    padding: 0.2rem 0 0;
    border-radius: 0.3rem;
    background: var(--color-main);
    color: var(--color-white);
    line-height: 0.9;
    text-align: center;
  }
  #global_nav #sp_btn::before {
    display: block;
    content: '\ecd5';
    font-weight: normal;
    font-size: 2.4rem;
    font-family: "fontello";
    transition: 0.3s;
  }
  #global_nav #sp_btn::after {
    content: "MENU";
    font-weight: 400;
    font-size: 1.1rem;
    font-family: "Poppins", sans-serif;
  }
  #global_nav #sp_btn.close::before {
    transform: scale(-1, 1);
    content: "\ecd4";
  }
  #global_nav #sp_btn.close::after {
    content: "CLOSE";
  }
  #global_nav #sp_btn span {
    display: none;
  }
  #global_nav .gnav {
    position: absolute;
    top: 7rem;
    left: 3vw;
    width: 94vw;
    max-height: 80dvh;
    padding: 1.6rem 2.4rem;
    overflow-y: auto;
    background: var(--color-base-bg);
    color: var(--color-base-txt);
    font-size: 1.6rem;
  }
  #global_nav .gnav > li {
    padding-block: 0.5rem;
    border-bottom: 1px dotted var(--color-nav-border);
  }
  #global_nav .gnav > li > a {
    display: block;
    padding: 1rem 0.2rem;
  }
  #global_nav .gnav > li > a.is_current {
    color: var(--color-main);
  }
  #global_nav .gnav > li > a.is_current::before {
    display: inline-block;
    margin-right: 0.5em;
    transform: scale(1.2);
    content: '\ed24';
    color: var(--color-main-vbrt);
    font-weight: normal;
    font-family: "fontello";
  }
}
@media screen and (width >= 768px), print {
  #global_nav {
    width: 100%;
    min-height: 78px;
    padding-block: 15px;
    background: var(--color-base-bg);
    color: var(--color-base-txt);
    font-size: clamp(1.6rem, 1.2444rem + 0.463vw, 1.8rem);
  }
  #global_nav #sp_btn {
    display: none;
  }
  #global_nav .gnav {
    container-name: glnavi;
    container-type: inline-size;
    display: flex;
    justify-content: space-between;
    max-width: 1200px;
    margin-inline: auto;
    padding-inline: clamp(0px, 264px + -22 * 1vw, 2%);
    padding-block: 10px;
    line-height: 1.1;
  }
  #global_nav .gnav > li {
    flex-grow: 1;
    padding-inline: 10px;
    border-right: 1px solid var(--color-nav-border);
    text-align: center;
  }
  #global_nav .gnav > li:first-child {
    border-left: 1px solid var(--color-nav-border);
  }
  #global_nav .gnav > li.hn {
    display: none;
  }
  #global_nav .gnav > li > a {
    display: inline-grid;
    position: relative;
    place-content: center;
    height: 100%;
    min-height: 25px;
    word-break: auto-phrase;
  }
  #global_nav .gnav > li > a::after {
    display: block;
    position: absolute;
    width: 100%;
    height: 2px;
    inset: auto 0 0;
    transform: translateY(0);
    content: "";
  }
  #global_nav .gnav > li > a:hover::after, #global_nav .gnav > li > a:focus::after {
    transform: translateY(9px);
    background-color: var(--color-main-soft);
  }
  #global_nav .gnav > li > a.is_current::after {
    transform: translateY(9px);
    background-color: var(--color-main-vbrt);
  }
  #global_nav .gnav > li > a wbr {
    display: none;
  }
  @container glnavi (max-width: 1024px) {
    #global_nav .gnav > li > a {
      word-break: keep-all;
    }
    #global_nav .gnav > li > a wbr {
      display: block;
    }
  }
}
main :where(p, .txt) {
  text-align: justify;
}

.overview {
  background-color: var(--color-overview-bg);
  color: var(--color-base-txt);
}
.overview .overview_wrap {
  padding-top: 3.5rem;
  padding-bottom: 3rem;
  padding-inline: 1.5rem;
  font-size: 1.3rem;
}
.overview .primary .logo {
  width: 98%;
  margin-bottom: 1rem;
  padding-inline: 0.5rem;
}
.overview .primary .outline {
  display: grid;
  grid-template-columns: 6.2rem auto;
  gap: 0 1rem;
}
.overview .primary .outline dt {
  display: grid;
  align-items: center;
  padding-block: 1.4rem;
  border-bottom: 1px solid var(--color-main);
  text-align: center;
}
.overview .primary .outline dd {
  display: grid;
  align-items: center;
  padding-block: 1.4rem;
  border-bottom: 1px solid var(--color-overview-line);
}
.overview .primary .timetable {
  margin-top: 2.5rem;
  font-size: 1.4rem;
}
.overview .secondary {
  margin-top: 2.5rem;
  padding: 2rem 1.5rem;
  border-radius: 1rem;
  background-color: var(--color-white);
}
.overview .secondary .tit {
  color: var(--color-main);
  font-weight: 700;
  font-size: 1.8rem;
}
.overview .secondary .tit::after {
  display: block;
  height: 0.6rem;
  margin-top: 1.2rem;
  border-top: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  content: "";
}
.overview .secondary .map {
  padding: 1.5rem 0;
}
.overview .secondary .map img {
  margin-inline: auto;
  border-radius: 1rem;
}
.overview .secondary .lst_ul em {
  color: var(--color-main);
  font-weight: 500;
}
.overview .secondary .contactus {
  margin-top: 2rem;
  padding: 1.2rem 1.5rem 1.5rem;
  border-radius: 0.7rem;
  background-color: var(--color-acnt-pale);
}
.overview .secondary .contactus dt {
  padding-bottom: 0.6rem;
  border-bottom: 1px solid currentColor;
  color: var(--color-main);
  font-weight: 500;
  font-size: 1.4rem;
}
.overview .secondary .contactus dd {
  margin-top: 0.8rem;
}
.overview .secondary .contactus dd.tel {
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1;
}
.overview .secondary .contactus dd.tel span {
  font-size: 1.9rem;
  letter-spacing: 0.06em;
}
.overview .secondary .contactus dd.tel span a {
  letter-spacing: inherit;
}
.overview .secondary .contactus dd.fax {
  margin-top: 0.4rem;
  padding-left: 0.2rem;
  font-size: 1.4rem;
}
.overview .gmap {
  width: 100%;
  height: 30rem;
}
.overview .gmap iframe {
  width: 100%;
  height: 100%;
  border: none;
}

@media screen and (width >= 768px), print {
  .overview .overview_wrap {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
    max-width: 1200px;
    margin-inline: auto;
    padding-inline: clamp(0px, 396px + -33 * 1vw, 3%);
    padding-block: clamp(80px, 44.444px + 4.63vw, 100px);
    gap: 28px;
    font-size: 1.6rem;
  }
  .overview .primary .logo {
    width: 100%;
    max-width: 468px;
    margin-bottom: 20px;
    padding-inline: 0;
  }
  .overview .primary .outline {
    grid-template-columns: 90px auto;
    gap: 0 10px;
  }
  .overview .primary .outline dt, .overview .primary .outline dd {
    padding-block: 16px;
  }
  .overview .primary .timetable {
    margin-top: 30px;
    font-size: clamp(1.6rem, 1.2444rem + 0.463vw, 1.8rem);
  }
  .overview .primary .timetable_tbl tbody th {
    font-size: clamp(1.8rem, 1.0889rem + 0.926vw, 2.2rem);
  }
  .overview .primary .timetable_tbl tbody td {
    transform: scale(0.8);
    font-size: 1.8rem;
  }
  .overview .primary .timetable_note {
    gap: 12px clamp(5px, -30.556px + 4.63vw, 25px);
  }
  .overview .primary .timetable_note .opentime {
    gap: 0 clamp(5px, -14.556px + 2.546vw, 16px);
  }
  .overview .primary .timetable_note .opentime dt {
    padding: 3px clamp(8px, -6.222px + 1.852vw, 16px);
  }
  .overview .secondary {
    margin-top: 0;
    padding: 28px 33px 33px;
    border-radius: 20px;
  }
  .overview .secondary .tit {
    font-size: 2.2rem;
  }
  .overview .secondary .map {
    padding: 20px 0;
  }
  .overview .secondary .map img {
    border-radius: 20px;
  }
  .overview .secondary .lst_ul {
    margin-inline: 10px;
  }
  .overview .secondary .contactus {
    margin-top: 30px;
    padding: 16px 30px 20px;
    border-radius: 10px;
  }
  .overview .secondary .contactus dt {
    padding-bottom: 8px;
    font-size: 1.8rem;
  }
  .overview .secondary .contactus dd {
    margin-top: 10px;
  }
  .overview .secondary .contactus dd.tel {
    font-size: 2rem;
  }
  .overview .secondary .contactus dd.tel span {
    font-size: 2.4rem;
  }
  .overview .secondary .contactus dd.fax {
    margin-top: 6px;
    font-size: 1.8rem;
  }
  .overview .gmap {
    height: 480px;
  }
}
#global_footer {
  padding: 0 0 4.4rem;
  background-color: var(--color-main);
  color: var(--color-white);
  line-height: 1;
  text-align: center;
}
#global_footer .footer_wrap {
  display: none;
}
#global_footer .copyright {
  display: block;
  padding-block: 1.5rem;
  background-color: var(--color-base-bg);
  color: var(--color-base-txt);
  font-size: 1.2rem;
}

@media screen and (width >= 768px), print {
  #global_footer {
    padding: 0;
  }
  #global_footer .footer_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 1200px;
    margin-inline: auto;
    padding-top: 44px;
    padding-bottom: 47px;
    padding-inline: clamp(0px, 264px + -22 * 1vw, 2%);
    gap: 20px;
    font-size: 1.6rem;
  }
  #global_footer .footer_wrap > li::before {
    display: inline-block;
    margin-right: 3px;
    content: '\ecff';
    font-weight: normal;
    font-size: 96%;
    font-family: "fontello";
  }
  #global_footer .footer_wrap > li a:hover {
    text-decoration: underline;
  }
  #global_footer .copyright {
    padding-block: 20px;
    font-size: 1.6rem;
  }
}
.js-floating_btm {
  visibility: hidden;
  position: fixed;
  inset: auto 0 0;
  opacity: 0;
  transition: 0.5s;
}
.js-floating_btm.is_active {
  visibility: visible;
  opacity: 1;
}
@media screen and (width >= 768px), print {
  .js-floating_btm {
    inset: auto 20px 20px auto;
  }
}

#sp_footer {
  display: flex;
  width: 100%;
  height: 4.4rem;
  padding-right: 4rem;
  border-bottom: 3px solid var(--color-main);
}
#sp_footer span {
  display: flex;
  flex-grow: 1;
  align-items: center;
  justify-content: center;
  height: 100%;
  text-align: center;
}
#sp_footer span.tel {
  background-color: var(--color-main);
  color: var(--color-white);
  font-weight: 600;
  font-size: 1.7rem;
  font-family: "Poppins", sans-serif;
}
#sp_footer span.tel::before {
  display: inline-block;
  margin-right: 2px;
  margin-left: -2px;
  content: '\e802';
  font-weight: normal;
  font-size: 88%;
  font-family: "fontello";
}
#sp_footer span.txt {
  background-color: var(--color-main-vbrt);
  color: var(--color-white);
  font-size: 1.3rem;
}
@media screen and (width >= 768px), print {
  #sp_footer {
    display: none;
  }
}

#pageup {
  display: block;
  z-index: 1;
  position: absolute;
  right: 0;
  bottom: 0.2rem;
  width: 4rem;
  height: 4.2rem;
  padding: 0 0 0.3rem;
  border: 1px solid currentColor;
  background: var(--color-white);
  color: var(--color-main);
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1;
  font-family: "Poppins", sans-serif;
  text-align: center;
}
#pageup::before {
  display: block;
  padding-block: 0.3rem;
  transform: scale(1, -1);
  content: '\ed02';
  font-weight: normal;
  font-size: 1.4rem;
  font-family: "fontello";
}
@media screen and (width >= 768px), print {
  #pageup {
    right: 0;
    bottom: 0;
    width: 92px;
    height: 92px;
    padding: 0 0 10px;
    border-radius: 50%;
    font-size: 1.8rem;
    letter-spacing: 0.08em;
  }
  #pageup::before {
    margin-bottom: 8px;
    padding-block: 0;
    font-size: 2.4rem;
  }
  #pageup:hover {
    transform: translateY(-2px);
    box-shadow: 0 2px 0 0 var(--color-main-soft);
    color: var(--color-main-vbrt);
  }
}
@media print {
  #pageup {
    display: none !important;
  }
}

a[href=""], .nolink {
  pointer-events: none;
}

.sp_n {
  display: none;
}

@media screen and (width >= 768px), print {
  .sp_n {
    display: block;
  }
  .pc_n {
    display: none;
  }
}
.cf::after {
  display: block;
  clear: both;
  content: "";
}

.l-cf {
  display: flow-root;
}

.wrap {
  margin-inline: 1.5rem;
}
@media screen and (width >= 768px), print {
  .wrap {
    max-width: 1200px;
    margin-inline: auto;
  }
  body > *:has(.wrap) {
    container-name: wrapper;
    container-type: inline-size;
  }
  @container wrapper (max-width: 1276.5957446809px) {
    .wrap {
      width: 94%;
    }
  }
}

.fl_l {
  float: left;
}

.fl_r {
  float: right;
}

.txt_l {
  text-align: left !important;
}

.txt_r {
  text-align: right !important;
}

.txt_c {
  text-align: center !important;
}

.img_c {
  max-width: 80%;
  margin: 0 auto 1.4rem;
}
.img_c.w100 {
  max-width: 100%;
}

.img_l, .img_r {
  max-width: 80%;
  margin: 0 auto 1.4rem;
}

@media screen and (width < 767px) {
  .img_c.sp_w100 {
    max-width: 100%;
  }
  .img_c.mb0, .img_l.mb0, .img_r.mb0 {
    margin-bottom: 1.4rem;
  }
}
@media screen and (width >= 768px), print {
  .img_c {
    max-width: 750px;
    margin: 0 auto 20px;
  }
  .img_c.pc_w100 {
    max-width: 100%;
  }
  .img_l {
    max-width: clamp(280px, 111.111px + 21.991vw, 375px);
    margin-top: calc((1lh - 1em) * 0.5);
    margin-right: clamp(30px, -32.222px + 8.102vw, 65px);
    margin-bottom: 0.5em;
    margin-left: 0;
    float: left;
  }
  .img_r {
    max-width: clamp(280px, 111.111px + 21.991vw, 375px);
    margin-top: calc((1lh - 1em) * 0.5);
    margin-right: 0;
    margin-bottom: 0.5em;
    margin-left: clamp(30px, -32.222px + 8.102vw, 65px);
    float: right;
  }
}
.mb40 {
  margin-bottom: 4rem;
}

.mb10 {
  margin-bottom: 1rem;
}

.mb5 {
  margin-bottom: 0.5rem;
}

.mb0 {
  margin-bottom: 0;
}

.mt40 {
  margin-top: 4rem;
}

.mt30 {
  margin-top: 3rem;
}

.mt20 {
  margin-top: 2rem;
}

.mt10 {
  margin-top: 1rem;
}

.mt5 {
  margin-top: 0.5rem;
}

.mt0 {
  margin-top: 0;
}

@media screen and (width >= 768px), print {
  .mb40 {
    margin-bottom: 80px;
  }
  .mb10 {
    margin-bottom: 20px;
  }
  .mb5 {
    margin-bottom: 10px;
  }
  .mt40 {
    margin-top: 80px;
  }
  .mt30 {
    margin-top: 60px;
  }
  .mt20 {
    margin-top: 40px;
  }
  .mt10 {
    margin-top: 20px;
  }
  .mt5 {
    margin-top: 10px;
  }
}
:where(section, .intro):has(> .img_r, > .img_l) {
  display: flow-root;
}
:where(section, .intro):has(> .img_r, > .img_l) > section:first-of-type {
  clear: both;
}
:where(section, .intro) > :last-child {
  margin-bottom: 0;
}

article .intro {
  margin-bottom: 4.5rem;
}
article > :where(section) ~ :where(section) {
  margin-top: 4rem;
}
article > :where(section) :where(section) {
  margin-top: 3rem;
}
article > :where(section) :where(section) :where(section) {
  margin-top: 2rem;
}
article :is(h2, h3, h4, h5, h6) + :is(section) {
  margin-top: 0;
}
article :is(h2, h3, h4, h5, h6) + p {
  margin-top: calc((1em - 1lh) * 0.5);
}

@media screen and (width >= 768px), print {
  article .intro {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 1020px;
    margin-bottom: 90px;
    margin-inline: auto;
  }
  article > :where(section) ~ :where(section) {
    margin-top: 80px;
  }
  article > :where(section) :where(section) {
    margin-top: 60px;
  }
  article > :where(section) :where(section) :where(section) {
    margin-top: 40px;
  }
  article > :where(section) :where(section) :where(section) :where(section) {
    margin-top: 30px;
  }
}
.tit_01 {
  color: var(--color-main);
  font-weight: 700;
  font-size: 2.2rem;
}

.tit_02 {
  margin-bottom: 2rem;
  font-size: 2.2rem;
  line-height: 1.25;
  font-family: "YakuHanJPs", "Zen Kaku Gothic New", "Hiragino Sans", "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
  letter-spacing: 0.04em;
  text-align: center;
}
.tit_02::before {
  display: block;
  margin-bottom: 0.3rem;
  content: '\ed24';
  color: var(--color-main-vbrt);
  font-weight: normal;
  font-size: 113%;
  line-height: 1;
  font-family: "fontello";
}
.tit_02::after {
  display: block;
  width: 2em;
  height: 2px;
  margin: 0.52em auto 0;
  background: var(--color-border);
  content: "";
}
.tit_02[data-en] {
  letter-spacing: 0.08em;
}
.tit_02[data-en]::after {
  width: auto;
  height: auto;
  margin: 0.3rem auto 0;
  background: transparent;
  content: attr(data-en);
  color: var(--color-main-vbrt);
  font-weight: 600;
  font-size: 1.2rem;
  font-family: "Poppins", sans-serif;
  letter-spacing: 0.08em;
}

.tit_03 {
  margin-bottom: 1.2rem;
  padding: 0.6rem 1.2rem;
  border-radius: 0.5rem;
  background-color: var(--color-main-vbrt);
  color: var(--color-white);
  font-weight: 700;
  font-size: 1.9rem;
  line-height: 1.25;
  font-family: "YakuHanJPs", "Zen Kaku Gothic New", "Hiragino Sans", "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
  letter-spacing: 0.04em;
}

.tit_04 {
  margin-bottom: 1.2rem;
  padding-bottom: 0.4em;
  padding-left: 1.4rem;
  border-bottom: 2px solid var(--color-lgray);
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.25;
  font-family: "YakuHanJPs", "Zen Kaku Gothic New", "Hiragino Sans", "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
  letter-spacing: 0.04em;
}
.tit_04::before {
  display: inline-block;
  width: 0.6rem;
  height: 1.18em;
  margin-right: 0.8rem;
  margin-left: -1.4rem;
  border-radius: 0.3rem;
  background: var(--color-acnt);
  content: "";
  line-height: 1;
  vertical-align: -0.25em;
}

.tit_05 {
  margin-bottom: 0.7rem;
  padding-left: 2rem;
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0.04em;
}
.tit_05::before {
  display: inline-block;
  margin-right: 0.4rem;
  margin-left: -2rem;
  content: '\ed1a';
  color: var(--color-acnt-vbrt);
  font-weight: normal;
  font-family: "fontello";
}

.tit_06 {
  margin-bottom: 0.6rem;
  padding-left: 0.8rem;
  border-left: 2px solid var(--color-gray);
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.2;
  letter-spacing: 0.04em;
}

@media screen and (width >= 768px), print {
  .tit_01 {
    font-size: 3.4rem;
    letter-spacing: 0.08em;
  }
  .tit_02 {
    margin-bottom: 30px;
    font-size: 3rem;
    letter-spacing: 0.08em;
  }
  .tit_02::before {
    margin-bottom: 6px;
  }
  .tit_02[data-en]::after {
    margin: 0.6rem auto 0;
    font-size: 1.6rem;
  }
  .tit_03 {
    margin-bottom: 15px;
    padding: 9px 20px 11px;
    border-radius: 10px;
    font-size: 2.2rem;
    letter-spacing: 0.08em;
  }
  .tit_04 {
    margin-bottom: 13px;
    padding-bottom: 12px;
    padding-left: 20px;
    font-size: 2.2rem;
    letter-spacing: 0.08em;
  }
  .tit_04::before {
    width: 8px;
    margin-right: 11px;
    margin-left: -20px;
    border-radius: 4px;
  }
  .tit_05 {
    margin-bottom: 8px;
    padding-left: 22px;
    font-size: 2rem;
    letter-spacing: 0.08em;
  }
  .tit_05::before {
    margin-right: 4px;
    margin-left: -24px;
  }
  .tit_06 {
    margin-bottom: 6px;
    padding-left: 11px;
    border-left-width: 3px;
    font-size: 2rem;
    letter-spacing: 0.08em;
  }
}
@media screen and (width >= 768px), print {
  :where(.contents) :where(ul, ol, dl) {
    line-height: 1.5;
  }
}

.lst_ul > li {
  padding-left: 1.4em;
}
.lst_ul > li::before {
  display: inline-block;
  margin-right: 0.2em;
  margin-left: -1.2em;
  transform: scale(0.6);
  content: "●";
  color: var(--color-main-vbrt);
}

.lst_ul {
  margin-bottom: 1em;
}
.lst_ul > li ~ li {
  margin-top: 0.5em;
}
.lst_ul > li.none::before {
  display: none;
}
.lst_ul > li.etc {
  padding-left: 0;
}
.lst_ul > li.etc::before {
  display: none;
}
.lst_ul > li i {
  display: inline-block;
}
.lst_ul.cols {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em 1.5em;
}
.lst_ul.cols > li ~ li {
  margin-top: 0;
}
@media screen and (width >= 768px), print {
  .lst_ul.cols2 {
    display: grid;
    grid-template-columns: auto auto;
    gap: 0.8em 5%;
  }
  .lst_ul.cols2 > li ~ li {
    margin-top: 0;
  }
  .lst_ul.cols2.l-flexible {
    grid-template-columns: repeat(auto-fit, minmax(410px, 1fr));
  }
}

.lst_dot > li {
  padding-left: 1em;
}
.lst_dot > li::before {
  display: inline-block;
  margin-left: -1em;
  content: "・";
}

.lst_ol {
  margin-bottom: 1em;
}
.lst_ol > li {
  margin-left: 1.4em;
  list-style-type: decimal;
}
.lst_ol > li ~ li {
  margin-top: 0.5em;
}
.lst_ol > li::marker {
  color: var(--color-main-vbrt);
  font-weight: 500;
}

.lst_dl {
  margin-bottom: 1em;
}
.lst_dl > dt {
  margin-bottom: 0.5em;
  color: var(--color-main);
  font-weight: 700;
  font-size: 112.5%;
  line-height: 1.25;
}
.lst_dl > dt::before {
  display: inline-block;
  margin-right: 0.2em;
  content: '\ed1a';
  font-weight: normal;
  font-family: "fontello";
}
.lst_dl > dt ~ dt {
  margin-top: 1em;
}
.lst_dl > dd :last-child {
  margin-bottom: 0;
}

.ol_flow {
  --color-border: #ececec;
  counter-reset: flowNum 0;
}
.ol_flow > li {
  position: relative;
  padding: 1.3rem 1.5rem;
  border: 2px solid var(--color-border);
  border-radius: 0.8rem;
  font-weight: bold;
  font-size: 1.6rem;
  counter-increment: flowNum 1;
}
.ol_flow > li::before {
  display: inline-block;
  width: 2.4rem;
  height: 2.4rem;
  margin-right: 0.8rem;
  border-radius: 50%;
  background-color: var(--color-main-vbrt);
  content: counter(flowNum);
  color: var(--color-white);
  font-weight: 500;
  line-height: 2.6rem;
  font-family: "Poppins", sans-serif;
  text-align: center;
}
.ol_flow > li:not(:last-child) {
  margin-bottom: 3.5rem;
}
.ol_flow > li:not(:last-child)::after {
  display: block;
  position: absolute;
  right: 0;
  bottom: -2.8rem;
  left: 0;
  width: 6.5rem;
  height: 1.6rem;
  background-color: var(--color-acnt-mute);
  content: "";
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
  margin-inline: auto;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
}
.ol_flow > li .cont {
  margin: 1rem 0 0.5rem;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: normal;
}
.ol_flow > li .cont > :last-child {
  margin-bottom: 0;
}
@media screen and (width >= 768px), print {
  .ol_flow > li {
    padding: 24px 30px 24px 86px;
    border-width: 3px;
    border-radius: 10px;
    font-size: 2rem;
    letter-spacing: 0.05em;
  }
  .ol_flow > li::before {
    width: 34px;
    height: 34px;
    margin-right: 20px;
    margin-left: -56px;
    line-height: 36px;
  }
  .ol_flow > li:not(:last-child) {
    margin-bottom: 60px;
  }
  .ol_flow > li:not(:last-child)::after {
    bottom: -48px;
    width: 96px;
    height: 28px;
  }
  .ol_flow > li .cont {
    margin: 14px 0 6px;
    font-size: 1.8rem;
  }
}

.footnote {
  margin-bottom: 1em;
  padding-top: 0.2em;
  line-height: 1.3;
}

.tbl_data {
  width: 100%;
  margin-bottom: 1em;
  border-collapse: collapse;
  line-height: 1.5;
}
.tbl_data::has(+ .footnote) {
  margin-bottom: 0;
}
.tbl_data th {
  font-weight: 500;
}

.tbl_data th, .tbl_data td {
  padding: 0.5em;
  border: 1px solid var(--color-border);
}
.tbl_data thead th {
  padding: 0.5em 0.3em;
  border-color: var(--color-acnt);
  background-color: var(--color-acnt);
  color: var(--color-white);
}
.tbl_data tbody th {
  background-color: var(--color-sub-pale);
}
@media screen and (width >= 768px), print {
  .tbl_data th, .tbl_data td {
    padding: 0.8em 1.5em;
  }
  .tbl_data thead th {
    padding: 0.8em 0.5em;
  }
}

@media screen and (width < 767px) {
  .sp_frame {
    width: 100%;
    padding-bottom: 1.2rem;
    overflow-x: auto;
  }
  .sp_frame > table {
    width: 200%;
  }
}
@media screen and (width >= 768px), print {
  .sp_frame > table {
    width: 100%;
  }
}

.box_bg03, .box_bg02, .box_bg01 {
  margin-bottom: 1em;
  padding: 1.3rem 1.5rem;
  border-radius: 0.8rem;
}
.box_bg03 > :last-child, .box_bg02 > :last-child, .box_bg01 > :last-child {
  margin-bottom: 0;
}
.box_bg03:has(+ .remarks), .box_bg02:has(+ .remarks), .box_bg01:has(+ .remarks) {
  margin-bottom: 0.5em;
}
@media screen and (width >= 768px), print {
  .box_bg03, .box_bg02, .box_bg01 {
    padding: 25px 30px;
    border-radius: 10px;
  }
}

.box_bg01 {
  background: var(--color-main-pale);
}

.box_bg02 {
  background: var(--color-sub-pale);
}

.box_bg03 {
  background: var(--color-acnt-pale2);
}

:where(main) :where(a):not([class*=btn_]) {
  color: var(--color-main-vbrt);
  text-decoration: underline;
}
@media screen and (width >= 768px), print {
  :where(main) :where(a):not([class*=btn_]):hover {
    color: var(--color-sub-vbrt);
  }
}

.lnk_to {
  color: inherit;
  text-decoration: underline;
}
.lnk_to::before {
  display: inline-block;
  margin-right: 0.3rem;
  content: '\ecff';
  color: var(--color-main);
  font-weight: normal;
  font-size: 90%;
  font-family: "fontello";
}
@media screen and (width >= 768px), print {
  .lnk_to:hover {
    color: var(--color-main);
  }
}

.btn_detail, .btn_back {
  display: inline-block;
  position: relative;
  padding: 0.76em 2.2em 0.84em 1.6em;
  border-radius: 10em;
  background-color: var(--color-main-vbrt);
  color: var(--color-white);
  line-height: 1.2;
  letter-spacing: 0.05em;
  text-align: center;
  text-decoration: none;
}
.btn_detail::after, .btn_back::after {
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 0.8em;
  transform: translateY(-0.5em);
}
.btn_detail::after, .btn_back::after {
  content: '\ecff';
  font-weight: normal;
  font-size: 90%;
  font-family: "fontello";
}
@media screen and (width >= 768px), print {
  .btn_detail, .btn_back {
    padding: 0.66em 2.2em 0.7em 1.6em;
  }
  .btn_detail::after, .btn_back::after {
    line-height: 1;
  }
  .btn_detail:hover, .btn_detail:focus, .btn_back:hover, .btn_back:focus {
    background-color: var(--color-acnt);
    color: var(--color-white);
  }
}

.btn_anchor, .lnkbtn_anchors li a {
  display: inline-block;
  position: relative;
  padding: 0.6em 2.2em 0.6em 2em;
  border-radius: 10em;
  background-color: var(--color-acnt);
  color: var(--color-white);
  line-height: 1.2;
  letter-spacing: 0.05em;
  text-align: center;
  text-decoration: none;
}
.btn_anchor::after, .lnkbtn_anchors li a::after {
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 1.2em;
  transform: translateY(-0.5em);
}
.btn_anchor::after, .lnkbtn_anchors li a::after {
  content: '\ed02';
  font-weight: normal;
  font-size: 77%;
  font-family: "fontello";
}
@media screen and (width >= 768px), print {
  .btn_anchor, .lnkbtn_anchors li a {
    padding: 0.5em 2em 0.5em 1.7em;
  }
  .btn_anchor::after, .lnkbtn_anchors li a::after {
    right: 1.6em;
    font-size: 60%;
  }
  .btn_anchor:hover, .lnkbtn_anchors li a:hover, .btn_anchor:focus, .lnkbtn_anchors li a:focus {
    background-color: var(--color-acnt-vbrt);
    color: var(--color-white);
  }
}

.lnkbtn_anchors li {
  margin-bottom: 0.6rem;
}
.lnkbtn_anchors li a {
  width: 100%;
}
@media screen and (width >= 768px), print {
  .lnkbtn_anchors {
    display: grid;
    grid-template-columns: repeat(auto-fill, 22%);
    gap: 20px 4%;
  }
}

:where(mark) {
  background: linear-gradient(transparent 60%, var(--color-highlight, mark) 60%);
  color: inherit;
}

.clr-attn, .notification {
  color: var(--color-attention, #f00);
}

.f-bold {
  font-weight: bold;
}

.f-medium {
  font-weight: 500;
}

.f-smaller {
  font-size: 0.85em;
}

.f-xsmaller {
  font-size: 0.7em;
}

.f-larger {
  font-size: 1.15em;
}

.f-xlarger {
  font-size: 1.3em;
}

.f-fpm {
  font-feature-settings: "palt";
}

@media screen and (width < 767px) {
  .sp_f-smaller {
    font-size: 0.85em;
  }
  .sp_f-larger {
    font-size: 1.15em;
  }
}
.notification, :is(ul, ol).remarks > li, dl.remarks > dt, :not(dl, ul).remarks {
  padding-left: 1em;
  text-indent: -1em;
}
.notification > *, :is(ul, ol).remarks > li > *, dl.remarks > dt > *, :not(dl, ul).remarks > * {
  text-indent: 0;
}

span:not(dl, ul).remarks {
  display: inline-block;
}

dl.remarks > dt ~ dt {
  margin-top: 0.8em;
}

.notification {
  line-height: 1.5;
}

.js-tel {
  white-space: nowrap;
}
@media screen and (width < 767px) {
  .js-tel a {
    color: inherit;
    text-decoration: none !important;
  }
}

.timetable_tbl {
  width: 100%;
  border-collapse: collapse;
  line-height: 1;
  table-layout: fixed;
}
.timetable_tbl thead th {
  padding: 0.6em 0;
  background-color: var(--color-main);
  color: var(--color-white);
  font-weight: 500;
}
.timetable_tbl thead th:first-child {
  width: 30%;
}
.timetable_tbl thead th:last-child {
  width: 13%;
  padding-right: 1.5%;
}
.timetable_tbl tbody {
  background-color: var(--color-white);
}
.timetable_tbl tbody th {
  padding: 1em 0;
  border-bottom: 1px solid var(--color-overview-line);
  font-weight: 500;
  font-size: 110%;
  white-space: nowrap;
}
.timetable_tbl tbody td {
  padding: 1em 0;
  transform: scale(0.7);
  border-bottom: 1px solid var(--color-overview-line);
  color: var(--color-gray);
  text-align: center;
}
.timetable_tbl tbody td:last-child {
  padding-right: 3%;
}
.timetable_tbl tbody td.open {
  color: var(--color-sub);
}
.timetable_note {
  padding-top: 1rem;
}
.timetable_note .opentime {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0 1em;
}
.timetable_note .opentime dt {
  padding: 0.2rem 1.2rem;
  border: 1px solid currentColor;
  color: var(--color-main);
  font-size: 94%;
  text-align: center;
}
.timetable_note .closetime {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  margin-top: 0.7rem;
}
.timetable_note .closetime dt::after {
  content: "：";
}
.timetable_note ul.remarks {
  margin-top: 0.5rem;
  font-size: 94%;
}

@media screen and (width >= 768px), print {
  .timetable_tbl thead th {
    padding: 0.84em 0;
  }
  .timetable_tbl thead th:last-child {
    padding-right: 2%;
  }
  .timetable_tbl tbody th {
    padding: 1.2em 0;
    font-size: 122%;
  }
  .timetable_tbl tbody td {
    padding: 1.2em 0;
  }
  .timetable_note {
    display: grid;
    grid-template-columns: auto auto;
    justify-content: space-between;
    padding-top: 1em;
    gap: 0.7em 1.4em;
  }
  .timetable_note .opentime dt {
    padding: 0.2em 1em;
    font-size: 88%;
  }
  .timetable_note .closetime {
    margin-top: 0;
  }
  .timetable_note ul.remarks {
    grid-column: 1/3;
    font-size: 94%;
  }
}
:where(body#page_index) :is(ul, ol):not([data-styled] *) {
  margin-left: 0;
}

.hero {
  --bg-height: 24rem;
  background-image: url(../img/index_hero.webp);
  background-position: center top;
  background-size: auto var(--bg-height);
  background-repeat: no-repeat;
}
.hero .wrap {
  position: relative;
  padding-top: calc(var(--bg-height) - 5rem);
}
.hero .wrap .newopen {
  display: grid;
  position: absolute;
  top: 1rem;
  left: -0.5rem;
  place-content: center;
  aspect-ratio: 1/1;
  width: 10rem;
  border-radius: 50%;
  background-color: var(--color-main-vbrt);
  box-shadow: 0 0.2rem 0.4rem var(--color-shadow);
  color: var(--color-white);
  text-align: center;
}
.hero .wrap .newopen .ym {
  margin-bottom: 0.2rem;
  padding-bottom: 0.2rem;
  border-bottom: 1px solid currentColor;
  font-size: 1.3rem;
  letter-spacing: 0.08em;
}
.hero .wrap .newopen .ym b {
  font-weight: 500;
  font-size: 150%;
  line-height: 1;
  letter-spacing: 0.08em;
}
.hero .wrap .newopen em {
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
}
.hero .wrap .ann {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 1.2rem 1.5rem;
  border-radius: 0.5rem;
  outline: 1px solid var(--color-white);
  outline-offset: -0.4rem;
  background-color: var(--color-acnt);
  box-shadow: 0 0.2rem 0.4rem var(--color-shadow);
  color: var(--color-white);
  text-align: center;
}
.hero .wrap .tagline {
  padding: 1.5rem 1.2rem 3rem;
  background-image: url(../img/logomark.svg);
  background-position: right 0 bottom 0.5rem;
  background-size: 25% auto;
  background-repeat: no-repeat;
  color: var(--color-main);
}
.hero .wrap .tagline em {
  display: block;
  margin-bottom: 0.5em;
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: 0.08em;
}
.hero .wrap .tagline p {
  margin-bottom: 0;
}

@media screen and (width >= 768px), print {
  .hero {
    --bg-height: 680px;
    background-size: auto;
  }
}
@media screen and (width >= 768px) and (width > 2000px) {
  .hero {
    background-size: cover;
  }
}
@media screen and (width >= 768px), print {
  .hero .wrap {
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-end;
    justify-content: space-between;
    height: var(--bg-height);
    padding-top: 0;
    padding-bottom: 40px;
    gap: 0 25px;
  }
  .hero .wrap .newopen {
    top: 50px;
    left: 0;
    width: 200px;
    box-shadow: 0 3px 6px var(--color-shadow);
  }
  .hero .wrap .newopen .ym {
    font-size: 2rem;
  }
  .hero .wrap .newopen .ym b {
    font-size: 3.6rem;
  }
  .hero .wrap .newopen em {
    font-size: 3rem;
  }
  .hero .wrap .ann {
    width: clamp(240px, 133.333px + 13.889vw, 300px);
    padding: 20px 7px;
    border-radius: 10px;
    outline-offset: -6px;
    box-shadow: 0 3px 6px var(--color-shadow);
    font-size: clamp(1.8rem, 0.7333rem + 1.389vw, 2.4rem);
    line-height: 1.4;
    letter-spacing: 0.1em;
  }
  .hero .wrap .tagline {
    width: 500px;
    padding: 5px 0;
    background: none;
    color: var(--color-white);
    filter: drop-shadow(0 0 1rem var(--color-black));
  }
  .hero .wrap .tagline em {
    margin-bottom: 10px;
    font-size: 3.2rem;
    filter: drop-shadow(0 0 0.6rem rgb(var(--color-black-rgb)/0.7));
  }
  .hero .wrap .tagline p {
    filter: drop-shadow(0 0 0.8rem var(--color-black));
  }
}
@supports (interpolate-size: allow-keywords) {
  :root {
    interpolate-size: allow-keywords;
  }
}
.news details::details-content {
  height: 0;
  overflow: clip;
  opacity: 0;
  transition: height 0.4s, opacity 0.4s, content-visibility 0.4s allow-discrete;
}
.news details[open]::details-content {
  height: auto;
  opacity: 1;
}
.news details[open] .accordion-header::before {
  transform: rotate(180deg);
}
.news details summary {
  display: block;
  list-style-type: none;
}
.news details summary::marker {
  content: "";
}
.news details summary::-webkit-details-marker {
  display: none;
}

.news {
  padding-top: 4rem;
  padding-bottom: 5rem;
  background-image: url(../img/index_news_bg_l.webp), url(../img/index_news_bg_r.webp);
  background-position: left -20% top 0, right -20% top 0;
  background-size: 80vw auto;
  background-repeat: no-repeat;
}
.news .box {
  padding-top: 1.8rem;
  border-top: 1px solid var(--color-main);
  background-color: var(--color-white);
}
.news #topnews {
  max-height: 24rem;
  padding-bottom: 0.5rem;
  overflow-y: auto;
}
.news #topnews .accordion-container {
  padding-right: 0.8rem;
}
.news #topnews .accordion-container .accordion-item {
  padding-bottom: 1.2em;
  padding-inline: 0.5rem;
  border-bottom: 1px solid var(--color-lgray);
}
.news #topnews .accordion-container .accordion-item .accordion-header {
  padding-left: 1.3em;
  color: var(--color-main);
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.3;
}
.news #topnews .accordion-container .accordion-item .accordion-header::before {
  display: inline-block;
  margin-right: 0.3em;
  margin-left: -1.3em;
  content: '\ed00';
  color: var(--color-main-vbrt);
  font-weight: normal;
  line-height: 1;
  font-family: "fontello";
}
.news #topnews .accordion-container .accordion-item .accordion-content {
  padding-top: 0.8rem;
  line-height: 1.5;
}
.news #topnews .accordion-container .accordion-item .accordion-content .content-inner > :last-child {
  margin-bottom: 0;
}
.news #topnews .accordion-container .accordion-item:not(:first-of-type) {
  margin-top: 1.2em;
}

@media screen and (width >= 768px), print {
  .news {
    padding-top: 80px;
    padding-bottom: 68px;
    background-position: left calc(50% - 550px) top 0, right calc(50% - 550px) top 0;
    background-size: auto;
  }
}
@media screen and (width >= 768px) and (width > 2000px) {
  .news {
    background-position: left top, right top;
  }
}
@media screen and (width >= 768px), print {
  .news .box {
    padding-top: 44px;
  }
  .news #topnews {
    max-height: 496px;
    padding-right: 28px;
  }
  .news #topnews .accordion-container {
    padding-right: 0.8rem;
  }
  .news #topnews .accordion-container .accordion-item {
    padding-bottom: 22px;
    padding-inline: 20px;
  }
  .news #topnews .accordion-container .accordion-item .accordion-header {
    padding-left: 25px;
    font-size: 2rem;
  }
  .news #topnews .accordion-container .accordion-item .accordion-header::before {
    margin-right: 7px;
    margin-left: -25px;
    font-size: 1.8rem;
  }
  .news #topnews .accordion-container .accordion-item .accordion-content {
    padding-top: 10px;
    padding-left: 25px;
    letter-spacing: 0.08em;
  }
  .news #topnews .accordion-container .accordion-item:not(:first-of-type) {
    margin-top: 24px;
  }
}
.feature {
  padding-top: 4rem;
  padding-bottom: 5rem;
  background-image: url(../img/index_feature_bg.webp);
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
}
.feature .wrap {
  counter-reset: fNum 0;
}
.feature .cont {
  display: flex;
  flex-direction: column;
  border-radius: 1rem;
  background: var(--color-white);
  counter-increment: fNum 1;
}
.feature .cont:not(:first-of-type) {
  margin-top: 3rem;
}
.feature .cont .img {
  order: -1;
  border-radius: 1rem 1rem 0 0;
  outline-color: var(--color-white);
  outline-style: solid;
  outline-width: 0.5rem;
  outline-offset: -0.4rem;
}
.feature .cont .box {
  position: relative;
  padding: 1.6rem 1.8rem 2rem;
}
.feature .cont .box::before {
  display: block;
  position: absolute;
  top: -5.4rem;
  right: 1rem;
  aspect-ratio: 1/1;
  width: 2em;
  border-radius: 50%;
  background-color: var(--color-main-vbrt);
  content: counter(fNum, decimal-leading-zero);
  color: var(--color-white);
  font-weight: 500;
  font-size: 3.4rem;
  line-height: 2;
  font-family: "Poppins", sans-serif;
  text-align: center;
}
.feature .cont .box .tit {
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  gap: 0 1rem;
  border-bottom: 1px solid var(--color-sub-soft);
  color: var(--color-main);
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.3;
  font-family: "YakuHanJPs", "Zen Kaku Gothic New", "Hiragino Sans", "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
  letter-spacing: 0.06em;
}
.feature .cont .box .tit::before {
  flex: none;
  aspect-ratio: 1/1;
  width: 2em;
  background-position: left center;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  vertical-align: -0.6em;
}
.feature .cont .box .txt {
  margin-bottom: 0;
  letter-spacing: 0.04em;
}
.feature .cont[data-cont=team] .box .tit::before {
  background-image: url(../img/index_feature_team_ico.svg);
}
.feature .cont[data-cont=meal] .box .tit::before {
  background-image: url(../img/index_feature_meal_ico.svg);
}
.feature .cont[data-cont=pharmacist] .box .tit::before {
  background-image: url(../img/index_feature_pharmacist_ico.svg);
}

@media screen and (width >= 768px), print {
  .feature {
    padding-top: 80px;
    padding-bottom: 96px;
    background-size: auto;
  }
}
@media screen and (width >= 768px) and (width > 2000px) {
  .feature {
    background-size: cover;
  }
}
@media screen and (width >= 768px), print {
  .feature .tit_02 {
    margin-bottom: 62px;
  }
  .feature .cont {
    display: block;
    position: relative;
    min-height: 380px;
    margin-right: clamp(0px, -17.778px + 2.315vw, 10px);
    margin-left: clamp(35px, 8.333px + 3.472vw, 50px);
    padding: 35px 35px 30px clamp(260px, -264.444px + 68.287vw, 555px);
    border-radius: 20px;
  }
  .feature .cont:not(:first-of-type) {
    margin-top: 84px;
  }
  .feature .cont .img {
    position: absolute;
    top: -30px;
    left: clamp(-50px, -8.333px + -3.472vw, -35px);
    aspect-ratio: 114/73;
    width: clamp(260px, -291.111px + 71.759vw, 570px);
    border-radius: 20px;
    outline-width: 7px;
    outline-offset: -6px;
  }
  .feature .cont .box {
    padding: 0;
  }
  .feature .cont .box::before {
    top: -90px;
    right: -35px;
    width: clamp(80px, 44.444px + 4.63vw, 100px);
    font-size: clamp(3.8rem, 2.0222rem + 2.315vw, 4.8rem);
    line-height: 2.08;
  }
  .feature .cont .box .tit {
    margin-bottom: 15px;
    padding-bottom: 11px;
    gap: 0 15px;
    border-bottom-width: 2px;
    font-size: 2.6rem;
  }
  .feature .cont .box .tit::before {
    width: 50px;
  }
  .feature .cont .box .txt {
    letter-spacing: 0.08em;
  }
}
.greeting {
  padding-top: 4rem;
  padding-bottom: 5rem;
  background: linear-gradient(#f4fcfb, rgb(var(--color-white-rgb)/0) 50%);
}
.greeting .wrap {
  background-image: url(../img/logomark.svg);
  background-position: right 50% top 7rem;
  background-size: 98% auto;
  background-repeat: no-repeat;
}
.greeting .pic {
  width: 60%;
  margin: 0 auto 1.8rem;
}
.greeting .pic figcaption {
  margin-top: 0.5rem;
  font-size: 1.7rem;
  letter-spacing: 0.08em;
  text-align: center;
}
.greeting .txt p {
  margin-bottom: 0;
  line-height: 1.8;
  letter-spacing: 0.04em;
}
.greeting .txt p em {
  display: block;
  margin-block: 1em;
  color: var(--color-main);
  font-weight: 500;
  font-size: 1.85rem;
  line-height: 1.4;
  font-family: "YakuHanJPs", "Zen Kaku Gothic New", "Hiragino Sans", "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
}
.greeting .txt .more {
  margin-top: 2rem;
  text-align: center;
}

@media screen and (width >= 768px), print {
  .greeting {
    padding-top: 80px;
    padding-bottom: 100px;
  }
  .greeting .wrap {
    display: flow-root;
    background-position: calc(50% + 310px) 57px;
    background-size: 580px auto;
  }
  .greeting .tit_02 {
    margin-bottom: 20px;
  }
  .greeting .pic {
    width: clamp(230px, 34.444px + 25.463vw, 340px);
    margin-right: clamp(0px, -53.333px + 6.944vw, 30px);
    margin-bottom: 0;
    margin-left: 30px;
    float: right;
  }
  .greeting .pic figcaption {
    margin-top: 15px;
    font-size: 2.2rem;
  }
  .greeting .txt {
    width: clamp(530px, 103.333px + 55.556vw, 770px);
    padding-top: 30px;
    padding-right: clamp(25px, -19.444px + 5.787vw, 50px);
    padding-left: clamp(0px, -88.889px + 11.574vw, 50px);
  }
  .greeting .txt p {
    line-height: 2.1;
    letter-spacing: 0.08em;
  }
  .greeting .txt p em {
    margin-block: 0.6em;
    font-size: 2.6rem;
  }
  .greeting .txt .more {
    margin-top: clamp(25px, -10.556px + 4.63vw, 45px);
  }
}
.disease {
  padding-top: 4rem;
  padding-bottom: 5rem;
  background-image: url(../img/index_disease_bg.webp);
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
}
.disease .lst {
  display: grid;
  grid-template-columns: repeat(2, 48%);
  justify-content: center;
  margin-inline: auto;
  padding-top: 1rem;
  gap: 1rem;
}
.disease .lst li {
  display: grid;
  place-content: center;
  padding-block: 1.2rem;
  border: 2px solid var(--color-main-lite);
  border-radius: 5em;
  background-color: var(--color-white);
  color: var(--color-main);
  font-size: 1.6rem;
  line-height: 1.3;
  letter-spacing: 0.08em;
}

@media screen and (width >= 768px), print {
  .disease {
    padding-top: 80px;
    padding-bottom: 100px;
    background-size: auto;
  }
}
@media screen and (width >= 768px) and (width > 2000px) {
  .disease {
    background-size: cover;
  }
}
@media screen and (width >= 768px), print {
  .disease .lst {
    display: grid;
    grid-template-columns: repeat(auto-fill, 228px);
    gap: 17px 15px;
  }
  .disease .lst li {
    padding-block: 17px;
    border-width: 3px;
    font-size: 2rem;
  }
}
.heading {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 10rem;
  padding: 1rem;
  background-image: url(../img/tit_heading.webp);
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
}
.heading h1 {
  color: var(--color-main);
  font-weight: 700;
  font-size: 2.2rem;
  line-height: 1.3;
  letter-spacing: 0.08em;
}
@media screen and (width >= 768px), print {
  .heading {
    min-height: 220px;
  }
  .heading h1 {
    font-size: 3.4rem;
  }
}

.breadcrumbs {
  padding-inline: 1.5rem;
  padding-block: 1rem;
  font-weight: 400;
  font-size: 1.3rem;
  line-height: 1.3;
}
.breadcrumbs li {
  display: inline-block;
}
.breadcrumbs li:not(:first-child)::before {
  display: inline-block;
  margin: 0 0.2em;
  content: "＞";
}
.breadcrumbs li a {
  color: var(--color-main);
  text-decoration: underline;
}
@media screen and (width >= 768px), print {
  .breadcrumbs {
    max-width: 1200px;
    margin-inline: auto;
    padding-inline: clamp(3%, -154px + 17 * 1vw, 50px);
    padding-block: 20px;
    font-size: 1.4rem;
  }
  .breadcrumbs a:hover {
    text-decoration: none;
  }
}

.contents {
  padding-top: 3rem;
  padding-bottom: 4rem;
  padding-inline: 1.5rem;
}
@media screen and (width >= 768px), print {
  .contents {
    max-width: 1200px;
    margin-inline: auto;
    padding-top: 60px;
    padding-bottom: 80px;
    padding-inline: clamp(4%, -22px + 6 * 1vw, 50px);
  }
}

body#page_clinic .philosophy {
  padding-bottom: 1.5rem;
  background-image: url(../img/logomark.svg);
  background-position: right -25vw bottom 2rem;
  background-size: 100vw auto;
  background-repeat: no-repeat;
}
body#page_clinic .philosophy p {
  margin-bottom: 1.5em;
  line-height: 1.8;
}
body#page_clinic .philosophy p:last-child {
  margin-bottom: 0;
}
body#page_clinic .philosophy em,
body#page_clinic .philosophy .f-bold {
  color: var(--color-main);
  font-size: 1.5rem;
}
body#page_clinic .doctor_greeting .img_l {
  max-width: 50%;
}
body#page_clinic .doctor_greeting .txt .signature {
  margin-top: 1.3em;
  text-align: right;
}
body#page_clinic .doctor_greeting .txt .signature span {
  font-size: 125%;
}
body#page_clinic .doctor_profile .lst_ul li {
  word-spacing: 0.5em;
}
@media screen and (width >= 768px), print {
  body#page_clinic .philosophy {
    padding-bottom: 0;
    background-position: 100% 45%;
    background-size: 400px auto;
  }
  body#page_clinic .philosophy p {
    line-height: 2;
  }
  body#page_clinic .philosophy em,
  body#page_clinic .philosophy .f-bold {
    font-size: 2rem;
  }
  body#page_clinic .doctor_greeting {
    display: flex;
    align-items: flex-start;
  }
  body#page_clinic .doctor_greeting .img_l {
    max-width: clamp(250px, 161.111px + 11.574vw, 300px);
  }
  body#page_clinic .doctor_profile {
    display: flex;
    flex-wrap: wrap;
    margin-top: 50px;
    gap: 30px 50px;
  }
  body#page_clinic .doctor_profile section {
    flex-grow: 1;
    margin-top: 0;
  }
}

body#page_faq .faqlist {
  margin-block: 1rem;
}
body#page_faq .faqlist > dt {
  margin-bottom: 1rem;
  padding-left: 3.5rem;
  color: var(--color-main);
  font-size: 1.8rem;
  line-height: 1.4;
}
body#page_faq .faqlist > dt::before {
  display: inline-block;
  width: 3.5rem;
  margin-left: -3.5rem;
  content: "Q.";
  font-size: 2.5rem;
  line-height: 1;
  font-family: "Poppins", sans-serif;
}
body#page_faq .faqlist > dt:not(:first-of-type) {
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px dotted var(--color-border);
}
body#page_faq .faqlist > dd {
  padding-left: 3.5rem;
}
body#page_faq .faqlist > dd::before {
  display: inline-block;
  width: 3.5rem;
  margin-left: -3.5rem;
  content: "A.";
  color: var(--color-sub);
  font-size: 2.5rem;
  line-height: 1;
  font-family: "Poppins", sans-serif;
}
@media screen and (width >= 768px), print {
  body#page_faq .faqlist > dt {
    margin-bottom: 20px;
    padding-left: 58px;
    font-size: 2.2rem;
  }
  body#page_faq .faqlist > dt::before {
    width: 58px;
    margin-left: -58px;
    font-size: 3.6rem;
  }
  body#page_faq .faqlist > dt:not(:first-of-type) {
    margin-top: 45px;
    padding-top: 40px;
  }
  body#page_faq .faqlist > dd {
    padding-left: 58px;
    line-height: 2;
  }
  body#page_faq .faqlist > dd::before {
    width: 58px;
    margin-left: -58px;
    font-size: 3.6rem;
  }
}

body#page_access .access_info {
  display: grid;
  grid-template-columns: 6em auto;
  gap: 0 2px;
}
body#page_access .access_info dt {
  padding: 1rem 1em;
  border-bottom: 1px solid var(--color-main-vbrt);
  color: var(--color-main);
  font-weight: bold;
  text-align-last: justify;
}
body#page_access .access_info dd {
  padding: 1rem 1.5em;
  border-bottom: 1px solid var(--color-gray);
}
body#page_access .gmap {
  width: 100%;
  height: 35rem;
}
body#page_access .gmap iframe {
  width: 100%;
  height: 100%;
  border: none;
}
body#page_access .gmap {
  margin-top: 2.5rem;
}
@media screen and (width >= 768px), print {
  body#page_access .timetable {
    font-size: 2rem;
  }
  body#page_access .access_info {
    grid-template-columns: 180px auto;
    font-size: 2rem;
  }
  body#page_access .access_info dt {
    padding: 20px 44px;
  }
  body#page_access .access_info dd {
    padding: 20px 50px;
    word-break: auto-phrase;
    word-spacing: 0.5em;
  }
  body#page_access .gmap {
    height: 400px;
    margin-top: 30px;
  }
}

@counter-style p-decimal {
  system: extends decimal;
  prefix: "";
  suffix: " ) ";
  speak-as: number;
}
body#page_privacy_policy article {
  line-height: 1.5;
}
body#page_privacy_policy article .lead {
  margin-bottom: 4rem;
}
body#page_privacy_policy article > section {
  margin-top: 3rem;
}
body#page_privacy_policy article > section > section {
  margin-top: 2rem;
}
body#page_privacy_policy article h3, body#page_privacy_policy article h4 {
  margin-bottom: 0.5em;
}
body#page_privacy_policy article ul > li ~ li, body#page_privacy_policy article ol > li ~ li {
  margin-top: 0.3em;
}
body#page_privacy_policy article ul ul, body#page_privacy_policy article ul ol, body#page_privacy_policy article ol ul, body#page_privacy_policy article ol ol {
  margin-block: 0.5em;
}
body#page_privacy_policy article .lst_dot {
  margin-bottom: 1em;
}
body#page_privacy_policy article .lst_ol {
  margin-left: 1.6em;
}
body#page_privacy_policy article .lst_ol > li {
  list-style-type: p-decimal;
}
body#page_privacy_policy article .lst_ol > li::marker {
  color: inherit;
  font-weight: normal;
  font-size: inherit;
  font-family: inherit;
}
body#page_privacy_policy article .dl_num dt {
  margin-bottom: 0.2em;
}
body#page_privacy_policy article .dl_num dt ~ dt {
  margin-top: 0.5em;
}
body#page_privacy_policy article .dl_num > dd {
  padding-left: 1.5em;
}
body#page_privacy_policy article .pp_sign {
  margin-top: 4rem;
  text-align: right;
}
body#page_privacy_policy article .pp_contactus {
  margin-top: 2rem;
  text-align: right;
}
body#page_privacy_policy article .pp_contactus div {
  word-break: auto-phrase;
  word-spacing: 0.5em;
}
@media screen and (width >= 768px), print {
  body#page_privacy_policy article .lead {
    margin-bottom: 80px;
  }
  body#page_privacy_policy article > section {
    margin-top: 50px;
  }
  body#page_privacy_policy article > section > section {
    margin-top: 30px;
  }
  body#page_privacy_policy article .pp_sign {
    margin-top: 80px;
  }
  body#page_privacy_policy article .pp_contactus {
    margin-top: 25px;
  }
}

body#page_404 .notfound {
  padding: 3rem 1rem;
  text-align: center;
}
body#page_404 .notfound .btn_back {
  margin-top: 2em;
}/*# sourceMappingURL=style.css.map */
