@charset 'utf-8';

/* ---------- common ---------- */
.att {
    font-size: 12px;
}

.dis_b {
    display: block;
}

.float_l {
    float: left;
}

.float_r {
    float: right;
}

.arrow_gray {
    position: relative;
    margin-bottom: 54px;
}

.arrow_gray::after {
    position: absolute;
    right: 0;
    bottom: -54px;
    left: 0;
    display: block;
    width: 186px;
    height: 54px;
    margin: 0 auto;
    background: url(/img/sb_hikari/arrow01.gif) no-repeat;
    content: "";
}

/* ---------- main ---------- */
#main {
    padding: 20px 0 40px;
    background-color: #eee;
}

#main ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    justify-content: space-between;
    box-sizing: border-box;
    width: 960px;
    margin: 0 auto;
    padding: 10px 30px 20px;
    background-color: #d4f5ff;
}

/* ---------- contents ---------- */
.about {
    position: relative;
    width: 960px;
    margin: 140px auto 110px;
    background-color: #fffef0;
    border: 2px solid #f3f1d8;
}

.about::before {
    position: absolute;
    bottom: -56px;
    left: 50%;
    z-index: 1;
    display: block;
    width: 0;
    border: 55px solid transparent;
    border-top-color: #fffef0;
    border-right-width: 90px;
    border-bottom-width: 2px;
    border-left-width: 90px;
    -webkit-transform: translateY(0) translateX(-50%);
    transform: translateY(0) translateX(-50%);
    content: "";
}

.about::after {
    position: absolute;
    bottom: -57px;
    left: 50%;
    display: block;
    width: 0;
    border: 55px solid transparent;
    border-top-color: #f3f1d8;
    border-right-width: 90px;
    border-bottom-width: 0;
    border-left-width: 90px;
    -webkit-transform: translateY(0) translateX(-50%);
    transform: translateY(0) translateX(-50%);
    content: "";
}

.about h2 {
    position: relative;
    padding: 40px 0 40px 0;
    text-indent: 120px;
    background: url(/img/sb_hikari/icon_about.gif) no-repeat 30px center;
}

.about h2::after {
    position: absolute;
    bottom: -6px;
    left: -1px;
    display: block;
    width: 962px;
    height: 6px;
    background-color: #ffe200;
    content: "";
}

.about .about_inner {
    padding: 30px 38px 60px;
}

.about .about_inner img {
    float: left;
    margin-right: 25px;
}

.about .about_inner p {
    padding-left: 355px;
}

.merit.arrow_gray {
    margin-bottom: 270px;
    padding-bottom: 55px;
}

.merit h2 {
    border-bottom: 6px solid #19479d;
}

.merit ul {
    width: 880px;
    margin-right: auto;
    margin-left: auto;
    padding: 45px 40px 0;
    background-color: #fbfbfb;
}

.merit li h3 {
    padding-bottom: 12px;
}

.merit li p {
    padding: 30px 0;
    font-size: 18px;
}

.tokuten {
    background-color: #f2fcff;
    border-top: 6px solid #004e9a;
}

.tokuten h2 {
    margin-top: -206px;
    margin-bottom: 40px;
}

.tokuten h3 {
    margin: 10px 0 20px;
}

.tokuten .att {
    padding-left: 3em;
    text-indent: -3em;
}

.tokuten .att.mb50 {
    padding-left: 1em;
    text-indent: -1em;
}

.tokuten_box {
    position: relative;
    margin: 0 60px 20px;
    padding: 58px 38px 28px;
    border: 2px solid #d4f5ff;
}

.tokuten_box::before {
    position: absolute;
    top: -2px;
    left: -2px;
    width: 0;
    height: 0;
    border-color: #d4f5ff transparent transparent transparent;
    border-style: solid;
    border-width: 67px 67px 0 0;
    content: "";
}

.tokuten_box01 {
    background-image: url(/img/sb_hikari/tokuten01_bg.png),
        url(/img/sb_hikari/pattern_houganshi.png);
    background-repeat: no-repeat, repeat;
    background-position: top right, top left;
}

.tokuten_box02 {
    padding: 38px 38px 28px;
    background-image: url(/img/sb_hikari/tokuten02_bg.png),
        url(/img/sb_hikari/pattern_houganshi.png);
    background-repeat: no-repeat, repeat;
    background-position: bottom right, top left;
}

.otoku {
    margin-top: 90px;
}

.otoku h2 {
    padding-bottom: 10px;
}

.otoku_inner {
    width: 800px;
    margin: 0 auto;
    padding: 0 80px 35px;
    background-color: #fbfbfb;
    border-top: 6px solid #004e9a;
}

