@import "https://cdn.jsdelivr.net/npm/flowbite@3.1.2/dist/flowbite.min.css";

@tailwind base;
@tailwind components;
@tailwind utilities;

@layer components {
  .btn-primary {
    @apply py-2 px-4 bg-blue-500 text-white font-semibold rounded-lg shadow-md hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-blue-400 focus:ring-opacity-75;
  }
}

/* Sponsor Slider Styles */
.sponsor-slider {
  @apply w-full;
}

.sponsor-slider .slick-slide {
  @apply px-4;
}

.sponsor-slider .slick-track {
  @apply flex items-center;
}

.sponsor-slider img {
  @apply mx-auto max-h-20 object-contain;
}

/* Hide default slick arrows */
.sponsor-slider .slick-prev,
.sponsor-slider .slick-next {
  @apply hidden;
}

/* Force black bullet color for black bulleted lists */
.list-disc.text-black > li::marker {
  color: #000;
}

/* Custom online event toggle color */
.peer:checked ~ .toggle-switch {
  background-color: #22C3B5 !important;
}

.dark .peer:checked ~ .toggle-switch {
  background-color: #22C3B5 !important;
}

/* Optional: Custom focus ring color for online event toggle */
.peer:focus ~ .toggle-switch {
  box-shadow: 0 0 0 4px rgba(34, 195, 181, 0.3) !important;
}

.dark .peer:focus ~ .toggle-switch {
  box-shadow: 0 0 0 4px rgba(34, 195, 181, 0.5) !important;
}

/* Debug class to test the toggle */
.toggle-switch.debug-checked {
  background-color: #22C3B5 !important;
}

