@charset "UTF-8";
/* CSS Document */
/* -------------------------------
	default
-------------------------------- */
:root {
  --app-h: 100vh;
  --app-w: 100vw;
  --anchor-offset: 50px;
}

@supports (height: 100dvh) {
  :root {
    --app-h: 100dvh;
    --app-w: 100dvw;
  }
}
@media print, screen and (min-width: 992px) {
  :root {
    --anchor-offset: 100px;
  }
}
html {
  font-size: 16px;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.06em;
}

.fs-en, .telphone {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.fs-orbitron {
  font-family: "Orbitron", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

/* -------------------------------
	見出しタグ調整
-------------------------------- */
h1 {
  font-size: 1.9rem;
  /* 30px相当 */
}

h2 {
  font-size: 1.69rem;
  /* 27px相当 */
}

h3 {
  font-size: 1.5rem;
  /* 24px相当 */
}

h4 {
  font-size: 1.33rem;
  /* 21px相当 */
}

h5 {
  font-size: 1.19rem;
  /* 19px相当 */
}

h6 {
  font-size: 1.05rem;
  /* 17px相当 */
}

@media screen and (min-width: 768px) {
  h1 {
    font-size: 2.21rem;
    /* 35px相当 */
  }

  h2 {
    font-size: 1.97rem;
    /* 32px相当 */
  }

  h3 {
    font-size: 1.75rem;
    /* 28px相当 */
  }

  h4 {
    font-size: 1.56rem;
    /* 25px相当 */
  }

  h5 {
    font-size: 1.38rem;
    /* 22px相当 */
  }

  h6 {
    font-size: 1.23rem;
    /* 20px相当 */
  }
}
@media screen and (min-width: 992px) {
  h1 {
    font-size: 2.37rem;
    /* 38px相当 */
  }

  h2 {
    font-size: 2.11rem;
    /* 34px相当 */
  }

  h3 {
    font-size: 1.88rem;
    /* 30px相当 */
  }

  h4 {
    font-size: 1.67rem;
    /* 27px相当 */
  }

  h5 {
    font-size: 1.48rem;
    /* 24px相当 */
  }

  h6 {
    font-size: 1.32rem;
    /* 21px相当 */
  }
}
@media screen and (min-width: 1200px) {
  h1 {
    font-size: 2.53rem;
    /* 40px相当 */
  }

  h2 {
    font-size: 2.25rem;
    /* 36px相当 */
  }

  h3 {
    font-size: 2rem;
    /* 32px相当 */
  }

  h4 {
    font-size: 1.78rem;
    /* 28px相当 */
  }

  h5 {
    font-size: 1.58rem;
    /* 25px相当 */
  }

  h6 {
    font-size: 1.4rem;
    /* 22px相当 */
  }
}
h2, h3, h4, h5, h6 {
  margin-top: 0;
  margin-bottom: 1.5rem;
}

p, ol, ul, dl, table {
  margin-bottom: 1rem;
}
p + h3, p + h4, p + h5, p + h6, ol + h3, ol + h4, ol + h5, ol + h6, ul + h3, ul + h4, ul + h5, ul + h6, dl + h3, dl + h4, dl + h5, dl + h6, table + h3, table + h4, table + h5, table + h6 {
  margin-top: 2rem;
}
p:last-child, ol:last-child, ul:last-child, dl:last-child, table:last-child {
  margin-bottom: 0;
}

img {
  max-width: 100%;
  vertical-align: middle;
}

ul {
  padding-left: 1.5em;
}

ol {
  padding-left: 2em;
}

a {
  text-decoration: underline;
}
a:hover {
  text-decoration: none;
}

/* -------------------------------
	header
-------------------------------- */
#header {
  --h1: min(calc(14px + 4 * (100vw - 375px) / 1125), 18px);
  padding: 10px 0;
  overflow: hidden;
  background-color: #fff;
}
@media print, screen and (min-width: 992px) {
  #header .container-fluid {
    padding-left: 30px;
    padding-right: 30px;
  }
}
#header h1 {
  color: #222;
  font-weight: 100;
  font-size: var(--h1);
  letter-spacing: 0.1em;
  line-height: 1.5;
  text-align: center;
  margin: 0;
}
#header h1 > a {
  text-decoration: none;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
