/*
 * Evento Single Page - Growth Hacking Optimized Styles
 * Following MoneyViz Design System and Eventi Page Pattern
 *
 * Design Principles:
 * - CSS Custom Properties for design tokens
 * - Mobile-first responsive design
 * - WCAG 2.1 AA accessible contrast ratios
 * - Performance optimized animations
 * - LIGHT gradient background like eventi.scss (NOT digital-dump dark gradient)
 */

/* =================================
   CSS CUSTOM PROPERTIES (Design Tokens)
   ================================= */

:root {
  /* MoneyViz Color System */
  --evento-color-primary: #ec6029;
  /* MoneyViz Orange */
  --evento-color-primary-light: #fce4d8;
  /* Lighten 48% equivalent */
  --evento-color-info: #17a2b8;
  /* Cyan */
  --evento-color-info-light: #d4f1f4;
  /* Lighten 48% equivalent */
  --evento-color-secondary: #54575a;
  /* Gray-600 */
  --evento-color-success: #1eb100;
  /* Green */
  --evento-color-warning: #ffc107;
  /* Yellow */
  /* Grayscale */
  --evento-color-white: #fff;
  --evento-color-gray-100: #f7f7f7;
  --evento-color-gray-200: #f3f3f3;
  --evento-color-gray-300: #eeede9;
  --evento-color-gray-600: #54575a;
  --evento-color-gray-700: #495057;
  --evento-color-gray-900: #2e2e2e;
  --evento-color-black: #000000;
  /* Gradients - LIGHT like eventi.scss */
  --evento-gradient-hero: linear-gradient(135deg, #fce4d8 0%, #fff 50%, #d4f1f4 100%);
  /* Spacing Scale (8px base) */
  --evento-spacing-sm: 0.5rem;
  /* 8px */
  --evento-spacing-md: 1rem;
  /* 16px */
  --evento-spacing-lg: 1.5rem;
  /* 24px */
  --evento-spacing-xl: 2rem;
  /* 32px */
  --evento-spacing-2xl: 2.5rem;
  /* 40px */
  --evento-spacing-3xl: 3.5rem;
  /* 56px */
  /* Typography */
  --evento-font-size-sm: 0.875rem;
  /* 14px */
  --evento-font-size-base: 1rem;
  /* 16px */
  --evento-font-size-lg: 1.125rem;
  /* 18px */
  --evento-font-size-xl: 1.25rem;
  /* 20px */
  /* Font Weights */
  --evento-font-weight-normal: 400;
  --evento-font-weight-medium: 500;
  --evento-font-weight-bold: 700;
  --evento-font-weight-bolder: 800;
  /* Border Radius */
  --evento-border-radius: 10px;
  --evento-border-radius-lg: 1rem;
  /* Shadows */
  --evento-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --evento-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --evento-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
  --evento-shadow-video: 0 20px 60px rgba(0, 0, 0, 0.3);
  /* Transitions */
  --evento-transition-base: all 0.2s ease-in-out;
  --evento-transition-fast: all 0.15s ease-in-out;
}

/* =================================
   HERO SECTION - LIGHT GRADIENT LIKE EVENTI
   ================================= */

.evento-hero {
  background: var(--evento-gradient-hero);
  padding: 5rem 0 4rem;
  position: relative;
  overflow: hidden;
}

/* Back Link - DARK text on light background */

.evento-back-link {
  color: var(--evento-color-gray-700);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  margin-bottom: 1rem;
  transition: var(--evento-transition-fast);
}

.evento-back-link:hover {
  color: var(--evento-color-primary);
  text-decoration: none;
}

/* Event Badge - Yellow/Warning style */

.evento-badge {
  display: inline-block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.5px;
  background: var(--evento-color-warning) !important;
  color: var(--evento-color-gray-900) !important;
  border: none !important;
}

/* Hero Typography - DARK text */

.evento-hero-title {
  color: var(--evento-color-gray-900) !important;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.02em;
  text-shadow: none;
  /* No shadow on light background */
}

.evento-hero-lead {
  color: var(--evento-color-gray-700) !important;
  font-weight: 400;
  line-height: 1.6;
  text-shadow: none;
  /* No shadow on light background */
}

/* Event Meta - DARK text */

.evento-meta {
  display: flex;
  align-items: center;
  color: var(--evento-color-gray-700);
  margin-bottom: var(--evento-spacing-lg);
  flex-wrap: wrap;
  gap: 0.5rem;
}

/* Trust Badges - DARK text on light background */

.evento-trust-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--evento-spacing-md);
  color: var(--evento-color-gray-700);
  margin-bottom: var(--evento-spacing-lg);
  padding-top: var(--evento-spacing-lg);
  border-top: 1px solid var(--evento-color-gray-300);
}

.evento-trust-badge {
  display: flex;
  align-items: center;
  font-weight: 500;
  font-size: var(--evento-font-size-sm);
}

