/* ==========================================================================
   Paralela Cloud - Custom Theme
   Based on Twenty-One | Cloud/VPS focused design
   Colors: #0948b3 (primary dark), #2E75F3 (primary), #1a1f36 (dark bg)
   ========================================================================== */

/* ---------- CSS Variables ---------- */
:root {
  --pc-primary: #2E75F3;
  --pc-primary-dark: #0948b3;
  --pc-primary-darker: #072d6e;
  --pc-accent: #00d4aa;
  --pc-accent-hover: #00b894;
  --pc-dark: #1a1f36;
  --pc-dark-light: #252b48;
  --pc-gray-50: #f8fafc;
  --pc-gray-100: #f1f5f9;
  --pc-gray-200: #e2e8f0;
  --pc-gray-300: #cbd5e1;
  --pc-gray-500: #64748b;
  --pc-gray-700: #334155;
  --pc-gray-900: #0f172a;
  --pc-radius: 12px;
  --pc-radius-sm: 8px;
  --pc-radius-lg: 16px;
  --pc-shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --pc-shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.05);
  --pc-shadow-lg: 0 10px 25px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04);
  --pc-shadow-xl: 0 20px 40px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.06);
  --pc-transition: all .2s cubic-bezier(.4,0,.2,1);
}

/* Fix: prepend-icon overlapping select text globally */
.prepend-icon select.form-control,
.prepend-icon select.field,
.form-group.prepend-icon select {
  padding-left: 42px !important;
}
/* Hide icon when intl-tel-input flag replaces it */
.form-group.prepend-icon:has(.iti) > .field-icon {
  display: none !important;
}

/* ---------- Inter Font Import ---------- */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");

/* ---------- Base Overrides ---------- */
body {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  background: var(--pc-gray-50) !important;
  color: var(--pc-gray-900);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Override the primary-bg-color on body - only header should be dark */
body.primary-bg-color {
  background-color: var(--pc-gray-50) !important;
}

/* Primary bg used on header elements - keep those dark */
.header .primary-bg-color {
  background-color: var(--pc-primary-dark) !important;
}
#order-standard_cart .empty-cart {
    margin: -10px 0px 0 0 !important;
}

/* Sub-heading section dividers - transparent bg with dark text */
/* Using body-level specificity to override theme.min.css */
body .sub-heading span.primary-bg-color,
body .sub-heading-borderless span.primary-bg-color,
body #order-standard_cart .sub-heading span.primary-bg-color,
body #order-standard_cart .sub-heading-borderless span.primary-bg-color,
body span.primary-bg-color[class] {
  background-color: #f8fafc !important;
  background: #f8fafc !important;
  color: #0948b3 !important;
}

a { color: var(--pc-primary); }
a:hover { color: var(--pc-primary-dark); text-decoration: none; }

/* ---------- Header ---------- */
#header.header {
  background: linear-gradient(135deg, var(--pc-dark) 0%, var(--pc-primary-darker) 100%) !important;
  border-bottom: none;
  box-shadow: 0 4px 20px rgba(9,72,179,.15);
}

#header .navbar {
  padding: .75rem 0;
}

#header .logo-container img,
#header .navbar-brand img {
  max-height: 42px;
  filter: brightness(0) invert(1);
}

#header .navbar-nav .nav-link {
  color: rgba(255,255,255,.85) !important;
  font-weight: 500;
  font-size: .9rem;
  padding: .5rem 1rem !important;
  border-radius: var(--pc-radius-sm);
  transition: var(--pc-transition);
  letter-spacing: .01em;
}

#header .navbar-nav .nav-link:hover,
#header .navbar-nav .nav-link.active {
  color: #fff !important;
  background: rgba(255,255,255,.1);
}

/* All navbar TOP-LEVEL links (excluding dropdown items) */
#header #nav > li > a,
#header #nav > li > .dropdown-toggle,
#header .navbar-nav.ml-auto > li > a,
#header .navbar-nav.ml-auto > li > .dropdown-toggle,
#header .main-navbar-wrapper > .container > .navbar-collapse > ul > li > a {
  color: rgba(255,255,255,.85) !important;
  font-weight: 500;
  font-size: .9rem;
  transition: var(--pc-transition);
}

#header #nav > li > a:hover,
#header .navbar-nav.ml-auto > li > a:hover {
  color: #fff !important;
}

