@charset "UTF-8";
.contentsWrap_v1_2 {
  background: #fff; }

.mainWrap {
  margin: 0 auto; }
  .mainWrap .miniNav {
    background: #FBFCFE; }
    .mainWrap .miniNav ul {
      width: 100%;
      padding: 2.05vw 4.10vw;
      display: flex;
      justify-content: space-between;
      align-items: center; }
      .mainWrap .miniNav ul li a {
        color: #636B74;
        font-size: 3.33vw;
        letter-spacing: 0.11vw;
        line-height: 5.64vw; }
  .mainWrap .mainImgWrap {
    position: relative;
    height: 143.58vw; }
    .mainWrap .mainImgWrap .mainImgSlider {
      position: absolute;
      width: 100%;
      height: 100%;
      overflow: hidden; }
      .mainWrap .mainImgWrap .mainImgSlider .bgLayer {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-repeat: no-repeat;
        background-size: cover;
        background-position: center;
        opacity: 0;
        transition: opacity 1s ease-in-out;
        z-index: 0; }
        .mainWrap .mainImgWrap .mainImgSlider .bgLayer.visible {
          opacity: 1;
          z-index: 1; }
    .mainWrap .mainImgWrap .mainImgBox {
      pointer-events: none;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 99; }
      .mainWrap .mainImgWrap .mainImgBox .mainImgInner {
        position: relative;
        width: 100%;
        height: 100%;
        margin: 0 auto;
        padding: 29.23vw 7.17vw; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead {
          color: #fff;
          opacity: 0;
          transition: opacity 1s ease-in-out; }
          .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead h1 {
            font-size: 9.23vw;
            line-height: 12.05vw;
            letter-spacing: 1.8px;
            margin-bottom: 7.17vw; }
            .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead h1 span {
              display: block;
              font-size: 4.1vw;
              line-height: 6.66vw;
              margin-bottom: 2.56vw; }
          .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead p {
            font-size: 4.61vw;
            line-height: 7.17vw;
            font-weight: bold; }
          .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead.visible {
            opacity: 1;
            z-index: 1; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars {
          pointer-events: auto;
          visibility: hidden; }
  .mainWrap .estimateWrap {
    position: relative;
    height: 56px; }
    .mainWrap .estimateWrap .estimateBox {
      position: absolute;
      top: -50px;
      left: 16px;
      z-index: 999;
      display: flex;
      align-items: center;
      width: 358px;
      margin: 0 auto;
      border-radius: 8px;
      padding: 16px;
      background: #fff;
      box-shadow: 0 2px 8px -2px rgba(21, 21, 21, 0.08), 0 6px 12px -2px rgba(21, 21, 21, 0.08); }
      .mainWrap .estimateWrap .estimateBox .estimateForm {
        display: none;
        color: #222; }
        .mainWrap .estimateWrap .estimateBox .estimateForm div span.formTitle {
          display: block;
          font-size: 16px;
          line-height: 18px;
          margin-bottom: 11px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .layerBox {
          display: flex; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox {
          position: relative;
          width: 70px;
          height: 34px;
          cursor: pointer;
          font-size: 16px;
          user-select: none;
          display: inline-block;
          margin-right: 15px; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input[type="checkbox"] {
            opacity: 0;
            position: absolute;
            left: 0;
            top: 0;
            width: 0;
            height: 0;
            margin: 0;
            z-index: 2; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input[type="checkbox"]:checked + span::after {
            content: "";
            display: flex;
            align-items: center;
            justify-content: center;
            position: absolute;
            left: 0;
            top: 0;
            width: 70px;
            height: 34px;
            color: #2FAA3B;
            border-radius: 2px;
            border: 0.56px solid #2FAA3B;
            background: #fff;
            background-image: url("/img/top/v1-2-icon-checked.svg");
            background-repeat: no-repeat;
            background-position: right bottom; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input.value3[type="checkbox"]:checked + span::after {
            content: "片面"; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input.value1[type="checkbox"]:checked + span::after {
            content: "両面"; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input.value2[type="checkbox"]:checked + span::after {
            content: "4"; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input.value4[type="checkbox"]:checked + span::after {
            content: "6"; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input.value5[type="checkbox"]:checked + span::after {
            content: "8"; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox::before {
            content: "";
            position: absolute;
            left: 0;
            top: 0;
            width: 70px;
            height: 34px;
            border: 0.56px solid #DBDBDB;
            border-radius: 2px;
            background: #fff; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox span {
            position: absolute;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 16px;
            width: 70px;
            height: 34px; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox:hover {
            opacity: 0.8; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer select {
          width: 70px;
          height: 34px;
          font-size: 16px;
          border: 0.56px solid #DBDBDB;
          border-radius: 2px;
          text-align: center;
          appearance: none;
          -webkit-appearance: none;
          -moz-appearance: none; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer select.selected {
            border: 0.56px solid #2FAA3B;
            background-image: url("/img/top/v1-2-icon-checked.svg");
            background-repeat: no-repeat;
            background-position: right bottom; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox {
          display: flex;
          align-items: center; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeBoxInput {
            border-radius: 2px;
            border: 0.56px solid #DBDBDB; }
            .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeBoxInput input {
              text-align: center;
              width: 64px;
              height: 34px;
              border: 0; }
            .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeBoxInput span {
              color: #CCCCCC; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeText {
            display: inline-block;
            margin-left: 9px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimatePcs input {
          width: 100px;
          height: 34px;
          border: 0.56px solid #DBDBDB;
          text-align: center; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer, .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize, .mainWrap .estimateWrap .estimateBox .estimateForm .estimatePcs {
          margin-right: 48px; }
      .mainWrap .estimateWrap .estimateBox .btnPrimary {
        width: 100%;
        padding: 16px;
        margin: 0;
        border: 0;
        cursor: pointer; }
        .mainWrap .estimateWrap .estimateBox .btnPrimary:hover {
          opacity: 0.8; }
        .mainWrap .estimateWrap .estimateBox .btnPrimary.spNone {
          display: none; }
  .mainWrap .whatsnewWrap {
    width: 90vw;
    margin: 0 auto;
    padding: 10px 4.1vw;
    box-sizing: border-box; }
    .mainWrap .whatsnewWrap .whatsnewBox {
      display: flex;
      align-items: center;
      height: 65px;
      overflow: hidden; }
      .mainWrap .whatsnewWrap .whatsnewBox div.newImg {
        display: none; }
      .mainWrap .whatsnewWrap .whatsnewBox div.newsList {
        height: 65px;
        overflow: hidden; }
        .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul {
          list-style: none;
          margin: 0;
          padding: 0;
          transition: transform 0.5s ease; }
          .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li {
            display: none;
            align-items: center;
            height: 65px;
            line-height: 18px; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li.index {
              display: block; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li.index .topHide {
                display: none; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a {
              display: flex;
              align-items: center; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a span {
                display: -webkit-box;
                line-height: 18px;
                max-width: 95vw;
                max-height: 36px;
                text-decoration-line: underline;
                text-decoration-style: solid;
                overflow: hidden;
                text-overflow: ellipsis;
                -webkit-box-orient: vertical;
                -webkit-line-clamp: 2; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a::after {
                content: '→';
                display: flex;
                align-items: center;
                height: 20px;
                margin-left: 8px; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li span.newsBlock {
              line-height: 1;
              margin: 0 8px 8px 0;
              display: flex;
              align-items: center; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li span.newsBlock:first-child::before {
                content: 'News';
                display: flex;
                align-items: center;
                height: 20px;
                color: #fff;
                line-height: 1;
                font-size: 14px;
                padding: 2px 8px;
                margin-right: 8px;
                border-radius: 6px;
                background: #E47474; }
  .mainWrap .serviceCategoryWrap {
    position: relative;
    overflow: hidden;
    padding-left: 0; }
    .mainWrap .serviceCategoryWrap .serviceCategoryBox * {
      user-select: none; }
    .mainWrap .serviceCategoryWrap .serviceCategoryBox {
      /*overflow-x: auto;
      scrollbar-width: none;
      -ms-overflow-style: none;
      &::-webkit-scrollbar { display: none; }*/ }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner {
        width: max-content;
        display: flex;
        flex-wrap: nowrap;
        padding: 6.15vw 4.10vw 12.30vw;
        transition: transform 0.5s ease; }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scList {
          width: 81.02vw;
          padding: 4.1vw;
          margin: 0 1.02vw;
          border-radius: 2.05vw;
          box-shadow: 0 0.51vw 2.05vw -0.51vw rgba(21, 21, 21, 0.08), 0 1.53vw 3.07vw -0.51vw rgba(21, 21, 21, 0.08); }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scImg {
          border-radius: 2.05vw;
          overflow: hidden;
          line-height: 0;
          margin-bottom: 4.1vw; }
          .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scImg img {
            user-drag: none;
            -webkit-user-drag: none;
            width: 100%; }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox {
          color: #222; }
          .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox h2 {
            font-size: 5.12vw;
            text-align: center;
            margin-bottom: 4.1vw; }
          .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox p {
            font-size: 4.1vw;
            line-height: 6.66vw;
            margin-bottom: 4.1vw; }
          .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox div {
            font-size: 3.07vw;
            font-weight: bold;
            display: flex;
            justify-content: space-between;
            align-items: center; }
          .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox .btnEstimate {
            color: #fff;
            background: #2FAA3B;
            border-radius: 4.1vw;
            padding: 1.53vw 3.07vw; }
            .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox .btnEstimate.blank {
              background: transparent; }
          .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox .btnDetail {
            text-decoration: underline; }
    .mainWrap .serviceCategoryWrap .arrow {
      position: absolute;
      z-index: 10;
      top: calc(50% - 7vw);
      height: 14.35vw;
      width: 14.35vw;
      cursor: pointer;
      background-color: rgba(221, 221, 221, 0.7);
      background-image: url("/img/top/arrow.svg");
      background-size: cover;
      border-radius: 50%; }
      .mainWrap .serviceCategoryWrap .arrow.left {
        left: 6.15%;
        transform: scaleX(-1); }
      .mainWrap .serviceCategoryWrap .arrow.right {
        right: 6.15%; }
      .mainWrap .serviceCategoryWrap .arrow:hover {
        background-color: rgba(221, 221, 221, 0.9); }
  .mainWrap .flex3 {
    max-width: 1116px;
    width: 100%;
    margin: 0 auto; }
    .mainWrap .flex3 .flexInner {
      width: 100%;
      color: #111;
      margin-bottom: 6.15vw; }
      .mainWrap .flex3 .flexInner:last-child {
        margin-bottom: 0; }
      .mainWrap .flex3 .flexInner .flexImg {
        display: block;
        height: 52.05vw;
        border-radius: 2.05vw;
        overflow: hidden; }
        .mainWrap .flex3 .flexInner .flexImg img {
          width: 100%; }
      .mainWrap .flex3 .flexInner .flexTextBox {
        padding: 5.12vw 5.12vw 0; }
        .mainWrap .flex3 .flexInner .flexTextBox h3 {
          font-size: 4.45vw;
          text-align: center;
          line-height: 1;
          margin-bottom: 3.84vw; }
          .mainWrap .flex3 .flexInner .flexTextBox h3 a {
            display: inline-block;
            position: relative; }
          .mainWrap .flex3 .flexInner .flexTextBox h3 a:hover {
            opacity: 0.8; }
          .mainWrap .flex3 .flexInner .flexTextBox h3 a::after {
            content: '';
            position: absolute;
            left: 0;
            bottom: -2px;
            width: 100%;
            height: 1px;
            background: #111; }
        .mainWrap .flex3 .flexInner .flexTextBox p {
          font-size: 4.1vw;
          line-height: 6.66vw; }
  .mainWrap .contentBox {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 1440px;
    margin: 0 auto;
    padding: 18.20vw 4.1vw; }
    .mainWrap .contentBox h2 {
      width: 100%;
      font-size: 8.2vw;
      text-align: center;
      margin-bottom: 14.35vw; }
  .mainWrap .featuresWrap .flexImg:hover img {
    transition: transform 0.5s ease;
    transform: scale(1.2); }
  .mainWrap .flowWrap .flexInner a {
    text-decoration: underline; }
  .mainWrap .flowWrap .flexInner .flexImg {
    border-radius: 2.05vw 2.05vw 0 0; }
  .mainWrap .flowWrap .flexInner .flexTextBox {
    background: #FAFAFA;
    padding: 5.12vw 5.12vw 7.69vw; }
  .mainWrap .voiceWrap .flexInner {
    color: #2B3B4B; }
    .mainWrap .voiceWrap .flexInner .flexImg {
      border-radius: 0 0 0 0; }
    .mainWrap .voiceWrap .flexInner .flexImg:hover img {
      opacity: 0.8; }
    .mainWrap .voiceWrap .flexInner .flexTextBox {
      padding: 3.84vw 5.12vw 0; }
      .mainWrap .voiceWrap .flexInner .flexTextBox span {
        display: inline-block;
        font-size: 3.07vw;
        line-height: 5.64vw;
        margin-bottom: 1.28vw; }
      .mainWrap .voiceWrap .flexInner .flexTextBox h3 {
        text-align: left;
        margin-bottom: 1.28vw; }

@media (min-width: 768px) {
  .mainWrap .miniNav ul {
    padding: 5.6px 22.75px;
    justify-content: flex-start; }
    .mainWrap .miniNav ul li a {
      font-size: 9.24px;
      letter-spacing: 0.32px;
      line-height: 19.91px;
      margin-right: 22.75px; }
      .mainWrap .miniNav ul li a:hover {
        opacity: 0.8; }
  .mainWrap .mainImgWrap {
    height: 355.55px; }
    .mainWrap .mainImgWrap .mainImgBox .mainImgInner {
      width: 910.22px;
      padding: 0; }
      .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead {
        position: absolute;
        top: 102.4px;
        left: 53.31px; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead h1 {
          font-size: 28.44px;
          line-height: 34.13px;
          letter-spacing: 1.42px;
          margin-bottom: 17.77px; }
          .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead h1 span {
            font-size: 11.37px;
            line-height: 18.48px;
            margin-bottom: 7.11px; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead p {
          font-size: 12.8px;
          line-height: 19.91px; }
      .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars {
        visibility: visible;
        position: absolute;
        top: 301.51px;
        right: 0;
        display: flex;
        gap: 7.11px;
        z-index: 2;
        max-width: 244.62px; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars .progress-bar {
          width: 42.66px;
          height: 2.84px;
          background-color: rgba(255, 255, 255, 0.3);
          overflow: hidden;
          border-radius: 1.42px; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars .progress-fill {
          height: 100%;
          width: 0%;
          background-color: #fff;
          transition: none; }
  .mainWrap .estimateWrap {
    height: 40.53px; }
    .mainWrap .estimateWrap .estimateBox {
      top: -35.55px;
      left: calc((1024px - 910.22px) / 2);
      width: 910.22px;
      border-radius: 5.68px;
      padding: 14.22px 0 14.22px 54.75px;
      background: #fff; }
      .mainWrap .estimateWrap .estimateBox .estimateForm {
        display: flex; }
        .mainWrap .estimateWrap .estimateBox .estimateForm div span.formTitle {
          font-size: 11.37px;
          line-height: 12.8px;
          margin-bottom: 7.82px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox {
          width: 46.77px;
          height: 24.17px;
          font-size: 9.95px;
          margin-right: 15px; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input[type="checkbox"]:checked + span::after {
            width: 46.77px;
            height: 24.17px; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox::before {
            width: 46.77px;
            height: 24.17px; }
          .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox span {
            font-size: 9.95px;
            width: 46.77px;
            height: 24.17px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer select {
          width: 46.77px;
          height: 24.17px;
          font-size: 9.95px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeBoxInput input {
          width: 45.51px;
          height: 24.17px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeText {
          margin-left: 6.4px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimatePcs input {
          width: 71.11px;
          height: 24.17px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer, .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize, .mainWrap .estimateWrap .estimateBox .estimateForm .estimatePcs {
          margin-right: 34.13px; }
      .mainWrap .estimateWrap .estimateBox .btnPrimary {
        width: 142.22px;
        padding: 11.37px; }
        .mainWrap .estimateWrap .estimateBox .btnPrimary.spNone {
          display: block; }
  .mainWrap .whatsnewWrap {
    width: 910.22px;
    padding: 10px 0;
    height: 56px; }
    .mainWrap .whatsnewWrap .whatsnewBox {
      display: flex;
      align-items: center;
      height: 56px;
      overflow: hidden; }
      .mainWrap .whatsnewWrap .whatsnewBox div.newImg {
        display: flex;
        align-items: center;
        height: 16.35px;
        color: #fff;
        line-height: 1;
        font-size: 9.95px;
        padding: 2.13px 5.68px 1.42px;
        margin-right: 5.68px;
        border-radius: 4.26px;
        background: #E47474; }
      .mainWrap .whatsnewWrap .whatsnewBox div.newsList {
        height: 20px;
        overflow: hidden; }
        .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul {
          list-style: none;
          margin: 0;
          padding: 0;
          transition: transform 0.5s ease; }
          .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li {
            display: none;
            align-items: center;
            height: 20px;
            line-height: 20px;
            font-size: 11.37px; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li.index {
              display: flex; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a {
              display: flex;
              align-items: center; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a span {
                display: inline-block;
                max-width: 743.22px;
                text-decoration-line: underline;
                text-decoration-style: solid;
                overflow: hidden;
                white-space: nowrap;
                text-overflow: ellipsis; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a::after {
                content: '→';
                display: flex;
                align-items: center;
                height: 20px;
                margin-left: 8px; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li span.newsBlock {
              margin: 0 8px 0 0;
              display: flex;
              align-items: center; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li span.newsBlock:first-child::before {
                display: none; }
  .mainWrap .serviceCategoryWrap {
    display: flex;
    justify-content: center;
    padding-left: 49.77px; }
    .mainWrap .serviceCategoryWrap .serviceCategoryBox {
      overflow-x: auto;
      position: relative;
      overflow: hidden; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner {
        padding: 22.75px 0 37.68px; }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scList {
          width: 224.71px;
          padding: 11.37px;
          margin: 0 2.84px;
          border-radius: 5.68px;
          box-shadow: 0px 1.42px 5.68px -1.42px rgba(21, 21, 21, 0.08), 0px 4.26px 8.53px -1.42px rgba(21, 21, 21, 0.08); }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scImg {
          border-radius: 5.68px;
          margin-bottom: 11.37px; }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox h2 {
          font-size: 14.22px;
          margin-bottom: 11.37px; }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox p {
          font-size: 11.37px;
          line-height: 18.48px;
          margin-bottom: 11.37px; }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox div {
          font-size: 8.53px; }
        .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox .btnEstimate {
          border-radius: 11.37px;
          padding: 4.26px 8.53px; }
    .mainWrap .serviceCategoryWrap .arrow {
      top: calc(50% - 24.88px);
      height: 39.82px;
      width: 39.82px; }
      .mainWrap .serviceCategoryWrap .arrow.left {
        left: calc(1.6% + 49.77px); }
      .mainWrap .serviceCategoryWrap .arrow.right {
        right: 1.6%; }
  .mainWrap .flex3 {
    display: flex;
    justify-content: space-between;
    max-width: 793.6px; }
    .mainWrap .flex3 .flexInner {
      width: 253.15px;
      margin-bottom: 0; }
      .mainWrap .flex3 .flexInner .flexImg {
        height: 144.35px;
        border-radius: 5.68px; }
        .mainWrap .flex3 .flexInner .flexImg img {
          width: 100%; }
      .mainWrap .flex3 .flexInner .flexTextBox {
        padding: 14.22px 14.22px 0; }
        .mainWrap .flex3 .flexInner .flexTextBox h3 {
          font-size: 12.6px;
          margin-bottom: 10.66px; }
        .mainWrap .flex3 .flexInner .flexTextBox p {
          font-size: 11.37px;
          line-height: 18.48px; }
  .mainWrap .contentBox {
    max-width: 1024px;
    padding: 56.88px 0; }
    .mainWrap .contentBox h2 {
      font-size: 22.75px;
      margin-bottom: 39.82px; }
  .mainWrap .flowWrap .flexInner .flexImg {
    border-radius: 5.68px 5.68px 0 0; }
  .mainWrap .flowWrap .flexInner .flexTextBox {
    padding: 14.22px 14.22px 21.33px; }
  .mainWrap .voiceWrap .flexInner {
    color: #2B3B4B; }
    .mainWrap .voiceWrap .flexInner .flexImg {
      border-radius: 0 0 0 0; }
    .mainWrap .voiceWrap .flexInner .flexTextBox {
      padding: 10.66px 14.22px 0; }
      .mainWrap .voiceWrap .flexInner .flexTextBox span {
        font-size: 8.53px;
        line-height: 15.64px;
        margin-bottom: 5.68px; }
      .mainWrap .voiceWrap .flexInner .flexTextBox h3 {
        margin-bottom: 10.66px; } }
@media (min-width: 1024px) {
  .mainWrap .miniNav ul {
    padding: 0.55vw 2.22vw; }
    .mainWrap .miniNav ul li a {
      font-size: 0.9vw;
      letter-spacing: 0.03vw;
      line-height: 1.94vw;
      margin-right: 2.22vw; }
  .mainWrap .mainImgWrap {
    height: 34.72vw; }
    .mainWrap .mainImgWrap .mainImgBox .mainImgInner {
      width: 88.88vw; }
      .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead {
        top: 10vw;
        left: 5.69vw; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead h1 {
          font-size: 2.77vw;
          line-height: 3.26vw;
          letter-spacing: 0.12vw;
          margin-bottom: 1.73vw; }
          .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead h1 span {
            font-size: 1.11vw;
            line-height: 1.80vw;
            margin-bottom: 0.69vw; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead p {
          font-size: 1.25vw;
          line-height: 1.94vw; }
      .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars {
        top: 29.44vw;
        gap: 0.69vw;
        max-width: 23.88vw; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars .progress-bar {
          width: 4.16vw;
          height: 0.27vw;
          border-radius: 0.13vw; }
  .mainWrap .estimateWrap {
    height: 3.95vw; }
    .mainWrap .estimateWrap .estimateBox {
      top: -3.47vw;
      left: calc((100vw / 2) - 45.13vw);
      width: 88.88vw;
      border-radius: 0.55vw;
      padding: 1.38vw 0 1.38vw 5.37; }
      .mainWrap .estimateWrap .estimateBox .estimateForm div span.formTitle {
        font-size: 1.11vw;
        line-height: 1.25vw;
        margin-bottom: 0.76vw; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox {
        width: 4.86vw;
        height: 2.36vw;
        font-size: 0.97vw;
        margin-right: 1.04vw; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input[type="checkbox"]:checked + span::after {
          width: 4.86vw;
          height: 2.36vw; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox::before {
          width: 4.86vw;
          height: 2.36vw; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox span {
          font-size: 0.97vw;
          width: 4.86vw;
          height: 2.36vw; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer select {
        width: 4.86vw;
        height: 2.36vw;
        font-size: 0.97vw; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeBoxInput input {
        width: 4.44vw;
        height: 2.36vw; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeText {
        margin-left: 0.62vw; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimatePcs input {
        width: 6.94vw;
        height: 2.36vw; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer, .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize, .mainWrap .estimateWrap .estimateBox .estimateForm .estimatePcs {
        margin-right: 3.33vw; }
      .mainWrap .estimateWrap .estimateBox .btnPrimary {
        width: 13.88vw;
        padding: 1.11vw; }
  .mainWrap .whatsnewWrap {
    width: 88.88vw; }
    .mainWrap .whatsnewWrap .whatsnewBox div.newImg {
      display: flex;
      align-items: center;
      height: 1.59vw;
      color: #fff;
      line-height: 1;
      font-size: 0.97vw;
      padding: 0.20vw 0.55vw 0.13vw;
      margin-right: 0.55vw;
      border-radius: 0.41vw;
      background: #E47474; }
    .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li {
      font-size: 1.11vw; }
      .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a span {
        max-width: 75.38vw; }
  .mainWrap .serviceCategoryWrap {
    padding-left: 4.86vw; }
    .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner {
      padding: 2.22vw 0 3.68vw; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scList {
        width: 21.94vw;
        padding: 1.11vw;
        margin: 0 0.27vw;
        border-radius: 0.55vw;
        box-shadow: 0 0.13vw 0.55vw -0.13vw rgba(21, 21, 21, 0.08), 0 0.41vw 0.83vw -0.13vw rgba(21, 21, 21, 0.08); }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scImg {
        border-radius: 0.55vw;
        margin-bottom: 1.11vw; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox h2 {
        font-size: 1.38vw;
        margin-bottom: 1.11vw; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox p {
        font-size: 1.11vw;
        line-height: 1.8vw;
        margin-bottom: 1.11vw; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox div {
        font-size: 0.83vw; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox .btnEstimate {
        border-radius: 1.11vw;
        padding: 0.41vw 0.83vw; }
    .mainWrap .serviceCategoryWrap .arrow.left {
      left: calc(1.6% + 4.86vw); }
  .mainWrap .flex3 {
    max-width: 77.5vw; }
    .mainWrap .flex3 .flexInner {
      width: 24.72vw; }
      .mainWrap .flex3 .flexInner .flexImg {
        height: 14.09vw;
        border-radius: 0.55vw; }
        .mainWrap .flex3 .flexInner .flexImg img {
          width: 100%; }
      .mainWrap .flex3 .flexInner .flexTextBox {
        padding: 1.38vw 1.38vw 0; }
        .mainWrap .flex3 .flexInner .flexTextBox h3 {
          font-size: 1.23vw;
          margin-bottom: 1.04vw; }
        .mainWrap .flex3 .flexInner .flexTextBox p {
          font-size: 1.11vw;
          line-height: 1.80vw; }
  .mainWrap .contentBox {
    max-width: 100vw;
    padding: 5.55vw 0; }
    .mainWrap .contentBox h2 {
      font-size: 2.22vw;
      margin-bottom: 3.88vw; }
  .mainWrap .flowWrap .flexInner .flexImg {
    border-radius: 0.55vw 0.55vw 0 0; }
  .mainWrap .flowWrap .flexInner .flexTextBox {
    padding: 1.38vw 1.38vw 2.08vw; }
  .mainWrap .voiceWrap .flexInner {
    color: #2B3B4B; }
    .mainWrap .voiceWrap .flexInner .flexImg {
      border-radius: 0 0 0 0; }
    .mainWrap .voiceWrap .flexInner .flexTextBox {
      padding: 1.04vw 1.38vw 0; }
      .mainWrap .voiceWrap .flexInner .flexTextBox span {
        font-size: 0.83vw;
        line-height: 1.52vw;
        margin-bottom: 0.55vw; }
      .mainWrap .voiceWrap .flexInner .flexTextBox h3 {
        margin-bottom: 1.04vw; } }
@media (min-width: 1440px) {
  .mainWrap .miniNav ul {
    padding: 8px 32px;
    max-width: 1440px;
    margin: 0 auto; }
    .mainWrap .miniNav ul li a {
      font-size: 13px;
      letter-spacing: 0.46px;
      line-height: 28px;
      margin-right: 32px; }
  .mainWrap .mainImgWrap {
    height: 500px; }
    .mainWrap .mainImgWrap .mainImgSlider .bgLayer {
      position: absolute;
      background-size: auto; }
    .mainWrap .mainImgWrap .mainImgBox .mainImgInner {
      width: 1280px; }
      .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead {
        top: 144px;
        left: 82px; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead h1 {
          font-size: 40px;
          line-height: 47px;
          letter-spacing: 2px;
          margin-bottom: 25px; }
          .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead h1 span {
            font-size: 16px;
            line-height: 26px;
            margin-bottom: 10px; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .mainImgLead p {
          font-size: 18px;
          line-height: 28px; }
      .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars {
        top: 424px;
        gap: 10px;
        z-index: 2;
        max-width: 344px; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars .progress-bar {
          cursor: pointer;
          width: 60px;
          height: 4px;
          border-radius: 2px; }
        .mainWrap .mainImgWrap .mainImgBox .mainImgInner .progress-bars .progress-fill {
          height: 100%;
          width: 0%; }
  .mainWrap .estimateWrap {
    height: 57px; }
    .mainWrap .estimateWrap .estimateBox {
      top: -50px;
      left: calc((100vw / 2) - 650px);
      width: 1280px;
      border-radius: 8px;
      padding: 20px 0 20px 77px; }
      .mainWrap .estimateWrap .estimateBox .estimateForm div span.formTitle {
        font-size: 16px;
        line-height: 18px;
        margin-bottom: 11px; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox {
        width: 70px;
        height: 34px;
        font-size: 14px;
        margin-right: 15px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox input[type="checkbox"]:checked + span::after {
          width: 70px;
          height: 34px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox::before {
          width: 70px;
          height: 34px; }
        .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer .estimateCheckbox span {
          font-size: 14px;
          width: 70px;
          height: 34px; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer select {
        width: 70px;
        height: 34px;
        font-size: 14px; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeBoxInput input {
        width: 64px;
        height: 34px; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize .sizeBox .sizeText {
        margin-left: 9px; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimatePcs input {
        width: 100px;
        height: 34px; }
      .mainWrap .estimateWrap .estimateBox .estimateForm .estimateLayer, .mainWrap .estimateWrap .estimateBox .estimateForm .estimateSize, .mainWrap .estimateWrap .estimateBox .estimateForm .estimatePcs {
        margin-right: 48px; }
      .mainWrap .estimateWrap .estimateBox .btnPrimary {
        width: 200px;
        padding: 16px; }
  .mainWrap .whatsnewWrap {
    width: 1280px; }
    .mainWrap .whatsnewWrap .whatsnewBox {
      display: flex;
      align-items: center;
      height: 56px;
      overflow: hidden; }
      .mainWrap .whatsnewWrap .whatsnewBox div.newImg {
        display: flex;
        align-items: center;
        height: 23px;
        color: #fff;
        line-height: 1;
        font-size: 14px;
        padding: 3px 8px 2px;
        margin-right: 8px;
        border-radius: 6px;
        background: #E47474; }
      .mainWrap .whatsnewWrap .whatsnewBox div.newsList {
        height: 20px;
        overflow: hidden; }
        .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul {
          list-style: none;
          margin: 0;
          padding: 0;
          transition: transform 0.5s ease; }
          .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li {
            display: none;
            align-items: center;
            height: 20px;
            line-height: 20px;
            font-size: 16px; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li.index {
              display: flex; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a {
              display: flex;
              align-items: center; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a span {
                display: inline-block;
                max-width: 1100px;
                text-decoration-line: underline;
                text-decoration-style: solid;
                overflow: hidden;
                white-space: nowrap;
                text-overflow: ellipsis; }
              .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li a::after {
                content: '→';
                display: flex;
                align-items: center;
                height: 20px;
                margin-left: 8px; }
            .mainWrap .whatsnewWrap .whatsnewBox div.newsList ul li span.newsBlock {
              margin-right: 8px;
              display: flex;
              align-items: center; }
  .mainWrap .serviceCategoryWrap {
    padding-left: 70px; }
    .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner {
      display: flex;
      flex-wrap: nowrap;
      width: max-content;
      padding: 32px 0 53px; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scList {
        width: 316px;
        box-sizing: border-box;
        flex-shrink: 0;
        padding: 16px;
        margin: 0 4px;
        border-radius: 8px;
        box-shadow: 0px 2px 8px -2px rgba(21, 21, 21, 0.08), 0px 6px 12px -2px rgba(21, 21, 21, 0.08); }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scImg {
        border-radius: 8px;
        margin-bottom: 16px; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox h2 {
        font-size: 20px;
        margin-bottom: 16px; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox p {
        font-size: 16px;
        line-height: 26px;
        margin-bottom: 16px; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox div {
        font-size: 12px; }
      .mainWrap .serviceCategoryWrap .serviceCategoryBox .serviceCategoryInner .scTextBox .btnEstimate {
        border-radius: 16px;
        padding: 6px 12px; }
    .mainWrap .serviceCategoryWrap .arrow {
      position: absolute;
      z-index: 10;
      top: calc(50% - 35px);
      height: 56px;
      width: 56px;
      background-color: rgba(221, 221, 221, 0.7);
      background-image: url("/img/top/arrow.svg");
      background-size: cover;
      border-radius: 50%; }
      .mainWrap .serviceCategoryWrap .arrow.left {
        left: calc(1.6% + 70px); }
      .mainWrap .serviceCategoryWrap .arrow.right {
        right: 1.6%; }
  .mainWrap .flex3 {
    max-width: 1116px; }
    .mainWrap .flex3 .flexInner {
      width: 356px; }
      .mainWrap .flex3 .flexInner .flexImg {
        height: 203px;
        border-radius: 8px; }
        .mainWrap .flex3 .flexInner .flexImg img {
          width: 100%; }
      .mainWrap .flex3 .flexInner .flexTextBox {
        padding: 20px 20px 0; }
        .mainWrap .flex3 .flexInner .flexTextBox h3 {
          font-size: 17px;
          margin-bottom: 15px; }
        .mainWrap .flex3 .flexInner .flexTextBox p {
          font-size: 16px;
          line-height: 26px; }
  .mainWrap .contentBox {
    max-width: 1440px;
    padding: 80px 0; }
    .mainWrap .contentBox h2 {
      font-size: 32px;
      margin-bottom: 56px; }
  .mainWrap .flowWrap .flexInner .flexImg {
    border-radius: 8px 8px 0 0; }
  .mainWrap .flowWrap .flexInner .flexTextBox {
    padding: 20px 20px 30px; }
  .mainWrap .voiceWrap .flexInner {
    color: #2B3B4B; }
    .mainWrap .voiceWrap .flexInner .flexImg {
      border-radius: 0 0 0 0; }
    .mainWrap .voiceWrap .flexInner .flexTextBox {
      padding: 15px 20px 0; }
      .mainWrap .voiceWrap .flexInner .flexTextBox span {
        font-size: 12px;
        line-height: 22px;
        margin-bottom: 8px; }
      .mainWrap .voiceWrap .flexInner .flexTextBox h3 {
        margin-bottom: 15px; } }
