@charset "utf-8";

/*------------------------------------------------------------------------------
  reset
------------------------------------------------------------------------------*/

html {
  font-size: 18px;
}

body {
  position: static;
}

#wrapper,
.outer-block {
  min-width: 1260px;
}

.inner-block {
  padding-left: 0;
  padding-right: 0;
  width: 1200px;
}

main .inner-block {
  padding: 100px 0;
}

.pc {
  display: block !important;
}

.pc-ib {
  display: inline-block !important;
}

.sp {
  display: none !important;
}

.sp-ib {
  display: none !important;
}

.sp-link {
  display: inline-block;
  pointer-events: none;
}


/* transition
----------------------------------------*/

a,
a::before,
a::after,
button,
button::before,
button::after,
.case-price-list .btn,
.question {
  -webkit-transition: .2s ease-in-out;
  transition: .2s ease-in-out;
  -webkit-transition-property: background-image, background-position, background-color, box-shadow, border, color, fill, top, bottom, right, left, text-shadow, transform, opacity, padding;
  transition-property: background-image, background-position, background-color, box-shadow, border, color, fill, top, bottom, right, left, text-shadow, transform, opacity, padding;
}

/*------------------------------------------------------------------------------
common-parts
------------------------------------------------------------------------------*/

/* title
----------------------------------------*/

.c-ttl-center {
  margin-bottom: 60px;
}

.c-ttl01 {
  margin-bottom: 50px;
}

.c-ttl01 .inn {
  font-size: 50px;
  padding-bottom: 30px;
}

.c-ttl01 .inn::before {
  height: 2px;
}

.c-ttl02 {
  font-size: 31px;
  margin-bottom: 40px;
}

/* text
----------------------------------------*/

.c-txt {
  font-size: 22px;
  margin: 60px 0;
  line-height: 2;
  text-align: center;
}

.c-txt + .c-txt {
  margin-top: -40px;
}

[class*=c-note] {
  font-size: 12px;
  text-align: center;
}

.c-txt + [class*=c-note] {
  margin-top: -30px;
}

.graph-box + [class*=c-note] {
  margin-top: -40px;
}

/* button
----------------------------------------*/

.btn-area .inner-block {
  padding: 25px 0;
}

.btn-area .c-btn01 + .c-btn01 {
  margin-left: 20px;
}

.c-btn01 {
  border-radius: 8px;
  padding: 0 40px 0 100px;
  height: 110px;
}

.c-btn01::before {
  width: 52px;
  height: 52px;
}

.c-btn01.document {
  box-shadow: 0px 4px 8px 0px rgba(0, 0, 0, 0.3),inset 0px -8px 16px 0px rgba(98, 157, 23, 0.004),inset 0px 8px 16px 0px rgba(107, 172, 25, 0.004);
  width: 300px;
}

.c-btn01.simulation {
  box-shadow: 0px 4px 8px 0px rgba(0, 0, 0, 0.3),inset 0px -8px 16px 0px rgba(225, 129, 2, 0.004),inset 0px 8px 16px 0px rgba(240, 137, 1, 0.004);
  width: 360px;
}

.c-btn01:hover {
  transform: translateY(2px);
}

.c-btn01.document:hover {
  background-color: #539400;
}

.c-btn01.simulation:hover {
  background-color: #e86c00;
}

/*------------------------------------------------------------------------------
header
------------------------------------------------------------------------------*/

.header .logo {
  justify-content: space-between;
  height: 80px;
}

.header .logo .img01 {
  height: 42px;
  margin-right: 24px;
}

.header .logo .img02 {
  height: 34px;
}

.btn-menu {
  display: none;
}


/*------------------------------------------------------------------------------
nav
------------------------------------------------------------------------------*/

.nav {
  border-bottom: 2px solid #efebdd;
}

.nav .inner {
  margin: auto;
  width: 1200px;
}

.nav-list {
  display: flex;
}

.nav-list li {
  flex: 1;
}

.nav-list li a {
  color: #66a417;
  display: block;
  font-size: 15px;
  font-weight: bold;
  line-height: 65px;
  text-align: center;
}

.nav-list li a:hover {
  color: #e88502;
}

/*------------------------------------------------------------------------------
footer
------------------------------------------------------------------------------*/

.footer .company .inner-block {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 40px;
  padding-bottom: 40px;
}

