body {
  background-color: #000000;
}
body * {
  font-family: serif;
}
section {
  min-width: 0;
  overflow: hidden;
  width: 100%;
}
h2 {
  font-size: 28px;
  line-height: 30px;
  font-family: "Lexend Zetta", sans-serif;
  font-weight: 400;
  display: inline-block;
  color: #E0CA8B;
  margin-bottom: 30px;
  position: relative;
  z-index: 20;
}
h2::before {
  content: "";
  display: block;
  width: 100px;
  height: 30px;
  background: linear-gradient(to right, #E0CA8B 0%, rgba(247, 231, 206, 0.4) 33%, rgba(0, 0, 0, 0) 100%);
  position: absolute;
  top: 0;
  right: -115px;
  bottom: 0;
  margin: auto 0;
}
.u-hidden-sp {
  display: none;
}
.portfolio_label {
  display: block;
  font-size: 3.8vw;
  padding: 2vw 0 0 0;
  text-align: center;
  color: #fff9ed;
  font-weight: bold;
}
.contact_btn--insta {
  display: block;
  margin: 20px auto 0 auto;
  background: linear-gradient(90deg, #E0CA8B 0%, #FFE59E 60%, #B4924A 100%);
  color: #450000;
  font-weight: bold;
  border-radius: 10vw;
  width: 86vw;
  max-width: 330px;
  line-height: 11vw;
  text-align: center;
  font-size: 4.3vw;
  text-decoration: none;
  box-shadow: 0 2vw 4vw rgba(224,202,139,.19);
  letter-spacing: 0.05em;
  transition: 0.2s;
  border: 2.5px solid #E0CA8B;
  margin-top: 15px;
  padding: 0;
}
.contact_btn--insta:active, .contact_btn--insta:hover {
  background: linear-gradient(90deg, #F7E7CE 0%, #E0CA8B 100%);
  color: #8f7b30;
  opacity: 0.92;
}
.contact_box a.contact_btn--insta {
  margin-top: 15px;
}
.logo-serif {
  font-family: serif, 'Noto Serif JP', Times, '游明朝', YuMincho, 'Hiragino Mincho ProN', 'MS P明朝', "MS 明朝", serif;
  font-size: 11vw;
  letter-spacing: 0.1em;
  color: #FFE59E;
  display: inline-block;
  text-shadow: 0 3vw 5vw rgba(0,0,0,0.18);
  line-height: 1;
}
.fv_red--catch {
  font-size: 6vw;
  color: #FFE59E;
  font-weight: 600;
  margin-top: 6vw;
  margin-bottom: 5vw;
  line-height: 1.2;
  text-shadow: 0 1vw 2vw rgba(0,0,0,0.13);
  text-align: left;
  position: absolute;
  top: 366px;
  left: 15px;
  z-index: 100;
}
.consultcase_inner {
  margin: 0 auto;
  max-width: 1200px;
  padding: 0 15px;
}
.h2_title.type2 {
  font-size: 5.2vw;
  color: #FFE59E;
  border-left: 0.8em solid #E0CA8B;
  padding-left: 2.2vw;
  margin-bottom: 4vw;
  font-weight: 700;
  letter-spacing: 0.01em;
}
.consultcase_list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.consultcase_list li {
  background: #fff9e72b;
  margin-bottom: 16px;
  color: #FFE59E;
  font-size: 15px;
  border-radius: 30px;
  box-shadow: 0 4vw 20vw 0 rgba(224,202,139,0.18);
  display: flex;
  align-items: center;
  padding: 2vw 3vw 2vw 13px;
  gap: 3vw;
  font-weight: 500;
  position: relative;
  border: none;
}
.consultcase_list li .consultcase_icon {
  width: 32px;
  max-width: 7vw;
  height: 32px;
  min-width: 32px;
  display: inline-block;
  margin-right: 0.7vw;
  border-radius: 18px;
  background: #ffd8002a;
  box-shadow: 0 0.5vw 2vw #fff1b80a;
}
.consultcase_list li .consultcase_text {
  flex: 1;
  font-size: 15px;
}
.voice_inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 6vw;
}
.voice_list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.voice_list li {
  background: #332100f5;
  border-radius: 28px;
  border: 3.5px solid #ffe6ae42;
  box-shadow: 0 3vw 12vw 0 rgba(224,202,139,0.075);
  margin-bottom: 21px;
  color: #FFE59E;
  font-size: 15px;
  padding: 24px 18px 18px 18px;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.voice_list .voice_text {
  margin-bottom: 2.5vw;
  padding-left: 0.3vw;
  font-size: 15px;
  line-height: 27px;
  font-weight: 400;
  letter-spacing: 0.01em;
}
.voice_list .voice_meta {
  color: #E0CA8B;
  font-size: 0.97em;
  margin-left: 7px;
  font-weight: 500;
  letter-spacing: 0.04em;
  opacity: 0.98;
}
.portfolio_nodata {
  color: #FFE59E;
  font-size: 15px;
  line-height: 33px;
  padding: 35px 15px 24px;
  text-align: center;
  margin: 0 auto 19px auto;
}
@media screen and (min-width: 768px) {
  section {
    min-width: 1200px;
    width: auto;
  }
  h2 {
    font-size: 60px;
    line-height: 130px;
    margin-bottom: 40px;
  }
  h2::before {
    width: 442px;
    height: 60px;
    right: -492px;
  }
  .u-hidden-sp {
    display: block;
  }
  .u-hidden-pc {
    display: none;
  }
  .portfolio_label {
    font-size: 1.1em;
    padding-top: 18px;
  }
  .contact_btn--insta {
    border-radius: 32px;
    width: 320px;
    line-height: 56px;
    font-size: 1.05em;
  }
  .contact_box a.contact_btn--insta {
    margin-top: 20px;
  }
  .logo-serif {
    font-size: 120px;
    text-shadow: 0 20px 32px rgba(0,0,0,0.19);
  }
  .fv_red--catch {
    font-size: 36px;
    margin-top: 28px;
    margin-bottom: 25px;
    top: 550px;
    left: 40px;
  }
  .h2_title.type2 {
    font-size: 31px;
    padding-left: 20px;
    margin-bottom: 22px;
    border-left-width: 14px;
  }
  .consultcase_list li {
    font-size: 17px;
    border-radius: 18px 40px 34px 21px/28px 33px 15px 15px;
    box-shadow: 0 38px 82px 0 rgba(224, 202, 139, 0.19);
    padding: 20px 25px 18px 16px;
    gap: 19px;
  }
  .voice_list li {
    border-radius: 44px;
    margin-bottom: 28px;
    font-size: 18px;
    padding: 32px 41px 23px 40px;
  }
  .voice_list .voice_text {
    margin-bottom: 10px;
    font-size: 1.19em;
    line-height: 34px;
  }
  .voice_list .voice_meta {
    font-size: 1.01em;
    margin-left: 11px;
  }
  .consultcase_inner, .voice_inner {
    padding: 0 40px;
  }
  .voice_list .voice_icon {
    width: 42px;
    height: 42px;
    margin-bottom: 6px;
  }
  .portfolio_nodata {
    font-size: 24px;
    line-height: 48px;
  }
}
#header .header_title {
  font-family: "Lexend Exa", sans-serif;
  color: #E0CA8B;
}
#header .header_ul li a {
  font-family: serif;
  color: #E0CA8B;
}
#header .header_inner .header_nav, #header .header_inner .header_nav::before, #header .header_inner .header_nav::after {
  background-color: #E0CA8B;
}
@media screen and (min-width: 768px) {
  #header .header_inner .header_nav, #header .header_inner .header_nav::before, #header .header_inner .header_nav::after {
    background-color: transparent;
  }
}
#nav .nav_inner .nav_list li a {
  color: #000000;
  text-decoration-line: none;
}
#nav .nav_inner {
  background-color: #E0CA8B;
}
#nav .nav_inner .nav_close::before, #nav .nav_inner .nav_close::after {
  background-color: #000000;
}
#nav .nav_inner .nav_contact {
  border: none;
}
#nav .nav_inner .nav_contact a {
  border: 1px solid #000000;
  background-color: #E0CA8B;
  color: #000000;
  text-decoration-line: none;
}
@media screen and (min-width: 768px) {
  #nav .nav_inner {
    background-color: transparent;
  }
  #nav .nav_inner .nav_close::before, #nav .nav_inner .nav_close::after {
    background-color: transparent;
  }
  #nav .nav_inner .nav_contact a {
    border: none;
    background-color: transparent;
    color: inherit;
  }
}

