@charset "euc-jp";
/*====================================================

layout.css

since-2015.03.02 s_uemura
update-0000.00.00

====================================================*/

/*-------------------------------------
default
---------------------------------------*/
* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

body>div {
    font-size: 14px;
    font-size: 1.4rem;
}

/* ----------------------
reset
------------------------- */
* {
    margin: 0;
    padding: 0;
}

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
input,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
dialog,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    vertical-align: baseline;
    background: transparent;
}

html {
    font-size: 62.5%;
    overflow-y: scroll;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    padding: 0;
    margin: 0;
    background: #3b3b3b;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section {
    display: block;
}

ol,
ul {
    list-style: none;
}

table {
    border-collapse: separate;
    border-spacing: 0;
}

caption,
th,
td {
    font-weight: normal;
    text-align: left;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: "";
}

blockquote,
q {
    quotes: "" "";
}

a:hover,
a:active {
    outline: 0;
}

a img {
    border: 0;
}

img {
    vertical-align: bottom;
    font-size: 0;
    line-height: 0;
}

body {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1;
    font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Sawarabi Gothic", "游ゴシック Medium", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;
    color: #333;
    background: #fff;
    padding: 0;
    margin: 0;
    border: none;
}

/* clear */
.clear {
    clear: both;
    background: transparent;
    height: 1px;
    font-size: 1px;
}

.clearfix:after {
    /*for modern browser*/
    content: ".";
    display: block;
    height: 0px;
    clear: both;
    line-height: 0;
    visibility: hidden;
}

.clearfix {
    zoom: 1;
    /*for IE 5.5-7*/
}

/* margin */
.mgt3 {
    margin-top: 3px !important;
}

.mgt5 {
    margin-top: 5px !important;
}

.mgt10 {
    margin-top: 10px !important;
}

.mgt15 {
    margin-top: 15px !important;
}

.mgt20 {
    margin-top: 20px !important;
}

.mgt25 {
    margin-top: 25px !important;
}

.mgt30 {
    margin-top: 30px !important;
}

.mgt35 {
    margin-top: 35px !important;
}

.mgt40 {
    margin-top: 40px !important;
}

.mgt50 {
    margin-top: 40px !important;
}

.mgt60 {
    margin-top: 60px !important;
}

.mgr5 {
    margin-right: 5px !important;
}

.mgr10 {
    margin-right: 10px !important;
}

.mgr15 {
    margin-right: 15px !important;
}

.mgr20 {
    margin-right: 20px !important;
}

.mgr25 {
    margin-right: 25px !important;
}

.mgr30 {
    margin-right: 30px !important;
}

.mgr35 {
    margin-right: 35px !important;
}

.mgr40 {
    margin-right: 40px !important;
}

.mgr50 {
    margin-right: 50px !important;
}

.mgl5 {
    margin-left: 5px !important;
}

.mgl10 {
    margin-left: 10px !important;
}

.mgl15 {
    margin-left: 15px !important;
}

.mgl20 {
    margin-left: 20px !important;
}

.mgl25 {
    margin-left: 25px !important;
}

.mgl30 {
    margin-left: 30px !important;
}

.mgl35 {
    margin-left: 35px !important;
}

.mgl40 {
    margin-left: 40px !important;
}

.mgl50 {
    margin-left: 50px !important;
}

.mgb3 {
    margin-bottom: 3px !important;
}

.mgb5 {
    margin-bottom: 5px !important;
}

.mgb10 {
    margin-bottom: 10px !important;
}

.mgb15 {
    margin-bottom: 15px !important;
}

.mgb20 {
    margin-bottom: 20px !important;
}

.mgb25 {
    margin-bottom: 25px !important;
}

.mgb30 {
    margin-bottom: 30px !important;
}

.mgb35 {
    margin-bottom: 35px !important;
}

.mgb40 {
    margin-bottom: 40px !important;
}

.mgb50 {
    margin-bottom: 50px !important;
}



/* padding */

.pdt5 {
    padding-top: 5px !important;
}

.pdt10 {
    padding-top: 10px !important;
}

.pdt15 {
    padding-top: 15px !important;
}

.pdt20 {
    padding-top: 20px !important;
}

.pdt25 {
    padding-top: 25px !important;
}

.pdt30 {
    padding-top: 30px !important;
}

.pdt35 {
    padding-top: 35px !important;
}

.pdt40 {
    padding-top: 40px !important;
}

