﻿@charset "utf-8";
/*--------------------------------------------------------------------------------

  reserve

--------------------------------------------------------------------------------*/

.rsv-flow_item {
  display: grid;
  column-gap: max(var(--space-s), 2rem);
  position: relative;
  padding-top: max(var(--space-s), 2rem);
}
.rsv-flow_item:first-of-type {
  border-top: 2px solid var(--color-gray-lighter2);
}
.rsv-flow_item:not(:last-of-type) {
  padding-bottom: max(var(--space-s), 2rem);
  border-bottom: 2px solid var(--color-gray-lighter2);
}
.rsv-flow_item:not(:last-of-type):before,
.rsv-flow_item:not(:last-of-type):after {
  content: "";
  width: 4rem;
  height: 2rem;
  line-height: 1;
  position: absolute;
  left: 50%;
  bottom: -1.25rem;
  z-index: 2;
}
.rsv-flow_item:not(:last-of-type):before {
  background: #FFF;
  transform: translateX(-50%);
}
.rsv-flow_item:not(:last-of-type):after {
  content: "";
  line-height: 1;
  background: currentColor;
  color: var(--color-tertiary);
  mask: var(--icon-arrow-alt-thin) no-repeat center center;
  mask-size: 1.75rem auto;
  transform: translateX(-50%) rotate(90deg);
}
.rsv-flow_item .no {
  grid-row: span 2;
  font-size: var(--fs-m);
  font-weight: 500;
  color: var(--color-primary);
  line-height: 1;
}
.rsv-flow_item .ttl {
  font-size: var(--fs-2l);
  font-family: var(--ff-go);
  font-weight: 500;
  color: var(--color-primary);
  margin-top: calc(-1 * (1em - 1.25rem));
}
.rsv-flow_item .txt {
  padding-top: 0.5rem;
}
@media (min-width: 761px) {
  .rsv-flow_item {
    grid-template-columns: auto 1fr;
  }
  .rsv-flow_item .no {
    padding-top: 0.65rem;
  }
}
@media (max-width: 760px) {
  .rsv-flow_item .ttl {
    padding-top: 1rem;
  }
}

