:root {
    --color-1: #f7f2df;
    --color-1v: rgba(247, 242, 223, .8);
    --color-2: #194c0f;
    --color-3: #9cbd30;
    --color-4: #b48624;
    --color-6: #9e8227;
    --color-5: #261b0b;

    --color-white: #fff;

    --font-opensans: 'Open Sans', sans-serif;
    --font-spartan: 'League Spartan', sans-serif;
}

/* Box sizing rules */
*,
*::before,
*::after {
    box-sizing: border-box;
}

/* Remove default padding */
ul[class],
ol[class] {
    padding: 0;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
ul[class],
ol[class],
li,
figure,
figcaption,
blockquote,
dl,
dd {
    margin: 0;
}

/* Set core body defaults */
body {
    min-height: 100vh;
    scroll-behavior: smooth;
    text-rendering: optimizeSpeed;
    line-height: 1.5;
    font-family: 'Open Sans', sans-serif;
    font-size: 62.5%;

    padding-top: 130px;
}

body.long {
    padding-top: 540px;
}

body > * {
    font-size: 1.6em;
}

/* Remove list styles on ul, ol elements with a class attribute */
ul[class],
ol[class] {
    list-style: none;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
    text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img {
    max-width: 100%;
    display: block;
}

/* Natural flow and rhythm in articles by default */
article > * + * {
    margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
    font: inherit;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

.container {
    margin-right: auto;
    margin-left: auto;
}

.row {
    display: flex;
    flex-wrap: wrap;
}

.column {
    padding: 0 10px;
    flex-basis: 100%;
    max-width: 100%;
    display: block;
    box-sizing: border-box;
    vertical-align: top;
}

.xs12 { flex-basis: 100%; max-width: 100%; }
.xs11 { flex-basis: 91.666%; max-width: 91.666%; }
.xs10 { flex-basis: 83.333%; max-width: 83.333%; }
.xs9 { flex-basis: 75%; max-width: 75%; }
.xs8 { flex-basis: 66.666%; max-width: 66.666%; }
.xs7 { flex-basis: 58.333%; max-width: 58.333%; }
.xs6 { flex-basis: 50%; max-width: 50%; }
.xs5 { flex-basis: 41.666%; max-width: 41.666%; }
.xs4 { flex-basis: 33.333%; max-width: 33.333%; }
.xs3 { flex-basis: 25%; max-width: 25%; }
.xs2 { flex-basis: 16.666%; max-width: 16.666%; }
.xs1 { flex-basis: 8.333%; max-width: 8.333%; }

.sm { display: none; }
.md { display: none; }
.lg { display: none; }

@media (min-width: 576px) {
    .container {
        max-width: 540px;
    }

    .sm12 { flex-basis: 100%; max-width: 100%; }
    .sm11 { flex-basis: 91.666%; max-width: 91.666%; }
    .sm10 { flex-basis: 83.333%; max-width: 83.333%; }
    .sm9 { flex-basis: 75%; max-width: 75%; }
    .sm8 { flex-basis: 66.666%; max-width: 66.666%; }
    .sm7 { flex-basis: 58.333%; max-width: 58.333%; }
    .sm6 { flex-basis: 50%; max-width: 50%; }
    .sm5 { flex-basis: 41.666%; max-width: 41.666%; }
    .sm4 { flex-basis: 33.333%; max-width: 33.333%; }
    .sm3 { flex-basis: 25%; max-width: 25%; }
    .sm2 { flex-basis: 16.666%; max-width: 16.666%; }
    .sm1 { flex-basis: 8.333%; max-width: 8.333%; }
    .sm0 { display: none; }
    .sm { display: inline-block; }
}

@media (min-width: 768px) {
    .container {
        max-width: 720px;
    }

    .md12 { flex-basis: 100%; max-width: 100%; }
    .md11 { flex-basis: 91.666%; max-width: 91.666%; }
    .md10 { flex-basis: 83.333%; max-width: 83.333%; }
    .md9 { flex-basis: 75%; max-width: 75%; }
    .md8 { flex-basis: 66.666%; max-width: 66.666%; }
    .md7 { flex-basis: 58.333%; max-width: 58.333%; }
    .md6 { flex-basis: 50%; max-width: 50%; }
    .md5 { flex-basis: 41.666%; max-width: 41.666%; }
    .md4 { flex-basis: 33.333%; max-width: 33.333%; }
    .md3 { flex-basis: 25%; max-width: 25%; }
    .md2 { flex-basis: 16.666%; max-width: 16.666%; }
    .md1 { flex-basis: 8.333%; max-width: 8.333%; }
    .md0 { display: none; }
    .md { display: inline-block; }
}

@media (min-width: 1050px) {
    .container {
        max-width: 1008px;
    }

    .lg12 { flex-basis: 100%; max-width: 100%; }
    .lg11 { flex-basis: 91.666%; max-width: 91.666%; }
    .lg10 { flex-basis: 83.333%; max-width: 83.333%; }
    .lg9 { flex-basis: 75%; max-width: 75%; }
    .lg8 { flex-basis: 66.666%; max-width: 66.666%; }
    .lg7 { flex-basis: 58.333%; max-width: 58.333%; }
    .lg6 { flex-basis: 50%; max-width: 50%; }
    .lg5 { flex-basis: 41.666%; max-width: 41.666%; }
    .lg4 { flex-basis: 33.333%; max-width: 33.333%; }
    .lg3 { flex-basis: 25%; max-width: 25%; }
    .lg2 { flex-basis: 16.666%; max-width: 16.666%; }
    .lg1 { flex-basis: 8.333%; max-width: 8.333%; }
    .lg0 { display: none; }
    .lg { display: inline-block; }
}

.widespace {
    padding: 0 30px;
}

html {
    background-color: var(--color-1);
    color: var(--color-5);
}

@font-face {
    font-family: 'League Spartan';
    src: url('/public/font/leaguespartan-bold.woff2') format('woff2'),
    url('/public/font/leaguespartan-bold.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

/* UTILS ------------------------- */
.section-separator {
    height: 40px;
    width: 100%;
    background-color: var(--color-2);
}


article .section-separator {
    position: relative;
    width: 100vw;
    transform: translateX(-50%);
    left: 50%;
    margin-top: 0;
}


.section-preface {
    padding: 21px 0 51px;
}

.section-preface p {
    margin: 0 0 15px;
}

.button {
    min-width: 220px;
    height: 43px;
    padding: 10px 40px;
    display: inline-block;
    color: var(--color-white);
    text-align: center;
    font-size: 15px;
    font-weight: bold;
    border-radius: 5px;
    box-shadow: 0 2px 4px 0 rgba(38, 27, 11, 0.5);
    background-color: var(--color-3);
    cursor: pointer;
    text-decoration: none;
    transition: all .3s;
}

.button:hover,
.button:active {
    background-color: var(--color-4);
}

.highlight {
    padding: 8px 10px 0;
    background-color: var(--color-1);
    font-family: var(--font-spartan);
    font-size: 22px;
    font-weight: bold;
    color: var(--color-3);
    text-transform: uppercase;
    display: inline-block;
}

.highlight.green {
    background-color: var(--color-4);
    color: var(--color-white);
}

.center {
    justify-content: center;
}

.block-readmore {
    padding-top: 32px;
}


.zoom-image {
    overflow: hidden;
}

.zoom-image img {
    transform: scale(1);
    transition: .4s all;
}

.zoom-image:hover img {
    transform: scale(1.1);
}






/* HEADER ------------------------- */
.header {
    position: fixed;
    padding-top: 7px;
    width: 100%;
    height: 100px;
    z-index: 10;
    top: 0;
    background-color: var(--color-1);
    box-shadow: 0 2px 4px -2px var(--color-6);
}

.header-logo img {
    height: 75px;
    z-index: 4;
}

.header-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    margin-top: 36px;
}

.main-navigation-wrapper {
    position: relative;
}

.main-navigation {
    width: 100%;
    position: absolute;
    top: 0;
    right: 10px;
    z-index: 3;
}

.main-navigation ul {
    display: flex;
    justify-content: flex-end;
    margin: 6px 0;
}

.main-navigation li {
    list-style: none;
    margin-left: 30px;
}

.main-navigation a {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-4);
    text-transform: uppercase;
    text-decoration: none;
}

.main-navigation a.active {
    border-bottom: 2px solid var(--color-4);
}


.lead {
     font-size: 18px;
     font-weight: 600;
     color: var(--color-2);
 }





#menuToggle input {
    display: none;
}

#menu .small-only {
    display: none;
}

@media all and (max-width: 1049px) {
    .header-donation {
        display: none;
    }

    .main-navigation {
        position: relative;
        width: auto;
        top: 0;
        right: 0;
    }

    #menuToggle {
        display: flex;
        position: relative;
        top: 30px;
        right: 30px;

        z-index: 1;

        -webkit-user-select: none;
        user-select: none;
        align-items: end;
    }

    #menuToggle a {
        text-decoration: none;

        transition: color 0.3s ease;
    }

    #menuToggle a:hover {
    }


    #menuToggle input {
        display: block;
        width: 40px;
        height: 32px;
        position: absolute;
        top: -7px;
        right: -5px;

        cursor: pointer;

        opacity: 0; /* hide this */
        z-index: 20; /* and place it over the hamburger */

        -webkit-touch-callout: none;
    }

    #menuToggle .hamburger {
        position: absolute;
        right: 0;
        top: 0;
         width: 40px;
        height: 40px;
        overflow: hidden;
    }

    /*
		 * Just a quick hamburger
		 */
    #menuToggle span {
        display: block;
        width: 33px;
        height: 4px;
        margin-bottom: 5px;
        position: relative;

        background: var(--color-4);
        border-radius: 3px;

        z-index: 1;

        transform-origin: 4px 0;

        transition: transform 0.5s cubic-bezier(0.77,0.2,0.05,1.0),
        background 0.5s cubic-bezier(0.77,0.2,0.05,1.0),
        opacity 0.55s ease;
    }

    #menuToggle span:first-child {
        transform-origin: 0% 0%;
    }

    #menuToggle span:nth-last-child(2) {
        transform-origin: 0% 100%;
    }

    /*
		 * Transform all the slices of hamburger
		 * into a crossmark.
		 */
    #menuToggle input:checked ~ .hamburger span {
        opacity: 1;
        transform: rotate(45deg) translate(0, -10px);
    }

    /*
		 * But let's hide the middle one.
		 */
    #menuToggle input:checked ~ .hamburger span:nth-last-child(3) {
        opacity: 0;
        transform: rotate(0deg) scale(0.2, 0.2);
    }

    /*
		 * Ohyeah and the last one should go the other direction
		 */
    #menuToggle input:checked ~ .hamburger span:nth-last-child(2) {
        transform: rotate(-45deg) translate(-9px, 21px);
    }

    /*
		 * Make this absolute positioned
		 * at the top left of the screen
		 */
    #menu {
        position: fixed;
        width: 300px;
        top: 0;
        right: 0;
        margin: -100px 0 0 0;
        padding: 125px 0 0;
        display: block;

        background: var(--color-1v);
        list-style-type: none;
        -webkit-font-smoothing: antialiased;
        /* to stop flickering of text in safari */

        transform-origin: 0% 0%;
        transform: translate(105vw, 0);

        transition: transform 0.5s cubic-bezier(0.77,0.2,0.05,1.0);
    }

    #menu li {
        padding: 2px 0;
    }

    #menu li a {
        display: inline-block;
        padding: 8px 0;
    }

    /*
		 * And let's slide it in from the left
		 */
    #menuToggle input:checked ~ ul {
        transform: none;
    }

    #menu .small-only {
        display: inline-block;
    }
}