#fv {
    position: relative;
    width: 100%;
    height: 80vh;
    background: radial-gradient(circle at center top, #600000 0%, #000000 100%);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

#fv .rising-sun {
    position: absolute;
    top: calc(40% - 100px);
    left: 50%;
    transform: translateX(-50%);
    width: 200px;
    aspect-ratio: 1/1;
    opacity: 0;
    filter: blur(15px);
    animation: fvSunRise_v2 1s cubic-bezier(0.16, .2, 0.3, 1) forwards;
    animation-delay: 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

@keyframes fvSunRise_v2 {
    0% { transform: translate(-50%, 50px); opacity: 0; filter: blur(15px); }
    100% { transform: translate(-50%, 0); opacity: 1; filter: blur(0); }
}

#fv .rising-sun::before,
#fv .rising-sun::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    filter: blur(25px);
    z-index: 1;
}

#fv .rising-sun::before {
    width: 100%;
    height: 50%;
    background: #F7E7CE;
    transform: scale(1.2, 0.8) rotate(10deg);
    animation: fvGlowPulse_before 3s ease-in-out infinite alternate;
}

@keyframes fvGlowPulse_before {
    0% { transform: scale(1.2, 0.8) rotate(10deg); opacity: 0.5; }
    100% { transform: scale(2.4, 1) rotate(100deg); opacity: 0.7; }
}

