/*! Writen  by SCSS */
.wrap {
  position: relative;
  clip-path: inset(0 0 0 0); }
  .wrap:before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: -1;
    background-image: url("../images/plan/detail/bg.png");
    background-position: top right;
    background-size: cover;
    background-repeat: no-repeat;
    opacity: .5; }

#premium .wrap:before {
  background-image: url("../images/plan/detail/premium_bg.jpg"); }
#premium .sec01 .in_box .txt_list li {
  background: rgba(255, 255, 255, 0.7); }
  #premium .sec01 .in_box .txt_list li:nth-child(2n) {
    background: rgba(255, 255, 255, 0.7); }

.sec01 {
  position: relative;
  padding-bottom: 120px;
  padding-top: 160px;
  z-index: 1; }
  @media screen and (max-width: 480px) {
    .sec01 {
      padding-top: 80px; } }
  .sec01 .inner {
    max-width: 1110px;
    max-width: 1200px; }
  .sec01 .flex_box {
    align-items: center; }
    @media screen and (max-width: 480px) {
      .sec01 .flex_box {
        flex-direction: column; } }
  .sec01 .in_box {
    width: 26.67%;
    display: flex;
    flex-direction: column;
    row-gap: clamp(30px, 5vw, 60px);
    margin-left: 6%; }
    @media screen and (max-width: 480px) {
      .sec01 .in_box {
        margin-left: 0;
        width: 100%; } }
    @media screen and (max-width: 480px) {
      .sec01 .in_box .txt_img {
        width: 75%;
        margin-inline: auto; } }
    .sec01 .in_box .txt_list {
      display: flex;
      flex-direction: column;
      row-gap: 10px; }
      .sec01 .in_box .txt_list li {
        font-size: clamp(18px, 2vw, 24px);
        line-height: 1;
        color: #002a55;
        text-align: center;
        padding: 0.5em 0;
        background: #e7eaf2; }
        .sec01 .in_box .txt_list li:nth-child(2n) {
          background: #ced3e2; }
    .sec01 .in_box .hanrei .cap_l {
      color: #000;
      font-weight: 500;
      margin-top: 10px;
      margin-right: -20%; }
  .sec01 .img_wrap {
    width: 64.09%; }
    @media screen and (max-width: 480px) {
      .sec01 .img_wrap {
        width: 100%; } }
    .sec01 .img_wrap .btn_wrap {
      display: flex;
      justify-content: space-between;
      max-width: 460px;
      margin-inline: auto; }
      @media screen and (max-width: 480px) {
        .sec01 .img_wrap .btn_wrap {
          width: 88%; } }
      .sec01 .img_wrap .btn_wrap li {
        position: relative;
        width: 50%;
        color: #fff;
        line-height: 1;
        text-align: center;
        font-size: clamp(16px, 1.5vw, 18px);
        background: #4b678c;
        padding: 16px 0;
        cursor: pointer;
        transition: background 0.3s ease-in-out 0s; }
        @media screen and (max-width: 480px) {
          .sec01 .img_wrap .btn_wrap li {
            padding: 10px 5px;
            align-content: center;
            line-height: 1.2; } }
        .sec01 .img_wrap .btn_wrap li.active {
          background: #002a55; }
          .sec01 .img_wrap .btn_wrap li.active::after {
            background-color: #002a55; }
        @media (hover: hover) {
          .sec01 .img_wrap .btn_wrap li:hover {
            background: #002a55; }
            .sec01 .img_wrap .btn_wrap li:hover::after {
              background-color: #002a55; } }
        .sec01 .img_wrap .btn_wrap li::after {
          content: '';
          aspect-ratio: 1;
          width: 20px;
          height: 100%;
          position: absolute;
          top: 0;
          background-color: #4b678c;
          transition: background 0.3s ease-in-out 0s; }
        .sec01 .img_wrap .btn_wrap li:nth-child(1)::after {
          right: 100%;
          clip-path: polygon(0 50%, 100% 0%, 100% 100%); }
        .sec01 .img_wrap .btn_wrap li:nth-child(2)::after {
          left: 100%;
          clip-path: polygon(100% 50%, 0 0, 0 100%); }
    .sec01 .img_wrap .img_in {
      position: relative; }
      .sec01 .img_wrap .img_in .img {
        width: 100%;
        position: absolute;
        top: 0;
        left: 0;
        opacity: 0;
        transition: opacity 0.2s ease-in-out;
        pointer-events: none; }
        .sec01 .img_wrap .img_in .img.active {
          position: relative;
          pointer-events: all;
          opacity: 1; }
  .sec01 .back {
    max-width: 182px;
    margin-inline: auto;
    display: block;
    transition: opacity 0.3s ease-in-out 0s; }
    @media (hover: hover) {
      .sec01 .back:hover {
        opacity: .7; } }
    @media screen and (max-width: 480px) {
      .sec01 .back {
        max-width: 120px; } }
  .sec01 .premium_txt {
    position: relative;
    background: #000;
    padding: 15px 0;
    width: 45%;
    max-width: 900px;
    text-align: center;
    margin-bottom: clamp(30px, 4.167vw, 50px); }
    @media screen and (max-width: 480px) {
      .sec01 .premium_txt {
        width: calc(100% - 40px);
        margin-inline: auto;
        padding: 15px;
        line-height: 1;
        font-size: 0; } }
    .sec01 .premium_txt::after {
      content: '';
      left: calc(100% - 1px);
      aspect-ratio: 1;
      height: 100%;
      background: #000;
      position: absolute;
      top: 0;
      bottom: 0;
      clip-path: polygon(100% 0, 0 0, 0 100%); }
      @media screen and (max-width: 480px) {
        .sec01 .premium_txt::after {
          display: none;
          padding: 10px; } }
    .sec01 .premium_txt img {
      height: 24px; }
      @media screen and (max-width: 480px) {
        .sec01 .premium_txt img {
          height: 16px; } }

/*# sourceMappingURL=plan_detail.css.map */