/* Dropdown items inside navbar must be dark on white */
#header .dropdown-menu a,
#header .dropdown-menu .dropdown-item,
#header .dropdown-menu li a {
  color: var(--pc-gray-700) !important;
  font-weight: 400;
}

#header .dropdown-menu a:hover,
#header .dropdown-menu .dropdown-item:hover,
#header .dropdown-menu li a:hover {
  color: var(--pc-primary) !important;
  background: var(--pc-gray-100) !important;
}

/* Search bar in header - remove white border */
#header .search .form-control,
#header .search .btn,
#header .input-group.search .form-control {
  border: none !important;
  background: rgba(255,255,255,.12) !important;
  color: #fff !important;
  box-shadow: none !important;
}

#header .search .form-control::placeholder {
  color: rgba(255,255,255,.5) !important;
}

#header .search .form-control:focus {
  background: rgba(255,255,255,.18) !important;
  box-shadow: none !important;
}

#header .search .btn {
  color: rgba(255,255,255,.6) !important;
}

#header .search .input-group-prepend .btn {
  border: none !important;
  background: rgba(255,255,255,.12) !important;
  color: rgba(255,255,255,.6) !important;
}

/* Cart button in header - remove white border */
#header .cart-btn,
#header .navbar-nav.toolbar .nav-link {
  color: rgba(255,255,255,.85) !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

#header .cart-btn:hover,
#header .navbar-nav.toolbar .nav-link:hover {
  color: #fff !important;
  background: rgba(255,255,255,.1) !important;
  border-radius: var(--pc-radius-sm);
}

/* Hamburger menu button */
#header .navbar-nav.toolbar button.btn {
  color: rgba(255,255,255,.85) !important;
  border: none !important;
  background: transparent !important;
}

.topbar {
  background: rgba(0,0,0,.15) !important;
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: .35rem 0;
}

.topbar .btn,
.topbar .input-group-text,
.topbar a {
  color: rgba(255,255,255,.7) !important;
  font-size: .82rem;
}

.topbar .btn:hover { color: #fff !important; }

/* ---------- Primary BG Override ---------- */
/* Only apply dark blue bg to header and sidebar headers, NOT sub-heading spans */
#header .primary-bg-color,
.card-sidebar .card-header.primary-bg-color,
.panel-sidebar .panel-heading.primary-bg-color,
.cart-sidebar .panel-heading.primary-bg-color,
.cart-sidebar .card-header.primary-bg-color {
  background-color: var(--pc-primary-dark) !important;
}

/* ---------- Buttons ---------- */
.btn-primary {
  background: linear-gradient(135deg, var(--pc-primary) 0%, var(--pc-primary-dark) 100%) !important;
  border: none !important;
  border-radius: var(--pc-radius-sm) !important;
  font-weight: 600;
  padding: .55rem 1.5rem;
  transition: var(--pc-transition);
  box-shadow: 0 2px 8px rgba(46,117,243,.25);
  letter-spacing: .01em;
}

.btn-primary:hover,
.btn-primary:focus {
  background: linear-gradient(135deg, var(--pc-primary-dark) 0%, var(--pc-primary-darker) 100%) !important;
  box-shadow: 0 4px 15px rgba(46,117,243,.35);
  transform: translateY(-1px);
}

.btn-success {
  background: linear-gradient(135deg, var(--pc-accent) 0%, var(--pc-accent-hover) 100%) !important;
  border: none !important;
  border-radius: var(--pc-radius-sm) !important;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(0,212,170,.25);
  color: #fff !important;
}

.btn-success:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 15px rgba(0,212,170,.35);
}

.btn { border-radius: var(--pc-radius-sm) !important; }

/* ---------- Cards & Panels ---------- */
.panel, .card {
  border: 1px solid var(--pc-gray-200) !important;
  border-radius: var(--pc-radius) !important;
  box-shadow: var(--pc-shadow);
  transition: var(--pc-transition);
  overflow: hidden;
}

.panel:hover, .card:hover {
  box-shadow: var(--pc-shadow-md);
}

.panel-heading, .card-header {
  background: #fff !important;
  border-bottom: 1px solid var(--pc-gray-200) !important;
  font-weight: 600;
  padding: 1rem 1.25rem;
}

.panel-body, .card-body { padding: 1.25rem; }

