@charset "UTF-8";
/*** The new CSS reset - version 1.5.1 (last updated 1.3.2022) ***/
*:where(:not(iframe, canvas, img, svg, video):not(svg *, symbol *)) {
  all: unset;
  display: revert;
}

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

a,
button {
  cursor: revert;
}

ol,
ul,
menu {
  list-style: none;
}

img,
video {
  max-width: 100%;
  vertical-align: middle;
  image-rendering: -webkit-optimize-contrast;
}

table {
  border-collapse: collapse;
}

textarea {
  white-space: revert;
}

meter {
  -webkit-appearance: revert;
  -moz-appearance: revert;
       appearance: revert;
}

::-moz-placeholder {
  color: unset;
}

::placeholder {
  color: unset;
}

:where([hidden]) {
  display: none;
}

:where([contenteditable]) {
  -moz-user-modify: read-write;
  -webkit-user-modify: read-write;
  overflow-wrap: break-word;
  /* -webkit-line-break: after-white-space */
}

:where([draggable=true]) {
  -webkit-user-drag: element;
}

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.slick-track:before,
.slick-track:after {
  display: table;
  content: "";
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px;
}

[dir=rtl] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  font-size: clamp(9.6px, 1.25vw, 16px);
}
@media screen and (max-width: 768px) {
  html {
    text-align: justify;
    font-size: 3.75vw;
  }
}

body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  color: #4B1F00;
  background-color: #ffffff;
  text-align: left;
  margin: 0 auto;
  line-height: 1.6em;
  letter-spacing: 0.05em;
  position: relative;
  overflow-x: hidden;
}

h1 {
  font-size: 1rem;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  h1 {
    font-size: 1rem;
  }
}

h2 {
  font-size: 2.25rem;
  font-weight: 900;
  color: #4B1F00;
}
@media screen and (max-width: 768px) {
  h2 {
    font-size: 1.5rem;
  }
}

.h2box {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: clamp(28.8px, 3.75vw, 48px);
}
@media screen and (max-width: 768px) {
  .h2box {
    margin-bottom: 7.5vw;
  }
}
.h2box .h2outer {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.h2box .h2outer span {
  font-weight: 900;
  font-size: 1.125rem;
  color: #FF9141;
}
@media screen and (max-width: 768px) {
  .h2box .h2outer span {
    font-size: 1.125rem;
  }
}
.h2box .h2outer div {
  width: 100%;
  height: 6px;
  margin-top: clamp(4.8px, 0.625vw, 8px);
}
@media screen and (max-width: 768px) {
  .h2box .h2outer div {
    height: 4px;
    margin-top: 0.625vw;
  }
}
.h2box .h2outer div img {
  width: 100%;
  height: 100%;
  vertical-align: text-top;
}
.h2box .lower-title {
  position: relative;
  margin-bottom: clamp(38.4px, 5vw, 64px);
}
@media screen and (max-width: 768px) {
  .h2box .lower-title {
    margin-bottom: 5vw;
  }
}
.h2box .lower-title span {
  position: absolute;
}
.h2box .lower-title span:nth-of-type(1) {
  width: clamp(134.4px, 17.5vw, 224px);
  left: -6em;
  top: -4em;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .h2box .lower-title span:nth-of-type(1) {
    width: 35vw;
    left: -4em;
    top: -2em;
  }
}
.h2box .lower-title span:nth-of-type(2) {
  width: clamp(34.2px, 4.453125vw, 57px);
  right: -4em;
  bottom: -1em;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .h2box .lower-title span:nth-of-type(2) {
    width: 8.125vw;
    right: -2em;
    bottom: 0em;
  }
}
.h2box .lower-title span:nth-of-type(3) {
  width: clamp(48px, 6.25vw, 80px);
  right: -3.5em;
  bottom: -2.5em;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .h2box .lower-title span:nth-of-type(3) {
    width: 12.5vw;
    right: -1.5em;
    bottom: -1.5em;
  }
}

button {
  position: relative;
  cursor: pointer;
  color: #ffffff;
  font-size: 1.3125rem;
  padding: clamp(12px, 1.5625vw, 20px) clamp(24px, 3.125vw, 40px);
  border-radius: 64px;
  line-height: 1;
  border: none;
  display: inline-flex;
  align-items: center;
  width: auto;
}
@media screen and (max-width: 768px) {
  button {
    font-size: 1rem;
    padding: 3.515625vw 7.03125vw;
    border-radius: 32px;
    width: auto;
    display: inline-flex;
  }
}
button p {
  margin-right: clamp(9.6px, 1.25vw, 16px);
}
@media screen and (max-width: 768px) {
  button p {
    margin-right: 2.5vw;
  }
}
button img {
  position: absolute;
  width: clamp(6px, 0.78125vw, 10px);
  right: clamp(9.6px, 1.25vw, 16px);
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  button img {
    width: 1.5625vw;
    right: 2.5vw;
  }
}
button.greenbutton {
  background-color: #278948;
}
button.orangebutton {
  background-color: #FF9141;
}

.grecaptcha-badge {
  visibility: hidden;
}

.container {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 20px;
  width: 100%;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  .container {
    width: 100%;
    padding: 0 3.125vw;
  }
}

.l-container {
  max-width: 1440px;
  margin: 0 auto;
  width: 100%;
}

.pcnone {
  display: none;
}
@media screen and (max-width: 768px) {
  .pcnone {
    display: block;
  }
}

@media screen and (max-width: 768px) {
  .spnone {
    display: none;
  }
}

.dropshadow {
  box-shadow: clamp(1.2px, 0.15625vw, 2px) clamp(1.2px, 0.15625vw, 2px) clamp(1.2px, 0.15625vw, 2px) 0px rgba(0, 0, 0, 0.15);
}
@media screen and (max-width: 768px) {
  .dropshadow {
    box-shadow: 0.3125vw 0.3125vw 0.3125vw 0px rgba(0, 0, 0, 0.15);
  }
}

.hover {
  transition-duration: 250ms;
  transition-timing-function: ease-in;
}
.hover.hover-active {
  transition-delay: 0ms !important;
  filter: opacity(0.65);
}

.fadein {
  transform: translateY(30px);
  opacity: 0;
  transition: 900ms cubic-bezier(0, 0, 0.2, 1);
}
@media screen and (max-width: 768px) {
  .fadein {
    transform: translateY(10px);
  }
}
.fadein.fadein-out {
  transform: translateY(0);
  opacity: 1;
}
.fadein.speed {
  transform: translateY(0);
  transition: 900ms cubic-bezier(0, 0, 0.2, 1);
}
.fadein.delay1 {
  transition-delay: 200ms;
}
.fadein.delay2 {
  transition-delay: 350ms;
}
.fadein.delay3 {
  transition-delay: 500ms;
}

#fv {
  position: relative;
  margin-top: clamp(60px, 7.8125vw, 100px);
  width: 100vw;
  height: calc(100vh - clamp(60px, 7.8125vw, 100px));
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  #fv {
    margin-top: 7.8125vw;
    height: calc(100vh - 7.8125vw);
  }
}
#fv video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: auto;
  min-width: 100%;
  min-height: 100%;
  transform: translate(-50%, -50%);
  -o-object-fit: cover;
     object-fit: cover;
  z-index: -1;
}

