@charset "UTF-8";
@font-face {
  font-family: MonaSans;
  src: url(/2024/static/fonts/MonaSans[slnt,wdth,wght].woff2); }

html {
  color: #1b0e29;
  font-family: MonaSans;
  font-size: 1.1em;
  letter-spacing: .03em;
  line-height: 1.5; }

body {
  display: flex;
  flex-direction: column;
  margin: 0;
  min-height: 100vh; }

h1 {
  color: #1b0e29;
  font-size: 3em;
  font-variation-settings: "wdth" 75;
  font-weight: 750;
  line-height: 1;
  margin: 0;
  text-transform: uppercase; }

h2 {
  color: #1b0e29;
  font-size: 3em;
  font-variation-settings: "wdth" 75;
  font-weight: 750;
  margin: 1em auto 0 auto;
  text-align: center;
  text-transform: uppercase; }

h3 {
  font-size: 2em;
  font-weight: 600;
  line-height: 1;
  margin: 1em auto; }

h4 {
  color: #1b0e29; }

a {
  color: #1b0e29;
  font-variation-settings: "wdth" 95;
  font-weight: 600;
  text-decoration: underline #cc0018; }
  a:hover, a:focus {
    text-decoration: underline #cc0018; }

address {
  font-style: normal;
  white-space: pre-line; }

ul {
  padding: 0; }
  ul ul {
    padding-left: 2em; }
  ul li::marker {
    color: #ff213b; }

embed {
  display: block;
  float: left;
  margin: 0 1em 2em 0;
  width: 50%; }

embed + p {
  margin-top: 2em; }

img {
  max-width: 100%; }

strong {
  font-variation-settings: "wdth" 95;
  font-weight: 600; }

sup {
  line-height: 1;
  text-transform: initial;
  vertical-align: 35%; }

*:target::before {
  content: "";
  display: block;
  height: 10rem;
  margin-top: -10rem; }

.button {
  background-color: #ff213b;
  border: 2px solid #ff213b;
  border-radius: 6px;
  color: white;
  display: inline-block;
  font-weight: 600;
  letter-spacing: 0.01em;
  margin: 1rem 0;
  max-width: max-content;
  padding: 1rem;
  text-transform: uppercase;
  transition: background-color 0.5s, border-color 0.5s;
  text-decoration: none; }
  .button:hover, .button:focus {
    background-color: #cc0018;
    border-color: #cc0018;
    text-decoration: inherit; }

.important {
  color: #ff213b;
  font-weight: 600; }

.brochures {
  display: flex;
  justify-content: space-evenly;
  list-style: none; }

.avatar {
  border-radius: 100%;
  box-shadow: 0 0 0.2em #dddd;
  height: 3em;
  margin-right: 0.2em;
  object-fit: cover;
  vertical-align: middle;
  width: 3em; }

nav {
  background: 2rem center no-repeat #1b0e29;
  color: white;
  display: flex;
  font-size: 0.9rem;
  padding: 0 2rem 0 20rem;
  position: sticky;
  top: 0;
  z-index: 2; }
  nav ul {
    align-items: center;
    display: flex;
    list-style: none; }
  nav li {
    border-bottom: 1px solid transparent;
    padding-bottom: 0.3em; }
  nav li:has(a:hover) {
    border-bottom-color: #cc0018; }
  nav li.active {
    border-bottom-color: #ff213b;
    font-weight: 600; }
    nav li.active a:hover {
      text-decoration: none; }
  nav a {
    color: inherit;
    font-weight: inherit;
    text-decoration: none; }
    nav a:hover {
      text-decoration: none; }
  nav ul#pages, nav ul#categories {
    flex-wrap: wrap;
    gap: 0 1em;
    justify-content: center;
    margin: auto; }
  nav ul#pages li:first-child a:before {
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 16rem; }
  nav ul#categories {
    font-size: 0.8em; }
  nav ul#languages {
    justify-content: space-evenly;
    width: 10rem; }
    nav ul#languages li {
      opacity: 0.5; }
    nav ul#languages li.active {
      border: none;
      opacity: 1; }
    nav ul#languages li a::before {
      background: 10% center / 1em no-repeat;
      content: '';
      display: inline-block;
      height: 0.75em;
      width: 1em; }
    nav ul#languages li#french a::before {
      background-image: url(/2024/static/images/france.svg); }
    nav ul#languages li#english a::before {
      background-image: url(/2024/static/images/united-kingdom.svg); }
  nav > a {
    align-self: center;
    box-sizing: border-box;
    display: block;
    max-width: none !important;
    text-align: center;
    width: 8rem; }
  nav:has(#pages) {
    background-image: url(/2024/static/images/logo-simple-semi-couleurs.svg);
    height: 6rem;
    padding: 0 2rem 0 20rem;
    top: 0; }
  nav:has(#categories) {
    padding: 0.5rem 2rem;
    top: 6rem; }

