@charset 'utf-8';
/* - general
 ------------------------------------------------------------ */

.rakujin {
    font-size: 14px;
    -webkit-text-size-adjust: 100%;
    background-color: #fff;
    width: 100%;
}
/* - ## media screen - */

@media screen and (min-width:769px) {
    .rakujin {
        font-size: 16px;
    }
}
.rakujin>div {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
}
.rakujin[class*=grid], .rakujin [class*=grid] {
    margin: 0 auto;
}
.rakujin header {
    width: 100%;
}
.rakujin .wrapping {
    width: 100%;
    max-width: 980px;
    margin: 0 auto;
}
.rakujin [class*=grid-].wrapping {
    width: 100%;
    max-width: 980px;
    margin: 0 auto;
}
.rakujin .for-pc {
    display: none;
}
.rakujin h2 {
    font-size: 1.5em;
    font-weight: normal;
    line-height: 1.2;
    margin: 0 0 .5em;
}
.rakujin h3 {
    font-size: 1.3em;
    font-weight: normal;
    line-height: 1.2;
    margin: 0 0 .5em;
    color: #146eb3;
    text-decoration-line: underline;
}
.rakujin p {
    font-size: .88em;
    line-height: 1.7;
    margin: 0 0 1em;
    letter-spacing: 1px;
}
.rakujin p em {
    font-weight: 800;
    font-style: normal;
    color: #494e6b;
}
.rakujin a {
    color: #555;
}
.rakujin .box p {
    margin: 0;
    padding: .6em 0 0;
    border-top: 1px dashed #ccc;
}
.rakujin .img {
    padding: .5em;
    border: 14px solid #f9f9f9;
    box-shadow: 0 2px 4px #ece9e9;
    margin: 0 0 1em;
}
.rakujin .white-space span:not(.eccetto) {
    white-space: nowrap;
    display: inline-block;
}
/* - purchase
 ------------------------------------------------------------ */

.rakujin [class*=purchase] {
    width: 100%;
    padding: 2em;
    background-color: rgba(186, 189, 183, .1);
}
.rakujin [class*=purchase] p {
    margin: 1em 0;
}
.rakujin [class*=purchase] .btn-primary {
    display: block;
    margin: 0 auto;
    border: none;
    border-radius: 2px;
    background-color: #02afb9;
    padding: 1em;
    box-shadow: 0 1px 1px #dedede;
}
.rakujin [class*=purchase] .btn-primary:hover {
    background-color: #51c1ce;
}
.rakujin [class*=purchase] .col:nth-of-type(3) .btn-primary {
    background-color: #494a6b;
}
/* - header
 ------------------------------------------------------------ */

