@font-face {
    font-family: "Courgette";
    src: url('https://katsudoto.id/plugin/fonts/Courgette-Regular.ttf') format("truetype");
    font-display: swap;
}

@font-face {
    font-family: "NotoSerif Bold";
    src: url('https://katsudoto.id/plugin/fonts/NotoSerif-Bold.ttf') format("truetype");
    font-display: swap;
}
@font-face {
    font-family: "NotoSerif Bold Italic";
    src: url('https://katsudoto.id/plugin/fonts/NotoSerif-BoldItalic.ttf') format("truetype");
    font-display: swap;
}
@font-face {
    font-family: "NotoSerif Italic";
    src: url('https://katsudoto.id/plugin/fonts/NotoSerif-Italic.ttf') format("truetype");
    font-display: swap;
}
@font-face {
    font-family: "NotoSerif";
    src: url('https://katsudoto.id/plugin/fonts/NotoSerif-Regular.ttf') format("truetype");
    font-display: swap;
}

html {
    scroll-behavior: smooth;
}

body font,
body sup {
    font-family: inherit;
    font-size: inherit;
    color: inherit;
    line-height: inherit;
}

body.ilham {

    --courgette: 'Courgette', sans-serif;
    --notoserif-b: 'NotoSerif Bold', sans-serif;
    --notoserif-bi: 'NotoSerif Bold Italic', sans-serif;
    --notoserif-i: 'NotoSerif Italic', sans-serif;
    --notoserif: 'NotoSerif', sans-serif;

    overflow: hidden;
    --body-height: 100vh;

    --fs-title: 35px;
    --fs-text: 16px;

}

@media only screen and (min-width: 1024px) {

    body.ilham {
        --fs-title: 40px;
        --fs-text: 18px;
    }

}

body.ilham p {
    font-family: var(--notoserif);
    font-size: var(--fs-text);
    line-height: 1.2;
    color: var(--wood-clr);
}

body.ilham h1,
body.ilham h2 {
    font-family: var(--courgette);
    font-size: var(--fs-title);
    color: var(--secondary-clr);
    line-height: 1.2;
    font-weight: normal;
}

body.ilham.original {

    /* COLOR */
    --primary-clr: #541112;
    --secondary-clr: #e5bc7c;
    --tertiary-clr: #fffde9;
    --wood-clr: #303030;

    --rgb-primary-clr: 84, 17, 18;
    --rgb-secondary-clr: 229, 188, 124;
    --rgb-tertiary-clr: 255, 253, 233;
    --rgb-wood-clr: 48, 48, 48;

    /* Ornaments */
    --bird-01: url("https://katsudoto.id/media/template/ilham/bird-01.png");
    --jawa-01: url("https://katsudoto.id/media/template/ilham/jawa-01.png");
    --butterflies-01: url("https://katsudoto.id/media/template/ilham/butterflies-01.png");

    --flower-01: url("https://katsudoto.id/media/template/ilham/flower-01.png");
    --flower-02: url("https://katsudoto.id/media/template/ilham/flower-02.png");
    --flower-03: url("https://katsudoto.id/media/template/ilham/flower-03.png");
    --flower-04: url("https://katsudoto.id/media/template/ilham/flower-04.png");
    --flower-05: url("https://katsudoto.id/media/template/ilham/flower-05.png");

}


/* =======================
        COVER TOP
======================= */
section.top-cover {
    background: var(--primary-clr);
    width: 100%;
    height: var(--body-height);
    z-index: 999999;
    position: fixed;
    top: 0;
    /* top: -120%; */
    left: 0;
    padding: 0;
    
    transition: all 1.8s;
    transition-timing-function: cubic-bezier(.23,.56,.38,.78);
    -webkit-transition-timing-function: cubic-bezier(.23,.56,.38,.78);
    -moz-transition-timing-function: cubic-bezier(.23,.56,.38,.78);
    -o-transition-timing-function: cubic-bezier(.23,.56,.38,.78);

    display: flex;
    flex-direction: column;
    padding: 0;
    overflow: hidden;
}
section.top-cover.hide {
    top: -120%;
    bottom: 120%;
    pointer-events: none;
}
section.top-cover .inner {
    padding: 0.5em 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    position: relative;
}
section.top-cover .inner::before {
    content: '';
    position: absolute;
    z-index: 2;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
}

section.top-cover .inner .details {
    text-align: center;
    padding: 0.5em;
    margin-top: auto;
    margin-bottom: 10vh;
    position: relative;
    z-index: 3;
}
section.top-cover .inner .details h1 {
    font-family: var(--notoserif);
    font-weight: normal;
    font-size: calc(var(--fs-title) + 5px);
    line-height: 1;
    margin: 0.1em auto;
    margin-top: 0.25em;
    color: #fff;
}
section.top-cover .inner .details p {
    font-size: calc(var(--fs-text) + 0px);
    color: #fff;
}
section.top-cover .inner .details a.link {
    background: var(--secondary-clr);
    color: var(--primary-clr);
    border-radius: 4px;
    padding: 0.2em 1.25em;
    margin: 0.25em auto 0.75em auto;
    display: inline-block;
    font-family: var(--notoserif);
    font-size: calc(var(--fs-text) - 1px);
    text-decoration: none;
    transition: all 0.25s ease-in-out;
}
section.top-cover .inner .details a.link:hover {
    background: #8b8b8b;
}

/* Highlight */
section.top-cover .inner .highlight {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #fff;
}
section.top-cover .inner .highlight .preview-container {
    width: 100%;
    height: 100%;
    display: block;
}
section.top-cover .inner .highlight .preview-container .slick-list {
    width: 100%!important;
    height: 100%!important;
}
section.top-cover .inner .highlight .preview-container .slick-track {
    width: 100%!important;
    height: 100%!important;
    position: relative!important;
}
section.top-cover .inner .highlight .preview-container .picture {
    width: 100%!important;
    height: 100%!important;
    top: 0;
    left: 0;
    position: absolute!important;
}
section.top-cover .inner .highlight .preview-container .picture img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
}

@media only screen and (min-width: 1024px) {

    section.top-cover .inner .details h1 {
        font-size: calc(var(--fs-title) + 15px);
    }

}

@media only screen and (min-width: 1440px) {

    section.top-cover .inner .details h1 {
        font-size: calc(var(--fs-title) + 25px);
    }

}




/* =======================
        COVER
======================= */
section.cover {
    background: var(--primary-clr);
    position: relative;
    overflow: hidden;
    padding: 0;
    min-height: var(--body-height);
    display: flex;
}
section.cover .inner {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0.5em 0;
    position: relative;
}
section.cover .inner .head {
    padding: 0.75em;
    text-align: center;
    position: relative;
    z-index: 1;
}   
section.cover .inner .head .logo {
    margin: 0 auto;
    margin-bottom: 1em;
}
section.cover .inner .head .logo .orn-logo {
    width: 60px;
    height: auto;
}
section.cover .inner .head .logo .orn-logo .cls-1,
section.cover .inner .head .logo .orn-logo .cls-2 {
    fill: var(--secondary-clr);
}
section.cover .inner .head .logo .orn-logo .cls-1 {
    fill-rule: evenodd;
}

