/*  Author:   Martin Stettler (https://www.dieweberei.ch/)
    Version:  15/09/2019 // BS v4.3.1
*/

/* ==========================================================================
   Browse Happy prompt lte IE 9
   ========================================================================== */

.browsehappy {
    margin: 3px 0;
    background: #CC0033;
    color: #FFF;
    padding: 8px;
}

.browsehappy a {
    color: #FFF;
    text-decoration: underline;
}

.browsehappy a:hover {
    text-decoration: none;
}

/* ==========================================================================
   BASE STYLES
   ========================================================================== */

/* Bootstrap CSS Overrides */
body {
    margin: 0;
    font-family: "Readex Pro", sans-serif;
    font-variation-settings: "HEXP" 0;
    font-optical-sizing: auto;
    font-style: normal;
    font-size: 18px;
    font-weight: 400;
    line-height: 1.4;
    color: #6f6f6f;
    text-align: left;
    background-color: #FFF;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto;
    font-style: normal;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "Readex Pro", sans-serif;
    font-variation-settings: "HEXP" 0;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
    margin-top: 0;
    margin-bottom: 8px;
}

h1,
.lead h1 {
    font-size: 50px;
    font-size: calc(28px + (50 - 28) * (100vw - 320px)/(1280 - 320));
    text-transform: none;
    color: #9c9c9c;
    margin-bottom: 30px;
}

h2 {
    font-size: 50px;
    font-size: calc(28px + (50 - 28) * (100vw - 320px)/(1280 - 320));
    margin-bottom: 24px;
    text-align: center;
    text-transform: uppercase;
}

h3 {
    font-size: 30px;
    font-size: calc(24px + (30 - 24) * (100vw - 320px)/(1280 - 320));
    text-transform: uppercase;
    margin-bottom: 0;
}

h4 {
    font-size: 24px;
    border-bottom: 1px solid #ffc700;
    padding-bottom: 8px;
    margin-bottom: 14px
}

h4 span {
    font-size: 18px;
    font-family: "Readex Pro", sans-serif;
    font-variation-settings: "HEXP" 0;
    font-optical-sizing: auto;
    font-style: 600;
}

section .unit:nth-child(2) h3 {
    margin-top: 0;
}

p {
    margin-top: 0;
    margin-bottom: 20px;
}

.lead p,
p.important {
    font-size: 30px;
    font-size: calc(24px + (30 - 24) * (100vw - 320px)/(1280 - 320));
    margin-bottom: 35px;
}

.lead p.small-text {
    font-size: 20px;
    font-size: calc(16px + (20 - 16) * (100vw - 320px)/(1280 - 320));
    margin-bottom: 35px;
}

ul {
    margin-top: 0;
    margin-bottom: 20px;
    padding-left: 18px;
}

li {
    color: #ffc700;
    margin-bottom: 0;
}

li span {
    color: #6f6f6f;
}

span.highlight {
    color: #ffc700;
}

b,
strong {
    font-family: "Readex Pro", sans-serif;
    font-variation-settings: "HEXP" 0;
    font-optical-sizing: auto;
    font-weight: 600;
    font-style: normal;
}

a {
    color: #6f6f6f;
}

a:hover,
a[href^="tel"]:hover {
    color: #ffc700;
    text-decoration: none;
    cursor: pointer;
}

a:focus,
button:focus {
    outline: none;
}

p a.link {
    font-size: 24px;
    text-decoration: underline;
    text-underline-offset: 4px;
    text-decoration-color: #ffc700;
    font-weight: 600;
}

/* Lists */
.article-full ul,
.article-half ul {
    padding-left: 20px;
}

/* Smooth animations */
a,
a:hover,
.footer a li,
.footer a:hover li,
.navbar,
.navbar.shrink,
.navbar-nav,
.navbar-nav.shrink,
.navbar-brand,
.navbar-brand.shrink,
.logo,
.logo.shrink,
.logo-title,
.logo-title.shrink,
.collapsed h4,
h4 {
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    transition: all 0.5s;
}

/* ==========================================================================
   HEADER
   ========================================================================== */

.navbar {
    border-bottom: 3px solid #ffc700;
}

.logo {
    display: block;
    width: 56px;
    height: 58px;
    background: url(../img/logo_nhp_small.svg);
    background-size: 100% 100%;
    text-indent: -9999px;
}

.logo-title {
    display: block;
    width: 180px;
    height: 11px;
    background: url(../img/logo_nhp_text.svg);
    background-size: 100% 100%;
    text-indent: -9999px;
    margin-top: 4px;
}

/* Shrink */
.navbar.shrink {
    padding-top: 0;
    padding-bottom: 0;
}

