body {
  font-family: Arial, sans-serif;
  margin: 0;
  padding: 0;
  background-color: #f2f2f2;
  color: #333;
  display: flex;
  flex-direction: column;
  height: 100vh;
}

.header {
  background-color: #4698e6;
  color: #fff;
  height: 8vh;
  display: flex;
  justify-content: center;
}

.header .header-content {
  display: flex;
  justify-content: center;
  align-items: center;
}

.header .logo {
  font-size: 24px;
  font-weight: bold;
}

.body-container {
  display: flex;
  gap: 2px;
  height: 87vh;
}

.card-previews {
  display: flex;
  gap: 40px;
  justify-content: center;
  align-items: center;
  flex: 1;
}

.card-preview {
  position: relative;

  border: 1px solid #ddd;
  box-sizing: border-box;
  background-color: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.card-preview #front-preview {
  width: 280px;
  height: 400px;
  display: flex;
  justify-content: center;
  align-items: center;

  border-radius: inherit;
}

.card-previews #previous-preview,
.card-previews #next-preview {
  width: 175px;
  height: 250px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: inherit;
  font-size: 400%;
  font-weight: bolder;
  color: #3d3d3d;
  
}

#previous-preview-button,
#next-preview-button {
  width: 100%;
  height: 100%;
  background-color: #ffffff21;
  border: 1px solid #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: inherit;
  font-size: 80%;
  font-weight: bolder;
  color: #3d3d3d;
  z-index: 3;
  cursor: pointer;
}

#previous-preview-button:hover,
#next-preview-button:hover {
  background-color: #7a7a7a50;
  color: #252525;
}


.card-preview .card-text {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  text-align: center;
  padding: 20px;
  box-sizing: border-box;
}

.card-preview .card-text span {
  font-size: 24px;
  font-weight: bold;
}


.text-box {
  position: absolute;
  padding: 2px;
}

.image-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  overflow: hidden;
  max-width: 100%;
  max-height: 100%;
  border-radius: inherit;
}

.image-overlay .background-img {
  width: 100%;
  height: auto;
  max-height: 750px;
  border-radius: 4px;
  border-radius: inherit;
}

.image-overlay .foreground-img {
  width: 100%;
  height: auto;
  max-height: 500px;
  border-radius: 4px;
  border-radius: inherit;
}

/* Add this style to create a tab-like appearance for the tab buttons */
.tabs {

}

.tab-button {
  padding: 10px 20px;
  font-size: 16px;
  cursor: pointer;
  border-top-left-radius: 29px;
  border-top-right-radius: 9px;
  border: 1px solid #ddd;
  background-color: #dadada;
  transition: background-color 0.3s ease;
  position: relative;
  z-index: 1; /* Ensure the active tab overlaps the card content */
  top: 12px;
  width: 33%;
}

.tab-button.active {
  background-color: #fff;
  border-bottom: 1px solid #fff;
  position: relative;
  z-index: 3; /* Ensure the active tab overlaps the card content */
  top: 2px;
}

.tab-button:not(.active):hover {
  background-color: #e0e0e0;
}

/* Adjust the spacing between tab buttons */
.tabs .tab-button:not(:last-child) {
  margin-right: 0px;
}


.column-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
  height: 80vh;
  margin-top: 1vh;
  background-color: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  padding: 20px;
  border-radius: 8px;
}

/* Previous CSS styles remain unchanged */

.image-list-column,
.text-box-list-column {
  position: relative;
  z-index: 2;
  background-color: #fff;
  border-top: 1px solid #ddd;
  border-left: 0px solid #ddd;
  overflow: overlay;
  max-height: 95%;
}

.image-list-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.image-list-item .image-options {
  position: absolute;
  bottom: 2px;
  left: 2px;
  display: flex;
  gap: 4px;
  font-size: 12px;
  color: #fff;
}

.image-list-item .image-options span {
  display: flex;
  align-items: center;
}

.image-list-item .image-options span:not(:last-child)::after {
  content: '|';
  margin-left: 4px;
  margin-right: 4px;
}

.image-list-item .image-options span:last-child {
  margin-left: 8px;
}


.image-box {
  position: absolute;
}

.tab-container {
  height: 100%;
  width: 20%;
  background: linear-gradient(#f2f2f2, 5%, #fff, #fff);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  border-top-left-radius: 0px;
  border-top-right-radius: 3px;
  border-left: 1px solid #ddd;
}


.text-box-list-container, 
.image-list-container {
  height: 100%;
  padding: 20px;
}

.text-box-list-container h3,
.image-list-container h3 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 18px;
  color: #333;
}

