@charset "UTF-8";

/* Reset */

/* CSS Remedy */
*,::after,::before{box-sizing:border-box}html{line-sizing:normal}body{margin:0}img{border-style:none}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}

/* wp reset */
#primary {
    float: none;
    padding: 0;
    width: 100%;
}
#primary article.hentry {
    background: none;
    box-shadow: none;
    padding: 0;
}
.page-content, .entry-content, .entry-summary {
  margin: 0;
}
.veu_socialSet {
  margin-bottom: 0;
}
.veu_socialSet-position-after {
  margin-top: 0;
}
.veu_contentAddSection {
  display: block;
  clear: both;
  overflow: hidden;
  margin-top: 0;
  margin-bottom: 0;
}
button, a.button, input[type="button"], input[type="reset"], input[type="submit"] {
    padding: 0;
}

/* ------ */

img {
    max-width:100%;
    height: auto;
}
ul,li {
	list-style: none;
    margin: 0;
    padding: 0;
}
dl,dt,dd {
  margin: 0;
  padding: 0;
}
p {
    color:#333;
}
a,
a:focus {
  text-decoration: none;
  color: #444;
  transition: all 0.4s;
}
a img {
  border-style: none;
}
a:hover{
    opacity: 0.7;
    filter: alpha(opacity=70);
    cursor: pointer;
}
html {
    overflow-x: hidden;
    line-height: 1.6;
    color: #444;
    font-size: 62.5%;
}
body {
	background: #fff;
    margin: 0;
    padding: 0;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 1.6rem;
}
p {margin: 0;}

.enTxt {
    font-family: 'Alata', sans-serif;
}

.alnL { text-align: left;}
.alnR { text-align: right;}
.alnC { text-align: center;}
.relative { position: relative;}
.attentionTxt { margin-left: 1em; text-indent: -1em; }
.clear {
	clear: both;
	padding: 0;
}
.clearfix:after {
  content: "";
  clear: both;
  display: block;
}
.inner {
    margin: 0 auto;
    padding: 0 24px;
}
.wrapper {
    overflow: hidden;
}
.pcBlank { display: none;}
.spBlank { display: block;}

.pc_Blank { display: none;}
.tabBlank { display: block;}

.redTxt {
    color:#f4052c;
}
.iconBlank {
    display: block;
}

@media screen and (max-width: 1024px) {
    .inner {
        margin: 0 auto;
        padding: 0 20px;
    }
    .pc_Blank { display: block;}
    .tabBlank { display: none;}
}

@media screen and (max-width: 768px) {
    .pcBlank { display: block;}
    .spBlank { display: none;}
    .inner {
        margin: 0 auto;
        padding: 0 15px;
        width: 98%;
    }
}
@media screen and (max-width: 480px) {
    .iconBlank {
        display: none;
    }
}


/* ==========================================================================
   Font size
   ========================================================================== */
* {
  --viewport-unit-converter: 1vw;
  --fz-from: var(--font-size-from, var(--min-font-size));
  --fz-to: var(--font-size-to, var(--max-font-size));
  --fz-slope: (var(--fz-to) - var(--fz-from)) / (var(--viewport-to) - var(--viewport-from)) * 100;
  --fz-intercept: (var(--viewport-to) * var(--fz-from) - var(--viewport-from) * var(--fz-to)) / (var(--viewport-to) - var(--viewport-from));
  --font-size: calc(var(--fz-slope) * var(--viewport-unit-converter) + var(--fz-intercept) * 1px);

  --min-fz-px: calc(var(--min-font-size) * 1px);
  --max-fz-px: calc(var(--max-font-size) * 1px);
  --clamp: clamp(var(--min-fz-px), var(--font-size), var(--max-fz-px));
  --max: var(--has-max, var(--min));
  --min: var(--has-min, var(--font-size));
  --has-max: min(var(--max-fz-px), var(--font-size));
  --has-min: max(var(--min-fz-px), var(--font-size));

  font-size: var(--clamp, var(--max));
}


/* ==========================================================================
   Header
   ========================================================================== */
