main #hero_wrap {
  position: relative;
  padding-top: 9rem; }
  main #hero_wrap .hero_dot {
    position: absolute;
    z-index: 2;
    width: 90%;
    left: 50%;
    bottom: 7%;
    transform: translateX(-50%); }
  main #hero_wrap .slide-hero {
    width: 100%; }
    main #hero_wrap .slide-hero div img {
      width: 100%;
      height: auto; }
      main #hero_wrap .slide-hero div img.pc-none {
        display: none; }
  main #hero_wrap .slider-dots-box {
    display: flex;
    justify-content: flex-start;
    align-items: center; }
    main #hero_wrap .slider-dots-box .slider-dots {
      display: flex;
      justify-content: center;
      align-items: center;
      min-height: 20px; }
      main #hero_wrap .slider-dots-box .slider-dots button {
        width: 20px;
        height: 20px;
        border-radius: 50%;
        display: block;
        border: 0;
        background-color: transparent;
        margin: 0 10px;
        cursor: pointer;
        display: flex;
        justify-content: center;
        align-items: center;
        flex-wrap: wrap;
        padding: 0;
        transition: .3s all;
        position: relative;
        z-index: 0; }
        main #hero_wrap .slider-dots-box .slider-dots button:after {
          content: "";
          display: block;
          width: 10px;
          height: 10px;
          border-radius: 50%;
          background-color: #cccccc; }
      main #hero_wrap .slider-dots-box .slider-dots .slick-active button:after {
        background-color: #1e17a8; }
      main #hero_wrap .slider-dots-box .slider-dots li button {
        width: 20px;
        height: 20px; }
        main #hero_wrap .slider-dots-box .slider-dots li button:after {
          position: absolute;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%); }
        main #hero_wrap .slider-dots-box .slider-dots li button:before {
          content: "";
          display: block;
          position: absolute;
          left: 0;
          right: 0;
          top: 0;
          bottom: 0;
          z-index: -1;
          border: 1px solid white;
          border-radius: 50%; }
      main #hero_wrap .slider-dots-box .slider-dots li:first-child button {
        margin-left: 0; }
      main #hero_wrap .slider-dots-box .slider-dots li.slick-active button:before {
        border: 1px solid #cccccc; }
  main #hero_wrap .circle-bg {
    fill: rgba(30, 23, 168, 0);
    stroke: #cccccc;
    stroke-width: 1;
    stroke-linecap: butt; }
  main #hero_wrap .circle-go {
    fill: rgba(30, 23, 168, 0);
    stroke: #1e17a8;
    stroke-width: 1;
    stroke-linecap: round;
    animation: progress 29s;
    stroke-dasharray: 360px;
    stroke-dashoffset: 360; }
@keyframes progress {
  from {
    stroke-dashoffset: 360; }
  to {
    stroke-dashoffset: 0; } }
  main #hero_wrap .top-scroll {
    font-size: 1.2rem;
    position: absolute;
    bottom: 7%;
    right: 5%;
    transition: opacity 1s ease, height 1s ease; }
    main #hero_wrap .top-scroll p {
      padding-top: 7.5rem;
      position: relative; }
      main #hero_wrap .top-scroll p span:first-child {
        position: absolute;
        top: 0;
        left: 50%;
        width: 1px;
        animation: scroll-border 1.5s infinite;
        background: #fff; }
      main #hero_wrap .top-scroll p span.scroll-txt {
        display: block;
        transform: rotate(90deg);
        position: absolute;
        top: 10px;
        left: -4px;
        color: #fff;
        letter-spacing: 1px;
        font-family: "Barlow Condensed", sans-serif; }
@keyframes scroll-border {
  0% {
    height: 0;
    opacity: 0; }
  50% {
    height: 7.5rem;
    opacity: 1; }
  100% {
    opacity: 0; } }
  main #hero_wrap .hero-inner {
    position: absolute;
    z-index: 10;
    top: 13rem;
    right: 2%; }
    main #hero_wrap .hero-inner .btn-lb {
      color: #000;
      background: #00ffff;
      border: 1px solid #00ffff;
      width: 213px; }
      main #hero_wrap .hero-inner .btn-lb .b-text {
        background: url("../img/common/icon_arrow_b.png") no-repeat center right 25px/12px; }