#header h1 .txt {
  display: block;
  padding-bottom: 1em;
  padding-left: 1em;
}
#header h1 img {
  width: min(4.11112em, 74px);
}
#header ul {
  font-weight: 100;
  font-size: 14px;
  letter-spacing: normal;
  line-height: 1.5;
  list-style: none;
  text-align: center;
  padding: 0;
  margin: 0;
}
@media print, screen and (min-width: 768px) {
  #header ul {
    display: flex;
    align-items: center;
    gap: 0 1em;
    margin-bottom: var(--h1);
  }
}

/* -------------------------------
	footer
-------------------------------- */
#footer {
  padding: 30px 0;
  background-color: #efefef;
}
@media print, screen and (min-width: 992px) {
  #footer .container-fluid {
    padding-left: 30px;
    padding-right: 30px;
  }
}
#footer h2 {
  color: #222;
  font-weight: 100;
  font-size: min(calc(14px + 4 * (100vw - 375px) / 1125), 18px);
  letter-spacing: 0.1em;
  text-align: center;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
#footer h2 img {
  width: min(4.11112em, 74px);
}
#footer h2 > .txt {
  display: block;
  padding-bottom: 1em;
  padding-left: 1em;
}
#footer ul {
  font-weight: 100;
  font-size: 14px;
  letter-spacing: normal;
  list-style: none;
  text-align: center;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5em 1em;
  white-space: nowrap;
}
#footer .copyright {
  font-weight: 100;
  font-size: 13px;
  text-align: center;
  margin-top: 2em;
}

/* -------------------------------
	common
-------------------------------- */
/* --▼color-- */
/* --▼text-- */
/* --▼font -- */
.fs-xxs {
  font-size: 0.75em !important;
}

.fs-sm {
  font-size: 0.875em !important;
}

.fs-md {
  font-size: 1.125em !important;
}

.fs-lg {
  font-size: 1.250em !important;
}

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

.fw4 {
  font-weight: 400 !important;
}

.fw5 {
  font-weight: 500 !important;
}

.fw7 {
  font-weight: 700 !important;
}

.fwn {
  font-weight: 400 !important;
}

.fwb {
  font-weight: 700 !important;
}

/* --▼margin-- */
/* space */
.mt-50 {
  margin-top: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
}

.mb-50 {
  margin-bottom: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
}

.mtb-50 {
  margin-top: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
  margin-bottom: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
}

.mt-60 {
  margin-top: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
}

.mb-60 {
  margin-bottom: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
}

.mtb-60 {
  margin-top: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
  margin-bottom: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
}

.mt-70 {
  margin-top: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
}

.mb-70 {
  margin-bottom: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
}

.mtb-70 {
  margin-top: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
  margin-bottom: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
}

.mt-80 {
  margin-top: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
}

.mb-80 {
  margin-bottom: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
}

.mtb-80 {
  margin-top: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
  margin-bottom: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
}

.mt-90 {
  margin-top: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
}

.mb-90 {
  margin-bottom: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
}

.mtb-90 {
  margin-top: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
  margin-bottom: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
}

.mt-100 {
  margin-top: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
}

.mb-100 {
  margin-bottom: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
}

.mtb-100 {
  margin-top: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
  margin-bottom: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
}

.mt-130 {
  margin-top: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
}

.mb-130 {
  margin-bottom: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
}

.mtb-130 {
  margin-top: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
  margin-bottom: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
}

.pt-50 {
  padding-top: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
}

.pb-50 {
  padding-bottom: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
}

.ptb-50 {
  padding-top: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
  padding-bottom: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
}

.pt-60 {
  padding-top: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
}

.pb-60 {
  padding-bottom: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
}

.ptb-60 {
  padding-top: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
  padding-bottom: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
}

.pt-70 {
  padding-top: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
}

.pb-70 {
  padding-bottom: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
}

