body {
    font-family: "Public Sans", arial, helvetica, sans-serif;
    font-size: 14px;
    background: #FFF;
    color: #1a223b;
    line-height: 1.75em;
    min-width: 320px;
}
@media screen and (min-width: 800px) {
    body {
        font-size: 15px;
    }
}
@media screen and (min-width: 1000px) {
    body {
        font-size: 16px;
    }
}

::-moz-selection {
    background: #2dc1ed;
    color: #FFF;
}
::selection {
    background: #2dc1ed;
    color: #FFF;
}

h1 {
    font-size: 1.75em;
    color: #ed1556;
    margin: 30px 0px 15px;
}
h2 {
    font-size: 1.45em;
    margin: 25px 0px 15px;
}
h3 {
    font-size: 1.25em;
    margin: 20px 0px 15px;
}

h1 a, h2 a, h3 a {
    text-decoration: none;
}

p {
    margin: 15px 0px;
}

a {
    color: #ed1556;
}
a:hover {
    color: #1fa177;
}

img {
	max-width: 100%;
    height: auto;
    -ms-interpolation-mode: bicubic;
    display: inline-block;
    vertical-align: middle;
}
img.float-right {
    float: right;
    padding: 0px 0px 20px 25px;
}
a img {
    border: none 0px;
}

a.icon svg {
    height: 20px;
    padding-right: 2px;
}
a.icon svg .icon_path {
    fill: #7D734D;
}
a.icon:hover svg .icon_path {
    fill: #1fa177;;
}

.info:not(.message) {
    font-size: 0.95em;
    color: #067da1;
}
.info a {
    color: inherit;
}
.white .info, .results .info {
    color: #4a89b0;
}

.center {
    text-align: center;
}

nav ul {
    list-style: none;
    margin: 0px;
    padding: 0px;
    display: flex;
    flex-flow: row wrap;
    gap: 15px;
}

h1 + .info, h2 + .info, h3 + .info {
    margin-top: -10px;
}

.info.neighbourhood {
    display: inline-block;
    background: url('/img/icon_neighbourhood2.png') no-repeat left center;
    background-size: 17px;
    padding-left: 24px;
    padding-top: 1px;
}

.hidden {
    display: none;
}

.removed {
    text-decoration: line-through;
}

b.success {
    color: #1fa177;
}

/* tables */

table {
    border-collapse: collapse;
    width: 100%;
    margin: 20px 0px;
}
tr {
    border-bottom: solid 1px;
    border-color: #ecbe41;
}
td, th {
    text-align: left;
    padding: 5px;
    line-height: 1.55em;
}
th {
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.85em;
}
th a {
    color: inherit;
    text-decoration: none;
}
div.full-table {
    margin: 20px 0px;
    overflow-x: auto;
}

tr:hover {
    background: rgba(255, 255, 255, 0.15);
    background-blend-mode: screen;
}

/* Tabs */
ul.tabs {
    list-style: none;
    margin: 15px 0px;
    padding: 0px;
    display: inline-flex;
    justify-content: right;
    border-radius: 4px;
    overflow: hidden;
    gap: 5px;
}
ul.tabs li {
    background: #FFF;
    font-weight: 700;
}
ul.tabs a {
    padding: 5px 10px;
    color: inherit;
    font-size: 0.9em;
    text-decoration: none;
    display: block;
    font-size: 0.95em;
    text-align: center;
    min-width: 20px;
    border: solid 1px #fdd850;
}
ul.tabs a:hover, ul.tabs li.active a:hover {
    background: #fdcc35;
    border: solid 1px #fdcc35;
    color: #1a303d;
}
ul.tabs li.active a, ul.tabs li.active a:hover {
    background: #ed1556;
    border: solid 1px #ed1556;
    color: #FFF;
}
@media screen and (max-width: 600px) {
    ul.tabs li.prev {
        display: none;
    }
    ul.tabs a {
        padding: 5px 8px;
    }
}
nav.pagination {
    background: #FFF;
    padding: 5px;
    margin: 15px 0px;
    display: flex;
    justify-content: center;
    border-radius: 4px;
}
nav.pagination ul.tabs {
    margin: 0px;
}
nav.pagination li {
    margin: 0px 1px;
}
nav.pagination a {
    border-radius: 4px;
}

/* Flash messages */
.container.message {
    background: #067da1;
    color: #FFF;
    border-radius: 4px;
	padding: 15px;
    position: relative;
    text-align: center;
    margin: 30px auto;
    overflow: visible;
}
.message.error {
    background-color: #d61509;
    color: #FFF;
}
.message.success {
    background-color: #1fa177;
}
.message.warning {
    background-color: #fcc337;
}
.message.hidden {
    display: none;
}

/* Common lists */

ul.multicolumn {
    column-width: 180px;
}
ul.multicolumn.narrow {
    column-width: 130px;
}
ul.multicolumn li {
    break-inside: avoid;
}

ul.zapper {
    list-style: none;
    padding: 0px;
    line-height: 1.5em;
    margin: 20px 0px 15px;
    border-bottom: solid 1px #b7d0df;
    padding-bottom: 15px;
}
ul.zapper + ul.zapper {
    margin-top: 15px;
}
ul.zapper + p {
    margin-top: 25px;
}
.zapper li {
    margin: 0px 0px 10px;
}
.zapper .count {
    color: #4a89b0;
    padding-left: 2px;
}
ul.zapper + ul.zapper {
}

