@charset "utf-8";

body {
color: #333333;
font-size: 15px;
line-height: 1.7;
letter-spacing: 0.2px;
-webkit-text-size-adjust: 100%;
font-family: 'Avenir','Helvetica Neue','Helvetica','Arial','Hiragino Sans','ヒラギノ角ゴシック','メイリオ', Meiryo, 'ＭＳ Ｐゴシック','MS PGothic'
}

/* Windows */
@font-face {
  font-family: YuGothicM;
  font-weight: normal;
  src: local('YuGothic-Medium'),  /* Mediumを明示的に指定 */
       local('Yu Gothic Medium'), /* Chrome用 */
       local('YuGothic-Regular'); /* Windows8.1ではMediumがないのでRegularを指定 */
}
@font-face {
  font-family: YuGothicM;
  font-weight: bold;
  src: local('YoGothic-Bold'), /* Boldはそのまま */
       local('Yu Gothic');     /* Chrome用 */
}

/* link
------------------------------------------------ */

a:link {
color:#2a2a2a;
text-decoration:none;
transition: .4s;
}

a:visited {
color:#2a2a2a;
text-decoration:none;
}

a:hover {
color:#CC4A00;
text-decoration: underline;
}

a:active {
color:#CC4A00;
text-decoration: underline;
}