#obi {
    width: 100%;
    background-color: #e6f4f9;
}

#feature {
    padding: 40px 0;
    background-color: #f8f8f8;
}

#feature > ol {
    box-sizing: border-box;
    width: 900px;
    margin: 0 auto;
}

#feature > ol > li:not(:last-of-type) {
    margin-bottom: 60px;
}

#feature h3 {
    position: relative;
    padding: 25px 0;
    background-color: #19479d;
    border-radius: 8px 8px 0 0;
}

#feature h3::before {
    position: absolute;
    bottom: -26px;
    left: 50%;
    z-index: 1;
    display: block;
    width: 0;
    border: 26px solid transparent;
    border-top-color: #19479d;
    border-right-width: 23px;
    border-bottom-width: 2px;
    border-left-width: 23px;
    -webkit-transform: translateY(0) translateX(-50%);
    transform: translateY(0) translateX(-50%);
    content: "";
}

#feature .feature_box {
    box-sizing: border-box;
    padding: 45px 40px 40px;
}

#feature ol > li {
    box-sizing: border-box;
    background: url(/img/sb_hikari/pattern_houganshi.png) repeat;
    border: 2px solid #efefef;
    border-radius: 10px;
}

#feature ol > li:nth-of-type(1) .feature_box {
    background: url(/img/sb_hikari/bg_feature01.png) no-repeat top left;
}

#feature .feature_box .feature_txt {
    padding-left: 360px;
}

#feature .att {
    padding-left: 1em;
    text-indent: -1em;
}

#feature .pricebox > dt {
    margin-bottom: 50px;
    padding: 8px 0 8px 17px;
    font-weight: bold;
    font-size: 30px;
    border-bottom: 1px dotted #999;
    border-left: 8px solid #064d79;
}

#feature .pricebox > dd:nth-of-type(2) {
    position: relative;
    margin: 80px 0 0;
    padding: 48px 38px;
    background-color: #fff;
    border: 1px solid #ddd;
}

#feature .pricebox > dd:nth-of-type(2)::before {
    position: absolute;
    top: -50px;
    left: 285px;
    display: block;
    width: 0;
    height: 0;
    border-color: transparent transparent #ddd transparent;
    border-style: solid;
    border-width: 0 22px 50px 22px;
    content: "";
}

#feature .pricebox > dd:nth-of-type(2)::after {
    position: absolute;
    top: -47px;
    left: 285px;
    display: block;
    width: 0;
    height: 0;
    border-color: transparent transparent #fff transparent;
    border-style: solid;
    border-width: 0 22px 50px 22px;
    content: "";
}

#feature .box table {
    box-sizing: border-box;
    width: 740px;
    margin-right: auto;
    margin-left: auto;
    border-spacing: 0;
}

#feature #price1 table th {
    box-sizing: border-box;
    width: 50%;
    height: 62px;
    color: #333;
    font-weight: bold;
    font-size: 28px;
    line-height: 1;
    text-align: center;
    vertical-align: middle;
    background-color: #f2fcff;
}

#feature .box tbody tr {
    border: 1px solid #e5e5e5;
}

#feature .box tbody th,
#feature .box tbody td {
    padding: 20px 10px;
    vertical-align: middle;
}

#feature .box tbody td.price_cell {
    color: #d30000;
    font-weight: bold;
    font-size: 30px;
}

#feature .box tbody td.price_cell span {
    font-size: 54px;
}

#feature .box tbody th:first-child,
#feature .box tbody td:first-child {
    border-right: 1px solid #e5e5e5;
}

#feature #price2 tbody th {
    width: 340px;
    padding: 20px;
    font-weight: bold;
    font-size: 18px;
    line-height: 1.4;
    vertical-align: middle;
    background-color: #f2fcff;
}

#feature #price2 tbody .blue_txt {
    display: block;
    color: #19479d;
    background: url(data:image/gif;base64,R0lGODlhAQABAPAAABlHnQAAACH5BAAAAAAALAAAAAABAAEAAAICRAEAOw==)
        repeat-x center center;
}

#feature #price2 tbody .blue_txt span {
    padding: 0 10px;
    background: #f2fcff;
}

#feature #price2 tbody td {
    font-weight: bold;
    font-size: 18px;
    line-height: 1;
    vertical-align: middle;
    border-right: 1px solid #e5e5e5;
}

#feature #price2 tbody td.large {
    color: #333;
    font-size: 26px;
}

#feature #price2 tbody td.prl12 {
    width: 220px;
}

#feature #price2 tbody td.prl10 {
    padding-right: 10px;
    padding-left: 10px;
    white-space: nowrap;
}