#osu-header header {
    background: #fff;
    height: 172px;
	width: 100%;
}
.headerFix {
    background: #fff;
    position: fixed;
    width: 100%;
    z-index: 9999;
}
#osu-header h1 {
    color:#fff;
	margin: 0;
	padding: 0;
	vertical-align: bottom;
}
#osu-header .headerTop {
	display: flex;
	align-self: flex-start;
	justify-content: flex-end;
	margin: 0 auto;
	max-width: 1200px;
	padding: 0 10px;
}
#osu-header .headerTop h1 {
	margin-right: auto;
    padding: 25px 0 0;
}
#osu-header .headerTelWrap {
    display: flex;
}
#osu-header .headerTelWrap img {
    margin: 0 15px 0 0;
}
#osu-header .headerTel {
	color:#004ea2;
	font-size:2.2rem;
	font-weight: bold;
	line-height: 1em;
	margin: 30px 10px 0 0;
	padding: 0 0 0 25px;
}
.headerBtn {
	display: flex;
	align-self: flex-start;
	justify-content: flex-end;
	margin: 20px 0;
}
.iconBtn {
    display: flex;
    justify-content: center;
}
.headerShiryou {
	background: #004ea2;
	font-size:1.6rem;
	font-weight: bold;
}
.headerShiryou a {
	color:#fff;
	display: block;
	padding: 10px 20px;
}
.headerShiryou img {
    margin: 0 10px 0 0;
}
.headerOpenSchool {
	background: #ffca36;
    font-size:1.6rem;
	font-weight: bold;
}
.headerOpenSchool a {
	color: #061849;
	display: block;
	padding: 10px 20px;
}
.headerOpenSchool img {
    margin: 2px 10px 0 0;
}
#osu-header .navTel {
    display: none;
}
#navTel {
    display: none;
}

header .entry-header .entry-title {
    margin-bottom: 0;
  }

  header.entry-header {
    display: none;
  }
.headerSnsIcon {
    display: flex;
    padding: 32px 20px 0 0;
}
.headerSnsIcon li {
    list-style: none;
    margin: 0 0 0 10px;
}

@media screen and (max-width: 1024px) {
    #osu-header header {
        height: 136px;
    }
    #osu-header .headerTop h1 {
        padding: 10px 0 0;
    }
    .headerBtn {
        margin: 0;
        position: fixed;
        top:auto;
        bottom:0;
        left:0;
        width: 100%;
        z-index: 1000;
    }
    .headerShiryou {
        background: #147ec3;
    }
    .headerShiryou a {
        padding: 15px 20px;
    }
    .headerShiryouShort {
        width: 50%;
    }
    .headerShiryouLong {
        width: 100%;
    }
    .headerOpenSchool {
        width: 50%;
    }
    .headerOpenSchool a {
        padding: 15px 10px;
    }
    #osu-header .headerTel {
        margin: 14px 12px 0 0;
    }
    .headerSnsIcon {
        padding: 16px 8px 0 0;
    }
}

@media screen and (max-width: 768px) {
    #osu-header .headerTop h1 {
        padding: 8px 0 0;
    }
    #osu-header .headerTop h1 img {
        height: auto;
        width: 300px;
    }
    #osu-header .headerTel {
        display: none;
    }
	.headerShiryou {
        font-size: 1.2rem;
    }
    .headerOpenSchool {
        font-size: 1.2rem;
    }
    #navTel {
        display: inline-block;
        color:#fff;
        font-size:100%;
        font-weight: normal;
        line-height: 1em;
        margin: 20px 0 0 0;
        padding: 10px 20px;
        text-align: center;
    }
    #osu-header .navTelWrap {
        display: flex;
        justify-content: center;
    }
    #osu-header .navTelWrap img {
        margin: 0 15px;
    }
    .headerSnsIcon {
        padding: 20px 48px 0 0;
    }

}
@media screen and (max-width: 480px) {
    #osu-header .headerTop h1 img {
        width: 220px;
    }
}

/* ==========================================================================
   Navigation
   ========================================================================== */
.navBg {
	background: url("../images/common/bg_nav.png");
	background-size: 16px auto;
	border-bottom: 1px solid #004ea2;
	padding: 5px 0;
	width: 100%;
}

.globalnav-wrap {
	color: #004ea2;
	display: flex;
	font-size: 1.8rem;
	font-weight: bold;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1200px;
}