section.cover .inner .head p {
    font-size: calc(var(--fs-text) + 2px);
    color: var(--secondary-clr);
}

section.cover .inner .body {
    padding: 0.5em 0;
    position: relative;
    z-index: 1;
}
section.cover .inner .body .highlight {
    position: relative;
    width: 75vw;
    height: 115vw;
    max-width: 290px;
    max-height: 440px;
    margin: 25px auto 20px auto;
}
section.cover .inner .body .highlight .preview-container {
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 1;
    background: #fff;
}
section.cover .inner .body .highlight .preview-container .slick-list {
    width: 100%!important;
    height: 100%!important;
}
section.cover .inner .body .highlight .preview-container .slick-track {
    width: 100%!important;
    height: 100%!important;
    position: relative!important;
}
section.cover .inner .body .highlight .preview-container .picture {
    width: 100%!important;
    height: 100%!important;
    top: 0;
    left: 0;
    position: absolute!important;
}
section.cover .inner .body .highlight .preview-container .picture img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
    cursor: pointer;
}
section.cover .inner .body .highlight::before {
    content: '';
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    width: 40%;
    height: 1.5px;
    background: var(--secondary-clr);
    pointer-events: none;
}
section.cover .inner .body .highlight::after {
    content: '';
    position: absolute;
    z-index: 2;
    top: 0;
    right: 0;
    width: 40%;
    height: 1.5px;
    background: var(--secondary-clr);
    pointer-events: none;
}
section.cover .inner .body .highlight .orn-top-frame {
    position: absolute;
    z-index: 2;
    width: 22.5%;
    max-width: 90px;
    top: 0;
    left: 50%;
    transform: translateX(-50%) translateY(-15px);
    pointer-events: none;
}
section.cover .inner .body .highlight .orn-bottom-left-frame {
    position: absolute;
    z-index: 2;
    width: 80px;
    bottom: 0;
    left: 0;
    transform: scaleX(-1) scaleY(-1) translateY(-13px) translateX(13px);
    pointer-events: none;
}
section.cover .inner .body .highlight .orn-bottom-right-frame {
    position: absolute;
    z-index: 2;
    width: 80px;
    bottom: 0;
    right: 0;
    transform: scaleY(-1) translateY(-13px) translateX(13px);
    pointer-events: none;
}
section.cover .inner .body .highlight .orn-top-frame .cls-1,
section.cover .inner .body .highlight .orn-bottom-left-frame .cls-1,
section.cover .inner .body .highlight .orn-bottom-right-frame .cls-1 {
    fill: var(--secondary-clr);
}

section.cover .inner .foot {
    padding: 0.75em;
    text-align: center;
    position: relative;
    z-index: 1;
}
section.cover .inner .foot p {
    font-size: calc(var(--fs-text) + 2px);
    color: var(--secondary-clr);
}
section.cover .inner .foot h1 {
    font-size: calc(var(--fs-title) + 5px);
    margin: 0.2em auto;
}

/* Ornament */
section.cover .inner .back-flower-top-left,
section.cover .inner .back-flower-top-right {
    position: absolute;
    width: 220px;
    height: 220px;
    background-image: var(--flower-02);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}
section.cover .inner .back-flower-top-left {
    top: -80px;
    left: -120px;    
    transform: scaleX(-1);
}
section.cover .inner .back-flower-top-right {    
    top: -80px;
    right: -120px;
}

section.cover .inner .back-flower-bottom-left,
section.cover .inner .back-flower-bottom-right {
    position: absolute;
    width: 200px;
    height: 200px;
    opacity: 0.75;
    background-image: var(--flower-01);
    background-position: center left;
    background-size: contain;
    background-repeat: no-repeat;
}
section.cover .inner .back-flower-bottom-left {    
    top: 50%;
    left: -70px;        
    transform: translateY(50px);    
}
section.cover .inner .back-flower-bottom-right {
    top: 50%;
    right: 0;
    transform: translateY(-40px) scaleX(-1);
}


@media only screen and (min-width: 1024px) {

    section.cover .inner .head .logo .orn-logo {
        width: 70px;
    }

    section.cover .inner .body .highlight {
        width: 80vw;
        height: 45vw;
        max-width: 1024px;
        max-height: 576px;
    }
    section.cover .inner .body .highlight .orn-top-frame {
        transform: translateX(-50%) translateY(-25px);
    }
    section.cover .inner .body .highlight .orn-bottom-left-frame,
    section.cover .inner .body .highlight .orn-bottom-right-frame {
        width: 120px;
    }
    section.cover .inner .body .highlight .orn-bottom-left-frame {
        transform: scaleX(-1) scaleY(-1) translateY(-18px) translateX(18px);
    }
    section.cover .inner .body .highlight .orn-bottom-right-frame {
        transform: scaleY(-1) translateY(-18px) translateX(18px);
    }
    
    section.cover .inner .body .highlight::before,
    section.cover .inner .body .highlight::after {
        width: 44.9%;
        height: 2px;
    }
    section.cover .inner .foot h1 {
        font-size: calc(var(--fs-title) + 15px);
    }


    /* Ornaments */
    section.cover .inner .back-flower-top-left,
    section.cover .inner .back-flower-top-right {
        width: 280px;
        height: 280px;    
    }
    section.cover .inner .back-flower-top-left {
        top: -110px;
        left: -150px;
    }
    section.cover .inner .back-flower-top-right {    
        top: -110px;
        right: -150px;
    }

    section.cover .inner .back-flower-bottom-left,
    section.cover .inner .back-flower-bottom-right {
        width: 240px;
        height: 240px;
    }
    section.cover .inner .back-flower-bottom-left {    
        left: -80px;
        transform: translateY(40px);    
    }
    section.cover .inner .back-flower-bottom-right {
        right: 0;
        transform: translateY(-50px) scaleX(-1);
    }

}

@media only screen and (min-width: 1200px) {

    section.cover .inner .body .highlight::before,
    section.cover .inner .body .highlight::after {
        width: 45.7%;
    }

}

@media only screen and (min-width: 1440px) {

    section.cover .inner .foot h1 {
        font-size: calc(var(--fs-title) + 25px);
    }

    section.cover .inner .back-flower-bottom-left,
    section.cover .inner .back-flower-bottom-right {
        width: 270px;
        height: 270px;
    }
    section.cover .inner .back-flower-bottom-left {    
        left: -80px;
        transform: translateY(30px);    
    }
    section.cover .inner .back-flower-bottom-right {
        right: -20px;
        transform: translateY(-60px) scaleX(-1);
    }

}




