/* ============================================================
   BiswasHost Modern Body Redesign
   CSS-first override layer for modern visual refresh
   Loaded AFTER main.css to override the bundled theme
   ============================================================ */

/* ============================================================
   SECTION 1: CSS Custom Properties / Design Tokens
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  /* Brand Core (preserved) */
  --bh-navy:            #080F2C;
  --bh-blue:            #0d6efd;
  --bh-blue-dark:       #0948b3;
  --bh-orange:          #ea550b;

  /* Modern Additions */
  --bh-blue-light:      #4f8fff;
  --bh-blue-glow:       #1a7fff;
  --bh-indigo:          #4338ca;
  --bh-violet:          #7c3aed;
  --bh-cyan:            #06b6d4;
  --bh-green:           #10b981;
  --bh-orange-warm:     #f97316;

  /* Section Backgrounds (refined) */
  --bh-bg-light:        #f0f4fb;
  --bh-bg-cream:        #f8fafd;
  --bh-bg-white:        #ffffff;
  --bh-bg-dark:         #060b1f;

  /* Glass Effect Tokens */
  --bh-glass-bg:        rgba(255, 255, 255, 0.08);
  --bh-glass-border:    rgba(255, 255, 255, 0.15);
  --bh-glass-shadow:    0 8px 32px rgba(0, 0, 0, 0.12);
  --bh-glass-blur:      blur(16px);

  /* Card Tokens */
  --bh-card-bg:         #ffffff;
  --bh-card-border:     rgba(0, 0, 0, 0.06);
  --bh-card-shadow:     0 2px 8px rgba(0, 0, 0, 0.04);
  --bh-card-shadow-hover: 0 12px 40px rgba(13, 110, 253, 0.12);
  --bh-card-radius:     1.25rem;

  /* Gradients */
  --bh-gradient-hero:   linear-gradient(135deg, #060b1f 0%, #0a1a4a 40%, #0d2d6e 100%);
  --bh-gradient-accent: linear-gradient(135deg, #0948b3 0%, #4338ca 50%, #7c3aed 100%);
  --bh-gradient-card-accent: linear-gradient(90deg, #0d6efd, #7c3aed);
  --bh-gradient-pricing: linear-gradient(180deg, #f0f4fb 0%, #ffffff 100%);
  --bh-mesh-1:          radial-gradient(ellipse at 20% 50%, rgba(13,110,253,0.05) 0%, transparent 50%),
                        radial-gradient(ellipse at 80% 20%, rgba(124,58,237,0.04) 0%, transparent 50%),
                        radial-gradient(ellipse at 50% 80%, rgba(6,182,212,0.03) 0%, transparent 50%);

  /* Transitions */
  --bh-transition:      0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --bh-transition-slow: 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}


/* ============================================================
   SECTION 2: Base & Typography Overrides
   ============================================================ */
.main {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.main h1, .main h2, .main h3, .main h4, .main h5, .main h6,
.main .h1, .main .h2, .main .h3, .main .h4, .main .h5, .main .h6 {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.main h2, .main .h2 {
  font-size: 2.25rem;
}

.main .section-heading p {
  font-size: 1.05rem;
  line-height: 1.75;
  color: #64748b;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

/* Heading underline accent - prominent */
.main .section-heading h2::after {
  content: '';
  display: block;
  width: 80px;
  height: 4px;
  background: linear-gradient(90deg, var(--bh-blue), var(--bh-violet));
  border-radius: 2px;
  margin: 1rem auto 0;
}

.main .section-heading:not(.text-center) h2::after {
  margin-left: 0;
}

/* Section heading h2 color */
.main .section-heading h2 {
  color: var(--bh-navy);
  font-weight: 800;
}

/* Body paragraph improvements */
.main p {
  line-height: 1.7;
}


/* ============================================================
   SECTION 3: Section Background Overrides
   ============================================================ */

/* Refined section backgrounds */
.main .gray-light-bg {
  background: var(--bh-bg-cream) !important;
}

/* Section-bg with mesh overlay handled in Section 13 (CTA) */
.main .section-bg > .container {
  position: relative;
  z-index: 1;
}

/* Hero sections - modern gradient */
.main .section-blue {
  background: var(--bh-gradient-hero) !important;
  position: relative;
  overflow: hidden;
}

/* Override data-overlay gradient */
.main [data-overlay]:before {
  background: linear-gradient(135deg,
    rgba(6, 11, 31, 0.92) 0%,
    rgba(9, 72, 179, 0.65) 100%) !important;
}


/* ============================================================
   SECTION 4: Hero Section Overrides
   ============================================================ */

/* Modern hero with floating orb effects */
.main .hero-equal-height {
  min-height: 680px;
  overflow: hidden;
  position: relative;
}

/* Floating abstract orb - blue */
.main .section-blue::after {
  content: '';
  position: absolute;
  top: -20%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(13,110,253,0.15) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(60px);
  animation: heroFloat 8s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}

/* Hero content text enhancements */
.main .hero-content-wrap {
  z-index: 2 !important;
  position: relative;
}

.main .hero-content-wrap h1 {
  font-size: 2.75rem;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.03em;
}

.main .hero-content-wrap .tech-feature-list li {
  padding: 0.4rem 0;
  font-size: 0.95rem;
  opacity: 0.92;
}

/* Modernize hero CTA buttons (exclude domain search form buttons) */
.main .hero-content-wrap .btn-tertiary:not(.newsletter-form .btn-tertiary) {
  padding: 0.875rem 2rem;
  font-weight: 600;
  border-radius: 0.75rem;
  font-size: 1rem;
  background: linear-gradient(135deg, #ea550b, #f97316) !important;
  border: none !important;
  box-shadow: 0 4px 15px rgba(234, 85, 11, 0.35);
  transition: all var(--bh-transition);
}

.main .hero-content-wrap .btn-tertiary:not(.newsletter-form .btn-tertiary):hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(234, 85, 11, 0.45);
}

/* Domain search form button - preserve original absolute positioning */
.main .hero-content-wrap .newsletter-form .btn-tertiary {
  position: absolute;
  right: 4px;
  top: 4px;
  bottom: 4px;
  height: auto;
  border-radius: 30px;
  padding-left: 30px;
  padding-right: 30px;
}

/* Hero image subtle float animation */
.main .section-blue .img-wrap img,
.main .hero-equal-height .img-wrap img {
  animation: heroImageFloat 6s ease-in-out infinite;
}

/* Page header sections (info/legal pages) */
.main .page-header-section {
  position: relative;
  overflow: hidden;
}

.main .page-header-section h2 {
  font-weight: 800;
  letter-spacing: -0.03em;
}

/* Slider hero adjustments */
.main .hero-slider-section {
  position: relative;
}

.main .hero-slider-section .section-blue {
  overflow: hidden;
}


/* ============================================================
   SECTION 5: Domain Search Bar Override
   ============================================================ */

/* Floating domain search card - elevated glass look */
.main .domain-search-wrap {
  background: #fff !important;
  border: none !important;
  border-radius: 1.5rem !important;
  padding: 2.5rem 2rem !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1),
              0 1px 3px rgba(0, 0, 0, 0.06) !important;
  transition: all 0.4s ease;
  position: relative;
  margin-top: -3rem;
  z-index: 10;
}

.main .domain-search-wrap::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--bh-blue), var(--bh-violet), var(--bh-cyan));
  border-radius: 1.5rem 1.5rem 0 0;
}

.main .domain-search-wrap:hover {
  box-shadow: 0 25px 70px rgba(13, 110, 253, 0.12),
              0 1px 3px rgba(0, 0, 0, 0.06) !important;
  transform: translateY(-2px);
}

.main .domain-search-wrap h4 {
  font-weight: 700;
  color: var(--bh-navy);
  font-size: 1.25rem;
}

/* Domain search input */
.main .domain-search-wrap .form-control {
  border: 2px solid #e2e8f0 !important;
  font-size: 1rem;
  transition: all 0.3s ease;
}

.main .domain-search-wrap .form-control:focus {
  border-color: var(--bh-blue) !important;
  box-shadow: 0 0 0 4px rgba(13, 110, 253, 0.1) !important;
}

/* Search button styling */
.main .domain-search-wrap .btn-primary {
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-indigo)) !important;
  border: none !important;
  box-shadow: 0 4px 12px rgba(13, 110, 253, 0.3);
}

