@charset "UTF-8";

/* ====================================================

  Assorti Media PC Style

==================================================== */

/* Page Common
------------------------------------------ */
section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: calc(590 / 1500 * 100vw);
  height: 20px;
  background-color: var(--green);
  transform: skewX(15deg);
  transform-origin: 0 100%;
}
.sec-heading {
  font-size: 48px;
  font-size: 4.8rem;
  font-weight: 400;
  letter-spacing: 0.075em;
  line-height: 1.0;
}
.case {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.case figure { flex-shrink: 0; }
.case-summary { padding: 0 150px 0 0; }
.case-summary dl dt {
  font-size: 24px;
  font-size: 2.4rem;
  letter-spacing: 0.075em;
  line-height: calc(40 / 24);
  margin: 0 0 30px;
}
.case-summary dl dd {
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  line-height: calc(40 / 18);
}
.case-summary dl dd small {
  font-size: calc(14 / 18 * 1em);
  display: block;
  line-height: calc(40 / 14);
}

@media screen and (max-width:1024px) {
  .sec-heading { font-size: calc(48 / 1500 * 100vw); }
  .case figure { width: calc(394 / 1200 * 100%); }
  .case-summary { padding: 0 calc(150 / 1500 * 100%) 0 0; }
  .case-summary dl dt {
    font-size: 22px;
    font-size: 2.2rem;
    margin: 0 0 calc(30 / 1500 * 100%);
  }
}

/* ------------------------------------------

  Page Header

------------------------------------------ */
.page-header .inner { padding: 130px 0 0; }
.page-heading {
  width: 396px;
  bottom: initial;
}
.page-catch {
  right: 0;
  width: 784px;
  opacity: 0.6;
}

@media screen and (max-width:1024px) {
  .page-header .inner { padding: calc(130 / 1500 * 100%) 0 0; }
  .page-heading { width: calc(396 / 1500 * 100vw); }
  .page-catch { width: calc(784 / 1500 * 100vw); }
}

/* ------------------------------------------

  Main Visual

------------------------------------------ */
.main-visual img {
  width: 100%;
  height: auto;
}

/* ------------------------------------------

  Section

------------------------------------------ */

/* Section01
------------------------------------------ */
.sec01 { padding: 110px 0 210px; }
.sec01 .sec-heading { margin: 0 0 55px; }
.sec01 .case-summary dl dd:last-of-type { margin: 50px 0 0; }
.sec01 .case-summary dl dd a {
  position: relative;
  display: flex;
  align-items: center;
  color: var(--blk);
  text-decoration: none;
  line-height: 1.4;
}
.sec01 .case-summary dl dd a i {
  width: 20px;
  height: 24px;
  display: inline-block;
  margin: 0 0 0 10px;
}
/*
.sec01 .case-summary dl dd a::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -30px;
  width: 20px;
  height: 24px;
  background: url(../images/icon_link.png) no-repeat 0 0;
  background-size: cover;
  display: inline-block;
}
*/

@media screen and (max-width:1024px) {
  .sec01 { padding: calc(110 / 1500 * 100%) 0 calc(210 / 1500 * 100%); }
  .sec01 .sec-heading { margin: 0 0 calc(55 / 1500 * 100%); }
  .sec01 .case-summary dl dd:last-of-type { margin: calc(50 / 1500 * 100%) 0 0; }
}

/* Section02
------------------------------------------ */
.sec02 { padding: 110px 0 140px; }
.sec02 .sec-heading { margin: 0 0 110px; }
.sec02 .case:not(:last-of-type) { margin: 0 0 95px; }

@media screen and (max-width:1024px) {
  .sec02 { padding: calc(110 / 1500 * 100%) 0 calc(140 / 1500 * 100%); }
  .sec02 .sec-heading { margin: 0 0 calc(110 / 1500 * 100%); }
  .sec02 .case:not(:last-of-type) { margin: 0 0 calc(95 / 1500 * 100%); }
}

/* ------------------------------------------

  Interview Request

------------------------------------------ */
.request-unit {
  position: relative;
  margin: 0 0 180px;
}
.request-unit figure { position: relative; }
.request-unit figure span {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(2,116,109,0.8);
}
.request-unit figure img {
  width: 100%;
  height: auto;
}
.contents-area {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.contents-area .inner { height: 100%; }
.request-summary {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.request-summary dl {
  width: calc(655 / 1200 * 100%);
  color: var(--wht);
}
.request-summary dl dt {
  font-size: 48px;
  font-size: 4.8rem;
  letter-spacing: 0.075em;
  line-height: calc(80 / 48);
  margin: 0 0 30px;
}
.request-summary dl dd {
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  line-height: calc(36 / 18);
}
.request-unit .link-btn {
  width: 380px;
  flex-shrink: 0;
}
.request-unit .link-btn:hover { outline-color: var(--wht); }

@media screen and (max-width:1024px) {
  .request-unit { margin: 0 0 calc(180 / 1500 * 100%); }
  .request-summary dl dt {
    font-size: calc(48 / 1500 * 100vw);
    margin: 0 0 calc(30 / 1500 * 100%);
  }
  .request-summary dl dd {
    font-size: 16px;
    font-size: 1.6rem;
  }
}