/* ============================================
   PRICING CARDS - MODERN REDESIGN 2026
   Clean, professional, and user-friendly design
   ============================================ */

/* ============================================
   CARD FADE IN ANIMATION
   ============================================ */

@keyframes cardFadeIn {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ============================================
   1. CARD CONTAINER - PREMIUM FOUNDATION
   ============================================ */

.pricing-card-modern {
  background: linear-gradient(to bottom, #FFFFFF 0%, #FAFBFC 100%) !important;
  border-radius: 24px !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: 
    0 4px 24px rgba(0, 0, 0, 0.06),
    0 1px 3px rgba(0, 0, 0, 0.04),
    0 0 0 1px rgba(226, 232, 240, 0.6) !important;
  border: 1px solid rgba(226, 232, 240, 0.8) !important;
  transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1) !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  cursor: default !important;
  isolation: isolate !important;
  animation: cardFadeIn 0.8s cubic-bezier(0.23, 1, 0.32, 1) both !important;
  pointer-events: auto !important;
}

/* Ensure buttons area is always clickable */
.pricing-card-modern .pricing-actions,
.pricing-card-modern .pricing-actions * {
  pointer-events: auto !important;
}

/* Stagger animation for multiple cards */
.pricing-card-modern:nth-child(1) {
  animation-delay: 0.1s !important;
}

.pricing-card-modern:nth-child(2) {
  animation-delay: 0.2s !important;
}

.pricing-card-modern:nth-child(3) {
  animation-delay: 0.3s !important;
}

.pricing-card-modern:nth-child(4) {
  animation-delay: 0.4s !important;
}

.pricing-card-modern:nth-child(5) {
  animation-delay: 0.5s !important;
}

.pricing-card-modern:nth-child(6) {
  animation-delay: 0.6s !important;
}

/* Subtle border gradient overlay on hover */
.pricing-card-modern::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: 24px !important;
  padding: 1px !important;
  background: linear-gradient(135deg, 
    rgba(37, 99, 235, 0.1) 0%, 
    rgba(59, 130, 246, 0.05) 50%,
    transparent 100%) !important;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0) !important;
  -webkit-mask-composite: xor !important;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0) !important;
  mask-composite: exclude !important;
  opacity: 0 !important;
  transition: opacity 0.6s ease !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

.pricing-card-modern:hover::after {
  opacity: 1 !important;
  pointer-events: none !important;
}

/* Top accent bar - animated on hover */
.pricing-card-modern::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 5px !important;
  background: linear-gradient(90deg, #2563EB 0%, #1D4ED8 50%, #2563EB 100%) !important;
  transform: scaleX(0) !important;
  transform-origin: left !important;
  transition: transform 0.6s cubic-bezier(0.23, 1, 0.32, 1) !important;
  z-index: 10 !important;
  box-shadow: 0 2px 12px rgba(37, 99, 235, 0.4) !important;
  pointer-events: none !important;
}

.pricing-card-modern:hover::before {
  transform: scaleX(1) !important;
  pointer-events: none !important;
}

/* Enhanced hover effect - matching services page */
.pricing-card-modern:hover {
  transform: translateY(-12px) !important;
  box-shadow: 
    0 40px 80px -16px rgba(37, 99, 235, 0.3),
    0 16px 32px -8px rgba(0, 0, 0, 0.1),
    0 0 0 1px rgba(37, 99, 235, 0.15),
    0 0 60px rgba(37, 99, 235, 0.1) !important;
  border-color: rgba(37, 99, 235, 0.3) !important;
  background: linear-gradient(to bottom, #FFFFFF 0%, #F8FAFC 100%) !important;
}

/* ============================================
   2. CARD BODY - OPTIMIZED SPACING
   ============================================ */

.pricing-card-body {
  padding: clamp(2rem, 4vw, 2.5rem) clamp(1.75rem, 3.5vw, 2.25rem) !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  background: transparent !important;
  position: relative !important;
  z-index: 1 !important;
  pointer-events: auto !important;
}

/* ============================================
   3. TITLE & BADGE - CLEAN HIERARCHY
   ============================================ */

.pricing-card-title {
  font-size: clamp(1.25rem, 1.8vw, 1.5rem) !important;
  font-weight: 800 !important;
  color: #0F172A !important;
  margin: 0 0 0.75rem 0 !important;
  line-height: 1.3 !important;
  text-align: left !important;
  letter-spacing: -0.02em !important;
  position: relative !important;
  z-index: 1 !important;
  transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1) !important;
}