.globalnav {
	padding: 0;
	width: 100%;
}

.globalnav ul {
	display: flex;
	justify-content: space-between;
	padding: 20px 0;
	width: 100%;
}
ul.navGakka {
    display: inline-block;
    padding: 5px 0 0;
}
p.navGakkaName {
    background: none;
    border: 1px solid #004ea2;
    color:#004ea2;
    font-size:1.4rem;
    font-weight: normal;
    text-align: center;
    margin: 10px 0 0;
    padding: 3px;
}
.globalnav ul ul.navOther {
    padding: 5px 0;
}
.globalnav .dropdown-btn {
	border-left: 1px solid #004ea2;
	cursor: pointer;
	display: inline-block;
	position: relative;
	padding: 5px 0;
	text-align: center;
	width: 16.5%;
}
.globalnav .dropdown-btn:first-child {
	border-left: none;
}
.globalnav .dropdown-btn:hover {
/*	background: #fff;*/
/*	transition: all 4s ease;*/
}
.globalnav .dropdown {
	background: url("../images/common/bg_nav.png") #fff;
	background-size: 16px auto;
/*	display: none;*/
	visibility: hidden;
	opacity: 0;
	position: absolute;
	left: 0;
	top: 45px;
/*	top: 55px;*/
	padding: 20px;
	transition: all .3s ease;
    text-align: left;
	width: 100%;
	z-index: 1000;
    box-shadow: 10px 10px 10px 1px rgba(0, 0, 0, .1);
}
.globalnav .dropdown-btn:hover .dropdown {
	visibility: visible;
	opacity: 1;
	top: 55px;
}

