@import url('https://fonts.googleapis.com/css2?family=Economica:ital,wght@0,400;0,700;1,400;1,700&family=Libre+Baskerville:wght@700&family=Quicksand:wght@400;500;700&display=swap');
:root {
    --ptaj-red: #ff2d2e;
    --ptaj-blue: #20203b;
    --ptaj-glauc: #547aa5;
    --ptaj-robin: #50d8d7;
    --ptaj-winkle: #d1d2f9;
    --ptaj-oxford: #234240;
    --ptaj-grey: #cccccc;
    --ptaj-body: "Quicksand", sans-serif;
    --ptaj-title: "Economica", sans-serif;
    --ptaj-serif: "Libre Baskerville", serif;
}
* { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
*:focus { outline: none; }
html, body { min-height: 100vh; margin: 0px; padding: 0px; }

body {
    background-color: var(--ptaj-blue);
    color: white;
    font-family: var(--ptaj-body);
    font-size: 18px;
    font-weight: 500;
}

input, select, button, textarea {
    font-family: inherit;
}

a {
    text-decoration: none;
    color: white;
}

a:hover {
    color: var(--ptaj-winkle);
}

#particles-js {
    position: fixed;
    z-index: -99999999999999999999;
    width: 100%;
    height: 100%;
}

.mg-r-10 { margin-right: 10px !important; }
.mg-r-15 { margin-right: 15px !important; }
.mg-r-20 { margin-right: 20px !important; }

.mg-b-20 { margin-bottom: 20px !important; }
.mg-b-30 { margin-bottom: 30px !important; }
.mg-b-50 { margin-bottom: 50px !important; }
.mg-b-80 { margin-bottom: 80px !important; }

.mg-t-10 { margin-top: 10px !important; }
.mg-t-20 { margin-top: 20px !important; }
.mg-t-30 { margin-top: 30px !important; }
.mg-t-40 { margin-top: 40px !important; }
.mg-t-50 { margin-top: 50px !important; }

#main {
    position: relative;
    width: 980px;
    margin: 0px auto;
}

@media all and (max-width: 1023px){
    #main {
        width: 100%;
        margin: 0px;
        /*padding: 20px;*/
    }
}

#main .top {
    display: flex;
    justify-content: stretch;
    align-items: stretch;
    padding: 30px 0px;
    column-gap: 30px;
    position: relative;
}

#main .top .logo {
    font-family: var(--ptaj-title);
    font-size: 1.5em;
    font-weight: 700;
    flex-grow: 1;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    overflow: hidden;
    color: white;
}

#main .top .logo-mq {
    font-family: var(--ptaj-serif);
    font-size: 1.2em;
    font-weight: 700;
    flex-grow: 1;
    display: flex;
    justify-content: flex-start;
    column-gap: 8px;
    align-items: center;
    background-color: rgba(255,45,46,0.8);
    overflow: hidden;
    color: white;
    white-space: nowrap;
    position: relative;
}

#main .top .logo-mq .mqtext {
    display: inline-block;
    white-space: nowrap;
    position: absolute;
}

@keyframes marquee {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-150%); }
}

#main .top .contact, #main .top .contact-ptp {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    column-gap: 20px;
    flex-basis: 300px;
    width: 300px;
    flex-shrink: 0;
}

#main .top .contact:hover, #main .top .contact-ptp:hover {
    cursor: pointer;
}

#main .top .contact > .icon, #main .top .contact-ptp > .icon {
    position: relative;
    width: 50px;
    display: block;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    border: solid 2px white;
}

#main .top .contact > .icon > img, #main .top .contact-ptp > .icon > img {
    display: block;
    width: 100%;
}

.backlink a {
    display: flex;
    align-items: center;
    column-gap: 15px;
}

@media all and (max-width: 1023px){
    #main .top {
        display: block;
        padding: 0px;
        margin-bottom: 20px;
        width: 100%;
    }

    #main .top .logo-mq {
        padding: 15px;
        margin-bottom: 15px;
    }
    #main .top .contact, #main .top .contact-ptp {
        justify-content: center;
        width: 100%;
    }
    #main .top .logo {
        justify-content: center;
        align-items: center;
        padding: 20px;
    }
    .backlink a {
        justify-content: center;
    }
}

#main .tiles {
    display: flex;
    flex-direction: column;
    row-gap: 20px;
    justify-content: stretch;
    align-items: stretch;
    overflow: hidden;
    position: relative;
}

#main .tiles .row {
    display: flex;
    column-gap: 20px;
    justify-content: stretch;
    align-items: stretch;
}

#main .tiles .row.center {
    justify-content: center;
    column-gap: 0px;
}

#main .tiles .row.h10 { height: 10vh; }
#main .tiles .row.h30 { height: 30vh; }
#main .tiles .row.h35 { height: 35vh; }
#main .tiles .row.h40 { height: 40vh; }
#main .tiles .row.h45 { height: 45vh; }
#main .tiles .row.h50 { height: 50vh; }

#main .tiles .row .box-8 {
    width: 67%;
}

#main .tiles .row .box-4 {
    width: 33%;
}

#main .tiles .row .box-3 {
    width: 25%;
}

#main .tiles .row .box-mini {
    width: 300px;
}

@media all and (max-width: 1023px){
    #main .tiles {
        padding: 20px;
    }
    #main .tiles .row {
        row-gap: 20px;
    }
    #main .tiles .row.h10 { height: 70px; }
    #main .tiles .row.h30 { height: 210px; }
    #main .tiles .row.h35 { height: 230px; }
    #main .tiles .row.h40 { height: 250px; }
    #main .tiles .row.h45 { height: 45vh; }
    #main .tiles .row.h50 { height: 50vh; }
}

@media all and (max-width: 699px){
    #main .tiles .row {
        height: auto !important;
        flex-wrap: wrap;
    }

    #main .tiles .row.h40 > .box {
        width: 100%;
        height: 200px;
    }

    #main .tiles .row.h30 {
        row-gap: 20px;
    }
    #main .tiles .row.h30 > .box {
        height: 180px;
        min-width: 40%;
        flex-grow: 1;
    }
    #main .tiles .row.h10 > .box-mini {
        width: 100%;
        padding: 20px 0px;
    }
}

#main .tiles .row .box, #main .tiles .more .box {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    opacity: 0.9;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

#main .tiles .row .box:hover {
    opacity: 1;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0px 2px 8px 0px #000;
    transform: translateY(-2px);
}

#main .tiles .row .box > .title {
    width: 100%;
    height: 100px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    row-gap: 20px;
    background-color: var(--ptaj-glauc);
    position: absolute;
    bottom: 0px;
    transform: translateY(40px);
    transition: all 0.3s ease;
    opacity: 0.9;
    z-index: 9999;
}

#main .tiles .row .box > .title > strong {
    text-align: center;
}

#main .tiles .row .box:hover > .title {
    transform: translateY(0px);
    transition: all 0.3s ease;
    opacity: 1;
    height: 100%;
}

#main .tiles .row .box:hover > .title > i:hover, #main .tiles .row .box:hover > .title > strong:hover {
    color: var(--ptaj-red);
}

#main .tiles .row .oxford {
    background-color: var(--ptaj-oxford);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    row-gap: 50px;
}

#main .tiles .row .oxford > button {
    font-size: 1em;
    font-weight: 700;
    height: 40px;
    border: solid 2px white;
    padding: 0px 20px;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    border-radius: 20px;
    background-color: rgba(0,0,0,0);
    color: white;
    text-transform: uppercase;
}

#main .tiles .row .oxford > button:hover {
    cursor: pointer;
}

@media all and (max-width: 1023px){
    #main .tiles .row .oxford {
        row-gap: 30px;
    }
    #main .tiles .row .oxford > img {
        display: block;
        width: 330px;
        margin-bottom: 50px;
    }
}

@media all and (max-width: 424px){
    #main .tiles .row .oxford > img {
        width: 250px;
    }
}

#main .tiles .row .others {
    background-color: var(--ptaj-winkle);
    font-family: var(--ptaj-title);
    font-size: 1.3em;
    font-weight: 700;
    text-transform: uppercase;
    display: flex;
    justify-content: center;
    align-items: center;
    column-gap: 15px;
    color: black;
}

#main .tiles .row .ptp {
    background-image: url(../img/tile_ptp.jpg);
}

#main .tiles .row .oxfordhome {
    background-image: url(../img/tile_oxford.jpg);
}

#main .tiles .row .homeschool {
    background-image: url(../img/tile_homeschool.jpg);
}

#main .tiles .row .coding {
    background-image: url(../img/tile_coding.jpg);
}

#main .tiles .row .explore {
    background-image: url(../img/tile_explore.jpg);
}

#main .tiles .row .ptp-main {
    background-image: url(../img/bigtile_ptp.jpg);
}

#main .tiles .row .explore::after {
    content: '';
    display: block;
    width: 80%;
    height: 100px;
    background-image: url(../img/obs.jpg);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 40px;
}

#main .tiles .row .studymy {
    background-image: url(../img/tile_studymy.jpg);
}

#main .tiles .more {
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: var(--ptaj-glauc);
    left: 0px;
    top: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    column-gap: 20px;
    row-gap: 20px;
}

@media all and (max-width: 699px){
    #main .tiles .more {
        flex-direction: column;
    }

    #main .tiles .row .explore::after {
        top: 0px;
    }
}

#main .tiles .more .box {
    display: block;
    width: 200px;
    height: 200px;
}