/* =======================
        COUPLE WRAPPER
======================= */
section.couple-wrapper {
    position: relative;
    overflow: hidden;
    background: var(--primary-clr);
}

/* =======================
        QUOTE TOP
======================= */
section.quote-top {
    padding: 0.75em 0;
    overflow: hidden;
    position: relative;
}
section.quote-top .inner {
    width: 100%;
    max-width: 1024px;
    margin: 0 auto;
    padding: 1em;
    text-align: center;
}
section.quote-top .inner p {
    font-style: italic;
    color: var(--secondary-clr);
    font-size: calc(var(--fs-text) + 2px);
}


/* =======================
        GUEST
======================= */
section.guest {
    position: relative;
    overflow: hidden;
    padding: 0.5em;
    display: flex;
    justify-content: center;
}
section.guest::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: calc(100% - 0.5em);
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
    background: var(--secondary-clr);
}
section.guest .inner {
    max-width: 1024px;
    min-height: 100px;
    padding: 0.5em 0.25em 1.25em 0.25em;
    margin-left: 55px;
    margin-right: 55px;
    text-align: center;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}
section.guest .inner p {
    color: #fff;
    font-size: calc(var(--fs-text) + 2px);
}
section.guest .inner h1 {
    color: #fff;
    margin: 0.25em 0;
    font-size: calc(var(--fs-title) + 5px);
}

section.guest .inner .orn-01,
section.guest .inner .orn-02 {
    position: absolute;
    background-image: var(--butterflies-01);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}

section.guest .inner .orn-01 {
    top: 50%;
    left: -45px;
    transform: translateY(-25px) scaleX(-1);
    width: 30px;
    height: 30px;
}
section.guest .inner .orn-02 {
    top: 50%;
    right: -45px;
    transform: translateY(-25px);
    width: 30px;
    height: 30px;
}

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

    section.guest .inner .orn-01 {
        left: -50px;
        width: 40px;
        height: 40px;
    }
    section.guest .inner .orn-02 {
        right: -50px;
        width: 40px;
        height: 40px;
    }   

}

@media only screen and (min-width: 1024px) {

    section.guest .inner h1 {
        font-size: calc(var(--fs-title) + 10px);
    }

}

@media only screen and (min-width: 1440px) {

    section.guest .inner h1 {
        font-size: calc(var(--fs-title) + 20px);
    }

    section.guest .inner .orn-01 {
        left: -60px;
        width: 50px;
        height: 50px;
    }
    section.guest .inner .orn-02 {
        right: -60px;
        width: 50px;
        height: 50px;
    }   

}





/* =======================
        COUPLE
======================= */
section.couple {
    padding: 0.75em 0 1.5em 0;
    position: relative;
}

section.couple .inner {
    padding: 0.75em 0 1.5em 0;
    position: relative;
}

section.couple .inner .head {
    width: 100%;
    max-width: 1024px;
    margin: 0 auto;
    padding: 0.75em;
    text-align: center;
}
section.couple .inner .head h1 {
    margin-bottom: 0.2em;
}
section.couple .inner .head p {
    font-style: italic;
    color: var(--secondary-clr);
    font-size: calc(var(--fs-text) + 2px);
}

section.couple .inner .body {
    display: flex;
    flex-direction: column;
    padding: 0;
    position: relative;
    min-height: 220px;
}
section.couple .inner .body.bride-first {
    flex-direction: column-reverse;
}

section.couple .inner .body .groom,
section.couple .inner .body .bride {
    padding: 0.75em 0;
    margin: 0 auto;
    width: 100%;
    max-width: 720px;
    min-height: 150px;
    position: relative;
    z-index: 1;
}

section.couple .inner .body > div .preview {
    padding: 0.5em 0.75em;
}

section.couple .inner .body > div .preview .picture {
    width: 150px;
    height: 180px;
    position: relative;
    border-radius: 70px;
    margin: 0.25em auto;
}

section.couple .inner .body > div .preview .picture::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    width: calc(100% + 10px);
    height: calc(100% + 10px);
    border-radius: 70px;
    pointer-events: none;
    border: 1.5px solid var(--secondary-clr);
}
section.couple .inner .body > div .preview .picture > a {
    width: 100%;
    height: 100%;
    display: inline-block;
    border-radius: inherit;
}
section.couple .inner .body > div .preview .picture > a > img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
    border-radius: inherit;
    background: var(--secondary-clr);
}

section.couple .inner .body > div .details {
    padding: 0.5em 0.75em;
    text-align: center;
}
section.couple .inner .body > div .details h2 {
    margin-bottom: 0.2em;
    color: var(--secondary-clr);    
}
section.couple .inner .body > div .details p {
    margin-bottom: 0.3em;
    color: var(--secondary-clr);
}
section.couple .inner .body > div .details p.bio {
    font-style: italic;
}
section.couple .inner .body > div .details a.link {
    display: inline-block;
    font-family: var(--notoserif);
    font-size: 1em;
    text-decoration: none;
    font-style: italic;
    color: var(--secondary-clr);
}
section.couple .inner .body > div .details a.link:hover {
    text-decoration: underline;
}
section.couple .inner .body > div .details a.link i {
    font-size: 1em;
}

section.couple .inner .body .separator {
    padding: 0.75em 0;
    text-align: center;
    position: relative;
    transition: all 0.25s ease-in-out;
}
section.couple .inner .body .separator p {
    color: var(--secondary-clr);
    font-family: var(--courgette);
    font-size: 90px;
}

section.couple .inner .body .separator > .flower-01 {
    position: absolute;
    top: 0;
    left: -235px;
    transform: scaleX(-1) translateY(-160px);
    width: 340px;
    height: 320px;
    background-image: var(--flower-04);
    background-size: contain;
    background-position: center left;
    background-repeat: no-repeat;
    pointer-events: none;
}
section.couple .inner .body .separator > .flower-02 {
    position: absolute;
    top: 0;
    right: -235px;
    width: 340px;
    height: 320px;
    transform: translateY(-160px);
    background-image: var(--flower-04);
    background-size: contain;
    background-position: center left;
    background-repeat: no-repeat;
    pointer-events: none;
}


section.couple .inner .back-flower-01,
section.couple .inner .back-flower-02,
section.couple .inner .back-flower-03 {
    position: absolute;
    background-image: var(--flower-01);
    background-size: contain;
    background-position: center left;
    background-repeat: no-repeat;
    pointer-events: none;
}

section.couple .inner .back-flower-01 {    
    top: 0;
    left: -55px;
    width: 180px;
    height: 180px;
    opacity: 0.5;
    transform: translateY(-50px);    
}
section.couple .inner .back-flower-02 {
    top: 0;
    right: -55px;
    width: 180px;
    height: 180px;
    opacity: 0.5;
    transform: scaleX(-1) translateY(-50px);    
}
section.couple .inner .back-flower-03 {
    bottom: 0;
    left: 50%;
    width: 360px;
    height: 360px;
    opacity: 0.5;
    transform: translateX(-50%) translateY(195px) scaleY(-1) rotate(90deg);    
}


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

    section.couple .inner .body > div .preview .picture {
        width: 180px;
        height: 210px;
    }

}

