@import url("./nunito.509ff2c1c710.css");
@import url("./lexend.959a126429ac.css");

html{
  color: rgba(53,53,53,1) !important;
  font-size: 1rem;
  line-height: 1.15;
  font-kerning: normal;
  overflow-x: hidden;
}
body{
  font-family: var(--bs-body-font-family);
  background-color: var(--background);
  overflow-x: hidden;
  letter-spacing: 0.025rem;
  font-variant-ligatures: no-common-ligatures;
  margin: 0;
}
h1, h2, h3, h4, h5{
  font-family: var(--bs-ttl-font-family);
}
.navbar-toggler{
  color: var(--bs-btn-hover-bg);
}
.custom-toggler.navbar-toggler-icon{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(245,135,5,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='1.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

:root{
  --background: rgb(240, 240, 240);
  --background-wrapper: rgb(250, 250, 250);
  --primary: rgb(103, 103, 103);
  --secondary: rgb(220, 220, 220);
  --accent:45,98%;
  --accent-normal: hsl(var(--accent), 54%);
  --accent-light: hsl(var(--accent), 75%);
  --bs-btn-hover-bg: rgb(242, 135, 5);
  --bs-link-color: rgb(242, 135, 5);
  --bs-body-font-family: 'Nunito', Arial, Tahoma, sans-serif;
  --bs-ttl-font-family: 'Lexend', Arial, Tahoma, sans-serif;
  --top-bar: 6.125rem;
  --bottom-bar: 5em;
  --div-padding: 3em;
  --div-padding-xxs: calc(var(--div-padding) / 5);
  --div-padding-sm: calc(var(--div-padding) / 3);
  --div-padding-md: calc(var(--div-padding) / 2);
  --bs-navbar-color: rgba(242, 135, 5, .15);
  --banner-gradient: linear-gradient(43deg, #f28705 0%, #f69602 22%, #f7a602 49%, #fbb409 75%, #fd9b14 100%)
}

.top-bar{
  height: var(--top-bar);
  border-bottom: 1px solid var(--accent-normal);
  background-color: rgb(var(--bs-tertiary-bg-rgb));
  box-shadow: 0 10px 20px 0 rgba(0, 0, 0, .1);
}
.top-bar > div{ 
  height: 100%;
}
main{
  margin-top: var(--top-bar);
}
/* navbar */
.navbar-brand img{
  height: calc(var(--top-bar) - 1.5em);
}
#main-nav, .offcanvas-backdrop{
  top: var(--top-bar);
}
.offcanvas-header, .offcanvas-body{
  padding: 1.625rem;
}
.wrapper{
  display: flex;
  align-items: center;
  justify-content: center;
  height: auto;
  min-height: calc(100vh - var(--top-bar));
}
.errorlist{ 
  list-style: none; 
  padding-left: 0 !important; 
}
.errorlist li{
  padding: .75rem 1.25rem;
  margin-bottom: 1rem;
  border-radius: .25rem;
  color: #721c24;
  background-color: #f8d7da;
  border-color: #f5c6cb;
}
.field-error{
  padding: var(--div-padding-xxs);
  font-size: 0.9em;
}
.emphasis{
  color: var(--accent-normal);
}
label.required:after{
  content:" *";
  color: var(--accent-normal);
}
.helptext { /* similat to BS form-text */
  margin-top: .25rem;
  font-size: .875em;
  color: var(--bs-secondary-color);
}
/* Avoid required markers on additional language formsets */
.additional_language label.required:after{
  content:"";
}
.form-check-input:checked{
  background-color: var(--bs-link-color);
  border-color: var(--bs-link-color);
}
/* Screens */
[data-screen="search"] .container-fluid > .row, [data-screen="profile"] .container-fluid > .row, [data-screen="invitations"] .container-fluid > .row, [data-screen="documents"] .container-fluid > .row, [data-screen="reports"] .container-fluid > .row{
  justify-content: center;
}

/* left side menu */
.nav-item .badge{
  background-color: var(--bs-link-color);
  margin-left: 0.25rem;
}
.side-menu .nav-link{
  color: black;
  padding: 0.725rem 1rem;
  border-radius: 0.25rem;
  background: white;
  border-left: 0px solid var(--accent-normal);
  transition: all ease-in 0.25s;
}
.side-menu .nav-link.active{
  background-color: var(--accent-normal);
  font-weight: 700;
  pointer-events: none;
  cursor: default;
}
.side-menu .nav-link:focus{
  color: black;
  background-color: var(--accent-light);
  font-weight: 600;
}
.side-menu li:not(:first-child){
  margin-top: 0.35rem;
}
.separator{
  margin-top: 1.5rem;
  border-bottom: 2px solid var(--bs-btn-hover-bg);
  font-weight: 700;
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
}

/* heros */
.hero{
  background-color: var(--bs-btn-hover-bg);
  background-image: var(--banner-gradient);
  margin-top: var(--top-bar);
  height: auto;
  border-bottom-left-radius: 1rem;
  border-bottom-right-radius: 1rem;
}
.hero:empty{
  background-image: none;
  padding: 0;
}
.hero > div{
  display: flex;
  justify-content: center;
}
.hero .row{
  justify-content: center !important;
  align-items: flex-end !important;
}
.hero div:not(.bottom-anchored){
  margin-top: auto !important;
  margin-bottom: auto !important;
}
.hero-primary, .hero-secondary{
  padding: var(--div-padding);
}
.hero-secondary .row{
  align-items: center !important;
  width: 100%;
}
.hero-secondary .img-fluid{
  max-height: 300px !important;
}
#lead{
  display: flex;
  height: 100%;
}
.lead{
  hyphens: auto;
  font-size: 1.25em;
}

/* screens */
.form-sign{
  background-color: white;
  padding: 2em;
  border-radius: 0.5rem;
}
.panel{
  background: white;
  padding: 2em;
  border-radius: 0.5rem;
}
#profile label{
  font-weight: 700;
}
#user-visibility{
  margin-left: auto;
}
#user-profile-infos label{
  min-width: 6em;
}
label.upload{ 
  position: relative;
}
label.upload input[type=file]{
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
}
.document.waiting {
  color: red !important;
}
.form-check.form-switch{
  margin-bottom: 0;
}
.form-switch:not(.form-check-reverse) input, .form-switch.form-check-reverse input{
  margin-right: .75rem;
  margin-top: 0;
  width: 3rem;
  height: 1.5rem;
}
.form-switch.form-check-reverse input{
  margin-left: .75rem;
  margin-right: 0;
}
.form-switch + a[data-bs-toggle="tooltip"]{
  margin-left: 0.25rem;
}
#tandem-meet .col{
  text-align: center;
  padding: 1.5rem;
  transition: all ease-out 0.3s;
}
#tandem-meet .col img{
  margin-bottom: 1rem;
  max-height: 3em;
}
#tandem-meet .col label{
  font-weight: initial;
}
#lang-level-list{
  padding: 0;
  list-style-type: none;
}
#lang-level-list h6{
  font-weight: 700;
  margin-bottom: 0;
}
#tandem-explanations{
  padding-top: 5rem;
  padding-bottom: 5rem;
  background-color: var(--background-wrapper);
}
#tandem-explanations header{
  display: grid;
  justify-items: center;
  text-align: center;
  padding: 0 3rem;
}
#tandem-explanations header p{
  color: rgb(100,100,100);
}
#tandem-explanations article{
  display: grid;
  justify-items: center;
  margin-top: 2rem;
  border-radius: 1rem;
  background-color: var(--accent-light);
  padding: var(--div-padding);
}
#tandem-method{
  background-image: linear-gradient(to right bottom, rgb(242,135,5), rgb(246,150,2), rgb(249,165,2), rgb(251,180,9), rgb(253,155,20));
}
#tandem-method ul{
  padding-left: 1rem;
}