/* Domain TLD items modernized */
.main .domain-search-list .list-inline-item {
  border-radius: 1rem !important;
  transition: all 0.3s ease;
  border: 1px solid rgba(0,0,0,0.06) !important;
  overflow: hidden;
}

.main .domain-search-list .list-inline-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(13, 110, 253, 0.12);
  border-color: var(--bh-blue) !important;
  background: linear-gradient(135deg, rgba(13,110,253,0.02), rgba(67,56,202,0.02)) !important;
}

.main .domain-search-list .list-inline-item .price-convert {
  font-weight: 700;
  color: var(--bh-blue);
}


/* ============================================================
   SECTION 6: Promo Card Overrides (Homepage)
   ============================================================ */

.main .single-promo-card {
  border: none !important;
  border-radius: var(--bh-card-radius) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.06);
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  background: var(--bh-card-bg) !important;
  overflow: hidden;
  position: relative;
  padding: 2rem 1.5rem !important;
}

/* Gradient top border accent - always visible */
.main .single-promo-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--bh-gradient-card-accent);
  opacity: 1;
  z-index: 1;
}

.main .single-promo-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 50px rgba(13, 110, 253, 0.15);
}

/* Icon in colored circle */
.main .single-promo-card .icon-size-lg {
  font-size: 1.75rem;
  width: 70px;
  height: 70px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 1rem;
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-indigo));
  color: #fff !important;
  -webkit-text-fill-color: #fff;
  -webkit-background-clip: unset;
  background-clip: unset;
  box-shadow: 0 8px 24px rgba(13, 110, 253, 0.25);
  transition: transform 0.4s ease;
}

