@charset "UTF-8";
/* CSS Document */
.contents {
  margin: 0 auto;
  font-family: 'Noto Sans JP', sans-serif;
}

.heading {
    font-size: 80px;
    font-weight: 600;
    line-height: 1.3;
    text-align: center;
    color: #0075c2;
    margin-bottom: 50px;
}

.heading span {
    font-size: 45px;
}

.heading span:last-child {
    color: #000;
}

section {
    width: 1024px;
    margin: 0 auto 50px;
    border-radius: 15px;
    padding: 10px;
}

.case_study_wapper {
    background-color: #4c9ed4;
}

.inner {
    background-color: #fff;
    border-radius: 15px;
    padding: 30px;
    box-shadow: 0 2.5rem 2rem -2rem rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.3s;
    position: relative;
}

.heading_h2 {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.case_study_wapper h2 {
    font-size: 50px;
    font-weight: 600;
    line-height: 1.0;
    color: #0075c2;
}

.sub_ttl {
    font-size: 30px;
    line-height: 1.0;
    color: #fff;
    padding: 8px 50px;
    margin-left: 20px;
    background-image: linear-gradient(90deg, rgba(255, 255, 255, 1), rgba(0, 160, 233, 1) 20% 80%, rgba(255, 255, 255, 1));
}

.case_study_wapper .heading_h2::before {
    position: absolute;
    top: -20px;
    left: -20px;
    content: "";
    display: inline-block;
    width: 211px;
    height: 144px;
    background: url(/attending/insurance/web/images/pc/bomb.png) no-repeat;
    background-size: contain;
}

.explanation h3 {
    font-size: 30px;
    margin: 30px 0 10px;
    text-align: center;
}

.txt {
    font-size: 18px;
}

.case_study {
    margin: 40px 0 0 15px;
    border: 5px solid #f39700;
    border-radius: 10px;
    padding: 15px 20px;
    display: flex;
    justify-content: space-between;
    gap: 20px;
    position: relative;
}

.case_study.green {
    border: 5px solid #8fc31f;
} 

.case_study.red {
    border: 5px solid #d0121b;
    margin-bottom: 20px;
} 

.case_study::before {
    position: absolute;
    top: -20px;
    left: -35px;
    content: "";
    display: inline-block;
    width: 156px;
    height: 62px;
    background: url(/attending/insurance/web/images/pc/case01.png) no-repeat;
    background-size: contain;
}

.case_study.green::before {
    background: url(/attending/insurance/web/images/pc/case02.png) no-repeat;
} 

.case_study.red::before {
    background: url(/attending/insurance/web/images/pc/case03.png) no-repeat;
} 

.left_block {
    width: 490px;
    position: relative;
}

.left_block::before {
    position: absolute;
    bottom: -15px;
    right: 0;
    content: "";
    display: inline-block;
    width: 175px;
    height: 94px;
    background: url(/attending/insurance/web/images/pc/ili_case01.png) no-repeat;
    background-size: contain;
}

.case_study.green .left_block::before {
    right: -22px;
    width: 75px;
    height: 145px;
    background: url(/attending/insurance/web/images/pc/ili_case02.png) no-repeat;
    background-size: contain;
}

.case_study.red .left_block::before {
    right: -40px;
    width: 84px;
    height: 141px;
    background: url(/attending/insurance/web/images/pc/ili_case03.png) no-repeat;
    background-size: contain;
}

.left_block dt {
    font-size: 25px;
    line-height: 1.2;
    color: #f39700;
    margin-bottom: 10px;
    margin-left: 110px;
}

.case_study.green .left_block dt {
    color: #8fc31f;
}

.case_study.red .left_block dt {
    color: #d0121b;
}

.left_block dt span {
    font-size: 20px;
}

.left_block dd {
    font-size: 17px;
}

.right_block dl {
    display: flex;
    justify-content: flex-start;
    align-items: center;
}


.right_block dl dt {
    font-size: 18px;
    line-height: 1.2;
    border-radius: 5px;
    padding: 5px;
    text-align: center;
    width: 90px;
    margin-right: 10px;
}

.right_block .kinds dt {
    color: #f39700;
    border: 2px solid #f39700;
}

.case_study.green .right_block .kinds dt  {
    color: #8fc31f;
    border: 2px solid #8fc31f;
}

.case_study.red .right_block .kinds dt  {
    color: #d0121b;
    border: 2px solid #d0121b;
}

.right_block .kinds dd {
    font-size: 18px;
}

.right_block .payment dt {
    color: #fff;
    background-color: #655d5b;
}

.right_block .payment dd {
    font-size: 40px;
    font-weight: 800;
}

.zurich_wapper {
    background-color: #9acf6b;
}

.zurich_wapper .heading_h2 {
    font-size: 50px;
    line-height: 1.0;
    font-weight: 800;
    color: #6fba2c;
}

.zurich_wapper .heading_h2::before {
    position: absolute;
    top: 10px;
    left: -15px;
    content: "";
    display: inline-block;
    width: 219px;
    height: 92px;
    background: url(/attending/insurance/web/images/pc/patch.png) no-repeat;
    background-size: contain;
}

.zurich_contents {
    margin-top: 40px;
}

.ribbon {
    position: relative;
}

.ribbon::before {
    position: absolute;
    bottom: 10px;
    left: 0;
    content: "";
    display: inline-block;
    width: 347px;
    height: 37px;
    background: url(/attending/insurance/web/images/pc/net.png) no-repeat;
    background-size: contain;
    transform: rotate(-3deg);
}

.ribbon dt {
    width: 383px;
    height: 56px;
    margin-left: -31px;
}

.ribbon dd {
    font-size: 25px;
    font-weight: 600;
}

.zurich_contents {
    display: flex;
    margin-bottom: 20px;
}

.example_block {
    padding: 15px;
    background-color: #fffab2;
    border-radius: 10px;
    width: 580px;
    margin-left: 12px;
}

.example_block h3 {
    font-size: 28px;
    line-height: 1.0;
    font-weight: 800;
    text-align: center;
    margin-bottom: 5px;
}

.example_block h3 span {
    color: #d0121b;
}

.example_block h3 strong {
    font-size: 35px;
}

.example_block .txt {
    text-align: center;
    margin-bottom: 10px;
}
.example {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.example dl dt {
    font-size: 17px;
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
    border-radius: 5px;
    background-color: #fff;
    padding: 5px;
    width: 105px;
    margin-bottom: 5px;
}

.example dl:nth-child(odd) dt {
    border: 3px solid #e5004f;
    color: #e5004f;
}

.example dl:nth-child(even) dt {
    border: 3px solid #eb6100;
    color: #eb6100;
}

.example dl dd {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
}

.example dl:nth-child(odd) dd {
    color: #e5004f;
}

.example dl:nth-child(even) dd {
    color: #eb6100;
}

.btn {
    display: block;
    width: 100%;
    font-size: 35px;
    font-weight: 600;
    line-height: 1.0;
    color: #fff;
    background-color: #eb6100;
    text-align: center;
    padding: 20px 0;
    border-radius: 10px;
    transition: opacity 0.3s;
    margin-bottom: 20px;
    cursor: pointer;
}

.btn:hover {
    opacity: 0.7;
} 

.banner {
    width: 1024px;
    height: 130px;
    font-size: 40px;
    font-weight: 700;
    line-height: 1.5;
    text-shadow: 0px 0px 15px rgba(0, 63, 194, 1);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: url(/attending/insurance/web/images/pc/BP19-125415D.png) no-repeat;
    background-size: contain;
}

.banner_wapper p {
    font-size: 30px;
    line-height: 1.0;
    text-align: center;
    color: #fff;
    background-color: #eb6100;
    padding: 10px 0;
    width: 1024px;
}

.compensation_wapper {
    position: relative;
    padding: 50px 30px 30px;
    background: #e9f0f9;
    box-shadow: inset 10px 20px 20px rgba(0,117,194,.5),
            inset -10px -20px 20px rgba(0,117,194,.5);
}

.compensation_wapper h2 {
    position: absolute;
    top: -15px;
    left: -10px;
}

.compensation_wapper dt {
    font-size: 25px;
    line-height: 1.4;
    color: #0075c2;
}

rt {
    color: #FF0000;
    font-size: 80%;
}

.compensation01 {
    position: relative;
    margin: 20px 0;
}

.compensation01::before {
    position: absolute;
    top: 0;
    left: -15px;
    content: "";
    display: inline-block;
    width: 164px;
    height: 188px;
    background: url(/attending/insurance/web/images/pc/compensation01.png) no-repeat;
    background-size: contain;
}

.compensation01 dt, .compensation01 dd {
    margin-left: 170px;
}

.compensation01 dd {
    margin-top: 10px;
    font-size: 18px;
}

.compensation01 span {
    font-size: 23px;
    font-weight: 700;
    padding: 0 0 0 10px;
    display: inline;
    background: linear-gradient(transparent 60%, #fff100 60%);
}

.compensation01_wapper figure {
    margin-top: 30px;
    width: 951px;
    height: auto;
}

.compensation01.no02, .compensation01.no03 {
    margin-top: 50px;
}

.compensation01.no02::before {
    width: 175px;
    height: 184px;
    background: url(/attending/insurance/web/images/pc/compensation02.png) no-repeat;
    background-size: contain;
}

.compensation01.no03::before {
    width: 163px;
    height: 184px;
    background: url(/attending/insurance/web/images/pc/compensation03.png) no-repeat;
    background-size: contain;
}

.zurich_wapper02 {
    background-color: #9acf6b;
    position: relative;
}

.zurich_wapper02 .heading_h2 {
    position: absolute;
    top: -30px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    font-size: 40px;
    line-height: 1.0;
    font-weight: 800;
    color: #fff;
    background-color: #6fba2c; 
    border-radius: 25px;
    padding: 5px 25px;
    width: 662px;
}

.zurich_contents02 {
    position: relative;
    margin-top: 20px;
}

.zurich_contents02::before {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    display: inline-block;
    width: 198px;
    height: 81px;
    background: url(/attending/insurance/web/images/pc/net2.png) no-repeat;
    background-size: contain;
    transform: rotate(-3deg);
}

.zurich_contents02 .btn {
    margin-left: 220px;
    width: auto;
}

.txt_wapper {
   width: 1024px;
    margin: 0 auto 30px;
}

.txt02 {
    text-align: center;
    font-size: 25px;
    margin-bottom: 30px;
}

.medium {
    text-align: right;
}

section.banner_wapper {
    padding: 0;
}

hr {
    width: 1024px;
    margin: 0 auto 50px;
}