header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  padding: 0 clamp(19.2px, 2.5vw, 32px);
  height: clamp(60px, 7.8125vw, 100px);
  margin-bottom: 0;
  background-color: #ffffff;
  z-index: 100;
  box-sizing: border-box;
}
@media screen and (max-width: 768px) {
  header {
    padding: 0 2.5vw;
    height: 10.15625vw;
  }
}
header .header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1.125rem;
  height: 100%;
  position: relative;
}
@media screen and (max-width: 768px) {
  header .header-inner {
    font-size: 1.125rem;
  }
}
header .header-inner .header-logo h1 img {
  width: clamp(182.4px, 23.75vw, 304px);
}
@media screen and (max-width: 768px) {
  header .header-inner .header-logo h1 img {
    width: 40.625vw;
  }
}
@media screen and (max-width: 768px) {
  header .header-inner nav.spnone {
    display: contents;
  }
  header .header-inner nav.spnone .gnav {
    position: fixed;
    top: 0;
    left: -110vw;
    width: 100vw;
    height: 100vh;
    background-color: #ffffff;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    transition-duration: 400ms;
    transition-timing-function: ease-out;
    z-index: 99;
  }
  header .header-inner nav.spnone.nav-open .gnav {
    left: 0;
  }
}
header .header-inner nav.spnone ul {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  header .header-inner nav.spnone ul {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: auto;
  }
}
header .header-inner nav.spnone ul li {
  padding: 0 clamp(9.6px, 1.25vw, 16px);
  position: relative;
}
@media screen and (max-width: 768px) {
  header .header-inner nav.spnone ul li {
    margin-right: 0;
    margin-bottom: 3.125vw;
    padding: 0;
    text-align: center;
  }
}
header .header-inner nav.spnone ul li::after {
  content: "";
  position: absolute;
  right: 0;
  top: 30%;
  width: 2px;
  height: 40%;
  background-color: #4B1F00;
}
@media screen and (max-width: 768px) {
  header .header-inner nav.spnone ul li::after {
    content: none;
  }
}
header .header-inner nav.spnone ul li:nth-of-type(4)::after, header .header-inner nav.spnone ul li:nth-of-type(5)::after {
  content: none;
}
header .header-inner nav.spnone ul li:nth-of-type(5) {
  font-size: 1.3125rem;
  background-color: #469A67;
  color: #ffffff;
  padding: clamp(9.6px, 1.25vw, 16px) clamp(19.2px, 2.5vw, 32px);
  border-radius: clamp(38.4px, 5vw, 64px);
}
@media screen and (max-width: 768px) {
  header .header-inner nav.spnone ul li:nth-of-type(5) {
    font-size: 1rem;
    padding: 1.25vw 2.5vw;
    border-radius: 5vw;
  }
}
@media screen and (max-width: 768px) {
  header .header-inner nav.pcnone {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 101;
  }
}
header .header-inner nav.pcnone .menu-btn {
  width: clamp(18px, 2.34375vw, 30px);
  height: clamp(13.2px, 1.71875vw, 22px);
  position: relative;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  header .header-inner nav.pcnone .menu-btn {
    width: 7.03125vw;
    height: 4.375vw;
  }
}
header .header-inner nav.pcnone .menu-btn span {
  position: absolute;
  left: 0;
  width: 100%;
  height: clamp(2.4px, 0.3125vw, 4px);
  background-color: #4B1F00;
  border-radius: clamp(1.2px, 0.15625vw, 2px);
  transition: all 0.3s ease-in-out;
  transform-origin: center;
}
@media screen and (max-width: 768px) {
  header .header-inner nav.pcnone .menu-btn span {
    height: 2px;
    border-radius: 4px;
  }
}
header .header-inner nav.pcnone .menu-btn span:nth-of-type(1) {
  top: 0;
}
header .header-inner nav.pcnone .menu-btn span:nth-of-type(2) {
  top: 50%;
  transform: translateY(-50%);
}
header .header-inner nav.pcnone .menu-btn span:nth-of-type(3) {
  bottom: 0;
}
header .header-inner nav.pcnone .menu-btn.nav-open span:nth-of-type(1) {
  transform: translateY(-50%) rotate(21.5deg);
  top: 50%;
}
header .header-inner nav.pcnone .menu-btn.nav-open span:nth-of-type(2) {
  opacity: 0;
}
header .header-inner nav.pcnone .menu-btn.nav-open span:nth-of-type(3) {
  transform: translateY(0) rotate(-21.5deg);
  bottom: 50%;
}