/* btn */
.btn, .btn input{
  font-weight: 500 !important;
  letter-spacing: 0.05rem;
}
.btn-primary{
  background-color: var(--bs-btn-hover-bg);
  border-color: var(--bs-btn-hover-bg);
}
.btn-hero-primary{
  background-color: white;
  color: var(--primary);
  padding: 0.5em 1.5em;
  border: none;
}
.btn-hero-primary:hover{
  background-color: var(--primary);
  color: white;
}
.btn-hero-secondary{
  border-color: var(--primary);
  color: var(--primary);
}
.btn-cta{
  background-color: var(--primary);
  color: white;
  padding: 0.5em 1.5em;
}
.btn-link, .text-link, .btn-icon{
  color: var(--bs-link-color);
  text-decoration: none;
}
.btn-link{
  padding: .725rem 1rem;
}
.btn-link:hover, .btn-link:focus-visible, .text-link:hover, .text-link:focus-visible{
  text-decoration: underline;
  color: var(--bs-link-color);
  background-color: transparent;
  text-underline-offset: 0.375em;
}
.ui-btn{
  display: inline-flex;
  background-color: white;
  border-radius: 0.5rem;
}
.icon-ui{
  width: 1.25em;
  height: 1.25em;
  margin-right: 0.65em;
}
.icon-ui-md{
  width: 1.5em;
  height: 1.5em;
}
.bottom-anchored{
  margin-bottom: calc(var(--div-padding) * -1);
  text-align: end;
}
.btn-stack{
  display: flex;
  justify-content: flex-start;
  gap: 1rem;
}

