@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700;900&display=swap");
*,
*::before,
*::after {
  box-sizing: border-box;
}

ul,
ol {
  padding: 0;
}

body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
li,
figure,
figcaption,
blockquote,
dl,
dd {
  margin: 0;
}
p:empty{
  display: none;
}

body {
  min-height: 100vh;
  line-height: 1.5;
  scroll-behavior: smooth;
  text-rendering: optimizeSpeed;
}

ul,
ol {
  list-style: none;
}

a {
  text-decoration-skip-ink: auto;
}

img {
  display: block;
  max-width: 100%;
}

article > * + * {
  margin-top: 1em;
}

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

.posts {
    background-color: #ffffff;
}

@media (prefers-reduced-motion: reduce) {
  * {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}
/* fixed points */
/* break points */
/* queries */
@media all and (max-width: 800px) {
  .pc {
    display: none !important;
  }
}
@media all and (min-width: 801px) {
  .sp {
    display: none !important;
  }
}
.entry-inner {
  padding: 0 !important;
}

body.open {
  overflow: hidden;
}
body.open .entire header .drawer .overlay {
  visibility: visible;
  opacity: 1;
}
body.open .entire header .drawer .body {
  left: 0;
}

.entire {
  box-sizing: content-box;
  font-weight: 500;
  font-family: "Noto Serif", serif;
}
@media all and (min-width: 801px) {
  .entire {
    max-width: 1680px;
  }
}
@media all and (min-width: 801px) {
  .entire {
    margin-right: auto;
  }
}
@media all and (min-width: 801px) {
  .entire {
    margin-left: auto;
  }
}
@media all and (min-width: 801px) {
  .entire {
    padding: 0 4.6153846154vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire {
    padding: 0 60px;
  }
}
@media all and (min-width: 801px) {
  .entire {
    font-size: 1.2307692308vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire {
    font-size: 16px;
  }
}
@media all and (max-width: 800px) {
  .entire {
    font-size: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire {
    font-size: 20px;
  }
}
@media all and (min-width: 801px) {
  .entire {
    line-height: 1.5;
  }
}
@media all and (max-width: 800px) {
  .entire > *:not(nav) {
    margin-top: 6.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire > *:not(nav) {
    margin-top: 40px;
  }
}
.entire header {
  display: flex;
  flex-direction: column;
}
@media all and (max-width: 800px) {
  .entire header > *:not(.drawer) {
    margin-top: 6.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header > *:not(.drawer) {
    margin-top: 40px;
  }
}
@media all and (min-width: 801px) {
  .entire header .drawer {
    order: 2;
  }
}
.entire header .drawer .humberger {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding: 0;
  background-color: transparent;
  border: none;
  cursor: pointer;
}
@media all and (min-width: 801px) {
  .entire header .drawer .humberger {
    width: 3.4615384615vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .drawer .humberger {
    width: 45px;
  }
}
@media all and (max-width: 800px) {
  .entire header .drawer .humberger {
    width: 7.5vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .drawer .humberger {
    width: 45px;
  }
}
@media all and (min-width: 801px) {
  .entire header .drawer .humberger {
    height: 2.6923076923vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .drawer .humberger {
    height: 35px;
  }
}
@media all and (max-width: 800px) {
  .entire header .drawer .humberger {
    height: 5.8333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .drawer .humberger {
    height: 35px;
  }
}
@media all and (min-width: 801px) {
  .entire header .drawer .humberger {
    margin-top: 0.7692307692vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .drawer .humberger {
    margin-top: 10px;
  }
}
@media all and (max-width: 800px) {
  .entire header .drawer .humberger {
    margin-left: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .drawer .humberger {
    margin-left: 20px;
  }
}
.entire header .drawer .humberger span {
  width: 100%;
  background-color: #00489d;
}
@media all and (min-width: 801px) {
  .entire header .drawer .humberger span {
    height: 0.3076923077vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .drawer .humberger span {
    height: 4px;
  }
}
@media all and (max-width: 800px) {
  .entire header .drawer .humberger span {
    height: 0.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .drawer .humberger span {
    height: 4px;
  }
}
.entire header .drawer .humberger::before, .entire header .drawer .humberger::after {
  display: block;
  width: 100%;
  position: relative;
  content: "";
  background-color: #00489d;
}
@media all and (min-width: 801px) {
  .entire header .drawer .humberger::before, .entire header .drawer .humberger::after {
    height: 0.3076923077vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .drawer .humberger::before, .entire header .drawer .humberger::after {
    height: 4px;
  }
}
@media all and (max-width: 800px) {
  .entire header .drawer .humberger::before, .entire header .drawer .humberger::after {
    height: 0.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .drawer .humberger::before, .entire header .drawer .humberger::after {
    height: 4px;
  }
}
.entire header .drawer .body {
  transition: left 0.3s;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  height: 100%;
  position: fixed;
  top: 0;
  z-index: 1000;
  background-color: #00489d;
}
@media all and (min-width: 801px) {
  .entire header .drawer .body {
    width: 34.6153846154vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .drawer .body {
    width: 450px;
  }
}
@media all and (max-width: 800px) {
  .entire header .drawer .body {
    width: 66.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .drawer .body {
    width: 400px;
  }
}
@media all and (min-width: 801px) {
  .entire header .drawer .body {
    padding: 2.3076923077vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .drawer .body {
    padding: 30px;
  }
}
@media all and (max-width: 800px) {
  .entire header .drawer .body {
    padding: 5vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .drawer .body {
    padding: 30px;
  }
}
@media all and (min-width: 801px) {
  .entire header .drawer .body {
    left: -38.4615384615vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .drawer .body {
    left: -500px;
  }
}
@media all and (max-width: 800px) {
  .entire header .drawer .body {
    left: -83.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .drawer .body {
    left: -500px;
  }
}
.entire header .drawer .body .humberger {
  position: relative;
}
.entire header .drawer .body .humberger::before, .entire header .drawer .body .humberger::after {
  position: absolute;
  position: absolute;
  top: 50%;
  left: 50%;
  background-color: #fff;
}
.entire header .drawer .body .humberger::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.entire header .drawer .body .humberger::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.entire header .drawer .overlay {
  transition: opacity 0.3s;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  background-color: rgba(0, 0, 0, 0.5);
  visibility: hidden;
  opacity: 0;
}
.entire header .logo {
  margin-right: auto;
  margin-left: auto;
}
@media all and (min-width: 801px) {
  .entire header .logo {
    order: 3;
  }
}
@media all and (min-width: 801px) {
  .entire header .logo {
    width: 26.9230769231vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .logo {
    width: 350px;
  }
}
@media all and (max-width: 800px) {
  .entire header .logo {
    width: 70.8333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header .logo {
    width: 425px;
  }
}
@media all and (min-width: 801px) {
  .entire header .logo {
    margin-top: 1.9230769231vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header .logo {
    margin-top: 60px;
  }
}
.entire header p {
  margin: 0 auto;
  text-align: center;
}
@media all and (min-width: 801px) {
  .entire header p {
    order: 3;
  }
}
@media all and (max-width: 800px) {
  .entire header p {
    width: 91.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header p {
    width: 550px;
  }
}
@media all and (min-width: 801px) {
  .entire header p {
    margin-top: 2.3076923077vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header p {
    margin-top: 30px;
  }
}
@media all and (max-width: 800px) {
  .entire header p {
    margin-top: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header p {
    margin-top: 20px;
  }
}
@media all and (min-width: 801px) {
  .entire header p {
    font-size: 1.3846153846vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header p {
    font-size: 18px;
  }
}
.entire header p span {
  display: inline-block;
}
@media all and (max-width: 800px) {
  .entire header p span {
    margin-top: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header p span {
    margin-top: 20px;
  }
}
.entire header input {
  display: block;
  width: 97.5%;
  margin-right: auto;
  margin-left: auto;
}
@media all and (max-width: 800px) {
  .entire header input {
    padding: 1.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header input {
    padding: 10px;
  }
}
@media all and (max-width: 800px) {
  .entire header input {
    font-size: 3vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header input {
    font-size: 18px;
  }
}
@media all and (min-width: 801px) {
  .entire header nav {
    order: 1;
  }
}
@media all and (min-width: 801px) {
  .entire header nav {
    width: 89.2307692308vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header nav {
    width: 1160px;
  }
}
@media all and (max-width: 800px) {
  .entire header nav {
    width: 100%;
  }
}
@media all and (min-width: 801px) {
  .entire header nav {
    margin: 0 auto;
  }
}
@media all and (max-width: 800px) {
  .entire header nav {
    margin-top: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header nav {
    margin-top: 20px;
  }
}
@media all and (max-width: 800px) {
  .entire header nav {
    border-bottom: 2px solid #00419a;
  }
}
.entire header nav .list {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.entire header nav .list li {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media all and (min-width: 801px) {
  .entire header nav .list li {
    width: 12.8571428571%;
  }
}
@media all and (max-width: 800px) {
  .entire header nav .list li {
    width: 33.3333333333%;
  }
}
@media all and (min-width: 801px) {
  .entire header nav .list li {
    height: 2.5vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header nav .list li {
    height: 32.5px;
  }
}
@media all and (max-width: 800px) {
  .entire header nav .list li {
    height: 10.8333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire header nav .list li {
    height: 65px;
  }
}
@media all and (min-width: 801px) {
  .entire header nav .list li {
    font-size: 1.1538461538vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire header nav .list li {
    font-size: 15px;
  }
}
@media all and (min-width: 801px) {
  .entire header nav .list li {
    border-bottom: 2px solid #00419a;
  }
}
@media all and (max-width: 800px) {
  .entire header nav .list li:not(:last-of-type) {
    border-right: 1.5px solid rgba(0, 65, 154, 0.5);
  }
}
.entire header nav .list li a {
  color: black;
  text-decoration: none;
}
@media all and (max-width: 800px) {
  .entire .container {
    padding-right: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container {
    padding-right: 20px;
  }
}
@media all and (max-width: 800px) {
  .entire .container {
    padding-left: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container {
    padding-left: 20px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news {
    display: grid;
    grid-template-columns: 33.333% 66.666%;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news {
    margin-top: 2.3076923077vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news {
    margin-top: 30px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news h2 {
    grid-row: 1/2;
    grid-column: 1/2;
    text-align: left;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news h2 {
    font-size: 1.8461538462vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news h2 {
    font-size: 24px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .posts {
    display: flex;
    flex-direction: column;
    grid-row: 2/3;
    grid-column: 1/2;
    height: 85%;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .posts {
    gap: 1.5384615385vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .posts {
    gap: 20px;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .posts {
    padding-right: 3.0769230769vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .posts {
    padding-right: 40px;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .posts li > a {
    width: 7.6923076923vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .posts li > a {
    width: 100px;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .posts li > a {
    margin-right: 1.5384615385vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .posts li > a {
    margin-right: 20px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .posts li p {
    display: -webkit-box;
    overflow: hidden;
    position: relative;
    -webkit-box-orient: vertical;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .more {
    grid-row: 3/4;
    grid-column: 1/2;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .banner-wrapper {
    display: flex;
    flex-wrap: wrap;
    grid-row: 2/3;
    grid-column: 2/4;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .banner-wrapper {
    gap: 2.3076923077vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .banner-wrapper {
    gap: 30px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .banner-wrapper .banner {
    /* height: max-content; */
    aspect-ratio: 18/5;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .banner-wrapper .banner {
    width: calc(
          (100% - 2.3076923077vw)
            / 2
        );
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .banner-wrapper .banner {
    width: calc(
            (100% - 30px) / 2
          );
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .banner-wrapper .banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .search-box {
    grid-row: 3/4;
    grid-column: 2/4;
    width: 80%;
    margin-right: 0;
    margin-bottom: 0;
    margin-left: auto;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .search-box {
    margin-top: 2.3076923077vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .search-box {
    margin-top: 30px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .search-box input {
    width: 100%;
    border: 1px solid #cccccc;
    border-radius: 2.5px;
    outline: none;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .search-box input {
    height: 3.0769230769vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .search-box input {
    height: 40px;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) {
  .entire .container.news .search-box input {
    padding-left: 0.7692307692vw;
  }
}
@media all and (min-width: 801px) and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.news .search-box input {
    padding-left: 10px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.news .search-box input:focus {
    border-color: #666666;
  }
}
.entire .container h2 {
  font-weight: 500;
  text-align: center;
}
@media all and (max-width: 800px) {
  .entire .container h2 {
    font-size: 7.5vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container h2 {
    font-size: 45px;
  }
}
@media all and (max-width: 800px) {
  .entire .container .posts {
    margin-top: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container .posts {
    margin-top: 20px;
  }
}
.entire .container .posts li {
  display: flex;
}
@media all and (max-width: 800px) {
  .entire .container .posts li {
    column-gap: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container .posts li {
    column-gap: 20px;
  }
}
.entire .container .posts li a {
  color: black;
}
.entire .container .posts li > a {
  width: 25%;
}
.entire .container .posts li > a img {
  object-fit: cover;
  aspect-ratio: 1/1!important;
}
.entire .container .posts li .description {
  width: 75%;
}
@media all and (max-width: 800px) {
  .entire .container .posts li .description time {
    font-size: 3vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container .posts li .description time {
    font-size: 18px;
  }
}
.entire .container .posts li .description .link-more {
  display: none;
}
.entire .container .posts li .description .link-more a {
  display: block;
  text-align: right;
}
@media all and (max-width: 800px) {
  .entire .container .posts li:not(:first-of-type) {
    margin-top: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container .posts li:not(:first-of-type) {
    margin-top: 20px;
  }
}
.entire .container hr {
  margin-bottom: 0;
}
@media all and (max-width: 800px) {
  .entire .container > *:not(h2, .posts) {
    margin-top: 8.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container > *:not(h2, .posts) {
    margin-top: 50px;
  }
}
.entire .container .more {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 250px;
  margin-right: auto;
  margin-left: auto;
  background-color: #8f8142;
  border: 0;
  outline: none;
}
@media all and (min-width: 801px) {
  .entire .container .more {
    width: 19.2307692308vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container .more {
    width: 250px;
  }
}
@media all and (max-width: 800px) {
  .entire .container .more {
    width: 41.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container .more {
    width: 250px;
  }
}
@media all and (min-width: 801px) {
  .entire .container .more {
    height: 4.2307692308vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container .more {
    height: 55px;
  }
}
@media all and (max-width: 800px) {
  .entire .container .more {
    height: 10.8333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container .more {
    height: 65px;
  }
}
@media all and (min-width: 801px) {
  .entire .container .more {
    margin-top: 0.7692307692vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container .more {
    margin-top: 10px;
  }
}
.entire .container .more a {
  color: white;
  text-decoration: none;
}
.entire .container.contents {
  position: relative;
}
@media all and (min-width: 801px) {
  .entire .container.contents {
    margin-top: 11.5384615385vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents {
    margin-top: 150px;
  }
}
.entire .container.contents .divide {
  width: 0.5px;
  height: 100%;
  position: absolute;
  top: 0;
  left: 50%;
  background-color: #cccccc;
  transform: translateX(-50%);
}
.entire .container.contents:not(.bottom) {
  display: flex;
}
@media all and (min-width: 801px) {
  .entire .container.contents:not(.bottom) {
    gap: 3.0769230769vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents:not(.bottom) {
    gap: 40px;
  }
}
@media all and (max-width: 800px) {
  .entire .container.contents:not(.bottom) {
    gap: 6.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container.contents:not(.bottom) {
    gap: 40px;
  }
}
.entire .container.contents.bottom, .entire .container.contents > *:not(.bottom) section {
  position: relative;
}
.entire .container.contents.bottom::before, .entire .container.contents > *:not(.bottom) section::before {
  display: block;
  pointer-events: none;
  content: "";
}
@media all and (min-width: 1200px) {
  .entire .container.contents.bottom::before, .entire .container.contents > *:not(.bottom) section::before {
    height: 50px;
  }
}
@media all and (min-width: 1200px) {
  .entire .container.contents.bottom::before, .entire .container.contents > *:not(.bottom) section::before {
    margin-top: -50px;
  }
}
.entire .container.contents .rows {
  width: 50%;
}
@media all and (min-width: 801px) {
  .entire .container.contents .rows section:not(:first-of-type) {
    margin-top: 15.3846153846vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents .rows section:not(:first-of-type) {
    margin-top: 200px;
  }
}
.entire .container.contents h3 {
  line-height: 1;
  border-bottom: 1px solid #000;
}
@media all and (min-width: 801px) {
  .entire .container.contents h3 {
    padding-bottom: 0.3846153846vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents h3 {
    padding-bottom: 5px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.contents h3 {
    font-size: 3.4615384615vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents h3 {
    font-size: 45px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.contents h3 + p {
    margin-top: 0.7692307692vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents h3 + p {
    margin-top: 10px;
  }
}
.entire .container.contents .header {
  display: flex;
  align-items: center;
}
.entire .container.contents .header .section-icon {
  position: relative;
}
.entire .container.contents .header .section-icon .title {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  color: white;
  text-align: center;
  transform: translate(-50%, -50%);
}
@media all and (min-width: 801px) {
  .entire .container.contents .header .section-icon .title {
    font-size: 3.2692307692vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents .header .section-icon .title {
    font-size: 42.5px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.contents .header .section-icon .title {
    line-height: 1.25;
  }
}
@media all and (min-width: 801px) {
  .entire .container.contents .header p {
    margin-left: 2.3076923077vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents .header p {
    margin-left: 30px;
  }
}
.entire .container.contents .banner-wrapper {
  display: flex;
  flex-direction: column;
}
@media all and (min-width: 801px) {
  .entire .container.contents .banner-wrapper {
    gap: 1.5384615385vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents .banner-wrapper {
    gap: 20px;
  }
}
@media all and (max-width: 800px) {
  .entire .container.contents .banner-wrapper {
    gap: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .container.contents .banner-wrapper {
    gap: 20px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.contents .banner-wrapper {
    margin-top: 1.5384615385vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents .banner-wrapper {
    margin-top: 20px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.contents .banner-wrapper .banner {
    font-size: 1.8461538462vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents .banner-wrapper .banner {
    font-size: 24px;
  }
}
.entire .container.contents.bottom {
  position: relative;
}
.entire .container.contents.bottom h3 {
  display: block;
  width: max-content;
  margin: 0 auto;
  text-align: center;
  background-clip: content-box;
}
@media all and (min-width: 801px) {
  .entire .container.contents.bottom h3 {
    padding: 0 1.5384615385vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents.bottom h3 {
    padding: 0 20px;
  }
}
.entire .container.contents.bottom p {
  text-align: center;
}
@media all and (min-width: 801px) {
  .entire .container.contents.bottom .banner-wrapper {
    margin-top: 4.6153846154vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents.bottom .banner-wrapper {
    margin-top: 60px;
  }
}
@media all and (min-width: 801px) {
  .entire .container.contents.bottom .banner-wrapper .column .banner {
    width: calc(
          (100% - 3.0769230769vw)
            / 3
        );
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .container.contents.bottom .banner-wrapper .column .banner {
    width: calc(
            (100% - 40px) / 3
          );
  }
}
@media all and (max-width: 800px) {
  .entire .banner-wrapper > *:not(:first-of-type) {
    margin-top: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .banner-wrapper > *:not(:first-of-type) {
    margin-top: 20px;
  }
}
.entire .banner-wrapper .banner {
  position: relative;
}
@media all and (min-width: 801px) {
  .entire .banner-wrapper .banner:not(.full) {
    width: calc(
          (100% - 1.5384615385vw)
            / 2
        );
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .banner-wrapper .banner:not(.full) {
    width: calc(
            (100% - 20px) / 2
          );
  }
}
@media all and (max-width: 800px) {
  .entire .banner-wrapper .banner:not(.full) {
    width: calc(
          (100% - 3.3333333333vw)
            / 2
        );
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .banner-wrapper .banner:not(.full) {
    width: calc(100% - 20px) / 2;
  }
}
.entire .banner-wrapper .banner p {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  color: white;
  text-align: center;
  text-shadow: 0 0 4px black, 0 0 4px black, 0 0 4px black;
  transform: translate(-50%, -50%);
  opacity: 1 !important;
}
.entire .banner-wrapper .banner img {
  width: 100%;
}
.entire .banner-wrapper .banner:hover::before {
  background-color: rgba(255, 255, 255, 0.35);
}
.entire .banner-wrapper .banner::before {
  transition: background-color 0.3s;
  width: 100%;
  height: 100%;
  pointer-events: none;
  position: absolute;
  content: "";
  background-color: rgba(255, 255, 255, 0);
  cursor: pointer;
}
.entire .banner-wrapper .column {
  display: flex;
  flex-wrap: wrap;
}
@media all and (min-width: 801px) {
  .entire .banner-wrapper .column {
    gap: 1.5384615385vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .banner-wrapper .column {
    gap: 20px;
  }
}
@media all and (max-width: 800px) {
  .entire .banner-wrapper .column {
    gap: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .banner-wrapper .column {
    gap: 20px;
  }
}
.entire .banner-wrapper .keen-slider {
  position: relative;
}
.entire .banner-wrapper .keen-slider .controls {
  width: 100%;
  height: 100%;
  position: absolute;
}
.entire .banner-wrapper .keen-slider .controls button {
  padding: 0;
  pointer-events: auto;
  position: absolute;
  top: 50%;
  z-index: 1;
  color: white;
  font-weight: bold;
  background-color: transparent;
  background-color: rgba(0, 0, 0, 0.5);
  border: 0;
  transform: translateY(-50%) scaleY(1.4);
  cursor: pointer;
}
@media all and (min-width: 801px) {
  .entire .banner-wrapper .keen-slider .controls button {
    padding: 0.7692307692vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .banner-wrapper .keen-slider .controls button {
    padding: 10px;
  }
}
@media all and (max-width: 800px) {
  .entire .banner-wrapper .keen-slider .controls button {
    padding: 1.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .banner-wrapper .keen-slider .controls button {
    padding: 10px;
  }
}
@media all and (min-width: 801px) {
  .entire .banner-wrapper .keen-slider .controls button {
    font-size: 1.9230769231vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire .banner-wrapper .keen-slider .controls button {
    font-size: 25px;
  }
}
@media all and (max-width: 800px) {
  .entire .banner-wrapper .keen-slider .controls button {
    font-size: 4.1666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire .banner-wrapper .keen-slider .controls button {
    font-size: 25px;
  }
}
.entire .banner-wrapper .keen-slider .controls button.prev {
  left: 0;
}
.entire .banner-wrapper .keen-slider .controls button.next {
  right: 0;
}
.entire footer {
  text-align: center;
}
@media all and (min-width: 801px) {
  .entire footer {
    display: grid;
  }
}
@media all and (min-width: 801px) {
  .entire footer {
    grid-template-columns: 25% 10% 65%;
  }
}
@media all and (min-width: 801px) {
  .entire footer {
    margin-top: 5.7692307692vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire footer {
    margin-top: 75px;
  }
}
@media all and (min-width: 801px) {
  .entire footer {
    padding: 2.6923076923vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire footer {
    padding: 35px;
  }
}
@media all and (min-width: 801px) {
  .entire footer {
    background-color: #333333;
  }
}
@media all and (max-width: 800px) {
  .entire footer > *:not(small) {
    margin-top: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire footer > *:not(small) {
    margin-top: 20px;
  }
}
.entire footer .logo {
  grid-row: 1/3;
  grid-column: 1/2;
}
@media all and (max-width: 800px) {
  .entire footer .logo {
    width: 41.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire footer .logo {
    width: 250px;
  }
}
@media all and (max-width: 800px) {
  .entire footer .logo {
    margin-left: auto;
  }
}
@media all and (max-width: 800px) {
  .entire footer .logo {
    margin-right: auto;
  }
}
.entire footer .menu {
  grid-row: 1/2;
  grid-column: 3/4;
}
.entire footer .menu nav ul {
  display: flex;
  list-style: none;
}
@media all and (min-width: 801px) {
  .entire footer .menu nav ul {
    gap: 3.0769230769vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire footer .menu nav ul {
    gap: 40px;
  }
}
@media all and (min-width: 801px) {
  .entire footer .menu nav ul {
    justify-content: flex-end;
  }
}
.entire footer .menu nav ul li a {
  color: white;
  font-weight: 200;
  text-decoration: none;
}
@media all and (min-width: 801px) {
  .entire footer .menu nav ul li a {
    font-size: 1.4230769231vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire footer .menu nav ul li a {
    font-size: 18.5px;
  }
}
.entire footer small {
  grid-row: 3/4;
  grid-column: 3/4;
}
@media all and (min-width: 801px) {
  .entire footer small {
    display: block;
  }
}
@media all and (min-width: 801px) {
  .entire footer small {
    color: white;
  }
}
@media all and (min-width: 801px) {
  .entire footer small {
    font-size: 1.5384615385vw;
  }
}
@media all and (min-width: 801px) and (min-width: 1300px) {
  .entire footer small {
    font-size: 20px;
  }
}
@media all and (min-width: 801px) {
  .entire footer small {
    text-align: right;
  }
}
.entire footer hr {
  border: 0;
  border-bottom: 3px solid #cccccc;
}
.entire footer small {
  display: inline-block;
}
@media all and (max-width: 800px) {
  .entire footer small {
    margin-top: 8.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire footer small {
    margin-top: 50px;
  }
}
@media all and (max-width: 800px) {
  .entire footer small {
    margin-bottom: 3.3333333333vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire footer small {
    margin-bottom: 20px;
  }
}
@media all and (max-width: 800px) {
  .entire footer small {
    font-size: 2.6666666667vw;
  }
}
@media all and (max-width: 800px) and (min-width: 600px) {
  .entire footer small {
    font-size: 16px;
  }
}

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


.news_first{
  width: calc( (100% - 30px) / 2 );
  margin:0 auto;
  text-align:center;
}
.news_first h2{
  text-align:center!important;
}


#recentPosts {
  height: auto;
}

.entire .container.news .posts li p {
  font-size: 0.8vw;
}