.pdr5 {
    padding-right: 5px !important;
}

.pdr10 {
    padding-right: 10px !important;
}

.pdr15 {
    padding-right: 15px !important;
}

.pdr20 {
    padding-right: 20px !important;
}

.pdr25 {
    padding-right: 25px !important;
}

.pdr30 {
    padding-right: 30px !important;
}

.pdr35 {
    padding-right: 35px !important;
}

.pdr40 {
    padding-right: 40px !important;
}

.pdl5 {
    padding-left: 5px !important;
}

.pdl10 {
    padding-left: 10px !important;
}

.pdl15 {
    padding-left: 15px !important;
}

.pdl20 {
    padding-left: 20px !important;
}

.pdl25 {
    padding-left: 25px !important;
}

.pdl30 {
    padding-left: 30px !important;
}

.pdl35 {
    padding-left: 35px !important;
}

.pdl40 {
    padding-left: 40px !important;
}

.pdb5 {
    padding-bottom: 5px !important;
}

.pdb10 {
    padding-bottom: 10px !important;
}

.pdb15 {
    padding-bottom: 15px !important;
}

.pdb20 {
    padding-bottom: 20px !important;
}

.pdb25 {
    padding-bottom: 25px !important;
}

.pdb30 {
    padding-bottom: 30px !important;
}

.pdb35 {
    padding-bottom: 35px !important;
}

.pdb40 {
    padding-bottom: 40px !important;
}


/* align */

.alR {
    text-align: right;
}

.alL {
    text-align: left;
}

.alC {
    text-align: center;
}

.vaT {
    vertical-align: top;
}

.vaM {
    vertical-align: middle;
}

.vaB {
    vertical-align: bottom;
}


/* link */
a:link {
    color: #169f9f;
    text-decoration: none;
}

a:visited {
    color: #169f9f;
    text-decoration: none;
}

a:hover {
    color: #077575;
    text-decoration: none;
}

a:active {
    color: #077575;
    text-decoration: none;
}

/* font-size */
.txtSS {
    font-size: 10px;
    font-size: 1.0rem;
}

.txtS {
    font-size: 12px;
    font-size: 1.2rem;
}

.txtR {
    font-size: 14px;
    font-size: 1.4rem;
}

.txtM {
    font-size: 16px;
    font-size: 1.6rem;
}

.txtB {
    font-size: 18px;
    font-size: 1.8rem;
}

.bold {
    font-weight: bold;
}

.corRed {
    color: #cc0000;
}

.reformline {
    white-space: pre-wrap;
}

/* care */
ul.care {
    font-size: 10px;
    font-size: 1.0rem;
    line-height: 1.3;
}

ul.care li {
    text-indent: -10px;
    padding-left: 10px;
    padding-bottom: 3px;
}

ul.care02 {
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1.3;
}

ul.care02 li {
    text-indent: -12px;
    padding-left: 12px;
    padding-bottom: 3px;
}

/* ----------------------
404, 403
------------------------- */
html {
    height: 100%;
    display: table;
    margin: 0 auto;
    padding: 0;
    background: #fff;
}

body {
    min-height: 100%;
    display: table-cell;
    margin: 0 auto;
    padding: 0;
    vertical-align: middle;
}

#notFound403,
#notFound404 {
    padding: 20px;
    font-size: 14px;
    font-size: 1.4rem;
    color: #666;
    text-align: center;
    line-height: 1.3;
}

#notFound403 .errorNo,
#notFound404 .errorNo {
    margin-top: 30px;
    font-size: 50px;
    font-size: 5.0rem;
    font-weight: bold;
}

#notFound403 .errorTxt,
#notFound404 .errorTxt {
    display: inline-block;
    margin-left: 10px;
    font-size: 28px;
    font-size: 2.8rem;
    color: #999;
}

#notFound403 img,
#notFound404 img {
    width: 100%;
    height: auto;
}

/* blueButton */
a.roundBtn {
    display: inline-block;
    padding: 10px;
    background: #0cb5bc;
    border-radius: 5px;
    font-size: 14px;
    font-size: 1.4rem;
    font-weight: bold;
    color: #fff;
}

a.roundBtn:hover {
    opacity: 0.7;
}

a.roundBtn span.arrow {
    display: inline-block;
    padding-left: 15px;
    background: url(/common/images/btn_arrow.png) left center no-repeat;
    background-size: 14px 14px;
}