@charset "UTF-8";
/**
 * Chinsatekun CSS
 */
@property --transition {
  syntax: "*";
  inherits: false;
  initial-value: all 0.1s linear;
}
@property --link-color {
  syntax: "<color>";
  inherits: false;
  initial-value: #285AC8;
}
@property --hover-color {
  syntax: "<color>";
  inherits: false;
  initial-value: #3399F9;
}
@property --btn-color {
  syntax: "<color>";
  inherits: false;
  initial-value: #285AC8;
}
@property --btn-color-rgb {
  syntax: "<number>+";
  inherits: false;
  initial-value: 40 90 200;
}
@property --text-color {
  syntax: "<color>";
  inherits: false;
  initial-value: #2C2C2C;
}
@property --text-color-rgb {
  syntax: "<number>+";
  inherits: false;
  initial-value: 44 44 44;
}
@property --subtext-color {
  syntax: "<color>";
  inherits: false;
  initial-value: #747D88;
}
@property --border-color {
  syntax: "<color>";
  inherits: false;
  initial-value: #EAEDF2;
}
@property --frame-color {
  syntax: "<color>";
  inherits: false;
  initial-value: #DEE0E2;
}
@property --enishi-red {
  syntax: "<color>";
  inherits: false;
  initial-value: #E01728;
}
/**
 * Mixin
 */
/**
 * Reset
 */
* {
  margin: 0;
  padding: 0;
}

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

body {
  font-feature-settings: "pwid";
  -webkit-font-smoothing: antialiased;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

address, caption, cite, code, em, th {
  font-style: normal;
  font-weight: normal;
  text-align: left;
}

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

img, svg {
  vertical-align: top;
  border: 0;
}

li {
  list-style-type: none;
}

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

fieldset {
  border: 0;
}

input[type=search] {
  border-radius: 0;
  appearance: none;
  -webkit-appearance: none;
}

input[type=date] {
  line-height: 1;
}

button, [type=button], [type=reset], [type=submit], [role=button] {
  cursor: pointer;
}

[disabled] {
  cursor: default;
}

input[type=search],
input[type=date],
input[type=time] {
  background-color: #fff;
}

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

object {
  pointer-events: none;
}

/**
 * Chinsatekun CSS
 */
html {
  scroll-behavior: smooth;
}

body {
  background: #fff;
  color: var(--text-color);
  container-type: inline-size;
  font-family: Helvetica, Arial, sans-serif;
  font-optical-sizing: auto;
  font-size: 0.875rem;
  font-weight: normal;
  font-style: normal;
  line-height: 0;
  line-height: 1.6;
}
body.app, body.dashboard {
  background: #F8FAFD;
  height: 100vh;
  overflow: auto;
}

input, textarea {
  border: 1px solid var(--border-color);
  border-radius: 5px;
  color: var(--text-color);
  font-size: 1rem;
  line-height: 1;
  padding: 12px;
}

a {
  color: var(--link-color);
  transition: var(--transition);
  text-decoration: none;
}
a:visited {
  color: var(--link-color);
}
a:hover {
  color: var(--hover-color);
  opacity: 1;
  text-decoration: underline;
}
a:active {
  color: var(--hover-color);
  opacity: 1;
}
a:focus {
  color: var(--hover-color);
  opacity: 1;
}

.header {
  background: #F8FAFD;
  display: flex;
  justify-content: space-between;
}

.header-nav__wrapper {
  align-items: center;
  display: flex;
  gap: 48px;
}

.header__head {
  align-items: center;
  display: flex;
  gap: 24px;
}

a.header__logo {
  display: block;
  line-height: 1;
  padding: 16px 24px 13px 16px;
}
a.header__logo:hover {
  opacity: 0.8;
}

.header__logo-img {
  height: 35px;
  width: 176px;
}

.header__plan {
  background: #fff;
  border: 1.5px solid var(--btn-color);
  border-radius: 5px;
  color: var(--btn-color);
  display: flex;
  font-weight: bold;
  gap: 10px;
  line-height: 1;
  padding: 8px 12px;
}
.header__plan dt {
  border-right: 1px solid var(--btn-color);
  padding-right: 10px;
}

.header__nav {
  align-items: center;
  display: flex;
  gap: 6px;
  margin: 14px 24px;
}

a.header__nav-btn {
  align-items: center;
  border-radius: 3px;
  display: flex;
  height: 36px;
  justify-content: center;
  line-height: 1;
  width: 36px;
}
a.header__nav-btn:hover {
  background: #EEF0F2;
}

.header__logout {
  border-left: 1px solid #E2DEDE;
  margin-left: 9px;
  padding-left: 9px;
}

.header__logout-btn {
  padding: 9px;
}
.header__logout-btn .btn__ico {
  height: 16px;
  width: 16px;
}

.wrapper {
  background: #F8FAFD;
  display: grid;
  grid-template-columns: 214px 1fr;
}

.wrapper__main {
  background: #FFF;
  border-radius: 10px 0 0 0;
}
.wrapper__main.-with-aside {
  display: grid;
  grid-template-columns: 1fr 328px;
}

/**
 * Chinsatekun CSS
 */
.pagemenu {
  align-self: start;
  background: #F8FAFD;
  bottom: 0;
  display: block;
  height: 100vh;
  position: sticky;
  top: 0;
  z-index: 100;
}

.pagemenu__ttl {
  color: var(--subtext-color);
  font-size: 0.75rem;
  font-weight: bold;
  margin: 16px 16px 14px;
}

.pagemenu__ul {
  display: grid;
  gap: 8px;
  margin: 14px 16px 24px;
}
.pagemenu__ul:not(:last-of-type)::after {
  border-bottom: 1px solid var(--border-color);
  content: "";
  margin: 16px;
}
.pagemenu__ul .btn {
  gap: 12px;
  width: 100%;
}
.pagemenu__ul .btn.-active {
  background: var(--btn-color);
  color: #fff;
}
.pagemenu__ul .btn.-active .btn__ico {
  fill: #fff;
}
.pagemenu__ul .btn__ico {
  height: 16px;
  width: 16px;
}

.pagenav {
  margin: 72px auto 24px;
  max-width: 1360px;
  width: 100%;
}
.pagenav + main {
  margin-top: 24px;
}

/**
 * Chinsatekun CSS
 */
.main {
  position: relative;
  padding-bottom: 80px;
}

.main__header {
  margin: 36px;
}
.main__header p {
  color: var(--subtext-color);
  font-size: 0.75rem;
}
.main__header.-satei {
  display: flex;
  justify-content: space-between;
  margin: 36px;
}
.main__header.-history {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 36px 36px 16px;
}
.main__header.-history h3 {
  margin-bottom: 0;
}

.main__ttl {
  font-size: 1.25rem;
  line-height: 1;
  margin-bottom: 12px;
}

.main__header-nav {
  display: flex;
  gap: 12px;
}

.main__body {
  margin: 36px;
}

.main__action {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-bottom: 60px;
}
.main__action .btn {
  font-size: 1rem;
}
.main__action.-header {
  position: absolute;
  right: 60px;
  top: 0;
  z-index: 2;
}

/**
 * Chinsatekun CSS
 */
.tab-ui.-satei .tab-ui__tab {
  padding-left: 36px;
}

.property-form__tab, .tab-ui__tab {
  align-self: start;
  background: #fff;
  border-bottom: 1px solid var(--border-color);
  display: flex;
  position: sticky;
  top: 0;
  z-index: 100;
}
.-wide.property-form__tab, .-wide.tab-ui__tab {
  display: flex;
  justify-content: stretch;
  margin: 24px;
  width: calc(100% - 48px);
}
.-wide.property-form__tab .tab-ui__label, .-wide.tab-ui__tab .tab-ui__label {
  justify-content: center;
  width: 100%;
}

.property-form__label, .tab-ui__label {
  align-items: center;
  border-bottom: 3px solid transparent;
  color: var(--subtext-color);
  cursor: pointer;
  display: flex;
  font-size: 0.875rem;
  font-weight: bold;
  gap: 10px;
  line-height: 1;
  padding: 12px 16px 11px;
  transition: var(--transition);
}
.property-form__label .btn__ico, .tab-ui__label .btn__ico {
  fill: #000;
}

.property-form__body, .tab-ui__body {
  display: none;
  padding: 24px 0;
  width: 100%;
}

.property-form__label:hover,
#tab-search:checked ~ .property-form__tab #tab-search__label,
#tab-input:checked ~ .property-form__tab #tab-input__label, #tab-10:checked ~ .tab-ui__tab #tab-10__label, #tab-9:checked ~ .tab-ui__tab #tab-9__label, #tab-8:checked ~ .tab-ui__tab #tab-8__label, #tab-7:checked ~ .tab-ui__tab #tab-7__label, #tab-6:checked ~ .tab-ui__tab #tab-6__label, #tab-5:checked ~ .tab-ui__tab #tab-5__label, #tab-4:checked ~ .tab-ui__tab #tab-4__label, #tab-3:checked ~ .tab-ui__tab #tab-3__label, #tab-2:checked ~ .tab-ui__tab #tab-2__label, #tab-1:checked ~ .tab-ui__tab #tab-1__label, .tab-ui__label:hover {
  background: #EAF3FF;
  border-color: var(--btn-color);
  color: var(--btn-color);
}
.property-form__label:hover .btn__ico,
#tab-search:checked ~ .property-form__tab #tab-search__label .btn__ico,
#tab-input:checked ~ .property-form__tab #tab-input__label .btn__ico, #tab-10:checked ~ .tab-ui__tab #tab-10__label .btn__ico, #tab-9:checked ~ .tab-ui__tab #tab-9__label .btn__ico, #tab-8:checked ~ .tab-ui__tab #tab-8__label .btn__ico, #tab-7:checked ~ .tab-ui__tab #tab-7__label .btn__ico, #tab-6:checked ~ .tab-ui__tab #tab-6__label .btn__ico, #tab-5:checked ~ .tab-ui__tab #tab-5__label .btn__ico, #tab-4:checked ~ .tab-ui__tab #tab-4__label .btn__ico, #tab-3:checked ~ .tab-ui__tab #tab-3__label .btn__ico, #tab-2:checked ~ .tab-ui__tab #tab-2__label .btn__ico, #tab-1:checked ~ .tab-ui__tab #tab-1__label .btn__ico, .tab-ui__label:hover .btn__ico {
  fill: var(--btn-color);
}
.property-form__label:hover .tab-ui__label-type,
#tab-search:checked ~ .property-form__tab #tab-search__label .tab-ui__label-type,
#tab-input:checked ~ .property-form__tab #tab-input__label .tab-ui__label-type, #tab-10:checked ~ .tab-ui__tab #tab-10__label .tab-ui__label-type, #tab-9:checked ~ .tab-ui__tab #tab-9__label .tab-ui__label-type, #tab-8:checked ~ .tab-ui__tab #tab-8__label .tab-ui__label-type, #tab-7:checked ~ .tab-ui__tab #tab-7__label .tab-ui__label-type, #tab-6:checked ~ .tab-ui__tab #tab-6__label .tab-ui__label-type, #tab-5:checked ~ .tab-ui__tab #tab-5__label .tab-ui__label-type, #tab-4:checked ~ .tab-ui__tab #tab-4__label .tab-ui__label-type, #tab-3:checked ~ .tab-ui__tab #tab-3__label .tab-ui__label-type, #tab-2:checked ~ .tab-ui__tab #tab-2__label .tab-ui__label-type, #tab-1:checked ~ .tab-ui__tab #tab-1__label .tab-ui__label-type, .tab-ui__label:hover .tab-ui__label-type {
  background: var(--btn-color);
}
.property-form__label:hover,
#tab-search:checked ~ .property-form__tab #tab-search__label:hover,
#tab-input:checked ~ .property-form__tab #tab-input__label:hover, #tab-10:checked ~ .tab-ui__tab #tab-10__label:hover, #tab-9:checked ~ .tab-ui__tab #tab-9__label:hover, #tab-8:checked ~ .tab-ui__tab #tab-8__label:hover, #tab-7:checked ~ .tab-ui__tab #tab-7__label:hover, #tab-6:checked ~ .tab-ui__tab #tab-6__label:hover, #tab-5:checked ~ .tab-ui__tab #tab-5__label:hover, #tab-4:checked ~ .tab-ui__tab #tab-4__label:hover, #tab-3:checked ~ .tab-ui__tab #tab-3__label:hover, #tab-2:checked ~ .tab-ui__tab #tab-2__label:hover, #tab-1:checked ~ .tab-ui__tab #tab-1__label:hover, .tab-ui__label:hover {
  transition: var(--transition);
}