.text-box-list, 
.image-list {
  display: flex;
  flex-direction: column;
  gap: 5px;
  height: 95%;
  overflow:auto;
}

.text-box-list-item, 
.image-list-item {
  border-radius: 4px;
  border-color: black;
  border-style: solid;
  border-width: 1px;
  padding: 8px;
  margin:4px;
  background-color: #b4e4ff31;
  transition: max-height 0.3s ease;
  height: auto;
  visibility: visible;
  position: relative;
}

#add-front-text-box,
#add-front-image {
  width: 90%;
  margin: 0% 5%;
  margin-bottom: 2%;
}

.text-box-list-item textarea {
  resize: none;
  width: 95%;
  height: 4vh;
  padding: 2px;
  margin: 2px;
}

.text-box-list-item.collapsed {
  height: 20px; /* Set the collapsed height here */
}

.input-container-header label {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 15px;
  font-weight: bold;
  padding-bottom: 8px;
  padding-top: 2px;
}

.remove-text-box-button, 
.remove-image-button  {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 17px;
  height: 17px;
  background-color: rgba(255, 0, 0, 0.75);
  color: #fff;
  border: 1px solid red;
  border-radius: 50%;
  font-size: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  cursor: pointer;
}

.toggle-text-box-button,
.toggle-image-button {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 17px;
  height: 17px;
  background-color: rgba(0, 99, 8, 0.75);
  color: #fff;
  border: 1px solid green;
  border-radius: 15%;
  font-size: 15px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  cursor: pointer;
}

.input-container-body {
  height: auto; /* Set the collapsed height here */
  visibility: visible;
  background-color: #77bdff3a;
  padding: 4px;
}

.input-container-body.collapsed {
  max-height: 0px; /* Set the collapsed height here */
  visibility: hidden;
}

.input-container-position,
.input-container-font,
.input-container-color,
.input-container-border {
  display: flex;
  align-items: center;
  gap: 4px;

  font-size: 10px;
  text-align: right;
}

.input-container-font {
  gap: 0px;
}

.input-container-font input {
  margin: 0px 5px 0px 3px;
}

.text-box-list-item input[type='number'],
.image-list-item input[type='number'] {
  width: 35px;
  padding: 2px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 10px;
}

.text-box-list-item select,
.image-list-item select {
  padding: 2px;
  border: 1px solid #ccc;
  border-radius: 4px;
  padding-right: 30px;
  font-size: 10px;
}

.input-container .font-style-checkbox,
.input-container .font-weight-checkbox,
.input-container .text-decoration-checkbox {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 16px;
}

.color-input {
  gap: 5px;
}

.color-input input[type='color'] {
  padding: 0px;
  margin: 0px;
  width: 25px;
  height: 20px;
  border-width: 1px;
  border-image:none;
  border-radius: 3px;
  border-color: transparent;
  background-color: transparent;
}

.opacity-input {
  width: 80px;
  height: 8px;
}

.form-column {
  width: 20%;
  height: auto;
  background-color: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
  transition: width 0.3s ease;
  overflow: auto;
  padding: 20px;
  border-right: 1px solid #ddd;
}

.form-column.collapsed {
  width: 5%;
}

.form-container {
  height: 100%;
  position: relative;

}

.form-container h2 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 18px;
  color: #333;
}

.form-item {
  margin: 5px 0px;
  position: relative;
  width: 95%;
}

.form-item-publish Button {
  position: absolute;
  bottom: 25px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 14px;
  width: 80%;
  margin: 0% 10%;
}

.form-item label {
  display: block;
  margin-bottom: 5px;
  font-size: 14px;
  color: #666;
}

.form-item input,
.form-item textarea {
  width: 100%;
  padding: 0px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 14px;
}

.form-item input[type="file"] {
  padding: 4px 0px 4px 4px;
}

.form-item input[type="text"] {
  padding: 4px 0px 4px 4px;
}

.form-item input[type="color"] {
  width: calc(100% + 6px);
}

.form-item .selected-file-name {
  margin-left: 5px;
}

.form-item .remove-image-button {
  position: absolute;
  top: 27px;
  right: 0px;
  width: 20px;
  height: 20px;
  background-color: rgba(255, 0, 0, 0.75);
  color: #fff;
  border: 1px solid red;
  border-radius: 50%;
  font-size: 12px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0;
  cursor: pointer;
}


.footer {
  background-color: #4698e6; /* #299684;*/
  color: #fff;
  text-align: center;
  font-size: 12px;
  margin-top: auto;
  height: 5vh;
}