#news {
  position: relative;
  margin-top: clamp(48px, 6.25vw, 80px);
}
@media screen and (max-width: 768px) {
  #news {
    margin-top: 6.25vw;
  }
}
#news .newsbg {
  position: absolute;
  top: 0;
  left: 0;
  width: 95%;
  z-index: -1;
}
#news .newsbg img {
  width: 100%;
  max-width: unset;
  max-height: 1500px;
}
#news .news-title__outer {
  padding-top: clamp(48px, 6.25vw, 80px);
  margin-bottom: clamp(12px, 1.5625vw, 20px);
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  #news .news-title__outer {
    padding-top: 6.25vw;
    margin-bottom: 9.375vw;
    justify-content: flex-start;
  }
}
#news .news-title__outer .news-title {
  margin-right: clamp(38.4px, 5vw, 64px);
}
@media screen and (max-width: 768px) {
  #news .news-title__outer .news-title {
    margin-right: 3.125vw;
  }
}
#news .news-title__outer a {
  display: flex;
  align-items: center;
}
#news .news-title__outer a .news-link {
  font-size: 1.3125rem;
  margin-right: clamp(4.8px, 0.625vw, 8px);
}
@media screen and (max-width: 768px) {
  #news .news-title__outer a .news-link {
    font-size: 0.875rem;
    margin-right: 0.625vw;
  }
}
#news .news-title__outer a img {
  width: clamp(28.8px, 3.75vw, 48px);
}
@media screen and (max-width: 768px) {
  #news .news-title__outer a img {
    width: 3.75vw;
  }
}
#news ul {
  display: flex;
  margin-bottom: clamp(96px, 12.5vw, 160px);
}
@media screen and (max-width: 768px) {
  #news ul {
    flex-direction: column;
    align-items: flex-start;
    gap: 10vw;
    margin-bottom: 18.75vw;
  }
}
#news ul li {
  width: calc(33.3333333333% - clamp(9.6px, 1.25vw, 16px));
  margin-right: clamp(15px, 1.953125vw, 25px);
  background-color: #ffffff;
  border-radius: 8px;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  #news ul li {
    margin-right: 0;
    width: 80%;
    margin: 0 auto;
  }
}
#news ul li:last-of-type {
  margin-right: 0;
  margin: 0 auto;
}
#news ul li .news-thumb {
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
}
#news ul li .news-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
#news ul li .news-text {
  padding: clamp(4.8px, 0.625vw, 8px) clamp(9.6px, 1.25vw, 16px) clamp(9.6px, 1.25vw, 16px) clamp(9.6px, 1.25vw, 16px);
  text-align: justify;
}
@media screen and (max-width: 768px) {
  #news ul li .news-text {
    padding: 1.25vw 1.875vw 1.875vw 1.875vw;
  }
}
#news ul li .news-text time {
  line-height: 1;
  font-size: 0.875rem;
}
@media screen and (max-width: 768px) {
  #news ul li .news-text time {
    font-size: 0.875rem;
  }
}
#news ul li .news-text .news-tags {
  font-size: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(4.8px, 0.625vw, 8px);
  margin-bottom: clamp(4.8px, 0.625vw, 8px);
}
@media screen and (max-width: 768px) {
  #news ul li .news-text .news-tags {
    font-size: 0.875rem;
    gap: 0.625vw;
    margin-bottom: 0.625vw;
  }
}
#news ul li .news-text .news-tags .news-tag {
  padding: clamp(4.8px, 0.625vw, 8px);
  line-height: 1;
  border-radius: 8px;
  background-color: #F1E9B0;
}
@media screen and (max-width: 768px) {
  #news ul li .news-text .news-tags .news-tag {
    padding: 1.25vw 1.875vw;
    border-radius: 8px;
  }
}
#news ul li .news-text .news-tags .news-tag.news-all {
  background-color: #F1E9B0;
}
#news ul li .news-text .news-tags .news-tag.news-camp {
  background-color: #FF9141;
  color: #ffffff;
}
#news ul li .news-text p {
  font-size: 1.125rem;
}
@media screen and (max-width: 768px) {
  #news ul li .news-text p {
    font-size: 1rem;
  }
}

#greeting {
  position: relative;
  padding-top: clamp(48px, 6.25vw, 80px);
  padding-bottom: clamp(48px, 6.25vw, 80px);
  margin-bottom: clamp(48px, 6.25vw, 80px);
}
@media screen and (max-width: 768px) {
  #greeting {
    padding-top: 6.25vw;
    padding-bottom: 12.5vw;
    margin-bottom: 12.5vw;
  }
}
#greeting .greeting-outer {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 5%;
  z-index: -1;
  background-image: url(../img/bg-g.svg);
  background-size: cover;
}
@media screen and (max-width: 768px) {
  #greeting .greeting-outer {
    left: -100%;
    width: 600%;
    height: 100%;
  }
}
#greeting .container-greeting {
  background-image: url(../img/bg-w.svg);
  background-size: 100% 100%;
  padding: clamp(33.6px, 4.375vw, 56px);
  text-align: center;
}
@media screen and (max-width: 768px) {
  #greeting .container-greeting {
    padding: 6.25vw;
    background-size: cover;
    background-image: none;
    background-color: #ffffff;
    border-radius: 16px;
  }
}
#greeting .greeting-inner {
  display: flex;
  margin-bottom: clamp(9.6px, 1.25vw, 16px);
}
@media screen and (max-width: 768px) {
  #greeting .greeting-inner {
    flex-direction: column;
    align-items: center;
    gap: 1.875vw;
    margin-bottom: 1.25vw;
  }
}
#greeting .greeting-inner .greeting-thumb {
  width: clamp(100.8px, 13.125vw, 168px);
  margin-right: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  #greeting .greeting-inner .greeting-thumb {
    width: 50%;
    margin-right: 0;
    margin-bottom: 3.125vw;
  }
}
#greeting .greeting-inner .greeting-text {
  width: calc(100% - clamp(109.2px, 14.21875vw, 182px));
  font-size: 1.125rem;
}
@media screen and (max-width: 768px) {
  #greeting .greeting-inner .greeting-text {
    width: 100%;
    font-size: 1rem;
  }
}
#greeting .greeting-inner .greeting-text p {
  text-align: justify;
  margin-bottom: 1em;
  line-height: 1.4em;
}
#greeting .greeting-inner .greeting-text p:last-of-type {
  text-align: right;
}
#greeting.aboutpage .greeting-outer {
  display: block;
}
#greeting.aboutpage .container {
  background-image: url(../img/bg-w.svg);
  background-size: cover;
  background-repeat: no-repeat;
  padding: clamp(24px, 3.125vw, 40px);
  margin-bottom: clamp(24px, 3.125vw, 40px);
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .container {
    padding: 3.125vw;
    margin-bottom: 3.125vw;
    background-image: none;
    background-color: #ffffff;
    border-radius: 16px;
    width: 90%;
    margin: 0 auto;
  }
}
#greeting.aboutpage .soroban-inner li {
  display: flex;
  gap: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner li {
    flex-direction: column;
    align-items: flex-start;
    gap: 3.75vw;
  }
}
#greeting.aboutpage .soroban-inner li .soroban-thumb {
  width: 50%;
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner li .soroban-thumb {
    width: 80%;
    margin: 0 auto;
    display: none;
  }
}
#greeting.aboutpage .soroban-inner li .soroban-thumb img {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner li .soroban-thumb img {
    max-width: 100%;
  }
}
#greeting.aboutpage .soroban-inner li .soroban-text {
  width: 50%;
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner li .soroban-text {
    width: 85%;
    margin: 0 auto;
  }
}
#greeting.aboutpage .soroban-inner li .soroban-text h3 {
  font-size: 1.75rem;
  line-height: 1.4em;
  margin-bottom: 0.5em;
  text-align: left;
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner li .soroban-text h3 {
    font-size: 1rem;
  }
}
#greeting.aboutpage .soroban-inner li .soroban-text h3 span {
  display: inline-block;
  width: clamp(15px, 1.953125vw, 25px);
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner li .soroban-text h3 span {
    width: 2.8125vw;
  }
}
#greeting.aboutpage .soroban-inner li .soroban-text p {
  text-align: left;
  font-size: 1.125rem;
  line-height: 1.6em;
  margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner li .soroban-text p {
    font-size: 0.875rem;
    line-height: 1.4em;
    margin-bottom: 0.8em;
  }
}
#greeting.aboutpage .soroban-inner .slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(38.4px, 5vw, 64px);
  height: clamp(38.4px, 5vw, 64px);
  background-size: cover;
  background-repeat: no-repeat;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner .slick-arrow {
    width: 7.5vw;
    height: 7.5vw;
  }
}
#greeting.aboutpage .soroban-inner .slick-arrow.soroban-arrow_prev {
  left: clamp(-84px, -10.9375vw, -140px);
  background-image: url(../img/btn-ol.png);
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner .slick-arrow.soroban-arrow_prev {
    left: -1.5625vw;
  }
}
#greeting.aboutpage .soroban-inner .slick-arrow.soroban-arrow_next {
  right: clamp(-84px, -10.9375vw, -140px);
  background-image: url(../img/btn-or.png);
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .soroban-inner .slick-arrow.soroban-arrow_next {
    right: -1.5625vw;
  }
}
#greeting.aboutpage .thumbslider .slick-track {
  transform: unset !important;
}
@media screen and (max-width: 768px) {
  #greeting.aboutpage .thumbslider .slick-track {
    display: none;
  }
}
#greeting.aboutpage .thumbslider {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 20px;
  width: 100%;
}
#greeting.aboutpage .thumbslider .slick-slide {
  margin: 0 10px;
}
#greeting.aboutpage .thumbslide {
  cursor: pointer;
}
#greeting.aboutpage .thumbslide {
  opacity: 0.3;
  transition: opacity 0.3s linear;
}
#greeting.aboutpage .thumbslider .slick-current {
  opacity: 1;
}

