@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans:wght@400;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Inter+Tight:ital,wght@0,100..900;1,100..900&family=Manrope:wght@200..800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap");
@font-face {
  font-family: "Geist";
  src: url("https://eventic-webapp.s3.ap-south-1.amazonaws.com/static/fonts/Geist/GeistVariableVF.woff2") format("woff2");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Google-sans";
  src: url("https://eventic-webapp.s3.ap-south-1.amazonaws.com/static/fonts/google-sans-cufonfonts/ProductSans-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "Google Sans Flex";
  src: url("https://db.onlinewebfonts.com/t/359daf377c374b65e821b9f218fc91ef.eot");
  src: url("https://db.onlinewebfonts.com/t/359daf377c374b65e821b9f218fc91ef.eot?#iefix") format("embedded-opentype"), url("https://db.onlinewebfonts.com/t/359daf377c374b65e821b9f218fc91ef.woff2") format("woff2"), url("https://db.onlinewebfonts.com/t/359daf377c374b65e821b9f218fc91ef.woff") format("woff"), url("https://db.onlinewebfonts.com/t/359daf377c374b65e821b9f218fc91ef.ttf") format("truetype"), url("https://db.onlinewebfonts.com/t/359daf377c374b65e821b9f218fc91ef.svg#Google Sans Flex") format("svg");
}
@font-face {
  font-family: "Roboto";
  src: url("https://eventic-webapp.s3.ap-south-1.amazonaws.com/static/fonts/Roboto/Roboto-Regular.ttf") format("truetype");
}
@font-face {
  font-family: "Platypi";
  src: url("https://eventic-webapp.s3.ap-south-1.amazonaws.com/static/fonts/Platypi/static/Platypi-Regular.ttf") format("truetype");
}
@font-face {
  font-family: "SF Pro", "SF Pro Text", "Myriad Set Pro", system-ui, "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
  src: url("https://eventic-webapp.s3.ap-south-1.amazonaws.com/static/fonts/SF-Pro/SFPRODISPLAYREGULAR.woff2") format("woff2");
  font-weight: normal;
}
@font-face {
  font-family: "Great Vibes";
  src: url("https://eventic-webapp.s3.ap-south-1.amazonaws.com/static/fonts/great-vibes/GreatVibes-Regular.ttf") format("truetype");
  font-weight: normal;
}
.geist {
  font-family: "Geist", "Open Sans", sans-serif !important;
}

.google-sans {
  font-family: "Google-sans", "Open Sans", sans-serif !important;
}

.poppins {
  font-family: "Poppins", sans-serif !important;
}

.roboto {
  font-family: "Roboto", sans-serif !important;
}

.platypi {
  font-family: "Platypi", sans-serif !important;
}

.sf-pro {
  font-family: "SF Pro", "Open Sans", Helvetica, sans-serif !important;
}

.playfair {
  font-family: "Playfair Display", serif !important;
}

.noto-sans {
  font-family: "Noto Sans", sans-serif !important;
}

.great-vibes {
  font-family: "Great Vibes" !important;
}

.inter {
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif !important;
}

.inter-tight {
  font-family: "Inter Tight", "Manrope", sans-serif !important;
}

.custom-scrollbar::-webkit-scrollbar {
  width: 8px;
  height: 0;
}

.custom-scrollbar::-webkit-scrollbar-thumb {
  background-color: rgb(217, 224, 231);
  border-radius: 8px;
}

.overflow-x-hidden {
  overflow-x: hidden;
}

.overflow-y-hidden {
  overflow-y: hidden;
}

.ls-0 {
  letter-spacing: 0px;
}

.ls-1 {
  letter-spacing: 1px;
}

.ls-2 {
  letter-spacing: 2px;
}

.ls-3 {
  letter-spacing: 3px;
}

.ls-4 {
  letter-spacing: 4px;
}

.ls-5 {
  letter-spacing: 5px;
}

label.form-check-label {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.dropdown-item-danger {
  color: #dc3545;
  background: transparent;
}

.dropdown-item-danger:focus,
.dropdown-item-danger:hover {
  color: #bd362f;
  background: #f8f9fa;
}

label.switch {
  position: relative;
  display: inline-block;
  width: 58px;
  height: 32px;
}
label.switch input[type=checkbox] {
  opacity: 0;
  width: 0;
  height: 0;
}
label.switch input[type=checkbox]:checked + .slider {
  background-color: #2196f3;
}
label.switch input[type=checkbox]:focus + .slider {
  box-shadow: 0 0 1px #2196f3;
}
label.switch input[type=checkbox]:checked + .slider:before {
  transform: translateX(26px);
}
label.switch span.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: 0.4s;
}
label.switch span.slider:before {
  position: absolute;
  content: "";
  height: 24px;
  width: 24px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  transition: 0.4s;
}
label.switch span.round {
  border-radius: 34px;
}
label.switch span.round:before {
  border-radius: 50%;
}

.no-results-box {
  padding: 50px;
  border-radius: 32px;
  background: #fff;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.no-results-box h2 {
  font-size: 2rem;
  margin-bottom: 16px;
}
.no-results-box h3 {
  font-size: 2.5rem;
  font-weight: 700;
  color: #606e9a;
  opacity: 0.4;
  font-family: "Poppins", sans-serif;
}
.no-results-box p {
  font-size: 1rem;
  max-width: 560px;
}

.btn-theme-blue {
  background: #4364d3;
  color: #ffffff;
  transition: all 0.25s ease-in-out;
}
.btn-theme-blue:hover {
  background: #3b59ba;
  color: #ffffff;
}

.btn-outline-theme-blue {
  border-color: #4364d3;
  color: #4364d3;
  transition: all 0.25s ease-in-out;
}
.btn-outline-theme-blue:hover {
  background: #4364d3;
  color: #ffffff;
}

@supports (-webkit-appearance: none) or (-moz-appearance: none) {
  .checkbox-wrapper label {
    cursor: pointer;
  }
  .checkbox-wrapper input[type=checkbox] {
    margin: 0;
    margin-top: 2px;
    --active: #275efe;
    --active-inner: #fff;
    --focus: 2px rgba(39, 94, 254, 0.3);
    --border: #bbc1e1;
    --border-hover: #275efe;
    --background: #fff;
    --disabled: #f6f8ff;
    --disabled-inner: #e1e6f9;
    -webkit-appearance: none;
    -moz-appearance: none;
    height: 22px;
    outline: none;
    display: inline-block;
    vertical-align: top;
    position: relative;
    cursor: pointer;
    box-shadow: none !important;
    border: 1px solid var(--bc, var(--border));
    background: var(--b, var(--background));
    transition: background 0.3s, border-color 0.3s, box-shadow 0.2s;
  }
  .checkbox-wrapper input[type=checkbox]:after {
    content: "";
    display: block;
    left: 0;
    top: 0;
    position: absolute;
    transition: transform var(--d-t, 0.3s) var(--d-t-e, ease), opacity var(--d-o, 0.2s);
  }
  .checkbox-wrapper input[type=checkbox]:checked {
    --b: var(--active);
    --bc: var(--active);
    --d-o: 0.3s;
    --d-t: 0.6s;
    --d-t-e: cubic-bezier(0.2, 0.85, 0.32, 1.2);
  }
  .checkbox-wrapper input[type=checkbox]:disabled {
    --b: var(--disabled);
    cursor: not-allowed;
    opacity: 0.9;
  }
  .checkbox-wrapper input[type=checkbox]:disabled:checked {
    --b: var(--disabled-inner);
    --bc: var(--border);
  }
  .checkbox-wrapper input[type=checkbox]:disabled + label {
    cursor: not-allowed;
  }
  .checkbox-wrapper input[type=checkbox]:hover:not(:checked):not(:disabled) {
    --bc: var(--border-hover);
  }
  .checkbox-wrapper input[type=checkbox]:focus {
    box-shadow: 0 0 0 var(--focus);
  }
  .checkbox-wrapper input[type=checkbox]:not(.switch) {
    width: 21px;
  }
  .checkbox-wrapper input[type=checkbox]:not(.switch):after {
    opacity: var(--o, 0);
  }
  .checkbox-wrapper input[type=checkbox]:not(.switch):checked {
    --o: 1;
  }
  .checkbox-wrapper input[type=checkbox] + label {
    display: inline-block;
    vertical-align: middle;
    cursor: pointer;
    margin-left: 4px;
  }
  .checkbox-wrapper input[type=checkbox]:not(.switch) {
    border-radius: 7px;
  }
  .checkbox-wrapper input[type=checkbox]:not(.switch):after {
    width: 5px;
    height: 9px;
    border: 2px solid var(--active-inner);
    border-top: 0;
    border-left: 0;
    left: 7px;
    top: 4px;
    transform: rotate(var(--r, 20deg));
  }
  .checkbox-wrapper input[type=checkbox]:not(.switch):checked {
    --r: 43deg;
  }
  .checkbox-wrapper input[type=checkbox].switch {
    width: 38px;
    border-radius: 11px;
  }
  .checkbox-wrapper input[type=checkbox].switch:after {
    left: 2px;
    top: 2px;
    border-radius: 50%;
    width: 17px;
    height: 17px;
    background: var(--ab, var(--border));
    transform: translateX(var(--x, 0));
  }
  .checkbox-wrapper input[type=checkbox].switch:checked {
    --ab: var(--active-inner);
    --x: 17px;
  }
  .checkbox-wrapper input[type=checkbox].switch:disabled:not(:checked):after {
    opacity: 0.6;
  }
}
.checkbox-wrapper * {
  box-sizing: inherit;
}

.checkbox-wrapper *:before,
.checkbox-wrapper *:after {
  box-sizing: inherit;
}

/* From Uiverse.io by alexruix */
.square-box-loader {
  width: 48px;
  height: 48px;
  margin: auto;
  position: relative;
}

.square-box-loader:before {
  content: "";
  width: 48px;
  height: 5px;
  background: rgba(67, 101, 211, 0.2980392157);
  position: absolute;
  top: 60px;
  left: 0;
  border-radius: 50%;
  animation: shadow324 0.5s linear infinite;
}

.square-box-loader:after {
  content: "";
  width: 100%;
  height: 100%;
  background: #4364d3;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 4px;
  animation: jump7456 0.5s linear infinite;
}

.overlay-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.5);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  display: none;
  z-index: 9999;
}
.overlay-loader .loading-container {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
}

@keyframes jump7456 {
  15% {
    border-bottom-right-radius: 3px;
  }
  25% {
    transform: translateY(9px) rotate(22.5deg);
  }
  50% {
    transform: translateY(18px) scale(1, 0.9) rotate(45deg);
    border-bottom-right-radius: 40px;
  }
  75% {
    transform: translateY(9px) rotate(67.5deg);
  }
  100% {
    transform: translateY(0) rotate(90deg);
  }
}
@keyframes shadow324 {
  0%, 100% {
    transform: scale(1, 1);
  }
  50% {
    transform: scale(1.2, 1);
  }
}
/* HTML: <div class="loader"></div> */
.box-circle-loader {
  width: 65px;
  aspect-ratio: 1;
  position: relative;
}

.box-circle-loader:before,
.box-circle-loader:after {
  content: "";
  position: absolute;
  border-radius: 50px;
  box-shadow: 0 0 0 3px inset #1a1a1a;
  animation: l5 2.5s infinite;
}

.box-circle-loader:after {
  animation-delay: -1.25s;
  border-radius: 0;
}

