
/**
 * Beatsy Solutions Limited — Custom Styles (Organized)
 * Version: 1.0.0
 */

/* ─── Variables & Themes ────────────────────────────── */
:root {
  --bs-primary: #2C58BC; --bs-secondary: #FF6D3B; --bs-primary-rgb: 44, 88, 188; --bs-secondary-rgb: 255, 109, 59; --beatsy-blue: #2C58BC; --beatsy-blue-dark: #1e3f8a; --beatsy-blue-light: #eef2ff; --beatsy-orange: #FF6D3B; --beatsy-orange-dark: #e55a2b; --beatsy-dark: #041527; --beatsy-dark-2: #08213a; --beatsy-gray: #f4f6fb; --beatsy-text: #2c3e50; --beatsy-text-muted: #6c7b8a; --beatsy-border: rgba(44, 88, 188, 0.12); --beatsy-shadow: 0 4px 25px rgba(44, 88, 188, 0.12); --beatsy-shadow-hover: 0 10px 40px rgba(44, 88, 188, 0.22); --beatsy-radius: 12px; --beatsy-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); --font-primary: 'Inter', sans-serif; --font-heading: 'Ubuntu', 'Futura', sans-serif; --beatsy-primary-gradient: linear-gradient(278.54deg, #2C58BC 15.93%, #041527 98.7%);

  /* Z-Index Hierarchy */
  --z-index-base: 1;
  --z-index-sticky: 1020;
  --z-index-topbar: 9000;
  --z-index-header: 10000;
  --z-index-dropdown: 11000;
  --z-index-overlay: 12000;
  --z-index-mobile-menu: 5;
  --z-index-modal: 15000;
  --z-index-tooltip: 16000;
  --z-index-toast: 17000;
  --z-index-max: 2147483647;
}

[data-bs-theme="dark"] {
  --beatsy-card-bg: #1a2340; --beatsy-section-bg: #0d1525; --beatsy-border: rgba(255, 255, 255, 0.08);
}

[data-bs-theme="light"] {
  --beatsy-card-bg: #ffffff; --beatsy-section-bg: #f4f6fb; --beatsy-border: rgba(44, 88, 188, 0.1);
}

[data-bs-theme="dark"] h1, [data-bs-theme="dark"] h2, [data-bs-theme="dark"] h3 {
  color: #fff;
}

[data-bs-theme="light"] .beatsy-header {
  background: #fff; border-bottom: none; box-shadow: 0 2px 15px rgba(0, 0, 0, 0.04);
}

[data-bs-theme="light"] .logo-text-main {
  color: var(--beatsy-blue);
}

[data-bs-theme="light"] .logo-text-sub {
  color: var(--beatsy-orange);
}

[data-bs-theme="light"] .beatsy-header .nav-link {
  color: var(--beatsy-text);
}

[data-bs-theme="light"] .dark-icon {
  display: none;
}

[data-bs-theme="light"] .light-icon {
  display: block;
}

:root {
  --header-height: 80px;
}

[data-bs-theme="dark"] .section-title .subtitle {
  background: rgba(44, 88, 188, 0.12);
}

