:root {
  --font-mono: "IBM Plex Mono", monospace;
  --font-emphasis: "Questrial", sans-serif;
  --font-serif: "Cormorant", serif;
  --font-words: "Literata", serif;

  --weight-light: 300;
  --weight-regular: 400;
  --weight-semibold: 600;
  --weight-bold: 700;

  --_colours---white: #fefefe;
  --_colours---black: #1E1E1E;
  --_colours---grey-v-dark: #212121;
  --_colours---grey-v-dark-rgb: 33, 33, 33;
  --_colours---grey-dark: #3f3f3f;
  --_colours---grey-medium-dark: #5c5c5c;
  --_colours---grey-medium: #e2e2e2;
  --_colours---grey-light: #f2f2f2;
  --_colours---grey-v-light: #f5f5f5;
  --_colours---grey-vv-light: #fafafa;

  --_colours---green-subtle-bg: #d4ffd4;
  --_colours---green-dark-text: #7d0000;
  --_colours---red-subtle-bg: #ffcaca;
  --_colours---red-dark-text: #1b4b1e;
  --_colours---yellow-subtle-bg: lemonchiffon;
  --_colours---yellow-dark-text: #1a237e;
  --_colours---blue-subtle-bg: #a2fdff;
  --_colours---blue-dark-text: #ff2d6d;
}

@font-face {
  font-family: "Fontello";
  src: url("../fonts/fontello.eot?90990909") format("embedded-opentype"), url("../fonts/fontello.woff2?90990909") format("woff2"), url("../fonts/fontello.woff?90990909") format("woff"), url("../fonts/fontello.ttf?90990909") format("truetype"), url("../fonts/fontello.svg?90990909#fontello") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 13px;
}

/* Vertical spacing between siblings */
p + p,
h1 + *,
h2 + *,
h3 + *,
h4 + *,
ul + *,
ol + *,
pre + *,
blockquote + * {
  margin-top: 1rem;
}

/* Remove top margin from first child in containers */
h1 + h2,
h1 + h3,
h1 + h4,
h1 + h5,
h2 + h3,
h2 + h4,
h2 + h5,
h3 + h4,
h3 + h5,
.parent > :first-child,
div > :not(section):first-child {
  margin-top: 0;
}

body {
  font-family: var(--font-mono);
  font-weight: var(--weight-regular);
  font-size: 1rem;
  background-color: var(--_colours---white);
  color: #222;
  /* no max-width or margin here */
  position: relative;
}

/* Letter background container */
.letter-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 0;
  pointer-events: none;
}

/* Add padding to the body when the jukebox is collapsed to prevent overlap */
body.jukebox-is-collapsed {
  padding-bottom: 100px; /* Adjust this value based on the collapsed jukebox height */
}

main, footer{
  width: calc(100% - 2rem); /* full width minus 1rem margin on each side */
  margin-left: 1rem;
  margin-right: 1rem;
  padding: clamp(0.324rem, 0.21px + 1.253vw, 1.25rem); /*PROPORTIONS: p-sm */
  padding-top: 0px;
  padding-left: 0px;
  padding-right: 0px;
  box-sizing: border-box; /* include padding and borders in width */

  display: flex;
  flex-direction: column;
  position: relative;
  background-color: var(--_colours---white);
  z-index: 1;
}

