@charset "UTF-8";
/*
---------------------------------------------------------------------------------------------------------------------
アバウト
---------------------------------------------------------------------------------------------------------------------
*/
#beginning {
  position: relative; }
  #beginning .favicon {
    position: sticky;
    top: 0;
    left: 0;
    z-index: -1;
    opacity: 0.8; }
    #beginning .favicon .favicon-ue {
      position: absolute;
      max-width: 400px;
      width: 60%; }
    #beginning .favicon .favicon-right {
      position: absolute;
      top: 300px;
      right: 0;
      max-width: 300px;
      width: 30%; }
  #beginning .prologue {
    padding-top: 60px; }
    @media (min-width: 768px) {
      #beginning .prologue {
        padding-top: 100px; } }
    @media (min-width: 1200px) {
      #beginning .prologue {
        padding-top: 160px; } }
  #beginning .copy {
    max-width: 1200px;
    width: 90%;
    margin: 40px auto 0; }
    @media (min-width: 768px) {
      #beginning .copy {
        display: flex;
        justify-content: center;
        margin: 80px auto 0; } }
    @media (min-width: 1200px) {
      #beginning .copy {
        margin: 160px auto 0; } }
    #beginning .copy .sp-data {
      width: 70%;
      margin: 0 auto 20px; }
      @media (min-width: 768px) {
        #beginning .copy .sp-data {
          display: none; } }
    #beginning .copy ul {
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 0 20px 0; }
      @media (min-width: 768px) {
        #beginning .copy ul {
          margin: 0 30px 0 0; } }
      @media (min-width: 1024px) {
        #beginning .copy ul {
          margin: 0 40px 0 0; } }
      @media (min-width: 1200px) {
        #beginning .copy ul {
          margin: 0 80px 0 0; } }
      #beginning .copy ul:last-child {
        margin-right: 0; }
      #beginning .copy ul li {
        margin: 0 20px 0 0; }
        @media (min-width: 768px) {
          #beginning .copy ul li {
            margin: 0 30px 0 0; } }
        @media (min-width: 1024px) {
          #beginning .copy ul li {
            margin: 0 40px 0 0; } }
        @media (min-width: 1200px) {
          #beginning .copy ul li {
            margin: 0 80px 0 0; } }
        #beginning .copy ul li:last-child {
          margin-right: 0; }
        #beginning .copy ul li:nth-child(1), #beginning .copy ul li:nth-child(3) {
          width: 50%; }
          @media (min-width: 768px) {
            #beginning .copy ul li:nth-child(1), #beginning .copy ul li:nth-child(3) {
              width: 30%; } }
        #beginning .copy ul li:nth-child(2) {
          display: none; }
          @media (min-width: 768px) {
            #beginning .copy ul li:nth-child(2) {
              display: block;
              width: 40%; } }
  #beginning .btn-beginning {
    margin-top: 40px; }
    @media (min-width: 768px) {
      #beginning .btn-beginning {
        margin-top: 100px; } }
    @media (min-width: 768px) {
      #beginning .btn-beginning ul {
        display: flex;
        justify-content: center; } }
    #beginning .btn-beginning ul li {
      margin-bottom: 15px; }
      #beginning .btn-beginning ul li:last-child {
        margin-bottom: 0; }
      @media (min-width: 768px) {
        #beginning .btn-beginning ul li:first-child {
          padding-right: 15px; }
        #beginning .btn-beginning ul li:last-child {
          padding-left: 15px; } }
      #beginning .btn-beginning ul li a:hover .service-btn > h6 {
        color: #0BB3B1; }
      #beginning .btn-beginning ul li a:hover .service-btn > svg {
        transform: scale(1.15); }
        #beginning .btn-beginning ul li a:hover .service-btn > svg #en {
          stroke: #0BB3B1;
          fill: #0BB3B1; }
        #beginning .btn-beginning ul li a:hover .service-btn > svg #ya {
          fill: #fff; }
      #beginning .btn-beginning ul li a .service-btn {
        display: flex;
        align-items: center;
        justify-content: space-between;
        background-color: #fff;
        border-radius: 10px;
        max-width: 400px;
        width: 90%;
        height: 80px;
        padding: 0 40px;
        margin: auto; }
        @media (min-width: 768px) {
          #beginning .btn-beginning ul li a .service-btn {
            height: 100px;
            width: 320px;
            padding: 0 30px; } }
        @media (min-width: 1200px) {
          #beginning .btn-beginning ul li a .service-btn {
            border-radius: 15px;
            height: 150px;
            width: 400px;
            padding: 0 60px; } }
        #beginning .btn-beginning ul li a .service-btn h6 {
          font-size: 1.0em;
          transition: .5s; }
          @media (min-width: 768px) {
            #beginning .btn-beginning ul li a .service-btn h6 {
              font-size: 1.125em; } }
          @media (min-width: 1200px) {
            #beginning .btn-beginning ul li a .service-btn h6 {
              font-size: 1.25em; } }
        #beginning .btn-beginning ul li a .service-btn svg {
          width: 30px;
          transition: .5s; }
          @media (min-width: 768px) {
            #beginning .btn-beginning ul li a .service-btn svg {
              width: 34px; } }
          #beginning .btn-beginning ul li a .service-btn svg #en {
            fill: none;
            stroke: #000;
            stroke-miterlimit: 4;
            stroke-width: 1px; }
          #beginning .btn-beginning ul li a .service-btn svg #ya {
            fill: #000; }
  #beginning .more-view {
    display: flex;
    justify-content: flex-end;
    padding-right: 5%;
    margin-top: 40px; }

