@charset "UTF-8";
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline; }

html {
  line-height: 1; }

ol, ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle; }

q, blockquote {
  quotes: none; }
  q:before, q:after, blockquote:before, blockquote:after {
    content: "";
    content: none; }

a img {
  border: none; }

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block; }

@keyframes button-fade {
  from {
    filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
    opacity: 1; }
  to {
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
    opacity: 0.7; } }
@keyframes link-fade {
  from {
    background: none; }
  to {
    color: #004098;
    background: #fff; } }
@keyframes task-hover-fade {
  from {
    top: 0; }
  to {
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
    opacity: 0.8;
    top: -5px; } }
@keyframes daikei-nice {
  -webkit-clip-path: polygon(0% 0%, 0% 0%, 0% 0%, 0% 0%, 0%);
  clip-path: polygon(0% 0%, 0% 0%, 0% 0%, 0% 0%, 0 0%);
  to {
    -webkit-clip-path: polygon(50% 0%, 100% 38%, 82% 100%, 18% 100%, 0 35%);
    clip-path: polygon(50% 0%, 100% 38%, 82% 100%, 18% 100%, 0 35%); } }
html {
  width: 100vw;
  font-family: sans-serif;
  overflow-x: hidden; }

#PageTopBtn {
  position: fixed;
  /*ボタンの配置場所を固定*/
  bottom: 40px;
  /*下からのボタンの配置場所を指定*/
  right: 50px;
  /*右からのボタンの配置場所を指定*/
  z-index: 9999;
  width: 85px;
  height: 85px; }
  #PageTopBtn a {
    display: block;
    width: 100%;
    height: 0;
    padding-top: 100%;
    background: url(../img/page_top.svg) 50% 50% no-repeat;
    background-size: cover;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    font-size: 0rem; }
    #PageTopBtn a:hover {
      text-decoration: none;
      opacity: 0.5; }

header .content-slider {
  display: block;
  width: 100%;
  height: 100%; }
  header .content-slider .main-carousel {
    width: 100%;
    height: 100%; }
    header .content-slider .main-carousel li {
      display: block;
      width: 100%;
      height: 500px; }
      header .content-slider .main-carousel li.kigakiku {
        background-color: #58CA1C; }
      header .content-slider .main-carousel li.logoq {
        background-color: #FD9100; }
      header .content-slider .main-carousel li.tenbai {
        background-color: #DB249B; }
      header .content-slider .main-carousel li img {
        width: 700px;
        margin: 0 auto; }

footer {
  display: block;
  background-color: #0088DB;
  width: 100%;
  height: 60px;
  margin-top: auto; }
  footer address {
    text-align: center;
    position: relative;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    color: #fff; }

body {
  width: 100%;
  height: 100%;
  background: url(../img/company_back.jpg);
  background-repeat: no-repeat;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-attachment: fixed; }

body, #wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh; }

header {
  width: 100vw;
  height: 50px; }
  header .header-wrapper {
    display: block;
    position: relative;
    width: 960px;
    height: 660px;
    margin: 0 auto;
    color: #fff; }
    header .header-wrapper h1 {
      position: absolute;
      top: 40px;
      left: 20px; }
      header .header-wrapper h1 a {
        display: block;
        width: 385px;
        height: 48px;
        width: 385px;
        height: 48px;
        background: url(../img/header_logo.svg);
        background-repeat: no-repeat;
        text-indent: 100%;
        white-space: nowrap;
        overflow: hidden;
        font-size: 0rem; }
        header .header-wrapper h1 a:hover {
          opacity: 0.8;
          filter: alpha(opacity=80); }

.cycle {
  width: 100%;
  height: 100%;
  background: url(../img/cycle.png);
  background-repeat: no-repeat;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-attachment: fixed;
  animation: rotate-anime 500s linear infinite;
  position: fixed;
  z-index: -1; }

@keyframes rotate-anime {
  0% {
    transform: rotate(30); }
  100% {
    transform: rotate(360deg); } }
.index-section1 {
  display: block;
  width: 960px;
  margin: 80px auto 0 auto; }
  .index-section1 h1 {
    display: block;
    width: 100%;
    height: 100%;
    background: url(../img/logo.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-repeat: no-repeat;
    width: 100px;
    height: 100px;
    margin: 0 auto;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    font-size: 0rem; }
  .index-section1 .company-profile {
    display: block;
    width: 760px;
    height: auto;
    background-color: #fff;
    opacity: 0.8;
    filter: alpha(opacity=80);
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    -ms-border-radius: 10px;
    border-radius: 10px;
    margin: 20px auto;
    padding: 20px; }
    .index-section1 .company-profile table {
      display: block;
      width: 700px;
      margin: 20px auto;
      font-size: 13pt;
      color: #3b3b3b; }
      .index-section1 .company-profile table th {
        width: 100px;
        padding: 20px 20px;
        border-bottom: 1px solid #3b3b3b; }
      .index-section1 .company-profile table td {
        width: 600px;
        padding: 20px 20px;
        border-bottom: 1px solid #3b3b3b; }

.index-seciont2 {
  display: block;
  width: 960px;
  margin: 30px auto 0 auto; }
  .index-seciont2 ul li {
    text-align: center;
    margin: 20px auto; }
    .index-seciont2 ul li a {
      background-color: #000036;
      font-family: “Trebuchet”;
      display: inline-block;
      text-decoration: none;
      text-transform: uppercase;
      font-size: 17pt;
      color: #ffffff;
      border: 1px solid #fff;
      padding: 14px;
      -webkit-transition: color 300ms, background 300ms;
      transition: color 300ms, background 300ms; }
      .index-seciont2 ul li a:hover {
        background: #fff;
        color: #000000; }
    .index-seciont2 ul li:first-of-type {
      margin-right: 10px; }
    .index-seciont2 ul li:last-of-type {
      margin-left: 10px; }