@media (max-width: 991px) {
    .navbar-brand.shrink {
        transform: translateY(-80px);
        padding: 0;
    }
}

.logo.shrink {
    height: 0;
}

.logo-title.shrink {
    transform: translateX(-180px);
    margin: 0;
    height: 0;
}

header {
    position: relative;
    width: 100% !important;
    margin-top: 0;
}

/* Owl Carousel */
.owl-carousel {
    position: relative;
    margin-bottom: 30px;
}

.owl-carousel img {
    margin: 0;
}

.owl-nav {
    position: absolute;
    width: 100%;
    height: 37px;
}

.owl-prev {
    position: absolute;
    left: 0;
    margin-left: 15px;
}

.owl-next {
    position: absolute;
    right: 0;
    margin-right: 15px;
}

.owl-prev:hover {
    margin-left: 10px;
}

.owl-next:hover {
    margin-right: 10px;
}

.owl-prev,
.owl-prev:hover,
.owl-next,
.owl-next:hover {
    -webkit-transition: all 0.25s;
    -moz-transition: all 0.25s;
    transition: all 0.25s;
}

.owl-prev span,
.owl-next span {
    content: " ";
    display: block;
    width: 30px;
    height: 30px;
    padding: 12px;
    border-radius: 100%;
    background-color: rgba(0, 0, 0, 0.65);
    background-image: url(../img/rwd.svg);
    background-repeat: no-repeat;
    background-size: 10px 16px;
    background-position: center center;
    text-indent: -9999px;
    -webkit-transition: all 0.25s;
    -moz-transition: all 0.25s;
    transition: all 0.25s;
}

.owl-next span {
    background-image: url(../img/fwd.svg);
    background-repeat: no-repeat;
}

.owl-prev:hover span,
.owl-next:hover span {
    background-color: rgba(0, 0, 0, 0.8);
    -webkit-transition: all 0.25s;
    -moz-transition: all 0.25s;
    transition: all 0.25s;
}

.title-container {
    position: absolute;
    right: 0;
    bottom: 0;
    padding: 5px 10px;
    font-family: "Readex Pro", sans-serif;
    font-variation-settings: "HEXP" 0;
    font-optical-sizing: auto;
    font-style: normal;
    font-size: 21px;
    font-weight: 400;
    color: #FFF;
    line-height: 1.2;
    background: rgba(0, 0, 0, 0.65);
}

/* ==========================================================================
   NAVIGATION
   ========================================================================== */

/* Offcanvas menu
-------------------------------------------------- */
html,
body {
    overflow-x: hidden;
}

/* Prevent scroll on narrow devices */
@media (max-width: 991.98px) {
    .offcanvas-collapse {
        position: fixed;
        top: 0;
        bottom: 0;
        right: 100%;
        /* left for collapse-left */
        right: -260px;
        /* left for collapse-left */
        width: 260px;
        border-left: 2px solid #ffc700;
        padding-right: 0;
        padding-left: 32px;
        overflow-y: auto;
        visibility: hidden;
        background-color: #FFF;
        transition-timing-function: ease-in-out;
        transition-duration: .3s;
        transition-property: right, visibility;
        z-index: 1000;
    }

    /* left for collapse-left */

    .offcanvas-collapse.open {
        right: 0;
        /* left for collapse-left */
        visibility: visible;
    }

    .navbar-nav {
        margin-top: 94px;
    }
}

/* Hamburger
-------------------------------------------------- */
/*!
 * Hamburgers
 * @description Tasty CSS-animated hamburgers
 * @author Jonathan Suh @jonsuh
 * @site https://jonsuh.com/hamburgers
 * @link https://github.com/jonsuh/hamburgers
 */
.hamburger {
    position: absolute;
    top: 15px;
    right: 15px;
    z-index: 1080;
    padding: 0;
    display: inline-block;
    cursor: pointer;
    transition-property: opacity, filter;
    transition-duration: 0.15s;
    transition-timing-function: linear;
    font: inherit;
    color: inherit;
    text-transform: none;
    background-color: transparent;
    border: 0;
    margin: 0;
    overflow: visible;
}

.hamburger:hover {
    opacity: 0.7;
}

.hamburger-box {
    width: 40px;
    height: 24px;
    display: inline-block;
    position: relative;
}

.hamburger-inner {
    display: block;
    top: 50%;
    margin-top: 1px;
}

.hamburger-inner,
.hamburger-inner::before,
.hamburger-inner::after {
    width: 40px;
    height: 4px;
    background-color: #6f6f6f;
    position: absolute;
    transition-property: transform;
    transition-duration: 0.15s;
    transition-timing-function: ease;
}