.dark .toggle-switch.debug-checked {
  background-color: #22C3B5 !important;
}
.primay-button {
  background: #30C4B6 !important;
  border-radius: 8px !important;
  font-size: 16px !important;
  line-height: 24px !important;
  padding: 8px 16px !important;
  color: #111827 !important;
  font-weight: 600 !important;
  &:hover {
    background-color: #269d92 !important;
  }
}
.grey-button {
  background: #F3F4F6 !important;
  border-radius: 8px !important;
  font-size: 16px !important;
  line-height: 24px !important;
  padding: 8px 16px !important;
  color: #111827 !important;
  text-align: center !important;
  font-weight: 600 !important;
  &:hover {
    background-color: #e5e7eb !important;
  }
}
.secondary-button {
  background: white !important;
  border-radius: 8px !important;
  font-size: 16px !important;
  line-height: 24px !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
  border: 1px solid #30C4B6 !important;
  color: #111827 !important;
  &:hover {
    background-color: #E5E7EB !important;
  }
}
.fc-postEvent-button {
  background: #30C4B6;
  border-radius: 8px;
  font-size: 16px;
  line-height: 24px;
  padding: 8px 16px;
  color: #111827;
  margin-left: 0.75em;
}
.button-outer {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.button-outer button {
  border-radius: 8px;
  padding: 8px 16px;
  border: none;
  background: #F3F4F6;
}
.card_details {
  border: 1px solid #E5E7EB;
  border-radius: 12px;
}
.price-text {
  color: #111827;
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
.price-outer {
  background: #FFFFFF;
  padding: 4px 8px;
  border: 1px solid #30C4B6;
  border-radius: 4px;
  top: 12px;
}
.card_details {
  border: 1px solid #E5E7EB;
  border-radius: 12px;
}
.full_image_card {
  position: relative;
  height: 374px;
}
.full_image_card .card_text_details_inner {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 240px;
  background: linear-gradient(180deg, rgba(17, 24, 39, 0.00) 0%, #111827 80.29%);
  border-radius: 0px 0px 12px 12px;
}
.full_image_card .card_text_details {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 12px;
}
.full_image_card .event_card_date, .full_image_card .event_card_heading, .full_image_card .event_card_description {
  color: #FFFFFF;
}
.full_image_card .image-outer {
  height: 373px;
}
.full_image_card .card_event_image {
  border-radius: 12px;
}
.card_text_details {
  padding: 12px;
  width: 100%;
}
.fc-theme-standard .fc-list {
  border: none !important;
}
.image-outer {
  height: 256px;
}
.card_event_image {
  border-radius: 12px 12px 0px 0px;
}

.share-outer {
  display: flex;
  gap: 8px;
  top: -12px;
  right: 12px;
}
.share-icon {
  border-radius: 50px;
  background: #FFFFFF;
  border: 1px solid #30C4B6;
  box-shadow: 0 4px 16px -6px rgba(0, 0, 0, 0.16)
}
.plus-icon {
  border-radius: 50px;
  background: #FFFFFF;
  border: 1px solid #30C4B6;
  box-shadow: 0 4px 16px -6px rgba(0, 0, 0, 0.16)
}
.event_card_date {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
  color: #4B5563;
  margin-bottom: 8px;
}
.event_card_heading {
  font-size: 16px !important;
  font-weight: 600;
  line-height: 20px;
  color: #000000;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  height: 40px; /* 2 lines * 20px line-height */
}
.event_card_description {
  font-size: 12px;
  line-height: 16px;
  letter-spacing: 0px;
  color: #4B5563;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.event_card_date {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
  color: #4B5563;
  margin-bottom: 8px;
}
.event_blur_bg {
  opacity: 0.6;
  filter: blur(26px);
  height: 192px;
}
.event_container {
  top: -165px;
  width: 75%;
  left: 50%;
  transform: translateX(-50%);
}
.event_container .event_banner_image {
  height: 320px;
}
.event_details {
  margin-top: 16px;
  font-family: var(--Font-family);
  color: var(--Black);
}
.event_details .title {
  font-weight: 600;
  font-size: 20px;
}
.event_title {
  min-height: 80px;
}
.event_details .location {
  font-size: 16px;
  font-weight: 400;
  line-height: 20px;
  color: var(--Dark-gray);
}
.event_details .title {
  font-size: 32px;
  line-height: 40px;
}
.event_price .price {
  font-size: 14px;
}
.about_section .categories {
  margin-bottom: 12px;
  margin-top: 12px;
}
.category {
  padding: 4px 8px;
  border-radius: 4px;
  background-color: var(--Base-light);
}
.description {
  font-size: 14px;
}

.button_outer {
  gap: 16px;
}
.button_outer .secondary-button {
  padding: 12px 16px !important;
}
.button_outer .primay-button {
  padding: 12px 16px !important;
}
.date_time .date_time_text {
  margin-top: 12px;
}
.about_calendar {
  background: var(--Base-light);
  border-radius: 12px;
  .calendar_logo_image {
    width: 52px;
    border-radius: 50%;
  }
  .title {
    font-size: 16px;
    font-weight: 600;
  }
  .description {
    font-size: 14px;
    font-weight: 400;
  }
}
.back_button a {
  background: var(--Base-light);
  width: 85px;
}

.selected {
  border-bottom: 2px solid #30C4B6 !important;
  color: #111827;
  font-size: 16px !important;
  font-weight: 400;
}
.button-outer {
  
}
.button-inner button {
  padding: 8px 16px;
  flex-direction: column;
  border-radius: 8px;
}
.card_details {
  border: 1px solid #E5E7EB;
  border-radius: 12px;
}
.price-text {
  color: #111827;
  font-weight: 600;
  font-size: 14px;
  line-height: 20px;
}
.price-outer {
  background: #FFFFFF;
  padding: 4px 8px;
  border: 1px solid #30C4B6;
  border-radius: 4px;
  top: 12px;
}
.card_details {
  border: 1px solid #E5E7EB;
  border-radius: 12px;
}
.full_image_card {
  position: relative;
  height: 374px;
}
.full_image_card .card_text_details_inner {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 240px;
  background: linear-gradient(180deg, rgba(17, 24, 39, 0.00) 0%, #111827 80.29%);
  border-radius: 0px 0px 12px 12px;
}
.full_image_card .card_text_details {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 12px;
}
.full_image_card .event_card_date, .full_image_card .event_card_heading, .full_image_card .event_card_description {
  color: #FFFFFF;
}
.full_image_card .image-outer {
  height: 373px;
}
.full_image_card .card_event_image {
  border-radius: 12px;
}
.card_text_details {
  padding: 12px;
  width: 100%;
}
.image-outer {
  height: 256px;
}
.card_event_image {
  border-radius: 12px 12px 0px 0px;
}
.share-outer {
  display: flex;
  gap: 8px;
  top: -12px;
  right: 12px;
}
.share-icon {
  border-radius: 50px;
  background: #FFFFFF;
  border: 1px solid #30C4B6;
  box-shadow: 0 4px 16px -6px rgba(0, 0, 0, 0.16)
}
.plus-icon {
  border-radius: 50px;
  background: #FFFFFF;
  border: 1px solid #30C4B6;
  box-shadow: 0 4px 16px -6px rgba(0, 0, 0, 0.16)
}
.event_card_date {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
  color: #4B5563;
  margin-bottom: 8px;
}
.event_card_heading {
  font-size: 16px !important;
  font-weight: 600;
  line-height: 20px;
  color: #000000;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  height: 40px; /* 2 lines * 20px line-height */
}
.event_card_description {
  font-size: 12px;
  line-height: 16px;
  letter-spacing: 0px;
  color: #4B5563;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.event_card_date {
  font-weight: 400;
  font-size: 12px;
  line-height: 16px;
  color: #4B5563;
  margin-bottom: 8px;
}
/* Hide scrollbar but keep functionality */
.hide-scrollbar {
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}
.hide-scrollbar::-webkit-scrollbar {
  display: none;  /* Chrome, Safari and Opera */
}

/* Ensure the container has proper spacing for arrows */
.all_categories {
  position: relative;
  padding-left: 0;
  padding-right: 0;
}

#all_influencers {
  position: relative;
  padding-left: 0;
  padding-right: 0;
}

/* Position arrows relative to the scroll container */
.scroll-left {
  left: 0;
}

.scroll-right {
  right: 0;
}

/* Add padding to scroll container to make space for arrows */
.scroll-container {
  margin: 0 40px;
  position: relative;
}

@media (max-width: 768px) {
  .scroll-container {
    margin: 0;
  }
}
#calendar-viewer-container, #event-card-view-skeleton {
  height: auto;
  overflow-y: auto;
  flex-wrap: wrap;
  justify-content: center;
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}

.event-card {
  max-width: 280px;
  height: 374px;
  width: 100%;
}
.button-inner {
  border-radius: 8px;
  background: var(--Base-light);
  padding: 4px;
}
.button-inner .active {
  background: var(--White);
}
.post-event-button {
  color: var(--Black);
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 24px;
  border-radius: 8px;
  border: 1px solid var(--Daisy-mint);
  background: var(--White);
  padding: 4px 12px;
}
.post-event-button:hover {
  background: var(--Base-gray) !important;
}
.list-disc li::marker {
  color: #30C4B6;
}
.list-decimal li::marker {
  color: #30C4B6;
}
.footer_pages h2 {
  font-size: 35px;
  font-weight: 500;
  line-height: 47.4925px;
}

.footer_pages h3 {
  font-size: 17px;
  font-weight: 700;
  line-height: 30.6px;
}
.footer_pages p {
  font-size: 17px;
  font-weight: 300;
  line-height: 30.6px;
}

.footer_pages li {
  font-size: 17px;
  font-weight: 300;
  line-height: 30.6px;
}
.footer_pages h1 {
  font-size: 63px;
  font-weight: 700;
  line-height: 78.3355px;
  color: rgb(20, 18, 18);
}

.terms * {
  color: rgb(20, 18, 18);
}
.privacy * {
  color: rgb(38, 37, 37)
}
.advertise h1 {
  color: #30C4B6;
  font-size: 40px;
  font-weight: 500;
}
.advertise h3 {
  font-weight: 700;
  font-size: 17px;
  color: rgb(3, 3, 3);
}
.advertise h3 b {
  font-weight: 1000;
}
.bg_teal {
  background-color: #22C3B5;
}
.menu-text {
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  color: #111827;
}
.outer-menu {
  padding: 8px;
  gap: 16px;
}
.active-menu {
  background-color: #E5E7EB !important;
}
/* Select2 Custom Styling */
.select2-container--default .select2-selection--multiple {
  border-color: #D1D5DB;
  border-radius: 0.375rem;
  min-height: 38px;
}

.select2-container--default.select2-container--focus .select2-selection--multiple {
  border-color: #3B82F6;
  box-shadow: 0 0 0 1px #3B82F6;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
  background-color: #E5E7EB;
  border: none;
  border-radius: 0.25rem;
  padding: 0.25rem 0.5rem;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
  color: #6B7280;
  margin-right: 0.5rem;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
  color: #374151;
}

.select2-container {
  width: 100% !important;
} 
.slick-prev,
.slick-next {
  width: 40px !important;
  height: 40px !important;
  background: transparent !important;
  z-index: 10 !important;
}

.slick-prev:hover,
.slick-next:hover {
  background: transparent !important;
}

.slick-prev:before,
.slick-next:before {
  font-size: 40px !important;
  color: #000000 !important;
  opacity: 1 !important;
}

/* Hide default arrows when disabled */
.slick-disabled {
  opacity: 0.3 !important;
  cursor: not-allowed !important;
}

.ads-slider {
  padding: 0 40px !important;
  margin: 0 20px !important;
}
@media (max-width: 768px) {
  .ads-slider {
    padding: 0 20px !important;
    margin: 0 10px !important;
  }
}
.ads-slider .custom-slick-arrow {
  background: white !important;
  border-radius: 50%;
  box-shadow: 0 8px 16px -4px rgba(0,0,0,0.18); /* Only bottom shadow */
  width: 48px;
  height: 48px;
  padding: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: box-shadow 0.2s;
  &:hover {
    background: #f0f0f0 !important;
  }
}
/*
 * This is a manifest file that'll be compiled into application.css, which will include all the files
 * listed below.
 *
 * Any CSS (and SCSS, if configured) file within this directory, lib/assets/stylesheets, or any plugin's
 * vendor/assets/stylesheets directory can be referenced here using a relative path.
 *
 * You're free to add application-wide styles to this file and they'll appear at the bottom of the
 * compiled file so the styles you add here take precedence over styles defined in any other CSS/SCSS files
 * in this directory. Styles defined in any other CSS/SCSS files in this directory. It's generally better to create a new
 * file per style scope.
 *


 */

/* Invisible Captcha Honeypot Styles */
.invisible-captcha {
  position: absolute !important;
  left: -9999px !important;
  top: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.invisible-captcha input {
  position: absolute !important;
  left: -9999px !important;
  top: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  border: none !important;
  background: transparent !important;
  color: transparent !important;
}

/* Import Select2 base styles */
@import "select2/dist/css/select2.css";

/* Import our custom Select2 styles */
@import "select2.css";
@import "footer.css";
@import "custom.css";
@import "menu.css";
@import "event_detail.css";
@import "event_card.css";

:root {
  /* custom colors */
  --Dark-gray: #4B5563;
  --Black: #111827;
  --Base-light: #F3F4F6;
  --White: #FFF;
  --Daisy-mint: #30C4B6;
}
/* Calendar custom styles */
.fc .fc-toolbar-title {
  font-size: 1.5rem;
  font-weight: bold;
}

.fc .fc-button-primary {
  background-color: #2D3142;
  border-color: #2D3142;
}

.fc .fc-button-primary:hover {
  background-color: #1e2130;
  border-color: #1e2130;
}

.fc .fc-daygrid-day-number {
  font-size: 0.9rem;
  color: #333;
}

.fc .fc-col-header-cell-cushion {
  font-weight: 600;
  color: #2D3142;
}
.fc-list-day.fc-day {
  display: none !important;
}
.fc-event.fc-event-start.fc-event-end.fc-event-future.fc-list-event, .fc-event.fc-event-start.fc-event-end.fc-event-past.fc-list-event {
  display: none !important;
}

.fc-event.fc-event-start.fc-event-end.fc-event-past.fc-list-event {
  display: none !important;
}
.event-month-view .event_month:last-of-type .save-options {
  bottom: 50px !important;
}
@media (max-width: 768px) {
  .category-filter {
    font-size: .8rem !important;
  }
  .card_category {
    font-size: .8rem !important;
  }
  #all_influencers .scroll-container button:first-child {
    margin-left: 1.5rem !important;
  }
}
.fc .fc-button:focus {
  box-shadow: none !important;
}
.loader {
  border-top-color: #3498db;
  animation: spin 1s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
.marquee-track {
  display: flex;
  flex-wrap: nowrap;
  animation: marquee-scroll 30s linear infinite;
}

@keyframes marquee-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
.calendar_show {
  width: 90% !important;
}
@media (max-width: 768px) {
  .calendar_show {
    width: 95% !important;
  }
}
@media (min-width: 480px) {
  .sponsor-slider {
    width: 80% !important;
  }
}

.ads-slider .slick-track {
  padding-bottom: .5rem;
}

.banner_logo {
  bottom: -60px;
  left: 50%;
  transform: translateX(-50%);
}

.banner_logo img {
  display: block;
  object-fit: cover;
  object-position: 50% 50%;
  width: 100%;
  height: 100%;
  border-radius: 50%;
}

.categoy-name {
  font-size: 14px;
}
.daisy-blue {
  background-color: #30c4b6;
}

/* Hide calendar and card views in map mode */
#calendar-viewer.map-mode .fc-dayGridMonth-view,
#calendar-viewer.map-mode .fc-listMonth-view {
  display: none !important;
}

#calendar-viewer.map-mode #calendar-map {
  display: block !important;
}

.about-daisy-btn {
  background-color: #22C3B5 !important;
  transition: filter 0.2s, background-color 0.2s;
}

.about-daisy-btn:hover {
  filter: brightness(0.90);
}
.dark\:peer-checked\:bg-blue-600 {
  background-color: #22C3B5 !important;
}
.dataTables_length {
  display: none !important;
}

.subscribe-button {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 48px;
  border-radius: 8px;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 14px;
  transition: all 0.3s ease;
  cursor: pointer;
  border: none;
  min-width: 140px;
}

.subscribe-button.subscribe {
  background-color: #2ECDAF;
  color: white;
}

.subscribe-button.subscribed {
  background-color: #E5E7EB;
  color: #374151;
}
