/* KUNAC Systems Corporate Theme */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");
:root {
  --ks-bg: #f5f7fb;
  --ks-surface: #ffffff;
  --ks-surface-strong: #0f243b;
  --ks-text: #172032;
  --ks-text-muted: #5f718d;
  --ks-primary: #0a66d6;
  --ks-primary-dark: #0849a1;
  --ks-secondary: #1c2843;
  --ks-accent: #00b1ff;
  --ks-border: #dae2ef;
  --ks-shadow: 0 24px 60px rgba(15, 36, 59, 0.12);
  --ks-radius: 18px;
  --ks-transition: all 0.3s ease;
}
html { scroll-behavior: smooth; }
body { font-family: 'Inter', sans-serif; background: var(--ks-bg); color: var(--ks-text); }
a, button { transition: var(--ks-transition); }
img { max-width:100%; height:auto; }
ul { list-style: none; padding:0; margin:0; }
button, input, textarea, select { font-family: inherit; }
::selection { background: rgba(10,102,214,0.18); }
/* Header */
.ve-header { 
  position: fixed; 
  top: 0; 
  left: 0; 
  right: 0; 
  z-index: 9999; 
  background: #ffffff; 
  backdrop-filter: blur(10px); 
  border-bottom: 1px solid rgba(14, 43, 83, 0.08);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  transition: box-shadow 0.3s ease;
}

.ve-header.scrolled { 
  box-shadow: 0 8px 24px rgba(15, 36, 59, 0.12); 
}

/* Navbar Container */
.ve-nav-wrap { 
  display: flex; 
  align-items: center; 
  justify-content: space-between; 
  gap: 24px; 
  padding: 12px 48px;
  max-width: 1600px;
  margin: 0 auto;
}

/* Logo Section */
.ve-logo a { 
  display: flex; 
  align-items: center; 
  gap: 12px; 
  color: var(--ks-secondary); 
  font-weight: 700; 
  font-size: 18px; 
  text-decoration: none;
  flex-shrink: 0;
}

.ks-brand-logo { 
  width: 40px; 
  height: 40px; 
  object-fit: contain; 
  border-radius: 10px; 
  display: block; 
}

.ve-logo-text { 
  color: var(--ks-secondary); 
  font-weight: 700; 
  font-size: 16px;
}

/* Main Navigation */
.ve-nav { 
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
}

.ve-nav ul { 
  display: flex; 
  align-items: center; 
  gap: 4px;
  flex-wrap: wrap;
  justify-content: center;
}

.ve-nav ul li { 
  position: relative; 
}

