@charset "UTF-8";

/*================================================
 *  CSSリセット
 ================================================*/
html,body,div,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,sidebar,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;font-weight:unset;}span{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;}body{line-height:1}article,aside,details,figcaption,figure,header,hgroup,menu,nav,section{display:block}footer{display:inline-block}ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}input,select{vertical-align:middle}
ul{list-style:none; padding-inline-start:0; margin-block:0;}
* {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
*:before, *:after { box-sizing: inherit; }
/*================================================
 *  common main-padding 20px scroll 20px = 40px追加 1040px 790px 540px
 ================================================*/
body {
    font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
    background:#fffffd; /*#f3f3f2*/
    color:#666666;
    line-height:1.8;
    width:100%;
    min-height: 100% !important;
    height: auto;
    margin: 0;
    padding: 0;
    word-wrap:break-word;
    -webkit-text-size-adjust: 100%;
    overflow-x: hidden;
}
_:lang(x)::-ms-backdrop, body {
    font-family: "Segoe UI", Meiryo, sans-serif;
}
b, strong, .bold{
	font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI semibold", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic", "Segoe UI", Verdana, Meiryo, sans-serif;
}
@media only screen and (max-width:416px){
body{font-size: -webkit-calc(100vw / 26); font-size: calc(100vw / 26);}
}
@media print, screen and (min-width:401px){
body{font-size:16px;}
}

#wrap {
    width:100%;
    min-height:100%;
    height:auto !important;
    height:100%;
    display:block;
    clear:both;
    overflow:hidden;
    padding-bottom: 0;
    margin-bottom: 0;
}
#contents {
    display:block;
    clear:both;
    overflow:hidden;
    word-wrap:break-word;
    width:100%;
    max-width:1150px;
    padding:0;
    margin:0px auto 0px;
}
#main {
    display:block;
    clear:both;
    overflow:hidden;
    word-wrap:break-word;
    width:100%;
    max-width: 900px;
    margin:0 auto;
    padding:0 0 1.5em;
    float:none;
}
#sidebar {
    display:block;
    overflow:hidden;
    float:none;
    width:100%;
}
@media print, screen and (min-width: 1150px){
#main {float:left; width:calc(100% - 250px);}
#sidebar {float:right; width:250px;}
}
@media print, screen and (min-width:1200px){
#contents {max-width:1200px;}
#main {margin:0 25px 0 25px; width:calc(100% - 300px);}
}
section{width:100%; margin:0 auto; padding:2.5em 5% 2em; display:block; overflow:hidden;}
section#subbox{padding-top:0 !important; padding-bottom:0 !important;}
.breadcrumb + section{padding-top:0 !important;}
.inner{max-width:1100px; margin: 0 auto; display: block; overflow: hidden; clear: both;}