#fv .rising-sun::after {
    width: 50%;
    height: 90%;
    background: #F7E7CE;
    transform: scale(0.8, 1.2) rotate(-20deg);
    animation: fvGlowPulse_after 5s ease-in-out infinite alternate-reverse;
}

@keyframes fvGlowPulse_after {
    0% { transform: scale(0.8, 1.2) rotate(20deg); opacity: 0.4; }
    100% { transform: scale(1.4, 1.5) rotate(-55deg); opacity: 0.6; }
}

#fv .sun-core {
    width: 100%;
    height: 100%;
    background-color: #550000;
    border: 1px solid #faf1e3;
    border-radius: 50%;
    position: relative;
    z-index: 5;
    filter: blur(3px);
    box-shadow: 0 0 100px rgba(224, 202, 139, 5);
}

/* --- #fv テキストコンテンツ（最後の一押し） --- */
#fv .fv-content {
    z-index: 10;
    text-align: center;
    display: block;
    width: 100%;
    position: absolute;
    top: 75%;
    left: 50%;
    transform: translate(-50%, calc(-50% + 5px));
    opacity: 0;
    animation: fvFadeIn 1s ease-out forwards;
    animation-delay: 1.4s;
}

#fv .main-logo {
    color: #E0CA8B;
    font-size: 48px;
    line-height: 1.6;
    font-weight: 400;
    letter-spacing: -0.05em;
    font-family: "Lexend Exa", sans-serif;
    margin: 0;
    text-shadow: 0 0 15px rgba(184, 134, 11, 0.4);
    position: absolute;
    top: 40%;
    left: 50%;
    transform: translate(-50%, calc(-50% + 5px));
    opacity: 0;
    animation: fvFadeIn 1s ease-out forwards;
    animation-delay: 1.4s;
}

@keyframes fvFadeIn {
    from { opacity: 0; transform: translate(-50%, calc(-50% + 5px)) }
    to { opacity: 1; transform: translate(-50%, calc(-50%)) }
}

#fv .sub-copy {
    color: #E0CA8B;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 0.6rem;
    letter-spacing: 0.05em;
}

#fv .lead-text {
    font-size: 14px;
    color: rgba(184, 168, 122, 0.85);
    letter-spacing: 0.02em;
}

#fv .scroll-indicator {
    position: absolute;
    bottom: 20px;
    font-size: 10px;
    letter-spacing: 0.3em;
    color: #E0CA8B;
    opacity: 0.6;
}

