﻿:root {
  --background-dark-blue: #141C24;
  --primary-blue: rgb(149, 208, 233);
  --accent-blue: #2E86C1;
  --active-blue: #1F77D0;
  --text-color: #EBEBEB;
}

/* Flyout remains light (or update as needed) */
.flyout {
  position: fixed;
  top: 0;
  right: 0;
  width: 400px;
  height: 100%;
  background: #fff;
  box-shadow: -2px 0 5px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  overflow-y: auto;
  border-left: 1px solid #ccc;
}

/* General panel styles */
.author-assist .panel {
  height: 30%;
  padding: 20px;
  margin-bottom: 10px;
  text-align: center;
}

  /* Top and Bottom Panel Styles */
  .author-assist .panel.panel-top,
  .author-assist .panel.panel-bottom {
    background-color: var(--background-dark-blue);
    color: var(--primary-blue);
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
  }

.panel.panel-top table {
  margin: 0 auto;
  text-align: center;
  border-collapse: collapse;
}

.panel.panel-top th,
.panel.panel-top td {
  text-align: center;
  padding: 10px;
}

/* Middle Panel Styles */
.author-assist .panel.panel-middle {
  background-color: var(--background-dark-blue);
  color: var(--primary-blue);
  text-align: center;
  padding: 20px;
  margin-bottom: 10px;
}

  .author-assist .panel.panel-middle > h2 {
    font-weight: bold;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    margin-bottom: 10px;
    color: var(--primary-blue);
  }

  .author-assist .panel.panel-middle > p {
    font-weight: normal;
    font-family: 'Open Sans', sans-serif;
    font-size: 14px;
    margin: 0;
    color: var(--primary-blue);
  }

/* Form Section Styling */
.form-section {
  margin-top: 15px;
}

.form-row {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
}

.form-label {
  width: 30%;
  text-align: right;
  margin-right: 10px;
  font-weight: bold;
  color: var(--primary-blue);
}

.form-input-group {
  display: flex;
  align-items: center;
  flex-grow: 1;
  gap: 10px;
}

.form-control {
  flex: 1;
  padding: 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 14px;
  max-width: 400px;
}

/* Button for Keyword Search */
.btn-vsearch {
  background-color: var(--background-dark-blue) !important;
  color: var(--primary-blue) !important;
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  border: none !important;
  padding: 8px 15px !important;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.3s ease;
  margin-left: 0;
}

  .btn-vsearch:hover {
    background-color: var(--primary-blue) !important;
    color: var(--background-dark-blue) !important;
  }

/* Select dropdown styling */
.form-select {
  padding: 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 14px;
  max-width: 400px;
}

/* Voices Panel Styles */
.panel-voices {
  flex: 1;
  min-height: 280px;
  background-color: var(--background-dark-blue);
  padding: 10px;
  display: flex;
  flex-direction: row;
  gap: 20px;
  color: var(--text-color);
  font-family: 'Open Sans', sans-serif;
}

/* Content Section Styling */
.panel-voices-content {
  flex: 2;
  text-align: left;
}

  .panel-voices-content .panel-title {
    margin-bottom: 5px;
    font-weight: bold;
    font-size: 18px;
    color: var(--primary-blue);
  }

  .panel-voices-content .panel-description,
  .panel-voices-content .panel-instructions {
    margin: 0 0 10px;
    font-size: 14px;
    color: var(--primary-blue);
  }

  /* Form Section Styling in Voices Panel */
  .panel-voices-content .form-section {
    margin-top: 15px;
  }

  .panel-voices-content .form-row {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
  }

  .panel-voices-content .form-label {
    width: 30%;
    text-align: right;
    margin-right: 10px;
    font-weight: bold;
    color: var(--primary-blue);
  }

  .panel-voices-content .form-input-group {
    display: flex;
    align-items: center;
    flex-grow: 1;
    gap: 10px;
  }

  .panel-voices-content .form-control {
    flex: 1;
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
    max-width: 400px;
  }

  .panel-voices-content .btn-vsearch {
    background-color: var(--background-dark-blue) !important;
    color: var(--primary-blue) !important;
    font-family: 'Open Sans', sans-serif;
    font-size: 14px;
    border: none !important;
    padding: 8px 15px !important;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    margin-left: 0;
  }

    .panel-voices-content .btn-vsearch:hover {
      background-color: var(--primary-blue) !important;
      color: var(--background-dark-blue) !important;
    }

  .panel-voices-content .form-select {
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
    max-width: 400px;
  }