main::before,
main::after,
footer::before,
footer::after {
  content: 'I i L \\ i I [ L ] i I / L l ( i L l i I ) [ l i I \\ L l I i L / i I l L l i I / L ) i I i L l i [ i / I ( l i 7 L l [ ) i L i L / i I l L 1 \\ l i I ( L l i [ I \\ l 1 L i [ L i L i L / i [ I l L l l I ( I i L l I ] i L i L [ L i I l L i / l i L i I l I ) I i L i I l L l i I ( L l i \\ I [ l I [ L [ I l I i L l i ) i L i L / i [ L l i ( i I L / i l L \\ i L l i L [ ) L l i ( i l L i [ L l [ i I / I l L i l [ i I l I i L i l I l \\ i L l i I L / l L i I l ( i L i l I i L i 1 I \\ i l L / l L i [ L l i I L l i L i l I l [ i L i l ) l / L i ( l I i [ L / i l L l i I L i ( l I i L l i [ L i l 1 L i I \\ l L i I i i L i I l L i l I / L l i \\ l i I L i l I i L l I i L i I l i [ l l i L i I l L i I / I i l I \\ L i [ l I i / L l i I ( l 7 L i i [ l L i / I l L i l \\ i I ( l I L i l ) [ i i L i L l i / i I l I l I i L i I i L l i I i L l I i l ( l I i L l i I L i i I i L l i [ i i ) L i i \\ L ( i l 1 [ i L i / i L ( l I / i L l I ( l L i I l [ i L ) i / l I L i i ( L \\ i L l [ i L I i L \\ i I [ L ] i I / L l ( i L l i I ) [ l i I \\ L l I i L / i I l L l i I / L ) i I i L l i [ i / I ( l i 7 L l [ ) i L i L / i I l L 1 \\ l i I ( L l i [ I \\ l 1 L i [ L i L i L / i [ I l L l l I ( I i L l I ] i L i L [ L i I l L i / l i L i I l I ) I i L i I l L l i I ( L l i \\ I [ l I [ L [ I l I i L l i ) i L i L / i [ L l i ( i I L / L l ( i L l i I ) [ l i I \\ L l I i L / i I l L l i I / L ) i I i L l i [ i / I ( l i 7 L l [ ) i L i L / i I l L 1 \\ l i I ( L l i [ I \\ l 1 L i [ L i L i L / i [ I l L l l I ( I i L l I ] i L i L [ L i I l L i / l i L i I l I ) I i L i I l L l i I ( L l i \\ I [ l I [ L [ I l I i L l i ) i L i L / i [ L l i ( i I L / i l L \\ i L l i L [ ) L l i ( i l L i [ L l [ i I / I l L i l [ i I l I i L i l I l \\ i L l i I L / l L i I l ( i L i l I i L i 1 I \\ i l L / l L i [ L l i I L l i L i l I l [ i L i l ) l / L i ( l I i [ L / i l L l i I L i ( l I i L l i [ L i l 1 L i I \\ l L i I i i L i I l L i l I / L l i \\ l i I L i l I i L l I i L i I l i [ l l i L i I l L i I / I i l I \\ L i [ l I i / L l i I ( l 7 L i i [ l L i / I l L i l \\ i I ( l I L i l ) [ i i L i L l i / i I l I l I i L i I i L l i I i L l I i l ( l I i L l i I L i i I i L l i [ i i ) L i i \\ L ( i l 1 [ i L i / i L ( l I / i L l I ( l L i I l [ i L ) i / l I L i i ( L \\ i L l [ i L I i L \\ i I [ L ] i I / L l ( i L l i I ) [ l i I \\ L l I i L / i I l L l i I / L ) i I i L l i [';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 5px;
  font-size: clamp(3px, 0.5vw + 0px, 5px);
  line-height: 2;
  font-weight: 900;
  word-spacing: 0.5em;
  overflow: hidden;
  white-space: normal;
  word-wrap: break-word;
  pointer-events: none;
  background-color: var(--_colours---white);
}

main::before,
footer::before {
  left: calc(-1rem - 5px);
}

main::after,
footer::after {
  right: calc(-1rem - 5px);
}

main {
  min-height: 100vh;
}

main.centred, footer.centred {
  max-width: 1280px;
  width: calc(100% - 4rem); 
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 600px) {
  html {
    font-size: 13px;
  }

  main {
    width: 100%; /* full width minus 1rem margin on each side */
    margin-left: auto;
    margin-right: auto;
    border: none;
  }

  main.centred, footer.centred {
    width: 100%;
  }

  main::before,
  main::after,
  footer::before,
  footer::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 0px;
    font-size: clamp(3px, 0.5vw + 0px, 5px);
    line-height: 2;
    font-weight: 900;
    word-spacing: 0.5em;
    overflow: hidden;
    white-space: normal;
    word-wrap: break-word;
    pointer-events: none;
  }

  main::before,
  footer::before {
    left: calc(-1rem - 5px);
  }

  main::after,
  footer::after {
    right: calc(-1rem - 5px);
  }
}