footer {
  background: url(/2024/static/images/logo-simple-couleurs.svg) 10% center/10rem no-repeat;
  border-top: 1px solid #eff1f3;
  font-size: 0.9rem;
  margin-top: 2em; }
  footer ul {
    align-items: center;
    display: flex;
    justify-content: space-between;
    list-style: none;
    margin: 2em auto;
    width: 40%; }
    footer ul a {
      font-weight: inherit;
      text-decoration: none; }

#index .pycon-logo {
  display: block;
  margin: 1em auto;
  width: 20%; }

#index .coverboard {
  align-items: center;
  background: url(/2024/static/images/strasbourg-small.jpg) center/cover no-repeat;
  display: flex;
  flex-direction: column;
  height: auto;
  overflow: hidden;
  padding: 3em 0; }

#index .pycon-presentation {
  background: white;
  border-radius: 1em;
  margin: auto auto auto 10%;
  padding: 2em;
  position: relative;
  width: 26%; }
  #index .pycon-presentation aside {
    background: #ff213b;
    border-radius: 50%;
    color: white;
    font-size: 0.8em;
    font-variation-settings: "wdth" 75;
    font-weight: 750;
    height: 6em;
    line-height: 0;
    padding: 0.2em 0 0.2em 0.2em;
    position: absolute;
    right: -2rem;
    top: -2rem;
    text-align: center;
    text-transform: uppercase;
    width: 6em; }
    #index .pycon-presentation aside sup {
      font-size: 1.1em;
      line-height: 1.5;
      text-transform: initial;
      vertical-align: 95%; }
    #index .pycon-presentation aside span {
      font-size: 3em;
      line-height: 1.5; }
  #index .pycon-presentation ul {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    gap: 1em;
    margin: 0; }
    #index .pycon-presentation ul .button {
      margin: 0; }
    #index .pycon-presentation ul .schedule {
      background: white;
      color: #ff213b;
      transition: background-color 0.5s; }
      #index .pycon-presentation ul .schedule:hover, #index .pycon-presentation ul .schedule:focus {
        background-color: #ffedef; }

#index .pycon-date {
  color: #ff213b;
  font-size: 1.2em;
  font-weight: 600; }

#index .details {
  display: block;
  margin: auto; }

#index .place {
  margin: 4em auto; }
  #index .place h2 {
    margin: 0 auto 0.5em auto;
    text-align: left; }
  #index .place > section {
    display: flex;
    gap: 2em;
    justify-content: space-between;
    margin: auto; }
    #index .place > section section {
      max-width: 40em; }
  #index .place iframe {
    border-radius: 10px;
    height: 30em;
    margin: -5em 0 0 0; }
  #index .place iframe + a {
    display: none; }

#index .afpy {
  background: #1b0e29;
  color: white;
  display: flex;
  justify-content: center;
  gap: 1em;
  padding: 3em 0; }
  #index .afpy h3 {
    line-height: 1.2; }
  #index .afpy section:first-of-type {
    margin: 0;
    max-width: 25em; }
    #index .afpy section:first-of-type h2 {
      color: inherit;
      line-height: 1;
      margin-top: 0.5em;
      text-align: left; }
  #index .afpy section:last-of-type {
    margin: 0;
    max-width: 30em; }