@media only screen and (min-width: 1024px) {

    section.couple .inner .body {
        flex-direction: row;
        justify-content: center;
    }
    section.couple .inner .body.bride-first {
        flex-direction: row-reverse;
    }
    section.couple .inner .body .groom,
    section.couple .inner .body .bride {
        margin: 0 1.5em;
    }
    section.couple .inner .body .separator {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translateX(-50%) translateY(-50%);
    }    
    section.couple .inner .body.show-picture .separator {
        top: 90px;
        transform: translateX(-50%) translateY(0);
    }

    section.couple .inner .body .separator > .flower-01,
    section.couple .inner .body .separator > .flower-02 {
        display: none;
    }  

    section.couple .inner .body > .flower-01 {
        position: absolute;
        top: 50%;
        left: -235px;
        transform: scaleX(-1) translateY(-50%);
        width: 340px;
        height: 320px;
        background-image: var(--flower-04);
        background-size: contain;
        background-position: center left;
        background-repeat: no-repeat;
        pointer-events: none;
    }
    section.couple .inner .body > .flower-02 {
        position: absolute;
        top: 50%;
        right: -235px;
        transform: translateY(-50%);
        width: 340px;
        height: 320px;
        background-image: var(--flower-04);
        background-size: contain;
        background-position: center left;
        background-repeat: no-repeat;
        pointer-events: none;
    }

    section.couple .inner .body.show-picture > .flower-01 {
        transform: scaleX(-1) translateY(-300px);
    }

    section.couple .inner .body.show-picture > .flower-02 {
        transform: translateY(-300px);
    }


    section.couple .inner .back-flower-01 {    
        top: -20px;
        left: -55px;
        width: 220px;
        height: 220px;
    }
    section.couple .inner .back-flower-02 {
        top: -20px;
        right: -55px;
        width: 220px;
        height: 220px;
    }


}

@media only screen and (min-width: 1440px) {

    section.couple .inner .body .groom,
    section.couple .inner .body .bride {
        margin: 0 3em;
    }
    section.couple .inner .body > div .preview .picture {
        width: 210px;
        height: 240px;
    }

    section.couple .inner .back-flower-03 {
        width: 400px;
        height: 400px;
    }

}




/* =======================
        GALLERY PHOTO(S)
======================= */
section.gallery {
    background: var(--primary-clr);
    overflow: hidden;
    position: relative;
    padding: 0;
    padding-top: 0.5em;
}
section.gallery::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-top-left-radius: 30px;
    border-top-right-radius: 30px;
    background: var(--tertiary-clr);
}
section.gallery .title {
    position: relative;
    width: 100%;
    max-width: 1024px;
    z-index: 2;
    margin: 0 auto;
    margin-bottom: -1em;
    padding: 0.5em;
    padding-top: 1em;
}
section.gallery .title h1 {
    margin: 0;
    margin-bottom: 0.15em;
    color: var(--primary-clr);
    font-size: var(--fs-title);
}
section.gallery .title p {
    color: var(--primary-clr);
    font-size: calc(var(--fs-text) + 2px);
    font-style: italic;
}
section.gallery .flexbin {
    margin: 0;
    padding: 0.75em 0.25em;
    padding-top: 1.25em;
    position: relative;
    z-index: 1;
}




/* =======================
        GALLERY VIDEO(S)
======================= */
section.video-gallery {
    background: var(--primary-clr);
    position: relative;
    overflow: hidden;
    padding: 0;
    padding-top: 0.5em;
}
section.video-gallery::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(100% - 0.5em);
    border-top-left-radius: 30px;
    border-top-right-radius: 30px;
    background: var(--tertiary-clr);
}
section.video-gallery .inner {
    padding: 0.5em 0;
}
section.video-gallery .inner > .title {
    position: relative;
    width: 100%;
    max-width: 1024px;
    z-index: 2;
    margin: 0 auto;
    margin-bottom: -1em;
    padding: 0.5em;
    padding-top: 1em;
}
section.video-gallery .inner > .title h1 {
    margin: 0;
    margin-bottom: 0.15em;
    color: var(--primary-clr);
    font-size: var(--fs-title);
}
section.video-gallery .inner > .title p {
    color: var(--primary-clr);
    font-size: calc(var(--fs-text) + 2px);
    font-style: italic;
}
section.video-gallery .inner .video-outer {
    position: relative;
    z-index: 1;
    margin: 0;
    padding: 0.75em 0;
    padding-top: 1.25em;
    padding-bottom: 0;
}
section.video-gallery .inner .video-outer .video {
    margin-bottom: 0.25em;
    padding: 0.5em;
}
section.video-gallery .inner .video-outer .video > .title {
    padding: 0.5em;
}
section.video-gallery .inner .video-outer .video > .title h2 {
    font-family: var(--notoserif);
    font-size: calc(var(--fs-title) - 12.5px);
    color: var(--primary-clr);
}



/* =======================
        SAVE THE DATE
======================= */
section.save-date {
    background: var(--secondary-clr);
    padding: 0.5em 0 0.75em 0;
    overflow: hidden;
    position: relative;
}
section.save-date .inner {
    padding: 0.5em 0 0.75em 0;
    position: relative;
}

section.save-date .inner::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    width: 120%;
    height: 120%;
    opacity: 0.2;
    background-image: var(--flower-05);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    pointer-events: none;
}

section.save-date .inner .head {
    padding: 0.5em 0;
    text-align: center;
    position: relative;
}
section.save-date .inner .head h1 {
    font-size: calc(var(--fs-title) + 5px);
    margin-bottom: 0.35em;
    color: #fff;
}
section.save-date .inner .head p {
    font-size: calc(var(--fs-text) + 2px);
    color: #fff;
}
section.save-date .inner .body {
    padding: 0.75em 0;
    position: relative;
}
section.save-date .inner .body::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-5px);
    width: 100%;
    height: 20px;
    background: var(--primary-clr);
}
section.save-date .inner .body .countdown {
    position: relative;
    z-index: 1;
    padding: 0.75em 0 0.5em 0;
    width: 97.5%;
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    align-items: center;
}
section.save-date .inner .body .countdown > div {
    background: #fff;
    display: inline-block;
    text-align: center;
    position: relative;
    width: 17.5%;
    border-radius: 12px;
    margin: 0 auto;
    padding: 0.5em 0.25em;
}