/* HERO ------------------------- */
.hero {
    position: relative;
    width: 100%;
    height: 440px;
    z-index: 1;
    overflow: hidden;
}

.hero.fixed {
    position: fixed;
    top: 100px;
}

.hero.simple::after {
    display: none;
}

.hero:not(.nofade)::after {
    position: absolute;
    content: '';
    bottom: 0;
    left: 0;
    width: 100%;
    height:  210px;
    background-image: linear-gradient(to bottom, rgba(54, 131, 34, 0), #194c0f 113%);
    z-index: 2;
}

article .hero {
    width: 100vw;
    transform: translateX(-50%);
    left: 50%;
}

.hero img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    position: relative;
    z-index: 1;
}

.hero-content {
    width: 100%;
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    opacity: 1;
    transition: .4s all;
}

.down .fixed .hero-content {
    opacity: 0;
}

.hero-content > * {
    margin: 0 auto;
}

.hero .highlight {
    margin-bottom: 23px;
}

.hero-lead {
    margin-bottom: 12px;
    color: var(--color-white);
    font-size: 1.125em;
}







/* MAIN ------------------------- */
.main-content {
    position: relative;
    z-index: 3;
    background: var(--color-1) url("/public/images/bg-gyerekek.png") no-repeat scroll center bottom;
    background-attachment: fixed;
    background-size: 100%;
    scroll-behavior: smooth;
    padding-bottom: 60px;
    overflow: hidden;
}