.prologue {
  text-align: center; }
  .prologue h2 {
    font-feature-settings: "palt";
    font-size: 1.5em;
    line-height: 1.6em; }
    @media (min-width: 768px) {
      .prologue h2 {
        font-size: 2.0em; } }
    @media (min-width: 1200px) {
      .prologue h2 {
        font-size: 3.3em; } }
  .prologue p {
    font-size: 0.9em;
    line-height: 1.8em;
    text-align: justify;
    margin-top: 20px;
    padding: 0 5%; }
    @media (min-width: 768px) {
      .prologue p {
        text-align: center; } }
    @media (min-width: 1024px) {
      .prologue p {
        font-size: 1.125em;
        margin-top: 40px; } }

/*
---------------------------------------------------------------------------------------------------------------------
サービス
---------------------------------------------------------------------------------------------------------------------
*/
#service.service-page {
  padding-top: 60px; }
  @media (min-width: 768px) {
    #service.service-page {
      padding-top: 100px; } }
  @media (min-width: 1200px) {
    #service.service-page {
      padding-top: 160px; } }
#service .page-title-type2 {
  padding-top: 60px; }
  @media (min-width: 1024px) {
    #service .page-title-type2 {
      padding-top: 120px; } }
  @media (min-width: 1200px) {
    #service .page-title-type2 {
      padding-top: 160px; } }