section.save-date .inner .body .countdown > div::before {
    content: '';
    position: absolute;
    z-index: -1;
    top: 50%;
    left: 50%;
    width: calc(100% + 7.5px);
    height: calc(100% + 7.5px);
    transform: translate(-50%, -50%);
    border: 1.5px solid #fff;
    border-radius: 12px;
}
section.save-date .inner .body .countdown > div h2 {
    color: var(--primary-clr);
    font-family: var(--notoserif);
    font-size: calc(var(--fs-title) - 5px);
    font-weight: normal;
    line-height: 1;
}
section.save-date .inner .body .countdown > div small {
    color: var(--primary-clr);
    font-family: var(--notoserif);
    font-size: calc(var(--fs-text) - 5px);    
}
section.save-date .inner .foot {
    padding: 0.5em 0;
    text-align: center;
    position: relative;
}
section.save-date .inner .foot #addToCalendar {
    background: #fff;
    display: inline-block;
    font-family: var(--notoserif-b);
    font-size: calc(var(--fs-text) - 2px);
    text-decoration: none;
    padding: 0.45em 1.5em;
    border-radius: 7px;
    color: var(--primary-clr);
    transition: all 0.4s ease-in-out;
}
section.save-date .inner .foot #addToCalendar:hover {
    background: var(--primary-clr);
    color: #fff;
}

@media only screen and (min-width: 1024px) {

    section.save-date .inner::before {
        width: 150%;
        height: 150%;
    }

    section.save-date .inner .head h1 {
        font-size: calc(var(--fs-title) + 10px);
    }
    section.save-date .inner .head p {
        font-size: calc(var(--fs-text) + 6px);
    }

    section.save-date .inner .body .countdown > div {
        padding: 1em 0.25em;
    }
    section.save-date .inner .body .countdown > div h2 {
        font-size: var(--fs-title);
    }
    section.save-date .inner .body .countdown > div small {
        font-size: calc(var(--fs-text) - 4px);   
    }

}

@media only screen and (min-width: 1024px) {

    section.save-date .inner .head h1 {
        font-size: calc(var(--fs-title) + 15px);
    }

}



/* =======================
        EVENT OUTER
======================= */
section.event-outer {
    background: var(--primary-clr);
    position: relative;
    overflow: hidden;
    padding: 0.75em 0;
}
section.event-outer .inner {
    position: relative;
    padding: 0.75em 0;
}
section.event-outer .inner .head {
    width: 100%;
    max-width: 1024px;
    margin: 0 auto;
    padding: 1em 0.75em;
    padding-top: 0.75em;
    text-align: center;
    position: relative;
}
section.event-outer .inner .head h1 {
    margin-left: 40px;
    margin-right: 40px;
    font-family: var(--notoserif);
    font-size: calc(var(--fs-title) - 7.5px);    
}
section.event-outer .inner .head p {
    font-size: calc(var(--fs-text) + 0px);
    font-style: italic;
    color: var(--secondary-clr);
    margin-top: 1em;
    margin-left: 20px;
    margin-right: 20px;
}
section.event-outer .inner .body {
    padding: 0.5em 0;
}
section.event-outer .inner .body .event {
    padding: 0;
    padding-bottom: 0.75em;
    margin-bottom: 1.25em;
}
section.event-outer .inner .body .event:last-of-type {
    margin-bottom: 0;
}
section.event-outer .inner .body .event > .title {
    width: 90%;
    max-width: 500px;
    padding: 1em 0.75em;
    margin: 0 auto;
    text-align: center;
    position: relative;
}
section.event-outer .inner .body .event > .title::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 100%;
    pointer-events: none;
    border-top: 1.5px solid var(--secondary-clr);
    border-bottom: 1.5px solid var(--secondary-clr);
}
section.event-outer .inner .body .event > .title h1 {
    font-family: var(--notoserif-b);
    font-size: calc(var(--fs-title) - 7.5px);
    line-height: 1.1;
}
section.event-outer .inner .body .event > .title p {
    font-style: italic;
    margin-top: 0.4em;
    margin-bottom: 0.4em;
    color: var(--secondary-clr);
}
section.event-outer .inner .body .event > .activities {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;    
    padding: 1em 0;
    padding-bottom: 0;
}
section.event-outer .inner .body .event > .activities .activity {
    width: 100%;
    max-width: 400px;
    padding: 0.5em;
    margin-bottom: 1em;
}
section.event-outer .inner .body .event > .activities .activity:last-of-type {
    margin-bottom: 0;
}
section.event-outer .inner .body .event > .activities .activity > .title {
    padding: 0.5em;
    text-align: center;
}
section.event-outer .inner .body .event > .activities .activity > .title img.party {
    width: 55px;
    display: block;
    object-fit: contain;
    object-position: center;
    margin: 0 auto;
    margin-bottom: 0.75em;
}
section.event-outer .inner .body .event > .activities .activity > .title h1 {
    margin-bottom: 0.15em;
}
section.event-outer .inner .body .event > .activities .activity > .title p {
    margin-bottom: 1.5em;
    color: var(--secondary-clr);
}
section.event-outer .inner .body .event > .activities .activity > .title p.desc {
    font-style: italic;
}
section.event-outer .inner .body .event > .activities .activity > .title p:last-of-type {
    margin-bottom: 0.5em;
}
section.event-outer .inner .body .event > .details,
section.event-outer .inner .body .event > .activities .activity > .details {
    padding: 0.5em;
    text-align: center;
}
section.event-outer .inner .body .event > .details {
    width: 100%;
    max-width: 860px;
    margin: 0 auto;
    padding-right: 1em;
    padding-left: 1em;
}
section.event-outer .inner .body .event > .details p,
section.event-outer .inner .body .event > .activities .activity > .details p {
    margin-bottom: 0.5em;
    color: var(--secondary-clr);
}
section.event-outer .inner .body .event > .details p:last-of-type,
section.event-outer .inner .body .event > .activities .activity > .details p:last-of-type {
    margin-bottom: 0;
}
section.event-outer .inner .body .event > .details a.link,
section.event-outer .inner .body .event > .activities .activity > .details a.link {
    font-family: var(--notoserif);
    text-decoration: none;
    font-size: calc(var(--fs-text) - 2px);
    display: inline-block;
    padding: 0.4em 1.25em;
    margin: 1em auto;
    margin-bottom: 0;
    border-radius: 4px;
    color: var(--secondary-clr);
    border: 1.5px solid var(--secondary-clr);
    transition: all 0.25s ease-in-out;
}
section.event-outer .inner .body .event > .details a.link:hover,
section.event-outer .inner .body .event > .activities .activity > .details a.link:hover {
    background: var(--secondary-clr);
    color: var(--primary-clr);
}

section.event-outer .inner .orn-top-01 {
    min-width: 150px;
    width: 45%;
    max-width: 300px;
    display: block;
    margin: 1.75em auto 0.75em auto;
}
section.event-outer .inner .orn-top-01 .cls-1 {
    fill: var(--secondary-clr);
}

section.event-outer .inner .line-01 {
    min-width: 150px;
    width: 50%;
    max-width: 250px;
    height: 2px;
    border-radius: 50%;
    margin: 0.5em auto 2.25em auto;
    background: var(--secondary-clr);
}