.main .single-promo-card:hover .icon-size-lg {
  transform: scale(1.1) rotate(-5deg);
}

.main .single-promo-card h5 {
  font-weight: 700;
  color: var(--bh-navy);
  margin-top: 0.5rem;
}

.main .single-promo-card p {
  color: #64748b;
  font-size: 0.95rem;
  line-height: 1.7;
}


/* ============================================================
   SECTION 7: Service Card Overrides (Homepage)
   ============================================================ */

.main .single-service {
  background: var(--bh-card-bg) !important;
  border: none !important;
  border-radius: var(--bh-card-radius) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.06);
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
  overflow: hidden;
  border-left: 4px solid var(--bh-blue) !important;
}

.main .single-service::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 0;
  background: linear-gradient(135deg, rgba(13,110,253,0.03) 0%, rgba(67,56,202,0.03) 100%);
  transition: height 0.4s ease;
  pointer-events: none;
}

.main .single-service:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(13, 110, 253, 0.12);
  border-left-color: var(--bh-indigo) !important;
}

.main .single-service:hover::after {
  height: 100%;
}

.main .single-service h4 {
  color: var(--bh-navy);
  font-weight: 700;
}

.main .single-service .color-primary {
  font-size: 2.5rem;
  width: 64px;
  height: 64px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.875rem;
  background: linear-gradient(135deg, rgba(13,110,253,0.1), rgba(67,56,202,0.1));
  color: var(--bh-blue) !important;
  transition: all 0.4s ease;
}

.main .single-service:hover .color-primary {
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-indigo));
  color: #fff !important;
  transform: scale(1.05);
  box-shadow: 0 8px 24px rgba(13, 110, 253, 0.3);
}


/* ============================================================
   SECTION 8: Hosting Pricing Cards - Vertical
   (cwp-web-hosting, cwp-reseller-hosting, website-design)
   ============================================================ */

.main .pricing-new-wrapper {
  border-radius: var(--bh-card-radius) !important;
  border: 1px solid var(--bh-card-border) !important;
  box-shadow: var(--bh-card-shadow);
  transition: all var(--bh-transition);
  overflow: hidden;
  position: relative;
}

.main .pricing-new-wrapper:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 50px rgba(13, 110, 253, 0.15);
  border-color: rgba(13, 110, 253, 0.2) !important;
}

/* Featured plan glow ring */
.main .pricing-new-wrapper.popular-price {
  border: 2px solid rgba(13, 110, 253, 0.3) !important;
  box-shadow: 0 0 0 4px rgba(13, 110, 253, 0.08), var(--bh-card-shadow);
}

.main .pricing-new-wrapper.popular-price:hover {
  box-shadow: 0 0 0 4px rgba(13, 110, 253, 0.12), 0 20px 50px rgba(13, 110, 253, 0.15);
}

/* Pricing header area */
.main .pricing-new-wrapper .pricing-header .price {
  font-weight: 800;
  letter-spacing: -0.02em;
}

/* Strikethrough original price */
.main .pricing-new-wrapper del.price-convert {
  font-size: 1rem;
}

/* Plan name styling */
.main .pricing-new-wrapper .pricing-info h5 {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--bh-navy);
}

/* Feature list modernization */
.main .pricing-feature-list-2 li {
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.04);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.main .pricing-feature-list-2 li:last-child {
  border-bottom: none;
}

