:root {
  --color-main: #ffff56;
  --font-body-large: 32pt; /** 60 */
  --font-body-big: 30pt; /** 40 */
  --font-body-chunky: 26pt;
  --font-body-medium: 20pt;
  --font-body-small: 12pt; /** 30 */
  --font-48: 38pt;
  --font-32: 2.22vw;
  --font-27: 1.88vw;
  --font-20: 1.39vw;
  --font-14: 0.97vw;
  --font-12: 0.83vw;

  --font-body-large-mobile: 6.17vw;
  --font-body-big-mobile: 6vw;

  --top-height: 60px;
  --body-border: 0.15vw;
}

@media (max-width: 1200px) {
  :root {
    --color-main: #ffff56;
    --font-body-large: 32pt; /** 60 */
    --font-body-big: 28pt; /** 40 */
    --font-body-chunky: 24pt;
    --font-body-medium: 16pt;
    --font-body-small: 12pt; /** 30 */
    --font-48: 38pt;
    --font-32: 2.22vw;
    --font-27: 1.88vw;
    --font-20: 1.39vw;
    --font-14: 0.97vw;
    --font-12: 0.83vw;

    --font-body-large-mobile: 6.17vw;
    --font-body-big-mobile: 6vw;

    --top-height: 60px;
    --body-border: 0.15vw;
  }
}

@media only screen and (orientation: portrait) {
  :root {
    --color-main: #ffff56;
    --font-body-large: 20pt; /** 60 */
    --font-body-big: 18pt; /** 40 */
    --font-body-chunky: 16pt;
    --font-body-medium: 12pt;
    --font-body-small: 10pt; /** 30 */
    --font-48: 38pt;
    --font-32: 2.22vw;
    --font-27: 1.88vw;
    --font-20: 1.39vw;
    --font-14: 0.97vw;
    --font-12: 0.83vw;

    --font-body-large-mobile: 6.17vw;
    --font-body-big-mobile: 6vw;

    --top-height: 60px;
    --body-border: 0.5vw;
  }
  .h_spacer {
    display: none;
  }
  * {
    transition: 0.3s;
  }
}

@font-face {
  font-family: "Suisse int";
  src: url("./fonts/SuisseIntl-Medium-WebM.woff2");
}

@font-face {
  font-family: "Suisse light";
  src: url("./fonts/SuisseIntl-Light-WebM.woff2");
}

@font-face {
  font-family: "Suisse regular italic";
  src: url("./fonts/SuisseIntl-RegularItalic-WebM.woff2");
}

@font-face {
  font-family: "Suisse regular";
  src: url("./fonts/SuisseIntl-Regular-WebM.woff2");
}

@font-face {
  font-family: "Steinbeck";
  src: url("./fonts/SteinbeckRegular1.10.woff");
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  transition: 0.1s;
}

html,
body {
  margin: 0;
  padding: 0;
  color: black;
  cursor: url("img/cursor.png"), auto;
  font-family: "Suisse regular", sans-serif;
  font-weight: 400;
  background-color: var(--color-main);
  font-size: var(--font-body-small);
}

body {
  width: 100%;
  overflow-x: hidden;
}

a,
a:hover {
  text-decoration: none;
  color: inherit;
}

.h_spacer,
.h_spacer_m {
  flex-grow: 1;
}

.link {
  cursor: pointer;
}

/** Top and menu */
#top {
  font-size: var(--font-body-small);
  position: sticky;
  top: 0px;
  display: flex;
  justify-content: space-between;
  height: var(--top-height);
  padding: 12px 0 0 17px;
  background-color: var(--color-main);
  z-index: 10;
  width: 100%;
}
#top_logo {
  height: 38px;
  width: 108px;
}
#top_logo img {
  height: 38px;
  width: 108px;
}
#top_menu_ico {
  width: 63px;
  margin-top: -10px;
  margin-right: 5px;
}
#top_menu_ico img {
  height: 100%;
}
#menu {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 12;
  display: none;
  flex-direction: column;
  gap: 2px;
  width: 6em;
  font-family: "Steinbeck", sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  font-size: var(--font-body-large);
  background-image: url("img/menu_bg.jpg");
  background-size: cover;
  height: 100svh;
  line-height: 1em;
}