.panel-default > .panel-heading,
.card-sidebar .card-header {
  background: linear-gradient(135deg, var(--pc-dark) 0%, var(--pc-primary-darker) 100%) !important;
  color: #fff !important;
  border: none !important;
}

.card-sidebar .card-header .panel-title,
.panel-sidebar .panel-heading .panel-title {
  color: #fff !important;
}

/* ---------- Sidebar ---------- */
.sidebar .list-group-item {
  border: none !important;
  padding: .6rem 1.25rem;
  font-size: .9rem;
  color: var(--pc-gray-700);
  transition: var(--pc-transition);
}

.sidebar .list-group-item:hover {
  background: var(--pc-gray-100);
  color: var(--pc-primary);
  padding-left: 1.5rem;
}

.sidebar .list-group-item.active {
  background: rgba(46,117,243,.08) !important;
  color: var(--pc-primary) !important;
  font-weight: 600;
  border-left: 3px solid var(--pc-primary) !important;
}

/* ---------- Tables ---------- */
.table { border-radius: var(--pc-radius); overflow: hidden; }

.table thead th {
  background: var(--pc-dark) !important;
  color: #fff !important;
  font-weight: 600;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: .85rem 1rem;
  border: none !important;
}

.table tbody tr { transition: var(--pc-transition); }
.table tbody tr:hover { background: rgba(46,117,243,.03); }

.table td {
  padding: .85rem 1rem;
  vertical-align: middle;
  border-color: var(--pc-gray-100) !important;
}

/* ---------- Forms ---------- */
.form-control {
  border: 1.5px solid var(--pc-gray-200) !important;
  border-radius: 6px !important;
  padding: .6rem .9rem;
  font-size: .9rem;
  transition: var(--pc-transition);
  background: #fff;
}

.form-control:focus {
  border-color: var(--pc-primary) !important;
  box-shadow: 0 0 0 3px rgba(46,117,243,.12) !important;
}

/* ---------- Input Groups (login, search etc) ---------- */
.input-group .input-group-prepend .input-group-text,
.input-group .input-group-append .input-group-text,
.input-group .input-group-prepend .btn {
  border-radius: 6px 0 0 6px !important;
  border: 1.5px solid var(--pc-gray-200) !important;
  border-right: none !important;
  background: var(--pc-gray-50) !important;
  color: var(--pc-gray-500);
}

.input-group .form-control {
  border-radius: 0 6px 6px 0 !important;
}

.input-group .input-group-append .input-group-text,
.input-group .input-group-append .btn {
  border-radius: 0 6px 6px 0 !important;
  border: 1.5px solid var(--pc-gray-200) !important;
  border-left: none !important;
}

/* Login page specific input group fix */
.login-container .input-group,
section#main-body .input-group {
  border-radius: 6px;
}

.login-container .input-group .input-group-prepend,
.login-container .input-group .input-group-prepend > * {
  border-radius: 6px 0 0 6px !important;
}

.login-container .input-group .form-control {
  border-radius: 0 6px 6px 0 !important;
  border-left: none !important;
}

/* ---------- Content Area ---------- */
.main-content { min-height: 70vh; }

#main-body {
  padding: 2rem 0;
  background: var(--pc-gray-50);
}

/* Also ensure the section has light bg */
section#main-body {
  background: var(--pc-gray-50) !important;
}

.header-lined h1 {
  color: var(--pc-dark);
  font-weight: 700;
  font-size: 1.75rem;
  position: relative;
  padding-bottom: .75rem;
}

.header-lined h1::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 50px;
  height: 3px;
  background: linear-gradient(90deg, var(--pc-primary), var(--pc-accent));
  border-radius: 2px;
}

/* ---------- Alerts ---------- */
.alert {
  border-radius: var(--pc-radius-sm) !important;
  border: none !important;
  font-size: .9rem;
}

.alert-info {
  background: rgba(46,117,243,.08) !important;
  color: var(--pc-primary-dark) !important;
}

.alert-success {
  background: rgba(0,212,170,.08) !important;
  color: #047857 !important;
}

/* ---------- Badges ---------- */
.badge {
  border-radius: 20px;
  padding: .35em .75em;
  font-weight: 600;
  font-size: .75rem;
}

.badge-primary, .badge-info { background: var(--pc-primary) !important; }
.badge-success { background: var(--pc-accent) !important; }