/* Order Now button in pricing */
.main .pricing-new-wrapper .btn-primary {
  border-radius: 0.75rem !important;
  padding: 0.75rem 2rem;
  font-weight: 600;
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-blue-dark)) !important;
  border: none !important;
  box-shadow: 0 4px 12px rgba(13, 110, 253, 0.25);
  transition: all var(--bh-transition);
}

.main .pricing-new-wrapper .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(13, 110, 253, 0.35);
}

/* Pricing icon modernization */
.main .pricing-new-wrapper .p-icon i {
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-indigo));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}


/* ============================================================
   SECTION 9: VPS / Cloud Pricing Tables
   ============================================================ */

/* Keep original border-spacing (row gaps) intact, just modernize the look */
.main .vps-hosting-pricing-table {
  box-shadow: none;
}

.main .vps-hosting-pricing-table thead {
  background: var(--bh-gradient-hero) !important;
}

.main .vps-hosting-pricing-table thead th {
  padding: 1rem 0.75rem;
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  border: none !important;
  color: #fff;
}

.main .vps-hosting-pricing-table thead .primary-bg {
  background: transparent !important;
}

.main .vps-hosting-pricing-table tbody tr {
  transition: all var(--bh-transition);
  border-radius: 0.5rem;
}

.main .vps-hosting-pricing-table tbody tr:hover {
  background: rgba(13, 110, 253, 0.06) !important;
  box-shadow: 0 2px 8px rgba(13, 110, 253, 0.08);
}

.main .vps-hosting-pricing-table .btn-primary {
  border-radius: 0.5rem !important;
  font-weight: 600;
  padding: 0.375rem 1.25rem;
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-blue-dark)) !important;
  border: none !important;
  box-shadow: 0 2px 8px rgba(13, 110, 253, 0.2);
  transition: all var(--bh-transition);
}

.main .vps-hosting-pricing-table .btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(13, 110, 253, 0.3);
}


/* ============================================================
   SECTION 10: Dedicated Server Horizontal Cards
   ============================================================ */

.main .single-price-package {
  border-radius: var(--bh-card-radius) !important;
  border: 1px solid var(--bh-card-border) !important;
  box-shadow: var(--bh-card-shadow);
  transition: all var(--bh-transition);
  overflow: hidden;
  background: var(--bh-card-bg) !important;
  margin-bottom: 1rem;
}

.main .single-price-package:hover {
  transform: translateX(4px);
  box-shadow: var(--bh-card-shadow-hover);
  border-left: 3px solid var(--bh-blue) !important;
}

.main .single-price-package .package_header .package_name h3 {
  font-weight: 700;
  color: var(--bh-navy);
}

.main .single-price-package .btn-primary {
  border-radius: 0.5rem !important;
  font-weight: 600;
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-blue-dark)) !important;
  border: none !important;
}


/* ============================================================
   SECTION 11: Homepage Pricing Cards (single-pricing-pack-2)
   ============================================================ */

.main .single-pricing-pack-2 {
  border-radius: var(--bh-card-radius) !important;
  border: none !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.06);
  transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  padding: 2.5rem 2rem !important;
  position: relative;
  overflow: hidden;
  background: #fff !important;
}

/* Gradient top accent - always visible */
.main .single-pricing-pack-2::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--bh-blue), var(--bh-indigo));
  opacity: 1;
}

.main .single-pricing-pack-2:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 50px rgba(13, 110, 253, 0.15);
}

/* Featured / popular plan - highlighted */
.main .single-pricing-pack-2.popular-price {
  border: 2px solid var(--bh-blue) !important;
  box-shadow: 0 8px 30px rgba(13, 110, 253, 0.15);
  transform: scale(1.03);
}

.main .single-pricing-pack-2.popular-price::before {
  height: 5px;
  background: linear-gradient(90deg, var(--bh-blue), var(--bh-violet));
}

.main .single-pricing-pack-2.popular-price:hover {
  transform: scale(1.03) translateY(-10px);
  box-shadow: 0 24px 50px rgba(13, 110, 253, 0.2);
}

.main .single-pricing-pack-2 .pricing-icon img {
  transition: transform 0.4s ease;
}

.main .single-pricing-pack-2:hover .pricing-icon img {
  transform: scale(1.15) rotate(-3deg);
}

.main .single-pricing-pack-2 .package-title {
  font-weight: 700;
  color: var(--bh-navy);
  font-size: 1.15rem;
}