.ptb-70 {
  padding-top: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
  padding-bottom: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
}

.pt-80 {
  padding-top: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
}

.pb-80 {
  padding-bottom: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
}

.ptb-80 {
  padding-top: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
  padding-bottom: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
}

.pt-90 {
  padding-top: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
}

.pb-90 {
  padding-bottom: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
}

.ptb-90 {
  padding-top: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
  padding-bottom: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
}

.pt-100 {
  padding-top: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
}

.pb-100 {
  padding-bottom: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
}

.ptb-100 {
  padding-top: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
  padding-bottom: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
}

.pt-130 {
  padding-top: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
}

.pb-130 {
  padding-bottom: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
}

.ptb-130 {
  padding-top: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
  padding-bottom: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
}

@media print, screen and (min-width: 992px) {
  .mt-lg-50 {
    margin-top: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
  }

  .mb-lg-50 {
    margin-bottom: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
  }

  .mtb-lg-50 {
    margin-top: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
    margin-bottom: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
  }

  .mt-lg-60 {
    margin-top: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
  }

  .mb-lg-60 {
    margin-bottom: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
  }

  .mtb-lg-60 {
    margin-top: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
    margin-bottom: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
  }

  .mt-lg-70 {
    margin-top: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
  }

  .mb-lg-70 {
    margin-bottom: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
  }

  .mtb-lg-70 {
    margin-top: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
    margin-bottom: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
  }

  .mt-lg-80 {
    margin-top: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
  }

  .mb-lg-80 {
    margin-bottom: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
  }

  .mtb-lg-80 {
    margin-top: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
    margin-bottom: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
  }

  .mt-lg-90 {
    margin-top: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
  }

  .mb-lg-90 {
    margin-bottom: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
  }

  .mtb-lg-90 {
    margin-top: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
    margin-bottom: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
  }

  .mt-lg-100 {
    margin-top: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
  }

  .mb-lg-100 {
    margin-bottom: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
  }

  .mtb-lg-100 {
    margin-top: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
    margin-bottom: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
  }

  .mt-lg-130 {
    margin-top: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
  }

  .mb-lg-130 {
    margin-bottom: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
  }

  .mtb-lg-130 {
    margin-top: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
    margin-bottom: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
  }
}
@media print, screen and (min-width: 992px) {
  .pt-lg-50 {
    padding-top: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
  }

  .pb-lg-50 {
    padding-bottom: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
  }

  .ptb-lg-50 {
    padding-top: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
    padding-bottom: min(calc(28px + 22 * (100vw - 375px) / 1325), 50px);
  }

  .pt-lg-60 {
    padding-top: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
  }

  .pb-lg-60 {
    padding-bottom: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
  }

  .ptb-lg-60 {
    padding-top: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
    padding-bottom: min(calc(28px + 32 * (100vw - 375px) / 1325), 60px);
  }

  .pt-lg-70 {
    padding-top: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
  }

  .pb-lg-70 {
    padding-bottom: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
  }

  .ptb-lg-70 {
    padding-top: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
    padding-bottom: min(calc(28px + 42 * (100vw - 375px) / 1325), 70px);
  }

  .pt-lg-80 {
    padding-top: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
  }

  .pb-lg-80 {
    padding-bottom: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
  }

  .ptb-lg-80 {
    padding-top: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
    padding-bottom: min(calc(28px + 52 * (100vw - 375px) / 1325), 80px);
  }

  .pt-lg-90 {
    padding-top: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
  }

  .pb-lg-90 {
    padding-bottom: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
  }

  .ptb-lg-90 {
    padding-top: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
    padding-bottom: min(calc(28px + 62 * (100vw - 375px) / 1325), 90px);
  }

  .pt-lg-100 {
    padding-top: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
  }

  .pb-lg-100 {
    padding-bottom: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
  }

  .ptb-lg-100 {
    padding-top: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
    padding-bottom: min(calc(29px + 71 * (100vw - 375px) / 1325), 100px);
  }

  .pt-lg-130 {
    padding-top: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
  }

  .pb-lg-130 {
    padding-bottom: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
  }

  .ptb-lg-130 {
    padding-top: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
    padding-bottom: min(calc(37px + 93 * (100vw - 375px) / 1325), 130px);
  }
}
/* -------------------------------
	ページ内　共通デザイン
-------------------------------- */
.htmlarea {
  word-wrap: break-word;
  overflow-wrap: break-word;
  overflow: hidden;
}