.ve-nav ul li a { 
  padding: 8px 16px; 
  border-radius: 8px; 
  color: var(--ks-secondary); 
  font-size: 15px; 
  font-weight: 500;
  text-decoration: none;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.ve-nav ul li a:hover, 
.ve-nav ul li a.active { 
  background: rgba(10, 102, 214, 0.1); 
  color: var(--ks-primary);
  font-weight: 600;
}

.ve-nav .ve-dropdown { 
  position: absolute; 
  top: 100%; 
  left: 0; 
  min-width: 200px; 
  background: #fff; 
  border-radius: 14px; 
  box-shadow: 0 12px 32px rgba(15, 36, 59, 0.14); 
  padding: 12px 0; 
  opacity: 0; 
  visibility: hidden; 
  transform: translateY(8px); 
  transition: var(--ks-transition); 
  border: 1px solid rgba(10, 102, 214, 0.08); 
}

.ve-nav .has-drop:hover .ve-dropdown { 
  opacity: 1; 
  visibility: visible; 
  transform: translateY(0); 
}

.ve-dropdown li a { 
  padding: 10px 18px; 
  display: block; 
  color: var(--ks-text-muted); 
  font-size: 14px;
  font-weight: 500;
}

.ve-dropdown li a:hover { 
  color: var(--ks-primary);
  background: rgba(10, 102, 214, 0.05);
}

/* Search Box */
.ve-search-box {
  display: flex;
  align-items: center;
  background: #f5f7fb;
  border: 1px solid #e0e8f0;
  border-radius: 8px;
  padding: 0;
  height: 42px;
  gap: 0;
  transition: all 0.3s ease;
}

.ve-search-box:focus-within {
  border-color: var(--ks-primary);
  box-shadow: 0 0 0 3px rgba(10, 102, 214, 0.1);
  background: #fff;
}

.ve-search-input {
  flex: 1;
  border: none;
  background: transparent;
  padding: 0 14px;
  height: 100%;
  font-size: 14px;
  color: var(--ks-secondary);
  outline: none;
  font-weight: 500;
}

.ve-search-input::placeholder {
  color: var(--ks-text-muted);
  font-weight: 400;
}

.ve-search-btn {
  width: 42px;
  height: 100%;
  border: none;
  background: transparent;
  color: var(--ks-text-muted);
  cursor: pointer;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.3s ease;
}

.ve-search-btn:hover {
  color: var(--ks-primary);
}

/* Right Section */
.ve-nav-cta { 
  display: flex; 
  align-items: center; 
  gap: 16px;
  flex-shrink: 0;
}

/* Account Links */
.ve-account-links {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ve-account-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  color: var(--ks-secondary);
  text-decoration: none;
  font-size: 12px;
  font-weight: 600;
  padding: 6px 10px;
  border-radius: 8px;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.ve-account-link i {
  font-size: 18px;
}

.ve-account-link:hover {
  background: rgba(10, 102, 214, 0.1);
  color: var(--ks-primary);
}

/* CTA Button */
.ve-cta-btn { 
  display: inline-flex; 
  align-items: center; 
  gap: 8px; 
  background: var(--ks-primary); 
  color: #fff; 
  padding: 10px 22px; 
  border-radius: 8px; 
  font-weight: 600; 
  text-decoration: none;
  font-size: 15px;
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.ve-cta-btn:hover { 
  transform: translateY(-2px);
  background: var(--ks-primary-dark);
  box-shadow: 0 8px 16px rgba(10, 102, 214, 0.3);
}

.ve-cta-btn i {
  font-size: 16px;
}

/* Dark Mode Toggle */
.ks-darkmode-toggle { 
  width: 40px; 
  height: 40px; 
  border-radius: 8px; 
  border: 1px solid #e0e8f0;
  background: #f5f7fb;
  color: var(--ks-secondary); 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 16px;
}

.ks-darkmode-toggle:hover { 
  background: rgba(10, 102, 214, 0.1);
  border-color: var(--ks-primary);
  color: var(--ks-primary);
}

/* Mobile Menu Toggle */
.ve-toggler { 
  display: none; 
  width: 40px; 
  height: 40px; 
  border: 1px solid #e0e8f0;
  background: #f5f7fb;
  color: var(--ks-secondary); 
  border-radius: 8px; 
  cursor: pointer;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  transition: all 0.3s ease;
}

.ve-toggler:hover {
  background: rgba(10, 102, 214, 0.1);
  border-color: var(--ks-primary);
}

.ve-toggler span { 
  display: block; 
  width: 18px; 
  height: 2px; 
  background: currentColor; 
  border-radius: 2px; 
  transition: all 0.3s ease;
}

/* Mobile Menu */
.ve-mobile-menu { 
  display: none; 
  background: #fff; 
  border-top: 1px solid rgba(14, 43, 83, 0.08); 
  padding: 16px 28px;
  animation: slideDown 0.3s ease;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.ve-mobile-menu ul li a { 
  display: block; 
  padding: 14px 0; 
  color: var(--ks-secondary); 
  border-bottom: 1px solid rgba(14, 43, 83, 0.06);
  font-weight: 500;
  transition: all 0.3s ease;
}

.ve-mobile-menu ul li a:hover {
  color: var(--ks-primary);
  padding-left: 8px;
}

.ve-mobile-menu.open { 
  display: block; 
}
/* Hero */
.ve-hero { display:flex; min-height:100vh; align-items:center; padding-top:92px; position:relative; overflow:hidden; }
.ve-hero::before { content:''; position:absolute; inset:0; background: radial-gradient(circle at top right, rgba(0,177,255,0.17), transparent 28%); pointer-events:none; }
.ve-hero-left { flex:0 0 55%; padding:80px 40px 80px 80px; z-index:2; }
.ve-hero-badge { display:inline-flex; align-items:center; gap:10px; background: rgba(10,102,214,0.12); color: var(--ks-primary); padding:10px 18px; border-radius:999px; font-size:13px; font-weight:700; margin-bottom:26px; }
.ve-hero-left h1 { font-size:58px; line-height:1.03; color:#081b34; margin-bottom:24px; max-width:720px; }
.ve-hero-left p { color: var(--ks-text-muted); max-width:620px; line-height:1.75; margin-bottom:38px; font-size:16px; }
.ve-hero-btns { display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.ve-btn-secondary { display:inline-flex; align-items:center; gap:10px; padding:12px 24px; border-radius:12px; border:1px solid rgba(10,102,214,0.18); color: var(--ks-primary); background: #fff; font-weight:700; text-decoration:none; }
.ve-btn-secondary:hover { background: rgba(10,102,214,0.08); }
.ve-hero-stats { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:18px; margin-top:50px; }
.ve-stat { background: rgba(10,102,214,0.05); border:1px solid rgba(10,102,214,0.12); border-radius:20px; padding:22px 24px; }
.ve-stat strong { display:block; font-size:34px; color: var(--ks-primary); }
.ve-stat span { display:block; color: var(--ks-text-muted); margin-top:6px; font-size:14px; }
.ve-hero-right { flex:0 0 45%; position:relative; min-height:680px; }
.ve-hero-img-main { position:absolute; inset:0; background-size:cover; background-position:center; border-radius:36px; box-shadow: var(--ks-shadow); }
.ve-hero-img-overlay { position:absolute; inset:0; background: linear-gradient(180deg, rgba(10,102,214,0.24), rgba(17,37,66,0.44)); border-radius:36px; }
.ve-hero-img-accent { position:absolute; bottom:60px; right:60px; width:240px; height:180px; background-size:cover; background-position:center; border-radius:24px; border:4px solid rgba(255,255,255,0.92); box-shadow: 0 30px 60px rgba(2,24,58,0.18); }
.ve-float-card { position:absolute; top:64px; right:68px; background:#fff; border-radius:22px; padding:18px 22px; display:flex; align-items:center; gap:16px; box-shadow: 0 35px 65px rgba(15,36,59,0.14); }
.ve-float-card i { color: var(--ks-primary); font-size:24px; }
.ve-float-card strong { display:block; font-size:24px; color: var(--ks-secondary); }
.ve-float-card span { color: var(--ks-text-muted); font-size:13px; }
/* Page hero */
.ks-page-hero { position:relative; min-height:460px; display:flex; align-items:center; padding-top:92px; }
.ks-page-hero::before { content:''; position:absolute; inset:0; background: rgba(10,102,214,0.18); }
.ks-page-hero-overlay { position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,102,214,0.42),rgba(10,102,214,0.06)); mix-blend-mode: multiply; }
.ks-page-hero-text { position:relative; z-index:1; color:#fff; max-width:680px; padding:0 30px; }
.ks-page-hero-text h1 { font-size:44px; line-height:1.08; margin-top:16px; }
.ks-page-hero-text p { margin-top:18px; color: rgba(255,255,255,0.9); font-size:16px; max-width:620px; }
.ks-section { padding:100px 0; }
.ks-section.bg-light { background: #f8fbff; }
.ks-section-header { text-align:center; margin-bottom:70px; }
.ks-section-header h2 { font-size:38px; line-height:1.15; margin-top:16px; color: var(--ks-secondary); }
.ks-section-header h2 span { color: var(--ks-primary); }
.ks-section-header p { max-width:680px; margin:18px auto 0; color: var(--ks-text-muted); }
.ks-section-tag { display:inline-block; padding:10px 18px; border-radius:999px; color: var(--ks-primary); background:rgba(10,102,214,0.12); font-weight:700; letter-spacing:0.8px; text-transform:uppercase; font-size:12px; }
/* Service cards */
.ks-services-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:28px; }
.ks-service-card { background: #fff; border-radius:24px; border:1px solid rgba(15,36,59,0.08); box-shadow: var(--ks-shadow); padding:34px; min-height:320px; display:flex; flex-direction:column; justify-content:space-between; }
.ks-service-icon { width:64px; height:64px; border-radius:18px; display:flex; align-items:center; justify-content:center; background: rgba(10,102,214,0.12); color: var(--ks-primary); font-size:24px; margin-bottom:24px; }
.ks-service-card h4 { font-size:20px; margin-bottom:14px; color: var(--ks-secondary); }
.ks-service-card p { color: var(--ks-text-muted); line-height:1.8; margin-bottom:26px; }
.ks-service-card .ks-btn-link { color: var(--ks-primary); font-weight:700; text-decoration:none; }
.ks-service-card .ks-btn-link:hover { text-decoration:underline; }
/* Product cards */
.ks-product-card { background:#fff; border-radius:24px; overflow:hidden; border:1px solid rgba(15,36,59,0.08); box-shadow: var(--ks-shadow); }
.ks-product-card img { width: 100%; height: 240px; object-fit: cover; display: block; }
.ks-product-card-body { padding:26px; }
.ks-product-meta { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px; }
.ks-product-category { display:inline-flex; align-items:center; border-radius:999px; padding:5px 10px; font-size:12px; font-weight:700; color:var(--ks-primary); background:rgba(10,102,214,0.1); }
.ks-product-price { font-size:14px; font-weight:700; color:var(--ks-secondary); }
.ks-photo-gallery { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:18px; }
.ks-gallery-item { background:#fff; border:1px solid rgba(15,36,59,0.08); border-radius:16px; overflow:hidden; box-shadow: var(--ks-shadow); display:block; }
.ks-gallery-item img { width:100%; height:220px; object-fit:cover; display:block; transition: transform 0.35s ease; }
.ks-gallery-item:hover img { transform: scale(1.05); }
.ks-product-gallery-groups { display:grid; gap:26px; }
.ks-product-gallery-group { background:#fff; border:1px solid rgba(15,36,59,0.08); border-radius:20px; padding:20px; box-shadow: var(--ks-shadow); }
.ks-product-gallery-group h4 { margin-bottom:14px; color: var(--ks-secondary); }
.ks-stock-stats { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:18px; margin-bottom:28px; }
.ks-stock-stat-card { background:#fff; border:1px solid rgba(15,36,59,0.08); border-radius:18px; padding:20px; box-shadow: var(--ks-shadow); }
.ks-stock-stat-card h5 { margin-bottom:10px; color: var(--ks-text-muted); font-size:14px; font-weight:600; }
.ks-stock-stat-card strong { font-size:28px; color: var(--ks-secondary); line-height:1.2; }
.ks-stock-module-wrap { display:grid; grid-template-columns: 1.05fr 1.4fr; gap:22px; }
.ks-stock-form-wrap, .ks-stock-table-wrap { background:#fff; border:1px solid rgba(15,36,59,0.08); border-radius:22px; box-shadow: var(--ks-shadow); padding:24px; }
.ks-stock-form-wrap h4, .ks-stock-table-wrap h4 { margin-bottom:8px; color: var(--ks-secondary); }
.ks-stock-help { color: var(--ks-text-muted); margin-bottom:18px; }
.ks-stock-form-row { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:14px; margin-bottom:14px; }
.ks-stock-form-group { display:flex; flex-direction:column; }
.ks-stock-form-group label { margin-bottom:8px; color: var(--ks-secondary); font-weight:600; font-size:14px; }
.ks-stock-form-group input { border:1px solid rgba(15,36,59,0.12); border-radius:12px; padding:12px 14px; background:#fff; color:var(--ks-secondary); outline:none; }
.ks-stock-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:8px; }
.ks-stock-table-head { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px; }
.ks-stock-table-head input { width:320px; max-width:100%; border:1px solid rgba(15,36,59,0.12); border-radius:12px; padding:10px 12px; }
.ks-stock-table { width:100%; border-collapse:collapse; }
.ks-stock-table th, .ks-stock-table td { padding:12px 10px; border-bottom:1px solid rgba(15,36,59,0.08); font-size:14px; text-align:left; }
.ks-stock-table th { color: var(--ks-secondary); font-weight:700; background: rgba(10,102,214,0.04); }
.ks-stock-table td { color: var(--ks-text-muted); }
.ks-stock-status { display:inline-flex; align-items:center; border-radius:999px; padding:5px 10px; font-size:12px; font-weight:700; }
.ks-stock-status.ok { background: rgba(9,174,86,0.12); color:#0a8e4d; }
.ks-stock-status.low { background: rgba(224,88,15,0.12); color:#c54b03; }
.ks-stock-table-actions { display:flex; gap:8px; }
.ks-stock-table-actions button { border:none; border-radius:8px; padding:7px 10px; font-size:12px; font-weight:700; cursor:pointer; }
.ks-stock-edit-btn { background: rgba(10,102,214,0.12); color: var(--ks-primary); }
.ks-stock-delete-btn { background: rgba(219,44,44,0.12); color:#be2a2a; }
.ks-stock-empty { text-align:center; color: var(--ks-text-muted); padding:18px 10px; }
.ks-admin-catalog-note { border-radius: 14px; padding: 14px 16px; margin-bottom: 18px; border: 1px solid rgba(10,102,214,0.18); background: rgba(10,102,214,0.08); color: var(--ks-secondary); font-weight: 500; }
.ks-admin-catalog-note.warning { background: rgba(224,88,15,0.12); border-color: rgba(224,88,15,0.25); }
.ks-admin-catalog-note.info { background: rgba(10,102,214,0.08); border-color: rgba(10,102,214,0.18); }
.ks-admin-cta-wrap { max-width: 760px; margin: 0 auto; border-radius: 22px; border: 1px solid rgba(15,36,59,0.08); background: #fff; box-shadow: var(--ks-shadow); padding: 32px; text-align: center; }
.ks-admin-cta-text { color: var(--ks-text-muted); margin-bottom: 20px; }
.ks-btn-secondary { display:inline-flex; align-items:center; gap:10px; padding:14px 24px; border-radius:14px; border:1px solid rgba(10,102,214,0.25); color: var(--ks-primary); background:#fff; font-size:15px; font-weight:700; text-decoration:none; cursor:pointer; }
.ks-btn-secondary:hover { background: rgba(10,102,214,0.08); }
.ks-admin-shell { max-width: 760px; margin: 0 auto 24px; background:#fff; border:1px solid rgba(15,36,59,0.08); border-radius:24px; box-shadow: var(--ks-shadow); padding:32px; }
.ks-admin-dashboard { display: grid; gap: 24px; }
.ks-admin-head { display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom: 8px; }
.ks-admin-head h3 { margin: 0; color: var(--ks-secondary); }
.ks-admin-status { border-radius: 12px; padding: 11px 14px; margin: 12px 0 4px; background: rgba(10,102,214,0.08); color: var(--ks-secondary); border: 1px solid rgba(10,102,214,0.2); }
.ks-admin-status.success { background: rgba(9,174,86,0.12); border-color: rgba(9,174,86,0.22); color: #0a8e4d; }
.ks-admin-status.warning { background: rgba(224,88,15,0.12); border-color: rgba(224,88,15,0.24); color: #9f3f0e; }
.ks-admin-status.info { background: rgba(10,102,214,0.08); border-color: rgba(10,102,214,0.2); color: var(--ks-secondary); }
.ks-admin-thumb { width: 58px; height: 58px; object-fit: cover; border-radius: 10px; border: 1px solid rgba(15,36,59,0.12); }
.ks-image-order-list { display:grid; gap:10px; margin-top:8px; }
.ks-image-order-item { display:flex; align-items:center; gap:10px; padding:10px; border:1px solid rgba(15,36,59,0.12); border-radius:12px; background:#fff; cursor:grab; }
.ks-image-order-item.dragging { opacity:0.5; }
.ks-image-order-item img { width:52px; height:52px; object-fit:cover; border-radius:8px; border:1px solid rgba(15,36,59,0.12); }
.ks-image-order-meta { display:flex; flex-direction:column; gap:2px; min-width:0; }
.ks-image-order-meta strong { font-size:13px; color: var(--ks-secondary); }
.ks-image-order-meta span { font-size:12px; color: var(--ks-text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:430px; }
.ks-product-card h4 { font-size:20px; color: var(--ks-secondary); margin-bottom:12px; }
.ks-product-card p { color: var(--ks-text-muted); line-height:1.8; margin-bottom:18px; }
.ks-product-description-trigger { cursor:pointer; border-bottom:1px dashed rgba(10,102,214,0.25); padding-bottom:8px; }
.ks-product-description-trigger:hover { color: var(--ks-primary); border-bottom-color: rgba(10,102,214,0.55); }
.ks-btn-link { color: var(--ks-primary); font-weight:700; text-decoration:none; }
.ks-btn-link:hover { color: var(--ks-primary-dark); }
.ks-btn-link.ks-add-to-cart { border: none; background: transparent; padding: 0; cursor: pointer; }
.ks-detail-page-wrap .container { max-width: 1320px; padding-left: 12px; padding-right: 12px; }
.ks-product-detail-panel { margin-top:30px; background:#fff; border:1px solid rgba(15,36,59,0.08); border-radius:24px; padding:16px; box-shadow: var(--ks-shadow); }
.ks-product-detail-grid { display:grid; grid-template-columns: 1.15fr 1fr; gap:16px; }
.ks-detail-media-wrap { display:grid; grid-template-columns: 86px 1fr; gap:12px; align-items:start; }
.ks-detail-main-image { width:100%; height:520px; object-fit:contain; border:1px solid rgba(15,36,59,0.1); border-radius:18px; background:#fff; cursor:zoom-in; }

/* Lightbox */
.ks-lightbox { display:none; position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,0.92); flex-direction:column; align-items:center; justify-content:center; padding:16px; }
.ks-lightbox.open { display:flex; }
.ks-lightbox-main { flex:1; display:flex; align-items:center; justify-content:center; max-height:80vh; width:100%; }
.ks-lightbox-main img { max-width:100%; max-height:80vh; object-fit:contain; border-radius:8px; display:block; }
.ks-lightbox-controls { display:flex; align-items:center; gap:16px; margin-top:14px; }
.ks-lightbox-btn { background:rgba(255,255,255,0.15); border:0; color:#fff; border-radius:8px; padding:10px 16px; font-size:18px; font-weight:700; cursor:pointer; transition:background 0.2s; }
.ks-lightbox-btn:hover { background:rgba(255,255,255,0.3); }
#ksLightboxClose { position:absolute; top:16px; right:20px; font-size:20px; line-height:1; padding:8px 14px; }
.ks-lightbox-thumbs { display:flex; gap:10px; margin-top:14px; overflow-x:auto; padding-bottom:4px; }
.ks-lightbox-thumbs img { width:60px; height:60px; object-fit:cover; border-radius:6px; cursor:pointer; opacity:0.6; border:2px solid transparent; transition:opacity 0.2s, border-color 0.2s; flex-shrink:0; }
.ks-lightbox-thumbs img.active, .ks-lightbox-thumbs img:hover { opacity:1; border-color:#fff; }
.ks-detail-thumbs { display:grid; grid-template-columns: 1fr; gap:10px; max-height:520px; overflow-y:auto; padding-right:2px; }
.ks-detail-thumb-btn { border:1px solid rgba(15,36,59,0.12); background:#fff; border-radius:10px; padding:4px; cursor:pointer; }
.ks-detail-thumb-btn img { width:100%; height:62px; object-fit:cover; border-radius:8px; }
.ks-detail-meta-list { margin:16px 0 22px; display:grid; gap:8px; }
.ks-detail-meta-list li { color: var(--ks-text-muted); }
.ks-detail-meta-list strong { color: var(--ks-secondary); margin-right:6px; }
.ks-pd-meta-text { margin-top:8px; color:#8a95a4; font-size:16px; }
.ks-pd-meta-text span:first-child { color:#9aa6b5; }
.ks-pd-stock-state { margin-top:14px; font-size:24px; color:#0e9e58; font-weight:500; }
.ks-pd-pricing { display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; margin-top:10px; }
.ks-pd-pricing #ksPdPrice { font-size:22px; color:#c11144; font-weight:800; line-height:1; }
.ks-pd-pricing #ksPdOldPrice { font-size:20px; color:#6f7b8a; text-decoration:line-through; }
.ks-pd-buy-row { margin-top:14px; display:grid; grid-template-columns: 250px 1fr; gap:12px; align-items:stretch; }
.ks-pd-qty-stepper { display:grid; grid-template-columns: 1fr 84px 1fr; border:1px solid #dde4ed; border-radius:8px; overflow:hidden; }
.ks-pd-qty-stepper button { border:0; background:#f8fbff; color:#637995; font-size:30px; line-height:1; cursor:pointer; }
.ks-pd-qty-stepper input { border:0; text-align:center; font-size:24px; color:#1f2e42; width:100%; outline:none; }
.ks-pd-add-btn { border:0; border-radius:8px; background:#e50045; color:#fff; font-size:18px; font-style:italic; font-weight:800; padding:12px 18px; cursor:pointer; }
.ks-pd-add-btn:hover { background:#c9003d; }
.ks-pd-stock-indicator { margin-top:18px; border-top:1px solid #e6edf5; padding-top:14px; }
.ks-pd-stock-indicator h5 { margin:0 0 10px; color:#1f3046; font-size:20px; }
.ks-pd-stock-chips { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:10px; }
.ks-pd-chip { border-radius:10px; text-align:center; padding:8px 10px; font-size:21px; font-weight:800; }
.ks-pd-chip.in { background:#0aa84f; color:#fff; }
.ks-pd-chip.low { background:#f4b300; color:#fff; }
.ks-pd-chip.out { background:#bdc6d1; color:#fff; }
.ks-pd-chip.neutral { background:#e5e7eb; color:#8a95a4; }
.ks-pd-qty-inline { margin:10px 0 0; color:#7b8798; font-size:16px; }
.ks-pd-qty-inline strong { color:#1f2e42; }
/* Timeline */
.ks-timeline { display:grid; gap:26px; }
.ks-step { background:#fff; border-radius:24px; border:1px solid rgba(15,36,59,0.08); padding:30px; box-shadow: var(--ks-shadow); }
.ks-step-number { display:inline-flex; align-items:center; justify-content:center; width:58px; height:58px; border-radius:18px; background: rgba(10,102,214,0.12); color: var(--ks-primary); font-weight:700; font-size:18px; margin-bottom:18px; }
.ks-step h5 { font-size:20px; color: var(--ks-secondary); margin-bottom:12px; }
.ks-step p { color: var(--ks-text-muted); line-height:1.8; }
/* Clients */
.ks-client-grid { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:22px; }
.ks-client-card { background:#fff; border-radius:20px; padding:24px; border:1px solid rgba(15,36,59,0.08); text-align:center; color: var(--ks-secondary); font-weight:700; box-shadow: var(--ks-shadow); min-height:120px; display:flex; align-items:center; justify-content:center; }
.ks-client-logo { display:block; max-width:160px; max-height:60px; width:auto; height:auto; object-fit:contain; opacity:1; transition: opacity 0.25s ease; }
.ks-client-card:hover .ks-client-logo { opacity:1; }
.ks-client-fallback { display:none; font-weight:700; color: var(--ks-secondary); }
.ks-testimonial-card { background:#fff; border-radius:24px; border:1px solid rgba(15,36,59,0.08); padding:28px; box-shadow: var(--ks-shadow); }
.ks-testimonial-card p { color: var(--ks-text-muted); font-size:15px; line-height:1.85; margin-bottom:20px; }
.ks-testimonial-card strong { color: var(--ks-secondary); font-size:15px; }
/* Organogram */
.ks-org-chart { display:flex; flex-direction:column; align-items:center; gap:24px; }
.ks-org-row { display:flex; flex-wrap:wrap; gap:24px; justify-content:center; }
.ks-org-card { background:#fff; border-radius:24px; border:1px solid rgba(15,36,59,0.08); padding:26px 28px; min-width:220px; text-align:center; box-shadow: var(--ks-shadow); }
.ks-org-card h5 { color: var(--ks-secondary); font-size:16px; }
/* Contact */
.ks-contact-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:24px; margin-bottom:50px; }
.ks-contact-card { background:#fff; border-radius:24px; padding:30px; border:1px solid rgba(15,36,59,0.08); box-shadow: var(--ks-shadow); }
.ks-contact-card i { font-size:22px; color: var(--ks-primary); margin-bottom:18px; }
.ks-contact-card h5 { margin-bottom:12px; color: var(--ks-secondary); }
.ks-contact-card p { color: var(--ks-text-muted); line-height:1.75; }
.ks-contact-card p a { color: var(--ks-text-muted); text-decoration: none; word-break: break-word; }
.ks-contact-card p a:hover { color: var(--ks-primary); text-decoration: underline; }
.ks-contact-cards-row .ks-contact-card { min-height: 260px; display: flex; flex-direction: column; }
.ks-contact-form-wrap { background:#fff; border-radius:28px; border:1px solid rgba(15,36,59,0.08); padding:38px; box-shadow: var(--ks-shadow); }
.ks-contact-form label { display:block; margin-bottom:10px; color: var(--ks-secondary); font-weight:600; }
.ks-form-row { display:grid; gap:20px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.ks-form-group { display:flex; flex-direction:column; }
.ks-form-group input, .ks-form-group textarea, .ks-form-group select { border:1px solid rgba(15,36,59,0.12); border-radius:16px; padding:16px 18px; background:#fff; color: var(--ks-secondary); outline:none; }
.ks-form-group textarea { min-height:160px; resize:vertical; }
.ks-btn-primary { display:inline-flex; align-items:center; gap:10px; padding:14px 30px; background: var(--ks-primary); color:#fff; border-radius:14px; border:none; font-size:15px; font-weight:700; text-decoration:none; cursor:pointer; }
.ks-btn-primary:hover { background: var(--ks-primary-dark); }
.ks-aside-card { background: #fff; border-radius:24px; border:1px solid rgba(15,36,59,0.08); padding:26px; box-shadow: var(--ks-shadow); margin-bottom:24px; }
.ks-aside-card h4 { margin-bottom:16px; color: var(--ks-secondary); }
.ks-aside-card ul { display:grid; gap:14px; }
.ks-aside-card ul li { color: var(--ks-text-muted); }
.ks-aside-card ul li i { color: var(--ks-primary); margin-right:12px; }
.ks-map-wrapper { border-radius:24px; overflow:hidden; box-shadow: var(--ks-shadow); border:1px solid rgba(15,36,59,0.08); }
.ks-map-wrapper iframe { width:100%; min-height:360px; border:0; }
/* Footer */
.ks-footer { background: #081b34; color:#c5d5ee; padding:60px 0 36px; }
.ks-footer-logo { color:#fff; font-size:20px; font-weight:800; text-decoration:none; display:inline-flex; align-items:center; gap:10px; margin-bottom:18px; }
.ks-footer-brand-logo { width:34px; height:34px; object-fit:contain; border-radius:8px; display:block; }
.ks-footer p { color:#b8c9e2; max-width:420px; line-height:1.9; }
.ks-social-links { display:flex; gap:14px; margin-top:18px; }
.ks-social-links a { display:flex; align-items:center; justify-content:center; width:44px; height:44px; background: rgba(255,255,255,0.08); border-radius:14px; color:#fff; }
.ks-footer h5 { color:#fff; margin-bottom:18px; font-size:16px; }
.ks-footer ul { list-style:none; padding:0; margin:0; display:grid; gap:12px; }
.ks-footer ul li a { color:#b8c9e2; text-decoration:none; font-size:14px; }
.ks-footer ul li a:hover { color:#fff; }
.ks-footer-contact li { display:flex; gap:12px; align-items:flex-start; color:#b8c9e2; font-size:14px; }
.ks-footer-contact li,
.ve-footer-contact li,
.ks-contact-card p {
  overflow-wrap: anywhere;
  word-break: break-word;
}
.ks-footer-bottom { margin-top:40px; border-top:1px solid rgba(255,255,255,0.08); padding-top:20px; color:#8ea4cd; font-size:13px; text-align:center; }
.ks-footer-bottom p { margin:0; }
.ks-google-footer-links { display:flex; justify-content:center; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:12px; }
.ks-google-footer-links a { display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:10px; border:1px solid rgba(255,255,255,0.2); color:#d7e6ff; text-decoration:none; font-size:13px; font-weight:700; }
.ks-google-footer-links a:hover { color:#fff; border-color: rgba(255,255,255,0.38); background: rgba(255,255,255,0.08); }
/* WhatsApp floating button */
.ks-whatsapp-float { position: fixed; right:24px; bottom:24px; width:56px; height:56px; background:#25d366; color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 18px 32px rgba(0,0,0,0.22); z-index: 9999; text-decoration:none; }
.ks-whatsapp-float:hover { transform: translateY(-2px); }
.ks-google-links-float { position: fixed; left: 24px; bottom: 24px; display: grid; gap: 10px; z-index: 9998; }
.ks-google-links-float a { display: inline-flex; align-items: center; gap: 8px; padding: 10px 14px; border-radius: 12px; background: #fff; color: var(--ks-secondary); border: 1px solid rgba(15,36,59,0.14); box-shadow: 0 14px 30px rgba(15,36,59,0.16); text-decoration: none; font-size: 13px; font-weight: 700; }
.ks-google-links-float a i { color: #0a66d6; }
.ks-google-links-float a:hover { transform: translateY(-2px); border-color: rgba(10,102,214,0.35); }

/* Remove header search input across pages */
.b2b-search { display:none !important; }

/* Remove large page hero banners across pages */
.ks-page-hero { display:none !important; }

/* Store tools */
.ks-store-tools { padding-top: 40px; padding-bottom: 20px; }
.ks-store-search-wrap { background:#13161d; border:1px solid rgba(255,255,255,0.25); border-radius:999px; padding:10px 12px; display:flex; align-items:center; gap:12px; margin-bottom:26px; }
.ks-store-search-wrap i { color:#fff; font-size:20px; margin-left:10px; }
.ks-store-search-wrap input { flex:1; background:transparent; border:none; color:#fff; font-size:30px; outline:none; }
.ks-store-search-wrap input::placeholder { color: rgba(255,255,255,0.8); }
.ks-category-showcase { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:20px; }
.ks-category-column { background:#fff; border:1px solid rgba(15,36,59,0.08); border-radius:18px; padding:20px; box-shadow: var(--ks-shadow); }
.ks-category-column h4 { margin: 0 0 12px; color: var(--ks-secondary); font-size: 19px; }
.ks-category-column ul { display:grid; gap:7px; margin-bottom:14px; }
.ks-category-column li { color: var(--ks-text-muted); font-size:14px; }
.ks-store-tools-group { display:flex; align-items:center; gap:10px; }
.ks-store-icon-btn { position:relative; width:44px; height:44px; border-radius:12px; border:1px solid rgba(10,102,214,0.18); background:#fff; color:var(--ks-secondary); display:inline-flex; align-items:center; justify-content:center; text-decoration:none; }
.ks-store-icon-btn:hover { color:var(--ks-primary); border-color:rgba(10,102,214,0.34); }
.ks-cart-badge { position:absolute; top:-6px; right:-5px; min-width:19px; height:19px; border-radius:999px; background:#d6003d; color:#fff; font-size:11px; font-weight:700; display:flex; align-items:center; justify-content:center; padding:0 5px; }
.ks-cart-table { width:100%; border-collapse:collapse; margin-top:16px; }
.ks-cart-table th, .ks-cart-table td { border-bottom:1px solid rgba(15,36,59,0.08); padding:12px 10px; text-align:left; }
.ks-cart-table th { background: rgba(10,102,214,0.04); color: var(--ks-secondary); }
.ks-qty-btn { border:none; border-radius:8px; background: rgba(10,102,214,0.12); color: var(--ks-primary); width:28px; height:28px; }
.ks-checkout-success { border-radius:18px; border:1px solid rgba(9,174,86,0.3); background:rgba(9,174,86,0.08); padding:20px; margin-top:16px; }

/* Products catalog controls and grouped grid */
.ks-catalog-layout { display:grid; grid-template-columns:minmax(200px, 230px) minmax(0, 1fr); gap:14px; align-items:start; }
.ks-catalog-sidebar { position:sticky; top:110px; border:1px solid #e2e9f2; border-radius:16px; background:#fff; box-shadow:0 12px 30px rgba(13,36,76,0.07); padding:10px; }
.ks-catalog-sidebar-title { margin:0 0 14px; font-size:16px; font-weight:800; color:#142d4f; }
.ks-catalog-toolbar { display:grid; grid-template-columns:1fr; gap:12px; margin:0; }
.ks-catalog-filter-group { display:flex; flex-direction:column; gap:7px; }
.ks-catalog-filter-group label { font-size:12px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:#3d4d65; }
.ks-catalog-select { width:100%; border:1px solid #d5dfea; border-radius:10px; background:#fff; color:#1f2b3d; font-size:14px; padding:10px 12px; transition:border-color 0.2s ease, box-shadow 0.2s ease; }
.ks-catalog-select:focus { border-color:#125dcf; box-shadow:0 0 0 3px rgba(18,93,207,0.12); outline:none; }
.ks-catalog-main { min-width:0; }
.ks-products-page-main { padding: 10px 0 28px; }
.ks-products-only-section { padding: 0; }
.ks-products-page-shell { width: 100%; margin: 0; padding: 0 12px; }
.ks-products-only-section .ks-catalog-layout { grid-template-columns:minmax(190px, 220px) minmax(0, 1fr); gap:12px; }
.ks-products-catalog { display:grid; gap:32px; }
.ks-products-category-block { border:1px solid #e2e9f2; border-radius:16px; background:linear-gradient(180deg, #ffffff 0%, #f9fbfe 100%); padding:16px; box-shadow:0 12px 30px rgba(13,36,76,0.07); }
.ks-products-category-head { display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin-bottom:16px; border-bottom:1px solid #e5edf6; padding-bottom:12px; }
.ks-products-category-head h3 { margin:0; font-size:20px; font-weight:700; color:#142d4f; }
.ks-products-category-head span { font-size:12px; text-transform:uppercase; letter-spacing:0.05em; font-weight:700; color:#6a7f99; }
.ks-products-grid { display:grid; grid-template-columns:repeat(4, minmax(0, 1fr)); gap:16px; }
.ks-product-card-eq { height:100%; display:flex; flex-direction:column; }
.ks-product-card-eq img { width:100%; height:210px; object-fit:contain; object-position:center; background:#fff; border-top-left-radius:14px; border-top-right-radius:14px; padding:8px; }
.ks-product-card-eq .ks-product-card-body { display:flex; flex-direction:column; height:100%; }
.ks-product-meta { display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:6px; }
.ks-product-category { font-size:11px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:#56708f; }
.ks-product-price { font-size:15px; font-weight:800; color:#0f4eaa; display:inline-flex; align-items:center; gap:7px; }
.ks-old-price { font-size:12px; color:#8fa0b6; text-decoration:line-through; font-weight:600; }
.ks-promo-pill { display:inline-flex; margin:0 0 8px; border-radius:999px; background:rgba(237,74,74,0.12); color:#b11a1a; font-size:11px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; padding:3px 9px; }
.ks-product-card-eq h4 { margin:4px 0 7px; line-height:1.3; }
.ks-product-card-eq h4 a { color:#112946; }
.ks-product-card-eq h4 a:hover { color:#125dcf; }
.ks-product-card-foot { margin-top:auto; padding-top:12px; }
.ks-stock-inline { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; }
.ks-stock-inline.ok { color:#0f8b55; }
.ks-stock-inline.low { color:#c12f2f; }
.ks-stock-availability-wrap { border-top:1px solid #e5edf6; padding-top:10px; margin-top:4px; }
.ks-stock-availability-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.ks-stock-availability-head span { font-size:13px; color:#1a2f4b; font-weight:700; }
.ks-stock-availability-head small { font-size:12px; color:#6b7f98; font-weight:600; }
.ks-stock-location-chips { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:6px; margin-bottom:7px; }
.ks-stock-chip { border-radius:8px; text-align:center; padding:6px 8px; font-size:12px; font-weight:800; letter-spacing:0.02em; }
.ks-stock-chip.in { background:#08a84f; color:#fff; }
.ks-stock-chip.limited { background:#f4b300; color:#fff; }
.ks-stock-chip.out { background:#b8c4d3; color:#fff; }
.ks-stock-chip.neutral { background:#e5e7eb; color:#838f9f; }
.ks-product-price-stack { display:flex; align-items:flex-end; gap:8px; margin-top:12px; flex-wrap:wrap; }
.ks-product-price-main { font-size:33px; line-height:1; color:#bf1447; font-weight:800; }
.ks-product-price-stack .ks-old-price { font-size:20px; color:#7f8b9c; }
.ks-product-price-note { width:100%; font-size:12px; color:#8f98a6; font-weight:600; margin-top:2px; }
.ks-product-actions-row { display:flex; gap:9px; margin-top:14px; }
.ks-product-actions-row .ks-btn-link, .ks-product-actions-row .ks-view-details { flex:1 1 0; display:inline-flex; justify-content:center; align-items:center; border-radius:9px; padding:9px 10px; font-size:13px; font-weight:700; text-align:center; transition:all 0.2s ease; }
.ks-product-actions-row .ks-add-to-cart { background:#e50045; color:#fff; border:1px solid #e50045; width:100%; font-size:14px; line-height:1.1; padding:12px 14px; font-style:italic; font-weight:800; border-radius:7px; }
.ks-product-actions-row .ks-add-to-cart:hover { background:#cb003e; border-color:#cb003e; }
.ks-product-actions-row .ks-view-details { border:1px solid #c8d7ec; color:#234f87; text-decoration:none; background:#f7fafe; }
.ks-product-actions-row .ks-view-details:hover { border-color:#125dcf; color:#125dcf; background:#edf4ff; }
.ks-product-actions-row .ks-view-details { display:none; }
.ks-catalog-pagination { margin-top: 18px; display:flex; justify-content:center; }
.ks-page-row { display:flex; flex-wrap:wrap; gap:8px; }
.ks-page-btn { border:1px solid #c8d7ec; background:#ffffff; color:#234f87; border-radius:8px; min-width:38px; padding:7px 12px; font-size:13px; font-weight:700; }
.ks-page-btn:hover { border-color:#125dcf; color:#125dcf; }
.ks-page-btn.active { background:#125dcf; border-color:#125dcf; color:#ffffff; }
.ks-page-btn[disabled] { opacity:0.5; cursor:not-allowed; }

@media (hover: hover) and (pointer: fine) {
  .ks-product-card-eq {
    transition: transform 0.25s ease, box-shadow 0.25s ease;
  }

  .ks-product-card-eq:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(13, 36, 76, 0.15);
  }
}
.ks-catalog-empty { border:1px dashed #bfd0e6; border-radius:14px; background:#f4f8fd; color:#426284; font-weight:600; text-align:center; padding:35px 16px; }
/* Newsletter */
.ks-newsletter { background: linear-gradient(135deg, rgba(10,102,214,0.95), rgba(0,177,255,0.95)); border-radius:28px; padding:42px 32px; color:#fff; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.ks-newsletter h3 { font-size:28px; margin-bottom:10px; }
.ks-newsletter p { max-width:520px; color: rgba(255,255,255,0.92); }
.ks-newsletter-form { display:flex; gap:14px; flex-wrap:wrap; width:100%; max-width:520px; }
.ks-newsletter-form input { flex:1 1 220px; padding:16px 20px; border-radius:14px; border:none; outline:none; }
.ks-newsletter-form button { padding:16px 28px; border-radius:14px; border:none; background: #fff; color: var(--ks-primary); font-weight:700; cursor:pointer; }
/* Reveal animations */
.ks-reveal { opacity:0; transform: translateY(24px); transition: var(--ks-transition); }
.ks-reveal.visible { opacity:1; transform: translateY(0); }
/* Preloader state */
.preloader-hidden { opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.45s ease, visibility 0.45s ease; }
/* Dark mode */
:root.ks-dark, html.ks-dark {
  --ks-bg: #04111f;
  --ks-surface: #0a1a2e;
  --ks-surface-strong: #0e2340;
  --ks-text: #d9e4ff;
  --ks-text-muted: #9bb2d0;
  --ks-primary: #4dabff;
  --ks-primary-dark: #1f5ec4;
  --ks-secondary: #f8fbff;
  --ks-accent: #52c7ff;
  --ks-border: rgba(255,255,255,0.12);
}
body.ks-dark { background: var(--ks-bg); color: var(--ks-text); }
.ks-dark .ve-header { background: rgba(5,17,33,0.94); border-bottom-color: rgba(255,255,255,0.08); }
.ks-dark .ve-nav ul li a { color: var(--ks-text); }
.ks-dark .ve-nav ul li a:hover, .ks-dark .ve-nav ul li a.active { background: rgba(77,171,255,0.14); color: var(--ks-primary); }
.ks-dark .ve-cta-btn { background: var(--ks-primary); color: #0b1a34; }
.ks-dark .ks-darkmode-toggle { background: rgba(77,171,255,0.14); border-color: rgba(255,255,255,0.2); color: #d9ecff; }
.ks-dark .ve-btn-secondary { background: rgba(77,171,255,0.12); color: var(--ks-primary); }
.ks-dark .ve-hero-left p, .ks-dark .ve-stat span, .ks-dark .ks-section-header p, .ks-dark .ks-product-card p, .ks-dark .ks-service-card p, .ks-dark .ks-step p, .ks-dark .ks-testimonial-card p, .ks-dark .ks-about-text p, .ks-dark .ks-footer p, .ks-dark .ks-footer-contact li { color: var(--ks-text-muted); }
.ks-dark .ks-section { background: #081623; }
.ks-dark .ks-section.bg-light { background: #061123; }
.ks-dark .ks-service-card, .ks-dark .ks-product-card, .ks-dark .ks-step, .ks-dark .ks-why-card, .ks-dark .ks-contact-card, .ks-dark .ks-contact-form-wrap, .ks-dark .ks-aside-card, .ks-dark .ks-testimonial-card, .ks-dark .ks-org-card, .ks-dark .ks-footer, .ks-dark .ks-footer-logo, .ks-dark .ks-footer-contact li, .ks-dark .ks-footer ul li a, .ks-dark .ks-client-card { background: #0c1f34; border-color: rgba(255,255,255,0.1); color: var(--ks-text); }
.ks-dark .ks-footer { background: #041324; }
.ks-dark .ks-footer h5, .ks-dark .ks-footer-logo, .ks-dark .ks-footer ul li a, .ks-dark .ks-footer-contact li { color: #e6f1ff; }
.ks-dark .ks-footer-bottom { color: #8fabd3; }
.ks-dark .ks-admin-shell, .ks-dark .ks-admin-cta-wrap, .ks-dark .ks-admin-dashboard .ks-stock-form-wrap, .ks-dark .ks-admin-dashboard .ks-stock-table-wrap { background: #0c1f34; border-color: rgba(255,255,255,0.1); }
.ks-dark .ks-btn-secondary { background: rgba(77,171,255,0.12); border-color: rgba(77,171,255,0.28); color: #d9ecff; }
.ks-dark .ks-google-links-float a { background: #0c1f34; border-color: rgba(255,255,255,0.16); color: #e6f1ff; }
.ks-dark .ks-google-footer-links a { border-color: rgba(255,255,255,0.24); color: #e6f1ff; }

/* About visual card */
.ks-about-visual { min-height:420px; background-size:cover; background-position:center; border-radius:28px; box-shadow: var(--ks-shadow); }
/* Responsive */
@media(max-width:1199px) { .ve-hero { flex-wrap:wrap; } .ve-hero-left { flex:0 0 100%; padding:80px 32px 40px; } .ve-hero-right { flex:0 0 100%; min-height:420px; } }
@media(max-width:1199px) { .ks-products-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); } }
@media(max-width:991px) { .ks-catalog-layout { grid-template-columns:1fr; } .ks-catalog-sidebar { position:static; top:auto; } }
@media(max-width:991px) { .ks-products-page-main { padding: 8px 0 22px; } .ks-products-page-shell { padding: 0 10px; } }
@media(max-width:991px) { .ve-nav-wrap { padding:16px 24px; } .ve-nav ul { display:none; } .ve-toggler { display:flex; } .ve-nav-cta { display:none; } .ve-hero-left h1 { font-size:44px; } .ve-hero-right { min-height:360px; } .ks-services-grid, .ks-client-grid, .ks-contact-grid, .ks-form-row { grid-template-columns:1fr; } .ks-photo-gallery { grid-template-columns: repeat(2, minmax(0, 1fr)); } .ks-stock-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); } .ks-stock-module-wrap { grid-template-columns: 1fr; } .ks-product-gallery-group { padding:16px; } }
@media(max-width:991px) { .ks-product-detail-grid { grid-template-columns:1fr; } .ks-detail-main-image { height:280px; } .ks-detail-media-wrap { grid-template-columns: 1fr; } .ks-detail-thumbs { grid-template-columns: repeat(4, minmax(0, 1fr)); max-height:none; overflow:visible; } }
@media(max-width:991px) { .ks-pd-buy-row { grid-template-columns:1fr; } .ks-pd-stock-state { font-size:20px; } .ks-pd-pricing #ksPdPrice { font-size:20px; } .ks-pd-add-btn { font-size:16px; } }
@media(max-width:991px) { .ks-category-showcase { grid-template-columns: repeat(2, minmax(0, 1fr)); } .ks-store-search-wrap input { font-size:20px; } }
@media(max-width:767px) { .ve-hero-left { padding:60px 22px 32px; } .ve-hero-btns { justify-content:center; } .ks-page-hero { padding-top:120px; } .ks-page-hero-text h1 { font-size:32px; } .ks-newsletter { flex-direction:column; text-align:center; } .ks-newsletter-form { justify-content:center; } .ks-google-links-float { left: 14px; right: 14px; bottom: 90px; } .ks-google-links-float a { justify-content: center; } .ks-google-footer-links { gap: 10px; } .ks-catalog-toolbar { grid-template-columns:1fr; } .ks-products-grid { grid-template-columns:1fr; } .ks-products-category-head { flex-direction:column; align-items:flex-start; } }
@media(max-width:575px) { .ks-photo-gallery { grid-template-columns:1fr; } .ks-section { padding:70px 0; } .ve-header { padding:16px 18px; } .ks-stock-stats { grid-template-columns:1fr; } .ks-stock-form-row { grid-template-columns:1fr; } .ks-stock-table th, .ks-stock-table td { white-space:nowrap; } .ks-google-links-float a span { font-size: 12px; } .ks-category-showcase { grid-template-columns:1fr; } }
.ks-related-products + .b2b-product-grid .ks-product-price-main { font-size:22px; }

/* ==========================================================================
   PREMIUM POLISH — vaultedge-premium-v2
   Visual enhancements only. No functional changes.
   ========================================================================== */

/* --- Global font & base --- */
.b2b-body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* --- Header polish --- */
.b2b-header {
  box-shadow: 0 1px 0 #e4ecf5, 0 4px 18px rgba(12, 32, 60, 0.06);
}

.b2b-logo span {
  font-family: 'Inter', sans-serif;
  font-weight: 800;
  letter-spacing: -0.01em;
  font-size: 1.05rem;
  color: #0f1d2e;
}

.b2b-nav-link {
  font-family: 'Inter', sans-serif;
  letter-spacing: 0.01em;
}

/* --- Start Shopping CTA --- */
.b2b-start-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  border-radius: 999px;
  background: linear-gradient(130deg, #0d5fc6 0%, #0a49a0 100%);
  color: #ffffff;
  font-size: 0.84rem;
  font-weight: 700;
  text-decoration: none;
  border: none;
  letter-spacing: 0.01em;
  transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
  box-shadow: 0 4px 12px rgba(10, 73, 160, 0.32);
}

.b2b-start-btn:hover {
  background: linear-gradient(130deg, #1166d8 0%, #0b53b8 100%);
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(10, 73, 160, 0.4);
  color: #ffffff;
}

/* --- Cart link --- */
.b2b-cart-link {
  gap: 7px;
  border-radius: 999px;
  padding: 8px 14px;
  font-weight: 700;
  letter-spacing: 0.01em;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.b2b-cart-link:hover {
  background: #eef5ff;
  border-color: #bad2f0;
}

/* --- Hero section --- */
.b2b-hero {
  background: linear-gradient(130deg, #0c1e35 0%, #173b60 42%, #0d7d66 100%);
  margin: 20px 20px 0;
  border-radius: 22px;
  overflow: hidden;
  position: relative;
}

.b2b-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 75% 30%, rgba(30, 180, 140, 0.22) 0%, transparent 55%),
              radial-gradient(ellipse at 20% 80%, rgba(10, 90, 200, 0.18) 0%, transparent 50%);
  pointer-events: none;
}

.b2b-hero-grid {
  padding: 56px 48px;
  gap: 28px;
  position: relative;
  z-index: 1;
}

.b2b-hero h1 {
  font-size: 2.65rem;
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -0.025em;
  margin-bottom: 16px;
  color: #ffffff;
}

.b2b-hero p {
  font-size: 0.95rem;
  line-height: 1.7;
  color: rgba(220, 238, 255, 0.9);
  max-width: 540px;
}

.b2b-hero-actions {
  margin-top: 28px;
  gap: 12px;
}

.b2b-btn-primary {
  background: linear-gradient(130deg, #f5ba30 0%, #e89e05 100%);
  color: #1e1400;
  font-weight: 800;
  border-radius: 999px;
  padding: 13px 26px;
  font-size: 0.9rem;
  letter-spacing: 0.01em;
  box-shadow: 0 6px 18px rgba(232, 158, 5, 0.45);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.b2b-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(232, 158, 5, 0.55);
}

.b2b-btn-secondary {
  border: 1.5px solid rgba(255, 255, 255, 0.4);
  color: #ffffff;
  border-radius: 999px;
  padding: 12px 26px;
  font-size: 0.9rem;
  font-weight: 700;
  backdrop-filter: blur(4px);
  background: rgba(255, 255, 255, 0.07);
  transition: background 0.22s ease, border-color 0.22s ease;
}

.b2b-btn-secondary:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.65);
}

.b2b-hero-panel {
  background: rgba(8, 20, 36, 0.44);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  padding: 24px 20px;
  backdrop-filter: blur(6px);
}

.b2b-hero-panel h4 {
  font-size: 0.92rem;
  font-weight: 700;
  color: #f0f8ff;
  margin-bottom: 6px;
  letter-spacing: 0.01em;
}

.b2b-hero-panel p {
  font-size: 0.82rem;
  color: rgba(200, 225, 255, 0.82);
  line-height: 1.6;
  margin-bottom: 16px;
}

.b2b-hero-panel p:last-child {
  margin-bottom: 0;
}

/* Hero dot indicators */
.b2b-hero-dots button {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.36);
  border: none;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease, width 0.25s ease;
}

.b2b-hero-dots button.active {
  background: #ffffff;
  width: 24px;
  border-radius: 999px;
  transform: scale(1);
}

/* --- Home product section --- */
.b2b-home-section {
  margin: 20px 20px;
  background: #ffffff;
  border-radius: 20px;
  border: 1px solid #e0eaf4;
  padding: 28px 24px;
  box-shadow: 0 4px 20px rgba(12, 28, 55, 0.06);
}

.b2b-home-section-head {
  align-items: center;
  margin-bottom: 20px;
}

.b2b-home-section-head h2 {
  font-size: 1.32rem;
  font-weight: 800;
  color: #0d1e30;
  letter-spacing: -0.02em;
  margin-bottom: 3px;
  line-height: 1.2;
}

.b2b-home-section-head p {
  font-size: 0.83rem;
  color: #5f7490;
  margin-bottom: 0;
}

.b2b-view-all {
  border: 1.5px solid #c8daee;
  border-radius: 999px;
  padding: 8px 18px;
  font-size: 0.81rem;
  font-weight: 700;
  color: #1b4070;
  background: #f4f9ff;
  letter-spacing: 0.01em;
  white-space: nowrap;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.b2b-view-all:hover {
  background: #e8f3ff;
  border-color: #a8c4e0;
  color: #0d3460;
}

/* --- Slider arrows --- */
.b2b-row-arrow {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1.5px solid #cddceb;
  background: #ffffff;
  color: #1b4070;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(12, 32, 64, 0.1);
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, transform 0.2s ease;
  flex-shrink: 0;
}

.b2b-row-arrow:hover:not([disabled]) {
  background: #0d5fc6;
  border-color: #0d5fc6;
  color: #ffffff;
  box-shadow: 0 6px 16px rgba(13, 95, 198, 0.35);
  transform: scale(1.06);
}

.b2b-row-arrow[disabled] {
  opacity: 0.3;
  cursor: default;
  box-shadow: none;
}

/* --- Product card --- */
.b2b-product-card {
  border-radius: 16px;
  border: 1px solid #e4edf6;
  box-shadow: 0 2px 12px rgba(12, 28, 60, 0.07);
  background: #ffffff;
  overflow: hidden;
  transition: transform 240ms ease, box-shadow 240ms ease, border-color 240ms ease;
}

.b2b-product-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 36px rgba(12, 28, 60, 0.14);
  border-color: #c8dbf0;
}

.b2b-product-image img {
  width: 100%;
  height: 195px;
  object-fit: cover;
  display: block;
  background: #f8fbff;
  transition: transform 300ms ease;
}

.b2b-product-card:hover .b2b-product-image img {
  transform: scale(1.04);
}

.b2b-discount-badge {
  top: 10px;
  left: 10px;
  background: linear-gradient(130deg, #d62b3b 0%, #b01e2e 100%);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 800;
  padding: 4px 10px;
  border-radius: 999px;
  letter-spacing: 0.03em;
  box-shadow: 0 3px 8px rgba(180, 20, 30, 0.35);
}

.b2b-product-content {
  padding: 16px;
}

.b2b-product-content h3 {
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 5px;
  color: #0d1e30;
  letter-spacing: -0.01em;
}

.b2b-product-content h3 a {
  color: #0d1e30;
  text-decoration: none;
}

.b2b-product-content h3 a:hover {
  color: #0d5fc6;
}

.b2b-product-content p {
  font-size: 0.8rem;
  color: #5d7190;
  line-height: 1.5;
  margin-bottom: 10px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Price display in cards */
.b2b-price-wrap {
  align-items: baseline;
  gap: 6px;
  margin-bottom: 10px;
}

.b2b-price-wrap strong {
  font-size: 1.05rem;
  font-weight: 800;
  color: #c01240;
  letter-spacing: -0.01em;
}

.b2b-price-wrap span {
  font-size: 0.79rem;
  color: #8e9bac;
  text-decoration: line-through;
  font-weight: 500;
}

/* Stock badges */
.b2b-stock-badge {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
}

.b2b-stock-badge.in {
  background: #e4f8f0;
  color: #127a56;
}

.b2b-stock-badge.out {
  background: #fce8e8;
  color: #a01f1f;
}

/* Card hover overlay — add to cart */
.b2b-card-hover {
  inset: auto 0 0 0;
  background: linear-gradient(to top, rgba(9, 26, 48, 0.97) 0%, rgba(9, 26, 48, 0.85) 100%);
  padding: 12px 14px;
  transition: transform 240ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

.b2b-card-stock {
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.b2b-add-cart {
  background: linear-gradient(130deg, #f5ba30 0%, #e89e05 100%);
  color: #1e1400;
  font-size: 0.78rem;
  font-weight: 800;
  border-radius: 999px;
  padding: 8px 14px;
  border: none;
  cursor: pointer;
  letter-spacing: 0.01em;
  box-shadow: 0 4px 10px rgba(232, 158, 5, 0.4);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  white-space: nowrap;
}

.b2b-add-cart:hover:not([disabled]) {
  transform: scale(1.04);
  box-shadow: 0 6px 14px rgba(232, 158, 5, 0.55);
}

.b2b-add-cart[disabled] {
  background: #b0bac7;
  color: #e8edf2;
  box-shadow: none;
  cursor: not-allowed;
}

/* Row track scroll style */
.b2b-row-track {
  scrollbar-width: thin;
  scrollbar-color: #c0d0e0 #f4f8fc;
  padding: 8px 2px 12px;
  gap: 18px;
}

/* --- Category quick links (homepage if present) --- */
.b2b-quick-link {
  border: 1px solid #dde8f2;
  border-radius: 16px;
  padding: 16px;
  background: linear-gradient(140deg, #ffffff 0%, #f2f8fd 100%);
  transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
  text-decoration: none;
}

.b2b-quick-link:hover {
  border-color: #b8d0ea;
  box-shadow: 0 8px 22px rgba(12, 28, 60, 0.12);
  transform: translateY(-3px);
}

.b2b-quick-link strong {
  font-size: 0.94rem;
  font-weight: 800;
  color: #0f1e30;
  letter-spacing: -0.01em;
}

.b2b-quick-link span {
  font-size: 0.78rem;
  color: #607080;
  margin-top: 4px;
  line-height: 1.45;
}

/* --- Footer polish --- */
.b2b-footer {
  background: linear-gradient(135deg, #0b1a2c 0%, #0f2640 100%);
  margin-top: 28px;
  padding: 36px 28px;
}

.b2b-footer h4 {
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin-bottom: 10px;
}

.b2b-footer p {
  font-size: 0.84rem;
  line-height: 1.7;
  color: #a8bed8;
  max-width: 380px;
}

.b2b-footer nav {
  gap: 10px 18px;
  flex-wrap: wrap;
}

.b2b-footer nav a {
  font-size: 0.84rem;
  font-weight: 600;
  color: #aec3da;
  text-decoration: none;
  transition: color 0.2s ease;
}

.b2b-footer nav a:hover {
  color: #ffffff;
}

/* --- Account dropdown polish --- */
.b2b-account-trigger {
  transition: background 0.2s ease, border-color 0.2s ease;
}

.b2b-account-trigger:hover {
  background: #eef5ff;
  border-color: #9ec0e8;
}

/* --- Mobile panel --- */
.b2b-mobile-categories summary {
  font-size: 0.9rem;
  font-weight: 700;
  color: #0d1e30;
  padding: 12px 0;
}

.b2b-mobile-sub a {
  font-size: 0.83rem;
  color: #3a5470;
  font-weight: 500;
}

/* --- Scrollbar global polish --- */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: #f0f4f8;
}

::-webkit-scrollbar-thumb {
  background: #c0cede;
  border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
  background: #9ab0c8;
}

/* --- Responsive overrides --- */
@media (max-width: 991px) {
  .b2b-hero {
    margin: 12px 12px 0;
  }

  .b2b-hero-grid {
    padding: 38px 28px;
    grid-template-columns: 1fr;
  }

  .b2b-hero h1 {
    font-size: 2rem;
  }

  .b2b-home-section {
    margin: 14px 12px;
    padding: 22px 18px;
  }

  .b2b-product-image img {
    height: 170px;
  }
}

@media (max-width: 767px) {
  .b2b-hero {
    margin: 10px 10px 0;
    border-radius: 16px;
  }

  .b2b-hero-grid {
    padding: 30px 22px;
  }

  .b2b-hero h1 {
    font-size: 1.75rem;
  }

  .b2b-home-section {
    margin: 12px 10px;
    padding: 18px 16px;
    border-radius: 16px;
  }

  .b2b-product-image img {
    height: 155px;
  }

  .b2b-row-arrow {
    width: 34px;
    height: 34px;
    font-size: 0.9rem;
  }
}


/* Live header overlap fix: keep Cart, Account and dropdowns above page content */
#ve-sticky,
.ve-header,
.ve-nav-wrap,
.b2b-header,
.b2b-nav-shell {
  position: relative;
  z-index: 9999;
  isolation: isolate;
}
.ve-nav-cta,
.b2b-actions,
.b2b-cart-wrap,
.b2b-account-wrap,
.ks-account-menu {
  position: relative;
  z-index: 10020;
  flex-shrink: 0;
}
.b2b-cart-dropdown,
.b2b-account-dropdown,
.ks-account-menu-list,
.ve-dropdown {
  z-index: 10050 !important;
  position: absolute;
}
.b2b-account-dropdown,
.ks-account-menu-list {
  right: 0;
  top: calc(100% + 10px);
  min-width: 220px;
}
.b2b-cart-dropdown {
  right: 0;
  top: calc(100% + 10px);
  min-width: 300px;
}
.ve-nav-wrap {
  gap: 14px;
  overflow: visible;
}
.ve-nav-cta {
  gap: 10px;
  margin-left: auto;
}
.ve-search-shell {
  max-width: 240px;
  min-width: 170px;
}
main,
.ve-hero,
.b2b-page,
.ks-section,
section {
  position: relative;
  z-index: 1;
}
@media (max-width: 991px) {
  .ve-nav-cta { display: none !important; }
  .ve-mobile-menu { z-index: 10060; position: absolute; }
  .b2b-account-dropdown,
  .b2b-cart-dropdown,
  .ks-account-menu-list { position: fixed; right: 12px; left: 12px; top: 72px; min-width: auto; max-width: none; }
}