.rakujin .layer::after {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: '';
    background-color: rgba(0, 0, 0, .6);
}
.rakujin header h1, .rakujin header h2, .rakujin header p {
    position: relative;
    z-index: 5;
    color: #fff;
}
.rakujin header h1 img {
    display: block;
    width: 50%;
    margin: 1em auto;
}
.rakujin header h2 {
    font-size: 1.2em;
}
.rakujin header p {
    font-size: .8em;
    font-weight: bold;
}
.rakujin header .inner {
    padding: 1em;
}
.banner {
    padding: 1em 1em 0;
    background-color: #e8e8e8;
}
.banner img {}
.rakujin .nav {
    background-color: #111;
}
.rakujin .nav a {
    font-weight: bold;
    color: #fff;
}
.rakujin .layer {
    position: relative;
}
.rakujin .layer .img-01 .inner {
    padding: 2em 0;
}
.rakujin .layer .img-01 h2 {
    font-size: 2em;
}
.rakujin .layer .img-01 a {
    font-size: 1.2em;
    font-weight: bold;
    position: relative;
    z-index: 5;
    padding: .5em 2em;
    color: #fff;
    border: 1px solid #fff;
    border-radius: 2px;
    background-color: #0008c;
}
.rakujin .img-01 {
    width: 100%;
    text-align: center;
    background-image: url(../images/bgg.jpg);
    background-size: cover;
}
.rakujin .img-02 {
    width: 100%;
    background-image: url(../images/foto-02.jpg);
    background-size: cover;
}
.rakujin .img-03 {
    width: 100%;
    background-image: url(../images/go-01.jpg);
    background-size: cover;
}
.rakujin .img-04 {
    width: 100%;
    background-image: url(../images/go-02.jpg);
    background-size: cover;
}
.rakujin .img-05 {
    width: 100%;
    background-image: url(../images/img-01.jpg);
    background-size: cover;
}
.rakujin .img-06 {
    width: 100%;
    background-image: url(https://sb-drops.s3.amazonaws.com/drop/rmopt-5cc01b0d9ec94-965039600-1556093709.jpg);
    background-size: cover;
    background-position: right;
}
/* - .intro
 ------------------------------------------------------------ */

.rakujin .intro {
    width: 100%;
    padding: 3em;
}
@media screen and (min-width:769px) {
    .rakujin .intro {
        padding: 3em 1em 1em;
    }
}
.rakujin .intro h1 {
    font-weight: normal;
    font-size: 1.8em;
    letter-spacing: 2px;
    margin: 0 0 1em;
}
@media screen and (min-width:769px) {
    .rakujin .intro h1 {
        text-align: center;
    }
}
.rakujin .intro p {
}
@media screen and (min-width:769px) {
    .rakujin .intro p {
        text-align: center;
    }
}
/* - .feature
 ------------------------------------------------------------ */

.rakujin .feature {
    margin: 2em 0 1em;
    padding: 1em;
}
.rakujin .feature .inner {
    padding: 1em;
}
.rakujin .feature h3 {
    font-size: 1.15em;
    font-weight: bold;
    line-height: 1.2;
    margin: .7em 0 .5em;
}
.rakujin .feature p {}
.rakujin .feature a {
    font-weight: bold;
    text-decoration: underline;
}
/* - .banner
 ------------------------------------------------------------ */

.rakujin .banner .youtube {}
.rakujin .banner .youtube .inner {
    margin: .5em;
    background-color: #fff;
    padding: .5em;
    border: 1px solid #868686;
    height: 182px;
}
.rakujin .banner .youtube .wrap {
    background-image: url(../images/youtube-bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
}
.rakujin .banner .youtube a {
    width: 100%;
    text-align: center;
}
.rakujin .banner .skype {}
.rakujin .banner .skype .inner {
    margin: .5em;
    background-color: #fff;
    padding: .5em .5em 41px .5em;
    border: 1px solid #868686;
    height: 182px;
}
.rakujin .banner .skype .wrap {
    background-color: #9cdefe;
    padding: .8em 0;
    position: relative;
}
.rakujin .banner .skype a {
    width: 100%;
    text-align: center;
}
.rakujin .banner .skype .logo {
    width: 120px;
    position: absolute;
    bottom: -34px;
    left: 0;
    right: 0;
    margin: auto;
}
.banner[class*=grid-] {}
.youtube {}
.youtube .inner {}
.youtube a {}
.youtube img {
    width: 50%;
    max-width: 200px;
}
.youtube h3 {
    margin: .5em 0 0;
}
.youtube .a-text {}
.youtube .fa-arrow-alt-circle-right {}
.skype {}
.skype .inner {}
.skype img {}
.skype a {}
.skype p {}
/* - .price
 ------------------------------------------------------------ */

.price {
    padding: 4em 2em 0em;
}
.price h2 {
    letter-spacing: 2px;
    margin: 0 0 1.3em;
}
.price p {
    line-height: 2;
}
.price .fa:not(.fb) {
    border: 1px solid #dedede;
    padding: 2em;
    color: #909090;
    position: absolute;
    top: -18px;
    left: -6em;
}
.price a:not(.fb) {
    padding: .5em 1em;
    border-radius: 20px;
    border: 2px solid rgba(27, 127, 204, .8);
    font-weight: bold;
    color: rgba(27, 127, 204, .8);
    margin-left: auto;
}
a.fb {
    font-weight: bold;
    /* margin: 1em 0; */
    background-color: #e0f0fb;
    padding: .3em 1em .3em .5em;
    box-shadow: 0 1px 2px #dcdcdc;
    color: #057ae6;
}
a.fb .fa {
    color: #fff;
    padding: .3em;
    background-color: #71aaf3;
    margin: 0 .5em 0 0;
}
.fb-free h3 {
    margin: 2em 0 3em;
}
.fb-free .inner {
    margin: 0 0 3em;
}
.fb-free .inner img {}
.fb-free .inner p {
    margin: 0 0 0 6em;
    position: relative;
    line-height: 1.5;
}
.cafe-premium {
    margin: 5em 0 0 0;
}
.cafe-premium h3 {
    margin: 2em 0 3em;
}
.cafe-premium .inner {
    margin: 0 0 3em;
}
.cafe-premium .inner img {}
.cafe-premium .inner p {
    margin: 0 0 0 6em;
    position: relative;
    line-height: 1.5;
}
.price .note {
    border-top: 1px dotted #dedede;
    margin: 2em 0 0 0;
    padding: 1em;
}
.price .note p {}
.price p span {
    display: block;
    font-size: 90%;
    color: #636363;
}
.rakujin .detail {
    background-color: #eee;
}
.rakujin .detail a {
    font-weight: bold;
    line-height: 2;
    color: #e23d3d;
}
.rakujin .detail a:hover {
    text-decoration: underline;
}
.rakujin .detail .fl-container {
    display: -webkit-inline-flex;
    display: inline-flex;
    width: 100%;
    margin: 1em 0;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
}
.rakujin .detail .box {
    padding: 1em;
}
.rakujin .detail .box h3 {
    font-weight: normal;
}
.rakujin .detail .price {
    margin: 2em 0;
    padding: 1em 1em;
    background-color: #fff;
}

.rakujin .text {
} 



.rakujin .event {
    width: 100%;
}
.rakujin .event .box {
    padding: 2em;
}
.rakujin .event .box h3 {
    font-weight: normal;
}
.rakujin .event .box p {
    line-height: 1.8;
}
.rakujin .event .img {
    max-width: 284px;
    margin: 2em .5em .3em 0;
    width: 44%;
}
.rakujin .btn-link {
    margin: 1em 0 0;
    padding: .3em 1em;
    border: 1px solid #ccc;
    border-radius: 20px;
}
.rakujin .text {
    padding: 1em;
}
/* - .fl-container
 ------------------------------------------------------------ */

.fl-container {
    display: flex;
    width: 100%;
    margin: 1em 0;
}
.fl-container .co-item {
    padding: .2em;
    text-align: center;
    -webkit-flex-grow: 1;
    /* flex-grow: 1; */
}
.fl-container .co-item a {
    display: block;
    padding: .4em .5em;
}
/* - .calendar
 ------------------------------------------------------------ */

.calendar h3 {
    text-align: center;
}
.calendar-icona {
    padding: 1em;
}
.calendar-icona {
    padding: 1em;
}
.calendar-icona .fa {
    font-size: 2em;
    padding: 0 0 12px;
    color: #777;
}
.calendar {
    padding: 2em 1em;
    background-color: #eee;
    width: 100%;
}
.rakujin .calendar .inner {
    position: relative;
    margin: 1em 0;
    padding: 5px;
    border: 1px solid #dedede;
    background-color: #fff;
}
.calendar [class*=data-] {
    font-weight: bold;
    line-height: 1.15;
    display: block;
    width: 100%;
    padding: .4em;
    text-align: center;
}
.calendar .data-m {
    color: #555;
    background-color: #95cca2;
}
.calendar .data-v {
    color: #555;
    background-color: #96d7ec;
}
.calendar .data-d {
    color: #ce0000;
    background-color: #f7b570;
}
.calendar .data-s {
    color: #3b4c75;
    background-color: #b4b3da;
}
.calendar span em {
    font-size: 1.2em;
    padding: 0 4px 0 0;
    color: #fff;
    font-style: normal;
}
.calendar .corso {
    font-size: .95em;
    line-height: 1.2;
    min-height: 46px;
    padding: .3em 0;
    letter-spacing: -1px;
}
.calendar .corso .livello {
    font-size: 80%;
}
.calendar p {
    font-size: .9em;
    width: 100%;
    margin: 0;
    padding: .6em 0 0;
    border-top: 1px dashed #ccc;
}
.calendar .tutor-name {
    display: block;
}
.calendar .tutor-name img {
    width: 25px;
    padding: 0 3px 0 0;
    border-radius: 50%;
}
/*google calendar*/

.addtocalendar var {
    display: none;
}
.addtocalendar {
    position: relative;
    display: block;
    margin: .4em 0;
    text-align: center;
    background: transparent !important;
}
.atcb-link {
    display: block;
    cursor: pointer;
    outline: none !important;
}
.atcb-link:focus~ul, .atcb-link:active~ul, .atcb-list:hover {
    visibility: visible;
}
.atcb-list {
    position: absolute;
    z-index: 900;
    top: 100%;
    left: 0;
    visibility: hidden;
    width: 170px;
}
.atcb-list, .atcb-item {
    margin: 0;
    padding: 0;
    list-style: none;
    background: #fff;
}
.atcb-item {
    float: none;
    text-align: left;
}
.atcb-item-link {
    display: block;
    text-decoration: none;
    outline: none;
}
.atcb-item.hover, .atcb-item:hover {
    position: relative;
    z-index: 900;
    cursor: pointer;
    text-decoration: none;
    outline: none;
}
/* Blue */

.atc-style-blue .atcb-link, .atc-style-blue .atcb-link:hover, .atc-style-blue .atcb-link:active, .atc-style-blue .atcb-link:focus {
    font-family: 'Verdana';
    font-size: 12px;
    line-height: 20px;
    zoom: 1;
    margin: 0;
    padding: 5px 20px;
    vertical-align: middle;
    text-decoration: none;
    color: #fff;
    border-radius: 2px;
    outline: none;
    background: rgb(165, 185, 220);
    box-shadow: 0 0 40px rgba(0, 0, 0, .13) inset;
}
.atc-style-blue .atcb-list {
    width: 170px;
    border: 1px solid rgb(186, 186, 186);
    border-radius: 2px;
    box-shadow: 0 0 5px #aaa;
}
.atc-style-blue .atcb-list, .atc-style-blue .atcb-item {
    color: #000;
    background: #fff;
}
.atc-style-blue .atcb-item, .atc-style-blue .atcb-item-link {
    line-height: 1.3em;
    zoom: 1;
    vertical-align: middle;
}
.atc-style-blue .atcb-item-link, .atc-style-blue .atcb-item-link:hover, .atc-style-blue .atcb-item-link:active, .atc-style-blue .atcb-item-link:focus {
    font-family: 'Verdana';
    font-size: 14px;
    padding: 5px 15px;
    text-decoration: none;
    color: #000;
    outline: none;
}
.atc-style-blue .atcb-item-link:hover, .atc-style-blue .atcb-item-link:active, .atc-style-blue .atcb-item-link:focus {
    color: #fff;
}
.atc-style-blue .atcb-item.hover, .atc-style-blue .atcb-item:hover {
    background: rgb(92, 130, 199);
}
/* - tutor profile
 ------------------------------------------------------------ */

.profile {
    padding: 3em;
    background-color: #eee;
    width: 100%;
}
.singolo:nth-of-type(odd) {
    width: 100%;
    margin: 1em 0;
}
.singolo:nth-of-type(even) {
    width: 100%;
    margin: 1em 0;
}
.singolo .inner {
    margin: 0 2em 0 0;
    padding: 2em;
    border: 1px dotted #ccc;
    border-radius: 6px;
    background-color: #fff;
}
.singolo img:not(.pub) {
    width: 120px;
    margin: 0 0 1em;
    padding: .5em;
    border-radius: 50%;
    background-color: #fff;
}
.singolo h3 {
    margin: 0;
}
.singolo a {
    font-size: .8em;
    color: #555;
}
.singolo h3 a {
    color: #555;
}
.singolo p {
    font-size: .9em;
}
/* - page scroll
 ------------------------------------------------------------ */

#page-top {
    position: fixed;
    z-index: 10;
    right: 20px;
    bottom: 150px;
}
#page-top a {
    font-size: 12px;
    display: block;
    width: 100px;
    height: 77px;
    padding: 30px 0;
    text-align: center;
    text-decoration: none;
    color: #fff !important;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    background: #8e7b87;
    -o-border-radius: 5px;
    -khtml-border-radius: 5px;
}
#page-top a:hover {
    text-decoration: none;
    background: #c0bbac;
}
/* - .abbonamenti
 ------------------------------------------------------------ */