.ov_hi {
  overflow: hidden;
}

.clear {
  clear: both;
}

/* ---  --- */
.fs-16-24 {
  font-size: min(calc(16px + 8 * (100vw - 320px) / 880), 24px);
}

/* -------------------------------
	main title
-------------------------------- */
.main_ttl {
  height: min(calc(160px + 200 * (100vw - 375px) / 1125), 360px);
  display: flex;
  align-items: center;
  position: relative;
  z-index: 0;
}
.main_ttl > .bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  pointer-events: none;
}
.main_ttl > .bg img {
  max-width: inherit;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.main_ttl h2 {
  line-height: 1.5;
  margin: 0;
}
.main_ttl h2 > .fs-en {
  font-weight: 500;
  font-size: min(calc(35px + 35 * (100vw - 375px) / 1125), 70px);
  line-height: 1;
  letter-spacing: normal;
  text-transform: uppercase;
  text-shadow: 0.1em 0.1em 0.3em #fff;
  display: block;
}
.main_ttl h2 > .fs-jp {
  font-weight: 500;
  font-size: min(calc(16px + 12 * (100vw - 375px) / 1125), 28px);
  line-height: 1.5;
  text-shadow: 0.1em 0.1em 0.3em #fff;
  display: block;
  margin-top: 1em;
}

.page-contents {
  overflow: hidden;
}

/* -------------------------------
	bootstrap
-------------------------------- */
.container-fluid-xl {
  max-width: 1500px;
  width: 100%;
  padding-left: calc(15px + 83 * (100vw - 320px) / 1180);
  padding-right: calc(15px + 83 * (100vw - 320px) / 1180);
  margin-left: auto;
  margin-right: auto;
}
@media print, screen and (min-width: 1500px) {
  .container-fluid-xl {
    padding-left: 98px;
    padding-right: 98px;
  }
}

/* --- gap --- */
.gap-y-10 {
  gap: 10px 0;
}

.gap-y-20 {
  gap: 20px 0;
}

.gap-y-30 {
  gap: 30px 0;
}

/* -------------------------------
	pagetop
-------------------------------- */
#pagetop {
  position: fixed;
  right: 20px;
  bottom: 20px;
  opacity: 0;
  width: 50px;
  visibility: hidden;
  transition: opacity .3s ease, visibility .3s ease;
  z-index: 10;
}
#pagetop.is-active {
  opacity: 1;
  visibility: visible;
}
@media (max-width: 767px) {
  #pagetop {
    right: 5px;
    bottom: 5px;
  }
}

/* -------------------------------
	btn
-------------------------------- */
.btn-icon-l, .btn-icon-r {
  position: relative;
}
.btn-icon-l i, .btn-icon-r i {
  font-size: 0.875em;
  line-height: 1;
  letter-spacing: normal;
  position: absolute;
  top: 50%;
  margin-top: -.5em;
}

.btn-icon-l {
  padding-left: 2em;
}
.btn-icon-l i {
  left: 1.2em;
}

.btn-icon-r {
  padding-right: 2em;
}
.btn-icon-r i {
  right: 1.2em;
}

/* file icon */
.link-icon:before {
  content: "";
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  font-size: 1em;
}
.link-icon[href$=".pdf"]:before {
  content: "\f1c1";
}
.link-icon[href$=".xls"]:before, .link-icon[href$=".xlsx"]:before {
  content: "\f1c3";
}
.link-icon[href$=".doc"]:before, .link-icon[href$=".docx"]:before {
  content: "\f1c2";
}
.link-icon [target="_blank"]:before {
  content: "\f35d";
  font-size: 0.875em;
}

