@charset "UTF-8";
/*
---------------------------------------------------------------------------------------------------------------------
プロの解説シリーズ　アーカイブ
---------------------------------------------------------------------------------------------------------------------
*/
#explanation-archive {
  max-width: 1400px;
  margin: 0 auto 40px;
  width: 90%; }
  @media (min-width: 768px) {
    #explanation-archive {
      margin: 0 auto 80px; } }
  @media (min-width: 1024px) {
    #explanation-archive {
      margin: 0 auto 100px;
      display: flex; } }
  #explanation-archive.personnel {
    margin: 0 auto 80px; }
  @media (min-width: 1024px) {
    #explanation-archive .contents {
      width: calc(100% - 300px); } }
  #explanation-archive ul.explanation {
    border-top: 1px solid #D8D8D8; }
    #explanation-archive ul.explanation li {
      position: relative;
      border-bottom: 1px solid #D8D8D8; }
      #explanation-archive ul.explanation li:first-child {
        padding-top: 0; }
      #explanation-archive ul.explanation li a:hover .title > h3 {
        color: #E96087; }
      #explanation-archive ul.explanation li a:hover::after {
        right: 0;
        border-top: solid 1px #E96087;
        border-right: solid 1px #E96087; }
      #explanation-archive ul.explanation li a .explanation-box {
        padding: 20px 0; }
        @media (min-width: 1024px) {
          #explanation-archive ul.explanation li a .explanation-box {
            display: flex;
            padding: 40px 0; } }
        #explanation-archive ul.explanation li a .explanation-box .icon {
          display: flex;
          align-items: center;
          margin-right: 10px; }
          @media (min-width: 1024px) {
            #explanation-archive ul.explanation li a .explanation-box .icon {
              margin-right: 0; } }
          #explanation-archive ul.explanation li a .explanation-box .icon h5 {
            font-family: "Outfit", sans-serif;
            font-size: 0.9em;
            font-weight: 400;
            margin-right: 5px; }
            @media (min-width: 1024px) {
              #explanation-archive ul.explanation li a .explanation-box .icon h5 {
                font-size: 1.0em;
                margin-right: 10px; } }
            #explanation-archive ul.explanation li a .explanation-box .icon h5.personnel {
              margin-right: 30px; }
          #explanation-archive ul.explanation li a .explanation-box .icon img {
            width: 40px;
            border-radius: 50%;
            margin-right: 5px; }
            @media (min-width: 1024px) {
              #explanation-archive ul.explanation li a .explanation-box .icon img {
                width: 75px;
                margin-right: 10px; } }
          #explanation-archive ul.explanation li a .explanation-box .icon h4 {
            font-size: 0.8em;
            font-weight: 400;
            color: #7D7775;
            margin-left: 5px; }
            @media (min-width: 1024px) {
              #explanation-archive ul.explanation li a .explanation-box .icon h4 {
                display: none; } }
        #explanation-archive ul.explanation li a .explanation-box .title {
          margin-top: 6px;
          padding-right: 2em; }
          @media (min-width: 1024px) {
            #explanation-archive ul.explanation li a .explanation-box .title {
              width: calc(100% - 220px);
              margin-top: 0; } }
          @media (min-width: 1200px) {
            #explanation-archive ul.explanation li a .explanation-box .title {
              width: calc(100% - 260px); } }
          #explanation-archive ul.explanation li a .explanation-box .title h4 {
            display: none;
            font-size: 0.8em;
            font-weight: 400;
            color: #7D7775;
            margin-bottom: 5px; }
            @media (min-width: 1024px) {
              #explanation-archive ul.explanation li a .explanation-box .title h4 {
                display: block; } }
            @media (min-width: 1200px) {
              #explanation-archive ul.explanation li a .explanation-box .title h4 {
                font-size: 0.9em; } }
          #explanation-archive ul.explanation li a .explanation-box .title h3 {
            font-size: 1.0em;
            font-weight: bold;
            line-height: 1.3em;
            transition: .5s;
            font-feature-settings: "palt";
            letter-spacing: 0.04em;
            word-break: break-all;
            display: -webkit-box;
            -webkit-line-clamp: 2;
            -webkit-box-orient: vertical;
            overflow: hidden; }
            @media (min-width: 768px) {
              #explanation-archive ul.explanation li a .explanation-box .title h3 {
                font-size: 1.125em; } }
            @media (min-width: 1200px) {
              #explanation-archive ul.explanation li a .explanation-box .title h3 {
                font-size: 1.25em; } }
      #explanation-archive ul.explanation li a::after {
        position: absolute;
        top: 50%;
        right: 10px;
        content: '';
        margin-top: -3px;
        width: 10px;
        height: 10px;
        border: 0px;
        border-top: solid 1px #222324;
        border-right: solid 1px #222324;
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        transition: .5s; }