/* user profile */
.profile{
  background: white;
  padding: var(--div-padding-md);
  border-radius: 0.25rem;
  margin-top: 1rem;
  position: relative;
}
.profile:not(:first-child){
  margin-top: 2.25rem;
}
.profile:not(:first-child):before{
  content: '•••';
  display: flex;
  position: absolute;
  top: -1.625rem;
  width: 100%;
  left: 0;
  justify-content: center;
  align-items: center;
  font-size: 1.2em;
  line-height: .425em;
  color: darkgray;
  letter-spacing: .25em;
}
.profile .user-avatar{
  text-align: center;
}
.user-avatar img{
  width: 9rem;
  height: 9rem;
  object-fit: cover;
  object-position: center;
  border: 2px solid white;
  border-radius: 50%;
}
#auth-user .user-avatar{
  display: inline;
}
.dropdown .user-avatar img{
  width: 3.5rem;
  height: 3.5rem;
}
.profile .label, #signal-modal label, #short-profile .label, .report .label{
  font-weight: 700;
}
.user-description{
  margin-top: 1.5em;
}
.profile-options, .profile-actions{
  margin-top: 1rem;
  justify-content: end;
  display: flex;
  gap: 1rem;
}
.profile-options p{
  margin-bottom: 0;
}
.profile-actions{
  justify-content: center;
}
.active-tandem, .pending-tandem{
  display: flex;
  align-items: center;
  font-weight: 700;
}
.active-tandem{
  color: var(--bs-success);
}
.pending-tandem{
  color: var(--bs-warning);
}
#avatar-container{
  align-items: center;
}
.inner-panel{
  background: var(--accent-light);
  padding: var(--div-padding-md);
  border-radius: 0.5rem;
}

/* invitations */
#invitationsResults ul{
  padding-left: 0;
}
.invitation, .tandem{
  display: flex;
  align-items: center;
  gap: 2rem;
  border-top: 1px solid var(--bs-gray-300);
  padding-top: .75rem;
}
.invitation .user-pseudo, .tandem .user-pseudo{
  margin-bottom: 0.125rem;
}
.invitation:not(:first-of-type), .tandem:not(:first-of-type){
  margin-top: .75rem;
}
.invitation .user-avatar img, .tandem .user-avatar img{
  width: 3rem;
  height: 3rem;
}
#my-tandems-list .user-avatar img{
  width: 5rem;
  height: 5rem;
}
p.date{
  font-size: 0.8em;
  color: var(--bs-gray-600);
  margin-bottom: 0.5rem;
}
h2.date{
  color: var(--bs-gray-600);
  border-bottom: 1px solid var(--bs-gray-600);
  padding-bottom: 0.5rem;
}
.invitation-options, .tandem-options{
  margin-left: auto;
  align-self: center;
}
#tandem-list > .row{
  justify-content: space-between;
  gap: .5rem;
}