#menu a {
  color: white;
}

#menu_top {
  display: flex;
  margin: calc(var(--body-border) * 2);
}

#menu_top_lng,
#menu_top_close {
  border-radius: 50%;
  background-color: black;
  color: white;
  width: 4.5vw;
  height: 4.5vw;
  min-width: 42px;
  min-height: 42px;
  display: grid;
  place-items: center;
  font-size: max(var(--font-body-medium), 24px);
  margin-top: 0;
}
#menu_top_close img {
  height: max(5.5vw, 30px);
  position: relative;
  left: -5px;
  bottom: 7px;
}

#menu_social {
  display: flex;
  margin-top: calc(var(--body-border) * 2);
  gap: 6px;
  margin-left: 0.3rem;
}

#menu_top_text {
  color: white;
  letter-spacing: -0.05em;
  -webkit-text-stroke: 1px black;
}

#menu_top_text > p {
  margin: 0.3rem;
}

#menu_bottom {
  display: flex;
  width: 27svw;
  flex-direction: column;
  flex-grow: 1;
  background-repeat: no-repeat;
  background-size: 100% 50vw;
  background-position: bottom center;
}

.menu_item {
  background-color: black;
  color: white;
  padding: 0.2rem 0.2rem;
  margin: 0 0.3rem;
}
.menu_item:hover,
.menu_item_selected {
  background-color: white !important;
}
.menu_item:hover a,
.menu_item_selected a {
  color: black !important;
  font-style: italic !important;
}

.social_ico {
  border-radius: 50%;
  background-color: black;
  color: white;
  width: 4.5vw;
  height: 4.5vw;
  display: grid;
  place-items: center;
  font-size: 0.9rem;
}
.social_ico a {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}

@media (min-aspect-ratio: 16/11) {
  #menu {
    padding: 0;
    gap: 2px;
    width: 39vh;
    height: 100svh;
    line-height: 1em;
    font-size: 6vh;
  }

  #menu_top {
    display: flex;
    margin: calc(var(--body-border) * 2) 1vh;
  }

  #menu_top_lng,
  #menu_top_close {
    border-radius: 50%;
    background-color: black;
    color: white;
    width: 6.66vh;
    height: 6.66vh;
    display: grid;
    place-items: center;
    min-width: 42px;
    min-height: 42px;
    font-size: max(3vh, 20px);
  }
  #menu_top_close img {
    height: max(7vh, 38px);
    left: 0px;
    bottom: 3px;
  }

  #menu_social {
    display: flex;
    gap: 6px;
    margin: calc(var(--body-border) * 2) 1vh;
  }

  #menu_top_text > p {
    margin: 1vh;
  }

  #menu_bottom {
    display: flex;
    width: 100%;
    flex-direction: column;
    flex-grow: 1;
    background-repeat: no-repeat;
    background-size: 100% 180%;
    background-position: 25% 80%;
  }

  .menu_item {
    background-color: black;
    color: white;
    padding: 0.6vh;
    margin: 0 1vh;
  }

  .social_ico {
    border-radius: 50%;
    background-color: black;
    color: white;
    width: 6.66vh;
    height: 6.66vh;
    display: grid;
    place-items: center;
    font-size: 3vh;
  }
}
@media only screen and (orientation: portrait) {
  #menu {
    padding: 0;
    gap: 2px;
    width: 100%;
    height: 100%;
    line-height: 1em;
    font-size: calc(var(--font-body-large) * 2);
    container-name: menu;
    overflow: hidden;
  }

  #menu_top {
    display: flex;
    margin: calc(var(--body-border) * 2);
  }

  #menu_top_lng,
  #menu_top_close {
    border-radius: 50%;
    background-color: black;
    color: white;
    width: 56px;
    height: 56px;
    display: grid;
    place-items: center;
    font-size: var(--font-body-big);
  }
  #menu_top_close img {
    height: 50pt;
  }

  #menu_social {
    display: flex;
    gap: 6px;
    margin: calc(var(--body-border) * 2) 1vh;
  }

  #menu_top_text > p {
    margin: 1vh;
  }

  #menu_bottom {
    display: flex;
    width: 100%;
    flex-direction: column;
    flex-grow: 1;
    background-repeat: no-repeat;
    background-size: 100% 180%;
    background-position: 25% 80%;
    font-size: calc(var(--font-body-large) * 2.2);
    letter-spacing: -0.05em;
    line-height: 0.8em;
  }

  .menu_item {
    background-color: black;
    color: white;
    padding: 0.1em 0.2em 0.04em;
    margin: 0 1vh;
  }

  .social_ico {
    border-radius: 50%;
    background-color: black;
    color: white;
    width: 6.66vh;
    height: 6.66vh;
    display: grid;
    place-items: center;
    font-size: 3vh;
  }
}