.side-menu {
  margin-bottom: 40px; }
  @media (min-width: 1024px) {
    .side-menu {
      width: 300px; } }
  .side-menu .side-menu-in {
    position: sticky;
    top: 100px; }
    .side-menu .side-menu-in .explanation-personnel {
      margin-bottom: 40px; }
      @media (min-width: 1024px) {
        .side-menu .side-menu-in .explanation-personnel {
          margin-bottom: 60px; } }
      .side-menu .side-menu-in .explanation-personnel h2 {
        font-size: 1.125em; }
        @media (min-width: 768px) {
          .side-menu .side-menu-in .explanation-personnel h2 {
            font-size: 1.125em; } }
        @media (min-width: 1200px) {
          .side-menu .side-menu-in .explanation-personnel h2 {
            font-size: 1.25em; } }
      .side-menu .side-menu-in .explanation-personnel .all {
        margin-top: 20px; }
        .side-menu .side-menu-in .explanation-personnel .all a {
          position: relative;
          font-size: 0.9em;
          display: inline-block;
          background-color: #FFD6D8;
          border-radius: 5px;
          padding: 10px 40px 10px 10px; }
          @media (min-width: 768px) {
            .side-menu .side-menu-in .explanation-personnel .all a {
              font-size: 1.0em; } }
          @media (min-width: 1024px) {
            .side-menu .side-menu-in .explanation-personnel .all a {
              border-radius: 10px; } }
          .side-menu .side-menu-in .explanation-personnel .all a:hover::after {
            right: 10px; }
          .side-menu .side-menu-in .explanation-personnel .all a::after {
            position: absolute;
            top: 50%;
            right: 15px;
            content: '';
            margin-top: -3px;
            width: 6px;
            height: 6px;
            border: 0px;
            border-top: solid 1px #000;
            border-right: solid 1px #000;
            -ms-transform: rotate(45deg);
            -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
            transition: .5s; }
      .side-menu .side-menu-in .explanation-personnel ul {
        margin-top: 10px;
        padding-left: 15px; }
        @media (min-width: 1024px) {
          .side-menu .side-menu-in .explanation-personnel ul {
            margin-top: 20px; } }
        .side-menu .side-menu-in .explanation-personnel ul li {
          margin: 0 30px 5px 0;
          display: inline-block; }
          @media (min-width: 1024px) {
            .side-menu .side-menu-in .explanation-personnel ul li {
              margin: 0 0 30px 0;
              display: block; } }
          .side-menu .side-menu-in .explanation-personnel ul li:last-child {
            margin-bottom: 0; }
          .side-menu .side-menu-in .explanation-personnel ul li a {
            position: relative;
            font-size: 0.8em;
            font-feature-settings: "palt";
            letter-spacing: 0.04em;
            transition: .5s; }
            @media (min-width: 768px) {
              .side-menu .side-menu-in .explanation-personnel ul li a {
                font-size: 0.9em; } }
            .side-menu .side-menu-in .explanation-personnel ul li a::before {
              content: "";
              position: absolute;
              left: -12px;
              top: 2px;
              bottom: 0;
              display: flex;
              margin: auto;
              width: 3px;
              height: 3px;
              background-color: #000;
              border-radius: 50%;
              transition: .5s; }
            .side-menu .side-menu-in .explanation-personnel ul li a:hover {
              color: #E96087; }
              .side-menu .side-menu-in .explanation-personnel ul li a:hover::before {
                background-color: #E96087;
                transform: scale(2); }

/*
---------------------------------------------------------------------------------------------------------------------
エフピオからのお知らせ　アーカイブ
---------------------------------------------------------------------------------------------------------------------
*/
ul.news-archive {
  margin-top: 30px; }
  @media (min-width: 1024px) {
    ul.news-archive {
      margin-top: 60px; } }
  ul.news-archive li {
    border-bottom: 1px solid #D8D8D8; }
    ul.news-archive li:last-child {
      border-bottom: none; }
    ul.news-archive li a:hover .news-box > p {
      color: #E96087; }
    ul.news-archive li a:hover .news-box::after {
      right: 10px;
      border-top: solid 1px #E96087;
      border-right: solid 1px #E96087; }
    ul.news-archive li a .news-box {
      position: relative;
      padding: 20px 0; }
      @media (min-width: 768px) {
        ul.news-archive li a .news-box {
          padding: 30px 0; } }
      @media (min-width: 1024px) {
        ul.news-archive li a .news-box {
          display: flex;
          align-items: center;
          padding: 40px 0; } }
      ul.news-archive li a .news-box .data {
        display: flex;
        align-items: center;
        margin-bottom: 10px; }
        @media (min-width: 1024px) {
          ul.news-archive li a .news-box .data {
            display: flex;
            width: 350px;
            margin-bottom: 0; } }
        ul.news-archive li a .news-box .data h3 {
          font-family: "Outfit", sans-serif;
          font-size: 0.9em;
          margin-right: 20px; }
          @media (min-width: 1024px) {
            ul.news-archive li a .news-box .data h3 {
              font-size: 1.0em; } }
        ul.news-archive li a .news-box .data h4 {
          font-size: 0.7em;
          font-weight: 400;
          display: inline-block;
          text-align: center;
          border-radius: 50px;
          padding: 6px 15px;
          border: 1px solid #7D7775;
          background-color: #fff;
          color: #7D7775; }
          @media (min-width: 1200px) {
            ul.news-archive li a .news-box .data h4 {
              font-size: 0.8em; } }
          ul.news-archive li a .news-box .data h4.news-type-seminar {
            color: #E96087;
            border: 1px solid #E96087; }
      ul.news-archive li a .news-box p {
        font-size: 0.9em;
        font-weight: 500;
        line-height: 1.4em;
        padding-right: 2em;
        transition: .5s; }
        @media (min-width: 1024px) {
          ul.news-archive li a .news-box p {
            font-size: 1.125em;
            width: calc(100% - 350px); } }
      ul.news-archive li a .news-box::after {
        position: absolute;
        top: 50%;
        right: 10px;
        content: '';
        margin-top: -3px;
        width: 10px;
        height: 10px;
        border: 0px;
        border-top: solid 1px #000;
        border-right: solid 1px #000;
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        transition: .5s; }
        @media (min-width: 1024px) {
          ul.news-archive li a .news-box::after {
            right: 15px; } }

/*
---------------------------------------------------------------------------------------------------------------------
プロジェクトストーリー
---------------------------------------------------------------------------------------------------------------------
*/
.project-company {
  display: flex;
  align-items: center;
  margin-bottom: 10px; }
  .project-company ul {
    display: flex; }
    .project-company ul li {
      color: #fff;
      font-size: 0.8em; }
      @media (min-width: 768px) {
        .project-company ul li {
          font-size: 0.9em; } }

ul.project-category li {
  display: inline-block;
  margin: 0 5px 0 0; }
  @media (min-width: 768px) {
    ul.project-category li {
      margin: 0 5px 5px 0; } }
  ul.project-category li:last-child {
    margin-bottom: 0; }
  ul.project-category li a {
    color: #fff;
    font-feature-settings: "palt";
    letter-spacing: 0.04em;
    font-size: 0.8em; }
    @media (min-width: 768px) {
      ul.project-category li a {
        font-size: 0.9em; } }

#project-slide {
  background-color: #0BB3B1;
  border-radius: 15px;
  padding: 40px 0 60px;
  margin-top: 80px; }
  @media (min-width: 1024px) {
    #project-slide {
      border-radius: 30px;
      padding: 100px 0 120px;
      margin-top: 160px; } }

#project-slide .title-area {
  position: relative; }
  #project-slide .title-area .title {
    text-align: center;
    color: #fff;
    margin: 0 auto 40px; }
    #project-slide .title-area .title h1 {
      font-family: "Outfit", sans-serif;
      font-size: 2.5em;
      font-weight: 700; }
      @media (min-width: 768px) {
        #project-slide .title-area .title h1 {
          font-size: 4.0em; } }
      @media (min-width: 1200px) {
        #project-slide .title-area .title h1 {
          font-size: 6.25em; } }
    #project-slide .title-area .title h2 {
      font-size: 0.9em;
      font-weight: 500;
      margin-top: 10px; }
      @media (min-width: 768px) {
        #project-slide .title-area .title h2 {
          font-size: 1.0em; } }
      @media (min-width: 1200px) {
        #project-slide .title-area .title h2 {
          font-size: 1.125em;
          margin-top: 20px; } }