.main-content .opaque {
    background-color: rgba(247, 242, 223, 0.8);
}









/* NEWS TEASER ------------------------- */
.news-teasers {
    padding: 50px 0 42px;
    background-color: rgba(247, 242, 223, 0.7);
}

.news-teaser:not(:last-child) {
    margin-bottom: 40px;
    position: relative;
}

.news-teaser:not(:last-child):after {
    position: absolute;
    content: '';
    width: 65%;
    bottom: 0;
    left: 0;
    border-bottom: 1px solid var(--color-6);
}


.news-image {
    display: block;
}

.news-date {
    padding-bottom: 8px;
    font-size: 15px;
    font-style: italic;
    color: var(--color-5);
}

.news-title {
    padding-top: 10px;
    padding-bottom: 14px;
    font-size: 25px;
    font-weight: 600;
    color: var(--color-4);
}

.news-lead {
    padding-top: 10px;
    padding-bottom: 18px;
    font-size: 15px;
    line-height: 1.44;
    color: var(--color-5);
}

.news.full .news-lead {
    font-size: 18px;
    font-weight: bold;
}

.news-teaser a {
    text-decoration: none;
}

.news-teaser img {
    transition: 0.4s all;
    filter: brightness(90%) contrast(90%);
}

.news-teaser a:hover .zoom-image img {
    transform: scale(1.05);
}


