/*! Writen  by SCSS */
@media screen and (max-width: 480px) {
  .sec_main .main_image img {
    object-position: center top; } }

.main_head {
  color: #fff;
  text-shadow: 0 0 8px rgba(60, 85, 120, 0.7); }
  @media screen and (max-width: 480px) {
    .main_head {
      text-shadow: 0px 0px 0px rgba(60, 85, 120, 0.7), 0px 0px 1px rgba(60, 85, 120, 0.7), 0px 0px 2px rgba(60, 85, 120, 0.7), 0px 0px 3px rgba(60, 85, 120, 0.7), 0px 0px 4px rgba(60, 85, 120, 0.7), 0px 0px 5px rgba(60, 85, 120, 0.7); } }
  .main_head .en {
    letter-spacing: 0.1em; }

.sec_lead_wrap {
  margin-bottom: clamp(40px, 5.84%, 70px); }
  @media screen and (max-width: 480px) {
    .sec_lead_wrap {
      margin-bottom: 70px; } }
  @media screen and (max-width: 480px) {
    .sec_lead_wrap .lead {
      font-size: 20px;
      letter-spacing: 0.3em; } }
  .sec_lead_wrap .read {
    font-size: clamp(12px, 1.06vw, 16px);
    display: flex;
    flex-direction: column;
    line-height: 2.5; }
    @media screen and (max-width: 768px) {
      .sec_lead_wrap .read {
        font-size: clamp(12px, 1.82vw, 16px); } }
    @media screen and (max-width: 480px) {
      .sec_lead_wrap .read {
        font-size: 14px;
        letter-spacing: -0.09em;
        margin-inline: -5px; } }

.sec01 {
  position: relative;
  z-index: 2;
  margin-top: clamp(-20px, -1.25%, -10px); }
  .sec01 .btn_wrap {
    display: flex;
    justify-content: center;
    column-gap: 5%; }
    .sec01 .btn_wrap a {
      position: relative;
      display: block;
      font-size: clamp(16px, 1.667vw, 20px);
      width: 100%;
      max-width: 280px;
      text-align: center;
      line-height: 1;
      padding: 15px 0;
      border: 1px solid #454e5e; }
      .sec01 .btn_wrap a::after, .sec01 .btn_wrap a:before {
        content: '';
        position: absolute;
        inset: 0;
        z-index: -1; }
      .sec01 .btn_wrap a::after {
        opacity: 0;
        background: linear-gradient(90deg, #9b852e 0%, #e6cd6a 50%, #9b852e 100%);
        transition: opacity 0.3s ease-in-out 0s; }
      .sec01 .btn_wrap a::before {
        background: linear-gradient(90deg, #c6cedd 0%, #FFF 50%, #c6cedd 100%); }
      .sec01 .btn_wrap a.cr {
        border: 1px solid #8e7c44; }
        .sec01 .btn_wrap a.cr::after {
          opacity: 1; }
      @media (hover: hover) {
        .sec01 .btn_wrap a:hover {
          border: 1px solid #8e7c44; }
          .sec01 .btn_wrap a:hover::after {
            opacity: 1; } }

.sec .inner {
  max-width: 1280px; }
.sec .img {
  padding-top: 40px;
  margin-top: -40px; }
  @media screen and (max-width: 480px) {
    .sec .img {
      padding-top: 20px;
      margin-top: -20px; } }

.page_btn {
  display: flex;
  justify-content: space-between; }
  @media screen and (max-width: 480px) {
    .page_btn {
      flex-wrap: wrap;
      row-gap: 10px; } }
  .page_btn a {
    position: relative;
    font-size: clamp(14px, 1.667vw, 20px);
    display: flex;
    flex-direction: column;
    border: 1px solid #cccccc;
    max-width: 290px;
    width: 22.66%;
    row-gap: 4px;
    padding-top: 8px;
    padding-bottom: 2px;
    background: #fff;
    transition: color 0.3s ease-in-out,background 0.3s ease-in-out; }
    @media screen and (max-width: 480px) {
      .page_btn a {
        max-width: 100%;
        font-size: 16px;
        padding-top: 11px;
        padding-bottom: 5px; } }
    .page_btn a::after {
      content: '';
      position: absolute;
      inset: 1px;
      border: 1px solid;
      border-image: linear-gradient(90deg, #9c852e, #e5cc6a, #9c852e);
      border-image-slice: 1;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.3s ease-in-out 0s; }
    @media screen and (max-width: 480px) {
      .page_btn a {
        width: 48%; } }
    .page_btn a.active {
      background: #003164;
      color: #fff; }
      .page_btn a.active::after {
        opacity: 1; }
    @media (hover: hover) {
      .page_btn a:hover {
        background: #003164;
        color: #fff; }
        .page_btn a:hover::after {
          opacity: 1; } }
    .page_btn a span {
      display: inline-block;
      line-height: 1;
      text-align: center; }
    .page_btn a .text {
      text-align: center;
      letter-spacing: 0.1em; }
    .page_btn a .icon {
      transform: rotate(90deg);
      margin-inline: auto;
      width: fit-content;
      font-size: 70%; }

.sec02 .img {
  max-width: 1281px; }

.sec03 {
  background: rgba(204, 204, 204, 0.1);
  padding-bottom: 150px;
  padding-top: 150px; }
  @media screen and (max-width: 768px) {
    .sec03 {
      padding: 60px 0; } }

.sec05 {
  background: rgba(204, 204, 204, 0.1);
  padding-bottom: 150px;
  padding-top: 150px; }
  @media screen and (max-width: 768px) {
    .sec05 {
      padding: 60px 0; } }
