@charset "UTF-8";

/* Reset */
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
hr {
  margin: 0;
  padding: 0;
  font-size: 1.6rem;
  font-weight: 400;
}

a {
  text-decoration: none;
  color: inherit;
  transition: 0.5s;
}

a:hover {
  opacity: 0.7;
}

img {
  max-width: 100%;
  height: auto;
}

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

p,
ol,
ol li {
  margin: 0;
  padding: 0;
}

button,
input,
select,
textarea {
  margin: 0;
  max-width: 100%;
  vertical-align: baseline;
}

button,
input {
  line-height: normal;
}

input,
textarea {
  background-image: -webkit-linear-gradient(hsla(0, 0%, 100%, 0), hsla(0, 0%, 100%, 0));
  /* Removing the inner shadow, rounded corners on iOS inputs */
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled],
input[disabled] {
  cursor: default;
}

input[type="checkbox"],
input[type="radio"] {
  padding: 0;
}

input[type="search"] {
  -webkit-appearance: textfield;
}

input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
  vertical-align: top;
}

/* common */
body {
  color: #000;
  font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 1.6rem;
}

p {
  line-height: 2.8rem;
}

/* layout */
.wrapper {
  width: 100%;
  margin: 0 auto;
  padding: 0 10px;
}

.container {
  width: 1000px;
  margin: 0 auto;
}

.align-left { text-align: left !important; }
.align-center { text-align: center !important; }
.align-right { text-align: right !important; }

.valign-top { vertical-align: top; }
.valign-middle { vertical-align: middle; }
.valign-bottom { vertical-align: bottom; }

.flex { display: flex; }
.flex.sp-flex { display: block; }
.flex.nowrap { flex-wrap: wrap; }
.flex.space-between { justify-content: space-between; }
.flex.space-around { justify-content: space-around; }
.flex.flex-end { justify-content: flex-end; }
.flex.center { justify-content: center; }
.flex.flex-align-center { align-items: center; }
.flex.flex-align-flex-end { align-items: flex-end; }
.flex.gap-10 { gap: 10px; }
.flex.gap-20 { gap: 20px; }
.flex.gap-30 { gap: 30px; }
.flex.gap-40 { gap: 40px; }
.flex.gap-50 { gap: 50px; }
.flex.gap-60 { gap: 60px; }
.flex.gap-70 { gap: 70px; }
.flex.gap-80 { gap: 80px; }
.flex.gap-90 { gap: 90px; }
.flex.gap-100 { gap: 100px; }
.flex-1 { flex: 1; }
.flex-3-column { flex: 1 1 calc(33.333% - 50px); }

.tablet-sp-only { display: none !important; }
.sp-only { display: none !important; }

.font-8 { font-size: 0.8rem; }
.font-10 { font-size: 1rem; }
.font-11 { font-size: 1.1rem; }
.font-12 { font-size: 1.2rem; }
.font-13 { font-size: 1.3rem; }
.font-14 { font-size: 1.4rem; }
.font-15 { font-size: 1.5rem; }
.font-16 { font-size: 1.6rem; }
.font-18 { font-size: 1.8rem; }
.font-20 { font-size: 2rem; }
.font-22 { font-size: 2.2rem; }
.font-24 { font-size: 2.4rem; }
.font-26 { font-size: 2.6rem; }
.font-28 { font-size: 2.8rem; }
.font-32 { font-size: 3.2rem; }
.font-30 { font-size: 3rem; }
.font-32 { font-size: 3.2rem; }
.font-34 { font-size: 3.4rem; }
.font-38 { font-size: 3.8rem; }
.font-40 { font-size: 4rem; }
.font-50 { font-size: 5rem; }
.font-60 { font-size: 6rem; }


.lh-16 { line-height: 1.6rem; }
.lh-18 { line-height: 1.8rem; }
.lh-20 { line-height: 2.0rem; }
.lh-22 { line-height: 2.2rem; }
.lh-24 { line-height: 2.4rem; }
.lh-26 { line-height: 2.6rem; }
.lh-27 { line-height: 2.7rem; }
.lh-28 { line-height: 2.8rem; }
.lh-30 { line-height: 3rem; }
.lh-32 { line-height: 3.2rem; }
.lh-34 { line-height: 3.4rem; }
.lh-36 { line-height: 3.6rem; }
.lh-40 { line-height: 4rem; }
.lh-44 { line-height: 4.4rem; }
.lh-60 { line-height: 6rem; }

.text-indent {
  text-indent: -1em;
  padding-left: 1em;
}

.text-indent-2 {
  text-indent: -2em;
  padding-left: 2em;
}

.text-underline {
	border-bottom: 1px solid #000;
	padding-bottom: -2px;
}

