/* === css/critical.css === */
/* BroadComms Critical CSS - Phase 2 Optimization */
/* Above-the-fold styles loaded synchronously for fast rendering */

/* Essential Layout & Typography */
* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: 'IBM Plex Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  line-height: 1.6;
  color: #2c3e50;
}

/* Critical Navigation Styles */
.navbar {
  background: rgba(255, 255, 255, 0.95) !important;
  border-bottom: 1px solid rgba(25, 112, 10, 0.1);
  transition: all 0.3s ease;
}

.navbar-brand {
  font-weight: 700;
  font-size: 1.8rem;
  color: #19700a !important;
}

/* Essential Hero Section - Simplified for Performance */
.enterprise-hero {
  min-height: 100vh;
  background: linear-gradient(135deg, #19700a 0%, #0f62fe 50%, #19700a 100%);
  color: white;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}

.hero-content {
  text-align: center;
  z-index: 2;
  position: relative;
  max-width: 900px;
  margin: 0 auto;
  padding: 2rem;
}

.hero-title {
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  margin-bottom: 1.5rem;
  line-height: 1.2;
}

.hero-subtitle {
  font-size: clamp(1.1rem, 2.5vw, 1.5rem);
  margin-bottom: 2rem;
  opacity: 0.95;
  font-weight: 400;
}

/* Critical Button Styles */
.btn {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
  transition: all 0.3s ease;
  border: none;
  cursor: pointer;
}

.btn-primary {
  background: #ffffff;
  color: #19700a;
}

.btn-outline-light {
  background: transparent;
  color: white;
  border: 2px solid rgba(255, 255, 255, 0.3);
}

/* Skip Navigation for Accessibility */
.skip-nav-link {
  position: absolute;
  top: -40px;
  left: 6px;
  z-index: 100000;
  color: white;
  background: #19700a;
  padding: 8px 16px;
  text-decoration: none;
  border-radius: 0 0 4px 4px;
  font-size: 14px;
  font-weight: 600;
  transition: top 0.3s ease;
}

.skip-nav-link:focus {
  top: 0;
  outline: 2px solid #ffd700;
  outline-offset: 2px;
}

/* Essential Focus Styles */
*:focus {
  outline: 2px solid #19700a;
  outline-offset: 2px;
}



/* Critical Utility Classes */
.text-center { text-align: center; }
.mb-3 { margin-bottom: 1rem; }
.mb-4 { margin-bottom: 1.5rem; }
.py-5 { padding: 3rem 0; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 1rem; }
.row { display: flex; flex-wrap: wrap; }
.col { flex: 1; }

/* Responsive Design */
@media (max-width: 768px) {
  .hero-content { padding: 1rem; }
  .hero-title { font-size: 2.5rem; }
  .hero-subtitle { font-size: 1.1rem; }
}


/* === css/design-system.css === */
/*
==================================================
BroadComms Design System - Optimized & Consolidated
==================================================

This file consolidates and optimizes all CSS for better performance,
maintainability, and compliance with modern web standards.

ARCHITECTURE:
1. CSS Custom Properties (Design Tokens)
2. Reset & Base Styles  
3. Typography System
4. Layout Components
5. Component Library
6. Utilities
7. Responsive Design
8. Accessibility Enhancements

VERSION: 2.0 (Optimized)
LAST UPDATED: July 15, 2025
*/

/* ==============================================
   1. CSS CUSTOM PROPERTIES (DESIGN TOKENS)
   ============================================== */

/* Global Overflow Prevention */
html {
  overflow-x: hidden;
}

/*
body {
  overflow-x: hidden;
  max-width: 100%;
}

*/

:root {
  /* Brand Colors - WCAG AA Compliant */
  --bc-primary: #19700a;
  --bc-primary-dark: #0f4f07;
  --bc-primary-light: #2d8a1f;
  --bc-primary-alpha: rgba(25, 112, 10, 0.1);
  
  --bc-secondary: #0f62fe;
  --bc-secondary-dark: #0043ce;
  --bc-secondary-light: #4589ff;
  --bc-secondary-alpha: rgba(15, 98, 254, 0.1);
  
  --bc-accent: #ffd700;
  --bc-accent-dark: #e6c200;
  --bc-accent-alpha: rgba(255, 215, 0, 0.2);
  
  --bc-danger: #dc3545;
  --bc-success: #28a745;
  --bc-warning: #ffc107;
  --bc-info: #17a2b8;
  
  /* Neutral Colors */
  --bc-white: #ffffff;
  --bc-gray-50: #f8f9fa;
  --bc-gray-100: #e9ecef;
  --bc-gray-200: #dee2e6;
  --bc-gray-300: #ced4da;
  --bc-gray-400: #adb5bd;
  --bc-gray-500: #6c757d;
  --bc-gray-600: #495057;
  --bc-gray-700: #343a40;
  --bc-gray-800: #212529;
  --bc-gray-900: #1a1d20;
  
  /* Text Colors */
  --bc-text-primary: #2c3e50;
  --bc-text-secondary: #6c757d;
  --bc-text-muted: #8a94a6;
  --bc-text-white: #ffffff;
  --bc-text-light: #f8f9fa;
  
  /* Background Colors */
  --bc-bg-primary: #ffffff;
  --bc-bg-secondary: #f8f9fa;
  --bc-bg-dark: #212529;
  --bc-bg-gradient: linear-gradient(135deg, var(--bc-primary) 0%, var(--bc-secondary) 100%);
  
  /* Typography Scale - Enhanced for WCAG 2.1 AA */
  --bc-font-family-primary: 'IBM Plex Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --bc-font-family-secondary: 'Nunito', sans-serif;
  --bc-font-family-display: 'Rubik', sans-serif;
  --bc-font-family-mono: 'JetBrains Mono', 'Consolas', 'Monaco', monospace;
  
  --bc-font-size-xs: 0.75rem;    /* 12px */
  --bc-font-size-sm: 0.875rem;   /* 14px */
  --bc-font-size-base: 1rem;     /* 16px */
  --bc-font-size-lg: 1.125rem;   /* 18px */
  --bc-font-size-xl: 1.25rem;    /* 20px */
  --bc-font-size-2xl: 1.5rem;    /* 24px */
  --bc-font-size-3xl: 1.875rem;  /* 30px */
  --bc-font-size-4xl: 2.25rem;   /* 36px */
  --bc-font-size-5xl: 3rem;      /* 48px */
  --bc-font-size-6xl: 3.75rem;   /* 60px */
  
  /* Enhanced Font Weight System for Perfect Consistency */
  --bc-font-weight-light: 300;
  --bc-font-weight-normal: 400;
  --bc-font-weight-medium: 500;
  --bc-font-weight-semibold: 600;
  --bc-font-weight-bold: 700;
  --bc-font-weight-extrabold: 800;
  
  /* Semantic Font Weights for Components */
  --bc-font-weight-body: var(--bc-font-weight-normal);
  --bc-font-weight-caption: var(--bc-font-weight-medium);
  --bc-font-weight-button: var(--bc-font-weight-semibold);
  --bc-font-weight-heading: var(--bc-font-weight-bold);
  --bc-font-weight-hero: var(--bc-font-weight-extrabold);
  
  --bc-line-height-tight: 1.25;
  --bc-line-height-normal: 1.5;
  --bc-line-height-relaxed: 1.75;
  
  /* Letter Spacing for Better Readability */
  --bc-letter-spacing-tight: -0.025em;
  --bc-letter-spacing-normal: 0;
  --bc-letter-spacing-wide: 0.025em;
  
  /* Spacing Scale (8px base) */
  --bc-space-1: 0.25rem;   /* 4px */
  --bc-space-2: 0.5rem;    /* 8px */
  --bc-space-3: 0.75rem;   /* 12px */
  --bc-space-4: 1rem;      /* 16px */
  --bc-space-5: 1.25rem;   /* 20px */
  --bc-space-6: 1.5rem;    /* 24px */
  --bc-space-8: 2rem;      /* 32px */
  --bc-space-10: 2.5rem;   /* 40px */
  --bc-space-12: 3rem;     /* 48px */
  --bc-space-16: 4rem;     /* 64px */
  --bc-space-20: 5rem;     /* 80px */
  --bc-space-24: 6rem;     /* 96px */
  
  /* Border Radius */
  --bc-radius-sm: 0.25rem;   /* 4px */
  --bc-radius-md: 0.375rem;  /* 6px */
  --bc-radius-lg: 0.5rem;    /* 8px */
  --bc-radius-xl: 0.75rem;   /* 12px */
  --bc-radius-2xl: 1rem;     /* 16px */
  --bc-radius-full: 50%;
  
  /* Shadows - WCAG Compliant */
  --bc-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --bc-shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07);
  --bc-shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
  --bc-shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.1);
  --bc-shadow-2xl: 0 25px 50px rgba(0, 0, 0, 0.15);
  --bc-shadow-inner: inset 0 2px 4px rgba(0, 0, 0, 0.06);
  
  /* Transitions */
  --bc-transition-fast: 150ms ease-in-out;
  --bc-transition-normal: 300ms cubic-bezier(0.4, 0, 0.2, 1);
  --bc-transition-slow: 500ms cubic-bezier(0.4, 0, 0.2, 1);
  
  /* Breakpoints */
  --bc-screen-sm: 576px;
  --bc-screen-md: 768px;
  --bc-screen-lg: 992px;
  --bc-screen-xl: 1200px;
  --bc-screen-2xl: 1400px;
  
  /* Component Specific */
  --bc-header-height: 80px;
  --bc-header-height-mobile: 70px;
  --bc-footer-height: auto;
  --bc-sidebar-width: 280px;
  
  /* Z-Index Scale */
  --bc-z-dropdown: 1000;
  --bc-z-sticky: 1020;
  --bc-z-fixed: 1030;
  --bc-z-modal-backdrop: 1040;
  --bc-z-modal: 1050;
  --bc-z-popover: 1060;
  --bc-z-tooltip: 1070;
  --bc-z-skip-nav: 100000;
}

