@charset "UTF-8";
/**!
Theme Name: Stavangeren
Description: The Wordpress theme for Stavangeren
Version: 1.0.3
Author: Breakfast
Author URI: https://www.ambio.no/software
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: gulp, boilerpate
Text Domain: STAVANGEREN
*/
/* ---------------------------------------------------------------------------- Mixins & Variables ------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------- Mixins ------------------------------------------------------------------------- */
/* Mixin for clearfix @include clearfix; */
/* @font-face mixin Bulletproof font-face via Font Squirrel @include fontface('family', 'assets/fonts/', 'myfontname'); */
/** IMAGE RETINA @include image-2x(/img/image.png, 100%, auto); */
/* VERTICAL ALIGN @include vertical-align(); */
/* ---------------------------------------------------------------------------- Responsive Usage @include r(240)  { } @include r(320)  { } @include r(480)  { } @include r(768)  { } @include r(1024) { } @include r(1280) { } ------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------- Variables ------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------- Colors ------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------- Primary Color Variants ------------------------------------------------------------------------- */
/*$color--primary: #406de4;*/
/*$color--primary: #00BCD4;*/
/*$color--primary: #03A9F4;*/
/*$color--primary: #3498db;*/
/*$color--primary: #2980b9;*/
/*$color--primary: #3F51B5;*/
/*$color--primary: #304FFE;*/
/*$color--primary: #FF5722;*/
/*$color--primary: #795548;*/
/*$color--primary: #2ecc71;*/
/*$color--primary: #27ae60;*/
/*$color--primary: #35ad68;*/
/*$color--primary: #1abc9c;*/
/*$color--primary: #16a085;*/
/*$color--primary: #9b59b6;*/
/*$color--primary: #8e44ad;*/
/*$color--primary: #673AB7;*/
/*$color--primary: #FFA000;*/
/*$color--primary: #FBC02D;*/
/*$color--primary: #f1c40f;*/
/*$color--primary: #f39c12;*/
/*$color--primary: #e67e22;*/
/*$color--primary: #d35400;*/
/*$color--primary: #e74c3c;*/
/*$color--primary: #c0392b;*/
/*$color--primary: #f44336;*/
/*$color--primary: #34495e;*/
/*$color--primary: #607D8B;*/
/* Header background colors */
/*
$image--ratio--grid-item: 56.25%; //55%
$image--ratio--single-item: 56.25%; //55%;
$image--ratio--carousel: 56.25%; //55%;
*/
/* ---------------------------------------------------------------------------- Normalize ------------------------------------------------------------------------- */
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
/** 1. Set default font family to sans-serif. 2. Prevent iOS and IE text size adjust after device orientation change, without disabling user zoom. */
html {
    font-family: sans-serif; /* 1 */
    -ms-text-size-adjust: 100%; /* 2 */
    -webkit-text-size-adjust: 100%; /* 2 */
}

/** Remove default margin. */
body {
    margin: 0;
}

/* HTML5 display definitions ========================================================================== */
/** Correct `block` display not defined for any HTML5 element in IE 8/9. Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox. Correct `block` display not defined for `main` in IE 11. */
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
    display: block;
}

/** 1. Correct `inline-block` display not defined in IE 8/9. 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. */
audio, canvas, progress, video {
    display: inline-block; /* 1 */
    vertical-align: baseline; /* 2 */
}

/** Prevent modern browsers from displaying `audio` without controls. Remove excess height in iOS 5 devices. */
audio:not([controls]) {
    display: none;
    height: 0;
}

/** Address `[hidden]` styling not present in IE 8/9/10. Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22. */
[hidden], template {
    display: none;
}

/* Links ========================================================================== */
/** Remove the gray background color from active links in IE 10. */
a {
    background-color: transparent;
}

/** Improve readability of focused elements when they are also in an active/hover state. */
a:active, a:hover {
    outline: 0;
}

/* Text-level semantics ========================================================================== */
/** Address styling not present in IE 8/9/10/11, Safari, and Chrome. */
abbr[title] {
    border-bottom: 1px dotted;
}

/** Address style set to `bolder` in Firefox 4+, Safari, and Chrome. */
b, strong {
    font-weight: bold;
}

/** Address styling not present in Safari and Chrome. */
dfn {
    font-style: italic;
}

/** Address variable `h1` font-size and margin within `section` and `article` contexts in Firefox 4+, Safari, and Chrome. */
h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

/** Address styling not present in IE 8/9. */
mark {
    background: #ff0;
    color: #000;
}

/** Address inconsistent and variable font size in all browsers. */
small {
    font-size: 80%;
}

/** Prevent `sub` and `sup` affecting `line-height` in all browsers. */
sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sup {
    top: -0.5em;
}

sub {
    bottom: -0.25em;
}

/* Embedded content ========================================================================== */
/** Remove border when inside `a` element in IE 8/9/10. */
img {
    border: 0;
}

/** Correct overflow not hidden in IE 9/10/11. */
svg:not(:root) {
    overflow: hidden;
}

/* Grouping content ========================================================================== */
/** Address margin not present in IE 8/9 and Safari. */
figure {
    margin: 1em 40px;
}

/** Address differences between Firefox and other browsers. */
hr {
    box-sizing: content-box;
    height: 0;
}

/** Contain overflow in all browsers. */
pre {
    overflow: auto;
}

/** Address odd `em`-unit font size rendering in all browsers. */
code, kbd, pre, samp {
    font-family: monospace, monospace;
    font-size: 1em;
}

/* Forms ========================================================================== */
/** Known limitation: by default, Chrome and Safari on OS X allow very limited styling of `select`, unless a `border` property is set. */
/** 1. Correct color not being inherited. Known issue: affects color of disabled elements. 2. Correct font properties not being inherited. 3. Address margins set differently in Firefox 4+, Safari, and Chrome. */
button, input, optgroup, select, textarea {
    color: inherit; /* 1 */
    font: inherit; /* 2 */
    margin: 0; /* 3 */
}

/** Address `overflow` set to `hidden` in IE 8/9/10/11. */
button {
    overflow: visible;
}

/** Address inconsistent `text-transform` inheritance for `button` and `select`. All other form control elements do not inherit `text-transform` values. Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera. Correct `select` style inheritance in Firefox. */
button, select {
    text-transform: none;
}

/** 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` and `video` controls. 2. Correct inability to style clickable `input` types in iOS. 3. Improve usability and consistency of cursor style between image-type `input` and others. */
button, html input[type="button"], input[type="reset"], input[type="submit"] {
    -webkit-appearance: button; /* 2 */
    cursor: pointer; /* 3 */
}

/** Re-set default cursor for disabled elements. */
button[disabled], html input[disabled] {
    cursor: default;
}

/** Remove inner padding and border in Firefox 4+. */
button::-moz-focus-inner, input::-moz-focus-inner {
    border: 0;
    padding: 0;
}

/** Address Firefox 4+ setting `line-height` on `input` using `!important` in the UA stylesheet. */
input {
    line-height: normal;
}

/** It's recommended that you don't attempt to style these elements. Firefox's implementation doesn't respect box-sizing, padding, or width. 1. Address box sizing set to `content-box` in IE 8/9/10. 2. Remove excess padding in IE 8/9/10. */
input[type="checkbox"], input[type="radio"] {
    box-sizing: border-box; /* 1 */
    padding: 0; /* 2 */
}

/** Fix the cursor style for Chrome's increment/decrement buttons. For certain `font-size` values of the `input`, it causes the cursor style of the decrement button to change from `default` to `text`. */
input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

/** 1. Address `appearance` set to `searchfield` in Safari and Chrome. 2. Address `box-sizing` set to `border-box` in Safari and Chrome. */
input[type="search"] {
    -webkit-appearance: textfield; /* 1 */
    box-sizing: content-box; /* 2 */
}

/** Remove inner padding and search cancel button in Safari and Chrome on OS X. Safari (but not Chrome) clips the cancel button when the search input has padding (and `textfield` appearance). */
input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

/** Define consistent border, margin, and padding. */
fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: 0.35em 0.625em 0.75em;
}

/** 1. Correct `color` not being inherited in IE 8/9/10/11. 2. Remove padding so people aren't caught out if they zero out fieldsets. */
legend {
    border: 0; /* 1 */
    padding: 0; /* 2 */
}

/** Remove default vertical scrollbar in IE 8/9/10/11. */
textarea {
    overflow: auto;
}

/** Don't inherit the `font-weight` (applied by a rule above). NOTE: the default cannot safely be changed in Chrome and Safari on OS X. */
optgroup {
    font-weight: bold;
}

/* Tables ========================================================================== */
/** Remove most spacing between table cells. */
table {
    border-collapse: collapse;
    border-spacing: 0;
}

td, th {
    padding: 0;
}