@keyframes l5 {
  0% {
    inset: 0 35px 35px 0;
  }
  12.5% {
    inset: 0 35px 0 0;
  }
  25% {
    inset: 35px 35px 0 0;
  }
  37.5% {
    inset: 35px 0 0 0;
  }
  50% {
    inset: 35px 0 0 35px;
  }
  62.5% {
    inset: 0 0 0 35px;
  }
  75% {
    inset: 0 0 35px 35px;
  }
  87.5% {
    inset: 0 0 35px 0;
  }
  100% {
    inset: 0 35px 35px 0;
  }
}
.heart-loader {
  width: 50px;
  aspect-ratio: 1;
  color: #dc1818;
  background: radial-gradient(circle at 60% 65%, currentColor 62%, rgba(0, 0, 0, 0) 65%) top left, radial-gradient(circle at 40% 65%, currentColor 62%, rgba(0, 0, 0, 0) 65%) top right, linear-gradient(to bottom left, currentColor 42%, rgba(0, 0, 0, 0) 43%) bottom left, linear-gradient(to bottom right, currentColor 42%, rgba(0, 0, 0, 0) 43%) bottom right;
  background-size: 50% 50%;
  background-repeat: no-repeat;
  position: relative;
}

.heart-loader:after {
  content: "";
  position: absolute;
  inset: 0;
  background: inherit;
  opacity: 0.4;
  animation: l3 1s infinite;
}

@keyframes l3 {
  to {
    transform: scale(1.8);
    opacity: 0;
  }
}
.feature-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 768px) {
  .feature-container {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}
.feature-container .feature-box {
  position: relative;
  padding: 24px;
  border-radius: 32px;
  background-color: #f8f9fa;
  background-image: linear-gradient(120deg, #fdfbfb 0%, #ebedee 100%);
  height: 100%;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 8px;
  transition: all 0.3s ease-in-out;
}
.feature-container .feature-box:hover {
  box-shadow: rgba(0, 0, 0, 0.1) -4px 9px 25px -6px;
}
@media (max-width: 768px) {
  .feature-container .feature-box {
    padding: 16px;
    border-radius: 24px;
    gap: 6px;
  }
}
.feature-container .feature-box h6 {
  font-size: 2.5rem;
  margin-bottom: 0;
  background: #1321DE;
  background: linear-gradient(to bottom right, #1321DE 0%, #110348 100%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media (max-width: 768px) {
  .feature-container .feature-box h6 {
    font-size: 2rem;
  }
}
.feature-container .feature-box p {
  font-size: 1rem;
  font-weight: 400;
  color: #606065;
  margin-bottom: 0;
}
.feature-container .feature-box .tooltip-box {
  position: absolute;
  top: 18px;
  right: 18px;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas: "tooltip-text tooltip-button";
  align-items: flex-start;
  gap: 4px;
}
.feature-container .feature-box .tooltip-box .tooltip-text {
  grid-area: tooltip-text;
  visibility: hidden;
  display: none;
  margin-left: auto;
  width: calc(100% - 18px);
  background-color: #232323;
  color: #fff;
  text-align: start;
  font-size: 0.875rem;
  border-radius: 16px;
  padding: 12px;
  z-index: 1000;
  opacity: 0;
  transition: display 0.3s, opacity 0.3s, visibility 0.3s ease-in-out;
}
.feature-container .feature-box .tooltip-box .tooltip-text a {
  color: #e1b94d;
  text-decoration: none;
}
.feature-container .feature-box .tooltip-box button.feature-info-btn {
  grid-area: tooltip-button;
  border: none;
  background: none;
  color: #606065;
  font-size: 1rem;
  padding: 0;
  cursor: pointer;
}
.feature-container .feature-box .tooltip-box button.feature-info-btn:hover, .feature-container .feature-box .tooltip-box button.feature-info-btn:focus {
  color: #000000;
  outline: none;
}
.feature-container .feature-box .tooltip-box:hover .tooltip-text,
.feature-container .feature-box .tooltip-box button.feature-info-btn:focus + .tooltip-text {
  visibility: visible;
  display: block;
  opacity: 1;
}
.feature-container .feature-box button.add-feature-btn {
  margin-top: auto;
  margin-left: auto;
  border: none;
  background-image: linear-gradient(60deg, #29323c 0%, #485563 100%);
  font-size: 1.25rem;
  height: 42px;
  width: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
  cursor: pointer;
  color: #f4f4f4;
  transition: all 0.3s ease-in-out;
}
.feature-container .feature-box button.add-feature-btn:hover {
  color: #ffffff;
  background-image: linear-gradient(to right, #434343 0%, black 100%);
  transform: scale(1.1);
}
@media (max-width: 768px) {
  .feature-container .feature-box button.add-feature-btn {
    font-size: 1rem;
    height: 32px;
    width: 32px;
  }
}

.selected-features-notification {
  position: sticky;
  top: 20px;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  border-radius: 16px;
  padding: 16px;
  margin-top: 24px;
  box-shadow: 0 4px 20px rgba(102, 126, 234, 0.25);
  z-index: 100;
  animation: slideInUp 0.4s ease-out;
}
.selected-features-notification .notification-header {
  margin-bottom: 12px;
}
.selected-features-notification .notification-header h6 {
  color: white;
  font-size: 1.1rem;
  margin: 0;
  font-weight: 600;
}
.selected-features-notification .notification-header h6 i {
  color: #4ade80;
  margin-right: 8px;
}
.selected-features-notification .notification-body .selected-features-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.selected-features-notification .notification-body .feature-tag {
  background: rgba(255, 255, 255, 0.2);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: white;
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 0.875rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s ease;
}
.selected-features-notification .notification-body .feature-tag:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: translateY(-1px);
}
.selected-features-notification .notification-body .feature-tag .remove-feature {
  background: none;
  border: none;
  color: white;
  padding: 0;
  margin-left: 4px;
  cursor: pointer;
  font-size: 0.75rem;
  opacity: 0.8;
  transition: opacity 0.2s ease;
}
.selected-features-notification .notification-body .feature-tag .remove-feature:hover {
  opacity: 1;
}

.feature-box.selected {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
  box-shadow: 0 8px 25px rgba(102, 126, 234, 0.3);
}
.feature-box.selected h6 {
  background: white;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.feature-box.selected p {
  color: rgba(255, 255, 255, 0.9);
}
.feature-box.selected .add-feature-btn {
  background: rgba(255, 255, 255, 0.2);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  color: white;
}
.feature-box.selected .add-feature-btn:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: scale(1.1);
}
.feature-box.selected .add-feature-btn i:before {
  content: "\f78b";
}
.feature-box.selected .tooltip-box button.feature-info-btn {
  color: rgba(255, 255, 255, 0.8);
}
.feature-box.selected .tooltip-box button.feature-info-btn:hover, .feature-box.selected .tooltip-box button.feature-info-btn:focus {
  color: white;
}

@keyframes slideInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.rsvp-form-builder .guest-count-container .form-label {
  font-weight: 600;
  color: #495057;
  margin-bottom: 8px;
}
.rsvp-form-builder .guest-count-container .input-group {
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
  border-radius: 8px;
  overflow: hidden;
}
.rsvp-form-builder .guest-count-container .input-group .btn {
  border-color: #dee2e6;
  background-color: #f8f9fa;
  color: #6c757d;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 45px;
  font-weight: 500;
  border-radius: 0;
  position: relative;
}
.rsvp-form-builder .guest-count-container .input-group .btn:first-child {
  border-top-left-radius: 8px;
  border-bottom-left-radius: 8px;
}
.rsvp-form-builder .guest-count-container .input-group .btn:last-child {
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
}
.rsvp-form-builder .guest-count-container .input-group .btn:hover:not(:disabled) {
  background-color: #e9ecef;
  border-color: #adb5bd;
  color: #495057;
  transform: translateY(-1px);
  z-index: 2;
}
.rsvp-form-builder .guest-count-container .input-group .btn:active, .rsvp-form-builder .guest-count-container .input-group .btn.btn-pressed {
  background-color: #dee2e6 !important;
  border-color: #adb5bd !important;
  transform: translateY(0);
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}
.rsvp-form-builder .guest-count-container .input-group .btn:disabled, .rsvp-form-builder .guest-count-container .input-group .btn.disabled {
  background-color: #f1f3f4;
  border-color: #e9ecef;
  color: #adb5bd;
  cursor: not-allowed;
  opacity: 0.6;
  transform: none;
}
.rsvp-form-builder .guest-count-container .input-group .btn:disabled:hover, .rsvp-form-builder .guest-count-container .input-group .btn.disabled:hover {
  background-color: #f1f3f4;
  border-color: #e9ecef;
  color: #adb5bd;
  transform: none;
  z-index: auto;
}
.rsvp-form-builder .guest-count-container .input-group .btn i {
  font-size: 1rem;
  line-height: 1;
}
.rsvp-form-builder .guest-count-container .input-group .form-control {
  border-color: #dee2e6;
  background-color: #fff;
  font-weight: 600;
  font-size: 1.1rem;
  box-shadow: none;
  padding: 12px;
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  z-index: 1;
}
.rsvp-form-builder .guest-count-container .input-group .form-control:focus {
  border-color: #007bff;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
  background-color: #fff;
  z-index: 3;
}
.rsvp-form-builder .guest-count-container .input-group .form-control:-moz-read-only {
  background-color: #fff;
  cursor: default;
}
.rsvp-form-builder .guest-count-container .input-group .form-control:read-only {
  background-color: #fff;
  cursor: default;
}
.rsvp-form-builder .guest-count-container .text-muted {
  font-size: 0.875rem;
  margin-top: 6px;
  padding-left: 4px;
}
@media (max-width: 768px) {
  .rsvp-form-builder .guest-count-container .input-group .btn {
    min-width: 40px;
    padding: 10px 8px;
  }
  .rsvp-form-builder .guest-count-container .input-group .form-control {
    font-size: 1rem;
    padding: 10px;
  }
  .rsvp-form-builder .guest-count-container .text-muted {
    font-size: 0.8rem;
  }
}
.rsvp-form-builder .guest-count-container .input-group .form-control {
  transition: all 0.3s ease;
}
.rsvp-form-builder .guest-count-container .input-group .form-control.value-changed {
  background-color: #e7f3ff;
  animation: valueHighlight 0.6s ease;
}
@keyframes valueHighlight {
  0% {
    background-color: #e7f3ff;
  }
  50% {
    background-color: #cce7ff;
  }
  100% {
    background-color: #fff;
  }
}
.rsvp-form-builder .questions-container {
  min-height: 200px;
  border: 2px dashed #e9ecef;
  border-radius: 8px;
  padding: 12px;
  background-color: #f8f9fa;
}
@media (max-width: 768px) {
  .rsvp-form-builder .questions-container {
    padding: 8px;
  }
}
.rsvp-form-builder .questions-container.has-questions {
  border-style: solid;
  background-color: transparent;
}
.rsvp-form-builder .question-item {
  background: white;
  border: 1px solid #dee2e6;
  border-radius: 8px;
  margin-bottom: 12px;
  padding: 16px;
  transition: all 0.3s ease;
  -webkit-user-select: text;
     -moz-user-select: text;
          user-select: text;
}
.rsvp-form-builder .question-item:hover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.rsvp-form-builder .question-item.moving {
  transform: translateY(-5px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  z-index: 10;
}
@media (max-width: 768px) {
  .rsvp-form-builder .question-item {
    padding: 12px;
    margin-bottom: 10px;
  }
}
.rsvp-form-builder .question-item .form-control, .rsvp-form-builder .question-item .form-select {
  box-shadow: none !important;
  border: 1px solid #dee2e6;
}
.rsvp-form-builder .question-item .form-control:focus, .rsvp-form-builder .question-item .form-select:focus {
  box-shadow: none !important;
  border-color: #007bff;
}
.rsvp-form-builder .question-item .question-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}
.rsvp-form-builder .question-item .question-header .question-controls {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.rsvp-form-builder .question-item .question-header .question-controls .move-btn {
  background: #f8f9fa;
  border: 1px solid #dee2e6;
  color: #6c757d;
  padding: 4px 6px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.75rem;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
}
.rsvp-form-builder .question-item .question-header .question-controls .move-btn:hover {
  background: #e9ecef;
  color: #495057;
  border-color: #adb5bd;
}
.rsvp-form-builder .question-item .question-header .question-controls .move-btn:active {
  background: #dee2e6;
}
.rsvp-form-builder .question-item .question-header .question-controls .move-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.rsvp-form-builder .question-item .question-header .question-controls .move-btn:disabled:hover {
  background: #f8f9fa;
  color: #6c757d;
  border-color: #dee2e6;
}
.rsvp-form-builder .question-item .question-header .question-controls .move-btn i {
  font-size: 0.8rem;
}
.rsvp-form-builder .question-item .question-header .question-content {
  flex: 1;
}
.rsvp-form-builder .question-item .question-header .question-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.rsvp-form-builder .question-item .question-header .question-actions .btn {
  padding: 4px 8px;
  font-size: 0.875rem;
}
.rsvp-form-builder .question-item .question-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 12px;
  margin-top: 12px;
  border-top: 1px solid #e9ecef;
  width: 100%;
}
.rsvp-form-builder .question-item .question-footer .form-check {
  margin-bottom: 0;
  flex-shrink: 0;
}
.rsvp-form-builder .question-item .question-footer .btn {
  padding: 4px 8px;
  font-size: 0.875rem;
  flex-shrink: 0;
  border: none;
  box-shadow: none;
}
.rsvp-form-builder .question-item .question-type-badge {
  margin-bottom: 12px;
}
.rsvp-form-builder .question-item .question-type-badge .badge {
  font-size: 0.75rem;
}
.rsvp-form-builder .question-item .question-options {
  padding-left: 24px;
}
.rsvp-form-builder .question-item .question-options .option-item {
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.rsvp-form-builder .question-item .question-options .option-item .input-group-text {
  background-color: transparent;
  border: none;
  color: #6c757d;
}
.rsvp-form-builder .question-item .question-options .option-item .btn-remove-option {
  border-left: 1px solid #dee2e6;
  border-top: none;
  border-right: none;
  border-bottom: none;
  box-shadow: none;
}
.rsvp-form-builder .question-item .question-options .option-item .btn-remove-option:focus, .rsvp-form-builder .question-item .question-options .option-item .btn-remove-option:active {
  box-shadow: none !important;
}
.rsvp-form-builder .question-item .question-options .add-option-btn {
  color: #6c757d;
  text-decoration: none;
  font-size: 0.875rem;
  padding: 4px 8px;
  border-radius: 4px;
  transition: all 0.2s ease;
}
.rsvp-form-builder .question-item .question-options .add-option-btn:hover {
  background-color: #f8f9fa;
  color: #495057;
  text-decoration: none;
}
.rsvp-form-builder .form-preview .card {
  border: 1px solid #e9ecef;
  background-color: #f8f9fa;
}
.rsvp-form-builder .form-preview .card .card-title {
  color: #495057;
  font-size: 1rem;
  margin-bottom: 16px;
}
.rsvp-form-builder .form-preview .preview-question {
  margin-bottom: 20px;
  padding: 12px;
  background: white;
  border-radius: 6px;
  border-left: 3px solid #007bff;
}
.rsvp-form-builder .form-preview .preview-question .preview-question-title {
  font-weight: 500;
  margin-bottom: 8px;
  color: #495057;
}
.rsvp-form-builder .form-preview .preview-question .preview-question-required {
  color: #dc3545;
  font-size: 0.875rem;
}
.rsvp-form-builder .form-preview .preview-question .form-control, .rsvp-form-builder .form-preview .preview-question .form-select, .rsvp-form-builder .form-preview .preview-question .form-check-input {
  margin-top: 8px;
}
.rsvp-form-builder .form-preview .preview-question .form-check {
  margin-bottom: 4px;
}
.rsvp-form-builder .form-preview .preview-question .form-check .form-check-label {
  padding-top: 4px;
}
.rsvp-form-builder .form-preview .preview-question .rating-stars {
  display: flex;
  gap: 4px;
}
.rsvp-form-builder .form-preview .preview-question .rating-stars .star {
  color: #e0e0e0;
  cursor: pointer;
  font-size: 2rem;
  transition: color 0.2s ease;
}
.rsvp-form-builder .form-preview .preview-question .rating-stars .star:hover, .rsvp-form-builder .form-preview .preview-question .rating-stars .star.selected {
  color: #ffc107;
}
.rsvp-form-builder .empty-state {
  text-align: center;
  padding: 40px 20px;
  color: #6c757d;
}
.rsvp-form-builder .empty-state i {
  font-size: 3rem;
  margin-bottom: 16px;
  color: #dee2e6;
}
.rsvp-form-builder .empty-state h6 {
  margin-bottom: 8px;
}
.rsvp-form-builder .empty-state p {
  font-size: 0.875rem;
  margin-bottom: 0;
}

.registry-type-card {
  cursor: pointer;
  transition: all 0.3s ease;
  border: 2px solid transparent;
}
.registry-type-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}
.registry-type-card.border-primary {
  border-color: #007bff !important;
}
.registry-type-card.border-success {
  border-color: #28a745 !important;
}
.registry-type-card .display-4 {
  font-size: 2.5rem;
}

.registry-section {
  border: 1px solid #e9ecef;
  border-radius: 8px;
  padding: 20px;
  background-color: #fafafa;
  margin-bottom: 20px;
}

.third-party-container,
.custom-gifts-container {
  min-height: 100px;
}
.third-party-container .card,
.custom-gifts-container .card {
  transition: all 0.3s ease;
}
.third-party-container .card:hover,
.custom-gifts-container .card:hover {
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.registry-item .card-body,
.gift-item .card-body {
  position: relative;
}
.registry-item .form-control, .registry-item .form-select,
.gift-item .form-control,
.gift-item .form-select {
  box-shadow: none !important;
  border: 1px solid #dee2e6;
}
.registry-item .form-control:focus, .registry-item .form-select:focus,
.gift-item .form-control:focus,
.gift-item .form-select:focus {
  box-shadow: none !important;
  border-color: #007bff;
}

.registry-preview {
  margin-top: 16px;
}
.registry-preview .alert {
  margin-bottom: 0;
  font-size: 0.875rem;
}

.gift-priority-badge.priority-high {
  background-color: #dc3545;
}
.gift-priority-badge.priority-medium {
  background-color: #ffc107;
  color: #000;
}
.gift-priority-badge.priority-low {
  background-color: #6c757d;
}

#paymentContainer {
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  line-height: 1.25;
}
#paymentContainer td {
  line-height: 1.5 !important;
}
#paymentContainer .semibold {
  font-weight: 500;
}
#paymentContainer .price-box {
  color: #222222;
}
#paymentContainer .price-box .main-amount {
  font-size: 32px;
  font-size: clamp(28px, 3vw, 32px);
  font-weight: 600;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  display: inline-block; /* Essential for transform to work correctly on inline elements */
  transform: scaleY(1.07); /* Stretches the text vertically by a factor of 2 */
  transform-origin: center; /* Ensures scaling happens from the center of the text */
  line-height: 1;
}