/* ---------- Status Indicators ---------- */
.label-active, .badge-active,
.label-success { background: var(--pc-accent) !important; }
.label-danger, .badge-danger { background: #ef4444 !important; }

/* ---------- Footer ---------- */
#footer.footer {
  background: var(--pc-dark) !important;
  color: rgba(255,255,255,.6);
  padding: 2.5rem 0;
  margin-top: 3rem;
}

#footer a { color: rgba(255,255,255,.7) !important; }
#footer a:hover { color: var(--pc-accent) !important; }
#footer .copyright { color: rgba(255,255,255,.4); font-size: .82rem; }

/* ---------- Login Page ---------- */
.auth-wrap {
  background: linear-gradient(135deg, var(--pc-dark) 0%, var(--pc-primary-darker) 50%, var(--pc-dark) 100%) !important;
}

.auth-wrap .login-container,
.auth-wrap .main-content .card {
  border-radius: var(--pc-radius-lg) !important;
  box-shadow: var(--pc-shadow-xl) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
}

/* ---------- Breadcrumb ---------- */
.master-breadcrumb {
  background: var(--pc-dark) !important;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.breadcrumb {
  background: transparent !important;
  padding: .5rem 0;
  font-size: .85rem;
  margin-bottom: 0;
}

.breadcrumb-item,
.breadcrumb-item a,
.breadcrumb-item.active {
  color: #fff !important;
}

.breadcrumb-item a:hover {
  color: var(--pc-accent) !important;
}

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

/* ---------- Pagination ---------- */
.page-item.active .page-link {
  background: var(--pc-primary) !important;
  border-color: var(--pc-primary) !important;
}

.page-link {
  color: var(--pc-primary);
  border-radius: var(--pc-radius-sm) !important;
  margin: 0 2px;
}

/* ---------- Dropdowns ---------- */
.dropdown-menu {
  border: 1px solid var(--pc-gray-200);
  border-radius: var(--pc-radius-sm) !important;
  box-shadow: var(--pc-shadow-lg);
  padding: .5rem;
  background: #fff !important;
}

/* Dropdown items must be dark text on white bg */
.dropdown-menu .dropdown-item,
.dropdown-menu .dropdown-item a,
.dropdown-menu a.dropdown-item,
.dropdown-menu li a {
  color: var(--pc-gray-700) !important;
  border-radius: 6px;
  padding: .5rem .75rem;
  font-size: .9rem;
  background: transparent !important;
}

.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item a:hover,
.dropdown-menu a.dropdown-item:hover,
.dropdown-menu li a:hover {
  background: var(--pc-gray-100) !important;
  color: var(--pc-primary) !important;
}

.dropdown-menu .dropdown-divider {
  border-color: var(--pc-gray-100);
}

/* ---------- Modal ---------- */
.modal-content {
  border-radius: var(--pc-radius-lg) !important;
  border: none !important;
  box-shadow: var(--pc-shadow-xl);
}

.modal-header {
  border-bottom: 1px solid var(--pc-gray-100);
  padding: 1.25rem 1.5rem;
}

.modal-body { padding: 1.5rem; }

/* ---------- Homepage Panels ---------- */
.home-shortcuts .shortcut-item,
.home-shortcuts a {
  border-radius: var(--pc-radius) !important;
  transition: var(--pc-transition);
}

.home-shortcuts a:hover {
  transform: translateY(-3px);
  box-shadow: var(--pc-shadow-lg);
}

/* ---------- Progress ---------- */
.progress {
  border-radius: 20px;
  height: .6rem;
  background: var(--pc-gray-100);
}

.progress-bar {
  background: linear-gradient(90deg, var(--pc-primary), var(--pc-accent));
  border-radius: 20px;
}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--pc-gray-100); }
::-webkit-scrollbar-thumb { background: var(--pc-gray-300); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--pc-gray-500); }

/* ---------- Animations ---------- */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(15px); }
  to { opacity: 1; transform: translateY(0); }
}

.main-content .container { animation: fadeInUp .35s ease-out; }

/* ---------- Custom Select ---------- */
.custom-select,
select.form-control {
  border-radius: 6px !important;
  color: var(--pc-gray-900) !important;
  font-weight: 500;
  background-color: #fff !important;
  height: auto !important;
  min-height: 38px;
  padding: .5rem 2rem .5rem .75rem !important;
  line-height: 1.5 !important;
}