/* ---------------------------------------------------------------------------- Structure ------------------------------------------------------------------------- */
/* ---------------------------------------------------------------------------- Structure ------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
    font-family: 'Fjalla One', sans-serif;
    text-transform: uppercase !important;
}

/* global box-sizing */
*, *:after, *:before {
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

/* html element 62.5% font-size for REM use i.e. 1rem = 10px*/
html {
    font-size: 62.5%;
    height: 100%;
    min-height: 100%;
}

body {
    font: 400 16px/1.4 'Oxygen', sans-serif;
    color: #292929;
    margin: 0;
    height: 100%;
    min-height: 100%; /*background-color:#fafafa;*/
    background-color: #ffffff;
}

/* clearfix */
.clearfix:before, .clearfix:after {
    content: ' ';
    display: table;
}

.clearfix:after {
    clear: both;
}

.clearfix {
    *zoom: 1;
}

.hidden {
    display: none !important;
}

img {
    max-width: 100%;
    vertical-align: bottom;
    height: auto;
}

a {
    color: #75630A;
    text-decoration: none;
}

#content a {
    color: #75630A !important;
    text-decoration: none;
}

#content a:hover {
    color: #444 !important;
}

a:hover {
    color: #444;
}

a:focus {
    outline: 0;
}

a:hover, a:active {
    outline: 0;
}

input:focus {
    outline: 0;
    border: 1px solid #292929;
}

select {
    width: 100%;
}

figure {
    margin: 0;
}

/* WPCore */
/* ---------------------------------------------------------------------------- WordPress Core Styles ------------------------------------------------------------------------- */
.alignnone {
    margin: 5px 20px 20px 0;
}

.aligncenter, div.aligncenter {
    display: block;
    margin: 5px auto 5px auto;
}

.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

a img.alignnone {
    margin: 5px 20px 20px 0;
}

a img.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.wp-caption {
    background: #c5c5c5;
    max-width: 100%;
    padding: 2rem;
    text-align: center;
}

.wp-caption.alignnone {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
    margin: 5px 0 20px 20px;
}

.wp-caption img {
    border: 0 none;
    height: auto;
    margin: 0;
    max-width: 100%;
    padding: 0;
    width: auto;
}

.wp-caption .wp-caption-text, .gallery-caption {
    margin: 0;
    padding: 0.5rem;
}

.textwidget img {
    margin: 1rem 0;
}

.bypostauthor {
    background: inherit;
}

/* ---------------------------------------------------------------------------- Calendar widget ------------------------------------------------------------------------- */
.widget_calendar {
    display: table;
    width: 100%;
}

#wp-calendar {
    width: 100%;
}

#wp-calendar caption {
    text-align: right;
    color: #000000;
    font-size: 12px;
    margin-top: 10px;
    margin-bottom: 15px;
}

#wp-calendar thead {
    font-size: 10px;
}

#wp-calendar thead th {
    padding-bottom: 10px;
}

#wp-calendar tbody {
    color: #000000;
    font-family: sans-serif;
    font-weight: 300;
}

#wp-calendar tbody td {
    background: #ffffff;
    border: 1px solid #ffffff;
    text-align: center;
    padding: 8px;
}

#wp-calendar tbody td:hover {
    background: #ffffff;
}

#wp-calendar tbody .pad {
    background: none;
}

#wp-calendar tfoot #next {
    font-size: 10px;
    text-transform: uppercase;
    text-align: right;
}

#wp-calendar tfoot #prev {
    font-size: 10px;
    text-transform: uppercase;
    padding-top: 10px;
}

/* ---------------------------------------------------------------------------- Recommended sizes ------------------------------------------------------------------------- */
.size-auto, .size-full, .size-large, .size-medium, .size-thumbnail {
    max-width: 100%;
    height: auto;
}

/* ---------------------------------------------------------------------------- Responsive ------------------------------------------------------------------------- */
@media (min-width: 240px) {
    .wp-caption .wp-caption-text, .gallery-caption {
        font: 300 1.4rem/1.8rem sans-serif;
    }
}

@media (min-width: 320px) {
    .wp-caption .wp-caption-text, .gallery-caption {
        font: 300 1.55rem/1.8 sans-serif;
    }
}

@media (min-width: 480px) {
    .wp-caption .wp-caption-text, .gallery-caption {
        font: 300 1.8rem/1.8 sans-serif;
    }
}

@media (min-width: 768px) {
    .wp-caption .wp-caption-text, .gallery-caption {
        font: 300 1.9rem/1.7 sans-serif;
    }
}

@media (min-width: 1024px) {
    .wp-caption .wp-caption-text, .gallery-caption {
        font: 300 2rem/3.1rem sans-serif;
    }
}

@media (min-width: 1280px) {
    .wp-caption .wp-caption-text, .gallery-caption {
        font: 300 2rem/3.1rem sans-serif;
    }
}

/* Base */
/** Base SCSS */
@media screen and (min-width: 992px) {
    .device-only {
        display: none;
    }

    .desktop-only {
        display: initial;
    }
}

@media screen and (max-width: 992px) {
    .device-only {
        display: initial;
    }

    .desktop-only {
        display: none;
    }
}

@media screen and (min-width: 992px) {
    body.logged-in {
        top: 32px;
    }
}

@media screen and (max-width: 992px) {
    body.logged-in {
        top: 32px;
    }
}

.container {
    padding-top: 0;
    padding-bottom: 0; /* @media screen and (max-width: 1240px) { padding:0 20px; } */
}

@media screen and (min-width: 1440px) {
    .container {
        width: 1400px;
        margin: 0 auto;
    }
}

@media screen and (max-width: 1440px) {
    .container {
        margin: 0 20px;
    }
}

@media screen and (max-width: 992px) {
    .container {
        margin: 0 16px;
    }
}

#header {
    background-color: #000;
    padding-bottom: 26.5px;
}

@media screen and (min-width: 992px) {
    #header {
        padding-bottom: 0px;
    }
}

#header .container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
}

@media screen and (min-width: 992px) {
    #header .container {
        height: 180px;
        box-sizing: border-box;
    }
}

@media screen and (max-width: 992px) {
    #header .container {
        height: 127px;
    }
}

#header .container figure#logo {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
    -ms-flex-order: 1;
    order: 1;
    margin: 0;
}

@media screen and (max-width: 992px) {
    #header .container figure#logo {
        width: 216.5px;
    }
}

@media screen and (min-width: 992px) {
    #header .container figure#logo {
        width: 297.5px;
        margin-bottom: 30px;
    }
}

#header .container nav {
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
}

@media screen and (max-width: 992px) {
    #header .container nav {
        -webkit-box-ordinal-group: 4;
        -webkit-order: 3;
        -ms-flex-order: 3;
        order: 3;
        justify-self: flex-end;
    }

    #header .container nav .menu-wrapper {
        display: none;
        position: absolute;
        left: 0;
        top: 153.5px;
        height: calc(100% - 153.5px);
        background: rgba(255, 255, 255, 0.85);
        padding: 0;
        width: 100%;
        padding: 0 20px;
        z-index: 800; /* &.open { display:block; } */
    }

    #header .container nav .menu-wrapper > ul {
        text-transform: uppercase;
        list-style: none;
        text-align: center;
        padding: 0;
        margin: 30px 0;
    }

    #header .container nav .menu-wrapper > ul li a {
        display: block;
        padding: 5px 0;
        font-size: 16px;
        font-weight: bold;
        letter-spacing: 1px;
    }

    #header .container nav .menu-wrapper > ul li a.toggle-search svg {
        width: 14px;
    }

    #header .container nav .menu-wrapper > ul li ul {
        list-style: none;
        padding: 0;
        margin-bottom: 20px;
    }

    #header .container nav .menu-wrapper > ul li ul li a {
        padding: 10px 0;
        font-size: 14px;
        display: block;
        text-transform: none;
        font-weight: normal;
    }

    body.navigation-open #header .container nav .menu-wrapper {
        display: block !important;
    }

    #header .container nav button.toggle-device-navigation {
        display: block;
        border: 0;
        background-color: #000;
        color: #fff;
        border-radius: 0;
        font-size: 30px;
        float: right;
        outline: 0;
        padding-right: 0;
        text-align: right;
    }

    #header .container nav button.toggle-device-navigation:hover {
        color: #888;
    }
}