:root {
  --beatsy-blue: #2C58BC; --beatsy-orange: #FF6D3B; --beatsy-text: #334155; --beatsy-text-muted: #64748b; --beatsy-bg-light: #f8fafc; --beatsy-border-color: #e2e8f0; --beatsy-radius: 12px; --beatsy-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ─── Typography & Base ────────────────────────────── */
body {
  font-family: var(--font-primary); font-size: 15px; line-height: 1.7;
}

h1, .h1 {
  font-size: 2.25rem !important; font-weight: 800;
}

p, li, .p-standard {
  font-size: 15px; line-height: 1.6; color: var(--beatsy-text);
}

a {
  color: var(--beatsy-blue); text-decoration: none; transition: var(--beatsy-transition);
}

a:hover {
  color: var(--beatsy-blue-dark);
}

.text-white h1, .text-white h2, .text-white h3, .text-white h4, .text-white h5, .text-white h6, 
.text-white p, .text-white li, .text-white span, .text-white small {
  color: #fff !important;
}

.text-white a:not(.btn) {
  color: rgba(255, 255, 255, 0.8) !important;
}

.text-white a:not(.btn):hover {
  color: #fff !important;
}

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

.text-warning {
  color: var(--beatsy-orange) !important;
}

.topbar-social.text-success:hover {
  background: #25d366; border-color: #25d366;
}

body > section,
body > div:not(.beatsy-header):not(.mobile-menu):not(.body-overlay):not(.main-wrapper) {
  isolation: isolate;
}

.tooltip {
  z-index: var(--z-index-tooltip) !important;
}

.toast {
  z-index: var(--z-index-toast) !important;
}

.floating-ai-btn {
  z-index: var(--z-index-overlay);
}

.main-wrapper {
  /* Removed stacking context to allow modals inside to layer above global header */
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.text-white-75 {
  color: rgba(255, 255, 255, 0.75);
}

body {
  font-family: 'Inter', sans-serif; color: var(--beatsy-text);
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5 {
  color: var(--beatsy-blue); font-family: 'Poppins', sans-serif; font-weight: 700; line-height: 1.3;
}

.gradient-text, 
.section-title h2 span, 
.hero-slide-content h1 span,
.display-5 span,
.text-primary,
[class*="text-gradient"] {
  background: none !important; -webkit-background-clip: initial !important; -webkit-text-fill-color: initial !important; color: var(--beatsy-blue) !important; background-clip: initial !important; text-fill-color: initial !important;
}

.text-warning, .logo-text-sub, .keyword-orange {
  color: var(--beatsy-orange) !important;
}

/* ─── Buttons ────────────────────────────── */
.btn-primary {
  background: var(--beatsy-blue); border-color: var(--beatsy-blue);
}

.btn-primary:hover {
  background: var(--beatsy-blue-dark); border-color: var(--beatsy-blue-dark); transform: translateY(-2px); box-shadow: var(--beatsy-shadow);
}

.btn-warning {
  color: #fff; background: var(--beatsy-orange); border-color: var(--beatsy-orange);
}

.btn-warning:hover {
  color: #fff; background: var(--beatsy-orange-dark); border-color: var(--beatsy-orange-dark);
}

.btn-main {
  background-color: var(--beatsy-orange); color: #fff !important; border: none; border-radius: 6px; padding: 12px 10px; font-weight: 700; font-size: 13px; transition: var(--beatsy-transition); text-decoration: none; text-align: center;
}

.btn-main:hover {
  background-color: var(--beatsy-blue); color: #fff !important;
}

.btn-outline-beatsy {
  border: 2px solid var(--beatsy-blue); color: var(--beatsy-dark) !important; background: transparent; border-radius: 6px; padding: 10px 10px; font-weight: 700; font-size: 13px; text-align: center; transition: var(--beatsy-transition); text-decoration: none;
}

.btn-outline-beatsy:hover {
  background: var(--beatsy-blue); color: #fff !important;
}

.btn-brand-orange {
  background-color: var(--beatsy-orange); border-color: var(--beatsy-orange); color: #fff !important; font-weight: 700;
}

.btn-brand-orange:hover {
  background-color: var(--beatsy-orange-dark); border-color: var(--beatsy-orange-dark); color: #fff !important;
}

.btn-beatsy {
  border-radius: 8px; font-weight: 600; font-size: 13.5px; padding: 8px 18px; align-items: center; gap: 6px; transition: var(--beatsy-transition);
}

.btn-beatsy:hover {
  transform: translateY(-2px); box-shadow: var(--beatsy-shadow);
}

.input-group .btn {
  border-radius: 0 8px 8px 0;
}

.btn {
  padding: 12px 30px; font-weight: 700; border-radius: 10px; transition: var(--beatsy-transition); font-size: 14px; display: inline-flex; align-items: center; justify-content: center; gap: 8px;
}

.btn-primary, .btn-warning, .btn-brand-orange, .btn-quote, .btn-info, .btn-danger, .btn-success {
  color: #fff !important;
}

.btn-outline-primary {
  color: var(--beatsy-blue) !important; border-color: var(--beatsy-blue) !important; background: rgba(44, 88, 188, 0.05) !important;
}

.btn-outline-primary:hover {
  background: var(--beatsy-blue) !important; color: #fff !important;
}

.btn-primary {
  background: var(--beatsy-blue) !important; border-color: var(--beatsy-blue) !important;
}

.btn-warning, .btn-brand-orange, .btn-quote {
  background: var(--beatsy-orange) !important; border-color: var(--beatsy-orange) !important;
}

.btn:hover {
  transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,0.1);
}

.portal-page .btn-light {
  background: rgba(44, 88, 188, 0.08) !important; border-color: rgba(44, 88, 188, 0.1) !important; color: var(--beatsy-blue) !important;
}

.portal-page .btn-light:hover {
  background: var(--beatsy-blue) !important; color: #fff !important;
}

.btn-topbar-white {
  background: #fff !important; color: #000 !important; font-weight: 700; border-radius: 6px; padding: 6px 15px; font-size: 12px; text-decoration: none; display: inline-flex; align-items: center; white-space: nowrap !important; transition: var(--beatsy-transition);
}

.btn-topbar-orange {
  background: var(--beatsy-orange) !important; color: #fff !important; font-weight: 700; border-radius: 6px; padding: 6px 15px; font-size: 12px; text-decoration: none; display: inline-flex; align-items: center; white-space: nowrap !important; transition: var(--beatsy-transition);
}

/* ─── Header & Topbar ────────────────────────────── */
.package-header .package-name {
  font-weight: 800; font-size: 1.35rem; color: var(--beatsy-dark); margin-bottom: 1rem;
}

.package-header .from-only {
  color: var(--beatsy-text-muted); font-weight: 700; font-size: 11px; margin-bottom: 5px; display: block; text-transform: uppercase;
}

.package-header .price-value {
  font-weight: 900; font-size: 1.5rem; color: var(--beatsy-blue); margin-bottom: 0px;
}

.package-header .price-suffix {
  color: var(--beatsy-text-muted); font-size: 13px; font-weight: 600;
}

.package-header .package-tagline {
  color: var(--beatsy-orange); font-weight: 600; font-size: 12.5px; margin-top: 1rem; margin-bottom: 1.25rem; display: block;
}

.beatsy-topbar {
  background: var(--beatsy-dark); z-index: var(--z-index-topbar); position: relative;
}

.topbar-social {
  color: rgba(255, 255, 255, 0.7); text-decoration: none; width: 26px; height: 26px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; border: 1px solid rgba(255, 255, 255, 0.15); font-size: 11px; transition: var(--beatsy-transition);
}

.topbar-social:hover {
  color: #fff; background: var(--beatsy-blue); border-color: var(--beatsy-blue); transform: translateY(-2px);
}

.topbar-divider {
  width: 1px; height: 16px; background: rgba(255, 255, 255, 0.2); display: inline-block;
}

.beatsy-header {
  background: var(--beatsy-dark); position: sticky; top: 0; z-index: var(--z-index-header) !important; transition: var(--beatsy-transition); border-bottom: none;
}

.beatsy-header.header-sticky {
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.3);
}

.beatsy-header .navbar-brand {
  padding: 0; font-family: var(--font-heading); font-weight: 800; font-size: 24px; letter-spacing: -0.5px; text-decoration: none; display: flex; align-items: center;
}

.beatsy-header .nav-link {
  color: rgba(255, 255, 255, 0.8); font-weight: 500; padding: 8px 8px !important; border-radius: 8px; transition: var(--beatsy-transition); font-size: 13.5px;
}

.beatsy-header .nav-link:hover,
.beatsy-header .nav-link.active {
  color: var(--beatsy-blue); background: rgba(44, 88, 188, 0.08);
}

.beatsy-header .nav-link.dropdown-toggle::after {
  margin-left: 6px;
}

.beatsy-dropdown {
  border: 1px solid var(--beatsy-border); border-radius: var(--beatsy-radius); padding: 8px; min-width: 220px; box-shadow: var(--beatsy-shadow); background: var(--beatsy-card-bg); z-index: var(--z-index-dropdown) !important; animation: dropFadeIn 0.2s ease;
}

.beatsy-dropdown .dropdown-item {
  border-radius: 8px; font-size: 13.5px; padding: 10px 15px; display: flex; align-items: center; gap: 10px; transition: var(--beatsy-transition); font-weight: 500; color: #333;
}

.beatsy-dropdown .dropdown-item:hover {
  background: var(--beatsy-blue); color: #fff !important;
}

.beatsy-dropdown .dropdown-item:hover i {
  color: #fff !important;
}

.header-icon-btn {
  background: transparent; border: 1px solid var(--beatsy-border); width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--beatsy-blue); transition: var(--beatsy-transition);
}