#index .become-sponsor aside {
  color: #ff213b;
  font-weight: 600;
  margin-top: 3em;
  text-align: center;
  text-transform: uppercase; }

#index .become-sponsor h2 {
  margin-top: 0; }

#index .become-sponsor p {
  margin: auto;
  max-width: 30em;
  text-align: center; }

#index .become-sponsor .contact-sponsor {
  background: #eff1f3;
  border-radius: 10px;
  margin: 3em auto;
  min-width: min-content;
  padding: 2em 6em;
  width: 30%; }
  #index .become-sponsor .contact-sponsor p {
    width: initial; }
  #index .become-sponsor .contact-sponsor a {
    color: #ff213b;
    font-size: 3em;
    font-weight: 600;
    transition: color 0.5s; }
    #index .become-sponsor .contact-sponsor a:hover {
      color: #cc0018; }

#index .become-sponsor .sponsors {
  margin: auto; }
  #index .become-sponsor .sponsors a {
    margin: initial; }

main {
  flex: 1; }
  main article > * {
    margin-left: auto;
    margin-right: auto;
    max-width: 70rem;
    padding: 0 2rem; }
    main article > * table {
      border-collapse: collapse;
      margin: 2em auto;
      width: 60rem; }
      main article > * table th {
        font-weight: normal; }
      main article > * table td {
        border: 1px solid #1b0e29;
        padding: 0.25em; }
        main article > * table td:not(:first-child) {
          text-align: center;
          width: 15%; }
    main article > * iframe {
      border: 0;
      height: 25rem;
      margin: 1em 0;
      max-width: 100%;
      overflow: hidden;
      padding: 0;
      width: 100%; }
  main .sponsors img {
    display: inline-block;
    line-height: 120px;
    height: 100px;
    margin: 1rem;
    object-fit: contain;
    vertical-align: middle;
    width: 200px; }

#sponsors h2 + p {
  text-align: center; }

#sponsors .sponsor {
  max-width: 32em; }
  #sponsors .sponsor > a {
    display: block;
    text-align: center; }
  #sponsors .sponsor .description {
    padding: 1.5rem;
    border-right: 5px solid #1b0e29;
    border-left: 5px solid #ff213b; }

#talks section, #speakers section {
  margin: 5em auto;
  padding-bottom: 1.2em;
  padding-top: 0.1em; }
  #talks section:nth-child(even), #speakers section:nth-child(even) {
    background: #F9F9F9; }

#index .event-description, #schedule .event-description {
  display: flex;
  justify-content: center;
  margin: 4em auto;
  gap: 2em; }
  #index .event-description section, #schedule .event-description section {
    background: #eff1f3;
    border-radius: 10px;
    flex: 1;
    padding: 2em; }
    #index .event-description section h3, #schedule .event-description section h3 {
      margin: 0 auto 1em auto; }
    #index .event-description section aside, #schedule .event-description section aside {
      color: #ff213b;
      font-weight: 600;
      margin-bottom: 1em;
      text-transform: uppercase; }
    #index .event-description section ul, #schedule .event-description section ul {
      list-style: inside; }
    #index .event-description section p:last-of-type, #schedule .event-description section p:last-of-type {
      margin-bottom: 0; }

#schedule article > p:first-of-type, #schedule article > p:nth-of-type(2) {
  text-align: center; }

#schedule .event-description section {
  position: relative; }

#schedule .keynotes .speakers {
  display: flex;
  justify-content: space-between; }
  #schedule .keynotes .speakers a {
    text-decoration: none; }
  #schedule .keynotes .speakers dl {
    background: #eff1f3;
    border-radius: 1em;
    width: 31%; }
    #schedule .keynotes .speakers dl dd {
      margin: 1rem 2rem 1rem 2.5rem; }
    #schedule .keynotes .speakers dl .speaker {
      font-size: 1.2em;
      font-weight: 600;
      margin-bottom: 0; }
    #schedule .keynotes .speakers dl .title {
      margin-top: 0.3rem; }
    #schedule .keynotes .speakers dl .talk {
      margin: 1.5rem 2rem 1rem 3.5rem;
      position: relative; }
      #schedule .keynotes .speakers dl .talk::before {
        color: #ff213b;
        content: "\”";
        font-size: 9rem;
        line-height: 1;
        opacity: 0.3;
        position: absolute;
        transform: translate(-3rem, -1.5rem); }
      #schedule .keynotes .speakers dl .talk a {
        font-weight: normal; }
    #schedule .keynotes .speakers dl img {
      border-radius: 1em 1em 0 0;
      display: block;
      width: 100%; }

