@charset "utf-8";
@import "/css/reset.css";
/* ------------------------------------------------------------
     base
------------------------------------------------------------ */
body {
    font-size: 14px;
    line-height: 160%;
}
p {
    line-height: 1.6em;
}
ul {
    list-style: none;
}
img {
    vertical-align: baseline;
}
span.type01 {
    background: url(/img/pc/line01.png) repeat-x bottom;
}
span.type02 {
    background: url(/img/pc/line02.png) repeat-x left bottom -3px;
    color: #559a41;
}
span.type03 {
    font-size: 20px;
}
div.column {
    margin-bottom: 30px;
}

header#header {
    position: relative;
}
header#header div#description {
    background: url(/img/pc/header_back0.png);
}
header#header div#description h1 {
    color: #fff;
    font-size: 10px;
    font-weight: bold;
}
header#header nav {
    background: url(/img/pc/header_back02.png) repeat-x;
    height: 70px;
}
header#header nav div.container {
    padding-top: 10px;
}
header#header nav div.container div#siteId {
    left: -3px;
    position: relative;
}
header#header nav div.container div.number {
    background: url(/img/pc/number_back.png) no-repeat;
    background-size: contain;
    font-size: 24px;
    height: 34px;
    left: 280px;
    padding: 5px 0 0 45px;
    position: absolute;
    top: 10px;
    width: 235px;
}
header#header nav div.container div.mail {
    left: 563px;
    position: absolute;
    top: 8px;
    z-index: 2;
}
header#header nav div.container div.company {
    left: 673px;
    position: absolute;
    top: 8px;
    z-index: 2;
}

#footer {
    background: url(/img/pc/footer_back.png);
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    margin-top: 1px;
    padding: 20px 0;
    text-align: center;
}
#footer p {
    margin-bottom: 5px;
}
#footer p:nth-child(2) {
    font-size: 11px;
}
#footer p:last-child {
    margin: 0;
}
#footer a {
    color: #fff;
    text-decoration: underline;
}

aside.contact {
    background: url(/img/pc/contact_back.png) repeat-x bottom;
    background-size: contain;
    height: 260px;
}
aside.contact div.container {
    background: url(/img/pc/contact.png);
    height: 240px;
    width: 1040px;
}
aside.contact div.container div.number {
    font-size: 80px;
    left: 170px;
    position: absolute;
    top: 145px;
}
aside.contact div.container div.mail {
    left: 749px;
    position: absolute;
    top: 118px;
}

.container {
    margin: 0 auto;
    position: relative;
    width: 940px;
}
.number {
    color: #f05548;
    font-family: "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: bold;
    letter-spacing: -.05em;
}
/* ------------------------------------------------------------
     content
------------------------------------------------------------ */
section#main {
    background: url(/img/pc/main_back01.png) repeat-x;
    margin-bottom: 50px;
}
section#main div#view {
    background: url(/img/pc/main_back02.png) no-repeat center top;
    width: 1140px;
}
section#main h2 {
    margin: 0 auto;
    padding-top: 20px;
    position: relative;
    width: 1000px;
    z-index: 1;
}
section#main div#point {
    position: absolute;
    right: 30px;
    top: -60px;
    z-index: 0;
}
section#main div#reason {
    width: 1040px;
}
section#main div#reason div.number {
    font-size: 68px;
    left: 215px;
    position: absolute;
    top: 952px;
}
section#main div#reason div.mail {
    left: 703px;
    position: absolute;
    top: 934px;
}
section#main.location {
}
section#main.location h2 {
    padding-top: 20px;
}
section#main.location div#location {
    color: #f05548;
    font-size: 40px;
    font-weight: bold;
    padding: 50px 100px 0;
    text-shadow: 1px 1px 0 #fff, -1px -1px 0 #fff;
}
section#main.location div#location span {
    font-size: 50px;
}
.notation {
    margin: 10px auto 30px;
    width: 900px;
}

article#example {
    background: url(/img/pc/example.png);
    height: 1890px;
}
article#example.min {
    background: url(/img/pc/example_min.png);
    height: 1470px;
}
article#example h1 {
    left: 30px;
    position: absolute;
    top: 30px;
}
article#example p {
    font-size: 18px;
    left: 60px;
    position: absolute;
    width: 490px;
}
article#example div.conclusion {
    left: 205px;
    position: absolute;
}
article#example section#speed {
}
article#example section#speed h2 {
    left: 147px;
    position: absolute;
    top: 199px;
}
article#example section#speed p {
    top: 300px;
}
article#example section#speed div.conclusion {
    top: 548px;
}
article#example section#time {
}
article#example section#time h2 {
    left: 147px;
    position: absolute;
    top: 742px;
}
article#example section#time p {
    top: 840px;
}
article#example section#time div.conclusion {
    top: 1087px;
}
article#example section#voice {
}
article#example section#voice h2 {
    left: 146px;
    position: absolute;
    top: 1265px;
}
article#example section#voice ul {
    font-size: 16px;
    left: 100px;
    line-height: 120%;
    position: absolute;
    top: 1385px;
    width: 940px;
}
article#example section#voice li {
    float: left;
    margin: 0 60px 40px 0;
    width: 360px;
}