section.event-outer .inner .back-flower-top-01,
section.event-outer .inner .back-flower-top-02 {
    position: absolute;
    width: 180px;
    height: 180px;
    background-image: var(--flower-02);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}
section.event-outer .inner .back-flower-top-01 {    
    top: -40px;
    left: -100px;    
    transform: scaleX(-1);
}
section.event-outer .inner .back-flower-top-02 {    
    top: -40px;
    right: -100px;    
}

section.event-outer .inner .back-flower-bottom-01,
section.event-outer .inner .back-flower-bottom-02 {
    position: absolute;
    width: 250px;
    height: 250px;
    opacity: 0.5;
    background-image: var(--flower-01);
    background-size: contain;
    background-position: center left;
    background-repeat: no-repeat;
    pointer-events: none;
}

section.event-outer .inner .back-flower-bottom-01 {    
    bottom: -50px;
    left: -120px;    
    transform: rotate(-22deg);
}
section.event-outer .inner .back-flower-bottom-02 {
    bottom: -50px;
    right: -120px;    
    transform: rotate(22deg) scaleX(-1);    
}

@media only screen and (min-width: 1024px) {

    section.event-outer .inner .back-flower-top-01,
    section.event-outer .inner .back-flower-top-02 {
        width: 250px;
        height: 250px;
        top: -85px;
    }
    section.event-outer .inner .back-flower-top-01 {
        left: -140px;
    }    
    section.event-outer .inner .back-flower-top-02 {
        right: -140px;
    }
    section.event-outer .inner .back-flower-bottom-01,
    section.event-outer .inner .back-flower-bottom-02 {
        position: absolute;
        width: 350px;
        height: 350px;
        bottom: -80px;
    }
    section.event-outer .inner .back-flower-bottom-01 {
        left: -150px;
    }
    section.event-outer .inner .back-flower-bottom-02 {
        right: -150px;
    }

}





/* =======================
        PROTOCOL
======================= */
section.protocol {
    background-color: #ffffff;
    overflow: hidden;
}
section.protocol.protocol-01 .inner .head,
section.protocol.protocol-03 .inner .head {
    padding: 1em 0.75em 0.75em 0.75em;
    background-color: var(--secondary-clr);
}
section.protocol.protocol-02 .inner .head .step-outer {
    background-color: var(--secondary-clr);
}
section.protocol.protocol-01 .inner .head p,
section.protocol.protocol-03 .inner .head p {
    color: #fff;
    font-size: calc(var(--fs-text) + 2.5px);
    margin-bottom: 0.25em;
}
section.protocol.protocol-01 .inner .head h1,
section.protocol.protocol-03 .inner .head h1 {
    font-size: calc(var(--fs-title) + 2.5px);
    font-family: var(--notoserif);
    color: #fff;
}
section.protocol.protocol-03 .inner .body .slider .content .text-01 {
    font-family: var(--notoserif);
    font-weight: normal;
    font-size: calc(var(--fs-text) + 5px);
    color: var(--primary-clr);
    text-transform: capitalize;
}
.protocol.protocol-03 .inner .body .slider_dots::before {
    border-color: var(--secondary-clr)!important;
}
.protocol.protocol-03 .inner .body .slider_dots .slider_navigator {
    background-color: var(--secondary-clr)!important;
}
.protocol.protocol-03 .inner .body .slider_dots .slider_navigator.slick-current.slick-center {
    background-color: var(--primary-clr)!important;
}


/* =======================
        RSVP
======================= */
section.rsvp {
    background: var(--tertiary-clr);
    padding: 0.75em 0 1em 0;
    overflow: hidden;
    position: relative;
}
section.rsvp .rsvp-inner {
    padding: 0.75em 0 1.25em 0;
    position: relative;
    z-index: 1;
}
section.rsvp .rsvp-inner .rsvp-form,
section.rsvp .rsvp-inner .rsvp-confirm,
section.rsvp .rsvp-inner .rsvp-full {
    padding: 0;
}
section.rsvp .rsvp-inner .head {
    padding: 0.5em 0.75em 0.75em 0.75em;
    margin: 0;
    position: relative;
    text-align: center;
}
section.rsvp .rsvp-inner .head h1 {
    margin-bottom: 0;
    margin-left: 25px;
    margin-right: 25px;
    font-size: calc(var(--fs-title) + 5px);
    color: var(--primary-clr);
    font-family: var(--courgette);
}
section.rsvp .rsvp-inner .body {
    padding: 0.75em;
    margin: 0;
    min-height: 0;
}
.rsvp .rsvp-confirm .body p {
    font-family: var(--notoserif);
    font-size: var(--fs-text);
    color: var(--wood-clr);
}
.rsvp .rsvp-confirm .body .status {
    font-size: calc(var(--fs-text) + 2px);
}
section.rsvp .rsvp-inner .foot {
    padding: 0.75em 0.75em 0.5em 0.75em;
    margin: 0;
}
section.rsvp label,
section.rsvp label.form-label,
section.rsvp button,
section.rsvp input,
section.rsvp p {
    font-family: var(--notoserif);
    font-size: var(--fs-text);
    color: var(--wood-clr);
}
section.rsvp .rsvp-inner .attendance-value {
    font-weight: normal;
    border-radius: 4px;
    font-family: var(--notoserif);
    font-size: var(--fs-text);
    color: #fff;
    padding: 0.5em 1em;
    background: #a19e97;
}
section.rsvp .rsvp-inner .attendance-value i {
    font-size: 1em;
}
section.rsvp .rsvp-inner button.rsvp-submit,
section.rsvp .rsvp-inner button.change-confirmation {
    background: var(--primary-clr);
    color: #fff;
    font-family: var(--notoserif);
    border-radius: 4px;
    font-weight: normal;
    font-size: var(--fs-text);
    padding: 0.5em 1em;
}
section.rsvp .rsvp-inner button.rsvp-submit:hover,
section.rsvp .rsvp-inner button.change-confirmation:hover {
    background-color: var(--secondary-clr);
}
.plus-minus-toggle button {
    border-radius: 4px;
}
.plus-minus-toggle button i {
    font-size: 0.8em;
}
.plus-minus-toggle.plus button {
    color: #fff;
    background: var(--primary-clr);
}
.plus-minus-toggle.minus button {
    background: #d4cfc2;
    color: #fff;
}
.plus-minus-toggle.plus button:hover {
    color: var(--primary-clr);
    background-color: var(--secondary-clr);
}
.plus-minus-toggle.minus button:hover {
    color: var(--primary-clr);
    background: var(--secondary-clr);
}
.plus-minus-control {
    border-radius: 4px!important;
    border-color: var(--wood-clr);
}