input[name=tab-ui] {
  display: none;
}

.tab-ui__label-type {
  background: var(--frame-color);
  border-radius: 50px;
  color: #fff;
  display: block;
  font-size: 0.75rem;
  font-weight: bold;
  padding: 7px 10px;
}

#tab-1:checked ~ #tab-1__body {
  display: block;
}

#tab-2:checked ~ #tab-2__body {
  display: block;
}

#tab-3:checked ~ #tab-3__body {
  display: block;
}

#tab-4:checked ~ #tab-4__body {
  display: block;
}

#tab-5:checked ~ #tab-5__body {
  display: block;
}

#tab-6:checked ~ #tab-6__body {
  display: block;
}

#tab-7:checked ~ #tab-7__body {
  display: block;
}

#tab-8:checked ~ #tab-8__body {
  display: block;
}

#tab-9:checked ~ #tab-9__body {
  display: block;
}

#tab-10:checked ~ #tab-10__body {
  display: block;
}

/**
 * Chinsatekun CSS
 */
.login {
  align-items: flex-start;
  background: none;
  display: flex;
  height: 100vh;
  height: 100dvh;
  justify-content: center;
  min-height: -webkit-fill-available;
}

.login__dialog {
  margin-top: 96px;
  width: fit-content;
}

.login__logo {
  margin-bottom: 48px;
  text-align: center;
}

.login__logo-img {
  fill: #000;
  height: 61px;
  width: 234px;
}

.login__body {
  background: #fff;
  border-radius: 10px;
  box-shadow: none;
  margin-bottom: 48px;
  padding: 48px;
  min-width: 540px;
}
.login__body li {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
  margin-bottom: 36px;
}
.login__body li:last-of-type {
  margin-bottom: 0;
}
.login__body .btn {
  font-size: 1rem;
  padding: 12px;
}
.login__body .btn.-bktologin {
  justify-content: center;
  margin: 0 auto;
  min-width: 320px;
}

li.login__error {
  align-items: center;
  background: #FFE9EB;
  border-radius: 3px;
  display: flex;
  gap: 6px;
  justify-content: center;
  line-height: 1;
  margin-bottom: 36px;
  padding: 16px 20px;
}

.login__ttl {
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1;
  margin-bottom: 36px;
  text-align: center;
}

.login__lead {
  margin-bottom: 1.5em;
  text-align: center;
}
.login__lead:last-of-type {
  margin-bottom: 36px;
}

.login__input {
  font-size: 1rem;
}

.login__agree {
  font-size: 0.75rem;
}
.login__agree a {
  color: #007FF7;
}

.login-help__wrapper li {
  margin-bottom: 12px;
}

a.login__help {
  font-size: 0.75rem;
  line-height: 1;
  margin: 0 0 0 auto;
  width: fit-content;
}
a.login__help::after {
  content: url(/img/common/ico-arrow-blue.svg);
  display: inline-block;
  margin-left: 6px;
}

li.login__sent-nav {
  grid-template-columns: 1fr 1fr;
}

.login__contact {
  font-size: 1.25rem;
  font-weight: bold;
  margin: 0 auto 36px;
  width: fit-content;
}

.login__contact-item {
  display: flex;
  gap: 0.5rem;
}
.login__contact-item a {
  color: #007FF7;
  opacity: 1;
}

.login__footer {
  display: flex;
  font-size: 0.875rem;
  gap: 24px;
  justify-content: center;
  line-height: 1;
}
.login__footer a {
  color: var(--ttl-color);
  text-decoration: underline;
}
.login__footer a:hover {
  opacity: 0.8;
}

.top {
  margin: 0 auto;
  width: fit-content;
}

.top__ttl {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1;
  margin-bottom: 24px;
}

.products {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(3, 432px);
  margin-bottom: 48px;
}

.products__item,
a.products__item {
  background: #fff;
  border-radius: 10px;
  box-shadow: 1px 1px 4px rgb(var(--ttl-color-rgb)/0.25);
  color: var(--ttl-color);
  cursor: pointer;
  display: block;
  height: 100%;
  min-height: 248px;
  opacity: 1;
  overflow: hidden;
  transition: var(--transition);
}
.products__item:hover,
a.products__item:hover {
  background: #EAF3FF;
  outline: 3px solid #285AC8;
  outline-offset: -3px;
  text-decoration: none;
}

.products__header {
  display: flex;
  justify-content: space-between;
  margin: 24px;
}

.products__plan {
  background: #E3F7FF;
  border-radius: 50px;
  color: #30ADC9;
  font-size: 1rem;
  font-weight: bold;
  min-width: 120px;
  padding: 10px 20px;
  text-align: center;
}
.products__plan.-enterprise {
  background: #F7E4FF;
  color: #8809BD;
}
.products__plan.-light {
  background: #FEF2CB;
  color: #EAB400;
}
.products__plan.-option {
  background: #E7E9EB;
  color: var(--text-color);
}

.products__ttl {
  display: grid;
  font-size: 1.25rem;
  font-weight: bold;
  gap: 8px;
  line-height: 1;
}
.products__ttl small {
  color: var(--text-color);
  font-size: 0.75rem;
  font-weight: normal;
}

.products__description {
  color: var(--text-color);
  margin: 24px;
}

.products__available {
  border-top: 1px solid #EFF0F4;
  margin: 24px;
  padding-top: 24px;
}

.products__limit {
  align-items: baseline;
  display: flex;
  justify-content: space-between;
}
.products__limit dt {
  color: var(--text-color);
}
.products__limit dd {
  font-weight: bold;
}
.products__limit dd strong {
  font-size: 1.25rem;
  margin-right: 2px;
}

/**
 * Media Queries
 */
@media only screen and (max-width: 1344px) {
  .products {
    grid-template-columns: repeat(2, 432px);
  }
}
.news {
  margin: 0 auto;
  max-width: 1344px;
}
.news li {
  display: grid;
  gap: 24px;
  grid-template-columns: 72px 1fr 40px;
  margin-bottom: 24px;
  padding-bottom: 24px;
}
.news li:not(:last-of-type) {
  border-bottom: 0.5px solid #DEDEE1;
}

.news__body {
  line-height: 1;
  margin-top: 7px;
}

.news__ttl {
  font-size: 1rem;
  margin-bottom: 12px;
}

.news__txt {
  color: var(--text-color);
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  line-height: 1.6;
  margin-bottom: 12px;
  overflow: hidden;
}

a.news__link {
  display: inline-block;
  margin: auto 12px auto 0;
}
a.news__link:hover {
  opacity: 0.8;
}

/**
 * Media Queries
 */
@media only screen and (max-width: 1344px) {
  .news {
    max-width: 888px;
  }
}
/**
 * Chinsatekun CSS
 */
.contact {
  background: #fff;
  border-radius: 1px;
  margin: 48px auto;
  padding: 36px 0;
  width: auto;
  max-width: 1096px;
}

.contact__header {
  margin: 0 36px 48px;
}

.contact__ttl {
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1;
  margin-bottom: 24px;
}

.contact__item {
  margin: 24px 36px;
}
.contact__item .select {
  width: 360px;
}
.contact__item.-error {
  background: #EAF3FF;
  margin: 0 0 24px;
  padding: 24px 36px;
}
.contact__item.-other {
  background: #E7E9EB;
  border-radius: 5px;
  padding: 24px;
}
.contact__item.-other .contact__item-ttl {
  font-weight: normal;
}

.contact__item-ttl {
  font-size: 0.875rem;
  font-weight: bold;
  line-height: 1;
  margin-bottom: 10px;
}

.contact__msg-input {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.contact__list {
  font-size: 1.25rem;
  font-weight: bold;
  margin: 0 auto;
}

.contact__list-item {
  display: flex;
  gap: 0.5rem;
}
.contact__list-item a {
  opacity: 1;
}

.contact__action {
  display: flex;
  gap: 12px;
  justify-content: flex-start;
  margin: 24px 36px 0;
}

/**
 * Chinsatekun CSS
 */
/* マウスオンする要素とツールチップを横並びにする */
.history-tooltip {
  display: inline-block;
  position: relative;
}

/* ツールチップ共通の設定 */
.history-tooltip::before,
.history-tooltip::after {
  -webkit-transition: all 0.2s;
  opacity: 0;
  position: absolute;
  transition: all 0.2s;
  visibility: hidden;
  z-index: 11;
}

/* ツールチップ吹き出しのひげ */
.history-tooltip::before {
  border-style: solid;
  border-width: 3px 4px 0 4px;
  border-color: rgb(var(--text-color-rgb)/90%) transparent transparent transparent;
  top: -10px;
  content: "";
  height: 0;
  left: 0;
  position: absolute;
  transform: translateX(-53%);
  width: 0;
}

/* ツールチップ吹き出しの本体 */
.history-tooltip::after {
  font-size: 0.75rem;
  background: rgb(var(--text-color-rgb)/90%);
  box-shadow: 2px 2px 10px rgb(var(--text-color-rgb)/25%);
  border-radius: 1px;
  bottom: 24px;
  color: #fff;
  content: attr(data-tooltip); /* ここでdata-tooltipの内容を呼び出しているよ */
  display: block;
  font-weight: 800;
  left: 0;
  padding: 6px 12px;
  transform: translateX(-53%);
  width: fit-content;
  white-space: nowrap;
}

/* マウスオンしたときのカーソルの設定 */
.history-tooltip:hover {
  cursor: pointer;
}

.history-tooltip:hover::before {
  opacity: 1;
  visibility: visible;
}

.history-tooltip:hover::after {
  opacity: 1;
  visibility: visible;
}

/**
 * Chinsatekun CSS
 */
.search-select {
  align-items: center;
  display: grid;
  height: calc(100vh - 64px - 100px);
  justify-content: center;
  width: 100%;
}

.search-select__ttl {
  font-size: 1.25rem;
  text-align: center;
  margin: 24px 0;
}

.search-select__nav {
  display: flex;
  gap: 32px;
}
.search-select__nav li {
  width: 100%;
}

.search-select__btn {
  align-items: center;
  background: #fff;
  border: 0;
  border-radius: 10px;
  box-shadow: 4px 4px 10px rgb(var(--text-color-rgb)/10%);
  display: flex;
  flex-direction: column;
  font-size: 1rem;
  font-weight: bold;
  gap: 16px;
  height: 178px;
  justify-content: center;
  outline: 1px solid var(--frame-color);
  transition: var(--transition);
  width: 100%;
}
.search-select__btn:hover {
  background: #EAF3FF;
  color: var(--btn-color);
  outline: 2px solid var(--btn-color);
}
.search-select__btn:disabled {
  box-shadow: none;
  color: #EAEDF2;
}
.search-select__btn:disabled:hover {
  background: #fff;
  outline: 1px solid var(--frame-color);
}
.search-select__btn:disabled .search-select__btn-ico {
  fill: #EAEDF2;
}

.search-select__btn-ico {
  fill: var(--btn-color);
  height: 80px;
  width: 80px;
}

/**
 * Chinsatekun CSS
 */
.layout-select {
  background: #F1F4F9;
  border-radius: 5px;
  padding: 24px;
  margin: 24px 24px 60px;
}

.layout-select__header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 16px;
}

.layout-select__ttl {
  display: grid;
  font-size: 1rem;
  gap: 8px;
  line-height: 1;
}
.layout-select__ttl small {
  color: var(--subtext-color);
  font-size: 0.75rem;
  font-weight: normal;
}

.layout-select__ul {
  display: grid;
  gap: 12px;
}