/* Dynamic Display Styling */
.panel-voices-bottom {
  flex: 1;
  background-color: var(--background-dark-blue);
  border: 1px solid #ccc;
  padding: 15px;
  height: 265px;
  overflow-y: auto;
}

/* Book Upload Panel Styles */
.panel-book-upload {
  flex: 1;
  min-height: 280px;
  background-color: var(--background-dark-blue);
  padding: 10px;
  display: flex;
  flex-direction: row;
  gap: 20px;
  color: var(--text-color);
  font-family: 'Open Sans', sans-serif;
}

/* Content Section Styling for Book Upload */
.panel-book-upload-content {
  flex: 2;
  text-align: left;
}

  .panel-book-upload-content .panel-title {
    margin-bottom: 5px;
    font-weight: bold;
    font-size: 18px;
    color: var(--primary-blue);
  }

  .panel-book-upload-content .panel-description,
  .panel-book-upload-content .panel-instructions {
    margin: 0 0 10px;
    font-size: 14px;
    color: var(--primary-blue);
  }

  /* Form Section Styling for Book Upload */
  .panel-book-upload-content .form-section {
    margin-top: 15px;
  }

  .panel-book-upload-content .form-row {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
  }

  .panel-book-upload-content .form-label {
    width: 30%;
    text-align: right;
    margin-right: 10px;
    font-weight: bold;
    color: var(--primary-blue);
  }

  .panel-book-upload-content .form-input-group {
    display: flex;
    align-items: center;
    flex-grow: 1;
    gap: 10px;
  }

  .panel-book-upload-content .form-control {
    flex: 1;
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
    max-width: 400px;
  }

  .panel-book-upload-content .btn-upload {
    background-color: var(--background-dark-blue) !important;
    color: var(--primary-blue) !important;
    font-family: 'Open Sans', sans-serif;
    font-size: 14px;
    border: none !important;
    padding: 8px 15px !important;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    margin-left: 0;
  }

    .panel-book-upload-content .btn-upload:hover {
      background-color: var(--primary-blue) !important;
      color: var(--background-dark-blue) !important;
    }

  .panel-book-upload-content .form-select {
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
    max-width: 400px;
  }

/* Dynamic Display Styling for Book Upload */
.panel-book-upload-bottom {
  flex: 1;
  background-color: var(--background-dark-blue);
  border: 1px solid #ccc;
  padding: 15px;
  height: 265px;
  overflow-y: auto;
}

/* Calculate Price Panel Styles */
.custom-calculate-price-panel {
  background-color: var(--background-dark-blue);
  padding: 20px;
  margin-top: 15px;
  border: 1px solid #ccc;
  border-radius: 8px;
  text-align: center;
  font-family: 'Open Sans', sans-serif;
}

.custom-centered-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  margin-top: 15px;
}

/* Example Price Display */
.custom-price-display {
  background-color: #000;
  color: #00ff00;
  font-weight: bold;
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  padding: 8px 12px;
  border-radius: 4px;
}