/* ---------- Nav Tabs ---------- */
.nav-tabs .nav-link {
  border-radius: var(--pc-radius-sm) var(--pc-radius-sm) 0 0 !important;
  font-weight: 500;
}

.nav-tabs .nav-link.active {
  color: var(--pc-primary);
  border-color: var(--pc-gray-200) var(--pc-gray-200) #fff;
}

/* ---------- Service Details ---------- */
.client-area-service-details .panel-sidebar {
  border-radius: var(--pc-radius) !important;
}

/* ---------- Ticket styling ---------- */
.ticket-reply {
  border-radius: var(--pc-radius) !important;
  margin-bottom: 1rem;
}

/* ---------- Invoice ---------- */
.invoice-container {
  border-radius: var(--pc-radius) !important;
  box-shadow: var(--pc-shadow-md);
}

/* ---------- Checkout Progress & UX ---------- */
.checkout-progress-summary {
  background: linear-gradient(135deg, var(--pc-primary) 0%, var(--pc-primary-dark) 100%);
  color: #fff;
  border-radius: var(--pc-radius-sm);
  padding: .85rem 1.25rem;
  margin-bottom: 1.5rem;
  font-size: .88rem;
}

.checkout-progress-summary .progress-info {
  display: flex;
  align-items: center;
  gap: .5rem;
}

.checkout-progress-summary .progress-info i {
  font-size: 1.1rem;
  opacity: .8;
}

/* Icons in sub-heading spans */
.sub-heading span i.fas,
.sub-heading span i.far {
  margin-right: .3rem;
  opacity: .7;
}

/* ---------- Checkout - Newsletter optin spacing ---------- */
.marketing-email-optin {
  margin-bottom: 2rem !important;
  padding: 1.25rem !important;
  background: var(--pc-gray-50) !important;
  border: 1px solid var(--pc-gray-200) !important;
  border-radius: 8px !important;
}


/* ==========================================================================
   MULTI-STEP REGISTRATION FORM
   ========================================================================== */

/* --- Stepper Progress Bar --- */
.reg-stepper {
  max-width: 600px;
  margin: 0 auto 2.5rem;
  position: relative;
  padding: 0 1rem;
}

.reg-stepper-track {
  position: absolute;
  top: 20px;
  left: 80px;
  right: 80px;
  height: 3px;
  background: var(--pc-gray-200);
  border-radius: 2px;
  z-index: 0;
}

.reg-stepper-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--pc-primary), var(--pc-accent));
  border-radius: 2px;
  width: 0%;
  transition: width 0.4s cubic-bezier(.4,0,.2,1);
}

.reg-stepper-steps {
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

.reg-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  outline: none;
  transition: var(--pc-transition);
}

.reg-step-num {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--pc-gray-200);
  color: var(--pc-gray-500);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: .95rem;
  transition: var(--pc-transition);
  border: 3px solid #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
}

.reg-step.active .reg-step-num {
  background: linear-gradient(135deg, var(--pc-primary), var(--pc-primary-dark));
  color: #fff;
  box-shadow: 0 4px 15px rgba(46,117,243,.35);
  transform: scale(1.1);
}

.reg-step.completed .reg-step-num {
  background: var(--pc-accent);
  color: #fff;
  box-shadow: 0 4px 12px rgba(0,212,170,.3);
}

.reg-step.completed .reg-step-num::after {
  content: "\f00c";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: .8rem;
}

.reg-step.completed .reg-step-num {
  font-size: 0;
}

.reg-step-label {
  font-size: .78rem;
  font-weight: 600;
  color: var(--pc-gray-500);
  text-transform: uppercase;
  letter-spacing: .03em;
  transition: var(--pc-transition);
  white-space: nowrap;
}

.reg-step.active .reg-step-label {
  color: var(--pc-primary);
}

.reg-step.completed .reg-step-label {
  color: var(--pc-accent-hover);
}