.footer .company .group {
  font-size: 0;
  margin: 30px 0;
}

.footer .company .group img {
  width: 440px;
}

.footer .company .tel a {
  font-size: 30px;
  line-height: 34px;
  padding-left: 68px;
}

.footer .company .tel .small {
  font-size: 12px;
  margin-top: 12px;
}

.footer .sitemap .inner-block {
  padding-top: 30px;
  padding-bottom: 30px;
}

.footer .sitemap ul {
  text-align: center;
}

.footer .sitemap li {
  font-size: 14px;
  margin-top: 0;
}

.footer .sitemap li + li {
  border-left: 1px solid #444;
  margin-left: 0.8em;
  padding-left: 0.8em;
}

.footer .sitemap li a:hover {
  text-decoration: underline;
}

.footer .sitemap .copyright {
  font-size: 12px;
  margin-top: 20px;
}

/* pagetop
----------------------------------------*/

#pagetop {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 97;
}

#pagetop a {
  background-size: 18px auto;
  width: 60px;
  height: 60px;
}

#pagetop a:hover {
  opacity: 1;
}


/*------------------------------------------------------------------------------
main-visual
------------------------------------------------------------------------------*/

.main-visual {
  background-image: url(../img/mv/bg_pc.jpg);
}

.main-visual .ttl {
  padding: 60px 0 32px 100px;
}

.main-visual .img {
  bottom: -30px;
  left: 60px;
}

.main-visual + .btn-area {
  position: relative;
  z-index: 1;
}

.main-visual + .btn-area .inner-block {
  text-align: right;
}

.main-visual + .btn-area .c-btn01:last-child {
  margin-left: 20px;
}

/*.main-visual + .btn-area .vets {
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 60px;
  height: 130px;
}*/

/*.main-visual + .btn-area .vets img {
  height: 130px;
}*/

/*------------------------------------------------------------------------------
thought
------------------------------------------------------------------------------*/

.thought .inner-block {
  padding-bottom: 130px;
}

.thought .txt img {
  width: 580px;
}

/*------------------------------------------------------------------------------
recommend
------------------------------------------------------------------------------*/

.recommend {
  margin-bottom: 60px;
}
.recommend::before {
  top: -50px;
  border-width: 0 80px 50px 80px;
}

.recommend .inner-block {
  padding-top: 60px;
  padding-bottom: 60px;
}

.recommend .vets,
.recommend .doctor {
  display: flex;
  margin: auto;
  width: 900px;
}

.recommend .vets {
  align-items: center;
}

.recommend .vets .img {
  margin: 0;
  text-align: center;
  width: 320px;
}

.recommend .vets .img img {
  width: 210px;
}

.recommend .vets .txt {
  font-size: 18px;
  margin-top: 40px;
}
.recommend .vets .txt-op {
  font-size: 12px;
  text-align: right;
  margin-top: 20px;
}

.recommend .vets .txt-op .logo {
  width: 76px;
}

.recommend .doctor {
  margin-top: 40px;
  padding: 30px 60px;
}

.recommend .doctor .img {
  width: 200px;
  height: 200px;
}

.recommend .doctor .txt-wrap {
  padding: 20px 0 0 60px;
  width: calc(100% - 200px);
}

.recommend .doctor .point li {
  font-size: inherit;
  margin: 0 10px 10px 0;
}

.recommend .doctor .txt {
  font-size: 24px;
  margin-bottom: 20px;
}

.recommend .doctor .txt.txt-base {
  font-size: inherit;
}

.recommend .doctor .info {
  font-size: 18px;
}

.recommend .doctor .info .large {
  font-size: 24px;
}

/*------------------------------------------------------------------------------
banner-price
------------------------------------------------------------------------------*/

.banner-price .inner-block {
  padding-top: 60px;
  padding-bottom: 40px;
}

.banner-price .box {
  border-width: 12px;
  margin: auto;
  padding: 48px 58px 48px 78px;
  position: relative;
  text-align: left;
  width: 900px;
}

.banner-price .ttl {
  font-size: 32px;
  margin-bottom: 15px;
}

.banner-price .price {
  font-size: 64px;
}

.banner-price .price .small {
  font-size: 40px;
}

.banner-price .type {
  font-size: 18px;
  margin: 12px 0 0;
}