.pricing-card-modern:hover .pricing-card-title {
  color: #2563EB !important;
  transform: translateX(2px) !important;
}

/* Compact label badge */
.pricing-card-label {
  margin-bottom: 1rem !important;
  text-align: left !important;
}

.pricing-label-badge {
  display: inline-block !important;
  padding: 0.4375rem 1rem !important;
  background: linear-gradient(135deg, #F1F5F9 0%, #E2E8F0 100%) !important;
  color: #475569 !important;
  border-radius: 8px !important;
  font-size: 0.6875rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  text-align: left !important;
  border: 1px solid rgba(226, 232, 240, 0.6) !important;
  box-shadow: 
    0 1px 2px rgba(0, 0, 0, 0.04),
    inset 0 1px 0 rgba(255, 255, 255, 0.8) !important;
}

/* ============================================
   4. PRICE DISPLAY - CLEAR & PROMINENT
   ============================================ */

.pricing-card-price-inline {
  display: flex !important;
  align-items: baseline !important;
  gap: 0.5rem !important;
  margin-bottom: 1.25rem !important;
  text-align: left !important;
  padding: 1rem 0 !important;
  border-bottom: 1.5px solid rgba(226, 232, 240, 0.6) !important;
  position: relative !important;
}

.pricing-amount-inline {
  font-size: clamp(1.25rem, 2.2vw, 1.625rem) !important;
  font-weight: 900 !important;
  background: linear-gradient(135deg, #0F172A 0%, #475569 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  line-height: 1 !important;
  letter-spacing: -0.02em !important;
}

.pricing-currency-inline {
  font-size: clamp(0.8125rem, 1.2vw, 0.9375rem) !important;
  font-weight: 600 !important;
  color: #64748B !important;
  letter-spacing: 0.01em !important;
  padding-bottom: 0.125rem !important;
}

/* ============================================
   5. DESCRIPTION - READABLE TEXT
   ============================================ */

.pricing-card-subtitle {
  font-size: clamp(0.8125rem, 1.1vw, 0.875rem) !important;
  color: #64748B !important;
  margin: 0 0 1.5rem 0 !important;
  line-height: 1.6 !important;
  text-align: left !important;
  font-weight: 400 !important;
}

/* ============================================
   6. FEATURES - CLEAN LIST DESIGN
   ============================================ */

.pricing-card-features {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.625rem !important;
  margin-top: auto !important;
  margin-bottom: 1.75rem !important;
}

.pricing-feature-item {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.75rem !important;
  padding: 0.75rem 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1) !important;
  border: none !important;
  box-shadow: none !important;
  position: relative !important;
  overflow: hidden !important;
}

.pricing-feature-item::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(37, 99, 235, 0.05), transparent) !important;
  transition: left 0.5s ease !important;
  z-index: 0 !important;
}

.pricing-card-modern:hover .pricing-feature-item::before {
  left: 100% !important;
}

.pricing-card-modern:hover .pricing-feature-item {
  background: transparent !important;
  transform: translateX(4px) !important;
  border: none !important;
  box-shadow: none !important;
}

.pricing-feature-check {
  color: #10B981 !important;
  font-size: 1.0625rem !important;
  flex-shrink: 0 !important;
  margin-top: 0.125rem !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  filter: drop-shadow(0 1px 2px rgba(16, 185, 129, 0.2)) !important;
}

