@font-face {
    font-family: "AvenirNext";
    src: url('/static/fonts/AvenirNext-Regular.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "AvenirNext";
    src: url('/static/fonts/AvenirNext-Bold.woff2') format('woff2');
    font-weight: bold;
    font-style: normal;
}

@font-face {
    font-family: "AvenirNextUltraLight";
    src: url('/static/fonts/AvenirNext-UltraLight.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: "AvenirRoman";
    src: url('/static/fonts/Avenir-Roman.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
}

html {
    box-sizing: border-box;
}

*, *:before, *:after {
    box-sizing: inherit;
}

body {
    background-color: #fff;
    font-family: "AvenirNext", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    margin: 0;
    font-size: 15px;
}

[v-cloak] {
    display: none;
}

h1, h2, h3, h4, h5, h6 {
    margin: 0 0 32px 0;
    font-weight: bold;
}

.h-alt {
    margin: 0 0 16px 0;
}

.margin-0 {
    margin: 0;
}

ul {
    padding-left: 0;
    list-style-type: none;
}

ul.list-disc {
    padding-left: 32px;
    list-style-type: disc;
}

ul.list-decimal {
    padding-left: 32px;
    list-style-type: decimal;
}

ul.list-circle {
    padding-left: 32px;
    list-style-type: circle;
}

a {
    color: #000;
    text-decoration: none;
}

p {
    margin: 0;
}

/* generic */
.link {
    text-decoration: underline;
}

.img-fit-opacity {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.1;
}

.image-preview {
    width: 180px;
    height: 180px;
    background-color: #ddd;
    border-radius: 50%;
    box-shadow: 0 2px 4px 2px rgba(0, 0, 0, 0.1);
}

.rating-star {
    width: 36px;
    height: 36px;
    cursor: pointer;
    user-select: none;
}

.rating-star > path {
    transition: fill .3s;
}

.main {
    position: relative;
    transition: margin .3s;
}

.main-right-first {
    background: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
    height: 280px;
    position: relative;
    color: #fff;
}

.main-right-first h1 {
    margin: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    transform: translate(-50%, -50%);
    font-size: 38px;
}

.main-right-instructor-splash:before {
    content: "";
    background: url("/static/images/app/instructor-bg.jpg") no-repeat center center;
    opacity: 0.4;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    position: absolute;
    background-size: cover;
}

.main-right-instructor-splash:after {
    content: "";
    background: url("/static/images/app/s-frame.png") no-repeat center center;
    opacity: 0.2;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    position: absolute;
    background-size: cover;
}

.main-right-splash:before {
    content: "";
    background: url("/static/images/app/member-bg.jpg") no-repeat center center;
    opacity: 0.4;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    position: absolute;
    background-size: cover;
}

.main-right-splash:after {
    content: "";
    background: url("/static/images/app/s-frame.png") no-repeat center center;
    opacity: 0.2;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    position: absolute;
    background-size: cover;
}

.main-left-splash {
    background: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
    height: 280px;
    position: relative;
    color: #fff;
}

.main-left-second {
    position: relative;
    height: 300px;
}

.main-left-second-content {
    margin: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: #fff;
}

.main-left-second-content-text {
    transform: translate(-50%, -100%);
}

.main-left-second-content-img-wrapper {
    position: relative;
    margin-bottom: 16px;
    width: 100px;
    height: 100px;
    display: inline;
}

.main-left-second-content-badge {
    position: absolute;
    left: -8px;
    bottom: 0;
    width: 40px;
    height: 40px;
}

.main-left-second-content-img {
    width: 100px;
    height: 100px;
    background-color: #ddd;
    border-radius: 50%;
    box-shadow: 0 2px 4px 2px rgba(0, 0, 0, 0.1);
}

.main-left-second-content-img-promoted {
    border: 5px solid #FF794F;
}

.main-left-map {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.image {
    display: block;
    width: 100%;
    height: 100%;
}

.signup-token {
    border: 1px solid #ddd;
    width: 140px;
    padding: 16px 0 16px 0;
    font-size: 36px;
    outline: none;
    text-align: center;
    transition: background-color .3s;
    margin: 0 4px 0 4px;
}

.signup-token:focus {
    background-color: #f9f9f9;
}

.message {
    background-color: #fcf8e3;
    margin: 0 auto;
    padding: 16px;
    border-radius: 8px;
    text-align: center;
}

.gradient {
    background: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
    color: #fff;
    border: none;
}

.text-wrap {
    white-space: pre-wrap;
}

.text-left {
    text-align: left;
}

.text-italic {
    font-style: italic;
}


.text-quote {
    font-size: 18px;
    font-style: italic;
}

.text-white {
    color: #fff;
}

.white {
    background-color: #fff;
}

.gray {
    background-color: #f1f1f1;
    background: #f1f1f1;
}

.purple {
    background-color: #8C6CE8;
}

.margin-right{
    margin-right: 20px;
}

.overlay {
    z-index: 5; /* hide absolute */
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0,0,0,0.5);
    transition: all .3s;
}

.overlay-inner {
    background: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.6);
    width: 400px;
}

.overlay-inner a {
    text-decoration: underline;
}

.overlay-inner-wide {
    background: #fff;
    position: absolute;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.6);
    overflow-y: auto;
    max-height: 100vh;
}

.overlay-bubble {
    position: relative;
    height: 100px;
    width: 100px;
    border-radius: 50%;
    margin: 0 auto;
    margin-top: -50px;
    color: #fff;
    line-height: 100px;
    font-size: 24px;
}

.overlay-bubble > img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
}

.overlay-bubble > svg {
    margin-top: 28px;
}

.overlay-enter {
    opacity: 0;
}

.overlay-leave-active {
    opacity: 0;
}

.video-wrapper {
    /* position: relative; */
    min-height: 100vh;
    width: 100%;
    margin-top: -60px;
}

video {
    width: 100%;
    height: 100%;
    position:absolute;
    top:0;
    left: 0;
    object-fit: cover;
}

.video-text {
    margin: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    transform: translate(-50%, -85%);
    text-align: center;
    color: #fff;
    font-size: 18px;
}

.video-text-desktop {
    display: none;
}

/* table */
.table {
    width: 100%;
    border-collapse: collapse;
}

.table th {
    padding-bottom: 8px;
}

/* form */
.form-label {
    text-align: left;
    display: block;
    margin-top: 16px;
    margin-bottom: 4px;
}

.form-input {
    width: 100%;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font: inherit;
    font-size: 16px;
    outline: none;
    transition: border-color .3s;
}

.form-input:hover {
    border-color: #888;
}