#feature .box .fs12 {
    font-weight: normal;
    font-size: 12px;
    line-height: 1.2;
}

#feature .box .ptb20 {
    padding: 20px 0;
}

#feature #price3 .txt {
    padding: 20px;
    font-size: 16px;
    line-height: 1.4;
}

#feature #price3 .sst {
    padding: 12px 0;
    color: #fff;
    font-weight: bold;
    font-size: 22px;
    line-height: 1.4;
    text-align: center;
    background-color: #f2fcff;
}

#feature #price3 .w800 {
    width: 800px;
    margin-right: auto;
    margin-left: auto;
}

#feature #price3 table {
}

#feature #price3 tbody th {
    width: 42.5%;
    font-weight: bold;
    font-size: 18px;
    line-height: 1.4;
    text-align: center;
    background-color: #f2fcff;
}

#feature #price3 tbody td {
    line-height: 1;
}

#feature #price3 ul {
    width: 740px;
    margin: 0 auto;
}

#feature #price3 li {
    float: left;
    margin-bottom: 20px;
}

#feature #price3 li:nth-child(odd) {
    margin-right: 20px;
}

.feature_box02 dd {
    float: left;
}

.feature_box02 dd:last-child {
    float: right;
}

.stepbox ul {
    margin-top: -25px;
    padding: 38px 13px;
    background-color: #fff;
    border: 1px solid #d3d3d3;
}

.stepbox li {
    float: left;
}

.stepbox li:nth-child(n + 2):nth-child(-n + 3) {
    margin-left: -5px;
}

.stepbox li:last-child {
    margin-top: 18px;
    margin-left: 12px;
}

.feature_box03 .att {
    padding-left: 2em !important;
    text-indent: -2em !important;
}

#flow {
    padding-top: 45px;
}

#flow ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    justify-content: space-between;
    box-sizing: border-box;
    width: 960px;
    margin: 0 auto 10px;
    padding: 45px 21px;
    background-color: #f5f5f5;
    border-top: 6px solid #19479d;
}

#flow ul li {
    position: relative;
}

#flow ul li::after {
    position: absolute;
    top: 0;
    right: -28px;
    bottom: 0;
    display: block;
    width: 20px;
    height: 31px;
    margin: auto 0;
    background: url(/img/sb_hikari/arrow_l.gif) no-repeat;
    content: "";
}

#flow ul li:nth-child(2)::after {
    right: -20px;
}

#flow ul li:last-child::after {
    content: none;
}

.t_price {
    padding-bottom: 15px;
    color: #19479d;
    font-weight: bold;
    font-size: 32px;
    line-height: 1;
    background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAFCAMAAABLuo1aAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAABtQTFRF////ra2t6enp9PT01NTUw8PDs7OzycnJ+fn58KVJfAAAACtJREFUeNpiYGBgYmaAAnZGNiYIi4mRkZEVwmRmY2RkgSpgYmXhADMAAgwABpEAQpUo0tUAAAAASUVORK5CYII=)
        repeat-x left bottom;
}

.ts_price {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    color: #333;
    font-weight: bold;
    font-size: 26px;
    line-height: 1;
}

.ts_price::before,
.ts_price::after {
    width: 37px;
    height: 32px;
    background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABEAAAAgCAMAAADDlWPAAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAHtQTFRF////S0tLTExMU1NTmJiYXV1d4eHh0tLS+/v79PT0p6en19fX/Pz88fHxaWlpvb29kpKSfX19zc3N/v7+bm5ug4OD5ubmYGBg3NzcsbGxhYWFUVFRra2twsLCiIiITk5OqampuLi4u7u7goKCcXFxb29v6OjogICA6urqMcrofAAAAJFJREFUeNpkzscWgkAUBNGpASSI5CBBMOv/f6Fu+7xe3tOLcu48H51s8mwqB8/+VaohVGkgSEXaAlY93WDMRZIILnrK4KlyWiBWqqA3lX5Q+pjK2FS6Dq4qJUSJqSxNZaeSBqYyhIfK8K88KPVQmcrlpPSCTOViKvMR7npaoWhNZWMqa5X3bio3/KRynM/uJ8AAgNIFw+8FsUgAAAAASUVORK5CYII=)
        no-repeat;
    content: "";
}

.ts_price::after {
    -webkit-transform: scale(-1, 1);
    -moz-transform: scale(-1, 1);
    -ms-transform: scale(-1, 1);
    -o-transform: scale(-1, 1);
    transform: scale(-1, 1);
}

/*
--------------------------------------------------------------------------------
 END OF CSS
--------------------------------------------------------------------------------
*/