/* --- Panel Animations --- */
@keyframes regSlideIn {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes regShake {
  0%, 100% { transform: translateX(0); }
  20%      { transform: translateX(-8px); }
  40%      { transform: translateX(8px); }
  60%      { transform: translateX(-5px); }
  80%      { transform: translateX(5px); }
}

.reg-panel {
  animation: regSlideIn 0.35s ease-out;
}

/* --- Navigation Buttons --- */
.reg-next-btn {
  min-width: 180px;
  padding: .75rem 2rem !important;
  font-size: 1rem !important;
}

/* --- Trust Signals --- */
.reg-trust-signals {
  margin: 1.5rem 0;
  padding: 1rem;
}

.reg-trust-item {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: var(--pc-gray-500);
  font-size: .82rem;
  font-weight: 500;
  padding: .4rem 1rem;
}

.reg-trust-item i {
  color: var(--pc-accent);
  font-size: .9rem;
}

/* --- CEP Field States (also for registration) --- */
.cep-loading {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 50 50'%3E%3Cpath fill='%232E75F3' d='M25 5A20 20 0 1 0 45 25' stroke='%232E75F3' stroke-width='4' fill='none'%3E%3CanimateTransform attributeName='transform' type='rotate' from='0 25 25' to='360 25 25' dur='0.8s' repeatCount='indefinite'/%3E%3C/path%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  background-size: 18px !important;
}

.cep-success {
  border-color: var(--pc-accent) !important;
  box-shadow: 0 0 0 3px rgba(0,212,170,.12) !important;
}

.cep-error {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.12) !important;
}

/* --- Invalid field highlight --- */
.is-invalid,
input.is-invalid.field,
input.is-invalid.form-control {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.1) !important;
}

/* --- Responsive Stepper --- */
@media (max-width: 576px) {
  .reg-stepper-track {
    left: 50px;
    right: 50px;
  }
  .reg-step-label {
    font-size: .65rem;
  }
  .reg-step-num {
    width: 34px;
    height: 34px;
    font-size: .85rem;
  }
  .reg-trust-item {
    font-size: .75rem;
    padding: .3rem .5rem;
  }
}

/* ==========================================================================
   CHECKOUT UX IMPROVEMENTS
   ========================================================================== */

/* Better "Already Registered" button prominence */
#order-standard_cart .already-registered {
  background: linear-gradient(135deg, rgba(46,117,243,.04), rgba(0,212,170,.04));
  border: 1px solid var(--pc-gray-200);
  border-radius: var(--pc-radius-sm);
  padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
}

#order-standard_cart .already-registered #btnAlreadyRegistered {
  background: linear-gradient(135deg, var(--pc-primary) 0%, var(--pc-primary-dark) 100%) !important;
  color: #fff !important;
  border: none !important;
  font-weight: 600;
  padding: .5rem 1.5rem;
  border-radius: var(--pc-radius-sm) !important;
  box-shadow: 0 2px 8px rgba(46,117,243,.25);
}

/* Checkout security message */
.checkout-security-msg {
  background: rgba(0,212,170,.06) !important;
  border: 1px solid rgba(0,212,170,.2) !important;
  color: #047857 !important;
  border-radius: var(--pc-radius-sm) !important;
  padding: 1rem 1.25rem;
  margin-top: 1.5rem;
  text-align: center;
  font-size: .88rem;
}

.checkout-security-msg i {
  color: var(--pc-accent);
  margin-right: .4rem;
}

/* Complete Order button enhancement */
#btnCompleteOrder {
  min-width: 280px;
  padding: 1rem 2rem !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  letter-spacing: .02em;
  background: linear-gradient(135deg, var(--pc-accent) 0%, var(--pc-accent-hover) 100%) !important;
  box-shadow: 0 4px 20px rgba(0,212,170,.3) !important;
  border-radius: var(--pc-radius) !important;
  margin-top: 1rem;
}

#btnCompleteOrder:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(0,212,170,.4) !important;
}

/* ==========================================================================
   HOMEPAGE IMPROVEMENTS
   ========================================================================== */

/* Domain search hero - more prominent */
.home-domain-search {
  background: linear-gradient(135deg, var(--pc-dark) 0%, var(--pc-primary-darker) 100%) !important;
  border-radius: 0 !important;
  box-shadow: inset 0 -4px 20px rgba(0,0,0,.1);
}

.home-domain-search h2 {
  color: #fff !important;
  font-weight: 700;
  font-size: 1.6rem;
  margin-bottom: 1.25rem;
}