#service .service-in {
  max-width: 1600px;
  margin: 40px auto 0;
  width: 90%; }
  @media (min-width: 1024px) {
    #service .service-in {
      margin: 100px auto 0; } }
  #service .service-in .service-box {
    margin-bottom: 60px; }
    @media (min-width: 768px) {
      #service .service-in .service-box .type {
        display: flex; } }
    #service .service-in .service-box .type .txt-area {
      background-color: #fff;
      border-radius: 10px;
      padding: 30px;
      display: flex;
      align-items: center; }
      @media (min-width: 768px) {
        #service .service-in .service-box .type .txt-area {
          border-radius: 15px;
          padding: 50px 40px;
          width: 65%; }
          #service .service-in .service-box .type .txt-area.left {
            margin-right: 10px; }
          #service .service-in .service-box .type .txt-area.right {
            margin-left: 10px; } }
      @media (min-width: 1200px) {
        #service .service-in .service-box .type .txt-area {
          padding: 90px 100px; } }
      #service .service-in .service-box .type .txt-area .txt-area-in.case {
        position: relative;
        top: -10%; }
      #service .service-in .service-box .type .txt-area .txt-area-in h4 {
        font-family: "Outfit", sans-serif;
        font-size: 0.9em;
        color: #0BB3B1; }
        @media (min-width: 768px) {
          #service .service-in .service-box .type .txt-area .txt-area-in h4 {
            font-size: 1.0em; } }
        @media (min-width: 1200px) {
          #service .service-in .service-box .type .txt-area .txt-area-in h4 {
            font-size: 1.125em; } }
      #service .service-in .service-box .type .txt-area .txt-area-in .title {
        margin-top: 5px; }
        @media (min-width: 1024px) {
          #service .service-in .service-box .type .txt-area .txt-area-in .title {
            margin-top: 20px; } }
        #service .service-in .service-box .type .txt-area .txt-area-in .title a {
          display: flex;
          align-items: center; }
          #service .service-in .service-box .type .txt-area .txt-area-in .title a:hover h2 {
            color: #0BB3B1; }
          #service .service-in .service-box .type .txt-area .txt-area-in .title a:hover svg {
            transform: scale(1.15); }
            #service .service-in .service-box .type .txt-area .txt-area-in .title a:hover svg #en {
              fill: #0BB3B1;
              stroke: none; }
            #service .service-in .service-box .type .txt-area .txt-area-in .title a:hover svg #ya {
              fill: #fff; }
          #service .service-in .service-box .type .txt-area .txt-area-in .title a h2 {
            font-size: 1.25em;
            margin-right: 5px;
            font-feature-settings: "palt";
            letter-spacing: 0.04em;
            transition: .5s; }
            @media (min-width: 768px) {
              #service .service-in .service-box .type .txt-area .txt-area-in .title a h2 {
                font-size: 2.5vw;
                margin-right: 10px; } }
            @media (min-width: 1200px) {
              #service .service-in .service-box .type .txt-area .txt-area-in .title a h2 {
                font-size: 2.0vw; } }
            @media (min-width: 1600px) {
              #service .service-in .service-box .type .txt-area .txt-area-in .title a h2 {
                font-size: 2.2em; } }
          #service .service-in .service-box .type .txt-area .txt-area-in .title a svg {
            width: 30px;
            transform: scale(1);
            transition: .5s;
            margin-top: 4px; }
            @media (min-width: 1024px) {
              #service .service-in .service-box .type .txt-area .txt-area-in .title a svg {
                width: 34px; } }
            #service .service-in .service-box .type .txt-area .txt-area-in .title a svg #en {
              fill: none;
              stroke: #222324;
              stroke-miterlimit: 4;
              stroke-width: 1px;
              transition: .5s; }
            #service .service-in .service-box .type .txt-area .txt-area-in .title a svg #ya {
              fill: #222324;
              transition: .5s; }
      #service .service-in .service-box .type .txt-area .txt-area-in p {
        font-size: 0.85em;
        line-height: 1.6em;
        margin-top: 20px; }
        @media (min-width: 768px) {
          #service .service-in .service-box .type .txt-area .txt-area-in p {
            font-size: 1.0em; } }
        @media (min-width: 1200px) {
          #service .service-in .service-box .type .txt-area .txt-area-in p {
            font-size: 1.125em;
            margin-top: 40px; } }
      #service .service-in .service-box .type .txt-area .txt-area-in .task {
        margin-top: 40px; }
        #service .service-in .service-box .type .txt-area .txt-area-in .task h3 {
          position: relative;
          font-size: 0.9em;
          color: #0BB3B1;
          border-bottom: 1px solid #0BB3B1;
          padding: 0 0 10px 18px; }
          @media (min-width: 768px) {
            #service .service-in .service-box .type .txt-area .txt-area-in .task h3 {
              font-size: 1.0em; } }
          @media (min-width: 1200px) {
            #service .service-in .service-box .type .txt-area .txt-area-in .task h3 {
              font-size: 1.125em; } }
          #service .service-in .service-box .type .txt-area .txt-area-in .task h3::before {
            content: "";
            position: absolute;
            left: 0;
            top: -6px;
            bottom: 0;
            display: flex;
            margin: auto;
            width: 12px;
            height: 12px;
            background-color: #0BB3B1;
            border-radius: 50%;
            transition: .5s; }
        #service .service-in .service-box .type .txt-area .txt-area-in .task .task-in {
          display: flex;
          margin-top: 20px; }
          #service .service-in .service-box .type .txt-area .txt-area-in .task .task-in ul {
            margin-right: 20px; }
            #service .service-in .service-box .type .txt-area .txt-area-in .task .task-in ul:last-child {
              margin-right: 0; }
            #service .service-in .service-box .type .txt-area .txt-area-in .task .task-in ul li {
              font-size: 0.85em;
              line-height: 1.4em;
              padding-left: 1em;
              text-indent: -1em;
              color: #8B837F;
              margin-bottom: 10px; }
              @media (min-width: 768px) {
                #service .service-in .service-box .type .txt-area .txt-area-in .task .task-in ul li {
                  font-size: 0.9em; } }
              @media (min-width: 1200px) {
                #service .service-in .service-box .type .txt-area .txt-area-in .task .task-in ul li {
                  font-size: 1.0em; } }
              #service .service-in .service-box .type .txt-area .txt-area-in .task .task-in ul li:last-child {
                margin-bottom: 0; }
    #service .service-in .service-box .type .photo {
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      border-radius: 10px;
      height: 200px;
      margin-bottom: 10px; }
      @media (min-width: 768px) {
        #service .service-in .service-box .type .photo {
          border-radius: 15px;
          width: 35%;
          height: auto;
          margin-bottom: 0; } }
      #service .service-in .service-box .type .photo.type1 {
        background-image: url("../../img/top/service1.webp"); }
      #service .service-in .service-box .type .photo.type2 {
        background-image: url("../../img/top/service2.webp"); }
      #service .service-in .service-box .type .photo.type3 {
        background-image: url("../../img/top/service3.webp"); }
      #service .service-in .service-box .type .photo.type4 {
        background-image: url("../../img/top/service4.webp"); }
    #service .service-in .service-box .case-study {
      background-color: #0BB3B1;
      border-radius: 10px;
      position: relative;
      padding: 40px 0;
      margin-top: -5%; }
      @media (min-width: 1024px) {
        #service .service-in .service-box .case-study {
          right: -2.5%;
          display: flex;
          border-radius: 20px; } }
      #service .service-in .service-box .case-study .title-area {
        margin: 0 0 20px 5%; }
        @media (min-width: 1024px) {
          #service .service-in .service-box .case-study .title-area {
            width: 20%;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0; } }
        #service .service-in .service-box .case-study .title-area .title {
          color: #fff; }
          #service .service-in .service-box .case-study .title-area .title p {
            font-family: "Outfit", sans-serif;
            font-size: 0.9em;
            margin-bottom: 5px; }
            @media (min-width: 1200px) {
              #service .service-in .service-box .case-study .title-area .title p {
                font-size: 1.125em;
                margin-bottom: 10px; } }
          #service .service-in .service-box .case-study .title-area .title h2 {
            font-size: 1.75em;
            font-weight: 700; }
            @media (min-width: 1200px) {
              #service .service-in .service-box .case-study .title-area .title h2 {
                font-size: 2.2em; } }
      #service .service-in .service-box .case-study .casestudy-card {
        overflow: hidden;
        position: relative;
        padding: 50px 5% 0;
        margin-top: -50px; }
        @media (min-width: 1024px) {
          #service .service-in .service-box .case-study .casestudy-card {
            width: 80%;
            padding: 50px 0 0 0; } }
        #service .service-in .service-box .case-study .casestudy-card .swiper-button-prev, #service .service-in .service-box .case-study .casestudy-card .swiper-button-next {
          top: 30px;
          right: 5%; }
          @media (min-width: 1024px) {
            #service .service-in .service-box .case-study .casestudy-card .swiper-button-prev, #service .service-in .service-box .case-study .casestudy-card .swiper-button-next {
              top: inherit;
              bottom: 0; } }
        #service .service-in .service-box .case-study .casestudy-card .swiper-button-prev {
          right: calc(5% + 40px);
          left: inherit; }
          @media (min-width: 1024px) {
            #service .service-in .service-box .case-study .casestudy-card .swiper-button-prev {
              top: inherit;
              bottom: 0; } }
          @media (min-width: 1200px) {
            #service .service-in .service-box .case-study .casestudy-card .swiper-button-prev {
              right: calc(5% + 50px); } }
      #service .service-in .service-box .case-study .story-box {
        position: relative; }
        @media (min-width: 1024px) {
          #service .service-in .service-box .case-study .story-box {
            display: flex;
            padding: 0 0 50px 0; } }
        @media (min-width: 1200px) {
          #service .service-in .service-box .case-study .story-box {
            padding: 0 0 0 0; } }
        @media (min-width: 1360px) {
          #service .service-in .service-box .case-study .story-box {
            padding: 0; } }
        #service .service-in .service-box .case-study .story-box .photo {
          position: relative; }
          @media (min-width: 1024px) {
            #service .service-in .service-box .case-study .story-box .photo {
              width: 50%; } }
          @media (min-width: 1360px) {
            #service .service-in .service-box .case-study .story-box .photo {
              width: 45%; } }
          #service .service-in .service-box .case-study .story-box .photo a:hover .imgWrap > img {
            transform: scale(1.04); }
          #service .service-in .service-box .case-study .story-box .photo a .imgWrap {
            position: relative;
            border-radius: 15px;
            overflow: hidden;
            z-index: 1; }
            #service .service-in .service-box .case-study .story-box .photo a .imgWrap img {
              transition-duration: 0.8s;
              transform: scale(1);
              border-radius: 15px; }
          #service .service-in .service-box .case-study .story-box .photo a .more-view {
            position: absolute;
            bottom: 0;
            left: 0; }
        #service .service-in .service-box .case-study .story-box .project-txt {
          margin-top: 20px; }
          @media (min-width: 1024px) {
            #service .service-in .service-box .case-study .story-box .project-txt {
              width: 50%;
              padding-left: 2%;
              margin-top: 0; } }
          @media (min-width: 1360px) {
            #service .service-in .service-box .case-study .story-box .project-txt {
              width: 45%; } }
          #service .service-in .service-box .case-study .story-box .project-txt .project-company {
            color: #fff;
            margin-bottom: 15px; }
            @media (min-width: 1024px) {
              #service .service-in .service-box .case-study .story-box .project-txt .project-company {
                margin-bottom: 20px; } }
            #service .service-in .service-box .case-study .story-box .project-txt .project-company ul.post-tags li {
              font-size: 0.95em; }
              @media (min-width: 768px) {
                #service .service-in .service-box .case-study .story-box .project-txt .project-company ul.post-tags li {
                  font-size: 1.05em; } }
            #service .service-in .service-box .case-study .story-box .project-txt .project-company ul li {
              color: #fff;
              font-size: 1.0em; }
              @media (min-width: 768px) {
                #service .service-in .service-box .case-study .story-box .project-txt .project-company ul li {
                  font-size: 1.25em; } }
          #service .service-in .service-box .case-study .story-box .project-txt .flow {
            display: flex; }
            #service .service-in .service-box .case-study .story-box .project-txt .flow ul li {
              height: 28px;
              display: flex;
              align-items: center;
              margin-bottom: 15px;
              font-size: 0.9em; }
              @media (min-width: 1024px) {
                #service .service-in .service-box .case-study .story-box .project-txt .flow ul li {
                  font-size: 1.0em; } }
              #service .service-in .service-box .case-study .story-box .project-txt .flow ul li:last-child {
                margin-bottom: 0; }
            #service .service-in .service-box .case-study .story-box .project-txt .flow ul.item {
              width: 110px; }
              @media (min-width: 768px) {
                #service .service-in .service-box .case-study .story-box .project-txt .flow ul.item {
                  width: 130px; } }
              #service .service-in .service-box .case-study .story-box .project-txt .flow ul.item li {
                position: relative;
                display: inline-block;
                width: 100px;
                border-radius: 50px;
                background-color: #fff;
                text-align: center;
                font-weight: bold;
                display: flex;
                justify-content: center;
                color: #0BB3B1; }
                @media (min-width: 1024px) {
                  #service .service-in .service-box .case-study .story-box .project-txt .flow ul.item li {
                    width: 120px; } }
                #service .service-in .service-box .case-study .story-box .project-txt .flow ul.item li:not(:last-child)::after {
                  content: "";
                  height: 20px;
                  width: 1.5px;
                  background-color: #fff;
                  position: absolute;
                  bottom: -20px; }
            #service .service-in .service-box .case-study .story-box .project-txt .flow ul.txt {
              width: calc(100% - 110px); }
              @media (min-width: 768px) {
                #service .service-in .service-box .case-study .story-box .project-txt .flow ul.txt {
                  width: calc(100% - 130px); } }
              #service .service-in .service-box .case-study .story-box .project-txt .flow ul.txt li {
                color: #fff; }
        #service .service-in .service-box .case-study .story-box .more-view {
          display: flex;
          justify-content: center;
          margin: 30px auto 0; }
          @media (min-width: 768px) {
            #service .service-in .service-box .case-study .story-box .more-view {
              position: absolute;
              bottom: 0;
              right: 5%;
              margin: 0; } }
          @media (min-width: 1024px) {
            #service .service-in .service-box .case-study .story-box .more-view {
              left: 52%;
              right: inherit; } }
          @media (min-width: 1360px) {
            #service .service-in .service-box .case-study .story-box .more-view {
              left: 47%; } }
  #service .service-in .more-view {
    display: flex;
    justify-content: center;
    margin: -30px 0 0 0; }
    @media (min-width: 768px) {
      #service .service-in .more-view {
        margin: -15px 0 0 0; } }
    @media (min-width: 1024px) {
      #service .service-in .more-view {
        justify-content: flex-end; } }