.font-blue { color: #3A84F7; }
.font-white { color: #FFF; }
.font-brown { color: #785512; }
.font-red { color: #f70633; }
.font-green { color: #199e1f; }
.font-beige { color: #8E7A65;}

.font-line {
	border-bottom: 1px solid #000;
	padding-bottom: -2px;
}

.font-bold { font-weight: 600; }
.font-italic { font-style: italic; }

.font-mimcho { font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif; }

.m-auto { margin: auto; }

.mt-5 { margin-top: 5px; }
.mt-10 { margin-top: 10px; }
.mt-15 { margin-top: 15px; }
.mt-20 { margin-top: 20px; }
.mt-25 { margin-top: 25px; }
.mt-30 { margin-top: 30px; }
.mt-40 { margin-top: 40px; }
.mt-50 { margin-top: 50px; }
.mt-60 { margin-top: 60px; }
.mt-70 { margin-top: 70px; }
.mt-80 { margin-top: 80px; }
.mt-100 { margin-top: 100px; }
.mt-120 { margin-top: 120px; }
.mt-140 { margin-top: 140px; }
.mt-200 { margin-top: 200px; }

.mb-5 { margin-bottom: 5px; }
.mb-10 { margin-bottom: 10px; }
.mb-15 { margin-bottom: 15px; }
.mb-20 { margin-bottom: 20px; }
.mb-25 { margin-bottom: 25px; }
.mb-30 { margin-bottom: 30px; }
.mb-40 { margin-bottom: 40px; }
.mb-50 { margin-bottom: 50px; }
.mb-60 { margin-bottom: 60px; }
.mb-70 { margin-bottom: 70px; }
.mb-80 { margin-bottom: 80px; }
.mb-100 { margin-bottom: 100px; }
.mb-120 { margin-bottom: 120px; }
.mb-140 { margin-bottom: 140px; }
.mb-200 { margin-bottom: 200px; }

.ml-10 { margin-left: 10px; }
.ml-15 { margin-left: 15px; }
.ml-20 { margin-left: 20px; }
.ml-30 { margin-left: 30px; }
.ml-40 { margin-left: 40px; }
.ml-50 { margin-left: 50px; }

.mr-10 { margin-right: 10px; }
.mr-15 { margin-right: 15px; }
.mr-20 { margin-right: 20px; }
.mr-30 { margin-right: 30px; }
.mr-40 { margin-right: 40px; }
.mr-50 { margin-right: 50px; }

.p-10 { padding: 10px; }
.p-15 { padding: 15px; }
.p-20 { padding: 20px; }
.p-30 { padding: 30px; }
.p-40 { padding: 40px; }
.p-50 { padding: 50px; }
.p-60 { padding: 60px; }
.p-80 { padding: 80px; }
.p-100 { padding: 100px; }
.p-150 { padding: 150px; }
.p-200 { padding: 200px; }

.pt-0 { padding-top: 0; }
.pt-10 { padding-top: 10px; }
.pt-15 { padding-top: 15px; }
.pt-20 { padding-top: 20px; }
.pt-25 { padding-top: 25px; }
.pt-30 { padding-top: 30px; }
.pt-40 { padding-top: 40px; }
.pt-50 { padding-top: 50px; }
.pt-60 { padding-top: 60px; }
.pt-70 { padding-top: 70px; }
.pt-80 { padding-top: 80px; }
.pt-90 { padding-top: 90px; }
.pt-100 { padding-top: 100px; }
.pt-150 { padding-top: 150px; }
.pt-200 { padding-top: 200px; }

.pb-0 { padding-bottom: 0; }
.pb-5 { padding-bottom: 5px; }
.pb-10 { padding-bottom: 10px; }
.pb-15 { padding-bottom: 15px; }
.pb-20 { padding-bottom: 20px; }
.pb-25 { padding-bottom: 25px; }
.pb-30 { padding-bottom: 30px; }
.pb-40 { padding-bottom: 40px; }
.pb-50 { padding-bottom: 50px; }
.pb-60 { padding-bottom: 60px; }
.pb-70 { padding-bottom: 70px; }
.pb-80 { padding-bottom: 80px; }
.pb-90 { padding-bottom: 90px; }
.pb-100 { padding-bottom: 100px; }
.pb-150 { padding-bottom: 150px; }
.pb-200 { padding-bottom: 200px; }

.pl-0 { padding-left: 0; }
.pl-10 { padding-left: 10px; }
.pl-15 { padding-left: 15px; }
.pl-20 { padding-left: 20px; }
.pl-30 { padding-left: 30px; }
.pl-40 { padding-left: 40px; }
.pl-50 { padding-left: 50px; }
.pl-60 { padding-left: 60px; }
.pl-70 { padding-left: 70px; }
.pl-80 { padding-left: 80px; }
.pl-100 { padding-left: 100px; }
.pl-150 { padding-left: 150px; }
.pl-200 { padding-left: 200px; }

.pr-0 { padding-right: 0; }
.pr-10 { padding-right: 10px; }
.pr-15 { padding-right: 15px; }
.pr-20 { padding-right: 20px; }
.pr-30 { padding-right: 30px; }
.pr-40 { padding-right: 40px; }
.pr-50 { padding-right: 50px; }
.pr-60 { padding-right: 60px; }
.pr-70 { padding-right: 70px; }
.pr-80 { padding-right: 80px; }
.pr-100 { padding-right: 100px; }
.pr-150 { padding-right: 150px; }
.pr-200 { padding-right: 200px; }

.float-left { float: left; }
.float-right { float: right; }

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.block {  display: block; }
.inline-block {  display: inline-block; }

.relative { position: relative; }

.w-100 { width: 100px; max-width: 100%; }
.w-150 { width: 150px; max-width: 100%; }
.w-200 { width: 200px; max-width: 100%; }
.w-250 { width: 250px; max-width: 100%; }
.w-280 { width: 280px; max-width: 100%; }
.w-300 { width: 300px; max-width: 100%; }
.w-350 { width: 350px; max-width: 100%; }
.w-400 { width: 400px; max-width: 100%; }
.w-450 { width: 450px; max-width: 100%; }
.w-500 { width: 500px; max-width: 100%; }
.w-600 { width: 600px; max-width: 100%; }
.w-700 { width: 700px; max-width: 100%; }
.w-800 { width: 800px; max-width: 100%; }
.w-900 { width: 900px; max-width: 100%; }
.w-940 { width: 940px; max-width: 100%; }

.w-5p { width: 5%; }
.w-10p { width: 10%; }
.w-20p { width: 20%; }
.w-25p { width: 25%; }
.w-30p { width: 30%; }
.w-40p { width: 40%; }
.w-50p { width: 50%; }
.w-60p { width: 60%; }
.w-70p { width: 70%; }
.w-80p { width: 80%; }
.w-90p { width: 90%; }
.w-100p { width: 100%; }

@media screen and (max-width: 1040px) {
  .container {
    width: 100%;
    padding: 0 10px;
  }

  .flex-pc-only {
    display: block;
  }

  .flex.tablet-column {
    flex-direction: column;
    gap: 20px;
  }

  .flex.tablet-column-reverse {
    flex-direction: column-reverse;
    gap: 10px;
  }

  .pc-only {
    display: none !important;
  }

  .tablet-sp-only {
    display: block !important;
  }
}

@media screen and (max-width: 800px) {
  .pc-tablet-only { display: none !important; }
  .sp-only { display: block !important; }

  .sp-font-0 { font-size: 0rem; }
  .sp-font-8 { font-size: 0.8rem; }
  .sp-font-10 { font-size: 1rem; }
  .sp-font-11 { font-size: 1.1rem; }
  .sp-font-12 { font-size: 1.2rem; }
  .sp-font-13 { font-size: 1.3rem; }
  .sp-font-14 { font-size: 1.4rem; }
  .sp-font-15 { font-size: 1.5rem; }
  .sp-font-16 { font-size: 1.6rem; }
  .sp-font-18 { font-size: 1.8rem; }
  .sp-font-20 { font-size: 2rem; }
  .sp-font-22 { font-size: 2.2rem; }
  .sp-font-24 { font-size: 2.4rem; }
  .sp-font-26 { font-size: 2.6rem; }
  .sp-font-28 { font-size: 2.8rem; }
  .sp-font-32 { font-size: 3.2rem; }
  .sp-font-30 { font-size: 3rem; }
  .sp-font-32 { font-size: 3.2rem; }
  .sp-font-34 { font-size: 3.4rem; }
  .sp-font-38 { font-size: 3.8rem; }
  .sp-font-40 { font-size: 4rem; }
  .sp-font-50 { font-size: 5rem; }
  .sp-font-60 { font-size: 6rem; }

  .sp-lh-16 { line-height: 1.6rem; }
  .sp-lh-18 { line-height: 1.8rem; }
  .sp-lh-20 { line-height: 2rem; }
  .sp-lh-22 { line-height: 2.2rem; }
  .sp-lh-24 { line-height: 2.4rem; }
  .sp-lh-26 { line-height: 2.6rem; }
  .sp-lh-27 { line-height: 2.7rem; }
  .sp-lh-28 { line-height: 2.8rem; }
  .sp-lh-30 { line-height: 3rem; }
  .sp-lh-32 { line-height: 3.2rem; }
  .sp-lh-36 { line-height: 3.6rem; }
  .sp-lh-40 { line-height: 4rem; }
  .sp-lh-44 { line-height: 4.4rem; }
  .sp-lh-60 { line-height: 6rem; }

  .sp-m-auto { margin-left: auto; margin-right: auto; }

  .sp-mt-5 { margin-top: 5px; }
  .sp-mt-10 { margin-top: 10px; }
  .sp-mt-15 { margin-top: 15px; }
  .sp-mt-20 { margin-top: 20px; }
  .sp-mt-25 { margin-top: 25px; }
  .sp-mt-30 { margin-top: 30px; }
  .sp-mt-40 { margin-top: 40px; }
  .sp-mt-50 { margin-top: 50px; }
  .sp-mt-60 { margin-top: 60px; }
  .sp-mt-70 { margin-top: 70px; }
  .sp-mt-80 { margin-top: 80px; }
  .sp-mt-100 { margin-top: 100px; }
  .sp-mt-120 { margin-top: 120px; }
  .sp-mt-140 { margin-top: 140px; }

  .sp-mb-5 { margin-bottom: 5px; }
  .sp-mb-10 { margin-bottom: 10px; }
  .sp-mb-15 { margin-bottom: 15px; }
  .sp-mb-20 { margin-bottom: 20px; }
  .sp-mb-25 { margin-bottom: 25px; }
  .sp-mb-30 { margin-bottom: 30px; }
  .sp-mb-40 { margin-bottom: 40px; }
  .sp-mb-50 { margin-bottom: 50px; }
  .sp-mb-60 { margin-bottom: 60px; }
  .sp-mb-70 { margin-bottom: 70px; }
  .sp-mb-80 { margin-bottom: 80px; }
  .sp-mb-100 { margin-bottom: 100px; }
  .sp-mb-120 { margin-bottom: 120px; }
  .sp-mb-140 { margin-bottom: 140px; }

  .sp-ml-10 { margin-left: 10px; }
  .sp-ml-15 { margin-left: 15px; }
  .sp-ml-20 { margin-left: 20px; }
  .sp-ml-30 { margin-left: 30px; }
  .sp-ml-40 { margin-left: 40px; }
  .sp-ml-50 { margin-left: 50px; }

  .sp-mr-10 { margin-right: 10px; }
  .sp-mr-15 { margin-right: 15px; }
  .sp-mr-20 { margin-right: 20px; }
  .sp-mr-30 { margin-right: 30px; }
  .sp-mr-40 { margin-right: 40px; }
  .sp-mr-50 { margin-right: 50px; }

  .sp-p-0 { padding: 0; }
  .sp-p-10 { padding: 10px; }
  .sp-p-15 { padding: 15px; }
  .sp-p-20 { padding: 20px; }
  .sp-p-30 { padding: 30px; }
  .sp-p-40 { padding: 40px; }
  .sp-p-50 { padding: 50px; }
  .sp-p-80 { padding: 80px; }
  .sp-p-100 { padding: 100px; }
  .sp-p-200 { padding: 200px; }

  .sp-pt-0 { padding-top: 0; }
  .sp-pt-10 { padding-top: 10px; }
  .sp-pt-15 { padding-top: 15px; }
  .sp-pt-20 { padding-top: 20px; }
  .sp-pt-25 { padding-top: 25px; }
  .sp-pt-30 { padding-top: 30px; }
  .sp-pt-40 { padding-top: 40px; }
  .sp-pt-50 { padding-top: 50px; }
  .sp-pt-60 { padding-top: 60px; }
  .sp-pt-70 { padding-top: 70px; }
  .sp-pt-80 { padding-top: 80px; }
  .sp-pt-90 { padding-top: 90px; }
  .sp-pt-100 { padding-top: 100px; }
  .sp-pt-200 { padding-top: 200px; }

  .sp-pb-0 { padding-bottom: 0; }
  .sp-pb-5 { padding-bottom: 5px; }
  .sp-pb-10 { padding-bottom: 10px; }
  .sp-pb-15 { padding-bottom: 15px; }
  .sp-pb-20 { padding-bottom: 20px; }
  .sp-pb-25 { padding-bottom: 25px; }
  .sp-pb-30 { padding-bottom: 30px; }
  .sp-pb-40 { padding-bottom: 40px; }
  .sp-pb-50 { padding-bottom: 50px; }
  .sp-pb-60 { padding-bottom: 60px; }
  .sp-pb-70 { padding-bottom: 70px; }
  .sp-pb-80 { padding-bottom: 80px; }
  .sp-pb-90 { padding-bottom: 90px; }
  .sp-pb-100 { padding-bottom: 100px; }
  .sp-pb-200 { padding-bottom: 200px; }

  .sp-pl-0 { padding-left: 0; }
  .sp-pl-10 { padding-left: 10px; }
  .sp-pl-15 { padding-left: 15px; }
  .sp-pl-20 { padding-left: 20px; }
  .sp-pl-30 { padding-left: 30px; }
  .sp-pl-40 { padding-left: 40px; }
  .sp-pl-50 { padding-left: 50px; }
  .sp-pl-80 { padding-left: 80px; }
  .sp-pl-100 { padding-left: 100px; }
  .sp-pl-200 { padding-left: 200px; }

  .sp-pr-0 { padding-right: 0; }
  .sp-pr-10 { padding-right: 10px; }
  .sp-pr-15 { padding-right: 15px; }
  .sp-pr-20 { padding-right: 20px; }
  .sp-pr-30 { padding-right: 30px; }
  .sp-pr-40 { padding-right: 40px; }
  .sp-pr-50 { padding-right: 50px; }
  .sp-pr-80 { padding-right: 80px; }
  .sp-pr-100 { padding-right: 100px; }
  .sp-pr-200 { padding-right: 200px; }

  .sp-align-center { text-align: center !important; }
  .sp-align-left { text-align: left !important; }
  .sp-align-right { text-align: right !important; }

  .sp-flex {
    display: flex !important;
  }

  .sp-w-100 { width: 100px; }
  .sp-w-150 { width: 150px; }
  .sp-w-200 { width: 200px; }
  .sp-w-250 { width: 250px; }
  .sp-w-280 { width: 280px; }
  .sp-w-300 { width: 300px; }
  .sp-w-350 { width: 350px; }
  .sp-w-400 { width: 400px; }
  .sp-w-450 { width: 450px; }
  .sp-w-500 { width: 500px; }
  .sp-w-600 { width: 600px; }
  .sp-w-700 { width: 700px; }
  .sp-w-800 { width: 800px; }
  .sp-w-900 { width: 900px; }
  .sp-w-1000 { width: 1000px; }

  .sp-w-10p { width: 10%; }
  .sp-w-20p { width: 20%; }
  .sp-w-30p { width: 30%; }
  .sp-w-40p { width: 40%; }
  .sp-w-50p { width: 50%; }
  .sp-w-50p { width: 50%; }
  .sp-w-75p { width: 75%; }
  .sp-w-80p { width: 80%; }
  .sp-w-90p { width: 90%; }
  .sp-w-100p { width: 100%; }

  .flex.sp-column {
    flex-direction: column;
    gap: 20px;
  }

  .flex.sp-column-reverse {
    flex-direction: column-reverse;
    gap: 20px;
  }

  .flex.sp-space-between { justify-content: space-between; }
  .flex.sp-space-around { justify-content: space-around; }
  .flex.sp-flex-end { justify-content: flex-end; }
  .flex.sp-center { justify-content: center; }
  .flex.sp-flex-align-center { align-items: center; }
  .flex.sp-flex-align-flex-end { align-items: flex-end; }

  .flex.sp-gap-0 { gap: 0; }
  .flex.sp-gap-10 { gap: 10px; }
  .flex.sp-gap-20 { gap: 20px; }
  .flex.sp-gap-30 { gap: 30px; }
  .flex.sp-gap-40 { gap: 40px; }
  .flex.sp-gap-50 { gap: 50px; }

  .sp-no-float {
    float: none;
  }

  .flex .sp-flex-order-1 { order: 1; }
}

/* decoration */
hr {
  border-color: #B8B8B8;
  border-width: 1px;
}

.border { border: 1px solid #222; }
.border-beige { border: 1px solid #C1B9AD; }

.rounded-8 { border-radius: 8px; }
.rounded-16 { border-radius: 16px; }
.rounded-20 { border-radius: 20px; }
.rounded-32 { border-radius: 32px; }
.rounded-40 { border-radius: 40px; }
.rounded-left-top-40 { border-radius: 40px 0 0 0; }
.rounded-right-top-40 { border-radius: 0 40px 0 0; }
.rounded-right-bottom-40 { border-radius: 0 0 40px 0; }
.rounded-left-bottom-40 { border-radius: 0 0 0 40px; }

/* bg */
.bg-gray { background: #F8F8F8; }
.bg-gray-transparant { background: #F8F8F880; }
.bg-brown { background: #BFAE9C; }
.bg-yellow { background: #FFFBE8; }
.bg-white { background: #FFF; }

.bg-image01-right {
  background: #FFF url('/wp-content/themes/radiotherapy/assets/images/common/image_01.png') right -20% top 0 / 50% no-repeat;
}

.bg-image01-left {
  background: #FFF url('/wp-content/themes/radiotherapy/assets/images/common/image_01.png') left -20% top 0 / 50% no-repeat;
}

.bg-image02-left {
  background: url('/wp-content/themes/radiotherapy/assets/images/common/image_02.png') left 0 bottom 0 / 50% no-repeat;
}

.bg-image03-right {
  background: #F8F8F8 url('/wp-content/themes/radiotherapy/assets/images/common/image_03.png') right -14% bottom 0 / 50% no-repeat;
}

@media screen and (max-width: 800px) {
  .bg-image01-right {
    background: #FFF url('/wp-content/themes/radiotherapy/assets/images/common/image_01.png') right -200% top 0 / 95% no-repeat;
  }

  .bg-image01-left {
    background: #FFF url('/wp-content/themes/radiotherapy/assets/images/common/image_01.png') left -200% top 0 / 95% no-repeat;
  }

  .bg-image02-left {
    background: url('/wp-content/themes/radiotherapy/assets/images/common/image_02.png') left -20% bottom 0 / 50% no-repeat;
  }
}

@media screen and (max-width: 600px) {
  .bg-image01-right {
    background: #FFF url('/wp-content/themes/radiotherapy/assets/images/common/image_01.png') right 120% top 0 / 150% no-repeat;
  }

  .bg-image01-left {
    background: #FFF url('/wp-content/themes/radiotherapy/assets/images/common/image_01.png') left 120% top 0 / 150% no-repeat;
  }

  .bg-image02-left {
    background: url('/wp-content/themes/radiotherapy/assets/images/common/image_02.png') left -170% bottom 0 / 90% no-repeat;
  }

  .bg-image03-right {
    background: #F8F8F8 url('/wp-content/themes/radiotherapy/assets/images/common/image_03.png') right -170% bottom 0 / 90% no-repeat;
  }
}

/* btn */
.btn {
  padding: 7px;
  text-align: center;
  background: #FAFCFF;
  border: 1px solid #707070;
  border-radius: 30px;
}

.btn a:hover {
  text-decoration: none;
}

.btn a,
.btn-overlay a {
  display: block;
}


.btn.btn-small {
  padding: 1px 30px;
}

.btn.btn-large {
  padding: 20px 30px;
  text-align: left;
  font-size: 16px;
  background: #FFF;
  border: 1px solid #C1B9AD;
  border-radius: 20px;
}

.btn.btn-right-arrow {
  background: url('/wp-content/themes/radiotherapy/assets/images/common/btn_arrow_01.png') right 15px top 16px / 32px no-repeat;
}

.btn.btn-large.btn-right-arrow {
  background: url('/wp-content/themes/radiotherapy/assets/images/common/btn_arrow_01.png') right 15px top 16px / 32px no-repeat;
}

.btn-overlay {
  position: absolute;
  width: 300px;
  bottom: 15px;
  left: calc((100% - 300px) / 2);
  padding: 15px 30px;
  font-size: 1.8rem;
  font-weight: bold;
  background: #FFFFFFCC url('/wp-content/themes/radiotherapy/assets/images/common/btn_arrow_01.png') right 15px top 12px / 32px no-repeat;
  border: 1px solid #707070;
  border-radius: 28px;
  transition: .5s;
}

.btn.bg-yellow {
  background: #FFFCEF;
}

@media screen and (max-width: 1040px) {
}

@media screen and (max-width: 800px) {
}

/* header */
header {
  position: fixed;
  width: 100%;
  top: 0;
  padding: 12px 0;
  background: #FFF;
  z-index: 100;
}

header .site-logo {
  margin-top: 5px;
}

.header-reserve-btn {
  position: fixed;
  width: 210px;
  top: 80px;
  right: 0;
  padding: 10px;
  text-align: center;
  border-radius: 0 0 0 50px;
}

@media screen and (max-width: 800px) {
  header {
    padding: 8px 0;
  }

  header .site-logo {
    width: auto;
    height: 32px;
    margin-top: 0;
  }

  .header-reserve-btn {
    width: 150px;
    top: 56px;
    padding: 10px;
    border-radius: 0 0 0 30px;
  }
}

/* main */
main {
  padding-top: 80px;
  width: 100%;
  overflow: hidden;
}

@media screen and (max-width: 800px) {
  main {
    padding-top: 56px;
  }
}

/* nav */
#nav-toggle {
  position: relative;
  height: 56px;
  width: 56px;
  border: 1px solid #C1B9AD;
  border-radius: 8px;
  cursor: pointer;
}

#nav-toggle span {
  position: absolute;
  width: 100%;
  height: 5px;
  right: 0;
  display: block;
  width: 40px;
  background: #C1B9AD;
  transition: transform .5s ease-in-out, top .5s ease;
}

#nav-toggle span:nth-child(1) {
  top: 13px; right: 7px;
}

#nav-toggle span:nth-child(2) {
  top: 25px; right: 7px;
}

#nav-toggle span:nth-child(3) {
  top: 37px; right: 7px;
}

.nav-opened #nav-toggle span:nth-child(1) {
  top: 25px;
  transform: rotate(45deg);
}

.nav-opened #nav-toggle span:nth-child(2) {
  top: 25px;
  width: 0;
  left: 50%;
}

.nav-opened #nav-toggle span:nth-child(3) {
  top: 25px;
  transform: rotate(-45deg);
}

@media screen and (max-width: 800px) {
  #nav-toggle {
    height: 40px;
    width: 40px;
  }

  #nav-toggle span {
    height: 4px;
    width: 28px;
  }

  #nav-toggle span:nth-child(1) {
    top: 9px; right: 5px;
  }

  #nav-toggle span:nth-child(2) {
    top: 18px; right: 5px;
  }

  #nav-toggle span:nth-child(3) {
    top: 27px; right: 5px;
  }

  .nav-opened #nav-toggle span:nth-child(1) {
    top: 17px;
    transform: rotate(45deg);
  }

  .nav-opened #nav-toggle span:nth-child(2) {
    top: 17px;
    width: 0;
    left: 50%;
  }

  .nav-opened #nav-toggle span:nth-child(3) {
    top: 17px;
    transform: rotate(-45deg);
  }
}