#main .tiles .more .box.books {
    background-image: url(../img/tile_books.jpg);
}

#main .tiles .more .box.spb {
    background-image: url(../img/tile_spb.jpg);
}

#main .tiles .more .box.engineer {
    background-image: url(../img/tile_engineer.jpg);
}

#main .tiles .more .box > .title {
    width: 100%;
    height: 100px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    row-gap: 20px;
    background-color: var(--ptaj-glauc);
    position: absolute;
    bottom: 0px;
    transform: translateY(40px);
    transition: all 0.3s ease;
    opacity: 0.9;
}

#main .tiles .more .box:hover > .title {
    transform: translateY(0px);
    transition: all 0.3s ease;
    opacity: 1;
    height: 100%;
}

#main .tiles .more .box:hover {
    opacity: 1;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0px 2px 8px 0px #000;
}

#main .tiles .more .box:hover > .title > i:hover, #main .tiles .more .box:hover > .title > strong:hover {
    color: var(--ptaj-red);
}

#main .tiles .more .close {
    position: absolute;
    display: inline-block;
    top: 20px;
    right: 20px;
    font-size: 3em;
}

#main .tiles .more .close:hover {
    cursor: pointer;
    color: var(--ptaj-red);
}

#main .section-title {
    font-size: 1.6em;
    text-align: center;
    font-family: var(--ptaj-title);
    font-weight: 700;
    text-transform: uppercase;
    margin: 150px 0px 50px;
    position: relative;
    padding-top: 20px;
    border-top: solid 3px white;
}

@media all and (max-width: 1023px){
    #main .section-title {
        margin: 50px 0px;
    }
}

#main .section-title::after {
    content: '';
    display: block;
    position: absolute;
    width: 100px;
    height: 6px;
    background-color: var(--ptaj-robin);
    left: 50%;
    top: 100%;
    transform: translate(-50%,15px);
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}

#main .fp-blog {
    display: flex;
    column-gap: 20px;
    justify-content: stretch;
}

#main .fp-blog .post {
    display: flex;
    flex-direction: column;
    width: 33.333334%;
}

@media all and (max-width: 1023px){
    #main .fp-blog {
        flex-direction: column;
        row-gap: 30px;
        justify-content: flex-start;
        align-items: center;
    }
    #main .fp-blog .post {
        width: 280px;
    }
}


#main .fp-blog .post:hover {
    cursor: pointer;
}

#main .fp-blog .post .p-img {
    position: relative;
    display: block;
    overflow: hidden;
    border: solid 2px white;
}

#main .fp-blog .post .p-img > img {
    display: block;
    width: 100%;
}

#main .fp-blog .post .p-img > span {
    width: 90%;
    height: 90%;
    background-color: var(--ptaj-blue);
    position: absolute;
    left: 5%;
    top: 100%;
    transform: translateY(-15px);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all 0.3s ease;
    font-size: 1em;
    text-align: center;
    padding: 20px;
}

#main .fp-blog .post:hover .p-img > span {
    transform: translateY(0px);
    top: 5%;
    transition: all 0.3s ease;
}

#main .fp-blog .post .title {
    text-align: center;
    display: flex;
    height: 80px;
    font-weight: 700;
    justify-content: center;
    align-items: center;
}

#main .fp-blog .post:hover .title {
    color: var(--ptaj-red);
}

#main .fp-blog .post .author {
    display: flex;
    justify-content: center;
    font-size: 0.85em;
    border-top: solid 1px var(--ptaj-glauc);
    border-bottom: solid 1px var(--ptaj-glauc);
    padding: 10px 0px;
}

#main .fp-blog .post .author > span:first-child {
    margin-right: 10px;
    padding-right: 10px;
    border-right: solid 1px var(--ptaj-glauc);
}

#main .fp-blog .post .author > span > i {
    margin-right: 10px;
}

#main .fp-links {
    margin: 20px 0px 30px;
}

#main .fp-links a {
    font-weight: 700;
}

#main .fp-links a:hover {
    color: var(--ptaj-red);
}

@media all and (max-width: 1023px){
    #main .fp-links {
        text-align: center;
    }
}

#main .footer {
    position: relative;
    background-color: white;
    margin-top: 100px;
    padding: 50px;
    color: var(--ptaj-glauc);
    font-size: 0.8em;
}

#main .footer > .cols {
    display: flex;
    justify-content: stretch;
    column-gap: 50px;
}

#main .footer > .cols > .left-foot {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

#main .footer > .cols > .left-foot > .logo {
    width: 200px;
    position: relative;
    margin-bottom: 30px;
}

#main .footer > .cols > .left-foot > .logo > img {
    display: block;
    width: 100%;
}

#main .footer > .cols > .right-foot {
    width: 400px;
    flex-shrink: 0;
}

@media all and (max-width: 1023px){
    #main .footer > .cols {
        flex-direction: column;
        row-gap: 20px;
    }
    #main .footer > .cols > .right-foot {
        width: 100%;
        flex-shrink: 0;
    }
}

#main .footer > .cols > .right-foot > .title {
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 30px;
    position: relative;
}

#main .footer > .cols > .right-foot > .title::after {
    content: '';
    display: block;
    position: absolute;
    width: 50px;
    height: 6px;
    background-color: var(--ptaj-robin);
    left: -3px;
    top: 100%;
    transform: translateY(6px);
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}

#main .footer > .cols > .right-foot > .links {
    display: flex;
    column-gap: 30px;
    justify-content: stretch;
}

#main .footer > .cols > .right-foot > .links > ul {
    list-style: none;
    padding: 0px;
    margin: 0px;
    flex-grow: 1;
}

#main .footer > .cols > .right-foot > .links > ul > li > a {
    color: var(--ptaj-glauc);
    padding: 5px 0px;
    display: block;
}

#main .footer > .cols > .right-foot > .links > ul > li > a:hover {
    color: var(--ptaj-red);
}

#main .footer > .foot-gmap {
    margin-top: 20px;
    border: solid 1px var(--ptaj-glauc);
}

#main .footer > .office {
    margin-top: 15px;
}

#main .footer > .office > span {
    font-weight: 700;
    display: block;
}

#main .footer > .office a {
    color: var(--ptaj-glauc);
}

#main .credit {
    margin-bottom: 60px;
    text-align: center;
    font-size: 0.75em;
    padding: 20px;
}

#main .page-menu {
    width: 100%;
    display: flex;
    justify-content: space-between;
}

#main .page-menu ul {
    list-style: none;
    margin: 0px;
    padding: 0px;
    display: flex;
    column-gap: 10px;
    margin-bottom: 20px;
}

#main .page-menu ul > li {
    position: relative;
    display: block;
}

#main .page-menu ul > li.filler {
    flex-grow: 1;
}

#main .page-menu ul > li:not(:last-child){
    padding-right: 10px;
}

#main .page-menu ul > li.sepr::after {
    content: '';
    display: block;
    position: absolute;
    width: 1px;
    height: 10px;
    background-color: var(--ptaj-glauc);
    right: 0px;
    top: 50%;
    transform: translateY(-50%);
}

#main .page-menu .toggle-menu {
    display: none;
}

#main .page-menu ul > li > a {
    padding: 10px 0px;
    display: block;
    position: relative;
}

#main .page-menu ul > li > a::after {
    content: '';
    display: block;
    position: absolute;
    width: 0px;
    height: 3px;
    background-color: var(--ptaj-robin);
    left: 0px;
    bottom: 0px;
    transition: all 0.1s ease;
}

#main .page-menu ul > li > a:hover {
    color: var(--ptaj-robin);
}

#main .page-menu ul > li > a:hover::after {
    width: 20px;
    transition: all 0.3s ease;
}

@media all and (max-width: 1023px){
    #main .page-menu {
        padding: 0px 20px;
    }
    #main .page-menu ul {
        flex-wrap: wrap;
        justify-content: center;
    }
    #main .page-menu ul > li.filler {
        flex-grow: 0;
    }
}

@media all and (max-width: 699px){
    #main .page-menu {
        flex-direction: column;
    }
    #main .page-menu .toggle-menu {
        display: block;
        margin: 5px auto;
    }
    #main .page-menu ul.menu-list {
        flex-direction: column;
        align-items: center;
        border: none;
        overflow: hidden;
        height: 0px;
    }
    #main .page-menu ul.menu-list > li {
        width: 100%;
    }
    #main .page-menu ul.menu-list > li > a {
        text-align: center;
    }
    #main .page-menu ul > li.sepr::after {
        content: '';
        display: none;
    }
}

#main .page-header {
    position: relative;
    overflow: hidden;
    background-color: var(--ptaj-blue);
    display: flex;
    justify-content: center;
    align-items: center;
}

#main .page-header > img {
    display: block;
    width: 100%;
    opacity: 0.7;
}

#main .page-header > img.full {
    opacity: 1;
}

#main .page-header > .title {
    position: absolute;
    left: 0px;
    bottom: 50px;
    padding: 20px 50px;
    font-family: var(--ptaj-title);
    font-size: 3em;
    font-weight: 700;
    text-transform: uppercase;
    background-color: var(--ptaj-blue);
    color: var(--ptaj-robin);
    -webkit-border-radius: 0px 30px 30px 0px;
    -moz-border-radius: 0px 30px 30px 0px;
    border-radius: 0px 30px 30px 0px;
}

#main .page-header > .title.has-sub {
  font-size: 2em;
}

#main .page-header > .title.has-sub > span {
  display: block;
  font-size: 0.7em;
  color: var(--ptaj-red);
}