.layout-select__item {
  background: #fff;
  border-radius: 3px;
  cursor: pointer;
  display: block;
  outline: 1px solid var(--frame-color);
  outline-offset: -1px;
  padding: 24px;
  position: relative;
  transition: var(--transition);
}
.layout-select__item::after {
  background: #fff;
  border-radius: 50px;
  content: "";
  display: block;
  height: 18px;
  left: 24px;
  outline: 1px solid #B7BCC1;
  outline-offset: -1px;
  position: absolute;
  top: 27px;
  width: 18px;
}
.layout-select__item:hover {
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
}
.layout-select__item:hover .layout-select__ctrl {
  display: flex;
}
.layout-select__item:has(.layout-select__checkbox:checked) {
  box-shadow: 1px 1px 5px rgba(36, 36, 36, 0.25);
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
}
.layout-select__item:has(.layout-select__checkbox:checked)::after {
  background: var(--btn-color) url(../../img/common/ico-check.svg) no-repeat center center;
  background-size: 16px;
  outline: none;
}
.layout-select__item:has(.layout-select__checkbox:checked) .layout-select__ctrl {
  display: flex;
}

.layout-select__checkbox {
  display: none;
}

.layout-select__floor {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 8px;
  padding: 0 0 16px 30px;
}

.layout-select__spec {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.layout-select__spec li {
  font-size: 0.75rem;
  line-height: 1;
}
.layout-select__spec li:not(:last-of-type)::after {
  content: " / ";
}

.layout-select__ctrl {
  display: none;
  gap: 8px;
  position: absolute;
  right: 24px;
  top: 18px;
}
.layout-select__ctrl .btn {
  padding: 12px;
}

.layout-select__action {
  background: rgba(5, 16, 28, 0.5);
  bottom: 0;
  display: flex;
  justify-content: center;
  margin-left: -214px;
  padding: 24px;
  position: fixed;
  width: 100vw;
  z-index: 200;
}

/**
 * Chinsatekun CSS
 */
.property-box {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 16px;
  margin: 24px 24px 36px;
}

.property-box__header {
  align-items: center;
  display: flex;
  line-height: 1;
  gap: 16px;
  margin-bottom: 16px;
}

.property-box__img {
  border-radius: 3px;
}

.property-box__ttl {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 8px;
}

.property-box__addr {
  font-size: 0.8125rem;
}

.property-box__data {
  border-top: 1px solid var(--border-color);
  display: grid;
  grid-template-columns: 160px 1fr;
  line-height: 1;
}
.property-box__data dt, .property-box__data dd {
  border-bottom: 1px solid var(--border-color);
  padding: 8px 10px;
}
.property-box__data dt {
  background: #F1F4F9;
}

.property-box__map {
  border-radius: 5px;
  height: 100%;
  overflow: hidden;
  vertical-align: top;
  width: 100%;
}

/**
 * Chinsatekun CSS
 */
.property-search__wrapper {
  margin: 0 auto 36px;
  outline: -3px solid var(--btn-color);
  width: fit-content;
}

.property-search__input-box {
  position: relative;
}
.property-search__input-box.-suggest::before {
  border-bottom: 1px solid var(--border-color);
  content: "";
  display: block;
  left: 3px;
  position: absolute;
  top: 56px;
  width: calc(100% - 6px);
  z-index: 102;
}
.property-search__input-box.-suggest .property-search__input {
  background-color: #fff;
  border-color: var(--btn-color);
  border-width: 3px 3px 0 3px;
  border-radius: 10px 10px 0 0;
}
.property-search__input-box.-suggest .property-search__reset:hover {
  background: #EEF0F2;
}
.property-search__input-box.-suggest .property-search__reset .property-search__reset-img {
  fill: var(--text-color);
}

.property-search__input {
  background: #EAEDF2 url(../../img/common/ico-circle-search.svg) no-repeat 14px center;
  border: 3px solid transparent;
  border-radius: 50px;
  display: block;
  height: 56px;
  line-height: 1;
  padding: 22px 58px;
  transition: var(--transition);
  width: 832px;
}
.property-search__input::placeholder {
  color: var(--subtext-color);
}
.property-search__input:focus {
  background-color: #fff;
  border-color: var(--btn-color);
}
.property-search__input:focus + .property-search__reset:hover {
  background: #EEF0F2;
}
.property-search__input:focus + .property-search__reset .property-search__reset-img {
  fill: var(--text-color);
}
.property-search__input:focus-visible {
  outline-width: 0;
}

.property-search__reset {
  appearance: none;
  background: none;
  border: 0;
  border-radius: 50px;
  height: 32px;
  position: absolute;
  right: 20px;
  top: calc(50% - 16px);
  transition: var(--transition);
  width: 32px;
  z-index: 2;
}

.property-search__reset-img {
  fill: transparent;
  height: 16px;
  width: 16px;
}

.property-search__action {
  display: flex;
  gap: 12px;
  justify-content: center;
}
.property-search__action .btn {
  font-size: 1rem;
}

.property-search.-simple .property-search__wrapper {
  margin: 0;
}
.property-search.-simple .property-search__input {
  background: #fff url(../../img/common/ico-search.svg) no-repeat 10px 50%;
  background-size: 13px;
  border-radius: 5px;
  outline: 1px solid var(--frame-color);
  font-size: 0.8125rem;
  height: 35px;
  min-height: auto;
  outline-offset: -1px;
  padding: 10px 38px 10px 31px;
  width: auto;
}
.property-search.-simple .property-search__reset {
  height: 14px;
  right: 10px;
  top: calc(50% - 7px);
  width: 14px;
}

/**
 * Chinsatekun CSS
 */
.property-suggest {
  background: #fff;
  border-color: var(--btn-color);
  border-style: solid;
  border-width: 0 3px 3px 3px;
  border-radius: 0 0 10px 10px;
  max-height: 40vh;
  overflow: auto;
  padding-bottom: 8px;
  position: absolute;
  scrollbar-color: var(--border-color) transparent;
  transition: var(--transition);
  width: 100%;
  z-index: 101;
}

.property-suggest__item {
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  line-height: 1;
  padding: 12px 14px;
}
.property-suggest__item address {
  color: var(--subtext-color);
  font-size: 0.75rem;
}
.property-suggest__item:hover {
  background: #EAF3FF;
}

.property-suggest__name {
  display: grid;
  gap: 6px;
}

.property-suggest__rooms {
  background: #EAEDF2;
  border-radius: 5px;
  padding: 8px 12px;
}

.backtosearch {
  margin: 36px 24px 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--frame-color);
}

input[name=property-tab] {
  display: none;
}

#tab-search:checked ~ #tab-search__body,
#tab-input:checked ~ #tab-input__body {
  display: block;
}

.property-input {
  margin: 0 auto;
  max-width: 880px;
}

.property-input__action {
  display: flex;
  gap: 12px;
  justify-content: center;
}
.property-input__action .btn {
  font-size: 1rem;
}

.prev-property {
  align-self: start;
  border-left: 1px solid var(--border-color);
  height: 100vh;
  position: sticky;
  top: 0;
  z-index: 100;
}

.prev-property__header {
  align-items: center;
  background: #fff;
  border-bottom: 1px solid var(--border-color);
  display: flex;
  justify-content: space-between;
  margin: 0 24px 26px;
  padding: 36px 0;
}

.prev-property__ttl {
  font-size: 1rem;
}

a.prev-property__link {
  align-items: center;
  display: flex;
  font-size: 0.75rem;
  gap: 4px;
  line-height: 1;
}

.prev-property__link-ico {
  fill: var(--link-color);
  height: 14px;
  scale: 0.84;
  width: 14px;
}

.prev-property__ul {
  display: grid;
  gap: 4px;
  height: calc(100vh - 210px);
  margin: 36px 10px 36px 24px;
  overflow: auto;
}

a.prev-property__item {
  border-radius: 5px;
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr 72px;
  padding: 10px;
}
a.prev-property__item:hover {
  background: #EAF3FF;
  text-decoration: none;
}

.prev-property__name {
  color: var(--ttl-color);
  display: block;
  font-weight: bold;
  line-height: 1;
  margin: 3px 0 10px;
}

.prev-property__data {
  color: var(--text-color);
  display: grid;
  gap: 6px;
  font-size: 0.75rem;
  line-height: 1;
}

.prev-property__data-spec,
.prev-property__data-date {
  background-repeat: no-repeat;
  background-position: left top;
  padding-left: 18px;
}

.prev-property__data-spec {
  background-image: url(../../img/common/ico-door.svg);
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.prev-property__data-date {
  background-image: url(../../img/common/ico-calendar.svg);
}

.satei-summary {
  background: #F5F6F7;
  display: flow-root;
  margin: 0 36px 36px;
}

.satei-summary__header {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  margin: 0 36px 24px;
}

.satei-summary__data,
.satei-summary__nav {
  margin-top: 36px;
}

.satei-summary__ttl {
  font-size: 1.125rem;
  line-height: 1;
  margin-bottom: 8px;
}

.satei-summary__nav {
  display: flex;
  gap: 12px;
  height: 38px;
}
.satei-summary__nav .dropmenu .btn {
  height: 38px;
  justify-content: center;
  padding: 0;
  width: 38px;
}
.satei-summary__nav .dropmenu__submenu {
  top: 38px;
}

.satei-summary__spec {
  display: flex;
  gap: 16px;
  margin: 0 36px 36px;
}
.satei-summary__spec li {
  align-items: center;
  display: flex;
  gap: 8px;
}

.satei-summary__price-list {
  align-items: center;
  background: #fff;
  border-radius: 5px;
  display: flex;
  gap: 48px;
  margin: 36px;
  padding: 28px;
}

.satei-summary__rent {
  border-right: 1px solid var(--border-color);
  line-height: 1;
  padding-right: 48px;
}
.satei-summary__rent span {
  background: var(--btn-color);
  border-radius: 50px;
  color: #fff;
  display: inline-block;
  font-size: 0.75rem;
  font-weight: bold;
  padding: 7px 12px;
  margin-bottom: 10px;
}
.satei-summary__rent p {
  font-weight: bold;
  margin-bottom: 10px;
}
.satei-summary__rent p strong {
  font-size: 3rem;
}
.satei-summary__rent small {
  font-size: 1rem;
}

.satei-summary__cost div {
  align-items: center;
  display: grid;
  gap: 1em;
  grid-template-columns: 5em 9em 1fr;
  font-size: 1rem;
}
.satei-summary__cost div dt {
  display: flex;
  justify-content: space-between;
}
.satei-summary__cost div dt::after {
  content: "：";
}

.satei-summary__cost-price strong {
  font-size: 1.5rem;
  white-space: nowrap;
}

.satei-summary__details {
  margin: 0 36px;
  overflow: hidden;
}
.satei-summary__details:not(:last-of-type) {
  border-bottom: 1px solid var(--border-color);
}
.satei-summary__details:first-of-type {
  border-radius: 5px 5px 0 0;
}
.satei-summary__details:last-of-type {
  border-radius: 0 0 5px 5px;
  margin-bottom: 36px;
}

.eq-correct {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr 1fr;
}

.eq-correct__tbl {
  font-size: 1rem;
}
.eq-correct__tbl thead th {
  background: #F7F8FA;
  padding: 12px 24px;
  text-align: left;
}
.eq-correct__tbl thead th:not(:last-of-type) {
  border-right: 1px solid #fff;
}
.eq-correct__tbl tbody tr:not(:last-of-type) {
  border-bottom: 1px solid var(--border-color);
}
.eq-correct__tbl tbody td {
  padding: 12px;
}
.eq-correct__tbl tbody td:last-of-type {
  width: 240px;
}

.case-list {
  position: relative;
}

.case-list__ttl {
  background: #EEEFF1;
  font-size: 1.125rem;
  line-height: 1;
  padding: 17px 36px;
}

input[name=case-tab] {
  display: none;
}

.case-list__tab-nav {
  display: flex;
  gap: 4px;
  position: absolute;
  right: 36px;
  top: 8px;
}

.case-list__tab-label {
  align-items: center;
  border-radius: 5px;
  cursor: pointer;
  display: flex;
  font-size: 1rem;
  font-weight: bold;
  height: 36px;
  justify-content: center;
  transition: var(--transition);
  width: 36px;
}
.case-list__tab-label:hover {
  background: #EAF3FF;
}
.case-list__tab-label:hover .case-list__tab-ico {
  fill: var(--btn-color);
}

.case-list__tab-ico {
  fill: #424242;
  height: 16px;
  width: 16px;
}
.case-list__tab-ico.-table {
  width: 19px;
}

.case-list__body {
  display: none;
}

.case-list__ctrl {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  margin: 24px 36px 24px 36px;
}
.case-list__ctrl .enishi-input.-search {
  min-height: auto;
  width: 324px;
}
.case-list__ctrl.-with-tab {
  margin-left: 308px;
}

.case-list__ctrl-axis {
  align-items: center;
  display: flex;
  gap: 24px;
  margin-right: auto;
  white-space: nowrap;
}
.case-list__ctrl-axis label {
  margin-right: -8px;
}

#case-table:checked ~ .case-list__tab-nav #case-table__label .case-list__tab-ico,
#case-map:checked ~ .case-list__tab-nav #case-map__label .case-list__tab-ico,
#case-graph:checked ~ .case-list__tab-nav #case-graph__label .case-list__tab-ico {
  fill: var(--btn-color);
}