.globalnav .dropdown li {
    font-size:1.4rem;
	display: inline-block;
	margin: 10px 0;
    width: 100%;
}
.globalnav .dropdown li a {
	color: #004ea2;
}
nav a { color: #004ea2; }
nav a:visited { color: #004ea2; }
nav a:active { color: #004ea2; }
.globalnav .nav-button-wrap,
.globalnav .open {
	display: block;
}
.globalnav .close {
	display: block;
}

@media screen and (max-width: 1024px) {
	.globalnav-wrap {
		font-size: 1.4rem;
	}
}

@media screen and (max-width: 768px) {
    header {
        height: 54px;
        position: relative;
        width: 100%;
    }
    header h1 {
        margin: 10px 0 0;
        width: 70%;
    }
    header h1 img {
        height: auto;
        width: 80%;
    }
    .navBg {
        border-bottom: none;
        padding: 0;
    }
    .nav-button-wrap {
        display: block;
        position: absolute;
        right: 0;
        top: 5px;
        z-index: 1000;
        cursor: pointer;
        padding: 15px;
        height: 53px;
    }
    .globalnav {
        display: none;
    }
    .globalnav .close {
        display: none;
    }
    nav.globalnav-wrap .globalnav ul li.dropdown-btn {
        border-left: none;
        padding: 0 0 14px;
        text-align: left;
        width: 100%;
    }
    .globalnav .dropdown-btn:first-child {
        border-top: none;
    }
    p.navGakkaName {
        background: #147ec3;
        border: none;
        border-bottom: none;
        color:#fff;
        font-size:83%;
        padding: 5px 0;
    }
    .globalnav .dropdown {
        font-weight: normal;
        visibility: visible;
        opacity: 1;
        box-shadow: none;
        padding: 0;
        margin: 15px 0 0;
    }
    .globalnav ul {
        color:#fff;
        display: inline;
    }
    .globalnav .dropdown li {
        margin: 0;
        padding: 0;
        font-size: 500%;
    }
    .globalnav .dropdown li a {
        color: #fff;
    }
    nav a { color: #fff; }
    nav a:visited { color: #fff; }
    nav a:active { color: #fff; }
    .globalnav .dropdown li:first-child {
        border-top: 1px solid #004ea2;
    }
    .globalnav .dropdown li:last-child {
        border-bottom: none;
    }
    .globalnav-wrap.open .globalnav li .dropdown li {
        font-size: 83%;
    }
    .globalnav-wrap.open .globalnav {
        display: block;
        padding: 40px 20px 100px;
        position: fixed;
        left: 0;
        top: 0;
        background-color: rgba(0, 78, 162, 1.0);
        width: 100%;
        height: 100%;
        overflow-x: hidden;
        overflow-y: auto;
    }
    .globalnav-wrap.open .globalnav li {
        font-size:117%;
        display: block;
        margin: 0;
        padding: 10px 0;
    }
    .globalnav-wrap.open .globalnav li:hover {
        background: transparent;
    }
    .globalnav-wrap.open .globalnav li a {
        padding: 0;
    }
    .globalnav-wrap.open .globalnav .dropdown {
        border-top: 1px solid #fff;
        display: block;
        position: static;
        background: transparent;
    }
    .globalnav li.dropdown-btn .dropdown ul.navGakka li a {
        padding: 0 0 0 20px;
    }
    .nav-button,
    .nav-button span {
        display: inline-block;
        transition: all 0.3s;
    }
    .nav-button {
        z-index: 20;
        width: 25px;
        height: 19px;
        position: relative;
    }
    .nav-button span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #004ea2;
        border-radius: 4px;
    }
    .nav-button span:nth-of-type(1) {
        top: 0;
    }
    .nav-button span:nth-of-type(2) {
        top: 8px;
    }
    .nav-button span:nth-of-type(3) {
        bottom: 0;
    }
    .active .nav-button span:nth-of-type(1) {
        background-color: #fff;
        transform: translateY(10px) rotate(-45deg);
    }
    .active .nav-button span:nth-of-type(2) {
        opacity: 0;
    }
    .active .nav-button span:nth-of-type(3) {
        background-color: #fff;
        transform: translateY(-8px) rotate(45deg);
    }
    .navLine {
        border-bottom: 1px solid #fff;
        padding: 15px 0 0;
    }
}/*# sourceMappingURL=header {.css.map */

@media screen and (max-width: 480px) {
    header h1 {
        width: 80%;
    }
    header h1 img {
        height: auto;
        width: 80%;
    }
}


/* ==========================================================================
   Common
   ========================================================================== */
h2.topTitle {
    font-size:10.6rem;
    margin: 0;
    line-height: 1em;
}
.btnArea {
    border-radius: 50px;
    font-size:1.6rem;
    margin: 0 auto;
    text-align: center;
    width: 350px;
}
.btnArea a {
    color:#fff;
    display: block;
    padding: 15px 0;
}

.orangeGd {
    background: linear-gradient(90deg, #ffca36, #ff9000);
    background: -webkit-linear-gradient(0deg, #ffca36, #ff9000);
}
.orangeGdReverse {
    background: linear-gradient(90deg, #ff9000, #ffca36);
    background: -webkit-linear-gradient(0deg, #ff9000, #ffca36);
}
.blueGd {
    background: linear-gradient(90deg, #004ea2, #04c3d1);
    background: -webkit-linear-gradient(0deg, #004ea2, #04c3d1);
}
.pinkGd {
    background: linear-gradient(90deg, #d76b9c, #fcb4be);
    background: -webkit-linear-gradient(0deg, #d76b9c, #fcb4be);
}
.pageAnkerLink {
    padding-top: 220px;
    margin-top: -220px;
}

@media screen and (max-width: 1024px) {
    h2.topTitle {
        font-size:8.0rem;
        margin: 0;
        line-height: 1em;
    }
    .pageAnkerLink {
        padding-top: 196px;
        margin-top: -196px;
    }
}
@media screen and (max-width: 768px) {
    h2.topTitle {
        font-size:240%;
        font-weight: bold;
    }
    .btnArea {
        font-size:1.2rem;
        width: 70%;
    }
    .btnArea a {
        padding: 20px 0;
    }
    .pageAnkerLink {
        padding-top: 114px;
        margin-top: -114px;
    }
}

.subHeader {
    height: 250px;
    margin: 216px 0 0;
    position: relative;
    width: 100%;
}
.subHeader h2 {
    color:#004ea2;
    font-size:3.5rem;
    font-weight: bold;
    margin: 0 0 10px;
}
.subHeader h2 span {
    font-size:2.2rem;
}
.subHeader h2 ruby rt {
    font-size:1.2rem;
}
.subHeaderWh {
    background: #fff;
    height: 35px;
    width: 100%;
    position: absolute;
    bottom:0;
}
.subHeader .inner {
    max-width: 1200px;
}
.subHeaderTitle {
    background: #fff;
    margin: 0 auto;
    padding: 30px 0 0;
    position: absolute;
    right: 0;
    bottom:-10px;
    left: 0;
    text-align: center;
    width: 66%;
    z-index: 1;
}
.subHeaderCaption {
    font-size:2.5rem;
}
.bgYellowTxtGr {
    display: inline-block;
    background: linear-gradient(90deg, #ffca36, #ff9000);
    background: -webkit-linear-gradient(0deg, #ffca36, #ff9000);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
.bgBlueTxtGr {
    display: inline-block;
    background: linear-gradient(90deg, #004ea2, #04c3d1);
    background: -webkit-linear-gradient(0deg, #004ea2, #04c3d1);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.bgDeepredTxtGr {
    display: inline-block;
    background: linear-gradient(90deg, #b92946, #f195b1);
    background: -webkit-linear-gradient(0deg, #b92946, #f195b1);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

@media screen and (max-width: 1024px) {
    .subHeader {
        height: 210px;
        margin: 178px 0 0;
    }
    .subHeader h2 {
        font-size:2.5rem;
    }
    .subHeader h2 span {
        font-size:1.8rem;
    }
    .subHeader h2 ruby rt {
        font-size:1.0rem;
    }
    .subHeaderWh {
        height: 35px;
        width: 100%;
    }
    .subHeaderTitle {
        padding: 20px 0 0;
        bottom:0;
        width: 50%;
    }
    .subHeaderCaption {
        font-size:2.0rem;
    }
}

@media screen and (max-width: 768px) {
    .subHeader {
        height: 150px;
        margin: 90px 0 0;
    }
    .subHeader h2 {
        font-size:117%;
        margin: 0 0 2px;
    }
    .subHeader h2 span {
        font-size:74%;
    }
    .subHeaderWh {
        display: none;
    }
    .subHeaderTitle {
        padding: 12px 0 0;
        bottom:0;
        width: 60%;
    }
    .subHeaderCaption {
        font-size:92%;
    }
}

@media screen and (max-width: 480px) {
    .subHeader {
        margin: 50px 0 0;
    }
    .subHeaderTitle {
        width: 70%;
    }
}

/* Course */
.courseWrap {
    background-color: #fbf7ed;
    background-image: url("../images/top/bg_course_top.png"), url("../images/top/bg_course_bottom.png");
    background-position: left top, right bottom;
    background-repeat: no-repeat, no-repeat;
    background-size: 528px auto, 303px auto;
    padding: 100px 0;
}
.courseWrap .inner {
    max-width: 1200px;
}
.topTitleWrap {
    display: flex;
}
.topTitleWrap p {
    font-size:1.6rem;
    padding: 15px 0 0 90px;
}
.gakkaCategory {
    border-radius: 8px;
    padding: 12px 5px 12px 0;
    display: flex;
    margin: 60px 0 40px;
}
.gakkaCategory h3 {
    color:#fff;
    font-size:2.5rem;
    font-weight: bold;
    padding: 0;
    margin: 0;
}
.gakkaCategory h3 span {
    font-size: 1.6rem;
}
.gakkaLine {
    background: #fff;
    height: 1px;
    margin:20px 20px 0 30px;
    width: 18px;
}
.gakkaList {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.gakkaList li {
    background: #fff;
    margin-bottom: 35px;
    width: 30%;
    display: flex;
    flex-direction: column;
    padding: 0 0 25px;
}

.gakkaList li h4 {
    --viewport-from: 1025;
    --viewport-to: 1200;
    --min-font-size:18;
    --max-font-size: 20;
    font-weight: normal;
    margin: 0 0 15px;
    padding: 15px 20px 0;
    text-align: center;
}
.gakkaList li p {
    font-size:1.5rem;
    line-height: 2.0em;
    padding: 0 20px 10px;
}
.btnCourse {
    border-radius: 50px;
    font-size:1.4rem;
    text-align: center;
    margin: auto 20px 0;
}
.btnCourse a {
    color:#fff;
    display: block;
    padding: 10px 0;
}

.courseGr .btnCourse {
    background: #2db7b3;
}
.courseGr h4 {
    color: #2db7b3;
}
.coursePk .btnCourse {
    background: #ea619e;
}
.coursePk h4 {
    color: #ea619e;
}
.courseBl .btnCourse {
    background: #00a5e4;
}
.courseBl h4 {
    color: #00a5e4;
}
.courseOr .btnCourse {
    background: #f08300;
}
.courseOr h4 {
    color: #f08300;
}
#course section.course-seito .inner {
    padding: 0;
    width: 100%;
}

/* renewal */
.renewal {
    background: #004ea2;
    color:#fff;
    font-size:1.3rem;
    position: absolute;
    padding: 3px 10px;
    text-align: center;
}
.renewalTxt {
    background: #dcdcdc;
    border-radius: 5px;
    padding: 10px;
    margin: 0 20px 20px;
}
.courseTxt {
    position: relative;
}
.courseTxt .renewalTxt p {
    font-size:1.2rem;
    line-height: 1.4em;
    padding: 0;
}
.gakkaList li p {
    padding: 0;
}
.gakkaList li p.courseSetsumeiTxt {
    padding: 0 20px 10px;
}

/* syoudain */
.syoudaain {
    position: absolute;
    top:-95px;
    right: 20px;
}
.syoudaainClub {
    position: absolute;
    top:-106px;
    left: 170px;
}

@media screen and (max-width: 1024px) {
    .courseWrap {
        background-size: 400px auto, 230px auto;
    }
    .topTitleWrap p {
        font-size:1.4rem;
        padding: 10px 0 0 40px;
    }
    .gakkaCategory {
        margin: 60px 0 40px;
    }
    .gakkaCategory h3 {
        font-size:2.2rem;
    }
    .gakkaCategory h3 span {
        font-size: 1.4rem;
    }
    .gakkaList {
        margin: 0 10px;
    }
    .gakkaList li h4 {
        --viewport-from: 768;
        --viewport-to: 1024;
        --min-font-size:14;
        --max-font-size: 18;
    }
    .gakkaList li {
        width: 31%;
    }
    .gakkaList li p {
        font-size:1.4rem;
        line-height: 1.8em;
    }
    /* renewal */
    .renewal {
        font-size:1.2rem;
        padding: 2px 7px;
    }
    /* syoudain */
    .syoudaain {
        height: auto;
        width: 50px;
        top:-70px;
        right: 10px;
    }
    .syoudaainClub {
        height: auto;
        width: 50px;
        top:-92px;
    }
}

@media screen and (max-width: 1024px) {
    .gakkaLine {
        margin: 18px 20px 0 20px;
    }
}
@media screen and (max-width: 768px) {
    .courseWrap {
        background:  url("../images/top/bg_course_top.png") no-repeat left top #fbf7ed;
        background-size: 140px auto;
        padding: 30px 0;
    }
    .topTitleWrap {
        display: inline;
    }
    .topTitleWrap p {
        font-size:83%;
        line-height: 1.8em;
        padding: 15px 0 0;
    }
    .gakkaCategory {
        margin: 30px 0 20px;
    }
    .gakkaCategory h3 {
        font-size:125%;
        letter-spacing: 0;
    }
    .gakkaCategory h3 span {
        font-size: 1.2rem;
    }
    .gakkaLine {
        margin: 16px 16px 0 20px;
        width: 16px;
    }
    .gakkaList li {
        margin-bottom: 15px;
        width: 48%;
        padding: 0 0 15px;
    }
    .courseTxt {
        padding: 0 10px;
    }
    .gakkaList li h4 {
        font-size:1.4rem;
        margin: 0 0 5px;
        padding: 15px 0 0;
        text-align: left;
    }
    .gakkaList li p {
        font-size:1.2rem;
        line-height: 1.6em;
        padding: 0 ;
    }
    .courseDetail {
        display: flex;
    }
    .courseDetail img {
        height: 100px;
        width: 100px;
        object-fit: cover;
        margin: 15px 5px 15px;
    }
    .btnCourse {
        font-size:83%;
        margin: auto 10px 0;
    }
    .btnCourse a {
        padding: 7px 0;
    }
    /* renewal */
    .renewal {
        font-size:1.0rem;
        top:100px;
        left:15px;
        width: 100px;
    }
    .renewalTxt {
        padding: 5px;
        margin: 10px 0 20px;
    }
    .courseTxt {
        width: 100%;
    }
    .courseTxt .renewalTxt p {
        font-size:74%;
    }
    /* syoudain */
    img.syoudaain {
        object-fit: fill;
        height: auto;
        width: 40px;
        top:-36px;
        right: 10px;
        margin: 0;
    }
    .syoudaainClub {
        height: auto;
        width: 60px;
        top:-111px;
        left: 110px;
    }
    .gakkaList li p.courseSetsumeiTxt {
        padding: 0;
    }
}

@media screen and (max-width: 480px) {
    .gakkaCategory h3 {
        font-size:100%;
    }

    .gakkaList li {
        margin-bottom: 15px;
        width: 100%;
        padding: 0 0 15px;
    }
    .courseTxt {
        padding: 0 10px;
    }
    .gakkaList li h4 {
        font-size:1.4rem;
        margin: 0 0 5px;
        padding: 15px 0 0;
        text-align: left;
    }
    .gakkaList li p {
        font-size:1.2rem;
        line-height: 1.6em;
        padding: 0 ;
    }

    .gakkaLine {
        margin: 12px 16px 0 20px;
        width: 12px;
    }
    .syoudaainClub {
        height: auto;
        width: 50px;
        top:-92px;
        left: 105px;
    }

}

/* ==========================================================================
   Footer Menu
   ========================================================================== */
.footerMenuWrap {
    background-color: #f1f1f1;
    padding: 32px 0;
}
.footerMenuWrap .inner {
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1200px;
}
.footerMenuWrap .inner a {
    color: #214e9b;
}
.footerBoxLeft {
    display: flex;
    justify-content: space-between;
    width: 40%;
}
.footerBoxRight {
    display: flex;
    justify-content: space-between;
    width: 60%;
}
.footerBoxLeft .footerMenu {
    margin: 0 0 32px;
    width: 46%;
}
.footerBoxRight .footerMenu {
    margin: 0 0 32px;
    width: 30%;
}
.footerMenu li {
    border-bottom: 1px solid #e3e3e3;
    color:#214e9b;
    font-size: 1.6rem;
    font-weight: bold;
    padding: 16px 0;
}
.subMenuWrap {
    padding: 16px 0 0;
}
.footerSubMenu li {
    border-bottom: none;
    font-size: 1.3rem;
    font-weight: normal;
    padding: 6px 0;
}
.footerSubMenu li::before {
    font-size: 0.8rem;
    content: '─　';
}
.footerGakka {
    background-color: #c7e4f4;
    font-size: 1rem;
    font-weight: normal;
    text-align: center;
    display: inline-block;
    border-radius: 20px;
    padding: 0 10px;
}
.footerMenu li.footerMenuLine {
    border-bottom: none;
}

@media screen and (max-width: 1024px) {
    .footerMenu li {
        font-size: 1.4rem;
    }
    .footerSubMenu li {
        font-size: 1.2rem;
    }
}

@media screen and (max-width: 768px) {
    .footerMenuWrap {
        padding: 24px 0;
    }
    .footerMenuWrap .inner {
        flex-wrap: wrap;
    }
    .footerBoxLeft {
        flex-wrap: wrap;
        width: 48%;
    }
    .footerBoxRight {
        flex-wrap: wrap;
        width: 48%;
    }
    .footerBoxLeft .footerMenu {
        margin: 0;
        width: 100%;
    }
    .footerBoxRight .footerMenu {
        margin: 0;
        width: 100%;
    }
    .footerMenu li {
        font-size: 1.2rem;
        padding: 12px 4px;
    }
    .subMenuWrap {
        padding: 8px 0 0;
    }
    .footerSubMenu li {
        font-size: 1.1rem;
        padding: 8px 4px;
    }
    .footerGakka {

        margin-top: 8px;
    }
    .footerMenu li.footerMenuLine {
        border-bottom: 1px solid #e3e3e3;
    }
}




/* ==========================================================================
   Footer
   ========================================================================== */
footer.osu-footer {
	background: #004ea2;
	padding: 100px 10px;
}
footer.osu-footer .inner {
	display: flex;
	margin: 0 auto;
	max-width: 1200px;
    position: relative;
}
footer.osu-footer .inner p,small {
	color:#fff;
	padding: 0;
	margin: 0;
}
.footerLogo {
	padding: 7px 50px 0 0;
}
.footerAbout {
	display: flex;
    padding-right: 30px;
}
.footerSchool {
	padding-right: 30px;
}
.footerSchool p {
	--viewport-from: 480;
    --viewport-to: 1200;
    --min-font-size:14;
    --max-font-size: 18;
	line-height: 1.3em;
}
.footerSchool p span {
	--viewport-from: 480;
    --viewport-to: 1200;
    --min-font-size:10;
    --max-font-size: 12;
}
.footerAdd {
	padding: 5px 0 0;
}
.footerAdd p {
	--viewport-from: 480;
    --viewport-to: 1200;
    --min-font-size:12;
    --max-font-size: 14;
}
.footerCopyright {
	margin-left:auto;
}
.footerCopyright p,small  {
	font-size:1.0rem;
}
.footerCopyright .inner {
	display: flex;
	justify-content: flex-end;
}
.footerCopyright .inner img {
	margin-right: 17px;
}
.footerCopyright a {
    color:#fff;
}
.footerKibi {
    padding: 5px 0 0;
}
.footerKibi p {
    --viewport-from: 480;
    --viewport-to: 1200;
    --min-font-size:12;
    --max-font-size: 14;
}
.footerKibi p a {
    color:#fff;
}
.triangle {
    position: absolute;
    top: -116px;
    right:0;
    width: 0;
    height: 0;
    border-left: 16px solid transparent;
    border-right: 16px solid transparent;
    border-bottom: 16px solid #004ea2;
}
a.triangleLink {
    display: block;
}
a.triangleLink:hover {
      opacity: 1.0;
  filter: alpha(opacity=100);
  -ms-filter: "alpha(opacity=100)";
}

footer.entry-footer {
    margin-bottom: 0;
  }
  footer.entry-footer .edit-link {
    display: none;
  }

/* .entry-footer {
    display: none;
} */
.post-edit-link {
    display: none;
}
footer.entry-footer {
    background: none;
    padding: 0;
}
.entry-footer .edit-link::before {
    content: " ";
  }

  .entry-footer > span {
    border-top: none !important;
  }

@media screen and (max-width: 1024px) {
	footer.osu-footer {
		padding: 30px 10px 80px;
		text-align: center;
	}
	footer.osu-footer .inner {
		display: inline-block;
        width: 100%;
	}
	.footerLogo {
		padding: 0;
	}
	.footerLogo img {
		height: auto;
		width: 85px;
	}
	.footerAbout {
		padding: 30px 0;
		justify-content: center;
	}
	.footerSchool {
		text-align: left;
	}
	.footerAdd {
		text-align: left;
	}
    .footerAdd a {
        color:#fff;
    }
	.footerCopyright .inner {
		justify-content: center;
	}
    .footerKibi {
        display: flex;
        justify-content: center;
        padding: 5px 0 30px;
    }
    .footerKibiList {
        padding: 0 10px;
    }
    .triangle{
        top: -46px;
        right:8px;
        border-left: 16px solid transparent;
        border-right: 16px solid transparent;
        border-bottom: 16px solid #004ea2;
    }
}

@media screen and (max-width: 768px) {
	.footerLogo {
		padding: 0 0 20px;
	}
	.footerLogo img {
		height: auto;
		width: 75px;
	}
	.footerAbout {
		display: inline;
	}
	.footerCopyright {
		padding: 40px 0 0;
	}
    .footerKibi {
        justify-content: flex-start;
        flex-wrap: wrap;
        margin: 8px 0 0;
    }
    .footerKibiList {
        padding: 4px 30px 0 0;
        text-align: left;
        width: 100%;
    }
    .triangle{
        right:0;
    }
}
