@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,500,700,900&display=swap&subset=japanese");
@import url("https://fonts.googleapis.com/css?family=Lato:400&display=swap");
@import url("https://fonts.googleapis.com/css?family=Roboto:400,700&display=swap");
@import url("https://fonts.googleapis.com/css?family=Noto+Serif+JP:700&display=swap");
@import url(base.css);
.head-image {
  background-image: url("../img/base/head-img2.jpg"); }
  .head-image .text-box {
    margin-top: 21px; }
    .head-image .text-box .head-image-text {
      font-size: 35px;
      font-weight: 700; }
    .head-image .text-box .head-image-text-sub {
      font-size: 20px;
      margin-top: 12px;
      letter-spacing: 1px; }

.top-area {
  margin: 73px 0 92px;
  padding: 0 20px; }
  .top-area .mission {
    color: #a52227;
    font-family: "Roboto", sans-serif;
    font-size: 22px;
    margin-bottom: 10px;
    text-align: center;
    letter-spacing: 1px; }
    .top-area .mission .num {
      font-size: 52px;
      margin-left: 10px;
      vertical-align: -10px;
      letter-spacing: 1.5px; }
  .top-area .top-catch {
    color: #a52227;
    font-size: 32px;
    letter-spacing: 4.5px;
    margin-bottom: 21px;
    line-height: 1.7;
    text-align: center; }
  .top-area .top-read {
    font-size: 26px;
    font-family: "Noto Serif JP", serif;
    font-weight: 700;
    line-height: 43px;
    margin-bottom: 48px;
    text-align: center;
    letter-spacing: 4px; }
  .top-area .top-text {
    line-height: 32px;
    max-width: 890px;
    margin: 0 auto;
    text-align: justify;
    letter-spacing: .5px; }

.flow {
  background: #fafafa; }
  .flow .inner {
    background: url("../img/oa/flow-line.png") no-repeat top 60px left 60px;
    position: relative;
    width: 1280px;
    height: 1933px; }
    .flow .inner .flow-content {
      position: absolute;
      width: 550px;
      height: 191px;
      border-radius: 11px;
      background: white;
      box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.3);
      padding: 38px 0 0 49px;
      z-index: 0; }
      .flow .inner .flow-content .flow-icon {
        position: absolute;
        z-index: 1; }
      .flow .inner .flow-content .flow-number {
        position: absolute;
        font-size: 123px;
        font-weight: 700;
        font-family: "Roboto", sans-serif;
        color: #a52227;
        opacity: .5;
        z-index: 1; }
      .flow .inner .flow-content .flow-en {
        position: absolute;
        font-size: 18px;
        font-weight: 700;
        font-family: "Roboto", sans-serif;
        letter-spacing: .5px; }
      .flow .inner .flow-content .flow-ttl {
        font-size: 30px;
        color: #a52227;
        font-weight: 700;
        letter-spacing: 1px;
        margin-bottom: 13px; }
      .flow .inner .flow-content .flow-text {
        font-size: 18px;
        line-height: 32px;
        letter-spacing: .8px; }
      .flow .inner .flow-content:nth-child(1) {
        top: 201px;
        left: 87px;
        z-index: 1; }
        .flow .inner .flow-content:nth-child(1) .flow-icon {
          top: -141px;
          left: -43px; }
        .flow .inner .flow-content:nth-child(1) .flow-number {
          top: -61px;
          left: 374px; }
        .flow .inner .flow-content:nth-child(1) .flow-en {
          top: 214px;
          left: 3px; }
      .flow .inner .flow-content:nth-child(2) {
        top: 352px;
        left: 571px;
        padding: 26px 0 0 154px; }
        .flow .inner .flow-content:nth-child(2) .flow-ttl {
          margin-bottom: 7px; }
        .flow .inner .flow-content:nth-child(2) .flow-icon {
          top: -183px;
          left: 250px; }
        .flow .inner .flow-content:nth-child(2) .flow-number {
          top: -80px;
          left: 394px; }
        .flow .inner .flow-content:nth-child(2) .flow-en {
          top: -123px;
          left: 424px; }
      .flow .inner .flow-content:nth-child(3) {
        top: 620px;
        left: 204px; }
        .flow .inner .flow-content:nth-child(3) .flow-icon {
          top: 129px;
          left: 437px; }
        .flow .inner .flow-content:nth-child(3) .flow-number {
          top: -128px;
          left: 22px; }
        .flow .inner .flow-content:nth-child(3) .flow-en {
          top: 209px;
          left: 338px; }
      .flow .inner .flow-content:nth-child(4) {
        top: 914px;
        left: 656px;
        z-index: 1; }
        .flow .inner .flow-content:nth-child(4) .flow-icon {
          top: 80px;
          left: 406px; }
        .flow .inner .flow-content:nth-child(4) .flow-number {
          top: -128px;
          left: 366px; }
        .flow .inner .flow-content:nth-child(4) .flow-en {
          top: 210px;
          left: 306px; }
      .flow .inner .flow-content:nth-child(5) {
        top: 997px;
        left: 165px;
        padding: 42px 0 0 62px; }
        .flow .inner .flow-content:nth-child(5) .flow-ttl {
          margin-bottom: 9px; }
        .flow .inner .flow-content:nth-child(5) .flow-icon {
          top: 221px;
          left: 167px; }
        .flow .inner .flow-content:nth-child(5) .flow-number {
          top: -61px;
          left: -92px; }
        .flow .inner .flow-content:nth-child(5) .flow-en {
          top: -30px;
          left: 62px; }
      .flow .inner .flow-content:nth-child(6) {
        top: 1231px;
        left: 666px;
        z-index: 1; }
        .flow .inner .flow-content:nth-child(6) .flow-icon {
          top: 231px;
          left: 310px; }
        .flow .inner .flow-content:nth-child(6) .flow-number {
          top: -80px;
          left: 364px; }
        .flow .inner .flow-content:nth-child(6) .flow-en {
          top: 203px;
          left: 465px; }
      .flow .inner .flow-content:nth-child(7) {
        top: 1366px;
        left: 148px;
        padding: 43px 0 0 62px; }
        .flow .inner .flow-content:nth-child(7) .flow-ttl {
          margin-bottom: 8px; }
        .flow .inner .flow-content:nth-child(7) .flow-icon {
          top: 237px;
          left: 69px; }
        .flow .inner .flow-content:nth-child(7) .flow-number {
          top: 135px;
          left: -96px; }
        .flow .inner .flow-content:nth-child(7) .flow-en {
          top: 112px;
          left: -84px; }
      .flow .inner .flow-content:nth-child(8) {
        top: 1605px;
        left: 586px; }
        .flow .inner .flow-content:nth-child(8) .flow-icon {
          top: 105px;
          left: 461px; }
        .flow .inner .flow-content:nth-child(8) .flow-number {
          top: -34px;
          left: 480px; }
        .flow .inner .flow-content:nth-child(8) .flow-en {
          top: 206px;
          left: 339px; }