#service .discussion {
  max-width: 1600px;
  margin: 80px auto 0;
  width: 90%; }
  @media (min-width: 1024px) {
    #service .discussion {
      margin: 160px auto 0; } }
  @media (min-width: 768px) {
    #service .discussion .txt {
      display: flex;
      justify-content: space-between;
      align-items: end; } }
  @media (min-width: 1200px) {
    #service .discussion .txt {
      align-items: center; } }
  @media (min-width: 1024px) {
    #service .discussion .txt .txt-in {
      display: flex;
      align-items: center; } }
  #service .discussion .txt .txt-in h2 {
    font-size: 1.25em;
    margin: 0 0 10px 0; }
    @media (min-width: 768px) {
      #service .discussion .txt .txt-in h2 {
        font-size: 1.75em;
        margin: 0 0 20px 0; } }
    @media (min-width: 1024px) {
      #service .discussion .txt .txt-in h2 {
        margin: 0 20px 0 0; } }
    @media (min-width: 1200px) {
      #service .discussion .txt .txt-in h2 {
        font-size: 2.2em; } }
  #service .discussion .txt .txt-in p {
    font-size: 0.9em;
    font-feature-settings: "palt";
    letter-spacing: 0.04em;
    line-height: 1.4em; }
    @media (min-width: 768px) {
      #service .discussion .txt .txt-in p {
        font-size: 1.0em; } }
    @media (min-width: 1200px) {
      #service .discussion .txt .txt-in p {
        font-size: 1.125em; } }
  #service .discussion .txt .more-view {
    display: flex;
    justify-content: flex-end;
    margin: 20px 0 0 0; }
    @media (min-width: 768px) {
      #service .discussion .txt .more-view {
        margin: 0; } }