/* E-Invitation */
.rsvp .e-invitation {
    margin-top: 0.5em;
    padding: 0.75em 0 1.25em 0;
}
.rsvp .e-invitation .e-invitation__card {
    margin-bottom: 2em;
}
.rsvp .e-invitation .e-invitation__download {    
    border-color: var(--primary-clr);
    background-color: var(--primary-clr);
    border-radius: 4px;
    color: #fff;
    font-family: var(--notoserif);
    border-radius: 4px;
    font-weight: normal;
    font-size: var(--fs-text);
    padding: 0.5em 2em;
}
.rsvp .e-invitation .e-invitation__download .e-invitation__download-svg path {    
    stroke: #fff;
}
.rsvp .e-invitation .e-invitation__download:hover {
    background: var(--secondary-clr);
    border-color: var(--secondary-clr);
}


section.rsvp > .flower-01 {
    position: absolute;
    top: -75px;
    left: -100px;
    width: 180px;
    height: 180px;
    transform: scaleX(-1);
    background-image: var(--flower-03);
    background-position: center bottom;
    background-size: contain;
    background-repeat: no-repeat;
}
section.rsvp > .flower-02 {
    position: absolute;
    top: -75px;
    right: -100px;
    width: 180px;
    height: 180px;
    background-image: var(--flower-03);
    background-position: center bottom;
    background-size: contain;
    background-repeat: no-repeat;
}

@media only screen and (min-width: 1024px) {
 
    section.rsvp > .flower-01 {
        top: -120px;
        left: -140px;
        width: 250px;
        height: 250px;
    }
    section.rsvp > .flower-02 {
        top: -120px;
        right: -140px;
        width: 250px;
        height: 250px;
    }

}




/* =======================
        STREAMING
======================= */
section.live-streaming {
    background: var(--tertiary-clr);
    padding: 0.75em 0 1em 0;
    overflow: hidden;
    position: relative;
}
section.live-streaming .inner {
    padding: 0.75em 0 1.25em 0;
    position: relative;
    z-index: 1;
}
section.live-streaming .inner .head {
    padding: 0.75em;
    position: relative;
}
section.live-streaming .inner .head h1 {    
    color: var(--primary-clr);
    font-size: var(--fs-title);
    margin-bottom: 0.2em;
}
section.live-streaming .inner .head p {
    font-style: italic;
    font-size: calc(var(--fs-text) + 2px);
}
.live-streaming .inner .body p {
    font-size: var(--fs-text);
}
.live-streaming .inner .body p.meeting-text {
    font-size: calc(var(--fs-text) + 2px);
    font-family: var(--notoserif-b);
}
.live-streaming .inner .body > .streaming-info > div.link > a {
    border-radius: 4px;
    background: var(--primary-clr);
    color: #fff;
    font-family: var(--notoserif);
    font-size: var(--fs-text);
    font-weight: normal;
    padding: 0.5em 1em;
}
.live-streaming .inner .body > .streaming-info > div.link > a:hover {
    background-color: var(--secondary-clr);
}




/* =======================
        GIFT
======================= */
section.gift {
    background: var(--tertiary-clr);
    padding: 0.5em 0 1em 0;
    overflow: hidden;
    position: relative;
}
section.gift .gift-inner {
    padding: 0.5em 0.5em 1.25em 0.5em;
    position: relative;
    z-index: 1;
}
section.gift .gift-inner .gift-title {
    padding: 0.5em;
    margin-bottom: 1em;
    position: relative;
}
section.gift .gift-inner .gift-title h1 {    
    font-size: calc(var(--fs-title));
    margin-bottom: 0.2em;
    color: var(--primary-clr);
}
section.gift .gift-inner .gift-title p {
    font-size: calc(var(--fs-text) + 2px);
    margin: 0;    
    line-height: 1.2;
    font-style: italic;
}

section.gift .gift-inner .gift-form {
    margin-bottom: 0.5em;
}

section.gift label,
section.gift input,
section.gift textarea,
section.gift button,
section.gift div,
section.gift p,
section.gift span {
    font-family: var(--notoserif);
    font-size: var(--fs-text);
    color: var(--wood-clr);
}
.gift label.form-label.center {
    font-size: calc(var(--fs-text) + 2px);
    font-family: var(--notoserif);
    font-weight: normal;
}
.gift .gift-inner .gift-form .gift-picture .picture-detail .head h2 {
    font-size: calc(var(--fs-text) + 5px);
    color: var(--primary-clr);
    font-family: var(--notoserif);
}
.gift .gift-inner .gift-form .gift-picture .picture-detail .gift-back,
.gift .gift-inner .gift-form .gift-picture .picture-detail .head p {
    font-size: var(--fs-text);
}
.gift .gift-inner .gift-form .gift-picture .picture-detail .gift-back i {
    font-size: 1em;
}
.gift .gift-inner .gift-form .selectize-control .item p,
.gift .gift-inner .gift-form .selectize-control .item p strong {
    font-family: var(--notoserif)!important;
    color: var(--wood-clr)!important;
    font-size: var(--fs-text)!important;
    font-weight: normal!important;
}
.gift .gift-inner .gift-form .selectize-control .item:hover {
    background-color: var(--primary-clr)!important;
}
.gift .gift-inner .gift-form .selectize-control .item:hover p,
.gift .gift-inner .gift-form .selectize-control .item:hover p strong {
    color: #fff!important;
}
.gift .gift-inner .gift-form .gift-details .bank-detail .saving-books .copy-account {
    border-color: var(--primary-clr);
    color: var(--primary-clr);
    margin-left: 5px;
}
.gift .gift-inner .gift-form .gift-details .bank-detail .saving-books .copy-account:hover {
    background: var(--primary-clr);
    color: #fff;
}
.gift .gift-inner .gift-form .gift-picture .picture-detail .body div[data-upload="gift-picture"]::before {
    border-color: var(--secondary-clr);
}
.gift .gift-inner .gift-form .gift-picture .picture-detail .body div[data-upload="gift-picture"] > i {
    color: var(--secondary-clr);
}
.gift .gift-inner .gift-form .gift-submit,
.gift .gift-inner .gift-form .gift-next {
    background: var(--primary-clr);
    color: #fff;
    font-family: var(--notoserif);
    font-weight: normal;
    font-size: var(--fs-text);
}
.gift .gift-inner .gift-form .gift-submit:hover,
.gift .gift-inner .gift-form .gift-next:hover {
    background-color: var(--secondary-clr);
}
.gift .gift-inner .gift-form .gift-submit i,
.gift .gift-inner .gift-form .gift-next i {
    font-size: 0.8em;
}

/* Tanpa Nominal Konfigurasi */
section.gift .gift-inner .gift-form .gift-details .bank-detail {
    padding-bottom: 0.25em;
}
section.gift .gift-inner .gift-form .gift-details .bank-detail .saving-books {
    margin-bottom: 0;
}
section.gift .gift-inner .gift-form .bio-detail {
    padding-top: 0.25em;
}