#about {
  position: relative;
  padding-top: clamp(48px, 6.25vw, 80px);
  margin-bottom: clamp(48px, 6.25vw, 80px);
}
@media screen and (max-width: 768px) {
  #about {
    padding-top: 12.5vw;
    margin-bottom: 12.5vw;
  }
}
#about.aboutpage {
  margin-bottom: clamp(96px, 12.5vw, 160px);
}
@media screen and (max-width: 768px) {
  #about.aboutpage {
    margin-bottom: 12.5vw;
  }
}
#about .aboutbg {
  position: absolute;
  top: 0;
  right: 0;
  width: 95%;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  #about .aboutbg {
    width: 100%;
  }
}
#about .aboutbg img {
  width: 100%;
  max-width: unset;
  max-height: 1180px;
}
#about .aboutbg.aboutpage {
  bottom: 0;
  left: 0;
  margin: auto;
}
#about .aboutbg.aboutpage img {
  width: 100%;
  max-width: unset;
  max-height: 610px;
}
#about .h2box .h2outer {
  text-align: center;
}
#about .about-inner {
  display: flex;
}
@media screen and (max-width: 768px) {
  #about .about-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.875vw;
  }
}
#about .about-inner .about-thumb {
  width: clamp(216px, 28.125vw, 360px);
  margin-right: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  #about .about-inner .about-thumb {
    width: 80%;
    margin-right: 0;
    margin: 0 auto;
    margin-bottom: 3.75vw;
  }
}
#about .about-inner .about-text {
  width: calc(100% - clamp(230.4px, 30vw, 384px));
  font-size: 1.125rem;
  text-align: justify;
  line-height: 1.4em;
}
@media screen and (max-width: 768px) {
  #about .about-inner .about-text {
    width: 100%;
    font-size: 1rem;
  }
}
#about .about-inner .about-text h3 {
  font-size: 1.75rem;
  line-height: 1.4em;
  margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
  #about .about-inner .about-text h3 {
    font-size: 1.4rem;
  }
}
#about .about-inner .about-text > p {
  margin-bottom: 1em;
}
#about .about-inner .about-text > p span {
  color: #278948;
}

#school {
  position: relative;
  padding-top: clamp(48px, 6.25vw, 80px);
  padding-bottom: clamp(48px, 6.25vw, 80px);
}
@media screen and (max-width: 768px) {
  #school {
    padding-top: 6.25vw;
    padding-bottom: 6.25vw;
  }
}
#school .schoolbg {
  position: absolute;
  top: 0;
  left: 0;
  width: 95%;
  height: 100%;
  z-index: -1;
  background-image: url(../img/bg-a.svg);
  background-size: cover;
}
@media screen and (max-width: 768px) {
  #school .schoolbg {
    width: 100%;
  }
}
#school .container {
  display: flex;
}
@media screen and (max-width: 768px) {
  #school .container {
    flex-direction: column;
    align-items: flex-start;
    gap: 3.75vw;
  }
}
#school .container .school-thumb {
  width: clamp(216px, 28.125vw, 360px);
  margin-right: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  #school .container .school-thumb {
    width: 80%;
    margin-right: 0;
    margin: 0 auto;
  }
}
#school .container .school-text {
  width: calc(100% - clamp(230.4px, 30vw, 384px));
  font-size: 1.125rem;
  text-align: justify;
  line-height: 1.4em;
}
@media screen and (max-width: 768px) {
  #school .container .school-text {
    width: 100%;
    font-size: 1rem;
  }
}
#school .container .school-text h3 {
  font-size: 1.75rem;
  line-height: 1.4em;
  margin-bottom: 0.6em;
}
@media screen and (max-width: 768px) {
  #school .container .school-text h3 {
    font-size: 1.5rem;
  }
}
#school .container .school-text > p {
  margin-bottom: 1em;
}
#school .container .school-text > p span {
  color: #278948;
}