.news-teaser a:hover img {
    filter: brightness(100%) contrast(100%);
}

.news-teaser a:hover h2 {
    text-decoration: underline;
}

.news-emphasized {
    position: relative;
    padding: 20px 0 20px 25px;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.39;
    color: var(--color-2);
}

.news-emphasized:before {
    position: absolute;
    top: 20px;
    left: 0;
    width: 8px;
    height: calc(100% - 40px);
    z-index: 2;
    content: '';
    background-color: var(--color-3);
}

.news-question {
    font-weight: bold;
}

.news-quote {
    position: relative;
    padding: 20px 0 20px 37px;
    font-size: 15px;
    color: var(--color-5);
}

.news-quote:before {
    position: absolute;
    top: 26px;
    left: 0;
    width: 25px;
    height: 20px;
    z-index: 2;
    content: '';
    background: url("../images/quote.png") no-repeat left top;
    background-size: contain;
}





.news.full {
    margin: 10px 0 100px;
}

.news.full h1 {
    font-size: 32px;
    font-weight: 600;
    line-height: 1.3;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--color-6);
    margin-bottom: 10px;
}

.news-figure {
    width: 100%;
    margin: 30px 0;
}

.news.full .news-image {
    width: 100%;
    margin: 10px 0;
}

.news-figure figcaption {
    font-size: 15px;
    font-weight: 300;
    font-style: italic;
    color: var(--color-5);
}





.post-image {
    margin: 3em 0;

}

.post-image.thumbs {
    display: flex;
    flex-wrap: wrap;
}

.post-image a {
    display: block;
}



/* DONATE TEASER ------------------------- */
.donate-block {
    padding: 50px 0 42px;
}

.donate-block h2,
.donate-block h3 {
    margin-bottom: 8px;
}

.donate-block h3 {
    font-size: 22px;
    font-weight: 800;
    color: var(--color-4);
    text-transform: uppercase;
}

.donate-block p {
    margin-bottom: 25px;
}

.donate-block-icons {
    margin-top: 2em;
}

.donate-block-icons + .donate-block-icons {
    margin-top: 0;
}


.donate-block-icons.center {
    text-align: center;
}

.donate-block-icons.center .column {
    margin-bottom: 30px;
}

.donate-block-icons.center img,
.donate-block-icons.center svg {
    margin: 0 auto 15px;
    transition: .3s ease-in-out all;
    display: block;
}

.donate-block-icons.center a {
    display: block;
    text-decoration: none;
}

.donate-block-icons.center a:hover img {
    transform: scale(1.05);
}

.donate-block-icons.center a:hover {
    text-decoration: underline;
}

.donate-block-icons.center span {
    font-size: 15px;
    color: var(--color-5);
}

.donate-block .donate-button {
    margin-top: 34px;
}

.panel:not(:first-of-type) {
    display: none;
}

ul.donate-links {
    margin: 80px 0;
}


.panels {
    padding: 80px 0;
}

.panels .top {
    top: -80px;
}

@media (min-width: 1050px) {
    .panels .top {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
    }

    .panels .top h2 {
    }
}

.panels h2,
.panels .h2 {
    color: var(--color-4);
    font-weight: 800;
}
.panels h2.special,
.panels .h2.special {
    font-family: var(--font-spartan);
    color: var(--color-3);
}

.donate-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 25px;
    width: 100%;
    height: 177px;
    border-radius: 5px;
    box-shadow: 2px 2px 4px 0 rgba(38, 27, 11, 0.5);
    background-color: var(--color-3);

    text-align: center;
    text-decoration: none;
    font-size: 22px;
    font-weight: 800;
    color: var(--color-1);
}
.donate-links a.active {
    background-color: var(--color-2);
}
.donate-links a > svg {
    display: block;
    width: 100%;
}