.rakujin .abbonamenti {
    margin: 2em 0 3em;
    padding: 0 1em 1em;
    border: 1px solid #ccc;
}
.rakujin .abbonamenti .waku p {
    line-height: 1.8;
}
.rakujin .abbonamenti p span {
    font-weight: 700;
    display: block;
    margin: .3em 1em 1em 0;
    padding: .3em;
    text-align: center;
    color: #ef2929;
    border: 1px solid #ef2929;
    background-color: #fcffe2;
}
.rakujin .abbonamenti p b {
    font-size: 110%;
    display: block;
    margin: .5em .5em 0 .8em;
    padding: .4em;
    border: 1px solid #ccc;
    border-radius: 3px;
}
/* - .skype
 ------------------------------------------------------------ */

.rakujin .skype {}
.rakujin .skype h4 {
    text-align: center;
}
.rakujin .skype .fl-container .co-item:nth-of-type(1) a {
    background-color: #def2fb;
}
.pub img {
    border: 1px solid #ccc;
}
.singolo.akihide {
    order: 3;
}
.singolo.pub {
    order: 2;
}
.singolo.magazine {
    order: 4;
}
.singolo.tohu {
    order: 1;
}
/* xs - max568px, sm - max768px, md - max1024px, lg - max1280px*/

/* - ## x >= 540px
 ------------------------------------------------------------ */