#soroban {
  position: relative;
  padding-top: clamp(48px, 6.25vw, 80px);
  padding-bottom: clamp(48px, 6.25vw, 80px);
  margin-top: clamp(96px, 12.5vw, 160px);
  margin-bottom: clamp(48px, 6.25vw, 80px);
}
@media screen and (max-width: 768px) {
  #soroban {
    padding-top: 6.25vw;
    padding-bottom: 6.25vw;
    margin-top: 12.5vw;
    margin-bottom: 6.25vw;
  }
}
#soroban .sorobanbg {
  position: absolute;
  top: 0;
  right: 0;
  width: 95%;
  height: 100%;
  z-index: -1;
  background-image: url(../img/sorobg1.svg);
  background-size: 100% 100%;
}
@media screen and (max-width: 768px) {
  #soroban .sorobanbg {
    background-size: cover;
  }
}
#soroban h2 {
  text-align: center;
}
#soroban .soroban-inner li {
  display: flex;
  gap: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner li {
    flex-direction: column;
    align-items: center;
    gap: 3.75vw;
  }
}
#soroban .soroban-inner li .soroban-thumb {
  width: 50%;
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner li .soroban-thumb {
    width: 30%;
  }
}
#soroban .soroban-inner li .soroban-thumb img {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner li .soroban-thumb img {
    max-width: 100%;
  }
}
#soroban .soroban-inner li .soroban-text {
  width: 50%;
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner li .soroban-text {
    width: 80%;
  }
}
#soroban .soroban-inner li .soroban-text h3 {
  font-size: 1.75rem;
  line-height: 1.4em;
  margin-bottom: 0.5em;
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner li .soroban-text h3 {
    font-size: 1.25rem;
  }
}
#soroban .soroban-inner li .soroban-text h3 span {
  display: inline-block;
  width: clamp(15px, 1.953125vw, 25px);
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner li .soroban-text h3 span {
    width: 3.90625vw;
  }
}
#soroban .soroban-inner li .soroban-text p {
  font-size: 1.125rem;
  line-height: 1.6em;
  margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner li .soroban-text p {
    font-size: 1rem;
  }
}
#soroban .soroban-inner .slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(38.4px, 5vw, 64px);
  height: clamp(38.4px, 5vw, 64px);
  background-size: cover;
  background-repeat: no-repeat;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner .slick-arrow {
    width: 7.8125vw;
    height: 7.8125vw;
  }
}
#soroban .soroban-inner .slick-arrow.soroban-arrow_prev {
  left: clamp(-84px, -10.9375vw, -140px);
  background-image: url(../img/btn-ol.png);
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner .slick-arrow.soroban-arrow_prev {
    left: -2.34375vw;
  }
}
#soroban .soroban-inner .slick-arrow.soroban-arrow_next {
  right: clamp(-84px, -10.9375vw, -140px);
  background-image: url(../img/btn-or.png);
}
@media screen and (max-width: 768px) {
  #soroban .soroban-inner .slick-arrow.soroban-arrow_next {
    right: -2.34375vw;
  }
}
#soroban .thumbslider .slick-track {
  transform: unset !important;
}
#soroban .thumbslider .slick-slide {
  margin: 0 10px;
}
#soroban .thumbslide {
  cursor: pointer;
}
#soroban .thumbslide {
  opacity: 0.3;
  transition: opacity 0.3s linear;
}
#soroban .thumbslider .slick-current {
  opacity: 1;
}

#soroban-brain {
  position: relative;
  padding-top: clamp(48px, 6.25vw, 80px);
  margin-top: clamp(96px, 12.5vw, 160px);
}
@media screen and (max-width: 768px) {
  #soroban-brain {
    padding-top: 6.25vw;
    margin-top: 12.5vw;
    margin-bottom: 12.5vw;
  }
}
#soroban-brain h2 {
  text-align: center;
}
#soroban-brain .soroban-brainbg {
  position: absolute;
  top: 0;
  left: 0;
  width: 95%;
  z-index: -1;
}
#soroban-brain .soroban-brainbg img {
  width: 200%;
  max-height: 1000px;
}
#soroban-brain .soroban-brain-inner {
  display: flex;
  gap: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  #soroban-brain .soroban-brain-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 3.75vw;
  }
}
#soroban-brain .soroban-brain-inner .soroban-brain-thumb {
  width: 50%;
}
@media screen and (max-width: 768px) {
  #soroban-brain .soroban-brain-inner .soroban-brain-thumb {
    width: 80%;
    margin: 0 auto;
  }
}
#soroban-brain .soroban-brain-inner .soroban-brain-thumb img {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 768px) {
  #soroban-brain .soroban-brain-inner .soroban-brain-thumb img {
    max-width: 100%;
  }
}
#soroban-brain .soroban-brain-inner .soroban-brain-text {
  width: 50%;
}
@media screen and (max-width: 768px) {
  #soroban-brain .soroban-brain-inner .soroban-brain-text {
    width: 100%;
  }
}
#soroban-brain .soroban-brain-inner .soroban-brain-text p {
  font-size: 1.125rem;
  line-height: 1.6em;
  margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
  #soroban-brain .soroban-brain-inner .soroban-brain-text p {
    font-size: 1rem;
  }
}

#school2 {
  position: relative;
  padding-top: clamp(24px, 3.125vw, 40px);
  margin-bottom: clamp(72px, 9.375vw, 120px);
}
@media screen and (max-width: 768px) {
  #school2 {
    padding-top: 6.25vw;
    margin-bottom: 9.375vw;
  }
}
#school2 .school2bg {
  position: absolute;
  top: 0px;
  right: 0px;
  width: 95%;
  height: 100%;
  z-index: -1;
  background-image: url(../img/bg-a2.svg);
  background-size: cover;
}
@media screen and (max-width: 768px) {
  #school2 .school2bg {
    width: 120%;
  }
}
#school2 .container .school2-h3 {
  font-size: 1.125rem;
  line-height: 1.4em;
  margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
  #school2 .container .school2-h3 {
    font-size: 1.125rem;
  }
}
#school2 .container .school2-ul-outer {
  display: flex;
  gap: clamp(14.4px, 1.875vw, 24px);
  padding-bottom: clamp(48px, 6.25vw, 80px);
}
@media screen and (max-width: 768px) {
  #school2 .container .school2-ul-outer {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.875vw;
    padding-bottom: 6.25vw;
  }
}
#school2 .container .school2-ul-outer ul {
  width: 50%;
}
@media screen and (max-width: 768px) {
  #school2 .container .school2-ul-outer ul {
    width: 100%;
  }
}
#school2 .container .school2-ul-outer ul li {
  margin-bottom: clamp(9.6px, 1.25vw, 16px);
}
@media screen and (max-width: 768px) {
  #school2 .container .school2-ul-outer ul li {
    margin-bottom: 2.5vw;
  }
}
#school2 .container .school2-ul-outer ul h4 {
  font-size: 1.125rem;
}
@media screen and (max-width: 768px) {
  #school2 .container .school2-ul-outer ul h4 {
    font-size: 1.125rem;
  }
}
#school2 .container .school2-ul-outer ul p {
  font-size: 1rem;
  line-height: 1.5em;
}
@media screen and (max-width: 768px) {
  #school2 .container .school2-ul-outer ul p {
    font-size: 1rem;
  }
}