@media screen and (min-width: 992px) {
    #header .container nav {
        -webkit-box-ordinal-group: 3;
        -webkit-order: 2;
        -ms-flex-order: 2;
        order: 2;
        -webkit-align-self: flex-end;
        -ms-flex-item-align: end;
        align-self: flex-end;
        text-align: right; /*margin-right:25px;*/
        padding: 0;
        margin: 0;
    }

    #header .container nav button.toggle-device-navigation {
        display: none;
    }

    #header .container nav ul {
        width: 100%;
        margin: 0;
        padding: 0;
        list-style: none;
    }

    #header .container nav ul > li {
        display: inline-block;
        font-size: 14px;
        position: relative;
    }

    #header .container nav ul > li > a {
        padding: 30px 12px;
        display: inline-block;
        text-transform: uppercase;
        color: #fff;
        font-weight: bold;
        letter-spacing: 2px;
        line-height: 1;
        background: black;
    }

    #header .container nav ul > li > a:hover {
        color: #8e7e21;
    }

    #header .container nav ul > li > a.toggle-search svg {
        width: 20px;
        margin: -5px 0;
    }

    #header .container nav ul > li > a.toggle-search svg path {
        fill: #fff;
    }

    #header .container nav ul > li > a.toggle-search:hover svg path {
        fill: #8e7e21;
    }

    #header .container nav ul > li > ul {
        width: 200px;
        text-align: left;
        visibility: hidden; /* hides sub-menu */
        opacity: 0;
        position: absolute;
        padding: 0;
        margin: 0;
        top: auto;
        left: 0;
        -webkit-transform: translateY(-2em);
        -ms-transform: translateY(-2em);
        transform: translateY(-2em);
        z-index: -1;
        -webkit-transition: all 0.1s ease-in-out 0s, visibility 0s linear 0.3s, z-index 0s linear 0.01s;
        transition: all 0.1s ease-in-out 0s, visibility 0s linear 0.3s, z-index 0s linear 0.01s;
        list-style: none;
    }

    #header .container nav ul > li > ul > li {
        display: block;
        text-align: left;
        margin: 0;
        padding: 0;
    }

    #header .container nav ul > li > ul > li > a {
        display: block;
        color: #fff;
        font-size: 14px;
        text-transform: none;
        font-weight: normal;
        padding: 15px;
    }

    #header .container nav ul > li:focus > ul, #header .container nav ul > li:hover > ul {
        visibility: visible; /* shows sub-menu */
        opacity: 1;
        z-index: 1000;
        -webkit-transform: translateY(0%);
        -ms-transform: translateY(0%);
        transform: translateY(0%);
        -webkit-transition-delay: 0s, 0s, 0s;
        transition-delay: 0s, 0s, 0s;
    }
}

#notice .container {
    color: #fff;
    padding: 0px;
}

#notice .container h3 {
    margin: 0;
}

#content {
    background-color: transparent;
}

#content h1 {
    margin: 0;
}

#content .post-content {
    margin: 20px 0 0 0;
    padding-bottom: 1em;
}

@media screen and (min-width: 992px) {
    #content .post-content {
        margin: 74px 0 0 0;
    }
}

#content .post-content h1.title {
    font-size: 33px;
    font-weight: normal;
    margin: 0;
}

@media screen and (min-width: 992px) {
    #content .post-content h1.title {
        font-size: 58px;
    }
}

#content .post-content p.date {
    font-size: 20px;
    font-weight: bold;
    margin: 0;
}

#content .post-content div.ingress {
    font-size: 26px;
    line-height: 1.5;
    letter-spacing: 1px;
    margin: 0 0 1em 0;
}

#content .post-content div.body {
    font-size: 16px;
    letter-spacing: 1px;
    line-height: 1.9;
}

#content .post-content div.body .ingress {
    font-size: 26px;
    line-height: 1.5;
    letter-spacing: 1px;
    margin: 0 0 1em 0;
}

body.single-event #content .row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}

body.single-event #content .row .event-image {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 100%;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}

@media screen and (min-width: 992px) {
    body.single-event #content .row .event-image {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 66.21428571%;
        -ms-flex: 0 0 66.21428571%;
        flex: 0 0 66.21428571%;
        max-width: 66.21428571%;
    }
}

body.single-event #content .row .event-image figure {
    margin: 0;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
    background-color: #8a8a8a;
    background-size: cover;
    position: relative;
}

body.single-event #content .row .event-image figure .sale-status {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    overflow: hidden;
    width: 100px;
    height: 100px;
    text-align: right;
}

body.single-event #content .row .event-image figure .sale-status span {
    font-size: 12px;
    font-weight: bold;
    color: #FFF;
    text-transform: uppercase;
    text-align: center;
    line-height: 30px;
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    width: 150px;
    display: block;
    background: #b88035;
    position: absolute;
    top: 25px;
    left: -35px;
}

@media screen and (max-width: 992px) {
    body.single-event #content .row .event-details {
        display: none;
    }
}

@media screen and (min-width: 992px) {
    body.single-event #content .row .event-details {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 33.78571429%;
        -ms-flex: 0 0 33.78571429%;
        flex: 0 0 33.78571429%;
        max-width: 33.78571429%;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
    }
}

body.single-event #content .event-details {
    padding: 45px 20px 25px 0;
    background-color: rgba(201, 192, 183, 0.3);
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    line-height: 1.3;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-details {
        display: none;
    }
}

body.single-event #content .event-details table {
    font-size: 17px;
    table-layout: fixed;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-details table {
        font-size: 23px; /*1.66666666vw;*/
    }
}

body.single-event #content .event-details table th {
    text-align: left;
    padding-left: 16px;
    text-transform: uppercase;
    vertical-align: top;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-details table th {
        padding-left: 20px;
    }
}

body.single-event #content .event-details table td {
    padding-left: 10px;
    padding-bottom: 40px;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-details table td {
        padding-left: 40px;
        padding-bottom: 40px;
    }
}

body.single-event #content .shows {
    /*margin: 34px 7% 50px 7%;*/
    margin-inline: auto;
    margin-block: 34px 50px;
}

@media screen and (min-width: 992px) {
    body.single-event #content .shows {
        margin-block:74px 50px;
        max-width: 1200px;
    }
}

body.single-event #content .shows table {
    width: 100%;
    margin: 0;
    padding: 0;
}

@media screen and (min-width: 992px) {
    body.single-event #content .shows table {
        table-layout: fixed;
    }
}

body.single-event #content .shows table tr.outdated {
    text-decoration: line-through;
    color: #999;
}

body.single-event #content .shows table tr td table tr td {
    background-color: #fafafa;
}

body.single-event #content .shows table tr:nth-child(2n) td table tr td {
    background: #fff;
}

body.single-event #content .shows table th {
    background: #000;
    color: #fff;
    text-transform: uppercase;
    text-align: left;
    padding: 10px;
}

body.single-event #content .shows table td {
    vertical-align: middle;
}

@media screen and (max-width: 768px) {
    body.single-event #content .shows table td.date-and-title, body.single-event #content .shows table td.sales-status-and-action {
        display: block !important;
        box-sizing: border-box !important;
        clear: both !important;
    }
}

body.single-event #content .shows table td table tr td {
    padding: 7px 5px;
}

body.single-event #content .shows table td table tr td.date {
    text-align: center;
    width: 50px;
}

body.single-event #content .shows table td table tr td.date span.date {
    display: block;
    font-size: 20px;
    margin: 0;
    line-height: 1;
}

body.single-event #content .shows table td table tr td.date span.weekday {
    color: #666;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0;
    line-height: 1;
}

body.single-event #content .shows table td table tr td.title {
    font-size: 18px;
    font-weight: bold;
}

body.single-event #content .shows table td table tr td.title .venue {
    font-size: 16px;
    font-weight: normal;
    color: darkred;
}

body.single-event #content .shows table td table tr td.title .venue .label {
    color: #000;
}

body.single-event #content .shows table td table tr td.sales-status .label {
    display: block;
    color: #666;
    font-size: 12px;
    text-transform: uppercase;
    margin: 0;
    line-height: 1;
}

body.single-event #content .shows table td table tr td.action {
    padding-right: 0;
    text-align: right;
}

body.single-event #content .shows table td table tr td.action a {
    text-transform: uppercase;
    padding: 10px 15px;
    background-color: #937d0d;
    color: #fff !important;
    font-weight: bold !important;
}

body.single-event #content .shows table td table tr td.action a.sold-out {
    background-color: darkred;
}

body.single-event #content .shows table tr.outdated td table tr td.action a {
    background-color: #ccc;
    cursor: not-allowed;
    pointer-events: none;
}

body.single-event #content .event-content {
    margin-block: 34px 0;
    padding-bottom: 1em;
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-width: 1200px;
    margin-inline: auto;
}

body.single-event #content .event-content {

    h1.title,
    figure.image,
    div.body {
        max-width: 740px;
    }

}

body.single-event #content .event-content .row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 50px;

    &:first-child {
        flex-direction: column-reverse;
    }

    &:last-child {
        align-items: flex-start;
    }
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content {
        margin-block: 74px 0;
        /*width: 52.71428571%;*/
    }

    body.single-event #content .event-content .row {
        flex-direction: row;
        gap:50px;

        &:first-child {
            flex-direction: row;
        }
    }
}

body.single-event #content .event-content .row h1 {
    font-size: 36px;
    line-height: 1.1;
    font-weight: normal;
    margin: 0 0 10px 0;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content .row h1 {
        font-size: 58px;
        flex: 0 0 calc( calc( 100% - 50px ) / 2 );
        max-width: calc( calc( 100% - 50px ) / 2 );
    }
}

body.single-event #content .event-content .row .image {

}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content .row .image {
        flex: 0 0 calc( calc( 100% - 50px ) / 2 );
        max-width: calc( calc( 100% - 50px ) / 2 );
    }
}

body.single-event #content .event-content .row .body {}
body.single-event #content .event-content .row .images {}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content .row .body,
    body.single-event #content .event-content .row .images {
        flex: 0 0 calc( calc( 100% - 50px ) / 2 );
        max-width: calc( calc( 100% - 50px ) / 2 );
    }
}

body.single-event #content .event-content .row .images {
    background: rgba(0,0,0,.04);
    padding:20px;
}

body.single-event #content .event-content p.date {
    font-size: 16px;
    letter-spacing: 1px;
    font-weight: bold;
    margin: 0;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content p.date {
        font-size: 20px;
    }
}