/* search filters */
#search-filters{
  border: 1px solid white;
  background-color: rgba(255,255,255,.5);
  margin-top: 0.5rem;
}
#search-filters form{
  padding: var(--div-padding-sm);
}
#advanced-filters{
  align-self: flex-end;
}
#id_distance{
  border: none;
}
.page-link{
  padding: var(--div-padding-sm);
}
.active > .page-link, .page-link.active{
  background-color: var(--bs-link-color);
  border-color: var(--bs-link-color);
  font-weight: 600;
}
.form-range::-webkit-slider-thumb{
  background-color: var(--bs-btn-hover-bg);
}
.form-range::-moz-range-thumb{
  background-color:var(--bs-btn-hover-bg);
}
/* forms */
.lang-select{
  max-width: 12em;
}
label[for="lang"]{
  font-size: 0.9em;
  margin-bottom: 0.25rem;
}
#search-filters label{
  font-weight: 600;
}
/* helpers */
.rounded{
  --bs-border-radius: 2rem;
}

/*modals*/
.modal{
  backdrop-filter: blur(5px);
}
.modal-header{
  border-bottom: none;
}
.modal-title{
  width: 100%;
  text-align: center;
}
.modal-body, .modal-footer{
  padding: 1em var(--div-padding-md);
}

/* partners logos */
#partners{
  padding: var(--div-padding);
  border-top: 1px solid var(--accent-normal);
  border-bottom: 1px solid var(--secondary);
}
.partners-logo-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12em, 1fr));
  grid-auto-rows: auto;
  grid-gap: 2em;
  margin: 0 auto;
  max-width: 100%;
  justify-items: center;
}
.partner-logo{
  display: flex;
  align-items: center;
}
.partner-logo img, .partner-logo svg{
  max-width: 7em;
  max-height: 3em;
  min-height: 2.5em;
}
.org-symbol{
  display: inline-flex;
  max-height: 1.5rem;
}

/* tables */
table#reports-todo{
  margin-bottom: 0;
}
table#reports-todo td{
  border: 0;
  padding: 0 1rem 1rem 1rem;
}
table#reports-todo td:first-child{
  padding: 1rem 1rem 0 1rem;
  text-align: left;
  min-width: 150px;
  border-top-left-radius: 0.25rem;
  border-top-right-radius: 0.25rem;
}
table#reports-todo td:last-child{
  display: flex;
  border-bottom-left-radius: 0.25rem;
  border-bottom-right-radius: 0.25rem;
}

