/* Theme Name: Cultime Theme Theme URI: https://github.com/wayne930242/cultime/tree/main Author: Hanyu and Weihung Description: The theme of Cultime.co's officail site. Requires at least: 6.1 Tested up to: 6.2 Requires PHP: 5.6 Version: 0.0.1 License: All Rights Preserved Text Domain: cultimetheme Tags: private */
.page-title {
  width: auto;
}

.page-title .wp-block-post-title {
  text-align: center;
  display: block;
  margin-block-end: 0.5em;
}

@media screen and (max-width: 1100px) {
  .wp-block-gallery.has-nested-images figure.wp-block-image:not(#individual-image) {
    width: 100% !important;
  }


  .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image):first-child:nth-last-child(2),
  .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image):first-child:nth-last-child(2)~figure.wp-block-image:not(#individual-image) {
    width: 100% !important;
  }
}

.wp-block-image img {
  width: 100%;
  height: auto;
}

.wp-block-gallery.has-nested-images figure.wp-block-image:not(#individual-image) {
  margin-top: 20px !important;
}

.wp-block-gallery.wp-block-gallery-2 {
  row-gap: 0 !important;
}

.is-layout-flex figure {
  row-gap: 0 !important;
}

.lb-dataContainer {
  padding-top: 22px !important;
}

.lb-close {
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

.lb-nav a.lb-next {
  background: url('assets/images/next.svg') right 48% no-repeat !important;
}

.lb-nav a.lb-prev {
  background: url('assets/images/prev.svg') left 48% no-repeat !important;
}

body {
  font-family: var(--wp--preset--font-family--noto-sans-tc);
  letter-spacing: 0.1rem;
  -webkit-text-size-adjust: 100%;
}

@media screen and (max-width: 600px) {
  #wpadminbar {
    position: fixed;
  }
}

a:where(:not(.wp-element-button)) {
  text-decoration: none;
}

.wp-site-blocks {
  padding-top: 0;
  position: relative;
}

:where(body .is-layout-constrained)>* {
  margin-block-start: 0.5rem;
  margin-block-end: 0.5rem;
}

@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  src: url('./assets/fonts/montserrat/Montserrat-Light.ttf') format('truetype');
}

.font-montserrat {
  font-family: Montserrat;
}

.wp-block-navigation__responsive-container.is-menu-open {
  padding: 20px 15px 20px 15px;
}

#modal-1-content>div.wp-block-group.header-pop-up.is-layout-flow.wp-block-group-is-layout-flow>figure>a {
  padding-left: 0;
  padding-right: 0;
}

#modal-1-content>div.wp-block-group.header-pop-up.is-layout-flow.wp-block-group-is-layout-flow>figure>a>img {
  margin-left: -6px;
}

html,
body {
  overflow-x: hidden;
  width: 100vw;
  height: 100%;
  margin: 0;
  padding: 0;
}

body {
  overflow-y: scroll;
}

html {
  overflow-y: hidden;
}

main,
footer {
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--wp--style--root--padding-left);
  padding-right: var(--wp--style--root--padding-right);
  max-width: var(--wp--style--global--wide-size);
}

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

  main,
  footer {
    padding-left: 20px;
    padding-right: 20px;
  }
}

.entry-content {
  margin-top: 24px;
}

.wp-block-button a {
  text-decoration: none;
}

.wp-block-button a:hover {
  text-decoration: none;
}

a {
  text-underline-offset: 5px;
  text-decoration-thickness: 1px;
}

a:hover {
  text-decoration: underline 1.5px;
  text-underline-offset: 5px;
}

h1 {
  font-weight: 500;
}

.wp-block-post-title {
  font-weight: 500;
  line-height: 135%;
}

h2 {
  font-size: 28px;
  margin-block-start: 0.83em;
  margin-block-end: 0.83em;
}

h3 {
  font-size: 20px;
  margin-block-start: 1.5em;
  margin-block-end: 1.5em;
}

h4 {
  font-size: var(--wp--preset--font-size--medium);
  font-weight: 500;
  letter-spacing: 1.6px;
  text-align: center;
}

p {
  margin-block-start: 1.5rem;
  font-size: 16px;
  line-height: 175%;
}

@media screen and (max-width: 1100px) {
  p {
    font-size: 14px;
  }
}

header {
  z-index: 10;
  height: 92px;
  position: relative;

  >div {
    height: 92px;
  }
}

#my-header {
  z-index: 10;
  height: 92px;
  position: fixed;
  width: 100%;
  background-color: var(--wp--preset--color--base);
  overflow: visible;
}

#my-header .my-header-container {
  max-width: var(--wp--style--global--wide-size);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--wp--style--root--padding-left);
  padding-right: var(--wp--style--root--padding-right);
}

#my-header .my-header-container>div {
  display: flex;
  justify-content: center;
  flex-grow: 1;
  flex-direction: column;
  width: 100%;
  height: 82px;
}

@media screen and (max-width: 1100px) {
  body.home #header-hr {
    color: transparent;
  }

  header {
    height: 73px;

    >div {
      height: 73px;
    }
  }

  #my-header {
    height: 73px;
  }

  #my-header .my-header-container {
    padding-left: 20px;
    padding-right: 20px;
  }

  #my-header .my-header-container>div {
    height: 73px;
  }
}

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

.header-content>nav {
  margin-block-start: 0;
}

#my-navbar>div {
  margin-block-start: 0;
}

#my-navbar .bold-nav-item {
  font-weight: 500;
}

#my-navbar>div>a:hover,
#my-navbar>div>a.is-active {
  text-decoration: underline;
  text-underline-offset: 5px;
}


.fixed-vertical-label {
  display: flex;
  gap: 30px;
  position: absolute;
  top: calc(100% + 488px);
  right: -350px;
  transform: translateY(-50%) rotate(90deg);
  transform-origin: top right;
  z-index: 999;
  font-size: 14px;
}

.vertical-label {
  font-size: 14px;
  pointer-events: auto;
  font-family: Montserrat;
  font-weight: 300;
  text-decoration: none;
}

.fixed-vertical-label a:link {
  text-decoration: none
}

@media screen and (max-width: 600px) {
  .fixed-vertical-label {
    display: none;
  }
}

/* header pop up */
.header-pop-up {
  display: flex;
}

.wp-block-navigation:not(.has-background) .wp-block-navigation__responsive-container.is-menu-open {
  background-color: #F1F1F1;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
  padding-top: 0;
}

.wp-block-navigation__responsive-container-content {
  align-items: center !important;
  gap: 1.5rem;
}

#my-navbar {
  display: flex;
  justify-content: left;
  align-items: center;
  flex-direction: column;
  font-weight: 300;
  letter-spacing: 1.6px;
  gap: 1.5rem;
}

.menu-item-sub-menu {
  gap: 2rem;
}

.menu-item-sub-group {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-block-start: 0;
}

.menu-item-sub {
  color: #666;
  font-size: 0.875rem;
  text-decoration: underline #666;
  text-underline-offset: 5px;
  margin-block-start: 0;
}

.menu-item-sub>a:hover {
  color: #000;
  text-decoration: underline #000 1.5px;
}