body.single-event #content .event-content a.button {
    margin: 20px 0 30px 0;
    display: inline-block;
    background-color: #000;
    color: #fff;
    font-size: 13px;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 18px 25px 14px 25px;
    font-weight: bold;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content a.button {
        margin: 40px 0 40px 0;
    }
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content a.button {
        font-size: 18px;
    }
}

body.single-event #content .event-content div.ingress {
    font-size: 21px;
    line-height: 1.5;
    letter-spacing: 1px;
    margin: 0 0 1em 0;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content div.ingress {
        font-size: 26px;
    }
}

body.single-event #content .event-content div.body {
    grid-area: body;
    font-size: 14px;
    letter-spacing: 1px;
    line-height: 1.9;
}

@media screen and (min-width: 992px) {
    body.single-event #content .event-content div.body {
        font-size: 16px;
    }
}

body.single-event #content .event-content .images {
    grid-area: images;
}

#event-carousel {
    background: #fff;
}

@media (max-width: 992px) {
    #event-carousel .container {
        width: 100%;
        margin: 0 0 20px 0;
    }
}

#event-carousel .container .slides {
    max-width: 100%;
    margin: 0 auto;
    width: 100%;
    position: relative;
}

#event-carousel .container .slides .event-carousel-pager {
    z-index: 500;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    text-align: center;
}

#event-carousel .container .slides .event-carousel-pager span {
    height: 15px;
    width: 15px;
    background-color: #fff;
    opacity: .5;
    border-radius: 50%;
    display: inline-block;
    margin: 0px 5px 20px 5px;
    color: transparent;
    cursor: pointer;
}

#event-carousel .container .slides .event-carousel-pager span.cycle-pager-active {
    opacity: 1;
}

#event-carousel .container .slides .slide {
    width: 100%;
    position: relative;
}

#event-carousel .container .slides .slide figure {
    margin: 0;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
    overflow: hidden;
    position: relative;
}

#event-carousel .container .slides .slide figure img {
    width: 100%;
}

#event-carousel .container .slides .slide figure .overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
}

#event-carousel .container .slides .slide figure .overlay .square { /*position: absolute;*/
    display: inline-block;
    width: 12.5%;
    padding-bottom: 12.5%;
    float: left; /*width: 11.42857143%;*/ /*0.55*/
    height: 0; /* padding-bottom: 11.42857143%; */
}

#event-carousel .container .slides .slide figure .overlay.variant-1 .square-1-2 {
    background: #b88035;
}

#event-carousel .container .slides .slide figure .overlay.variant-1 .square-1-6 {
    background: rgba(116, 112, 108, 0.1);
}

#event-carousel .container .slides .slide figure .overlay.variant-1 .square-2-1 {
    background: rgba(182, 128, 53, 0.5);
}

#event-carousel .container .slides .slide figure .overlay.variant-1 .square-2-3 {
    background: rgba(208, 226, 223, 0.5);
}

#event-carousel .container .slides .slide figure .overlay.variant-1 .square-2-7 {
    background: #b88036;
}

#event-carousel .container .slides .slide figure .overlay.variant-1 .square-2-8 {
    background: rgba(182, 128, 53, 0.5);
}

#event-carousel .container .slides .slide figure .overlay.variant-1 .square-3-6 {
    background: rgba(182, 128, 53, 0.5);
}

#event-carousel .container .slides .slide figure .overlay.variant-1 .square-4-7 {
    background: #ffd3b6;
}

#event-carousel .container .slides .slide figure .overlay.variant-2 .square-1-2 {
    background: #b88035;
}

#event-carousel .container .slides .slide figure .overlay.variant-2 .square-1-6 {
    background: rgba(208, 226, 223, 0.5);
}

#event-carousel .container .slides .slide figure .overlay.variant-2 .square-2-1 {
    background: rgba(182, 128, 53, 0.5);
}

#event-carousel .container .slides .slide figure .overlay.variant-2 .square-2-3 {
    background: rgba(208, 226, 223, 0.5);
}

#event-carousel .container .slides .slide figure .overlay.variant-2 .square-2-8 {
    background: #d0e2df;
}

#event-carousel .container .slides .slide .details {
    text-align: right;
}

@media (max-width: 992px) {
    #event-carousel .container .slides .slide .details {
        margin-right: 16px;
        margin-left: 16px;
    }
}

@media (min-width: 992px) {
    #event-carousel .container .slides .slide .details {
        position: absolute;
        bottom: 80px;
        margin: auto auto 70px 12.5%; /* Magic! */ /*max-width: 75%;*/
    }
}

#event-carousel .container .slides .slide .details .textual-content {
    padding: 20px 0;
    display: block;
    text-align: left;
}

@media (min-width: 992px) {
    #event-carousel .container .slides .slide .details .textual-content {
        background-color: rgba(255, 255, 255, 0.4);
        padding: 20px 30px;
    }
}

#event-carousel .container .slides .slide .details .textual-content h2 {
    font-weight: normal;
    font-size: 33px;
    line-height: 1.1;
    margin: 0 0 10px 0;
}

@media (min-width: 992px) {
    #event-carousel .container .slides .slide .details .textual-content h2 {
        font-size: 68px;
        margin: 0;
    }
}

#event-carousel .container .slides .slide .details .textual-content h2 a {
    color: #000;
}

#event-carousel .container .slides .slide .details .textual-content p {
    font-weight: bold;
    font-size: 15px;
    font-weight: bold;
    color: #000;
    line-height: 1.1;
    letter-spacing: 1px;
    margin: 0;
}

@media (min-width: 992px) {
    #event-carousel .container .slides .slide .details .textual-content p {
        font-size: 24px;
    }
}

#event-carousel .container .slides .slide .details a.button {
    font-size: 16px;
    padding: 15px 20px 12px 20px;
    display: inline-block;
    border: 0;
    text-align: center;
    background-color: #000;
    color: #fff;
    font-weight: bold;
    letter-spacing: 2px;
    text-transform: uppercase;
}

@media (min-width: 992px) {
    #event-carousel .container .slides .slide .details a.button {
        font-size: 18px;
        padding: 15px 20px 12px 20px;
    }
}

#sub-pages {
    border-top: 1px solid #e7e7e7;
    background-color: #ffffff;
}

#sub-pages .container {
    padding-top: 50px;
    padding-bottom: 50px;
}

#sub-pages .container .grid:before, #sub-pages .container .grid:after {
    content: " ";
    display: table;
}

#sub-pages .container .grid:after {
    clear: both;
}

#sub-pages .container .grid .page {
    padding: 0;
    text-align: left;
    display: block;
    background-color: #f4f2f1;
    margin: 0 0 20px 0;
}

@media (min-width: 992px) {
    #sub-pages .container .grid .page {
        margin: 0 0 1.428571429% 1.428571429%;
        width: 32.38095238%;
        float: left;
    }

    #sub-pages .container .grid .page:nth-child(3n+1) {
        margin-left: 0;
        clear: left;
    }
}

#sub-pages .container .grid .page figure.image {
    background-color: #8a8a8a;
    height: 0;
    width: 100%;
    padding-bottom: 56.25%;
    cursor: pointer;
    position: relative;
    background-size: cover;
    background-position: center !important;
    margin: 0;
}

#sub-pages .container .grid .page figure.image .sale-status {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
}

#sub-pages .container .grid .page figure.image .sale-status img {
    width: 140px;
}

#sub-pages .container .grid .page figure.image:hover .overlay {
    display: block;
}

#sub-pages .container .grid .page .textual-content {
    text-align: left;
}

#sub-pages .container .grid .page .textual-content h3 {
    font-size: 25px;
    line-height: 1.2;
    font-weight: normal;
    text-transform: none;
    margin: 20px 43px;
}

@media (min-width: 992px) {
    #sub-pages .container .grid .page .textual-content h3 {
        font-size: 30px;
        line-height: 1.2;
    }
}

#sub-pages .container .grid .page .textual-content p {
    margin: 0 43px;
    text-transform: none;
    font-size: 14px;
    letter-spacing: 0;
}

@media (min-width: 992px) {
    #sub-pages .container .grid .page .textual-content p {
        font-size: 16px;
        letter-spacing: -1px;
    }
}

#sub-pages .container .grid .page .buttons {
    margin: 10px 20px 20px 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: flex-end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
}

#sub-pages .container .grid .page .buttons a {
    color: #fff;
    background-color: #000;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 1.8px;
    line-height: 38px;
    padding: 0 15px;
    font-weight: bold;
}

@media (min-width: 992px) {
    #sub-pages .container .grid .page .buttons a {
        font-size: 13px;
    }
}

#sub-pages .container .grid .page .buttons a.more_info {
    background-color: #937d0d;
}

#sub-pages .container .grid .page .buttons a.buy_ticket {
    background-color: #000000;
}

#program, #similar-events {
    background-color: transparent;
}

#program .container, #similar-events .container {
    padding-bottom: 20px;
}

#program .container #toggle-filter, #similar-events .container #toggle-filter {
    border: 1px solid #e7e7e7;
    background-color: #fff;
    text-align: center;
    display: block;
    width: 100%;
    font-size: 13px;
    text-transform: uppercase;
    padding: 10px 0;
    margin: 20px 0;
}