.main .single-pricing-pack-2 .pricing-price .h2 {
  font-weight: 800;
  color: var(--bh-navy);
}

.main .single-pricing-pack-2 .btn-primary {
  border-radius: 0.75rem !important;
  padding: 0.75rem 2rem;
  font-weight: 600;
  width: 100%;
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-indigo)) !important;
  border: none !important;
  box-shadow: 0 4px 16px rgba(13, 110, 253, 0.3);
  transition: all 0.3s ease;
  letter-spacing: 0.02em;
}

.main .single-pricing-pack-2 .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(13, 110, 253, 0.4);
  background: linear-gradient(135deg, var(--bh-indigo), var(--bh-blue)) !important;
}


/* ============================================================
   SECTION 12: Features Box Overrides
   ============================================================ */

.main .features-box {
  border: 1px solid rgba(0, 0, 0, 0.06) !important;
  border-radius: var(--bh-card-radius) !important;
  background: var(--bh-card-bg) !important;
  box-shadow: var(--bh-card-shadow);
  transition: all var(--bh-transition);
}

.main .features-box:hover {
  transform: translateY(-4px);
  box-shadow: var(--bh-card-shadow-hover);
  border-color: transparent !important;
}

.main .features-box .icon-size-md {
  font-size: 1.5rem;
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.875rem;
  background: rgba(13, 110, 253, 0.08);
  color: var(--bh-blue) !important;
  transition: all var(--bh-transition);
}

.main .features-box:hover .icon-size-md {
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-indigo));
  color: #fff !important;
  -webkit-text-fill-color: #fff;
}

.main .features-box h5 {
  font-weight: 700;
  color: var(--bh-navy);
}

.main .features-box p {
  color: #64748b;
}


/* ============================================================
   SECTION 13: CTA Section Overrides
   ============================================================ */

/* CTA sections - gradient background with accent */
.main .section-bg {
  background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 50%, #f0f4fb 100%) !important;
  position: relative;
}

.main .section-bg::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(13,110,253,0.06) 0%, transparent 60%),
              radial-gradient(ellipse at 80% 50%, rgba(67,56,202,0.04) 0%, transparent 60%);
  pointer-events: none;
}

.main .cta-content-wrap h2 {
  font-weight: 800;
  color: var(--bh-navy);
}

.main .cta-content-wrap p {
  color: #475569;
  line-height: 1.7;
}

/* CTA buttons */
.main .cta-content-wrap + .action-btns .btn-tertiary,
.main .action-btns .btn-tertiary {
  background: linear-gradient(135deg, var(--bh-blue), var(--bh-indigo)) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0.75rem;
  padding: 0.75rem 2rem;
  font-weight: 600;
  box-shadow: 0 4px 16px rgba(13, 110, 253, 0.3);
  transition: all 0.3s ease;
}

.main .action-btns .btn-tertiary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(13, 110, 253, 0.4);
}

/* CTA images */
.main .cta-img-wrap img {
  transition: transform 0.4s ease;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,0.1));
}

.main .cta-img-wrap:hover img {
  transform: scale(1.05);
}

/* Bottom CTA banner - dark gradient */
.main > section.section-bg.text-white {
  background: var(--bh-gradient-hero) !important;
}

.main > section.section-bg.text-white .btn-light {
  background: #fff !important;
  color: var(--bh-navy) !important;
  border: none !important;
  border-radius: 0.75rem;
  padding: 0.75rem 2.5rem;
  font-weight: 700;
  box-shadow: 0 4px 16px rgba(255,255,255,0.2);
  transition: all 0.3s ease;
}

.main > section.section-bg.text-white .btn-light:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(255,255,255,0.3);
}

/* Full-width CTA banners */
.main section.text-white.text-center.py-5 {
  background: var(--bh-gradient-accent) !important;
  position: relative;
  overflow: hidden;
}

.main section.text-white.text-center.py-5::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 60%);
  border-radius: 50%;
  pointer-events: none;
}

.main section.text-white.text-center.py-5 h3 {
  font-weight: 800;
  position: relative;
  z-index: 1;
}

.main section.text-white.text-center.py-5 .btn-light {
  border-radius: 0.75rem;
  font-weight: 600;
  padding: 0.875rem 2.5rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  transition: all var(--bh-transition);
  position: relative;
  z-index: 1;
}

.main section.text-white.text-center.py-5 .btn-light:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
}

/* Support CTA section */
.main .support-action a,
.main .support-action div {
  transition: all var(--bh-transition);
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
}