#case-table:checked ~ #case-table__body,
#case-map:checked ~ #case-map__body,
#case-graph:checked ~ #case-graph__body {
  display: block;
}

.case-column {
  align-items: flex-start;
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr 440px;
  margin: 24px 36px;
}

.case-column__map,
.case-column__graph {
  border-radius: 5px;
  width: 100%;
}

.case-column__map {
  height: 914px;
  overflow: hidden;
}

.case-column__graph {
  background: #D7D9DB;
}

.case-column__graph-img {
  border-radius: 3px;
  height: auto;
  margin: 18px;
  width: calc(100% - 36px);
}

.case-ol {
  height: 914px;
  overflow-y: auto;
  overflow-x: hidden;
}

.case-ol__item {
  border-bottom: 1px solid var(--border-color);
  counter-increment: case_num;
  line-height: 1;
  position: relative;
}
.case-ol__item details[open] .case-ol__summary {
  background: #EAF3FF;
}
.case-ol__item details[open] .case-ol__summary::before {
  background: var(--btn-color);
}
.case-ol__item details[open] .case-ol__ttl-ico {
  fill: var(--btn-color);
  rotate: -90deg;
}
.case-ol__item:has(.case-body__check:checked) .case-ol__summary {
  background: #EAF3FF;
}
.case-ol__item:has(.case-body__check:checked) .case-ol__summary::before {
  background: var(--btn-color);
}
.case-ol__item:has(.case-body__check:checked) .case-ol__selected {
  display: inline-block;
}

.case-ol__summary {
  align-items: center;
  cursor: pointer;
  display: grid;
  font-size: 0.75rem;
  grid-template-columns: 56px 1fr 30px;
  padding: 12px;
  transition: var(--transition);
}
.case-ol__summary::before {
  align-items: center;
  background: #424242;
  border-radius: 5px;
  color: #fff;
  content: counter(case_num);
  display: flex;
  font-size: 0.875rem;
  font-weight: bold;
  height: 36px;
  justify-content: center;
  margin-right: 20px;
  width: 36px;
}
.case-ol__summary:hover {
  background: #EAF3FF;
}
.case-ol__summary::-webkit-details-marker {
  display: none;
}

.case-ol__ttl-ico {
  fill: #424242;
  height: 14px;
  margin: 0 auto;
  rotate: 90deg;
  transition: all 0.2s ease-out;
  width: 14px;
}

.case-ol__selected {
  background: #fff;
  border: 1px solid var(--btn-color);
  border-radius: 50px;
  color: var(--btn-color);
  display: none;
  font-size: 0.75rem;
  font-weight: bold;
  right: 54px;
  line-height: 1;
  padding: 6px 12px;
  position: absolute;
  top: 18px;
}

.case-ol__name {
  display: block;
  font-size: 1rem;
  margin-bottom: 8px;
}

.case-body__header {
  align-items: center;
  display: flex;
  gap: 16px;
  margin: 16px 12px;
}
.case-body__header .enishi-checkbox {
  margin-left: auto;
  outline: none;
  padding: 0;
}
.case-body__header .enishi-checkbox::before {
  background: #fff;
}

.case-body__ttl {
  border: 1px solid var(--enishi-red);
  border-radius: 50px;
  color: var(--enishi-red);
  display: inline-block;
  font-size: 0.75rem;
  line-height: 1;
  padding: 8px 12px;
}

.case-body__plan {
  font-size: 1rem;
}

.case-body__price {
  background: #F7F8FA;
  border-radius: 5px;
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(4, 1fr);
  margin: 24px 12px;
  padding: 12px;
}

.case-body__price-item {
  font-size: 0.75rem;
}
.case-body__price-item:not(:last-of-type) {
  border-right: 1px solid var(--border-color);
  padding-right: 16px;
}
.case-body__price-item dt {
  margin-bottom: 6px;
}
.case-body__price-item dd {
  font-weight: bold;
}
.case-body__price-item dd strong {
  font-size: 1rem;
}

.case-body__data {
  column-count: 2;
  column-gap: 32px;
  margin: 24px 24px 16px;
  position: relative;
}
.case-body__data::before {
  border-right: 1px solid var(--border-color);
  content: "";
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 50%;
  height: 100%;
}

.case-body__data-item {
  break-inside: avoid;
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  margin-bottom: 8px;
}
.case-body__data-item dt, .case-body__data-item dd {
  width: 82px;
}

.case-body__spec {
  margin: 0 12px 16px;
}

.case-body__figure {
  display: flex;
  gap: 12px;
  margin: 16px 12px;
}

.list-table {
  position: relative;
}

input[name=table-tab] {
  display: none;
}

.list-table__nav {
  border: 1px solid var(--btn-color);
  border-radius: 5px;
  display: grid;
  grid-template-columns: repeat(2, fit-content(150px));
  overflow: hidden;
  position: absolute;
  left: 24px;
  top: 0;
}

.list-table__label {
  color: var(--btn-color);
  cursor: pointer;
  font-weight: bold;
  line-height: 1;
  padding: 12px;
  text-align: center;
  transition: var(--transition);
}
.list-table__label:hover {
  background: #EAF3FF;
}

.list-table__body {
  display: none;
  margin-bottom: 60px;
}

.list-table__wrapper {
  overflow-x: scroll;
  margin: 24px 0 24px 24px;
  width: calc(100vw - 214px - 60px);
}

.list-table__table th, .list-table__table td {
  line-height: 1;
  padding: 12px;
  white-space: nowrap;
}
.list-table__table thead th {
  background: #EEEFF1;
  text-align: left;
}
.list-table__table thead th:not(:last-of-type) {
  border-right: 1px solid #fff;
}
.list-table__table tbody tr {
  transition: var(--transition);
}
.list-table__table tbody tr:hover {
  background: #EAF3FF;
}

a.list-table__name {
  align-items: center;
  color: #000;
  display: flex;
  justify-content: space-between;
  min-width: 234px;
}
a.list-table__name:hover {
  color: var(--link-color);
  text-decoration: underline;
}

#table-room:checked ~ .list-table__nav #table-room__label,
#table-building:checked ~ .list-table__nav #table-building__label {
  background: var(--btn-color);
  color: #fff;
}

#table-room:checked ~ #table-room__body,
#table-building:checked ~ #table-building__body {
  display: block;
}

/**
 * Chinsatekun CSS
 */
.stacking {
  display: grid;
  grid-template-columns: 255px 1fr;
}

.stacking__header,
.stacking__header-ttl,
.stacking__header-setting,
.stacking__header-setting li,
.stacking__header-nav {
  align-items: center;
  display: flex;
}

.stacking__header {
  border-bottom: 1px solid var(--border-color);
  gap: 78px;
  grid-column: 1/3;
  height: 60px;
}

.stacking__header-ttl {
  gap: 12px;
  font-size: 1.125rem;
  margin-left: 24px;
  white-space: nowrap;
}

.stacking__header-setting {
  gap: 16px;
}
.stacking__header-setting li {
  gap: 16px;
  white-space: nowrap;
}
.stacking__header-setting .select {
  width: 200px;
}
.stacking__header-setting .select:after {
  height: 38px;
  width: 38px;
}
.stacking__header-setting .select__item {
  height: 38px;
}

.stacking__header-nav {
  gap: 6px;
  margin-left: auto;
  margin-right: 24px;
  white-space: nowrap;
}

/**
 * Chinsatekun CSS
 */
.stack-summary {
  background: #fff;
  position: relative;
}
.stack-summary .tab-ui__body {
  padding: 0;
}

.stack-summary__list {
  display: grid;
  gap: 12px;
  margin: 0 24px 12px;
}

.stack-summary__item {
  appearance: none;
  border: none;
  background: #F8FAFD;
  border-radius: 5px;
  display: block;
  line-height: 1;
  padding: 12px;
  text-align: left;
  transition: var(--transition);
  width: 100%;
}

button.stack-summary__item:hover {
  background: #EAEDF2;
}

.stack-summary__ttl {
  font-size: 0.8125rem;
  margin-bottom: 8px;
}

.stack-summary__body {
  font-size: 0.75rem;
  font-weight: bold;
}

.satei-summary__value {
  font-size: 1.25rem;
}

.stack-summary__action {
  bottom: 0;
  left: 0;
  margin: 24px;
  position: fixed;
  width: 207px;
}
.stack-summary__action ul {
  display: flex;
  gap: 20px;
  justify-content: center;
}

/**
 * Chinsatekun CSS
 */
.stack-table {
  background: #D7D9DB;
  overflow: auto;
}

.stack-table__table {
  box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.25);
  line-height: 1;
  margin: 24px;
}
.stack-table__table thead {
  background: #285AC8;
}
.stack-table__table thead th {
  border-color: #E5E6E7;
  border-style: solid;
  border-width: 0 1px 1px 0;
}
.stack-table__table tbody {
  background: #fff;
}
.stack-table__table th, .stack-table__table td {
  vertical-align: top;
}
.stack-table__table th:last-of-type, .stack-table__table td:last-of-type {
  border-right: none;
}
.stack-table__table th {
  padding: 8px;
}
.stack-table__table th:first-of-type {
  font-size: 0.75rem;
  min-width: 83px;
}
.stack-table__table .enishi-checkbox {
  background: transparent;
  font-size: 0.75rem;
  outline: none;
  padding: 0;
}
.stack-table__table .enishi-checkbox::before {
  background: #fff;
}
.stack-table__table thead th .enishi-checkbox:has(input:checked) {
  outline: none;
}
.stack-table__table thead th .enishi-checkbox:has(input:checked)::before {
  background: #fff url(../../img/common/ico-check-blue.svg) no-repeat center center;
}
.stack-table__table tbody tr:not(:last-of-type) {
  border-bottom: 1px solid var(--border-color);
}
.stack-table__table tbody th .enishi-checkbox {
  background: transparent;
  font-weight: bold;
}
.stack-table__table tbody th .enishi-checkbox:has(input:checked) {
  outline: none;
}
.stack-table__table tbody td {
  border: 1px solid var(--border-color);
  border-width: 0 1px;
}
.stack-table__table tbody td .enishi-checkbox {
  background: #F3F5F7;
  border-radius: 0;
  display: grid;
  grid-template-columns: 20px auto 1fr;
  font-weight: bold;
  padding: 8px;
  white-space: nowrap;
  width: 270px;
}
.stack-table__table tbody td .enishi-checkbox:has(input:checked) {
  outline: none;
}
.stack-table__table tbody td .enishi-checkbox:has(.stack-table__type-type, .stack-table__type-info) {
  background: #EAF3FF;
}

.stack-table__type {
  display: flex;
  width: 100%;
}
.stack-table__type::before {
  background: var(--text-color);
  content: "";
  display: inline-block;
  font-weight: normal;
  height: 12px;
  margin: 0 8px 0 2px;
  width: 1px;
}