@media screen and (min-width: 768px) {
  #fv {
    /* height: 600px; */
  }

  #fv .rising-sun {
    width: 400px;
    top: calc(40% - 200px);
  }

  #fv .fv-content {
    top: 80%;
  }
}

#aboutus {
  background: no-repeat url("../img/topgold/aboutus_bk.jpg") 0 0/cover;
  height: auto;
  position: relative;
}
#aboutus::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #000000;
  opacity: 0.92;
  position: absolute;
  top: 0;
  left: 0;
}
#aboutus .aboutus_inner {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding-top: 120px;
  padding-left: 40px;
  padding-right: 40px;
  padding: 60px 15px;
  position: relative;
}
#aboutus .aboutus_inner .aboutus_content {
  font-size: 12px;
  line-height: 24px;
  color: #FFEFC2;
  display: block;
  width: 100%;
  position: relative;
  z-index: 20;
}
#aboutus .aboutus_content p {
  font-size: 16px;
  line-height: 1.8;
  color: #FFE59E;
  letter-spacing: 0.08em;
  margin-bottom: 16px;
  text-align: left;
}
#aboutus .aboutus_content p.large {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 24px;
}
#aboutus .aboutus_inner .h3_title {
  color: #FFE59E;
  font-size: 20px;
  line-height: 1.6;
  font-weight: 400;
  font-family: "Lexend Zetta", sans-serif;
  text-align: center;
  padding-top: 32px;
  margin: 0 0 16px;
  position: relative;
}
#aboutus .aboutus_inner .promise__inner {
  margin: 0;
  padding: 0;
  position: relative;
}
#aboutus .aboutus_inner .promise__inner li {
  padding: 20px 20px 0;
  margin-bottom: 10px;
  border-bottom: 1px solid #FFE59E;
  transition: .5s;
}
#aboutus .aboutus_inner .promise__inner li.is-open {
  background-color: #000000;
}
#aboutus .aboutus_inner .promise__inner li p {
  color: #FFE59E;
  line-height: 1.6;
  font-weight: 400;
  overflow: hidden;
}
#aboutus .aboutus_inner .promise__inner li p.outer {
  font-size: 16px;
  padding-right: 30px;
  padding-bottom: 20px;
  position: relative;
}
#aboutus .aboutus_inner .promise__inner li p.outer::after {
  content: "\002b";
  position: absolute;
  top: calc(50% - 10px);
  right: 0;
  transform: translateY(-50%);
}
#aboutus .aboutus_inner .promise__inner li.is-open p.outer::after {
  content: "\2212";
}
#aboutus .aboutus_inner .promise__inner li p.inner {
  font-size: 14px;
  max-height: 0;
  transition: .5s;
}
#aboutus .aboutus_inner .promise__inner li.is-open p.inner {
  max-height: 400px;
  padding-bottom: 20px;
}
#aboutus::after {
  content: "";
  display: none;
  width: calc(50% - 300px);
  height: 100%;
  background: no-repeat url("../img/topgold/aboutus_right.jpg") center 0/cover;
  position: absolute;
  top: 0;
  left: calc(50% + 300px);
  z-index: 25;
}
@media screen and (min-width: 768px) {
  #aboutus {
    min-height: 1000px;
  }
  #aboutus .aboutus_inner {
    width: 1200px;
    padding-bottom: 0;
    position: static;
  }
  #aboutus .aboutus_inner .aboutus_content {
    font-size: 18px;
    line-height: 50px;
    width: 571px;
  }
  #aboutus::after {
    display: block;
  }

  #aboutus .aboutus_inner .h3_title {
    text-align: left; 
  }
  #aboutus .aboutus_inner .promise__inner {
    width: 700px;
    padding-bottom: 120px;
  }
  #aboutus .aboutus_inner .promise__inner li {
    cursor: pointer;
  }
}
#portfolio {
  background: #450000;
  position: relative;
  z-index: 5;
  height: auto;
}
#portfolio .portfolio_inner {
  width: 100%;
  margin: 0 auto;
  padding: 60px 0;
  position: relative;
  z-index: 10;
}
#portfolio .portfolio_inner h2 {
  padding-left: 15px;
}
#portfolio .portfolio_inner .portfolio__slick {
  width: 100%;
}
#portfolio .portfolio_inner .portfolio__slick a {
  display: block;
  width: calc(100% - 80px);
  margin: 0 auto;
  background-color: rgba(0, 0, 0, 0.75);
  text-decoration-line: none !important;
}
#portfolio .portfolio_inner .portfolio__slick a img {
  display: block;
  width: 100%;
  max-height: 60vh;
  object-fit: cover; 
  object-position: top;
}
#portfolio .portfolio_inner .portfolio__slick a p {
  color: #FFE59E;
  line-height: 1.6;
  font-weight: 400;
}
#portfolio .portfolio_inner .portfolio__slick a p.title {
  font-size: 16px;
  padding: 20px 20px 10px;
  text-align: center;
  border-top: 1px #FFE59E dotted;
}
#portfolio .portfolio_inner .portfolio__slick a p.more {
  font-size: 14px;
  text-align: right;
  padding: 0 10px 10px;
}
#portfolio .portfolio_inner .portfolio__slick a p.more::after {
  content: ">";
  padding-left: 5px;
}
#portfolio::after {
  content: "";
  display: block;
  width: 600px;
  height: 600px;
  border: 2px solid #E0CA8B;
  border-radius: 50%;
  box-shadow: 0 0 50px #E0CA8B;
  position: absolute;
  right: -202px;
  bottom: -390px;
  z-index: 5;
}
@media screen and (min-width: 768px) {
  #portfolio .portfolio_inner {
    width: 1200px;
    padding: 120px 40px;
  }
  #portfolio::after {
    width: 800px;
    height: 800px;
    right: -225px;
    bottom: -387px;
  }
  #portfolio .portfolio_inner h2 {
    padding-left: 0;
  }
  #portfolio .portfolio_inner .portfolio__slick a {
    width: 400px;
  }
}
#plan {
  background: no-repeat url("../img/topgold/plan_bk.jpg") 0 0/cover;
  position: relative;
  height: auto;
}
#plan::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #000000;
  opacity: 0.85;
  position: absolute;
  top: 0;
  left: 0;
}
#plan .plan_inner {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 60px 0;
  position: relative;
  z-index: 10;
}
#plan .plan_inner h2 {
  padding-left: 15px;
}
#plan .plan_inner .plan__hbottom {
  color: #E0CA8B;
  font-size: 16px;
  line-height: 1.6;
  padding: 0 15px;
  margin-bottom: 30px;
}
#plan .plan_inner .plan__slick {
  display: block;
  width: 100%;
  margin-bottom: 50px;
}
#plan .plan_inner .slick-track {
  display: flex !important;
  align-items: stretch;
}
#plan .plan_inner .plan__slick--li {
  padding: 0 8px;
  height: auto;
  display: flex;
  flex: 1 0 auto;
}
#plan .plan_inner .plan__slick--li--inner {
  color: #E0CA8B;
  line-height: 1.6;
  display: block;
  width: 100%;
  border: 1px solid #E0CA8B;
  padding: 30px 20px;
  background-color: #350000;
}
#plan .plan_inner .plan__slick--li .title {
  font-size: 20px;
  line-height: 1.6;
  font-weight: 400;
  text-align: center;
  font-family: "Lexend Zetta", sans-serif;
  margin: 0 0 5px;
}
#plan .plan_inner .plan__slick--li .titlebottom {
  font-size: 20px;
  text-align: center;
  margin-bottom: 30px;
}
#plan .plan_inner .plan__slick--li .caption{
  font-size: 16px;
  margin-bottom: 20px;
}
#plan .plan_inner .plan__slick--li .price {
  font-size: 16px;
  margin-bottom: 30px;
}
#plan .plan_inner .plan__slick--li .price .large {
  font-size: 24px;
}
#plan .plan_inner .plan__slick--li .listcaption {
  font-size: 20px;
  text-align: center;
  margin-bottom: 10px;
}
#plan .plan_inner .plan__slick--li .list {
  margin: 0;
  padding: 0;
}
#plan .plan_inner .plan__slick--li .list li {
  font-size: 14px;
  list-style-type: none;
  margin-bottom: 10px;
  padding-left: 10px;
  position: relative;
}
#plan .plan_inner .plan__slick--li .list li::before {
  content: "";
  display: block;
  width: 3px;
  height: 3px;
  background-color: #E0CA8B;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}