main #lineup h2 {
  margin-bottom: 5rem; }
main #lineup .wrapper {
  padding: 85px 0 100px; }
  @media screen and (max-width: 770px) {
    main #lineup .wrapper {
      padding: 30px 0 60px; } }
main #lineup .service {
  display: flex;
  justify-content: space-between;
  margin-bottom: 5rem; }
  main #lineup .service li {
    width: calc(33.333% - 5rem /3); }
    main #lineup .service li:nth-child(2) {
      margin: 0 5rem; }
    main #lineup .service li p {
      color: #1e17a8;
      padding: 1rem 0 0.5rem; }
    main #lineup .service li h3 {
      font-size: 1.8rem;
      font-weight: bold; }
main #lineup .ser-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap; }
  main #lineup .ser-item li {
    width: calc(33.333% - 5rem /3);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: 3rem; }
    main #lineup .ser-item li:nth-last-child(-n+3) {
      margin-bottom: 0; }
    main #lineup .ser-item li img {
      width: 100px;
      height: 100px; }
    main #lineup .ser-item li p {
      margin-left: 2rem;
      width: calc(100% - 120px /2); }
main #plan h2 {
  margin-bottom: 8rem; }
main #plan .plan-inner {
  display: flex; }
  main #plan .plan-inner div {
    width: 50%;
    margin: 0;
    position: relative; }
    main #plan .plan-inner div .text-wrap {
      width: 100%;
      max-width: 40rem;
      position: absolute;
      right: 10rem;
      top: 50%;
      transform: translateY(-50%); }
      main #plan .plan-inner div .text-wrap h3 {
        background: url("../img/top/icon_plan.png") no-repeat left center/111px;
        padding: 16px 0 16px 135px;
        font-weight: bold;
        margin-bottom: 55px; }
        main #plan .plan-inner div .text-wrap h3 span {
          font-size: 3.2rem; }
      main #plan .plan-inner div .text-wrap dl dt {
        font-size: 2rem;
        font-weight: bold;
        margin-bottom: 2rem; }
  main #plan .plan-inner img {
    width: 48%;
    min-height: 444px;
    height: 100%; }
main #plan .voice {
  padding: 6rem 0 7.5rem;
  position: relative; }
  main #plan .voice .wrapper {
    position: relative;
    z-index: 1;
    color: #fff; }
  main #plan .voice .voice-inner {
    display: flex; }
    main #plan .voice .voice-inner dl {
      width: calc(50% - 12rem/2);
      margin-top: 4rem; }
      main #plan .voice .voice-inner dl:first-child {
        margin-right: 6rem;
        padding-right: 6rem;
        border-right: 1px solid #fff; }
      main #plan .voice .voice-inner dl dt {
        font-size: 1.6rem;
        font-weight: bold;
        margin-bottom: 2rem; }
  main #plan .voice .back-blue {
    position: absolute;
    content: "";
    width: 98%;
    height: 100%;
    z-index: 0;
    top: 0;
    left: 0;
    border-radius: 0 0 6px 0; }
main .work {
  padding: 7rem 0 10rem; }
  main .work .work-contents {
    display: flex;
    align-items: center;
    justify-content: space-between; }
    main .work .work-contents dl {
      max-width: 400px;
      width: 100%;
      margin-right: 8rem; }
      main .work .work-contents dl dt {
        font-size: 2.4rem;
        font-weight: bold;
        color: #1e17a8;
        line-height: 4.2rem;
        margin-bottom: 2rem; }
    main .work .work-contents:first-child {
      margin-bottom: 8rem;
      padding-bottom: 6rem;
      border-bottom: 1px solid #1e17a8; }
main #reach .wrapper {
  padding: 85px 0 0; }
main #reach h2 {
  margin-bottom: 5rem; }