.header-button-group {
  width: 100%;
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 1.2px;
  gap: 2rem;
}

.header-button-group>div,
.header-button-group hr {
  margin-block-start: 0;
}

.header-button-group #crazy-mode-button-group {
  font-family: Montserrat;
  font-weight: 300;
  letter-spacing: 0.6px;
}

.header-button-group>.cultime-contact-button {
  cursor: pointer;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 1.6px;
}

.header-pop-up-social-link {
  font-size: 1.3rem;
  margin-block-start: 0;
}

.wp-block-separator {
  max-width: unset;
}

.wp-element-button {
  background-color: var(--wp--preset--color--base) !important;
  color: var(--wp--preset--color--black) !important;
  font-size: 12px;
}

.wp-element-button.is-active {
  background-color: var(--wp--preset--color--contrast) !important;
  color: var(--wp--preset--color--white) !important;
}

@media (hover: hover) {
  .wp-block-button__link:not(.is-active):hover {
    background-color: var(--wp--preset--color--orange) !important;
  }
}

.state-block {
  visibility: hidden;
  width: 0;
  height: 0;
}

/* contact form */
.jquery-modal.blocker.current {
  z-index: 1000;
  padding: 0;
  text-align: right;
}

#contact-form-modal {
  max-width: 889px;
  padding: 3rem;
  background-color: black;
  color: white;
  height: min-content;
  font-size: 16px;
  line-height: 185%;
  letter-spacing: 1.6px;
  white-space: nowrap;
  overflow: hidden;
  width: 100%;
  z-index: 1001;
  vertical-align: top;
  border-radius: 0;
  -moz-border-radius: 0;
  -webkit-border-radius: 0;
  -o-border-radius: 0;
  -ms-border-radius: 0;
  text-align: unset;
}

#contact-form-modal .close-modal {
  display: none;
}

/* contact form */
.contact-form-block input[type="month"]::-webkit-calendar-picker-indicator {
  filter: invert(1);
}

.contact-form-block-layout {
  display: flex;
  position: relative;
}

.contact-form-layout {
  display: flex;
  width: 100%;
}

.contact-form-title-block {
  flex-grow: 1;
  max-width: 225px;
}

.contact-form-content-block {
  flex-grow: 1;
  padding-left: 60px;
  padding-right: 120px;
}

.contact-form-block .submit-container {
  display: flex;
  justify-content: flex-end;
  margin-top: 40px;
  margin-right: 50px;
}

#contact-form-message.is-success {
  color: white;
}

#contact-form-message.is-error {
  color: lightpink;
}

.input-group {
  position: relative;
  margin-top: 8px;
}

.input-group label {
  position: absolute;
  bottom: 10px;
  left: 0;
  font-size: 16px;
  line-height: 185%;
  letter-spacing: 1.6px;
  color: var(--wp--preset--color--white);
  transition: all 0.3s;
}

.textarea-group {
  position: relative;
  margin-top: 8px;
}

.textarea-group label {
  position: absolute;
  bottom: 11px;
  left: 0;
  font-size: 16px;
  line-height: 185%;
  letter-spacing: 1.6px;
  color: var(--wp--preset--color--white);
  transition: all 0.3s;
}

.input-group input {
  width: 100%;
  height: 50px;
  font-size: 16px;
  line-height: 185%;
  text-align: end;
  background-color: black;
  color: #FFF;
  border: 0;
  outline: none;
  border-bottom: solid 1px var(--wp--preset--color--white);
  margin: 0;
}

.textarea-group textarea {
  font-family: Arial, Helvetica, sans-serif;
  width: 100%;
  min-height: 50px;
  height: 50px;
  font-size: 16px;
  text-align: end;
  vertical-align: bottom;
  padding-top: 16px;
  padding-left: 7em;
  padding-bottom: 5px;
  background-color: black;
  color: #FFF;
  border: 0;
  outline: none;
  border-bottom: solid 1px var(--wp--preset--color--white);
  margin: 0;
  overflow: hidden;
  resize: none;
}

.select-group {
  margin-top: 9px;
  border-bottom: solid 1px var(--wp--preset--color--white);
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.select-group select {
  position: relative;
  border-bottom: solid 1px var(--wp--preset--color--white);
  width: 12rem;
  background-color: black;
  color: var(--wp--preset--color--option);
  font-weight: 500;
  font-size: 12px;
  border: 0;
  outline: none;
  text-align: center;
  margin: 0;
}

.select-group option {
  background-color: black;
  color: var(--wp--preset--color--option);
  font-size: 12px;
  font-weight: 500;
}

.months-select-group {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  border-bottom: solid 1px var(--wp--preset--color--white);
  height: 50px;
  margin-top: 9px;
}

.months-select-group .months-select-group-inputs {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

.months-select-group .month-input-group {
  display: flex;
  flex-grow: 1;
}

.months-select-group label {
  font-size: 12px;
  flex-grow: 0;
  color: var(--wp--preset--color--option);
  font-weight: 500;
  height: 30px;
  line-height: 30px;
}

.months-select-group input {
  font-size: 12px;
  font-weight: 500;
  line-height: 28px;
  vertical-align: middle;
  text-align: end;
  flex-grow: 1;
  max-width: 4rem;
  background-color: black;
  color: #FFF;
  border: 0;
  outline: none;
  margin: 0;
  height: 30px;
}

.contact-form-title {
  font-size: var(--wp--preset--font-size--large);
  font-weight: 500;
  margin-block-start: 1.6rem;
}

.contact-form-mobile {
  display: none;
}

@media screen and (max-width: 889px) {
  .contact-form-block.is-open {
    left: 0;
  }

  .contact-form-layout {
    flex-direction: column;
  }

  .contact-form-layout .contact-form-content-block {
    padding-left: 0;
    padding-right: 0;
  }

  .months-select-group {
    height: 100px;
    align-items: flex-end;
  }

  .months-select-group .months-select-label {
    margin-bottom: 33px;
  }

  .months-select-group .months-select-group-inputs {
    flex-direction: column;
    gap: 0;
    justify-content: flex-end;
  }

  .contact-form-block .submit-container {
    display: flex;
    margin-top: 0;
    margin-right: auto;
    margin-left: auto;
    justify-content: center;
    align-items: center;
  }
}

#contact-form-submit {
  width: 83px;
  height: 47px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 25px;
  background: #E5E5E5;
  font-size: var(--wp--preset--font-size--normal);
  font-weight: 500;
}

.contact-form-close-buttun {
  display: flex;
  width: 100%;
  justify-content: flex-end;
  align-items: center;
}

.contact-form-close-buttun>svg {
  margin-block-start: 0;
}

.contact-form-desktop {
  color: #FFF;
  font-family: Montserrat;
  cursor: pointer;
}

@media screen and (max-width: 889px) {
  .contact-form-desktop {
    display: none;
  }

  .contact-form-mobile {
    display: block;
  }

  .contact-form-title {
    font-size: var(--wp--preset--font-size--normal);
    letter-spacing: 1.6px;
    font-weight: 600;
  }

  .contact-form-block select {
    width: 10rem;
  }

  .contact-form-close {
    width: 24px;
    height: 24px;
  }

  #contact-form-submit {
    width: 89px;
    height: 35px;
    font-size: 0.8rem;
    letter-spacing: 1.4px;
  }
}