#service #repeat-txt {
  margin: 40px auto 80px;
  overflow: hidden; }
  @media (min-width: 768px) {
    #service #repeat-txt {
      margin: 40px auto 120px; } }
  #service #repeat-txt .loop {
    display: flex;
    align-items: center;
    color: #C1C1C1;
    width: 100%;
    white-space: nowrap;
    z-index: 1;
    margin-bottom: 10px; }
    #service #repeat-txt .loop:last-child {
      margin-bottom: 0; }
    #service #repeat-txt .loop ul.loop-area {
      display: flex;
      list-style: none;
      margin: 0;
      padding: 0;
      font-size: 1.35em;
      font-weight: 900; }
      @media (min-width: 1024px) {
        #service #repeat-txt .loop ul.loop-area {
          font-size: 2.0em; } }
      #service #repeat-txt .loop ul.loop-area.first {
        animation: loop-slide1 800s infinite linear 1s both; }
      #service #repeat-txt .loop ul.loop-area.second {
        animation: loop-slide2 700s infinite linear 1s both; }
      #service #repeat-txt .loop ul.loop-area.third {
        animation: loop-slide1 1400s infinite linear 1s both; }
      #service #repeat-txt .loop ul.loop-area li {
        display: inline-block;
        padding-right: 20px;
        line-height: 1.2em; }
@keyframes loop-slide1 {
  from {
    transform: translateX(0); }
  to {
    transform: translateX(-100%); } }
@keyframes loop-slide2 {
  from {
    transform: translateX(-100%); }
  to {
    transform: translateX(0); } }
/*
---------------------------------------------------------------------------------------------------------------------
その他サービス
---------------------------------------------------------------------------------------------------------------------
*/
#service-other {
  max-width: 1600px;
  margin: 40px auto 0;
  width: 90%; }
  @media (min-width: 1024px) {
    #service-other {
      margin: 100px auto 0; } }
  @media (min-width: 1024px) {
    #service-other .service-grid .o-6column .col-lg-6 {
      padding: 0 20px; }
    #service-other .service-grid .o-6column {
      margin: 0 -20px; } }
  #service-other .service-grid .service-other-box {
    background-color: #fff;
    border-radius: 10px;
    padding: 30px;
    margin-bottom: 40px; }
    @media (min-width: 1024px) {
      #service-other .service-grid .service-other-box {
        border-radius: 20px;
        padding: 60px; } }
    #service-other .service-grid .service-other-box .box-in h4 {
      font-family: "Outfit", sans-serif;
      font-size: 0.9em;
      color: #0BB3B1; }
      @media (min-width: 768px) {
        #service-other .service-grid .service-other-box .box-in h4 {
          font-size: 1.0em; } }
      @media (min-width: 1200px) {
        #service-other .service-grid .service-other-box .box-in h4 {
          font-size: 1.125em; } }
    #service-other .service-grid .service-other-box .box-in a {
      display: flex;
      align-items: center; }
      #service-other .service-grid .service-other-box .box-in a:hover h2 {
        color: #0BB3B1; }
      #service-other .service-grid .service-other-box .box-in a:hover svg {
        transform: scale(1.15); }
        #service-other .service-grid .service-other-box .box-in a:hover svg #en {
          fill: #0BB3B1;
          stroke: none; }
        #service-other .service-grid .service-other-box .box-in a:hover svg #ya {
          fill: #fff; }
      #service-other .service-grid .service-other-box .box-in a h2 {
        font-size: 1.25em;
        margin-right: 3px;
        font-feature-settings: "palt";
        letter-spacing: 0.04em;
        transition: .5s; }
        @media (min-width: 768px) {
          #service-other .service-grid .service-other-box .box-in a h2 {
            font-size: 2.5vw;
            margin-right: 5px; } }
        @media (min-width: 1200px) {
          #service-other .service-grid .service-other-box .box-in a h2 {
            font-size: 2.0vw; } }
        @media (min-width: 1600px) {
          #service-other .service-grid .service-other-box .box-in a h2 {
            font-size: 2.2em; } }
      #service-other .service-grid .service-other-box .box-in a h3 {
        font-size: 0.7em;
        display: inline-block;
        background-color: #E96087;
        color: #fff;
        padding: 3px 4px 4px;
        margin-top: 3px; }
        @media (min-width: 768px) {
          #service-other .service-grid .service-other-box .box-in a h3 {
            font-size: 1.0em;
            padding: 5px 10px; } }
      #service-other .service-grid .service-other-box .box-in a svg {
        width: 30px;
        transform: scale(1);
        transition: .5s;
        margin: 4px 0 0 5px; }
        @media (min-width: 1024px) {
          #service-other .service-grid .service-other-box .box-in a svg {
            width: 34px; } }
        #service-other .service-grid .service-other-box .box-in a svg #en {
          fill: none;
          stroke: #222324;
          stroke-miterlimit: 4;
          stroke-width: 1px;
          transition: .5s; }
        #service-other .service-grid .service-other-box .box-in a svg #ya {
          fill: #222324;
          transition: .5s; }
    #service-other .service-grid .service-other-box .box-in p {
      font-size: 0.85em;
      line-height: 1.6em;
      margin-top: 10px; }
      @media (min-width: 768px) {
        #service-other .service-grid .service-other-box .box-in p {
          font-size: 1.0em;
          margin-top: 20px; } }
      @media (min-width: 1200px) {
        #service-other .service-grid .service-other-box .box-in p {
          font-size: 1.125em;
          margin-top: 40px; } }