main #reach ul {
  display: flex; }
  main #reach ul li {
    width: calc(25% - 6rem/4);
    margin-right: 6rem; }
    main #reach ul li:last-child {
      margin: 0; }
    main #reach ul li div {
      min-height: 160px;
      margin: 2rem 0; }
      main #reach ul li div h3 {
        text-align: center; }
        main #reach ul li div h3 span {
          font-size: 1.7rem;
          font-weight: bold;
          margin-bottom: 1rem;
          position: relative;
          display: inline-block; }
          main #reach ul li div h3 span:before, main #reach ul li div h3 span:after {
            position: absolute;
            content: "";
            width: 1rem;
            height: 2px;
            top: 50%;
            transform: translateY(-50%); }
          main #reach ul li div h3 span:before {
            left: -20px; }
          main #reach ul li div h3 span:after {
            right: -20px; }
          main #reach ul li div h3 span:before, main #reach ul li div h3 span:after {
            background: #000; }
    main #reach ul li dl dt {
      background: #1e17a8;
      color: #fff;
      font-weight: bold;
      text-align: center;
      padding: 4px 0 2px;
      border-radius: 6px;
      margin-bottom: 1rem; }
    main #reach ul li dl dd span {
      color: #1e17a8;
      letter-spacing: -0.05rem; }
main #reach .sticker {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #ebebee;
  padding: 3rem 5rem;
  border-radius: 6px;
  margin: 5rem auto 0; }
  main #reach .sticker .sticker01 {
    width: 158px; }
  main #reach .sticker .sticker02 {
    width: 144px;
    margin: 0 4rem 0 2rem; }
  main #reach .sticker dl {
    max-width: 544px;
    width: 100%; }
    main #reach .sticker dl dt {
      font-size: 2.3rem;
      color: #1e17a8;
      font-weight: bold;
      position: relative;
      padding-bottom: 4rem; }
      main #reach .sticker dl dt:after {
        position: absolute;
        content: "";
        height: 1px;
        width: 3rem;
        background: #1e17a8;
        bottom: 23px;
        left: 0; }
main #flow .flow-inner {
  position: relative;
  color: #fff;
  padding: 9rem 0; }
  main #flow .flow-inner .wrapper {
    position: relative;
    z-index: 1; }
    main #flow .flow-inner .wrapper h2 {
      margin-bottom: 4rem; }
    main #flow .flow-inner .wrapper ul {
      display: flex; }
      main #flow .flow-inner .wrapper ul li {
        width: calc(25% /4); }
  main #flow .flow-inner .back-blue {
    position: absolute;
    content: "";
    width: 98%;
    height: 100%;
    z-index: 0;
    top: 0;
    right: 0;
    border-radius: 6px 0 0 6px; }
  main #flow .flow-inner .pc-none {
    display: none; }
main #area .wrapper-min {
  padding: 8rem 0; }
main #area h2 {
  margin-bottom: 2rem; }
main #area .area-inner {
  display: flex;
  align-items: center; }
  main #area .area-inner .pc-none {
    display: none; }
  main #area .area-inner dl dt {
    font-size: 2.4rem;
    font-weight: bold;
    margin-bottom: 3rem; }
    main #area .area-inner dl dt .color {
      color: #1e17a8; }
    main #area .area-inner dl dt .sp, main #area .area-inner dl dt .sp500 {
      display: none; }
  main #area .area-inner img {
    width: 550px;
    max-height: 478px; }
main #operation h3 span {
  position: relative;
  display: inline-block; }
  main #operation h3 span:before, main #operation h3 span:after {
    position: absolute;
    content: "";
    width: 1rem;
    height: 2px;
    top: 50%;
    transform: translateY(-50%); }
  main #operation h3 span:before {
    left: -20px; }
  main #operation h3 span:after {
    right: -20px; }
  main #operation h3 span:before, main #operation h3 span:after {
    background: #fff; }
main #operation .operation-top {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 7.5rem; }
  main #operation .operation-top h2 {
    margin-bottom: 12rem; }
  main #operation .operation-top div {
    max-width: 42rem;
    width: 100%;
    margin-right: 8rem; }
    main #operation .operation-top div dl dt {
      font-size: 2rem;
      font-weight: bold;
      margin-bottom: 3rem; }
  main #operation .operation-top .r-image {
    width: 50%;
    text-align: right;
    border-radius: 0 0 0 6px; }