#main .roller {
    position: relative;
    text-align: center;
    background-color: var(--ptaj-glauc);
    color: white;
    font-size: 1em;
    margin: 20px 0px;
    overflow: hidden;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

#main .roller .roll-note {
    height: 40px;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    position: absolute;
    left: 0px;
    top: 40px;
}

#main .roller .roll-note:first-child {
    left: 0px;
    top: 0px;
}

@media all and (max-width: 1023px){
    #main .page-header {
        display: block;
        width: 100%;
    }
    #main .page-header > img {
        opacity: 0.8;
    }
    #main .page-header > .title {
        position: relative;
        left: 0px;
        bottom: 0px;
        padding: 20px;
        font-size: 2em;
        text-transform: uppercase;
        -webkit-border-radius: 0px;
        -moz-border-radius: 0px;
        border-radius: 0px;
        display: block;
        text-align: center;
    }

    #main .roller {
        height: 60px;
    }

    #main .roller .roll-note {
        height: 60px;
        top: 60px;
    }
    #main .roller .roll-note:first-child {
        left: 0px;
        top: 0px;
    }
}

#main .page-header.mobile-header {
    display: none;
}

@media all and (max-width: 600px){
    #main .page-header.with-mobile {
        display: none;
    }
    #main .page-header.mobile-header {
        display: block;
    }
}

#main .special-text {
    font-size: 1.5em;
    text-align: center;
    padding: 30px;
    border: dashed 2px var(--ptaj-robin);
}

#main .inner-title, #main .error-title, #main .blog-title {
    font-family: var(--ptaj-title);
    font-size: 2em;
    font-weight: 700;
    margin: 80px 0px 50px;
    position: relative;
}

#main .inner-title.title-special {
    font-size: 3em;
    font-family: var(--ptaj-body);
    margin-top: 150px;
}

#main .big-title {
    font-family: var(--ptaj-body);
    font-size: 3em;
    font-weight: 800;
    text-align: center;
    text-transform: uppercase;
    margin: 50px 0px;
    color: yellow;
}

@media all and (max-width: 699px){
    #main .special-text {
        width: 95%;
        margin-left: auto;
        margin-right: auto;
        font-size: 1.3em;
    }
    #main .inner-title.title-special {
        font-size: 2.5em;
    }
}

#main .error-title { text-align: center; }

#main .blog-title {
    text-transform: uppercase;
    margin-bottom: 10px;
    font-size: 2.5em;
}

#main .info-strip {
    border-bottom: solid 2px var(--ptaj-robin);
    padding: 10px 0px;
    font-size: 0.85em;
    margin-bottom: 50px;
}

#main .inner-title::after {
    content: '';
    display: block;
    position: absolute;
    width: 50px;
    height: 6px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    background-color: var(--ptaj-robin);
    left: 0px;
    bottom: -12px;
}

#main .blog-contents {
    position: relative;
}

#main .blog-contents table {
    max-width: 100%;
}

#main .blog-contents img {
    display: block;
    max-width: 100%;
    height: auto;
}

#main .blog-footer {
    border-top: dotted 1px var(--ptaj-robin);
    margin-top: 80px;
    padding-top: 20px;
    padding-bottom: 50px;
    font-size: 0.9em;
    text-align: center;
}

#main .blog-footer i {
    margin-right: 10px;
}

@media all and (max-width: 1023px){
    #main .inner-title {
        text-align: center;
    }
    #main .inner-title::after {
        left: 50%;
        transform: translateX(-50%);
    }

    #main .blog-title, #main .info-strip {
        text-align: center;
    }

    #main .blog-title, #main .info-strip, #main .blog-contents {
        margin-left: 15px;
        margin-right: 15px;
    }
}

#main table.bloglist {
    width: 100%;
    border-collapse: collapse;
}

#main table.bloglist tr {
    border-top: dotted 1px white;
}

#main table.bloglist tr:last-of-type {
    border-bottom: dotted 1px white;
}

#main table.bloglist tr:hover {
    cursor: pointer;
    color: var(--ptaj-red);
}

#main table.bloglist td {
    vertical-align: top;
    padding: 15px 10px 15px 0px;
}

#main table.bloglist .feat img {
    display: block;
    width: 100px;
}

#main table.bloglist .post .title, #main table.bloglist .post .info {
    display: block;
}

#main table.bloglist .post .title {
    font-weight: 700;
    font-size: 1.2em;
}

#main table.bloglist .post .info {
    font-size: 0.85em;
}

@media all and (max-width: 1023px){
    #main table.bloglist {
        margin: 0px 15px;
        width: auto;
    }
}

@media all and (max-width: 699px){
    #main table.bloglist tr {
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    #main table.bloglist .post .title, #main table.bloglist .post .info {
        text-align: center;
    }
}

#main blockquote {
    position: relative;
    margin: 20px 0px;
    padding: 50px;
    background-color: var(--ptaj-glauc);
    text-align: center;
    font-size: 1.5em;
    line-height: 1.5em;
}

#main .teaser {
    position: relative;
    display: flex;
    column-gap: 20px;
    align-items: stretch;
}

#main .teaser .tease-card {
    display: flex;
    flex-direction: column;
    row-gap: 20px;
    position: relative;
    width: 34%;
    padding-bottom: 20px;
    border-bottom: dotted 1px white;
}

#main .teaser .tease-card-1 {
    display: block;
    position: relative;
    width: 34%;
}

#main .teaser .tease-card-2 {
    width: 66%;
    text-align: justify;
    line-height: 150%;
}

#main .teaser .tease-card > img, #main .teaser .tease-card-1 > img {
    display: block;
    width: 100%;
}

@media all and (max-width: 1023px){
    #main .teaser {
        align-items: flex-start;
        row-gap: 20px;
        flex-direction: column;
        width: 100%;
    }

    #main .teaser .tease-card-1 {
        width: 100%;
        padding: 30px;
    }

    #main .teaser .tease-card-2 {
        width: 100%;
        padding: 30px;
    }

    #main .teaser .tease-card {
        flex-direction: row;
        column-gap: 20px;
        position: relative;
        width: 100%;
        padding-bottom: 20px;
        border-bottom: dotted 1px white;
        align-items: flex-start;
    }

    #main .teaser .tease-card > img {
        display: block;
        width: 40%;
    }
}

@media all and (max-width: 699px){
    #main .teaser {
        padding: 20px;
    }
    #main .teaser .tease-card {
        flex-direction: column;
    }
    #main .teaser .tease-card > img {
        display: block;
        width: 100%;
    }
    #main .teaser .tease-card-1 {
        padding: 20px;
    }

    #main .teaser .tease-card-2 {
        padding: 20px;
    }
}

#main .block-buttons {
    display: flex;
    column-gap: 30px;
    row-gap: 30px;
}

#main .block-buttons > div {
    aspect-ratio: 1.5 / 1;
    background-color: var(--ptaj-glauc);
    flex-grow: 1;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border-bottom: solid 10px var(--ptaj-glauc);
}

#main .block-buttons > div.active {
    border-bottom: solid 10px var(--ptaj-red);
}

#main .block-buttons > div:hover {
    cursor: pointer;
    background-color: var(--ptaj-robin);
    border-bottom: solid 10px var(--ptaj-robin);
}

#main .block-buttons > div.active:hover {
    border-bottom: solid 10px var(--ptaj-red);
}

#main .block-buttons > div > img {
    display: block;
    width: 100%;
}

#main .block-buttons > div > span {
    font-family: var(--ptaj-title);
    text-align: center;
    font-size: 2em;
    padding: 40px 0px;
}

#main .collapsed-info {
    position: relative;
    width: 100%;
    padding: 20px;
    background-color: var(--ptaj-glauc);
    margin-top: 30px;
}

#main .collapsed-info .private-tables {
    display: none;
}

#main .usp {
    display: flex;
    position: relative;
    align-items: stretch;
    margin: 30px 0px;
    border: solid 3px var(--ptaj-winkle);
}

#main .usp-image {
    display: flex;
    flex-direction: column;
    position: relative;
    align-items: stretch;
    margin: 30px 0px;
}

#main .usp .usp-title {
    width: 300px;
    flex-grow: 0;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    padding: 30px;
    background-color: var(--ptaj-winkle);
    font-size: 1.3em;
    line-height: 1.5em;
    color: black;
    position: relative;
}

#main .usp-image .usp-pix {
    width: 100%;
    flex-grow: 0;
    flex-shrink: 0;
    position: relative;
}

#main .usp-image .usp-pix img {
    display: block;
    width: 100%;
}

#main .usp .usp-title > i.fa {
    display: block;
    position: absolute;
    font-size: 60px;
    color: var(--ptaj-glauc);
    right: 0px;
    top: 50%;
    transform: translate(50%, -50%);
    background-color: var(--ptaj-winkle);
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    border: solid 2px var(--ptaj-winkle);
}

#main .usp .usp-text {
    padding: 30px 30px 30px 80px;
    flex-grow: 1;
}

#main .usp-image .usp-text {
    padding: 50px 0px;
    flex-grow: 1;
}

@media all and (max-width: 1023px){
    #main .usp-image .usp-text {
        padding: 30px;
        flex-grow: 1;
    }
}

.usp-text > ul {
    list-style: none;
    padding: 0px;
    margin: 0px;
}

.usp-text > ul > li {
    display: block;
}

.usp-text > ul > li:not(:last-child){
    padding-bottom: 20px;
    margin-bottom: 20px;
    border-bottom: dotted 1px var(--ptaj-winkle);
}

