html {
    width: 100%;
    font-family: '¥á¥¤¥ê¥ª', Meiryo, sans-serif;
}

BODY {
    width: 100%;
    margin:0;
    padding: 0;
    background: #fff;
}

#wrapper {
    /* width: 100%; */
    width: 1280px;
    margin: auto;
}

#header_wrapper {
    width: 100%;
    border-top: 10px solid #014099;
}

#header {
    width: 100%;
    min-width: 1280px;
    position: relative;
    overflow: hidden;
    height: 322px;
    background: #fff;
}

#header_left {
    position: absolute;
    top: 0;
    left: 0;
    width: 15%;
    height: 322px;
    background: #dcdcdc;
z-index: 1;
}

#header_right {
    position: absolute;
    top: 0;
    left: 85%;
    width: 15%;
    height: 322px;
    background: #dcdcdc;
z-index: 1;
}

#logo_top {
    top: 0;
    width: 100%;
    margin: auto;
    text-align: center;
    background: #fff;
z-index: 10;
}

#logo_top H1 {
/*    width: 1280px;*/
    width: 1278px;
    height: 320px;
    margin: 0 auto;
    background: url(../images/230722_1280.jpg) top left no-repeat;
    text-indent: -10000px;
    border: solid 1px black; 
}

#header_min {
    width: 100%;
    padding: 10px 0;
    background: #fff;
}

#header_min H1 {
    float: right;
    font-size: 12px;
    font-weight: normal;
    margin: 0 10px 0 0;
}

#menu {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1270px;
    height: 120px;
    margin: auto;
    padding: 5px; 
    background: #014099;
}

@keyframes scroll{
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc(-250px * 6));
  }
}

.slider {
    height: 114px;
    width: 100%;
    margin-left: 5px;
    overflow:hidden;
    position: relative;
}
.slider-wrap {
    animation: scroll 10s linear infinite;
    display: flex;
    width: calc(250px * 18);
    align-items: center;
    justify-content: center;
    background: #014099;
}

.slide{
    width:230px;
    height:110px;
    text-align:center;
    margin-right: 20px; 
}

.slide-image{
    width:230px;
    height:110px;
    object-fit:cover;
    /* border: solid 2px blue; */
}


#pagemenu UL {
    width: 1281px;
    height: 60px;
    margin: 0;
    padding: 0;
    list-style-type: none;
}

#pagemenu LI {
    height: 60px;
    width: 12%;
    line-height: 60px;
    margin: 0;
    float: left;
}

#pagemenu LI.w13 {
    width: 13%;
}

#pagemenu LI A {
    text-decoration: none;
    color: #fff;
    text-align: center;
    display: block;
    margin-right: 1px;
    margin-top: 1px;
    background: #014099;
}

#pagemenu LI A:hover {
    text-decoration: underline;
    background: #000;
}

#pagemenu LI P {
    color: rgb(84,132,200);
    text-align: center;
    display: block;
    margin: 0 1px 0 0;
    background: #014099;
}

#pagemenu LI P.sel {
    color: #fff;
    background: #000;
}

#pagemenu LI .noborder {
    margin: 0;
}



#page_body {
    width: 1268px;
    margin: auto;
    padding: 30px 5px 0 5px;
    overflow: hidden;
    border-right: solid 1px #014099;
    border-left: solid 1px #014099;
    background: rgb(245,245,245);
}

#page_right a {
    font-size: 12px;
}

H3.headline {
    margin: 0 0 15px 0;
    border-left: 5px solid #014099;
    padding: 0 0 0 15px;
    height: 30px;
    font-size: 22px;
    font-weight: bold;
    line-height: 30px;
    color: #014099;
}

H2.catch, H2.catch_b, H2.catch_c {
    margin: 0 0 30px 0;
    padding: 0;
    height: 30px;
    font-size: 24px;
    font-weight: bold;
    line-height: 30px;
    color: #014099;
}

H2.catch_b, H2.catch_c {
    color: #014099;
}

#page_left {
    float: left;
    margin-left: 30px;
    min-width: 630px;
    width: 100%;
    margin-right: -180px;
    padding-right: 180px;
    box-sizing: border-box;
}

#page_right {
    text-align: center;
    width: 150px;
    float: right;
}

#page_right p {
    margin:0 0 10px 0;
}