/*** body ***/
#page_container {
  display: flex;
  flex-direction: column;
  min-height: 100svh;
  background-attachment: fixed;
}
.body_container {
  display: flex;
  flex-direction: column;
  align-items: center;
  background-attachment: fixed;
  flex-grow: 1;
  width: 100%;
}

#home {
  width: 100%;
  background-position: 100px 50px;
  flex-grow: 1;
  display: grid;
  place-items: center;
}
#home_bg {
  width: 100%;
  min-height: calc(100vh - var(--top-height));
  background-image: url("img/Home1.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

#theme {
  font-family: "Suisse int", sans-serif;
  color: black;
  font-size: var(--font-body-big);
  letter-spacing: -0.02em;
  line-height: 1.2em;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  width: 66vw;
  align-items: flex-start;
}
#theme_container {
  background-image: url("img/theme_bg.png");
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: top 200px right 50%;
}
#theme_title {
  width: 100%;
  font-size: var(--font-body-large);
  padding: 0.57vw 3.5vw 0.33vw;
  line-height: 1em;
}

#theme_body {
  width: 100%;
  margin: 0 0;
  margin-bottom: 1svw;
  padding: 2.5vw 3.5vw;
  flex-grow: 1;
  background-color: initial;
}
#theme p,
.about-body p {
  margin-bottom: 1em;
}

/** ABOUT */
#about_container {
  background-image: url("img/about_bg.png");
  background-size: cover;
  background-position: top center;
}
#about {
  color: white;
  width: 66vw;
  font-size: var(--font-body-big);
  flex-grow: 1;
}
.about_link,
.about_link_selected {
  align-items: stretch;
  flex-grow: 1;
  display: grid;
  place-items: center;
  padding: 10px 20px 7px;
}
.about_link,
.about_link a {
  color: white;
  background-color: black;
}
.about_link_selected,
.about_link_selected a,
.about_link:hover,
.about_link:hover a {
  color: black;
  background-color: white;
}

#about_menu {
  width: 100%;
  border-bottom: var(--body-border) solid var(--color-main);
  background-color: var(--color-main);
  font-size: var(--font-body-large);
  position: sticky;
  top: var(--top-height);
  line-height: 1em;
  display: flex;
  justify-content: space-between;
  gap: var(--body-border);
  font-size: var(--font-body-large);
  font-family: Steinbeck, sans-serif;
  letter-spacing: -0.1vw;
}

.about-body {
  margin-top: 0px;
  background-color: black;
  padding: 2.5vw 3.5vw;
  overflow-x: hidden;
  width: 66vw;
}
.about-body * {
  max-width: 100%;
}
.about-title {
  margin: auto;
  background-color: black;
  padding: 0 1vw;
  margin-bottom: var(--body-border);
  font-family: Steinbeck, sans-serif;
  font-size: var(--font-body-large);
  width: 66vw;
}
.about-logos-container {
  margin: auto;
  display: flex;
  gap: var(--body-border);
  flex-wrap: wrap;
  width: 66vw;
  margin-bottom: var(--body-border);
}
.about-logo {
  background-color: black;
  width: 10.875vw;
  height: 10.875vw;
  display: grid;
  place-items: center;
}

#about-team {
  display: flex;
  width: 100%;
  gap: 1em;
}
#team-col1,
#team-col2 {
  width: 50%;
}