/*
---------------------------------------------------------------------------------------------------------------------
お問い合わせ
---------------------------------------------------------------------------------------------------------------------
*/
#contact-area {
  padding-top: 30px;
  width: 90%;
  margin: auto; }
  @media (min-width: 768px) {
    #contact-area {
      padding-top: 80px;
      display: flex;
      justify-content: center; } }
  @media (min-width: 1200px) {
    #contact-area {
      padding-top: 140px; } }
  @media (min-width: 1024px) {
    #contact-area ul {
      display: flex;
      justify-content: center; } }
  #contact-area ul li {
    display: flex;
    align-items: center;
    margin-bottom: 20px; }
    #contact-area ul li:first-child a {
      padding-left: 15px; }
    #contact-area ul li:last-child {
      margin-bottom: 0; }
      #contact-area ul li:last-child a {
        padding-right: 15px; }
    @media (min-width: 768px) {
      #contact-area ul li {
        margin-bottom: 0; }
        #contact-area ul li:first-child {
          padding-right: 15px; }
        #contact-area ul li:last-child {
          padding-left: 15px; } }
    #contact-area ul li .photo {
      width: 140px; }
    #contact-area ul li a .foam {
      position: relative;
      background-color: #E96087;
      border: solid 3px #E96087;
      width: 240px;
      border-radius: 10px;
      padding: 20px; }
      @media (min-width: 768px) {
        #contact-area ul li a .foam {
          border-radius: 20px;
          width: 300px; } }
      @media (min-width: 1200px) {
        #contact-area ul li a .foam {
          width: 340px; } }
      #contact-area ul li a .foam h6 {
        font-size: 1.0em;
        line-height: 1.4em;
        display: flex;
        justify-content: center;
        color: #fff; }
        @media (min-width: 768px) {
          #contact-area ul li a .foam h6 {
            font-size: 1.25em; } }
        @media (min-width: 1200px) {
          #contact-area ul li a .foam h6 {
            font-size: 1.375em; } }
      #contact-area ul li a .foam::before {
        content: "";
        position: absolute;
        top: 50%;
        left: -30px;
        margin-top: -15px;
        border: 15px solid transparent;
        border-right: 15px solid #E96087; }
    #contact-area ul li a .tell {
      position: relative;
      background-color: #fff;
      width: 240px;
      color: #E96087;
      border-radius: 10px;
      padding: 15px 20px;
      display: flex;
      justify-content: center;
      border: solid 3px #E96087; }
      @media (min-width: 768px) {
        #contact-area ul li a .tell {
          border-radius: 20px;
          padding: 20px;
          width: 300px; } }
      @media (min-width: 1200px) {
        #contact-area ul li a .tell {
          width: 340px; } }
      #contact-area ul li a .tell::after {
        content: "";
        position: absolute;
        top: 50%;
        right: -30px;
        margin-top: -14px;
        border: 14px solid transparent;
        border-left: 14px solid #E96087;
        z-index: 1; }
      #contact-area ul li a .tell::before {
        content: "";
        position: absolute;
        top: 50%;
        right: -24px;
        margin-top: -12px;
        border: 12px solid transparent;
        border-left: 12px solid #FFF;
        z-index: 2; }
      #contact-area ul li a .tell .tell-in h6 {
        font-size: 1.0em;
        margin-bottom: 5px; }
        @media (min-width: 768px) {
          #contact-area ul li a .tell .tell-in h6 {
            font-size: 1.125em; } }
        @media (min-width: 1200px) {
          #contact-area ul li a .tell .tell-in h6 {
            font-size: 1.3em; } }
      #contact-area ul li a .tell .tell-in .tell-btn {
        display: flex;
        align-items: center; }
        #contact-area ul li a .tell .tell-in .tell-btn img {
          width: 20px; }
        #contact-area ul li a .tell .tell-in .tell-btn h4 {
          font-family: "Outfit", sans-serif;
          font-size: 1.5em; }
          @media (min-width: 768px) {
            #contact-area ul li a .tell .tell-in .tell-btn h4 {
              font-size: 1.7em; } }
          @media (min-width: 1200px) {
            #contact-area ul li a .tell .tell-in .tell-btn h4 {
              font-size: 2.0em; } }