/* ===========================================
   LOADING & SPINNER STYLES
   =========================================== */

/* Page loading spinner - hidden by default */
#spinner {
  z-index: 9999;
}

#spinner.show {
  display: flex !important;
}

/* Custom spinner animation if needed */
.spinner {
  width: 40px;
  height: 40px;
  border: 4px solid #f3f3f3;
  border-top: 4px solid var(--bc-primary);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Ensure spinner doesn't interfere with content */
body:not(.loading) #spinner {
  display: none !important;
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
  :root {
    --bc-bg-primary: #1a1d20;
    --bc-bg-secondary: #212529;
    --bc-text-primary: #ffffff;
    --bc-text-secondary: #adb5bd;
    --bc-gray-50: #343a40;
    --bc-gray-100: #495057;
  }
}

/* ==============================================
   2. RESET & BASE STYLES
   ============================================== */

/* Modern CSS Reset */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 100%;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  font-family: var(--bc-font-family-primary);
  font-size: var(--bc-font-size-base);
  font-weight: var(--bc-font-weight-normal);
  line-height: var(--bc-line-height-normal);
  color: var(--bc-text-primary);
  background-color: var(--bc-bg-primary);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Improved focus management */
*:focus {
  outline: 2px solid var(--bc-primary);
  outline-offset: 2px;
}

*:focus:not(:focus-visible) {
  outline: none;
}

*:focus-visible {
  outline: 3px solid var(--bc-accent);
  outline-offset: 2px;
}


.success-story-card h4,
.success-story-card h3,
.feature-highlight span{
  color: #222d20!important;
}


/* ==============================================
   3. ENHANCED TYPOGRAPHY SYSTEM - WCAG 2.1 AA
   ============================================== */