.stack-table__type-select {
  color: var(--subtext-color);
  font-weight: normal;
}

.stack-table__type-info {
  margin-left: auto;
}

.stack-table__data {
  display: grid;
  font-size: 0.75rem;
  grid-template-columns: 1fr 1fr;
}
.stack-table__data li:nth-of-type(even) {
  border-right: 1px solid var(--border-color);
}

.stack-table__data-total,
.stack-table__data-item {
  border-top: 1px solid var(--border-color);
}

.stack-table__data-total {
  align-items: center;
  display: flex;
  grid-column: 1/3;
  justify-content: space-between;
  padding: 8px;
}

.stack-table__data-item {
  align-items: center;
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  padding: 6px;
}

.stack-table__data-value {
  white-space: nowrap;
}

.stack-table__data-input {
  appearance: none;
  border: none;
  font-size: 0.75rem;
  padding: 0;
  text-align: right;
  width: 5em;
}
.stack-table__data-input:disabled {
  background: transparent;
}

.stack-table__data-rent {
  font-size: 0.875rem;
}

/**
 * Chinsatekun CSS
 */
.select-type {
  border: 0;
  max-height: none;
  max-width: none;
  position: fixed;
  background: rgba(5, 16, 28, 0.5);
  height: 100vh;
  width: 100vw;
}

.select-type__body {
  background: #fff;
  box-shadow: -1px 0 3px rgba(0, 0, 0, 0.25);
  height: 100vh;
  position: fixed;
  right: 0;
  top: 0;
  width: 288px;
}

.select-type__wrapper {
  height: calc(100vh - 86px);
  overflow: auto;
}

.select-type__ttl {
  font-weight: bold;
  margin: 16px 24px;
}
.select-type__ttl:first-of-type {
  margin-top: 24px;
}

.select-type__list {
  margin: 0 24px 16px;
  padding-bottom: 16px;
}
.select-type__list:not(:last-of-type) {
  border-bottom: 1px solid var(--border-color);
}
.select-type__list li:not(:last-of-type) {
  margin-bottom: 10px;
}

.select-type__label {
  border-radius: 5px;
  cursor: pointer;
  display: grid;
  font-size: 0.8125rem;
  gap: 6px;
  line-height: 1.4;
  outline: 1px solid var(--border-color);
  outline-offset: -1px;
  padding: 12px;
  position: relative;
  transition: var(--transition);
}
.select-type__label::after {
  background: #fff;
  border-radius: 50px;
  content: "";
  display: block;
  height: 20px;
  outline: 1px solid var(--frame-color);
  outline-offset: -1px;
  position: absolute;
  right: 9px;
  scale: 0.9;
  top: 9px;
  width: 20px;
}
.select-type__label:hover {
  background: #EAF3FF;
}
.select-type__label:has(.select-type__checkbox:checked) {
  background: #EAF3FF;
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
}
.select-type__label:has(.select-type__checkbox:checked)::after {
  background: var(--btn-color) url(../../img/common/ico-check.svg) no-repeat center center;
  outline: none;
}
.select-type__label:has(.select-type__checkbox:checked) .select-type__type {
  color: var(--btn-color);
}

.select-type__checkbox {
  display: none;
}

.select-type__type {
  font-size: 0.875rem;
  font-weight: bold;
  line-height: 1;
}

dt.select-type__type {
  margin-bottom: 9px;
}

.select-type__action {
  align-items: center;
  display: grid;
  gap: 10px;
  grid-template-columns: 1.2fr 1fr;
  height: 86px;
  padding: 24px;
}

.select-type,
.select-type__body {
  animation: fadeIn 0.1s ease-in-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/**
 * Chinsatekun CSS
 */
.rent-setting {
  display: grid;
  gap: 24px;
  margin: 24px;
}

.rent-setting__item:not(:last-of-type) {
  border-bottom: 1px solid var(--border-color);
  padding-bottom: 24px;
}

.rent-setting__ttl {
  display: block;
  font-size: 0.8125rem;
  font-weight: bold;
  margin-bottom: 16px;
}

.rent-setting__select {
  display: grid;
  gap: 8px;
  grid-template-columns: 28px repeat(3, 1fr);
  margin-bottom: 16px;
}

.rent-setting__minus {
  align-items: center;
  appearance: none;
  background: transparent;
  border: none;
  display: flex;
  transition: var(--transition);
}
.rent-setting__minus:hover {
  opacity: 0.8;
}

#add-item .dialog__body {
  height: 80vh;
}
#add-item .dialog__wrapper {
  max-height: none;
  height: calc(80vh - 92px - 86px);
}

.add-item {
  border-bottom: 1px solid var(--border-color);
  margin: 0 36px;
}
.add-item:first-of-type {
  margin-top: 12px;
}
.add-item:last-of-type {
  border: none;
  margin-bottom: 12px;
}
.add-item .toggle-btn {
  pointer-events: none;
}
.add-item[open] {
  border: none;
}
.add-item[open] .toggle-btn::before {
  background: var(--link-color);
  padding-left: 14px;
}
.add-item[open] .toggle-btn::after {
  content: url(../../img/common/ico-toggle-on.svg);
  left: 40px;
}

.add-item__ttl {
  align-items: center;
  cursor: pointer;
  display: flex;
  font-size: 1rem;
  gap: 8px;
  height: 70px;
  justify-content: space-between;
  margin: 0 12px;
}
.add-item__ttl::-webkit-details-marker {
  display: none;
}

.add-item__list {
  background: #F7F8FA;
  display: flow-root;
}

.add-item__item {
  margin: 24px;
}

.add-item__label {
  display: block;
  font-size: 0.75rem;
  font-weight: bold;
  margin-bottom: 10px;
}

#report {
  margin-top: 36px;
}

#report.theme-black {
  --base01: black;
  --base02: black;
  --base03: rgba(0, 0, 0, 0.8);
  --base04: rgba(0, 0, 0, 0.3);
  --base05: black;
  --base06: black;
  --base07: #2e2e2e;
  --base08: #222222;
  --base09: #757575;
  --base10: #0f0f0f;
  --base11: rgba(117, 117, 117, 0.3);
  --base12: #525252;
  --base13: #4d4d4d;
}
#report.theme-gray {
  --base01: #787878;
  --base02: #7c7c7c;
  --base03: rgba(124, 124, 124, 0.8);
  --base04: rgba(124, 124, 124, 0.3);
  --base05: #585858;
  --base06: #787878;
  --base07: #aeaeae;
  --base08: #a2a2a2;
  --base09: whitesmoke;
  --base10: #8f8f8f;
  --base11: rgba(245, 245, 245, 0.3);
  --base12: #d2d2d2;
  --base13: #cdcdcd;
}
#report.theme-blue {
  --base01: #23418C;
  --base02: #285AC8;
  --base03: rgba(40, 90, 200, 0.8);
  --base04: rgba(40, 90, 200, 0.3);
  --base05: #007FF7;
  --base06: #54A4EF;
  --base07: #6D96EE;
  --base08: #3591E8;
  --base09: #EAF3FF;
  --base10: #9ACEFF;
  --base11: rgb(234 243 255 / 30%);
  --base12: #abd3f8;
  --base13: #9ACEFF;
  /* 12　散布図の中央値の線色 */
  /* 13　棒グラフ */
}
#report.theme-red {
  --base01: #940B0B;
  --base02: #BD2626;
  --base03: rgba(189, 38, 38, 0.8);
  --base04: rgba(189, 38, 38, 0.3);
  --base05: #CB1F1F;
  --base06: #EF5454;
  --base07: #EE6D6D;
  --base08: #D43030;
  --base09: #F9DCDB;
  --base10: #FF9F9A;
  --base11: rgb(234 243 255 / 30%);
  --base12: #abd3f8;
  --base13: #FF9F9A;
}
#report.theme-green {
  --base01: #0A6431;
  --base02: #127C40;
  --base03: rgba(18, 124, 64, 0.8);
  --base04: rgba(18, 124, 64, 0.3);
  --base05: #21A05E;
  --base06: #5FC58B;
  --base07: #5FC58B;
  --base08: #46CB8B;
  --base09: #D1F5E6;
  --base10: #87D2AA;
  --base11: rgb(234 243 255 / 30%);
  --base12: #abd3f8;
  --base13: #87D2AA;
}
#report.theme-yellow {
  --base01: #CEA10B;
  --base02: #DCAC0F;
  --base03: rgba(220, 172, 15, 0.8);
  --base04: rgba(220, 172, 15, 0.3);
  --base05: #D8C718;
  --base06: #F0E355;
  --base07: #E7EA97;
  --base08: #D4C430;
  --base09: #F4F4D1;
  --base10: #CCCC7A;
  --base11: rgb(234 243 255 / 30%);
  --base12: #abd3f8;
  --base13: #CCCC7A;
}
#report.theme-purple {
  --base01: #51096B;
  --base02: #9528C8;
  --base03: rgba(149, 40, 200, 0.8);
  --base04: rgba(149, 40, 200, 0.3);
  --base05: #9113BF;
  --base06: #BB54EF;
  --base07: #CE6DEE;
  --base08: #A935E8;
  --base09: #F9E3FF;
  --base10: #F184DD;
  --base11: rgb(234 243 255 / 30%);
  --base12: #abd3f8;
  --base13: #F184DD;
}

/**
 * Chinsatekun CSS
 */
.report-ui__header,
.report-ui__ttl,
.report-ui__ttl dd {
  align-items: center;
  display: flex;
  line-height: 1;
}

.report-ui__header {
  background-color: #FFF;
  height: 74px;
  justify-content: space-between;
  padding: 18px 24px;
  position: sticky;
  top: 0;
  z-index: 101;
  width: calc(100vw - 214px);
}

.report-ui__ttl {
  gap: 8px;
}
.report-ui__ttl dt {
  background: var(--text-color);
  border-radius: 50px;
  color: #fff;
  font-size: 0.8125rem;
  font-weight: bold;
  padding: 8px 12px;
}
.report-ui__ttl dd {
  gap: 16px;
  font-size: 1.125rem;
}
.report-ui__ttl dd:hover .report-ui__ttl-txt {
  background: #EEEFF1;
}
.report-ui__ttl .report-ui__edit::after {
  content: "";
  height: auto;
  margin-left: 0;
  width: auto;
}

.report-ui__edit {
  align-items: center;
  color: #333;
  cursor: pointer;
  display: inline-block;
}
.report-ui__edit:hover {
  opacity: 0.8;
}
.report-ui__edit::after {
  content: url(../../img/common/ico-pen.svg);
  display: inline-block;
  font-size: 0.75rem;
  height: 12px;
  line-height: 1;
  margin-left: 10px;
  vertical-align: middle;
  width: 11px;
}
.report-ui__edit.-white {
  color: #fff;
}
.report-ui__edit.-white::after {
  content: url(../../img/common/ico-pen-white.svg);
}

[class^=report-editable-]:empty::before {
  color: #A6A6A6;
}

.report-editable-title:empty::before {
  content: "（物件名未設定）";
}

.report-editable-name:empty::before {
  content: "（家主名を追加できます）";
}

.report-editable-company:empty::before {
  content: "（企業名を追加できます）";
}

.report-editable-store:empty::before {
  content: "（店舗名を追加できます）";
}

.report-editable-tanto:empty::before {
  content: "（担当者名を追加できます）";
}

.report-editable-mail:empty::before {
  content: "（メールアドレスを追加できます）";
}

.report-editable-tel:empty::before {
  content: "（電話番号を追加できます）";
}

.report-editable-date:empty::before {
  content: "（日付を追加できます）";
}

.report-editable-mail,
.report-editable-tel {
  display: inline-block;
}

.report-ui__edit-field {
  background: transparent;
  border: 0;
  padding: 0;
  width: fit-content;
}

.report-ui__ttl-txt {
  border-radius: 1px;
  display: inline-block;
  padding: 8px;
  transition: var(--transition);
}

.report-ui__ttl-ico {
  height: 14px;
  width: 15px;
}

