@charset "utf-8";
html,
body {
min-height: 100%;
height: 100%;
}

#wrapper {
position: relative;
width: 100%;
min-width: 1200px;
min-height: 100%;
margin: 0 auto;
overflow: hidden;
background-color: #fcffc9;
}
#wrapper:before,
#wrapper:after {
content: "";
position: absolute;
left: 0;
display: block;
width: 100%;
height: 44px;
background: url(../images/border01.jpg) left top repeat-x;
}
#wrapper:before {
top: 0;
}
#wrapper:after {
bottom: 0;
}
#wrapper > * {
width: 1190px;
margin: 0 auto;
}
#wrapper > * a {
transition: all 0.5s;
}

a:hover img,
a.hover:hover,
.btn a:hover {
text-decoration: none;
opacity: 0.8;
}

.inlineList {
font-size: 0px;
text-align: left;
letter-spacing: -0.4em;
}
.inlineList > * {
display: inline-block;
font-size: 1rem;
letter-spacing: 0;
vertical-align: top;
}
.inlineList > * * {
letter-spacing: 0;
}

[class^="grid_"].clearFix {
float: none;
margin-left: auto;
margin-right: auto;
}

#header {
position: relative;
padding-top: 14px;
}
#header .btn {
position: absolute;
left: 50%;
top: 450px;
display: block;
width: 430px;
height: 84px;
transform: translateX(-50%);
}

#content {
padding: 0 55px;
}
#content > section {
position: relative;
overflow: hidden;
}
#content > section .txt {
position: absolute;
left: -100vw;
display: block;
width: 100%;
}
#content #example > a {
position: absolute;
bottom: 0;
display: block;
width: 426px;
height: 426px;
border-radius: 100%;
text-indent: -9999px;
background-color: rgba(255,
255,
255,
0);
}
#content #example > a:hover {
background-color: rgba(255,
255,
255,
.4);
}
#content #example > a.bad {
right: 0;
}
#content #example > a.good {
left: 0;
}
#content #ability {
position: relative;
padding: 30px 0 55px;
background: url(../images/pht05_bg.jpg) left top repeat-y;
}
#content #ability:after {
content: "";
position: absolute;
left: 50%;
bottom: 0;
display: block;
width: 970px;
height: 1px;
background-color: #f7f4f3;
transform: translateX(-50%);
}
#content #ability > * {
width: 750px;
margin: 0 auto;
}
#content #ability > p {
font-size: 18px;
line-height: 35px;
}
#content #ability > ul {
padding-top: 10px;
}
#content #ability > ul li {
position: relative;
margin-top: 25px;
padding-left: 55px;
}
#content #ability > ul li:before {
content: "";
position: absolute;
left: 0;
top: 0;
display: block;
width: 35px;
height: 33px;
background: url(../images/icon01.png) left top no-repeat;
}
#content #ability > ul li em {
display: block;
color: #f4650e;
font-size: 22px;
font-weight: bold;
}
#content #ability > ul li p {
font-size: 18px;
font-weight: bold;
line-height: 30px;
}
#content #profile {
padding: 65px 0 80px;
border: 2px #f57a97 solid;
border-top: none;
background-color: #fff;
}
#content #profile > .clearFix {
position: relative;
width: 968px;
margin: 0 auto;
padding: 80px 0 40px;
border-radius: 35px;
background: url(../images/pht06_bg.jpg) left top no-repeat #fbcdde;
}
#content #profile > .clearFix > figure {
float: left;
width: 420px;
padding-top: 75px;
text-align: center;
}
#content #profile > .clearFix > figure figcaption {
position: absolute;
left: 50px;
bottom: 50px;
color: #fff;
font-size: 36px;
font-weight: bold;
line-height: 1;
}
#content #profile > .clearFix > div {
float: right;
width: 530px;
padding-right: 55px;
}
#content #profile > .clearFix > div h4 {
margin-bottom: 25px;
padding-bottom: 20px;
border-bottom: 2px #fff solid;
color: #693017;
font-family: "ヒラギノ明朝 Pro",
"Hiragino Mincho Pro",
"游明朝",
"Yu Mincho",
serif;
font-size: 45px;
font-weight: bold;
line-height: 1;
}
#content #profile > .clearFix > div h4 span {
position: relative;
top: 13px;
font-size: 20px;
vertical-align: top;
}
#content #profile > .clearFix > div p {
font-size: 18px;
line-height: 35px;
}

#footer {
position: relative;
margin-top: 105px;
padding-bottom: 105px;
}
#footer:before {
content: "";
position: absolute;
left: 50%;
top: -175px;
display: block;
width: 195px;
height: 131px;
background: url(../images/icon02.png) left top no-repeat;
transform: translateX(-50%);
}
#footer .inner {
margin-top: 45px;
padding: 0 55px;
}
#footer .inner p {
margin-top: 30px;
font-size: 25px;
line-height: 45px;
}

.clear {
clear: both;
display: block;
overflow: hidden;
visibility: hidden;
width: 0;
height: 0;
}

.clearFix:after {
content: "";
clear: both;
display: block;
height: 0;
visibility: hidden;
font-size: 0;
line-height: 0;
}

* html .clearFix {
height: 1%;
}

.clearFix {
display: block;
}