.usp-text > ul > li > i {
    margin-right: 15px;
}

@media all and (max-width: 1023px){
    #main .usp {
        flex-direction: column;
        width: 100%;
        border: none;
        border-bottom: solid 3px var(--ptaj-winkle);
    }
    #main .usp .usp-title > i.fa {
        display: none;
    }
    #main .usp .usp-title {
        width: 100%;
    }
    #main .usp .usp-text {
        padding: 30px;
        flex-grow: 0;
        width: 100%;
    }

    .usp-text > ul {
        display: block;
        position: relative;
        width: 100%;
    }
}

#main .cta {
    display: flex;
    flex-direction: column;
    margin: 50px 0px;
    row-gap: 20px;
}

#main .cta > a {
    display: block;
    width: 100%;
    font-family: var(--ptaj-title);
    font-size: 3em;
    text-transform: uppercase;
    font-weight: 700;
    border: solid 1px black;
    background-color: var(--ptaj-robin);
    padding: 20px;
    transition: all 0.3s ease;
    color: black;
    text-align: center;
}

#main .cta > a:hover {
    cursor: pointer;
    background-color: var(--ptaj-red);
    color: white;
    transition: all 0.3s ease;
    box-shadow: 0px 0px 5px 0px black;
}

#main .cta .cta-text {
    display: flex;
    justify-content: center;
    column-gap: 10px;
}

#main .cta .cta-text > span {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2em;
    width: 500px;
}

#main .cta .cta-text > img {
    display: block;
    width: 200px;
}

#main .select-mix {
    display: flex;
    justify-content: stretch;
    column-gap: 20px;
    padding: 20px;
    border: solid 1px var(--ptaj-glauc);
    -webkit-border-radius: 15px 15px 0px 0px;
    -moz-border-radius: 15px 15px 0px 0px;
    border-radius: 15px 15px 0px 0px;
}

@media all and (max-width: 1023px){
    #main .cta .cta-text {
        flex-direction: column;
        align-items: center;
    }
    #main .cta .cta-text > span {
        width: 80%;
        text-align: center;
    }
    #main .select-mix {
        flex-direction: column;
        align-items: center;
    }
}

#main .select-mix > select {
    width: 34%;
    font-size: 1em;
    border: solid 1px black;
    padding: 5px;
}

#main .select-mix .hide-private {
    display: none;
}

#main .program-display {
    position: relative;
    background-color: white;
    border: solid 1px var(--ptaj-glauc);
    color: black;
}

#main .program-display > .program {
    padding: 30px;
    display: none;
}

@media all and (max-width: 1023px){
    #main .program-display {
        width: 100%;
    }
    #main .select-mix > select {
        width: 100%;
    }
}

#main .program-display > .program > .title {
    font-size: 1.3em;
    text-transform: uppercase;
    font-weight: 700;
    text-align: center;
    margin-bottom: 20px;
}

#main .program-display > .program > .prog-table {
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

#main .program-display > .program > .prog-table > .row {
    display: flex;
    justify-content: stretch;
    margin: 10px 0px;
    padding-top: 10px;
    border-top: dashed 1px var(--ptaj-glauc);
    column-gap: 10px;
}

@media all and (max-width: 1023px){
    #main .program-display > .program > .prog-table > .row {
        flex-direction: column;
        padding: 10px;
        border: dashed 1px var(--ptaj-glauc);
    }
}

#main .program-display > .program > .prog-table > .row:last-child {
    padding-bottom: 10px;
    border-bottom: dashed 1px var(--ptaj-glauc);
}

#main .program-display > .program > .prog-table > .row > .col-packs {
    width: 130px;
    flex-grow: 0;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding-right: 10px;
}

#main .program-display > .program > .prog-table > .row > .col-packs.no-class {
    width: 190px;
}

#main .program-display > .program > .prog-table > .row > .col-packs.longer {
    width: 360px;
}

#main .program-display > .program > .prog-table > .row > .col-packs > span {
    display: block;
    font-size: 0.75em;
}

#main .program-display > .program > .prog-table > .row > .col-class {
    width: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 0.9em;
}

#main .program-display > .program > .prog-table > .row > .col-subjects-row {
    display: flex;
    flex-direction: column;
    row-gap: 10px;
    flex-grow: 1;
}

#main .program-display > .program > .prog-table > .row > .col-subjects-pack,
#main .program-display > .program > .prog-table > .row > .col-subjects-row > .row {
    display: flex;
    justify-content: stretch;
    flex-grow: 1;
    column-gap: 15px;
}

@media all and (max-width: 1023px){
    #main .program-display > .program > .prog-table > .row > .col-packs {
        width: 100%;
    }
    #main .program-display > .program > .prog-table > .row > .col-class {
        width: 100%;
        display: block;
        margin-bottom: 20px;
    }
    #main .program-display > .program > .prog-table > .row > .col-packs.no-class {
        width: 100%;
        margin-bottom: 20px;
    }
    #main .program-display > .program > .prog-table > .row > .col-subjects-row {
        row-gap: 20px;
    }
    #main .program-display > .program > .prog-table > .row > .col-subjects-pack,
    #main .program-display > .program > .prog-table > .row > .col-subjects-row > .row {
        flex-direction: column;
        justify-content: flex-start;
    }
}

#main .program-display > .program > .prog-table > .row > .col-subjects-pack > .pack,
#main .program-display > .program > .prog-table > .row > .col-subjects-row > .row > .subj {
    border: solid 1px var(--ptaj-glauc);
    flex-grow: 1;
    padding: 15px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    display: flex;
    flex-direction: column;
    row-gap: 15px;
}

#main .program-display > .program > .prog-table > .row > .col-subjects-row > .row > .subj {
    row-gap: 0px;
}

#main .program-display > .program > .prog-table > .row > .col-subjects-pack > .pack > .subj {
    display: flex;
    flex-direction: column;
}

#main .program-display > .program > .prog-table > .row > .col-subjects-pack > .pack > .subj > span,
#main .program-display > .program > .prog-table > .row > .col-subjects-row > .row > .subj > span {
    font-size: 0.8em;
}

#main .program-display > .program > .prog-table > .row > .col-subjects-pack > .fees,
#main .program-display > .program > .prog-table > .row > .col-subjects-row > .row > .fees {
    width: 300px;
    flex-grow: 0;
    flex-shrink: 0;
    font-size: 0.9em;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

#main .program-display > .program > .prog-table > .row > .col-subjects-pack > .fees span,
#main .program-display > .program > .prog-table > .row > .col-subjects-row > .row > .fees span {
    font-weight: 700;
}

#main .program-display > .program > .prog-table > .row > .col-subjects-pack > .act,
#main .program-display > .program > .prog-table > .row > .col-subjects-row > .row > .act {
    width: 110px;
    flex-grow: 0;
    flex-shrink: 0;
    font-size: 0.9em;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

#main .program-display > .program > .notes {
    margin: 20px 0px;
    font-size: 0.9em;
}
#main .program-display > .program > .notes ul {
    margin: 0px;
}

#main .program-display > .program > .notes > span:not(:first-child){
    margin-top: 20px;
    display: block;
}

#main .program-display > .program > .notes table {
    border-collapse: collapse;
    width: 100%;
}

#main .program-display > .program > .notes table td {
    border: solid 1px var(--ptaj-glauc);
    text-align: center;
    vertical-align: top;
    padding: 15px;
}

#main .form-control {
    border: dashed 1px var(--ptaj-robin);
    padding: 30px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    position: relative;
    overflow: hidden;
}

#main .form-control .form-loading {
    position: absolute;
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.7);
    z-index: 99;
    display: none;
}

#main .form-control .form-loading > div {
    display: flex;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
    column-gap: 30px;
}

#main .form-control > .section {
    font-weight: 700;
    margin: 80px 0px 50px;
    position: relative;
}

#main .form-control > .section::after {
    content: '';
    display: block;
    position: absolute;
    width: 60px;
    height: 6px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    background-color: var(--ptaj-robin);
    bottom: 0px;
    left: 0px;
    transform: translateY(12px);
}

#main .form-control > .note {
    text-align: center;
    font-size: 1.2em;
    font-weight: 700;
    margin-bottom: 50px;
    position: relative;
}

#main .form-control > .note::after {
    content: '';
    display: block;
    position: absolute;
    width: 60px;
    height: 6px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    background-color: var(--ptaj-robin);
    bottom: 0px;
    left: 50%;
    transform: translate(-50%, 12px);
}

#main .form-control > .row {
    display: flex;
    flex-direction: column;
    justify-content: stretch;
}

#main .form-control > .row:not(:last-child){
    margin-bottom: 20px;
}

#main .form-control > .row > label {
    display: flex;
    flex-grow: 1;
    flex-shrink: 1;
    column-gap: 10px;
    align-items: center;
}

#main .form-control > .row > .note-row {
    display: flex;
    align-items: center;
    font-size: 0.8em;
    column-gap: 10px;
}

#main .form-control > .row > .note-row > span.w-200 {
    width: 200px;
    flex-grow: 0;
    flex-shrink: 0;
    display: block;
}

@media all and (max-width: 1023px){
    #main .form-control > .row {
        flex-direction: column;
        justify-content: flex-start;
        row-gap: 20px;
    }
    #main .form-control > .row > label {
        flex-direction: column;
        align-items: flex-start;
    }
    #main .form-control > .row > .note-row > span.w-200 {
        display: none;
    }
}