section {
  background-color: var(--_colours---grey-vv-light);
  overflow: hidden;
  padding: clamp(0.324rem, 0.21px + 1.253vw, 1.25rem); /*PROPORTIONS: p-sm */
  margin: clamp(0.524rem, 0.38px + 2.002vw, 2rem); /*PROPORTIONS: m-md */
}

p {
  padding-left: 0.3rem;
  padding-right: 0.3rem;
  background-color: var(--_colours---grey-v-light);
}

p span {
  background-color: var(--_colours---white);
}

blockquote {
  border-left: 4px solid var(--_colours---grey-medium);
  background-color: var(--_colours---white);
  font-style: italic;
  font-weight: var(--weight-semibold);
  font-size: 1.06rem;
  color: var(--_colours---grey-medium-dark);
  padding: clamp(0.2rem, 0.22px + 0.74vw, 0.75rem); /* PROPORTIONS: p-xs */
  margin: clamp(0.848rem, -0.46px + 3.59vw, 3.5rem); /* PROPORTIONS: m-lg */
}

h1 {
  font-family: var(--font-emphasis);
  font-weight: var(--weight-regular);
  font-size: clamp(1.9rem, 5vw, 3rem);
}

h2 {
  font-family: var(--font-emphasis);
  font-weight: var(--weight-light);
  font-size: clamp(1.5rem, 4vw, 2rem);
}

h3 {
  font-family: var(--font-emphasis);
  font-weight: var(--weight-regular);
  font-size: clamp(1.3rem, 2vw, 1.5rem);
}

h4 {
  font-family: var(--font-emphasis);
  font-weight: var(--weight-regular);
  font-size: clamp(1.2rem, 2vw, 1.2rem);
}

h1 span,
h2 span,
h3 span,
h4 span {
  background-color: var(--_colours---white);
}

b {
  font-weight: 900;
  letter-spacing: -0.02em;
  font-variation-settings: "wght" 950;
}

a {
  color: var(--_colours---grey-v-dark);
  cursor: pointer;
}

a.linkbtn {
  padding: 0 10px;
  border-left: 1px dashed var(--_colours---grey-v-dark);
  border-right: 1px dashed var(--_colours---grey-v-dark);
  background-color: var(--_colours---grey-vv-light);
}

a:hover {
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

.icons {
  font-family: "Fontello", sans-serif;
  display: inline-block;
  margin-left: 10px;
  vertical-align: middle;
}

.text-visualizer {
  position: absolute;
  inset: 0;
  display: none;
  grid-template-rows: 1fr;
  place-items: center;
  color: limegreen;
  background: rgba(0, 0, 0, 0.1);
  user-select: none;
  white-space: pre;
  line-height: 1;
  margin: 0;
}

.visualizer-trigger {
  cursor: pointer;
}

/* background cover for visualizer */
.cover {
  position: relative;
  background-size: cover;
  background-position: center;
  cursor: pointer;
  overflow: hidden;
}

.underline-pulsing {
  text-decoration: underline;
  text-decoration-color: rgba(0, 0, 0, 0.3); /* Starting color - semi-transparent black */
  animation: pulse-underline-fade 1s infinite alternate;
}

.pulsing {
  animation: pulse-fade 1s infinite alternate;
}

@keyframes pulse-underline-fade {
  0% {
    text-decoration-color: rgba(0, 0, 0, 0.2); /* Faint black */
  }
  100% {
    text-decoration-color: rgba(0, 0, 0, 1); /* Fully opaque black */
  }
}

@keyframes pulse-fade {
  0% {
    opacity: 0.5; /* Faint */
  }
  100% {
    opacity: 1; /* Fully opaque */
  }
}






/* ============================================
   MODAL BACKGROUND STYLES
   Reusable frosted glass background for modals
   ============================================ */
.modal-background-blur {
  background-color: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

/* Apply to GLightbox overlay */
.goverlay {
  background-color: rgba(0, 0, 0, 0.7) !important;
  backdrop-filter: blur(5px) !important;
  -webkit-backdrop-filter: blur(5px) !important;
}


