@charset "UTF-8";
/*
 * style.css
 *
 *  version --- 1.0
 *  updated --- 2013/5/10
 */
/* !Clearfix
---------------------------------------------------------- */
.clearfix {
  display: block;
  min-height: 1%; }

.clearfix:after {
  clear: both;
  content: ".";
  display: block;
  height: 0;
  visibility: hidden; }

ol,
ul {
  list-style: none;
  margin: 0; }

img {
  vertical-align: top;
  max-width: 100%; }

table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 100%; }

body p {
  margin: 0; }

body ul {
  padding: 0; }

.visible-pc {
  display: block; }

.visible-sp {
  display: none; }

.inner {
  width: 980px;
  margin: 0 auto; }

@media screen and (max-width: 979px) {
  .visible-sp {
    display: block; }
  .visible-pc {
    display: none; }
  .inner {
    width: 100%;
    padding: 0;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box; } }

.wrap {
  line-height: 1.5; }

.bg-color-main {
  background: #ffe5c4; }

.mainimg {
  background: url("/assets/agingcare/light/injection/prp/images/mainbg.jpg") center center no-repeat;
  background-size: cover;
  text-align: center; }

.bg-image.-ribbon {
  max-width: 980px;
  margin: 30px auto; }

@media screen and (max-width: 979px) {
  .bg-image.-ribbon {
    text-align: center;
    background-image: url(/assets/images/components/bg_ribbon.png);
    background-size: 100% 80px;
    font-size: 13px;
    height: inherit;
    line-height: 1.3;
    padding: 10px 0 20px; } }

.topnavi {
  padding: 20px 0; }

.navilist {
  display: flex;
  justify-content: center; }
  .navilist li {
    width: 16.66%;
    border-left: 1px solid #f8cd9f;
    display: flex;
    align-items: center; }
    .navilist li a {
      font-size: 16px;
      text-decoration: none;
      display: table;
      width: 100%; }
      .navilist li a span {
        display: table-cell;
        vertical-align: middle;
        text-align: center; }
  .navilist li:last-child {
    border-right: 1px solid #f8cd9f; }

.hdl {
  text-align: center;
  font-size: 20px; }

.hdl span {
  display: block;
  font-size: 52px;
  position: relative;
  margin-bottom: 15px; }

.hdl span::before {
  background: #000;
  width: 95px;
  height: 2px;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  content: "";
  z-index: 2;
  position: absolute; }

@media screen and (max-width: 979px) {
  .hdl {
    font-size: 12px; }
  .hdl span {
    font-size: 27px;
    margin-bottom: 10px; }
  .hdl span::before {
    width: 50px;
    height: 1px; }
  .topnavi {
    padding: 0; }
  .navilist {
    flex-wrap: wrap; }
    .navilist li {
      width: 50%;
      padding: 10px 5px;
      position: relative; }
      .navilist li a {
        font-size: 13px; }
    .navilist li:nth-child(2n + 1) {
      border-left: none; }
    .navilist li:nth-child(n + 3) {
      border-top: 1px solid #f8cd9f; }
    .navilist li:last-child {
      width: 100%;
      border-right: none;
      border-bottom: 1px solid #f8cd9f; }
    .navilist li::before {
      content: "";
      width: 10px;
      height: 10px;
      position: absolute;
      right: 10px;
      top: 45%;
      top: calc(50% - 8px);
      border: 1px solid;
      border-color: #000 #000 transparent transparent;
      transform: rotate(135deg); } }

.toppick {
  padding: 40px 0 60px;
  background: #fff4e5; }

.pickupInner {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 30px 0 10px; }

.pickupInner .arrow {
  width: 60px;
  position: relative; }

.pickupInner .arrow::before {
  content: "";
  width: 30px;
  position: absolute;
  left: 10px;
  left: calc(50% - 22px);
  top: 45%;
  top: calc(50% - 20px);
  height: 30px;
  border: 5px solid;
  border-color: #000 #000 transparent transparent;
  transform: rotate(45deg); }

@media screen and (max-width: 979px) {
  .toppick {
    padding: 20px 0 35px; }
  .pickupInner {
    width: 85%;
    flex-wrap: wrap;
    margin: 10px auto; }
  .pickupInner .arrow {
    width: 100%;
    height: 30px; }
  .pickupInner .arrow::before {
    content: "";
    width: 20px;
    height: 20px;
    left: 48%;
    left: calc(50% - 8px);
    top: 45%;
    top: calc(50% - 15px);
    border: 3px solid;
    border-color: #000 #000 transparent transparent;
    transform: rotate(135deg); } }

.topwhat {
  background: url("/assets/agingcare/light/injection/prp/images/what01.jpg") center top no-repeat #000;
  padding: 60px 0 85px;
  height: 673px; }
  .topwhat .hdl {
    color: #fff; }
    .topwhat .hdl span:before {
      background: #fff; }
  .topwhat .list {
    margin: 55px 0 0; }
    .topwhat .list li {
      font-size: 24px;
      color: #fff;
      padding: 0 0 0 45px;
      background: url("/assets/agingcare/light/injection/prp/images/check.png") 0 0 no-repeat; }
    .topwhat .list li + li {
      margin: 25px 0 0; }

@media screen and (max-width: 979px) {
  .topwhat {
    background: none #000;
    background-size: cover;
    padding: 30px 0 0;
    height: auto; }
    .topwhat .list {
      margin: 30px 20px 0; }
      .topwhat .list li {
        font-size: 15px;
        color: #fff;
        padding: 0 0 0 20px;
        background-size: 15px; }
      .topwhat .list li + li {
        margin: 10px 0 0; } }

.toppoint {
  background: url("/assets/agingcare/light/injection/prp/images/point01.jpg") center top no-repeat;
  background-size: cover;
  padding: 30px 0 50px;
  height: 916px; }

.toppoint ul {
  width: 913px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center; }

.toppoint ul li {
  width: 284px;
  margin: 10px; }

.toppoint .hdl {
  margin-bottom: 40px; }

@media screen and (max-width: 979px) {
  .toppoint {
    background-image: url("/assets/agingcare/light/injection/prp/images/point01_sp.jpg");
    background-size: cover;
    padding: 40px 0 35px;
    height: auto; }
  .toppoint .hdl {
    margin-bottom: 10px; }
  .toppoint ul {
    width: 100%;
    margin: 0 auto; }
  .toppoint ul li {
    width: 46%;
    margin: 2%; } }

.topabout {
  padding: 70px 0; }
  .topabout .inner {
    width: 980px;
    margin: 0 auto; }
    .topabout .inner p {
      font-size: 130%; }
  .topabout h3 {
    font-size: 28px;
    text-align: center;
    margin: 20px 0; }
  .topabout h4 {
    font-size: 24px;
    text-align: center;
    margin-bottom: 15px;
    background-color: #000;
    color: #fff;
    padding: 5px; }
  .topabout div > h4 {
    margin: 50px 0 15px; }
  .topabout div {
    margin: 30px 0 0; }
  .topabout .dr {
    display: flex;
    flex-wrap: wrap;
    justify-content: center; }
    .topabout .dr p {
      width: 484px; }
    .topabout .dr div {
      width: 476px;
      margin: 0 0 0 20px; }

.textMinistry {
  font-size: 14px;
  border: 2px solid #ffdfbc;
  padding: 20px 25px;
  background: #fcf6ee;
  word-wrap: break-word; }

@media screen and (max-width: 979px) {
  .topabout {
    padding: 30px 0 15px; }
    .topabout .inner {
      width: 100%; }
      .topabout .inner p {
        font-size: 100%; }
    .topabout h3 {
      font-size: 18px;
      text-align: center;
      margin: 20px 5px; }
    .topabout h4 {
      font-size: 16px;
      text-align: center;
      margin-bottom: 15px;
      background-color: #000;
      color: #fff;
      padding: 5px; }
    .topabout div > h4 {
      margin: 25px 0 15px; }
    .topabout p {
      margin: 0 5%; }
    .topabout div {
      width: 96%;
      margin: 10px auto 0; }
    .topabout .dr {
      display: flex;
      flex-wrap: wrap;
      justify-content: center; }
      .topabout .dr div {
        margin: 0 0 0 20px; }
  .textMinistry {
    font-size: 12px;
    border: 2px solid #ffdfbc;
    padding: 10px 15px; } }

.topphoto {
  padding: 90px 0 120px;
  background: #fff4e5; }

.topcomment {
  background: url("/assets/agingcare/light/injection/prp/images/comment.jpg") center bottom no-repeat #ffdfbc;
  padding: 60px 0 0;
  height: 990px; }

.commentbox {
  width: 550px;
  margin: 40px 0 0 auto; }

.commentbox .txt {
  font-size: 18px;
  line-height: 1.5; }

.commentbox .txt .txt_2 {
  display: block;
  max-width: 450px; }

.commentbox .name {
  margin: 35px 0 0;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
  font-weight: bold;
  font-size: 21px; }

.commentbox .name span {
  display: block;
  font-size: 24px; }

.commentbox .name i {
  font-style: normal;
  margin-right: 10px;
  font-size: 37px; }

@media screen and (max-width: 979px) {
  .topphoto {
    padding: 10% 5%;
    background: #fff4e5; }
  .topcomment {
    background-color: #ffdfbc;
    background-image: url("/assets/agingcare/light/injection/prp/images/comment_sp.jpg");
    background-size: contain;
    padding: 10% 5% 0;
    height: auto; }
    .topcomment .inner {
      padding: 0; }
    .topcomment .commentbox {
      width: 100%;
      margin: 20px 0 0;
      -ms-box-sizing: border-box;
      -o-box-sizing: border-box;
      box-sizing: border-box; }
      .topcomment .commentbox .txt {
        font-size: 13px; }
    .topcomment .img {
      margin-top: 10px; }
      .topcomment .img img {
        width: 100%; } }

.topprice {
  padding: 100px 0 115px; }
  .topprice img {
    text-align: center;
    margin: 30px 0; }
  .topprice .pricetab {
    width: 100%;
    background: #fff;
    margin: 0; }
    .topprice .pricetab th {
      text-align: center;
      font-weight: bold;
      padding: 10px; }
    .topprice .pricetab td {
      text-align: right; }
    .topprice .pricetab td,
    .topprice .pricetab th {
      border: 1px solid #000;
      font-size: 17px;
      padding: 10px;
      width: 25%; }
      .topprice .pricetab td .price,
      .topprice .pricetab th .price {
        color: #ef4071;
        font-weight: bold; }
    .topprice .pricetab tr.t_header {
      background: #000000;
      border-bottom: none;
      color: #ffffff; }
      .topprice .pricetab tr.t_header th {
        text-align: center;
        font-size: 18px;
        padding: 10px; }
    .topprice .pricetab .price-cat {
      text-align: center; }
      .topprice .pricetab .price-cat th {
        background: #ffe5c4;
        padding: 10px; }
    .topprice .pricetab tr.monitor td,
    .topprice .pricetab tr.monitor th {
      color: #cc0000;
      padding-bottom: 0; }
  .topprice .catch {
    font-size: 24px;
    font-weight: 600;
    line-height: 1.4;
    text-align: center;
    background-color: #000;
    color: #fff;
    padding: 10px; }
    @media only screen and (max-width: 979px) {
      .topprice .catch {
        font-size: 18px;
        padding: 5px; } }
  .topprice .priceContainer {
    margin: 40px 0 0; }
    @media only screen and (max-width: 979px) {
      .topprice .priceContainer {
        margin-top: 5vw; } }
    .topprice .priceContainer .priceContainer__bd {
      padding: 30px 55px;
      background: #fff4e5; }
      @media only screen and (max-width: 979px) {
        .topprice .priceContainer .priceContainer__bd {
          padding: 15px; } }
    @media only screen and (max-width: 979px) {
      .topprice .priceContainer {
        margin-top: 30px; } }
    .topprice .priceContainer .cont {
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      font-size: 20px;
      font-weight: bold;
      line-height: 1.5; }
      .topprice .priceContainer .cont + .cont {
        border-top: 1px dashed #918f8f;
        margin-top: 25px;
        padding-top: 25px; }
      @media only screen and (max-width: 979px) {
        .topprice .priceContainer .cont {
          font-size: 14px; }
          .topprice .priceContainer .cont + .cont {
            margin-top: 15px;
            padding-top: 15px; } }
      .topprice .priceContainer .cont .txt01 {
        width: 250px;
        text-align: center;
        border: 1px solid #000;
        padding: 3px 0; }
        @media only screen and (max-width: 979px) {
          .topprice .priceContainer .cont .txt01 {
            width: 33%;
            margin-bottom: 10px; } }
      .topprice .priceContainer .cont .txt02 {
        font-weight: bold;
        font-size: 31px;
        margin-right: 20px; }
        @media only screen and (max-width: 979px) {
          .topprice .priceContainer .cont .txt02 {
            font-size: 16px; } }
      .topprice .priceContainer .cont .num {
        text-align: center;
        flex: 1;
        text-align: right; }
        @media only screen and (max-width: 979px) {
          .topprice .priceContainer .cont .num {
            width: 100%; } }
        .topprice .priceContainer .cont .num .cost {
          font-size: 52px;
          font-weight: 400;
          line-height: 1;
          display: flex;
          align-items: center;
          justify-content: flex-end; }
          @media only screen and (max-width: 979px) {
            .topprice .priceContainer .cont .num .cost {
              font-size: 45px; } }
          .topprice .priceContainer .cont .num .cost .en {
            display: inline-block;
            letter-spacing: -2px;
            font-family: arial, sans-serif; }
            @media only screen and (max-width: 979px) {
              .topprice .priceContainer .cont .num .cost .en {
                margin-right: 5px; } }
          .topprice .priceContainer .cont .num .cost .unit {
            position: relative;
            display: inline-block;
            font-size: 30px;
            font-weight: bold;
            line-height: 1;
            margin-bottom: -15px;
            margin-left: 5px; }
            .topprice .priceContainer .cont .num .cost .unit em {
              position: absolute;
              font-style: normal;
              font-size: 40px; }
              @media only screen and (max-width: 979px) {
                .topprice .priceContainer .cont .num .cost .unit em {
                  font-size: 14px; } }
            @media only screen and (max-width: 979px) {
              .topprice .priceContainer .cont .num .cost .unit {
                font-size: 20px;
                margin-bottom: -10px;
                margin-left: 0; } }
            .topprice .priceContainer .cont .num .cost .unit small {
              position: absolute;
              left: 0;
              bottom: 100%;
              width: 100%;
              font-size: 14px;
              text-align: center;
              white-space: nowrap; }
              @media only screen and (max-width: 979px) {
                .topprice .priceContainer .cont .num .cost .unit small {
                  font-size: 12px;
                  white-space: nowrap; } }
      .topprice .priceContainer .cont._monitor {
        color: #ef4071; }
        .topprice .priceContainer .cont._monitor .txt01 {
          border-color: #ef4071; }
    .topprice .priceContainer .bui {
      font-size: 18px;
      margin: 20px 0 0;
      padding: 15px;
      background-color: #fff; }
      @media only screen and (max-width: 979px) {
        .topprice .priceContainer .bui {
          margin-top: 10px;
          padding: 10px;
          font-size: 14px; } }

@media screen and (max-width: 979px) {
  .topprice {
    padding: 45px 0; }
    .topprice .inner {
      width: auto;
      margin: 0 2%; }
    .topprice .pricetab th,
    .topprice .pricetab td {
      font-size: 13px;
      padding: 10px; }
    .topprice .pricetab tr.t_header th {
      text-align: center;
      font-size: 14px;
      padding: 5px 0; }
    .topprice .pricetab tr.t_header_monitor th {
      text-align: center;
      font-size: 14px;
      padding: 5px 0; }
    .topprice .pricetab .price-cat th {
      font-size: 14px; } }

.topflow {
  padding: 90px 0 120px;
  background: #fff4e5; }

.flowmain {
  margin: 30px 0 0; }

.flowpanel {
  padding-bottom: 40px;
  border-bottom: 1px solid #000;
  position: relative;
  display: flex;
  justify-content: space-between; }

.flowpanel {
  margin: 38px 0 0; }

.flowpanel:before {
  background: url("/assets/agingcare/light/injection/prp/images/flow_icon.png") 0 0 no-repeat;
  width: 67px;
  height: 31px;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  content: "";
  z-index: 2;
  position: absolute; }

.flowmain .flowpanel:last-child {
  border-bottom: none; }

.flowmain .flowpanel:last-child:before {
  display: none; }

.flowbox {
  width: 580px;
  font-size: 19px;
  line-height: 1.7; }

.flowbox .tit {
  display: flex;
  align-items: center;
  font-size: 30px;
  font-weight: bold;
  margin-bottom: 25px; }

.flowbox .tit img {
  flex-shrink: 0;
  margin-right: 10px; }

.flowbox .list li {
  text-indent: -1em;
  padding-left: 1em; }

.flowbox .list li img {
  vertical-align: middle;
  margin-top: -5px; }

.flowbox .list li span {
  font-size: 17px; }

.flowbox .list li a {
  font-weight: bold;
  text-decoration: underline;
  color: #000; }

.flowbox .list li a:hover {
  text-decoration: none; }

.flowtab {
  width: 100%;
  background: #fff; }

.flowtab th {
  width: 220px;
  font-size: 18px;
  background: #eee;
  text-align: left;
  padding: 10px 20px;
  border: 1px solid #000;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box; }

.flowtab td {
  border: 1px solid #000;
  padding: 15px 20px;
  font-size: 17px; }

@media screen and (max-width: 979px) {
  .topflow {
    padding: 40px 0; }
  .topflow .inner {
    padding: 0; }
  .flowmain {
    margin: 15px 0 0; }
  .flowpanel {
    padding-bottom: 30px;
    display: block; }
  .flowpanel + .flowpanel {
    margin: 35px 0 0; }
  .flowpanel:before {
    background-size: 100%;
    width: 38px;
    height: 18px; }
  .flowbox {
    width: 100%;
    padding: 0 10px;
    font-size: 12px;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box; }
  .flowbox .tit {
    display: flex;
    font-size: 19px;
    margin-bottom: 25px; }
  .flowbox .tit img {
    flex-shrink: 0;
    width: 40px;
    margin-right: 5px; }
  .flowbox .list li img {
    width: 87px;
    margin-top: -2px; }
  .flowbox .list li span {
    font-size: 10px; }
  .flowpanel .img {
    text-align: center;
    margin: 15px 0 0; }
  .flowpanel .img img {
    width: 80%; }
  .flowtab {
    width: 96%;
    margin: 0 auto; }
  .flowtab th {
    width: 100px;
    font-size: 12px;
    padding: 5px 10px; }
  .flowtab td {
    padding: 5px 10px;
    font-size: 12px; } }

.topfaq {
  padding: 70px 0 105px;
  background: #ffebcc; }

.faqmain {
  margin: 30px 0 0; }

.faqcont {
  padding: 40px; }

.faqcont:nth-child(2n + 1) {
  background: #fff; }

.faqcont .tit {
  font-size: 24px;
  font-weight: bold;
  padding: 5px 0 0 68px;
  margin-bottom: 35px;
  min-height: 41px;
  background: url("/assets/agingcare/light/injection/prp/images/qa01.png") 0 0 no-repeat; }

.faqcont .txt {
  font-size: 21px;
  padding: 5px 0 0 68px;
  min-height: 41px;
  background: url("/assets/agingcare/light/injection/prp/images/qa02.png") 0 0 no-repeat; }

@media screen and (max-width: 979px) {
  .topfaq {
    padding: 50px 0 2px; }
  .topfaq .inner {
    padding: 0; }
  .faqmain {
    margin: 15px 0 0; }
  .faqcont {
    padding: 20px 25px 15px; }
  .faqcont .tit {
    font-size: 15px;
    padding: 0 0 0 25px;
    margin-bottom: 10px;
    background-size: 20px; }
  .faqcont .txt {
    font-size: 13px;
    padding: 0 0 0 25px;
    background-size: 20px; } }

#clinic {
  padding: 65px 0 30px;
  margin: 0 !important; }
  #clinic #clinic-map {
    min-height: 1100px; }
    #clinic #clinic-map #hokkaido,
    #clinic #clinic-map #tohoku {
      display: none; }
    #clinic #clinic-map #tokai {
      top: 350px;
      left: 280px; }
    #clinic #clinic-map #chugoku {
      top: 530px; }
    #clinic #clinic-map #fukidashi-chugoku {
      top: 25px; }
    #clinic #clinic-map #fukidashi-tohoku {
      top: 15px; }
  #clinic #tokai {
    width: 175px !important; }
    #clinic #tokai .clinic-area {
      justify-content: center !important; }
      #clinic #tokai .clinic-area div {
        width: 100% !important; }
  #clinic #fukidashi-tokai {
    left: 172px !important; }
  #clinic .map iframe {
    max-height: 250px; }
  #clinic .name,
  #clinic .number {
    color: #ed7c6a !important;
    font-weight: bold; }
  #clinic .-freetelcolor {
    fill: #ed7c6a !important; }
  #clinic .address {
    font-size: 18px;
    margin-bottom: 10px !important; }

@media (max-width: 979px) {
  #clinic {
    padding: 35px 0 0; }
    #clinic .address {
      font-size: 16px; }
    #clinic .name {
      font-size: 22px; }
    #clinic .freetel {
      width: 40px;
      height: 40px; }
    #clinic .number {
      font-size: 2.8rem; } }

.topconference {
  padding: 70px 0;
  background: #fff4e5; }
  .topconference h2 {
    font-size: 36px; }
  .topconference table.conf_table {
    margin: 20px 0; }
    .topconference table.conf_table tr th {
      font-weight: bold;
      background-color: #ffebcc;
      width: 20%; }
    .topconference table.conf_table tr td p.title {
      color: #ed7c6a;
      font-weight: bold;
      font-size: 20px;
      margin-bottom: 3px; }
    .topconference table.conf_table tr td p.cont {
      margin-top: 10px;
      font-size: 18px; }

@media screen and (max-width: 979px) {
  .topconference {
    padding: 40px 25px; }
    .topconference h2 {
      font-size: 24px; }
    .topconference table.conf_table {
      margin: 10px 0; }
      .topconference table.conf_table tr th,
      .topconference table.conf_table tr td {
        display: block;
        border-bottom: none !important;
        width: 100%; }
      .topconference table.conf_table tr:last-child td {
        border-bottom: 1px solid #c2c2c2 !important; }
      .topconference table.conf_table tr td p.title {
        font-size: 18px; }
      .topconference table.conf_table tr td p.cont {
        font-size: 16px; } }