#main .form-control > .row > label > span {
    flex-grow: 0;
    flex-shrink: 0;
    display: block;
    text-align: right;
}

#main .form-control > .row > label > .w-100 { width: 100px !important; flex-grow: 0; flex-shrink: 0; }
#main .form-control > .row > label > .w-120 { width: 120px; flex-grow: 0; flex-shrink: 0; }
#main .form-control > .row > label > .w-140 { width: 140px; flex-grow: 0; flex-shrink: 0; }
#main .form-control > .row > label > .w-160 { width: 160px; flex-grow: 0; flex-shrink: 0; }
#main .form-control > .row > label > .w-180 { width: 180px; flex-grow: 0; flex-shrink: 0; }
#main .form-control > .row > label > .w-200 { width: 200px; flex-grow: 0; flex-shrink: 0; }
#main .form-control > .row > label > .w-220 { width: 220px; flex-grow: 0; flex-shrink: 0; }
#main .form-control > .row > label > .w-240 { width: 240px; flex-grow: 0; flex-shrink: 0; }
#main .form-control > .row > label > .w-260 { width: 260px; flex-grow: 0; flex-shrink: 0; }

@media all and (max-width: 1023px){
    #main .form-control > .row > label > span {
        text-align: left;
        width: 100%;
    }
    #main .form-control > .row > label > .w-100 { width: 100%; }
    #main .form-control > .row > label > .w-120 { width: 100%; }
    #main .form-control > .row > label > .w-140 { width: 100%; }
    #main .form-control > .row > label > .w-160 { width: 100%; }
    #main .form-control > .row > label > .w-180 { width: 100%; }
    #main .form-control > .row > label > .w-200 { width: 100%; }
    #main .form-control > .row > label > .w-220 { width: 100%; }
    #main .form-control > .row > label > .w-240 { width: 100%; }
    #main .form-control > .row > label > .w-260 { width: 100%; }
}

#main .form-control > .row > label > span.autocomplete,
#main .form-control > .row > label > div.choices {
    position: relative;
    flex-grow: 1;
}

#main .form-control > .row > label > div.choices {
    display: none;
    flex-wrap: wrap;
    column-gap: 20px;
    row-gap: 20px;
    text-align: left;
}

#main .form-control > .row > label > div.choices > input[type="checkbox"]{
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 160px;
    height: 45px;
    display: inline-block;
    background-color: white;
    font-size: 1em;
    margin: 0px;
    position: relative;
    border: none;
}

#main .form-control > .row > label > div.choices > input[type="checkbox"]::after {
    content: attr(data-txt);
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 150px;
    height: 39px;
    left: 5px;
    top: 3px;
    font-size: 0.9em;
    text-align: center;
}

#main .form-control > .row > label > div.choices > input[type="checkbox"]:checked {
    background-color: var(--ptaj-robin);
}

#main .form-control > .row > label > div.choices > input[type="checkbox"]:checked::before {
    content: '\2714';
    display: block;
    position: absolute;
    right: 0px;
    bottom: -5px;
    color: var(--ptaj-red);
}

#main .form-control > .row > label > span.autocomplete > .autocomplete_choice {
    display: block;
    position: absolute;
    z-index: 99;
    left: 0px;
    top: 100%;
    width: 100%;
}

#main .form-control > .row > label > span.autocomplete > .autocomplete_choice > span {
    border-bottom: solid 1px var(--ptaj-glauc);
    background-color: white;
    text-align: left;
    color: black;
    padding: 10px 15px;
    display: block;
    font-size: 0.9em;
}

#main .form-control > .row > label > span.autocomplete > .autocomplete_choice > span:hover {
    background-color: var(--ptaj-winkle);
    cursor: pointer;
}

#main .form-control > .row > label > input,
#main .form-control > .row > label > select,
#main .form-control > .row > label > textarea,
#main .form-control > .row > label > .autocomplete > input {
    flex-grow: 1;
    flex-shrink: 1;
    font-size: 1em;
    border: solid 1px var(--ptaj-glauc);
    padding: 10px 15px;
    font-weight: 700;
}

#main .form-control > .row > label > .autocomplete > input {
    width: 100%;
}

#main .form-control > .row > label > div.notes {
    border: dotted 1px rgba(255,255,255,0.5);
    max-width: 100%;
    flex-grow: 1;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    padding: 20px;
    font-size: 0.8em;
}

#main .form-control > .row > label > div.notes.note-lg{
    font-size: 1em;
}

#main .form-control > .row > label > input.w-200 { flex-basis: 200px; width: 200px; flex-grow: 0; }
#main .form-control > .row > label > input.w-250 { flex-basis: 250px; width: 250px; flex-grow: 0; }
#main .form-control > .row > label > input.w-300 { flex-basis: 300px; width: 300px; flex-grow: 0; }
#main .form-control > .row > label > input.w-350 { flex-basis: 350px; width: 350px; flex-grow: 0; }
#main .form-control > .row > label > input.w-400 { flex-basis: 400px; width: 400px; flex-grow: 0; }

@media all and (max-width: 1023px){
    #main .form-control > .row > label > input,
    #main .form-control > .row > label > select,
    #main .form-control > .row > label > textarea,
    #main .form-control > .row > label > .autocomplete > input {
        width: 100%;
    }
    #main .form-control > .row > label > input.w-200 { flex-basis: auto; width:100%; }
    #main .form-control > .row > label > input.w-250 { flex-basis: auto; width:100%; }
    #main .form-control > .row > label > input.w-300 { flex-basis: auto; width:100%; }
    #main .form-control > .row > label > input.w-350 { flex-basis: auto; width:100%; }
    #main .form-control > .row > label > input.w-400 { flex-basis: auto; width:100%; }
}

#main .form-control > .row button {
    width: 100%;
    font-size: 1.3em;
    font-family: var(--ptaj-title);
    text-transform: uppercase;
    font-weight: 700;
    padding: 10px;
    border: none;
    background-color: var(--ptaj-robin);
    color: black;
    transition: all 0.2s ease;
}

#main .form-control > .row button:hover {
    background-color: var(--ptaj-red);
    color: white;
    cursor: pointer;
    transition: all 0.2s ease;
}

#main .page-title {
    font-family: var(--ptaj-title);
    font-size: 3em;
    text-transform: uppercase;
    font-weight: 700;
    margin: 5px 0px 50px;
    padding: 30px 0px;
    border-top: solid 1px var(--ptaj-glauc);
    border-bottom: solid 6px var(--ptaj-robin);
}

@media all and (max-width: 1023px){
    #main .page-title {
        padding: 0px 20px;
        text-align: center;
    }
}

#main > .back-link {
    margin-top: 20px;
}

#main > .back-link > a {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    column-gap: 15px;
    padding: 5px 0px;
}

#main > .back-link > a:hover {
    color: var(--ptaj-red);
}

@media all and (max-width: 1023px){
    #main > .back-link {
        padding: 0px 20px 20px;
    }
    #main > .back-link > a {
        justify-content: center;
    }
}

#main > p {
    text-align: justify;
    line-height: 150%;
}

@media all and (max-width: 1023px){
    #main > p {
        padding: 0px 20px;
    }
}

#main > .sign {
    display: flex;
    flex-direction: column;
    position: relative;
    margin-top: 50px;
    line-height: 150%;
    align-items: flex-start;
    width: 250px;
}

#main > .sign > img {
    display: block;
    width: 100%;
    margin-bottom: 30px;
    border: solid 2px white;
    position: relative;
}

#main > .sign > .name {
    font-weight: 700;
    display: block;
    position: relative;
}

#main > .sign > .name::before {
    content: '';
    display: block;
    position: absolute;
    width: 100px;
    height: 6px;
    background-color: var(--ptaj-robin);
    left: 0px;
    top: -15px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}

#main > .sign > .caption {
    display: block;
    font-weight: 400;
    font-size: 0.8em;
}

@media all and (max-width: 1023px){
    #main > .sign {
        padding: 0px 20px;
    }
}

#main .para .smallnote {
    font-size: 0.8em;
}

#main .para > ul > li,
#main .para > ol > li {
    padding-left: 15px;
}

#main .para > ul > li:not(:last-child){
    margin-bottom: 0.8em;
}

#main .para > ul > li > ol {
    list-style-type: lower-roman;
}

#main .para > ul > li > ol > li,
#main .para > ol > li > ul > li {
    padding-left: 20px;
}

@media all and (max-width: 1023px){
    #main .para {
        padding: 0px 20px;
    }
}

#main .section-text {
    background-color: white;
    color: black;
    padding: 50px;
}

#main a.yellowbox {
    display: block;
    background-color: yellow;
    padding: 30px;
    text-align: center;
    color: black;
    font-weight: 600;
    font-size: 1.2em;
}

#main a.yellowbox:hover{
    color: var(--ptaj-red);
}

#main .flex-center {
    display: flex;
    justify-content: center;
    column-gap: 30px;
}

#main .flex-center img.logo {
    display: block;
    height: 100px;
}

#main .big-text {
    text-align: center;
    font-size: 40px;
}

.infotable {
    position: relative;
    display: none;
}

@media all and (min-width: 1024px){
    .infotable.desktop, .infotable.both {
        display: block;
    }
}

@media all and (max-width: 1023px){
    .infotable.mobile, .infotable.both {
        display: block;
        margin: 0px 15px;
    }
    .infotable .mhd {
        display: none;
    }
}

.infotable > table {
    width: 100%;
    border-collapse: collapse;
}