/* --- FAQs --- */
.eventic-faq {
  max-width: 700px;
  margin: 60px auto;
  padding: 0;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  color: #222;
}

.faq-header {
  margin-bottom: 32px;
  text-align: center;
}

.faq-header h2 {
  font-family: "Poppins", sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: 4px;
  text-align: center;
}

.faq-header p {
  color: #444;
  font-size: 0.9rem;
  text-align: center;
}

.faq-wrapper {
  border-top: 1px solid #efefef;
}

.faq-item {
  border-bottom: 1px solid #efefef;
  transition: background-color 0.2s ease;
}

.faq-item:hover {
  background-color: #fcfcfc;
}

.faq-toggle {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  outline: none;
}

.faq-question {
  font-family: "Poppins", sans-serif;
  font-size: 1rem;
  font-weight: 500;
  color: #222;
  padding-right: 20px;
}

.faq-chevron {
  flex-shrink: 0;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  color: #444;
  height: 12px;
  width: 12px;
}

/* Logic for opening */
.faq-collapse {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
}

.faq-item.active .faq-collapse {
  grid-template-rows: 1fr;
}

.faq-item.active .faq-chevron {
  transform: rotate(180deg);
  color: #222;
}

.faq-content {
  min-height: 0;
  font-size: 0.95rem;
  line-height: 1.6;
  color: #444;
  padding: 0 20px;
  opacity: 0;
  transition: opacity 0.3s ease, padding 0.3s ease;
}

.faq-item.active .faq-content {
  padding: 0 20px 20px 20px;
  opacity: 1;
  transition-delay: 0.1s;
}
.faq-item.active .faq-content a {
  color: #06c;
  text-decoration: none;
  transition: -webkit-text-decoration 0.3s ease;
  transition: text-decoration 0.3s ease;
  transition: text-decoration 0.3s ease, -webkit-text-decoration 0.3s ease;
}
.faq-item.active .faq-content a:hover {
  text-decoration: underline;
}

/* --- END FAQs --- */
.model-box[data-model=login-tab] .form-container {
  background: #ffffff;
}
.model-box[data-model=login-tab] .form-container .form-header {
  background: rgba(255, 255, 255, 0.8);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}
