/*! Writen  by SCSS */
.raise_txt {
  font-size: clamp(36px, 3.334vw, 40px);
  color: #990000;
  line-height: 1.4; }
  @media screen and (max-width: 480px) {
    .raise_txt {
      font-size: 7vw; } }
  .raise_txt .sub {
    display: block;
    font-size: 60%;
    color: #221815;
    margin-bottom: 10px; }

.lead {
  font-size: clamp(14px, 1.5vw, 18px);
  line-height: 1.94; }

.read {
  font-size: clamp(12px, 1.334vw, 16px); }
  @media screen and (max-width: 480px) {
    .read {
      font-size: 14px; } }

.green {
  color: #12734c; }

.orange {
  color: #c37122; }

.orange02 {
  color: #ee7e28; }

.cap_inner {
  margin: 10px auto 0;
  max-width: 1400px;
  width: calc(100% - 60px);
  text-align: left; }
  @media screen and (max-width: 480px) {
    .cap_inner .cap_l {
      padding-left: 1em;
      text-indent: -1em; } }

.information_area {
  padding: 30px 0 clamp(40px, 5.834vw, 70px); }
  .information_area .merit_area {
    text-align: center;
    margin-bottom: clamp(50px, 7.5vw, 90px); }
    @media screen and (max-width: 820px) {
      .information_area .merit_area {
        margin-bottom: 50px; } }
    @media screen and (max-width: 480px) {
      .information_area .merit_area {
        margin-bottom: 30px; } }
    .information_area .merit_area .merit_txt {
      font-size: clamp(20px, 2.5vw, 30px);
      letter-spacing: 0.05em;
      position: relative; }
      @media screen and (max-width: 480px) {
        .information_area .merit_area .merit_txt {
          font-size: 3.6vw; } }
      .information_area .merit_area .merit_txt .big {
        font-size: 160%;
        line-height: 1.2; }
      .information_area .merit_area .merit_txt .big2 {
        font-size: 160%;
        line-height: 1.2; }
        @media screen and (max-width: 480px) {
          .information_area .merit_area .merit_txt .big2 {
            font-size: 200%; } }
      .information_area .merit_area .merit_txt .color01 {
        color: #0080c3; }
      .information_area .merit_area .merit_txt .color02 {
        color: #e88f4e; }
    .information_area .merit_area .merit_group {
      width: fit-content;
      margin: 0 auto;
      padding-top: 20px;
      margin-top: 20px;
      border-top: 1px solid #CCC;
      justify-content: center; }
      @media screen and (max-width: 820px) {
        .information_area .merit_area .merit_group {
          padding-top: 15px;
          margin-top: 15px; } }
      @media screen and (max-width: 480px) {
        .information_area .merit_area .merit_group {
          width: 100%;
          padding-top: 10px;
          margin-top: 10px;
          flex-direction: column; } }
      .information_area .merit_area .merit_group .merit_txt {
        line-height: 1.4; }
        .information_area .merit_area .merit_group .merit_txt:before, .information_area .merit_area .merit_group .merit_txt:after {
          position: absolute;
          bottom: 0;
          height: 60%;
          width: 1px;
          background: #CCC; }
          @media screen and (max-width: 480px) {
            .information_area .merit_area .merit_group .merit_txt:before, .information_area .merit_area .merit_group .merit_txt:after {
              width: 100%;
              height: 1px;
              top: 0;
              bottom: auto;
              left: 0;
              right: 0; } }
        .information_area .merit_area .merit_group .merit_txt:before {
          left: 0; }
        .information_area .merit_area .merit_group .merit_txt:nth-of-type(2) {
          padding-left: 20px;
          margin-left: 20px; }
          @media screen and (max-width: 480px) {
            .information_area .merit_area .merit_group .merit_txt:nth-of-type(2) {
              padding-left: 0px;
              margin-left: 0px;
              padding-top: 10px;
              margin-top: 10px; } }
          .information_area .merit_area .merit_group .merit_txt:nth-of-type(2):before {
            content: ""; }
  .information_area .information {
    text-align: center; }
    .information_area .information .link_button_group {
      max-width: 400px;
      margin: 20px auto 0; }
      .information_area .information .link_button_group .site_btn {
        color: #FFF;
        padding: 15px 10px; }
  .information_area .photo_group {
    max-width: 1500px;
    margin: clamp(60px, 7.5vw, 90px) auto;
    position: relative;
    display: grid;
    justify-content: space-between;
    grid-template-columns: 32.8% 32.8% 32.8%; }
    @media screen and (max-width: 480px) {
      .information_area .photo_group {
        margin: 40px auto; } }
    .information_area .photo_group .photo {
      line-height: 0; }
      .information_area .photo_group .photo.first {
        grid-row: 1/3; }
      .information_area .photo_group .photo.third {
        align-self: end; }
      .information_area .photo_group .photo.fourth {
        grid-column: 3/4;
        grid-row: 1/3; }
    .information_area .photo_group .cap_r {
      position: absolute;
      right: 0;
      top: 100%; }
  .information_area .loop_element_wrap {
    width: 100%;
    overflow: hidden; }
    .information_area .loop_element_wrap .loop_element {
      justify-content: flex-start; }
      .information_area .loop_element_wrap .loop_element .element {
        white-space: nowrap;
        line-height: 1;
        padding-right: 50px;
        animation: loop_element 70s linear infinite;
        display: flex;
        padding-right: 0;
        line-height: 0; }
        .information_area .loop_element_wrap .loop_element .element img {
          padding-right: 50px;
          max-width: none; }
          @media screen and (max-width: 820px) {
            .information_area .loop_element_wrap .loop_element .element img {
              width: 1600px; } }
          @media screen and (max-width: 480px) {
            .information_area .loop_element_wrap .loop_element .element img {
              width: 1000px; } }
@keyframes loop_element {
  100% {
    transform: translateX(-100%); } }
.concept_area .concept_group {
  position: relative;
  padding: clamp(40px, 5.834vw, 70px) 0; }
  .concept_area .concept_group .bg_concept {
    position: absolute;
    inset: 0;
    bottom: auto;
    aspect-ratio: 1600/900;
    background-position: top center;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: -1;
    background-image: url("../images/top/bg01.jpg"); }
  .concept_area .concept_group .concept_logo_group {
    flex-direction: column;
    align-items: center;
    row-gap: clamp(30px, 5vw, 60px); }
    .concept_area .concept_group .concept_logo_group .concept_logo {
      max-width: 698px;
      margin: 0 auto;
      width: 100%;
      display: flex;
      flex-direction: column;
      align-items: center;
      row-gap: clamp(30px, 5vw, 60px); }
      @media screen and (max-width: 820px) {
        .concept_area .concept_group .concept_logo_group .concept_logo {
          max-width: 600px; } }
      .concept_area .concept_group .concept_logo_group .concept_logo .concept01 {
        width: 68.77%;
        margin: 0 auto; }
  .concept_area .concept_group .concept_copy_group {
    flex-direction: column;
    row-gap: 20px;
    text-align: center; }
    .concept_area .concept_group .concept_copy_group .concept_copy {
      font-size: clamp(26px, 2.834vw, 34px);
      width: fit-content;
      margin: 0 auto;
      position: relative;
      letter-spacing: 0.1em; }
      @media screen and (max-width: 480px) {
        .concept_area .concept_group .concept_copy_group .concept_copy {
          font-size: 5.4vw; } }
      .concept_area .concept_group .concept_copy_group .concept_copy .text_deco {
        position: absolute;
        right: 25%;
        top: -15%;
        z-index: -1;
        width: 30.9%; }

.location_area .location_main {
  height: 370px;
  position: relative;
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
  background-image: url("../images/top/location_main.jpg"); }
  @media screen and (max-width: 820px) {
    .location_area .location_main {
      height: 250px;
      background-position: right 35% center; } }
  @media screen and (max-width: 480px) {
    .location_area .location_main {
      height: 180px;
      background-position: right 17% center; } }
  .location_area .location_main .sec_ttl {
    position: absolute;
    inset: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 40px;
    color: #FFF; }
.location_area .lead.first {
  text-align: center;
  margin-top: 25px;
  margin-bottom: clamp(50px, 6.25vw, 75px); }
  @media screen and (max-width: 820px) {
    .location_area .lead.first {
      margin-bottom: 40px; } }
.location_area .location_group {
  flex-direction: column; }
  .location_area .location_group .group_in {
    padding: clamp(50px, 6.667vw, 80px) 0; }
    .location_area .location_group .group_in:nth-of-type(1) {
      background-position: top center;
      background-repeat: no-repeat;
      background-size: cover;
      background-image: url("../images/top/bg02.jpg"); }
      .location_area .location_group .group_in:nth-of-type(1) .text_photo {
        flex-direction: row; }
        .location_area .location_group .group_in:nth-of-type(1) .text_photo .text_group {
          width: 100%;
          margin: 40px 0 clamp(40px, 5vw, 60px);
          align-items: center;
          text-align: center; }
          .location_area .location_group .group_in:nth-of-type(1) .text_photo .text_group .ttl_group .loc_ttl {
            justify-content: center; }
          @media screen and (max-width: 480px) {
            .location_area .location_group .group_in:nth-of-type(1) .text_photo .text_group .read {
              text-align: left; } }
      .location_area .location_group .group_in:nth-of-type(1) .map_infor .photo_group {
        width: 100%; }
        .location_area .location_group .group_in:nth-of-type(1) .map_infor .photo_group .photo_in {
          flex-direction: row;
          width: 48.34%; }
          @media screen and (max-width: 480px) {
            .location_area .location_group .group_in:nth-of-type(1) .map_infor .photo_group .photo_in {
              flex-direction: column;
              width: 48%; } }
          .location_area .location_group .group_in:nth-of-type(1) .map_infor .photo_group .photo_in .photo {
            width: 48.28%; }
            @media screen and (max-width: 480px) {
              .location_area .location_group .group_in:nth-of-type(1) .map_infor .photo_group .photo_in .photo {
                width: 100%; } }
          .location_area .location_group .group_in:nth-of-type(1) .map_infor .photo_group .photo_in .name_box {
            width: 51.72%; }
            @media screen and (max-width: 480px) {
              .location_area .location_group .group_in:nth-of-type(1) .map_infor .photo_group .photo_in .name_box {
                width: 100%; } }
    .location_area .location_group .group_in:nth-of-type(2) {
      border-bottom: 1px solid #CCC; }
      .location_area .location_group .group_in:nth-of-type(2) .map_infor {
        align-items: stretch; }
        .location_area .location_group .group_in:nth-of-type(2) .map_infor .map_image_wrap {
          display: flex;
          flex-direction: column;
          justify-content: space-between; }
          .location_area .location_group .group_in:nth-of-type(2) .map_infor .map_image_wrap .sub_photo {
            width: 48.08%; }
            @media screen and (max-width: 480px) {
              .location_area .location_group .group_in:nth-of-type(2) .map_infor .map_image_wrap .sub_photo {
                display: none; } }
    .location_area .location_group .group_in .text_photo {
      flex-direction: row-reverse; }
      @media screen and (max-width: 480px) {
        .location_area .location_group .group_in .text_photo {
          flex-direction: column;
          row-gap: 30px; } }
      .location_area .location_group .group_in .text_photo .text_group {
        width: 38.34%;
        flex-direction: column; }
        @media screen and (max-width: 480px) {
          .location_area .location_group .group_in .text_photo .text_group {
            width: 100%; } }
        .location_area .location_group .group_in .text_photo .text_group .ttl_group {
          flex-direction: column;
          row-gap: clamp(20px, 2.917vw, 35px); }
          @media screen and (max-width: 820px) {
            .location_area .location_group .group_in .text_photo .text_group .ttl_group {
              row-gap: 20px; } }
          .location_area .location_group .group_in .text_photo .text_group .ttl_group .loc_ttl {
            align-items: center;
            justify-content: flex-start;
            column-gap: 15px;
            font-size: clamp(24px, 2.5vw, 30px); }
            @media screen and (max-width: 480px) {
              .location_area .location_group .group_in .text_photo .text_group .ttl_group .loc_ttl {
                font-size: 7vw;
                justify-content: center; } }
        .location_area .location_group .group_in .text_photo .text_group .sub_photo {
          width: 54.35%;
          margin-left: auto; }
          @media screen and (max-width: 480px) {
            .location_area .location_group .group_in .text_photo .text_group .sub_photo {
              display: none;
              margin: 30px auto 0; } }
      .location_area .location_group .group_in .text_photo .photo {
        width: 53.34%;
        position: relative;
        height: max-content; }
        @media screen and (max-width: 480px) {
          .location_area .location_group .group_in .text_photo .photo {
            width: 100%; } }
        .location_area .location_group .group_in .text_photo .photo.line:before {
          content: "";
          position: absolute;
          inset: 0;
          border: 1px solid currentColor;
          transform: translate(10px, 10px);
          z-index: -1; }
          @media screen and (max-width: 480px) {
            .location_area .location_group .group_in .text_photo .photo.line:before {
              transform: translate(5px, 5px); } }
    @media screen and (max-width: 480px) {
      .location_area .location_group .group_in .map_photo {
        flex-wrap: wrap;
        gap: 20px 0; } }
    .location_area .location_group .group_in .map_photo .photo_group {
      width: 25%;
      flex-direction: column; }
      @media screen and (max-width: 480px) {
        .location_area .location_group .group_in .map_photo .photo_group {
          order: 2;
          width: 50%; } }
      @media screen and (max-width: 480px) {
        .location_area .location_group .group_in .map_photo .photo_group .photo:last-child {
          display: none; } }
    .location_area .location_group .group_in .map_photo .map_image_wrap {
      width: 43.34%; }
      @media screen and (max-width: 480px) {
        .location_area .location_group .group_in .map_photo .map_image_wrap {
          order: 1;
          width: 100%; } }
      .location_area .location_group .group_in .map_photo .map_image_wrap .map_image {
        position: relative; }
        .location_area .location_group .group_in .map_photo .map_image_wrap .map_image:after {
          content: "";
          position: absolute;
          inset: 0;
          pointer-events: none;
          border: 1px solid #c37122; }
    .location_area .location_group .group_in .map_infor {
      margin-top: clamp(30px, 4.167vw, 50px);
      align-items: flex-start; }
      @media screen and (max-width: 480px) {
        .location_area .location_group .group_in .map_infor {
          margin-top: 30px;
          flex-direction: column;
          row-gap: 30px; } }
      .location_area .location_group .group_in .map_infor.stretch {
        align-items: stretch; }
      .location_area .location_group .group_in .map_infor .map_image_wrap {
        width: 43.34%;
        position: relative; }
        @media screen and (max-width: 480px) {
          .location_area .location_group .group_in .map_infor .map_image_wrap {
            width: 100%; } }
        .location_area .location_group .group_in .map_infor .map_image_wrap .map_image {
          position: relative; }
          .location_area .location_group .group_in .map_infor .map_image_wrap .map_image:after {
            content: "";
            position: absolute;
            inset: 0;
            pointer-events: none;
            border: 1px solid #c37122; }
      .location_area .location_group .group_in .map_infor .photo_group {
        width: 52.5%;
        flex-wrap: wrap;
        gap: 30px 0; }
        @media screen and (max-width: 480px) {
          .location_area .location_group .group_in .map_infor .photo_group {
            width: 100%;
            gap: 15px 0; } }
        .location_area .location_group .group_in .map_infor .photo_group .photo_in {
          width: 47.62%;
          display: flex;
          flex-direction: column; }
          .location_area .location_group .group_in .map_infor .photo_group .photo_in .photo {
            position: relative; }
            .location_area .location_group .group_in .map_infor .photo_group .photo_in .photo .num {
              position: absolute;
              left: 0;
              top: 0;
              width: 30px;
              aspect-ratio: 1;
              display: flex;
              justify-content: center;
              align-items: center;
              line-height: 1;
              font-size: clamp(12px, 1.5vw, 18px);
              color: #FFF;
              background: #c37122; }
              @media screen and (max-width: 480px) {
                .location_area .location_group .group_in .map_infor .photo_group .photo_in .photo .num {
                  width: 26px;
                  font-size: 16px; } }
              .location_area .location_group .group_in .map_infor .photo_group .photo_in .photo .num.edu {
                background: #007205; }
              .location_area .location_group .group_in .map_infor .photo_group .photo_in .photo .num.shop {
                background: #0038d6; }
          .location_area .location_group .group_in .map_infor .photo_group .photo_in.full {
            width: 100%;
            flex-direction: row; }
            .location_area .location_group .group_in .map_infor .photo_group .photo_in.full .photo {
              width: 47.62%; }
            .location_area .location_group .group_in .map_infor .photo_group .photo_in.full .name_box {
              width: 52.38%; }
          .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box {
            flex-grow: 1;
            padding: 15px 10px;
            text-align: center;
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            background-position: top center;
            background-repeat: no-repeat;
            background-size: cover;
            background-image: url("../images/top/bg_text.jpg"); }
            @media screen and (max-width: 820px) {
              .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box {
                padding: 10px 5px; } }
            .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box .name {
              font-size: clamp(13px, 1.385vw, 18px);
              line-height: 1.4;
              margin-bottom: 10px; }
              @media screen and (max-width: 820px) {
                .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box .name {
                  margin-bottom: 5px; } }
              @media screen and (max-width: 480px) {
                .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box .name {
                  font-size: 12px; } }
              .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box .name.lt {
                letter-spacing: -0.075em; }
                @media screen and (max-width: 480px) {
                  .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box .name.lt {
                    letter-spacing: normal;
                    letter-spacing: -0.1em; } }
            .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box .minutes {
              font-size: clamp(11px, 1.231vw, 16px);
              line-height: 1.6; }
              @media screen and (max-width: 480px) {
                .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box .minutes {
                  font-size: 12px; } }
              .location_area .location_group .group_in .map_infor .photo_group .photo_in .name_box .minutes .small {
                display: block;
                font-size: 80%; }
      .location_area .location_group .group_in .map_infor .temple_group {
        width: 52.5%;
        flex-direction: column; }
        @media screen and (max-width: 480px) {
          .location_area .location_group .group_in .map_infor .temple_group {
            width: 100%; } }
        .location_area .location_group .group_in .map_infor .temple_group .text_group {
          flex-wrap: wrap;
          align-items: flex-start;
          justify-content: flex-start;
          gap: 20px; }
          @media screen and (max-width: 480px) {
            .location_area .location_group .group_in .map_infor .temple_group .text_group {
              gap: 20px 10px;
              margin-bottom: 30px; } }
          .location_area .location_group .group_in .map_infor .temple_group .text_group .num {
            width: 30px;
            aspect-ratio: 1;
            line-height: 1;
            font-size: clamp(13px, 1.385vw, 18px);
            color: #FFF;
            display: flex;
            justify-content: center;
            align-items: center;
            background: #c37122; }
            @media screen and (max-width: 480px) {
              .location_area .location_group .group_in .map_infor .temple_group .text_group .num {
                width: 26px;
                font-size: 16px; } }
          .location_area .location_group .group_in .map_infor .temple_group .text_group .temple_name {
            flex-grow: 1; }
            .location_area .location_group .group_in .map_infor .temple_group .text_group .temple_name .t01 {
              line-height: 1.2;
              margin-bottom: 5px;
              font-size: clamp(16px, 1.693vw, 22px);
              color: #c37122; }
            .location_area .location_group .group_in .map_infor .temple_group .text_group .temple_name .t02 {
              font-size: clamp(12px, 1.231vw, 16px); }
              .location_area .location_group .group_in .map_infor .temple_group .text_group .temple_name .t02 .small {
                font-size: 80%; }
          .location_area .location_group .group_in .map_infor .temple_group .text_group .read {
            width: 100%;
            line-height: 2.5; }
            @media screen and (max-width: 820px) {
              .location_area .location_group .group_in .map_infor .temple_group .text_group .read {
                line-height: 1.8; } }
        .location_area .location_group .group_in .map_infor .temple_group .photo02 .photo {
          width: 47.62%; }

.foot_cv_area {
  padding: clamp(60px, 7.5vw, 90px) 0;
  text-align: center;
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
  background-image: url("../images/top/bg_cv_area.jpg"); }
  @media screen and (max-width: 480px) {
    .foot_cv_area {
      padding: 50px 0; } }
  .foot_cv_area .link_group {
    max-width: 840px;
    margin: clamp(40px, 5vw, 60px) auto 0; }
    @media screen and (max-width: 480px) {
      .foot_cv_area .link_group {
        flex-direction: column;
        row-gap: 20px;
        margin: 30px auto 0; } }
    .foot_cv_area .link_group .site_btn {
      width: 47.62%;
      padding: 15px 10px; }
      @media screen and (max-width: 480px) {
        .foot_cv_area .link_group .site_btn {
          width: 100%; } }