/* Perfect Font Weight Consistency */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--bc-font-family-display);
  font-weight: var(--bc-font-weight-heading);
  line-height: var(--bc-line-height-tight);
  /* color: var(--bc-text-primary); */
  margin-bottom: var(--bc-space-4);
  letter-spacing: var(--bc-letter-spacing-tight);
}


.product-detail-hero .lead, 
.product-detail-hero h1 {
  color: var(--bc-white);
}

/* Semantic Heading Hierarchy */
h1 {
  font-size: var(--bc-font-size-5xl);
  font-weight: var(--bc-font-weight-hero);
  letter-spacing: var(--bc-letter-spacing-tight);
}

h2 {
  font-size: var(--bc-font-size-4xl);
  font-weight: var(--bc-font-weight-bold);
  letter-spacing: var(--bc-letter-spacing-normal);
}

h3 {
  font-size: var(--bc-font-size-3xl);
  font-weight: var(--bc-font-weight-bold);
  letter-spacing: var(--bc-letter-spacing-normal);
}

h4 {
  font-size: var(--bc-font-size-2xl);
  font-weight: var(--bc-font-weight-semibold);
  letter-spacing: var(--bc-letter-spacing-normal);
}

h5 {
  font-size: var(--bc-font-size-xl);
  font-weight: var(--bc-font-weight-semibold);
  letter-spacing: var(--bc-letter-spacing-normal);
}

h6 {
  font-size: var(--bc-font-size-lg);
  font-weight: var(--bc-font-weight-semibold);
  letter-spacing: var(--bc-letter-spacing-wide);
}

/* Body Text with Perfect Typography */
body, p, .body-text {
  font-family: var(--bc-font-family-primary);
  font-weight: var(--bc-font-weight-body);
  font-size: var(--bc-font-size-base);
  line-height: var(--bc-line-height-normal);
  color: var(--bc-text-primary);
  letter-spacing: var(--bc-letter-spacing-normal);
}

/* Caption and Small Text */
.caption, .small, small {
  font-family: var(--bc-font-family-primary);
  font-weight: var(--bc-font-weight-caption);
  font-size: var(--bc-font-size-sm);
  line-height: var(--bc-line-height-normal);
  letter-spacing: var(--bc-letter-spacing-wide);
}

/* Lead Text */
.lead {
  font-family: var(--bc-font-family-primary);
  font-weight: var(--bc-font-weight-normal);
  font-size: var(--bc-font-size-lg);
  line-height: var(--bc-line-height-relaxed);
  letter-spacing: var(--bc-letter-spacing-normal);
}

/* Ensure Bootstrap display classes take precedence */
.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
  font-family: var(--bc-font-family-display) !important;
  font-weight: var(--bc-font-weight-hero) !important;
  line-height: var(--bc-line-height-tight) !important;
  letter-spacing: var(--bc-letter-spacing-tight) !important;
}

.display-1 { font-size: calc(1.625rem + 4.5vw) !important; }
.display-2 { font-size: calc(1.575rem + 3.9vw) !important; }
.display-3 { font-size: calc(1.525rem + 3.3vw) !important; }
.display-4 { font-size: calc(1.475rem + 2.7vw) !important; }
.display-5 { font-size: calc(1.425rem + 2.1vw) !important; }
.display-6 { font-size: calc(1.375rem + 1.5vw) !important; }

/* Bootstrap responsive display classes */
@media (min-width: 1200px) {
  .display-1 { font-size: 5rem !important; }
  .display-2 { font-size: 4.5rem !important; }
  .display-3 { font-size: 4rem !important; }
  .display-4 { font-size: 3.5rem !important; }
  .display-5 { font-size: 3rem !important; }
  .display-6 { font-size: 2.5rem !important; }
}

/* Font Optimization for Better Rendering */
* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

h2 {
  font-size: var(--bc-font-size-4xl);
  font-weight: var(--bc-font-weight-bold);
}

h3 {
  font-size: var(--bc-font-size-3xl);
  font-weight: var(--bc-font-weight-bold);
}

h4 {
  font-size: var(--bc-font-size-2xl);
  font-weight: var(--bc-font-weight-semibold);
}

h5 {
  font-size: var(--bc-font-size-xl);
  font-weight: var(--bc-font-weight-semibold);
}

h6 {
  font-size: var(--bc-font-size-lg);
  font-weight: var(--bc-font-weight-medium);
}

p {
  margin-bottom: var(--bc-space-4);
  line-height: var(--bc-line-height-relaxed);
}

/* Responsive Typography */
@media (max-width: 768px) {
  h1 { font-size: var(--bc-font-size-4xl); }
  h2 { font-size: var(--bc-font-size-3xl); }
  h3 { font-size: var(--bc-font-size-2xl); }
  h4 { font-size: var(--bc-font-size-xl); }
}

/* ==============================================
   4. LAYOUT COMPONENTS
   ============================================== */

/* Flexible Layout System */
.bc-container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--bc-space-4);
}

.bc-container-fluid {
  width: 100%;
  padding: 0 var(--bc-space-4);
}

/* Grid System */
.bc-grid {
  display: grid;
  gap: var(--bc-space-6);
}

.bc-grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.bc-grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.bc-grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.bc-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }

/* Flexbox Utilities */
.bc-flex {
  display: flex;
}

.bc-flex-col {
  flex-direction: column;
}

.bc-items-center {
  align-items: center;
}

.bc-justify-center {
  justify-content: center;
}

.bc-justify-between {
  justify-content: space-between;
}

/* Main Layout */
main {
  flex: 1 0 auto;
  min-height: calc(100vh - var(--bc-header-height) - var(--bc-footer-height));
}

/* ==============================================
   5. ENHANCED COMPONENT LIBRARY - WCAG 2.1 AA
   ============================================== */

/* Perfect Button Component with Consistent Typography */
.bc-btn, .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--bc-space-3) var(--bc-space-6);
  font-family: var(--bc-font-family-primary);
  font-size: var(--bc-font-size-base);
  font-weight: var(--bc-font-weight-button);
  line-height: 1;
  border: 1px solid transparent;
  border-radius: var(--bc-radius-md);
  cursor: pointer;
  text-decoration: none;
  transition: var(--bc-transition-fast);
  min-height: 44px; /* WCAG touch target */
  letter-spacing: var(--bc-letter-spacing-normal);
  text-align: center;
}