.model-box[data-model=login-tab] .form-container .form-header .form-title h5 {
  font-weight: 600;
  font-size: 16px;
  margin: 0;
  color: #1d1d1f;
  letter-spacing: -0.01em;
}
.model-box[data-model=login-tab] .form-container .form-header .form-close button.edit-modal-close {
  background: #f5f5f7;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border: none;
  transition: all 0.2s;
  cursor: pointer;
}
.model-box[data-model=login-tab] .form-container .form-header .form-close button.edit-modal-close i {
  font-size: 12px;
  color: #86868b;
  -webkit-text-stroke: 1px;
}
.model-box[data-model=login-tab] .form-container .form-body {
  padding-top: 80px;
}
.model-box[data-model=login-tab] .form-container .form-body .fade-in-up h3 {
  font-family: "Inter", sans-serif;
  font-weight: 700;
  color: #1d1d1f;
  margin-bottom: 12px;
  font-size: 32px;
  letter-spacing: -0.03em;
}
.model-box[data-model=login-tab] .form-container .form-body .fade-in-up p {
  color: #86868b;
  font-size: 16px;
  line-height: 1.5;
  max-width: 280px;
  margin: 0 auto;
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up {
  max-width: 360px;
  animation-delay: 0.1s;
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up .btn {
  border: 1px solid #e5e5ea;
  background: white;
  height: 52px;
  border-radius: 14px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  color: #1d1d1f;
  font-weight: 500;
  font-family: "Inter", sans-serif;
  font-size: 15px;
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up .btn img {
  width: 22px;
  height: 22px;
  position: absolute;
  left: 20px;
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up .btn img[alt=Facebook] {
  width: 24px;
  height: 24px;
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up .btn i.bi-envelope {
  position: absolute;
  left: 20px;
  color: #1d1d1f;
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up .position-relative.my-4.text-center hr {
  border-top: 1px solid #e5e5ea;
  opacity: 1;
  margin: 0;
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up .position-relative.my-4.text-center span {
  background: white;
  padding: 0 10px;
  color: #86868b;
  font-size: 13px;
  transform: translateY(-50%);
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up p.text-center.mt-4 {
  font-size: 12px;
  color: #86868b;
}
.model-box[data-model=login-tab] .form-container .form-body .w-100.px-4.fade-in-up p.text-center.mt-4 a {
  color: #06c;
  text-decoration: none;
}

.hover-lift:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  background: #fbfbfd !important;
  border-color: #d1d1d6 !important;
}
.hover-lift:active {
  transform: translateY(0);
  background: #f1f1f1 !important;
}

.fade-in-up {
  animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  opacity: 0;
  transform: translateY(20px);
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.theme-info-container {
  display: grid;
  grid-template-rows: auto 1fr auto;
  grid-template-areas: "header" "content" "footer";
  position: relative;
  height: 100svh;
  padding: 0;
  width: 100%;
}
.theme-info-container .theme-info-header {
  grid-area: header;
  padding: 24px;
  width: 100%;
  background: #ffffff;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 8px;
  z-index: 1000;
}
.theme-info-container .theme-info-header a.back-to-previous-page {
  padding: 8px 16px;
  border-radius: 50px;
  font-size: 14px;
  color: #4d565f;
  border: 1px solid rgba(77, 86, 95, 0.4431372549);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
}
.theme-info-container .theme-info-header a.back-to-previous-page:hover {
  color: #222;
}
.theme-info-container .theme-info-header a.back-to-previous-page i {
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.theme-info-container .theme-info-header button.select-country-currency-btn {
  background: rgba(248, 249, 250, 0.5764705882);
  color: #4d545b;
  padding: 8px 16px;
  border-radius: 50px;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.3s ease-in-out;
}
.theme-info-container .theme-info-header button.select-country-currency-btn:hover {
  background: #e7e9eb;
  color: #1c1c1c;
}
.theme-info-container .theme-info-header button.select-country-currency-btn i {
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.theme-info-container .theme-info-header button.select-country-currency-btn img {
  height: 18px;
  width: auto;
  margin-bottom: 4px;
}
.theme-info-container .theme-info-header .btn-close-tab {
  background: rgba(248, 249, 250, 0.5764705882);
  color: #4d545b;
  height: 42px;
  width: 42px;
  border-radius: 50%;
  font-size: 16px;
  border: none;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: all 0.3s ease-in-out;
}
.theme-info-container .theme-info-header .btn-close-tab:hover {
  background: #e7e9eb;
  color: #1c1c1c;
}
.theme-info-container .theme-info-content {
  grid-area: content;
  padding: 4px 24px 8px 24px;
  width: 100%;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  scroll-behavior: smooth;
  overflow-x: hidden;
  overflow-y: auto;
  height: 100%;
}
.theme-info-container .theme-info-content::-webkit-scrollbar {
  width: 0;
}
.theme-info-container .theme-info-content .theme-title-text {
  font-size: 12px;
  font-weight: 400;
  color: #222;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  margin-bottom: 8px;
}
.theme-info-container .theme-info-content .theme-title-name {
  font-size: 2.5rem;
  font-weight: 600;
  margin-bottom: 8px;
  margin-top: 0;
  line-height: 1.1;
  font-family: "Inter Tight", "Manrope", sans-serif;
  font-optical-sizing: auto;
  color: #1c1c1c;
}
.theme-info-container .theme-info-content .theme-description {
  padding: 12px;
  border-radius: 12px;
  background: #f9f9f9;
  margin-bottom: 12px;
}
.theme-info-container .theme-info-content .theme-description .theme-info-description {
  font-size: 14px;
  line-height: 20px;
  color: #333;
  margin-bottom: 8px;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
}
.theme-info-container .theme-info-content .theme-description .read-more-button {
  font-size: 14px;
  line-height: 18px;
  font-weight: 500;
  color: #0071e3;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  text-decoration: none;
}
.theme-info-container .theme-info-content .theme-description .read-more-button:hover {
  color: #0062c4;
}
.theme-info-container .theme-info-content .ratings-box {
  margin-bottom: 12px;
}
.theme-info-container .theme-info-content .ratings-box .ratings {
  font-size: 24px;
  color: #222222;
  font-weight: 500;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  letter-spacing: 0.05em;
  line-height: 1;
}
.theme-info-container .theme-info-content .ratings-box .ratings small {
  font-size: 14px;
  font-weight: 400;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
}
.theme-info-container .theme-info-content .ratings-box .ratings .gradient-icon {
  display: inline-block;
  background: linear-gradient(to right, #b99010, #e8ca2c, #b99010);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.theme-info-container .theme-info-content .ratings-box .ratings .gradient-icon i {
  font-size: 24px; /* Adjust size */
}
.theme-info-container .theme-info-content .ratings-box .ratings .ratings-count {
  font-size: 14px;
  color: #6e6e73;
  margin-top: 4px;
  font-weight: 400;
}
.theme-info-container .theme-info-content .ratings-box .ratings .ratings-count .ratings-count-number {
  color: #1c1c1c;
  font-weight: 600;
}
.theme-info-container .theme-edit-footer {
  grid-area: footer;
  width: 100%;
  height: auto;
  padding: 12px 24px;
  background: #ffffff;
  z-index: 100;
}
.theme-info-container .theme-edit-footer .theme-edit-btn, .theme-info-container .theme-edit-footer .theme-customize-btn {
  padding: 16px 24px;
  width: 100%;
  opacity: 1;
  visibility: visible;
  text-align: center;
  background: #222;
  color: #fff;
  border: none;
  border-radius: 100px;
  font-size: 16px;
  font-family: "Poppins", sans-serif;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.3s ease-in-out;
}
.theme-info-container .theme-edit-footer .theme-edit-btn:hover, .theme-info-container .theme-edit-footer .theme-customize-btn:hover {
  background-color: #111;
}
@media (max-width: 768px) {
  .theme-info-container .theme-edit-footer .theme-edit-btn, .theme-info-container .theme-edit-footer .theme-customize-btn {
    padding: 16px 24px;
    font-size: 16px;
  }
}
.theme-info-container .theme-edit-footer .theme-edit-btn i, .theme-info-container .theme-edit-footer .theme-customize-btn i {
  font-size: 16px;
}
@media (max-width: 768px) {
  .theme-info-container .theme-edit-footer .theme-edit-btn i, .theme-info-container .theme-edit-footer .theme-customize-btn i {
    font-size: 16px;
  }
}

@media (max-width: 768px) {
  .theme-info-container {
    position: relative;
    width: 100vw;
  }
  .theme-info-container .theme-info-header {
    padding: 16px;
  }
  .theme-info-container .theme-info-content {
    height: 100%;
    overflow-y: auto;
  }
  .theme-info-container .theme-info-content .theme-title-name {
    font-size: 2rem;
  }
  .theme-info-container .theme-edit-footer {
    padding: 8px 16px 16px 16px;
  }
}
.recommended-templates {
  margin-bottom: 28px;
}
.recommended-templates .section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 17px;
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 16px;
}
.recommended-templates .section-title svg {
  flex-shrink: 0;
}
.recommended-templates .recommendations-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.recommended-templates .recommendation-card-wrapper {
  position: relative;
}
.recommended-templates .recommendation-card {
  display: block;
  background: #fbfbfd;
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 14px;
  overflow: hidden;
  text-decoration: none;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.recommended-templates .recommendation-card:hover {
  transform: translateY(-2px);
  border-color: rgba(0, 0, 0, 0.12);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}
.recommended-templates .recommendation-card .card-image {
  position: relative;
  width: 100%;
  height: 140px;
  background: #f5f5f7;
  overflow: hidden;
}
.recommended-templates .recommendation-card .card-image img, .recommended-templates .recommendation-card .card-image video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.recommended-templates .recommendation-card .card-image .image-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f0f0f2;
  color: #86868b;
  font-size: 24px;
}
.recommended-templates .recommendation-card .card-image .premium-tag {
  position: absolute;
  top: 8px;
  left: 8px;
  background: rgba(255, 255, 255, 0.95);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  padding: 4px 8px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 600;
  color: #1d1d1f;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
  display: flex;
  align-items: center;
  gap: 4px;
}
.recommended-templates .recommendation-card .card-image .premium-tag i {
  color: #f5a623;
  font-size: 10px;
}
.recommended-templates .recommendation-card:hover .card-image img {
  transform: scale(1.05);
}
.recommended-templates .recommendation-card .card-content {
  padding: 12px;
}
.recommended-templates .recommendation-card .card-content .card-title {
  margin: 0 0 6px 0;
  font-size: 13px;
  font-weight: 500;
  color: #1d1d1f;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.4;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 11px;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating {
  display: flex;
  align-items: center;
  gap: 3px;
  color: #424245;
  font-weight: 500;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating svg {
  color: #f5a623;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating .new-badge {
  background: rgba(0, 113, 227, 0.1);
  color: #0071e3;
  padding: 1px 6px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 10px;
  text-transform: uppercase;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-price-section {
  font-weight: 600;
  color: #1d1d1f;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-price-section .card-category {
  color: #86868b;
  font-weight: 400;
}
.recommended-templates .view-more-container {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}
.recommended-templates .view-more-container .view-more-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: #06c;
  text-decoration: none;
  padding: 8px 16px;
  border-radius: 20px;
  background: transparent;
  transition: all 0.2s ease;
}
.recommended-templates .view-more-container .view-more-btn svg {
  font-size: 12px;
}
.recommended-templates .view-more-container .view-more-btn:hover {
  background: rgba(0, 113, 227, 0.08);
  padding-right: 12px;
}
@media (max-width: 768px) {
  .recommended-templates {
    margin-bottom: 24px;
  }
  .recommended-templates .section-title {
    font-size: 16px;
    margin-bottom: 14px;
  }
  .recommended-templates .section-title svg {
    font-size: 14px;
  }
  .recommended-templates .recommendations-grid {
    gap: 10px;
  }
  .recommended-templates .recommendation-card {
    border-radius: 12px;
  }
  .recommended-templates .recommendation-card .card-image {
    height: 120px;
  }
  .recommended-templates .recommendation-card .card-content {
    padding: 10px;
  }
  .recommended-templates .recommendation-card .card-content .card-title {
    font-size: 12px;
  }
  .recommended-templates .view-more-container {
    margin-top: 10px;
  }
  .recommended-templates .view-more-container .view-more-btn {
    font-size: 12px;
    padding: 6px 12px;
  }
}

.ratings-box {
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  padding: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: all 0.2s ease;
}
.ratings-box .ratings-info .ratings {
  font-size: 2.5rem;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
}
.ratings-box .ratings-info .ratings-count {
  margin-top: 4px;
}
.ratings-box .ratings-info .ratings-count .ratings-count-text {
  font-weight: 500;
  color: #6e6e73;
  font-size: 13px;
}
.ratings-box .ratings-info .ratings-count .ratings-count-text .ratings-count-number {
  color: #1d1d1f;
  font-weight: 600;
}
.ratings-box .ratings-arrow {
  font-size: 1.5rem;
  color: #c7c7cc;
}
.ratings-box:hover {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(245, 245, 245, 0.164);
}
.ratings-box:hover .ratings-arrow {
  color: #424242;
}

.theme-pricing-section {
  margin-bottom: 12px;
}
.theme-pricing-section .price-container {
  background: #fbfbfd;
  border-radius: 12px;
  padding: 16px 18px;
  position: relative;
  overflow: hidden;
}
.theme-pricing-section .pricing-content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.theme-pricing-section .pricing-content.regular {
  gap: 10px;
}
.theme-pricing-section .price-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
}
.theme-pricing-section .price-row .price-label {
  font-size: 11px;
  color: #86868b;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 12px;
}
.theme-pricing-section .price-row .info-box .info-box-text {
  padding: 8px;
  text-align: center;
  border-radius: 8px;
  border: 1px solid rgba(34, 34, 34, 0.2588235294);
  color: #222;
  background-color: white;
  font-size: 12px;
  line-height: 1.2;
}
.theme-pricing-section .price-row .info-box .info-box-text div {
  font-weight: 600;
  color: #222;
  font-size: 18px;
  margin-bottom: 4px;
}
.theme-pricing-section .price-row .info-box .info-box-text div small {
  font-size: 14px;
}
.theme-pricing-section .price-row .original-price {
  display: flex;
  align-items: baseline;
  gap: 1px;
  opacity: 0.4;
  position: relative;
}
.theme-pricing-section .price-row .original-price::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 1.5px;
  background: currentColor;
  transform: translateY(-50%);
}
.theme-pricing-section .price-row .original-price .currency-symbol {
  font-size: 14px;
  font-weight: 500;
  color: #1d1d1f;
  align-self: flex-start;
  margin-top: 1px;
}
.theme-pricing-section .price-row .original-price .price-integer {
  font-size: 18px;
  font-weight: 600;
  color: #1d1d1f;
  letter-spacing: -0.3px;
  line-height: 1;
}
.theme-pricing-section .price-row .original-price .price-decimal {
  font-size: 14px;
  font-weight: 500;
  color: #1d1d1f;
  align-self: flex-start;
  margin-top: 1px;
}
.theme-pricing-section .price-row .current-price {
  display: flex;
  align-items: flex-end;
  gap: 1px;
}
.theme-pricing-section .price-row .current-price.solo {
  margin-top: 2px;
}
.theme-pricing-section .price-row .current-price .currency-symbol {
  font-size: 16px;
  font-weight: 500;
  color: #1d1d1f;
  align-self: flex-end;
  margin-top: 2px;
}
.theme-pricing-section .price-row .current-price .price-integer {
  font-size: 32px;
  font-weight: 600;
  color: #1d1d1f;
  letter-spacing: -0.8px;
  line-height: 1;
}
.theme-pricing-section .price-row .current-price .price-decimal {
  font-size: 16px;
  font-weight: 500;
  color: #1d1d1f;
  align-self: flex-end;
  margin-top: 2px;
}
.theme-pricing-section .price-row .discount-badge {
  display: inline-flex;
  align-items: center;
  background: #ff3b30;
  color: #ffffff;
  padding: 3px 10px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.2px;
}
.theme-pricing-section .price-row .premium-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(245, 124, 0, 0.08);
  color: #f59700;
  padding: 3px 10px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
}
.theme-pricing-section .price-row .premium-badge svg {
  width: 10px;
  height: 10px;
}
.theme-pricing-section .price-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: #86868b;
  padding-top: 8px;
  border-top: 1px solid rgba(0, 0, 0, 0.04);
}
.theme-pricing-section .price-meta .offer-text {
  color: #ff3b30;
  font-weight: 500;
}
.theme-pricing-section .price-meta .separator {
  color: #d2d2d7;
  margin: 0 2px;
}
.theme-pricing-section .price-meta .terms-link {
  color: #06c;
  text-decoration: none;
  font-weight: 400;
  transition: opacity 0.2s ease;
}
.theme-pricing-section .price-meta .terms-link:hover {
  opacity: 0.7;
  text-decoration: none;
}
@media (max-width: 768px) {
  .theme-pricing-section {
    margin-bottom: 20px;
  }
  .theme-pricing-section .price-container {
    padding: 14px 16px;
    border-radius: 10px;
  }
  .theme-pricing-section .price-row .price-label {
    font-size: 10px;
  }
  .theme-pricing-section .price-row .discount-badge,
  .theme-pricing-section .price-row .premium-badge {
    font-size: 10px;
    padding: 2px 8px;
  }
  .theme-pricing-section .price-display .current-price .currency-symbol {
    font-size: 14px;
  }
  .theme-pricing-section .price-display .current-price .price-integer {
    font-size: 28px;
    letter-spacing: -0.6px;
  }
  .theme-pricing-section .price-display .current-price .price-decimal {
    font-size: 14px;
  }
  .theme-pricing-section .price-display .original-price .currency-symbol {
    font-size: 12px;
  }
  .theme-pricing-section .price-display .original-price .price-integer {
    font-size: 16px;
  }
  .theme-pricing-section .price-display .original-price .price-decimal {
    font-size: 12px;
  }
  .theme-pricing-section .price-meta {
    font-size: 10px;
    flex-wrap: wrap;
  }
}

.model-box[data-model=share-theme-tab] .theme-info-container {
  height: 100%;
  display: flex;
  flex-direction: column;
}
.model-box[data-model=share-theme-tab] .theme-info-container .theme-info-header {
  position: sticky;
  top: 0;
  z-index: 10;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  background: rgba(255, 255, 255, 0.9);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card {
  cursor: pointer;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.social-share .icon-wrapper {
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease, background-color 0.3s ease;
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.social-share span {
  transition: color 0.3s ease;
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.social-share:hover .icon-wrapper {
  transform: translateY(-4px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.08) !important;
  background-color: #ffffff !important;
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.social-share:hover span {
  color: #212529 !important;
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.social-share:active .icon-wrapper {
  transform: scale(0.92);
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.copy-link {
  cursor: pointer;
  transition: transform 0.2s ease;
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.copy-link:hover {
  transform: translateY(-2px);
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.copy-link:hover .bg-light {
  background-color: #e9ecef !important;
}
.model-box[data-model=share-theme-tab] .theme-info-container .share-grid .share-card.copy-link:active {
  transform: scale(0.98);
}

.model-box[data-model=schedule-tab] .form-container #offersCarousel .carousel-inner {
  border-radius: 16px;
  overflow: hidden;
}
.model-box[data-model=schedule-tab] .form-container #offersCarousel .carousel-inner .carousel-item .offer-badge .badge {
  font-weight: 600;
  padding: 6px 10px;
  border-radius: 8px;
}
.model-box[data-model=schedule-tab] .form-container .form-group .form-label {
  font-size: 11px;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}
.model-box[data-model=schedule-tab] .form-container .form-group .form-control, .model-box[data-model=schedule-tab] .form-container .form-group .form-select {
  background: transparent;
  padding-left: 0;
  padding-right: 0;
  font-family: inherit;
}
.model-box[data-model=schedule-tab] .form-container .form-group .form-control:focus, .model-box[data-model=schedule-tab] .form-container .form-group .form-select:focus {
  border-color: #000;
  box-shadow: none;
}
.model-box[data-model=schedule-tab] .form-container .card.bg-light {
  background-color: #f8f9fa !important;
}
.model-box[data-model=schedule-tab] .form-container .card.bg-light .form-control {
  background-color: #fff !important;
  border: 1px solid rgba(0, 0, 0, 0.05) !important;
  padding: 10px;
}
.model-box[data-model=schedule-tab] .form-container .card.bg-light .form-control:focus {
  border-color: #000 !important;
}

.rsvp-toggle-section .form-check-input {
  width: 3rem;
  height: 1.5rem;
  cursor: pointer;
}
.rsvp-toggle-section .form-check-input:checked {
  background-color: #0d6efd;
  border-color: #0d6efd;
}

#rsvpFormContent {
  transition: opacity 0.3s ease, max-height 0.3s ease;
}
#rsvpFormContent.disabled {
  opacity: 0.5;
  pointer-events: none;
  max-height: 0;
  overflow: hidden;
}

#rsvpGuestCount {
  border-left: 0;
  border-right: 0;
  background-color: #f8f9fa;
  font-weight: 600;
  transition: all 0.3s ease;
}
#rsvpGuestCount.value-changed {
  animation: valueChange 0.6s ease;
}

@keyframes valueChange {
  0%, 100% {
    transform: scale(1);
    color: inherit;
  }
  50% {
    transform: scale(1.1);
    color: #0d6efd;
  }
}
#decreaseGuestCount,
#increaseGuestCount {
  border: 1px solid #ced4da;
  transition: all 0.2s ease;
}
#decreaseGuestCount:hover,
#increaseGuestCount:hover {
  background-color: #e9ecef;
  border-color: #adb5bd;
}
#decreaseGuestCount:active, #decreaseGuestCount.btn-pressed,
#increaseGuestCount:active,
#increaseGuestCount.btn-pressed {
  transform: scale(0.95);
  background-color: #dee2e6;
}
#decreaseGuestCount:disabled,
#increaseGuestCount:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.attendance-options-list .form-check {
  padding: 12px;
  border-radius: 8px;
  transition: background-color 0.2s ease;
}
.attendance-options-list .form-check:hover {
  background-color: #f8f9fa;
}
.attendance-options-list .form-check .form-check-input {
  margin-top: 0.3rem;
}
.attendance-options-list .form-check .badge {
  font-size: 0.75rem;
  padding: 0.25rem 0.5rem;
}

.rsvp-option-card {
  transition: all 0.2s ease;
  background-color: #fff;
}
.rsvp-option-card:hover {
  background-color: #f8f9fa;
  border-color: #adb5bd !important;
}
.rsvp-option-card .form-check-input:checked ~ .form-check-label {
  color: #0d6efd;
}
.rsvp-option-card .form-check-inline {
  margin-right: 1rem;
}

.sticky-add-btn {
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.sticky-add-btn:hover {
  transform: translateY(-2px);
}
.sticky-add-btn:active {
  transform: translateY(0);
}

.custom-questions-list {
  position: relative;
  z-index: 1;
}

.minimal-card {
  background: #fff;
  padding: 16px;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow: none;
  margin-bottom: 12px;
  transition: all 0.2s ease;
}
.minimal-card:hover {
  border-color: rgba(0, 0, 0, 0.15) !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05) !important;
}
.minimal-card .cursor-move {
  cursor: move;
  cursor: grab;
  opacity: 0.5;
  transition: opacity 0.2s;
}
.minimal-card .cursor-move:hover {
  opacity: 1;
}
.minimal-card .cursor-move:active {
  cursor: grabbing;
}

.form-control-flush {
  background: transparent;
  border: 1px solid transparent;
  transition: all 0.2s;
  font-size: 1.05rem;
}
.form-control-flush:hover {
  background-color: #f8f9fa;
  border-color: transparent;
}
.form-control-flush:focus {
  background-color: #fff;
  border-color: #dee2e6;
  box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.05);
}

.form-switch-sm .form-check-input {
  width: 2em;
  height: 1em;
  margin-top: 0.25em;
}

.option-item .input-group-text {
  background: transparent;
  color: #6c757d;
}
.option-item .form-control:focus {
  background-color: #fff;
  box-shadow: none;
  border-color: #dee2e6;
}

.empty-state {
  text-align: center;
  padding: 40px 20px;
  color: #6c757d;
}
.empty-state i {
  font-size: 3rem;
  opacity: 0.3;
  margin-bottom: 16px;
}
.empty-state p {
  margin: 0;
  font-size: 0.95rem;
}

.custom-question-item {
  cursor: move;
}
.custom-question-item.sortable-ghost {
  opacity: 0.4;
  background: #f8f9fa;
}
.custom-question-item.sortable-drag {
  cursor: grabbing;
}

@media (max-width: 768px) {
  .rsvp-option-card {
    margin-bottom: 12px;
  }
  .custom-question-item .question-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  #rsvpGuestCount {
    font-size: 1.25rem;
  }
}
@keyframes slideInQuestion {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.custom-question-item.new-question {
  animation: slideInQuestion 0.3s ease;
}

:root {
  --transition-speed: 0.5s;
  --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
  /* Super smooth deceleration */
  --text-main: #111111;
  --text-sub: #717171;
  --light-bg: #f8f9fa8f;
  --light-bg-hover: #f8f9fa;
  --text-primary: #0d6efd;
  --bg-toggle-btn: #2391ff;
  --bg-toggle-btn-hover: #0b7cd1;
  --poppins: "Poppins", sans-serif;
  --inter: "Inter", sans-serif;
}

[data-toggle-elem-state=block] {
  display: block !important;
  height: auto !important;
  overflow: visible !important;
  transition: all 0.2s ease-in-out;
}

[data-toggle-elem-state=hidden] {
  display: none !important;
  height: 0 !important;
  overflow: hidden !important;
  transition: all 0.2s ease-in-out;
}

/* Main Container: Square edges */
.collapsible-card {
  width: 100%;
  font-family: "Inter", sans-serif;
  /* Closed State Styles */
  /* Chevron Rotation */
  /* The Grid Animation Trick */
}
.collapsible-card .card-toggle-header {
  padding: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  z-index: 2;
  position: relative;
  transition: all 0.2s ease-in-out;
}
.collapsible-card .card-toggle-header:hover {
  background: var(--light-bg);
  border-radius: 8px;
}
.collapsible-card .card-toggle-header .title {
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  line-height: 18px;
  color: var(--text-main);
  font-family: var(--poppins);
  transition: color var(--transition-speed) var(--ease-out-expo);
}
.collapsible-card .card-toggle-header .subtitle {
  margin: 0;
  font-size: 14px;
  color: var(--text-sub);
  line-height: 18px;
  font-family: var(--inter);
  transition: color var(--transition-speed) var(--ease-out-expo);
}
.collapsible-card .chevron-wrapper {
  transition: transform var(--transition-speed) var(--ease-out-expo);
  display: flex;
}
.collapsible-card[data-toggle-state=open] .card-toggle-header .title {
  background: linear-gradient(to right, #b99010, #e8ca2c, #b99010);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  transition: all var(--transition-speed) var(--ease-out-expo);
}
.collapsible-card[data-toggle-state=open] .card-toggle-header .title i {
  color: var(--text-main) !important;
  transition: color var(--transition-speed) var(--ease-out-expo);
}
.collapsible-card[data-toggle-state=open] .card-toggle-header .subtitle {
  color: var(--text-main);
}
.collapsible-card[data-toggle-state=open] .chevron-wrapper {
  transform: rotate(180deg);
}
.collapsible-card .content-overflow-container {
  display: grid;
  grid-template-rows: 0fr;
  /* Initial state */
  transition: grid-template-rows var(--transition-speed) var(--ease-out-expo);
  /* This inner div ensures the content doesn't "jump" or snap */
}
.collapsible-card .content-overflow-container .content-inner {
  overflow: hidden;
}
.collapsible-card[data-toggle-state=open] .content-overflow-container {
  grid-template-rows: 1fr;
  /* Open state */
}
.collapsible-card[data-toggle-state=open] .content-padding {
  opacity: 1;
  transform: translateY(0);
}

.open-edit-card {
  width: 100%;
  font-family: "Inter", sans-serif;
  /* The Grid Animation Trick */
}
.open-edit-card .card-toggle-header {
  padding: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  z-index: 2;
  position: relative;
}
.open-edit-card .card-toggle-header .title {
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  line-height: 18px;
  color: var(--text-main);
  font-family: var(--poppins);
}
.open-edit-card .card-toggle-header .subtitle {
  margin: 0;
  font-size: 14px;
  color: var(--text-sub);
  line-height: 18px;
  font-family: var(--inter);
}
.open-edit-card .content-overflow-container .content-inner {
  overflow: hidden;
}

.content-padding {
  padding: 4px 12px 0 12px;
  /* Optional: small fade in for elements */
  opacity: 0;
  transform: translateY(-10px);
  transition: all var(--transition-speed) var(--ease-out-expo);
}
.content-padding input, .content-padding textarea, .content-padding select {
  background-color: var(--light-bg);
  border-radius: 8px;
  border: 1px solid #ced4da;
  font-family: var(--inter);
  font-size: 16px;
  padding: 8px 12px;
  box-shadow: none !important;
  outline: none;
  transition: all 0.2s ease-in-out;
}
.content-padding .icon-group-input {
  position: relative;
  display: flex;
  align-items: center;
}
.content-padding .icon-group-input .input-icon {
  position: absolute;
  left: 10px;
  color: #6c757d;
  pointer-events: none;
  font-size: 16px;
  transition: all 0.2s ease-in-out;
}
.content-padding .icon-group-input .input-icon i.bi {
  transform: translateX(2px);
}
.content-padding .icon-group-input input {
  padding-left: 32px;
}
.content-padding input[type=date], .content-padding input[type=time], .content-padding select {
  box-shadow: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  cursor: pointer;
}
.content-padding label {
  font-family: var(--poppins);
  font-size: 14px;
  font-weight: 500;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.content-padding .form-check-custom-switch {
  border-radius: 8px;
  background-color: var(--light-bg);
  margin-bottom: 0;
  padding: 12px;
}
.content-padding .form-check-custom-switch .form-label-switch {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: 0;
  margin-bottom: 0;
}
.content-padding .form-check-custom-switch .form-label-switch span {
  font-family: var(--poppins);
  font-size: 16px;
  line-height: 16px;
  font-weight: 500;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.content-padding .form-check-custom-switch .form-label-switch .custom-check-switch-2 {
  transform: scale(0.75);
}
.content-padding .form-check-custom-switch .switch-input-group {
  background-color: white;
}

.open-edit-card {
  /* The Grid Animation Trick */
}
.open-edit-card .open-edit-header {
  padding: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 2;
  position: relative;
}
.open-edit-card .open-edit-header .title {
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  line-height: 18px;
  color: var(--text-main);
  font-family: var(--poppins);
}
.open-edit-card .open-edit-header .subtitle {
  margin: 0;
  font-size: 14px;
  color: var(--text-sub);
  line-height: 18px;
  font-family: var(--inter);
}
.open-edit-card .content-overflow-container .content-inner {
  overflow: hidden;
}
.open-edit-card .content-overflow-container .content-inner .content-padding {
  opacity: 1;
  transform: translateY(0);
}

.input-info-text {
  font-size: 12px;
  color: var(--text-sub);
}

.tab-toggle-btn {
  width: 100%;
  background: var(--bg-toggle-btn);
  border: none;
  padding: 12px;
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  line-height: 18px;
  color: white;
  font-family: var(--inter);
  border-radius: 50px;
  box-shadow: none !important;
  outline: none;
  transition: all var(--transition-speed) ease-in-out;
}
.tab-toggle-btn:hover {
  background: var(--bg-toggle-btn-hover);
}

hr.toggle-hr {
  margin: 0;
  background: var(--text-sub);
  height: 1px;
  border: none;
}

.glass-btn {
  background: rgba(255, 255, 255, 0.01);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255, 255, 255, 0.3);
}

.content-edit-box {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: auto 1fr;
  transition: all 0.2s ease;
}
.content-edit-box .content-edit-header {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--text-main);
  font-family: var(--poppins);
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 8px;
}
.content-edit-box .content-edit-header button {
  background: var(--light-bg);
  border: none;
  box-shadow: none !important;
  outline: none;
  color: var(--text-sub);
  cursor: pointer;
  font-size: 16px;
  font-weight: 600;
  line-height: 16px;
  font-family: var(--poppins);
  height: 32px;
  width: 32px;
  border-radius: 8px;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: color 0.2s ease-in-out;
}
.content-edit-box .content-edit-header button:hover {
  color: var(--text-main);
  background: var(--light-bg-hover);
}
.content-edit-box .content-edit-body {
  width: 100%;
  height: 100%;
  overflow-y: auto;
  font-size: 14px;
  line-height: 20px;
  color: var(--text-main);
  outline: none;
  border: none;
  resize: none;
  font-family: var(--inter);
  padding: 12px;
  border-radius: 8px;
  background: var(--light-bg);
  border: 1px solid #ced4da;
  box-shadow: none;
  transition: all var(--transition-speed) ease-in-out;
}
.content-edit-box .content-edit-body::-webkit-scrollbar {
  width: 6px;
}
.content-edit-box .content-edit-body::-webkit-scrollbar-track {
  background: transparent;
}
.content-edit-box .content-edit-body::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: 8px;
}
.content-edit-box .content-edit-body p {
  margin: 0;
  padding: 0;
  margin-bottom: 16px;
  font-family: var(--inter);
  font-size: 14px;
  line-height: 18px;
  color: var(--text-main);
  font-weight: 400;
  font-family: var(--inter);
  transition: all var(--transition-speed) ease-in-out;
}
.content-edit-box .content-edit-body h5 {
  font-family: var(--poppins);
  font-size: 18px;
  line-height: 24px;
  color: var(--text-main);
  font-weight: 600;
  margin-top: 16px;
  margin-bottom: 8px;
}
.content-edit-box .content-edit-body ul, .content-edit-box .content-edit-body ol {
  padding-left: 20px;
  margin-bottom: 16px;
}
.content-edit-box .content-edit-body ul li, .content-edit-box .content-edit-body ol li {
  margin-bottom: 8px;
}

/* From Uiverse.io by ICe1BotMaker */
.custom-check-switch-2 input {
  display: none;
}

.custom-check-switch-2 .check-bg {
  width: 50px;
  padding: 2.5px;
  background: #ffffff;
  border-radius: 100px;
  border: 1px solid #a0a6ad;
  transition: background 0.1s, border 0.1s;
}

.custom-check-switch-2 .check-span {
  display: block;
  background: #b0b3b7;
  width: 25px;
  height: 25px;
  border-radius: 100%;
  transition: background 0.1s, border 0.1s, margin-left 0.325s;
}

.custom-check-switch-2 input:checked ~ .check-bg {
  background: linear-gradient(to right, #b99010, #e8ca2c, #b99010);
  border: 1px solid #b99010;
}

.custom-check-switch-2 input:checked ~ .check-bg .check-span {
  background: white;
  border: 0;
  margin-left: 18px;
}

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

html {
  overflow-x: hidden !important;
}

body {
  overflow-x: hidden !important;
}

html, body {
  height: 100svh;
}
@media (max-width: 768px) {
  html, body {
    height: 100%;
    scroll-behavior: smooth;
  }
}

/* Enhanced Date and Time Input Styles */
.form-floating input[type=date],
.form-floating input[type=time] {
  cursor: pointer;
  padding-right: 40px; /* Make room for the icon */
}

.form-floating input[type=date]:focus,
.form-floating input[type=time]:focus {
  outline: none;
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
  border-color: #007bff;
}

.form-floating input[type=date]:hover,
.form-floating input[type=time]:hover {
  border-color: #80bdff;
  background-color: #f8f9fa;
}

/* Make the entire form-floating container clickable for date/time */
.form-floating:has(input[type=date]),
.form-floating:has(input[type=time]) {
  cursor: pointer;
}

.form-floating:has(input[type=date]) label,
.form-floating:has(input[type=time]) label {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

/* Add visual feedback when clicking on the label */
.form-floating:has(input[type=date]) label:active,
.form-floating:has(input[type=time]) label:active {
  transform: translateY(-1px);
}

/* Ensure consistent appearance across browsers */
.form-floating input[type=date],
.form-floating input[type=time] {
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield;
}

.form-floating input[type=date]::-webkit-calendar-picker-indicator,
.form-floating input[type=time]::-webkit-calendar-picker-indicator {
  opacity: 1;
  cursor: pointer;
  position: absolute;
  right: 12px;
  width: 20px;
  height: 20px;
}

/* Fallback for browsers that don't support :has() */
@supports not (selector(:has(*))) {
  .form-floating .date-time-clickable {
    cursor: pointer;
  }
  .form-floating .date-time-clickable label {
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
  }
}
/* Custom Date and Time Picker Boxes */
.event-date-box,
.event-time-box,
.validity-box {
  position: relative;
  cursor: pointer;
}
.event-date-box input[type=date],
.event-date-box input[type=time],
.event-time-box input[type=date],
.event-time-box input[type=time],
.validity-box input[type=date],
.validity-box input[type=time] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 2;
}

#mainContainer {
  display: grid;
  grid-template-columns: 1fr minmax(380px, 420px);
  grid-template-areas: "themePreview sidebarSection";
  gap: 0;
  height: 100svh;
  width: 100%;
}
@media (max-width: 768px) {
  #mainContainer {
    height: 100%;
    grid-template-columns: 1fr;
    grid-template-rows: 70svh auto;
    grid-template-areas: "themePreview" "sidebarSection";
    /* Enable smooth scroll snap for mobile */
    scroll-snap-type: y mandatory;
    height: 100%;
    overflow-y: auto;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
  }
  #mainContainer #themePreviewContainer {
    scroll-snap-align: start;
    scroll-snap-stop: always;
    height: 70svh;
  }
  #mainContainer #sidebarSection {
    scroll-snap-align: start;
    scroll-snap-stop: always;
    height: 100%;
  }
}
#mainContainer #themePreviewContainer {
  grid-area: themePreview;
  overflow: hidden;
  position: relative;
  width: 100%;
  height: 100%;
  padding: 12px 0 12px 12px;
  transition: padding 0.3s ease;
  touch-action: none; /* Prevent touch scroll on the container */
}
#mainContainer #themePreviewContainer .logo-box {
  position: absolute;
  top: 36px;
  left: 36px;
  z-index: 10;
}
#mainContainer #themePreviewContainer .logo-box img#eventicLogo {
  height: 42px;
  width: 42px;
  border-radius: 12px;
}
@media (max-width: 768px) {
  #mainContainer #themePreviewContainer .logo-box {
    top: 30px;
    left: 30px;
  }
  #mainContainer #themePreviewContainer .logo-box img#eventicLogo {
    height: 36px;
    width: 36px;
  }
}
#mainContainer #themePreviewContainer .action-btn {
  position: absolute;
  bottom: 36px;
  right: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  z-index: 10;
}
#mainContainer #themePreviewContainer .action-btn button {
  background: rgba(137, 137, 137, 0.0784313725);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  opacity: 0.9;
  height: 46px;
  border: none;
  font-size: 20px;
  transition: all 0.2s ease-in-out;
}
#mainContainer #themePreviewContainer .action-btn button i {
  box-shadow: rgba(0, 0, 0, 0.25) 0px 25px 50px -12px;
}
#mainContainer #themePreviewContainer .action-btn button:hover {
  opacity: 1;
}
#mainContainer #themePreviewContainer .action-btn button.spinning {
  animation: spin 0.8s linear infinite;
}
#mainContainer #themePreviewContainer .action-btn button.edit-btn {
  background-color: #4285F4 !important;
  color: white !important;
  transition: all 0.2s ease-in-out;
}
#mainContainer #themePreviewContainer .action-btn button.edit-btn:hover {
  background-color: #3d7feb !important;
  color: white !important;
}
#mainContainer #themePreviewContainer .action-btn[data-theme-type=dark] button {
  color: rgb(255, 255, 255);
}
#mainContainer #themePreviewContainer .action-btn[data-theme-type=dark]:hover button {
  color: #fff;
}
#mainContainer #themePreviewContainer .action-btn[data-theme-type=light] button {
  color: rgba(39, 39, 39, 0.8);
}
#mainContainer #themePreviewContainer .action-btn[data-theme-type=light]:hover button {
  color: #000;
}
@media (max-width: 768px) {
  #mainContainer #themePreviewContainer {
    padding: 12px 12px 4px 12px;
  }
  #mainContainer #themePreviewContainer .action-btn {
    bottom: 30px;
    right: 30px;
    flex-direction: row;
    gap: 12px;
  }
  #mainContainer #themePreviewContainer .action-btn button {
    width: 48px;
    height: 48px;
    font-size: 20px;
  }
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes slideIn {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}
@keyframes slideOut {
  from {
    transform: translateX(0);
    opacity: 1;
  }
  to {
    transform: translateX(100%);
    opacity: 0;
  }
}
#mainContainer #themePreviewContainer .flexible-container {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 100%;
  border-radius: 32px;
  overflow: hidden;
  background: #f5f7f8;
  pointer-events: auto; /* Allow iframe interactions */
  overscroll-behavior: none;
  /* Loader styles */
}
#mainContainer #themePreviewContainer .flexible-container .loader {
  width: 65px;
  aspect-ratio: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10;
}
#mainContainer #themePreviewContainer .flexible-container .loader:before,
#mainContainer #themePreviewContainer .flexible-container .loader:after {
  content: "";
  position: absolute;
  border-radius: 50px;
  box-shadow: 0 0 0 3px inset #333;
  animation: l5 2.5s infinite;
}
#mainContainer #themePreviewContainer .flexible-container .loader:after {
  animation-delay: -1.25s;
  border-radius: 0;
}
@keyframes l5 {
  0% {
    inset: 0 35px 35px 0;
  }
  12.5% {
    inset: 0 35px 0 0;
  }
  25% {
    inset: 35px 35px 0 0;
  }
  37.5% {
    inset: 35px 0 0 0;
  }
  50% {
    inset: 35px 0 0 35px;
  }
  62.5% {
    inset: 0 0 0 35px;
  }
  75% {
    inset: 0 0 35px 35px;
  }
  87.5% {
    inset: 0 0 35px 0;
  }
  100% {
    inset: 0 35px 35px 0;
  }
}
#mainContainer #themePreviewContainer .flexible-container #theme-iframe {
  position: relative;
  width: 100%;
  height: 100%;
  pointer-events: auto; /* Enable iframe interactions */
  overscroll-behavior: none;
  -webkit-overflow-scrolling: touch;
  transition: opacity 0.3s ease;
}
@media (max-width: 768px) {
  #mainContainer #themePreviewContainer .flexible-container {
    border-radius: 20px;
  }
}
#mainContainer #themePreviewContainer #themePreview {
  position: relative;
  width: 100%;
  height: 100%;
}
#mainContainer #sidebarSection {
  grid-area: sidebarSection;
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  transition: all 0.3s ease;
}
#mainContainer #sidebarSection #modelContainer .model-box {
  position: relative;
  width: 100%;
  height: 100%;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-state=show] {
  display: block;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-state=hide] {
  display: none;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] {
  padding: 0;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-header-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid #e0e0e0;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-header-box h6 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: #222;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-header-box .close-model-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 20px;
  color: #999;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  transition: all 0.2s ease;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-header-box .close-model-btn:hover {
  background: #f5f5f5;
  color: #333;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box {
  flex: 1;
  overflow-y: auto;
  padding: 12px;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-options {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px;
  border: 1px solid #e0e0e0;
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
  background: #ffffff;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item:hover {
  border-color: #d0d0d0;
  background: #f9f9f9;
  transform: translateX(4px);
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item:active {
  transform: translateX(2px);
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: #f0f0f0;
  font-size: 24px;
  color: #666;
  flex-shrink: 0;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-icon.facebook {
  background: #E7F3FF;
  color: #1877F2;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-icon.twitter {
  background: #E8F5FE;
  color: #1DA1F2;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-icon.whatsapp {
  background: #E7F5EE;
  color: #25D366;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-icon.email {
  background: #FFF3E0;
  color: #FF6D00;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-icon.linkedin {
  background: #E8F4F8;
  color: #0A66C2;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-info {
  flex: 1;
  min-width: 0;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-info h6 {
  margin: 0 0 4px 0;
  font-size: 14px;
  font-weight: 600;
  color: #222;
  display: flex;
  align-items: center;
  gap: 8px;
}
#mainContainer #sidebarSection #modelContainer .model-box[data-model=share-theme-tab] .model-content-box .share-option-item .share-info p {
  margin: 0;
  font-size: 12px;
  color: #999;
  line-height: 1.4;
}
@media (max-width: 768px) {
  #mainContainer #sidebarSection {
    height: 100%;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    overflow: visible;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
  }
  #mainContainer #sidebarSection #modelContainer {
    height: 100%;
  }
  #mainContainer #sidebarSection #modelContainer .model-box {
    height: 100%;
  }
}
#mainContainer.expanded {
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  grid-template-areas: "themePreview";
}
@media (max-width: 768px) {
  #mainContainer.expanded {
    grid-template-rows: 1fr;
    grid-template-areas: "themePreview";
  }
}
#mainContainer.expanded #themePreviewContainer {
  padding: 0;
  margin: 0;
}
#mainContainer.expanded #themePreviewContainer .flexible-container {
  border-radius: 0;
  box-shadow: none;
  margin: 0;
}
#mainContainer.expanded #themePreviewContainer .action-btn {
  bottom: 24px;
  top: auto;
  right: 24px;
}
#mainContainer.expanded #sidebarSection {
  display: none;
}

