@font-face {
  font-family: Georgia;
  src: url("georgia.62fd5d2b.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}

* {
  touch-action: manipulation;
  -webkit-touch-callout: none;
  font-family: Georgia;
}

html, body {
  background-color: #faf9f7;
  margin: 0;
}

body {
  padding-bottom: 80px;
}

.container {
  width: 500px;
  max-width: 500px;
  margin: 0 auto;
}

.flower {
  justify-content: center;
  align-items: center;
  margin-top: 50px;
  display: flex;
}

.flower path {
  stroke: #8c021a;
  stroke-width: 1.8px;
  stroke-dasharray: 1;
  stroke-dashoffset: 1px;
  stroke-linecap: round;
  stroke-linejoin: round;
  visibility: hidden;
}

.title {
  width: 90%;
  margin-top: 30px;
  margin-left: 5%;
}

.title svg {
  width: 100%;
}

.title #letter path {
  stroke: #8c021a;
  fill: #8c021a;
  fill-opacity: 0;
  stroke-width: .7px;
  stroke-dasharray: 1;
  stroke-dashoffset: 1px;
  stroke-linecap: round;
  stroke-linejoin: round;
  visibility: hidden;
}

.date {
  opacity: 0;
  visibility: hidden;
  width: 90%;
  margin-top: 20px;
  margin-left: 5%;
}

.date svg {
  width: 100%;
}

.timeline-container {
  position: relative;
  overflow: hidden;
}

.timeline-item {
  margin-top: 58px;
  transform: translateX(89px);
}

.timeline-item-header {
  display: flex;
}

.timeline-item-top-row {
  justify-content: space-between;
  width: 365px;
  display: flex;
}

.timeline-item-icon {
  opacity: 0;
  visibility: hidden;
  transform: translateX(-20px);
}

.timeline-item-title {
  color: #8c021a;
  opacity: 0;
  visibility: hidden;
  margin-left: 12px;
  font-size: 18px;
  font-weight: bold;
  transform: translateX(-20px);
}

.timeline-item-button {
  color: #faf9f7;
  opacity: 0;
  visibility: hidden;
  -webkit-user-select: none;
  user-select: none;
  background-color: #8c021a;
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  padding: 4px 9px 5px;
  font-size: 17px;
  text-decoration: none;
  display: flex;
}

.timeline-item:nth-of-type(2) .timeline-item-button {
  margin-left: 62px;
}

.timeline-item:nth-of-type(3) .timeline-item-button {
  margin-left: 82px;
}

.timeline-item:nth-of-type(5) .timeline-item-button {
  margin-left: 103px;
}

.timeline-item-subtitle {
  color: #8c021a;
  opacity: 0;
  visibility: hidden;
  margin-top: 8px;
  margin-left: 32px;
  font-size: 17px;
}

.timeline-dot {
  opacity: 0;
  visibility: hidden;
  background-color: #bf9b30;
  border-radius: 5px;
  width: 10px;
  height: 10px;
  margin-top: 7px;
  position: absolute;
  left: -62px;
}

.timeline-bar {
  opacity: 0;
  visibility: hidden;
  background-color: #bf9b30;
  border-radius: 1px;
  width: 2px;
  height: 0;
  margin-top: 65px;
  position: absolute;
  top: 0;
  left: -58px;
  transform: translateX(89px);
}

.timeline-time {
  color: #faf9f7;
  opacity: 0;
  visibility: hidden;
  background-color: #655753;
  border-radius: 14px;
  justify-content: center;
  align-items: center;
  width: 57px;
  height: 28px;
  margin-top: -2px;
  font-size: 17px;
  display: flex;
  position: absolute;
  top: 0;
  left: -85px;
}

.photos-container {
  flex-direction: column;
  align-items: center;
  display: flex;
  position: relative;
}

.photos-title {
  color: #8c021a;
  opacity: 0;
  visibility: hidden;
  margin-top: 150px;
  font-size: 18px;
  font-weight: bold;
}

#photos-input {
  display: none;
}

.photos-button {
  opacity: 0;
  visibility: hidden;
  -webkit-user-select: none;
  user-select: none;
  cursor: pointer;
  background-color: #8c021a;
  border-radius: 12px;
  justify-content: center;
  align-items: center;
  width: 222px;
  height: 56px;
  margin-top: 28px;
  display: flex;
}

.photos-button-text {
  color: #faf9f7;
  -webkit-user-select: none;
  user-select: none;
  font-size: 17px;
  position: absolute;
}

.photos-button-progress-outer {
  opacity: 0;
  visibility: hidden;
  -webkit-user-select: none;
  user-select: none;
  background-color: #faf9f7;
  border-radius: 6px;
  width: 198px;
  height: 12px;
  margin-left: 24px;
  position: absolute;
}

.photos-button-progress-inner {
  opacity: 0;
  visibility: hidden;
  -webkit-user-select: none;
  user-select: none;
  background-color: #8c021a;
  border-radius: 4px;
  width: 194px;
  height: 8px;
  margin-left: 26px;
  position: absolute;
}

.photos-button-checkmark, .photos-button-error {
  opacity: 0;
  visibility: hidden;
  -webkit-user-select: none;
  user-select: none;
  width: 26px;
  height: 26px;
  position: absolute;
}

.photos-gallery {
  width: 460px;
  height: 460px;
  position: absolute;
  top: 230px;
  left: 50%;
  transform: translateX(-50%);
}

.photos-gallery-caption {
  color: #655753;
  opacity: 0;
  visibility: hidden;
  margin-top: -32px;
  font-size: 18px;
  font-weight: bold;
}

.photos-gallery-item {
  opacity: 0;
  visibility: hidden;
  border: 2px solid #655753;
  position: absolute;
  overflow: hidden;
  box-shadow: 0 0 8px #25120d33;
}

.photos-gallery-item:first-child {
  border-radius: 6%;
  width: 30.2%;
  height: 33.3%;
  top: 0%;
  left: 0%;
}

.photos-gallery-item:nth-child(2) {
  border-radius: 3.5%;
  width: 57.2%;
  height: 42.8%;
  top: 0%;
  left: 34.7%;
}

.photos-gallery-item:nth-child(3) {
  border-radius: 6%;
  width: 26.5%;
  height: 36.8%;
  top: 37.8%;
  left: 0%;
}

.photos-gallery-item:nth-child(4) {
  border-radius: 4%;
  width: 36%;
  height: 48.5%;
  top: 47.4%;
  left: 31%;
}

.photos-gallery-item:nth-child(5) {
  border-radius: 5%;
  width: 28.7%;
  height: 38.5%;
  top: 47.4%;
  left: 71.6%;
}

.photos-gallery-image {
  object-fit: cover;
  opacity: 0;
  visibility: hidden;
  width: 100%;
  height: 100%;
  transform: scale(1.2);
}

.photos-gallery-padding {
  width: 100%;
  height: 115%;
}
