
html,
body {
  overflow-x: hidden;
}

.page-divider {
  width: 100%;
  height: 1px;
  background: #000;
  margin: 20px 0 0;

}

.about-viewport {
    max-height: 80vh;
    position: relative;
    padding: 0px 20px 0px 20px;
    box-sizing: border-box;

    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.about-intro {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    margin-top: 10px;
    align-items: start;
}

.about-grid {
    display: grid;
    grid-template-columns: 0.3fr 2fr 1fr;
    gap: 20px;
}

.about-text {
    max-width: 520px;
}

.about-player {
  justify-self: end;
    white-space: nowrap;
}






.about-player {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.audio-icon {
  width: 10px;
  height: 10px;
  fill: currentColor;
}

/* BUTTON RESET */
.audio-toggle {
  all: unset;
  cursor: pointer;

  display: inline-flex;
  align-items: center;
  gap: 8px;

  padding: 6px 10px;

  font-size: 12px;
  line-height: 1;
  white-space: nowrap;

  color: #000;
  background: transparent;

  border: 1px solid #000;
}

/* Hover = subtle editorial feedback */
.audio-toggle:hover {
  background: transparent;
  color: #000;
}

/* Active / playing state (JS will toggle this later) */
.audio-toggle.is-playing {
  background: #000;
  color: #fff;
}


/* Default state */
.icon-pause {
  display: none;
}

/* Playing state */
.audio-toggle.is-playing .icon-play {
  display: none;
}

.audio-toggle.is-playing .icon-pause {
  display: inline;
}



.floating-words {
  position: relative;
  width: 100%;
  height: 66vh; /* or whatever you decide */
  overflow: hidden;
}

/* === WORD OBJECT === */

.word {
  position: absolute;
  transform: translate(-50%, -50%);
}

.word-wrap {
  position: relative;
  display: inline-block;

}

/* Default scale (desktop) */
.word-wrap {
  --bubble-scale: 1;
}

/* === WORD SVG === */

.word-svg {
  position: relative;
  z-index: 1;

  width: 450px;   /* start here, tune by eye */
  height: auto;
  display: block;
}

.word-svg path {
  fill: #000;
}

/* === OVAL === */

.word-oval {
  position: absolute;
  inset: calc(-1 * var(--oval-padding, 0px));
  width: calc(100% + (2 * var(--oval-padding, 0px)));
  height: calc(100% + (2 * var(--oval-padding, 0px)));
  z-index: 0;
  pointer-events: none;

}


.word-oval ellipse {
  fill: none;
  stroke: #000;
  stroke-width: 1px;
  vector-effect: non-scaling-stroke;
}



.word-born-nyc {
    top: 60.1%;
    left: 23.8%;
    rotate: 8deg;

  --oval-padding: 78px;
}

.word-born-nyc .word-svg {
    width: 590px;
}



.word-i-love-design {
    top: 70%;
    left: 62.2%;
    rotate: 21deg;

  --oval-padding: 45px;
}

.word-i-love-design .word-svg {
    width: 600px;
}


.word-live-laugh-love {
    top: 58.9%;
    left: 53%;
    rotate: -8deg;
  --oval-padding: 180px;
}

.word-live-laugh-love .word-svg {
    width: 180px;
}



.word-memento-mori {
  top: 84%;
  left: 34%;

  --oval-padding: 218px;
}

.word-memento-mori .word-svg {
    width: 900px;
}



.word-1997 {
    top: 96%;
    left: 90%;
    rotate: 10deg;

  --oval-padding: 350px;
  
}

.word-1997 .word-svg {
    width: 800px;
}



.word-my-dog {
    top: 32.8%;
    left: 106%;
    rotate: -4deg;

  --oval-padding: 100px;
}

.word-my-dog .word-svg {
    width: 800px;
}



.word-star-1 {
    top: 86.3%;
    left: 69.2%;
    
    --oval-padding: 40px; 
}

.word-star-1 .word-svg {
  width: 40px;
}



.word-star-2 {
    top: 66.8%;
    left: 61.6%;
    rotate: -8deg;

    --oval-padding: 40px; 
}

.word-star-2 .word-svg {
  width: 40px;
}



.word-star-3 {
    top: 65.2%;
    left: 8.8%;
    rotate: -8deg;

    --oval-padding: 40px; 
}

.word-star-3 .word-svg {
  width: 40px;
}



.word-star-4 {
    top: 48.1%;
    left: 46%;
    rotate: 20deg;

    --oval-padding: 40px; 
}

.word-star-4 .word-svg {
  width: 40px;
}



.word-star-5 {
    top: 49.5%;
    left: 96%;
    rotate: 20deg;

    --oval-padding: 40px; 
}

.word-star-5 .word-svg {
  width: 40px;
}





@media (max-width: 768px) {

.about-viewport {
    max-height: none;
    height: auto;
    overflow: visible;
    padding-bottom: 0px;
  }

.about-text {
    margin: 0;
    position: relative;
    z-index: 2;
  }

.about-intro {
    grid-template-columns: 1fr;
    gap: 20px;

  }

  .about-text p {
    font-size: 14px;
    line-height: 1;

  }

.about-grid {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    align-items: start;
    }


.about-player {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
  }


.about-label {
    grid-column: 1;
    grid-row: 1;
  }

.about-text {
    grid-column: 1 / -1;
    grid-row: 2;
  }

.about-grid {
    z-index: 2;
  }

.floating-words {
    height: clamp(420px, 65svh, 620px);
    position: relative;
    overflow: hidden;
    z-index: 1;
  }

  .word-wrap {
    --bubble-scale: 0.55;
  }

  /* CENTER MOST THINGS */
  .word-born-nyc {
    top: 18%;
    left: 50%;
    rotate: -3deg;
  }

  .word-i-love-design {
    top: 52%;
    left: 90%;
    rotate: 11deg;
  }

  .word-live-laugh-love {
    top: 45%;
    left: 20%;
    rotate: -6deg;
  }

  .word-memento-mori {
    top: 85%;
    left: 50%;
  }

  .word-1997 {
    top: 28%;
    left: 98%;
    rotate: -20deg;
  }

  .word-my-dog {
    top: 25%;
    left: 65%;
    rotate: -4deg;
  }

  /* STARS — SUPPORTING, NOT COMPETING */

  .word-star-1 {
    top: 43%;
    left: 45%;
  }

  .word-star-2 {
    top: 65%;
    left: 92%;
  }

  .word-star-3 {
    top: 60%;
    left: 16%;
  }

  .word-star-4 {
    top: 14%;
    left: 10%;
  }

  .word-star-5 {
    top: 20.9%;
    left: 85%;
  }

}