#nav-menu {
  position: fixed;
  width: 940px;
  max-height: 80%;
  top: 100px;
  left: calc((100% - 940px) / 2);
  padding: 50px 100px;
  background: #FFFEFC;
  border: 1px solid #8E7A65;
  border-radius: 20px;
  z-index: -100;
  opacity: 0;
  transition: opacity .5s;
  overflow-y: scroll;
}

.nav-opened #nav-menu {
  opacity: 100;
  z-index: 100;
}

.nav-main-links {
  display: flex;
  justify-content: space-evenly;
  gap: 18px;
}

.nav-main-links div {
  width: 164px;
}

.nav-main-links div a {
  display: block;
  padding: 20px 0;
  background: #FFFCEF;
  text-align: center;
  color: #222;
  border: 1px solid #8E7A65;
  border-radius: 10px;
}

.nav-sub-links {
  display: flex;
  flex-wrap: wrap;
  color: #222;
}

.nav-sub-links > div {
  width: 50%;
  margin-top: 50px;
}

.nav-sub-links > div ul {
  margin-left: 20px;
}

.nav-sub-links > div ul li {
  margin-top: 15px;
}

@media screen and (max-width: 800px) {
  #nav-menu {
    width: 100%;
    max-height: 100%;
    top: 56px;
    left: 0;
    padding: 20px 10px 50px;
    background: #FFFEFC;
    border: none;
    border-bottom: 1px solid #8E7A65;
    border-radius: 0;
    z-index: -100;
  }

  .nav-main-links {
    flex-wrap: wrap;
  }

  .nav-main-links div {
    width: calc((100% - 18px) / 2);
  }

  .nav-sub-links {
    margin-bottom: 50px;
    border-bottom: 1px solid #8E7A65;
  }

  .nav-sub-links > div {
    width: 100%;
    margin-top: 15px;
  }

  .nav-sub-links-title {
    position: relative;
    padding-top: 15px;
    border-top: 1px solid #8E7A65;
  }

  .nav-sub-links-title::after {
    content: "";
    position: absolute;
    display: block;
    width: 24px;
    height: 24px;
    top: 15px;
    right: 5px;
    background: url(/wp-content/themes/radiotherapy/assets/images/common/icon_plus_01.png) top right / 24px no-repeat;
    transition: .5s;
  }

  .nav-sub-links-title.opened::after {
    transform: rotate(135deg);
  }

  .nav-sub-links-link {
    padding-top: 15px;
    padding-bottom: 15px;
    border-top: 1px solid #8E7A65;
  }

  .nav-sub-links > div ul {
    display: none;
    margin-left: 0;
  }

  .nav-sub-links > div ul li {
    padding-top: 15px;
    padding-left: 20px;
    border-top: 1px solid #8E7A65;
  }
}