.lowerheader {
  margin-top: clamp(96px, 12.5vw, 160px);
}
@media screen and (max-width: 768px) {
  .lowerheader {
    margin-top: 12.5vw;
  }
}

.h2box.features {
  margin-top: clamp(144px, 18.75vw, 240px);
}
@media screen and (max-width: 768px) {
  .h2box.features {
    margin-top: 18.75vw;
  }
}

#aboutfeature {
  position: relative;
  margin-bottom: clamp(48px, 6.25vw, 80px);
}
@media screen and (max-width: 768px) {
  #aboutfeature {
    margin-bottom: 6.25vw;
  }
}
#aboutfeature .schoolbg {
  position: absolute;
  top: 0;
  right: 0;
  width: 95%;
  height: 100%;
  z-index: -1;
  background-image: url(../img/aboutbg2.svg);
  background-size: cover;
}
@media screen and (max-width: 768px) {
  #aboutfeature .schoolbg {
    width: 120%;
  }
}
#aboutfeature .container {
  display: flex;
  padding: clamp(24px, 3.125vw, 40px) 0;
}
@media screen and (max-width: 768px) {
  #aboutfeature .container {
    flex-direction: column;
    align-items: flex-start;
    padding: 6.25vw 3.125vw;
    gap: 3.75vw;
  }
}
#aboutfeature .container .school-thumb {
  width: clamp(216px, 28.125vw, 360px);
  margin-right: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  #aboutfeature .container .school-thumb {
    width: 80%;
    margin-right: 0;
    margin: 0 auto;
  }
}
#aboutfeature .container .school-text {
  width: calc(100% - clamp(230.4px, 30vw, 384px));
  font-size: 1.125rem;
  text-align: justify;
  line-height: 1.4em;
}
@media screen and (max-width: 768px) {
  #aboutfeature .container .school-text {
    width: 100%;
    font-size: 1rem;
  }
}
#aboutfeature .container .school-text h3 {
  font-size: 1.75rem;
  line-height: 1.4em;
  margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
  #aboutfeature .container .school-text h3 {
    font-size: 1.5rem;
  }
}
#aboutfeature .container .school-text > p {
  margin-bottom: 1em;
}
#aboutfeature .container .school-text > p span {
  color: #278948;
}

#aboutfeature2 {
  position: relative;
  margin-bottom: clamp(48px, 6.25vw, 80px);
}
@media screen and (max-width: 768px) {
  #aboutfeature2 {
    margin-bottom: 6.25vw;
  }
}
#aboutfeature2 .schoolbg {
  position: absolute;
  top: 0;
  left: 0;
  width: 95%;
  height: 100%;
  z-index: -1;
  background-image: url(../img/aboutbg3.svg);
  background-size: cover;
}
@media screen and (max-width: 768px) {
  #aboutfeature2 .schoolbg {
    width: 120%;
  }
}
#aboutfeature2 .container {
  display: flex;
  padding: clamp(24px, 3.125vw, 40px) 0;
}
@media screen and (max-width: 768px) {
  #aboutfeature2 .container {
    flex-direction: column;
    align-items: flex-start;
    padding: 6.25vw 3.125vw;
    gap: 3.75vw;
  }
}
#aboutfeature2 .container .school-thumb {
  width: clamp(216px, 28.125vw, 360px);
  margin-right: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  #aboutfeature2 .container .school-thumb {
    width: 80%;
    margin-right: 0;
    margin: 0 auto;
  }
}
#aboutfeature2 .container .school-text {
  width: calc(100% - clamp(230.4px, 30vw, 384px));
  font-size: 1.125rem;
  text-align: justify;
  line-height: 1.4em;
}
@media screen and (max-width: 768px) {
  #aboutfeature2 .container .school-text {
    width: 100%;
    font-size: 1em;
  }
}
#aboutfeature2 .container .school-text h3 {
  font-size: 1.75rem;
  line-height: 1.4em;
  margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
  #aboutfeature2 .container .school-text h3 {
    font-size: 1.5rem;
  }
}
#aboutfeature2 .container .school-text > p {
  margin-bottom: 1em;
}
#aboutfeature2 .container .school-text > p span {
  color: #278948;
}

.information {
  position: relative;
  background-image: url(../img/aboutbg4.svg);
  background-repeat: no-repeat;
  background-size: cover;
}
.information .container {
  padding-top: clamp(48px, 6.25vw, 80px);
  padding-bottom: clamp(48px, 6.25vw, 80px);
  text-align: center;
}
@media screen and (max-width: 768px) {
  .information .container {
    padding-top: 6.25vw;
    padding-bottom: 6.25vw;
  }
}
.information .information-list {
  margin-bottom: clamp(48px, 6.25vw, 80px);
  text-align: left;
}
@media screen and (max-width: 768px) {
  .information .information-list {
    margin-bottom: 6.25vw;
  }
}
.information .information-list h3 {
  font-size: 1.75rem;
  margin-top: clamp(19.2px, 2.5vw, 32px);
  margin-bottom: 0.4em;
}
@media screen and (max-width: 768px) {
  .information .information-list h3 {
    font-size: 1.5rem;
    margin-top: 5vw;
  }
}
.information .information-list dl {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  background-color: #ffffff;
  border: 1px solid #4B1F00;
}
.information .information-list dl dt {
  width: 30%;
  padding: clamp(4.8px, 0.625vw, 8px);
  border: 1px solid #4B1F00;
  line-height: 1.5em;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .information .information-list dl dt {
    padding: 0.625vw;
  }
}
.information .information-list dl dd {
  width: 70%;
  padding: clamp(4.8px, 0.625vw, 8px);
  border: 1px solid #4B1F00;
  line-height: 1.5em;
}
@media screen and (max-width: 768px) {
  .information .information-list dl dd {
    padding: 0.625vw;
  }
}