.header-icon-btn:hover {
  background: var(--beatsy-blue); color: #fff !important; border-color: var(--beatsy-blue);
}

.header-icon-btn:hover i {
  color: #fff !important;
}

.dropdown-submenu {
  position: relative;
}

.dropdown-submenu > .dropdown-menu {
  top: 0; left: 100%; margin-top: -8px; margin-left: 0;
}

.dropdown-submenu-left > .dropdown-menu {
  left: auto; right: 100%;
}

.dropdown-submenu:hover > .dropdown-menu {
  display: block; opacity: 1; visibility: visible;
}

.header-icon-btn:hover {
  background: var(--beatsy-blue); border-color: var(--beatsy-blue);
}

.beatsy-search-dropdown {
  min-width: 300px; border-radius: var(--beatsy-radius); border: 1px solid var(--beatsy-border); box-shadow: var(--beatsy-shadow);
}

.mobile-nav-link {
  display: block; padding: 10px 0; font-weight: 500; text-decoration: none; border-bottom: 1px solid var(--beatsy-border); color: inherit; font-size: 15px;
}

.sticky-top:not(.beatsy-header) {
  z-index: var(--z-index-sticky) !important;
}

.sticky-top:not(.beatsy-header) {
  top: calc(var(--header-height) + 16px) !important;
}

.footer-nav {
  list-style: none; padding: 0; margin: 0;
}

.footer-nav li {
  margin-bottom: 8px;
}

.footer-nav a {
  color: rgba(255, 255, 255, 0.55); text-decoration: none; font-size: 13.5px; transition: var(--beatsy-transition); display: flex; align-items: center; gap: 6px;
}

.footer-nav a:hover {
  color: var(--beatsy-blue); padding-left: 5px;
}

.beatsy-page-header {
  background: linear-gradient(135deg, var(--beatsy-dark) 0%, var(--beatsy-dark-2) 100%); padding: 80px 0 60px; position: relative; overflow: hidden;
}

.beatsy-page-header::before {
  content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 20% 50%, rgba(0, 116, 217, 0.15), transparent 60%);
}

.portal-sidebar-nav {
  padding: 12px;
}

.portal-nav-link {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: 8px; color: inherit; text-decoration: none; font-weight: 500; font-size: 14px; transition: var(--beatsy-transition); margin-bottom: 2px;
}

.portal-nav-link:hover,
.portal-nav-link.active {
  background: rgba(0, 116, 217, 0.1); color: var(--beatsy-blue);
}

.beatsy-topbar {
  background: var(--beatsy-blue) !important; color: #fff !important; font-size: 13px; z-index: var(--z-index-topbar); position: relative;
}

.beatsy-header {
  background: #ffffff !important; box-shadow: 0 2px 20px rgba(0,0,0,0.06) !important; height: 80px; display: flex; align-items: center; z-index: var(--z-index-header) !important;
}

.navbar-brand {
  font-size: 26px !important; font-weight: 800 !important; display: flex !important; align-items: center !important;
}

.beatsy-header .nav-link {
  font-weight: 700 !important; color: #333 !important; font-size: 13.5px !important; letter-spacing: 0.2px; padding: 0 12px !important; line-height: 80px !important; display: flex !important; align-items: center !important; transition: var(--beatsy-transition); text-transform: uppercase;
}

.beatsy-header .nav-link:hover, 
.beatsy-header .nav-link.active {
  color: var(--beatsy-blue) !important;
}

.beatsy-header .dropdown-menu {
  margin-top: 0 !important; border: none !important; border-top: 3px solid var(--beatsy-blue) !important; box-shadow: 0 10px 30px rgba(0,0,0,0.1) !important; border-radius: 0 0 10px 10px !important; padding: 10px 0 !important; z-index: 10001;
}

.beatsy-header .dropdown-item {
  padding: 8px 20px !important; line-height: 1.6 !important; font-size: 14px !important; font-weight: 500 !important; color: var(--beatsy-text) !important;
}

.beatsy-header .dropdown-item:hover {
  background-color: var(--beatsy-bg-light) !important; color: var(--beatsy-blue) !important; padding-left: 25px !important;
}

.header-actions {
  height: 80px; display: flex !important; align-items: center !important;
}

.header-icon-btn {
  background: none; border: none; color: #333 !important; font-size: 18px; padding: 10px; display: flex; align-items: center; justify-content: center;
}

/* ─── Hero & Slider ────────────────────────────── */
.beatsy-hero {
  background: linear-gradient(135deg, var(--beatsy-dark) 0%, var(--beatsy-dark-2) 100%); position: relative; overflow: hidden; padding: 20px 0 80px;
}