main #operation .popular {
  padding: 7.5rem 0 8rem;
  margin-bottom: 7rem;
  border-bottom: 1px solid #fff;
  border-top: 1px solid #fff; }
main #operation .operation-items {
  display: flex;
  align-items: center; }
  main #operation .operation-items img {
    width: 50%;
    max-width: 500px; }
  main #operation .operation-items dl {
    width: calc(50% - 5rem /2);
    margin-left: 5rem; }
    main #operation .operation-items dl dt {
      position: relative;
      margin-bottom: 5rem; }
      main #operation .operation-items dl dt span {
        font-size: 2rem;
        font-weight: bold;
        padding-top: 5px;
        display: block; }
      main #operation .operation-items dl dt:after {
        position: absolute;
        content: "";
        width: 3rem;
        height: 1px;
        background: #fff;
        left: 0;
        bottom: -25px; }
  main #operation .operation-items.first {
    margin: 4rem 0 1.5rem;
    position: relative; }
    main #operation .operation-items.first:after {
      position: absolute;
      content: "";
      max-width: 45rem;
      width: 45%;
      height: 1px;
      background: #fff;
      right: 0;
      bottom: -9px; }
  main #operation .operation-items.third {
    margin-top: 3rem; }
main #operation .induce a {
  background: url("../img/common/icon_arrow_w.png") no-repeat right 25px center/12px, #b50005; }
main #company .company-inner {
  padding: 3rem 3rem 0;
  margin-bottom: 9rem; }
  main #company .company-inner .company-image {
    width: 100%;
    height: auto; }
  main #company .company-inner .company-contents {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    margin: 9rem 0 0; }
    main #company .company-inner .company-contents h2 {
      width: 22rem;
      margin-right: 10rem;
      font-size: 2.4rem;
      font-weight: bold; }
    main #company .company-inner .company-contents div {
      max-width: 685px;
      width: 100%; }
      main #company .company-inner .company-contents div dl dt {
        margin-bottom: 2rem;
        font-size: 1.6rem;
        font-weight: bold; }
        main #company .company-inner .company-contents div dl dt span {
          color: #b50005; }
      main #company .company-inner .company-contents div dl dd p.text-space {
        margin-bottom: 3rem; }
      main #company .company-inner .company-contents div dl:first-child, main #company .company-inner .company-contents div dl:nth-child(2) {
        margin-bottom: 6rem;
        padding-bottom: 6rem;
        border-bottom: 1px solid #808080; }
      main #company .company-inner .company-contents div dl:last-child dd {
        display: flex;
        align-items: flex-start;
        justify-content: space-between; }
        main #company .company-inner .company-contents div dl:last-child dd p {
          max-width: 511px;
          margin-right: 3rem; }
        main #company .company-inner .company-contents div dl:last-child dd img {
          width: 144px; }