/* footer */
footer {
  margin-top: 120px;
}

/* page-top */
#page-top {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 99;
  cursor: pointer;
}

@media screen and (max-width: 800px) {
  #page-top {
    width: 93px;
    height: auto;
    bottom: 10px;
    right: 0px;
  }
}

/* list */
ul,
ol {
  letter-spacing: -1em;
}

ul li,
ol li {
  letter-spacing: 0em;
}

ul.list-dot li {
  padding-left: 30px;
  background: url('/wp-content/themes/radiotherapy/assets/images/common/dot_01.svg') top 2px left 0 / 20px no-repeat;
}

@media screen and (max-width: 800px) {
  ul.list-dot li {
    padding-left: 20px;
    background: url('/wp-content/themes/radiotherapy/assets/images/common/dot_01.svg') top 4px left 0 / 12px no-repeat;
  }
}

ul.list-dot-small-brown li {
  position: relative;
  padding-left: 20px;
}

ul.list-dot-small-brown li::before {
  content: "●";
  position: absolute;
  left: 0;
  color: #6C4D7B;
  font-size: 2.2rem;
  line-height: 2.2rem;
}

ul.list-dot-small-blue li {
  position: relative;
  padding-left: 20px;
}

ul.list-dot-small-blue li::before {
  content: "●";
  position: absolute;
  left: 0;
  color: #87AA9E;
  font-size: 2.2rem;
  line-height: 2.2rem;
}