.beatsy-hero::before {
  content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: radial-gradient(circle at 30% 50%, rgba(44, 88, 188, 0.15) 0%, transparent 60%),
    radial-gradient(circle at 70% 20%, rgba(236, 88, 0, 0.08) 0%, transparent 50%);
}

.hero-particles {
  position: absolute; inset: 0; overflow: hidden; pointer-events: none;
}

.hero-particle {
  position: absolute; width: 4px; height: 4px; background: var(--beatsy-blue); border-radius: 50%; opacity: 0.4; animation: float 8s infinite ease-in-out;
}

.beatsy-hero {
  padding-top: 100px; position: relative; overflow: hidden;
}

.beatsy-main-slider {
  position: relative; overflow: visible; background: #ffffff;
}

.hero-slide {
  padding: 40px 0 80px; min-height: 500px; display: flex; align-items: center; position: relative; overflow: hidden; background: linear-gradient(135deg, #ffffff 0%, #dae9ff 100%);
}

.hero-slide-image img {
  max-width: 100%; height: auto; filter: drop-shadow(0 30px 60px rgba(44, 88, 188, 0.15));
}

/* ─── Components & Cards ────────────────────────────── */
label, .form-label {
  font-size: 13.5px; font-weight: 600; color: var(--beatsy-text); margin-bottom: 0.4rem; display: inline-block;
}

.package-card {
  background: var(--beatsy-card-bg); border-radius: 12px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05); padding: 2.25rem; height: 100%; display: flex; flex-direction: column; position: relative; transition: var(--beatsy-transition); border: 1px solid var(--beatsy-border); overflow: hidden;
}

.package-card:hover {
  transform: translateY(-8px); box-shadow: 0 15px 40px rgba(0, 0, 0, 0.08); border-color: var(--beatsy-blue);
}

.form-control, .form-select {
  border-radius: 8px; border: 1px solid #ddd; padding: 10px 15px; font-size: 14px; transition: var(--beatsy-transition); background-color: #fff;
}

.form-control:focus, .form-select:focus {
  border-color: var(--beatsy-blue); box-shadow: 0 0 0 3px rgba(44, 88, 188, 0.1); outline: none;
}

.form-check-input {
  width: 18px; height: 18px; cursor: pointer;
}

.form-check-input:checked {
  background-color: var(--beatsy-blue); border-color: var(--beatsy-blue);
}

.modal {
  z-index: var(--z-index-modal) !important;
}

.modal-backdrop {
  z-index: var(--z-index-modal-backdrop) !important; backdrop-filter: none !important; -webkit-backdrop-filter: none !important;
}

.swal2-container {
  z-index: var(--z-index-max) !important;
}

.beatsy-card {
  background: var(--beatsy-card-bg); border: 1px solid var(--beatsy-border); border-radius: var(--beatsy-radius); padding: 28px; transition: var(--beatsy-transition);
}

.beatsy-card:hover {
  border-color: var(--beatsy-blue); box-shadow: var(--beatsy-shadow-hover); transform: translateY(-5px);
}

.beatsy-card .card-icon {
  width: 56px; height: 56px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: 16px; background: rgba(44, 88, 188, 0.1); color: var(--beatsy-blue); transition: var(--beatsy-transition);
}

.beatsy-card:hover .card-icon {
  background: var(--beatsy-blue); color: #fff;
}

.pricing-card {
  background: var(--beatsy-card-bg); border: 1px solid var(--beatsy-border); border-radius: var(--beatsy-radius); padding: 32px; position: relative; transition: var(--beatsy-transition); height: 100%;
}

.pricing-card.featured {
  background: linear-gradient(135deg, var(--beatsy-blue), var(--beatsy-blue-dark)); border-color: var(--beatsy-blue); color: #fff;
}

.pricing-card:hover {
  transform: translateY(-8px); box-shadow: var(--beatsy-shadow-hover);
}

.pricing-card .featured-badge {
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: var(--beatsy-orange); color: #fff; padding: 4px 20px; border-radius: 100px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px;
}

.pricing-card .price-amount {
  font-size: 42px; font-weight: 800; line-height: 1;
}

.pricing-card .price-period {
  font-size: 14px; opacity: 0.7; margin-left: 4px;
}

.pricing-card.featured .pricing-features li {
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

.pricing-card.featured .feature-check {
  background: rgba(255, 255, 255, 0.15); color: #fff;
}

.stat-item {
  text-align: center;
}

.stat-item .stat-number {
  font-size: 40px; font-weight: 800; color: #fff; line-height: 1;
}

.stat-item .stat-label {
  color: rgba(255, 255, 255, 0.75); font-size: 14px; margin-top: 4px;
}

.service-card {
  background: var(--beatsy-card-bg); border: 1px solid var(--beatsy-border); border-radius: var(--beatsy-radius); padding: 32px 24px; text-align: center; transition: var(--beatsy-transition); position: relative; overflow: hidden; height: 100%;
}

.service-card::before {
  content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 3px; background: linear-gradient(90deg, var(--beatsy-blue), var(--beatsy-orange)); opacity: 0; transition: var(--beatsy-transition);
}

.service-card:hover {
  transform: translateY(-8px); box-shadow: var(--beatsy-shadow-hover); border-color: var(--beatsy-blue);
}

.service-card:hover::before {
  opacity: 1;
}

.service-card .service-icon {
  width: 70px; height: 70px; border-radius: 16px; display: flex; align-items: center; justify-content: center; font-size: 28px; margin: 0 auto 20px; background: linear-gradient(135deg, rgba(0, 116, 217, 0.1), rgba(0, 116, 217, 0.05)); color: var(--beatsy-blue); transition: var(--beatsy-transition);
}

.service-card:hover .service-icon {
  background: var(--beatsy-blue); color: #fff; transform: scale(1.1);
}

.service-card.orange-accent .service-icon {
  color: var(--beatsy-orange); background: rgba(236, 88, 0, 0.1);
}

.service-card.orange-accent:hover .service-icon {
  background: var(--beatsy-orange); color: #fff;
}

.testimonial-card {
  background: var(--beatsy-card-bg); border: 1px solid var(--beatsy-border); border-radius: var(--beatsy-radius); padding: 28px; position: relative; transition: var(--beatsy-transition);
}

.testimonial-card:hover {
  box-shadow: var(--beatsy-shadow-hover);
}

.testimonial-card .quote-icon {
  font-size: 48px; color: var(--beatsy-blue); opacity: 0.15; position: absolute; top: 16px; right: 20px; line-height: 1;
}

.testimonial-card .stars {
  color: #ffc107; font-size: 14px;
}

.blog-card {
  background: var(--beatsy-card-bg); border: 1px solid var(--beatsy-border); border-radius: var(--beatsy-radius); overflow: hidden; transition: var(--beatsy-transition); height: 100%;
}

.blog-card:hover {
  transform: translateY(-6px); box-shadow: var(--beatsy-shadow-hover);
}

.blog-card .blog-img {
  width: 100%; aspect-ratio: 16/9; object-fit: cover; background: var(--beatsy-section-bg);
}

.blog-card .blog-content {
  padding: 20px;
}

.blog-card .blog-category {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--beatsy-blue); margin-bottom: 8px;
}