main .induce {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 0 75px; }
  main .induce p {
    font-size: 2rem;
    font-weight: bold; }
  main .induce .btn {
    margin-left: 4rem;
    width: 220px;
    color: #fff;
    background: #1e17a8; }
    main .induce .btn .b-text {
      background: url("../img/common/icon_arrow_w.png") no-repeat center right 25px/12px; }
  main .induce .btn-b {
    border: 1px solid #1e17a8; }
    main .induce .btn-b:hover {
      color: #1e17a8; }
      main .induce .btn-b:hover .b-text {
        background: url("../img/common/icon_arrow_bl.png") no-repeat center right 25px/12px; }
  main .induce .btn-r {
    border: 1px solid #b50005; }
    main .induce .btn-r:hover {
      color: #b50005; }
      main .induce .btn-r:hover .b-text {
        background: url("../img/common/icon_arrow_r.png") no-repeat center right 25px/12px; }

@media screen and (max-width: 1040px) {
  main #lineup h2 {
    margin-bottom: 3rem; }
  main #lineup .wrapper {
    padding: 5rem 0 7rem; }
  main #lineup .service {
    display: block;
    max-width: 55rem;
    margin: 0 auto 5rem; }
    main #lineup .service li {
      width: 100%;
      text-align: center; }
      main #lineup .service li:nth-child(2) {
        margin: 3rem 0; }
      main #lineup .service li img {
        width: 100%; }
  main #lineup .ser-item {
    max-width: 55rem;
    margin: 0 auto; }
    main #lineup .ser-item li {
      width: calc(50% - 4rem /2);
      margin-bottom: 3rem !important; }
      main #lineup .ser-item li:nth-last-child(-n+2) {
        margin-bottom: 0; }
  main #plan h2 {
    margin-bottom: 4rem;
    padding: 0 5%; }
  main #plan .plan-inner {
    display: block; }
    main #plan .plan-inner div {
      width: 100%;
      max-width: 100%; }
      main #plan .plan-inner div .text-wrap {
        max-width: 100%;
        position: relative;
        right: 0;
        top: 0;
        transform: translateY(0);
        padding: 3rem 5%;
        box-sizing: border-box; }
        main #plan .plan-inner div .text-wrap h3 {
          width: 235px;
          margin: 0 auto 2rem; }
        main #plan .plan-inner div .text-wrap dl dt {
          text-align: center; }
          main #plan .plan-inner div .text-wrap dl dt br {
            display: none; }
    main #plan .plan-inner img {
      width: 100%;
      min-height: auto;
      height: auto; }
  main #plan .voice {
    padding: 2rem 0 4rem; }
    main #plan .voice .voice-inner {
      display: block;
      margin-top: 2rem;
      margin: 2rem auto 0;
      max-width: 65rem; }
      main #plan .voice .voice-inner dl {
        width: 100%;
        margin-top: 4rem; }
        main #plan .voice .voice-inner dl:first-child {
          margin: 0 auto 3rem;
          padding: 0 0 3rem;
          border-right: none;
          border-bottom: 1px solid #fff; }
        main #plan .voice .voice-inner dl dt br {
          display: none; }
    main #plan .voice .back-blue {
      width: 100%;
      border-radius: 0;
      top: -8px; }
  main .work {
    padding: 4rem 0 5rem; }
    main .work .work-contents {
      display: block;
      max-width: 65rem;
      margin: 0 auto; }
      main .work .work-contents dl {
        max-width: 100%;
        margin: 0 auto 4rem; }
        main .work .work-contents dl dt br {
          display: none; }
      main .work .work-contents:first-child {
        margin-bottom: 4rem;
        padding-bottom: 3rem; }
      main .work .work-contents img {
        width: 100%; }
  main #reach .wrapper {
    padding: 5rem 0 0; }
  main #reach ul {
    flex-wrap: wrap;
    max-width: 55rem;
    margin: 0 auto; }
    main #reach ul li {
      width: calc(50% - 3rem/2);
      margin-right: 3rem; }
      main #reach ul li:nth-child(1), main #reach ul li:nth-child(2) {
        margin-bottom: 3rem; }
      main #reach ul li:nth-child(2), main #reach ul li:last-child {
        margin-right: 0; }
      main #reach ul li div {
        min-height: 14rem; }
      main #reach ul li img {
        margin: 0 auto;
        display: block; }
  main #reach .sticker {
    flex-wrap: wrap;
    padding: 3rem 5%;
    max-width: 65rem;
    margin: 5rem auto 0; }
    main #reach .sticker .sticker01 {
      width: 158px; }
    main #reach .sticker .sticker02 {
      width: 144px;
      margin: 0 0 0 2rem; }
    main #reach .sticker dl {
      max-width: 50rem;
      margin: 3rem auto 0; }
      main #reach .sticker dl dt {
        padding-bottom: 2rem;
        text-align: center; }
        main #reach .sticker dl dt:after {
          bottom: 13px;
          left: 50%;
          transform: translateX(-50%); }
  main #area .wrapper-min {
    padding: 4rem 0 6rem; }
  main #area .area-inner {
    display: block; }
    main #area .area-inner dl dt {
      text-align: center; }
      main #area .area-inner dl dt .sp {
        display: inline; }
      main #area .area-inner dl dt .pc, main #area .area-inner dl dt .sp500 {
        display: none; }
      main #area .area-inner dl dt br {
        display: none; }
    main #area .area-inner img {
      margin: 4rem auto 0;
      display: block; }
  main #operation h3 {
    padding: 0 5%; }
    main #operation h3 span {
      position: relative;
      display: inline-block; }
      main #operation h3 span:before, main #operation h3 span:after {
        position: absolute;
        content: "";
        width: 1rem;
        height: 2px;
        top: 50%;
        transform: translateY(-50%); }
      main #operation h3 span:before {
        left: -20px; }
      main #operation h3 span:after {
        right: -20px; }
      main #operation h3 span:before, main #operation h3 span:after {
        background: #fff; }
  main #operation .operation-top {
    margin-bottom: 4rem;
    padding: 5px 0 0 5%; }
    main #operation .operation-top h2 {
      margin-bottom: 2rem; }
    main #operation .operation-top div {
      max-width: 100%;
      margin-right: 3rem; }
      main #operation .operation-top div dl dt {
        margin-bottom: 2rem; }
      main #operation .operation-top div dl dd br {
        display: none; }
    main #operation .operation-top .r-image {
      width: 50%;
      text-align: right; }
  main #operation .popular {
    padding: 4rem 0;
    margin-bottom: 3rem; }
  main #operation .operation-items {
    flex-direction: column-reverse;
    max-width: 65rem;
    margin: 0 auto; }
    main #operation .operation-items img {
      width: 100%;
      max-width: 100%; }
    main #operation .operation-items dl {
      width: 100%;
      margin: 0 auto 2rem; }
      main #operation .operation-items dl dt {
        text-align: center; }
        main #operation .operation-items dl dt:after {
          left: 50%;
          transform: translateX(-50%); }
    main #operation .operation-items.first {
      margin: 4rem auto 8rem; }
      main #operation .operation-items.first:after {
        max-width: 100%;
        width: 100%;
        right: 50%;
        bottom: -4rem;
        transform: translateX(50%); }
  main #company .company-inner .company-contents {
    display: block;
    margin: 4rem 0 0; }
    main #company .company-inner .company-contents h2 {
      width: 100%;
      margin: 0 auto 3rem;
      text-align: center; }
    main #company .company-inner .company-contents div {
      max-width: 100%; }
      main #company .company-inner .company-contents div dl dd p.text-space {
        margin-bottom: 2rem; }
      main #company .company-inner .company-contents div dl:first-child, main #company .company-inner .company-contents div dl:nth-child(2) {
        margin-bottom: 3rem;
        padding-bottom: 3rem; }
      main #company .company-inner .company-contents div dl:last-child dd {
        display: block; }
        main #company .company-inner .company-contents div dl:last-child dd p {
          max-width: 100%;
          margin: 0 auto 2rem; }
  main .induce {
    display: block;
    padding: 3rem 5% 3rem;
    text-align: center; }
    main .induce a {
      margin: 2rem auto 0;
      display: inline-block; }
    main .induce .btn {
      margin-left: auto; } }