/* CONTACT PAGE  ------------------------- */
.iframe-rwd  {
}
.iframe-rwd iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}





/* DEFAULT ARTICLE FORMAT  ------------------------- */
.post {
    margin: 3em 0 6em;
}

.post.post-alter {
    margin: 0 0 6em;
}

.post h1 {
    margin: 2em 0 1em;
    font-size: 28px;
    font-weight: 600;
    color: var(--color-4);
}

.post h2,
.post .h2 {
    margin: 2em 0 0;
    font-size: 26px;
    font-weight: 600;
    color: var(--color-4);
}

.post h3,
.post h4 {
    color: var(--color-4);
}

.post .full-width h2,
.post .full-width .h2 {
    margin-top: 0;
}

.post .nomargin {
  margin: 0;
}

.post p {
}

article a,
.post a {
    color: var(--color-4);
}

article a:hover,
article a:active,
.post a:hover,
.post a:active {
    color: var(--color-3);
}


.post .date {
    margin-top: .2em;
    font-size: .8em;
    color: var(--color-2);
}

.post * + .full-width {
    margin: 0;
}







/* ABOUT US PAGE  ------------------------- */
.aboutus-icons .column {
    margin-bottom: 36px;
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
    align-content: flex-start;
}

.aboutus-icons img {
    margin-bottom: 24px;
}

.aboutus-icons p {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-4);
}

.sections {
    margin-bottom: 40px;
}

.full-width {
    position: relative;
    height: 40px;
}

.full-width.separator-wrapper {
  margin: 30px 0;
  height: 113px;  
}

.sections * + .full-width {
    margin: 2em;
}

.sections * + .full-width.no-margin {
    margin: 0;
}

.full-width .separator2,
.full-width h2,
.full-width .h2 {
    width: 100vw;
    height: 40px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    line-height: 40px;
    color: var(--color-white);
    background-color: var(--color-2);
    font-style: italic;
    font-size: 1.5em;
}

.full-width.color6 h2 {
    background-color: var(--color-6);
}

.full-width.color3 h2 {
    background-color: var(--color-3);
}

.full-width .separator2 {
  height: 113px;
  background: url('/public/images/separator2.png') center center;
}

.separator2 {
  height: 113px;
  background: url('/public/images/separator2.png') center center;
}

.sections h3 {
    margin-top: 2em;
    font-size: 22px;
    font-weight: 800;
    color: var(--color-4);
}

.sections h3 + * {
    margin-top: .5em;
}

.sections h3.alter {
    font-family: var(--font-spartan);
    font-size: 20px;
    color: var(--color-2);

}






/* FOOTER  ------------------------- */
.footer {
    position: relative;
    color: var(--color-1);
    background: var(--color-1);
    z-index: 3;
}

.footer a {
    color: var(--color-1);
    text-decoration: none;
}

.footer-main {
    padding: 12px 0 30px;
    background: var(--color-2) url("/public/images/footer_NONE.png") no-repeat center bottom;
}

.footer-navigation ul {
    margin: 0 0 30px;
    padding: 0;
    list-style: none;
}

.footer-navigation .first {
    display: block;
    text-transform: uppercase;
    margin: 0 0 15px;
    font-weight: bold;
}

.footer-navigation-first-row {
    margin-bottom: 5px;
}

.footer-sponsors p,
.footer-sponsors a {
    display: inline-block;
    color: var(--color-5);
}

.footer-navigation a:hover,
.footer-navigation a:active {
    color: var(--color-3);
}

.footer-sponsors img {
    max-height: 48px;
    max-width: 110px;
}

.footer-sponsors ul {
    display: inline-flex;
    align-items: center;
    list-style: none;
    flex-wrap: wrap;
}

.footer-sponsors li {
    padding: 10px;
}



.chart {
    height: 300px
}

.chart .ct-series-a .ct-slice-donut {
    stroke: var(--color-4);
}

.chart .ct-series-b .ct-slice-donut {
    stroke: var(--color-3);
}






.no-margin {
    margin: 0;
}



#mc_embed_signup {
    margin: 0 0 30px;
}

.mc-field-group {
    margin: 10px 0;
}

.mc-field-group label {
    font-size: 15px;
}

.mce-rules {
    margin: 10px 0;
    font-size: 14px;
}




.conference-table td {
    padding: 0 0 15px;
}

.conference-day td {
    padding: 25px 0 5px;
    font-weight: bold;
}