.report-ui__body {
  background: #D7D9DB;
  display: grid;
  grid-template-columns: 1fr 298px;
}

.report-ui__setting {
  background: #fff;
  border-radius: 5px;
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.25);
  height: calc(100vh - 84px - 74px);
  margin-top: 36px;
  overflow: auto;
  position: sticky;
  right: 24px;
  top: 36px;
}
.report-ui__setting .tab-ui__body {
  padding: 0 24px 24px;
}
.report-ui__setting li > ul {
  margin-left: 12px;
}

@media print {
  .report-ui__edit::after {
    content: "";
    height: auto;
    margin-left: 0;
    width: auto;
  }
  [class^=report-editable-]:empty::before {
    display: none;
  }
}
.change-cover {
  border-top: 1px solid var(--border-color);
  display: grid;
  gap: 16px;
  margin: 24px 0;
  padding-top: 24px;
}

.change-cover__item {
  border-radius: 5px;
  cursor: pointer;
  display: block;
  outline: 2px solid var(--border-color);
  outline-offset: -2px;
  overflow: hidden;
  position: relative;
  transition: var(--transition);
}
.change-cover__item::after {
  background: #fff;
  border-radius: 50px;
  content: "";
  display: block;
  height: 20px;
  left: 12px;
  outline: 1px solid var(--frame-color);
  outline-offset: -1px;
  position: absolute;
  top: 12px;
  width: 20px;
}
.change-cover__item:hover {
  outline-color: var(--btn-color);
}
.change-cover__item:has(.change-cover__radio:checked) {
  background: #EAF3FF;
  outline-color: var(--btn-color);
}
.change-cover__item:has(.change-cover__radio:checked)::after {
  background: var(--btn-color) url(../../img/common/ico-check.svg) no-repeat center center;
  outline: none;
}

.change-cover__radio {
  display: none;
}

.change-cover__thumbnail {
  height: auto;
  width: 100%;
}

.ctrl {
  background: #fff;
  border-radius: 5px;
  margin: 72px auto;
  max-width: 1360px;
  padding: 36px;
  width: 100%;
}

.ctrl__header {
  margin-bottom: 24px;
}

.ctrl__ttl {
  font-size: 1.25rem;
  margin-bottom: 12px;
}

.ctrl__description {
  margin-bottom: 36px;
}

.ctrl__nav {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr 240px 240px;
  margin-bottom: 16px;
}
.ctrl__nav input, .ctrl__nav select {
  font-size: 0.875rem;
}
.ctrl__nav .enishi-input.-search {
  background-size: 14px;
  padding-left: 34px;
}

.ctrl__account-header {
  display: flex;
  gap: 36px;
  margin-bottom: 36px;
}

.ctrl__account-img {
  border-radius: 10px;
  overflow: hidden;
}

.ctrl__account-info {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  line-height: 1;
  padding: 6px 0;
}

.ctrl__account-company {
  margin-bottom: 8px;
}

.ctrl__account-name {
  align-items: center;
  display: flex;
  font-size: 1.25rem;
  font-weight: bold;
  gap: 12px;
}

.ctrl__account-role {
  background: #EAF3FF;
  border-radius: 5px;
  color: var(--btn-color);
  font-size: 0.75rem;
  font-weight: bold;
  padding: 6px 8px;
}

.ctrl__body {
  background: #EEEFF1;
  border-radius: 5px;
  display: flow-root;
}
.ctrl__body .form-item {
  width: 320px;
}

.ctrl__txt {
  margin: 36px 36px 24px;
}

.ctrl__action {
  display: flex;
  gap: 12px;
  margin: 24px 0;
}

.dept-edit__breadcrumb {
  margin-bottom: 16px;
}
.dept-edit__breadcrumb ul {
  display: flex;
  gap: 12px;
}
.dept-edit__breadcrumb a {
  align-items: center;
  display: flex;
  gap: 12px;
}
.dept-edit__breadcrumb a::after {
  background-image: url(../../img/common/ico-arrow.svg);
  content: "";
  display: block;
  height: 14px;
  width: 14px;
  scale: 0.857;
}
.dept-edit__breadcrumb a:hover .dept-edit__breadcrumb-ico, .dept-edit__breadcrumb a:hover::after {
  opacity: 0.8;
  transition: var(--transition);
}

.dept-edit__breadcrumb-ico {
  margin-right: -4px;
}

.dept-edit__list dt {
  background: #EEEFF1;
  padding: 12px 24px;
}

a.dept-edit__dept {
  border-bottom: 1px solid #D7D9DB;
  color: #000;
  display: block;
  padding: 12px 24px;
}
a.dept-edit__dept:hover {
  background: #EAF3FF;
}

.dept-edit__input {
  background: #EAF3FF;
  border-bottom: 1px solid #D7D9DB;
  display: flex;
  justify-content: space-between;
  margin-bottom: 16px;
  padding: 12px 24px;
}
.dept-edit__input input {
  width: 280px;
}

.dept-edit__action {
  display: flex;
  gap: 6px;
}

.other-setting__wrapper {
  margin-top: 24px;
  width: 100%;
}

/**
 * Chinsatekun CSS
 */
.btn,
a.btn {
  appearance: none;
  align-items: center;
  background: var(--btn-color);
  border: none;
  border-radius: 5px;
  color: #fff;
  display: flex;
  font-size: 0.875rem;
  font-weight: bold;
  gap: 6px;
  line-height: 1;
  padding: 10px 16px;
  text-align: left;
  text-decoration: none;
  transition: var(--transition);
  width: fit-content;
}
.btn:hover,
a.btn:hover {
  background: #23418C;
}
.btn.-large,
a.btn.-large {
  font-size: 1.125rem;
  padding: 15px 50px;
}
.btn.-wide,
a.btn.-wide {
  justify-content: center;
  width: 100%;
}
.btn.-black,
a.btn.-black {
  background: var(--text-color);
}
.btn.-black:hover,
a.btn.-black:hover {
  background: rgb(var(--text-color-rgb)/0.8);
}
.btn.-framed,
a.btn.-framed {
  background: #fff;
  outline: 1px solid var(--frame-color);
  outline-offset: -1px;
  color: var(--text-color);
}
.btn.-framed .btn__ico,
a.btn.-framed .btn__ico {
  fill: var(--text-color);
}
.btn.-framed:hover,
a.btn.-framed:hover {
  color: var(--btn-color);
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
}
.btn.-framed:hover .btn__ico,
a.btn.-framed:hover .btn__ico {
  fill: var(--btn-color);
}
.btn.-no-frame,
a.btn.-no-frame {
  background: transparent;
  color: var(--text-color);
  outline-color: transparent;
}
.btn.-no-frame .btn__ico,
a.btn.-no-frame .btn__ico {
  fill: var(--text-color);
}
.btn.-no-frame:hover,
a.btn.-no-frame:hover {
  background: var(--btn-color);
  color: #fff;
}
.btn.-no-frame:hover .btn__ico,
a.btn.-no-frame:hover .btn__ico {
  fill: #fff;
}
.btn:disabled,
a.btn:disabled {
  background: var(--frame-color);
  color: #fff;
  pointer-events: none;
}
.btn:disabled .btn__ico,
a.btn:disabled .btn__ico {
  fill: #fff;
}

.btn__ico {
  fill: #fff;
  height: 14px;
  width: 14px;
}
.btn__ico.-flip {
  rotate: 180deg;
}
.btn__ico.-right {
  margin-left: auto;
}

/**
 * Chinsatekun CSS
 */
.dialog {
  border: 0;
  color: var(--text-color);
  max-height: none;
  max-width: none;
  position: fixed;
  background: rgba(5, 16, 28, 0.5);
  height: 100vh;
  width: 100vw;
}
.dialog.-setting .dialog__body {
  text-align: left;
  max-height: 90vh;
  min-width: 640px;
  max-width: 808px;
}
.dialog.-setting .dialog__ttl {
  border-bottom: 1px solid var(--border-color);
  height: 68px;
  margin: 0;
  padding: 24px;
}
.dialog.-setting .dialog__action {
  align-items: center;
  border-top: 1px solid var(--border-color);
  height: 82px;
  margin: 0;
  padding: 0 24px;
}
.dialog.-setting .dialog__action li {
  flex: 0 0 auto;
}

.dialog__body {
  background: #fff;
  border-radius: 10px;
  box-shadow: 2px 2px 8px rgb(var(--text-color-rgb)/0.25);
  height: fit-content;
  inset: 0;
  margin: auto;
  min-width: 440px;
  position: fixed;
  text-align: center;
  width: fit-content;
}

.dialog__ttl {
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1;
  margin: 36px;
}

.dialog__subttl {
  font-size: 0.75rem;
  font-weight: bold;
  line-height: 1;
  margin: 24px 24px 12px;
  padding: 10px 12px;
}

.dialog__msg {
  line-height: 1.4;
  margin: 36px;
}

.dialog__price {
  align-items: center;
  color: var(--enishi-red);
  display: flex;
  font-size: 0.75rem;
  gap: 12px;
  justify-content: center;
  line-height: 1;
}
.dialog__price dt {
  background: var(--enishi-red);
  border-radius: 3px;
  color: #fff;
  font-weight: bold;
  padding: 8px 12px;
}

.dialog__price-num {
  font-size: 1.5rem;
  font-weight: bold;
  margin-right: 3px;
}

.dialog__wrapper {
  max-height: calc(90vh - 68px - 82px);
  overflow-x: hidden;
  overflow-y: auto;
}

.dialog__action {
  display: flex;
  gap: 12px;
  margin: 36px;
}
.dialog__action li {
  flex: 1 1 0;
}
.dialog__action.-filter-result {
  background: #EAF3FF;
  border-radius: 0 0 10px 10px;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
}

.dialog__action__result {
  margin-right: 12px;
}

.dialog__action__result-value {
  font-size: 2.5rem;
  font-weight: bold;
}

.dialog__btn {
  appearance: none;
  background: transparent;
  border: 0;
  transition: all 0.1s ease-out;
}
.dialog__btn:hover {
  opacity: 0.8;
}

.dialog__add-dept {
  border: 1px solid var(--border-color);
  border-width: 1px 0;
}
.dialog__add-dept .form-item {
  align-items: center;
  display: flex;
  gap: 24px;
}
.dialog__add-dept .form-item__ttl {
  margin-bottom: 0;
  white-space: nowrap;
}