#program .container .filter, #similar-events .container .filter {
    margin: -20px 0 20px 0;
    padding: 10px 20px;
    border: 1px solid #e7e7e7;
    border-width: 0 1px 1px 1px;
    background: #fafafa;
}

#program .container .filter:before, #program .container .filter:after, #similar-events .container .filter:before, #similar-events .container .filter:after {
    content: " ";
    display: table;
}

#program .container .filter:after, #similar-events .container .filter:after {
    clear: both;
}

#program .container .filter ul, #similar-events .container .filter ul {
    list-style: none;
    padding: 0;
    margin: 10px 0 0 0;
    display: inline-block;
    float: none;
    clear: both;
}

#program .container .filter ul li, #similar-events .container .filter ul li {
    float: left;
    margin: 0 5px 5px 0;
}

#program .container .filter ul li a, #similar-events .container .filter ul li a {
    display: block;
    color: #fff;
    padding: 10px 20px;
    text-transform: uppercase;
    border: 1px solid #000;
}

#program .container .filter ul li a:hover, #similar-events .container .filter ul li a:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

#program .container .filter ul li a.selected, #similar-events .container .filter ul li a.selected {
    background-color: #7aced5;
}

#program .container .filter ul:nth-of-type(1) li a, #similar-events .container .filter ul:nth-of-type(1) li a {
    border-color: #829e95;
    color: #000;
}

#program .container .filter ul:nth-of-type(1) li a.selected, #similar-events .container .filter ul:nth-of-type(1) li a.selected {
    background-color: #829e95;
    color: #fff;
}

#program .container .filter ul:nth-of-type(2) li a, #similar-events .container .filter ul:nth-of-type(2) li a {
    border-color: #cfb62c;
    color: #000;
}

#program .container .filter ul:nth-of-type(2) li a.selected, #similar-events .container .filter ul:nth-of-type(2) li a.selected {
    background-color: #cfb62c;
    color: #fff;
}

#program .container .filter ul:nth-of-type(3) li a, #similar-events .container .filter ul:nth-of-type(3) li a {
    border-color: #ac2a25;
    color: #000;
}

#program .container .filter ul:nth-of-type(3) li a.selected, #similar-events .container .filter ul:nth-of-type(3) li a.selected {
    background-color: #ac2a25;
    color: #fff;
}

#program .container h3, #similar-events .container h3 {
    margin: 0;
    font-size: 17px;
    line-height: 3;
    text-align: center;
    font-weight: normal;
    letter-spacing: 1px;
}

@media (min-width: 992px) {
    #program .container h3, #similar-events .container h3 {
        font-size: 24px;
        line-height: 90px;
    }
}

#program .container .grid:before, #program .container .grid:after, #similar-events .container .grid:before, #similar-events .container .grid:after {
    content: " ";
    display: table;
}

#program .container .grid:after, #similar-events .container .grid:after {
    clear: both;
}

#program .container .grid .event, #similar-events .container .grid .event {
    padding: 0;
    text-align: left;
    text-transform: uppercase;
    display: block;
    background-color: #fff;
    outline: 1px solid #e7e7e7;
    margin: 0 0 20px 0;
}

@media (min-width: 992px) {
    #program .container .grid .event, #similar-events .container .grid .event {
        margin: 0 0 1.428571429% 1.428571429%;
        width: 32.38095238%;
        float: left;
    }

    #program .container .grid .event:nth-child(3n+1), #similar-events .container .grid .event:nth-child(3n+1) {
        margin-left: 0;
        clear: left;
    }
}

#program .container .grid .event figure.image, #similar-events .container .grid .event figure.image {
    background-color: #8a8a8a;
    height: 0;
    width: 100%;
    padding-bottom: 56.25%;
    cursor: pointer;
    position: relative;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center !important;
    margin: 0;
}

#program .container .grid .event figure.image .sale-status, #similar-events .container .grid .event figure.image .sale-status {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    overflow: hidden;
    width: 100px;
    height: 100px;
    text-align: right;
}

#program .container .grid .event figure.image .sale-status span, #similar-events .container .grid .event figure.image .sale-status span {
    font-size: 12px;
    font-weight: bold;
    color: #FFF;
    text-transform: uppercase;
    text-align: center;
    line-height: 30px;
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    width: 150px;
    display: block;
    background: #b88035;
    position: absolute;
    top: 25px;
    left: -35px;
}

#program .container .grid .event figure.image:hover .overlay, #similar-events .container .grid .event figure.image:hover .overlay {
    display: block;
}

#program .container .grid .event .textual-content, #similar-events .container .grid .event .textual-content {
    min-height: 80px;
}

#program .container .grid .event .textual-content h3, #similar-events .container .grid .event .textual-content h3 {
    font-size: 25px;
    line-height: 1.2;
    font-weight: bold;
    text-align: left;
    text-transform: none;
    margin: 20px 43px 0 43px;
    letter-spacing: 0;
}

@media (min-width: 992px) {
    #program .container .grid .event .textual-content h3, #similar-events .container .grid .event .textual-content h3 {
        font-size: 23px;
        line-height: 1.1;
    }
}

#program .container .grid .event .textual-content p, #similar-events .container .grid .event .textual-content p {
    text-align: left;
    margin: 5px 43px 0 43px;
    text-transform: none;
    font-size: 15px;
    letter-spacing: 0;
    font-weight: normal;
}

@media (min-width: 992px) {
    #program .container .grid .event .textual-content p, #similar-events .container .grid .event .textual-content p {
        font-size: 16px;
    }
}

#program .container .grid .event .textual-content p a, #similar-events .container .grid .event .textual-content p a {
    color: #000;
}

#program .container .grid .event .buttons, #similar-events .container .grid .event .buttons {
    margin-top: 28px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

#program .container .grid .event .buttons a, #similar-events .container .grid .event .buttons a {
    color: #fff;
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: 1.8px;
    line-height: 50px;
    padding: 0 15px;
    font-weight: bold;
    width: 50%;
    text-align: center;
    -webkit-transition-property: font-size;
    transition-property: font-size;
    -webkit-transition-duration: 100ms;
    transition-duration: 100ms;
    -webkit-transition-timing-function: ease;
    transition-timing-function: ease;
}

@media (min-width: 992px) {
    #program .container .grid .event .buttons a, #similar-events .container .grid .event .buttons a {
        font-size: 13px;
    }
}

#program .container .grid .event .buttons a.more_info, #similar-events .container .grid .event .buttons a.more_info {
    background-color: #937d0d;
    margin: 0 15px 15px auto;
}

@media (min-width: 992px) {
    #program .container .grid .event .buttons a.more_info, #similar-events .container .grid .event .buttons a.more_info {
        margin: 0 auto 15px 43px;
    }
}

#program .container .grid .event .buttons a.buy_ticket, #similar-events .container .grid .event .buttons a.buy_ticket {
    background-color: #000000;
    margin: 0 auto 15px 0;
}

@media (min-width: 992px) {
    #program .container .grid .event .buttons a.buy_ticket, #similar-events .container .grid .event .buttons a.buy_ticket {
        margin: 0 43px 15px auto;
    }
}

#program .container .grid .event .buttons a:hover, #similar-events .container .grid .event .buttons a:hover {
    font-size: 14px;
}

@media (min-width: 992px) {
    #program .container .grid .event .buttons a:hover, #similar-events .container .grid .event .buttons a:hover {
        font-size: 15px;
    }
}

#program .read-more, #similar-events .read-more {
    text-align: center;
    display: block;
    margin-top: 30px;
}

@media (min-width: 992px) {
    #program .read-more, #similar-events .read-more {
        margin-top: 0;
    }
}

#program .read-more a, #similar-events .read-more a {
    display: inline-block;
    padding: 0 25px;
    border: 0;
    font-weight: bold;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: 2px;
    background: #000;
    color: #fff;
    line-height: 56px;
}

#program .read-more a:hover, #similar-events .read-more a:hover {
    color: #555;
    border-color: #555;
}

#search {
    position: fixed;
    z-index: 980;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(244, 123, 105, 0.95);
    -webkit-transform: translate(0%, 0%);
    -ms-transform: translate(0%, 0%);
    transform: translate(0%, 0%);
    overflow-y: scroll;
    overflow-x: none;
    -webkit-overflow-scrolling: touch;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
}

#search .toggle-search {
    float: right;
    color: #fff;
    font-size: 30px;
    background: transparent;
    border: 0;
    outline: 0;
}

#search .content-wrapper {
    max-width: 660px;
    width: 100%;
    margin: 50px 20px 0 20px;
}

#search .content-wrapper form {
    width: 100%;
    margin: 75px auto 0 auto;
}

@media (min-width: 678px) {
    #search .content-wrapper form {
        margin: 100px auto 0 auto;
    }
}

@media (min-width: 992px) {
    #search .content-wrapper form {
        margin: 200px auto 0 auto;
    }
}

#search .content-wrapper form input {
    border: 0;
    width: 100%;
    height: 45px;
    background-color: #fff;
    color: #000;
    font-size: 20px;
    text-indent: 20px;
    position: relative;
}