.evento-trust-badge .material-icons {
  margin-right: 0.5rem;
  color: var(--evento-color-primary);
}

/* Social Proof Box - Light background with border */

.evento-social-proof {
  background: var(--evento-color-white) !important;
  border: 2px solid var(--evento-color-gray-300);
  border-radius: var(--evento-border-radius);
  padding: 1.25rem;
  color: var(--evento-color-gray-700);
  box-shadow: var(--evento-shadow);
}

.evento-social-proof .material-icons {
  font-size: 2.5rem;
  margin-right: 1rem;
  color: var(--evento-color-primary);
  flex-shrink: 0;
}

.evento-social-proof-number {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: 0.25rem;
  color: var(--evento-color-gray-900);
}

.evento-social-proof-text {
  font-size: 0.875rem;
  color: var(--evento-color-gray-600);
  display: block;
}

/* =================================
   VIDEO PLAYER
   ================================= */

.evento-video-container {
  position: relative;
  border-radius: var(--evento-border-radius-lg);
  overflow: hidden;
  box-shadow: var(--evento-shadow-video);
  cursor: pointer;
  transition: var(--evento-transition-base);
  width: 100%;
  max-width: 100%;
  /* Ensure embed-responsive works properly */
}

.evento-video-container:hover {
  transform: translateY(-4px);
  box-shadow: 0 25px 70px rgba(0, 0, 0, 0.35);
}

.evento-video-container .embed-responsive {
  border-radius: 0;
  /* Remove border-radius from inner element */
}

.evento-video-container iframe {
  border-radius: 0;
}

.evento-video-thumbnail {
  width: 100%;
  height: auto;
  display: block;
  max-width: 100%;
}

.evento-video-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.4);
  transition: var(--evento-transition-base);
}

.evento-video-overlay:hover {
  background: rgba(0, 0, 0, 0.5);
}

.evento-play-button {
  text-align: center;
  padding: 1rem;
}

.evento-play-button .material-icons {
  font-size: 5rem;
  color: var(--evento-color-white);
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.3));
}

.evento-play-text {
  color: var(--evento-color-white);
  font-weight: 700;
  margin-top: 1rem;
  margin-bottom: 0;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  font-size: 0.875rem;
}

/* =================================
   DESCRIPTION SECTION
   ================================= */

.evento-description-section {
  padding: var(--evento-spacing-3xl) 0;
  background: var(--evento-color-white);
}

.evento-description-card {
  border: 0;
  border-radius: var(--evento-border-radius);
  box-shadow: var(--evento-shadow-sm);
}

.evento-description-title {
  font-weight: 700;
  margin-bottom: var(--evento-spacing-lg);
}

.evento-description-title .material-icons {
  color: var(--evento-color-primary);
  font-size: 1.8rem;
  vertical-align: middle;
  margin-right: 0.5rem;
}

.evento-description-content {
  white-space: pre-wrap;
  line-height: 1.8;
  color: #4b5563;
  font-size: 15px;
}

/* =================================
   RESPONSIVE DESIGN
   ================================= */

@media (min-width: 768px) {
  .evento-hero {
    padding: 7rem 0 5rem;
  }
}

@media (max-width: 991.98px) {
  .evento-hero {
    padding: 4rem 0 3rem;
  }

  .evento-hero-title {
    font-size: 2rem;
  }

  .evento-video-container {
    margin-top: var(--evento-spacing-xl);
  }
}

@media (max-width: 767.98px) {
  .evento-hero {
    padding: 3rem 0 2rem;
  }

  .evento-badge {
    font-size: 10px;
  }

  .evento-trust-badges {
    flex-direction: column;
    gap: var(--evento-spacing-sm);
  }

  .evento-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--evento-spacing-sm);
  }

  /* Social proof box - more compact on mobile */

  .evento-social-proof {
    padding: 1rem;
  }

  .evento-social-proof .material-icons {
    font-size: 2rem;
    margin-right: 0.75rem;
  }

  .evento-social-proof-number {
    font-size: 1rem;
  }

  /* Video player - ensure it fits on mobile */

  .evento-video-container {
    margin-top: var(--evento-spacing-lg);
    box-shadow: var(--evento-shadow);
  }

  .evento-video-container:hover {
    transform: none;
    /* Disable hover transform on mobile */
  }

  .evento-play-button {
    padding: 0.5rem;
  }

  .evento-play-button .material-icons {
    font-size: 3.5rem;
  }

  .evento-play-text {
    font-size: 0.75rem;
    margin-top: 0.5rem;
  }
}

/* =================================
   UTILITY CLASSES & GLOBAL FIXES
   ================================= */

.evento-single-page {
  overflow-x: hidden;
  /* Prevent horizontal scroll on mobile */
}

.evento-animate-fadeIn {
  animation: fadeIn 0.6s ease-in-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Ensure Bootstrap embed-responsive doesn't overflow */

.embed-responsive {
  max-width: 100%;
}