/*
---------------------------------------------------------------------------------------------------------------------
お困りごとから相談する
---------------------------------------------------------------------------------------------------------------------
*/
#problems {
  padding-top: 60px; }
  @media (min-width: 768px) {
    #problems {
      padding-top: 100px; } }
  @media (min-width: 1200px) {
    #problems {
      padding-top: 160px; } }
  #problems .problems-in {
    max-width: 1600px;
    margin: 40px auto 0;
    width: 90%; }
    @media (min-width: 1024px) {
      #problems .problems-in {
        margin: 100px auto 0; } }
    #problems .problems-in .problems-box {
      border-radius: 10px;
      padding: 40px 0;
      margin-bottom: 10px; }
      @media (min-width: 768px) {
        #problems .problems-in .problems-box {
          border-radius: 20px;
          padding: 80px 0; } }
      @media (min-width: 1200px) {
        #problems .problems-in .problems-box {
          padding: 100px 0;
          margin-bottom: 20px; } }
      #problems .problems-in .problems-box:last-child {
        margin-bottom: 0; }
      #problems .problems-in .problems-box.color1 {
        background-color: #BEEBEF; }
      #problems .problems-in .problems-box.color2 {
        background-color: #C2E8FC; }
      #problems .problems-in .problems-box.color3 {
        background-color: #C9F4E5; }
      #problems .problems-in .problems-box .problems-title {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 5%; }
        #problems .problems-in .problems-box .problems-title h2 {
          font-size: 1.5em;
          line-height: 1.4em;
          text-align: center; }
          @media (min-width: 768px) {
            #problems .problems-in .problems-box .problems-title h2 {
              font-size: 1.8em;
              margin: 0 5px; } }
          @media (min-width: 1200px) {
            #problems .problems-in .problems-box .problems-title h2 {
              font-size: 2.8em;
              margin: 0 10px; } }
        #problems .problems-in .problems-box .problems-title img {
          width: 20px;
          margin-top: 4px; }
      #problems .problems-in .problems-box .contents {
        padding: 0 20px;
        margin-top: 40px; }
        @media (min-width: 768px) {
          #problems .problems-in .problems-box .contents {
            padding: 0 60px;
            margin-top: 80px; } }
        @media (min-width: 1200px) {
          #problems .problems-in .problems-box .contents {
            padding: 0 120px;
            margin-top: 100px; } }
      #problems .problems-in .problems-box .contents-box {
        margin-bottom: 60px; }
        @media (min-width: 1024px) {
          #problems .problems-in .problems-box .contents-box {
            display: flex;
            margin-bottom: 120px; } }
        #problems .problems-in .problems-box .contents-box:last-child {
          margin-bottom: 0; }
        #problems .problems-in .problems-box .contents-box .want-to {
          margin-bottom: 30px; }
          @media (min-width: 1024px) {
            #problems .problems-in .problems-box .contents-box .want-to {
              width: 350px; } }
          @media (min-width: 1400px) {
            #problems .problems-in .problems-box .contents-box .want-to {
              width: 400px; } }
          #problems .problems-in .problems-box .contents-box .want-to .title {
            position: relative;
            background-color: #fff;
            padding: 20px 30px;
            border-radius: 30px; }
            @media (min-width: 1024px) {
              #problems .problems-in .problems-box .contents-box .want-to .title {
                border-radius: 40px; } }
            @media (min-width: 1200px) {
              #problems .problems-in .problems-box .contents-box .want-to .title {
                border-radius: 60px; } }
            #problems .problems-in .problems-box .contents-box .want-to .title h3 {
              font-size: 1.35em;
              font-weight: bold;
              text-align: justify;
              line-height: 1.45em; }
              @media (min-width: 768px) {
                #problems .problems-in .problems-box .contents-box .want-to .title h3 {
                  font-size: 1.75em; } }
              @media (min-width: 1200px) {
                #problems .problems-in .problems-box .contents-box .want-to .title h3 {
                  font-size: 2.0em; } }
          #problems .problems-in .problems-box .contents-box .want-to img {
            width: 60px;
            margin-left: 80px; }
          #problems .problems-in .problems-box .contents-box .want-to p {
            font-size: 0.85em;
            line-height: 1.6em;
            text-align: justify;
            margin-top: 10px; }
            @media (min-width: 768px) {
              #problems .problems-in .problems-box .contents-box .want-to p {
                font-size: 1.0em; } }
            @media (min-width: 1200px) {
              #problems .problems-in .problems-box .contents-box .want-to p {
                font-size: 1.125em;
                margin-top: 20px; } }
        @media (min-width: 1024px) {
          #problems .problems-in .problems-box .contents-box .to-service {
            width: calc(100% - 350px);
            padding-left: 5%; } }
        @media (min-width: 1400px) {
          #problems .problems-in .problems-box .contents-box .to-service {
            width: calc(100% - 400px); } }
        #problems .problems-in .problems-box .contents-box .to-service ul li {
          margin-bottom: 20px; }
          @media (min-width: 1024px) {
            #problems .problems-in .problems-box .contents-box .to-service ul li {
              margin-bottom: 40px; } }
          #problems .problems-in .problems-box .contents-box .to-service ul li:last-child {
            margin-bottom: 0; }
          #problems .problems-in .problems-box .contents-box .to-service ul li a {
            display: flex;
            align-items: center; }
            #problems .problems-in .problems-box .contents-box .to-service ul li a:hover h4 {
              color: #0BB3B1; }
            #problems .problems-in .problems-box .contents-box .to-service ul li a:hover svg {
              transform: scale(1.15); }
              #problems .problems-in .problems-box .contents-box .to-service ul li a:hover svg #en {
                fill: #0BB3B1;
                stroke: none; }
              #problems .problems-in .problems-box .contents-box .to-service ul li a:hover svg #ya {
                fill: #fff; }
            #problems .problems-in .problems-box .contents-box .to-service ul li a h4 {
              font-size: 1.125em;
              font-weight: bold;
              font-feature-settings: "palt";
              letter-spacing: 0.04em; }
              @media (min-width: 768px) {
                #problems .problems-in .problems-box .contents-box .to-service ul li a h4 {
                  font-size: 1.5em; } }
              @media (min-width: 1200px) {
                #problems .problems-in .problems-box .contents-box .to-service ul li a h4 {
                  font-size: 1.75em; } }
            #problems .problems-in .problems-box .contents-box .to-service ul li a svg {
              width: 26px;
              transform: scale(1);
              transition: .5s;
              margin: 4px 0 0 5px; }
              @media (min-width: 1024px) {
                #problems .problems-in .problems-box .contents-box .to-service ul li a svg {
                  width: 30px; } }
              #problems .problems-in .problems-box .contents-box .to-service ul li a svg #en {
                fill: none;
                stroke: #222324;
                stroke-miterlimit: 4;
                stroke-width: 1px;
                transition: .5s; }
              #problems .problems-in .problems-box .contents-box .to-service ul li a svg #ya {
                fill: #222324;
                transition: .5s; }
          #problems .problems-in .problems-box .contents-box .to-service ul li p {
            font-size: 0.85em;
            font-weight: 300;
            line-height: 1.8em;
            text-align: justify;
            margin-top: 5px; }
            @media (min-width: 768px) {
              #problems .problems-in .problems-box .contents-box .to-service ul li p {
                font-size: 1.0em; } }
            @media (min-width: 1200px) {
              #problems .problems-in .problems-box .contents-box .to-service ul li p {
                font-size: 1.125em;
                margin-top: 10px; } }