ul.list-notes li {
  position: relative;
  padding-left: 20px;
  counter-increment: num 1;
}

ul.list-notes li::before {
  content: "*"counter(num);
  position: absolute;
  top: 4px;
  left: 0;
  color: #6C4D7B;
  font-size: 1.6rem;
  line-height: 1.6rem;
}

ol li {
  padding-left: 15px;
}

/* box */
.box-pink {
  padding: 30px 45px;
  background: transparent linear-gradient(180deg, #FCF7FF 0%, #EEDEF6 100%) 0% 0% no-repeat padding-box;
  border: 1px solid #6C4D7B;
  border-radius: 20px;
}

@media screen and (max-width: 800px) {
  .box-pink {
    padding: 30px 15px;
  }
}

.box-blue {
  padding: 30px 45px;
  background: transparent linear-gradient(180deg, #FFFFFF 0%, #E9F7F2 100%) 0% 0% no-repeat padding-box;
  border: 1px solid #314940;
  border-radius: 20px;
}

@media screen and (max-width: 800px) {
  .box-blue {
    padding: 30px 15px;
  }
}

.box-yellow {
  padding: 30px 45px;
  background: #FFFCEF;
  border: 1px solid #314940;
  border-radius: 20px;
}

@media screen and (max-width: 800px) {
  .box-yellow {
    padding: 30px 10px;
  }
}

.box-sfaff {
  padding: 45px 65px;
  border: 1px solid #8E7A65;
  border-radius: 20px;
}

.box-sfaff table {
  border-collapse: collapse;
}

.box-sfaff table th,
.box-sfaff table td {
  padding: 20px;
  font-weight: normal;
  vertical-align: top;
  border-top: 1px solid #8E7A65;
}

@media screen and (max-width: 800px) {
  .box-sfaff {
    padding: 45px 15px;
    border: 1px solid #8E7A65;
    border-radius: 20px;
  }

  .box-sfaff table th,
  .box-sfaff table td {
    display: block;
  }

  .box-sfaff table th {
    text-align: left;
    padding: 20px 0 10px;
  }

  .box-sfaff table td {
    width: 100%;
    padding: 10px 0 20px;
    border-top: none;
  }
}

/* box-qa */
.box-qa dl {
  width: 940px;
  margin: 0 auto 15px;
  line-height: 2.8rem;
}

.box-qa dl dt {
  position: relative;
  margin-top: 15px;
  padding: 30px 150px 2px 170px;
  background: #FFFCEF;
  border: 1px solid #A89C8E;
  border-width: 1px 1px 0;
  border-radius: 20px 20px 0 0;
  cursor: pointer;
  counter-increment: q-num 1;
}

.box-qa dl dt::before {
  content: 'Q' counter(q-num) '.';
  position: absolute;
  display: block;
  width: 70px;
  left: 80px;
  padding-right: 21px;
  text-align: right;
  font-size: 3rem;
  font-weight: bold;
  color: #6C4D7B;
  vertical-align: sub;
}

.box-qa dl dd {
  position: relative;
  max-height: 20px;
  margin: auto;
  padding: 30px 100px 0 170px;
  background: #FFFCEF;
  border: 1px solid #A89C8E;
  border-width: 0 1px 1px;
  border-radius: 0 0 20px 20px;
  overflow: hidden;
}

.box-qa dl dt.opened + dd {
  max-height: 2000px;
  padding: 30px 100px 30px 170px;
}

.box-qa dl dd::before {
  content: 'A.';
  position: absolute;
  left: 120px;
  padding-right: 25px;
  font-size: 3rem;
  font-weight: bold;
  color: #314940;
  vertical-align: sub;
}

.box-qa dl dt::after {
  content: "開く";
  display: block;
  position: absolute;
  width: 100px;
  text-align: center;
  border: 1px solid #8E7A65;
  border-radius: 30px;
  top: 30px;
  right: 30px;
}

.box-qa dl dt.opened::after {
  content: "閉じる";
}

@media screen and (max-width: 1040px) {
  .box-qa dl {
    width: 100%;
  }
}

@media screen and (max-width: 800px) {
  .box-qa dl dt {
    padding: 30px 20px 2px 20px;
  }

  .box-qa dl dt::before {
    display: block;
    position: relative;
    /* width: 70px; */
    left: 0;
    margin-bottom: 10px;
    text-align: left;
  }


  .box-qa dl dt::after {
    width: 100px;
    right: 20px;
  }

  .box-qa dl dt.opened + dd {
    padding: 30px 20px 30px 20px;
  }

  .box-qa dl dd::before {
    display: block;
    position: relative;
    left: 0;
    margin-bottom: 10px;
  }
}

/* box-flow */

.box-flow-item {
  position: relative;
  width: 940px;
  margin: 0 auto 20px;
  padding: 50px 100px 50px 120px;
  line-height: 2.2rem;
  background: #FFFCEF;
  border: 1px solid #314940;
  border-radius: 20px;
  counter-increment: flow-num 1;
}

.box-flow-item::before {
  content: "";
  position: absolute;
  width: 5px;
  height: 100%;
  top: 100px;
  left: 65px;
  background: #87AA9E;
  z-index: 1;
}

.box-flow-item::after {
  content: counter(flow-num);
  position: absolute;
  width: 75px;
  height: 75px;
  top: 25px;
  left: 30px;
  padding-top: 22px;
  background: #FFFEFC;
  color: #87AA9E;
  text-align: center;
  font-size: 3.2rem;
  font-weight: bold;
  border: 3px solid #87AA9E;
  border-radius: 50%;
  box-sizing: border-box;
  z-index: 2;
}

.box-flow-item:last-child::before {
  height: calc(100% - 150px);
}

.box-flow-item h3 {
  margin-bottom: 35px;
  padding-left: 20px;
  padding-bottom: 5px;
  font-size: 1.8rem !important;
  font-weight: normal !important;
  border-bottom: 2px solid #314940;
}

.box-flow-item-body {
  display: flex;
  justify-content: space-between;
  padding-left: 20px;
  gap: 30px;
}

@media screen and (max-width: 1040px) {
  .box-flow-item {
    width: 100%;
    padding: 50px 50px 50px 100px;
  }

  .box-flow-item::before {
    width: 5px;
    height: 100%;
    top: 100px;
    left: 45px;
  }

  .box-flow-item::after {
    width: 75px;
    height: 75px;
    top: 25px;
    left: 10px;
    padding-top: 22px;
  }
}

@media screen and (max-width: 800px) {
  .box-flow-item {
    padding: 50px 20px 50px 70px;
  }

  .box-flow-item h3 {
    margin-left: 30px;
    padding-left: 0;
  }

  .box-flow-item-body {
    flex-direction: column;
    padding-left: 0;
  }
}

/* table */
.table-01 table .left-top { border-radius: 20px 0 0 0; }
.table-01 table .right-top { border-radius: 0 20px 0 0; }
.table-01 table .right-bottom { border-radius: 0 0 20px 0; }
.table-01 table .left-bottom { border-radius: 0 0 0 20px; }

.table-01 table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid #8E7A65;
  border-width: 1px 0 0 1px;
  border-radius: 20px;
}

.table-01 table thead {
  background: #FFFCEF;
}

.table-01 table th,
.table-01 table td {
  padding: 20px;
  border: 1px solid #8E7A65;
  border-width: 0 1px 1px 0;
  overflow: hidden;
}

.table-02 table .left-top { border-radius: 20px 0 0 0; }
.table-02 table .right-top { border-radius: 0 20px 0 0; }
.table-02 table .right-bottom { border-radius: 0 0 20px 0; }
.table-02 table .left-bottom { border-radius: 0 0 0 20px; }

.table-02 table {
  margin: auto;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid #8E7A65;
  border-width: 1px 0 0 1px;
  border-radius: 20px;
}

.table-02 table thead {
  background: #BFAE9C;
}

.table-02 table th,
.table-02 table td {
  padding: 10px;
  border: 1px solid #8E7A65;
  border-width: 0 1px 1px 0;
  overflow: hidden;
}

.table-02 table tr:nth-child(even) {
  background: #FFFCEF;
}


/* QA　table */
.table-03 table .left-top { border-radius: 20px 0 0 0; }
.table-03 table .right-top { border-radius: 0 20px 0 0; }
.table-03 table .right-bottom { border-radius: 0 0 20px 0; }
.table-03 table .left-bottom { border-radius: 0 0 0 20px; }

.table-03 table {
  /* width: 100%; */
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid #8E7A65;
  border-width: 1px 0 0 1px;
  border-radius: 20px;
}

.table-03 table thead {
	background: #e6dbd0;
/*  background: #FFFCEF;  */
}

.table-03 table th,
.table-03 table td {
  padding: 20px;
  border: 1px solid #8E7A65;
  border-width: 0 1px 1px 0;
  overflow: hidden;
}

@media screen and (max-width: 800px) {

}
.table-03 table th,
.table-03 table td {
  padding: 20px 8px;
  border: 1px solid #8E7A65;
  border-width: 0 1px 1px 0;
  overflow: hidden;
}

@media screen and (max-width: 800px) {
  .table-01.scroll-x,
  .table-02.scroll-x,
  .table-03.scroll-x {
    overflow-x: scroll;
  }
}

.btn-tabs {
  display: flex;
  justify-content: space-between;
  margin-bottom: 50px !important;
  gap: 10px;
}

.btn-tabs li {
  flex: 1;
  text-align: center;
  border: 1px solid #8E7A65;
  border-radius: 8px;
}

.btn-tabs li.ui-state-active {
  background-color: #BFAE9C;
}

.btn-tabs li a {
  display: block;
  padding: 10px 0;
}