.form-textarea {
    width: 100%;
    height: 200px;
    resize: none;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font: inherit;
    font-size: 16px;
    outline: none;
    transition: border-color .3s;
}

.form-textarea:hover {
    border-color: #888;
}

.form-radio-hidden {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
    padding: 0;
}

.form-radio-hidden-label {
    float: left;
    border: 1px solid #000;
    padding: 8px;
    font: inherit;
    font-weight: bold;
    text-align: center;
    border-radius: 18px;
    transition: background-color .3s;
    text-align: center;
    cursor: pointer;
    user-select: none;
    width: 48%;
    margin-bottom: 16px;
}

.form-radio-hidden-label:last-child {
    margin-left: 4%;
}

.form-radio-hidden-label:hover {
    background-color: #000;
    color: #fff;
}

.form-radio-hidden:checked+label {
    background-color: #000;
    color: #fff;
}

.form-tip {
    color: #626262;
    font-size: 12px;
    margin-top: 4px;
    text-align: left;
}

.form-info {
    font-size: 12px;
    margin-top: 16px;
    text-align: left;
    color: #626262;
}

.form-info a {
    text-decoration: underline;
    color: #626262;
}

.form-button {
    font: inherit;
    margin-top: 16px;
    width: 200px;
    padding: 8px 16px;
    cursor: pointer;
    outline: none;
    border-radius: 18px;
    color: #fff;
    border: none;
    background-image: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
}

.form-error {
    /* box-shadow: inset 0 0 1px 1px rgba(255, 47, 97, 0.5); */
    border-color: #ff9d9d;
}

.form-error:hover {
    border-color: #ff9d9d;
}

img.form-error {
    box-shadow: 0px 0px 20px #ff9d9d;
    /* border: 1px solid #ff9d9d; */
}

/* overwrite choises */
.choices__inner {
    background-color: #fff;
    border-radius: 4px;
    min-height: 40px;
    border: 1px solid #ddd;
}

.choices__input {
    background-color: #fff;
    font-size: 16px;
    padding: 0;
}

.choices__list--multiple .choices__item {
    background-color: #000;
    border: 1px solid #000;
}

.choices__list--multiple .choices__item.is-highlighted {
    background-color: #000;
    border: 1px solid #000;
}

.choices[data-type*=select-multiple] .choices__button, .choices[data-type*=text] .choices__button {
    border-left: 1px solid #fff;
}

.choices {
    margin-bottom: 0;
}

.choices-error {
    border-color: #ff9d9d;
}