/* パーツ追記
----------------------------------------*/
.rsv-flow .c-list.-circle { --list-mark-size: 0.8em; --list-mark-mgt: 0.5em; }
.rsv-flow .c-list.-circle { display: flex; flex-direction: column; line-height: var(--line-height); }
.rsv-flow .c-list.-circle[data-list-fs="s"] { --list-mark-fs: var(--fs-s); } 
.rsv-flow .c-list.-circle[data-list-fs="m"] { --list-mark-fs: var(--fs-m); }
.rsv-flow .c-list.-circle[data-list-fs="l"] { --list-mark-fs: var(--fs-l); } 
.rsv-flow .c-list.-circle:not([class*="u-rgap"]):not([class*="u-gap"]) { row-gap: var(--list-rgap, 0.25rem); }
.rsv-flow .c-list.-circle > li,
.rsv-flow .c-list.-circle:not(:has(li)) { position: relative; padding-left: calc(var(--list-mark-size) + 0.75rem); }
.rsv-flow .c-list.-circle > li:before,
.rsv-flow .c-list.-circle:not(:has(li)):before {
  content: "";
  position: absolute;
  top: var(--list-mark-mgt);
  left: calc((1em - var(--list-mark-size)) / 2);
  display: inline-block;
  width: var(--list-mark-size);
  height: var(--list-mark-size);
  font-size: var(--list-mark-fs);
  vertical-align: middle;
  line-height: 1;
}
.rsv-flow .c-list.-circle.-blue > li:before,
.rsv-flow .c-list.-circle.-blue:not(:has(li)):before   { background-color: #82c8fc; }
.rsv-flow .c-list.-circle > li:before,
.rsv-flow .c-list.-circle:not(:has(li)):before { --list-mark-size: 0.5em; --list-mark-mgt: 0.6em; border-radius: 9999px; }
.rsv-flow .c-list.-circle > li,
.rsv-flow .c-list.-circle:not(:has(li)) { padding-left: calc(var(--list-mark-size) + 0.5rem); }
.rsv-flow .c-list.-circle > li {
  margin-top: 1em;
}

/* caution
----------------------------------------*/
.rsv-flow ul.caution {
  color: #e65064;
  margin-top: 5px;
}
.rsv-flow ul.caution.mgt-m {
  margin-top: 15px !important;
}
.rsv-flow ul.caution > li {
  padding-left: calc(1em + 5px);
}
.rsv-flow ul.caution > li::before {
  content: "※";
  display: inline-block;
  text-indent: calc((1em + 5px) * -1);
}

/* c-box-contact
----------------------------------------*/
:root {
  /* default */
  --default-box-contact-line: var(--pale-color-primary-light);
}
.rsv-flow dl.c-box-contact.-line      { --box-contact-line: var(--pale-color-primary-lighter); }
.rsv-flow dl.c-box-contact.-gray-line { --box-contact-line: var(--border-color-light); }
.rsv-flow dl.c-box-contact.-red       { --box-contact-line: var(--pale-color-red); }
.rsv-flow dl.c-box-contact.-red-line  { --box-contact-line: var(--pale-color-red-lighter); }
.rsv-flow dl.c-box-contact {
  display: grid;
  align-items: center;
  line-height: var(--line-height);
  margin-top: 1em;
}
.rsv-flow dl.c-box-contact > dt {
  position: relative;
  font-weight: bold;
  text-align: center;
}
.rsv-flow dl.c-box-contact > dd {
}
.rsv-flow dl.c-box-contact > dd > p {
  position: relative;
}
.rsv-flow dl.c-box-contact > dd > p > sup {
  position: absolute;
  top: 0;
  left: clamp(112px,9.5vw,120px);
  display: inline-block;
  width: 8em;
  color: var(--tel-color, var(--color-primary));
}
.rsv-flow dl.c-box-contact > dd > dl {
  display: flex;
  align-items: stretch;
  column-gap: 10px;
}
.rsv-flow dl.c-box-contact > dd > dl > dt {
  font-weight: normal;
}
.rsv-flow dl.c-box-contact > dd > dl > dd {
}
.rsv-flow dl.c-box-contact > dd > dl > dd > dl {
  display: flex;
  column-gap: 10px;
}
.rsv-flow dl.c-box-contact > dd > dl > dd > dl > dt {
  font-weight: normal;
}
.rsv-flow dl.c-box-contact > dd > dl > dd > dl > dd {
}
.rsv-flow dl.c-box-contact > dd > dl > dd > dl > dd span {
  display: inline-block;
  text-indent: 0.625rem;
}
@media (min-width: 761px) {
  .rsv-flow dl.c-box-contact {
    grid-template-columns: auto 1fr;
  }
  .rsv-flow dl.c-box-contact > dt {
    padding-left: var(--box-space-s);
    padding-right: calc(var(--box-pd, var(--default-box-pd)) + var(--box-space-s));
  }
  .rsv-flow dl.c-box-contact > dd {
    padding-left: var(--box-space-m);
    border-left: 1px solid var(--box-contact-line, var(--default-box-contact-line));
  }
}
@media (max-width: 760px) {
  .rsv-flow dl.c-box-contact { justify-items: center; }
  .rsv-flow dl.c-box-contact > dt {
    border-bottom: 1px solid var(--box-contact-line, var(--default-box-contact-line));
    padding-bottom: 1rem;
  }
  .rsv-flow dl.c-box-contact > dd {
    align-items: center;
    text-align: center;
    padding-top: var(--box-space-s);
  }
  .rsv-flow dl.c-box-contact > dd * {
    justify-content: center;
  }
  .rsv-flow dl.c-box-contact > dd > p > sup {
    left: 103px;
  }
}
@media (max-width: 600px) {
  .rsv-flow dl.c-box-contact > dd > p > sup {
    left: clamp(72px,22vw,90px);
  }
}

/*--------------------------------------------------------------------------------

  dock

--------------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------------
  .dock-kenpo-tbl
--------------------------------------------------------------------------------*/
.dock-kenpo-tbl tbody td { width: 20%; }
.dock-kenpo-tbl thead th { min-width: 9em; }
.dock-kenpo-tbl thead th,
.dock-kenpo-tbl tbody td { text-align: center; }
@media (max-width: 760px) {
  .dock-kenpo-tbl { font-size: var(--fs-s); }
}

/*--------------------------------------------------------------------------------

  lifestyle

--------------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------------
  .lifestyle-kenpo-tbl
--------------------------------------------------------------------------------*/
@media (max-width: 760px) {
  .lifestyle-kenpo-tbl {
    font-size: var(--fs-n);
    display: grid;
  }
  .lifestyle-kenpo-tbl tr {
    display: grid;
    grid-template-columns: subgrid;
    grid-column: 1 / -1;
  }
  .lifestyle-kenpo-tbl th,
  .lifestyle-kenpo-tbl td {
    width: 100% !important;
    height: 100% !important;
    text-align: left;
  }
  .lifestyle-kenpo-tbl tr:not(:first-child) th,
  .lifestyle-kenpo-tbl td { border-top: 0 !important; }
  .lifestyle-kenpo-tbl td { padding-top: 1rem; padding-bottom: 1rem; }
}

/*--------------------------------------------------------------------------------

  cities

--------------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------------
  .cities-list
--------------------------------------------------------------------------------*/
.cities-list li { min-width: 8em; }


/*--------------------------------------------------------------------------------
  共通
--------------------------------------------------------------------------------*/

/* caution
----------------------------------------*/
ul.caution {
  color: #e65064;
  margin-top: 5px;
}
ul.caution.u-pdt-s {
  padding-top: 15px !important;
}
ul.caution.u-pdb-s {
  padding-bottom: 15px !important;
}
ul.caution > li {
  padding-left: calc(1em + 5px);
}
ul.caution > li::before {
  content: "※";
  display: inline-block;
  text-indent: calc((1em + 5px) * -1);
}

/* faq
----------------------------------------*/
.js_acod {
}
.js_acod .js_acod-trigger {
  position: relative;
  display: flex;
  color: var(--color-primary-dark);
  font-weight: 500;
  margin-bottom: 0.5em;
  padding: 0.5em 2.5em 0.5em 1em;
  transition: background .3s ease;
  cursor: pointer;
}
.js_acod .js_acod-trigger:hover {
  background-color: var(--pale-color-primary-lighter);
}
.js_acod .js_acod-trigger::before {
  content: "Q：";
  flex-shrink: 0;
  display: block;
  width: 2rem;
  height: 100%;
}
.js_acod .js_acod-trigger span {
  display: block;
}
.js_acod .js_acod-trigger span::before,
.js_acod .js_acod-trigger span::after {
  content: "";
  position: absolute;
  top: 1px;
  right: 20px;
  bottom: 0;
  width: 12px;
  height: 2px;
  background: var(--color-primary-dark);
  margin: auto;
}
.js_acod .js_acod-trigger span::after {
  transform: rotate(-90deg);
  transition: transform 0.3s;
}
.js_acod .js_acod-trigger.is-active span::after {
  transform: rotate(0deg);
}
.js_acod .js_acod-item {
  display: flex;
  margin-bottom: 1em;
  padding: 0.5em 1em;
}
.js_acod .js_acod-item::before {
  content:"A：";
  flex-shrink: 0;
  display: block;
  width: 2rem;
  color: #151e2f;
  font-weight: bold;
}
.js_acod .js_acod-item div {
  width: 100%;
}