.infotable > table, .infotable > table th, .infotable > table td {
    border: solid 1px black;
}

.infotable > table thead {
    background-color: var(--ptaj-robin);
    color: black;
}

.infotable > table tbody {
    background-color: white;
    color: black;
}

.infotable > table th, .infotable > table td {
    padding: 5px 10px;
}

.infotable.desktop > table th:not(:first-of-type){
    width: 20%;
}

.infotable.mobile > table th:nth-of-type(2){
    width: 50%;
}

.infotable > table td.subhead {
    text-align: center;
    font-weight: 700;
}

.infotable > table.res-twocol tr td {
    width: 50%;
}

.infotable > table.res-threecol tr > td:first-child,
.infotable > table.res-twocol tr > td:first-child {
    font-weight: 700;
}

.infotable > table.res-threecol tr td > span,
.infotable > table.res-twocol tr td > span {
    display: block;
    font-size: 0.9em;
}

.infotable > table.notes td {
    font-size: 0.9em;
    padding: 20px 30px;
}

.infotable .table-close {
    text-align: center;
    margin: 50px 0px 20px;
}

.infotable .tbl-link a {
    display: block;
    width: 100%;
    height: 100%;
    text-align: center;
    color: var(--ptaj-blue);
    font-weight: 700;
}

.infotable .tbl-link a:hover {
    color: var(--ptaj-red);
}

.loading {
    display: none !important;
}

ol.terms > li {
    margin-bottom: 15px;
}

.pd-l-15 { padding-left: 15px !important; }
.tx-small { font-size: 0.8em; }

.points-col {
    display: flex;
    column-gap: 30px;
    justify-content: space-between;
    align-items: center;
}

.points-col > .ptscard {
    width: 50%;
    font-size: 1.5em;
}

.points-col > .ptscard:first-child {
    text-align: left;
}

.points-col > .ptscard:nth-child(2){
    text-align: right;
}

@media all and (max-width: 1023px){
    .points-col > .ptscard {
        padding: 0px 20px;
    }
}

@media all and (max-width: 879px){
    .points-col {
        margin-bottom: 30px;
    }
    .points-col.img-right {
        flex-direction: column-reverse;
        justify-content: flex-start;
        row-gap: 20px;
    }
    .points-col.img-left {
        flex-direction: column;
        justify-content: flex-start;
        row-gap: 20px;
    }
    .points-col > .ptscard {
        width: 100%;
        font-size: 1.4em;
        text-align: center !important;
    }
}

@media all and (max-width: 474px){
    .points-col > .ptscard {
        position: relative;
    }
    .points-col > .ptscard > img {
        display: block;
        width: 100%;
    }
}

.exp-col {
    display: flex;
    column-gap: 20px;
    align-items: stretch;
}

.exp-col > .expcard {
    width: 50%;
}

.exp-col .expcard {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 50px 10px;
    row-gap: 20px;
}

.exp-col > .txcard:first-child {
    width: 60%;
}

.exp-col > .txcard:last-child {
    width: 40%;
}

.exp-col .txcard {
    display: block;
    position: relative;
}

.exp-col .txcard > h4 {
    font-family: var(--ptaj-title);
    margin: 0px 0px 40px;
    font-size: 2em;
    position: relative;
}

.exp-col .txcard > h4::after {
    content: '';
    display: block;
    width: 100px;
    height: 8px;
    border-radius: 4px;
    background-color: var(--ptaj-robin);
    position: absolute;
    left: 0px;
    bottom: -20px;
}

.exp-col .txcard > img {
    display: block;
    width: 100%;
}

.exp-col .expcard:hover {
    cursor: pointer;
}

.exp-col .obs-card {
    position: relative;
    padding: 30px;
    background-color: white;
}

.exp-col .obs-card .card-title {
    color: var(--ptaj-glauc);
}

.exp-col .obs-card img {
    display: block;
    width: 100%;
}

.exp-col .camps-card {
    background-color: var(--ptaj-glauc);
}
.exp-col .camps-card > blockquote {
    margin: 0px !important;
    padding: 0px !important;
}

@media all and (max-width: 767px){
    .exp-col {
        flex-direction: column-reverse;
        row-gap: 20px;
    }
    .exp-col > .txcard:first-child {
        width: 100%;
    }

    .exp-col > .txcard:last-child {
        width: 100%;
    }

    #infos {
        padding: 20px;
    }
}

#sidewasap, #sidewasap-ptp {
    position: fixed;
    right: 40px;
    bottom: 120px;
    width: 54px;
    display: none;
    opacity: 0.6;
}

#sidewasap > img, #sidewasap-ptp > img {
    display: block;
    width: 100%;
}

#goTop {
    position: fixed;
    right: 40px;
    bottom: 50px;
    display: none;
    opacity: 0.6;
}

#sidewasap:hover, #sidewasap-ptp:hover, #goTop:hover {
    cursor: pointer;
    opacity: 0.9;
}

#oxford_learnmore {
    display: flex;
    flex-direction: column;
    row-gap: 30px;
    align-items: center;
    justify-content: center;
    padding: 50px;
    width: 100%;
    border: solid 5px var(--ptaj-robin);
    margin: 130px 0px 40px;
    position: relative;
    background-color: #ffffff;
    color: #000000;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    border-radius: 30px;
}

#oxford_learnmore > .lmheader {
    position: absolute;
    width: 500px;
    left: 50%;
    transform: translateX(-50%);
    top: -117px;
}


#oxford_learnmore > .lm {
    display: flex;
    font-size: 2em;
    width: 90%;
    align-items: center;
}

#oxford_learnmore > .lm > .qicon {
    font-size: 3em;
    color: var(--ptaj-robin);
    margin-right: 50px;
}

#oxford_learnmore > .lm > .quest {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    row-gap: 15px;
}

#oxford_learnmore > .lm > .quest > .qt {
    font-weight: 600;
}

#oxford_learnmore > .lm > .quest > .lmbtn {
    color: #ffffff;
    height: 60px;
    padding: 0px 20px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    border-radius: 30px;
    overflow: hidden;
    background-color: var(--ptaj-oxford);
    font-size: 0.9em;
    position: relative;
}

#oxford_learnmore > .lm > .quest > .lmbtn > span {
    display: flex;
    align-items: center;
    column-gap: 20px;
    height: 100%;
    z-index: 9999;
    position: relative;
}

#oxford_learnmore > .lm > .quest > .lmbtn::before {
    content: '';
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: var(--ptaj-red);
    right: 100%;
    top: 0px;
    transition: all 0.3s ease;
    z-index: 99;
}

#oxford_learnmore > .lm > .quest > .lmbtn:hover::before {
    right: 0px;
    transition: all 0.3s ease;
}

@media all and (max-width: 669px){
    #oxford_learnmore {
        justify-content: flex-start;
        margin: 100px 0px 40px;
    }

    #oxford_learnmore > .lmheader {
        width: 80%;
        top: -77px;
    }

    #oxford_learnmore > .lm {
        font-size: 1.5em;
        flex-direction: column;
        align-items: center;
    }

    #oxford_learnmore > .lm > .qicon {
        font-size: 2em;
        margin-right: 0px;
    }

    #oxford_learnmore > .lm > .quest {
        align-items: center;
    }

    #oxford_learnmore > .lm > .quest > .qt {
        text-align: center;
    }
}

@media all and (max-width: 424px){
    #oxford_learnmore > .lmheader {
        top: -69px;
    }
}

@media all and (max-width: 374px){
    #oxford_learnmore > .lmheader {
        top: -60px;
    }
}

#myoffers {
    position: relative;
    width: 100%;
    margin: 100px auto 50px;
}

#myoffers > img {
    display: block;
    width: 100%;
}

#myoffers .offers-btn {
    position: absolute;
    display: flex;
    flex-direction: column;
    row-gap: 10px;
    right: 50px;
    bottom: 40px;
}

#myoffers .offers-btn > a {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 250px;
    height: 80px;
    background-color: var(--ptaj-robin);
    font-size: 1.5em;
    padding: 0px 20px;
    color: var(--ptaj-oxford);
    font-weight: 600;
    transition: all 0.3s ease;
}

#myoffers .offers-btn > a:hover {
    background-color: var(--ptaj-oxford);
    color: #ffffff;
    transition: all 0.3s ease;
}

@media all and (max-width: 1023px){
    #myoffers .offers-btn {
        bottom: 30px;
    }
    #myoffers .offers-btn > a {
        height: 70px;
    }
}

@media all and (max-width: 669px){
    #myoffers {
        margin: 100px auto;
    }

    #myoffers .offers-btn {
        flex-direction: row;
        justify-content:stretch;
        right: 0px;
        bottom: -60px;
        width: 100%;
        column-gap: 5px;
        padding: 5px;
    }

    #myoffers .offers-btn > a {
        justify-content: center;
        padding: 0px;
        width: auto;
        flex-grow: 1;
    }
}

#specialdeal {
    display: block;
    position: relative;
    width: 100%;
    aspect-ratio: 1.77 / 1;
    overflow: hidden;
}

#specialdeal a {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
}

#specialdeal a > img {
    display: block;
    width: 100%;
    transition: all 0.1s ease;
}

#specialdeal a:hover > img {
    width: 107%;
    transition: all 0.3s ease;
}

#f2fsupport {
    position: relative;
    width: 100%;
    margin-top: 50px;
}

#f2fsupport > img {
    display: block;
    width: 100%;
}