.bc-btn:focus, .btn:focus {
  outline: 3px solid var(--bc-accent);
  outline-offset: 2px;
  box-shadow: 0 0 0 2px var(--bc-primary), 0 0 8px rgba(25, 112, 10, 0.3);
  transform: translateY(-1px);
}

.bc-btn:hover, .btn:hover {
  text-decoration: none;
  transform: translateY(-1px);
  transition: all var(--bc-transition-fast);
}

.bc-btn-primary, .btn-primary {
  background: var(--bc-bg-gradient);
  color: var(--bc-text-white);
  border-color: var(--bc-primary);
  font-weight: var(--bc-font-weight-button);
}

.bc-btn-primary:hover, .btn-primary:hover {
  background: var(--bc-primary-dark);
  color: var(--bc-text-white);
  transform: translateY(-1px);
  box-shadow: var(--bc-shadow-md);
}

.bc-btn-secondary, .btn-secondary {
  background: transparent;
  color: var(--bc-primary);
  border-color: var(--bc-primary);
  font-weight: var(--bc-font-weight-button);
}

.btn-bc-secondary, .product-detail-hero .btn-secondary-bc, .btn-outline-light {
  color: var(--bc-white)!important;
  border-color: var(--bc-white)!important;
  font-weight: var(--bc-font-weight-button);
    background: var(--bc-bg-gradient)!important;
    border: 1px solid var(--bc-primary-light)!important;
}

.btn-bc-primary {
  border: 1px solid var(--bc-primary-light)!important;

}

.bc-btn-secondary:hover, .btn-secondary:hover {
  background: var(--bc-primary);
  color: var(--bc-text-white);
}

/* Cards */
.bc-card {
  background: var(--bc-bg-primary);
  border-radius: var(--bc-radius-xl);
  box-shadow: var(--bc-shadow-md);
  padding: var(--bc-space-6);
  transition: var(--bc-transition-normal);
  border: 1px solid var(--bc-gray-200);
}

.bc-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--bc-shadow-xl);
}

/* Form Elements */
.bc-input,
.bc-select,
.bc-textarea {
  width: 100%;
  padding: var(--bc-space-3) var(--bc-space-4);
  font-size: var(--bc-font-size-base);
  border: 1px solid var(--bc-gray-300);
  border-radius: var(--bc-radius-md);
  transition: var(--bc-transition-fast);
  min-height: 44px; /* WCAG touch target */
}

.bc-input:focus,
.bc-select:focus,
.bc-textarea:focus {
  border-color: var(--bc-primary);
  box-shadow: 0 0 0 3px var(--bc-primary-alpha);
  outline: none;
}

/* ==============================================
   6. UTILITIES
   ============================================== */

/* Spacing */
.mt-0 { margin-top: 0; }
.mt-1 { margin-top: var(--bc-space-1); }
.mt-2 { margin-top: var(--bc-space-2); }
.mt-3 { margin-top: var(--bc-space-3); }
.mt-4 { margin-top: var(--bc-space-4); }
.mt-5 { margin-top: var(--bc-space-5); }
.mt-6 { margin-top: var(--bc-space-6); }
.mt-8 { margin-top: var(--bc-space-8); }
.mt-10 { margin-top: var(--bc-space-10); }
.mt-12 { margin-top: var(--bc-space-12); }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--bc-space-1); }
.mb-2 { margin-bottom: var(--bc-space-2); }
.mb-3 { margin-bottom: var(--bc-space-3); }
.mb-4 { margin-bottom: var(--bc-space-4); }
.mb-5 { margin-bottom: var(--bc-space-5); }
.mb-6 { margin-bottom: var(--bc-space-6); }
.mb-8 { margin-bottom: var(--bc-space-8); }
.mb-10 { margin-bottom: var(--bc-space-10); }
.mb-12 { margin-bottom: var(--bc-space-12); }

/* Text Utilities */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.text-primary { color: var(--bc-primary); }
.text-secondary { color: var(--bc-text-secondary); }
.text-muted { color: var(--bc-text-muted); }
.text-white { color: var(--bc-text-white); }

/* Accessibility Utilities */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.skip-nav-link {
  position: absolute;
  top: -40px;
  left: var(--bc-space-2);
  z-index: var(--bc-z-skip-nav);
  color: var(--bc-text-white);
  background: var(--bc-primary);
  padding: var(--bc-space-2) var(--bc-space-4);
  text-decoration: none;
  border-radius: 0 0 var(--bc-radius-md) var(--bc-radius-md);
  font-size: var(--bc-font-size-sm);
  font-weight: var(--bc-font-weight-semibold);
  transition: top var(--bc-transition-normal);
}

.skip-nav-link:focus {
  top: 0;
  outline: 2px solid var(--bc-accent);
  outline-offset: 2px;
}

/* ==============================================
   7. RESPONSIVE DESIGN
   ============================================== */

/* Mobile First Approach */
@media (min-width: 576px) {
  .bc-container {
    max-width: 540px;
  }
}

@media (min-width: 768px) {
  .bc-container {
    max-width: 720px;
  }
  
  .bc-grid-md-cols-2 { 
    grid-template-columns: repeat(2, 1fr); 
  }
  
  .bc-grid-md-cols-3 { 
    grid-template-columns: repeat(3, 1fr); 
  }
}

@media (min-width: 992px) {
  .bc-container {
    max-width: 960px;
  }
  
  .bc-grid-lg-cols-3 { 
    grid-template-columns: repeat(3, 1fr); 
  }
  
  .bc-grid-lg-cols-4 { 
    grid-template-columns: repeat(4, 1fr); 
  }
}

@media (min-width: 1200px) {
  .bc-container {
    max-width: 1140px;
  }
}