/* Approve Button Styling */
.custom-btn-approve {
  background-color: var(--background-dark-blue);
  color: var(--primary-blue);
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  border: none;
  padding: 10px 20px;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

  .custom-btn-approve:hover {
    background-color: var(--primary-blue);
    color: var(--background-dark-blue);
  }

/* Make Payment Button Styling */
.custom-btn-make-payment {
  background-color: #2E86C1;
  color: #fff;
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  border: none;
  padding: 10px 20px;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

  .custom-btn-make-payment:hover {
    background-color: #218838;
  }

  .custom-btn-make-payment:disabled,
  .custom-btn-convert:disabled {
    background-color: #555;
    color: #fff;
  }

/* New Panel Container */
.custom-panel-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 20px;
  margin-top: 15px;
}

/* Existing Panel Styles Adjustments */
.custom-panel-bottom {
  background-color: var(--background-dark-blue);
  color: var(--primary-blue);
  font-family: 'Open Sans', sans-serif;
  font-size: 18px;
  padding: 20px;
  margin-bottom: 10px;
  width: 48%;
  box-sizing: border-box;
  border: 1px solid #ccc;
  border-radius: 8px;
}

/* New Price Calculator Panel Styles */
.custom-panel-custom-right {
  background-color: #ffffff;
  color: var(--primary-blue);
  font-family: 'Open Sans', sans-serif;
  font-size: 16px;
  padding: 20px;
  margin-bottom: 10px;
  width: 48%;
  box-sizing: border-box;
  border: 1px solid #ccc;
  border-radius: 8px;
}

  .custom-panel-custom-right h3 {
    margin-bottom: 15px;
    color: var(--primary-blue);
  }

  .custom-panel-custom-right label {
    display: block;
    margin-bottom: 10px;
    font-weight: bold;
  }

  .custom-panel-custom-right input[type="number"] {
    width: 100%;
    padding: 8px;
    margin-bottom: 15px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
    box-sizing: border-box;
  }

  .custom-panel-custom-right button {
    padding: 10px 20px;
    background-color: var(--background-dark-blue);
    color: var(--primary-blue);
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    font-size: 14px;
    margin-bottom: 15px;
  }

    .custom-panel-custom-right button:hover:not(:disabled) {
      background-color: var(--primary-blue);
      color: var(--background-dark-blue);
    }

    .custom-panel-custom-right button:disabled {
      background-color: darkgray;
      color: white;
      cursor: not-allowed;
    }

  .custom-panel-custom-right p {
    font-weight: bold;
    margin-bottom: 15px;
  }

  .custom-panel-custom-right .approve-section {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
  }

    .custom-panel-custom-right .approve-section input[type="radio"] {
      transform: scale(1.2);
      cursor: pointer;
    }

    .custom-panel-custom-right .approve-section label {
      cursor: pointer;
    }

/* New Interest Form Section */
.custom-interest-form {
  margin-top: 20px;
  text-align: left;
}

  .custom-interest-form .custom-form-row {
    display: flex;
    flex-direction: column;
    margin-bottom: 15px;
  }

    .custom-interest-form .custom-form-row label {
      margin-bottom: 5px;
      font-weight: bold;
      color: var(--primary-blue);
    }

    .custom-interest-form .custom-form-row input,
    .custom-interest-form .custom-form-row select,
    .custom-interest-form .custom-form-row textarea {
      padding: 8px;
      border: 1px solid #ccc;
      border-radius: 4px;
      font-size: 14px;
      width: 100%;
      box-sizing: border-box;
    }

    .custom-interest-form .custom-form-row textarea {
      resize: vertical;
      height: 100px;
    }

  /* Submit Button Styling for Interest Form */
  .custom-interest-form .btn-send-note {
    padding: 10px 20px;
    background-color: var(--background-dark-blue);
    color: var(--primary-blue);
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    font-size: 14px;
  }

    .custom-interest-form .btn-send-note:hover {
      background-color: var(--primary-blue);
      color: var(--background-dark-blue);
    }

    .custom-interest-form .btn-send-note:disabled {
      background-color: darkgray;
      color: white;
      cursor: not-allowed;
    }

/* Responsive Adjustments */
@media (max-width: 768px) {
  .custom-panel-bottom,
  .custom-panel-custom-right {
    width: 100%;
  }
}



.side-by-side-container {
  display: flex;
  flex-direction: row;
  gap: 20px;
  align-items: flex-start;
  padding: 1rem;
}

.instructions {
  flex: 3;
  max-width: 600px;
}

.form-container {
  flex: 2;
  max-width: 400px;
  text-align: center;
}
/* Single media query for responsive stacking */
@media (max-width: 768px) {
  .side-by-side-container {
    flex-direction: column;
  }

  .instructions,
  .form-container {
    max-width: 100%;
  }
}