#f2fsupport > a {
    display: block;
    position: absolute;
    background-color: var(--ptaj-robin);
    color: #000000;
    width: 350px;
    right: 30px;
    bottom: 20px;
    padding: 15px 20px;
    text-align: center;
    font-weight: 600;
    text-transform: uppercase;
}

#f2fsupport > a:hover {
    background-color: var(--ptaj-red);
    color: #ffffff;
}

@media all and (max-width: 1023px){
    #f2fsupport > a {
        right: 50%;
        bottom: 0px;
        transform: translate(50%,50%);
    }
}

@media all and (max-width: 669px){
    #f2fsupport > a {
        transform: translate(50%,80%);
    }
}

@media all and (max-width: 374px){
    #f2fsupport > a {
        right: 0px;
        bottom: -80px;
        transform: translate(0%,0%);
        width: 100%;
    }
}

.exp-download {
    background-color: var(--ptaj-winkle);
    text-align: center;
    font-size: 1.5em;
    padding: 30px 20px;
    color: black;
    margin-bottom: 30px;
}

.exp-download > a {
    border-bottom: solid 2px var(--ptaj-red);
    color: black;
    font-weight: bold;
}

.exp-download > a:hover {
    color: var(--ptaj-glauc);
}

.exp-programs {
    position: relative;
    overflow: hidden;
}

.exp-programs > img {
    display: block;
    width: 100%;
}

.exp-programs > .pg-contents {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0px;
    top: 0px;
    display: flex;
    justify-content: space-between;
}

.exp-programs > .pg-contents > .pg-title {
    display: flex;
    flex-direction: column;
    text-transform: uppercase;
    padding: 50px;
    font-family: var(--ptaj-title);
    font-weight: 700;
}

.exp-programs > .pg-contents > .pg-title > span {
    font-size: 4em;
    padding: 10px;
}

.exp-programs > .pg-contents > .pg-title > span.bg {
    background-color: var(--ptaj-robin);
}

.exp-programs > .pg-contents > .pg-buttons {
    padding: 50px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-end;
    row-gap: 30px;
}

.exp-programs > .pg-contents > .pg-buttons > a {
    font-size: 1.3em;
    font-weight: 700;
    width: 320px;
    height: 80px;
    background-color: white;
    color: black;
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;
    border-radius: 40px;
    padding: 0px 80px 0px 40px;
}

.exp-programs > .pg-contents > .pg-buttons > a > i {
    position: absolute;
    right: 0px;
    font-size: 58px;
    right: 10px;
    color: #625f93;
}

.exp-programs > .pg-contents > .pg-buttons > a:hover > i {
    color: var(--ptaj-red);
}

.exp-programs .summercamp-dates {
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0px;
    top: 100%;
    background-color: var(--ptaj-glauc);
    color: white;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    padding-top: 50px;
    row-gap: 10px;
}

.exp-programs .summercamp-dates > span {
    margin-bottom: 20px;
}

.exp-programs .summercamp-dates > a.listDates {
    font-size: 1.5em;
    padding: 10px;
    width: 300px;
    text-align: center;
    border: solid 2px white;
}

.exp-programs .summercamp-dates > a.closeDates {
    position: absolute;
    right: 20px;
    top: 20px;
    color: white;
    font-size: 2.5em;
}

.exp-programs .summercamp-dates > a.closeDates:hover {
    color: var(--ptaj-red);
}

@media all and (max-width: 1023px){
    .exp-programs > .pg-contents > .pg-title {
        padding: 25px;
    }
    .exp-programs > .pg-contents > .pg-buttons {
        padding: 25px;
    }
}

@media all and (max-width: 719px){
    .exp-programs {
        margin-bottom: 50px;
    }
    .exp-programs > .pg-contents {
        /*height: 100%;*/
        flex-direction: column;
        position: relative;
    }
    .exp-programs > .pg-contents > .pg-title {
        padding: 10px 25px;
        align-items: center;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
    }
    .exp-programs > .pg-contents > .pg-title > span {
        font-size: 2.7em;
    }
    .exp-programs > .pg-contents > .pg-buttons {
        padding: 20px;
        align-items: center;
        row-gap: 20px;
    }
    .exp-programs > .pg-contents > .pg-buttons > a {
        font-size: 1.2em;
    }
}

@media all and (max-width: 374px){
    .exp-programs > .pg-contents > .pg-buttons > a {
        font-size: 1em;
        width: 99%;
    }
}

.corporate-header {
    position: relative;
}

.corporate-header > .hdtitle {
    position: absolute;
    width: 45%;
    height: 100%;
    padding: 50px 30px;
    right: 0px;
    top: 0px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-end;
    font-size: 3.5em;
    font-weight: 700;
    font-family: var(--ptaj-title);
}

.corporate-header > .hdtitle > span {
    padding: 15px;
}

.corporate-header > .hdtitle > span.bg {
    background-color: var(--ptaj-glauc);
}

.corporate-header > .hdtitle > .sub {
    font-family: var(--ptaj-body);
    font-size: 16px;
    text-align: right;
}

.corporate-feature {
    display: flex;
    position: relative;
    background-color: var(--ptaj-winkle);
    padding: 20px 0px 20px 20px;
}

.corporate-feature > div {
    width: 50%;
    position: relative;
}

.corporate-feature > .image > img {
    display: block;
    width: 100%;
}

.corporate-feature > .text {
    padding: 0px 20px;
    color: black;
}

.corporate-feature > .text > .foot {
    display: flex;
    column-gap: 20px;
}

