/*! Writen  by SCSS */
body .wrap {
  overflow: inherit; }

.main_section .main_image {
  background-image: url("../images/housing/01/main.jpg"); }

@media screen and (max-width: 480px) {
  .read_wrap {
    line-height: 1.8; } }

.housing_head {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  font-size: clamp(24px, 4.19vw, 52px);
  line-height: 1;
  letter-spacing: 0.2em;
  margin-bottom: -0.5em;
  padding-top: clamp(25px, 3.34%, 40px);
  gap: 0.3em 0; }
  @media screen and (max-width: 480px) {
    .housing_head {
      font-size: 30px; } }
  .housing_head .text_min {
    font-size: clamp(14px, 1.45vw, 18px); }

.order_head {
  font-size: clamp(24px, 2.74vw, 34px);
  line-height: 1.77; }

.sec {
  font-weight: 600; }

.sec01 {
  padding-top: clamp(60px, 8.34%, 100px);
  padding-bottom: clamp(50px, 6.67%, 80px); }

.sec02 {
  padding-top: clamp(50px, 6.67%, 80px);
  padding-bottom: clamp(60px, 15%, 180px);
  background-image: url("../images/housing/01/bg_pattern.jpg");
  background-position: top left;
  background-size: 720px 720px;
  background-repeat: repeat; }
  @media screen and (max-width: 768px) {
    .sec02 {
      background-size: 360px 360px; } }

.sec03 .bg_content {
  padding-bottom: clamp(80px, 10%, 120px); }

.sec02_line_head_wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: clamp(24px, 3.06vw, 38px);
  line-height: 1;
  margin-bottom: clamp(25px, 3.34%, 40px);
  gap: 0.5em 0;
  letter-spacing: 0.2em; }
  @media screen and (max-width: 480px) {
    .sec02_line_head_wrap {
      letter-spacing: 0.1em; } }
  .sec02_line_head_wrap .sec02_line_head {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8em;
    gap: 0 0.8em;
    letter-spacing: 0.2em; }
    .sec02_line_head_wrap .sec02_line_head::before, .sec02_line_head_wrap .sec02_line_head::after {
      content: "";
      display: block;
      width: 1px;
      height: 1.66em;
      background: currentColor; }
    .sec02_line_head_wrap .sec02_line_head::before {
      transform: rotate(-30deg); }
    .sec02_line_head_wrap .sec02_line_head::after {
      transform: rotate(30deg); }
    .sec02_line_head_wrap .sec02_line_head .text {
      flex-shrink: 0;
      margin-bottom: 0.3em; }

.sec02_merit_list {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 0 4.5%; }
  @media screen and (max-width: 480px) {
    .sec02_merit_list {
      flex-wrap: wrap;
      gap: 15px 4%; } }
  .sec02_merit_list .item {
    max-width: 317px;
    width: 26.42%; }
    @media screen and (max-width: 480px) {
      .sec02_merit_list .item {
        width: 48%; } }