.pricing-card-modern:hover .pricing-feature-check {
  transform: scale(1.15) !important;
  filter: drop-shadow(0 2px 4px rgba(16, 185, 129, 0.3)) !important;
}

.pricing-feature-text {
  font-size: clamp(0.8125rem, 1.1vw, 0.875rem) !important;
  color: #475569 !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  letter-spacing: 0 !important;
  flex: 1 !important;
  position: relative !important;
  z-index: 1 !important;
  transition: color 0.3s ease !important;
}

.pricing-card-modern:hover .pricing-feature-text {
  color: #334155 !important;
}

/* ============================================
   7. BUTTONS - MODERN CTA DESIGN
   ============================================ */

.pricing-actions {
  margin-top: auto !important;
  padding-top: 1.75rem !important;
  border-top: 1.5px solid rgba(226, 232, 240, 0.7) !important;
  display: flex !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  gap: 0.875rem !important;
  position: relative !important;
  z-index: 100 !important;
  pointer-events: auto !important;
  isolation: isolate !important;
  align-items: stretch !important;
}

.pricing-actions .btn-view-details,
.pricing-actions .btn-pay,
.pricing-actions a {
  width: 100% !important;
  text-align: center !important;
  padding: 0.9375rem 1.5rem !important;
  border-radius: 12px !important;
  font-weight: 600 !important;
  font-size: clamp(0.875rem, 1.1vw, 0.9375rem) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 
    0 1px 3px rgba(0, 0, 0, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.1) !important;
  border: 1.5px solid transparent !important;
  cursor: pointer !important;
  font-family: 'Noto Sans Lao', 'Phetsarath OT', 'Saysettha OT', 'Plus Jakarta Sans', sans-serif !important;
  position: relative !important;
  overflow: visible !important;
  z-index: 999 !important;
  pointer-events: auto !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  touch-action: manipulation !important;
  -webkit-tap-highlight-color: rgba(37, 99, 235, 0.2) !important;
  display: inline-block !important;
}

/* View Details Button - Subtle Outline */
.pricing-actions .btn-view-details {
  background: #FFFFFF !important;
  color: #2563EB !important;
  border-color: #E2E8F0 !important;
}

.pricing-actions .btn-view-details i {
  color: #2563EB !important;
  margin-right: 0.5rem !important;
}

