/* Footer */
footer {
  padding: 0; }
  footer .f-contact {
    background-image: url("../images/foot-bg.webp");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    text-align: center;
    padding: 60px 0 80px;
    color: #FFF; }
    @media screen and (max-width: 768px) {
      footer .f-contact {
        padding: 50px 0 60px; } }
    @media screen and (max-width: 480px) {
      footer .f-contact {
        padding: 50px 0 60px; } }
    footer .f-contact .title {
      font-weight: 700;
      font-size: 5.0rem; }
      @media screen and (max-width: 768px) {
        footer .f-contact .title {
          font-size: 4.0rem; } }
      @media screen and (max-width: 480px) {
        footer .f-contact .title {
          font-size: 3.0rem; } }
    footer .f-contact .f-btn {
      width: 300px;
      margin: 1.5em auto 0; }
      @media screen and (max-width: 768px) {
        footer .f-contact .f-btn {
          width: 280px; } }
      @media screen and (max-width: 480px) {
        footer .f-contact .f-btn {
          width: 260px; } }
      footer .f-contact .f-btn a {
        background-color: #EC0E0E;
        border: 2px solid #EC0E0E;
        color: #FFF;
        display: inline-block;
        width: 100%;
        padding: 12px 0 9px;
        box-sizing: border-box; }
        footer .f-contact .f-btn a:hover {
          background-color: #FFF;
          color: #EC0E0E;
          border: 2px solid #EC0E0E;
          opacity: 1.0; }
  footer .f-info {
    padding: 60px 0;
    width: 1080px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    @media screen and (max-width: 1140px) {
      footer .f-info {
        width: 90%; } }
    @media screen and (max-width: 768px) {
      footer .f-info {
        padding: 40px 0; } }
    @media screen and (max-width: 480px) {
      footer .f-info {
        padding: 30px 0; } }
    footer .f-info .f-logo-area {
      width: 450px; }
      @media screen and (max-width: 1140px) {
        footer .f-info .f-logo-area {
          width: 45%; } }
      @media screen and (max-width: 768px) {
        footer .f-info .f-logo-area {
          width: 100%; } }
      footer .f-info .f-logo-area .f-logo {
        width: 200px;
        margin: 0 0 15px; }
        @media screen and (max-width: 768px) {
          footer .f-info .f-logo-area .f-logo {
            width: 180px;
            margin: 0 0 10px; } }
        @media screen and (max-width: 480px) {
          footer .f-info .f-logo-area .f-logo {
            width: 160px; } }
    footer .f-info ul {
      display: flex;
      flex-wrap: wrap;
      margin-top: 1em; }
      @media screen and (max-width: 480px) {
        footer .f-info ul {
          margin-top: 2em; } }
      footer .f-info ul li {
        margin-left: 1.5em;
        font-weight: 700; }
        footer .f-info ul li:first-child {
          margin-left: 0; }
        @media screen and (max-width: 480px) {
          footer .f-info ul li {
            margin-left: 1.0em; } }
  footer .link-copy {
    background-color: #303030;
    color: #FFF;
    text-align: center;
    font-size: 1.2rem;
    line-height: 1.0em;
    padding: 20px 4%; }
    footer .link-copy .nav-area {
      display: flex; }
      @media screen and (max-width: 480px) {
        footer .link-copy .nav-area {
          margin-bottom: 10px; } }
      footer .link-copy .nav-area a {
        margin-right: 1em;
        padding-right: 1em;
        border-right: 1px solid #FFF; }
        footer .link-copy .nav-area a:last-child {
          border-right: none;
          margin-right: 0;
          padding-right: 0; }