.popular ul, ul.popular {
    list-style: none;
    padding: 0px;
    line-height: 1.5em;
}
.popular li {
    margin: 0px 0px 10px;
}
.popular a {
    font-weight: bold;
    text-decoration: none;
    display: block;
}

ul.areas {
    list-style: none;
    padding: 0px;
    display: grid;
    gap: 10px;
    grid-auto-flow: row dense;
    grid-template-columns: repeat(3, 1fr);
    font-size: 0.95em;
}
@media screen and (max-width: 1000px) {
    ul.areas {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media screen and (max-width: 600px) {
    ul.areas {
        grid-template-columns: repeat(1, 1fr);
    }
}
ul.areas li {
    color: #ed1556;
    line-height: 1.35em;
    font-weight: 700;
}
ul.areas .city {
    font-weight: 400;
    color: #1a303d;
    padding-left: 2px;
}

.openings th {
    font-weight: normal;
}
.openings .today th, .openings .today td {
    font-weight: bold;
}

/* Rating stars */
.rating {
    overflow: hidden;
    display: inline-block;
    vertical-align: middle;
}
a.rating {
    text-decoration: none;
}
.rating:not(.with-caption) .caption {
    display: none;
}
.rating:before {
    content: "\2605 \2605 \2605 \2605 \2605";
    font-size: 1.3em;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    position: relative;
    left: -1px;
}
.rating-10:before {
    background-image: linear-gradient(to right, #ed1556 20%, rgba(64, 128, 169, 0.4) 20%);
}
.rating-15:before {
    background-image: linear-gradient(to right, #ed1556 30%, rgba(64, 128, 169, 0.4) 30%);
}
.rating-20:before {
    background-image: linear-gradient(to right, #ed1556 40%, rgba(64, 128, 169, 0.4) 40%);
}
.rating-25:before {
    background-image: linear-gradient(to right, #ed1556 50%, rgba(64, 128, 169, 0.4) 50%);
}
.rating-30:before {
    background-image: linear-gradient(to right, #ed1556 60%, rgba(64, 128, 169, 0.4) 60%);
}
.rating-35:before {
    background-image: linear-gradient(to right, #ed1556 70%, rgba(64, 128, 169, 0.4) 70%);
}
.rating-40:before {
    background-image: linear-gradient(to right, #ed1556 80%, rgba(64, 128, 169, 0.4) 80%);
}
.rating-45:before {
    background-image: linear-gradient(to right, #ed1556 90%, rgba(64, 128, 169, 0.4) 90%);
}
.rating-50:before {
    background-color: #ed1556;
}


.results .rating-10:before {
    background-image: linear-gradient(to right, #fdcc35 20%, rgba(28, 117, 144, 0.25) 20%);
}
.results .rating-15:before {
    background-image: linear-gradient(to right, #fdcc35 30%, rgba(28, 117, 144, 0.25) 30%);
}
.results .rating-20:before {
    background-image: linear-gradient(to right, #fdcc35 40%, rgba(28, 117, 144, 0.25) 40%);
}
.results .rating-25:before {
    background-image: linear-gradient(to right, #fdcc35 50%, rgba(28, 117, 144, 0.25) 50%);
}
.results .rating-30:before {
    background-image: linear-gradient(to right, #fdcc35 60%, rgba(28, 117, 144, 0.25) 60%);
}
.results .rating-35:before {
    background-image: linear-gradient(to right, #fdcc35 70%, rgba(28, 117, 144, 0.25) 70%);
}
.results .rating-40:before {
    background-image: linear-gradient(to right, #fdcc35 80%, rgba(28, 117, 144, 0.25) 80%);
}
.results .rating-45:before {
    background-image: linear-gradient(to right, #fdcc35 90%, rgba(28, 117, 144, 0.25) 90%);
}
.results .rating-50:before {
    background-color: #fdcc35;
}

/* Poll results */
ul.poll {
    list-style: none;
    padding: 0px;
}
.poll li {
    margin: 20px 0px;
}
.poll b {
    color: #ed1556;
}
.bar_container {
    background: #ffdf6b;
}
.bar {
    background: #2dc1ed;
    height: 12px;
    border-radius: 2px;
}

/* Profile address + map */
.wrapper.address .container {
    display: flex;
    flex-flow: row wrap;
    align-items: stretch;
    gap: 20px;
}
.wrapper.address .inner {
    min-width: 350px;
    flex-grow: 1;
}
#mapid {
    min-height: 250px;
    min-width: 250px;
    flex-grow: 2;
    border-radius: 4px;
}
@media screen and (max-width: 645px) {
    #mapid {
        margin-top: 20px;
    }
}

.partnerlogo {
    background: #e5f7fc;
    border-radius: 4px;
    padding: 10px;
    margin-right: 20px;
    color: #067da1;
    font-size: 0.95em;
    display: block;
    text-decoration: none;
}
.partnerlogo img {
    max-height: 36px;
    margin-right: 10px;
}