@charset "utf-8";

/* メッセージセクション */
#message {
    position: relative;
    margin-bottom: 12rem;
}

#message .img {
    width: calc((100vw - var(--main-max-width)) / 2 + 400px);
}

#message .container {
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: var(--main-width);
    max-width: var(--main-max-width);
    z-index: 1;
}

#message .container .text_content {
    width: 840px;
    max-width: 75%;
    position: absolute;
    right: 0;
    top: 2rem;
}

#message .container .text_content p {
    line-height: 2;
    font-weight: bold;
}

#message .container .text_content p.ieiri {
    margin-top: 1rem;
    text-align: right;
}

@media only screen and (max-width:1100px) {
    #message .img {
        width: 43%;
    }

    #message .container .text_content {
        max-width: 65%;
    }
}

@media only screen and (max-width:900px) {
    #message {
        margin-bottom: 20rem;
    }

    #message .container .text_content p {
        line-height: 1.75;
    }
}

@media only screen and (max-width:768px) {
    #message {
        margin-bottom: 4rem;
    }

    #message .img {
        width: 70%;
    }

    #message .container .text_content {
        position: relative;
        max-width: 100%;
        padding: 1rem;
        background-color: rgba(255, 255, 255, .75);
    }

    #message .container {
        margin: 0;
        position: relative;
        top: -170px;
        width: calc(70% - 1rem);
        left: 30%;
    }
}

@media only screen and (max-width:600px) {
    #message .img {
        width: 80%;
    }

    #message .container {
        width: calc(80% - 1rem);
        left: 20%;
        top: -130px;
    }
}

@media only screen and (max-width:475px) {
    #message .img {
        width: 90%;
    }

    #message .container {
        width: calc(90% - 1rem);
        left: 10%;
        top: -100px;
    }
}

/* Livertyとリバ邸 */
#about {
    margin: 0 auto 12rem;
    width: var(--main-width);
    max-width: var(--main-max-width);
    display: flex;
}

#about .left {
    padding-right: 3rem;
}

#about .left h2 {
    font-size: 4rem;
    font-weight: bold;
    color: #FFF;
    padding: .75rem 2rem;
    background-color: var(--main-black);
    word-break: keep-all;
    letter-spacing: 3px;
    margin: 0;
}

#about .left div {
    font-size: 4rem;
    font-weight: bold;
    margin: 1rem 0;
    padding-left: 2rem;
}

#about .right p {
    line-height: 2;
    font-weight: bold;
    margin-bottom: 3rem;
}


@media only screen and (max-width:768px) {

    #about .left h2,
    #about .left div {
        font-size: 3rem;
    }

    #about .left {
        padding-right: 2rem;
    }

    #about .right p {
        margin-bottom: 2rem;
        line-height: 1.75;
    }
}

@media only screen and (max-width:660px) {

    #about .left h2,
    #about .left div {
        font-size: 2rem;
    }

    #about .left {
        padding-right: 1.5rem;
    }
}

@media only screen and (max-width:600px) {

    #about .left h2,
    #about .left div {
        font-size: 2.5rem;
    }

    #about {
        display: block;
    }

    #about .left {
        padding-left: 0;
        margin-bottom: 2rem;
    }

    #about .right p {
        margin-bottom: 1rem;
    }
}


/* 現代の駆け込み */
#kakekomi {
    padding: 6rem 0;
    background-position: center;
    background-size: cover;
    background-image: url(../img/philosophy/tera.png);
}

#kakekomi .container {
    margin: 0 auto;
    width: var(--main-width);
    max-width: var(--main-max-width);
    display: flex;
    align-items: start;
}

#kakekomi .container p,
#kakekomi .container h3 {
    color: var(--main-white);
    font-weight: bold;
}

#kakekomi .container .right,
#kakekomi .container .left {
    width: 50%;
    padding: 1rem;
}

#kakekomi .container .left p {
    line-height: 2;
    margin-bottom: 2rem;
    letter-spacing: 2px;
}

#kakekomi .container .left h3 {
    display: none;
    font-size: 3rem;
}

#kakekomi .container .right h3 {
    font-weight: bold;
    font-size: 4rem;
    margin: 0;
}

@media only screen and (max-width:1000px) {
    #kakekomi .container .right h3 {
        font-size: 3rem;
    }
}

@media only screen and (max-width:768px) {
    #kakekomi .container .right h3 {
        font-size: 2.5rem;
    }

    #kakekomi .container .left p {
        line-height: 1.75;
    }

    #kakekomi .container .right,
    #kakekomi .container .left {
        padding: .5rem;
    }

    #kakekomi{
        padding: 3rem 0;
    }
}

@media only screen and (max-width:600px) {
    #kakekomi{
        padding: 1px 0 2rem;
    }
    #kakekomi .container .right, #kakekomi .container .left{
        padding: 0;
    }
    #kakekomi .container {
        display: block;
    }

    #kakekomi .container .right {
        display: none;
    }

    #kakekomi .container .left {
        width: 100%;
    }

    #kakekomi .container .left h3 {
        display: block;
    }
}

@media only screen and (max-width:475px) {
    #kakekomi .container .left h3 {
        font-size: 2.5rem;
    }
}

/* アジール */
#asir {
    position: relative;
    margin-bottom: 16rem;
}

#asir .img {
    bottom: 0;
    position: absolute;
    left: 0;
    width: 55vw;
    max-width: 1000px;
    opacity: .25;
}

#asir .container {
    margin: 0 auto;
    padding-bottom: 10rem;
    width: var(--main-width);
    max-width: var(--main-max-width);
    position: relative;
    z-index: 1;
}

#asir .container h3 {
    font-size: 4rem;
    font-weight: bold;
}

#asir .container .text p {
    margin-bottom: 2rem;
    font-weight: bold;
}

#asir .message {
    position: absolute;
    bottom: -8rem;
    right: 0;
    background-color: var(--main-black);
    color: var(--main-white);
    padding: 2rem 8rem 2rem 2rem;
}

#asir .message p {
    color: var(--main-thite);
    font-weight: bold;
    text-align: right;
    line-height: 2;
}

@media only screen and (max-width:768px) {
    #asir .container h3 {
        font-size: 3rem;
    }

    #asir .img {
        width: 70vw;
    }

    #asir .message {
        padding: 1.5rem;
    }
}

@media only screen and (max-width:600px) {
    #asir{
        margin-bottom: 4rem;
    }
    
    #asir .container h3 {
        font-size: 2.5rem;
        word-break: keep-all;
    }

    #asir .img {
        top: auto;
        bottom: auto;
        position: relative;
        width: 90%;
        opacity: .7;
    }

    #asir .message {
        padding: 1rem;
        top: -4rem;
        width: 90%;
        left: 10%;
    }

    #asir .message p {
        word-break: keep-all;
        text-align: left;
        margin-bottom: .5rem;
    }

    #asir .message p:last-child {
        margin-top: 1rem;
        text-align: right;
    }

    #asir .container {
        padding-bottom: 0;
        margin-bottom: 4rem;
    }

    #asir .message {
        position: relative;
        bottom: 0;
    }
}

@media only screen and (max-width:475px) {
    #asir .message {
        top: -2rem;
    }
}