.main .support-action a:hover {
  background: rgba(13, 110, 253, 0.05);
}

/* Support CTA in pricing */
.main .support-cta h5 {
  font-weight: 700;
  color: var(--bh-navy);
}


/* ============================================================
   SECTION 14: Partners / Clients Carousel
   ============================================================ */

.main .client-section {
  background: var(--bh-navy) !important;
  position: relative;
  overflow: hidden;
}

.main .client-section::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -20%;
  width: 60%;
  height: 200%;
  background: radial-gradient(ellipse, rgba(13,110,253,0.08) 0%, transparent 70%);
  pointer-events: none;
}

.main .client-section .section-heading h2 {
  color: #fff !important;
}

.main .client-section .section-heading h2::after {
  background: linear-gradient(90deg, var(--bh-blue-light), var(--bh-cyan)) !important;
}

.main .client-section .section-heading p {
  color: rgba(255,255,255,0.7) !important;
}

.main .clients-carousel .single-customer {
  padding: 1rem;
}

.main .clients-carousel .customer-logo {
  filter: grayscale(100%) brightness(2);
  opacity: 0.5;
  transition: all 0.4s ease;
  border-radius: 0.5rem;
  padding: 0.25rem;
}

.main .clients-carousel .customer-logo:hover {
  filter: grayscale(0%) brightness(1);
  opacity: 1;
  transform: scale(1.1);
}


/* ============================================================
   SECTION 15: Network Map
   ============================================================ */

.main .network-map-wrap {
  position: relative;
  padding: 2rem;
  background: var(--bh-card-bg);
  border-radius: var(--bh-card-radius);
  box-shadow: var(--bh-card-shadow);
  border: 1px solid var(--bh-card-border);
}

.main .custom-map-location li span {
  animation: mapPulse 2s ease-in-out infinite;
}


/* ============================================================
   SECTION 16: FAQ Accordion
   ============================================================ */

.main .accordion.faq-wrap {
  border-radius: var(--bh-card-radius);
  overflow: hidden;
  border: 1px solid var(--bh-card-border);
  box-shadow: var(--bh-card-shadow);
}

.main .accordion-item {
  border: none !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.04) !important;
}

.main .accordion-item:last-child {
  border-bottom: none !important;
}

.main .accordion-button {
  font-weight: 600;
  font-size: 1rem;
  padding: 1.25rem 1.5rem;
  color: var(--bh-navy);
  background: transparent !important;
  transition: all var(--bh-transition);
}

.main .accordion-button:not(.collapsed) {
  background: rgba(13, 110, 253, 0.03) !important;
  color: var(--bh-blue) !important;
  box-shadow: none !important;
}

.main .accordion-button::after {
  transition: transform var(--bh-transition);
}

.main .accordion-button:focus {
  box-shadow: none !important;
}

.main .accordion-body {
  padding: 0 1.5rem 1.25rem;
  color: #475569;
  line-height: 1.7;
}


/* ============================================================
   SECTION 17: Tool Pages (form + results)
   ============================================================ */

/* Tool inputs (exclude rounded-pill domain search inputs) */
.main input[type="text"].form-control:not(.rounded-pill),
.main textarea.form-control {
  border: 2px solid #e2e8f0;
  border-radius: 0.75rem;
  transition: border-color var(--bh-transition), box-shadow var(--bh-transition);
}

.main input[type="text"].form-control:not(.rounded-pill):focus,
.main textarea.form-control:focus {
  border-color: var(--bh-blue);
  box-shadow: 0 0 0 4px rgba(13, 110, 253, 0.1);
}

/* Tool buttons */
.main .btn-primary {
  border-radius: 0.625rem;
  font-weight: 600;
  transition: all var(--bh-transition);
}

/* Tool results cards */
.main .card.shadow,
.main .card.shadow-sm {
  border-radius: var(--bh-card-radius) !important;
  overflow: hidden;
  border: 1px solid var(--bh-card-border) !important;
}

/* Table header modernized */
.main .table-dark {
  background: var(--bh-gradient-hero) !important;
}

/* Tool page textarea */
.main .bh-textarea {
  border-radius: 0.75rem !important;
  border: 2px solid #e2e8f0 !important;
}

.main .bh-textarea:focus {
  border-color: var(--bh-blue) !important;
  box-shadow: 0 0 0 4px rgba(13, 110, 253, 0.1) !important;
}


/* ============================================================
   SECTION 18: Legal / Info Page Overrides
   ============================================================ */