/* select */
.filter-select {
    display: block;
    font: inherit;
    font-size: 16px;
	color: #6f6f6f;
	padding: .6em 1.4em .5em .8em;
	width: 100%;
	max-width: 100%;
	margin: 0;
	border: 1px solid #ddd;
	border-radius: 6px;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
    background-color: #fff;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.75593 7.79363C6.35716 8.25409 5.64284 8.25409 5.24407 7.79363L0.504769 2.32116C-0.0561072 1.67351 0.403946 0.666503 1.2607 0.666503L10.7393 0.666502C11.5961 0.666502 12.0561 1.67351 11.4952 2.32116L6.75593 7.79363Z' fill='%236F6F6F'/%3E%3C/svg%3E"),
        linear-gradient(to bottom, #ffffff 0%,#fff 100%);
	background-repeat: no-repeat, repeat;
	background-position: right .7em top 50%, 0 0;
    background-size: .65em auto, 100%;
    cursor: pointer;
    outline: none;
    transition: border-color .3s;
}

.filter-select::-ms-expand {
	display: none;
}
.filter-select:hover {
	border-color: #888;
}

.filter-select:focus {
	outline: none;
}

.filter-select option {
	font-weight:normal;
}

/* Support for rtl text, explicit support for Arabic and Hebrew */
*[dir="rtl"] .filter-select, :root:lang(ar) .filter-select, :root:lang(iw) .filter-select {
	background-position: left .7em top 50%, 0 0;
	padding: .6em .8em .5em 1.4em;
}

/* Disabled styles */
.filter-select:disabled, .filter-select[aria-disabled=true] {
	color: graytext;
	background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22graytext%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E'), #fff;
}
.filter-select:disabled:hover, .filter-select[aria-disabled=true] {
	border-color: #aaa;
}

.filter-select-highlight {
    color: #fff;
    border-color: #fff;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.75593 7.79363C6.35716 8.25409 5.64284 8.25409 5.24407 7.79363L0.504769 2.32116C-0.0561072 1.67351 0.403946 0.666503 1.2607 0.666503L10.7393 0.666502C11.5961 0.666502 12.0561 1.67351 11.4952 2.32116L6.75593 7.79363Z' fill='%23FFFFFF'/%3E%3C/svg%3E"),
        linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
}

.filter-date {
    display: block;
    font: inherit;
    font-size: 16px;
	color: #444;
	padding: .6em 1.4em .5em .8em;
	width: 100%;
	max-width: 100%;
	margin: 0;
	border: 1px solid #ddd;
	border-radius: 6px;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	background-color: #fff;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.75593 7.79363C6.35716 8.25409 5.64284 8.25409 5.24407 7.79363L0.504769 2.32116C-0.0561072 1.67351 0.403946 0.666503 1.2607 0.666503L10.7393 0.666502C11.5961 0.666502 12.0561 1.67351 11.4952 2.32116L6.75593 7.79363Z' fill='%236F6F6F'/%3E%3C/svg%3E"),
    linear-gradient(to bottom, #ffffff 0%,#fff 100%);
	background-repeat: no-repeat, repeat;
	background-position: right .7em top 50%, 0 0;
    background-size: .65em auto, 100%;
}

.filter-date:hover {
	border-color: #888;
}

.filter-date:focus {
	border-color: #aaa;
	color: #fff;
	outline: none;
}

.filter-date-highlight {
    color: #fff;
    border-color: #fff;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.75593 7.79363C6.35716 8.25409 5.64284 8.25409 5.24407 7.79363L0.504769 2.32116C-0.0561072 1.67351 0.403946 0.666503 1.2607 0.666503L10.7393 0.666502C11.5961 0.666502 12.0561 1.67351 11.4952 2.32116L6.75593 7.79363Z' fill='%23FFFFFF'/%3E%3C/svg%3E"),
        linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
}

.filter-date-highlight option {
    color: #000;
}

.text-normal {
    font-weight: normal;
}

.text-light {
    color: #626262;
}

.text-strong {
    font-weight: bold;
}

.text-center {
    text-align: center;
}

.min-w-85px {
    min-width: 85px;
}

.group:after {
    content: "";
    display: table;
    clear: both;
}

.group-twentyfive {
    float: left;
    width: 25%;
}

.group-fifty {
    float: left;
    width: 50%;
}

.group-fifty:first-child {
    padding-right: 16px;
}

.group-fifty:last-child {
    padding-left: 16px;
}

.group-column-third {
    float: left;
    width: 33.33%;
    text-align: center;
}

.group-column-third:first-child {
    text-align: left;
}

.group-column-third:last-child {
    text-align: right;
}

.group-column {
    float: left;
    width: 100%;
}

.group-item {
    float: left;
    width: 50%;
}

/* navigation */
.nav-bar {
    background-color: #fff;
    position: sticky;
    top: 0;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
    z-index: 3;
}

.nav-logo {
    height: 60px;
    display: block;
    background-image: url("/static/images/app/upforsports.png");
    background-repeat: no-repeat;
    background-size: 60px;
    background-position: 16px 50%;
    transition: height .3s;
}

.nav-action {
    float: right;
    padding: 12px 16px 10px 16px;
}

.nav-action-bar1, .nav-action-bar2, .nav-action-bar3 {
    width: 35px;
    height: 3px;
    background-color: #333;
    margin: 6px 0;
    transition: 0.4s;
}

.nav-action-open .nav-action-bar1 {
    transform: rotate(-45deg) translate(-9px, 6px) ;
}

.nav-action-open .nav-action-bar2 {
    opacity: 0;
}

.nav-action-open .nav-action-bar3 {
    transform: rotate(45deg) translate(-5px, -5px) ;
}

.nav-menu {
    display: none;
}

.nav-menu-open {
    display: block;
    padding-bottom: 16px;
}

.nav-link {
    display: block;
    padding: 16px;
    text-align: center;
    font-weight: bold;
    font-size: 18px;
}

.nav-link-active > .nav-link-border {
    padding-bottom: 2px;
    border-bottom: 2px solid #000;
}

.nav-link:hover > .nav-link-border {
    padding-bottom: 2px;
    border-bottom: 2px solid #000;
}

/* index / nav-bar-public */
.nav-bar-public {
    background: #fff;
    transition: background .3s;
}

.nav-bar-public-alt {
    background: transparent;
    box-shadow: none;
    color: #fff;
}

.nav-bar-public-alt a {
    color: #fff;
}

.nav-bar-public-alt .nav-link:hover > .nav-link-border {
    border-color: #fff;
}

.nav-bar-public-alt .nav-action-bar1 {
    background-color: #fff;
}

.nav-bar-public-alt .nav-action-bar2 {
    background-color: #fff;
}

.nav-bar-public-alt .nav-action-bar3 {
    background-color: #fff;
}

.nav-bar-public-alt .nav-logo {
    background-image: url("/static/images/app/upforsports-light.png");
}
/* nav bar open */
.nav-bar-public-alt.nav-bar-open {
    background-color: #fff;
}

.nav-bar-public-alt.nav-bar-open .nav-link:hover > .nav-link-border {
    border-color: #000;
}

.nav-bar-public-alt.nav-bar-open .nav-logo {
    background-image: url("/static/images/app/upforsports.png");
}

.nav-bar-public-alt.nav-bar-open .nav-action-bar1 {
    background-color: #000;
}

.nav-bar-public-alt.nav-bar-open .nav-action-bar2 {
    background-color: #000;
}

.nav-bar-public-alt.nav-bar-open .nav-action-bar3 {
    background-color: #000;
}

.nav-bar-public-alt.nav-bar-open .nav-link {
    color: #000;
}

/* box */
.box {
    display: block;
    position: relative;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
    overflow: hidden;
}

.box-body {
    padding: 16px;
}

/* ad sliders */
.slide-ad-enter-active {
    transition: all 1s ease;
}

.slide-ad-enter {
    transform: translateX(100%);
}

.slide-ad-leave-active {
    transition: all 1s ease;
    position: absolute;
    opacity: 0;
    transform: translateX(-100%);
}

.slide-ad-alt-enter-active {
    transition: all 1s ease;
}

.slide-ad-alt-enter {
    transform: translateX(-100%);
}

.slide-ad-alt-leave-active {
    transition: all 1s ease;
    position: absolute;
    opacity: 0;
    transform: translateX(100%);
}

/* index */

.index-about-partners {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
    align-items: flex-end;
}

.index-about-partners:last-child {
    margin-top: 32px;
}

.index-img-wrapper {
    position: relative;
}

.index-img-container {
    position: relative;
    background-color: #fff;
    margin-top: -60px;
    padding: 16px;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
}

.index-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.index-img-height {
    min-height: 380px;
}

.index-img-text {
    margin: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    transform: translate(-50%, -50%);
    color: #fff;
    max-width: 960px;
    padding: 16px;
}

.index-img-text h1 {
    font-size: 24px;
}

.index-img-text h2 {
    font-size: 18px;
    font-weight: normal;
}

.index-instructor {
    padding: 16px;
}

.index-feedback-img {
    position: absolute;
    top: -24px;
    left: calc(50% - 50px);
    width: 100px;
    height: 100px;
    background-color: #ddd;
    border-radius: 50%;
    box-shadow: 0 2px 4px 2px rgba(0, 0, 0, 0.1);
}

.index-feedback-circle-container {
    width: 130px;
    height: 13px;
    margin: 0 auto;
}

.index-feedback-circle {
    float: left;
    width: 8px;
    height: 8px;
    border-radius: 4px;
    background-color: #C4C4C4;
    margin: 0 4px 0 4px;
    transition: background-color .3s ease;
}

.index-feedback-circle-active {
    background-color: #000;
}

.index-feedback-container {
    position: relative;
    width: 100%;
    height: 400px;
    overflow: hidden;
    /* width: calc(100% * 3); */
}

.index-feedback {
    position: absolute;
    top: 24px;
    left: 0;
    right: 0;
    bottom: 0;
    transition: all .3s ease;
}

.index-feedback-slide-right {
    transform: translateX(110%);
}

.index-feedback-slide-left {
    transform: translateX(-110%);
}

.index-feedback-btn {
    cursor: pointer;
    user-select: none;
}

.index-feedback-btn-container {
    position: relative;
    max-width: 600px;
    margin: 0 auto;
}

.index-feedback-btn {
    cursor: pointer;
    user-select: none;
}

.index-feedback-prev {
    position: absolute;
    top: -38px;
    left: 16px;
}

.index-feedback-next {
    position: absolute;
    top: -38px;
    right: 16px;
}

/* ambassador */
.ambassador-row {
    /* float: left;
    width: 50%; */
    padding-bottom: 32px;
}

.ambassador-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    height: 300px;
    object-position: top;
}

/* grant */
.grant {
    float: left;
    width: 100%;
    padding: 16px 0 0 0;
}

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

.grant-image {
    max-height: 360px;
    padding-bottom: 100px;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}

.grant-info {
    margin-top: -100px;
}

.grant-award {
    border-top: 1px solid #f2f2f2;
}

.grant-splash {
    width: 100%;
    height: 350px;
    object-fit: cover;
    margin-bottom: -80px
}

.grant-giver {
    background-color: #f1f1f1;
    margin-top: 64px;
}

.grant-giver-img {
    display: none;
}

.grant-giver-content {
    padding: 32px;
}

.grant-giver a {
    margin-top: 16px;
    width: 228px;
}

/*activity*/
.activity {
    height: 150px;
    display: block;
    position: relative;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
    transition: box-shadow .3s;
    overflow: hidden;
}

.activity-1, .activity-2, .activity-3 {
    float: left;
    width: 100%;
    padding: 16px 0 0 0;
}

.activity h2 {
    margin: 0;
    font-size: 26px;
}

.activity-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}

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