.dialog,
.dialog__body {
  animation: fadeIn 0.1s ease-in-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/**
 * Chinsatekun CSS
 */
.details {
  position: relative;
}

.details[open] .details__summary {
  background: #23418C;
  color: #fff;
}
.details[open] .details__toggle-ico {
  fill: #fff;
  rotate: -90deg;
}

.details__summary,
.details__toggle {
  align-items: center;
  transition: var(--transition);
  display: flex;
}

.details__summary {
  background: #fff;
  cursor: pointer;
  font-weight: bold;
  justify-content: space-between;
  line-height: 1;
  padding: 16px 24px;
}
.details__summary::-webkit-details-marker {
  display: none;
}

.details__ttl {
  font-size: 1rem;
}

.details__summary-info {
  align-items: center;
  display: flex;
  gap: 36px;
}

.details__toggle {
  height: 14px;
  justify-content: center;
  width: 14px;
}

.details__toggle-ico {
  fill: #424242;
  height: 14px;
  rotate: 90deg;
  transition: all 0.2s ease-out;
  width: 14px;
}

.details__body {
  background: #fff;
  padding: 24px;
}

.details__body-header {
  align-items: center;
  display: flex; /*査定ページ 散布図100%表示のためコメントアウト 設備補正用に 戻す　コメントアウトなし*/
  justify-content: space-between; /*査定ページ 散布図100%表示のためコメントアウト　設備補正用に 戻す　コメントアウトなし*/
  margin-bottom: 24px;
}

.details__body-ttl {
  font-size: 0.875rem;
  line-height: 1;
  margin-bottom: 12px;
}

.details__body-explain {
  color: var(--subtext-color);
  font-size: 0.75rem;
  margin-bottom: 18px;
}

.details__body-nav {
  display: flex;
  gap: 8px;
}

/**
 * Chinsatekun CSS
 */
.download-list {
  margin: 24px;
}

.download-list__item {
  border-radius: 5px;
  display: flex;
  justify-content: space-between;
  padding: 10px;
  transition: var(--transition);
}
.download-list__item:not(:last-of-type) {
  margin-bottom: 6px;
}
.download-list__item:hover {
  background: #EAF3FF;
}

.download-list__filetype {
  background: var(--frame-color);
  border-radius: 3px;
  color: #fff;
  display: inline-block;
  font-size: 0.8125rem;
  font-weight: bold;
  line-height: 1;
  padding: 9px;
  text-align: center;
}
.download-list__filetype.-excel {
  background: #0F7C41;
}
.download-list__filetype.-pdf {
  background: #E01728;
}

.drilldown {
  height: 480px;
  margin: 24px 0 24px 24px;
  overflow-x: hidden;
  overflow-y: auto;
  position: relative;
  width: 592px;
}

.drilldown__wrapper {
  display: flex;
  left: 0;
  overflow-x: hidden;
  position: absolute;
  top: 0;
  transition: all 0.3s ease-out;
}

.drilldown__lv {
  display: block;
  flex-shrink: 0;
  width: 592px;
}
.drilldown__lv .dialog__subttl {
  margin: 0 0 12px;
}
.drilldown__lv:last-of-type .drilldown__item:hover::after {
  display: none;
}

.drilldown__item {
  appearance: none;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--border-color);
  cursor: pointer;
  display: block;
  line-height: 1;
  padding: 12px;
  position: relative;
  text-align: left;
  transition: var(--transition);
  width: 100%;
}
.drilldown__item:hover {
  background: #EAF3FF;
}
.drilldown__item:hover::after {
  background-image: url(../../img/common/ico-arrow.svg);
  content: "";
  display: block;
  height: 14px;
  position: absolute;
  right: 20px;
  top: 13px;
  width: 14px;
}

.drilldown__back {
  margin-bottom: 12px;
  padding: 10px;
}

.dropmenu {
  background: transparent;
  border-radius: 5px;
  cursor: pointer;
  display: block;
  position: relative;
  transition: var(--transition);
}
.dropmenu:hover {
  background: #E8F0FF;
}
.dropmenu:hover .dropmenu__ico {
  fill: var(--link-color);
}
.dropmenu:hover .dropmenu__submenu {
  display: grid;
  opacity: 1;
  scale: 1;
}
.dropmenu.-right .dropmenu__submenu {
  left: auto;
  right: 0;
}

.dropmenu__ico {
  fill: #000;
  height: 4px;
  transition: var(--transition);
  width: 16px;
}

.dropmenu__submenu {
  background: #fff;
  border-radius: 5px;
  box-shadow: 2px 2px 8px rgb(var(--text-color-rgb)/0.25);
  display: none;
  gap: 4px;
  left: 0;
  opacity: 0;
  padding: 8px;
  position: absolute;
  top: 40px;
  transform-origin: 0 0;
  transition: all 0.1s ease-out;
  scale: 0;
  z-index: 200;
}

.dropmenu__submenu-ico {
  fill: #000;
  height: 14px;
  transition: var(--transition);
  width: 14px;
}

a.dropmenu__submenu-link {
  border-radius: 3px;
  color: var(--text-color);
  display: flex;
  gap: 6px;
  line-height: 1;
  opacity: 1;
  padding: 8px;
  white-space: nowrap;
}
a.dropmenu__submenu-link:hover {
  background: #E8F0FF;
  color: var(--link-color);
  font-weight: bold;
  text-decoration: none;
}
a.dropmenu__submenu-link:hover .dropmenu__submenu-ico {
  fill: var(--link-color);
}

/**
 * Chinsatekun CSS
 */
.enishi-checkbox {
  align-items: center;
  background: #fff;
  border-radius: 5px;
  cursor: pointer;
  display: flex;
  font-size: 1rem;
  gap: 6px;
  line-height: 1;
  outline: 1px solid #B7BCC1;
  outline-offset: -1px;
  padding: 10px;
  transition: var(--transition);
  width: fit-content;
}
.enishi-checkbox::before {
  background: #fff;
  content: "";
  display: block;
  height: 18px;
  outline: 1px solid #B7BCC1;
  outline-offset: -1px;
  width: 18px;
}
.enishi-checkbox:hover {
  background: #EAF3FF;
}
.enishi-checkbox:has(input:checked) {
  background: #EAF3FF;
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
}
.enishi-checkbox:has(input:checked)::before {
  background: var(--btn-color) url(../../img/common/ico-check.svg) no-repeat center center;
  outline: none;
}
.enishi-checkbox input {
  display: none;
}
.enishi-checkbox.-list {
  background: transparent;
  font-size: 0.875rem;
  outline: none;
  padding: 9px 12px;
  width: 100%;
}
.enishi-checkbox.-list::before {
  background: #fff;
  scale: 0.9;
}
.enishi-checkbox.-list:has(input:checked) {
  background: transparent;
  outline: none;
}
.enishi-checkbox.-list:hover {
  background: #EAF3FF;
}
.enishi-checkbox::before {
  border-radius: 2px;
}
.enishi-checkbox.-no-frame {
  background: transparent;
  outline: none;
  padding: 0;
}
.enishi-checkbox.-no-frame::before {
  background: #B7BCC1;
  outline: none;
}

.enishi-input {
  border: none;
  border-radius: 3px;
  display: inline-block;
  line-height: 1;
  max-width: 480px;
  min-height: 36px;
  outline: 1px solid var(--frame-color);
  padding: 10px 16px 10px 10px;
  width: 100%;
}
.enishi-input::placeholder {
  color: var(--subtext-color);
}
.enishi-input:focus {
  box-shadow: 1px 1px 5px rgb(var(--btn-color-rgb)/0.25);
  outline: 2px solid var(--btn-color);
}
.enishi-input ::-ms-reveal {
  display: none;
}
.enishi-input.-error {
  outline: 2px solid #E01728;
}
.enishi-input.-disabled {
  background: transparent;
  outline: none;
}
.enishi-input.-mail {
  padding: 12px;
}
.enishi-input.-pass {
  padding: 12px;
}
.enishi-input.-search {
  background: #fff url(../../img/common/ico-search.svg) no-repeat 12px 50%;
  padding-left: 44px;
}

/**
 * Chinsatekun CSS
 */
.enishi-radio {
  align-items: center;
  background: #fff;
  border-radius: 5px;
  cursor: pointer;
  display: flex;
  font-size: 1rem;
  gap: 6px;
  line-height: 1;
  outline: 1px solid #B7BCC1;
  outline-offset: -1px;
  padding: 10px;
  transition: var(--transition);
  width: fit-content;
}
.enishi-radio::before {
  background: #fff;
  content: "";
  display: block;
  height: 18px;
  outline: 1px solid #B7BCC1;
  outline-offset: -1px;
  width: 18px;
}
.enishi-radio:hover {
  background: #EAF3FF;
}
.enishi-radio:has(input:checked) {
  background: #EAF3FF;
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
}
.enishi-radio:has(input:checked)::before {
  background: var(--btn-color) url(../../img/common/ico-check.svg) no-repeat center center;
  outline: none;
}
.enishi-radio input {
  display: none;
}
.enishi-radio.-list {
  background: transparent;
  font-size: 0.875rem;
  outline: none;
  padding: 9px 12px;
  width: 100%;
}
.enishi-radio.-list::before {
  background: #fff;
  scale: 0.9;
}
.enishi-radio.-list:has(input:checked) {
  background: transparent;
  outline: none;
}
.enishi-radio.-list:hover {
  background: #EAF3FF;
}
.enishi-radio::before {
  border-radius: 50px;
}
.enishi-radio.-no-frame {
  background: transparent;
  outline: none;
  padding: 0;
}
.enishi-radio.-no-frame:has(input:checked) {
  background: transparent;
  outline: none;
}

/**
 * Chinsatekun CSS
 */
.form-details {
  border-radius: 5px;
  box-shadow: 4px 4px 20px rgba(var(--btn-color-rgb)/10%);
  display: flow-root;
  margin-bottom: 24px;
  transition: var(--transition);
}
.form-details[open] {
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
  margin-bottom: 60px;
}
.form-details[open] .form-details__ttl:hover {
  outline: none;
}
.form-details[open] .form-details__ttl + .form-item {
  margin-top: 0;
}
.form-details[open] .form-details__ttl-ico {
  rotate: -90deg;
}

.form-details__ttl {
  align-items: center;
  cursor: pointer;
  display: flex;
  font-size: 1rem;
  font-weight: bold;
  gap: 8px;
  min-height: 68px;
  justify-content: space-between;
  line-height: 1;
  padding: 30px 24px;
  transition: var(--transition);
}
.form-details__ttl::-webkit-details-marker {
  display: none;
}
.form-details__ttl:hover {
  background: #EAF3FF;
  border-radius: 5px;
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
}

.form-details__summary {
  align-items: center;
  display: flex;
  gap: 16px;
}
.form-details__summary small {
  background: var(--btn-color);
  border-radius: 3px;
  color: #fff;
  font-size: 0.75rem;
  font-weight: bold;
  line-height: 1;
  padding: 8px 12px;
}

.form-details__result {
  align-items: center;
  display: flex;
  gap: 16px;
}

.form-details__result-num {
  align-items: baseline;
  display: grid;
  gap: 2px;
  grid-template-columns: 1fr 20px;
  font-weight: normal;
  line-height: 1;
  text-align: right;
}
.form-details__result-num strong {
  font-size: 1.75rem;
}
.form-details__result-num small {
  color: var(--subtext-color);
  font-size: 0.75rem;
}

.form-details__ttl-ico {
  rotate: 90deg;
  transition: var(--transition);
}

.form-details__action {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin: 24px;
}
.form-details__action small {
  color: var(--subtext-color);
  font-size: 0.75rem;
}

/**
 * Chinsatekun CSS
 */
.form-item {
  margin: 24px;
}
.form-item.-ctrl {
  align-items: baseline;
  display: grid;
  gap: 8px;
  grid-template-columns: 12em 320px 1fr;
  white-space: nowrap;
  width: 80%;
}
.form-item.-ctrl .form-item__ttl {
  justify-content: flex-end;
  margin-bottom: 0;
  padding-right: 16px;
}
.form-item.-state-ctrl {
  border-top: 1px solid var(--border-color);
  grid-template-columns: 12em 1fr;
  padding-top: 24px;
  width: -webkit-fill-available;
  width: -moz-available;
  width: stretch;
}
.form-item.-table {
  align-items: center;
  border-top: 1px solid var(--border-color);
  display: grid;
  grid-template-columns: 150px 1fr;
  margin: 0 24px;
}
.form-item.-table:first-of-type {
  margin-top: 24px;
}
.dialog__subttl + .form-item.-table:first-of-type {
  margin-top: 12px;
}
.form-item.-table:last-of-type {
  border-bottom: 1px solid var(--border-color);
  margin-bottom: 24px;
}
.form-item.-table .form-item__ttl {
  background: #F3F5F7;
  font-weight: normal;
  height: 100%;
  margin-bottom: 0;
  padding: 16px;
}
.form-item.-table .form-item__body {
  margin: 13px 12px;
}
.form-item.-column {
  align-items: baseline;
  display: grid;
  grid-template-columns: 1fr 3fr;
  margin: 16px 36px;
}
.form-item.-column:first-of-type {
  margin-top: 24px;
}
.form-item.-column:last-of-type {
  margin-bottom: 24px;
}
.form-item.-column .form-item__ttl {
  margin-bottom: 0;
}

.form-item__ttl {
  align-items: center;
  color: #000;
  display: flex;
  gap: 10px;
  font-weight: bold;
  line-height: 1;
  margin-bottom: 10px;
}

.form-item__column {
  align-items: center;
  display: flex;
  gap: 10px;
}

.form-item__column-item {
  flex: 1;
}