#project-slide .more-view {
  display: flex;
  justify-content: end;
  padding-right: 5%; }
#project-slide .project-card2 {
  padding: 50px 0 0 4%;
  position: relative;
  overflow: hidden;
  width: 100%;
  margin-top: -30px; }
  @media (min-width: 768px) {
    #project-slide .project-card2 {
      padding: 60px 0 0 5%;
      margin-top: -20px; } }
  #project-slide .project-card2 .swiper-slide {
    width: 280px;
    margin: 0 15px 0 0; }
    @media (min-width: 768px) {
      #project-slide .project-card2 .swiper-slide {
        width: 320px;
        margin: 0 20px 0 0; } }
    @media (min-width: 1250px) {
      #project-slide .project-card2 .swiper-slide {
        width: 380px;
        margin: 0 40px 0 0; } }
    #project-slide .project-card2 .swiper-slide:last-child {
      margin-right: 3%; }
#project-slide .swiper-button-prev, #project-slide .swiper-button-next {
  top: 30px;
  left: calc(5% + 40px); }
  @media (min-width: 1200px) {
    #project-slide .swiper-button-prev, #project-slide .swiper-button-next {
      left: calc(5% + 50px); } }
#project-slide .swiper-button-prev {
  left: 5%; }
#project-slide .project-box a:hover .iCatch > img {
  transform: scale(1.04); }
#project-slide .project-box a .iCatch {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  z-index: 1; }
  #project-slide .project-box a .iCatch img {
    transition-duration: 0.8s;
    transform: scale(1); }
#project-slide .project-box a .txt {
  color: #fff;
  margin-top: 10px; }
  #project-slide .project-box a .txt h3 {
    font-size: 0.9em;
    line-height: 1.4em; }
    @media (min-width: 768px) {
      #project-slide .project-box a .txt h3 {
        font-size: 1.0em; } }
    @media (min-width: 1200px) {
      #project-slide .project-box a .txt h3 {
        font-size: 1.125em; } }
#project-slide .project-box .project-company {
  margin-top: 5px; }
#project-slide .project-box ul.project-category li {
  display: inline-block;
  margin: 0 5px 0 0; }
  @media (min-width: 768px) {
    #project-slide .project-box ul.project-category li {
      margin: 0 5px 2px 0; } }