.activity:hover {
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.3);
}

.activity-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
}

.activity-name {
    color: #fff;
    position: absolute;
    top: 50px;
    left: 0;
    right: 0;
}

.activity-sessions {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #fff;
    padding: 8px 4px 8px 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.activity-splash {
    height: 400px;
    display: block;
    position: relative;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
    transition: box-shadow .3s;
    overflow: hidden;
}

/* booking */
.book-session {
    background-color: #fff;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
}

/* view */
.view-center {
    text-align: center;
}

.view-row {
    margin-top: 16px;
}

.view-row-alt {
    margin-top: 32px;
}

.view-pad {
    transition: padding .3s;
}

.view-container {
    position: relative;
    padding: 32px 16px 32px 16px;
}

.view-container-alt {
    padding: 32px 0 32px 16px;
}

.view-image-wrapper {
    position: relative;
    width: 150px;
    height: 150px;
}

.view-image {
    position: absolute;
    left: 40px;
    width: 150px;
    height: 150px;
    background-color: #ddd;
    border-radius: 50%;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
}

.view-image-label {
    position: absolute;
    left: 40px;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    cursor: pointer;
    text-align: center;
    color: #fff;
    line-height: 200px;
    background: rgba(0, 0, 0, 0.4);
    transition: background .3s;
}

.view-image-label:hover {
    background: rgba(0, 0, 0, 0.6);
}

.view-image-form {
    margin-top: 120px;
}

.view-file {
    width: 0.1px;
    height: 0.1px;
    opacity: 0;
    overflow: hidden;
    position: absolute;
    z-index: -1;
}

.view-btn {
    background: transparent;
    display: inline-block;
    border: 1px solid #000;
    padding: 8px 64px;
    font: inherit;
    font-weight: bold;
    text-align: center;
    border-radius: 18px;
    transition: ease .3s;
    cursor: pointer;
    outline: none;

}

.highlighted {
    color: #fff;
    border-color: #fff;
    background: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
}


.view-btn:hover {
    transform: scale(1.05);
}


.view-btn:active {
    background-color: #000;
    color: #fff;
}

.view-btn-light {
    color: #fff;
    border-color: #fff;
}

.view-btn-sel {
    background-color: #000;
    color: #fff;
}


.view-btn-alt {
    display: inline-block;
    border: none;
    padding: 10px 64px;
    font: inherit;
    font-weight: bold;
    text-align: center;
    border-radius: 18px;
    background: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
    color: #fff;
    border: none;
    cursor: pointer;
    outline: none;
    transition: ease .3s;
}

.view-btn-alt:hover {
    transform: scale(1.05);
}

.view-btn-alt:active {
    transform: scale(1);
}

.view-btn-gray {
    background: #ddd;
    color: #888;
}

.view-btn-alt:disabled:hover {
    cursor: not-allowed;
    transform: scale(1);
}

.view-btn-green {
    color: #fff;
    border-color: #75DD73;
    background-color: #75DD73;
}

.view-btn-green:hover {
    color: #fff;
    border-color: #75DD73;
    background-color: #75DD73;
}

.view-btn-green:focus {
    color: #fff;
    border-color: #75DD73;
    background-color: #75DD73;
}

.view-btn-full {
    width: 100%;
    max-width: 460px;
}

.view-pic-space {
    height:32px;
}

.view-pic-wrapper {
    margin: -78px auto 0 auto;
    width: 100px;
    height: 100px;
    position: relative;
}

.view-pic {
    position: absolute;
    width: 100px;
    height: 100px;
    background-color: #ddd;
    border-radius: 50%;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
}

.view-pic-promoted {
    border: 5px solid #FF794F;
}

.view-pic-badge {
    position: absolute;
    left: -8px;
    bottom: 0;
    width: 40px;
    height: 40px;
}

.view-emoji {
    float: left;
    width: 15%;
    text-align: left;
    line-height: 32px;
    font-size: 32px;
}

.view-percent {
    float: left;
    width: 15%;
    text-align: right;
    line-height: 32px;
}

.view-progress-row {
    margin-top: 16px;
    height: 32px;
}

.view-progress {
    float: left;
    width: 70%;
    background-color: #ddd;
    height: 32px;
    border-radius: 18px;
}

.view-progress-fill {
    height: 32px;
    background: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
    border-radius: 18px;
    width: 0;
    transition: width .3s;
}

/* container */
.container {
    padding: 16px;
    background-color: #fff;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
    transition: box-shadow .3s;
}

/* flow */
.page-s-frame {
    background: #fff url("/static/images/app/s-frame.png") no-repeat center center;
    background-size: cover;
}

.page-container {
    position: relative;
    min-height: calc(100vh - 60px);
}

.page-wider {
    max-width: 960px;
    margin: 0 auto;
}

.page {
    max-width: 660px;
    margin: 0 auto;
    padding-bottom: 84px; /* step-page */
}

.step-wrapper {
    padding-top: 0px;
    padding-bottom: 0px;
    text-align: center;
}

.step {
    display: inline-block;
    height: 64px;
    width: 64px;
    border-radius: 50%;
    color: #fff;
    text-align: center;
    line-height: 64px;
    font-size: 32px;
    font-weight: bold;
    box-shadow: 0px 0 4px rgba(255, 47, 97, 0.5);
}

.fade-enter-active, .fade-leave-active {
    transition: opacity .3s;
}

.fade-enter, .fade-leave-to {
    opacity: 0;
}

.step-page-wrapper {
    background-color: #fff;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    user-select: none;
}

.step-container {
    max-width: 660px;
    margin: 0 auto;
    height: 60px;
}

.step-page {
    float: left;
    width: 33%;
    height: 60px;
    line-height: 60px;
    text-align: center;
}

.step-page h3 {
    margin: 0;
}

.step-arrow {
    transition: transform .3s ease;
    cursor: pointer;
}

.step-arrow:hover {
    transform: scale(1.1);
}

.calendar-component {
    user-select: none;
}

.calendar-arrow {
    margin-top: 4px;
    cursor: pointer;
    transition: transform .3s ease;
}

.calendar-arrow:hover {
    transform: scale(1.1);
}

.calendar {
    background-color: #fff;
    border: 1px solid #ddd;
    text-align: center;
    padding: 8px 8px;
    cursor: pointer;
    color: #aaa;
    transition: background-color .3s;
}

.calendar-week {
    color: #000;
}

.calendar:hover {
    background-color: #000;
    color: #fff;
}

.calendar-selected {
    background: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
    color: #fff;
    border-top-color: #FFD15A;
    border-left-color: #FFD15A;
    border-right-color: #FF2F61;
    border-bottom-color: #FF2F61;
}

.calendar-input {
    padding-right: 16px;
    text-align: left;
}

.calendar-session-btn {
    margin-top: 20px;
}

.list-container {
    position: relative;
    padding: 0 0 32px 0;
    overflow: hidden;
}

.list-container h1 {
    padding-left: 16px;
}

.list-item {
    background-color: #fff;
    display: block;
    position: relative;
    padding: 16px 8px 16px 88px;
    margin: 8px 0 0 0px;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
    cursor: pointer;
    transition: box-shadow .3s;
}

.list-item:hover {
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.3);
}