article#results {
}
article#results h1 {
    margin-bottom: 20px;
}
article#results section#failureStory {
}
article#results section#failureStory h2 {
    left: 56px;
    position: absolute;
    top: 667px;
}
article#results section#failureStory div {
    left: 94px;
    position: absolute;
    top: 798px;
}
article#results section#failureStory p {
    font-size: 16px;
    left: 90px;
    position: absolute;
    top: 840px;
    width: 760px;
}

article#lineup {
}
article#lineup div.content {
    padding: 30px 10px 30px 30px;
}
article#lineup section.service {
    float: left;
    margin-right: 20px;
    width: 430px;
}
article#lineup section.service header {
    background: url(/img/pc/line03.png) repeat-x bottom;
    color: #6c462c;
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 15px;
    padding-bottom: 5px;
}
article#lineup section.service header h2 {
    color: #6c462c;
    float: left;
    font-weight: bold;
}
article#lineup section.service header div.price {
    color: #d12525;
    float: right;
    font-size: 18px;
}
article#lineup section.service header div.price span {
    font-size: 24px;
}
article#lineup section.service p {
    float: left;
    width: 270px;
}
article#lineup section.service div.image {
    float: right;
}
article#lineup section.category {
    float: left;
    margin-right: 20px;
    width: 205px;
}
article#lineup section.category header {
    background: url(/img/pc/line03.png) repeat-x bottom;
    color: #6c462c;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 15px;
    padding-bottom: 5px;
}
article#lineup section.category header h2 {
    color: #6c462c;
    float: left;
    font-weight: bold;
}
article#lineup section.category header div.item {
    float: right;
}

article#faq {
}
article#faq div.content {
    padding: 30px 10px 30px 30px;
}
article#faq section.faq {
    float: left;
    margin-right: 20px;
    width: 430px;
}


article#faq section.faq header {
    background: url(/img/pc/line03.png) repeat-x bottom;
}
article#faq section.faq header h2 {
    background: url(/img/pc/faq01.png) no-repeat left center;
    color: #6c462c;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 10px;
    padding: 0 0 5px 30px;
    position: relative;
}
article#faq section.faq p {
    background: #fff;
    padding: 20px;
}

article#area {
}
article#area div.content {
    padding: 30px 10px 30px 30px;
}
article#area ul {
    float: left;
    font-weight: bold;
    margin-right: 20px;
    width: 130px;
}
article#area li:before {
    color: #6ab653;
    content: "・";
}
article#area li.category {
    background: url(/img/pc/line03.png) repeat-x bottom;
    color: #6c462c;
    font-size: 18px;
    margin-bottom: 10px;
    padding-bottom: 5px;
}
article#area li.category:before {
    content: normal;
}
article#area p {
    width: 880px;
}

article#company,
#policy {
    font-size: 13px;
    margin: 100px auto 100px;
    padding-bottom: 30px;
}

article#company table {
    width: calc(100% - 60px);
}
article#company tr {
    background: url(/img/pc/line03.png) repeat-x bottom;
}
article#company th {
    padding: 10px;
    width: 200px;
}
article#company li:last-child {
    padding-bottom: 10px;
}

#policy ul {
    height: 250px;
    overflow-y: scroll;
}

article.other {
    background: url(/img/pc/other_back.png);
    border-radius: 10px;
    box-shadow: 1px 1px 3px rgba(108,70,44,.3);
    margin-top: 100px;
}
article.other div.content {
    padding: 30px;
}
/* ------------------------------------------------------------
     Hacks
------------------------------------------------------------ */
.clearfix {
}
.clearfix:after {
    clear: both;
    content: ".";
    display: block;
    font-size: 0;
    height: 0;
    visibility: hidden;
}
div.codeHide {
    bottom: 0;
    position: absolute;
}

#company2 h2 {
    display: none;
}
#company2 .client li:nth-child(odd) {
    float: left;
    width: 50%;
}
#company2 dl {
    background: url(/img/pc/line03.png) repeat-x bottom;
    margin-bottom: 10px;
}
#company2 dt:nth-child(odd) {
    float: left;
    width: 20%;
}
#company2 td p {
    margin-bottom: 10px;
}

.main-kiyaku a {
    bottom: -15px;
    left: 0;
    position: absolute;
    right: 0;
    text-align: center;
}