.banner-price .btn {
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 60px;
  height: 110px;
}

/*------------------------------------------------------------------------------
features
------------------------------------------------------------------------------*/

.features-list {
  margin: 40px 0;
}

.features-list li {
  width: 285px;
}

.features .txt:first-child {
  text-align: left;
}

.features .txt:last-child {
  text-align: right;
}

.features-list li a {
  border-width: 2px;
}

.features-list li a:hover {
  border-color: #e88502;
}

/*------------------------------------------------------------------------------
feature
------------------------------------------------------------------------------*/

.feature01 .inner-block {
  padding-bottom: 0;
}

.feature01 .graph-box,
.feature01 .table-ttl,
.feature01 .c-table {
  margin-right: auto;
  margin-left: auto;
  width: 700px;
}

/* title
----------------------------------------*/

.feature-ttl {
  margin-bottom: 50px;
}

.feature-ttl .inn {
  margin-left: 0;
  padding-left: 0;
  padding-bottom: 20px;
}

.feature-ttl .inn::before {
  height: 2px;
}

.feature-ttl .num {
  font-size: 36px;
  line-height: 80px;
  margin-right: 30px;
  width: 80px;
  height: 80px;
}

.feature-ttl .txt {
  font-size: 36px;
}

.feature-ttl .txt strong {
  font-size: 50px;
}

.feature-check,
.feature-check-slim {
  margin-bottom: 80px;
}

.feature-check .main,
.feature-check-slim .main {
  font-size: 50px;
}

.feature-check .sub {
  font-size: 26px;
  margin-bottom: 20px;
}

.feature-check-slim .sub {
  margin-bottom: 24px;
}

.c-marker::before {
  bottom: -6px;
  height: 20px;
}

/* graph-box
----------------------------------------*/

.graph-box {
  border-width: 2px;
  border-radius: 8px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 80px auto 50px;
  padding: 0 40px 40px;
}
.graph-box > * {
  width: 100%;
}
.graph-box .graph-type {
  margin: -24px 0 40px;
}
.graph-box .graph-type .inn {
  font-size: 26px;
  line-height: 46px;
  padding: 0 16px;
}
.graph-box .graph-type .inn::before {
  left: -20px;
  border-width: 23px 20px 23px 0;
}
.graph-box .graph-type .inn::after {
  right: -20px;
  border-width: 23px 0 23px 20px;
}

.graph-box .box {
  position: relative;
  width: calc(50% - 50px);
}

.graph-box .box + .box::before {
  background: #444;
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -50px;
  width: 2px;
  height: 100%;
}

.graph-box.slim .box + .box::before {
  background: #3e7224;
}

.graph-box .graph-ttl {
  font-size: 26px;
  margin: -10px 0 40px;
}

.graph-box .balloon {
  font-size: 20px;
  padding: 24px 16px;
}

.graph-box .balloon .inn {
  font-size: 14px;
  padding: 10px 20px;
}

/* table
----------------------------------------*/

.table-ttl {
  font-size: 24px;
  margin: 50px auto 20px;
  padding-left: 20px;
}
.table-ttl::before {
  border-radius: 6px;
  width: 6px;
}

.c-table {
  border-width: 2px;
  font-size: 18px;
}

.c-table th {
  padding: 16px;
}

.c-table td {
  padding: 16px;
}

.c-table th .small,
.c-table td .small {
  font-size: 13px;
}

.c-table th:first-child .small {
  margin: 0 0 0 1.2em;
}

.c-table thead th:first-child,
.c-table tbody th {
  padding-left: 20px;
  text-align: left;
}

.c-table thead th:last-child,
.c-table tbody td:last-child {
  padding-right: 20px;
}

/* doctor-recommend
----------------------------------------*/

.doctor-recommend .read-more {
  display: none;
}

.doctor-recommend {
  margin: 100px 0 0;
  padding: 50px;
}

.doctor-recommend .img-wrap {
  width: 150px;
}

.doctor-recommend .img {
  width: 150px;
  height: 150px;
}

.doctor-recommend .info {
  font-size: 16px;
}

.doctor-recommend .info .large {
  font-size: 20px;
}

.doctor-recommend .txt-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-left: 0;
  padding: 0 0 0 50px;
  width: calc(100% - 150px);
}

.doctor-recommend .txt {
  font-size: 16px;
}