.schoollist-list .map {
  margin-bottom: clamp(38.4px, 5vw, 64px);
}
@media screen and (max-width: 768px) {
  .schoollist-list .map {
    margin-bottom: 10vw;
    margin-top: 10vw;
  }
}
.schoollist-list ul li {
  display: flex;
  gap: clamp(14.4px, 1.875vw, 24px);
  margin-bottom: clamp(38.4px, 5vw, 64px);
}
@media screen and (max-width: 768px) {
  .schoollist-list ul li {
    flex-direction: column;
    align-items: flex-start;
    gap: 3.75vw;
    width: 80%;
    margin: 0 auto;
    margin-bottom: 10vw;
  }
}
.schoollist-list ul li .map-thumb {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .schoollist-list ul li .map-thumb {
    width: 100%;
  }
}
.schoollist-list ul li .map-text {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .schoollist-list ul li .map-text {
    width: 100%;
  }
}
.schoollist-list ul li .map-text h3 {
  font-size: 1.75rem;
  line-height: 1;
  background-color: #4B1F00;
  color: #ffffff;
  padding: clamp(9.6px, 1.25vw, 16px) clamp(9.6px, 1.25vw, 16px);
  border-radius: 8px;
  margin-bottom: clamp(14.4px, 1.875vw, 24px);
}
@media screen and (max-width: 768px) {
  .schoollist-list ul li .map-text h3 {
    font-size: 1.25rem;
    padding: 2.5vw 2.5vw;
    margin-bottom: 3.75vw;
  }
}
.schoollist-list ul li .map-text .openmap {
  color: #278948;
  text-decoration: underline;
}
.schoollist-list ul li .map-text .openmap span {
  margin-left: clamp(4.8px, 0.625vw, 8px);
}
@media screen and (max-width: 768px) {
  .schoollist-list ul li .map-text .openmap span {
    margin-left: 1.25vw;
  }
}

.news-taglist-inner {
  display: flex;
  justify-content: center;
  gap: clamp(9.6px, 1.25vw, 16px);
  margin-bottom: clamp(33.6px, 4.375vw, 56px);
}
@media screen and (max-width: 768px) {
  .news-taglist-inner {
    gap: 2.5vw;
    margin-bottom: 4.375vw;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}
.news-taglist-inner li {
  padding: clamp(4.8px, 0.625vw, 8px);
  line-height: 1;
  border-radius: 8px;
  background-color: #7B7A79;
  color: #ffffff;
}
@media screen and (max-width: 768px) {
  .news-taglist-inner li {
    padding: 1.25vw 2.5vw;
    border-radius: 16px;
  }
}
.news-taglist-inner li.active {
  background-color: #FF9141;
  color: #ffffff;
}

.newslist ul {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: clamp(96px, 12.5vw, 160px);
}
@media screen and (max-width: 768px) {
  .newslist ul {
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 25vw;
  }
}
.newslist ul li {
  width: 30%;
  margin-right: clamp(14.4px, 1.875vw, 24px);
  background-color: #ffffff;
  border-radius: 8px;
  margin-bottom: clamp(14.4px, 1.875vw, 24px);
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .newslist ul li {
    width: 80%;
    margin-right: 0;
    margin: 0 auto;
    margin-bottom: 7.5vw;
  }
}
.newslist ul li:last-of-type {
  margin-right: 0;
}
@media screen and (max-width: 768px) {
  .newslist ul li:last-of-type {
    margin: 0 auto;
  }
}
.newslist ul li .news-thumb {
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
}
.newslist ul li .news-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}
.newslist ul li .news-text {
  padding: clamp(4.8px, 0.625vw, 8px) clamp(9.6px, 1.25vw, 16px) clamp(9.6px, 1.25vw, 16px) clamp(9.6px, 1.25vw, 16px);
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .newslist ul li .news-text {
    padding: 2.5vw 2.5vw 2.5vw 2.5vw;
  }
}
.newslist ul li .news-text time {
  line-height: 1;
  font-size: 0.875rem;
}
@media screen and (max-width: 768px) {
  .newslist ul li .news-text time {
    font-size: 0.875rem;
  }
}
.newslist ul li .news-text .news-tags {
  font-size: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(4.8px, 0.625vw, 8px);
  margin-bottom: clamp(4.8px, 0.625vw, 8px);
}
@media screen and (max-width: 768px) {
  .newslist ul li .news-text .news-tags {
    font-size: 0.875rem;
    gap: 1.25vw;
    margin-bottom: 1.25vw;
  }
}
.newslist ul li .news-text .news-tags .news-tag {
  padding: clamp(4.8px, 0.625vw, 8px);
  line-height: 1;
  border-radius: 8px;
  background-color: #F1E9B0;
}
.newslist ul li .news-text .news-tags .news-tag.news-all {
  background-color: #F1E9B0;
}
.newslist ul li .news-text .news-tags .news-tag.news-camp {
  background-color: #FF9141;
  color: #ffffff;
}
.newslist ul li .news-text p {
  font-size: 1.125rem;
}
@media screen and (max-width: 768px) {
  .newslist ul li .news-text p {
    font-size: 1.125rem;
  }
}

.single-outer {
  margin-top: clamp(96px, 12.5vw, 160px);
}
@media screen and (max-width: 768px) {
  .single-outer {
    margin-top: 12.5vw;
  }
}
.single-outer ul,
.single-outer ol,
.single-outer menu {
  list-style: initial;
  list-style-position: inside;
}
.single-outer .single-clamb {
  display: flex;
  align-items: center;
  gap: clamp(4.8px, 0.625vw, 8px);
  margin-bottom: clamp(28.8px, 3.75vw, 48px);
}
.single-outer .single-clamb p {
  margin-bottom: 0;
}
.single-outer .single-clamb.clamb-bottom {
  margin-top: clamp(36px, 4.6875vw, 60px);
  margin-bottom: clamp(72px, 9.375vw, 120px);
}
.single-outer .single-head .single-date {
  font-weight: 900;
  margin-bottom: clamp(14.4px, 1.875vw, 24px);
}
.single-outer .single-tag {
  display: flex;
  gap: clamp(4.8px, 0.625vw, 8px);
  flex-wrap: wrap;
  margin-bottom: clamp(21.6px, 2.8125vw, 36px);
}
.single-outer .single-tag .news-tag {
  padding: clamp(2.4px, 0.3125vw, 4px) clamp(4.8px, 0.625vw, 8px);
  border-radius: clamp(4.8px, 0.625vw, 8px);
  background-color: #F1E9B0;
}
.single-outer .single-tag .news-tag.news-camp {
  background-color: #FF9141;
  color: #ffffff;
}
.single-outer .single-tag .news-tag.news-all {
  background-color: #F1E9B0;
}
.single-outer h1 {
  font-size: 2.25rem;
  font-weight: 900;
  color: #4B1F00;
  margin-bottom: 1.4rem;
}
.single-outer h2 {
  font-size: 1.75rem;
  font-weight: 900;
  line-height: 1.4em;
  margin-bottom: 1.4rem;
}
.single-outer h3 {
  font-size: 1.5rem;
  line-height: 1.4em;
  margin-bottom: 1.4rem;
}
.single-outer h4 {
  font-size: 1.25rem;
  line-height: 1.4em;
  margin-bottom: 1.4rem;
}
.single-outer p {
  font-size: 1.125rem;
  line-height: 1.6em;
  margin-bottom: 1.4rem;
}
.single-outer p a {
  color: #FF9141;
  text-decoration: underline;
}
.single-outer ul,
.single-outer ol,
.single-outer menu {
  font-size: 1.125rem;
  line-height: 1.6em;
  margin-bottom: 1.4rem;
}
.single-outer figure {
  margin-bottom: 1.4rem;
}
.single-outer .single-placeholder img {
  margin-bottom: clamp(28.8px, 3.75vw, 48px);
  border-radius: clamp(7.2px, 0.9375vw, 12px);
  border: 4px solid #E65F05;
  height: auto;
}