#team-col1,
#team-col2 {
  width: 100%;
}
.team-member {
  margin-bottom: 1em;
}
.team-pos {
  font-weight: 500;
  font-family: "Suisse int", sans-serif;
}
.team-name {
  font-weight: 400;
  font-family: "Suisse regular", sans-serif;
}
/** PROGRAM */
#program_container {
  background-image: url("img/program_bg1.png"), url("img/program_bg2.png"),
    url("img/program_bg3.png");
  background-position: top left, center, right center;
  background-size: contain, cover, 50vw 80vh;
  background-repeat: no-repeat;
  background-attachment: scroll;
}
#program {
  color: white;
  font-family: Steinbeck, sans-serif;
  flex-grow: 1;
  margin: auto;
  width: 66vw;
  display: flex;
  flex-flow: column;
  align-items: flex-start;
  padding-bottom: 5em;
}
#program_head_container {
  width: 100%;
  background-color: var(--color-main);
  z-index: 8;
  position: sticky;
  top: var(--top-height);
  padding-bottom: var(--body-border);
  z-index: 8;
}
#program_head {
  margin: auto;
  width: 100%;
  display: flex;
  justify-content: space-between;
  font-size: var(--font-body-large);
  gap: var(--body-border);
  line-height: 1em;
}

.program_date,
.program_date_selected {
  align-items: stretch;
  flex-grow: 1;
  display: grid;
  place-items: center;
  padding: 10px 20px 7px;
}

.program_date {
  background-color: black;
  color: white;
}

.program_date_selected,
.program_date:hover {
  background-color: white;
  color: black;
  font-style: italic;
}
.program_date:hover a {
  font-style: normal;
  transform: skewX(-14deg);
  transition: 0.3s;
  position: relative;
  left: 0.075em;
}

#program_body {
  margin: auto;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  justify-content: flex-start;
  width: 100%;
}
.program_location {
  width: 100%;
  background-color: black;
  margin-bottom: var(--body-border);
  padding: 10px 20px 7px;
  display: flex;
  font-size: var(--font-body-large);
  align-items: center;
  line-height: 1em;
}
.program_item {
  display: flex;
  gap: var(--body-border);
  min-height: 7.5vw;
  margin-bottom: var(--body-border);
  flex-grow: 1;
  width: 100%;
}
.pl_title {
  letter-spacing: -0.05em;
}
.program_item:hover .pi_time,
.program_item:hover .pi_text,
.program_item:hover .pi_type {
  background-color: white;
  color: black;
  box-shadow: 0 4px 8px 2px rgba(0, 0, 0, 0.3);
}
.pi_time {
  background-color: black;
  width: 5.3vw;
  height: 5.3vw;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: var(--font-body-medium);
}
.pi_image {
  padding: 0;
  width: 14vw;
  height: 14vw;
  overflow: hidden;
  display: grid;
  place-items: center;
  box-shadow: 0 4px 8px 2px rgba(0, 0, 0, 0.3);
  background-size: cover;
  background-position: center;
}
.pi_text_type_container {
  display: flex;
  flex-direction: column;
  gap: var(--body-border);
  flex-grow: 1;
  width: 46.4vw;
}
.pi_text {
  background-color: black;
  width: 100%;
  min-height: 7.5vw;
  line-height: 1.2em;
  padding: 1em;
  display: grid;
  place-items: center;
}

.pit_artist {
  font-size: var(--font-body-chunky);
  line-height: 1.2em;
}
.pit_title {
  font-size: var(--font-body-medium);
  line-height: 1.2em;
}
.pi_type {
  align-self: flex-start;
  text-transform: uppercase;
  background-color: black;
  font-size: var(--font-body-small);
  padding: 0.2em 1em;
}
/**** PROGRAM POPUP **/
#progra_preview_container {
  display: flex;
  width: 100%;
}
#program_eventview {
  width: 66vw;
  margin: auto;
  z-index: 7;
  background-color: black;
  display: none;
  flex-direction: column;
  padding: 0 50px;
}
.pevt_top {
  width: 100%;
  display: flex;
  justify-content: space-between;
  padding-top: 30px;
  position: sticky;
  top: calc(var(--top-height) + 55px);
  background-color: black;
  z-index: 8;
  gap: 20px;
}