/* FOOTER */
@media screen and (max-width: 796px) {
  .footer-logo {
    width: 150px;
    height: auto;
  }
}


#footer-right-part {
  flex: 1;
  gap: 1rem;
  padding-left: 8rem;
}

#footer-nav {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 0.5rem;
}

#footer-info {
  gap: 6rem;
}

footer {
  padding-bottom: 14px;
}

footer .wp-block-social-link {
  color: #666666
}

footer .wp-block-social-link:hover {
  color: #9D9D9D;
}

/* footer nav 比照 header nav 樣式 */
.wp-block-footer-nav {
  font-weight: 300;
  word-break: keep-all;
  margin: 0;
}

.wp-block-footer-nav a {
  text-decoration: none;
}

.wp-block-footer-nav a:hover {
  text-decoration: underline;
}

/* footer social link color */
.wp-block-social-link {
  color: #666;
}

/* about survice */
.about-survice-row {
  display: grid;
  grid-template-columns: 1fr 1px 1fr 1px 1fr;
  margin: 3rem 0;
  gap: 3rem 0;
}

.about-survice-row .divider {
  width: 1px;
  background-color: #000;
  margin: 0;
}

.about-survice-cell {
  flex-basis: 20rem;
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: center;
  text-align: center;
  line-height: 175%;
  /* 28px */
  letter-spacing: 1.6px;
  padding: 0 30px;
  margin: 0;
}

.about-survice-row a:hover {
  text-decoration: none;

  .about-survice-cell-title {
    text-decoration: underline 1.5px;
    text-underline-offset: 5px;
  }
}

.about-survice-cell-img {
  height: 10rem;
  display: flex;
  align-items: center;
}

.about-survice-cell p {
  margin: 0 0 0.5rem 0;
  font-weight: 300;
}

.about-survice-cell .about-survice-cell-title {
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: 2px;
}

.about-survice-cell-text {
  text-decoration: none !important;
}

@media (max-width: 694px) {

  /* 手機版 about */
  #about-title-block {
    flex-direction: column;
    padding: 0;
  }

  #about-title-block>.about-description-block {
    width: clamp(80%, 400px, 100%);
  }

  .about-survice-title {
    text-align: center;
  }

  .about-survice-row {
    display: flex;
    flex-direction: column;
    margin: 0;
    gap: 0;
  }

  .about-survice-row .divider {
    display: none;
  }

  .about-survice-cell {
    flex-basis: auto;
    flex-direction: row;
    padding: 1.5rem 0 0 0;
  }

  .about-survice-cell-img {
    height: fit-content;
    min-width: 7rem;
    display: flex;
    justify-content: center;
  }

  .about-survice-cell-img img {
    height: 4rem;
    max-width: none;
  }

  .about-survice-row hr {
    display: none;
  }

  .about-survice-cell-text {
    text-align: justify;
    padding-left: 2rem;
    margin: 0;
  }
}

/* Redeclare the breakpoint for header */
@media (min-width: 1100px) {
  .header-pop-up {
    display: none;
  }

  #my-navbar {
    flex-direction: row !important;
    gap: 0 !important;
  }

  .header-button-group {
    width: fit-content !important;
    flex-direction: row !important;
    justify-content: space-between !important;
  }

  .header-button-group>.cultime-contact-button {
    font-weight: 500 !important;
  }

  .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: none !important;
  }

  .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
    display: block !important;
    width: 100%;
    position: relative;
    z-index: auto;
    background-color: inherit;
  }

  .wp-container-1.wp-container-1,
  .wp-container-4.wp-container-4,
  .wp-container-8.wp-container-8 {
    flex-grow: 1;
    padding-left: var(--wp--preset--spacing--30);
  }
}

/* contact-form */
#contact-form-block-6 {
  padding-right: var(--wp--preset--spacing--60);
  margin-top: -0.5rem;
  white-space: nowrap;
}

/* Redeclare the breakpoint for header */
@media (min-width: 1100px) {
  #contact-form-block-7 {
    padding-left: var(--wp--preset--spacing--50);
    margin-top: 0;
  }

  /* FOOTER */
  #footer-content {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.5rem !important;
  }


  #footer-info {
    padding-right: var(--wp--preset--spacing--40);
  }
}


@media (min-width: 600px) {
  .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: flex;
  }

  /* neutralize the wp default for 600px */
  .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
    display: none;
  }
}

/* HOME PAGE */
.contact-us-section-container {
  display: flex;
  justify-content: center;
  margin-top: 2rem;
}

/* Swiper */
.scroll-down {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin-top: 22px;
  font-size: var(--wp--preset--font-size--small);
}

@media screen and (max-width: 899px) {
  .scroll-down {
    display: none;
  }
}

.swiper-slide a {
  text-decoration: none !important;
}

.myswiper-project-slide-content {
  display: flex;
}

.crazy-line {
  top: 2px;
  left: 51px;
  position: absolute;
  z-index: 2;
  opacity: 0;
}

.crazy-line.is-crazy {
  opacity: 1;
}

.crazy-border-absolute {
  position: absolute;
  z-index: 2;
  top: -32px;
  left: -31px;
  right: -15px;
  bottom: -30px;
}

.crazy-border {
  width: 100%;
  height: 100%;
  object-fit: fill;
  opacity: 0;
}

.crazy-border.is-crazy {
  opacity: 1;
}

.myswiper-project-slide-content .myswiper-project-image {
  width: 533px;
  height: 400px;
  flex-shrink: 0;
  flex-grow: 0;
  position: relative;
}

.myswiper-project-slide-content .myswiper-project-image img:not(.crazy-border) {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* border: #666666 solid 1px; */
}

.myswiper-project-slide-content .myswiper-project-info {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;

}

.myswiper-project-slide-content .myswiper-project-info .myswiper-project-category {
  padding: 0 var(--wp--preset--spacing--40);
  font-size: var(--wp--preset--font-size--medium);
  font-weight: 500;
  margin-bottom: var(--wp--preset--spacing--10);
  max-width: 450px;
}

.myswiper-project-slide-content .myswiper-project-info .myswiper-project-title {
  padding: 0 var(--wp--preset--spacing--40);
  font-size: 32px;
  font-weight: 700;
  margin-bottom: var(--wp--preset--spacing--20);
  margin-top: 0;
  max-width: 450px;
  position: relative;
}