.main .content-with-sidebar {
  background: var(--bh-card-bg);
  padding: 2.5rem;
  border-radius: var(--bh-card-radius);
  box-shadow: var(--bh-card-shadow);
  border: 1px solid var(--bh-card-border);
}

.main .content-with-sidebar h3,
.main .content-with-sidebar h5 {
  color: var(--bh-navy);
  font-weight: 700;
}

.main .content-with-sidebar p {
  color: #475569;
  line-height: 1.8;
}

/* Feature tab sections on info pages */
/* Homepage pricing section background */
.main .pricing-section.gray-light-bg {
  background: linear-gradient(180deg, #f0f4fb 0%, #e8eef8 100%) !important;
}

.main .feature-content-wrap h2 {
  font-weight: 800;
  color: var(--bh-navy);
}

.main .feature-content-wrap p {
  color: #475569;
  line-height: 1.7;
}

.main .read-more-link {
  font-weight: 600;
  color: var(--bh-blue);
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1.25rem;
  background: rgba(13,110,253,0.06);
  border-radius: 2rem;
}

.main .read-more-link:hover {
  background: rgba(13,110,253,0.12);
  color: var(--bh-indigo);
  transform: translateX(4px);
}

.main .read-more-link i {
  transition: transform 0.3s ease;
}

.main .read-more-link:hover i {
  transform: translateX(4px);
}

/* Feature images with float effect */
.main .feature-img-wrap {
  position: relative;
}

.main .feature-img-wrap::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: 10%;
  right: 10%;
  height: 20px;
  background: radial-gradient(ellipse, rgba(0,0,0,0.1) 0%, transparent 70%);
  border-radius: 50%;
}

/* Feature images */
.main .feature-img-wrap img {
  transition: transform var(--bh-transition-slow);
}

.main .feature-img-wrap:hover img {
  transform: scale(1.03);
}


/* ============================================================
   SECTION 19: 404 Page
   ============================================================ */

.main .error-content-wrap h1 {
  font-size: 10rem;
  font-weight: 900;
  background: linear-gradient(135deg, #fff, rgba(255,255,255,0.6));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-shadow: none;
}

.main .error-content-wrap .btn-tertiary {
  padding: 1rem 2.5rem;
  font-size: 1.1rem;
  border-radius: 0.75rem;
}


/* ============================================================
   SECTION 20: Pricing Toggle
   ============================================================ */

.main .switch-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  background: var(--bh-card-bg);
  padding: 0.5rem 1.5rem;
  border-radius: 3rem;
  box-shadow: var(--bh-card-shadow);
  border: 1px solid var(--bh-card-border);
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

.main .form-switch .switch-icon {
  border-radius: 2rem !important;
}

.main .pricing-onsale .badge {
  border-radius: 2rem;
  padding: 0.375rem 0.75rem;
  font-weight: 600;
}


/* ============================================================
   SECTION 21: SVG Wave Section Dividers
   ============================================================ */

/* Wave divider for hero/slider sections going into white content */
.main .hero-slider-section .owl-carousel .item > div::after,
.modern-wave-white::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 60px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23ffffff' d='M0,30 C360,60 720,0 1080,30 C1260,45 1380,40 1440,30 L1440,60 L0,60 Z'/%3E%3C/svg%3E") no-repeat bottom center;
  background-size: cover;
  z-index: 2;
  pointer-events: none;
}

/* Wave to light background */
.modern-wave-light::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 60px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23f0f4fb' d='M0,30 C360,60 720,0 1080,30 C1260,45 1380,40 1440,30 L1440,60 L0,60 Z'/%3E%3C/svg%3E") no-repeat bottom center;
  background-size: cover;
  z-index: 2;
  pointer-events: none;
}


/* ============================================================
   SECTION 22: Utility Classes
   ============================================================ */