#page_right p.txt {
    text-align: left;
    font-size: 10pt;
    color: rgb(1,64,153);
    margin-left: 15px;
    width: 120px;
    border-bottom: 1px solid rgb(1,64,153);

}

#page_right p img {
    border: 1px solid #dcdcdc;
}

.left_container {
    margin: 0 15px 45px 15px;
}

.left_container P {
    margin: 0;
    padding: 0;
    color: rgb(60,60,60);
    font-size: 16px;
    line-height: 1.5em;
}

H2.headline {
    margin: 0 0 15px 0;
    border-left: 5px solid #014099;
    padding: 0 0 0 15px;
    height: 30px;
    font-size: 26px;
    font-weight: bold;
    line-height: 30px;
    color: #014099;
}

H2.catch {
    margin: 0 0 15px 0;
    padding: 0;
    height: 30px;
    font-size: 26px;
    font-weight: bold;
    line-height: 30px;
    color: #014099;
}

H3.catch {
    font-size: 22px;
    font-weight: bold;
    color: #014099;
    padding: 0 0 0 10px;
    margin: 0 0 10px 0;
}

#speaker_container {
    width: 100%;
}

.speaker {
    margin: 0 5px 20px 5px;
    float: left;
    padding: 10px 0 5px 0;
    border: 1px solid #dcdcdc;
    text-align: center;
    background: #fff;
    width: 100px;
    height: 170px;
}

.speaker P {
    padding: 0 3px 0px 3px;
}

.speaker IMG {
    border: 5px solid #fff;
    margin-bottom: 5px;
}

.speaker A {
    text-decoration: none;
    color: rgb(80,80,80);
}

.speaker A:hover {
    text-decoration: underline;
}

.speaker_box {
    background: #fff;
    padding: 20px;
    margin: 0 0 30px 0;
}
.speaker_box .profimg {
    float: left;
    margin-right: 30px;
}

.speaker_box .prof {
    overflow: hidden;
}

.speaker_box H3 {
    margin: 0 0 20px 0;
    font-size: 20px;
    color: rgb(60,60,60);
}

.speaker_box .proftxt {
    padding: 0 10px 0 0;
}

.speaker_box .books {
    margin: 20px 0 0 0;
}

.speaker_box .books A {
    margin: 0 20px 0 0;
}

.sub {
    background: #fff; 
    border: solid 1px gray; 
    padding: 10px 25px 10px 25px;
}

.sub H3 {
    font-size: 22px;
    font-weight: bold;
    color: #014099;
    padding: 0 0 0 10px;
    margin: 5px 0 0 0;
}

.name {
    display: inline-block;
    width: 200px;
}

.pr {
    display: inline-block;
    width: 960px;
}

.schedule DL {
    list-style-type: none;
    margin: 0;
    padding: 0;
    overflow: auto;
    text-align: left;
    background: #fff;
}

.schedule DT {
    float: left;
    width: 180px;
    clear: both;
    font-weight: bold;
    margin: 0 -1em 0 0;
    padding: 12px 0 12px 10px;
    font-size: 13px;
    line-height: 1.5em;
    color: rgb(100,100,100);
    background: #fff;
}

.schedule DD {
    margin: 0 0 0 0;
    padding: 12px 20px 12px 200px;
    border-bottom: 1px solid rgb(245,245,245);
    font-size: 13px;
    line-height: 1.5em;
    color: rgb(60,60,60);
    background: #fff;
}

A.btn {
    margin: 30px 0 0 0;
    display: block;
    width: 400px;
    height: 60px;
    line-height: 60px;
    text-align: center;
    color: #fff;
    text-decoration: none;
    background: rgb(1,64,153);
}

A:hover.btn {
    text-decoration: underline;
    background: #000;
}


.page_container {
    margin: 0 45px 45px 45px;
}

.page_container H4 {
    font-size: 16px;
    font-weight: bold;
    color: rgb(60,60,60);
    margin-bottom: 10px;
}

.page_contents {
    background: #fff;
    padding: 20px;
}

.page_container P {
    margin: 0;
    padding: 0;
    color: rgb(60,60,60);
    font-size: 16px;
    line-height: 1.5em;
}


#footer {
    /* width: 100%; */
    width: 1280px;
    margin: auto;
}

#footer_contents {
    background: rgb(100,100,100);
    padding: 30px 0;
    text-align: center;
    color: #fff;
    font-size: 13px;
}

/* clearfix */

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

.clearfix { display: inline-table; }

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