.form-container {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr auto;
  grid-template-areas: "header" "content" "bottom";
  height: 100%;
}
@media (max-width: 768px) {
  .form-container {
    height: 100svh;
  }
}
.form-container .form-header {
  grid-area: header;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background: linear-gradient(to bottom, rgb(255, 255, 255) 80%, rgba(255, 255, 255, 0) 100%);
  display: grid;
  grid-template-columns: 30% 1fr 30%;
  grid-template-areas: "back title close";
  align-items: center;
  gap: 0;
  padding: 24px;
  z-index: 100;
}
@media (max-width: 768px) {
  .form-container .form-header {
    grid-template-columns: auto 1fr auto;
    padding: 20px 24px;
  }
}
.form-container .form-header .form-back {
  grid-area: back;
  justify-self: start;
}
.form-container .form-header .form-back button {
  background: transparent;
  color: #4d565f;
  padding: 6px 0;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  border: none;
  outline: none;
  box-shadow: none;
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  font-size: 16px;
  margin-right: 12px;
}
.form-container .form-header .form-back button:hover {
  color: #1c1c1c;
}
.form-container .form-header .form-back button i {
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 768px) {
  .form-container .form-header .form-back button {
    padding: 6px;
    font-size: 14px;
  }
  .form-container .form-header .form-back button i {
    font-size: 16px;
  }
  .form-container .form-header .form-back button span {
    display: none;
  }
}
.form-container .form-header .form-title {
  grid-area: title;
  text-align: center;
}
@media (max-width: 768px) {
  .form-container .form-header .form-title {
    text-align: left;
  }
}
.form-container .form-header .form-title h5 {
  margin: 0;
  padding: 0;
  font-size: 1.25rem;
  font-weight: 600;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
}
@media (max-width: 768px) {
  .form-container .form-header .form-title h5 {
    font-size: 1rem;
  }
}
.form-container .form-header .form-close {
  grid-area: close;
  cursor: pointer;
  justify-self: end;
}
.form-container .form-header .form-close button {
  background: #f8f9fa;
  color: #4d545b;
  padding: 0;
  border-radius: 50px;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border: none;
  font-size: 16px;
  margin-left: 12px;
  transition: all 0.3s ease-in-out;
}
.form-container .form-header .form-close button:hover {
  background: #e7e9eb;
  color: #1c1c1c;
}
.form-container .form-body {
  grid-area: content;
  padding: 100px 16px 150px 16px;
  width: 100%;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  scroll-behavior: smooth;
  overflow-x: hidden;
  overflow-y: auto;
  height: 100svh;
}
@media (max-width: 768px) {
  .form-container .form-body {
    padding: 80px 24px 100px 24px;
  }
}
.form-container .form-body::-webkit-scrollbar {
  width: 0;
}
.form-container .form-body::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 3px;
}
.form-container .form-body::-webkit-scrollbar-thumb {
  background: #d7d7d7;
  border-radius: 3px;
}
.form-container .form-body::-webkit-scrollbar-thumb:hover {
  background: #c4c4c4;
}
.form-container .form-body label.form-label {
  font-size: 14px;
  margin-bottom: 8px;
}
.form-container .form-body input, .form-container .form-body select, .form-container .form-body textarea {
  border: 1px solid #a1a7ac;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
}
.form-container .form-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  background: linear-gradient(to top, rgb(255, 255, 255) 80%, rgba(255, 255, 255, 0) 100%);
  grid-area: bottom;
  padding: 24px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-areas: "btn-left btn-center btn-right";
  align-items: center;
  gap: 0;
  z-index: 100;
}
@media (max-width: 768px) {
  .form-container .form-footer {
    grid-template-columns: auto 1fr auto;
    padding: 20px 24px;
  }
}
.form-container .form-footer .btn-left {
  grid-area: btn-left;
  justify-self: start;
}
.form-container .form-footer .btn-center {
  grid-area: btn-center;
  justify-self: center;
  width: 100%;
}
.form-container .form-footer .btn-right {
  grid-area: btn-right;
  justify-self: end;
}
.form-container .form-footer .btn {
  padding: 12px 24px;
  border-radius: 12px;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  box-shadow: none;
  outline: none;
  font-weight: 500;
  font-size: 16px;
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
}
.form-container .form-footer .btn.btn-back {
  padding: 12px 24px 12px 20px;
  background: #f8f9fa;
  color: #6c757d;
}
.form-container .form-footer .btn.btn-back:hover {
  background: #e9ecef;
  color: #495057;
}
.form-container .form-footer .btn.btn-next {
  padding: 12px 32px;
  background: #4285F4;
  color: #fff;
}
.form-container .form-footer .btn.btn-next:hover {
  background: #357ae8;
}