.form-item__field.-error + .form-item__alert {
  display: flex;
}

.form-item__note,
.form-item__alert {
  align-items: center;
  font-size: 1rem;
  gap: 6px;
  line-height: 1;
  margin-top: 10px;
}

.form-item__alert {
  display: none;
}

.form-item__required,
.form-item__optional {
  border-radius: 3px;
  color: #fff;
  display: inline-block;
  font-size: 0.75rem;
  font-weight: bold;
  padding: 4px 6px;
}

.form-item__required {
  background: var(--btn-color);
}

.form-item__optional {
  background: #B7BCC1;
}

.form-item__file {
  border: none;
  border-radius: 0;
  color: transparent;
  font-size: 0.75rem;
  padding: 0;
}
.form-item__file::file-selector-button {
  appearance: none;
  background: #fff;
  border: none;
  border-radius: 5px;
  color: var(--text-color);
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: bold;
  line-height: 1;
  margin-right: 10px;
  outline: 1px solid var(--frame-color);
  outline-offset: -1px;
  padding: 12px 18px;
  transition: var(--transition);
}
.form-item__file::file-selector-button:hover {
  background: #EAF3FF;
  color: var(--btn-color);
  outline: 2px solid var(--btn-color);
  outline-offset: -2px;
}

.form-item__file-preview {
  align-items: center;
  border: 1px solid var(--border-color);
  border-radius: 5px;
  display: flex;
  justify-content: center;
  padding: 20px;
  position: relative;
  margin-top: 10px;
  min-height: 160px;
}
.form-item__file-preview img {
  height: auto;
  max-width: 400px;
}
.form-item__file-preview:not(:has(img[src])) {
  display: none;
}
.form-item__file-preview:not(:has(img[src])) .form-item__file-clear {
  display: none;
}

.form-item__file-clear {
  appearance: none;
  background: transparent;
  border: none;
  cursor: pointer;
  position: absolute;
  right: 10px;
  top: 10px;
}
.form-item__file-clear:hover {
  opacity: 0.8;
}

.form-item__ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.form-item__ul.-even-4, .form-item__ul.-even-5, .form-item__ul.-even-7 {
  display: grid;
}
.form-item__ul.-even-4 label, .form-item__ul.-even-5 label, .form-item__ul.-even-7 label {
  white-space: nowrap;
  width: 100%;
}
.form-item__ul.-even-4 {
  grid-template-columns: repeat(4, 1fr);
}
.form-item__ul.-even-5 {
  grid-template-columns: repeat(5, 1fr);
}
.form-item__ul.-even-7 {
  grid-template-columns: repeat(7, 1fr);
}
.form-item__ul.-row {
  flex-direction: column;
  gap: 0;
}
.form-item__ul.-row li {
  margin-bottom: 0;
}
.form-item__ul.-row label {
  outline: none;
  padding: 10px;
}
.form-item__ul.-row label:has(input:checked) {
  background: transparent;
}
.form-item__ul.-no-frame {
  gap: 4px;
}
.form-item__ul.-no-frame .enishi-checkbox {
  font-size: 0.875rem;
  outline: none;
}
.form-item__ul.-no-frame .enishi-checkbox:has(input:checked) {
  background: transparent;
}
.form-item__ul.-no-frame .enishi-checkbox:has(input:checked):hover {
  background: #EAF3FF;
}

.form-item__state-ctrl {
  background: #fff;
  border: 1px solid var(--frame-color);
  border-radius: 5px;
  padding: 12px;
  width: 100%;
}
.form-item__state-ctrl li {
  align-items: center;
  display: flex;
  justify-content: space-between;
  line-height: 1;
  padding: 19px 16px;
}
.form-item__state-ctrl li:not(:last-of-type) {
  border-bottom: 1px solid var(--border-color);
}

.form-item__with-unit {
  max-width: 480px;
  position: relative;
}

.form-item__unit {
  font-size: 0.875rem;
  line-height: 1;
  position: absolute;
  right: 12px;
  top: calc(50% - 8px);
}

[class^=form-item__].-short {
  min-width: 540px;
  width: 40%;
}

.ico.-circle-check {
  fill: var(--btn-color);
  height: 16px;
  width: 16px;
  scale: 0.875;
}

/**
 * Chinsatekun CSS
 */
.pagenation {
  align-items: center;
  display: flex;
  gap: 16px;
  justify-content: flex-end;
  margin-right: 36px;
}

.pagenation__nav {
  align-items: center;
  display: flex;
  gap: 4px;
}

a.pagenation__link {
  display: block;
  line-height: 1;
  padding: 6px;
}
a.pagenation__link.-prev img {
  rotate: 180deg;
}
a.pagenation__link:hover {
  opacity: 0.8;
}

/**
 * Chinsatekun CSS
 */
.select {
  display: inline-block;
  max-width: 480px;
  position: relative;
  width: 100%;
}
.select.-fit-content {
  width: fit-content;
}

.select:after {
  background: #fff url('data:image/svg+xml,<svg width="12" height="9" viewBox="0 0 12 9" fill="%23242424" xmlns="http://www.w3.org/2000/svg"><path d="M11.3996 0.428573L0.599333 0.428573C0.489985 0.4289 0.3828 0.457673 0.289318 0.511794C0.195835 0.565915 0.119595 0.643335 0.0688009 0.735723C0.0180063 0.828109 -0.00541687 0.931962 0.00105381 1.0361C0.00752354 1.14024 0.0436411 1.24073 0.105519 1.32675L5.50567 8.76859C5.72948 9.07714 6.26829 9.07714 6.4927 8.76859L11.8929 1.32675C11.9554 1.24091 11.992 1.14037 11.9988 1.03606C12.0057 0.931744 11.9824 0.82764 11.9315 0.735059C11.8807 0.642477 11.8042 0.564957 11.7105 0.510923C11.6167 0.45689 11.5092 0.428409 11.3996 0.428573Z"/></svg>') no-repeat center center;
  border-radius: 0 5px 5px 0;
  content: "";
  height: 36px;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 0;
  width: 36px;
}

.select__item {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #fff;
  border: 0;
  border-radius: 5px;
  font-size: 0.875rem;
  height: 36px;
  outline: 1px solid var(--frame-color);
  padding: 10px 44px 10px 10px;
  position: relative;
  width: 100%;
}
.select__item:has(option:checked[value=""]) {
  color: var(--subtext-color);
}
.select__item.-user {
  background: #fff url(../../img/common/ico-user.svg) no-repeat 12px 50%;
  padding-left: 34px;
}

/**
 * Chinsatekun CSS
 */
.table {
  margin-bottom: 16px;
  overflow: auto;
  width: 100%;
}
.table.-history {
  font-size: 0.8125rem;
  padding: 0 36px;
}
.table.-history th, .table.-history td {
  padding: 8px 10px;
}

.table__body {
  line-height: 1;
  width: 100%;
}
.table__body thead th {
  background: #EEEFF1;
  padding: 12px;
  white-space: nowrap;
}
.table__body thead.history-thead th {
  font-size: 0.75rem;
  background: #23418C;
  color: #FFF;
}
.table__body th, .table__body td {
  padding: 20px 12px;
}
.table__body th:not(.table__id), .table__body td:not(.table__id) {
  text-align: left;
}
.table__body th:not(:last-of-type), .table__body td:not(:last-of-type) {
  border-right: 1px solid #fff;
}
.table__body tbody td {
  border-bottom: 1px solid #D7D9DB;
}
.table__body tbody tr:hover {
  background: #EAF3FF;
}
.table__body tbody tr:hover th:not(:last-of-type), .table__body tbody tr:hover td:not(:last-of-type) {
  border-right: 1px solid #EAF3FF;
}
.table__body.-fixed {
  table-layout: fixed;
}
.table__body.-dept th, .table__body.-dept td {
  padding: 12px 24px;
}
.table__body.-facility-adjustment td {
  padding: 12px;
}

.table__id {
  text-align: center;
}

a.table__user {
  color: #000;
  display: flex;
  justify-content: space-between;
}
a.table__user:hover {
  color: var(--link-color);
  text-decoration: underline;
}
a.table__user svg {
  fill: var(--link-color);
  height: 16px;
  margin-top: -1px;
  scale: 0.75;
  width: 16px;
}

.table__dept {
  max-width: 100px;
  min-width: 100px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  width: 100px;
}

.history__ttl {
  align-items: center;
  display: flex;
  gap: 12px;
}
.history__ttl dt {
  font-size: 0.8125rem;
  margin-bottom: 4px;
}
.history__ttl dd {
  font-size: 0.75rem;
  color: #747D88;
}

.history-action__wrapper {
  display: grid;
  gap: 6px;
  grid-template-columns: 1fr 1fr 1fr;
  margin: 8px 16px 8px 10px;
}

/**
 * Chinsatekun CSS
 */
.toggle-btn {
  cursor: pointer;
  display: inline-block;
  font-size: 0.875rem;
  position: relative;
  width: fit-content;
}
.toggle-btn input {
  display: none;
}
.toggle-btn::before, .toggle-btn::after {
  border-radius: 50px;
  display: block;
  transition: all 0.2s ease-out;
}
.toggle-btn::before {
  background: #B7B9BB;
  color: #fff;
  content: "OFF";
  font-size: 0.75rem;
  font-weight: bold;
  height: 22px;
  line-height: 1;
  padding: 5px 8px 5px 25px;
  width: 60px;
  z-index: 1;
}
.toggle-btn::after {
  content: url(../../img/common/ico-toggle-off.svg);
  height: 16px;
  left: 4px;
  position: absolute;
  top: 3px;
  width: 16px;
  z-index: 2;
}
.toggle-btn:has(input:checked)::before {
  background: var(--link-color);
  content: "ON";
  padding-left: 14px;
}
.toggle-btn:has(input:checked)::after {
  content: url(../../img/common/ico-toggle-on.svg);
  left: 40px;
}
.toggle-btn.-no-label::before {
  content: "";
}
.toggle-btn.-no-label:has(input:checked)::before {
  content: "";
}

/**
 * Chinsatekun CSS
 */
/**
 * パスワード欄を表示／非表示切り替えさせる
 */
.toggle-pass {
  position: relative;
}
.toggle-pass label {
  font-size: 0.8125rem;
  display: block;
  font-weight: 800;
  margin-bottom: 10px;
}

.toggle-pass__btn {
  appearance: none;
  background: transparent;
  border: 0;
  border-radius: 3px;
  height: calc(100% - 4px);
  opacity: 0.8;
  padding: 0 12px;
  position: absolute;
  right: 2px;
  top: 2px;
  transition: var(--transition);
}
.toggle-pass__btn span {
  display: none;
}
.toggle-pass__btn::after {
  content: url(../../img/common/ico-hidden.svg);
  display: block;
}
.toggle-pass__btn.-display::after {
  content: url(../../img/common/ico-display.svg);
}
.toggle-pass__btn:hover {
  opacity: 1;
}

/**
 * Chinsatekun CSS
 */
small {
  font-size: 0.75rem;
}

.circled-txt {
  background: #EAF3FF;
  border-radius: 50px;
  color: var(--btn-color);
  display: inline-block;
  line-height: 1;
  padding: 4px 9px;
}
.circled-txt.-gray {
  background: #EAEDF2;
  color: var(--text-color);
}

.error-msg {
  align-items: center;
  background: #FFE9EB;
  border: 2px solid var(--enishi-red);
  border-radius: 5px;
  color: #000;
  display: flex;
  gap: 6px;
  line-height: 1;
  margin-bottom: 36px;
  padding: 16px 20px;
}

.Loader {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 1000000000;
}
.Loader.-active {
  display: block;
}

.Loader__bg {
  background-color: rgba(5, 16, 28, 0.5);
  height: 100vh;
  position: absolute;
  width: 100%;
}

.Loader__content {
  font-size: 1.5rem;
  align-items: center;
  color: #FFF;
  display: flex;
  flex-direction: column-reverse;
  gap: 20px;
  justify-content: center;
  left: calc(50% - 200px);
  position: absolute;
  text-align: center;
  top: 40%;
}
.Loader__content img {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