#plan .plan_inner .plan__h3 {
  color: #FFE59E;
  font-size: 20px;
  line-height: 1.6;
  font-weight: 400;
  font-family: "Lexend Zetta", sans-serif;
  text-align: center;
  margin: 0 0 16px;
}
#plan .plan_inner .plan_tile {
  padding: 0 25px;
}
#plan .plan_inner .plan_tile li {
  display: flex;
  flex-wrap: nowrap;
  gap: 5%;
  align-items: center;
}
#plan .plan_inner .plan_tile li:not(:last-of-type) {
  margin-bottom: 10px;
}
#plan .plan_inner .plan_tile li img {
  display: block;
  width: 10%;
}
#plan .plan_inner .plan_tile li p {
  color: #FFE59E;
  font-size: 16px;
  width: 85%;
}

@media screen and (min-width: 768px) {
  #plan .plan_inner {
    width: 1200px;
    padding-bottom: 0;
  }

  #plan .plan_inner .plan__slick {
    display: flex;
    flex-wrap: nowrap;
  }
  #plan .plan_inner .plan__slick > li {
    width: calc(100% / 3);
  }

  #plan .plan_inner .plan_tile {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 120px;
  }
  #plan .plan_inner .plan_tile li {
    width: calc((100% - 40px)/3);
  }
}
#consultcase {
  width: 100%;
  background: linear-gradient(135deg, #3B2400 65%, #FFE59E 110%);
  padding: 9vw 0 6vw 0;
  margin-top: 0px;
  position: relative;
  z-index: 7;
}
@media screen and (min-width: 768px) {
  #consultcase, #voice {
    padding: 64px 0 34px 0;
  }
}
#voice {
  width: 100%;
  background: linear-gradient(133deg, #1c1206 85%, #deba6b40 160%);
  padding: 8vw 0 7vw 0;
  position: relative;
  z-index: 6;
}
#contact {
  background: no-repeat url("../img/topgold/contact_bk.jpg") 0 0/cover;
  position: relative;
}
#contact::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(153deg, rgb(0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 50%, rgba(0, 0, 0, 0.6) 70%, rgba(0, 0, 0, 0) 100%);
  position: absolute;
  top: 0;
  left: 0;
}
#contact .contact_inner {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 60px 15px;
  position: relative;
  z-index: 10;
}
#contact .contact_inner .contact_box {
  width: 100%;
  padding: 50px 10px;
  border: 1px solid #E0CA8B;
  box-shadow: 0 0 10px rgba(224, 202, 139, 0.5);
  margin: 0 auto;
  background-color: rgba(0, 0, 0, 0.3);
}
#contact .contact_inner .contact_box p {
  font-size: 18px;
  line-height: 1.6;
  color: #FFE59E;
  text-align: center;
  margin-bottom: 30px;
}
#contact .contact_inner .contact_box a {
  display: block;
  width: 150px;
  padding: 0;
  border: 1px solid #E0CA8B;
  font-size: 14px;
  line-height: 48px;
  color: #FFE59E;
  text-align: center;
  margin: 0 auto;
  text-decoration-line: none;
  transition: 0.3s;
}
#contact .contact_inner .contact_box a.contact_btn--insta {
  color: #000000;
}
#contact .contact_inner .contact_box a:hover {
  opacity: 0.5;
}
#contact .contact_inner .contact_box a:not(:last-of-type) {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  #contact .contact_inner {
    width: 1200px;
    padding: 120px 40px;
  }
  #contact .contact_inner .contact_box {
    width: 682px;
    padding: 80px 0;
    box-shadow: 0 0 40px rgba(224, 202, 139, 0.5);
    background-color: transparent;
  }
  #contact .contact_inner .contact_box p {
    font-size: 24px;
    line-height: 32px;
    margin-bottom: 40px;
  }
  #contact .contact_inner .contact_box a {
    width: 200px;
    padding: 20px 0;
    font-size: 20px;
    line-height: 32px;
  }
}
#footer {
  background-color: #000000;
  color: #E0CA8B;
}