.list-text {
    display: block;
    width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 12px;
}

.list-time {
    background-image: url('/static/images/app/watch.svg');
    background-repeat: no-repeat;
    background-position: 0 50%;
    padding-left: 16px;
}

.list-image {
    position: absolute;
    top: 16px;
    left: 16px;
    width: 65px;
    height: 65px;
    background-color: #ddd;
    border-radius: 50%;
    box-shadow: 0 2px 4px 2px rgba(0, 0, 0, 0.1);
}

.list-image-promoted {
    border: 5px solid #FF794F;
}

.list-image-badge {
    position: absolute;
    height: 30px;
    width: 30px;
    left: 14px;
    bottom: 14px;
}

.list-rating {
    position: absolute;
    top: 18px;
    right: 16px;
    height: 16px;
    line-height: 16px;
    font-size: 12px;
    background-color: #fff;
}

.list-rating-text {
    float: left;
    padding-right: 2px;
}

.list-rating-star {
    float: left;
}

.list-warning {
    position: absolute;
    top: 38px;
    right: 16px;
    color: #fff;
    background-color: #FF3561;
    padding: 4px 8px;
    border-radius: 16px;
    font-size: 12px;
}

.list-free {
    background-color: #75DD73;
    height: 16px;
    line-height: 16px;
    padding: 0 4px 0 4px;
    border-radius: 16px;
    font-size: 12px;
    color: #fff;
}

.slide-fade-enter-active {
    transition: all .3s ease;
}

.slide-fade-leave-active {
    display: none;
}

.slide-fade-enter, .slide-fade-leave-to {
    transform: translateX(10px);
    opacity: 0;
}

/* map */
.gmap {
    background-color: #ddd;
    max-width: 928px;
    margin: 0 auto;
    height: 280px;
    margin-top: 16px;
}

/* filter */
.filter {
    position: relative;
    height: 70px;
    z-index: 2;
}

.filter-item {
    float: left;
    width: 25%;
}

.filter-value {
    margin-right: 16px;
}

.filter-value-last {
    margin-right: 0;
}

/* card */
.card {
    margin: 16px 16px 0 0;
    display: block;
    cursor: pointer;
    font-size: 12px;
}

.card:hover {
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.3);
}

.card:hover .card-pic {
    transform: scale(1.1);
}

.card-profile {
    position: relative;
    background-color: #ddd;
    margin: -16px -16px 16px -16px;
    height: 200px;
    overflow: hidden;
}

.card-profile-promoted {
    border: 5px solid #FF794F;
}

.card-profile-badge {
    position: absolute;
    height: 40px;
    width: 40px;
    left: 8px;
    bottom: 8px;
    z-index: 1;
}

.card-pic {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}