/*
---------------------------------------------------------------------------------------------------------------------
ご契約までの流れ
---------------------------------------------------------------------------------------------------------------------
*/
#flow {
  padding: 100px 0 0; }
  @media (min-width: 768px) {
    #flow {
      padding: 150px 0 0; } }
  @media (min-width: 1200px) {
    #flow {
      padding: 200px 0 0; } }
  #flow .flow-in {
    background-color: #fff;
    border: 2px solid #E96087;
    border-radius: 20px;
    max-width: 1040px;
    width: 90%;
    margin: auto;
    padding: 40px 20px; }
    @media (min-width: 768px) {
      #flow .flow-in {
        border-radius: 40px;
        border: 3px solid #E96087;
        padding: 40px; } }
    @media (min-width: 1200px) {
      #flow .flow-in {
        padding: 100px; } }
    #flow .flow-in .sab-common-title {
      text-align: center; }
      #flow .flow-in .sab-common-title h3 {
        left: 0;
        right: 0; }
    #flow .flow-in .flow-contents {
      margin-top: 40px; }
      @media (min-width: 768px) {
        #flow .flow-in .flow-contents {
          margin-top: 60px; } }
      #flow .flow-in .flow-contents .flow-box {
        border-bottom: 1px solid #D9D0CD;
        padding: 30px 0; }
        @media (min-width: 768px) {
          #flow .flow-in .flow-contents .flow-box {
            display: flex;
            align-items: flex-start;
            padding: 40px 0; } }
        #flow .flow-in .flow-contents .flow-box:first-child {
          padding-top: 0; }
        #flow .flow-in .flow-contents .flow-box:last-child {
          border-bottom: none;
          padding-bottom: 0; }
        #flow .flow-in .flow-contents .flow-box .title {
          display: flex;
          align-items: center; }
          @media (min-width: 768px) {
            #flow .flow-in .flow-contents .flow-box .title {
              width: 300px; } }
          #flow .flow-in .flow-contents .flow-box .title h3 {
            font-family: "Outfit", sans-serif;
            font-size: 1.25em;
            color: #E96087;
            margin-right: 15px; }
            @media (min-width: 768px) {
              #flow .flow-in .flow-contents .flow-box .title h3 {
                font-size: 1.45em; } }
            @media (min-width: 1200px) {
              #flow .flow-in .flow-contents .flow-box .title h3 {
                font-size: 1.875em; } }
          #flow .flow-in .flow-contents .flow-box .title h4 {
            font-size: 1.125em;
            font-weight: bold; }
            @media (min-width: 768px) {
              #flow .flow-in .flow-contents .flow-box .title h4 {
                font-size: 1.25em; } }
            @media (min-width: 1200px) {
              #flow .flow-in .flow-contents .flow-box .title h4 {
                font-size: 1.5em; } }
        #flow .flow-in .flow-contents .flow-box .contents {
          margin-top: 10px; }
          @media (min-width: 768px) {
            #flow .flow-in .flow-contents .flow-box .contents {
              width: calc(100% - 300px);
              margin-top: 0; } }
          #flow .flow-in .flow-contents .flow-box .contents p {
            font-size: 0.85em;
            line-height: 2.0em;
            text-align: justify; }
            @media (min-width: 1024px) {
              #flow .flow-in .flow-contents .flow-box .contents p {
                font-size: 1.0em; } }
          #flow .flow-in .flow-contents .flow-box .contents ul {
            margin-top: 20px; }
            #flow .flow-in .flow-contents .flow-box .contents ul li {
              position: relative;
              font-size: 0.85em;
              font-weight: 700;
              margin-bottom: 15px;
              padding-left: 16px; }
              @media (min-width: 1024px) {
                #flow .flow-in .flow-contents .flow-box .contents ul li {
                  font-size: 1.0em;
                  margin-bottom: 20px; } }
              #flow .flow-in .flow-contents .flow-box .contents ul li:last-child {
                margin-bottom: 0; }
              #flow .flow-in .flow-contents .flow-box .contents ul li::before {
                content: "";
                position: absolute;
                left: 0;
                top: 2px;
                bottom: 0;
                display: flex;
                margin: auto;
                width: 12px;
                height: 12px;
                border-radius: 50%;
                background-color: #E96087; }
          #flow .flow-in .flow-contents .flow-box .contents .more-view {
            margin-top: 20px; }
            #flow .flow-in .flow-contents .flow-box .contents .more-view a {
              display: inline-block; }