.pricing-actions .btn-view-details:hover {
  background: linear-gradient(135deg, #F8FAFC 0%, #F1F5F9 100%) !important;
  color: #1D4ED8 !important;
  border-color: #2563EB !important;
  transform: translateY(-2px) !important;
  box-shadow: 
    0 4px 12px rgba(37, 99, 235, 0.2),
    0 2px 4px rgba(0, 0, 0, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
}

.pricing-actions .btn-view-details:hover i {
  color: #1D4ED8 !important;
}

/* Primary Button - Solid Blue */
.pricing-actions .btn-pay {
  background: linear-gradient(135deg, #2563EB 0%, #1D4ED8 100%) !important;
  color: #FFFFFF !important;
  border-color: #2563EB !important;
}

.pricing-actions .btn-pay:hover {
  background: linear-gradient(135deg, #1D4ED8 0%, #1E40AF 100%) !important;
  border-color: #1D4ED8 !important;
  transform: translateY(-2px) !important;
  box-shadow: 
    0 6px 16px rgba(37, 99, 235, 0.35),
    0 2px 4px rgba(0, 0, 0, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
}

/* Green button for recommended plan */
.pricing-card-modern .btn-pay.lite-pay-btn {
  background: linear-gradient(135deg, #10B981 0%, #059669 100%) !important;
  border-color: #10B981 !important;
}

.pricing-card-modern .btn-pay.lite-pay-btn:hover {
  background: linear-gradient(135deg, #059669 0%, #047857 100%) !important;
  border-color: #059669 !important;
  box-shadow: 
    0 6px 16px rgba(16, 185, 129, 0.35),
    0 2px 4px rgba(0, 0, 0, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
}

/* Link buttons */
.pricing-actions a {
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  z-index: 20 !important;
  pointer-events: auto !important;
}

.pricing-actions a i {
  margin-right: 0.5rem !important;
  pointer-events: none !important;
}

/* Ensure all button children don't block clicks */
.pricing-actions .btn-view-details i,
.pricing-actions .btn-view-details span,
.pricing-actions .btn-pay i,
.pricing-actions .btn-pay span,
.pricing-actions a span {
  pointer-events: none !important;
}

/* ============================================
   8. GRID LAYOUT - OPTIMIZED SPACING
   ============================================ */

.pricing-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 360px), 1fr)) !important;
  gap: clamp(2rem, 4vw, 2.5rem) !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 1400px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
  align-items: stretch !important;
}

/* ============================================
   9. MOBILE RESPONSIVE
   ============================================ */

@media (max-width: 768px) {
  .pricing-card-body {
    padding: 1.5rem 1.25rem !important;
  }
  
  .pricing-card-title {
    font-size: clamp(1.25rem, 1.8vw, 1.5rem) !important;
    margin-bottom: 0.625rem !important;
  }
  
  .pricing-label-badge {
    font-size: 0.625rem !important;
    padding: 0.3125rem 0.75rem !important;
  }
  
  .pricing-amount-inline {
    font-size: clamp(1.25rem, 2.2vw, 1.625rem) !important;
  }
  
  .pricing-card-price-inline {
    padding: 0.75rem 0 !important;
    margin-bottom: 0.875rem !important;
  }
  
  .pricing-card-subtitle {
    margin-bottom: 1.25rem !important;
  }
  
  .pricing-card-features {
    gap: 0.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  
  .pricing-feature-item {
    padding: 0.625rem 0 !important;
  }
  
  .pricing-actions {
    padding-top: 1.25rem !important;
    gap: 0.625rem !important;
  }
  
  .pricing-actions .btn-view-details,
  .pricing-actions .btn-pay,
  .pricing-actions a {
    padding: 0.75rem 1rem !important;
    font-size: 0.875rem !important;
  }
  
  .pricing-grid {
    gap: 1.25rem !important;
  }
}

/* ============================================
   10. ACCESSIBILITY & UX
   ============================================ */

.pricing-card-modern:focus-within {
  outline: 2px solid rgba(37, 99, 235, 0.5) !important;
  outline-offset: 3px !important;
  border-radius: 20px !important;
}

.pricing-actions button:focus-visible,
.pricing-actions a:focus-visible {
  outline: 2px solid rgba(37, 99, 235, 0.5) !important;
  outline-offset: 2px !important;
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  .pricing-card-modern,
  .pricing-feature-item,
  .pricing-feature-check,
  .pricing-actions button,
  .pricing-actions a,
  .pricing-card-title {
    animation: none !important;
    transition: none !important;
  }
  
  .pricing-card-modern:hover {
    transform: none !important;
  }
  
  .pricing-card-modern:hover .pricing-feature-item {
    transform: none !important;
  }
  
  .pricing-card-modern:hover .pricing-feature-check {
    transform: none !important;
  }
  
  .pricing-card-modern:hover .pricing-card-title {
    transform: none !important;
  }
}

/* ============================================
   11. LAO LANGUAGE SUPPORT
   ============================================ */

.lang-lao .pricing-card-title,
.lang-lao .pricing-card-subtitle,
.lang-lao .pricing-feature-text,
.lang-lao .pricing-actions button,
.lang-lao .pricing-actions a {
  font-family: 'Noto Sans Lao', 'Phetsarath OT', 'Saysettha OT', sans-serif !important;
}

.lang-lao .pricing-card-title {
  line-height: 1.4 !important;
}

.lang-lao .pricing-feature-text {
  line-height: 1.6 !important;
}

/* ============================================
   12. RECOMMENDED PLAN HIGHLIGHT
   ============================================ */

.pricing-card-modern[data-recommended="true"] {
  border-color: rgba(16, 185, 129, 0.3) !important;
  box-shadow: 
    0 4px 16px rgba(16, 185, 129, 0.1),
    0 2px 8px rgba(0, 0, 0, 0.06),
    0 0 0 1px rgba(16, 185, 129, 0.2) !important;
}

.pricing-card-modern[data-recommended="true"]::before {
  background: linear-gradient(90deg, #10B981 0%, #059669 100%) !important;
  opacity: 1 !important;
}

.pricing-card-modern[data-recommended="true"]:hover {
  transform: translateY(-12px) !important;
  border-color: rgba(16, 185, 129, 0.4) !important;
  box-shadow: 
    0 40px 80px -16px rgba(16, 185, 129, 0.3),
    0 16px 32px -8px rgba(0, 0, 0, 0.1),
    0 0 0 1px rgba(16, 185, 129, 0.15),
    0 0 60px rgba(16, 185, 129, 0.1) !important;
}

.pricing-card-modern[data-recommended="true"]::before {
  background: linear-gradient(90deg, #10B981 0%, #059669 50%, #10B981 100%) !important;
  box-shadow: 0 2px 12px rgba(16, 185, 129, 0.4) !important;
}

/* ============================================
   13. BUTTON CLICKABILITY - FINAL FIX
   Ensure buttons are always clickable
   ============================================ */

/* Force button clickability - highest priority */
button.btn-view-details,
.pricing-actions button.btn-view-details,
.pricing-actions .btn-view-details,
.pricing-actions .btn-pay,
.pricing-actions a.btn-view-details,
.pricing-actions a {
  pointer-events: auto !important;
  cursor: pointer !important;
  z-index: 999999 !important;
  position: relative !important;
  display: inline-block !important;
  touch-action: manipulation !important;
  -webkit-tap-highlight-color: rgba(37, 99, 235, 0.3) !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* Ensure button container doesn't block */
.pricing-actions {
  pointer-events: auto !important;
  z-index: 1000 !important;
  position: relative !important;
  isolation: isolate !important;
}

/* Make sure card doesn't block button clicks */
.pricing-card-modern {
  pointer-events: auto !important;
}

/* But disable pointer events on decorative elements */
.pricing-card-modern::before,
.pricing-card-modern::after {
  pointer-events: none !important;
}

/* Re-enable for buttons specifically */
.pricing-card-modern .pricing-actions,
.pricing-card-modern .pricing-actions * {
  pointer-events: auto !important;
}

/* Button children should not block */
.pricing-actions .btn-view-details *,
.pricing-actions .btn-pay *,
.pricing-actions a * {
  pointer-events: none !important;
}

/* Ensure button is above everything - override any other rules */
button.btn-view-details,
.pricing-card-modern button.btn-view-details,
.pricing-card-modern .pricing-actions button.btn-view-details,
.pricing-card-modern .pricing-actions .btn-view-details {
  position: relative !important;
  z-index: 9999999 !important;
  pointer-events: auto !important;
  cursor: pointer !important;
  display: inline-block !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Active state for visual feedback */
.pricing-actions .btn-view-details:active,
.pricing-actions .btn-pay:active,
.pricing-actions a:active {
  transform: scale(0.98) !important;
  opacity: 0.9 !important;
}

/* Focus state */
.pricing-actions .btn-view-details:focus,
.pricing-actions .btn-pay:focus,
.pricing-actions a:focus {
  outline: 2px solid rgba(37, 99, 235, 0.5) !important;
  outline-offset: 2px !important;
}

/* Mobile touch optimization */
@media (max-width: 768px) {
  .pricing-actions .btn-view-details,
  .pricing-actions .btn-pay,
  .pricing-actions a {
    min-height: 44px !important;
    min-width: 44px !important;
    touch-action: manipulation !important;
    -webkit-tap-highlight-color: rgba(37, 99, 235, 0.4) !important;
  }
}

