html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
  box-sizing: border-box;
}

html {
  line-height: 1.5;
}

ol, ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

q, blockquote {
  quotes: none;
}

q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none;
}

a img {
  border: none;
}

img {
  display: block;
  border: none;
}


.noscroll {
  overflow: hidden;
  height: 100%;
}

.project {
  font-family: "Microsoft JhengHei";
  width: 100%;
  overflow: hidden;
}
.project picture {
  display: block;
  width: 100%;
}
.project picture img {
  display: block;
  width: 100%;
}
.project .goTop {
  display: none;
  width: 7.5%;
  height: 0;
  padding-bottom: 8.4895833333%;
  background-image: url("../images/img_top.svg");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  position: fixed;
  right: 2.1875rem;
  bottom: 6%;
  z-index: 10;
  transition: bottom 0.3s ease;
}
@media (max-width: 1440px) {
  .project .goTop {
    transform: scale(0.95);
    right: 1.25rem;
    bottom: 10%;
  }
}
@media (max-width: 980px) {
  .project .goTop {
    width: 4.5rem;
    padding-bottom: 5.09375rem;
    right: 0.625rem;
    bottom: 4%;
  }
}
@media (max-width: 980px) {
  .project .goTop--up {
    bottom: calc(5% + 11.875rem);
  }
}
@media (max-width: 450px) {
  .project .goTop--up {
    bottom: calc(5% + 12.5rem);
  }
}
.project .pc-hide {
  display: none;
}
@media (max-width: 980px) {
  .project .pc-hide {
    display: block;
  }
}
.project .sp-hide {
  display: block;
}
@media (max-width: 980px) {
  .project .sp-hide {
    display: none;
  }
}
.project .hide-text {
  display: block;
  white-space: nowrap;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
  overflow: hidden;
  text-indent: 110%;
  width: 0rem;
  height: 0rem;
}
.project .hide-title {
  width: 1px;
  height: 1px;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-indent: 110%;
  position: absolute;
  left: 0;
  top: 0;
}
.project .header {
  width: 100%;
  height: 0;
  padding-bottom: 40%;
  box-sizing: border-box;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  position: relative;
  background-image: url("../images/banner_pc.png");
}
@media (max-width: 980px) {
  .project .header {
    background-image: url("../images/banner_m.png");
    padding-bottom: 132.6530612245%;
  }
}
.project .header .header_title {
  display: none;
}
.project .header_main {
  width: 25.65%;
  height: 0;
  padding-bottom: 18.5%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  left: 38vw;
  top: 6vw;
  background-image: url("../images/banner_main.svg");
}
@media (max-width: 1440px) {
  .project .header_main {
    top: 6.5vw;
  }
}
@media (max-width: 980px) {
  .project .header_main {
    background-image: url("../images/banner_main_m.svg");
    width: 50.4081632653%;
    padding-bottom: 38.6734693878%;
    left: 8.6734693878%;
    top: 3vw;
  }
}
@keyframes scale {
  0% {
    transform: scale(0.9);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes scale-sp {
  0% {
    transform: scale(0.9);
  }
  100% {
    transform: scale(0.8);
  }
}
.project .nav {
  width: 100%;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 90;
}
@media (max-width: 980px) {
  .project .nav {
    pointer-events: auto;
  }
}
.project .nav_wrap {
  width: 90%;
  max-width: 75rem;
  margin: 1.875rem auto;
  display: flex;
  justify-content: flex-end;
}
@media (max-width: 1440px) {
  .project .nav_wrap {
    margin: 1.375rem auto;
  }
}
@media (max-width: 1200px) {
  .project .nav_wrap {
    width: 99%;
  }
}
.project .nav-btn {
  width: 9.693877551%;
  height: 0;
  padding-bottom: 9.693877551%;
  background-color: #eb6b6a;
  border-radius: 50%;
  border: 0.125rem solid white;
  box-sizing: content-box;
  cursor: pointer;
  position: relative;
  z-index: 99;
  display: none;
  pointer-events: auto;
  transform: translate(-10px, -10px);
}
@media (max-width: 980px) {
  .project .nav-btn {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
@media (max-width: 575px) {
  .project .nav-btn {
    width: 2.875rem;
    padding-bottom: 2.875rem;
  }
}
.project .nav-btn .midline {
  width: 50%;
  height: 0.1875rem;
  background-color: white;
  position: absolute;
  left: 25%;
  top: calc(50% - 1.5px);
  transition: all 0.4s ease;
}
.project .nav-btn .midline::before {
  content: "";
  width: 100%;
  height: 0.1875rem;
  background-color: white;
  position: absolute;
  top: -1.2vw;
  transition: all 0.4s ease;
}
@media (max-width: 575px) {
  .project .nav-btn .midline::before {
    top: -0.375rem;
  }
}
.project .nav-btn .midline::after {
  content: "";
  width: 100%;
  height: 0.1875rem;
  background-color: white;
  position: absolute;
  bottom: -1.2vw;
  transition: all 0.4s ease;
}
@media (max-width: 575px) {
  .project .nav-btn .midline::after {
    bottom: -0.375rem;
  }
}
.project .nav-btn.show .midline {
  background-color: transparent;
}
.project .nav-btn.show .midline::before {
  top: 0;
  transform: rotate(45deg);
}
.project .nav-btn.show .midline::after {
  bottom: 0;
  transform: rotate(-45deg);
}
.project nav {
  width: 100%;
}
@media (max-width: 980px) {
  .project nav {
    display: none;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background-color: #89b69f;
    padding: 5.9375rem 0;
    z-index: 80;
    justify-content: center;
    align-items: center;
    overflow-y: auto;
  }
}
.project nav ul {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 980px) {
  .project nav ul {
    flex-wrap: wrap;
  }
}
.project nav li {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.1875rem;
}
@media (max-width: 980px) {
  .project nav li {
    padding: unset;
    margin: 0.625rem 0;
  }
}
@media (max-width: 980px) {
  .project nav li:last-child {
    margin-top: 1.875rem;
  }
}
.project nav a {
  width: 8.75rem;
  display: block;
  text-decoration: none;
  color: #eb6b6a;
  text-align: center;
  padding: 0.625rem 0.3125rem;
  box-sizing: border-box;
  background-color: white;
  border-radius: 5rem;
  border: 0.125rem solid #eb6b6a;
  font-size: 1.125rem;
  transition: all 0.3s;
  font-weight: bold;
  position: relative;
  line-height: 1;
  letter-spacing: 0.1em;
}
@media (max-width: 1200px) {
  .project nav a {
    font-size: 1rem;
    width: 100%;
    padding: 0.5rem 0.1875rem;
  }
}
@media (max-width: 980px) {
  .project nav a {
    width: 10.625rem;
    font-size: 1.125rem;
    padding: 0.625rem;
  }
}
.project nav a:hover {
  background-color: #eb6b6a;
  color: white;
}
.project nav a:hover::after {
  content: "";
  display: block;
  position: absolute;
  top: 0.1875rem;
  left: 0.0625rem;
  width: 100%;
  height: 100%;
  border-radius: 5rem;
  border: 0.125rem solid #eb6b6a;
  z-index: -1;
}
.project nav a.fb, .project nav a.ig {
  margin: 0 0.3125rem;
  padding: unset;
  border: unset;
  background-color: unset;
  width: 2.5625rem;
  height: 0;
  padding-bottom: 2.5625rem;
  box-sizing: border-box;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
@media (max-width: 1200px) {
  .project nav a.fb, .project nav a.ig {
    width: 2.30625rem;
    padding-bottom: 2.30625rem;
  }
}
@media (max-width: 980px) {
  .project nav a.fb, .project nav a.ig {
    width: 3.125rem;
    padding-bottom: 3.125rem;
    margin: 0 0.8125rem;
  }
}
.project nav a.fb:hover::after, .project nav a.ig:hover::after {
  content: "";
  display: none;
}
.project nav a.fb {
  background-image: url("../images/icon_fb.png");
}
.project nav a.ig {
  background-image: url("../images/icon_ig.png");
}
.project .scroll {
  display: block;
  width: 100%;
  text-align: center;
  position: absolute;
  left: 0;
  bottom: 0rem;
  color: #db4218;
  font-weight: bold;
  font-family: "Microsoft JhengHei";
  z-index: 2;
  font-size: 0.78125rem;
  letter-spacing: 1px;
}
@media (max-width: 980px) {
  .project .scroll {
    font-size: 0.875rem;
    bottom: -25px;
  }
}
.project .scroll_icon {
  display: inline-block;
  width: 1rem;
  height: 0;
  padding-bottom: 1.4375rem;
  box-sizing: border-box;
  background-image: url("../images/icon_scrolldown.svg");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  animation: scroll 0.6s linear infinite alternate;
  position: absolute;
  left: calc(50% - 8px);
}
@media (max-width: 980px) {
  .project .scroll_icon {
    animation: scroll_pad 0.6s linear infinite alternate;
  }
}
@media (max-width: 575px) {
  .project .scroll_icon {
    width: 1.0625rem;
    padding-bottom: 1.5rem;
    left: calc(50% - 8.5px);
    animation: scroll_mb 0.6s linear infinite alternate;
  }
}
@keyframes scroll {
  0% {
    top: 1.25rem;
  }
  100% {
    top: 1.75rem;
  }
}
@keyframes scroll_pad {
  0% {
    top: 3.0612244898vw;
  }
  100% {
    top: 4.0816326531vw;
  }
}
@keyframes scroll_mb {
  0% {
    top: 1.25rem;
  }
  100% {
    top: 1.875rem;
  }
}
@keyframes arrow {
  0% {
    right: 1.25rem;
  }
  100% {
    right: 0.625rem;
  }
}
.project .sec {
  padding: 1.875rem 0 6.25rem;
  box-sizing: border-box;
  position: relative;
}
@media (max-width: 980px) {
  .project .sec {
    padding: 3.125rem 0;
  }
}
.project .sec_title {
  text-align: center;
  padding-top: 1.25rem;
  margin-bottom: 0.9375rem;
  box-sizing: border-box;
  font-size: 2.3125rem;
  letter-spacing: 0.07em;
  position: relative;
}
.project .sec_title::before {
  content: "";
  display: block;
  position: absolute;
  top: -1.25rem;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
@media (max-width: 980px) {
  .project .sec_title {
    font-size: 1.5rem;
  }
}
.project .sec_caption {
  text-align: center;
  font-size: 1.0375rem;
  letter-spacing: 0.1em;
  color: #464646;
  margin-bottom: 5rem;
}
@media (max-width: 980px) {
  .project .sec_caption {
    margin-bottom: 3.125rem;
  }
  .project .sec_caption br {
    display: none;
  }
}
.project .sec_cards {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  margin: 3.125rem 0;
  gap: 5rem 2.5rem;
}
@media (max-width: 1440px) {
  .project .sec_cards {
    gap: 4.0625rem 1.5625rem;
  }
}
@media (max-width: 980px) {
  .project .sec_cards {
    gap: 0.3125rem 1.25rem;
  }
}
.project .sec .sec_link {
  text-align: center;
  margin-top: 2.5rem;
}
.project .sec .sec_link a {
  display: inline-block;
  text-decoration: none;
  background-color: #db4218;
  color: white;
  font-size: 1rem;
  letter-spacing: 0.1em;
  padding: 0.5rem 3.75rem 0.5rem 2.1875rem;
  box-sizing: border-box;
  border-radius: 1.25rem;
  position: relative;
  transition: all 0.3s;
}
.project .sec .sec_link a:hover::after {
  animation: arrow 0.4s linear infinite alternate;
}
.project .sec .sec_link a::after {
  content: "";
  display: block;
  width: 1.0625rem;
  height: 0;
  padding-bottom: 0.75rem;
  box-sizing: border-box;
  background-image: url("../images/icon_arrow.svg");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: calc(50% - 6px);
  right: 1.25rem;
}
.project .sec_tips {
  width: 100%;
  background: #fcd3cd;
  position: relative;
  padding: 6.875rem 0 0;
}
@media (max-width: 980px) {
  .project .sec_tips {
    padding: 6.25rem 0 0;
  }
}
.project .sec_award::before {
  content: "";
  display: block;
  width: 90.625%;
  height: 0;
  padding-bottom: 106.25%;
  box-sizing: border-box;
  background-image: url("../images/award_bg.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  left: 4.1666666667%;
  top: 17.5rem;
  z-index: -1;
}
@media (max-width: 1440px) {
  .project .sec_award::before {
    width: 101%;
    left: -15px;
    padding-bottom: 130%;
    top: 29.375rem;
  }
}
@media (max-width: 980px) {
  .project .sec_award::before {
    display: none;
  }
}
.project .sec_form {
  background-image: url("../images/form_bg.png");
  padding: 13.5416666667% 0 8.3333333333%;
  z-index: 1;
}
@media (max-width: 980px) {
  .project .sec_form {
    padding: 7.5rem 0 9.375rem;
  }
}
@media (max-width: 575px) {
  .project .sec_form {
    padding: 5.625rem 0 9.375rem;
  }
}
.project .sec_form::before {
  content: "";
  display: block;
  width: 100%;
  height: 0;
  padding-bottom: 10.7291666667%;
  box-sizing: border-box;
  background-image: url("../images/tips-wave_bg.png");
  background-position: left bottom;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  left: 0;
  top: -0.3125rem;
  transform: rotateX(180deg);
}
@media (max-width: 980px) {
  .project .sec_form::before {
    padding-bottom: 16.25rem;
    background-size: contain;
  }
}
.project .sec_form .container {
  position: relative;
}
.project .sec_form .container::before, .project .sec_form .container::after {
  content: "";
  display: block;
  height: 0;
  box-sizing: border-box;
  position: absolute;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
.project .sec_form .container::before {
  width: 12.7433628319%;
  padding-bottom: 34.1592920354%;
  background-image: url("../images/ppl.svg");
  right: -15.4867256637%;
  top: -23.0088495575%;
}
@media (max-width: 1440px) {
  .project .sec_form .container::before {
    transform: scale(0.7);
    right: -3.0973451327%;
    top: -20.7079646018%;
  }
}
@media (max-width: 980px) {
  .project .sec_form .container::before {
    width: 5.4rem;
    padding-bottom: 14.475rem;
    right: -1.09375rem;
    top: -11.375rem;
  }
}
.project .sec_form .container::after {
  width: 41.8584070796%;
  padding-bottom: 23.0973451327%;
  background-image: url("../images/img_hotspring.png");
  left: -24.3362831858%;
  bottom: -4.0625rem;
}
@media (max-width: 1440px) {
  .project .sec_form .container::after {
    transform: scale(0.75);
    left: -17.0353982301%;
  }
}
@media (max-width: 980px) {
  .project .sec_form .container::after {
    width: 16.5625rem;
    padding-bottom: 8.1875rem;
    left: -35px;
    bottom: -8.1875rem;
  }
}
.project .sec_rule {
  padding: 6.5625rem 0 7.5rem;
  background: #a9cec3;
  background-position: left bottom;
  background-repeat: repeat;
  background-size: cover;
  z-index: 1;
}
@media (max-width: 980px) {
  .project .sec_rule {
    padding: 4.375rem 0 6.25rem;
  }
}
.project .sec_rule .sec_title {
  margin-bottom: 5rem;
}
@media (max-width: 980px) {
  .project .sec_rule .sec_title {
    margin-bottom: 1.875rem;
  }
}
.project .sec_others {
  background-color: #fcd3cd;
  padding: 6.25rem 0;
  z-index: 1;
}
@media (max-width: 980px) {
  .project .sec_others {
    padding-bottom: 6.875rem;
  }
}
.project .container {
  width: 90%;
  max-width: 70.625rem;
  margin: 0 auto;
}
@media (max-width: 1440px) {
  .project .container {
    max-width: 62.5rem;
  }
}
.project .heightlight {
  background-image: url("../images/lightheight.png");
  background-repeat: no-repeat;
  background-size: 100% 0.5rem;
  background-position: left bottom;
  font-weight: 400;
}
.project .cards_item {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
}
.project .cards_title {
  width: 106%;
  font-size: 1.5625rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  text-align: center;
  margin-bottom: 0.625rem;
}
.project .cards_text {
  width: 100%;
  font-size: 1.040625rem;
  letter-spacing: 0.1em;
  color: #575757;
  text-align: left;
  position: relative;
}
.project .cards_link {
  display: inline-block;
  text-decoration: none;
  background-color: #db4218;
  color: white;
  font-size: 1rem;
  letter-spacing: 0.1em;
  padding: 0.5rem 3.4375rem 0.5rem 1.875rem;
  box-sizing: border-box;
  border-radius: 1.25rem;
  position: relative;
  margin-top: auto;
  transition: all 0.3s;
}
@media (max-width: 1440px) {
  .project .cards_link {
    padding: 0.5rem 2.5rem 0.5rem 1.5625rem;
  }
}
.project .cards_link:hover::after {
  animation: arrow 0.4s linear infinite alternate;
}
.project .cards_link::after {
  content: "";
  display: block;
  width: 1.0625rem;
  height: 0;
  padding-bottom: 0.75rem;
  box-sizing: border-box;
  background-image: url("../images/icon_arrow.svg");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: calc(50% - 6px);
  right: 1.25rem;
}
.project input::-moz-placeholder {
  font-size: 0.9375rem;
  letter-spacing: 0.1em;
  color: #a19898;
}
.project input::placeholder {
  font-size: 0.9375rem;
  letter-spacing: 0.1em;
  color: #a19898;
}
.project select {
  width: 100%;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0.9375rem;
  text-align: left;
  font-size: 0.9375rem;
  letter-spacing: 0.1em;
  border: 0.0625rem solid #bfbfbf;
  border-radius: 0.625rem;
  cursor: pointer;
}
.project .table_cont {
  text-align: left;
  padding: 0 0.625rem;
  box-sizing: border-box;
}
.project .table_inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.25rem;
}
.project .table_inner p:nth-child(2) {
  word-break: keep-all;
}
.project .table .cont_title {
  color: #eb6b6a;
  font-size: 1.040625rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin: 0.9375rem 0;
}
@media (max-width: 980px) {
  .project .table .cont_title {
    font-size: 1rem;
  }
}
.project table {
  width: 100%;
}
@media (max-width: 575px) {
  .project table {
    width: 31.25rem;
  }
}
.project table th {
  padding-bottom: 0.625rem;
  box-sizing: border-box;
}
.project table th p {
  width: 95%;
  margin: 0 auto;
  text-align: center;
  background-color: #eb6b6a;
  border-radius: 1.25rem;
  padding: 0.3125rem 0;
  box-sizing: border-box;
  color: white;
  font-weight: bold;
  font-size: 1.125rem;
  letter-spacing: 0.025em;
}
@media (max-width: 980px) {
  .project table th p {
    font-size: 1rem;
    padding: 0.125rem 0;
  }
}
.project table td {
  padding: 0.625rem 2.1875rem 1.875rem;
  box-sizing: border-box;
  border: 0.0625rem solid #d2d2d2;
  border-collapse: collapse;
  text-align: center;
  font-size: 1.040625rem;
}
@media (max-width: 980px) {
  .project table td {
    padding: 0.625rem;
    font-size: 1rem;
  }
}
.project .pagination {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 3.75rem;
}
.project .pagination a {
  width: 1.875rem;
  height: 1.875rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0.3125rem;
  background-color: #b4b4b4;
  border-radius: 50%;
  font-size: 0.875rem;
  line-height: 1.5rem;
  transition: all 0.3s;
  box-sizing: border-box;
  text-decoration: none;
  color: white;
}
.project .pagination a:hover, .project .pagination a.active {
  background-color: #ff8d8d;
}
.project .pagination a:first-child, .project .pagination a:last-child {
  width: auto;
  height: auto;
  border-radius: 1.25rem;
  padding: 0.375rem 0.75rem;
  font-size: 0.875rem;
  line-height: 1.5rem;
  background-color: #eb6b6a;
}
.project .pagination a:first-child .pagination_icon {
  margin-right: 0.3125rem;
}
.project .pagination a:last-child .pagination_icon {
  margin-left: 0.3125rem;
  transform: rotate(180deg);
}
.project .pagination_icon {
  width: 0.5rem;
  height: 0;
  padding-bottom: 0.875rem;
  box-sizing: border-box;
  background-image: url("../images/icon-pagination.svg");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
.project .footer {
  background-color: #fdd283;
}
.project .footer .container {
  position: relative;
  z-index: 1;
}
@media (max-width: 1440px) {
  .project .footer .container {
    max-width: 56.25rem;
  }
}
.project .footer .container::before, .project .footer .container::after {
  content: "";
  display: block;
  height: 0;
  box-sizing: border-box;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
}
.project .footer .container::before {
  width: 12.5663716814%;
  padding-bottom: 11.2389380531%;
  background-image: url("../images/Calla_lily.svg");
  right: calc(100% + 80px);
  top: 2.3125rem;
}
@media (max-width: 1440px) {
  .project .footer .container::before {
    right: 100%;
    transform: scale(0.85);
  }
}
@media (max-width: 980px) {
  .project .footer .container::before {
    display: none;
  }
}
.project .footer .container::after {
  width: 11.3274336283%;
  padding-bottom: 7.9646017699%;
  background-image: url("../images/hydrangeas.png");
  left: calc(100% + 40px);
  top: 4.6875rem;
}
@media (max-width: 1440px) {
  .project .footer .container::after {
    left: calc(100% - 70px);
    top: 6.25rem;
    transform: scale(0.9);
  }
}
@media (max-width: 980px) {
  .project .footer .container::after {
    display: none;
  }
}
.project .footer_up {
  padding: 1.875rem 1.875rem 2.5rem;
  box-sizing: border-box;
}
@media (max-width: 980px) {
  .project .footer_up {
    padding: 0.9375rem 0 0.625rem;
  }
}
.project .footer_up p {
  text-align: right;
}
@media (max-width: 980px) {
  .project .footer_up p {
    margin-bottom: 1.25rem;
  }
}
.project .footer_up p a {
  font-size: 1rem;
  letter-spacing: 0.025em;
  color: #464646;
  text-decoration: none;
  position: relative;
}
.project .footer_up p a::after {
  content: "";
  display: block;
  width: 100%;
  height: 0.0625rem;
  background-color: #464646;
  position: absolute;
  left: 0;
  bottom: -0.1875rem;
}
.project .footer_up p a:hover {
  color: #eb6b6a;
}
.project .footer_up p a:hover::after {
  background-color: #eb6b6a;
}
.project .footer_group {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: 1.5625rem;
  gap: 0.9375rem;
}
@media (max-width: 980px) {
  .project .footer_group {
    margin-bottom: 1.25rem;
  }
  .project .footer_group:last-child {
    margin-bottom: 0.9375rem;
  }
}
.project .footer_group a {
  display: inline-block;
}
.project .footer_group a img {
  width: 100%;
}
.project .footer_group a.tourism {
  max-width: 17.5rem;
}
.project .footer_group a.shuttle {
  max-width: 17.25rem;
}
.project .footer_group span {
  display: inline-block;
  padding: 0.1875rem 1.25rem;
  box-sizing: border-box;
  background-color: #eb6b6a;
  border-radius: 5rem;
  color: white;
  letter-spacing: 0.2em;
  word-break: keep-all;
}
@media (max-width: 980px) {
  .project .footer_group span {
    padding: 0.1875rem 0.9375rem;
  }
}
.project .footer_group div {
  color: #464646;
  position: relative;
  top: 0.125rem;
}
@media (max-width: 575px) {
  .project .footer_group div {
    width: 100%;
    margin-top: 0.3125rem;
  }
}
.project .footer_down {
  padding: 0.625rem 0.9375rem;
  box-sizing: border-box;
  background-color: #eb6b6a;
}
.project .footer_down p {
  text-align: center;
  color: white;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
}