.hamburger.is-active .hamburger-inner,
.hamburger.is-active .hamburger-inner::before,
.hamburger.is-active .hamburger-inner::after {
    background-color: #6f6f6f;
}

.hamburger-inner::before,
.hamburger-inner::after {
    content: "";
    display: block;
}

.hamburger-inner::before {
    top: -10px;
}

.hamburger-inner::after {
    bottom: -10px;
}

/* Spin */
.hamburger--spin .hamburger-inner {
    transition-duration: 0.22s;
    transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.hamburger--spin .hamburger-inner::before {
    transition: top 0.1s 0.25s ease-in, opacity 0.1s ease-in;
}

.hamburger--spin .hamburger-inner::after {
    transition: bottom 0.1s 0.25s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.hamburger--spin.is-active .hamburger-inner {
    transform: rotate(225deg);
    transition-delay: 0.12s;
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

.hamburger--spin.is-active .hamburger-inner::before {
    top: 0;
    opacity: 0;
    transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out;
}

.hamburger--spin.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(-90deg);
    transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/* Bootstrap CSS Overrides */

.navbar-brand {
    display: inline-block;
    padding-top: 5px;
    padding-bottom: 5px;
    margin-right: 16px;
    font-size: 20px;
    line-height: inherit;
    white-space: nowrap;
}

.navbar-light .navbar-brand {
    color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-brand:hover,
.navbar-light .navbar-brand:focus {
    color: rgba(0, 0, 0, 0.9);
}

.nav-link {
    display: block;
    padding: 8px 16px;
    margin-right: 0;
    margin-left: 0;
    text-transform: uppercase;
}

.navbar-light .navbar-nav .nav-link {
    color: #6f6f6f;
}

.navbar-light .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link:focus {
    color: #ffc700;
}

.navbar-light .navbar-nav .nav-link.disabled {
    color: #ffc700;
}

.navbar-light .navbar-nav .show>.nav-link,
.navbar-light .navbar-nav .active>.nav-link,
.navbar-light .navbar-nav .nav-link.show,
.navbar-light .navbar-nav .nav-link.active {
    color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-toggler {
    color: rgba(0, 0, 0, 0.5);
    border-color: rgba(0, 0, 0, 0.1);
}

.bg-light {
    background-color: #FFF !important;
}

a.bg-light:hover,
a.bg-light:focus,
button.bg-light:hover,
button.bg-light:focus {
    background-color: #dae0e5 !important;
}

@media (min-width: 576px) {
    .navbar-expand-sm .navbar-nav .nav-link {
        padding-right: 8px;
        padding-left: 8px;
    }
}

.anchor {
    display: block;
    height: 55px;
    /* OPL adjust */
    margin-top: -55px;
    /* OPL adjust */
    visibility: hidden;
}

/* ==========================================================================
   MAIN CONTENT
   ========================================================================== */
header {
    margin-top: 102px;
}

.main {
    position: relative;
    padding-top: 3vw;
    /* 5vw 30px*/
    padding-bottom: 3vw;
    /* 5vw 30px */
}

.main li {
    margin-bottom: 12px;
}

.main .card-body li {
    margin-bottom: 6px;
}

.main ul li:last-child {
    margin-bottom: 0;
}

.flower-1 span,
.flower-2 span,
.flower-3 span,
.flower-4 span,
.flower-5 span {
    position: absolute;
    top: -10%;
    left: -35%;
    display: block;
    background: url(../img/flower.svg) no-repeat;
    background-size: 100% 100%;
    width: 70%;
    height: 70%;
}

.flower-2 span {
    top: 0%;
    right: -25%;
    left: auto;
    width: 50%;
    height: 50%;
}

.flower-3 span {
    top: 40%;
    left: -25%;
    width: 50%;
    height: 50%;
}

.flower-4 span {
    top: 0%;
    right: -25%;
    left: auto;
    width: 70%;
    height: 70%;
}

.flower-5 span {
    top: 30%;
    left: -25%;
    width: 50%;
    height: 50%;
}

hr.yellow-line {
    width: 50%;
    height: 2px;
    background-color: #ffc700;
    margin: 0 auto;
}

.unit {
    margin-top: 5vw;
    /* 45px */
    margin-bottom: 5vw;
    /* 45px */
}

.part {
    margin-top: 10px;
    /* 5vw */
    margin-bottom: 10px;
    /* 5vw */
}

.card-block {
    margin-bottom: 12px;
}


.unit p:last-child,
.unit ul:last-child,
.unit img:last-child {
    margin-bottom: 0;
}

.part p:last-child,
.part ul:last-child,
.part img:last-child {
    margin-bottom: 0;
}

/* Collapse */
.accordion .part {
    margin: 0;
}

.part.card {
    margin-top: 0;
}

.part h3 {
    position: relative;
    padding-bottom: 6px;
    margin-bottom: 3px;
}

.part h3:after {
    background-color: #ffc700;
    bottom: 0;
    content: '';
    display: block;
    height: 1px;
    position: absolute;
    width: 100%;
}

.part-col {
    margin-bottom: 4vw;
}

.unit .part-col:last-child {
    margin-bottom: 0;
}

.card {
    position: relative;
    border: none;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 0;
    background-color: transparent;
}

.card_abc h4 {
    color: #9c9c9c;
    text-transform: uppercase;
}

.card_abc h4:first-letter {
    color: #6f6f6f;
}


.card_abc h4:hover:first-letter,
.card_abc h4:hover {
    color: #ffc700;
}

.card-header {
    padding: 0;
    background-color: transparent;
    margin: 0;
    border-bottom: 0;
}

.card-header:after {
    background-color: #ffc700;
    bottom: 0;
    content: '';
    display: block;
    height: 1px;
    position: absolute;
    width: calc(100% - 30px);
}

.card-title h4 {
    margin-top: 5px;
    margin-bottom: 0;
    border-bottom: 0;
}

.card-body {
    padding: 0;
    padding-bottom: 30px;
}

.card-header .icon {
    display: inline-block;
    width: 15px;
    height: 8px;
    margin-left: 15px;
    margin-right: 15px;
    background-size: 100% 100%;
    background-image: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='utf-8'%3F%3E%3C!-- Generator: Adobe Illustrator 24.0.3, SVG Export Plug-In . SVG Version: 6.00 Build 0) --%3E%3Csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 15 7.7' style='enable-background:new 0 0 15 7.7;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%23FFC700;%7D%0A%3C/style%3E%3Cpolygon class='st0' points='1.3,7.7 7.5,2.6 13.7,7.7 15,6.1 7.5,0 0,6.1 '/%3E%3C/svg%3E%0A");
    transition: .3s transform ease-in-out;
}

.card-header .collapsed .icon {

    background-image: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='utf-8'%3F%3E%3C!-- Generator: Adobe Illustrator 24.0.3, SVG Export Plug-In . SVG Version: 6.00 Build 0) --%3E%3Csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 15 7.7' style='enable-background:new 0 0 15 7.7;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:%236F6F6F;%7D%0A%3C/style%3E%3Cpolygon class='st0' points='13.7,0 7.5,5.1 1.3,0 0,1.6 7.5,7.7 15,1.6 '/%3E%3C/svg%3E%0A");
    transition: .3s transform ease-in-out;
}

.card-header a .icon {
    position: absolute;
    right: 0;
    top: 15px;
}

/* Back to top */
#return-to-top {
    position: fixed;
    bottom: 36px;
    right: 15px;
    display: block;
    display: none;
    width: 34px;
    height: 23px;
    opacity: 1;
    background: url(../img/arrow-go-to-top-yellow.svg);
    background-repeat: no-repeat;
    -webkit-transition: all 0.3s linear;
    -moz-transition: all 0.3s ease;
    -ms-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

#return-to-top:hover {
    opacity: 0.8;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

footer {
    background-color: #6f6f6f;
    padding-top: 5vw;
    color: #FFF;
    font-size: 20px;
}

.footer a {
    color: #FFF;
}

.footer a:hover,
.footer a:hover li {
    color: #ffc700 !important;
    cursor: pointer;
}

.footer ul {
    margin: 0;
    padding-left: 0;
    margin-bottom: 0 !important;
}

.footer li,
.footer .vcard ul li ul li {
    display: inline-block;
    padding-right: 5px;
    color: #FFF;
}

.footer .vcard ul li ul li:first-child {
    display: block;
}

.bottom-links li {
    margin-right: 40px;
}

.footer .vcard li {
    display: block;
}

.bottom-links {
    margin-bottom: 36px;
}

/* ==========================================================================
   SELECTION
   ========================================================================== */

::-moz-selection {
    text-shadow: none;
    background: #333;
    color: #FFF;
}

::selection {
    text-shadow: none;
    background: #333;
    color: #FFF;
}

img::selection {
    background: 0 0;
}

img::-moz-selection {
    background: 0 0;
}

body {
    webkit-tap-highlight-color: #333;
}

a[href^="tel"],
a[href^="sms"] {
    color: inherit;
    cursor: default;
    text-decoration: none;
}