@media (min-width: 1400px) {
  .bc-container {
    max-width: 1320px;
  }
}

/* ==============================================
   8. ACCESSIBILITY ENHANCEMENTS
   ============================================== */

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
  :root {
    --bc-primary: #000000;
    --bc-text-primary: #000000;
    --bc-bg-primary: #ffffff;
    --bc-gray-300: #666666;
  }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Focus Management */
.js-focus-visible *:focus:not(.focus-visible) {
  outline: none;
}

/* Improved Button Accessibility */
button:disabled,
.bc-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
}

/* ARIA Live Regions */
.aria-live-polite {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* ==============================================
   9. PERFORMANCE OPTIMIZATIONS
   ============================================== */

/* GPU Acceleration for Animations */
.bc-card,
.bc-btn {
  transform: translateZ(0);
  will-change: transform, box-shadow;
}

/* Optimize Web Fonts */
.font-display-swap {
  font-display: swap;
}

/* ==============================================
   10. PRINT STYLES
   ============================================== */

@media print {
  *,
  *::before,
  *::after {
    background: white !important;
    color: black !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  
  a,
  a:visited {
    text-decoration: underline;
  }
  
  .skip-nav-link,
  .bc-btn {
    display: none;
  }
  
  h1, h2, h3, h4, h5, h6 {
    page-break-after: avoid;
  }
}

/* ==============================================
   11. LEGACY SUPPORT & COMPATIBILITY
   ============================================== */

/* Bootstrap Override Classes for Backwards Compatibility */
.bg-primary {
  background-color: var(--bc-primary) !important;
}

.text-primary {
  color: var(--bc-primary) !important;
}

.btn-primary {
  background: var(--bc-bg-gradient);
  color: var(--bc-text-white);
/* ==============================================
   9. LEGACY COMPATIBILITY & UTILITIES
   ============================================== */

/* Sticky Footer System */
html, body {
  height: 100%;
  margin: 0;
  padding: 0;
}

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  position: relative;
}

main {
  flex: 1 0 auto;
  background-color: #fff;
}

footer {
  flex-shrink: 0;
}

/* Alert Messages */
.alert-message {
  color: #055160;
  background-color: #cff4fc;
  border-color: #b6effb;
  padding: 0.75rem 1rem;
  border-radius: 0.375rem;
  border: 1px solid;
}

/* Legacy Bootstrap Support */
.bg-primary {
  background-color: var(--bc-primary) !important;
}

.btn-secondary {
  background: transparent;
  color: var(--bc-primary);
  border-color: var(--bc-primary);
}

/* Maintain existing class structure while improving */
.navbar {
  transition: var(--bc-transition-normal);
}

.sticky-top {
  position: sticky;
  top: 0;
  z-index: var(--bc-z-sticky);
}

/* ==============================================
   END OF DESIGN SYSTEM
   ============================================== */


/* === lib/owlcarousel/assets/owl.carousel.min.css === */
/**
 * Owl Carousel v2.2.1
 * Copyright 2013-2017 David Deutsch
 * Licensed under  ()
 */
.owl-carousel,.owl-carousel .owl-item{-webkit-tap-highlight-color:transparent;position:relative}.owl-carousel{display:none;width:100%;z-index:1}.owl-carousel .owl-stage{position:relative;-ms-touch-action:pan-Y;-moz-backface-visibility:hidden}.owl-carousel .owl-stage:after{content:".";display:block;clear:both;visibility:hidden;line-height:0;height:0}.owl-carousel .owl-stage-outer{position:relative;overflow:hidden;-webkit-transform:translate3d(0,0,0)}.owl-carousel .owl-item,.owl-carousel .owl-wrapper{-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;-webkit-transform:translate3d(0,0,0);-moz-transform:translate3d(0,0,0);-ms-transform:translate3d(0,0,0)}.owl-carousel .owl-item{min-height:1px;float:left;-webkit-backface-visibility:hidden;-webkit-touch-callout:none}.owl-carousel .owl-item img{display:block;width:100%}.owl-carousel .owl-dots.disabled,.owl-carousel .owl-nav.disabled{display:none}.no-js .owl-carousel,.owl-carousel.owl-loaded{display:block}.owl-carousel .owl-dot,.owl-carousel .owl-nav .owl-next,.owl-carousel .owl-nav .owl-prev{cursor:pointer;cursor:hand;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.owl-carousel.owl-loading{opacity:0;display:block}.owl-carousel.owl-hidden{opacity:0}.owl-carousel.owl-refresh .owl-item{visibility:hidden}.owl-carousel.owl-drag .owl-item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.owl-carousel.owl-grab{cursor:move;cursor:grab}.owl-carousel.owl-rtl{direction:rtl}.owl-carousel.owl-rtl .owl-item{float:right}.owl-carousel .animated{animation-duration:1s;animation-fill-mode:both}.owl-carousel .owl-animated-in{z-index:0}.owl-carousel .owl-animated-out{z-index:1}.owl-carousel .fadeOut{animation-name:fadeOut}@keyframes fadeOut{0%{opacity:1}100%{opacity:0}}.owl-height{transition:height .5s ease-in-out}.owl-carousel .owl-item .owl-lazy{opacity:0;transition:opacity .4s ease}.owl-carousel .owl-item img.owl-lazy{transform-style:preserve-3d}.owl-carousel .owl-video-wrapper{position:relative;height:100%;background:#000}.owl-carousel .owl-video-play-icon{position:absolute;height:80px;width:80px;left:50%;top:50%;margin-left:-40px;margin-top:-40px;background:url(owl.video.play.png) no-repeat;cursor:pointer;z-index:1;-webkit-backface-visibility:hidden;transition:transform .1s ease}.owl-carousel .owl-video-play-icon:hover{-ms-transform:scale(1.3,1.3);transform:scale(1.3,1.3)}.owl-carousel .owl-video-playing .owl-video-play-icon,.owl-carousel .owl-video-playing .owl-video-tn{display:none}.owl-carousel .owl-video-tn{opacity:0;height:100%;background-position:center center;background-repeat:no-repeat;background-size:contain;transition:opacity .4s ease}.owl-carousel .owl-video-frame{position:relative;z-index:1;height:100%;width:100%}

/* === lib/animate/animate.min.css === */
@charset "UTF-8";

/*!
 * animate.css -http://daneden.me/animate
 * Version - 3.5.2
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2017 Daniel Eden
 */

.animated{animation-duration:1s;animation-fill-mode:both}.animated.infinite{animation-iteration-count:infinite}.animated.hinge{animation-duration:2s}.animated.bounceIn,.animated.bounceOut,.animated.flipOutX,.animated.flipOutY{animation-duration:.75s}@keyframes bounce{0%,20%,53%,80%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1);transform:translateZ(0)}40%,43%{animation-timing-function:cubic-bezier(.755,.05,.855,.06);transform:translate3d(0,-30px,0)}70%{animation-timing-function:cubic-bezier(.755,.05,.855,.06);transform:translate3d(0,-15px,0)}90%{transform:translate3d(0,-4px,0)}}.bounce{animation-name:bounce;transform-origin:center bottom}@keyframes flash{0%,50%,to{opacity:1}25%,75%{opacity:0}}.flash{animation-name:flash}@keyframes pulse{0%{transform:scaleX(1)}50%{transform:scale3d(1.05,1.05,1.05)}to{transform:scaleX(1)}}.pulse{animation-name:pulse}@keyframes rubberBand{0%{transform:scaleX(1)}30%{transform:scale3d(1.25,.75,1)}40%{transform:scale3d(.75,1.25,1)}50%{transform:scale3d(1.15,.85,1)}65%{transform:scale3d(.95,1.05,1)}75%{transform:scale3d(1.05,.95,1)}to{transform:scaleX(1)}}.rubberBand{animation-name:rubberBand}@keyframes shake{0%,to{transform:translateZ(0)}10%,30%,50%,70%,90%{transform:translate3d(-10px,0,0)}20%,40%,60%,80%{transform:translate3d(10px,0,0)}}.shake{animation-name:shake}@keyframes headShake{0%{transform:translateX(0)}6.5%{transform:translateX(-6px) rotateY(-9deg)}18.5%{transform:translateX(5px) rotateY(7deg)}31.5%{transform:translateX(-3px) rotateY(-5deg)}43.5%{transform:translateX(2px) rotateY(3deg)}50%{transform:translateX(0)}}.headShake{animation-timing-function:ease-in-out;animation-name:headShake}@keyframes swing{20%{transform:rotate(15deg)}40%{transform:rotate(-10deg)}60%{transform:rotate(5deg)}80%{transform:rotate(-5deg)}to{transform:rotate(0deg)}}.swing{transform-origin:top center;animation-name:swing}@keyframes tada{0%{transform:scaleX(1)}10%,20%{transform:scale3d(.9,.9,.9) rotate(-3deg)}30%,50%,70%,90%{transform:scale3d(1.1,1.1,1.1) rotate(3deg)}40%,60%,80%{transform:scale3d(1.1,1.1,1.1) rotate(-3deg)}to{transform:scaleX(1)}}.tada{animation-name:tada}@keyframes wobble{0%{transform:none}15%{transform:translate3d(-25%,0,0) rotate(-5deg)}30%{transform:translate3d(20%,0,0) rotate(3deg)}45%{transform:translate3d(-15%,0,0) rotate(-3deg)}60%{transform:translate3d(10%,0,0) rotate(2deg)}75%{transform:translate3d(-5%,0,0) rotate(-1deg)}to{transform:none}}.wobble{animation-name:wobble}@keyframes jello{0%,11.1%,to{transform:none}22.2%{transform:skewX(-12.5deg) skewY(-12.5deg)}33.3%{transform:skewX(6.25deg) skewY(6.25deg)}44.4%{transform:skewX(-3.125deg) skewY(-3.125deg)}55.5%{transform:skewX(1.5625deg) skewY(1.5625deg)}66.6%{transform:skewX(-.78125deg) skewY(-.78125deg)}77.7%{transform:skewX(.390625deg) skewY(.390625deg)}88.8%{transform:skewX(-.1953125deg) skewY(-.1953125deg)}}.jello{animation-name:jello;transform-origin:center}@keyframes bounceIn{0%,20%,40%,60%,80%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:scale3d(.3,.3,.3)}20%{transform:scale3d(1.1,1.1,1.1)}40%{transform:scale3d(.9,.9,.9)}60%{opacity:1;transform:scale3d(1.03,1.03,1.03)}80%{transform:scale3d(.97,.97,.97)}to{opacity:1;transform:scaleX(1)}}.bounceIn{animation-name:bounceIn}@keyframes bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}.bounceInDown{animation-name:bounceInDown}@keyframes bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}.bounceInLeft{animation-name:bounceInLeft}@keyframes bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}.bounceInRight{animation-name:bounceInRight}@keyframes bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}.bounceInUp{animation-name:bounceInUp}@keyframes bounceOut{20%{transform:scale3d(.9,.9,.9)}50%,55%{opacity:1;transform:scale3d(1.1,1.1,1.1)}to{opacity:0;transform:scale3d(.3,.3,.3)}}.bounceOut{animation-name:bounceOut}@keyframes bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.bounceOutDown{animation-name:bounceOutDown}@keyframes bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}.bounceOutLeft{animation-name:bounceOutLeft}@keyframes bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}.bounceOutRight{animation-name:bounceOutRight}@keyframes bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}.bounceOutUp{animation-name:bounceOutUp}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fadeIn{animation-name:fadeIn}@keyframes fadeInDown{0%{opacity:0;transform:translate3d(0,-100%,0)}to{opacity:1;transform:none}}.fadeInDown{animation-name:fadeInDown}@keyframes fadeInDownBig{0%{opacity:0;transform:translate3d(0,-2000px,0)}to{opacity:1;transform:none}}.fadeInDownBig{animation-name:fadeInDownBig}@keyframes fadeInLeft{0%{opacity:0;transform:translate3d(-100%,0,0)}to{opacity:1;transform:none}}.fadeInLeft{animation-name:fadeInLeft}@keyframes fadeInLeftBig{0%{opacity:0;transform:translate3d(-2000px,0,0)}to{opacity:1;transform:none}}.fadeInLeftBig{animation-name:fadeInLeftBig}@keyframes fadeInRight{0%{opacity:0;transform:translate3d(100%,0,0)}to{opacity:1;transform:none}}.fadeInRight{animation-name:fadeInRight}@keyframes fadeInRightBig{0%{opacity:0;transform:translate3d(2000px,0,0)}to{opacity:1;transform:none}}.fadeInRightBig{animation-name:fadeInRightBig}@keyframes fadeInUp{0%{opacity:0;transform:translate3d(0,100%,0)}to{opacity:1;transform:none}}.fadeInUp{animation-name:fadeInUp}@keyframes fadeInUpBig{0%{opacity:0;transform:translate3d(0,2000px,0)}to{opacity:1;transform:none}}.fadeInUpBig{animation-name:fadeInUpBig}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.fadeOut{animation-name:fadeOut}@keyframes fadeOutDown{0%{opacity:1}to{opacity:0;transform:translate3d(0,100%,0)}}.fadeOutDown{animation-name:fadeOutDown}@keyframes fadeOutDownBig{0%{opacity:1}to{opacity:0;transform:translate3d(0,2000px,0)}}.fadeOutDownBig{animation-name:fadeOutDownBig}@keyframes fadeOutLeft{0%{opacity:1}to{opacity:0;transform:translate3d(-100%,0,0)}}.fadeOutLeft{animation-name:fadeOutLeft}@keyframes fadeOutLeftBig{0%{opacity:1}to{opacity:0;transform:translate3d(-2000px,0,0)}}.fadeOutLeftBig{animation-name:fadeOutLeftBig}@keyframes fadeOutRight{0%{opacity:1}to{opacity:0;transform:translate3d(100%,0,0)}}.fadeOutRight{animation-name:fadeOutRight}@keyframes fadeOutRightBig{0%{opacity:1}to{opacity:0;transform:translate3d(2000px,0,0)}}.fadeOutRightBig{animation-name:fadeOutRightBig}@keyframes fadeOutUp{0%{opacity:1}to{opacity:0;transform:translate3d(0,-100%,0)}}.fadeOutUp{animation-name:fadeOutUp}@keyframes fadeOutUpBig{0%{opacity:1}to{opacity:0;transform:translate3d(0,-2000px,0)}}.fadeOutUpBig{animation-name:fadeOutUpBig}@keyframes flip{0%{transform:perspective(400px) rotateY(-1turn);animation-timing-function:ease-out}40%{transform:perspective(400px) translateZ(150px) rotateY(-190deg);animation-timing-function:ease-out}50%{transform:perspective(400px) translateZ(150px) rotateY(-170deg);animation-timing-function:ease-in}80%{transform:perspective(400px) scale3d(.95,.95,.95);animation-timing-function:ease-in}to{transform:perspective(400px);animation-timing-function:ease-in}}.animated.flip{-webkit-backface-visibility:visible;backface-visibility:visible;animation-name:flip}@keyframes flipInX{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}.flipInX{-webkit-backface-visibility:visible!important;backface-visibility:visible!important;animation-name:flipInX}@keyframes flipInY{0%{transform:perspective(400px) rotateY(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateY(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateY(10deg);opacity:1}80%{transform:perspective(400px) rotateY(-5deg)}to{transform:perspective(400px)}}.flipInY{-webkit-backface-visibility:visible!important;backface-visibility:visible!important;animation-name:flipInY}@keyframes flipOutX{0%{transform:perspective(400px)}30%{transform:perspective(400px) rotateX(-20deg);opacity:1}to{transform:perspective(400px) rotateX(90deg);opacity:0}}.flipOutX{animation-name:flipOutX;-webkit-backface-visibility:visible!important;backface-visibility:visible!important}@keyframes flipOutY{0%{transform:perspective(400px)}30%{transform:perspective(400px) rotateY(-15deg);opacity:1}to{transform:perspective(400px) rotateY(90deg);opacity:0}}.flipOutY{-webkit-backface-visibility:visible!important;backface-visibility:visible!important;animation-name:flipOutY}@keyframes lightSpeedIn{0%{transform:translate3d(100%,0,0) skewX(-30deg);opacity:0}60%{transform:skewX(20deg);opacity:1}80%{transform:skewX(-5deg);opacity:1}to{transform:none;opacity:1}}.lightSpeedIn{animation-name:lightSpeedIn;animation-timing-function:ease-out}@keyframes lightSpeedOut{0%{opacity:1}to{transform:translate3d(100%,0,0) skewX(30deg);opacity:0}}.lightSpeedOut{animation-name:lightSpeedOut;animation-timing-function:ease-in}@keyframes rotateIn{0%{transform-origin:center;transform:rotate(-200deg);opacity:0}to{transform-origin:center;transform:none;opacity:1}}.rotateIn{animation-name:rotateIn}@keyframes rotateInDownLeft{0%{transform-origin:left bottom;transform:rotate(-45deg);opacity:0}to{transform-origin:left bottom;transform:none;opacity:1}}.rotateInDownLeft{animation-name:rotateInDownLeft}@keyframes rotateInDownRight{0%{transform-origin:right bottom;transform:rotate(45deg);opacity:0}to{transform-origin:right bottom;transform:none;opacity:1}}.rotateInDownRight{animation-name:rotateInDownRight}@keyframes rotateInUpLeft{0%{transform-origin:left bottom;transform:rotate(45deg);opacity:0}to{transform-origin:left bottom;transform:none;opacity:1}}.rotateInUpLeft{animation-name:rotateInUpLeft}@keyframes rotateInUpRight{0%{transform-origin:right bottom;transform:rotate(-90deg);opacity:0}to{transform-origin:right bottom;transform:none;opacity:1}}.rotateInUpRight{animation-name:rotateInUpRight}@keyframes rotateOut{0%{transform-origin:center;opacity:1}to{transform-origin:center;transform:rotate(200deg);opacity:0}}.rotateOut{animation-name:rotateOut}@keyframes rotateOutDownLeft{0%{transform-origin:left bottom;opacity:1}to{transform-origin:left bottom;transform:rotate(45deg);opacity:0}}.rotateOutDownLeft{animation-name:rotateOutDownLeft}@keyframes rotateOutDownRight{0%{transform-origin:right bottom;opacity:1}to{transform-origin:right bottom;transform:rotate(-45deg);opacity:0}}.rotateOutDownRight{animation-name:rotateOutDownRight}@keyframes rotateOutUpLeft{0%{transform-origin:left bottom;opacity:1}to{transform-origin:left bottom;transform:rotate(-45deg);opacity:0}}.rotateOutUpLeft{animation-name:rotateOutUpLeft}@keyframes rotateOutUpRight{0%{transform-origin:right bottom;opacity:1}to{transform-origin:right bottom;transform:rotate(90deg);opacity:0}}.rotateOutUpRight{animation-name:rotateOutUpRight}@keyframes hinge{0%{transform-origin:top left;animation-timing-function:ease-in-out}20%,60%{transform:rotate(80deg);transform-origin:top left;animation-timing-function:ease-in-out}40%,80%{transform:rotate(60deg);transform-origin:top left;animation-timing-function:ease-in-out;opacity:1}to{transform:translate3d(0,700px,0);opacity:0}}.hinge{animation-name:hinge}@keyframes jackInTheBox{0%{opacity:0;transform:scale(.1) rotate(30deg);transform-origin:center bottom}50%{transform:rotate(-10deg)}70%{transform:rotate(3deg)}to{opacity:1;transform:scale(1)}}.jackInTheBox{animation-name:jackInTheBox}@keyframes rollIn{0%{opacity:0;transform:translate3d(-100%,0,0) rotate(-120deg)}to{opacity:1;transform:none}}.rollIn{animation-name:rollIn}@keyframes rollOut{0%{opacity:1}to{opacity:0;transform:translate3d(100%,0,0) rotate(120deg)}}.rollOut{animation-name:rollOut}@keyframes zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}.zoomIn{animation-name:zoomIn}@keyframes zoomInDown{0%{opacity:0;transform:scale3d(.1,.1,.1) translate3d(0,-1000px,0);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;transform:scale3d(.475,.475,.475) translate3d(0,60px,0);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomInDown{animation-name:zoomInDown}@keyframes zoomInLeft{0%{opacity:0;transform:scale3d(.1,.1,.1) translate3d(-1000px,0,0);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;transform:scale3d(.475,.475,.475) translate3d(10px,0,0);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomInLeft{animation-name:zoomInLeft}@keyframes zoomInRight{0%{opacity:0;transform:scale3d(.1,.1,.1) translate3d(1000px,0,0);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;transform:scale3d(.475,.475,.475) translate3d(-10px,0,0);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomInRight{animation-name:zoomInRight}@keyframes zoomInUp{0%{opacity:0;transform:scale3d(.1,.1,.1) translate3d(0,1000px,0);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}60%{opacity:1;transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomInUp{animation-name:zoomInUp}@keyframes zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.zoomOut{animation-name:zoomOut}@keyframes zoomOutDown{40%{opacity:1;transform:scale3d(.475,.475,.475) translate3d(0,-60px,0);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}to{opacity:0;transform:scale3d(.1,.1,.1) translate3d(0,2000px,0);transform-origin:center bottom;animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomOutDown{animation-name:zoomOutDown}@keyframes zoomOutLeft{40%{opacity:1;transform:scale3d(.475,.475,.475) translate3d(42px,0,0)}to{opacity:0;transform:scale(.1) translate3d(-2000px,0,0);transform-origin:left center}}.zoomOutLeft{animation-name:zoomOutLeft}@keyframes zoomOutRight{40%{opacity:1;transform:scale3d(.475,.475,.475) translate3d(-42px,0,0)}to{opacity:0;transform:scale(.1) translate3d(2000px,0,0);transform-origin:right center}}.zoomOutRight{animation-name:zoomOutRight}@keyframes zoomOutUp{40%{opacity:1;transform:scale3d(.475,.475,.475) translate3d(0,60px,0);animation-timing-function:cubic-bezier(.55,.055,.675,.19)}to{opacity:0;transform:scale3d(.1,.1,.1) translate3d(0,-2000px,0);transform-origin:center bottom;animation-timing-function:cubic-bezier(.175,.885,.32,1)}}.zoomOutUp{animation-name:zoomOutUp}@keyframes slideInDown{0%{transform:translate3d(0,-100%,0);visibility:visible}to{transform:translateZ(0)}}.slideInDown{animation-name:slideInDown}@keyframes slideInLeft{0%{transform:translate3d(-100%,0,0);visibility:visible}to{transform:translateZ(0)}}.slideInLeft{animation-name:slideInLeft}@keyframes slideInRight{0%{transform:translate3d(100%,0,0);visibility:visible}to{transform:translateZ(0)}}.slideInRight{animation-name:slideInRight}@keyframes slideInUp{0%{transform:translate3d(0,100%,0);visibility:visible}to{transform:translateZ(0)}}.slideInUp{animation-name:slideInUp}@keyframes slideOutDown{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,100%,0)}}.slideOutDown{animation-name:slideOutDown}@keyframes slideOutLeft{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(-100%,0,0)}}.slideOutLeft{animation-name:slideOutLeft}@keyframes slideOutRight{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(100%,0,0)}}.slideOutRight{animation-name:slideOutRight}@keyframes slideOutUp{0%{transform:translateZ(0)}to{visibility:hidden;transform:translate3d(0,-100%,0)}}.slideOutUp{animation-name:slideOutUp}