@media screen and (max-width: 1000px) {
  main #hero_wrap {
    padding-top: 5rem; }
    main #hero_wrap .hero-inner {
      display: none; } }
@media screen and (max-width: 850px) {
  main #flow .flow-inner {
    padding: 4rem 0 5rem; }
    main #flow .flow-inner .wrapper h2 {
      margin-bottom: 2rem; }
    main #flow .flow-inner .sp-none {
      display: none; }
    main #flow .flow-inner .pc-none {
      display: block;
      max-width: 40rem;
      margin: 0 auto; }
      main #flow .flow-inner .pc-none img {
        width: 100%; }
        main #flow .flow-inner .pc-none img:first-child {
          border-bottom: 1px solid #fff;
          padding-bottom: 4rem;
          margin-bottom: 4rem; }
    main #flow .flow-inner .back-blue {
      width: 100%;
      border-radius: 0; }
  main #operation .operation-top {
    padding: 4rem 5% 0;
    display: block;
    max-width: 65rem;
    margin: 0 auto 4rem; }
    main #operation .operation-top h2 {
      margin-bottom: 2rem; }
    main #operation .operation-top div {
      max-width: 100%;
      margin-right: 3rem; }
      main #operation .operation-top div h2 {
        text-align: center; }
      main #operation .operation-top div dl {
        margin-bottom: 4rem; }
        main #operation .operation-top div dl dt {
          text-align: center; }
          main #operation .operation-top div dl dt br {
            display: none; }
    main #operation .operation-top .r-image {
      width: 100%;
      text-align: center;
      border-radius: 0; } }