#search .content-wrapper form input:focus {
    border: 0;
}

#search .content-wrapper .search-result {
    margin-top: 65px;
}

#search .content-wrapper .search-result .item h2 {
    line-height: 1;
    font-size: 20px;
    padding: 10px 0 0 0;
    margin: 0;
    text-transform: uppercase;
}

#search .content-wrapper .search-result .item h2 a {
    color: #FFFFFF;
}

#search .content-wrapper .search-result .item p {
    font-size: 14px;
    padding: 10px 0;
    color: #fafafa;
    margin: 0;
}

body.inverted #search .content-wrapper .search-result .item p {
    color: #333;
}

#search .content-wrapper .search-result .item p.dates {
    font-size: 13px;
    padding: 0;
    color: #fff;
    margin-bottom: 5px;
}

#search .content-wrapper .search-result .item p.dates:before, #search .content-wrapper .search-result .item p.dates:after {
    content: " ";
    display: table;
}

#search .content-wrapper .search-result .item p.dates:after {
    clear: both;
}

#search .content-wrapper .search-result .item p.dates a.button {
    color: #fff;
    background-color: #000;
    font-size: inherit;
    padding: 8px 10px 5px 10px;
    display: inline-block;
    text-transform: uppercase;
    margin-top: 5px;
    font-weight: bold;
}

#search .content-wrapper .search-result .item:last-child {
    border-bottom: 0;
}

#breadcrumbs {
    display: none;
}

@media screen and (min-width: 992px) {
    #breadcrumbs {
        display: block;
        list-style: none;
        margin: 0;
        padding: 0;
        font-size: 12px;
        letter-spacing: 1px;
        line-height: 3;
    }

    #breadcrumbs li {
        display: inline;
    }

    #breadcrumbs li.separator {
        margin: 0 2em;
    }
}

body.page h1 {
    padding-top: 20px;
    text-transform: uppercase;
    font-size: 25px;
    font-weight: 200;
    line-height: 1.3;
}

@media (min-width: 678px) {
    body.page h1 {
        font-size: 35px;
    }
}

@media (min-width: 992px) {
    body.page h1 {
        font-size: 40px;
    }
}

body.page h2 {
    padding-top: 20px;
    text-transform: uppercase;
    font-size: 21.333px;
    font-weight: 200;
    line-height: 1.3;
}

#program .section-content-container {
    margin: 50px auto 0 auto;
}

#program .section-content-container hr {
    border-color: #fafafa;
}

#program .section-content-container hr.fat {
    border-color: #000;
}

#program .section-content-container .row {
    margin: 0;
}

#program .section-content-container .row:before, #program .section-content-container .row:after {
    content: " ";
    display: table;
}

#program .section-content-container .row:after {
    clear: both;
}

@media screen and (min-width: 992px) {
    #program .section-content-container .row.headings {
        border-bottom: 1px solid #000;
        margin-bottom: 25px;
        padding-top: 80px;
    }

    #program .section-content-container .row.headings .column {
        font-size: 21px;
        font-weight: normal;
        vertical-align: baseline;
        position: relative;
    }

    #program .section-content-container .row.headings .column.with-filter {
        cursor: pointer;
    }

    #program .section-content-container .row.headings .column.with-filter.selected {
        color: #db677a;
    }

    #program .section-content-container .row.headings .column.with-filter span:after {
        border-style: solid;
        border-width: 0.10em 0.10em 0 0;
        content: '';
        display: inline-block;
        position: relative;
        height: 0.45em;
        top: 0.35em;
        left: 0.25em;
        -webkit-transform: rotate(135deg);
        -ms-transform: rotate(135deg);
        transform: rotate(135deg);
        vertical-align: top;
        width: 0.45em;
    }

    #program .section-content-container .row.headings .column.with-filter .filter {
        display: none;
    }

    #program .section-content-container .row.headings .column.with-filter:hover {
        color: #666;
        cursor: pointer;
    }

    #program .section-content-container .row.headings .column.with-filter:hover .filter {
        display: block !important;
        position: absolute;
        background-color: #fff;
        z-index: 10;
        line-height: 1.75;
        margin: 0 0 0 -20px;
        padding: 0;
        list-style: none;
        display: block;
        border: 1px solid #444;
    }

    #program .section-content-container .row.headings .column.with-filter:hover .filter li {
        display: block;
        cursor: pointer;
        padding: 0 20px;
    }

    #program .section-content-container .row.headings .column.with-filter:hover .filter li:hover {
        background-color: #f7f7f7;
    }

    #program .section-content-container .row.headings .column.with-filter:hover .filter li.selected {
        background-color: #db677b;
        color: #fff !important;
    }

    #program .section-content-container .row.headings .column span {
        position: absolute;
        bottom: 0;
    }

    #program .section-content-container .row.headings .column.year-and-month {
        font-weight: bold;
        padding-left: 5%;
    }

    #program .section-content-container .row.headings .column.action a {
        display: none;
    }

    #program .section-content-container .row.event {
        padding: 25px 0;
        border-bottom: 1px solid #9e9e9e;
    }

    #program .section-content-container .row.event.last {
        border: 0;
    }

    #program .section-content-container .row .column {
        float: left;
    }

    #program .section-content-container .row .column.year-and-month {
        width: 20%;
        padding-left: 5%;
    }

    #program .section-content-container .row .column.year-and-month a img {
        max-width: 240px;
        width: 100%;
        height: auto;
    }

    #program .section-content-container .row .column.year-and-month a.sales-status {
        position: relative;
        overflow: hidden;
        display: inline-block;
    }

    #program .section-content-container .row .column.year-and-month a.sales-status:after {
        position: absolute;
        top: 50%;
        text-indent: 25%;
        left: -30%;
        z-index: 1;
        width: 140%;
        text-align: center;
        -webkit-transform: rotate(-30deg);
        -ms-transform: rotate(-30deg);
        transform: rotate(-30deg);
        color: #fff;
        font-size: 22px;
        font-weight: bold;
    }

    #program .section-content-container .row .column.year-and-month a.sales-status.sales-status-1:after {
        content: "FÅ BILLETTER";
        background-color: #f69576;
    }

    #program .section-content-container .row .column.year-and-month a.sales-status.sales-status-2:after {
        content: "UTSOLGT";
        background-color: #4b6375;
    }

    #program .section-content-container .row .column.year-and-month a.sales-status.sales-status-3:after {
        content: "AVLYST";
        background-color: #db677a;
    }

    #program .section-content-container .row .column.place {
        width: 30%;
        padding-left: 30px;
        padding-right: 30px;
    }

    #program .section-content-container .row .column.place h3 {
        font-size: 26px;
        font-weight: normal;
        margin: 0;
        line-height: 1.1;
    }

    #program .section-content-container .row .column.categories {
        width: 20%;
    }

    #program .section-content-container .row .column.price {
        width: 10%;
    }

    #program .section-content-container .row .column.action {
        text-align: right;
        padding-right: 5%;
        width: 19%;
    }

    #program .section-content-container .row .column.action a.button {
        border: 2px solid #db677a;
        font-size: 28px;
        white-space: nowrap;
        padding: 10px 20px;
        display: inline-block;
    }

    #program .section-content-container .row .column p {
        margin: 0;
    }
}