body.contact {
  background-color: #F4F0EA;
}

body.privacy {
  background-color: #F4F0EA;
}

body.schoolnews {
  background-color: #F4F0EA;
}

.contact-container {
  margin: 0 auto;
  margin-top: clamp(144px, 18.75vw, 240px);
  margin-bottom: clamp(144px, 18.75vw, 240px);
  background-color: #ffffff;
  border: 4px solid #278948;
  border-radius: 16px;
  padding: clamp(28.8px, 3.75vw, 48px);
  width: 80%;
}
@media screen and (max-width: 768px) {
  .contact-container {
    margin-top: 18.75vw;
    margin-bottom: 18.75vw;
    width: 100%;
    padding: 3.75vw;
    border: 4px solid #278948;
  }
}
.contact-container .contact-container-line {
  width: 50%;
  height: 6px;
  margin: 0 auto;
  margin-top: clamp(4.8px, 0.625vw, 8px);
  margin-bottom: clamp(28.8px, 3.75vw, 48px);
}
@media screen and (max-width: 768px) {
  .contact-container .contact-container-line {
    width: 100%;
    margin-bottom: 7.5vw;
  }
}
@media screen and (max-width: 768px) {
  .contact-container .contact-container-line {
    height: 4px;
    margin-top: 1.875vw;
  }
}
.contact-container .contact-container-line img {
  width: 100%;
  height: 100%;
  vertical-align: text-top;
}
.contact-container h1 {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 900;
  color: #4B1F00;
}
.contact-container .smf-radio-buttons-control__control {
  display: flex;
  gap: clamp(9.6px, 1.25vw, 16px);
  flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  .contact-container .smf-radio-buttons-control__control {
    gap: 1.25vw;
  }
}
.contact-container .smf-radio-buttons-control__control .smf-label {
  width: 45%;
}
.contact-container .req .smf-item__label__text {
  position: relative;
}
.contact-container .req .smf-item__label__text::after {
  content: "必須";
  color: #FF9141;
  position: relative;
  top: 0;
  right: clamp(-9.6px, -1.25vw, -16px);
}
@media screen and (max-width: 768px) {
  .contact-container .req .smf-item__label__text::after {
    right: -1.25vw;
  }
}
.contact-container .smf-button-control .smf-button-control__control {
  position: relative;
  background-color: #278948;
  background-image: none;
  color: #ffffff;
  border: none;
  padding: clamp(10.8px, 1.40625vw, 18px) clamp(28.8px, 3.75vw, 48px);
  font-size: 1.25rem;
  cursor: pointer;
  border-radius: 36px;
}
@media screen and (max-width: 768px) {
  .contact-container .smf-button-control .smf-button-control__control {
    padding: 1.40625vw 3.75vw;
    font-size: 1rem;
  }
}

.privacy-policy-container {
  line-height: 1.8;
  color: #333;
  max-width: 800px;
  margin: 0 auto;
  padding: 20px 10px;
}

.privacy-policy-container h1 {
  font-size: 1.8rem;
  margin-bottom: 1.5rem;
  border-bottom: 2px solid #333;
  padding-bottom: 0.5rem;
}

.privacy-policy-container h2 {
  font-size: 1.3rem;
  margin-top: 0;
  margin-bottom: 1rem;
  color: #111;
}

.privacy-policy-container p {
  margin-bottom: 1rem;
}

.privacy-policy-container hr {
  margin: 2rem 0;
  border: 0;
  border-top: 1px solid #ccc;
}

/* 条文ごとの適切な間隔を設定 */
.policy-section {
  margin-bottom: 2.5rem;
}

/* リストのスタイル定義 */
.privacy-policy-container ol,
.privacy-policy-container ul {
  margin-top: 0.5rem;
  margin-bottom: 1rem;
  padding-left: 1.5rem;
}

.privacy-policy-container li {
  margin-bottom: 0.5rem;
}

/* 1. 2. 3. のスタイル */
.list-numeric {
  list-style-type: decimal;
}

/* a. b. c. のスタイル */
.list-alpha {
  list-style-type: lower-latin;
}

/* i. ii. iii. のスタイル */
.list-roman {
  list-style-type: lower-roman;
}

footer {
  position: relative;
  background-color: #A38977;
  color: #ffffff;
  padding: clamp(24px, 3.125vw, 40px) 0;
  font-size: 1rem;
}
@media screen and (max-width: 768px) {
  footer {
    padding: 6.25vw 0;
    font-size: 1rem;
  }
}
footer .footer-logo {
  width: clamp(144px, 18.75vw, 240px);
  margin-bottom: clamp(4.8px, 0.625vw, 8px);
}
@media screen and (max-width: 768px) {
  footer .footer-logo {
    width: 40.625vw;
    margin-bottom: 3.75vw;
  }
}
footer p {
  line-height: 1.5em;
  margin-bottom: clamp(24px, 3.125vw, 40px);
}
@media screen and (max-width: 768px) {
  footer p {
    margin-bottom: 3.125vw;
  }
}
footer nav {
  border-top: 2px solid #ffffff;
  padding-top: clamp(4.8px, 0.625vw, 8px);
  width: 50%;
}
@media screen and (max-width: 768px) {
  footer nav {
    padding-top: 3.125vw;
    width: 100%;
  }
}
footer .footer-bottom {
  margin-top: clamp(24px, 3.125vw, 40px);
  text-align: center;
  font-size: 0.875rem;
}
@media screen and (max-width: 768px) {
  footer .footer-bottom {
    font-size: 0.875rem;
    margin-top: 6.25vw;
  }
}/*# sourceMappingURL=style.css.map */