.sec02_marker_text {
  margin-top: clamp(40px, 5%, 60px);
  text-align: center;
  font-size: clamp(18px, 2.41vw, 30px);
  line-height: 2; }
  @media screen and (max-width: 480px) {
    .sec02_marker_text {
      font-size: 20px; } }
  .sec02_marker_text .text {
    background: linear-gradient(transparent 60%, #ffff00 60%); }

.sec03_lead_wrap {
  position: relative;
  z-index: 2;
  margin-top: clamp(-100px, -6.49vw, -40px);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding-bottom: clamp(30px, 4.17%, 50px); }
  @media screen and (max-width: 480px) {
    .sec03_lead_wrap {
      margin-top: 0;
      flex-direction: column;
      gap: 20px; } }
  .sec03_lead_wrap .sec03_lead_image {
    z-index: 3;
    width: 64.29%; }
    @media screen and (max-width: 480px) {
      .sec03_lead_wrap .sec03_lead_image {
        width: 100%; } }
    .sec03_lead_wrap .sec03_lead_image img {
      width: 100%; }
  .sec03_lead_wrap .text_box {
    color: #fff;
    z-index: 2;
    width: 35.71%;
    padding-left: 2.66%;
    padding-right: 2.66%;
    padding-bottom: 4%;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center; }
    @media screen and (max-width: 960px) {
      .sec03_lead_wrap .text_box {
        padding-left: 5px;
        padding-right: 5px; } }
    @media screen and (max-width: 480px) {
      .sec03_lead_wrap .text_box {
        width: 100%;
        padding-bottom: 0; } }
    .sec03_lead_wrap .text_box .sec03_lead_head {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      font-size: clamp(24px, 2.33vw, 36px);
      line-height: 1.4;
      gap: 0.55em;
      letter-spacing: 0.2em; }
      @media screen and (max-width: 960px) {
        .sec03_lead_wrap .text_box .sec03_lead_head {
          letter-spacing: 0;
          flex-direction: row;
          align-items: baseline;
          gap: 0.25em; } }
      .sec03_lead_wrap .text_box .sec03_lead_head .text_marker {
        background: linear-gradient(transparent 60%, rgba(255, 255, 0, 0.6) 60%);
        padding-left: 0.3em;
        padding-right: 0.3em; }
        @media screen and (max-width: 480px) {
          .sec03_lead_wrap .text_box .sec03_lead_head .text_marker {
            padding-left: 0.1em;
            padding-right: 0.1em; } }
  .sec03_lead_wrap::before {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
    inset: 0;
    margin-top: 6.5%;
    background: #184b85; }

.sec03_list {
  padding-top: clamp(80px, 10%, 120px);
  padding-bottom: clamp(80px, 10%, 120px);
  max-width: 940px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  gap: clamp(40px, 8.52vw, 80px) 0; }
  @media screen and (max-width: 480px) {
    .sec03_list {
      gap: 40px 0;
      padding-bottom: 50px; } }
  .sec03_list .item {
    display: flex;
    align-items: center;
    justify-content: space-between; }
    @media screen and (max-width: 480px) {
      .sec03_list .item {
        flex-direction: column;
        gap: 25px 0;
        align-items: center; } }
    .sec03_list .item .image_box {
      max-width: 300px;
      width: 31.92%; }
      @media screen and (max-width: 480px) {
        .sec03_list .item .image_box {
          width: 90%; } }
    .sec03_list .item .text_box {
      width: 60.64%; }
      @media screen and (max-width: 480px) {
        .sec03_list .item .text_box {
          width: 100%; } }
      .sec03_list .item .text_box .item_number {
        line-height: 0;
        margin-bottom: 8.78%; }
        @media screen and (max-width: 480px) {
          .sec03_list .item .text_box .item_number {
            margin-bottom: 15px;
            margin-left: auto;
            margin-right: auto; } }
      .sec03_list .item .text_box .read {
        font-size: clamp(13px, 1.63vw, 16px);
        line-height: 2.19; }
        @media screen and (max-width: 480px) {
          .sec03_list .item .text_box .read {
            font-size: 14px;
            line-height: 1.8; } }
    .sec03_list .item.item01 .text_box .item_number {
      max-width: 111px;
      width: 19.48%; }
    .sec03_list .item.item02 .text_box .item_number {
      max-width: 113px;
      width: 19.83%; }
    .sec03_list .item.item03 .text_box .item_number {
      max-width: 112px;
      width: 19.65%; }
    .sec03_list .item.item04 .text_box .item_number {
      max-width: 109px;
      width: 19.13%; }

.lineup_button {
  margin-top: clamp(80px, 10%, 120px);
  max-width: 600px;
  width: 90%;
  margin-left: auto;
  margin-right: auto; }
  @media screen and (max-width: 480px) {
    .lineup_button {
      margin-top: 50px; } }
  .lineup_button a {
    width: 100%;
    height: 100%;
    display: block;
    text-align: center;
    font-size: clamp(18px, 4.06vw, 26px);
    line-height: 1;
    color: #fff;
    background: #333;
    padding: 1.38em 0.2em;
    letter-spacing: 0.2em;
    transition: opacity 0.3s ease-in-out; }
    @media (hover: hover) {
      .lineup_button a:hover {
        opacity: 0.7; } }