@media screen and (max-width: 700px) {
  main .work .work-contents dl dt {
    font-size: 2rem; }
  main #area .area-inner .pc-none {
    display: block; }
  main #area .area-inner .sp-none {
    display: none; }
  main #area .area-inner img {
    margin: 0 auto 4rem; }
  main #area .area-inner dl dt {
    font-size: 2rem; }
    main #area .area-inner dl dt .sp500 {
      display: inline; }
    main #area .area-inner dl dt .pc, main #area .area-inner dl dt .sp {
      display: none; }
  main #operation h3 {
    padding: 0; }
    main #operation h3 span:before, main #operation h3 span:after {
      content: none; } }
@media screen and (max-width: 660px) {
  main #lineup .ser-item {
    align-items: baseline; }
    main #lineup .ser-item li {
      display: block;
      text-align: center;
      margin-bottom: 2rem !important; }
      main #lineup .ser-item li br {
        display: none; }
      main #lineup .ser-item li p {
        margin: 0 auto;
        width: 100%; }
      main #lineup .ser-item li:last-child {
        margin-bottom: 0 !important; }
  main #reach .sticker {
    display: block; }
    main #reach .sticker .sticker01 {
      width: 158px;
      display: block;
      margin: 0 auto; }
    main #reach .sticker .sticker02 {
      width: 144px;
      display: block;
      margin: 2rem auto 0; }
  main #company .company-inner {
    margin-bottom: 5rem; } }
@media screen and (max-width: 500px) {
  main #hero_wrap .hero_dot {
    bottom: 15%; }
  main #hero_wrap .slide-hero {
    width: 100%; }
    main #hero_wrap .slide-hero div img {
      width: 100%;
      height: auto; }
      main #hero_wrap .slide-hero div img.pc-none {
        display: block; }
      main #hero_wrap .slide-hero div img.sp-none {
        display: none; }
  main #hero_wrap .top-scroll {
    bottom: 15%;
    right: 3rem; }
  main #lineup .wrapper {
    padding: 5rem 2rem 7rem; }
  main #plan h2 {
    padding: 0 2rem; }
  main #plan .plan-inner div .text-wrap {
    padding: 3rem 2rem; }
    main #plan .plan-inner div .text-wrap h3 {
      width: 286px;
      background-size: 70px;
      padding: 16px 0 16px 90px;
      box-sizing: border-box; }
      main #plan .plan-inner div .text-wrap h3 span {
        font-size: 2.8rem; }
  main #plan .voice {
    padding: 2rem 2rem 4rem; }
  main .work {
    padding: 4rem 2rem 5rem; }
  main #reach .wrapper {
    padding: 5rem 2rem 0; }
  main #reach h2 {
    margin-bottom: 3rem; }
  main #reach ul {
    display: block; }
    main #reach ul li {
      width: 100%;
      margin: 0 auto 37px !important; }
      main #reach ul li:last-child {
        margin-bottom: 0 !important; }
      main #reach ul li div {
        min-height: auto; }
  main #flow .flow-inner .pc-none {
    padding: 0 2rem; }
  main #area .wrapper-min {
    padding: 4rem 2rem; }
  main #operation .back-dark {
    padding: 0 2rem; }
  main #operation .operation-top {
    padding: 4rem 0 0; }
  main #operation .popular {
    padding: 4rem 0; }
  main #company .company-inner {
    padding: 3rem 2rem 0; }
    main #company .company-inner .company-contents div dl:last-child dd a {
      text-align: center;
      display: block; }
  main .induce {
    padding: 3rem 2rem; } }