.blog-card .blog-title {
  font-size: 16px; font-weight: 700; line-height: 1.4; margin-bottom: 12px;
}

.blog-card .blog-title a {
  color: inherit; text-decoration: none;
}

.blog-card .blog-title a:hover {
  color: var(--beatsy-blue);
}

.newsletter-card {
  background: linear-gradient(135deg, var(--beatsy-dark), var(--beatsy-dark-2)); border: 1px solid rgba(0, 116, 217, 0.2); position: relative; overflow: hidden;
}

.newsletter-card::before {
  content: ''; position: absolute; right: -80px; top: -80px; width: 250px; height: 250px; border-radius: 50%; background: rgba(0, 116, 217, 0.08);
}

.portal-sidebar .portal-user-card {
  background: linear-gradient(135deg, var(--beatsy-blue), var(--beatsy-blue-dark)); padding: 24px; text-align: center;
}

.form-control,
.form-select {
  border-radius: 8px; padding: 10px 14px; border-color: var(--beatsy-border); font-size: 14.5px; transition: var(--beatsy-transition);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--beatsy-blue); box-shadow: 0 0 0 3px rgba(0, 116, 217, 0.12);
}

.form-label {
  font-weight: 600; font-size: 13.5px; margin-bottom: 6px;
}

.beatsy-accordion .accordion-item {
  border: 1px solid var(--beatsy-border); border-radius: var(--beatsy-radius) !important; margin-bottom: 10px; overflow: hidden;
}

.beatsy-accordion .accordion-button {
  font-weight: 600; font-size: 15px; background: var(--beatsy-card-bg); color: inherit; box-shadow: none;
}

.beatsy-accordion .accordion-button:not(.collapsed) {
  background: rgba(0, 116, 217, 0.06); color: var(--beatsy-blue);
}

.beatsy-accordion .accordion-button::after {
  filter: none;
}

.form-switch .form-check-input {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba(0, 0, 0, 0.25)'/%3e%3c/svg%3e");
}

.form-switch .form-check-input:checked {
  background-color: var(--beatsy-blue); border-color: var(--beatsy-blue);
}

.stat-label {
  font-size: 0.85rem; color: var(--beatsy-text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 0.5rem; display: block;
}

.stat-value {
  font-size: 1.5rem; font-weight: 700; color: var(--beatsy-blue); line-height: 1.2;
}

.modal-backdrop {
  z-index: var(--z-index-modal-backdrop) !important;
}

.modal {
  z-index: var(--z-index-modal) !important;
}

.swal2-container {
  z-index: var(--z-index-max) !important;
}

/* ─── Utilities ────────────────────────────── */
.py-6 {
  padding-top: 4.5rem !important; padding-bottom: 4.5rem !important;
}

.py-7 {
  padding-top: 6rem !important; padding-bottom: 6rem !important;
}

.mt-40 {
  margin-top: 40px;
}

.mt-60 {
  margin-top: 60px;
}

.mb-20 {
  margin-bottom: 20px;
}

.pt-70 {
  padding-top: 70px;
}

.pt-120 {
  padding-top: 120px;
}

.pb-120 {
  padding-bottom: 120px;
}

.rounded-beatsy {
  border-radius: var(--beatsy-radius) !important;
}

.shadow-beatsy {
  box-shadow: var(--beatsy-shadow) !important;
}

.transition {
  transition: var(--beatsy-transition);
}

/* ─── Keyframes & Animations ────────────────────────────── */
@keyframes promoGradient {

  0%,
  100% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }
}

@keyframes dropFadeIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }

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