/* -------------------------------
	お問い合わせ
-------------------------------- */
.tel_contact {
  overflow: hidden;
}
.tel_contact h3 {
  font-weight: 500;
  font-size: min(calc(20px + 8 * (100vw - 375px) / 1125), 28px);
  letter-spacing: 0.1em;
  text-align: center;
}
.tel_contact h3 > .txt {
  color: #fff;
  display: inline-block;
  padding: 0.25em 1.75em;
  border-radius: 50em;
  background-color: #bf8770;
}
.tel_contact .telphone {
  font-size: min(calc(30px + 20 * (100vw - 375px) / 1125), 50px);
  display: flex;
  justify-content: center;
  align-items: center;
  letter-spacing: 0.1em;
}
.tel_contact .telphone i {
  margin-right: 0.25em;
}
.tel_contact .btn-line {
  box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.1);
  display: inline-flex;
  align-items: center;
  padding: 10px;
  position: relative;
}
.tel_contact .btn-line img {
  width: 3em;
}
.tel_contact .btn-line .txt {
  text-align: left;
  display: block;
  padding-left: 1em;
}
.tel_contact .btn-line:hover {
  box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.3);
}
@media print, screen and (min-width: 768px) {
  .tel_contact {
    background: linear-gradient(to right, #1c1c1c 0%, #1c1c1c 50%, white 50%, white 100%);
  }
  .tel_contact h3 {
    font-size: min(calc(20px + 8 * (100vw - 768px) / 732), 28px);
  }
  .tel_contact .telphone {
    font-size: min(calc(30px + 20 * (100vw - 768px) / 732), 50px);
  }
}
.tel_contact .tel_contact_item {
  padding: min(calc(50px + 50 * (100vw - 375px) / 1125), 100px) 0;
}
.tel_contact .tel_contact_item.performance {
  color: #fff;
  position: relative;
  z-index: 0;
}
.tel_contact .tel_contact_item.performance::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -50vw;
  right: -50vw;
  z-index: -1;
  background-color: #1c1c1c;
}
.tel_contact .tel_contact_item.performance h3 .txt {
  color: #fff;
  background-color: #e36025;
}
.tel_contact .tel_contact_item.performance .telphone {
  color: #fff;
}
.tel_contact .tel_contact_item.performance .telphone a {
  color: #fff;
}
@media print, screen and (min-width: 768px) {
  .tel_contact .tel_contact_item.performance::before {
    display: none;
  }
}
.tel_contact h4 {
  font-weight: 700;
  font-size: 18px;
  text-align: center;
  margin: 0 0 0.5rem;
}
.tel_contact p {
  font-size: 14px;
  text-align: center;
  margin: 0;
}

.dl_contact_1 {
  font-weight: 500;
  font-size: 14px;
  padding: 0;
  margin: 0;
  display: grid;
  justify-content: center;
  grid-template-columns: auto auto;
}
.dl_contact_1 > dt, .dl_contact_1 > dd {
  margin: 0;
}
.dl_contact_1 > dt {
  padding-right: 1em;
}

.tel_contact_line {
  text-align: center;
  background-color: #efefef;
}
.tel_contact_line .btn {
  font-size: min(calc(16px + 12 * (100vw - 375px) / 1125), 28px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1em 2em;
  border-radius: 0.5em;
  background-color: #fff;
}
.tel_contact_line .btn img {
  width: min(3.57143em, 100px);
}
.tel_contact_line .btn .txt {
  font-weight: 500;
  display: block;
  padding-left: 0.75em;
}
.tel_contact_line .btn:hover {
  box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.25);
}