.pevt_title {
  font-family: Steinbeck, sans-serif;
  font-size: var(--font-body-big);
}
#p_title {
  font-size: var(--font-body-chunky);
  font-style: italic;
  margin-bottom: 0.6em;
}
.pevt_close img {
  height: 3.6vw;
}
.pevt_body {
  width: 100%;
  padding-bottom: 50px;
  padding-right: 50px;
  display: flex;
  flex-direction: column;
  min-height: 80vh;
  font-family: "Suisse regular", sans-serif;
}
#pe_image {
  max-width: 37vw;
  max-height: 40vw;
  width: 37vw;
  padding: 0;
  overflow: hidden;
  display: flex;
}
#pe_image img {
  width: auto; 
  height: auto; 
  max-width: 100%; 
  max-height: 100%; 
  object-fit: contain; 
  object-position: left center;
}
#pe_image_title {
  font-size: var(--font-body-small);
  margin-bottom: 1em;
}
#pe_text {
  flex-grow: 1;
  font-size: var(--font-body-medium);
}

/** ARCHIVE */
#archive {
  flex-grow: 1;
  padding-top: 20px;
}
#archive_bg {
  position: relative;
  min-height: calc(calc(100svh - var(--top-height)) - 20px);
  background-image: url("img/archive_bg2.png");
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
}
#archive_bg::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("img/ruut.png");
  background-size: 167px;
}
#arch_body_container {
  display: flex;
  justify-content: space-evenly;
  padding-top: 100px;
}
.arch_island {
  display: grid;
  place-items: center;
  margin: 0 -10vw;
  z-index: 4;
  position: relative;
}
.arch_island:hover img {
  filter: invert(1);
}
.txt_box {
  background-color: var(--color-main);
  color: black;
  padding: 0.1em 1em;
  font-size: var(--font-body-medium);
  border: var(--body-border) solid black;
}
#arch_box_21 {
  position: absolute;
  top: 80%;
  left: 25%;
}
#arch_box_22 {
  position: absolute;
  top: 50%;
  left: 25%;
}
#arch_box_23 {
  position: absolute;
  top: 33%;
  left: 15%;
}

#arch_container {
  background-color: black;
  color: white;
  display: flex;
  min-height: calc(100vh - var(--top-height));
  padding: 2vw 3vw;
  width: 100vw;
}
.arch_left {
  width: 50%;
  display: grid;
  place-items: center;
  min-height: calc(100vh - var(--top-height));
  position: relative;
  height: calc(100vh - var(--top-height));;
}
.arch_gal_img {
  max-width: 10vw;
  max-height: 20vw;
  width: 10vw;
  padding: 0;
  overflow: hidden;
  display: flex;
  position: absolute;
}
.arch_gal_img:hover {
  border: 1px solid white;
}
.arch_gal_img img {
  width: auto; 
  height: auto; 
  max-width: 100%; 
  max-height: 100%; 
  object-fit: contain; 
  object-position: left center;
}

.arch_right {
  width: 50%;
}
.arch_title {
  font-family: Steinbeck, sans-serif;
  font-size: var(--font-body-big);
}
.arch_subtitle {
  font-family: Steinbeck, sans-serif;
  font-size: var(--font-body-chunky);
  font-style: italic;
  margin-bottom: 1em;
}
.arch_text {
  font-size: var(--font-body-medium);
  width: 50vw;
}

.arch_fullview_c {
  position: fixed;
  top: var(--top-height);
  left: 0;
  height: calc(100vh - var(--top-height));
  width: 45vw;
  z-index: 1;
}
#arch_img_fullview {
  padding: 2vw; 
  display: none; 
  flex-direction: column; 
  background-size: contain; 
  background-position: center; 
  background-color: black; 
  color: white; 
  position: fixed; 
  top: var(--top-height); 
  width: 44%; 
  height: calc(100vh - var(--top-height));
  z-index: 9;
}