/* support-list
----------------------------------------*/

.support-list {
  display: flex;
  justify-content: space-between;
}

.support-list li {
  flex: 1;
}

.support-list li + li {
  margin-left: 40px;
}

.support-list li .img {
  margin: auto;
  width: 200px;
  height: 200px;
}

.support-list li .img::before {
  border-width: 12px;
}

.support-list li .ttl {
  font-size: 28px;
  margin-top: 20px;
  margin-bottom: 20px;
  text-align: center;
}

.support-list li .txt {
  font-size: 18px;
}

/* caution-box
----------------------------------------*/

.caution-ttl {
  margin-bottom: 32px;
}

.caution-ttl .inn {
  background-size: auto 48px;
  font-size: 24px;
  line-height: 48px;
  padding-left: 70px;
}

.c-txt + .caution-ttl {
  margin-top: 100px;
}

.caution-ttl + .graph-box {
  margin-top: 60px;
}

.caution-box {
  border-width: 2px;
  border-radius: 8px;
  font-size: 16px;
  margin-top: 80px;
  padding: 0 50px 30px;
}

.caution-box .caution-ttl {
  margin-top: -26px;
}

.caution-box .caution-ttl .inn {
  padding-left: 85px;
}

/* column-wrap
----------------------------------------*/

.column-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.column-wrap .img {
  width: 600px;
}

.column-wrap .c-txt {
  font-size: 18px;
  padding-left: 60px;
  text-align: left;
  width: calc(100% - 600px);
}

/*------------------------------------------------------------------------------
plan
------------------------------------------------------------------------------*/

.plan-table {
  margin-top: 50px;
}

.plan-table th,
.plan-table td {
  border-width: 2px 0 0 2px;
}

.plan-table th:last-child,
.plan-table td:last-child {
  border-right-width: 2px;
}

.plan-table tr:last-child th,
.plan-table tr:last-child td {
  border-bottom-width: 2px;
}

.plan-table th {
  font-size: 20px;
  padding: 12px 20px;
}

.plan-table td {
  font-size: 28px;
  padding: 20px 32px;
}

.plan-table th .small {
  font-size: 16px;
  display: inline-block;
}

.plan-table td .small {
  font-size: 22px;
}

.plan-table thead th {
  padding: 20px;
}

.plan-table thead th .large {
  font-size: 32px;
}

.plan-table .plan-point {
  font-size: 28px;
  padding-left: 68px;
}

.sample-ttl {
  margin-top: 100px;
}

.sample-subttl {
  margin: 30px 0;
}

.sample-subttl .inn {
  border-width: 2px;
  font-size: 20px;
  line-height: 40px;
  padding: 0 24px;
}

.sample-list li {
  padding: 50px 120px 40px 50px;
  width: calc(50% - 20px);
}

.sample-list li:nth-child(n+3) {
  margin-top: 40px;
}

.sample-list li .txt02 {
  margin-top: 24px;
}

.sample-list li .type {
  font-size: 26px;
  margin-right: 20px;
}

.sample-list li .age {
  font-size: 20px;
  display: inline-block;
}

.sample-list li .price {
  font-size: 36px;
  margin-right: 20px;
}

.sample-list li .price .small {
  font-size: 26px;
}

.sample-list li .plan {
  font-size: 16px;
  display: inline-block;
}

.sample-list li .img {
  right: 50px;
  top: 50%;
  transform: translateY(-50%);
}


/*------------------------------------------------------------------------------
case
------------------------------------------------------------------------------*/

.case-plan {
  margin: -10px 0 50px;
}

.case-plan .inn {
  border-width: 2px;
  font-size: 20px;
  line-height: 46px;
  padding: 0 24px;
}

.case-plan .inn .large {
  font-size: 24px;
}

.case-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.case-list > li {
  border-top-width: 4px;
  padding: 0 30px 50px;
  width: calc(50% - 20px);
}

.case-list > li:nth-child(n+3) {
  margin-top: 60px;
}

.case-list .num {
  font-size: 36px;
  line-height: 80px;
  top: -40px;
  width: 80px;
  height: 80px;
}

.case-list .img {
  margin: 0 -30px 25px;
}

.case-list .info .type {
  font-size: 24px;
}

.case-list .info .age {
  font-size: 16px;
}