#schedule iframe {
  border-radius: 10px;
  height: 30em; }

#full-schedule {
  background: #eff1f3;
  min-width: 65em;
  padding: 0.25em; }
  #full-schedule table {
    border-spacing: 0.5rem;
    table-layout: fixed;
    width: 100%; }
    #full-schedule table a {
      font-variation-settings: "wdth" 100;
      font-weight: normal;
      text-decoration: none; }
  #full-schedule thead {
    height: 2em;
    position: sticky;
    top: 0.5rem;
    z-index: 1; }
    #full-schedule thead.rooms th {
      color: white; }
    #full-schedule thead.rooms tr > :first-child::before {
      background: #1b0e29;
      box-shadow: 0 0.75em 1em #1b0e29;
      content: "";
      height: 5em;
      left: 0;
      position: absolute;
      right: 0;
      outline: 1em solid #1b0e29;
      top: -1rem;
      z-index: -1; }
    #full-schedule thead.day {
      top: 3rem;
      z-index: 2; }
      #full-schedule thead.day th {
        background-clip: content-box;
        background-color: #1b0e29;
        color: white;
        padding-bottom: 2rem; }
  #full-schedule tr:not(:last-child) {
    height: 8rem; }
  #full-schedule td {
    background: white;
    border-left: 0.5em solid;
    border-radius: 0 0.3em 0.3em 0;
    box-shadow: 0 0 0.1em #ddd, 0 0 1em #ddd8;
    font-size: 0.75em;
    line-height: 1.3;
    padding: 0.5rem 0.5rem 3.5em 0.5rem;
    position: relative; }
    #full-schedule td:empty {
      background: none;
      border: none;
      box-shadow: none; }
  #full-schedule th {
    font-weight: 600; }
  #full-schedule tbody th {
    font-weight: 400;
    position: relative;
    transform: translatey(-52%);
    z-index: 0; }
  #full-schedule tr > *:first-child {
    width: 4.5em; }
  #full-schedule aside.type {
    bottom: 0.5em;
    font-size: 0.7em;
    font-variation-settings: "wdth" 90;
    left: 0.5em;
    position: absolute; }
    #full-schedule aside.type::before {
      border-radius: 0.2em;
      box-shadow: 0 0 0.2em #ddd;
      content: "";
      display: inline-block;
      height: 1em;
      margin-right: 0.4em;
      vertical-align: -10%;
      width: 1em; }
  #full-schedule aside.speakers {
    font-size: 0.8em;
    line-height: 1.1;
    margin-top: 0.5em; }
  #full-schedule .short-plenary {
    border-left-color: maroon; }
    #full-schedule .short-plenary .type::before {
      background: maroon; }
  #full-schedule .plenary {
    border-left-color: blue; }
    #full-schedule .plenary .type::before {
      background: blue; }
  #full-schedule .workshop {
    border-left-color: turquoise; }
    #full-schedule .workshop .type::before {
      background: turquoise; }
  #full-schedule .short-talk {
    border-left-color: orange; }
    #full-schedule .short-talk .type::before {
      background: orange; }
  #full-schedule .long-talk {
    border-left-color: red; }
    #full-schedule .long-talk .type::before {
      background: red; }
  #full-schedule .general-assembly {
    border-left-color: maroon; }
    #full-schedule .general-assembly .type::before {
      background: maroon; }
  #full-schedule .lightning-talk {
    border-left-color: pink; }
    #full-schedule .lightning-talk .type::before {
      background: pink; }
  #full-schedule .lunch {
    border-left-color: purple; }
    #full-schedule .lunch .type::before {
      background: purple; }
  #full-schedule .extra {
    border: none;
    padding: 0;
    vertical-align: top; }
    #full-schedule .extra div {
      align-items: center;
      background: center / cover;
      border-radius: 0.1em;
      color: white;
      display: flex;
      font-size: 2em;
      font-weight: 600;
      justify-content: center;
      position: absolute;
      text-shadow: 0 0 0.15em #1b0e29; }
  #full-schedule #saturday-breakfast div,
  #full-schedule #sunday-breakfast div {
    background-image: url(/2024/static/images/breakfast.webp);
    height: 8rem;
    width: calc(400% + 0.9 * 3 * 0.5rem); }
  #full-schedule #saturday-lunch div {
    background-image: url(/2024/static/images/lunch.webp);
    height: calc(2 * 8rem + 0.9 * 0.5rem);
    width: calc(400% + 0.9 * 3 * 0.5rem); }
  #full-schedule #saturday-snack div {
    background-image: url(/2024/static/images/snack.webp);
    height: 8rem;
    width: calc(400% + 0.9 * 3 * 0.5rem); }
  #full-schedule #sunday-lunch div {
    background-image: url(/2024/static/images/lunch.webp);
    height: calc(3 * 8rem + 0.9 * 2 * 0.5rem);
    width: calc(400% + 0.9 * 3 * 0.5rem); }