#arch_gal_m {
  display: none;
}

/**PROJECTS**/
#projects {
}
#projects_bg {
  position: relative;
  min-height: calc(calc(100svh - var(--top-height)) - 20px);
  background-image: url("img/projects_bg.png");
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
}
#projects_bg::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("img/ruut.png");
  background-size: 167px;
}
.proj_isl_cont {
  position: absolute;
}
.proj_isl {
  position: relative;
}
.proj_isl:hover img {
  filter: invert(1);
}
.proj_isl span {
  position: absolute;
  left: 25%;
  top: 50%;
}
.proj_isl img {
  width: min(25vw, 40vh);
}
#proj_sym {
  top: 30px;
  left: 50px;
}

#proj_cooking {
  bottom: 30px;
  left: 50px;
}

#proj_land {
  top: 25vh;
  left: 40vw;
}

#proj_network {
  top: 30px;
  right: 50px;
}

#proj_fabric {
  bottom: 30px;
  right: 50px;
}

/** Mobiili stiilid **/
@media only screen and (orientation: portrait) {
  #top {
    padding: 12px 0 7px 8px;
  }
  #top_logo {
    height: 38px;
    width: 108px;
  }
  #top_logo img {
    height: 38px;
    width: 108px;
  }
  #top_menu_ico {
    width: 53px;
  }
  #top_menu_ico img {
    height: 100%;
    padding-right: 7px;
  }

  #page_container {
    display: flex;
    flex-direction: column;
    min-height: 100svh;
  }
  .body_container {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-grow: 1;
    width: 100%;
    background: var(--color-main);
  }
  #home_bg {
    background-position: center 15vh;
  }

  /** THEME **/
  #theme {
    color: black;
    font-size: var(--font-body-big-mobile);
    letter-spacing: -0.02em;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    width: 96vw;
    align-items: flex-start;
  }
  #theme_container {
    background-size: 200vw 80vh;
    background-position: bottom center;
  }
  #theme_title {
    width: 100%;
    margin: auto;
    display: grid;
    place-items: end start;
    padding: 1vw 0;
  }
  #theme_title > img {
    height: 7vw;
  }
  #theme_body {
    width: 100%;
    margin: 0 0;
    margin-bottom: 1svw;
    padding: 3vw 0vw;
    font-family: "Suisse int", sans-serif;
    flex-grow: 1;
  }

  /** ABOUT */
  #about {
    color: white;
    width: 96vw;
    font-size: var(--font-body-big);
    background: var(--color-main);
    flex-grow: 1;
  }

  .about_link,
  .about_link_selected {
    padding: 4px 10px;
  }

  #about_menu {
    flex-wrap: wrap;
    gap: var(--body-border);
  }
  /* #about_menu  {
  margin-bottom: var(--body-border);
} */

  .about-body {
    margin: auto;
    background-color: black;
    padding: 3.5vw;
    overflow-x: hidden;
    width: 100%;
    font-size: var(--font-body-big-mobile);
  }
  .about-body * {
    max-width: 100%;
  }
  .about-title {
    margin: auto;
    background-color: black;
    padding: 4px 10px;
    margin-bottom: var(--body-border);
    font-family: Steinbeck, sans-serif;
    width: 100%;
  }
  .about-logos-container {
    margin: auto;
    display: flex;
    gap: var(--body-border);
    flex-wrap: wrap;
    width: 100%;
    margin-bottom: var(--body-border);
  }
  .about-logo {
    background-color: black;
    width: 31.666vw;
    height: 31.666vw;
    display: grid;
    place-items: center;
  }
  #about-team {
    display: flex;
    width: 100%;
    gap: 0;
    flex-wrap: wrap;
  }
  #team-col1,
  #team-col2 {
    width: 100%;
  }
  .team-member {
    margin-bottom: 1em;
  }
  .team-pos {
    font-weight: 400;
  }
  .team-name {
    font-weight: 400;
  }

  /*** PROGRAM **/
  #program_container {
    background-position: bottom left, top center, right center;
    background-size: contain, contain, contain;
    background-repeat: no-repeat;
    background-attachment: scroll;
  }
  #program {
    width: 96vw;
  }

  #program_eventview {
    width: 96vw;
    padding: 0 20px;
  }
  #program_head {
    width: 100%;
  }
  .program_date,
  .program_date_selected {
    padding: 4px 10px;
  }
  .program_location {
    padding: 4px 10px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .pi_time {
    width: 10vw;
    height: 10vw;
    font-size: var(--font-body-small);
  }
  .pi_image {
    width: 33vw;
    height: 33vw;
  }
  .pi_text_type_container {
    width: 52vw;
  }
  .pevt_top {
    top: calc(var(--top-height) + 35px);
    padding-top: 10px;
  }
  .pevt_close img {
    height: 10vw;
    position: relative;
    top: 5px;
  }
  .pevt_body {
    width: 100%;
    padding-bottom: 50px;
    padding-right: 20px;
    display: flex;
    flex-direction: column;
    min-height: 80vh;
    font-family: "Suisse regular", sans-serif;
  }
  #pe_image {
    max-width: 80vw;
    max-height: 60vw;
    width: 80vw;
    padding: 0;
    overflow: hidden;
    display: flex;
  }
  #pe_text {
    font-size: 14pt;
  }
  #archive_bg {
    position: relative;
    min-height: calc(calc(100svh - var(--top-height)) - 20px);
    background: url("img/archive_bg2.png") center/cover no-repeat;
    padding-bottom: 20vh;
  }
  #archive_bg::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: url("img/ruut.png");
    background-size: calc(100vw / 3 - 4px);
  }
  #arch_body_container {
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
    padding-top: 100px;
  }
  .arch_island {
    display: grid;
    place-items: center;
    margin: 0 0;
    z-index: 4;
  }
  #arch_body_container img {
    margin: -5vh 0;
    max-width: 96vw;
  }
  #arch_body_container div:nth-child(1) {
    margin-top: -20vh;
  }
  #arch_body_container div:nth-child(3) {
    margin-top: -65vh;
  }
  .txt_box {
    border: var(--body-border) solid black;
    z-index: 7;
  }
  #arch_box_21 {
    position: absolute;
    top: 87%;
    left: 25%;
  }
  #arch_box_22 {
    position: absolute;
    top: 47%;
    left: 30%;
  }
  #arch_box_23 {
    position: absolute;
    top: 27%;
    left: 25%;
  }
  #arch_isl_23 {
    order: 1;
  }
  #arch_isl_22 {
    order: 2;
    top: -280px;
  }
  #arch_isl_21 {
    order: 3;
  }

  #arch_gal_m {
    display: inline;
    height: 40vh;
    width: 100%;
  }
  .arch_fullview_c {
    position: static;
    height: 40vh;
    width: 100%;
    z-index: 1;
  }
  .arch_gal_img {
    max-width: 35vw;
    width: 35vw;
    max-height: 35vw;
  }

  .arch_left {
    display: none;
  }
  .arch_right {
    width: 100%;
  }
  .arch_text {
    width: 100%;
  }
  #arch_img_fullview {
    width: 80vw;
    left: 10vw;
  }

  /**PROJECTS**/
  #projects {
  }
  #projects_bg {
    position: relative;
    min-height: calc(calc(100svh - var(--top-height)) - 20px);
    background: url("img/projects_bg.png") center/cover no-repeat;
    padding-bottom: 20vh;
  }
  #projects_bg::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: url("img/ruut.png");
    background-size: calc(100vw / 3 - 4px);
  }

  #proj_body_container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5vw;
    padding-top: 25px;
  }
  .proj_isl_cont {
    position: static;
    display: grid;
    place-items: center;
  }

  .proj_isl img {
    width: min(65vw, 40vh);
  }
  #proj_sym {
    top: 15vh;
    left: 5vw;
  }

  #proj_cooking {
    bottom: 5vw;
    left: 5vw;
  }

  #proj_land {
    top: 25vh;
    left: 37.5vw;
  }

  #proj_network {
    top: 5vw;
    right: 0vw;
  }

  #proj_fabric {
    bottom: 5vw;
    right: 0vw;
  }
}