.myswiper-project-slide-content .myswiper-project-info .myswiper-project-intro {
  padding: 0 var(--wp--preset--spacing--40);
  max-width: 450px;
  font-size: var(--wp--preset--font-size--normal);
  font-weight: 300;
  margin-bottom: var(--wp--preset--spacing--40);
  margin-top: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.myswiper-project-intro {
  letter-spacing: 0.05rem;
  color: #7d7d7d;
}

.myswiper-project-slide-content .myswiper-project-info .myswiper-project-intro p {
  margin-block-start: 0;
}

.myswiper-project-slide-content .myswiper-project-info .myswiper-project-intro>* :not(:first-child) :not(p) {
  display: none;
}

.myswiper-project-slide-content .myswiper-project-info .myswiper-view-more {
  margin-bottom: 0;
  font-size: var(--wp--preset--font-size--small);
  margin-right: 44px;
  align-self: flex-end;
  text-decoration: underline !important;
}

@media screen and (max-width: 1100px) {
  .myswiper-project-slide-content {
    flex-direction: column;
  }

  .myswiper-project-slide-content .myswiper-project-info .myswiper-project-category {
    padding: 0;
    font-size: var(--wp--preset--font-size--small);
  }

  .myswiper-project-slide-content .myswiper-project-info .myswiper-project-title {
    padding: 0;
    font-size: 20px;
  }

  .myswiper-project-slide-content .myswiper-project-info .myswiper-project-intro {
    padding: 0;
  }

  .myswiper-project-slide-content .myswiper-project-image {
    width: unset;
    height: 300px;
  }

  .myswiper-project-intro {
    display: none !important;
  }

  .myswiper-view-more {
    display: none !important;
  }
}

/* Project */
.project-head {
  margin-block-start: 0.5rem;
  display: flex;
  align-content: center;
  justify-content: space-between;
  width: 100%;
}

@media screen and (max-width: 1100px) {
  .project-head {
    justify-content: center;
  }

  .project-head h2 {
    text-align: center;
  }

  .project-head .view-mode-block {
    display: none;
  }
}

.view-mode-block {
  display: flex;
  align-content: center;
  gap: 4px;
  justify-content: flex-end;
  align-items: center;
  flex-grow: 0;
  flex-shrink: 0;
  font-family: Montserrat;
  font-weight: 300;
  font-size: 12px;
}

.view-mode-block.mobile-view-mode-block {
  display: none;
}

@media screen and (max-width: 1100px) {
  .view-mode-block {
    justify-content: center;
  }

  .view-mode-block.mobile-view-mode-block {
    display: flex;
  }
}

.main-button {
  background-color: var(--wp--preset--color--white) !important;
  font-size: var(--wp--preset--font-size--medium);
  font-weight: 400 !important;
  padding: 12px 24px !important;
  border-radius: 9999px !important;
}

@media (hover: hover) {
  .main-button:hover:not(.is-active) {
    background-color: var(--wp--preset--color--orange) !important;
  }
}

#project-category-buttons-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 28px;
  justify-content: flex-start;
  align-items: center;
}

/* Project grid */
#projects-container {
  padding-top: 1rem;
}

#projects-container.projects-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-column-gap: 30px;
  grid-row-gap: 20px;
}

/* Project grid */
#projects-container.projects-grid .grid-item {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  padding: 0;
  margin: 0;
  width: min-content;
  height: 100%;
  overflow: hidden;
}

/* Project grid */
#projects-container.projects-grid .grid-item a {
  text-decoration: none;
  color: inherit;
  display: block;
  width: 100%;
}

/* Project grid */
#projects-container.projects-grid .grid-item .grid-item__content {
  padding: 0;
  margin: 0;
  width: 100%;
  overflow: hidden;
}

/* Project grid */
#projects-container.projects-grid .grid-item .grid-item__content .grid-item__category {
  padding-bottom: 4px;
  border-bottom: 1px solid #666666;
  border-top: none;
  border-left: none;
  border-right: none;
  margin-bottom: 0;
}

/* Project grid */
#projects-container.projects-grid .grid-item .grid-item__content .grid-item__title {
  font-size: 20px;
  font-weight: 500;
  margin-top: var(--wp--preset--spacing--20);
  padding-bottom: var(--wp--preset--spacing--20);
}

/* Project grid */
#projects-container.projects-grid .grid-item .grid-item__image {
  width: 340px;
  height: 256px;
  position: relative;
}

/* Project grid */
#projects-container.projects-grid .grid-item .grid-item__image>img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

/* Project grid */
#projects-container.projects-grid .grid-item:nth-child(3n+1) {
  justify-self: start;
}

/* Project grid */
#projects-container.projects-grid .grid-item:nth-child(3n+2) {
  justify-self: center;
}

/* Project grid */
#projects-container.projects-grid .grid-item:nth-child(3n+3) {
  justify-self: end;
}

@media screen and (max-width: 1200px) {
  #projects-container.projects-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  #projects-container.projects-grid .grid-item {
    width: 100%;
  }

  #projects-container.projects-grid .grid-item .grid-item__image {
    width: 100%;
  }

  #projects-container.projects-grid .grid-item:nth-child(2n+1) {
    justify-self: start;
  }

  #projects-container.projects-grid .grid-item:nth-child(2n+2) {
    justify-self: end;
  }
}

@media screen and (max-width: 768px) {
  #projects-container.projects-grid {
    grid-template-columns: repeat(1, 1fr);
  }

  #projects-container.projects-grid .grid-item {
    width: 100%;
  }

  #projects-container.projects-grid .grid-item .grid-item__image {
    width: 100%;
  }
}

/* Project list */
#projects-container.projects-list table {
  width: 100%;
  border-collapse: collapse;
}

/* Project list */
#projects-container table tr a {
  text-decoration: none;
}

#projects-container.projects-list table th {
  padding: 0;
  margin: 0;
  overflow: hidden;
  text-align: left;
  border-bottom: solid 1.3px #666666;
  border-top: none;
  border-left: none;
  border-right: none;
  height: 50px;
  vertical-align: middle;
  font-weight: 500;
}

/* Project list */
#projects-container.projects-list table th.year {
  width: 8em;
}

/* Project list */
#projects-container.projects-list table th.tax {
  width: 8em;
}

/* Project list */
#projects-container.projects-list table th.unit {
  width: 8em;
}

/* Project list */
#projects-container.projects-list table th:not(:first-child):not(:last-child) {
  padding-left: 24px;
  padding-right: 24px;
}

/* Project list */
#projects-container.projects-list table td:not(:first-child):not(:last-child) {
  padding-left: 24px;
  padding-right: 24px;
}

/* Project list */
#projects-container.projects-list table td {
  padding: 0;
  margin: 0;
  overflow: hidden;
  text-align: left;
  border-bottom: solid 1px #9E9E9E;
  border-top: none;
  border-left: none;
  border-right: none;
  padding-top: 9px;
  padding-bottom: 9px;
  height: 65px;
}


@media screen and (max-width: 1100px) {
  #projects-container.projects-list table td.name {
    padding-left: 0 !important;
  }

  #projects-container.projects-list table th.name {
    padding-left: 0 !important;
  }

  #projects-container.projects-list table .year {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  #projects-container.projects-list table .tax {
    display: none;
  }
}

/* Pagniation */
#projects-pagination {
  display: flex;
  justify-content: center;
}

/* Pagniation */
#projects-pagination .inner-container {
  margin-top: 20px;
  width: 350px;
  display: flex;
  justify-content: center;
  gap: 10px;
}