@keyframes float {

  0%,
  100% {
    transform: translateY(0) rotate(0deg);
    opacity: 0.4;
  }

  50% {
    transform: translateY(-30px) rotate(180deg);
    opacity: 0.8;
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes letterBounce {

  0%,
  80%,
  100% {
    transform: translateY(0);
  }

  40% {
    transform: translateY(-12px);
  }
}

/* ─── Media Queries ────────────────────────────── */
@media (min-width: 1200px) {
  .beatsy-header .dropdown:hover>.dropdown-menu {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    margin-top: 0;
    pointer-events: auto;
  }
}

@media (max-width: 1199px) {
  .beatsy-main-slider .hero-slide {
    padding: 70px 0 70px;
  }
}

@media (max-width: 991px) {
  .beatsy-header .nav-link {
    font-size: 13px;
  }

  .hero-particles .hero-particle {
    display: none;
  }
}

@media (max-width: 767px) {
  .beatsy-hero {
    padding: 80px 0 50px;
  }

  .section-title {
    margin-bottom: 32px;
  }

  .pricing-card {
    padding: 24px;
  }

  .stat-item .stat-number {
    font-size: 30px;
  }
}

/* ─── Other ────────────────────────────── */
h2, .h2 {
  font-size: 1.85rem !important; font-weight: 700;
}

h3, .h3 {
  font-size: 1.5rem !important; font-weight: 700;
}

h4, .h4 {
  font-size: 1.25rem !important; font-weight: 700;
}

h5, .h5 {
  font-size: 1.1rem !important; font-weight: 700;
}

h6, .h6 {
  font-size: 0.95rem !important; font-weight: 700;
}

.sash-popular {
  position: absolute; top: 30px; right: -55px; width: 180px; background: var(--beatsy-orange); color: #fff; font-size: 11px; font-weight: 800; text-transform: uppercase; padding: 8px 0; text-align: center; transform: rotate(45deg); z-index: var(--z-index-base); box-shadow: 0 4px 10px rgba(236, 88, 0, 0.3);
}

.feature-list {
  list-style: none; padding: 0; margin: 1rem 0; flex-grow: 1;
}

.feature-list li {
  margin-bottom: 10px; font-size: 13.5px; color: var(--beatsy-text); display: flex; align-items: center; font-weight: 500;
}

.feature-list li i {
  color: #28a745; margin-right: 12px; font-size: 13px;
}

.bg-primary {
  background: var(--beatsy-blue) !important;
}

.bg-warning {
  background: var(--beatsy-orange) !important;
}

.border-primary {
  border-color: var(--beatsy-blue) !important;
}

.badge {
  display: inline-flex; align-items: center; justify-content: center; padding: 0.55em 1em; font-weight: 700; text-transform: uppercase; font-size: 10px; letter-spacing: 0.5px; color: #fff !important; border-radius: 8px; line-height: 1; vertical-align: middle;
}

.badge-sm {
  padding: 0.4em 0.8em; font-size: 9px;
}

.badge-lg {
  padding: 0.7em 1.2em; font-size: 11px;
}

.section-gap {
  margin-bottom: 5rem;
}

.bg-primary-gradient {
  background: var(--beatsy-primary-gradient) !important;
}

.bg-primary-gradient h1,
.bg-primary-gradient h2,
.bg-primary-gradient h3,
.bg-primary-gradient h4,
.bg-primary-gradient p,
.bg-primary-gradient span,
.bg-primary-gradient button {
  color: #fff !important;
}

.beatsy-promo-bar {
  background: linear-gradient(90deg, var(--beatsy-orange), #ff6b1a, var(--beatsy-orange)); background-size: 200% 100%; animation: promoGradient 4s ease infinite; z-index: var(--z-index-topbar); position: relative;
}

.logo-text-main {
  color: var(--beatsy-blue);
}

.logo-text-sub {
  color: var(--beatsy-orange); margin-left: 6px;
}

.cart-badge {
  position: absolute; top: -6px; right: -6px; background: var(--beatsy-orange); color: #fff; width: 18px; height: 18px; border-radius: 50%; font-size: 10px; display: flex; align-items: center; justify-content: center; font-weight: 700;
}

.theme-switcher-btn {
  background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.1); color: rgba(255, 255, 255, 0.8); width: 36px; height: 36px; border-radius: 8px; cursor: pointer; transition: var(--beatsy-transition); display: inline-flex; align-items: center; justify-content: center;
}

.theme-switcher-btn:hover {
  background: var(--beatsy-blue); color: #fff;
}

.dark-icon {
  display: block;
}

.light-icon {
  display: none;
}

.mobile-menu {
  top: 0; left: -320px; width: 300px; height: 100vh; z-index: var(--z-index-mobile-menu); padding: 30px 24px; overflow-y: auto; transition: left 0.35s cubic-bezier(0.4, 0, 0.2, 1); display: block !important;
}

.mobile-menu.active {
  left: 0;
}

.mobile-menu .close-menu {
  top: 16px; right: 16px; background: rgba(0, 0, 0, 0.07); border: none; width: 32px; height: 32px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center;
}

.mobile-submenu {
  display: none; padding: 4px 0 4px 16px; border-left: 2px solid var(--beatsy-blue); margin-bottom: 8px;
}

.mobile-submenu a {
  display: block; padding: 6px 8px; font-size: 14px; color: var(--beatsy-text-muted); text-decoration: none; border-radius: 6px; transition: var(--beatsy-transition);
}

.mobile-submenu a:hover {
  color: var(--beatsy-blue); background: var(--beatsy-blue-light);
}

.body-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: transparent; z-index: var(--z-index-overlay); opacity: 0; visibility: hidden; pointer-events: none; transition: visibility 0.35s ease;
}

.body-overlay.overlay-on,
.body-overlay.active {
  opacity: 1; visibility: visible; pointer-events: auto;
}

#scrollTopBtn {
  position: fixed; bottom: 100px; right: 30px; width: 44px; height: 44px; background: var(--beatsy-blue); color: #fff; border: none; border-radius: 10px; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: var(--z-index-topbar); opacity: 0; transform: translateY(20px); transition: var(--beatsy-transition); box-shadow: var(--beatsy-shadow);
}

#scrollTopBtn.show {
  opacity: 1; transform: translateY(0);
}

#scrollTopBtn:hover {
  background: var(--beatsy-blue-dark); transform: translateY(-3px); box-shadow: var(--beatsy-shadow-hover);
}

.section-title {
  margin-bottom: 48px;
}

.section-title .subtitle {
  display: inline-flex; align-items: center; gap: 8px; color: var(--beatsy-blue); font-weight: 600; font-size: 13px; text-transform: uppercase; letter-spacing: 1.5px; background: var(--beatsy-blue-light); padding: 5px 14px; border-radius: 100px; border: 1px solid rgba(44, 88, 188, 0.2); margin-bottom: 16px;
}

.section-title h2 {
  font-size: clamp(26px, 4vw, 42px); line-height: 1.25;
}