.recommended-templates {
  margin-bottom: 28px;
}
.recommended-templates .section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 17px;
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 16px;
}
.recommended-templates .section-title svg {
  flex-shrink: 0;
}
.recommended-templates .recommendations-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.recommended-templates .recommendation-card-wrapper {
  position: relative;
}
.recommended-templates .recommendation-card {
  display: block;
  background: #fbfbfd;
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 14px;
  overflow: hidden;
  text-decoration: none;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.recommended-templates .recommendation-card:hover {
  transform: translateY(-2px);
  border-color: rgba(0, 0, 0, 0.12);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}
.recommended-templates .recommendation-card .card-image {
  position: relative;
  width: 100%;
  height: 140px;
  background: #f5f5f7;
  overflow: hidden;
}
.recommended-templates .recommendation-card .card-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.3s ease;
}
.recommended-templates .recommendation-card .card-image .image-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #f5f5f7 0%, #fafafa 100%);
}
.recommended-templates .recommendation-card .card-image .premium-tag {
  position: absolute;
  top: 8px;
  left: 8px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(245, 124, 0, 0.95);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  color: #ffffff;
  padding: 4px 8px;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.2px;
}
.recommended-templates .recommendation-card .card-image .premium-tag svg {
  flex-shrink: 0;
}
.recommended-templates .recommendation-card:hover .card-image img {
  transform: scale(1.05);
}
.recommended-templates .recommendation-card .card-content {
  padding: 12px;
}
.recommended-templates .recommendation-card .card-content .card-title {
  font-size: 14px;
  font-weight: 600;
  color: #1d1d1f;
  margin: 0 0 8px 0;
  line-height: 1.3;
  letter-spacing: -0.2px;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating {
  display: flex;
  align-items: center;
  gap: 4px;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating svg {
  flex-shrink: 0;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating .rating-value {
  font-size: 12px;
  font-weight: 500;
  color: #1d1d1f;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating .new-badge {
  font-size: 11px;
  font-weight: 500;
  color: #86868b;
  background: rgba(134, 134, 139, 0.1);
  padding: 2px 8px;
  border-radius: 6px;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-price-section .price-amount {
  font-size: 14px;
  font-weight: 600;
  color: #1d1d1f;
  letter-spacing: -0.2px;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-price-section .price-amount .currency-symbol {
  font-size: 12px;
  font-weight: 500;
  opacity: 0.7;
}
.recommended-templates .recommendation-card .card-content .card-footer-meta .card-price-section .card-category {
  font-size: 11px;
  font-weight: 500;
  color: #86868b;
  background: rgba(134, 134, 139, 0.08);
  padding: 3px 8px;
  border-radius: 6px;
}
.recommended-templates .view-more-container {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}
.recommended-templates .view-more-container .view-more-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: #06c;
  text-decoration: none;
  padding: 8px 16px;
  border-radius: 20px;
  background: transparent;
  transition: all 0.2s ease;
}
.recommended-templates .view-more-container .view-more-btn svg {
  transition: transform 0.2s ease;
}
.recommended-templates .view-more-container .view-more-btn:hover {
  background: rgba(0, 102, 204, 0.06);
}
.recommended-templates .view-more-container .view-more-btn:hover svg {
  transform: translateX(2px);
}
@media (max-width: 768px) {
  .recommended-templates {
    margin-bottom: 24px;
  }
  .recommended-templates .section-title {
    font-size: 16px;
    margin-bottom: 14px;
  }
  .recommended-templates .section-title svg {
    width: 16px;
    height: 16px;
  }
  .recommended-templates .recommendations-grid {
    gap: 10px;
  }
  .recommended-templates .recommendation-card {
    border-radius: 12px;
  }
  .recommended-templates .recommendation-card .card-image {
    height: 120px;
  }
  .recommended-templates .recommendation-card .card-image .premium-tag {
    top: 6px;
    left: 6px;
    padding: 3px 6px;
    font-size: 9px;
    border-radius: 5px;
  }
  .recommended-templates .recommendation-card .card-image .premium-tag svg {
    width: 8px;
    height: 8px;
  }
  .recommended-templates .recommendation-card .card-content {
    padding: 10px;
  }
  .recommended-templates .recommendation-card .card-content .card-title {
    font-size: 13px;
    margin-bottom: 6px;
  }
  .recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating svg {
    width: 10px;
    height: 10px;
  }
  .recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating .rating-value {
    font-size: 11px;
  }
  .recommended-templates .recommendation-card .card-content .card-footer-meta .card-rating .new-badge {
    font-size: 10px;
    padding: 2px 6px;
  }
  .recommended-templates .recommendation-card .card-content .card-footer-meta .card-price-section .price-amount {
    font-size: 13px;
  }
  .recommended-templates .recommendation-card .card-content .card-footer-meta .card-price-section .price-amount .currency-symbol {
    font-size: 11px;
  }
  .recommended-templates .recommendation-card .card-content .card-footer-meta .card-price-section .card-category {
    font-size: 10px;
    padding: 2px 6px;
  }
  .recommended-templates .view-more-container {
    margin-top: 10px;
  }
  .recommended-templates .view-more-container .view-more-btn {
    font-size: 12px;
    padding: 6px 14px;
  }
  .recommended-templates .view-more-container .view-more-btn svg {
    width: 12px;
    height: 12px;
  }
}

.tag-link:hover {
  background-color: #e9ecef !important;
  border-color: #6c757d !important;
  transform: translateY(-1px);
  transition: all 0.2s ease;
}

.recommendation-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1) !important;
  transition: all 0.2s ease;
}

.recommendation-card .recommendation-thumbnail::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(to bottom, transparent 60%, rgba(0, 0, 0, 0.1));
  pointer-events: none;
}

.edit-form-container {
  height: 100svh;
  width: 100%;
  display: grid;
  grid-template-rows: auto 1fr auto;
  grid-template-areas: "header" "content" "footer";
}
.edit-form-container .edit-form-header {
  grid-area: header;
  padding: 12px 12px 8px 12px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 8px;
}
.edit-form-container .edit-form-header .edit-form-back .edit-form-back-btn {
  color: #333;
  height: 42px;
  width: 42px;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  border: none;
  outline: none;
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 16px;
  font-weight: 500;
  cursor: pointer;
  background-color: #f8f9fa;
  border-radius: 50px;
  transition: all 0.3s ease-in-out;
}
.edit-form-container .edit-form-header .edit-form-back .edit-form-back-btn:hover {
  color: #1c1c1c;
  background-color: #e9ecef;
}
.edit-form-container .edit-form-header .edit-form-back .edit-form-back-btn i {
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.edit-form-container .edit-form-header .edit-form-title h5 {
  color: #1d1d1f;
  font-size: 16px;
  line-height: 18px;
  font-weight: 600;
  margin-bottom: 0;
  text-align: center;
  font-family: "Poppins", sans-serif;
}
.edit-form-container .edit-form-header .edit-form-close {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #1d1d1f;
  font-size: 16px;
}
.edit-form-container .edit-form-header .edit-form-close .edit-modal-close {
  background: #f8f9fa;
  color: #4d545b;
  height: 42px;
  width: 42px;
  border-radius: 50%;
  font-size: 16px;
  border: none;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: all 0.3s ease-in-out;
}
.edit-form-container .edit-form-header .edit-form-close .edit-modal-close:hover {
  background: #e7e9eb;
  color: #1c1c1c;
}
.edit-form-container .edit-form-header .edit-form-close .edit-modal-close i {
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.edit-form-container .edit-form-content {
  position: relative;
  grid-area: content;
  overflow-y: auto;
  padding: 12px;
  height: 100%;
  scroll-behavior: smooth;
}
.edit-form-container .edit-form-content::-webkit-scrollbar {
  width: 0;
}
.edit-form-container .edit-form-footer {
  grid-area: footer;
  padding: 12px;
}
.edit-form-container .edit-form-footer .action-btn-sticky-bottom {
  padding: 0 12px;
  background: #fff;
}
.edit-form-container .edit-form-footer .action-btn-sticky-bottom .btn-action-next {
  width: 100%;
  padding: 12px;
  border: none;
  border-radius: 50px;
  font-size: 16px;
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  color: #fff;
  background: #222;
  border: 1px solid #7c7c7c;
  cursor: pointer;
  transition: all 0.3s ease;
}