#news section:not(:last-of-type) {
  border-bottom: 1px solid #1b0e29;
  padding-bottom: 1em; }

@media (max-width: 1000px) {
  html {
    font-size: 1em; }
  h3 {
    font-size: 1.4em; }
  #index .logo {
    max-width: 30em;
    width: 80%; }
  #index .pycon-presentation {
    margin: auto;
    width: 65%; }
    #index .pycon-presentation a {
      margin: 0 auto; }
  #index .place > section {
    flex-direction: column; }
    #index .place > section iframe {
      margin-top: 0; }
  #index .afpy {
    flex-direction: column; }
    #index .afpy section:first-child,
    #index .afpy section:last-child {
      max-width: none; }
  #index .become-sponsor .contact-sponsor a {
    font-size: 1.2em; }
  #index .event-description, #schedule .event-description {
    flex-direction: column;
    gap: 2em; }
    #index .event-description section, #schedule .event-description section {
      padding: 1em; }
  #schedule .event-description .button {
    left: 1em; }
  #schedule .keynotes .speakers {
    flex-direction: column;
    gap: 1em; }
    #schedule .keynotes .speakers dl {
      width: auto; }
  nav {
    align-items: flex-start;
    flex-direction: row-reverse;
    flex-wrap: wrap; }
    nav:has(#pages) {
      background-image: none;
      height: auto;
      min-height: 6rem;
      padding-left: 2rem; }
    nav ul#pages {
      flex-direction: column;
      gap: 2em;
      justify-content: center;
      height: 0;
      margin: 0 auto 0 0;
      order: 10;
      overflow: hidden;
      width: 100%; }
      nav ul#pages:hover {
        height: 100vh; }
      nav ul#pages:before {
        content: '☰';
        font-size: 3rem;
        line-height: 1.2;
        position: absolute;
        right: 1.5rem;
        top: 0.5rem; }
      nav ul#pages:hover:before {
        content: "⨯"; }
    nav:after {
      content: " ";
      height: 4rem;
      position: absolute;
      right: 1.5rem;
      top: 0.5rem;
      width: 4rem;
      z-index: -1; }
    nav:has(ul:hover):after {
      transition: z-index 1s;
      z-index: 1; }
    nav li:first-child a:before {
      display: none; }
    nav ul#languages {
      height: 4rem;
      margin-right: auto;
      width: 7rem; }
  footer {
    background-position: center 40px; }
    footer ul {
      flex-direction: column;
      margin-top: 100px; }
  aside ul {
    flex-direction: column; }
  main article table {
    font-size: 0.9em;
    width: auto; }
  embed {
    float: none;
    margin: 0;
    width: 100%; } }

/*# sourceMappingURL=style.css.map */