.corporate-feature > .text > .foot > .locicon {
    font-size: 34px;
    background-color: var(--ptaj-red);
    color: white;
    height: 50px;
    width: 50px;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.corporate-proglists {
    position: relative;
    margin: 30px 0px;
}

.corporate-proglists > img {
    display: block;
    width: 100%;
}

.corporate-proglists > .content {
    position: absolute;
    display: flex;
    width: 100%;
    height: 600px;
    left: 0px;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(255,255,255,0.7);
}

.corporate-proglists > .content > span {
    width: 50%;
    padding: 30px;
}

.corporate-proglists > .content > .titles {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-end;
    color: black;
    font-size: 3em;
    font-weight: 700;
}

.corporate-proglists > .content > .titles > span {
    padding: 0px 15px;
}

.corporate-proglists > .content > .titles > span.bg {
    background-color: var(--ptaj-robin);
}

.corporate-proglists > .content > .list {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    color: black;
}

.corporate-proglists > .content > .list > ul {
    list-style: none;
    padding: 0px;
}

.corporate-proglists > .content > .list > ul > li {
    background-color: var(--ptaj-blue);
    color: white;
    padding: 10px 15px;
    border-bottom: solid 5px var(--ptaj-glauc);
}

.corporate-proglists > .content > .list > ul > li:not(:last-child){
    margin-bottom: 10px;
}

.corporate-contact {
    position: relative;
}

.corporate-contact > img {
    display: block;
    width: 100%;
}

.corporate-contact > .contents {
    position: absolute;
    width: 50%;
    height: 100%;
    right: 0px;
    top: 0px;
    color: black;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    padding: 50px;
}

.corporate-contact > .contents > span {
    font-size: 2.5em;
    font-weight: 700;
    padding: 10px;
}

.corporate-contact > .contents > span.bg {
    background-color: var(--ptaj-robin);
}

.corporate-contact > .contents > a {
    background-color: var(--ptaj-winkle);
    color: black;
    padding: 10px 20px;
    font-weight: 700;
    margin-top: 20px;
}

.corporate-contact > .contents > a:hover {
    background-color: var(--ptaj-red);
}

.corporate-gallery {
    width: 100%;
    height: 330px;
    position: relative;
    background-color: var(--ptaj-grey);
    display: flex;
    align-items: center;
    justify-content: center;
}

.corporate-gallery .scroll-btn {
    position: absolute;
    color: black;
    font-size: 3em;
    top: 50%;
    transform: translateY(-50%);
    z-index: 9;
}

.corporate-gallery .scroll-btn:hover {
    color: var(--ptaj-glauc);
    cursor: pointer;
}

.corporate-gallery .scroll-btn.btn-prev {
    left: 30px;
}

.corporate-gallery .scroll-btn.btn-next {
    right: 30px;
}

.corporate-gallery .container {
    position: relative;
    width: 720px;
    height: 300px;
    overflow: hidden;
}

.corporate-gallery .container .slider {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 30px;
    padding: 10px 30px;
    position: absolute;
    top: 0px;
    left: 0px;
}

.corporate-gallery .container .slider > a {
    position: relative;
    width: 200px;
    display: block;
    flex-shrink: 0;
    flex-grow: 0;
    border: solid 1px var(--ptaj-blue);
}

.corporate-gallery .container .slider > a::after {
    content: attr(data-num);
    display: flex;
    justify-content: flex-start;
    align-items: flex-end;
    padding: 0px 0px 20px 20px;
    width: 60px;
    height: 60px;
    border-radius: 0px 100% 0px 0px;
    font-size: 30px;
    background-color: var(--ptaj-winkle);
    position: absolute;
    left: 0px;
    bottom: 0px;
    color: black;
}

.corporate-gallery .container .slider > a > img {
    display: block;
    width: 100%;
    opacity: 0.8;
}

@media all and (max-width: 1023px){
    .corporate-gallery .container {
        width: 490px;
    }
}

@media all and (max-width: 767px){
    .corporate-gallery .container {
        width: 260px;
    }
}

@media all and (max-width: 759px){
    .corporate-header > .hdtitle {
        position: relative;
        width: 100%;
        height: auto;
        padding: 0px;
        display: flex;
        justify-content: flex-start;
        align-items: center;
        font-size: 3em;
    }
    .corporate-header > .hdtitle > span {
        padding: 15px;
        display: block;
        width: 100%;
    }
    .corporate-header > .hdtitle > .sub {
        text-align: justify;
    }
    .corporate-feature {
        display: flex;
        flex-direction: column;
        row-gap: 20px;
        padding: 20px;
    }
    .corporate-feature > div {
        width: 100%;
    }
    .corporate-proglists > .content {
        position: relative;
        display: flex;
        flex-direction: column;
        width: 100%;
        height: auto;
        left: 0px;
        top: 0px;
        transform: none;
        background-color: rgba(255,255,255,0.8);
    }
    .corporate-proglists > .content > span {
        width: 100%;
        padding: 30px;
    }
    .corporate-proglists > .content > span:first-child {
        padding-bottom: 0px;
    }
    .corporate-contact > .contents {
        position: relative;
        width: 100%;
        height: auto;
        color: black;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        padding: 0px 20px 30px;
        background-color: white;
    }
}

@media all and (max-width: 374px){
    .corporate-gallery .scroll-btn {
        font-size: 2.5em;
    }
    .corporate-gallery .scroll-btn.btn-prev {
        left: 20px;
    }

    .corporate-gallery .scroll-btn.btn-next {
        right: 20px;
    }
    .corporate-gallery .container .slider > a {
        width: 180px;
        margin: 0px 10px;
    }
}

.summercamp-header:hover {
    cursor: pointer;
}

.form-control span.select2 {
    flex-grow: 1 !important;
}

.custom-select2 {
    padding: 8px 10px;
    font-size: 1em;
    border: solid 1px var(--ptaj-glauc) !important;
    display: block !important;
    border-radius: 0px !important;
    height: auto !important;
    font-weight: 700;
    color: black;
}

.custom-select2-100 {
    padding: 8px 10px;
    font-size: 1em;
    border: solid 1px var(--ptaj-glauc) !important;
    display: block !important;
    border-radius: 0px !important;
    height: auto !important;
    font-weight: 700;
    color: black;
}

.custom-select2 > span, .custom-select2-100 > span {
    text-align: left;
}

.custom-select2 .select2-selection__arrow, .custom-select2-100 .select2-selection__arrow {
    display: none;
}

.custom-select2 .select2-container .select2-dropdown, .custom-select2 .select2-container .select2-dropdown-100 {
    color: black;
}

label[for="phone_num"] > span.select2 {
    flex-grow: 0 !important;
}

.summercamp-sched {
    background-color: white;
    color: black;
    position: relative;
    display: block;
    padding: 10px;
}

.summercamp-sched > .row {
    display: flex;
    border: solid 1px #ccc;
    position: relative;
    align-items: stretch;
}

.summercamp-sched > .row:not(:first-of-type) {
    border-top: none
}

.summercamp-sched > .row > .day {
    width: 200px;
    display: flex;
    flex-direction: column;
    row-gap: 5px;
    justify-content: center;
    align-items: center;
    border-right: dashed 1px #ccc;
    padding: 10px;
}

.summercamp-sched > .row > .day > a {
    color: var(--ptaj-glauc);
    font-size: 1.2em;
}

.summercamp-sched > .row > .day > a:hover {
    color: var(--ptaj-robin);
}

.summercamp-sched > .row > .day > a.prog-hide {
    display: none;
}

.summercamp-sched > .row > .prog > ul li:not(:first-child){
    display: none;
}

.study-partners {
    display: flex;
    position: relative;
    background-color: white;
}

.study-partners > div {
    width: 50%;
    flex-grow: 0;
    flex-shrink: 0;
    position: relative;
}

.study-partners > .feature > img {
    display: block;
    width: 100%;
}

.study-partners > .two-partners {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
    padding: 50px;
    color: black;
    row-gap: 50px;
}

.study-partners > .two-partners > .part > .name {
    display: block;
    width: 100%;
    text-transform: uppercase;
    text-align: center;
    font-weight: 800;
    padding-bottom: 20px;
    border-bottom: solid 2px #333;
}

.study-partners > .two-partners > .part > a {
    display: block;
    width: 100%;
}

.study-partners > .two-partners > .part > a > img {
    display: block;
    width: 300px;
    margin: 10px auto;
}

.qrcodes {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: white;
    column-gap: 20px;
    row-gap: 20px;
}

.qrcodes > a {
    display: block;
    position: relative;
    width: 50%;
    padding: 30px;
}

.qrcodes > a > img {
    display: block;
    width: 100%;
}

.banner-image {
    position: relative;
}

.banner-image img {
    display: block;
    width: 100%;
}

@media all and (max-width: 767px){
    .study-partners {
        flex-direction: column;
    }
    .study-partners > div {
        width: 100%;
    }
    .qrcodes {
        flex-direction: column;
    }

    .qrcodes > a {
        width: 80%;
    }
}

.smlgroup-container {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    position: relative;
}

.smlgroup-container > .smlgroup-item {
    border: solid 1px var(--ptaj-glauc);
    padding: 15px;
    text-align: center;
    flex-grow: 1;
    flex-shrink: 1;
    min-width: 40%;
}

.smlgroup-container > .smlgroup-item > .smlgroup-price {
    padding-bottom: 15px;
    margin-bottom: 15px;
    border-bottom: dashed 1px var(--ptaj-glauc);
}

.form-control > .row > label > select option.close {
    color: #f00;
}

.payfpx {
    background-color: white;
    color: black;
    padding: 5px 10px;
    display: flex;
    align-items: center;
    column-gap: 5px;
    border-radius: 4px;
}

.payfpx > input[type="checkbox"]{
    width: 20px;
    height: 20px;
}

.payfpx > img {
    display: block;
    width: 50px;
}

.payment-confirm {
    border: solid 3px white;
    margin-bottom: 50px;
    padding: 50px;
}

#bootcampfee {
    position: relative;
    margin-right: 10px;
}

#bootcampfee::after {
    content: '';
    display: block;
    position: absolute;
    width: calc(100% + 10px);
    height: 2px;
    border-radius: 1px;
    background-color: red;
    left: -5px;
    top: 50%;
    transform: translateY(-50%);
}

.inner-scroll {
    display: inline-block;
    background-color: var(--ptaj-oxford);
    border: solid 1px var(--ptaj-robin);
    padding: 0px 15px;
    border-radius: 15px;
}

#redeem {
    position: relative;
    background-color: #fcfe55;
    width: 100%;
    height: 300px;
    padding: 50px;
    color: var(--ptaj-blue);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    row-gap: 5px;
    margin-top: 50px;
}

#redeem h3 {
    text-align: center;
    margin: 0px;
    z-index: 999;
}

#redeem::before {
    content: '';
    display: block;
    position: absolute;
    left: 13px;
    top: 13px;
    width: calc(100% - 30px);
    height: calc(100% - 30px);
    border: dashed 2px black;
}

#redeem input {
    border: dashed 2px var(--ptaj-red);
    font-size: 20px;
    text-align: center;
    padding: 10px 25px;
    font-weight: 500;
    height: 50px;
    width: 300px;
    border-radius: 25px;
    margin-top: 20px;
    z-index: 999;
}

#redeem button {
    font-size: 16px;
    font-weight: 600;
    border: solid 1px var(--ptaj-blue);
    background-color: var(--ptaj-blue);
    color: white;
    padding: 5px 40px;
    height: 38px;
    border-radius: 19px;
    z-index: 999;
}

#redeem button:hover {
    cursor: pointer;
}

#redeemtop {
    position: relative;
    margin: 30px 0px;
    display: flex;
    justify-content: center;
    align-items: center;
    column-gap: 30px;
}

#redeemtop > img {
    display: block;
    height: 50px;
}

#redeemtitle {
    background-color: white;
    padding: 30px 50px;
    font-size: 30px;
    color: black;
    text-align: center;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 50px;
}

#redeemimages {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 30px;
    padding: 50px;
    border: dashed 2px white;
}

#redeemimages > .preview {
    display: block;
    position: relative;
    min-width: 150px;
    max-width: 200px;
    aspect-ratio: 1 / 1;
    border: solid 1px white;
    background-repeat: no-repeat;
    background-size: cover;
    overflow: hidden;
}

#redeemimages > .preview > span {
    position: absolute;
    width: 100%;
    left: 0px;
    bottom: 0px;
    text-align: center;
    padding: 10px;
    background-color: rgba(0, 0, 0, 0.7);
}

#redeempdf {
  width: 100%;
  border: solid 1px white;
  position: relative;
}

#redeempdf > .loader {
  width: 100%;
  height: 300px;
  display: flex;
  column-gap: 20px;
  align-items: center;
  justify-content: center;
}

#redeempdf > object.pdf {
  display: none;
  width: 100%;
  height: 100vh;
}

.preloadpdf {
  visibility: hidden;
}

@media all and (max-width: 1023px){
    #redeem {
        margin: 20px;
        width: auto;
    }
}

@media all and (max-width: 424px){
    #redeem {
        padding: 30px;
    }
}

.promo-banner {
    display: block;
    width: 100%;
    margin: 20px 0 30px;
}

.promo-banner img {
    display: block;
    width: 100%;
    border: solid 2px white;
}

.seperator {
    width: 100%;
    height: 2px;
    background-color: var(--ptaj-glauc);
    margin: 80px 0px 30px;
}