table#reports-todo td span:not(:first-of-type){
  margin-top: 0.25rem;
}
table#reports-todo tr{
  display: grid;
}
table#reports-todo tr:not(:first-of-type){
  border-top: 1px dotted var(--bs-gray-400);
}
#short-profile .user-avatar img{
  width: 6rem;
  height: 6rem;
}
#archived-reports{
  padding-left: 0;
  margin-bottom: 0
}
#archived-reports li{
  list-style-type: none;
  display: flex;
  align-items: center;
  gap: 2rem;
  border-top: 1px dotted var(--bs-gray-400);
  padding-top: .75rem;
}
.report p:not(.date), .tandem p:not(.date){
  margin-bottom: 0;
}
table thead{
  font-weight: 600;
}
tr.account{
  font-size: 0.9em;
  height: 3rem;
  vertical-align: middle;
}
table#accounts thead a{
  color: var(--bs-link-color);
  text-decoration: none;
  display: flex;
  flex-direction: row;
  align-items: center;
}
table#accounts thead a.asc::after, table#accounts thead a.desc::after{
  content: '';
  display: block;
  width: .75rem;
  height: .75rem;
  margin-left: 0.5rem;
  color: black;
  transform-origin: center;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  transition: all 0.3s ease;
}
table#accounts thead a.asc::after{
  transform: rotate(0deg);
}
table#accounts thead a.desc::after{
  transform: rotate(180deg);
}
footer{
  background-color: rgb(var(--bs-tertiary-bg-rgb));
  padding: var(--div-padding-md);
  font-family: var(--bs-ttl-font-family);
  font-weight: 300;
  border-top: 1px solid var(--accent-normal);
}
footer .footer-nav{
  display: grid;
  column-gap: .75rem;
  grid-template-columns: repeat(4,1fr);
  grid-template-rows: auto;
  justify-items: start;
  row-gap: 2rem
}
footer .footer-nav h1{
  text-transform: uppercase;
  color: var(--bs-gray-600);
  font-size: 0.8em;
}
footer .footer-nav li {
  line-height: 1.25;
}
footer .footer-nav li:not(:first-of-type) {
  margin-top: 0.5rem;
}
ol.letter {
  list-style-type: none;
  padding: 0;
}
[name^="anchor"] {
  scroll-margin-top: calc(var(--top-bar) + 1em);
}
.nav-tabs .nav-link.active{
  border-radius: initial;
  border: initial;
  border-bottom: 2px solid var(--bs-link-color);
}
.accordion {
  --bs-accordion-bg: initial;
  --bs-accordion-border-color: initial;
  --bs-accordion-border-width: initial;
  --bs-accordion-border-radius: initial;
}
.accordion-button:not(.collapsed) {
  color: var(--bs-accordion-active-color);
  background-color: var(--accent-light);
}
.accordion-button:focus {
  box-shadow: initial;
}
/* media queries */
@media only screen and (width <= 576px){
  :root{
    --div-padding: 2em;
    --bottom-bar: 40px;
  }
  .navbar-brand{
    margin-left: .25rem;
  }
  .partner-header img{
    max-width: 6rem;
  }
  .lead{
    hyphens: none;
  }
  .lang-select{
    max-width: none;
  }
  #auth-user .dropdown-menu{
    right: auto;
  }
  .pagination:has(> li:nth-child(12)) > li {
    display: none;
  }
  .pagination:has(> li:nth-child(12)) > li:has(> a.pagination-el-head-0),
  .pagination:has(> li:nth-child(12)) > li:has(> a.pagination-el-tail-0),
  .pagination:has(> li:nth-child(12)) > li:has(> a.pagination-el-prev-1),
  .pagination:has(> li:nth-child(12)) > li:has(> a.pagination-el-next-1),
  .pagination:has(> li:nth-child(12)) > li:has(> span){
    display: block;
  }
  footer a img{
    height: 100%;
    max-height: 2.5em;
  }
  .partners-logo-grid{
    grid-template-columns: repeat(auto-fit, minmax(6em, 1fr));
  }
  .user-avatar img{
    width: 6rem;
    height: 6rem;
  }
  .profile .user-avatar, .profile .user-pseudo, .offcanvas .user-avatar{
    margin: 0 auto;
    text-align: center
  }
  .profile .user-pseudo{
    margin: .5em auto;
  }
  .invitation, .tandem{
    gap: 1rem;
  }
  .invitation .user-pseudo, .tandem .user-pseudo{
    text-align: left;
  }
  footer .footer-nav{
    grid-template-columns: repeat(1,1fr) !important;
    row-gap: 1rem;
  }
}
@media only screen and (width <= 1024px){
  :root{
    --top-bar: 5rem;
  }
  h1, h2, h3, h4{
    text-align: center;
  }
  #impressum h1, h2, h3, .footer-nav h1 {
    text-align: initial;
  }
  #avatar-container{
    text-align: center;
  }
  .profile-options, .invitation-options, .tandem-options{
    display: grid;
    gap: 0 .5rem;
	  width: fit-content;
	  margin: var(--div-padding-sm) auto 0;
  }
  .invitation-options, .tandem-options{
	  margin: 0;
  }
  .offcanvas .user-avatar{
    margin: 0 auto;
    text-align: center
  }
  .offcanvas .user-avatar img{
    width: 5rem;
    height: 5rem;
  }
  .offcanvas-body{
    padding: 0;
    background: var(--bs-gray-300);
  }
  .offcanvas .nav{
    padding-left: var(--div-padding-md);
    margin-bottom: auto !important;
    flex-direction: column !important;
  }
  .offcanvas .nav-link{
    display: flex;
    align-items: center;
    background: none;
    padding: var(--bs-nav-link-padding-y) var(--div-padding-md);
    border-radius: 0;
    color: black;
    width: 100%;
  }
  .offcanvas .nav-link.active{
    background-color: rgba(255,255,255,.5);
    font-weight: 700;
    pointer-events: none;
    cursor: default;
    border-top-left-radius: 2rem;
    border-bottom-left-radius: 2rem;
  }
  .offcanvas .nav-link:focus{
    color: white;
    background-color: rgb(253, 195, 20);
    font-weight: 600;
  }
  .offcanvas li:not(:first-child){
    margin-top: initial;
  }
  .offcanvas .user-pseudo{
    font-weight: 700;
    margin-bottom: 1.5rem;
    text-align: center;
    max-width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  #side-lang{
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: var(--div-padding);
  }
  #auth-user{
    display: flex;
    justify-content: center;
    padding-left: 1em;
    margin-top: var(--div-padding-md);
  }
  .separator.menu-admin{
    margin-top: .5rem;
    padding-left: 2rem;
    padding-bottom: 0;
  }
  .separator.menu-admin > .btn-link{
    padding: .725rem 1rem .725rem 0;
  }
  #user-languages .btn-cta {
    margin: 0 auto;
    display: flex;
    line-height: 1.25em;
    letter-spacing: 0.025em;
  }
  .invitation-options button span, .tandem-options button span{
    display: none;
  }
  .invitation-options button .icon-ui, .tandem-options button .icon-ui{
    margin: 0;
  }
  table#reports-todo td, table#reports-todo td:first-child{
    display: inline-grid;
    width: 100%;
    padding: 0;
  }
  table#reports-todo tr:first-of-type{
    margin-bottom: 1rem;
  }
  table#reports-todo tr:not(:first-of-type){
    padding-top: 1rem;
  }
  table#reports-todo td:last-child{
   min-width: unset;
   max-width: unset;
  }
  .modal .user-avatar{
    margin: 0 auto;
  }
  footer .footer-nav{
    grid-template-columns: repeat(3,1fr);
  }
}
@media only screen and (576px <= width <= 992px){
  table#reports-todo td, table#reports-todo td:first-child{
    display: inline-grid;
    width: 100%;
    padding: 0;
  }
  table#reports-todo tr:first-of-type{
    margin-bottom: 1rem;
  }
  table#reports-todo tr:not(:first-of-type){
    padding-top: 1rem;
  }
  table#reports-todo td:last-child{
   min-width: unset;
   max-width: unset;
  }
  .modal .user-avatar{
    margin: 0 auto;
  }
}
@media only screen and (any-hover: hover){
  .btn-cta:hover{
    background-color: var(--accent-normal);
    color: black;
    border: 1px solid white;
  }
  .btn-hero-primary:hover{
    background-color: var(--primary);
    color: white;
  }
  .btn-link:hover, .text-link:hover{
    text-decoration: underline;
    color: var(--bs-link-color);
    background-color: transparent;
    text-underline-offset: 0.375em;
  }
  .btn-icon:hover{
    border: 1px solid var(--bs-link-color);
    color: var(--bs-link-color);
    background-color: transparent;
  }
  #tandem-meet .col:hover{
    background-color: var(--accent-light);
    border-radius: 0.5rem;
    transition: all ease-out 0.3s;
  }
  #tandem-meet .col:hover .form-check-input{
    --bs-border-color: var(--primary);
  }
  .side-menu .nav-link:not(.active):hover{
    color: black;
    border-left: 6px solid var(--accent-normal);
    transition: all ease-in 0.25s;
  }
}