.gradient-text {
  background: linear-gradient(120deg, var(--beatsy-blue), var(--beatsy-orange)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

.alt-bg {
  background: var(--beatsy-section-bg);
}

.pricing-features {
  list-style: none; padding: 0; margin: 20px 0;
}

.pricing-features li {
  padding: 8px 0; border-bottom: 1px solid var(--beatsy-border); display: flex; align-items: center; gap: 10px; font-size: 14px;
}

.pricing-features li:last-child {
  border-bottom: none;
}

.pricing-features li .feature-check {
  width: 20px; height: 20px; border-radius: 50%; background: rgba(44, 88, 188, 0.1); color: var(--beatsy-blue); display: flex; align-items: center; justify-content: center; font-size: 11px; flex-shrink: 0;
}

.beatsy-domain-search {
  background: rgba(255, 255, 255, 0.05); backdrop-filter: blur(10px); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: var(--beatsy-radius); padding: 6px; display: flex; gap: 8px; max-width: 600px;
}

.beatsy-domain-search input {
  flex: 1; background: transparent; border: none; color: #fff; padding: 10px 16px; font-size: 15px; outline: none;
}

.beatsy-domain-search input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.beatsy-domain-search select {
  background: rgba(255, 255, 255, 0.1); border: none; color: #fff; padding: 8px 12px; border-radius: 8px; outline: none; cursor: pointer;
}

.beatsy-domain-search select option {
  background: var(--beatsy-dark);
}

.beatsy-domain-search.search-light {
  background: #f8f9fa;
  border: 1px solid rgba(0, 0, 0, 0.08);
}

.beatsy-domain-search.search-light input {
  color: #1a2f6e;
}

.beatsy-domain-search.search-light input::placeholder {
  color: rgba(26, 47, 110, 0.5);
}

.beatsy-domain-search.search-light select {
  background: rgba(0, 0, 0, 0.05);
  color: #1a2f6e;
}

.beatsy-domain-search.search-light select option {
  background: #ffffff;
  color: #1a2f6e;
}

/* Light container domain results overrides */
.search-light-container .domain-result-card h6 {
  color: #212529 !important;
}

.search-light-container .domain-result-card .text-white {
  color: #212529 !important;
}

.search-light-container .domain-result-card .text-white-50 {
  color: #6c757d !important;
}

.search-light-container .domain-result-card .btn-outline-light {
  color: #212529 !important;
  border-color: #212529 !important;
}

.search-light-container .domain-result-card .btn-outline-light:hover {
  background-color: #212529 !important;
  color: #ffffff !important;
}

.tld-chips {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px;
}

.tld-chip {
  background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.12); color: rgba(255, 255, 255, 0.75); padding: 4px 14px; border-radius: 100px; font-size: 13px; cursor: pointer; transition: var(--beatsy-transition); text-decoration: none; display: inline-flex; align-items: center; gap: 6px;
}

.tld-chip:hover,
.tld-chip.active {
  background: var(--beatsy-blue); border-color: var(--beatsy-blue); color: #fff;
}

.tld-chip .price {
  color: var(--beatsy-orange); font-weight: 600; font-size: 12px;
}

.beatsy-stats {
  background: var(--beatsy-blue); padding: 40px 0;
}

.feature-item {
  display: flex; gap: 16px; margin-bottom: 24px;
}

.feature-icon-wrap {
  width: 48px; height: 48px; border-radius: 12px; background: rgba(0, 116, 217, 0.1); color: var(--beatsy-blue); display: flex; align-items: center; justify-content: center; font-size: 20px; flex-shrink: 0; transition: var(--beatsy-transition);
}

.feature-item:hover .feature-icon-wrap {
  background: var(--beatsy-blue); color: #fff;
}

.testimonial-avatar {
  width: 46px; height: 46px; border-radius: 50%; object-fit: cover; border: 2px solid var(--beatsy-blue);
}

.blog-meta {
  font-size: 12.5px; color: var(--beatsy-text-muted);
}

.beatsy-newsletter {
  background: var(--beatsy-section-bg);
}

.beatsy-footer {
  background: var(--beatsy-dark); color: rgba(255, 255, 255, 0.75); background-attachment: fixed; background-size: cover; background-position: center;
}

.footer-brand .footer-desc {
  font-size: 14px; color: rgba(255, 255, 255, 0.55); line-height: 1.7; max-width: 340px;
}

.footer-contact-item {
  display: flex; align-items: flex-start; gap: 10px; padding: 6px 0; font-size: 13.5px; color: rgba(255, 255, 255, 0.65); text-decoration: none; transition: var(--beatsy-transition);
}

.footer-contact-item:hover {
  color: rgba(255, 255, 255, 0.9);
}

.footer-widget-title {
  font-size: 14px; font-weight: 700; color: #fff; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 18px; position: relative; padding-bottom: 10px;
}

.footer-widget-title::after {
  content: ''; position: absolute; left: 0; bottom: 0; width: 30px; height: 2px; background: var(--beatsy-blue);
}

.footer-socials .footer-social-icon {
  width: 36px; height: 36px; border-radius: 8px; border: 1px solid rgba(255, 255, 255, 0.1); display: flex; align-items: center; justify-content: center; color: rgba(255, 255, 255, 0.65); text-decoration: none; font-size: 14px; transition: var(--beatsy-transition);
}

.footer-social-icon:hover {
  background: var(--beatsy-blue); border-color: var(--beatsy-blue); color: #fff; transform: translateY(-3px);
}

.footer-whatsapp:hover {
  background: #25d366 !important; border-color: #25d366 !important;
}

.payment-badge {
  background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.1); color: rgba(255, 255, 255, 0.65); padding: 4px 10px; border-radius: 6px; font-size: 12.5px; display: inline-flex; align-items: center; gap: 5px;
}

.mpesa-badge {
  font-weight: 700;
}