.match {
  margin-top: 53px; }
  .match .match-box {
    max-width: 1110px;
    padding: 0 20px 30px;
    position: relative; }
    .match .match-box .match-ttl {
      background: #a52227;
      padding: 20px 11px 20px 17px;
      font-size: 24px;
      font-weight: 700;
      color: white;
      letter-spacing: .5px;
      display: inline-block;
      position: relative; }
      .match .match-box .match-ttl:after {
        content: "";
        position: absolute;
        top: 0;
        right: -40px;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 68px 0 0 40px;
        border-color: transparent transparent transparent #a52227; }
    .match .match-box .match-text {
      border: solid 5px #a52227;
      color: #a52227;
      font-size: 20px;
      line-height: 37px;
      letter-spacing: .5px;
      padding: 15px 29px; }
      .match .match-box .match-text li {
        display: flex;
        align-items: flex-start; }
        .match .match-box .match-text li:before {
          content: "□";
          margin-right: .2em; }
    .match .match-box .match-iamge {
      position: absolute;
      width: 255px;
      bottom: 0;
      right: -49px;
      z-index: 1; }

.detail-area {
  background: #fafafa;
  padding: 80px 0 47px; }
  .detail-area .inner {
    max-width: 1140px;
    width: 100%;
    padding: 0 20px; }
    .detail-area .inner .detail-box {
      *zoom: 1;
      margin-bottom: 56px; }
      .detail-area .inner .detail-box:before, .detail-area .inner .detail-box:after {
        display: table;
        content: "";
        line-height: 0; }
      .detail-area .inner .detail-box:after {
        clear: both; }
      .detail-area .inner .detail-box .detail-image {
        width: 50%;
        height: 300px;
        overflow: hidden;
        float: left;
        position: relative; }
        .detail-area .inner .detail-box .detail-image .image {
          position: absolute;
          height: 100%;
          top: 50%;
          left: 50%;
          transform: translate(-50%, -50%); }
      .detail-area .inner .detail-box .detail-ttl, .detail-area .inner .detail-box .detail-text {
        width: 46.1%;
        float: right; }
      .detail-area .inner .detail-box .detail-ttl {
        color: #a52227;
        font-size: 26px;
        letter-spacing: 1.5px;
        margin-bottom: 30px; }
      .detail-area .inner .detail-box .detail-text {
        line-height: 32px;
        text-align: justify;
        letter-spacing: .5px; }
      .detail-area .inner .detail-box:nth-child(even) .detail-image {
        float: right; }
      .detail-area .inner .detail-box:nth-child(even) .detail-ttl, .detail-area .inner .detail-box:nth-child(even) .detail-text {
        float: left; }
      .detail-area .inner .detail-box:last-child {
        margin-bottom: 0; }

.link-contact {
  margin-top: 47px; }

@media screen and (max-width: 768px) {
  .head-image {
    height: 220px; }
    .head-image .text-box {
      margin-top: 8px; }
      .head-image .text-box .head-image-text {
        font-size: 30px;
        line-height: 1.2; }
      .head-image .text-box .head-image-text-sub {
        font-size: 17px;
        margin-top: 15px; }

  .top-area {
    margin: 50px 0 60px;
    padding: 0 20px; }
    .top-area .mission {
      font-size: 18px;
      margin-bottom: 8px; }
      .top-area .mission .num {
        font-size: 35px;
        margin-left: 7px;
        vertical-align: -7px;
        letter-spacing: 1px; }
    .top-area .top-catch {
      font-size: 23px;
      letter-spacing: 2.5px;
      margin-bottom: 14px;
      line-height: 1.7; }
    .top-area .top-read {
      font-size: 18px;
      line-height: 32px;
      margin-bottom: 30px;
      letter-spacing: 2px; }
    .top-area .top-text {
      line-height: 26px; }

  .flow {
    background: #fafafa;
    padding: 25px 0; }
    .flow .inner {
      background: url("../img/oa/flow-dots.png") top center repeat-y;
      background-size: 8px 20px;
      width: 100%;
      height: auto;
      padding: 30px 20px 20px; }
      .flow .inner .flow-content {
        position: relative;
        width: 100%;
        max-width: 500px;
        height: auto;
        border-radius: 8px;
        padding: 30px 15px;
        margin: 0 auto 30px; }
        .flow .inner .flow-content .flow-icon {
          opacity: .12; }
        .flow .inner .flow-content .flow-number {
          font-size: 60px; }
        .flow .inner .flow-content .flow-en {
          font-size: 15px; }
        .flow .inner .flow-content .flow-ttl {
          font-size: 22px; }
        .flow .inner .flow-content .flow-text {
          font-size: 15px;
          line-height: 26px; }
        .flow .inner .flow-content:nth-child(n) {
          top: 0;
          left: 0;
          padding: 40px 20px 30px;
          z-index: 0; }
          .flow .inner .flow-content:nth-child(n) .flow-ttl {
            margin-bottom: 8px; }
          .flow .inner .flow-content:nth-child(n) .flow-number {
            top: -25px;
            left: -10px; }
          .flow .inner .flow-content:nth-child(n) .flow-icon {
            top: -10px;
            right: 15px;
            left: initial; }
          .flow .inner .flow-content:nth-child(n) .flow-en {
            top: 10px;
            right: 15px;
            left: initial; }

  .match {
    margin-top: 30px; }
    .match .match-box {
      padding: 0 20px 30px; }
      .match .match-box .match-ttl {
        padding: 12px 30px 12px 15px;
        font-size: 20px;
        line-height: 1.5; }
        .match .match-box .match-ttl:after {
          border-width: 84px 0 0 40px; }
      .match .match-box .match-text {
        font-size: 17px;
        line-height: 30px;
        padding: 15px 20px; }
      .match .match-box .match-iamge {
        display: none; }

  .detail-area {
    padding: 30px 0 35px; }
    .detail-area .inner .detail-box {
      margin-bottom: 35px; }
      .detail-area .inner .detail-box .detail-image {
        width: 100%;
        height: 200px;
        float: none;
        margin-bottom: 15px; }
        .detail-area .inner .detail-box .detail-image .image {
          width: 100%;
          min-width: 348px;
          height: auto;
          min-height: auto;
          max-height: none; }
      .detail-area .inner .detail-box .detail-ttl, .detail-area .inner .detail-box .detail-text {
        width: 100%;
        float: none; }
      .detail-area .inner .detail-box .detail-ttl {
        color: white;
        background: #a52227;
        padding: 14px 20px;
        font-size: 20px;
        margin: 0 -20px 15px;
        line-height: 1.5;
        width: 100vw; }
      .detail-area .inner .detail-box .detail-text {
        line-height: 26px; }
      .detail-area .inner .detail-box:nth-child(even) .detail-image {
        float: none; }
      .detail-area .inner .detail-box:nth-child(even) .detail-ttl, .detail-area .inner .detail-box:nth-child(even) .detail-text {
        float: none; }

  .link-contact {
    margin-top: 30px; } }

/*# sourceMappingURL=oa.css.map */