@media screen and (max-width: 992px) {
    #program .section-content-container .row.headings {
        margin-top: 25px;
    }

    #program .section-content-container .row.headings .column.with-filter.selected {
        color: #db677a;
    }

    #program .section-content-container .row.headings .column.with-filter span:after {
        border-style: solid;
        border-width: 0.10em 0.10em 0 0;
        content: '';
        display: inline-block;
        position: relative;
        height: 0.45em;
        top: 0.65em;
        left: 0.35em;
        -webkit-transform: rotate(135deg);
        -ms-transform: rotate(135deg);
        transform: rotate(135deg);
        vertical-align: top;
        width: 0.45em;
    }

    #program .section-content-container .row.headings .column.with-filter.open {
        color: #666;
        cursor: pointer;
    }

    #program .section-content-container .row.headings .column.with-filter.open .filter {
        display: block !important;
        position: absolute;
        background-color: #fff;
        z-index: 10;
        line-height: 1.75;
        margin: 0 0 0 -20px;
        padding: 0;
        list-style: none;
        display: block;
        border: 1px solid #444;
    }

    #program .section-content-container .row.headings .column.with-filter.open .filter li {
        display: block;
        cursor: pointer;
        padding: 0 20px;
    }

    #program .section-content-container .row.headings .column.with-filter.open .filter li:hover {
        background-color: #f7f7f7;
    }

    #program .section-content-container .row.headings .column.with-filter.open .filter li.selected {
        background-color: #db677b;
        color: #fff !important;
    }

    #program .section-content-container .row.headings .column.year-and-month {
        width: 70%;
        font-size: 16px;
        font-weight: 600;
        line-height: 2;
        padding-left: 5%;
    }

    #program .section-content-container .row.headings .column.place, #program .section-content-container .row.headings .column.categories, #program .section-content-container .row.headings .column.price {
        display: none;
    }

    #program .section-content-container .row.headings .column.action {
        width: 29%;
        text-align: right;
        padding-right: 5%;
    }

    #program .section-content-container .row.headings .column.action a {
        display: inline-block;
        margin-left: 10px;
    }

    #program .section-content-container .row.headings .column.action a svg {
        width: 18.45px;
        height: 13.653px;
    }

    #program .section-content-container .row.headings .column.action a svg path {
        fill: #686868;
    }

    #program .section-content-container .row.headings .column.action a:hover svg path, #program .section-content-container .row.headings .column.action a.selected svg path {
        fill: #000;
    }

    body.list #program .section-content-container .row.event {
        padding: 15px 0;
        border-top: 1px solid #9e9e9e;
    }

    body.list #program .section-content-container .row.event .column.year-and-month, body.list #program .section-content-container .row.event .column.price {
        display: none;
    }

    body.list #program .section-content-container .row.event .column.place {
        width: 40%;
        padding-left: 5%;
        padding-right: 10px;
        overflow: hidden;
    }

    body.list #program .section-content-container .row.event .column.place h3 {
        margin: 0;
        font-weight: 400;
        font-size: 14px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    body.list #program .section-content-container .row.event .column.place .place {
        font-size: 10px;
        margin: 0;
        padding: 0;
    }

    body.list #program .section-content-container .row.event .column.place a.read-more {
        display: none;
    }

    body.list #program .section-content-container .row.event .column.categories {
        width: 30%;
        font-size: 10px;
        padding-left: 10px;
    }

    body.list #program .section-content-container .row.event .column.categories .categories {
        display: none;
    }

    body.list #program .section-content-container .row.event .column.action {
        width: 28%;
        text-align: right;
        padding-right: 5%;
    }

    body.list #program .section-content-container .row.event .column.action a.button {
        font-size: 10px;
        display: inline-block;
        max-width: 70px;
        border: 1px solid #db677a;
        padding: 2px 5px;
    }

    body.list #program .section-content-container .row.event .column p {
        margin: 0;
    }

    body.with-thumbnails #program .section-content-container .row.event {
        position: relative;
        margin-bottom: 10px;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.year-and-month {
        width: 100%;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.year-and-month a {
        pointer-events: none;
        cursor: default;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.year-and-month a img {
        width: 100% !important;
        height: auto;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.year-and-month a.sales-status {
        position: relative;
        overflow: hidden;
        display: inline-block;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.year-and-month a.sales-status:after {
        position: absolute;
        bottom: 0;
        left: 0%;
        z-index: 0;
        width: 100%;
        text-align: left;
        color: #fff;
        font-size: 16px;
        padding: 10px 10px 30px 10px;
        font-weight: bold;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.year-and-month a.sales-status.sales-status-1:after {
        content: "FÅ BILLETTER";
        background-color: #f69576;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.year-and-month a.sales-status.sales-status-2:after {
        content: "UTSOLGT";
        background-color: #4b6375;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.year-and-month a.sales-status.sales-status-3:after {
        content: "AVLYST";
        background-color: #db677a;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.place, body.with-thumbnails #program .section-content-container .row.event .column.categories, body.with-thumbnails #program .section-content-container .row.event .column.price, body.with-thumbnails #program .section-content-container .row.event .column.action {
        position: absolute;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.place {
        top: 10px;
        left: 10px;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.place h3 {
        margin: 0;
        font-size: 14px;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.place h3 a {
        color: #fff;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.place p {
        display: none;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.categories {
        bottom: 10px;
        left: 10px;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.categories p {
        font-size: 10px;
        color: #fff;
        padding: 0;
        margin: 0;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.categories p br, body.with-thumbnails #program .section-content-container .row.event .column.categories p br:after {
        content: ' ';
    }

    body.with-thumbnails #program .section-content-container .row.event .column.categories p .categories {
        display: none;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.price {
        bottom: 10px;
        right: 10px;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.price p {
        font-size: 10px;
        color: #fff;
        padding: 0;
        margin: 0;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.action {
        top: 10px;
        right: 10px;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.action p {
        margin: 0;
        padding: 0;
    }

    body.with-thumbnails #program .section-content-container .row.event .column.action p a.button {
        color: #000;
        font-size: 10px;
        background-color: #fff;
        border: 1px solid #db677a;
        padding: 5px 10px;
    }

    body.with-thumbnails #program .section-content-container .row.event.inverted * {
        color: #000 !important;
    }
}

#coming-events, #similar-events {
    margin: 100px 0 0 0;
}

@media screen and (max-width: 992px) {
    #coming-events, #similar-events {
        display: none;
    }
}

#coming-events .content-wrapper, #similar-events .content-wrapper {
    max-width: 1080px;
}

@media screen and (min-width: 1080px) {
    #coming-events .content-wrapper, #similar-events .content-wrapper {
        margin: 0 auto;
    }
}

@media screen and (max-width: 1080px) {
    #coming-events .content-wrapper, #similar-events .content-wrapper {
        margin: 0 20px;
    }
}

#coming-events .content-wrapper h2, #similar-events .content-wrapper h2 {
    max-width: 1080px;
    margin: 0 auto;
}

@media screen and (min-width: 992px) {
    #coming-events .content-wrapper h2, #similar-events .content-wrapper h2 {
        font-size: 28px;
        line-height: 2;
    }
}

@media screen and (max-width: 992px) {
    #coming-events .content-wrapper h2, #similar-events .content-wrapper h2 {
        font-size: 20px;
        line-height: 1.5;
    }
}

#coming-events hr, #similar-events hr {
    margin: 0;
    border-top: 1px solid #1a1a1a;
}

#coming-events .event-list, #similar-events .event-list {
    padding: 30px 0;
}

#coming-events .event-list:before, #coming-events .event-list:after, #similar-events .event-list:before, #similar-events .event-list:after {
    content: " ";
    display: table;
}

#coming-events .event-list:after, #similar-events .event-list:after {
    clear: both;
}

#coming-events .event-list .event, #similar-events .event-list .event {
    display: inline-block;
}

@media screen and (min-width: 992px) {
    #coming-events .event-list .event, #similar-events .event-list .event {
        float: left;
        width: 32%;
    }
}

@media screen and (max-width: 992px) {
    #coming-events .event-list .event, #similar-events .event-list .event {
        width: 100%;
    }
}

#coming-events .event-list .event figure, #similar-events .event-list .event figure {
    width: 100%;
    height: 0;
    padding-bottom: 51.27388535%;
    background-repeat: no-repeat;
    background-size: cover;
}

#coming-events .event-list .event h3, #similar-events .event-list .event h3 {
    font-weight: normal;
    font-size: 20px;
    margin: 5px 0 0 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

#coming-events .event-list .event p, #similar-events .event-list .event p {
    margin: 0 0 5px 0;
    font-size: 15px;
}

#coming-events .event-list .event a.button, #similar-events .event-list .event a.button {
    font-size: 27px;
    display: inline-block;
    min-width: 196px;
    line-height: 48px;
    border: 2px solid #db677a;
    background-color: #fff;
    text-align: center;
    padding: 0 5px;
}

#coming-events .event-list .event:nth-child(2), #similar-events .event-list .event:nth-child(2) {
    margin-left: 2%;
    margin-right: 2%;
}

#coming-events .event-list .spinner, #similar-events .event-list .spinner {
    width: 40px;
    height: 40px;
    background-color: #333;
    margin: 100px auto;
    -webkit-animation: sk-rotateplane 1.2s infinite ease-in-out;
    animation: sk-rotateplane 1.2s infinite ease-in-out;
    outline: 1px solid red;
}

@-webkit-keyframes sk-rotateplane {
    0% {
        -webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg);
        transform: perspective(120px) rotateX(0deg) rotateY(0deg);
    }
    50% {
        -webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
        transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
    }
    100% {
        -webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
        transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
    }
}

@keyframes sk-rotateplane {
    0% {
        -webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg);
        transform: perspective(120px) rotateX(0deg) rotateY(0deg);
    }
    50% {
        -webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
        transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
    }
    100% {
        -webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
        transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
    }
}

#social-medias {
    border-top: 1px solid #e7e7e7;
    background: #ffff;
}

#social-medias .container .grid .row {
    padding: 50px 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
}

@media screen and (min-width: 992px) {
    #social-medias .container .grid .row {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -ms-flex-direction: row;
        flex-direction: row;
    }
}

#social-medias .container .grid .row .column {
    margin-bottom: 30px;
    text-align: center;
}

@media screen and (min-width: 992px) {
    #social-medias .container .grid .row .column {
        width: 50%;
        margin-bottom: 0px;
    }
}

#footer {
    background-color: #000;
    margin: 0 auto 0 auto;
    padding: 65px 0 65px 0;
}

#footer .container {
    max-width: 1204px;
}

@media screen and (max-width: 992px) {
    #footer .container {
        margin-left: 44px;
    }
}

#footer .container .row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    position: relative;
}

@media screen and (min-width: 992px) {
    #footer .container .row {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -ms-flex-direction: row;
        flex-direction: row;
    }
}

#footer .container .row .column {
    margin-top: 30px;
}

@media screen and (min-width: 992px) {
    #footer .container .row .column {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 50%;
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
        margin-top: 0px;
    }
}