.card-text {
    text-align: center;
    display: inline-block;
    width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.card-info {
    text-align: center;
    margin: 16px -16px -16px -16px;
}

.card-booking {
    float: left;
    width: 50%;
    border-top: 1px solid #eee;
    border-right: 1px solid #eee;
    padding: 8px;
    min-height: 52px;
}

.card-rating {
    border-top: 1px solid #eee;
    float: left;
    width: 50%;
    padding: 8px;
}

/* pagination */
.paginate {
    position: relative;
    margin: 0 auto;
    padding-bottom: 32px;
    width: 340px;
}

.paginate-item {
    background-color: #f1f1f1;
    font: inherit;
    font-size: 16px;
    padding: 0 32px 0 0;
    border: 1px solid transparent;
    outline: none;
    cursor: pointer;
    height: 52px;
    line-height: 52px;
}

.paginate-item:hover {
    text-decoration: underline;
}

.paginate-active {
    font-weight: bold;
}

.paginate-next {
    position: absolute;
    right: 0;
    transition: transform .3s ease;
    cursor: pointer;
}

.paginate-next:hover {
    transform: scale(1.1);
}

/* footer */
.footer {
    background-color: #000;
    color: #fff;
    padding: 64px 16px 64px 16px;
}

.footer-logo {
    height: 70px;
    height: 40px;
    margin-top: 8px;
    margin-bottom: 32px;
    display: block;
}

.footer a {
    display: block;
    color: #fff;
}

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

.footer-list{
    display: flex; 
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 20px;
}

.footer-list > * {
    min-width: 85px;
}

/* ads */

.ad-container {
    position: relative;
    min-height: 100vh;
}

.ad-img {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ad-link {
    float: right;
    color: #fff;
    padding-top: 30px;
    font-weight: bold;
}

.upformatch-text {
    background: linear-gradient(125.55deg, #40DB87 3.12%, #52F29B 104.52%);
    margin: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: #fff;
    padding: 0 8px 0 8px;
}

.ad-app {
    overflow: hidden;
}

.ads-wrapper {
    position: relative;
    height: 300px;
    overflow: hidden;
}

.ads-container {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.ads-background {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ads-ambassador {
    background-color: #000;
    color: #fff;
}

.ads-ambassador-text {
    margin: 0;
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    text-align: left;
    padding-left: 32px;
    color: #fff;
    max-width: 960px;
}

.ads-btn {
    cursor: pointer;
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #C4C4C4;
    margin: 16px 2px 0 2px;
}

.ads-btn-active {
    background-color: #000;
}

.ads-sverigesportar {
    background-color: #FF794F;
    text-align: left;
}

.ads-sverigesportar-mobile-img {
    display: unset;
}

.ads-sverigesportar-desktop-img {
    display: none;
}

.ads-sverigesportar-text {
    color: #FFE769;
    max-width: 400px;
    padding: 0 16px 0 16px;
    text-align: center;
}

.ads-sverigesportar-btn {
    border: 1px solid #FFE769;
    font: inherit;
    display: block;
    background-color: #FF794F;
    padding: 8px 32px;
    border-radius: 18px;
    color: #FFE769;
    transition: ease .3s;
    cursor: pointer;
    margin-left: 16px;
    margin-right: 16px;
}

.ads-sverigesportar-btn:hover {
    transform: scale(1.05);
}

.ads-sverigesportar-container {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 64px;
    height: 300px;
}

.ads-sverigesportar-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 32px;
    height: 300px;
}

/* ufs ad */
/* .ads-upforsports-ad {} */

.ads-upforsports-ad-container {
    padding: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 32px;
    height: 300px;
    color: #fff;
    background: linear-gradient(131.87deg, #FF2F61 0%, #FFD15A 101.56%);
}

.ads-upforsports-ad-logo {
    display: none;
}

@media (min-width: 1024px) {
    .ads-upforsports-ad-logo {
        display: unset;
    }
}

.ads-upforsports-ad-content {
    font-size: 17px;
    display: grid;
    justify-items: start;
    gap: 32px;
}

.ads-upforsports-ad-text {
    color: #fff;
    max-width: 400px;
    text-align: left;
}

.ads-upforsports-ad-bottom {
    display: grid;
    align-items: end;
    justify-items: center;
}


@media (min-width: 1024px) {
    .ads-upforsports-ad-bottom {
        grid-template-columns: 1fr 1fr;
    }
}

/* ufm ad */
.ads-upformatch-team {
    display: none;
}

.ads-upformatch-container {
    display: grid;
    grid-template-columns: 345px 1fr;
    align-items: center;
    height: 300px;
    background-color: #2FD27A;
    color: #fff;
}

.ads-upformatch-content {
    font-size: 16px;
    display: grid;
    justify-items: center;
}

.ads-upformatch-text {
    color: #fff;
    max-width: 550px;
}

.max-items:nth-child(n+3) {
    display: none;
}

@media (min-width: 680px) {
    /* nav bar open */
    .nav-bar-public-alt.nav-bar-open {
        background: transparent;
    }

    .nav-bar-public-alt.nav-bar-open .nav-link:hover > .nav-link-border {
        border-color: #fff;
    }

    .nav-bar-public-alt.nav-bar-open .nav-logo {
        background-image: url("/static/images/app/upforsports-light.png");
    }

    .nav-bar-public-alt.nav-bar-open .nav-action-bar1 {
        background-color: #fff;
    }

    .nav-bar-public-alt.nav-bar-open .nav-action-bar2 {
        background-color: #fff;
    }

    .nav-bar-public-alt.nav-bar-open .nav-action-bar3 {
        background-color: #fff;
    }

    .nav-bar-public-alt.nav-bar-open .nav-link {
        color: #fff;
    }

    .nav-logo {
        width: 80px;
        float: left;
    }

    .nav-action {
        display: none;
    }

    .nav-menu {
        float: right;
        display: block;
    }

    .nav-link {
        font-size: 14px;
        float: left;
        height: 60px;
        line-height: 60px;
        padding: 0 16px 0 16px;
    }

    .nav-link:first-child {
        padding: 0 16px 0 0;
    }

    .footer {
        line-height: 24px;
    }

    .footer-logo {
        height: 70px;
    }

    .main-right-first {
        position: sticky;
        top: 60px;
        float: left;
        width: 50%;
        height: calc(100vh - 60px);
    }

    .main-right-second {
        width: 50%;
        margin-left: 50%;
        min-height: calc(100vh - 60px);
    }

    .main-left-first {
        width: 55%;
        min-height: calc(100vh - 60px);
    }

    .main-left-second {
        display: block;
        position: sticky;
        top: 60px;
        float: right;
        width: 45%;
        height: calc(100vh - 60px);
    }


    .main-left-second-content-badge {
        left: 20px;
    }

    .main-left-second-content-img-wrapper {
        width: 180px;
        height: 180px;
    }

    .main-left-second-content-img {
        width: 180px;
        height: 180px;
    }

    .group-item {
        float: left;
        width: 33.33%;
    }

    .overlay-inner-wide {
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    .index-img-text h1 {
        font-size: 30px;
    }

    .index-img-text h2 {
        font-size: 20px;
    }

    .card {
        font-size: 14px;
    }

    .list-container {
        padding: 0 16px 32px 16px;
    }

    .list-container h1 {
        padding: 0;
    }

    .list-text {
        font-size: 14px;
    }

    .list-rating {
        top: 26px;
        font-size: 14px;
    }

    .list-warning {
        top: 48px;
        font-size: 14px;
    }

    .list-item {
        padding: 24px 16px 24px 70px;
        margin: 16px 0 0 50px;
    }

    .list-image {
        position: absolute;
        top: 11px;
        left: -50px;
        width: 100px;
        height: 100px;
        background-color: #ddd;
        border-radius: 50%;
        box-shadow: 0 2px 4px 2px rgba(0, 0, 0, 0.1);
    }

    .list-image-badge {
        height: 40px;
        width: 40px;
        left: -60px;
        bottom: 12px;
    }

    .activity {
        height: 300px;
    }

    .activity-name {
        top: 128px;
    }

    .activity-1 {
        float: left;
        width: 100%;
        padding: 16px 0 0 0;
    }

    .activity-2 {
        float: left;
        width: 50%;
        padding: 8px;
        padding: 16px 16px 0 0;
    }

    .activity-2:last-child {
        padding: 16px 0 0 0;
    }

    .activity-3 {
        float: left;
        width: 33.33%;
        padding: 16px 16px 0 0;
    }

    .activity-3:last-child {
        padding: 16px 0 0 0;
    }

    .grant-info {
        position: absolute;
        left: 0;
        bottom: 0;
        width: 60%;
        background-color: #fff;
        height: 100px;
    }

    .grant-award {
        position: absolute;
        right: 0;
        bottom: 0;
        width: 40%;
        background-color: #fff;
        height: 100px;
        line-height: 32px;
        border-left: 1px solid #F2F2F2;
    }

    .video-text {
        font-size: 24px;
    }

    .video-text-desktop {
        display: block;
    }

    .video-text-mobile {
        display: none;
    }

    .max-items:nth-child(n+3) {
        display: block;
    }

    .max-items:nth-child(n+4) {
        display: none;
    }

    .ads-upformatch-team {
        display: block;
    }

    .ambassador-row {
        float: left;
        width: 50%;
        padding-bottom: 32px;
    }

    .ambassador-row:first-child {
        padding-right: 16px;
    }

    .ambassador-row:last-child {
        padding-left: 16px;
    }

}

@media (min-width: 1024px) {
    .nav-logo {
        height: 100px;
        width: 120px;
        background-size: 100px;
    }

    .nav-link {
        height: 100px;
        line-height: 100px;
    }

    .nav-btn {
        background-color: #fff;
        color: #000;
        border: 1px solid #000;
        height: 40px;
        line-height: 40px;
        border-radius: 20px;
        margin-top: 29px;
        margin-left: 16px;
        margin-right: 16px;
        transition: ease .3s;
    }

    .nav-btn:hover {
        transform: scale(1.05);
    }

    .nav-btn:hover .nav-link-border {
        border: none;
    }

    .nav-btn .nav-link-border {
        color: #000;
        border: none;
    }

    .nav-btn-transparent {
        background: transparent;
        border-color: #fff;
    }

    .nav-btn-transparent .nav-link-border {
        color: #fff;
    }

    .nav-btn-alt {
        background: linear-gradient(131.87deg, #FFD15A 0%, #FF2F61 101.56%);
        color: #fff;
        border: none;
        padding: 0 32px 0 32px;
    }

    .nav-btn-alt:hover {
        /* background-color: #000; */
        transform: scale(1.05);
    }

    .nav-btn-alt:hover .nav-link-border {
        border: none;
        color: #fff;
    }

    .nav-btn-alt .nav-link-border {
        color: #fff;
        border: none;
    }

    .video-wrapper {
        margin-top: -100px;
    }

    .index-text {
        padding-top: 200px;
    }

    .index-right {
        float: right;
        width: 50%;
    }

    .index-left {
        float: left;
        width: 50%;
    }

    .index-img-container {
        padding: 32px 128px 32px 128px;
        margin: -150px 16px 60px 16px;
    }

    .index-instructor {
        float: left;
        width: 33.33%;
        padding: 16px;
    }

    .page-container {
        min-height: calc(100vh - 100px);
    }

    .main-left-first {
        min-height: calc(100vh - 100px);
    }

    .main-left-second {
        top: 100px;
        height: calc(100vh - 100px);
    }

    .main-right-first {
        top: 100px;
        height: calc(100vh - 100px);
    }

    .main-right-second {
        min-height: calc(100vh - 100px);
    }

    /* TODO: not pretty */
    .group-column:nth-child(even) .list-item {
        margin-left: 66px;
    }

    .group-column {
        float: left;
        width: 50%;
    }

    .group-item {
        float: left;
        width: 25%;
    }

    .grant {
        float: left;
        width: 50%;
        padding: 8px;
        padding: 16px 16px 0 0;
    }

    .grant:last-child {
        padding: 16px 0 0 0;
    }

    .grant-giver {
        height: 360px;
    }

    .grant-giver-content {
        padding: 104px 32px 0 32px;
    }

    .grant-giver-img {
        display: block;
        float: left;
        object-fit: cover;
        height: 360px;
        width: 390px;
    }

    .grant-giver a:first-child {
        margin-right: 16px;
    }

    .grant-giver a:last-child {
        margin-left: 16px;
    }

    .video-text {
        font-size: 32px;
    }

    .max-items:nth-child(n+4) {
        display: block;
    }

    .max-items:nth-child(n+5) {
        display: none;
    }

    .ads-sverigesportar-desktop-img {
        display: unset;
    }

    .ads-sverigesportar-mobile-img {
        display: none;
    }

    .ads-sverigesportar-content {
        align-items: flex-start;
    }

    .ads-sverigesportar-text {
        text-align: left;
    }
}

@media (min-width: 1440px) {
    .view-pad {
        padding: 0 128px 0 128px;
    }

    .main {
        margin: 0 128px 0 128px;
    }

    .group-item {
        float: left;
        width: 20%;
    }

    .card-profile {
        height: 300px;
    }

    .max-items:nth-child(n+5) {
        display: block;
    }

    .max-items:nth-child(n+6) {
        display: none;
    }

    .ambassador-img {
        height: 500px;
    }
}

/* loader */
@keyframes bouncing-loader {
    to {
      opacity: 0.1;
      transform: translate3d(0, -1rem, 0);
    }
}

.bouncing-loader {
    display: flex;
    justify-content: center;
}

.bouncing-loader > div {
    width: 1rem;
    height: 1rem;
    margin: 3rem 0.2rem;
    background: #FFD15A;
    border-radius: 50%;
    animation: bouncing-loader 0.6s infinite alternate;
}

.bouncing-loader > div:nth-child(2) {
    animation-delay: 0.2s;
    background: #000;
}

.bouncing-loader > div:nth-child(3) {
    animation-delay: 0.4s;
    background: #FF2F61;
}

.session-types{
    display: flex;
    justify-content: space-between;
}

.session-type h3{
    margin: 20px;
    line-height: 20px;
}

.session-type{
    box-shadow: 0px 10px 25px rgba(0, 0, 0, 0.2);
    width: 45%;
    transition: scale 0.2s ease;
}

.session-type:hover{
    scale: 1.05;
}

.session-type-img{
    width: 100%;
    /* height: 300px;
    max-height: 70%; */
    object-position: top;
    object-fit: cover;
}


/* overwrite choises */
.choices__inner {
    background-color: #fff;
    border-radius: 8px;
    min-height: 40px;
    border: 1px solid #ddd;
}

.choices__inner-alt {
    display: inline-block;
    vertical-align: top;
    width: 100%;
    background-color: #fff;
    border-radius: 8px;
    min-height: 40px;
    border: 1px solid #fff;
    padding: 7.5px 7.5px 3.75px;
    font-size: 14px;
    overflow: hidden;
}

.choices__input {
    background-color: #fff;
    font-size: 16px;
    padding: 0;
}

.choices__list--multiple .choices__item {
    background-color: #000;
    border: 1px solid #000;
}

.choices__list--multiple .choices__item.is-highlighted {
    background-color: #000;
    border: 1px solid #000;
}

.choices[data-type*=select-multiple] .choices__button, .choices[data-type*=text] .choices__button {
    border-left: 1px solid #fff;
}

.choices {
    margin-bottom: 0;
}

.pin-center{
    display: flex;
    justify-content: center;
    align-items: center;
}



.instructor-selection{
    flex-shrink: 0;

    width: 1000px;
    max-width: 100vw;

    /* display: flex; */
    /* flex-direction: row;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap; */
    margin-left: 20px
}


.instructor-card-columns {
    float: left;
    width: 25%;
    text-align: center;

    padding-top: 16px;
    padding-right: 25px;
}

@media (min-width: 680px) {
    .instructor-card-columns:nth-child(4n) {
        padding-right: 0;
        width: calc(25% - 25px);
    }
}


@media (max-width: 680px) {

    .instructor-card-columns {
        width: 50%;
        padding-top: 16px;
        padding-right: 25px;
    }

    .instructor-card-columns:nth-child(2n) {
        padding-right: 0;
        width: calc(50% - 25px);
    }
}


.group-column-fourth {
    float: left;
    width: 25%;
    text-align: center;

    padding-top: 16px;
    padding-right: 25px;
}

@media (min-width: 680px) {
    .group-column-fourth:nth-child(4n) {
        padding-right: 0;
        width: calc(25% - 25px);
    }
}


.wrap{
    text-wrap: wrap;
}

.no-wrap{
    text-wrap: nowrap;
}

.instructor-card{
    width: 100%;
    text-align: center;

    float: left;
    text-wrap: nowrap;
    border-radius: 16px;

    box-shadow: 2px 2px 10px 1px #c6c6c6;;
}


.instructor-card img{
    border-top-right-radius: 16px;
    border-top-left-radius: 16px;

    object-fit: cover;
    object-position: center;
    overflow: hidden;
    width: 100%;
}

.instructor-card button{
    padding: 8px 0px;
}

.flex-column-center{
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    gap: 8px;
}

.margin-10{
    margin: 10px
}

.margin-20{
    margin: 20px
}

.bold{
    font-weight: bold;
}

.center{
    text-align: center;
}

.inline-20{
    display: inline-block;
    width: 20%;
}

.inline-30{
    display: inline-block;
    width: 30%;
}

.inline-33{
    display: inline-block;
    width: 33.3%;
}

.inline-50{
    display: inline-block;
    width: 50%;
}

.inline-60{
    display: inline-block;
    width: 60%;
}

.inline-66{
    display: inline-block;
    width: 66.6%;
}

.inline-70{
    display: inline-block;
    width: 70%;
}

.instructor-modal{
    width: 700px;
    max-width: 95%;   
}

.instructor-img{
    object-fit: cover;
    object-position: center;
    width: 100%;
    height: 100%;
}

.flex{
    display: flex;
    justify-content: space-between;
}

.nothing-notice {
    text-align: center;
}

.nothing-notice p{
    padding-top: 100px;
    max-width: 400px;
    margin: auto;
    font-size: 1.2em;
}

.nothing-notice a{
    margin: 20px auto;;
}

/* Price */

.price-checkmark {
    display: flex;
    align-items: center;
}

.price-checkmark svg {
    padding-right: 8px;
}

.flex-container {
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    align-content: stretch;
}

/* price-container */
.price-flex {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.price-item {
    position: relative;
    flex-grow: 1;
    width: 40%;
    transition: box-shadow .3s;
    box-shadow: 0px 0px 20px rgba(183, 183, 183, 0.35);
}

.price-item-label {
    cursor: pointer;
}

.price-item-label-selected {
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.35);
}

.price-info {
    width: 25%;
    margin-bottom: 16px;
}

.price-img {
    height: 116px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.price-container {
    overflow: hidden;
}

.price-container-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 1px;
    background: rgba(140, 108, 232, 0.4);
    border-radius: 30px;
    z-index: 1;
    transition: opacity .3s;
}

.price-item-label-selected > .price-container-overlay {
    opacity: 0;
}

.price-container-top {
    min-height: 230px;
}

.price-container-white {
    background-color: #fff;
}

.price-container-green {
    background-color: #40DB88;
}

.price-container-brown {
    background-color: #A86B5E;
}

.price-container-gray {
    background-color: #9EBDC7;
}

.price-container-yellow {
    background-color: #FFBF42;
}

.price-amount {
    display: flex;
    justify-content: center
}

.price-offer {
    position: relative;
    padding-right: 8px;
    color: #9C9C9C;
}

.price-amount svg {
    position: absolute;
    height: 80%;
    top: 3px;
    left: -7px;
}

.price-star {
    position: relative;
    display: inline-block;
    color: #CA4900;
    font-weight: bold;
    font-size: 14px;
    padding-top: 8px;
    padding-left: 32px;
}

.price-star img {
    position: absolute;
    top: 2px;
    left: 0px;
}

.price-line {
    margin-top: 64px;
    margin-bottom: 64px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.price-line1 {
    width: 40%;
    height: 42px;
    border-left: 3px solid #fff;
    border-bottom: 3px solid #fff;
    border-bottom-left-radius: 30px;
}

.price-line2 {
    width: 30px;
    height: 21px;
    margin-bottom: -18px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    border-top-right-radius: 30px;
    margin-right: -1px;
}

.price-line3 {
    width: 30px;
    height: 21px;
    margin-bottom: -18px;
    border-top: 3px solid #fff;
    border-left: 3px solid #fff;
    border-top-left-radius: 30px;
    margin-left: -2px;
}

.price-line4 {
    width: 40%;
    height: 42px;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    border-bottom-right-radius: 30px;
}

.price-dl {
    width: 500px;
    /* color: #fff; */
}

.price-dt {
    float: left;
    width: 220px;
    overflow: hidden;
    white-space: nowrap;
}

.price-dt:after { content: " .................................................................................." }

/* subscriptions */
.subscription {
    background-color: #fff;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
    transition: box-shadow .3s;
    color: #000;
    grid-template-columns: 200px 1fr;
    max-width: 800px;
    align-items: center;
}

.subscription-text {
    padding: 16px;
}
@media (min-width: 1024px) {
    .price-flex {
        gap: 32px;
    }
    
    .price-item {
        flex-grow: 1;
        width: 20%;
    }
}

/*  flex vertical center*/
.flex-vc{
    display: flex;
    flex-direction: column; 
    align-items: center; 
    gap: 10px;
}

.spinner-container {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.spinner {
    border: 4px solid #f3f3f3;
    border-top: 4px solid #3498db;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    animation: spin .7s ease-in-out infinite;
    margin-bottom: 15px;
    margin: 20px auto;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.scroll-text{
    max-height: 120px;
    overflow: auto;
}

.flex-auto{
    flex: auto;
}