.home-domain-search .form-control {
  border-radius: var(--pc-radius-sm) 0 0 var(--pc-radius-sm) !important;
  border: 2px solid rgba(255,255,255,.15) !important;
  background: rgba(255,255,255,.1) !important;
  color: #fff !important;
  font-size: 1.05rem;
  padding: .85rem 1.25rem;
  height: auto;
}

.home-domain-search .form-control::placeholder {
  color: rgba(255,255,255,.5) !important;
}

.home-domain-search .form-control:focus {
  background: rgba(255,255,255,.15) !important;
  border-color: var(--pc-accent) !important;
  box-shadow: 0 0 0 3px rgba(0,212,170,.2) !important;
}

.home-domain-search .btn-primary {
  border-radius: 0 !important;
  padding: .85rem 1.5rem !important;
  font-weight: 700;
  font-size: .95rem;
}

.home-domain-search .btn-success {
  border-radius: 0 var(--pc-radius-sm) var(--pc-radius-sm) 0 !important;
  padding: .85rem 1.5rem !important;
  font-weight: 700;
  font-size: .95rem;
}

.home-domain-search .tld-logos {
  margin-top: 1.25rem;
}

.home-domain-search .tld-logos li {
  color: rgba(255,255,255,.7) !important;
  font-size: .85rem;
}

.home-domain-search .tld-logos li img {
  filter: brightness(0) invert(1);
  opacity: .7;
}

.home-domain-search .btn-link {
  color: rgba(255,255,255,.6) !important;
}

.home-domain-search .btn-link:hover {
  color: var(--pc-accent) !important;
}

/* Homepage action icons - better visual hierarchy */
.action-icon-btns a {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1.5rem 1rem;
  border-radius: var(--pc-radius) !important;
  background: #fff;
  border: 1px solid var(--pc-gray-200);
  box-shadow: var(--pc-shadow);
  transition: var(--pc-transition);
  color: var(--pc-gray-700);
  font-weight: 600;
  font-size: .88rem;
  text-decoration: none !important;
  margin-bottom: .75rem;
}

.action-icon-btns a:hover {
  transform: translateY(-3px);
  box-shadow: var(--pc-shadow-lg);
  border-color: var(--pc-primary);
  color: var(--pc-primary);
}

.action-icon-btns .ico-container {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(46,117,243,.08), rgba(0,212,170,.08));
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .75rem;
}

.action-icon-btns .ico-container i {
  font-size: 1.4rem;
  color: var(--pc-primary);
}

/* Homepage product cards */
.home .card {
  transition: var(--pc-transition);
}

.home .card:hover {
  transform: translateY(-4px);
  box-shadow: var(--pc-shadow-lg);
  border-color: var(--pc-primary) !important;
}

.home .card .btn-outline-primary {
  border: 2px solid var(--pc-primary) !important;
  font-weight: 600;
  transition: var(--pc-transition);
}

.home .card:hover .btn-outline-primary {
  background: var(--pc-primary) !important;
  color: #fff !important;
}


/* Fix: Order Summary sidebar header - force dark gradient */
#orderSummary > .panel-heading,
#orderSummary > .card-header,
#order-standard_cart #orderSummary > .panel-heading,
#order-standard_cart #orderSummary > .card-header,
div#orderSummary .panel-heading,
div#orderSummary .card-header {
  background: linear-gradient(135deg, var(--pc-dark) 0%, var(--pc-primary-darker) 100%) !important;
  color: #fff !important;
  border: none !important;
}

#orderSummary > .panel-heading .panel-title,
#orderSummary > .card-header .panel-title,
#orderSummary > .panel-heading h3,
#orderSummary > .card-header h3,
div#orderSummary .panel-heading .panel-title,
div#orderSummary .card-header h3 {
  color: #fff !important;
}


/* Fix: sub-heading span bg must match page background */
body .sub-heading span.primary-bg-color,
body .sub-heading-borderless span.primary-bg-color,
body #order-standard_cart .sub-heading span.primary-bg-color,
body #order-standard_cart .sub-heading-borderless span.primary-bg-color,
body span.primary-bg-color[class],
section#main-body .sub-heading span,
section#main-body .sub-heading span.primary-bg-color {
  background-color: var(--pc-gray-50, #f8fafc) !important;
  background: var(--pc-gray-50, #f8fafc) !important;
  color: var(--pc-primary-dark, #0948b3) !important;
}