.case-list .txt {
  margin: 12px 0 20px;
}

.case-price-list {
  margin-bottom: 50px;
}

.case-price-list .item {
  font-size: 16px;
}

.case-price-list .item .content {
  font-size: 14px;
}

.case-price-list .item.total .price,
.case-price-list .item.total02 .price {
  font-size: 20px;
}

.case-price-list .btn {
  font-size: 16px;
  line-height: 40px;
}

.case-price-list .btn::before,
.case-price-list .btn::after {
  right: 20px;
  width: 16px;
  height: 2px;
}

.case-price-list .btn:hover {
  background-color: #c3bfb1;
}

.case-list .price-wrap {
  display: flex;
  justify-content: center;
}

.case-list .price01,
.case-list .price02 {
  display: inline-block;
}

.case-list .price01 {
  padding-right: 60px;
  position: relative;
}

.case-list .price01::after {
  background: url(../img/ico_equal.svg) no-repeat center center / contain;
  content: "";
  display: block;
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 22px;
  transform: rotate(90deg);
  width: 10px;
  height: 15px;
}

/*------------------------------------------------------------------------------
caution
------------------------------------------------------------------------------*/

.caution .graph-box {
  margin-left: auto;
  margin-right: auto;
  width: 700px;
}

/*------------------------------------------------------------------------------
point
------------------------------------------------------------------------------*/

/* support-list
----------------------------------------*/

.point-list {
  display: flex;
  justify-content: space-between;
}

.point-list li {
  flex: 1;
}

.point-list li + li {
  margin-left: 40px;
}

.point-list li .img {
  margin: auto;
  width: 200px;
  height: 200px;
}

.point-list li .img::before {
  border-width: 12px;
}

.point-list li .ttl {
  font-size: 28px;
  margin-top: 20px;
  margin-bottom: 20px;
  text-align: center;
}

.point-list li .txt {
  font-size: 18px;
}

.point-list li .c-note {
  text-align: left;
}

/*------------------------------------------------------------------------------
about
------------------------------------------------------------------------------*/


/*------------------------------------------------------------------------------
group
------------------------------------------------------------------------------*/

.group .img-box.parent {
  margin-top: 40px;
  padding-bottom: 40px;
}

.group .img-box.parent::after {
  width: 2px;
  height: 30px;
}

.group .graph-box {
  margin: 20px auto 30px;
  padding: 0 18px 20px;
  width: 700px;
}

.group .graph-box .graph-type {
  margin-bottom: 20px;
}


/*------------------------------------------------------------------------------
faq
------------------------------------------------------------------------------*/
.question {
  padding-left: 35px;
  cursor: pointer;
}

.question:hover {
  color: #e88502;
}

.answer {
  font-size: 16px;
  padding-left: 35px;
}

.question::before {
  background-size: 18px 20px;
  height: 20px;
  width: 18px;
}

.answer::before {
  background-size: 18px 18px;
  height: 18px;
  width: 18px;
  top: 5px;
}

.question .aco-btn {
  width: 25px;
  height: 25px;
}
.question .aco-btn::before,
.question .aco-btn::after {
  width: 13px;
}

/*------------------------------------------------------------------------------
enroll
------------------------------------------------------------------------------*/
.enroll dd,
.enroll .list-num li .txt:before {
  font-size: 16px;
}

.enroll dt {
  padding: 10px 15px;
}

.enroll dd {
  padding: 20px 15px;
}

.enroll dd .note {
  font-size: 13px;
}

/*------------------------------------------------------------------------------
print
------------------------------------------------------------------------------*/

@media print {

  #footer,
  #pagetop,
  #nav {
    display: none !important;
  }
}

/*------------------------------------------------------------------------------
clearfix
------------------------------------------------------------------------------*/

.clearfix:after,
.inner-block:after {
  clear: both;
  content: "";
  display: block;
  height: 0px;
  font-size: 0;
  visibility: hidden;
}

/* vets_badge */
.main-visual + .btn-area .vets {
  margin: auto;
}

.main-visual .vets {
  width: auto;
  flex-direction: column;
  padding: 0;
  position: absolute;
  right: 0;
  bottom: 40px;
}

.main-visual .vets img {
  width: revert-layer;
  margin-left: 0;
}

.main-visual .vets p {
  margin: 10px 0 0;
}