.modern-gradient-text {
  background: var(--bh-gradient-card-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.modern-glass {
  background: var(--bh-glass-bg);
  border: 1px solid var(--bh-glass-border);
  backdrop-filter: var(--bh-glass-blur);
  -webkit-backdrop-filter: var(--bh-glass-blur);
  border-radius: var(--bh-card-radius);
}

.modern-glow-blue {
  box-shadow: 0 0 30px rgba(13, 110, 253, 0.15);
}

/* Scroll-triggered reveal animation */
.modern-reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.modern-reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger children animations */
.modern-stagger > * {
  opacity: 0;
  transform: translateY(20px);
}

.modern-stagger.revealed > * {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.modern-stagger.revealed > *:nth-child(1) { transition-delay: 0ms; }
.modern-stagger.revealed > *:nth-child(2) { transition-delay: 100ms; }
.modern-stagger.revealed > *:nth-child(3) { transition-delay: 200ms; }
.modern-stagger.revealed > *:nth-child(4) { transition-delay: 300ms; }
.modern-stagger.revealed > *:nth-child(5) { transition-delay: 400ms; }
.modern-stagger.revealed > *:nth-child(6) { transition-delay: 500ms; }


/* ============================================================
   SECTION 23: Animations & Keyframes
   ============================================================ */

@keyframes heroFloat {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(20px, -20px) scale(1.05); }
}

@keyframes heroImageFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

@keyframes mapPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(13, 110, 253, 0.4); }
  50% { box-shadow: 0 0 0 12px rgba(13, 110, 253, 0); }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* Prefers reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .modern-reveal,
  .modern-stagger > * {
    opacity: 1 !important;
    transform: none !important;
  }
}


/* ============================================================
   SECTION 24: Responsive Overrides
   ============================================================ */

@media (max-width: 991.98px) {
  .main .hero-content-wrap h1 {
    font-size: 2rem;
  }

  .main .hero-equal-height {
    min-height: auto;
  }

  /* Hide floating orbs on tablet */
  .main .section-blue::after {
    display: none;
  }

  .main .domain-search-wrap {
    margin-top: 0 !important;
    padding: 1.5rem !important;
  }

  .main .domain-search-wrap .newsletter-form {
    width: 100% !important;
  }

  .modern-wave-white::after,
  .modern-wave-light::after {
    height: 30px;
  }
}

@media (max-width: 767.98px) {
  .main h2, .main .h2 {
    font-size: 1.75rem;
  }

  .main .hero-content-wrap h1 {
    font-size: 1.75rem;
  }

  /* Disable hover transforms on mobile for touch */
  .main .single-promo-card:hover,
  .main .single-pricing-pack-2:hover,
  .main .pricing-new-wrapper:hover,
  .main .features-box:hover,
  .main .single-service:hover,
  .main .single-price-package:hover {
    transform: none;
  }

  .main .content-with-sidebar {
    padding: 1.5rem;
  }

  .main .section-heading h2::after {
    margin-top: 0.5rem;
  }

  /* Smaller wave on mobile */
  .modern-wave-white::after,
  .modern-wave-light::after {
    height: 20px;
  }

  /* Stack pricing cards properly */
  .main .pricing-new-wrapper {
    margin-bottom: 1rem;
  }

  /* Force pricing stagger children visible on mobile */
  .main .pricing-section .modern-stagger > *,
  .modern-stagger > .col-lg-4,
  .modern-stagger > .col-12 {
    opacity: 1 !important;
    transform: none !important;
  }

  /* Force all pricing/plan sections visible on mobile to prevent white space on first load */
  .main .vps-pricing-plane.modern-reveal,
  .main .pricing-section.modern-reveal,
  .main .domain-pricing-section.modern-reveal {
    opacity: 1 !important;
    transform: none !important;
  }

  /* Center VPS pricing cards on mobile */
  .main .vps-pricing-row {
    float: none !important;
    margin: 0 auto 15px auto !important;
  }
}

/* OS/utility icon grid modernization */
.main .single-icon-wrap {
  border-radius: var(--bh-card-radius) !important;
  transition: all var(--bh-transition);
  border: 1px solid var(--bh-card-border) !important;
}

.main .single-icon-wrap:hover {
  transform: translateY(-3px);
  box-shadow: var(--bh-card-shadow-hover);
}

/* General button improvements throughout body (exclude domain search form buttons) */
.main .btn-tertiary:not(.newsletter-form .btn-tertiary) {
  border-radius: 0.75rem;
  font-weight: 600;
  transition: all var(--bh-transition);
}

.main .btn-tertiary:not(.newsletter-form .btn-tertiary):hover {
  transform: translateY(-2px);
}

/* Read more links throughout */
.main a.read-more-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

/* Improve spacing for section headings */
.main .section-heading {
  margin-bottom: 2.5rem;
}

/* Modern scrollbar for tool results */
.main .table-responsive::-webkit-scrollbar {
  height: 6px;
}

.main .table-responsive::-webkit-scrollbar-track {
  background: #f1f5f9;
  border-radius: 3px;
}

.main .table-responsive::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 3px;
}

.main .table-responsive::-webkit-scrollbar-thumb:hover {
  background: #94a3b8;
}