/* =======================
        COMMENT(S)
======================= */
section.comment-outer {
    background: var(--primary-clr);
    padding: 0.75em 0 1.25em 0;
    overflow: hidden;
    position: relative;
}
section.comment-outer .comment-inner {
    padding: 0.75em 0 1.25em 0;
    position: relative;
    z-index: 1;
}
section.comment-outer .comment-inner .head {
    padding: 0.75em;
    text-align: center;
    margin-bottom: 0.5em;
    position: relative;
}
section.comment-outer .comment-inner .head h1 {
    margin: 0;
    font-size: var(--fs-title);
    padding: 0;
    color: var(--secondary-clr);
}
section.comment-outer .comment-inner .head p {
    margin-top: 0.25em;
    color: var(--secondary-clr);
    font-size: calc(var(--fs-text) + 2px);
}

section.comment-outer .comment-inner .comment-form {
    padding: 0.5em 0.75em;
    margin-bottom: 0;
}
section.comment-outer .comment-inner .comments {
    padding: 0;
}
section.comment-outer .comment-inner .comments .comment {
    padding: 0.5em 0.75em;
}
section.comment-outer .form-group {
    margin-bottom: 0.5em;
}

section.comment-outer .comment-inner .foot {
    padding: 0.5em 0.75em;
}

section.comment-outer p,
section.comment-outer button,
section.comment-outer textarea,
section.comment-outer input,
section.comment-outer small,
section.comment-outer a,
section.comment-outer strong,
section.comment-outer .comment-body p {
    font-family: var(--notoserif);
    color: var(--secondary-clr);
    font-weight: normal;
    font-size: var(--fs-text);
}
section.comment-outer strong {
    font-family: var(--notoserif-b);
    color: inherit;
    font-weight: normal;
    font-size: calc(var(--fs-text) + 2px);
}
section.comment-outer .comment .comment-head p {
    font-size: var(--fs-text);
    color: var(--secondary-clr);
    font-family: var(--notoserif);
}
section.comment-outer .comment .comment-body p {
    font-size: calc(var(--fs-text) - 1px);
}
.comment .comment-foot small {
    font-size: calc(var(--fs-text) - 2px);
    color: #8b8b8b;
}
.comment .comment-foot a {
    font-size: calc(var(--fs-text) - 2px);
}
section.comment-outer .comment-inner button.more-comment,
section.comment-outer .comment-form button.send-comment,
section.comment-outer input,
section.comment-outer textarea {
    border-radius: 4px;
}
section.comment-outer .comment-inner button.more-comment,
section.comment-outer .comment-form button.send-comment {
    background-color: var(--secondary-clr);
    color: var(--primary-clr);
    font-size: calc(var(--fs-text) - 1px);
    padding: 0.4em 1.25em;
}
section.comment-outer .comment-inner button.more-comment:hover,
section.comment-outer .comment-form button.send-comment:hover {
    background-color: #8b8b8b;
    color: #fff;
}

section.comment-outer .bird-01 {
    position: absolute;
    bottom: 0;
    right: -65px;
    width: 280px;
    height: 350px;
    background-image: var(--bird-01);
    background-position: left bottom;
    background-size: contain;
    background-repeat: no-repeat;
    transition: all 0.25s ease-in-out;
}


@media only screen and (min-width: 1024px) {

    section.comment-outer .bird-01 {
        bottom: 0;
        right: -20px;
        width: 350px;
        height: 400px;
    }

}

@media only screen and (min-width: 1440px) {

    section.comment-outer .bird-01 {
        bottom: 0;
        right: -10px;
        width: 380px;
        height: 430px;
    }

}




/* =======================
        FOOTNOTE
======================= */
section.footnote {
    background: var(--primary-clr);
    padding: 0;
    position: relative;
    overflow: hidden;
}
section.footnote .inner {
    padding: 0.75em 0;
    padding-bottom: 75px;
    position: relative;    
}
section.footnote .inner .details {
    padding: 1em 0;
    text-align: center;
    position: relative;
}

section.footnote .inner .details .orn-01 {
    width: 60px;
    display: block;
    margin: 0 auto;
    margin-bottom: 2.5em;
}
section.footnote .inner .details .orn-01 .cls-1,
section.footnote .inner .details .orn-01 .cls-2 {
    fill: var(--secondary-clr);
}
section.footnote .inner .details .orn-01 .cls-1 {
    fill-rule: evenodd;
}

section.footnote .inner .details h1 {
    font-size: calc(var(--fs-title) + 5px);
}
section.footnote .inner .details p.date {
    font-size: calc(var(--fs-text) + 2px);
    color: var(--secondary-clr);
    margin-top: 0.75em;
}

section.footnote .inner .flower-01,
section.footnote .inner .flower-02 {
    position: absolute;
    background-image: var(--flower-01);
    background-size: contain;
    background-position: center left;
    background-repeat: no-repeat;
    pointer-events: none;
    transition: all 0.25s ease-in-out;
}

section.footnote .inner .flower-01 {    
    bottom: -50px;
    left: -120px;
    width: 250px;
    height: 250px;
    opacity: 0.75;
    transform: rotate(-22deg);
}
section.footnote .inner .flower-02 {
    bottom: -50px;
    right: -120px;
    width: 250px;
    height: 250px;
    opacity: 0.75;
    transform: rotate(22deg) scaleX(-1);    
}

@media only screen and (min-width: 1024px) {

    section.footnote .inner {
        padding-bottom: 125px;
    }
    section.footnote .inner .details .orn-01 {
        width: 80px;
    }
    section.footnote .inner .details h1 {
        font-size: calc(var(--fs-title) + 15px);
    }
    section.footnote .inner .flower-01 {    
        bottom: -90px;
        left: -150px;
        width: 350px;
        height: 350px;
    }
    section.footnote .inner .flower-02 {
        bottom: -90px;
        right: -150px;
        width: 350px;
        height: 350px;
    }

}

@media only screen and (min-width: 1440px) {

    section.footnote .inner .details h1 {
        font-size: calc(var(--fs-title) + 25px);
    }

}




/* =======================
        FOOTER
======================= */
section.footer {
    background: var(--secondary-clr);
    padding: 0;
}
section.footer .footer-inner {
    padding: 0.5em;
}
section.footer .footer-inner p {
    font-weight: normal;
    font-family: var(--notoserif-b);
    font-size: calc(var(--fs-text) - 2px);
    color: var(--primary-clr);
}

section.footer .footer-inner .footer-logo {
    width: 55px;
}
section.footer .footer-inner .footer-logo path {
    fill: var(--primary-clr);
}

@media only screen and (max-width: 960px) {
    section.footer .footer-inner.flex-column {
        flex-direction: column;
        padding-top: 80px;
        padding-bottom: 150px;
    }
    section.footer .footer-inner.flex-column p {
        margin-right: 0;
        font-size: calc(var(--fs-text) + 2px);
    }
    section.footer .footer-inner.flex-column .footer-logo {
        margin-top: 10px;
        width: 150px;
    }
}