#footer .container .row .column.footer-logo img {
    max-width: 200px;
    width: 100%;
    margin-left: 30px;
}

#footer .container .row .column.addresses {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
}

@media screen and (max-width: 992px) {
    #footer .container .row .column.addresses {
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -ms-flex-direction: row;
        flex-direction: row;
    }
}

@media screen and (min-width: 992px) {
    #footer .container .row .column.addresses {
        padding-left: 20px;
    }
}

#footer .container .row .column address {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    background: black;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    color: #fff;
    font-size: 14px;
}

@media screen and (max-width: 992px) {
    #footer .container .row .column address {
        -webkit-box-flex: 0;
        -webkit-flex: 0 0 50%;
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
}

@media screen and (min-width: 992px) {
    #footer .container .row .column address {
        display: inline-block;
        margin-left: 60px;
    }
}

@media screen and (min-width: 992px) {
    #footer .container .row .column address {
        font-size: 16px;
    }
}

#footer .container .row .column address h3 {
    margin: 0;
    text-transform: uppercase;
    font-size: 14px;
    color: #fff;
}

@media screen and (min-width: 992px) {
    #footer .container .row .column address h3 {
        font-size: 16px;
    }
}

#footer .container address {
    font-style: normal;
}

#footer .container .producer svg {
    width: 75px;
    height: 28.52px;
    margin: 0 0 -7px 5px;
}

#footer .container .producer svg path, #footer .container .producer svg rect {
    fill: #fff;
}

#footer .container .producer svg path.circle, #footer .container .producer svg rect.circle {
    fill: #f99000;
}

#footer .container .social-media-links a {
    display: inline-block;
    width: 41px;
    height: 41px;
    background: #fff;
    color: #000;
    font-size: 30px;
    position: relative;
}

#footer .container .social-media-links a i {
    position: absolute;
}

#footer .container .social-media-links a:first-child i {
    top: 15%;
    left: 18%;
}

#footer .container .social-media-links a:last-child i {
    bottom: -3px;
    right: 5px;
    font-size: 35px;
}

#footer .container a {
    color: #fff;
}

#footer .container a:hover {
    text-decoration: underline;
}

#gift-card {
    margin-top: 50px;
}

#gift-card .container .element {
    text-align: right;
}

#gift-card .container .element:before, #gift-card .container .element:after {
    content: " ";
    display: table;
}

#gift-card .container .element:after {
    clear: both;
}

@media screen and (min-width: 992px) {
    #gift-card .container .element {
        max-width: 690px;
        width: 100%;
        margin: 0 auto;
    }
}

#gift-card .container .element .text {
    background-color: #e7f0ef;
    padding: 46px 30px 39px 30px;
    text-align: left;
    position: relative;
}

@media screen and (min-width: 992px) {
    #gift-card .container .element .text {
        padding: 50px 50px 0 50px;
        height: 160px;
    }
}

@media screen and (min-width: 992px) {
    #gift-card .container .element .text {
        padding-left: 200px;
    }

    #gift-card .container .element .text:before {
        content: "";
        background-color: #fed3b8;
        height: 100%;
        width: 160px;
        position: absolute;
        left: 0;
        top: 0;
    }

    #gift-card .container .element .text:after {
        content: "";
        background-color: #b87f34;
        height: 160px;
        width: 160px;
        position: absolute;
        left: -160px;
        bottom: -160px;
    }
}

#gift-card .container .element .text h2 {
    font-size: 35px;
    font-weight: bold;
    text-transform: uppercase;
    line-height: 1;
    margin: 0;
}

@media screen and (min-width: 992px) {
    #gift-card .container .element .text h2 {
        font-size: 48px;
    }
}

#gift-card .container .element .text p {
    font-size: 20px;
    line-height: 1;
    margin: 0;
}

@media screen and (min-width: 992px) {
    #gift-card .container .element .text p {
        font-size: 24px;
    }
}

#gift-card .container .element a.button {
    border: 0;
    background-color: #000;
    text-align: center;
    letter-spacing: 1px;
    color: #fff;
    text-transform: uppercase;
    padding: 10px 20px;
    font-size: 13px;
    display: inline-block;
    font-weight: bold;
}

@media screen and (min-width: 992px) {
    #gift-card .container .element a.button {
        padding: 15px 30px;
        font-size: 18px;
    }
}

#sponsors {
    margin: 0 auto 50px auto;
}

@media screen and (min-width: 992px) {
    #sponsors {
        margin: 0 auto 50px auto;
    }
}

/*#sponsors .container .grid:before, #sponsors .container .grid:after { content: " "; display: table; }*/

#sponsors .container .grid:after {
    clear: both;
}

#sponsors .container .grid .sponsor {
    margin: 0;
    padding: 0;
    display: block;
    float: left;
}

@media screen and (max-width: 992px) {
    /*#sponsors .container .grid .sponsor {*/
    /*    width: 18%;*/
    /*    margin-right: 2.5%;*/
    /*    margin-bottom: 2.5%;*/
    /*}*/

    #sponsors .container .grid .sponsor:nth-child(5n) {
        margin-right: 0;
    }

    #sponsors .container .grid .sponsor:nth-child(5n+1) {
        clear: left;
    }
}

@media screen and (min-width: 992px) {
    #sponsors .container .grid .sponsor {
        width: 9%;
        margin-right: 1.1111111111%;
    }

    #sponsors .container .grid .sponsor:nth-child(10n) {
        margin-right: 0;
    }

    #sponsors .container .grid .sponsor:nth-child(10n+1) {
        clear: left;
    }
}

#sponsors .container h3 {
    margin: 0;
    font-size: 17px;
    line-height: 3;
    text-align: center;
    font-weight: normal;
    letter-spacing: 1px;
}

@media (min-width: 992px) {
    #sponsors .container h3 {
        font-size: 24px;
        line-height: 90px;
    }
}

#sponsors .container ul {
    list-style: none;
    padding: 0;
}

#sponsors .container ul li {
    display: inline-block;
}

#sponsors .container ul li a {
    padding: 10px;
}

#sponsors .container ul li a img {
    max-height: 66px;
}

#sponsors .container {
    width: 100%;
    margin: 0 auto;
    justify-content: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

@media (max-width: 768px) {
    #sponsors .container .grid-2 {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        padding: 0 1rem;
        margin-top: 2rem;
    }

    #sponsors .container .grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        padding: 0 1rem;
        margin-top: 2rem;
        gap: 2rem;
    }

}

#sponsors .container .grid .category-hovedsponsor figure {
    margin: 0;
    padding: 0;
    width: 30vw;
    height: 10vh;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}

#sponsors .container .grid .sponsor {
    display: none;
}

@media (min-width: 769px) and (max-width: 991px) {
    #sponsors .container .grid {
        grid-template-columns: repeat(3, 1fr);
        grid-auto-columns: auto;
        display: grid;
        gap: 2rem;
        padding: 0 5rem;
        margin: 0;
        justify-content: center;
    }
    #sponsors .container .grid .category-hovedsponsor figure {
        width: 28vw;
        height: 14vh;
    }


}

@media (min-width: 992px) {
    #sponsors .container .grid {
        grid-template-columns: repeat(5, 1fr);
        grid-auto-columns: auto;
        display: grid;
        gap: 1rem;
        padding: 0 5rem;
        margin: 0;
        justify-content: center;
    }

    #sponsors .container .grid .category-hovedsponsor figure {
        margin: 0;
        padding: 0;
        width: 16vw;
        height: 16vh;
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
}

#sponsors .container .grid .category-hovedsponsor {
    display: block;
    margin-top: 2rem;
}

@media screen and (min-width: 992px) {
    #sponsors .container ul li a img {
        max-height: 86px;
    }
}

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

    #sponsors .container .grid-2 {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        grid-auto-columns: auto;
        width: 100%;
        gap: 2rem;
        place-items: center;
        justify-content: center;
        height: auto;
        padding: 0 1rem;
    }
}

#sponsors .container .grid-2 {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-auto-columns: auto;
    width: 100%;
    gap: 1rem;
    place-items: center;
    height: auto;
    padding: 0 19rem;
    margin-top: 2rem
}

#sponsors .container .grid-2 .category-hovedsponsor {
    display: none;
}

#sponsors .container .grid-2 .category-sponsor figure {
    padding: 0;
    width: 7vw;
    height: 11vh;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

#sponsors .container .grid-2 .category-sponsor {
    display: flex;
    flex-direction: row;
    justify-content: center;
}

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

    #sponsors .container .grid-2 {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        padding: 0 1rem;
        margin-top: 2rem
    }

    #sponsors .container .grid-2 .category-sponsor figure {
        padding: 0;
        width: 14vw;
        height: 14vh;
        background-size: contain;
        background-repeat: no-repeat;
    }

    #sponsors .container .grid-2 .category-sponsor {
        flex-direction: row;
    }
}

@media screen and (max-width: 768px) {
    #sponsors .container .grid-2 {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        padding: 0 7rem;
        gap: 1rem;
        margin-top: 2rem
    }

    #sponsors .container .grid-2 .category-sponsor figure {
        width: 15vw;
        height: 7vh;
    }
}

#banner {
    margin-bottom: 1em;
}