#contactform {
  /**/
}
#contactform .form-control {
  border-color: #eee;
  background-color: #f6f6f6;
  box-shadow: none;
}
#contactform .form-control:focus {
  border-color: #ccc;
  background-color: #fff;
  box-shadow: none;
}
#contactform .form-control:not(:placeholder-shown) {
  border-color: #ccc;
  background-color: #fff;
  box-shadow: none;
}
#contactform .custom-select {
  box-shadow: none !important;
}
#contactform .custom-select:focus {
  border-color: #ccc;
}
#contactform input[type="file"] {
  font-size: 15px;
  letter-spacing: normal;
}
#contactform input[type="file"]::-webkit-file-upload-button {
  font-size: 12px;
}
@media print, screen and (min-width: 768px) {
  #contactform .select-inline, #contactform .p-region {
    width: auto;
    display: inline;
  }
}
#contactform .radio_group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25em 0;
}
#contactform .radio_group > label {
  flex: 0 0 100%;
}
@media print, screen and (min-width: 768px) {
  #contactform .radio_group {
    gap: 0.25em 1.5em;
  }
  #contactform .radio_group > label {
    flex: 0 0 auto;
  }
}

/* フォーム用　table */
.table-contact {
  line-height: 1.75;
  width: 100%;
  border-collapse: collapse;
  text-align: left;
  border-top: 1px solid #ccc;
  margin-bottom: 30px;
}
.table-contact > tbody > tr {
  border-bottom: 1px solid #ccc;
}
.table-contact > tbody > tr > th, .table-contact > tbody > tr > td {
  padding: 1em 0;
}
.table-contact > tbody > tr > th {
  font-weight: 500;
  width: 15em;
  padding-left: 1em;
  position: relative;
}
.table-contact > tbody > tr > th .hisu {
  color: #fff;
  font-weight: 500;
  font-size: 11px;
  line-height: 1.35;
  height: 1.5em;
  display: block;
  padding: 0 0.75em 0.15em;
  border-radius: 0.25em;
  background-color: var(--danger);
  margin-top: -.75em;
  position: absolute;
  right: 0;
  top: 50%;
}
.table-contact > tbody > tr > td {
  padding-left: 2em;
}
.table-contact > tbody > tr > td .sm {
  width: auto !important;
  display: inline;
}
.table-contact > tbody > tr > td .p-postal-code {
  width: 8em !important;
  display: inline;
}
.table-contact > tbody > tr > td .md {
  max-width: 360px !important;
}
.table-contact > tbody > tr > td .rei {
  color: #555;
  font-size: 0.8125rem;
  line-height: normal;
  display: block;
  margin: 5px 0 0;
}
@media only screen and (max-width: 767px) {
  .table-contact > tbody > tr {
    width: 100%;
    display: block;
    padding: 1em 0.5em;
  }
  .table-contact > tbody > tr > th, .table-contact > tbody > tr > td {
    width: 100%;
    display: block;
    padding: 0;
  }
  .table-contact > tbody > tr > th + td, .table-contact > tbody > tr > td + td {
    margin-top: .5em;
  }
}

.img-hisu {
  margin: -.2em .5em 0 0;
}

/*  */
.agree {
  text-align: center;
  margin-top: 20px;
}

.buttons {
  text-align: center;
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.buttons .btn {
  font-size: 15px;
  margin: 0.3125em 0.625em;
  width: 260px;
  display: block;
  cursor: pointer;
}
@media print, screen and (min-width: 1200px) {
  .buttons .btn {
    font-size: 16px;
  }
}

/* プライバシーポリシー */
#policy {
  margin-top: 30px;
}
#policy .contents {
  padding: 1.5% 3.4448%;
  border: solid 1px #ccc;
  width: 100%;
  aspect-ratio: 4/3;
  max-height: 300px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  overflow: auto;
}
#policy .contents h5 {
  font-size: 1rem;
  font-weight: bold;
  margin: 2rem 0 0;
}
#policy .contents p, #policy .contents ol {
  font-size: 0.9375rem;
  margin: 1rem 0;
}
#policy .contents > ol {
  padding-left: 0;
  list-style: none;
  counter-reset: number;
}
#policy .contents > ol > li {
  padding-left: 2em;
  margin-bottom: 5px;
  position: relative;
}
#policy .contents > ol > li:before {
  position: absolute;
  top: 0;
  left: 0;
  counter-increment: number;
  content: counter(number) " )";
}

/*# sourceMappingURL=contact.css.map */