/* Pagniation */
#projects-pagination .inner-container button {
  background-color: transparent;
  color: black;
  cursor: pointer;
  border: none;
  font-size: var(--wp--preset--font-size--medium);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Pagniation */
#projects-pagination .inner-container button.is-active {
  text-decoration: underline;
  text-underline-offset: 5px;
}

/* Pagniation */
#projects-pagination .inner-container button:hover {
  text-decoration: none;
}

/* ABOUT PAGE */
#about-collaborate .wp-block-post-content {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px 30px;
  margin-bottom: 32px;
}

@media screen and (max-width: 1100px) {
  #about-collaborate .wp-block-post-content {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media screen and (max-width: 900px) {
  #about-collaborate .wp-block-post-content {
    grid-template-columns: repeat(3, 1fr);
  }
}

#about-collaborate .wp-block-post-content .wp-block-image {
  margin-block-start: 0;
}

#about-collaborate .wp-block-post-content .wp-block-image>img {
  object-fit: scale-down;
  height: 70px;
  width: auto;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

#about-title-block {
  display: flex;
  align-items: center;
  padding-top: 2.3rem;
  padding-bottom: 1.3rem;
}

#about-title-block .about-title-description {
  line-height: 175%;
  margin-block-start: 24px;
  margin-block-end: 24px;
}

#about-title-block>.about-description-block {
  max-width: 350px;
  padding-left: var(--wp--preset--spacing--50);
  padding-right: var(--wp--preset--spacing--50);
}

#about-title-block>.about-description-block {
  width: 100%;
}

#about-title-block>.about-description-block>h1 {
  font-size: var(--wp--preset--font-size--x-large);
  text-align: center;
}

#about-title-block>.about-description-block>p {
  font-weight: 300;
}

.recent-report-title {
  text-align: center;
}

/* COURSE PAGE */
.header-anchor {
  visibility: hidden;
  margin-top: -70px;
  margin-bottom: 70px;
}

.course-podcast {
  padding-left: var(--wp--preset--spacing--50);
  padding-right: var(--wp--preset--spacing--50);
  padding-bottom: var(--wp--preset--spacing--50);
  display: flex;
  gap: 40px;
}

.course-swiper-container {
  padding-left: var(--wp--style--root--padding-left);
  padding-right: var(--wp--style--root--padding-right);
}

.course-podcast>div {
  opacity: 0;
}

/* COURSE PAGE */
.course-podcast .podcast-blocks-grid {
  display: grid;
  flex-grow: 1;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px 10px;
  margin-top: 20px;
}

/* COURSE PAGE */
.course-podcast .podcast-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 16px;
}

/* COURSE PAGE */
.course-podcast .podcast-block .podcast-block-icon {
  margin-left: auto;
  margin-right: auto;
  margin-top: 12px;
  width: 100%;
  height: 36px;
  position: relative;
}

.course-podcast .podcast-block .podcast-block-icon img {
  width: 100%;
  height: 100%;
  object-fit: fill;
  position: absolute;
  top: 0;
  left: 0;
}

.course-podcast .podcast-block .podcast-block-title {
  margin-top: 18px;
  margin-bottom: 16px;
  font-size: 18px;
  font-weight: 500;
}

@media screen and (max-width: 1100px) {
  .course-podcast .podcast-block .podcast-block-title {
    margin-top: 8px;
  }
}