/* 
@media print, screen and (min-width: 736px) {

a:hover img {
opacity: 0.7;
filter: alpha(opacity=70);
-moz-opacity: 0.7;
}
a:active img {
opacity: 0.7;
filter: alpha(opacity=70);
-moz-opacity: 0.7;
}

a:active img {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -moz-opacity: 0.7;
}

header a:hover img,
.nav ul li a:hover img,
.nav ul li a:active img {
opacity: 1;
filter: alpha(opacity=100);
-moz-opacity: 1;
}

}
------------------------ */
/* clearfix
------------------------------------------------ */
.clearfix:after {
  content: " ";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.clearfix {
  display: inline-block;
  min-height: 1%;
}

/* Hides from IE-mac \*/
* html .clearfix {
  height: 1%;
}
.clearfix {
  display: block;
}
/* End hide from IE-Mac */

/* 文字
------------------------------------------------ */

strong {
  font-weight: bold;
}

.textC {
  text-align: center;
}

.textR {
  text-align: right;
}

.red {
  color: red;
}

.bold {
  font-weight: bold;
}

.smallCap {
font-size: 0.8rem;
}

.largeCap {
font-size: 1.2rem;
}

.vLast {
margin-bottom:0 !important;
}

.hLast {
margin-right:0 !important;
}

.margin-bottom {
margin-bottom: 20px;
}

.super {
vertical-align: super;
font-size: 0.8rem;
}

.main .entryBody p {
margin-bottom: 1em;
}

.floatL {
float: left;
}

.floatR {
float: right;
}

.italic {
font-style: italic;
}

.superText {
font-size: 70%;
vertical-align: top;
}

.subText {
font-size: 70%;
vertical-align: bottom;
}

article p {
margin-bottom: 1em;
}

article blockquote {
margin-bottom: 20px;
font-size: 80%;
border-left: 10px solid #E0E0E0;
padding-left: 10px;
}

/* 画像
------------------------------------------------ */

article .img-l {
text-align: center;
margin: 0 0 1em 0;
}

article .img-r {
text-align: center;
margin: 0 0 1em 0;
}

@media print, screen and (min-width: 736px) {
article .img-l {
float: left;
margin: 0 1em 1em 0;
}

article .img-r {
float: right;
margin: 0 0 1em 1em;
}
}

/* flex
------------------------------------------------ */

@media screen and (max-width: 735px) {
.sp-flex {
  display: -webkit-flex; /* Safari */
  display: flex;
}
}

@media print, screen and (min-width: 736px) {
.flex {
  display: -webkit-flex; /* Safari */
  display: flex;
}
}

/* img
------------------------------------------------ */

img {
max-width: 100%;
height: auto;
}

/* display: none;
------------------------------------------------ */

@media screen and (max-width: 735px) {
.pcOnly {
display: none !important;
}
}

@media print, screen and (min-width: 736px), print {
.spOnly {
display: none !important;
}
}



/* noscript
------------------------------------------------ */
.noscript {
  position: relative;
  z-index: 5260;
  padding: 10px;
  border-bottom: #00A893 solid 1px;
  background: #fff;
  color: #000;
  text-align: center;
  font-size: 14px;
}

.noscript span {
  color: #ff0000;
}

/* #page-top
------------------------------------------------ */

.pageTop {
position: fixed;
bottom: 10px;
right: 5px;
text-align: center;
font-size: 90%
}
.pageTop a {
display: block;
text-decoration: none;
color: #fff;
background: #8E236B;
opacity: 0.7;
padding: 10px;
border-radius: 5px;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
}
.pageTop a:hover {
background: #D3006D;
opacity: 0.7;
}

@media print, screen and (min-width: 736px) {
.pageTop {
position: fixed;
bottom: 20px;
right: 10px;
}
}

/* layout
------------------------------------------------ */
.container {
width: 1000px;
margin: 0 auto;
padding: 0 20px;
box-shadow: 0 0 10px 5px rgba(0,0,0,0.2);
background: url(/images/bg.png) no-repeat 20px 70px #fff;
}

.container-wrap {
padding-bottom: 20px;
}

main {
width: 680px;
float: left;
}

/* side
------------------------------------------------ */
.side {
width: 250px;
float: right;
}


.side .box {
margin-bottom: 10px;
}
.side ul {
background: #EBFFFF;
line-height: 1.5;
margin-bottom: 10px;
}

.side ul a,
.side ul span {
display:block;
margin-bottom: 5px;
padding: 0 5px;
}
.side .gray a {
color: #505050;
font-size: 80%;
}

.side .midashi a,
.side .midashi span {
border: 1px solid #cdcdcd;
font-weight: bold;
font-size: 15px;
padding: 5px;
}


.side .midashi.p1 span {
color: #001cb0;
}

.side .midashi.p2 a {
color: #001cb0;
background: #b9e7ff;
}

.side .midashi.p3 a {
color: #d00000;
background: #ffe8fa;
}

.side .midashi.p4 span {
color: #007400;
background: #beffe3;
}

.side .midashi.p5 span {
color: #9d2a00;
background: #fff6aa;
}

.side .midashi.p2.smallCap a,
.side .midashi.p3.smallCap a {
font-size: 90%;
position:relative;
}

.side .midashi.p2.smallCap a:after,
.side .midashi.p3.smallCap a:after {
font-family: FontAwesome;
content : "\f138";
position:absolute;
top:5px;
right: 5px;
}

.side .midashi a:hover {
color: #0073e5;
background: #cccccc;
text-decoration: none;
}

.side .gray a:hover {
color: #0000b1;
background: #ffcafd;
text-decoration: none;
}

/* ------------------------------------------------ */
/* side */
.side .sss {
font-size: 80%;
}

.side .sss .sss-box {
margin-bottom: 5px;
width: 100%;
}

.side .sss .sss-box .wrap {
margin:5px;
}

.side .side_box2{
 border:solid 1px #ff8600;
}

.side .side_box3{
 border:solid 1px #ebbcd1;
}

.side .side_box4{
 border:solid 1px #aa989a;
}

.side .side_box5{
 border:solid 1px #acddfd;
}

.side .side_box6{
 border:solid 1px #80dd92;
}

.side .side_box7{
 border:solid 1px #eaa524;
}

.side .side_box8{
 border:solid 1px #c1b25c;
}


/* ------------------------------------------------ */

footer {
font-size: 90%;
border-top: #00e9fc solid 1px;
text-align: center;
padding: 10px;
}