.trust-badge {
  display: flex; align-items: center; gap: 6px; font-size: 12.5px; color: rgba(255, 255, 255, 0.6);
}

.footer-copyright {
  background: rgba(0, 0, 0, 0.2); padding: 16px 0;
}

.footer-legal-links a {
  color: rgba(255, 255, 255, 0.5); text-decoration: none; font-size: 12.5px; transition: var(--beatsy-transition);
}

.footer-legal-links a:hover {
  color: rgba(255, 255, 255, 0.85);
}

.breadcrumb-item a {
  color: rgba(255, 255, 255, 0.65); text-decoration: none;
}

.breadcrumb-item a:hover {
  color: #fff;
}

.breadcrumb-item.active {
  color: var(--beatsy-blue);
}

.breadcrumb-item+.breadcrumb-item::before {
  color: rgba(255, 255, 255, 0.3);
}

.highlight-box {
  background: linear-gradient(135deg, rgba(0, 116, 217, 0.08), rgba(236, 88, 0, 0.04)); border: 1px solid rgba(0, 116, 217, 0.15); border-radius: var(--beatsy-radius); padding: 24px; position: relative;
}

.highlight-box::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: linear-gradient(to bottom, var(--beatsy-blue), var(--beatsy-orange)); border-radius: 4px 0 0 4px;
}

.portal-sidebar {
  background: var(--beatsy-card-bg); border: 1px solid var(--beatsy-border); border-radius: var(--beatsy-radius); padding: 0; overflow: hidden;
}

.alert {
  border-radius: var(--beatsy-radius); border: none; font-size: 14px;
}

.alert-success {
  background: rgba(40, 167, 69, 0.1); color: #28a745; border-left: 4px solid #28a745;
}

.alert-danger {
  background: rgba(220, 53, 69, 0.1); color: #dc3545; border-left: 4px solid #dc3545;
}

.alert-warning {
  background: rgba(255, 193, 7, 0.1); color: #e6a800; border-left: 4px solid #ffc107;
}

.alert-info {
  background: rgba(0, 116, 217, 0.1); color: var(--beatsy-blue); border-left: 4px solid var(--beatsy-blue);
}

.badge-sm {
  font-size: 10px; padding: 3px 7px;
}

.swiper-pagination-bullet-active {
  background: var(--beatsy-blue) !important;
}

.swiper-button-next,
.swiper-button-prev {
  color: var(--beatsy-blue) !important; background: rgba(255, 255, 255, 0.1); width: 44px; height: 44px; border-radius: 50%; backdrop-filter: blur(10px);
}

.swiper-button-next::after,
.swiper-button-prev::after {
  font-size: 18px !important;
}

.loader-wrap {
  position: fixed; inset: 0; z-index: var(--z-index-modal);
}

.preloader {
  position: absolute; inset: 0; background: var(--beatsy-dark); display: flex; align-items: center; justify-content: center;
}

.handle-preloader {
  text-align: center;
}

.spinner {
  width: 60px; height: 60px; border: 3px solid rgba(0, 116, 217, 0.2); border-top: 3px solid var(--beatsy-blue); border-radius: 50%; animation: spin 0.8s linear infinite; margin: 0 auto 20px;
}

.txt-loading {
  display: flex; gap: 4px; justify-content: center;
}

.letters-loading {
  color: #fff; font-size: 20px; font-weight: 800; font-family: var(--font-heading); animation: letterBounce 1.2s ease infinite;
}

.letters-loading:nth-child(1) {
  animation-delay: 0.0s; color: var(--beatsy-blue);
}

.letters-loading:nth-child(2) {
  animation-delay: 0.1s;
}

.letters-loading:nth-child(3) {
  animation-delay: 0.2s;
}

.letters-loading:nth-child(4) {
  animation-delay: 0.3s;
}

.letters-loading:nth-child(5) {
  animation-delay: 0.4s; color: var(--beatsy-orange);
}

.letters-loading:nth-child(6) {
  animation-delay: 0.5s;
}

.beatsy-cta {
  background: linear-gradient(135deg, var(--beatsy-blue), var(--beatsy-blue-dark)); padding: 70px 0; position: relative; overflow: hidden;
}

.beatsy-cta::before {
  content: ''; position: absolute; right: -100px; bottom: -100px; width: 400px; height: 400px; border-radius: 50%; background: rgba(236, 88, 0, 0.1);
}

.beatsy-cta-orange {
  background: linear-gradient(135deg, var(--beatsy-orange), var(--beatsy-orange-dark));
}

.domain-result-item {
  display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-radius: 8px; background: var(--beatsy-card-bg); border: 1px solid var(--beatsy-border); margin-bottom: 8px;
}

.domain-result-item.available {
  border-color: #28a745;
}

.domain-result-item.taken {
  border-color: #dc3545; opacity: 0.75;
}

.beatsy-ai-search-wrap {
  width: 100%; max-width: 850px; margin: -60px auto 0; position: relative; z-index: var(--z-index-base); padding: 0 20px;
}

.beatsy-ai-search-box {
  background: #fff; border: 1px solid rgba(0, 0, 0, 0.05); border-radius: 20px; padding: 28px 40px; box-shadow: 0 25px 60px rgba(44, 88, 188, 0.15);
}

.ai-search-input-group {
  display: flex; align-items: center; background: #f1f4f9; padding: 6px; border-radius: 50px; border: 1px solid rgba(0,0,0,0.05); transition: var(--beatsy-transition);
}

.ai-search-input-group:focus-within {
  background: #fff; box-shadow: 0 10px 25px rgba(44, 88, 188, 0.1); border-color: var(--beatsy-blue);
}

.ai-search-input-group input {
  flex: 1; background: transparent; border: none; padding: 10px 20px; font-size: 15px; outline: none !important; color: var(--beatsy-text);
}

.ai-search-btn {
  background: var(--beatsy-blue); color: #fff; border: none; padding: 12px 30px; border-radius: 50px; font-weight: 700;
}