.course-podcast .podcast-block .podcast-block-content {
  line-height: 175%;
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block {
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-cover img {
  width: 310px;
  height: 310px;
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-top: 8px;
  margin-bottom: 8px;
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .podcast-button {
  width: 40px;
  height: 40px;
  color: transparent;
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .apple-podcast,
/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .spotify,
/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .kkbox,
/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .google-podcast {
  position: relative;
  background-size: fill;
}

.course-podcast .podcast-cover-block .podcast-buttons .apple-podcast::before,
.course-podcast .podcast-cover-block .podcast-buttons .spotify::before,
.course-podcast .podcast-cover-block .podcast-buttons .kkbox::before,
.course-podcast .podcast-cover-block .podcast-buttons .google-podcast::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  opacity: 0;
  pointer-events: none;
  background-size: fill;
  transition: opacity 0.3s ease;
}

.course-podcast .podcast-cover-block .podcast-buttons .apple-podcast {
  background-image: url('assets/img/vectors/podcast/apple-podcast.svg');
}

.course-podcast .podcast-cover-block .podcast-buttons .apple-podcast::before {
  background-image: url('assets/img/vectors/podcast/apple-podcast-active.svg');
}

.course-podcast .podcast-cover-block .podcast-buttons .spotify {
  background-image: url('assets/img/vectors/podcast/spotify.svg');
}

.course-podcast .podcast-cover-block .podcast-buttons .spotify::before {
  background-image: url('assets/img/vectors/podcast/spotify-active.svg');
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .kkbox {
  background-image: url('assets/img/vectors/podcast/kkbox.svg');
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .kkbox::before {
  background-image: url('assets/img/vectors/podcast/kkbox-active.svg');
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .google-podcast {
  background-image: url('assets/img/vectors/podcast/google-podcast.svg');
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .google-podcast::before {
  background-image: url('assets/img/vectors/podcast/google-podcast-active.svg');
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .apple-podcast:hover::before,
/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .spotify:hover::before,
/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .kkbox:hover::before,
/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-buttons .google-podcast:hover::before {
  opacity: 1;
}

/* COURSE PAGE */
.course-podcast .podcast-cover-block .podcast-text {
  font-family: Montserrat;
  font-size: var(--wp--preset--font-size--small);
  line-height: 20px;
  height: 20px;
}

@media screen and (max-width: 1100px) {
  .course-podcast {
    flex-direction: column-reverse;
    gap: 16px;
  }

  .course-podcast .podcast-blocks-grid {
    grid-template-columns: repeat(1, 1fr);
  }
}

.along-side-feature-relative {
  position: relative;
  width: 100%;
  height: 700px;
  overflow: hidden;
}

.along-side-feature {
  position: absolute;
  width: 100%;
  height: 700px;
  left: 50%;
  transform: translateX(-50%);
}

.course-feature-icon {
  width: 89px;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.course-feature-icon img {
  max-width: 100%;
  height: auto;
}

.course-feature-icon-text {
  align-self: start;
  text-align: justify;
  padding-top: 20px;
}

.course-feature-content {
  position: relative;
  display: none;
  padding-left: var(--wp--preset--spacing--50);
  padding-right: var(--wp--preset--spacing--50);
  font-size: 16px;
  opacity: 1;
}

.course-feature-content .course-title {
  padding-left: 0;
  padding-right: 0;
}

.course-feature-content p {
  margin-block-start: 0;
  text-align: justify;
}

.feature-group {
  width: 729px;
  height: 426px;
  top: 200px;
  left: 25px;
}

.feature-group .feature-group-relative {
  position: relative;
  width: 100%;
  height: 100%;
}

.feature-group .course-feature-icon-text {
  position: absolute;
  width: 200px;
}

.feature-group .course-feature-icons {
  position: absolute;
  top: 42px;
  left: 176px;
  width: 338px;
  height: 305px;
}

.feature-group .basic-course {
  top: 22px;
  left: 494px;
  width: 178px;
}

.feature-group .intern-workshop {
  top: 202px;
  left: 0;
  width: 178px;
}

.feature-group .intern-plan {
  top: 341px;
  left: 375px;
  width: 178px;
}

.course-feature {
  position: relative;
  height: 700px;
  width: 100%;
}

.course-feature>div {
  position: absolute;
  opacity: 0;
}

.course-feature div img {
  width: 100%;
  height: 100%;
  object-fit: fill;
}

.course-feature .yellow-7 {
  width: 79px;
  height: 79px;
  left: 181px;
  top: 140px;
}

.course-feature .blue-7 {
  width: 447px;
  height: 74px;
  left: -84px;
}

.course-feature .middle-text {
  left: 27%;
  top: 79px;
  width: 550px;
}

.course-feature .blue-group-9 {
  width: 298px;
  height: 154px;
  right: -21px;
  top: 0;
}

.course-feature .main-pink {
  width: 829px;
  height: 240px;
  bottom: 121px;
  right: -148px;
}

.course-feature .yellow-3 {
  width: 101px;
  height: 101px;
  bottom: 289px;
  right: 223px;
}

.course-feature .download-button-block {
  width: 165px;
  height: 64px;
  bottom: 269px;
  right: 311px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.course-feature .download-button-block p {
  color: #666666;
  margin-block-end: 0.5rem;
}

.course-feature .download-button-block a {
  width: 165px;
}

.course-feature .opacity-white {
  width: 630px;
  height: 59px;
  right: -148px;
  bottom: 145px;
}

.course-feature .white-text-logo {
  width: 95px;
  height: 67px;
  bottom: 244px;
  right: 119px;
}

@media screen and (max-width: 1100px) {
  .along-side-feature-relative {
    height: auto;
  }

  .along-side-feature {
    height: 209px;
    position: relative;
    padding-bottom: var(--wp--preset--spacing--20);
  }

  .course-feature-content {
    display: block;
  }

  .course-feature-content .course-feature-grid {
    display: none;
  }

  .course-feature {
    height: 209px;
  }

  .course-feature .course-title {
    display: none;
  }

  .course-feature .blue-7 {
    display: none;
  }

  .course-feature .yellow-7 {
    display: none;
  }

  .course-feature .blue-group-9 {
    display: none;
  }

  .course-feature .middle-text {
    display: none;
  }

  .course-feature .feature-group {
    display: none;
  }

  .course-feature .main-pink {
    right: 0px;
    width: 527px;
    height: 152px;
    bottom: 0;
  }

  .course-feature .yellow-3 {
    right: 126px;
    bottom: 108px;
  }

  .course-feature .download-button-block {
    right: 211px;
    bottom: 80px;
  }

  .course-feature .white-text-logo {
    width: 66px;
    height: 47px;
    right: 122px;
    bottom: 40px;
  }

  .course-feature .opacity-white {
    display: none;
  }
}

@media screen and (max-width: 900px) {
  .course-feature-content .feature-group {
    display: none;
  }

  .course-feature-content .course-feature-grid {
    margin-top: 20px;
    display: grid;
    grid-template-columns: 89px auto;
    gap: 20px;
    align-items: center;
  }
}

@media screen and (max-width: 500px) {
  .course-feature .main-pink {
    right: -104px;
  }

  .course-feature .yellow-3 {
    right: 22px;
  }

  .course-feature .download-button-block {
    right: 107px;
  }

  .course-feature .white-text-logo {
    right: 8px;
  }
}

.along-side-intro-relative {
  position: relative;
  width: 100%;
  height: 350px;
  overflow: hidden;
}

.along-side-intro {
  position: absolute;
  width: 1100px;
  height: 350px;
  left: 50%;
  transform: translateX(-50%);
}

.course-intro {
  position: relative;
  height: 350px;
  width: 100%;
}

.course-intro>div {
  position: absolute;
  opacity: 0;
}

.course-intro>.middle-text {
  width: 400px;
  opacity: 0;
  left: 50%;
  transform: translateX(-50%);
}

.course-intro>.middle-text>h2 {
  text-align: center;
  padding: 0;
  margin-block-start: 0.8rem;
  margin-block-end: 0.8rem;
  line-height: 40px;
}

.course-intro>.middle-text>div {
  padding-left: var(--wp--preset--spacing--30);
  padding-right: var(--wp--preset--spacing--30);
  margin-top: 20px;
  margin-bottom: 20px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: center;
}

.course-intro>.middle-text>p {
  font-size: 16px;
  padding-left: var(--wp--preset--spacing--30);
  padding-right: var(--wp--preset--spacing--30);
  margin-block-start: 0;
  text-align: justify;
}

.course-intro .big-yellow-circle {
  width: 112px;
  height: 112px;
  left: 270px;
  top: 0px;
}

.course-intro .blue-circle-left {
  width: 40px;
  height: 40px;
  left: 230px;
  top: 210px;
}

.course-intro .small-yellow-circle {
  width: 78px;
  height: 78px;
  left: 140px;
  top: 140px;
}

.course-intro .outline-circle-right {
  width: 130px;
  height: 130px;
  left: 875px;
  top: 50px;
}

.course-intro .blue-circle-right {
  width: 79px;
  height: 250px;
  top: 60px;
  left: 950px;
}

.course-intro>div>img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.along-side-banner-relative {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 500px;
}

.along-side-banner {
  position: absolute;
  width: 1100px;
  height: 500px;
  left: 50%;
  transform: translateX(-50%);
}

.course-banner {
  position: relative;
  height: 500px;
  width: 100%;
}

.course-banner>div {
  position: absolute;
  opacity: 0;
}

.course-banner>div>img {
  width: 100%;
  height: 100%;
  object-fit: fill;
}

.course-banner .blue-1-circle {
  width: 124px;
  height: 124px;
  left: 220px;
  top: 310px;
}

.course-banner .blue-7 {
  width: 446px;
  height: 74px;
  left: -28px;
  top: 55px;
}

.course-banner .blue-group-3 {
  width: 298px;
  height: 154px;
  left: 750px;
  top: 320px;
}

.course-banner .green-1 {
  width: 699px;
  height: 86px;
  left: -50px;
  top: 385px;
}

.course-banner .main-red {
  width: 920px;
  height: 266px;
  left: 458px;
  top: 82px;
}

.course-banner .middle-big-char {
  width: 134px;
  height: 95px;
  top: 142px;
  left: 50%;
  transform: translateX(-50%);
}

.course-banner .middle-text {
  width: 306px;
  height: 57px;
  top: 292px;
  left: 50%;
  transform: translateX(-50%);
}

.course-banner .outline-5-circle {
  width: 149px;
  height: 140px;
  left: 375px;
  top: 190px;
}

.course-banner .pink-6 {
  width: 684px;
  height: 90px;
  left: 705px;
  top: 158px;
}

.course-banner .yellow-3-circle {
  width: 118px;
  height: 118px;
  left: 763px;
  top: 267px;
}

.course-banner .yellow-8-circle {
  width: 78px;
  height: 78px;
  left: 655px;
  top: 52px;
}

.left-block.apply-animate:not(.with-delay) {
  animation: flyInFromLeft 0.5s ease-out forwards;
}

.right-block.apply-animate:not(.with-delay) {
  animation: flyInFromRight 0.5s ease-out forwards;
}

.bottom-block.apply-animate:not(.with-delay) {
  animation: flyInFromBottom 0.5s ease-out forwards;
}

.left-block.apply-animate.with-delay {
  animation: flyInFromLeft 0.5s ease-out 0.7s forwards;
}

.right-block.apply-animate.with-delay {
  animation: flyInFromRight 0.5s ease-out 0.7s forwards;
}

.bottom-block.apply-animate.with-delay {
  animation: flyInFromBottom 0.5s ease-out 0.7s forwards;
}

.fade-in-block.apply-animate.with-delay {
  animation: fadeIn 0.3s ease-out 0.7s forwards;
}

.fade-in-block.apply-animate:not(.with-delay) {
  animation: fadeIn 0.3s ease-out forwards;
}

.left-block.apply-slow-animate {
  animation: flyInFromLeft 0.7s ease-out forwards;
}

.right-block.apply-slow-animate {
  animation: flyInFromRight 0.7s ease-out forwards;
}

.fade-in-block.apply-slow-animate {
  animation: fadeIn 0.5s ease-out 0.7s forwards;
}

.course-container {
  background: #F9FAF3;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes flyInFromLeft {
  from {
    transform: translateX(-100%);
    opacity: 0;
  }

  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes flyInFromRight {
  from {
    transform: translateX(100%);
    opacity: 0;
  }

  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes flyInFromBottom {
  from {
    transform: translateY(100%);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@media screen and (max-width: 600px) {
  .along-side-intro-relative {
    overflow: visible;
  }

  .course-intro .big-yellow-circle {
    width: 112px;
    height: 112px;
    left: 425px;
    top: 0px;
  }

  .course-intro .outline-circle-right {
    width: 130px;
    height: 130px;
    left: 562px;
    top: 205px;
  }

  .course-intro .blue-circle-right {
    width: 79px;
    height: 250px;
    top: 225px;
    left: 625px;
  }

  .course-intro .middle-text {
    max-width: 348px;
    width: 100%;
  }

  .course-intro .middle-text img {
    width: 200px;
  }

  .course-banner {
    height: 278px;
  }

  .along-side-banner-relative {
    height: 278px;
  }

  .along-side-banner-relative>.scale-wrapper {
    transform: scale(0.556);
    transform-origin: center;
  }
}

.course-title {
  margin-bottom: 0;
}

@media screen and (max-width: 600px) {
  h2.course-title {
    text-align: center;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

.course-page h1 {
  color: #505050;
  text-align: center;
  font-family: GenSenMaruGothic JP TTF;
  font-size: 36px;
  font-weight: 700;
  line-height: 135%;
  /* 48.6px */
  letter-spacing: 3.6px;
}

.course-page h2 {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 2.8px;
  padding: 1.5rem var(--wp--style--root--padding-left) 1.5rem var(--wp--style--root--padding-right);
}

.course-page p {
  line-height: 175%;
  /* 28px */
  letter-spacing: 1.6px;
}

.course-page-small p {
  color: #666;
  font-size: 12px;
  letter-spacing: 1.2px;
}

.course-page-intro {
  width: 1100px;
  margin: auto;
  display: flex;
}

.course-page-campus-title {
  width: 1100px;
  margin: auto;
  display: flex;
  justify-content: space-between;
}

.course-page-campus-intro-text {
  position: absolute;
  max-width: 55rem;
  display: flex;
  padding-left: 20rem;
  margin-top: 0;
}

.course-page-campus {
  width: 1100px;
  margin: auto;
  display: flex;
}

.course-page-campus-info-group {
  display: flex;
  padding-left: var(--wp--preset--spacing--50);
}

.course-page-campus-info-text-01 {
  max-width: 16rem;
  position: absolute;
  padding: 0 0 0 30rem;
}

.course-page-campus-info-text-02 {
  max-width: 11rem;
  position: absolute;
  padding: 10rem 0 0 0;
}

.course-page-campus-info-text-03 {
  max-width: 12rem;
  position: absolute;
  padding: 18rem 0 0 25rem;
}

#course-page-button {
  display: flex;
  width: 119px;
  height: 47px;
  padding: 12px 18px;
  justify-content: center;
  align-items: center;
  gap: 20px;
  border-radius: 20px;
  border: 1px solid #000;
  background: #FFF;
  color: #000;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 1.6px;
}

.course-page-podcast {
  max-width: 1100px;
  margin: auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 0 0 3rem;
}

.course-page-podcast-content {
  display: flex;
  justify-content: space-between;
  gap: 1.5rem;
}

.course-page-podcast-content-group {
  flex: 1;
  display: flex;
  justify-content: space-between;
  gap: 1.5rem;
  padding-left: var(--wp--preset--spacing--50);
  margin-bottom: 3rem;
}

.course-page-podcast-links {
  flex: 0.8;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0;
}

.course-page-podcast-cell {
  max-width: 18rem;
  min-width: 13rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0;
}

.course-page-podcast-title {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 175%;
  /* 31.5px */
  letter-spacing: 1.8px;
}

#footer-nav-mobile {
  display: none;
}

@media (max-width: 796px) {
  #footer-nav-mobile {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
  }

  .footer-desktop {
    display: none;
  }

  #footer-content {
    margin-top: 48px;
    padding-left: 0;
    padding-right: 0;
    flex-direction: column;
    align-items: center;
    position: relative;
    gap: 2rem;
  }

  #footer-right-part {
    padding-left: 0 !important;
  }

  #footer-info {
    padding: 0;
    align-items: center;
    flex-direction: column-reverse;
    height: fit-content;
    gap: 0;
  }

  #footer-nav {
    display: none;
  }

  /* COURSE PAGE */
  .course-page-campus {
    width: auto;
    flex-direction: column;
  }

  .course-page-campus-info {
    align-self: start;
  }

  .course-page-campus-doc {
    align-self: end;
    margin-top: 0;
  }
}

/* Reports Swiper */

.swiper-container {
  position: relative;
  overflow: hidden;
}

.swiper-container.is-crazy {
  overflow: visible;
}

/*
.swiper-container .swiper-button-prev,
.swiper-container .swiper-button-next {
  width: 32px;
  height: 32px;
  background-color: var(--wp--preset--color--base);
  color: var(--wp--preset--color--black);
  border: var(--wp--preset--color--black) solid 2px;
  border-radius: 9999px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
}

.swiper-container .swiper-button-prev:after,
.swiper-container .swiper-button-next:after {
  font-size: 16px;
  font-weight: 700;
}

.swiper-container .swiper-button-next:after {
  padding-left: 2px;
}

.swiper-container .swiper-button-prev:after {
  padding-right: 2px;
}

.swiper-container .swiper-button-next,
.swiper-container .swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 15px);
}

.swiper-container .swiper-button-prev,
.swiper-container .swiper-rtl .swiper-button-next {
  left: var(--swiper-navigation-sides-offset, 15px);
}

#projects-swiper.swiper-container .swiper-button-prev,
#projects-swiper.swiper-container .swiper-button-next {
  top: var(--swiper-navigation-top-offset, 173px);
}
*/

.myswiper-report-image {
  width: 100%;
  padding-top: 75.29%;
  position: relative;
}

.myswiper-report-image>img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

.swiper-slide .myswiper-report-info .myswiper-report-title {
  font-size: 18px;
  text-align: justify;
  font-weight: 500;
  margin-bottom: var(--wp--preset--spacing--20);
  margin-top: var(--wp--preset--spacing--20);
  -webkit-text-size-adjust: 100%;
}

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


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


#projects-swiper-wide-block {
  margin-block-start: 2.3rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--wp--style--root--padding-left);
  padding-right: var(--wp--style--root--padding-right);
  max-width: var(--wp--style--global--wide-size);
}

@media screen and (max-width: 1100px) {
  #projects-swiper-wide-block {
    margin-block-start: 0;
    padding-left: 0;
    padding-right: 0;
  }

  #projects-swiper-wide-block .myswiper-project-slide-content {
    width: 100vw;
  }

  #projects-swiper-wide-block .myswiper-project-info {
    padding-right: 20px;
    padding-left: 20px;
  }

  #projects-swiper-wide-block .myswiper-project-category {
    max-width: unset;
  }

  #projects-swiper-wide-block .myswiper-project-title {
    max-width: unset;
  }
}

/* Single Project */
.project-description {
  display: grid;
  grid-template-columns: 1fr auto;
}

/* Single Project */
.project-description .project-intro-box {
  padding-right: var(--wp--preset--spacing--50);
}

/* Single Project */
.project-description .project-intro-box .project-intro p {
  margin-block-end: 0.5rem;
  margin-block-start: 0.5rem;
}

/* Single Project */
.project-description .project-intro-box .project-featured-image {
  width: 100%;
  margin-top: var(--wp--preset--spacing--20);
}

/* Single Project */
.project-description .project-intro-box .project-featured-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Single Project */
.project-description .project-details {
  max-width: 400px;
  min-width: 250px;
  flex-grow: 1;
  flex-shrink: 1;
  padding-left: var(--wp--preset--spacing--40);
  border-left: solid 1px #000000;
}

/* Single Project */
.project-description .project-details p {
  margin-block-end: 0;
  margin-block-start: 0;
  color: #636363;
}

/* Single Project */
.project-description .project-details p span {
  color: #9E9E9E;
}

.project-detail-container {
  width: 100%;
  justify-content: center;
  display: flex;
  gap: 7px var(--wp--preset--spacing--20);
  flex-wrap: wrap;
  padding: var(--wp--preset--spacing--30) 0;
}

.project-detail-container div {
  flex-shrink: 0;
  flex-grow: 0;
}

@media screen and (max-width: 1100px) {
  .project-description {
    grid-template-columns: 1fr;
  }

  .project-intro-box {
    padding-top: 0;
  }

  .project-description {
    flex-direction: column-reverse;
  }

  .project-description .project-intro-box {
    padding-right: 0;
  }

  .project-description .project-details {
    max-width: 100%;
    min-width: 100%;
    padding-left: 0;
    padding-bottom: var(--wp--preset--spacing--30);
    border-left: none;
    border-bottom: solid 1px #000000;
  }

  .project-content .wp-block-gallery {
    display: block;
    margin: 0;
  }

  .project-detail-container {
    flex-direction: column;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--wp--preset--spacing--30);
    padding: var(--wp--preset--spacing--30) 0;
  }

  .project-detail-container div {
    flex-shrink: 0;
    flex-grow: 0;
  }
}

/* Reports */
.single-report {
  margin-left: auto;
  margin-right: auto;
  max-width: 760px;
}

.single-report h1 {
  line-height: 150%;
  margin-top: 2rem;
  margin-bottom: 0.5rem;
}

.report-title {
  text-align: left;
}

.cultime-report {
  margin: var(--wp--preset--spacing--20) auto;
  max-width: var(--wp--style--global--wide-size);
}

.cultime-report h2 {
  padding-left: 0;
}

.post-time {
  margin-block-start: 0;
  font-size: 18px
}

.report-content {
  color: #303030;
}

.report-content p {
  line-height: 175%;
  margin-block-start: 24px;
  margin-block-end: 24px;
}

.report-content blockquote {
  font-size: 24px;
  padding-right: 0;
  padding-left: 30px;
  border-left: solid 1px #000000;
  margin-left: 0;
  margin-right: 0;
}

.report-content h2 {
  color: #000000;
  font-size: 24px;
}

.report-content h3 {
  color: #333333;
  font-size: 20px;
}

.report-content a {
  color: #000;
  text-decoration: underline;
  text-decoration-color: currentColor;
  text-decoration-thickness: 2px;
  text-underline-offset: 5px;
  font-weight: 600;
}

.report-content ol {
  padding-inline-start: 30px;
}

.report-content ul {
  list-style: none;
  padding-inline-start: 0px;
}

.report-content ul li:before {
  padding-left: 10px;
  content: "．";
  font-size: 16pt;
}

/* Share block */
.social-sharing-block {
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Share block */
.social-sharing-block .horizontal-line {
  display: inline-block;
  position: relative;
  width: 150px;
  vertical-align: middle;
  margin: 0 0.5rem;
}

/* Share block */
.social-sharing-block .horizontal-line>span {
  width: 150px;
  height: 1px;
  background-color: black;
  margin: 0 auto;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
}

/* Share block */
.social-sharing-block .social-sharing {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-inline-start: 0;
}

/* Share block */
.social-sharing-block .social-sharing>li {
  list-style: none;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background-color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

/* Share block */
.social-sharing-block .social-sharing>li .checked-animation {
  animation: check-animation 0.5s ease;
}

/* Share block */
.social-sharing-block .social-sharing>li a {
  display: flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
}

.social-sharing-block .social-sharing>li a i {
  color: #666666;
  fill: #666666;
  text-align: center;
  font-size: 20px;
}

@keyframes check-animation {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.3);
  }

  100% {
    transform: scale(1);
  }
}

.origin-info {
  text-align: center;
  line-height: 1.5;
}

.origin-info a {
  margin-left: 5px;
  text-decoration: underline;
  color: #000000;
  text-underline-offset: 5px;
  text-decoration-thickness: 1px;
}

@media screen and (max-width: 768px) {
  .social-sharing-block {
    flex-direction: column;
  }
}

.w-full {
  width: 100%;
}

.mb-4 {
  margin-bottom: 1rem;
}

.mb-2 {
  margin-bottom: 0.5rem;
}

.text-right {
  text-align: right;
}

.my-4 {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.crazy-logo {
  z-index: 9999;
  pointer-events: none;
  width: 100%;
  height: 100%;
  animation: spin 6s linear infinite;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

body.page h1 {
  font-size: 28px;
}

body.page h2 {
  font-size: 24px;
}

.page-title-hr {
  margin-block-start: 16px;
  margin-block-end: 16px;
}