@charset "UTF-8";
/*----------------------------------------------

    cool-shooting株式会社
    http://cool-shooting.com/

----------------------------------------------*/
@media only screen and (min-width: 768px) {
  /*
    basic
----------------------------------------------*/
  html {
    font-size: 62.5%; }
  body {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    word-wrap: break-word;
    overflow-wrap: break-word;
    color: #3f3a39; }
  * {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
    zoom: 1; }
  a {
    transition: 0.3s;
    outline: none; }
  a:link,
  a:visited {
    color: #66ccff;
    text-decoration: none; }
  a:hover,
  a:focus,
  a:active {
    color: #66ccff;
    text-decoration: none; }
  .none {
    display: none; }
  .pc-b {
    display: block; }
  .pc-i {
    display: inline; }
  .sp-b {
    display: none; }
  .sp-i {
    display: none; }
  /*
    clearfix
----------------------------------------------*/
  .clearfix:after, header .inner:after, header .inner nav ul:after, header .inner .sns-list:after, #our-strength .inner ul li:after, #works .inner .bxslider li:after, #flow-of-services .inner ul li:after, #price-list .inner .price-list:after, #company .inner:after, #c-group .inner:after, #mlit .inner:after, #inquiry .inner:after, #confirm .inner:after, #thanks .inner:after {
    display: block;
    clear: both;
    content: ""; }
  /*
    loading
----------------------------------------------*/
  #loader-bg {
    width: 100%;
    height: 100%;
    display: block;
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: 4;
    background: #27499d; }
  #loader {
    width: 700px;
    height: 3px;
    display: block;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
    color: #FFF;
    z-index: 10; }
  /************************************************
header
************************************************/
  header {
    width: 100%;
    height: 90px;
    background: #fff; }
    header .inner {
      width: 1200px;
      margin: 0 auto; }
      header .inner h1 {
        margin: 0 20px 0 0;
        padding: 15px 0 0 0;
        line-height: 90px;
        float: left; }
      header .inner .sp-menu {
        display: none; }
      header .inner nav ul {
        float: left; }
      header .inner nav li {
        line-height: 90px;
        float: left; }
        header .inner nav li a {
          padding: 0 15px;
          display: block; }
      header .inner .sns-list {
        padding: 28px 0 0 0;
        float: right; }
        header .inner .sns-list li {
          margin: 0 10px;
          float: left; }
    header #gnav-menu {
      display: none; }
  /************************************************
index
************************************************/
  .main-visual {
    margin: 250px 0;
    text-align: center; }
    .main-visual video {
      position: fixed;
      left: 0;
      bottom: 0;
      min-width: 100%;
      min-height: 100%;
      width: auto;
      height: auto;
      z-index: -100;
      background-size: cover; }
    .main-visual .bg-video {
      position: fixed;
      left: 0;
      bottom: 0;
      min-width: 100%;
      height: 100vh;
      /* width: auto; */
      /* height: auto; */
      z-index: -200;
      /* background-size: cover; */
      background: url(../images/pc/bg_body.png) no-repeat 0 50%;
      background-size: cover; }
    .main-visual .logo {
      width: 100%;
      height: 290px;
      text-align: center; }
      .main-visual .logo h2 {
        padding: 30px 0 0 0; }
  #concept {
    width: 100%;
    margin: 0 0 75px 0;
    text-align: center; }
    #concept .inner {
      width: 1100px;
      margin: 0 auto;
      padding: 50px 0 30px 0;
      border-radius: 30px;
      background: rgba(255, 255, 255, 0.8); }
      #concept .inner h3 {
        margin: 0 0 40px 0; }
      #concept .inner .sentence01 {
        margin: 0 0 40px 0;
        font-size: 30px;
        font-size: 3.0rem;
        line-height: 130%; }
      #concept .inner .sentence02 {
        margin: 0 0 30px 0;
        font-size: 18px;
        font-size: 1.8rem;
        line-height: 150%; }
  #our-strength {
    width: 100%;
    margin: 0 0 75px 0; }
    #our-strength .inner {
      width: 1100px;
      margin: 0 auto;
      padding: 50px 70px 30px 70px;
      border-radius: 30px;
      background: rgba(63, 58, 57, 0.8); }
      #our-strength .inner h3 {
        margin: 0 0 40px 0;
        text-align: center; }
      #our-strength .inner ul li {
        margin: 0 0 35px 0; }
        #our-strength .inner ul li .thumb {
          float: right; }
        #our-strength .inner ul li .sentence {
          width: 660px;
          padding: 0 0 0 12px;
          float: left;
          background: url(../images/pc/bg_border.png) no-repeat; }
          #our-strength .inner ul li .sentence h4 {
            margin: 0 0 10px 0;
            font-size: 24px;
            font-size: 2.4rem;
            font-weight: bold;
            line-height: 1.3;
            color: #fff; }
          #our-strength .inner ul li .sentence p {
            font-size: 15px;
            font-size: 1.5rem;
            line-height: 1.7;
            color: #fff; }
            #our-strength .inner ul li .sentence p a:hover {
              opacity: 0.6; }
  #works {
    width: 100%;
    margin: 0 0 75px 0; }
    #works .inner {
      width: 1100px;
      margin: 0 auto;
      padding: 50px 55px 30px 55px;
      border-radius: 30px;
      background: rgba(255, 255, 255, 0.8); }
      #works .inner h3 {
        margin: 0 0 40px 0;
        text-align: center; }
      #works .inner .bxslider li .youtube {
        width: 225px;
        margin: 50px 30px 0 0;
        float: left; }
        #works .inner .bxslider li .youtube .thumb {
          margin: 0 0 10px 0;
          width: 225px;
          height: 125px;
          overflow: hidden; }
          #works .inner .bxslider li .youtube .thumb a {
            display: block; }
            #works .inner .bxslider li .youtube .thumb a:hover {
              opacity: 0.9; }
              #works .inner .bxslider li .youtube .thumb a:hover img {
                -webkit-transform: scale(1.1);
                transform: scale(1.1); }
            #works .inner .bxslider li .youtube .thumb a img {
              transition: 0.5s; }
        #works .inner .bxslider li .youtube .title {
          margin: 0 0 5px 0;
          font-size: 13px;
          font-size: 1.3rem;
          font-weight: bold;
          line-height: 1.3; }
        #works .inner .bxslider li .youtube .sentence {
          font-size: 12px;
          font-size: 1.2rem;
          line-height: 1.5; }
      #works .inner .bxslider li .youtube:nth-child(4n) {
        margin: 50px 0 0 0; }
      #works .inner .bxslider li .youtube:nth-child(-n+3) {
        margin: 0 30px 0 0; }
      #works .inner .bxslider li .youtube:nth-child(4) {
        margin: 0; }
      #works .inner .bx-controls-direction {
        display: none; }
  #flow-of-services {
    width: 100%;
    margin: 0 0 75px 0; }
    #flow-of-services .inner {
      width: 1100px;
      margin: 0 auto;
      padding: 50px 70px 50px 70px;
      border-radius: 30px;
      background: rgba(63, 58, 57, 0.8); }
      #flow-of-services .inner h3 {
        margin: 0 0 40px 0;
        text-align: center; }
      #flow-of-services .inner ul li {
        margin: 0 0 10px 0; }
        #flow-of-services .inner ul li:last-child {
          margin: 0; }
          #flow-of-services .inner ul li:last-child:after {
            content: ""; }
        #flow-of-services .inner ul li:after {
          margin: 0 0 0 118px;
          padding: 10px 0 0 0;
          content: "▼";
          color: #fff;
          font-size: 14px;
          font-size: 1.4rem; }
        #flow-of-services .inner ul li .icon {
          width: 84px;
          margin: 0 30px 0 0;
          float: left; }
        #flow-of-services .inner ul li .sentence {
          width: 840px;
          float: left; }
          #flow-of-services .inner ul li .sentence h4 {
            font-size: 24px;
            font-size: 2.4rem;
            font-weight: bold;
            line-height: 1.3;
            color: #fff; }
          #flow-of-services .inner ul li .sentence p {
            font-size: 15px;
            font-size: 1.5rem;
            line-height: 1.7;
            color: #fff; }
            #flow-of-services .inner ul li .sentence p a:hover {
              opacity: 0.6; }
  #price-list {
    width: 100%;
    margin: 0 0 75px 0; }
    #price-list .inner {
      width: 1100px;
      margin: 0 auto;
      padding: 50px 55px 30px 55px;
      border-radius: 30px;
      background: rgba(255, 255, 255, 0.8); }
      #price-list .inner h3 {
        margin: 0 0 40px 0;
        text-align: center; }
      #price-list .inner .price-list li {
        width: 230px;
        margin: 0 23px 23px 0;
        padding: 0 0 15px 0;
        background: #fff;
        float: left; }
        #price-list .inner .price-list li:nth-child(4) {
          margin: 0; }
        #price-list .inner .price-list li .price {
          padding: 15px 0;
          text-align: center; }
        #price-list .inner .price-list li .content {
          padding: 12px 0;
          text-align: center;
          font-size: 14px;
          font-size: 1.4rem;
          line-height: 1.3; }
        #price-list .inner .price-list li:nth-child(1) .content {
          background: #ccf2f8; }
        #price-list .inner .price-list li:nth-child(2) .content {
          background: #d0e8fd; }
        #price-list .inner .price-list li:nth-child(3) .content {
          background: #d9dffc; }
        #price-list .inner .price-list li:nth-child(4) .content {
          background: #e7dcff; }
      #price-list .inner .price-list .detail-list {
        padding: 15px 3px 15px 7px; }
        #price-list .inner .price-list .detail-list li {
          margin: 0 0 8px 0;
          padding: 0 0 0 1em;
          text-indent: -1em;
          font-size: 13px;
          font-size: 1.3rem;
          line-height: 1.3;
          background: none;
          float: none; }
      #price-list .inner .price-list .inquiry {
        text-align: center; }
        #price-list .inner .price-list .inquiry a {
          font-size: 15px;
          font-size: 1.5rem;
          font-weight: bold;
          color: #27499d; }
          #price-list .inner .price-list .inquiry a:hover {
            opacity: 0.6; }
      #price-list .inner .caution-list li {
        margin: 0 0 10px 0;
        padding: 0 0 0 7em;
        text-indent: -7em;
        font-size: 12px;
        font-size: 1.2rem;
        line-height: 1.3; }
  /************************************************
company
************************************************/
  #company {
    padding: 75px;
    background: #27499d; }
    #company .inner {
      width: 1100px;
      margin: 0 auto; }
      #company .inner h2 {
        width: 250px;
        padding: 10px 0 0 0;
        font-size: 24px;
        font-size: 2.4rem;
        color: #fff;
        float: left; }
      #company .inner .contents {
        float: left; }
        #company .inner .contents table {
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 1.5;
          color: #fff; }
          #company .inner .contents table th {
            width: 130px;
            padding: 12px 0;
            text-align: left;
            vertical-align: top; }
          #company .inner .contents table td {
            padding: 12px 0;
            vertical-align: top; }
            #company .inner .contents table td a:hover {
              opacity: 0.6; }
            #company .inner .contents table td iframe {
              width: 80%;
              height: 300px;
              padding: 10px 0 0 0; }
  /************************************************
c-group
************************************************/
  #c-group {
    padding: 75px;
    background: #27499d; }
    #c-group .inner {
      width: 1100px;
      margin: 0 auto; }
      #c-group .inner h2 {
        width: 250px;
        padding: 10px 0 0 0;
        font-size: 24px;
        font-size: 2.4rem;
        color: #fff;
        float: left; }
      #c-group .inner .contents {
        width: 850px;
        float: left; }
        #c-group .inner .contents dl {
          margin: 0 0 40px 0; }
          #c-group .inner .contents dl dt {
            width: 300px;
            display: table-cell;
            text-align: center;
            vertical-align: middle; }
          #c-group .inner .contents dl dd {
            font-size: 15px;
            font-size: 1.5rem;
            line-height: 1.5;
            color: #fff;
            display: table-cell;
            vertical-align: middle; }
            #c-group .inner .contents dl dd span {
              font-size: 18px;
              font-size: 1.8rem;
              font-weight: bold; }
            #c-group .inner .contents dl dd a:hover {
              opacity: 0.6; }
        #c-group .inner .contents .c-group {
          margin: 0 0 40px 0;
          padding: 0 0 50px 0;
          border-bottom: 1px solid #fff; }
          #c-group .inner .contents .c-group dd {
            padding: 0 0 0 50px;
            font-size: 18px;
            font-size: 1.8rem; }
  /************************************************
mlit
************************************************/
  #mlit {
    padding: 75px;
    background: #27499d; }
    #mlit .inner {
      width: 1100px;
      margin: 0 auto 50px auto; }
      #mlit .inner h2 {
        width: 350px;
        font-size: 24px;
        font-size: 2.4rem;
        color: #fff;
        float: left; }
      #mlit .inner .contents {
        width: 550px;
        float: left; }
    #mlit .law {
      width: 1000px;
      margin: 0 auto; }
      #mlit .law .sentence {
        margin: 0 0 30px 0;
        font-size: 18px;
        font-size: 1.8rem;
        line-height: 1.5;
        color: #fff; }
      #mlit .law table {
        width: 100%; }
        #mlit .law table tr th {
          padding: 0 0 10px 0;
          text-align: left;
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 1.3;
          color: #fff;
          border-bottom: 1px solid #fff; }
        #mlit .law table tr td {
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 1.3;
          color: #fff; }
          #mlit .law table tr td:nth-child(1) {
            width: 150px; }
          #mlit .law table tr td:nth-child(2) {
            width: 380px; }
        #mlit .law table tr:nth-child(2) td {
          padding: 10px 0 0 0; }
  /************************************************
inquiry
************************************************/
  #inquiry {
    padding: 75px;
    background: #ddd; }
    #inquiry .inner {
      width: 1100px;
      margin: 0 auto; }
      #inquiry .inner h2 {
        width: 250px;
        font-size: 24px;
        font-size: 2.4rem;
        color: #5a5656;
        float: left; }
      #inquiry .inner .contents {
        width: 850px;
        float: left; }
        #inquiry .inner .contents .sentence {
          margin: 0 0 20px 0;
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 1.5;
          color: #5a5656; }
          #inquiry .inner .contents .sentence span {
            color: #ff3300; }
        #inquiry .inner .contents table {
          width: 100%;
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 1.5;
          color: #5a5656; }
          #inquiry .inner .contents table tr th {
            width: 170px;
            text-align: left;
            vertical-align: middle; }
            #inquiry .inner .contents table tr th span {
              color: #ff3300; }
          #inquiry .inner .contents table tr td {
            padding: 15px 0;
            vertical-align: middle; }
            #inquiry .inner .contents table tr td input {
              width: 100%;
              height: 35px;
              padding: 5px; }
            #inquiry .inner .contents table tr td textarea {
              width: 100%;
              height: 175px;
              margin: 0 0 50px 0;
              padding: 5px; }
            #inquiry .inner .contents table tr td .confirm {
              width: 40%;
              height: 60px;
              padding: 0;
              font-size: 24px;
              font-size: 2.4rem;
              line-height: 60px;
              color: #fff;
              background: #27499d;
              border-radius: 5px;
              border: 1px solid #27499d;
              cursor: pointer;
              transition: 0.3s; }
              #inquiry .inner .contents table tr td .confirm:hover {
                opacity: 0.6; }
          #inquiry .inner .contents table tr:last-child th {
            padding: 20px 0 0 0;
            vertical-align: top; }
  /************************************************
confirm
************************************************/
  #confirm {
    padding: 75px;
    background: #ddd; }
    #confirm .inner {
      width: 1100px;
      margin: 0 auto; }
      #confirm .inner h2 {
        width: 250px;
        font-size: 24px;
        font-size: 2.4rem;
        color: #5a5656;
        float: left; }
      #confirm .inner .contents {
        width: 850px;
        float: left; }
        #confirm .inner .contents .sentence {
          margin: 0 0 20px 0;
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 1.5;
          color: #5a5656; }
          #confirm .inner .contents .sentence span {
            color: #ff3300; }
        #confirm .inner .contents .goback,
        #confirm .inner .contents .send {
          width: 40%;
          height: 60px;
          margin: 0 2%;
          padding: 0;
          font-size: 24px;
          font-size: 2.4rem;
          line-height: 60px;
          color: #fff;
          background: #27499d;
          border-radius: 5px;
          border: 1px solid #27499d;
          cursor: pointer;
          transition: 0.3s; }
          #confirm .inner .contents .goback:hover,
          #confirm .inner .contents .send:hover {
            opacity: 0.6; }
        #confirm .inner .contents span.error_msg {
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 150%;
          color: #FF0000; }
        #confirm .inner .contents table {
          width: 100%;
          margin: 0 0 50px 0;
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 1.5;
          color: #5a5656; }
          #confirm .inner .contents table tr th {
            width: 170px;
            text-align: left;
            vertical-align: middle; }
            #confirm .inner .contents table tr th span {
              color: #ff3300; }
          #confirm .inner .contents table tr td {
            padding: 15px 0;
            vertical-align: middle; }
            #confirm .inner .contents table tr td input {
              width: 100%;
              height: 35px;
              padding: 5px; }
            #confirm .inner .contents table tr td textarea {
              width: 100%;
              height: 175px;
              margin: 0 0 50px 0;
              padding: 5px; }
  /************************************************
thanks
************************************************/
  #thanks {
    padding: 75px;
    background: #ddd; }
    #thanks .inner {
      width: 1100px;
      margin: 0 auto; }
      #thanks .inner h2 {
        width: 200px;
        font-size: 24px;
        font-size: 2.4rem;
        color: #5a5656;
        float: left; }
      #thanks .inner .contents {
        width: 850px;
        float: left; }
        #thanks .inner .contents .sentence {
          margin: 0 0 30px 0;
          font-size: 18px;
          font-size: 1.8rem;
          line-height: 1.5;
          color: #5a5656; }
        #thanks .inner .contents .sentence02 {
          font-size: 15px;
          font-size: 1.5rem;
          line-height: 1.5;
          color: #5a5656; }
  /************************************************
footer
************************************************/
  footer {
    width: 100%;
    padding: 20px 0;
    background: #fff;
    clear: both; }
    footer ul {
      margin: 0 0 20px 0;
      text-align: center; }
      footer ul li {
        font-size: 15px;
        font-size: 1.5rem;
        display: inline-block; }
        footer ul li a {
          color: #3f3a39 !important; }
          footer ul li a:hover {
            color: #27499d !important; }
      footer ul li + li {
        margin: 0 0 0 40px; }
    footer .copyright {
      text-align: center; }
  .to-top {
    position: fixed;
    bottom: 15px;
    right: 15px; } }