@media screen and (min-width:540px) {}
/* - ## x >= 769px
 ------------------------------------------------------------ */

@media screen and (min-width:769px) {
    .rakujin .for-pc {
        display: block;
    }
    .singolo.akihide {
        order: 2;
    }
    .singolo.pub {
        order: 3;
    }
    .singolo.magazine {
        order: 4;
    }
    .singolo.tohu {
        order: 1;
    }
}
/* - ## x >= 800px
 ------------------------------------------------------------ */

@media screen and (min-width:800px) {}
/* - ## x >= 1025px
 ------------------------------------------------------------ */

@media screen and (min-width:1025px) {
    .fl-container .co-item {}
    .fl-container .co-item a {
        padding: .5em 1em;
    }
    .rakujin .event .box {
        padding: 0 1em;
    }
    .rakujin .detail .box {
        padding: 3em 3em 3em 3em;
        max-width: 90%;
    }
}
/* - ## x >= 1380px
 ------------------------------------------------------------ */

@media screen and (min-width:1281px) {}
/* - .section video lesson
 ------------------------------------------------------------ */

.rakujin .video {
    padding: 1em;
    background-color: #f7f7f7;
    width: 100%;
    margin: 0 0 5em;
    /* max-width: 700px; */
    text-align: center;
    padding: 2em 1em;
    /* border: 15px solid #ececec; */
}
.rakujin .video div.video_lesson span {
    display: block;
    position: relative;
    top: 4px;
}
.rakujin .video .video_wrap img {
    border: 5px solid #fff;
    box-shadow: 0 0 5px #dadada;
    display: block;
    margin: 0 auto;
}
.rakujin .video .video_wrap img:hover {
    box-shadow: 0 0 5px #aaa;
}
.rakujin .video .video_wrap .fa {
    position: absolute;
    margin: auto;
    width: 65px;
    height: 65px;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 50%;
    text-align: center;
    line-height: 1.3;
    font-size: 45px;
    color: #fff;
    background-color: #0000004f;
}
.rakujin .video .video_wrap .fa::after {
    content: '';
    position: absolute;
    margin: auto;
    width: 70px;
    height: 70px;
    top: -10px;
    bottom: 0;
    left: -5px;
    right: 0;
    border-radius: 50%;
    border: 6px solid #fff;
    box-shadow: 0 0 5px #333;
}
.rakujin .video div.video_lesson span:hover {
    cursor: pointer;
}
.rakujin .video a.videolink {
    background-color: #9ebfda;
    box-shadow: 0 1px 0 #999;
    color: #fff;
    padding: 13px 0;
    text-align: center;
    margin: 5px 10px 5px 0;
    display: inline-block;
    width: 325px
}
/* - ## form
 ------------------------------------------------------------ */

.magazine h4 {
    font-weight: normal;
    font-size: 1em;
}
.magazine h4 span {
    font-size: 110%;
    font-weight: bold;
}
.magazine p {
    color: #af4848;
    font-weight: bold;
    margin: 0 0 .5em;
}
.magazine input[type=submit] {
    background-color: #5ea1cd;
    color: #fff;
    font-weight: bold;
    margin: 1em 0 .7em;
}
.magazine input {
    border-radius: 2px;
    width: 100%;
    display: block;
    padding: .4em;
    margin: 0 0 .3em;
}
.magazine label {
    font-size: .8em;
}
.magazine small {
    line-height: .5;
    font-size: 73%;
}
.magazine small a {
    font-size: 100%;
}
.magazine small a b {}