/* Zed Webtech Store - custom styles on top of Bootstrap 5 (minimal white / ink / coral-red) */
:root {
  --bs-primary: #fb7185;
  --bs-primary-rgb: 5, 150, 105;
  --bs-link-color: #f43f5e;
  --bs-link-hover-color: #e11d48;
  --bs-link-color-rgb: 4, 120, 87;
  --bs-link-hover-color-rgb: 6, 95, 70;
  --uc-blue: #fb7185;
  --uc-blue-dark: #f43f5e;
  --uc-indigo: #fb7185;
  --uc-ink: #141414;
  --uc-soft: #f8f7f7;
  --uc-grad: linear-gradient(135deg, #fb7185, #fdba74);
  --uc-grad-hover: linear-gradient(135deg, #f43f5e, #fb923c);
  --uc-shadow-sm: 0 1px 2px rgba(2, 6, 23, .05), 0 5px 16px rgba(2, 6, 23, .06);
  --uc-shadow-lg: 0 16px 44px rgba(2, 6, 23, .16);
  --uc-ring: rgba(251, 113, 133, .3);
}
/* Bootstrap utility recolor — soft coral, light-first */
.text-primary { color: #f43f5e !important; }
.text-bg-primary { background-color: #ffe4e6 !important; color: #e11d48 !important; }
.badge.text-bg-danger { background-color: #ffe4e6 !important; color: #e11d48 !important; }
.btn-outline-primary { --bs-btn-color: #f43f5e; --bs-btn-border-color: #fda4af; --bs-btn-hover-bg: #fb7185; --bs-btn-hover-border-color: #fb7185; --bs-btn-active-bg: #f43f5e; --bs-btn-active-border-color: #f43f5e; }
.form-check-input:checked { background-color: #fb7185; border-color: #fb7185; }
.form-check-input:focus { border-color: #fb7185; box-shadow: 0 0 0 .25rem rgba(251, 113, 133, .2); }
.spinner-border.text-primary { color: #fb7185 !important; }
.bg-primary { background-color: #fb7185 !important; }
.border-primary { border-color: #fb7185 !important; }

/* Soft indigo-slate dark palette — bright, readable, never murky */
[data-bs-theme="dark"] {
  --bs-body-bg: #16161a;
  --bs-body-color: #ececf0;
  --bs-emphasis-color: #ffffff;
  --bs-secondary-color: #b9b9c1;
  --bs-border-color: rgba(253, 164, 175, .22);
  --bs-tertiary-bg: #1d1d22;
  --bs-secondary-bg: #232329;
  --uc-soft: #1a1a1f;
  --uc-shadow-sm: 0 1px 2px rgba(0, 0, 0, .35), 0 5px 18px rgba(0, 0, 0, .28);
  --uc-shadow-lg: 0 18px 48px rgba(0, 0, 0, .5);
  --uc-ring: rgba(253, 164, 175, .45);
}
[data-bs-theme="dark"] .card { --bs-card-bg: transparent; background: linear-gradient(180deg, #222228, #1b1b20); }
[data-bs-theme="dark"] .dropdown-menu { --bs-dropdown-bg: #1d1d22; --bs-dropdown-link-color: #ececf0; --bs-dropdown-link-hover-bg: #2a2a31; --bs-dropdown-link-hover-color: #fff; }
[data-bs-theme="dark"] .accordion-item { --bs-accordion-bg: #1d1d22; --bs-accordion-btn-color: #ececf0; --bs-accordion-active-bg: rgba(253, 164, 175, .12); --bs-accordion-active-color: #fecdd3; }
[data-bs-theme="dark"] .form-control, [data-bs-theme="dark"] .form-select { background-color: #1d1d22; border-color: rgba(253, 164, 175, .3); color: #ececf0; }
[data-bs-theme="dark"] .form-control::placeholder { color: #9b9ba4; }
[data-bs-theme="dark"] .text-primary { color: #fda4af !important; }
[data-bs-theme="dark"] .text-secondary { color: #b9b9c1 !important; }
[data-bs-theme="dark"] a:not(.btn):not(.nav-link):not(.dropdown-item) { color: #fda4af; }
[data-bs-theme="dark"] .btn-outline-secondary { --bs-btn-color: #c6c6cd; --bs-btn-border-color: rgba(253, 164, 175, .42); --bs-btn-hover-bg: #2a2a31; --bs-btn-hover-color: #fff; --bs-btn-hover-border-color: rgba(253, 164, 175, .55); }
[data-bs-theme="dark"] .table { --bs-table-color: #ececf0; --bs-table-bg: transparent; --bs-table-border-color: rgba(253, 164, 175, .22); }
[data-bs-theme="dark"] .badge.text-bg-light { background-color: #232329 !important; color: #ececf0 !important; border-color: rgba(253, 164, 175, .3) !important; }
[data-bs-theme="dark"] .page-content h2 { border-bottom-color: rgba(253, 164, 175, .3); }
[data-bs-theme="dark"] .page-content thead { background: rgba(253, 164, 175, .14); }
[data-bs-theme="dark"] .ask-ai-pill { background: linear-gradient(90deg, rgba(253, 164, 175, .16), rgba(255, 146, 110, .12)); border-color: rgba(253, 164, 175, .3); }
[data-bs-theme="dark"] .shop-toolbar { background: linear-gradient(90deg, rgba(253, 164, 175, .14), rgba(255, 146, 110, .1)); border-color: rgba(253, 164, 175, .25); }

body { font-family: "Poppins", "Segoe UI", system-ui, -apple-system, sans-serif; font-weight: 400; }
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6, .display-4, .display-5, .display-6 { letter-spacing: -.025em; }
.fw-bold { font-weight: 800 !important; }
.fw-semibold { font-weight: 650 !important; }
.btn { font-weight: 650; }
.display-4, .display-5 { font-weight: 800; }
::selection { background: rgba(251, 113, 133, .18); }

/* ---------- Brand logo ---------- */
.brand-mark { flex-shrink: 0; filter: drop-shadow(0 4px 10px rgba(251, 113, 133, .35)); }
.brand-text { font-weight: 800; letter-spacing: -.02em; font-size: 1.02rem; color: var(--bs-emphasis-color); }
.brand-grad { background: linear-gradient(90deg, #fb7185, #fdba74); -webkit-background-clip: text; background-clip: text; color: transparent; }
[data-bs-theme="dark"] .brand-grad, .footer-dark .brand-grad { background: linear-gradient(90deg, #fb7185, #fdba74); -webkit-background-clip: text; background-clip: text; color: transparent; }
.brand-tag { display: block; font-size: .58rem; letter-spacing: .16em; font-weight: 700; color: var(--bs-secondary-color); }

/* Eyebrow section labels */
.eyebrow { display: inline-block; font-size: .72rem; font-weight: 800; letter-spacing: .2em; color: var(--uc-blue); text-transform: uppercase; }
[data-bs-theme="dark"] .eyebrow { color: #fb7185; }

/* Soft alternating section background */
.bg-soft { background-color: var(--uc-soft); }

/* ---------- Top bar ---------- */
.topbar { background: #141414; color: #fff; font-size: .85rem; }
.topbar strong { color: #fda4af; }
.trustbar { background: #141414; color: #cbd5e1; font-size: .8rem; border-top: 1px solid rgba(255, 255, 255, .08); }
[data-bs-theme="dark"] .topbar { background: #101013; }
[data-bs-theme="dark"] .trustbar { background: #131316; color: #d9d9df; }

/* Glassy sticky navbar */
.navbar.sticky-top { background: rgba(255, 255, 255, .86) !important; backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
[data-bs-theme="dark"] .navbar.sticky-top { background: rgba(21, 31, 56, .88) !important; }

/* ---------- Page head band ---------- */
.page-head { background: linear-gradient(135deg, #fdf1f2 0%, #f8fafc 70%); border-bottom: 1px solid var(--bs-border-color); }
[data-bs-theme="dark"] .page-head { background: linear-gradient(135deg, #2a1f24 0%, #16161a 70%); }
.breadcrumb-item + .breadcrumb-item::before { color: var(--bs-secondary-color); }
.breadcrumb a { text-decoration: none; }

/* ---------- Mega menu ---------- */
.navbar .dropdown-menu.mega { left: 0; right: 0; top: 100%; width: 100%; border-radius: 0 0 1rem 1rem; max-height: 80vh; overflow-y: auto; border-top: 0; box-shadow: var(--uc-shadow-lg); }
.mega .mega-heading, .antivirus-menu .mega-heading { font-size: .72rem; letter-spacing: .08em; color: var(--uc-blue); font-weight: 800; }
[data-bs-theme="dark"] .mega .mega-heading, [data-bs-theme="dark"] .antivirus-menu .mega-heading { color: #fb7185; }
.mega-year { display: block; font-size: .92rem; font-weight: 700; padding: .3rem 0; color: var(--bs-body-color); text-decoration: none; transition: color .15s ease, padding-left .15s ease; }
.mega-year:hover { color: var(--uc-blue); padding-left: .25rem; }
.antivirus-menu .mega-link, .mega a.mega-link { display: block; font-size: .8rem; padding: .2rem 0; color: var(--bs-secondary-color); text-decoration: none; transition: color .15s ease, padding-left .15s ease; }
.antivirus-menu .mega-link:hover, .mega a.mega-link:hover { color: var(--uc-blue); padding-left: .2rem; }
.dropdown-menu .mega-promo { border-top: 1px solid var(--bs-border-color); }
@media (min-width: 992px) {
  .navbar .dropdown:hover > .dropdown-menu { display: block; margin-top: 0; }
}

/* ---------- Cards (clean minimal layer) ---------- */
.card { border-radius: .75rem; border: 1px solid var(--bs-border-color); box-shadow: var(--uc-shadow-sm); }
.accordion-item, .card .card { box-shadow: none; }
.product-card { transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; overflow: hidden; }
.product-card:hover { transform: translateY(-5px); box-shadow: 0 0 0 2px var(--uc-ring), var(--uc-shadow-lg); border-color: transparent; }
.product-title { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 0; font-size: .88rem; font-weight: 700; transition: color .15s ease; }
.product-card:hover .product-title { color: var(--uc-blue); }
.product-img-wrap { overflow: hidden; }
/* Compact framed artwork — smaller box, no dead space */
.product-card .ratio-1x1 { --bs-aspect-ratio: 76%; }
.product-card .product-img-wrap {
  margin: .65rem .65rem 0;
  border-radius: .8rem !important;
  background: linear-gradient(180deg, #f9fafc, #edf1f8) !important;
  border: 1px solid rgba(15, 23, 42, .06);
  transition: border-color .2s ease;
}
.product-card:hover .product-img-wrap { border-color: rgba(251, 113, 133, .35); }
.product-card .badge.position-absolute { z-index: 2; }
.product-card .product-img-wrap img { mix-blend-mode: multiply; transition: transform .35s ease; padding: .9rem !important; }
.product-card .card-body { padding: .85rem 1rem 1rem; }
.product-card .card-body .small { font-size: .78rem; }
.product-img-wrap img { mix-blend-mode: multiply; transition: transform .35s ease; }
.product-card:hover .product-img-wrap img { transform: scale(1.06); }
[data-bs-theme="dark"] .product-img-wrap, [data-bs-theme="dark"] .product-card .product-img-wrap { background: #fff !important; }
.app-chip { width: 20px; height: 20px; border-radius: 5px; object-fit: contain; margin-right: 4px; }

/* ---------- Buttons: gradient color combos ---------- */
.btn { transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease, color .15s ease, border-color .15s ease, background-image .15s ease; }
.btn-primary { background-image: var(--uc-grad); border-color: transparent; }
.btn-primary:hover, .btn-primary:focus { background-image: var(--uc-grad-hover); border-color: transparent; transform: translateY(-1px); box-shadow: 0 8px 22px rgba(251, 113, 133, .35); }
.btn-primary:active { background-image: var(--uc-grad-hover) !important; border-color: transparent !important; transform: translateY(0); }
.btn-outline-primary:hover { background-image: var(--uc-grad); border-color: transparent; color: #fff; transform: translateY(-1px); box-shadow: 0 8px 22px rgba(251, 113, 133, .28); }
[data-bs-theme="dark"] .btn-outline-primary { --bs-btn-color: #fb7185; --bs-btn-border-color: rgba(253, 164, 175, .5); }

/* ---------- "For Every Business" compact card ---------- */
.biz-card { background: linear-gradient(135deg, #f43f5e, #fda4af); box-shadow: 0 14px 36px rgba(244, 63, 94, .35); }
.biz-glow { position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(220px 140px at 90% 0%, rgba(255, 255, 255, .18), transparent 70%),
              radial-gradient(180px 120px at 0% 100%, rgba(251, 191, 36, .18), transparent 70%); }
.biz-chip { display: inline-flex; align-items: center; font-size: .74rem; font-weight: 650; color: #fff;
  background: rgba(255, 255, 255, .14); border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 999px; padding: .3rem .7rem; backdrop-filter: blur(4px); }

/* ---------- Shop filter sidebar ---------- */
.filter-card { position: sticky; top: 96px; }
.filter-group-title { font-size: .72rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--uc-blue); margin-bottom: .5rem; }
[data-bs-theme="dark"] .filter-group-title { color: #fb7185; }
.filter-check { padding-top: .2rem; padding-bottom: .2rem; }
.filter-check .form-check-label { width: 100%; font-size: .88rem; cursor: pointer; }
.filter-check .form-check-input { cursor: pointer; }
.filter-check .form-check-input:checked { background-image: var(--uc-grad); background-color: var(--uc-blue); border-color: transparent; }
.filter-count { font-size: .7rem; font-weight: 700; color: var(--bs-secondary-color); background: var(--bs-tertiary-bg); border-radius: 999px; padding: .1rem .5rem; }
.view-toggle .btn { width: 38px; }

/* ---------- Content pages (policy/help) ---------- */
.page-content h2 { margin-top: 2.2rem; font-weight: 800; padding-bottom: .35rem; border-bottom: 2px solid rgba(251, 113, 133, .15); }
.page-content h3 { margin-top: 1.4rem; font-weight: 700; font-size: 1.05rem; }
.page-content table { border-radius: .6rem; overflow: hidden; }
.page-content .alert { border-radius: .9rem; }
.page-content thead { background: rgba(251, 113, 133, .08); }

/* ---------- Accordion (FAQ) ---------- */
.accordion-item { border: 1px solid var(--bs-border-color); border-radius: .9rem !important; overflow: hidden; margin-bottom: .65rem; }
.accordion-button { font-weight: 700; }
.accordion-button:focus { box-shadow: none; }
.accordion-button:not(.collapsed) { background: rgba(251, 113, 133, .06); color: var(--uc-blue); box-shadow: none; }

/* ---------- Hero ---------- */
.hero { background: linear-gradient(135deg, #fdf1f2 0%, #f8fafc 60%); position: relative; overflow: hidden; }
.hero::after { content: ''; position: absolute; inset: 0; background: radial-gradient(640px 320px at 85% 15%, rgba(251, 113, 133, .12), transparent 70%); pointer-events: none; }
[data-bs-theme="dark"] .hero { background: linear-gradient(135deg, #2a1f24 0%, #16161a 60%); }
[data-bs-theme="dark"] .hero::after { background: radial-gradient(640px 320px at 85% 15%, rgba(253, 164, 175, .2), transparent 70%); }
.hero h1 { font-weight: 800; }
.hero .accent { color: var(--uc-blue); }
[data-bs-theme="dark"] .hero .accent { color: #fda4af; }

/* ---------- Hero showcase: workspace photo + rotating product glass card ---------- */
.hero-showcase { position: relative; width: min(460px, 100%); }
.hero-showcase-frame { position: relative; border-radius: 1.4rem; overflow: hidden; aspect-ratio: 10 / 11;
  box-shadow: var(--uc-shadow-lg); border: 1px solid rgba(255, 255, 255, .45); }
.hero-showcase-img { width: 100%; height: 100%; object-fit: cover; }
.hero-showcase-overlay { position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(251, 113, 133, .1) 0%, rgba(20, 20, 20, .04) 42%, rgba(20, 20, 20, .58) 100%); }
/* Whole photo links to the product currently shown in the glass card (href synced by the rotator in main.js) */
.hero-photo-link { position: absolute; inset: 0; z-index: 1; }
.hero-apps-pill { position: absolute; top: 14px; left: 14px; z-index: 2;
  display: inline-flex; align-items: center; gap: .45rem; padding: .45rem .7rem; border-radius: 999px;
  background: rgba(255, 255, 255, .88); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 8px 22px rgba(2, 6, 23, .18); }
.hero-apps-pill img { width: 22px; height: 22px; object-fit: contain; border-radius: 5px; }
.hero-delivery-pill { position: absolute; top: 16px; right: 14px; z-index: 2;
  display: inline-flex; align-items: center; gap: .35rem; font-size: .74rem; font-weight: 750; color: #fff;
  padding: .4rem .8rem; border-radius: 999px; background: var(--uc-grad);
  box-shadow: 0 8px 22px rgba(251, 113, 133, .4); animation: pill-float 4s ease-in-out infinite; }
@keyframes pill-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
.hero-product-glass { position: absolute; left: 5%; right: 5%; bottom: 5%; height: 92px; z-index: 2;
  border-radius: 18px; overflow: hidden;
  background: rgba(255, 255, 255, .9); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, .7); box-shadow: 0 18px 44px rgba(2, 6, 23, .28); }
[data-bs-theme="dark"] .hero-product-glass { background: rgba(16, 35, 30, .9); border-color: rgba(253, 164, 175, .28); }
.hero-glass-slide { position: absolute; inset: 0; display: flex; align-items: center; gap: .8rem;
  padding: .8rem 1rem; text-decoration: none; }
.hero-glass-thumb { width: 60px; height: 60px; flex-shrink: 0; border-radius: 12px; background: #fff;
  border: 1px solid rgba(15, 23, 42, .08); display: inline-flex; align-items: center; justify-content: center; padding: 6px; }
.hero-glass-thumb img { width: 100%; height: 100%; object-fit: contain; }
.hero-glass-cta { width: 34px; height: 34px; flex-shrink: 0; border-radius: 50%;
  background: var(--uc-grad); color: #fff; display: inline-flex; align-items: center; justify-content: center;
  transition: transform .15s ease; }
.hero-glass-slide:hover .hero-glass-cta { transform: translateX(3px); }
.hero-rating-chip { position: absolute; top: 17%; left: -18px; z-index: 3; white-space: nowrap;
  animation: pill-float 4.5s ease-in-out infinite; animation-delay: 1.4s; }
@media (prefers-reduced-motion: reduce) {
  .hero-delivery-pill, .hero-rating-chip { animation: none; }
}

/* ---------- Home: Elessi-minimal centered product cards ---------- */
.product-card .card-body.text-center .product-title { font-size: .85rem; max-width: 100%; }
.btn-elessi { border: 1.5px solid var(--bs-border-color); color: var(--bs-body-color); background: transparent;
  border-radius: 999px; font-size: .8rem; font-weight: 650; letter-spacing: .02em;
  transition: background-color .18s ease, background-image .18s ease, color .18s ease, border-color .18s ease, transform .15s ease, box-shadow .15s ease; }
.btn-elessi:hover { background-image: var(--uc-grad); border-color: transparent; color: #fff;
  transform: translateY(-1px); box-shadow: 0 8px 22px rgba(251, 113, 133, .3); }
[data-bs-theme="dark"] .btn-elessi { border-color: rgba(253, 164, 175, .35); color: #ececf0; }

/* ---------- Home: Picked-for-you horizontal scroll strip ---------- */
.scroll-strip { scrollbar-width: thin; scroll-snap-type: x mandatory; }
.strip-card { width: 232px; scroll-snap-align: start; }
.strip-img { height: 132px; margin: .65rem .65rem 0; border-radius: .8rem; overflow: hidden;
  background: linear-gradient(180deg, #f9fafc, #edf1f8); border: 1px solid rgba(15, 23, 42, .06);
  display: flex; align-items: center; justify-content: center; transition: border-color .2s ease; }
.strip-img img { max-width: 100%; max-height: 100%; object-fit: contain; padding: .8rem; mix-blend-mode: multiply; transition: transform .35s ease; }
.strip-card:hover .strip-img { border-color: rgba(251, 113, 133, .35); }
.strip-card:hover .strip-img img { transform: scale(1.06); }
[data-bs-theme="dark"] .strip-img { background: #fff; }

/* ---------- Shop: wide horizontal product banners ---------- */
.shop-row:hover { transform: translateY(-3px); }
.shop-row-img { width: 132px; height: 132px; overflow: hidden;
  background: linear-gradient(180deg, #f9fafc, #edf1f8); border: 1px solid rgba(15, 23, 42, .06);
  display: flex; align-items: center; justify-content: center; transition: border-color .2s ease; }
.shop-row-img img { width: 100%; height: 100%; object-fit: contain; padding: .9rem; mix-blend-mode: multiply; transition: transform .35s ease; }
.shop-row:hover .shop-row-img { border-color: rgba(251, 113, 133, .35); }
.shop-row:hover .shop-row-img img { transform: scale(1.06); }
[data-bs-theme="dark"] .shop-row-img { background: #fff; }
.shop-row-buy { min-width: 138px; }

/* ---------- Category: compact price-list rows ---------- */
.cat-row { border-bottom: 1px solid var(--bs-border-color); transition: background-color .15s ease; }
.cat-row:last-child { border-bottom: 0; }
.cat-row:hover { background: rgba(251, 113, 133, .05); }
[data-bs-theme="dark"] .cat-row:hover { background: rgba(253, 164, 175, .08); }
.cat-thumb { width: 60px; height: 60px; flex-shrink: 0; border-radius: .7rem;
  background: linear-gradient(180deg, #f9fafc, #edf1f8); border: 1px solid rgba(15, 23, 42, .06);
  display: inline-flex; align-items: center; justify-content: center; padding: 6px; }
.cat-thumb img { width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; }
[data-bs-theme="dark"] .cat-thumb { background: #fff; }
.cat-add { width: 40px; height: 40px; padding: 0; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center; }
.min-w-0 { min-width: 0; }

/* ---------- Scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .55s ease, transform .55s ease; }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ---------- Chat widget ---------- */
#chat-bubble {
  position: fixed; bottom: 24px; right: 24px; z-index: 1080;
  width: 58px; height: 58px; border-radius: 50%;
  background: var(--uc-grad); color: #fff; border: none;
  box-shadow: 0 10px 25px rgba(251, 113, 133, .45);
  font-size: 1.4rem;
  transition: transform .2s ease, box-shadow .2s ease;
}
#chat-bubble:hover { transform: scale(1.07); box-shadow: 0 14px 32px rgba(251, 113, 133, .5); }
#chat-panel {
  position: fixed; bottom: 95px; right: 24px; z-index: 1080;
  width: 360px; max-width: calc(100vw - 32px); height: 480px;
  display: none; flex-direction: column;
  border-radius: 18px; overflow: hidden;
  box-shadow: 0 24px 60px rgba(2, 6, 23, .4);
  background: var(--bs-body-bg); border: 1px solid var(--bs-border-color);
}
#chat-panel.open { display: flex; animation: chat-pop .25s ease; }
@keyframes chat-pop { from { opacity: 0; transform: translateY(14px) scale(.97); } to { opacity: 1; transform: none; } }
#chat-head { background: var(--uc-grad); color: #fff; padding: .85rem 1rem; }
.chat-avatar { width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
  background: rgba(255, 255, 255, .2); border: 1.5px solid rgba(255, 255, 255, .45);
  display: inline-flex; align-items: center; justify-content: center; font-size: 1.05rem; }
.chat-online-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%;
  background: #4ade80; margin-right: .3rem; box-shadow: 0 0 0 2px rgba(74, 222, 128, .3);
  animation: online-pulse 2s ease-in-out infinite; }
@keyframes online-pulse { 0%, 100% { box-shadow: 0 0 0 2px rgba(74, 222, 128, .35); } 50% { box-shadow: 0 0 0 5px rgba(74, 222, 128, .12); } }
#chat-body { flex: 1; overflow-y: auto; padding: .9rem;
  background: linear-gradient(180deg, rgba(251, 113, 133, .04), transparent 120px); }
.chat-msg { max-width: 85%; padding: .6rem .85rem; border-radius: 14px; margin-bottom: .55rem;
  font-size: .85rem; line-height: 1.45; white-space: pre-wrap; }
.chat-msg.user { background: var(--uc-grad); color: #fff; margin-left: auto;
  border-bottom-right-radius: 4px; box-shadow: 0 4px 14px rgba(251, 113, 133, .3); }
.chat-msg.bot { background: var(--bs-body-bg); border: 1px solid var(--bs-border-color);
  border-bottom-left-radius: 4px; box-shadow: var(--uc-shadow-sm); }
[data-bs-theme="dark"] .chat-msg.bot { background: #1d1d22; }
.chat-msg.typing { display: inline-flex; gap: 4px; align-items: center; padding: .75rem .9rem; }
.chat-msg.typing span { width: 6px; height: 6px; border-radius: 50%; background: var(--bs-secondary-color);
  animation: typing-bounce 1.1s ease-in-out infinite; }
.chat-msg.typing span:nth-child(2) { animation-delay: .15s; }
.chat-msg.typing span:nth-child(3) { animation-delay: .3s; }
@keyframes typing-bounce { 0%, 60%, 100% { transform: translateY(0); opacity: .45; } 30% { transform: translateY(-4px); opacity: 1; } }
/* Quick suggestion chips */
.chat-chips { display: flex; flex-wrap: wrap; gap: .4rem; margin: .2rem 0 .6rem; }
.chat-chip { border: 1px solid rgba(251, 113, 133, .35); background: rgba(251, 113, 133, .06);
  color: var(--uc-blue); font-size: .74rem; font-weight: 650; border-radius: 999px;
  padding: .3rem .75rem; cursor: pointer; transition: background-color .15s ease, color .15s ease, transform .15s ease; }
.chat-chip:hover { background: var(--uc-grad); color: #fff; transform: translateY(-1px); }
[data-bs-theme="dark"] .chat-chip { color: #fda4af; border-color: rgba(253, 164, 175, .4); background: rgba(253, 164, 175, .1); }
[data-bs-theme="dark"] .chat-chip:hover { color: #fff; }
/* Talk band + input row */
.chat-talk-band { border-top: 1px solid var(--bs-border-color); background: var(--bs-tertiary-bg); color: var(--bs-secondary-color); }
.chat-input { border-radius: 999px; padding-left: 1rem; font-weight: 600;
  border: 2px solid rgba(251, 113, 133, .55);
  background: linear-gradient(90deg, rgba(251, 113, 133, .07), rgba(255, 120, 73, .06));
  box-shadow: 0 0 0 3px rgba(251, 113, 133, .12);
  animation: input-glow 2.4s ease-in-out infinite; }
.chat-input::placeholder { color: var(--uc-blue); font-weight: 650; opacity: .85; }
@keyframes input-glow {
  0%, 100% { box-shadow: 0 0 0 3px rgba(251, 113, 133, .12); }
  50% { box-shadow: 0 0 0 5px rgba(251, 113, 133, .22), 0 0 14px rgba(251, 113, 133, .25); }
}
.chat-input:focus { border-color: var(--uc-indigo); animation: none;
  background: var(--bs-body-bg); box-shadow: 0 0 0 .22rem rgba(251, 113, 133, .22); }
[data-bs-theme="dark"] .chat-input { border-color: rgba(253, 164, 175, .6);
  background: linear-gradient(90deg, rgba(253, 164, 175, .12), rgba(255, 146, 110, .1)); }
[data-bs-theme="dark"] .chat-input::placeholder { color: #fda4af; }
@media (prefers-reduced-motion: reduce) { .chat-input { animation: none; } }
.chat-send-btn { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; padding: 0;
  background: var(--uc-grad); color: #fff; border: none; font-size: .85rem;
  display: inline-flex; align-items: center; justify-content: center;
  transition: transform .15s ease, box-shadow .15s ease; }
.chat-send-btn:hover { color: #fff; transform: scale(1.08); box-shadow: 0 6px 16px rgba(251, 113, 133, .4); }

/* ---------- Misc ---------- */
.footer-dark { background: #141414; color: #b4b4bc; }
[data-bs-theme="dark"] .footer-dark { background: #141418; border-top: 1px solid rgba(253, 164, 175, .15); }
.footer-dark a { color: #d9d9df; text-decoration: none; transition: color .15s ease; }
.footer-dark a:hover { color: #fff; }
.footer-dark h6 { letter-spacing: .04em; }
.cat-chip { border: 1px solid var(--bs-border-color); border-radius: 999px; padding: .45rem 1rem; font-size: .85rem; font-weight: 600; text-decoration: none; color: var(--bs-body-color); display: inline-block; transition: border-color .15s ease, color .15s ease, background-color .15s ease; }
.cat-chip:hover { border-color: var(--uc-blue); color: var(--uc-blue); background: rgba(251, 113, 133, .05); }
.pay-option { cursor: pointer; border: 2px solid var(--bs-border-color); border-radius: 12px; transition: border-color .15s ease; }
.pay-option.active { border-color: var(--uc-blue); background: rgba(251, 113, 133, .04); }
.pay-option.active.paypal { border-color: #0070BA; background: rgba(0, 112, 186, .05); }
.btn-paypal { background: #FFC439; color: #003087; font-weight: 700; }
.btn-paypal:hover { background: #f0b62e; color: #003087; }
.logo-mark {
  width: 40px; height: 40px; border-radius: 12px;
  background: var(--uc-grad);
  color: #fff; font-weight: 800; display: inline-flex; align-items: center; justify-content: center;
}

/* Payment method mini badges (footer + checkout) */
.pay-badge {
  display: inline-block;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .03em;
  padding: .2rem .45rem;
  border-radius: .25rem;
  background: #fff;
  color: #1e293b;
  border: 1px solid rgba(0,0,0,.15);
}
[data-bs-theme="dark"] .pay-badge { background: #e2e8f0; }

/* Footer social icons */
.social-circle {
  width: 34px; height: 34px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  color: #cbd5e1 !important;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}
.social-circle:hover { background: #fb7185; color: #fff !important; transform: translateY(-2px); }

/* Unavailable variant options: blurred + non-interactive */
.variant-blur {
  filter: blur(1px);
  opacity: .45;
  pointer-events: none;
  user-select: none;
}

/* ---------- Payment & trust badge images ---------- */
.pay-icon { height: 27px; width: auto; border-radius: 4px; box-shadow: 0 1px 4px rgba(0, 0, 0, .28); background: #fff; }
.pay-icon-sm { height: 21px; }
.trust-badge-img { height: 40px; width: auto; border-radius: 8px; box-shadow: 0 1px 4px rgba(0, 0, 0, .28); }

/* ---------- Mobile fixed contact strip (inside sticky header) ---------- */
.mobile-contact-strip { border-top: 1px solid var(--bs-border-color); background: var(--bs-body-bg); }
.mobile-contact-strip .btn { white-space: nowrap; }

/* ---------- Star rating input (Write a Review) ---------- */
.star-input { display: inline-flex; flex-direction: row-reverse; gap: .2rem; font-size: 1.7rem; line-height: 1; }
.star-input input { display: none; }
.star-input label { color: #cbd5e1; cursor: pointer; transition: color .15s ease, transform .15s ease; }
.star-input label:hover { transform: scale(1.12); }
.star-input label:hover, .star-input label:hover ~ label, .star-input input:checked ~ label { color: #f59e0b; }

/* ---------- Hero image rotator (5 slides, 10s each) ---------- */
/* Hidden slides must NOT catch clicks — only the visible one is interactive */
.hero-slide { opacity: 0; transition: opacity .9s ease; z-index: 1; pointer-events: none; visibility: hidden; }
.hero-slide.active { opacity: 1; pointer-events: auto; visibility: visible; }
.hero-dots { position: relative; z-index: 3; }
.hero-dot { width: 24px; height: 8px; border-radius: 999px; border: none; padding: 0; cursor: pointer;
  background: rgba(251, 113, 133, .18); overflow: hidden; position: relative; transition: width .25s ease, background-color .2s ease; }
.hero-dot:hover { background: rgba(251, 113, 133, .35); }
.hero-dot.active { width: 46px; background: rgba(251, 113, 133, .22); }
.hero-dot.active::after { content: ''; position: absolute; inset: 0; border-radius: 999px;
  background: var(--uc-grad); transform-origin: left; animation: dot-progress 10s linear forwards; }
@keyframes dot-progress { from { transform: scaleX(0); } to { transform: scaleX(1); } }
[data-bs-theme="dark"] .hero-dot { background: rgba(253, 164, 175, .22); }
@media (prefers-reduced-motion: reduce) { .hero-dot.active::after { animation: none; transform: none; } }

/* ---------- Ask AI compact pill ---------- */
.ask-ai-pill { border-radius: 999px; background: linear-gradient(90deg, rgba(251, 113, 133, .1), rgba(251, 113, 133, .08));
  border: 1px solid rgba(251, 113, 133, .18); }
.ask-ai-mark { width: 34px; height: 34px; border-radius: 10px; font-size: .95rem; }

/* ---------- OS icons (Windows / Mac) ---------- */
.os-icon { width: 16px; height: 16px; object-fit: contain; vertical-align: -3px; }
.os-icon-lg { width: 22px; height: 22px; vertical-align: -5px; }
.os-badge { background: var(--bs-tertiary-bg); color: var(--bs-body-color); border: 1px solid var(--bs-border-color); font-weight: 650; }
.btn-primary .os-icon { filter: drop-shadow(0 0 1px rgba(255, 255, 255, .8)); }

/* ---------- Shop toolbar + colorful sort ---------- */
.shop-toolbar { border-radius: 1rem; background: linear-gradient(90deg, rgba(251, 113, 133, .08), rgba(255, 120, 73, .07));
  border: 1px solid rgba(251, 113, 133, .15); }
.sort-label { background: var(--uc-grad); color: #fff; border-radius: 999px; padding: .32rem .85rem; font-size: .78rem; font-weight: 750; }
.sort-select { border: 2px solid rgba(251, 113, 133, .45); border-radius: 999px; font-weight: 700; color: var(--uc-blue);
  box-shadow: 0 2px 8px rgba(251, 113, 133, .12); padding-left: .9rem; }
.sort-select:focus { border-color: var(--uc-indigo); box-shadow: 0 0 0 .2rem rgba(251, 113, 133, .15); }
[data-bs-theme="dark"] .sort-select { color: #fb7185; border-color: rgba(253, 164, 175, .5); }

/* ---------- Header alignment ---------- */
.navbar .navbar-nav .nav-link { display: flex; align-items: center; }
.navbar-brand .brand-text { white-space: nowrap; }

/* ---------- Footer alignment ---------- */
.footer-dark h6 { margin-bottom: 1rem !important; }
.footer-dark ul li a { display: inline-block; padding: .05rem 0; }

/* ---------- Added-to-cart button state ---------- */
.add-to-cart-btn.added { background-image: linear-gradient(135deg, #16a34a, #15803d); border-color: transparent; color: #fff; }
.add-to-cart-btn.added:hover, .add-to-cart-btn.added:focus { background-image: linear-gradient(135deg, #15803d, #166534); border-color: transparent; color: #fff; box-shadow: 0 8px 22px rgba(22, 163, 74, .35); transform: translateY(-1px); }

/* ---------- Cart remove button ---------- */
.cart-remove-btn { width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
  border: 1px solid rgba(220, 38, 38, .3); background: rgba(220, 38, 38, .08); color: #dc2626;
  display: inline-flex; align-items: center; justify-content: center; font-size: .95rem;
  transition: background-color .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease; }
.cart-remove-btn:hover { background: linear-gradient(135deg, #ef4444, #b91c1c); color: #fff;
  transform: scale(1.1) rotate(8deg); box-shadow: 0 6px 16px rgba(220, 38, 38, .4); }
[data-bs-theme="dark"] .cart-remove-btn { background: rgba(248, 113, 113, .14); color: #f87171; border-color: rgba(248, 113, 113, .35); }
[data-bs-theme="dark"] .cart-remove-btn:hover { color: #fff; }

/* ---------- Checkout flow stepper ---------- */
.checkout-steps { gap: .6rem; }
.checkout-steps .step { display: flex; align-items: center; gap: .45rem; }
.step-dot { width: 38px; height: 38px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  background: var(--bs-tertiary-bg); color: var(--bs-secondary-color); border: 2px solid var(--bs-border-color); font-size: .95rem;
  transition: box-shadow .2s ease; }
.step-label { font-size: .82rem; font-weight: 750; color: var(--bs-secondary-color); }
.step.done .step-dot { background: rgba(22, 163, 74, .12); color: #16a34a; border-color: rgba(22, 163, 74, .45); }
.step.done .step-label { color: #16a34a; }
.step.active .step-dot { background: var(--uc-grad); color: #fff; border-color: transparent; animation: step-pulse 2.2s ease-in-out infinite; }
.step.active .step-label { color: var(--uc-blue); }
[data-bs-theme="dark"] .step.active .step-label { color: #fda4af; }
.step-line { flex: 0 0 44px; height: 3px; border-radius: 3px; background: var(--bs-border-color); }
.step-line.done { background: linear-gradient(90deg, #16a34a, #fb7185); }
@keyframes step-pulse { 0%, 100% { box-shadow: 0 6px 16px rgba(251, 113, 133, .35); } 50% { box-shadow: 0 6px 24px rgba(251, 113, 133, .6); } }

/* ---------- Checkout summary + assist cards ---------- */
.summary-card { overflow: hidden; }
.summary-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--uc-grad); }
.summary-total { background: linear-gradient(90deg, rgba(251, 113, 133, .1), rgba(255, 120, 73, .08)); border: 1px solid rgba(251, 113, 133, .22); }
[data-bs-theme="dark"] .summary-total { background: linear-gradient(90deg, rgba(253, 164, 175, .14), rgba(255, 146, 110, .1)); border-color: rgba(253, 164, 175, .28); }
.assist-card { border: 1.5px dashed rgba(251, 113, 133, .35); border-radius: .9rem;
  background: linear-gradient(135deg, rgba(251, 113, 133, .06), rgba(255, 120, 73, .05)); }
[data-bs-theme="dark"] .assist-card { border-color: rgba(253, 164, 175, .4); background: linear-gradient(135deg, rgba(253, 164, 175, .1), rgba(255, 146, 110, .08)); }

/* ---------- Checkout phone: flag | code | number ---------- */
.phone-flag { font-size: 1.15rem; background: var(--bs-tertiary-bg); border-right: 0; }
.phone-code { font-weight: 700; color: var(--uc-blue); }
[data-bs-theme="dark"] .phone-code { color: #fda4af; }

/* ---------- Checkout canvas: stacked receipt-style banners ---------- */
.checkout-canvas { background: linear-gradient(180deg, #131316 0%, #1f1f27 55%, #131316 100%); }
[data-bs-theme="dark"] .checkout-canvas { background: linear-gradient(180deg, #101013 0%, #1e1e28 55%, #101013 100%); }
.checkout-canvas .step-label { color: #c6c6cd; }
.checkout-canvas .step.done .step-label { color: #4ade80; }
.checkout-canvas .step.active .step-label { color: #fda4af; }
.checkout-canvas .step-dot { background: rgba(255, 255, 255, .08); border-color: rgba(255, 255, 255, .22); color: #c6c6cd; }
.checkout-canvas .step.done .step-dot { background: rgba(74, 222, 128, .15); color: #4ade80; border-color: rgba(74, 222, 128, .45); }
.checkout-canvas .step.active .step-dot { background: var(--uc-grad); color: #fff; border-color: transparent; }
.checkout-canvas .step-line { background: rgba(255, 255, 255, .16); }
.checkout-canvas .step-line.done { background: linear-gradient(90deg, #4ade80, #22c55e); }
.checkout-canvas .back-to-cart { color: #fda4af; }
.co-banner { border: none; border-radius: 18px; box-shadow: 0 18px 44px rgba(2, 6, 23, .35); }
.receipt-amount { font-size: 2.6rem; letter-spacing: -1px; line-height: 1.1; }

/* Stylish banner columns: numbered heads + refined fields */
.co-head { border-bottom: 1px dashed var(--bs-border-color); padding-bottom: .85rem; }
.co-num { width: 38px; height: 38px; border-radius: 12px; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--uc-grad); color: #fff; font-weight: 800; font-size: 1rem;
  box-shadow: 0 6px 16px rgba(251, 113, 133, .35); }
.co-head-icon { font-size: 1.4rem; color: var(--uc-blue); opacity: .35; }
.co-banner .form-label { font-size: .76rem; font-weight: 750; text-transform: uppercase; letter-spacing: .04em; color: var(--bs-secondary-color); margin-bottom: .3rem; }
.co-banner .form-control, .co-banner .form-select { border-radius: .65rem; padding: .6rem .85rem;
  background: var(--bs-tertiary-bg); border: 1.5px solid transparent;
  transition: border-color .15s ease, background-color .15s ease, box-shadow .15s ease; }
.co-banner .form-control:hover, .co-banner .form-select:hover { border-color: rgba(251, 113, 133, .25); }
.co-banner .form-control:focus, .co-banner .form-select:focus { background: var(--bs-body-bg);
  border-color: var(--uc-blue); box-shadow: 0 0 0 .2rem rgba(251, 113, 133, .12); }
.co-banner .input-group .form-control, .co-banner .input-group .form-select { border-radius: 0; }
.co-banner .input-group > :first-child { border-top-left-radius: .65rem; border-bottom-left-radius: .65rem; }
.co-banner .input-group > :last-child { border-top-right-radius: .65rem; border-bottom-right-radius: .65rem; }
[data-bs-theme="dark"] .co-banner .form-control, [data-bs-theme="dark"] .co-banner .form-select { background: #1b1b20; }
[data-bs-theme="dark"] .co-banner .form-control:focus, [data-bs-theme="dark"] .co-banner .form-select:focus { background: #1d1d22; border-color: #fda4af; }

/* Payment tiles — short & sweet */
.pay-tile { border-radius: 14px; }
.pay-tile:hover { border-color: rgba(251, 113, 133, .5); }
.pay-option.active { box-shadow: 0 0 0 3px rgba(251, 113, 133, .14); }
.pay-option.active.paypal { box-shadow: 0 0 0 3px rgba(0, 112, 186, .14); }

/* Card details drop-down reveal */
.card-form-reveal { animation: card-reveal .3s ease; }
.card-form-reveal.d-none { animation: none; }
@keyframes card-reveal { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }

/* Live card brand detection icons */
.card-brands { gap: .3rem; }
.card-brand-icon { height: 18px; width: auto; border-radius: 3px; opacity: .45;
  transition: opacity .2s ease, filter .2s ease, transform .2s ease; }
.card-brand-icon.dimmed { opacity: .15; filter: grayscale(100%); }
.card-brand-icon.active { opacity: 1; transform: scale(1.2); box-shadow: 0 2px 8px rgba(251, 113, 133, .35); }

/* ---------- Order success: blue tick ---------- */
.success-tick { width: 96px; height: 96px; border-radius: 50%; margin: 0 auto;
  background: linear-gradient(135deg, #fb7185, #fb7185); color: #fff; font-size: 3rem;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 16px 40px rgba(251, 113, 133, .4);
  animation: tick-pop .55s cubic-bezier(.34, 1.56, .64, 1); }
@keyframes tick-pop { from { transform: scale(.3); opacity: 0; } to { transform: scale(1); opacity: 1; } }

/* ---------- Footer Google Maps button ---------- */
.gmap-btn { display: inline-flex; align-items: center; gap: .45rem; font-weight: 650; font-size: .78rem;
  border-color: rgba(255, 255, 255, .35); transition: background-color .2s ease, transform .2s ease, box-shadow .2s ease; }
.gmap-btn:hover { background: linear-gradient(135deg, #4285F4, #34A853); border-color: transparent;
  transform: translateY(-1px); box-shadow: 0 6px 16px rgba(66, 133, 244, .4); }
.gmap-pin { width: 20px; height: 20px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  background: #EA4335; color: #fff; font-size: .65rem; }

/* ---------- Cart badge bump ---------- */
.cart-bump { animation: cart-bump .45s cubic-bezier(.34, 1.56, .64, 1); }
@keyframes cart-bump { 0% { transform: translate(-50%, -50%) scale(1); } 40% { transform: translate(-50%, -50%) scale(1.55); } 100% { transform: translate(-50%, -50%) scale(1); } }

/* ---------- Platform segmented filter (category toolbar) ---------- */
.platform-seg { background: var(--bs-body-bg); border: 1px solid rgba(251, 113, 133, .25); border-radius: 999px; }
[data-bs-theme="dark"] .platform-seg { border-color: rgba(253, 164, 175, .3); }
.platform-pill { display: inline-flex; align-items: center; padding: .3rem .85rem; border-radius: 999px;
  font-size: .82rem; font-weight: 700; text-decoration: none; color: var(--bs-body-color);
  transition: background-color .15s ease, color .15s ease, box-shadow .15s ease; }
.platform-pill:hover { background: rgba(251, 113, 133, .08); color: var(--uc-blue); }
.platform-pill.active { background: var(--uc-grad); color: #fff !important; box-shadow: 0 4px 12px rgba(251, 113, 133, .3); }
.platform-pill.active .os-icon { filter: brightness(0) invert(1); }

/* ---------- Responsive: tablets & mobile ---------- */
@media (max-width: 991.98px) {
  .navbar-collapse { padding: .5rem 0 .85rem; }
  .navbar-collapse .navbar-nav { margin-bottom: .5rem; }
  .navbar .dropdown-menu.mega { max-height: 60vh; box-shadow: none; border: 1px solid var(--bs-border-color); border-radius: .75rem; }
  .antivirus-menu { min-width: 100% !important; box-shadow: none !important; border: 1px solid var(--bs-border-color); }
  .mega-promo .text-lg-end { text-align: left !important; }
}

@media (max-width: 767.98px) {
  .footer-dark .row.g-4 > div { text-align: center; }
  .footer-dark .row.g-4 .d-flex:not(.justify-content-center):not(.justify-content-md-start):not(.justify-content-md-end) { justify-content: center; }
  .footer-dark form { margin-left: auto; margin-right: auto; }
  .footer-dark .text-md-end .d-flex, .footer-dark .text-md-start .d-flex, .footer-dark .text-md-center .d-flex { justify-content: center; }
  .page-head .text-lg-end { text-align: left !important; }
}

@media (max-width: 575.98px) {
  .topbar { font-size: .72rem; }
  .hero h1 { font-size: 1.95rem; }
  .hero .fs-5 { font-size: 1rem !important; }
  .hero-stats { gap: 1.4rem !important; }
  .hero-stats .fs-3 { font-size: 1.3rem !important; }
  .hero-showcase { width: min(340px, 96%); margin-top: .5rem; }
  .hero-product-glass { height: 82px; }
  .hero-glass-thumb { width: 48px; height: 48px; }
  .hero-glass-cta { width: 30px; height: 30px; }
  .hero-rating-chip { left: 4px; }
  .hero-apps-pill img { width: 18px; height: 18px; }
  .page-content { overflow-x: hidden; }
  .page-content table { display: block; overflow-x: auto; }
  #chat-panel { height: min(460px, 68vh); bottom: 88px; right: 16px; }
  #chat-bubble { bottom: 18px; right: 16px; width: 52px; height: 52px; font-size: 1.25rem; }
  .pay-icon { height: 23px; }
  .trust-badge-img { height: 36px; }
  .display-4, .display-5 { font-size: 2rem; }
  .reviews-cta h2 { font-size: 1.3rem; }
}

/* ============================================================
   3D enhancements (Jan 2026) — product 360°, logo spin, 3D text
   ============================================================ */

/* --- 3D product viewer (works with single flat image) --- */
.product-3d {
  position: relative;
  perspective: 900px;
  transform-style: preserve-3d;
  cursor: grab;
}
.product-3d:active { cursor: grabbing; }
.product-3d-stage {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transform-style: preserve-3d;
  transition: transform .25s ease-out;
  animation: product-bounce 5.5s ease-in-out infinite;
}
.product-3d-stage > img {
  max-width: 92%;
  max-height: 92%;
  object-fit: contain;
  transform-style: preserve-3d;
  animation: product-spin 14s linear infinite;
  filter: drop-shadow(0 18px 26px rgba(15, 23, 42, .22));
  backface-visibility: visible;
  will-change: transform;
}
.product-3d:hover .product-3d-stage > img { animation-duration: 6s; }
.product-3d.dragging .product-3d-stage > img { animation-play-state: paused; transition: none; }
.product-3d-floor {
  position: absolute;
  left: 12%; right: 12%; bottom: 6%;
  height: 14px;
  background: radial-gradient(ellipse at center, rgba(15, 23, 42, .28) 0%, rgba(15, 23, 42, 0) 70%);
  filter: blur(2px);
  animation: product-shadow 5.5s ease-in-out infinite;
  pointer-events: none;
}
.product-3d-badge {
  position: absolute;
  bottom: 8px; left: 8px;
  z-index: 3;
  background: linear-gradient(135deg, #f43f5e, #ff7849);
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .04em;
  padding: 3px 8px;
  border-radius: 999px;
  box-shadow: 0 4px 12px rgba(244, 63, 94, .35);
  pointer-events: none;
  display: inline-flex; align-items: center; gap: 4px;
}
.product-3d-badge::before { content: "↻"; font-size: .8rem; display: inline-block; animation: badge-spin 3s linear infinite; }

@keyframes product-spin {
  0%   { transform: rotateY(-22deg) rotateX(3deg); }
  50%  { transform: rotateY( 22deg) rotateX(3deg); }
  100% { transform: rotateY(-22deg) rotateX(3deg); }
}
@keyframes product-bounce {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}
@keyframes product-shadow {
  0%, 100% { transform: scaleX(1);   opacity: .55; }
  50%      { transform: scaleX(.78); opacity: .35; }
}
@keyframes badge-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* large variant for product detail */
.product-3d-lg { min-height: 320px; }
.product-3d-lg .product-3d-stage > img { max-height: 320px; }

/* small variant for cart / checkout summary thumbs */
.product-3d-sm .product-3d-stage > img { animation-duration: 10s; }
.product-3d-sm { perspective: 500px; }

/* --- 360° rotating logo (homepage + checkout banner) --- */
.logo-3d {
  display: inline-block;
  perspective: 600px;
  transform-style: preserve-3d;
}
.logo-3d > svg, .logo-3d > .brand-mark {
  display: block;
  transform-style: preserve-3d;
  animation: logo-spin 6s linear infinite;
  filter: drop-shadow(0 6px 14px rgba(244, 63, 94, .35));
  backface-visibility: visible;
  will-change: transform;
}
.logo-3d:hover > svg, .logo-3d:hover > .brand-mark { animation-duration: 2.4s; }
@keyframes logo-spin {
  0%   { transform: rotateY(0deg)   rotateX(6deg); }
  100% { transform: rotateY(360deg) rotateX(6deg); }
}

/* --- 3D extruded text for company name --- */
.text-3d {
  font-weight: 800;
  letter-spacing: -.01em;
  background: linear-gradient(180deg, #fff 0%, #ffd8df 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow:
    0 1px 0 #ffb4be,
    0 2px 0 #ff8593,
    0 3px 0 #ff5b6c,
    0 4px 0 #f43f5e,
    0 5px 0 #d63146,
    0 6px 0 #ad2738,
    0 12px 18px rgba(15, 23, 42, .35);
  animation: text-3d-bob 4s ease-in-out infinite;
  display: inline-block;
}
.text-3d-dark {
  background: linear-gradient(180deg, #1f2937 0%, #475569 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow:
    0 1px 0 #cbd5e1,
    0 2px 0 #94a3b8,
    0 3px 0 #64748b,
    0 4px 0 #475569,
    0 5px 0 #334155,
    0 12px 18px rgba(15, 23, 42, .18);
}
.text-3d-shine {
  position: relative;
  overflow: hidden;
}
.text-3d-shine::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,.55) 48%, transparent 60%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: text-shine 3.4s linear infinite;
  pointer-events: none;
}
@keyframes text-3d-bob {
  0%, 100% { transform: translateY(0) rotateX(0deg); }
  50%      { transform: translateY(-3px) rotateX(8deg); }
}
@keyframes text-shine {
  0%   { background-position: -300% 0; }
  100% { background-position: 300% 0; }
}

/* ============================================================
   Checkout v3 — single-screen compact layout
   ============================================================ */
.checkout-v3-banner {
  background: linear-gradient(135deg, #0b1222 0%, #1f1326 55%, #311826 100%);
  color: #fff;
  padding: 18px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.checkout-v3-banner::before, .checkout-v3-banner::after {
  content: ""; position: absolute; border-radius: 50%; filter: blur(60px); opacity: .55;
}
.checkout-v3-banner::before { width: 260px; height: 260px; background: #f43f5e; left: -80px; top: -120px; }
.checkout-v3-banner::after  { width: 320px; height: 320px; background: #ff7849; right: -120px; bottom: -160px; }
.checkout-v3-banner .v3b-inner {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.checkout-v3-banner .v3b-title { font-size: clamp(1.4rem, 2.5vw, 2rem); margin: 0; }
.checkout-v3-banner .v3b-sub { font-size: .82rem; color: rgba(255,255,255,.78); letter-spacing: .12em; text-transform: uppercase; }

.checkout-v3 {
  background: linear-gradient(180deg, #f8f7f7 0%, #efeaec 100%);
  min-height: 100vh;
}
[data-bs-theme="dark"] .checkout-v3 {
  background: linear-gradient(180deg, #0a101f 0%, #131a2e 100%);
}
.checkout-v3 .v3-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
  gap: 20px;
  align-items: stretch;
}
@media (max-width: 991px) {
  .checkout-v3 .v3-grid { grid-template-columns: 1fr; }
}
.v3-card {
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: 14px;
  padding: 18px 20px;
  box-shadow: 0 6px 18px rgba(15, 23, 42, .06);
}
.v3-card + .v3-card { margin-top: 14px; }
.v3-card h6 {
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bs-secondary-color);
  margin: 0 0 10px;
  display: flex; align-items: center; gap: 8px;
}
.v3-card h6 .v3-num {
  width: 22px; height: 22px; border-radius: 50%;
  background: linear-gradient(135deg, #f43f5e, #ff7849);
  color: #fff; font-size: .72rem; font-weight: 800;
  display: inline-flex; align-items: center; justify-content: center;
}
.v3-field { margin-bottom: 8px; }
.v3-field label {
  font-size: .62rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--bs-secondary-color); display: block; margin-bottom: 3px; font-weight: 600;
}
.v3-field .form-control, .v3-field .form-select {
  padding: .42rem .65rem; font-size: .9rem; border-radius: 9px;
}
.v3-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.v3-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
@media (max-width: 575px) { .v3-row-2, .v3-row-3 { grid-template-columns: 1fr; } }

.v3-summary {
  position: sticky;
  top: 14px;
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: 14px;
  padding: 18px 20px;
  box-shadow: 0 6px 18px rgba(15, 23, 42, .06);
}
.v3-sum-item { display: flex; gap: 10px; align-items: center; padding: 6px 0; border-bottom: 1px dashed var(--bs-border-color); }
.v3-sum-item:last-of-type { border-bottom: none; }
.v3-sum-item .thumb { width: 38px; height: 38px; flex: 0 0 38px; }
.v3-sum-item .name { font-size: .82rem; font-weight: 600; line-height: 1.2; }
.v3-sum-item .meta { font-size: .7rem; color: var(--bs-secondary-color); }
.v3-sum-item .price { font-size: .85rem; font-weight: 700; color: var(--bs-primary); white-space: nowrap; }
.v3-sum-total {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 10px; padding: 10px 12px; border-radius: 10px;
  background: linear-gradient(135deg, rgba(244,63,94,.10), rgba(255,120,73,.10));
}
.v3-sum-total .v3-total-num { font-size: 1.4rem; font-weight: 800; color: var(--bs-primary); }
.v3-pay-tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
.v3-pay-tile {
  border: 1.5px solid var(--bs-border-color);
  border-radius: 10px; padding: 10px 12px;
  display: flex; align-items: center; gap: 8px;
  cursor: pointer; transition: all .15s;
  font-size: .85rem; font-weight: 600;
}
.v3-pay-tile:hover { border-color: var(--bs-primary); }
.v3-pay-tile.active { border-color: var(--bs-primary); background: rgba(244, 63, 94, .06); box-shadow: 0 0 0 3px rgba(244, 63, 94, .12); }
.v3-pay-tile img { height: 18px; }
.v3-pay-btn {
  width: 100%; padding: 12px;
  border: none; border-radius: 12px;
  background: linear-gradient(135deg, #f43f5e, #ff7849);
  color: #fff; font-weight: 800; font-size: 1rem;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: transform .15s, box-shadow .15s;
}
.v3-pay-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(244, 63, 94, .35); color: #fff; }
.v3-pay-btn.paypal { background: linear-gradient(135deg, #ffc439, #f4b400); color: #1f2937; }
.v3-trust-row { display: flex; gap: 6px; justify-content: center; align-items: center; margin-top: 8px; font-size: .7rem; color: var(--bs-secondary-color); flex-wrap: wrap; }
.v3-pay-icons { display: inline-flex; gap: 4px; align-items: center; }
.v3-pay-icons img { height: 16px; opacity: .8; }

/* Hero techie tweak — subtle blue tech tint */
.hero-techie .hero-showcase-img {
  filter: brightness(.88) contrast(1.08) saturate(1.1);
}
.hero-techie .hero-showcase-overlay {
  background:
    radial-gradient(60% 50% at 30% 30%, rgba(244, 63, 94, .14), transparent 60%),
    radial-gradient(50% 60% at 80% 70%, rgba(56, 189, 248, .18), transparent 70%);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .product-3d-stage, .product-3d-stage > img, .product-3d-floor,
  .logo-3d > svg, .logo-3d > .brand-mark, .product-3d-badge::before,
  .text-3d, .text-3d-shine::after { animation: none !important; }
}


/* ================================================================
   PREMIUM DARK-GRAY THEME OVERHAUL (Jan 2026)
   Final override layer — recolours the entire site with a slate/graphite
   palette and a single warm amber accent, replacing the previous coral.
   Applied via :root + dark variants. All `#f43f5e/#fb7185/#fda4af`
   coral usages are remapped to graphite/amber here for consistency.
   ================================================================ */
:root {
  /* graphite primary */
  --bs-primary:        #1f2937;   /* slate-800 */
  --bs-primary-rgb:    31, 41, 55;
  --bs-link-color:     #1f2937;
  --bs-link-hover-color: #0f172a; /* slate-900 */
  --bs-link-color-rgb: 31, 41, 55;
  --bs-link-hover-color-rgb: 15, 23, 42;

  /* warm gold/amber accent for prices, badges, hover */
  --uc-accent:        #d4a85a;
  --uc-accent-strong: #b58a3c;
  --uc-accent-soft:   #f4e4c1;

  --uc-blue:        #1f2937;
  --uc-blue-dark:   #0f172a;
  --uc-indigo:      #374151;
  --uc-ink:         #0a0c10;
  --uc-soft:        #f6f6f5;

  --uc-grad:       linear-gradient(135deg, #1f2937 0%, #4b5563 100%);
  --uc-grad-hover: linear-gradient(135deg, #111827 0%, #374151 100%);
  --uc-grad-accent: linear-gradient(135deg, #d4a85a 0%, #b58a3c 100%);

  --uc-shadow-sm: 0 1px 2px rgba(15, 23, 42, .05), 0 5px 16px rgba(15, 23, 42, .07);
  --uc-shadow-lg: 0 16px 44px rgba(15, 23, 42, .18);
  --uc-ring:      rgba(31, 41, 55, .25);
}

/* High-specificity recolour of every coral leftover */
body, html { color: #0a0c10; }
body { background: #f6f6f5; }

.text-primary { color: #1f2937 !important; }
.text-bg-primary { background-color: #1f2937 !important; color: #fff !important; }
.bg-primary { background-color: #1f2937 !important; }
.border-primary { border-color: #1f2937 !important; }
.badge.text-bg-danger { background-color: #fef3c7 !important; color: #92400e !important; }
.badge.text-bg-warning { background-color: #1f2937 !important; color: #d4a85a !important; }

/* Buttons */
.btn-primary, .btn.btn-primary {
  --bs-btn-bg: #1f2937; --bs-btn-border-color: #1f2937; --bs-btn-color: #fff;
  --bs-btn-hover-bg: #0f172a; --bs-btn-hover-border-color: #0f172a; --bs-btn-hover-color: #fff;
  --bs-btn-active-bg: #0f172a; --bs-btn-active-border-color: #0f172a;
  background: var(--uc-grad); border: none;
}
.btn-primary:hover, .btn.btn-primary:hover { background: var(--uc-grad-hover); transform: translateY(-1px); box-shadow: 0 10px 22px rgba(15, 23, 42, .28); }
.btn-outline-primary {
  --bs-btn-color: #1f2937; --bs-btn-border-color: #1f2937;
  --bs-btn-hover-bg: #1f2937; --bs-btn-hover-border-color: #1f2937; --bs-btn-hover-color: #fff;
  --bs-btn-active-bg: #0f172a; --bs-btn-active-border-color: #0f172a;
}
.btn-elessi { background: var(--uc-grad); color: #fff; border: none; padding: .55rem 1rem; border-radius: 999px; transition: all .18s; }
.btn-elessi:hover { background: var(--uc-grad-hover); color: #fff; transform: translateY(-1px); box-shadow: 0 10px 22px rgba(15, 23, 42, .28); }
.btn-elessi.added { background: linear-gradient(135deg, #166534, #15803d) !important; color: #fff !important; }

/* Topbar / trustbar — graphite ink, gold accent text */
.topbar { background: #0a0c10; color: #fff; }
.topbar strong { color: var(--uc-accent); }
.topbar a { color: var(--uc-accent) !important; text-decoration: underline; text-underline-offset: 3px; }
.trustbar { background: #15171c; color: #d1d5db; }
.trustbar .badge.text-bg-warning { background-color: var(--uc-accent) !important; color: #0a0c10 !important; }
.trustbar a { color: #fff; }

/* Form focus */
.form-control:focus, .form-select:focus { border-color: #1f2937; box-shadow: 0 0 0 .2rem rgba(31, 41, 55, .15); }
.form-check-input:checked { background-color: #1f2937; border-color: #1f2937; }

/* Hero accent text */
.accent, h1 .accent { color: var(--uc-accent-strong); }
.text-warning { color: var(--uc-accent-strong) !important; }
.bi-lightning-charge-fill.text-warning, .bi-star-fill.text-warning { color: var(--uc-accent) !important; }

/* Links default */
a:not(.btn):not(.nav-link):not(.dropdown-item):not(.text-decoration-none) { color: #1f2937; }
a:not(.btn):not(.nav-link):not(.dropdown-item):not(.text-decoration-none):hover { color: var(--uc-accent-strong); }

/* Brand 3D text — switch to a refined graphite→gold palette */
.text-3d {
  background: linear-gradient(180deg, #f4e4c1 0%, #d4a85a 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow:
    0 1px 0 #b58a3c,
    0 2px 0 #8a6628,
    0 3px 0 #5e4419,
    0 4px 0 #3a2a10,
    0 5px 0 #1f1409,
    0 12px 18px rgba(0, 0, 0, .55);
}
.brand-grad { background: linear-gradient(135deg, #d4a85a, #b58a3c); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* Logo: keep visible against graphite — change SVG gradient stops via filter ONLY on the new theme look (we'll redefine logo gradient inside SVG below) */
.logo-3d > svg defs linearGradient stop:first-child { stop-color: #d4a85a; }
.logo-3d > svg defs linearGradient stop:last-child  { stop-color: #1f2937; }

/* Cards & dropdowns */
.card { background-color: #fff; border-color: rgba(15, 23, 42, .08); box-shadow: var(--uc-shadow-sm); }
.dropdown-menu { border-color: rgba(15, 23, 42, .08); box-shadow: var(--uc-shadow-lg); }

/* Product card "Best Seller / Save% / Save xx%" badges */
.product-card .badge.text-bg-primary { background-color: var(--uc-accent) !important; color: #0a0c10 !important; font-weight: 700; }
.product-card .badge.text-bg-danger  { background-color: #0a0c10 !important; color: var(--uc-accent) !important; font-weight: 700; }

/* Product 3D 360° badge — graphite + gold */
.product-3d-badge { background: linear-gradient(135deg, #0a0c10, #1f2937); color: var(--uc-accent); box-shadow: 0 4px 12px rgba(15, 23, 42, .35); }

/* Checkout v3 — graphite banner */
.checkout-v3-banner { background: linear-gradient(135deg, #0a0c10 0%, #1f2937 50%, #374151 100%); }
.checkout-v3-banner::before { background: #d4a85a; opacity: .25; }
.checkout-v3-banner::after  { background: #1f2937; opacity: .65; }
.v3-card h6 .v3-num { background: var(--uc-grad); }
.v3-sum-total { background: linear-gradient(135deg, rgba(212, 168, 90, .14), rgba(31, 41, 55, .08)); }
.v3-sum-total .v3-total-num { color: var(--uc-accent-strong); }
.v3-pay-tile.active { border-color: #1f2937; background: rgba(31, 41, 55, .05); box-shadow: 0 0 0 3px rgba(31, 41, 55, .1); }
.v3-pay-btn { background: var(--uc-grad); }
.v3-pay-btn:hover { background: var(--uc-grad-hover); box-shadow: 0 8px 20px rgba(15, 23, 42, .35); }

/* Hero techie tint */
.hero-techie .hero-showcase-overlay {
  background:
    radial-gradient(60% 50% at 30% 30%, rgba(212, 168, 90, .14), transparent 60%),
    radial-gradient(50% 60% at 80% 70%, rgba(31, 41, 55, .25), transparent 70%);
}
.hero-rating-chip { color: var(--uc-accent-strong); }

/* ============================================================
   DARK MODE — graphite/onyx palette
   ============================================================ */
[data-bs-theme="dark"] {
  --bs-body-bg:    #0b0d12;
  --bs-body-color: #e5e7eb;
  --bs-emphasis-color: #f9fafb;
  --bs-secondary-color: #9ca3af;
  --bs-border-color: rgba(212, 168, 90, .18);
  --bs-tertiary-bg: #14171d;
  --bs-secondary-bg: #1a1e26;
  --uc-soft: #11141a;
}
[data-bs-theme="dark"] body, [data-bs-theme="dark"] html { color: #e5e7eb; background: #0b0d12; }
[data-bs-theme="dark"] .card { background: linear-gradient(180deg, #181c24, #11141a); border-color: rgba(212, 168, 90, .14); }
[data-bs-theme="dark"] .text-primary { color: var(--uc-accent) !important; }
[data-bs-theme="dark"] .text-secondary { color: #9ca3af !important; }
[data-bs-theme="dark"] .form-control, [data-bs-theme="dark"] .form-select { background-color: #14171d; border-color: rgba(212, 168, 90, .22); color: #e5e7eb; }
[data-bs-theme="dark"] .form-control::placeholder { color: #6b7280; }
[data-bs-theme="dark"] a:not(.btn):not(.nav-link):not(.dropdown-item) { color: var(--uc-accent); }
[data-bs-theme="dark"] .dropdown-menu { background: #14171d; border-color: rgba(212, 168, 90, .18); }
[data-bs-theme="dark"] .dropdown-item { color: #e5e7eb; }
[data-bs-theme="dark"] .dropdown-item:hover { background: #1f242d; color: #fff; }
[data-bs-theme="dark"] .table { --bs-table-color: #e5e7eb; --bs-table-border-color: rgba(212, 168, 90, .15); }
[data-bs-theme="dark"] .topbar { background: #050608; }
[data-bs-theme="dark"] .trustbar { background: #0b0d12; color: #d1d5db; }
[data-bs-theme="dark"] .checkout-v3 { background: linear-gradient(180deg, #0b0d12, #11141a); }
[data-bs-theme="dark"] .v3-card, [data-bs-theme="dark"] .v3-summary { background: #14171d; border-color: rgba(212, 168, 90, .15); }
[data-bs-theme="dark"] .product-card .badge.text-bg-primary { background-color: var(--uc-accent) !important; color: #0a0c10 !important; }
[data-bs-theme="dark"] .product-card .badge.text-bg-danger  { background-color: #0a0c10 !important; color: var(--uc-accent) !important; }

/* ================================================================
   CART POPUP — slide-in mini cart after Add to Cart
   ================================================================ */
.cart-popup {
  position: fixed;
  top: 100px;
  right: 24px;
  width: 360px;
  max-width: calc(100vw - 32px);
  background: var(--bs-body-bg);
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
  border-radius: 16px;
  box-shadow: 0 24px 60px rgba(15, 23, 42, .28);
  padding: 16px 16px 14px;
  z-index: 2100;
  transform: translateX(120%) scale(.92);
  opacity: 0;
  transition: transform .42s cubic-bezier(.22, 1, .36, 1), opacity .3s ease;
}
.cart-popup.show {
  transform: translateX(0) scale(1);
  opacity: 1;
}
.cart-popup-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.cart-popup-tick {
  width: 32px; height: 32px; flex: 0 0 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #16a34a, #15803d);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1rem;
  box-shadow: 0 6px 14px rgba(22, 163, 74, .35);
  animation: tick-pop .55s cubic-bezier(.22, 1, .36, 1) .05s both;
}
@keyframes tick-pop {
  0%   { transform: scale(0) rotate(-30deg); opacity: 0; }
  60%  { transform: scale(1.15) rotate(0deg); opacity: 1; }
  100% { transform: scale(1) rotate(0deg); }
}
.cart-popup-title { font-weight: 700; font-size: .95rem; }
.cart-popup-close {
  background: none; border: none; font-size: 1.4rem; line-height: 1;
  color: var(--bs-secondary-color); cursor: pointer; padding: 4px 6px;
  margin-left: auto; border-radius: 8px; transition: all .15s;
}
.cart-popup-close:hover { background: var(--bs-tertiary-bg); color: var(--bs-body-color); }
.cart-popup-item {
  display: flex; gap: 10px; align-items: center;
  padding: 10px; border-radius: 12px;
  background: var(--bs-tertiary-bg);
  margin-bottom: 10px;
}
.cart-popup-thumb {
  width: 52px; height: 52px; flex: 0 0 52px;
  background: #fff; border-radius: 10px; padding: 6px;
  display: flex; align-items: center; justify-content: center;
}
.cart-popup-thumb img { width: 100%; height: 100%; object-fit: contain; }
.cart-popup-name {
  font-weight: 600; font-size: .82rem; line-height: 1.25;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.cart-popup-total {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 12px; border-radius: 10px;
  background: linear-gradient(135deg, rgba(212, 168, 90, .12), rgba(31, 41, 55, .06));
  margin-bottom: 10px;
}
.cart-popup-amount { font-weight: 800; font-size: 1.15rem; color: var(--uc-accent-strong); }
.cart-popup-actions { display: flex; gap: 8px; }
.cart-popup-btn {
  flex: 1; text-align: center; padding: 9px 12px; border-radius: 10px;
  font-weight: 700; font-size: .85rem; text-decoration: none;
  transition: all .18s;
}
.cart-popup-btn.ghost {
  background: transparent; border: 1.5px solid var(--bs-border-color);
  color: var(--bs-body-color);
}
.cart-popup-btn.ghost:hover { background: var(--bs-tertiary-bg); }
.cart-popup-btn.primary {
  background: var(--uc-grad); color: #fff; border: 1.5px solid transparent;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
}
.cart-popup-btn.primary:hover { background: var(--uc-grad-hover); color: #fff; transform: translateY(-1px); box-shadow: 0 8px 18px rgba(15, 23, 42, .28); }
.cart-popup-meta { font-size: .7rem; color: var(--bs-secondary-color); text-align: center; margin-top: 8px; }
.cart-popup-meta i { color: var(--uc-accent); }

@media (max-width: 575px) {
  .cart-popup { right: 12px; left: 12px; width: auto; top: 90px; }
}

/* Add-to-cart button loading micro-interaction */
.add-to-cart-btn.is-loading {
  position: relative; pointer-events: none; opacity: .85;
}
.add-to-cart-btn.is-loading::after {
  content: ""; position: absolute; right: 12px; top: 50%; margin-top: -7px;
  width: 14px; height: 14px;
  border: 2px solid currentColor; border-right-color: transparent;
  border-radius: 50%; animation: btn-spin .7s linear infinite;
}
@keyframes btn-spin { to { transform: rotate(360deg); } }

/* Cart badge bump animation */
.cart-count-badge { transition: transform .2s; }
.cart-bump { animation: cart-bump .6s cubic-bezier(.22, 1, .36, 1); }
@keyframes cart-bump {
  0%   { transform: scale(1); }
  35%  { transform: scale(1.5); }
  100% { transform: scale(1); }
}

/* ================================================================
   FLOATING TOLL-FREE BUTTON (bottom-left, always visible)
   ================================================================ */
.call-fab {
  position: fixed;
  bottom: 92px;
  left: 18px;
  z-index: 1900;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px 10px 12px;
  background: linear-gradient(135deg, #1f2937 0%, #374151 100%);
  color: #fff !important;
  text-decoration: none;
  border-radius: 999px;
  font-weight: 700;
  font-size: .92rem;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .35), 0 0 0 4px rgba(212, 168, 90, .18);
  transition: transform .25s cubic-bezier(.22, 1, .36, 1), box-shadow .25s;
  animation: fab-pulse 2.4s ease-in-out infinite;
}
.call-fab:hover {
  transform: translateY(-2px) scale(1.03);
  color: #fff;
  box-shadow: 0 18px 36px rgba(15, 23, 42, .45), 0 0 0 6px rgba(212, 168, 90, .28);
}
.call-fab .call-fab-icon {
  width: 36px; height: 36px; flex: 0 0 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--uc-accent), var(--uc-accent-strong));
  color: #0a0c10;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  animation: fab-ring 1.6s ease-in-out infinite;
}
.call-fab .call-fab-lbl {
  display: flex; flex-direction: column; line-height: 1.1;
}
.call-fab .call-fab-lbl small {
  font-size: .62rem; color: var(--uc-accent); letter-spacing: .12em; text-transform: uppercase; font-weight: 700;
}
.call-fab .call-fab-lbl b { font-size: .96rem; }

@keyframes fab-pulse {
  0%, 100% { box-shadow: 0 12px 28px rgba(15, 23, 42, .35), 0 0 0 4px rgba(212, 168, 90, .18); }
  50%      { box-shadow: 0 12px 28px rgba(15, 23, 42, .45), 0 0 0 10px rgba(212, 168, 90, .05); }
}
@keyframes fab-ring {
  0%, 100% { transform: rotate(0deg) scale(1); }
  10%      { transform: rotate(-12deg) scale(1.05); }
  20%      { transform: rotate(12deg)  scale(1.05); }
  30%      { transform: rotate(-8deg)  scale(1.05); }
  40%      { transform: rotate(0deg)   scale(1); }
}

@media (max-width: 575px) {
  .call-fab {
    bottom: 80px; left: 10px;
    padding: 8px 14px 8px 10px;
    font-size: .82rem;
  }
  .call-fab .call-fab-icon { width: 30px; height: 30px; flex: 0 0 30px; font-size: .95rem; }
  .call-fab .call-fab-lbl small { font-size: .56rem; }
  .call-fab .call-fab-lbl b { font-size: .82rem; }
}

/* Header phone pill — make it pop even more in the trust bar */
.trustbar a[href^="tel:"] {
  background: var(--uc-accent);
  color: #0a0c10 !important;
  padding: 2px 12px;
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 4px 10px rgba(212, 168, 90, .35);
  transition: transform .2s, box-shadow .2s;
  display: inline-flex; align-items: center; gap: 6px;
}
.trustbar a[href^="tel:"]:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(212, 168, 90, .55);
  color: #0a0c10 !important;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .cart-popup, .call-fab, .call-fab .call-fab-icon, .cart-popup-tick { animation: none !important; transition: opacity .2s !important; }
}


/* ================================================================
   PREMIUM HERO — no glass-card overlay, watermark brand mark
   ================================================================ */
.hero-premium .hero-showcase-frame {
  border-radius: 1.6rem;
  box-shadow:
    0 28px 60px rgba(15, 23, 42, .22),
    0 4px 12px rgba(15, 23, 42, .08),
    inset 0 0 0 1px rgba(255, 255, 255, .08);
  position: relative;
}
.hero-premium .hero-showcase-img {
  filter: brightness(.78) contrast(1.08) saturate(1.05);
}
/* Cinematic gradient + soft top fade for depth */
.hero-premium .hero-showcase-overlay {
  background:
    radial-gradient(60% 50% at 30% 25%, rgba(212, 168, 90, .18), transparent 65%),
    radial-gradient(50% 60% at 80% 80%, rgba(31, 41, 55, .55), transparent 70%),
    linear-gradient(180deg, rgba(10, 12, 16, .15) 0%, transparent 30%, rgba(10, 12, 16, .55) 100%);
}
/* Hide the old square box completely on premium hero */
.hero-premium .hero-product-glass,
.hero-premium .hero-feature-chip { z-index: 3; }
.hero-premium .hero-product-glass { display: none !important; }

/* Big watermark "Z" — subtle, blends into the image */
.hero-watermark {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  opacity: .22;
  mix-blend-mode: screen;
  animation: hero-wm-float 9s ease-in-out infinite;
}
@keyframes hero-wm-float {
  0%, 100% { transform: translateY(0) scale(1); opacity: .22; }
  50%      { transform: translateY(-6px) scale(1.02); opacity: .3; }
}

/* Wrap-around watermark tag line (curves around the bottom area) */
.hero-watermark-tag {
  position: absolute;
  left: 0; right: 0; bottom: 14px;
  text-align: center;
  font-size: .58rem;
  letter-spacing: .35em;
  color: rgba(212, 168, 90, .42);
  font-weight: 700;
  text-transform: uppercase;
  z-index: 2;
  pointer-events: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
  padding: 0 10px;
}

/* Featured product floating chip (replaces the full glass card) */
.hero-feature-chip {
  position: absolute;
  bottom: 24px;
  right: 18px;
  z-index: 3;
  width: auto;
  height: 56px;
  pointer-events: none;
}
.hero-feature-slide {
  position: absolute;
  inset: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px 6px 6px;
  border-radius: 999px;
  background: rgba(10, 12, 16, .55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(212, 168, 90, .35);
  color: #fff;
  text-decoration: none;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .4s, transform .4s;
  pointer-events: auto;
  white-space: nowrap;
}
.hero-feature-slide.active {
  opacity: 1;
  transform: translateY(0);
}
.hero-feature-slide:hover { background: rgba(10, 12, 16, .7); border-color: rgba(212, 168, 90, .55); color: #fff; }
.hero-feature-thumb {
  width: 44px; height: 44px; flex: 0 0 44px;
  border-radius: 50%;
  background: #fff;
  padding: 5px;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 10px rgba(0, 0, 0, .25);
}
.hero-feature-thumb img { width: 100%; height: 100%; object-fit: contain; }
.hero-feature-meta { display: flex; flex-direction: column; line-height: 1.1; }
.hero-feature-eyebrow {
  font-size: .54rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--uc-accent);
  font-weight: 800;
}
.hero-feature-price {
  font-size: .92rem;
  font-weight: 800;
  color: #fff;
}

/* Rating chip — turn into a floating refined pill, off-card */
.hero-premium .hero-rating-chip {
  position: absolute;
  top: 18px;
  left: -10px;
  background: linear-gradient(135deg, #0a0c10, #1f2937);
  color: #fff;
  border: 1px solid rgba(212, 168, 90, .35);
  border-radius: 999px;
  padding: 7px 14px;
  font-size: .78rem;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(0, 0, 0, .35);
  z-index: 4;
}
.hero-premium .hero-rating-chip .text-warning { color: var(--uc-accent) !important; }

/* Refined floating pills */
.hero-premium .hero-apps-pill {
  background: rgba(10, 12, 16, .55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(212, 168, 90, .28);
  padding: 6px 10px;
  border-radius: 999px;
  z-index: 3;
}
.hero-premium .hero-delivery-pill {
  background: linear-gradient(135deg, var(--uc-accent), var(--uc-accent-strong));
  color: #0a0c10;
  border-radius: 999px;
  padding: 7px 14px;
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .02em;
  box-shadow: 0 8px 20px rgba(212, 168, 90, .35);
  z-index: 3;
}
.hero-premium .hero-delivery-pill i { color: #0a0c10 !important; }

@media (max-width: 575px) {
  .hero-premium .hero-feature-chip { right: 10px; bottom: 16px; height: 48px; }
  .hero-feature-thumb { width: 38px; height: 38px; flex: 0 0 38px; }
  .hero-feature-price { font-size: .82rem; }
  .hero-watermark-tag { font-size: .5rem; letter-spacing: .22em; }
  .hero-premium .hero-rating-chip { font-size: .68rem; padding: 5px 10px; left: 0; top: 12px; }
}

/* ================================================================
   CARD PAYMENT FORM (checkout v3) — premium reveal under Card tile
   ================================================================ */
.v3-card-form {
  display: none;
  margin-top: 12px;
  margin-bottom: 14px;
  padding: 16px;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, var(--bs-body-bg) 100%);
  border: 1px solid var(--bs-border-color);
  animation: cardform-reveal .35s cubic-bezier(.22, 1, .36, 1);
}
.v3-card-form.show { display: block; }
@keyframes cardform-reveal {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.v3-card-form .v3-field { margin-bottom: 12px; }
.v3-card-form .v3-field:last-child { margin-bottom: 0; }
.v3-card-form .v3-field label {
  font-size: .62rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--bs-secondary-color);
  font-weight: 700;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.v3-card-form .v3-field input {
  padding: .55rem .75rem;
  font-size: .95rem;
  font-weight: 600;
  letter-spacing: .04em;
  border-radius: 9px;
  border: 1.5px solid var(--bs-border-color);
  background: var(--bs-body-bg);
  color: var(--bs-body-color);
  width: 100%;
  transition: border-color .15s, box-shadow .15s, background .15s;
  font-family: 'SF Mono', Menlo, Consolas, monospace;
}
.v3-card-form .v3-field input::placeholder { color: var(--bs-secondary-color); opacity: .6; letter-spacing: .04em; }
.v3-card-form .v3-field input:focus {
  border-color: var(--uc-accent);
  box-shadow: 0 0 0 3px rgba(212, 168, 90, .22);
  background: var(--bs-body-bg);
  outline: none;
}
.v3-card-form .v3-field.valid input { border-color: #16a34a; background-color: rgba(22, 163, 74, .04); }
.v3-card-form .v3-field.invalid input { border-color: #dc2626; background-color: rgba(220, 38, 38, .04); }
.v3-card-form .v3-field-error {
  font-size: .68rem;
  color: #dc2626;
  margin-top: 3px;
  display: none;
  align-items: center;
  gap: 4px;
  font-weight: 600;
}
.v3-card-form .v3-field.invalid .v3-field-error { display: flex; }
.v3-card-form .v3-field.valid .v3-field-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: #16a34a;
  color: #fff;
  font-size: .65rem;
  margin-left: auto;
}
.v3-card-form .v3-field-check { display: none; }
.v3-card-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.v3-card-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.v3-card-input-wrap .v3-card-brand-icons {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  gap: 4px;
  pointer-events: none;
}
.v3-card-input-wrap .v3-card-brand-icons img {
  height: 16px;
  opacity: .35;
  filter: grayscale(1);
  transition: opacity .2s, filter .2s, transform .2s;
}
.v3-card-input-wrap .v3-card-brand-icons img.active {
  opacity: 1;
  filter: none;
  transform: scale(1.15);
}
.v3-card-input-wrap.has-icons input { padding-right: 110px; }
.v3-card-form .v3-cvv-wrap {
  position: relative;
}
.v3-card-form .v3-cvv-help {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--bs-secondary-color);
  cursor: help;
  font-size: .9rem;
}
.v3-card-form .v3-cvv-wrap input { padding-right: 30px; }
.v3-pay-secure-note {
  font-size: .68rem;
  color: var(--bs-secondary-color);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  margin-top: 8px;
}
.v3-pay-secure-note i { color: #16a34a; }


/* ================================================================
   LIGHT & ELEGANT THEME REFINEMENT (Jan 2026)
   Tones down the dark/bold look — soft slate primary, light surfaces,
   refined typography. This block overrides earlier definitions.
   ================================================================ */
:root {
  /* Soft slate primary (refined, not too bold) */
  --bs-primary:        #475569;   /* slate-600 */
  --bs-primary-rgb:    71, 85, 105;
  --bs-link-color:     #475569;
  --bs-link-hover-color: #334155; /* slate-700 */
  --bs-body-bg:        #fbfbfa;
  --bs-body-color:     #1f2937;
  --bs-secondary-color:#6b7280;
  --bs-tertiary-bg:    #f4f4f3;
  --bs-secondary-bg:   #eeeeed;
  --bs-border-color:   #e7e7e3;

  /* Soft muted gold accent (much lighter) */
  --uc-accent:        #b08d4a;
  --uc-accent-strong: #8e7137;
  --uc-accent-soft:   #f5edd9;

  --uc-blue:        #475569;
  --uc-blue-dark:   #334155;
  --uc-indigo:      #64748b;
  --uc-ink:         #1f2937;
  --uc-soft:        #fbfbfa;

  --uc-grad:        linear-gradient(135deg, #475569 0%, #64748b 100%);
  --uc-grad-hover:  linear-gradient(135deg, #334155 0%, #475569 100%);
  --uc-grad-accent: linear-gradient(135deg, #c8a45f 0%, #b08d4a 100%);

  --uc-shadow-sm: 0 1px 2px rgba(15, 23, 42, .04), 0 2px 8px rgba(15, 23, 42, .04);
  --uc-shadow-lg: 0 12px 32px rgba(15, 23, 42, .10);
  --uc-ring:      rgba(71, 85, 105, .18);
}

/* Body & global */
body, html { color: #1f2937; background: #fbfbfa; font-weight: 400; }
.page-content, .container { color: #1f2937; }
.fw-bold { font-weight: 700 !important; }
.fw-semibold { font-weight: 600 !important; }

/* Buttons — softer slate gradient */
.btn-primary, .btn.btn-primary {
  --bs-btn-bg: #475569; --bs-btn-border-color: #475569; --bs-btn-color: #fff;
  --bs-btn-hover-bg: #334155; --bs-btn-hover-border-color: #334155;
  background: var(--uc-grad); border: none; box-shadow: 0 2px 8px rgba(71, 85, 105, .18);
}
.btn-primary:hover, .btn.btn-primary:hover { background: var(--uc-grad-hover); box-shadow: 0 6px 16px rgba(71, 85, 105, .25); transform: translateY(-1px); }
.btn-elessi { background: var(--uc-grad); color: #fff; border: none; box-shadow: 0 2px 8px rgba(71, 85, 105, .18); }
.btn-elessi:hover { background: var(--uc-grad-hover); color: #fff; box-shadow: 0 6px 16px rgba(71, 85, 105, .25); }
.btn-elessi.added { background: linear-gradient(135deg, #4d7c4d, #3f6b3f) !important; }
.btn-outline-primary {
  --bs-btn-color: #475569; --bs-btn-border-color: #cbd5e1;
  --bs-btn-hover-bg: #475569; --bs-btn-hover-border-color: #475569; --bs-btn-hover-color: #fff;
}

/* Text + utility recolour */
.text-primary { color: #475569 !important; }
.bg-primary { background-color: #475569 !important; }
.border-primary { border-color: #cbd5e1 !important; }
.text-bg-primary { background-color: #475569 !important; color: #fff !important; }
.badge.text-bg-danger { background-color: #f8e8d3 !important; color: #8e7137 !important; font-weight: 600; }
.badge.text-bg-primary { background-color: #eef2f6 !important; color: #475569 !important; font-weight: 700; }
.badge.text-bg-warning { background-color: #f8e8d3 !important; color: #8e7137 !important; }
.bi-lightning-charge-fill.text-warning, .bi-star-fill.text-warning, .text-warning { color: #c8a45f !important; }

/* Topbar (promo strip) — soft slate ink, not pure black */
.topbar { background: #1f2937; color: #f1f5f9; font-weight: 500; }
.topbar strong { color: #c8a45f; }
.topbar a { color: #c8a45f !important; text-decoration: underline; text-underline-offset: 3px; }

/* TRUST BAR — soft light gray */
.trustbar { background: #f1f1ef; color: #4b5563; border-bottom: 1px solid #e7e7e3; }
.trustbar .badge.text-bg-warning { background-color: #c8a45f !important; color: #1f2937 !important; font-weight: 700; }
.trustbar a { color: #1f2937; }
.trustbar a[href^="tel:"] {
  background: #1f2937; color: #f5edd9 !important; padding: 3px 12px;
  border-radius: 999px; font-weight: 700; box-shadow: 0 2px 6px rgba(15, 23, 42, .15);
}
.trustbar a[href^="tel:"]:hover { background: #c8a45f; color: #1f2937 !important; }
[data-bs-theme="dark"] .trustbar { background: #15171c; color: #d1d5db; }

/* HEADER (main navbar) — light gray, clean, minimalistic */
.navbar.bg-body {
  background: #f5f5f4 !important;
  border-bottom: 1px solid #e7e7e3 !important;
  backdrop-filter: saturate(140%) blur(8px);
}
.navbar.sticky-top { box-shadow: 0 1px 0 #e7e7e3; }
.navbar .nav-link { color: #374151 !important; font-weight: 500 !important; transition: color .15s; }
.navbar .nav-link:hover, .navbar .nav-link:focus { color: #1f2937 !important; }
.navbar .nav-link.fw-semibold { font-weight: 500 !important; }
.navbar .dropdown-toggle.fw-semibold { font-weight: 500 !important; }
.navbar .btn { font-weight: 500; }
.navbar .btn-outline-secondary { border-color: #d1d5db; color: #4b5563; }
.navbar .btn-outline-secondary:hover { background: #1f2937; border-color: #1f2937; color: #fff; }

/* COMPANY LOGO — refined, less bold */
.logo-3d > svg, .logo-3d > .brand-mark {
  filter: drop-shadow(0 2px 6px rgba(15, 23, 42, .15));
  animation: logo-spin 9s linear infinite; /* slower, more refined */
}
.brand-text {
  font-family: 'Poppins', 'Inter', sans-serif;
  font-weight: 500;
  letter-spacing: -.005em;
  color: #1f2937;
  font-size: 1.18rem;
}
.brand-grad { color: #475569 !important; background: none !important; -webkit-text-fill-color: #475569 !important; font-weight: 600; }
.brand-tag {
  font-family: 'Poppins', sans-serif;
  font-size: .56rem;
  font-weight: 500;
  letter-spacing: .22em;
  color: #9ca3af;
  text-transform: uppercase;
}
/* Tone down the extruded 3D text — refined, flat, single soft shadow */
.text-3d, .text-3d-shine {
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: #1f2937 !important;
  -webkit-text-fill-color: #1f2937 !important;
  text-shadow: 0 1px 2px rgba(15, 23, 42, .12) !important;
  animation: none !important;
  font-weight: 500 !important;
}
.text-3d-shine::after { display: none !important; }
.v3b-title.text-3d-shine, .v3b-title.text-3d {
  color: #f1f5f9 !important; -webkit-text-fill-color: #f1f5f9 !important;
  font-weight: 500 !important;
  text-shadow: 0 2px 6px rgba(0, 0, 0, .35) !important;
}

/* Cards — pure white, super soft shadow */
.card {
  background-color: #ffffff;
  border-color: #ececea;
  box-shadow: 0 1px 2px rgba(15, 23, 42, .03), 0 4px 14px rgba(15, 23, 42, .04);
  border-radius: 14px;
}
.product-card { background-color: #ffffff; }
.product-card:hover { box-shadow: 0 10px 28px rgba(15, 23, 42, .08); }
.product-card .badge.text-bg-primary { background-color: #1f2937 !important; color: #c8a45f !important; }
.product-card .badge.text-bg-danger  { background-color: #fde2c2 !important; color: #8e5612 !important; }

/* Inputs */
.form-control, .form-select { background-color: #fff; border-color: #e5e7eb; color: #1f2937; }
.form-control:focus, .form-select:focus { border-color: #94a3b8; box-shadow: 0 0 0 .18rem rgba(148, 163, 184, .25); }
.form-check-input:checked { background-color: #475569; border-color: #475569; }

/* Page heads — soft */
.page-head { background: linear-gradient(180deg, #f9f9f8 0%, #ffffff 100%); border-bottom: 1px solid #e7e7e3; }

/* Section soft band */
.bg-soft { background: #f5f5f4; }

/* Toll-free FAB — refined, less heavy */
.call-fab {
  background: #ffffff;
  color: #1f2937 !important;
  border: 1px solid #e7e7e3;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .10), 0 0 0 3px rgba(176, 141, 74, .15);
  animation: fab-pulse-light 3s ease-in-out infinite;
}
.call-fab:hover { color: #1f2937; box-shadow: 0 14px 28px rgba(15, 23, 42, .16), 0 0 0 5px rgba(176, 141, 74, .22); transform: translateY(-2px); }
.call-fab .call-fab-icon { background: linear-gradient(135deg, #c8a45f, #b08d4a); color: #1f2937; }
.call-fab .call-fab-lbl small { color: #8e7137; }
@keyframes fab-pulse-light {
  0%, 100% { box-shadow: 0 10px 22px rgba(15, 23, 42, .10), 0 0 0 3px rgba(176, 141, 74, .15); }
  50%      { box-shadow: 0 12px 26px rgba(15, 23, 42, .14), 0 0 0 9px rgba(176, 141, 74, .06); }
}

/* Checkout banner — soft slate, not heavy */
.checkout-v3-banner {
  background: linear-gradient(135deg, #475569 0%, #64748b 50%, #94a3b8 100%);
  padding: 22px 0;
}
.checkout-v3-banner::before { background: #c8a45f; opacity: .18; }
.checkout-v3-banner::after  { background: #1f2937; opacity: .35; }
.checkout-v3 { background: linear-gradient(180deg, #f9f9f8 0%, #f1f1ef 100%); }
.v3-card, .v3-summary { background: #ffffff; border-color: #ececea; box-shadow: 0 1px 2px rgba(15, 23, 42, .03), 0 4px 14px rgba(15, 23, 42, .04); }
.v3-card h6 .v3-num { background: var(--uc-grad); }
.v3-sum-total { background: linear-gradient(135deg, #f5edd9, #f1f1ef); }
.v3-sum-total .v3-total-num { color: #8e7137; }
.v3-pay-btn { background: var(--uc-grad); box-shadow: 0 4px 12px rgba(71, 85, 105, .25); }
.v3-pay-btn:hover { background: var(--uc-grad-hover); box-shadow: 0 8px 20px rgba(71, 85, 105, .35); }
.v3-pay-tile.active { border-color: #475569; background: #f9f9f8; box-shadow: 0 0 0 3px rgba(71, 85, 105, .1); }
.v3-card-form { background: linear-gradient(180deg, #f9f9f8 0%, #ffffff 100%); border-color: #e7e7e3; }
.v3-card-form .v3-field input { background: #ffffff; border-color: #e5e7eb; color: #1f2937; }
.v3-card-form .v3-field input:focus { border-color: #c8a45f; box-shadow: 0 0 0 3px rgba(200, 164, 95, .25); }

/* Product 3D 360° badge — softer */
.product-3d-badge { background: linear-gradient(135deg, #475569, #64748b); color: #f5edd9; box-shadow: 0 4px 10px rgba(71, 85, 105, .25); }

/* Cart popup — soft */
.cart-popup { box-shadow: 0 24px 48px rgba(15, 23, 42, .15); border-color: #ececea; }
.cart-popup-tick { background: linear-gradient(135deg, #84cc84, #4d7c4d); box-shadow: 0 6px 14px rgba(77, 124, 77, .3); }
.cart-popup-total { background: linear-gradient(135deg, #f5edd9, #f9f9f8); }
.cart-popup-amount { color: #8e7137; }
.cart-popup-btn.primary { background: var(--uc-grad); }
.cart-popup-btn.primary:hover { background: var(--uc-grad-hover); box-shadow: 0 6px 14px rgba(71, 85, 105, .25); }

/* Hero text accent — soft slate */
h1, h2, h3 { font-weight: 700; color: #111827; }
h1 .accent, .accent { color: #8e7137; }

/* Links */
a:not(.btn):not(.nav-link):not(.dropdown-item):not(.text-decoration-none) { color: #475569; }
a:not(.btn):not(.nav-link):not(.dropdown-item):not(.text-decoration-none):hover { color: #8e7137; }

/* ================================================================
   FLOATING PRODUCT HERO — large floating product image with 3D feel
   ================================================================ */
.hero-float-stage {
  position: relative;
  width: 100%;
  min-height: 500px;
  aspect-ratio: 5 / 5;
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 1400px;
  isolation: isolate;
}
.hero-float-bg {
  position: absolute; inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  border-radius: 32px;
}
.hero-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  opacity: .55;
}
.hero-blob-a { width: 360px; height: 360px; background: #f5edd9; top: -60px; left: -40px; animation: blob-float 14s ease-in-out infinite; }
.hero-blob-b { width: 280px; height: 280px; background: #dbe5f1; bottom: -50px; right: -30px; animation: blob-float 16s ease-in-out infinite reverse; }
.hero-blob-c { width: 220px; height: 220px; background: #fae8d4; top: 40%; right: 25%; opacity: .35; animation: blob-float 18s ease-in-out infinite; }
@keyframes blob-float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(20px, -16px) scale(1.06); }
}
/* Subtle dot grid background */
.hero-grid {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(15, 23, 42, .07) 1px, transparent 1px);
  background-size: 22px 22px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 78%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 78%);
}

/* Floating product image */
.hero-float-product {
  position: relative;
  z-index: 3;
  display: block;
  width: 78%;
  max-width: 480px;
  transform-style: preserve-3d;
  animation: hero-float 6s ease-in-out infinite;
}
.hero-float-product img {
  width: 100%;
  height: auto;
  display: block;
  filter:
    drop-shadow(0 30px 32px rgba(15, 23, 42, .22))
    drop-shadow(0 8px 14px rgba(15, 23, 42, .12));
  transform: rotateY(-10deg) rotateX(6deg);
  transition: transform .35s ease, opacity .18s;
  transform-style: preserve-3d;
  cursor: pointer;
}
.hero-float-product:hover img { transform: rotateY(0deg) rotateX(2deg) scale(1.04); }
#hero-float-img.swapping { opacity: 0; transform: rotateY(-10deg) rotateX(6deg) scale(.92); }
.hero-float-shadow {
  position: absolute;
  bottom: -16px; left: 12%; right: 12%;
  height: 28px;
  background: radial-gradient(ellipse at center, rgba(15, 23, 42, .35) 0%, rgba(15, 23, 42, 0) 70%);
  filter: blur(6px);
  z-index: -1;
  animation: hero-shadow-pulse 6s ease-in-out infinite;
}
@keyframes hero-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-16px); }
}
@keyframes hero-shadow-pulse {
  0%, 100% { transform: scaleX(1);   opacity: .55; }
  50%      { transform: scaleX(.78); opacity: .35; }
}

/* Floating chips around the product */
.hero-chip {
  position: absolute;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(15, 23, 42, .06);
  border-radius: 14px;
  box-shadow: 0 12px 26px rgba(15, 23, 42, .10);
  font-size: .82rem;
  color: #1f2937;
  white-space: nowrap;
  animation: chip-bob 5s ease-in-out infinite;
}
.hero-chip small { color: #6b7280; font-size: .66rem; display: block; line-height: 1.1; }
.hero-chip b { font-weight: 700; line-height: 1.1; }
.hero-chip-rating { top: 8%; left: -4%; animation-delay: .4s; }
.hero-chip-rating .hero-chip-star {
  width: 30px; height: 30px; border-radius: 50%;
  background: linear-gradient(135deg, #c8a45f, #b08d4a);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1rem;
}
.hero-chip-delivery { top: 18%; right: -4%; animation-delay: 1.2s; }
.hero-chip-delivery i {
  width: 30px; height: 30px; border-radius: 50%;
  background: linear-gradient(135deg, #fdba74, #f97316);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
}
.hero-chip-apps { bottom: 18%; left: -2%; animation-delay: 2s; padding: 7px 12px; }
.hero-chip-apps img { width: 22px; height: 22px; object-fit: contain; }
@keyframes chip-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

/* Featured name + price card */
.hero-name-card {
  position: absolute;
  bottom: 4%;
  right: -2%;
  z-index: 4;
  background: #ffffff;
  border: 1px solid #ececea;
  border-radius: 14px;
  padding: 12px 16px;
  box-shadow: 0 14px 30px rgba(15, 23, 42, .12);
  min-width: 220px;
  max-width: 260px;
  animation: chip-bob 5s ease-in-out infinite;
  animation-delay: 2.8s;
}
.hero-name-eyebrow { font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; color: #8e7137; font-weight: 700; }
.hero-name-title { font-size: .85rem; font-weight: 600; line-height: 1.25; margin-top: 2px; color: #1f2937; }
.hero-name-price { font-size: 1.1rem; font-weight: 800; color: #8e7137; margin-top: 4px; }

/* Hide old hero-* styles when stage is present */
.hero-float-stage + .hero-showcase, .hero-float-stage .hero-showcase-frame { display: none; }

/* Responsive */
@media (max-width: 991px) {
  .hero-float-stage { min-height: 420px; aspect-ratio: auto; padding: 30px 10px 50px; }
  .hero-float-product { width: 62%; max-width: 360px; }
  .hero-chip-rating { top: 6%; left: 2%; }
  .hero-chip-delivery { top: 14%; right: 2%; }
  .hero-chip-apps { bottom: 16%; left: 2%; }
  .hero-name-card { right: 2%; bottom: 4%; min-width: 180px; }
}
@media (max-width: 575px) {
  .hero-float-stage { min-height: 360px; }
  .hero-float-product { width: 60%; max-width: 270px; }
  .hero-chip { font-size: .7rem; padding: 6px 10px; }
  .hero-chip-rating .hero-chip-star, .hero-chip-delivery i { width: 24px; height: 24px; font-size: .8rem; }
  .hero-chip-apps img { width: 16px; height: 16px; }
  .hero-name-card { padding: 8px 12px; min-width: 150px; }
  .hero-name-title { font-size: .72rem; }
  .hero-name-price { font-size: .92rem; }
}

/* ============================================================
   DARK MODE — refined light-dark (still elegant, not heavy)
   ============================================================ */
[data-bs-theme="dark"] {
  --bs-body-bg:    #1a1d23;
  --bs-body-color: #e2e4e8;
  --bs-emphasis-color: #f8fafc;
  --bs-secondary-color: #9ca3af;
  --bs-border-color: #2c3038;
  --bs-tertiary-bg: #22262d;
  --bs-secondary-bg: #2a2f37;
}
[data-bs-theme="dark"] body { background: #1a1d23; color: #e2e4e8; }
[data-bs-theme="dark"] .card { background: #22262d; border-color: #2c3038; }
[data-bs-theme="dark"] .navbar.bg-body { background: #1f232a !important; border-bottom-color: #2c3038 !important; }
[data-bs-theme="dark"] .trustbar { background: #1f232a; color: #d1d5db; }
[data-bs-theme="dark"] .topbar { background: #14171c; }
[data-bs-theme="dark"] .hero-blob-a { background: rgba(200, 164, 95, .15); }
[data-bs-theme="dark"] .hero-blob-b { background: rgba(100, 116, 139, .15); }
[data-bs-theme="dark"] .hero-blob-c { background: rgba(200, 164, 95, .1); }
[data-bs-theme="dark"] .hero-grid { background-image: radial-gradient(rgba(255, 255, 255, .07) 1px, transparent 1px); }
[data-bs-theme="dark"] .hero-chip { background: rgba(34, 38, 45, .92); color: #e2e4e8; border-color: rgba(255, 255, 255, .06); }
[data-bs-theme="dark"] .hero-chip small { color: #9ca3af; }
[data-bs-theme="dark"] .hero-name-card { background: #22262d; border-color: #2c3038; }
[data-bs-theme="dark"] .hero-name-title { color: #f1f5f9; }
[data-bs-theme="dark"] .brand-text { color: #f1f5f9; }
[data-bs-theme="dark"] .brand-grad { color: #94a3b8 !important; -webkit-text-fill-color: #94a3b8 !important; }
[data-bs-theme="dark"] .text-3d { color: #f1f5f9 !important; -webkit-text-fill-color: #f1f5f9 !important; }
[data-bs-theme="dark"] .call-fab { background: #22262d; color: #f1f5f9 !important; border-color: #2c3038; }
[data-bs-theme="dark"] .v3-card, [data-bs-theme="dark"] .v3-summary { background: #22262d; border-color: #2c3038; }
[data-bs-theme="dark"] .checkout-v3 { background: linear-gradient(180deg, #1a1d23, #14171c); }
[data-bs-theme="dark"] .form-control, [data-bs-theme="dark"] .form-select { background: #22262d; border-color: #2c3038; color: #e2e4e8; }


/* ================================================================
   DARK MODE — FINAL CONTRAST & READABILITY PASS (Jan 2026)
   Comprehensive fix for all hard-coded light-mode colors so every
   text, button, icon and surface is clearly visible in dark mode.
   ================================================================ */
[data-bs-theme="dark"] {
  --bs-body-bg:          #1a1d23;
  --bs-body-color:       #e5e7eb;
  --bs-emphasis-color:   #ffffff;
  --bs-secondary-color:  #adb5bd;
  --bs-border-color:     #353a45;
  --bs-tertiary-bg:      #232830;
  --bs-secondary-bg:     #2a303a;
  /* Slightly brighter slate primary for dark for higher contrast */
  --bs-primary:          #94a3b8;
  --bs-primary-rgb:      148, 163, 184;
  --bs-link-color:       #cbd5e1;
  --bs-link-hover-color: #ffffff;
  --uc-accent:           #d4b16a;
  --uc-accent-strong:    #e6c483;
  --uc-accent-soft:      #3b3526;
  --uc-grad:             linear-gradient(135deg, #6b7280 0%, #94a3b8 100%);
  --uc-grad-hover:       linear-gradient(135deg, #94a3b8 0%, #cbd5e1 100%);
  --uc-soft:             #14171c;
  --uc-shadow-sm: 0 1px 2px rgba(0, 0, 0, .35), 0 4px 14px rgba(0, 0, 0, .35);
  --uc-shadow-lg: 0 14px 38px rgba(0, 0, 0, .55);
  --uc-ring:      rgba(148, 163, 184, .35);
}

/* Body / global */
[data-bs-theme="dark"] body,
[data-bs-theme="dark"] html { background: #1a1d23 !important; color: #e5e7eb !important; }
[data-bs-theme="dark"] .page-content,
[data-bs-theme="dark"] .container,
[data-bs-theme="dark"] p,
[data-bs-theme="dark"] li,
[data-bs-theme="dark"] span,
[data-bs-theme="dark"] div { color: inherit; }

/* Headings — restore strong contrast (was hardcoded #111827 dark slate) */
[data-bs-theme="dark"] h1,
[data-bs-theme="dark"] h2,
[data-bs-theme="dark"] h3,
[data-bs-theme="dark"] h4,
[data-bs-theme="dark"] h5,
[data-bs-theme="dark"] h6 { color: #f8fafc !important; }
[data-bs-theme="dark"] .display-1,
[data-bs-theme="dark"] .display-2,
[data-bs-theme="dark"] .display-3,
[data-bs-theme="dark"] .display-4,
[data-bs-theme="dark"] .display-5,
[data-bs-theme="dark"] .display-6 { color: #f8fafc !important; }

/* Accent in hero — soft gold, NOT coral pink */
[data-bs-theme="dark"] .accent,
[data-bs-theme="dark"] h1 .accent,
[data-bs-theme="dark"] .hero .accent { color: #e6c483 !important; }

/* Secondary text uniformly visible */
[data-bs-theme="dark"] .text-secondary,
[data-bs-theme="dark"] small.text-secondary { color: #b6bfcc !important; }
[data-bs-theme="dark"] .text-body { color: #e5e7eb !important; }
[data-bs-theme="dark"] .text-muted { color: #adb5bd !important; }
[data-bs-theme="dark"] .text-dark { color: #e5e7eb !important; }
[data-bs-theme="dark"] .text-black { color: #f1f5f9 !important; }
[data-bs-theme="dark"] .text-primary { color: #cbd5e1 !important; }
[data-bs-theme="dark"] .text-warning { color: #e6c483 !important; }
[data-bs-theme="dark"] .text-success { color: #86efac !important; }
[data-bs-theme="dark"] .text-info { color: #93c5fd !important; }
[data-bs-theme="dark"] .text-danger { color: #fda4a4 !important; }
[data-bs-theme="dark"] .text-white { color: #f8fafc !important; }

/* Topbar / trust bar / header — clearly readable */
[data-bs-theme="dark"] .topbar { background: #11141a !important; color: #f1f5f9 !important; }
[data-bs-theme="dark"] .topbar strong, [data-bs-theme="dark"] .topbar a { color: #e6c483 !important; }
[data-bs-theme="dark"] .trustbar { background: #1f232a !important; color: #e5e7eb !important; border-bottom-color: #2c3038 !important; }
[data-bs-theme="dark"] .trustbar span,
[data-bs-theme="dark"] .trustbar a { color: #e5e7eb !important; }
[data-bs-theme="dark"] .trustbar a[href^="tel:"] { background: #e6c483 !important; color: #1a1d23 !important; box-shadow: 0 4px 10px rgba(230, 196, 131, .25); }
[data-bs-theme="dark"] .trustbar a[href^="tel:"]:hover { background: #f0d287 !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .trustbar .badge.text-bg-warning { background: #e6c483 !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .trustbar .badge.bg-white { background: #2a303a !important; color: #e5e7eb !important; }

/* Header navbar */
[data-bs-theme="dark"] .navbar.bg-body,
[data-bs-theme="dark"] .navbar { background: #1f232a !important; border-bottom-color: #353a45 !important; }
[data-bs-theme="dark"] .navbar .nav-link { color: #e5e7eb !important; }
[data-bs-theme="dark"] .navbar .nav-link:hover { color: #ffffff !important; }
[data-bs-theme="dark"] .navbar-toggler-icon { filter: invert(1) brightness(1.3); }

/* Brand / logo */
[data-bs-theme="dark"] .brand-text { color: #f1f5f9 !important; }
[data-bs-theme="dark"] .brand-grad { color: #cbd5e1 !important; -webkit-text-fill-color: #cbd5e1 !important; }
[data-bs-theme="dark"] .brand-tag { color: #94a3b8 !important; }

/* Buttons */
[data-bs-theme="dark"] .btn-outline-primary { --bs-btn-color: #cbd5e1; --bs-btn-border-color: #4b5563; --bs-btn-hover-bg: #cbd5e1; --bs-btn-hover-border-color: #cbd5e1; --bs-btn-hover-color: #1a1d23; }
[data-bs-theme="dark"] .btn-outline-secondary { --bs-btn-color: #d1d5db; --bs-btn-border-color: #4b5563; --bs-btn-hover-bg: #2a303a; --bs-btn-hover-border-color: #6b7280; --bs-btn-hover-color: #fff; }
[data-bs-theme="dark"] .btn-light { background: #2a303a !important; color: #e5e7eb !important; border-color: #353a45 !important; }
[data-bs-theme="dark"] .btn-light:hover { background: #353a45 !important; color: #fff !important; }
[data-bs-theme="dark"] .btn-success { background: linear-gradient(135deg, #16a34a, #15803d) !important; color: #fff !important; border: none !important; }

/* Cards (white→dark surface) */
[data-bs-theme="dark"] .card,
[data-bs-theme="dark"] .product-card,
[data-bs-theme="dark"] .info-card { background: #232830 !important; border-color: #353a45 !important; color: #e5e7eb; box-shadow: 0 4px 14px rgba(0, 0, 0, .35) !important; }
[data-bs-theme="dark"] .card-body { color: #e5e7eb; }
[data-bs-theme="dark"] .card .text-body,
[data-bs-theme="dark"] .card a:not(.btn) { color: #e5e7eb !important; }
[data-bs-theme="dark"] .product-card a.text-body { color: #f1f5f9 !important; }

/* Product card badges */
[data-bs-theme="dark"] .product-card .badge.text-bg-primary { background: #e6c483 !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .product-card .badge.text-bg-danger  { background: #2a303a !important; color: #e6c483 !important; }

/* Background utilities */
[data-bs-theme="dark"] .bg-light,
[data-bs-theme="dark"] .bg-body-tertiary { background: #2a303a !important; color: #e5e7eb !important; }
[data-bs-theme="dark"] .bg-white,
[data-bs-theme="dark"] .bg-body { background: #232830 !important; color: #e5e7eb !important; }
[data-bs-theme="dark"] .bg-soft { background: #1f232a !important; }
[data-bs-theme="dark"] .border, [data-bs-theme="dark"] .border-bottom, [data-bs-theme="dark"] .border-top, [data-bs-theme="dark"] .border-start, [data-bs-theme="dark"] .border-end { border-color: #353a45 !important; }
[data-bs-theme="dark"] .border-secondary-subtle { border-color: #353a45 !important; }

/* Badges */
[data-bs-theme="dark"] .badge.text-bg-light { background: #2a303a !important; color: #e5e7eb !important; border: 1px solid #353a45 !important; }
[data-bs-theme="dark"] .badge.text-bg-primary { background: #e6c483 !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .badge.text-bg-danger { background: #5a3a3a !important; color: #fda4a4 !important; }
[data-bs-theme="dark"] .badge.text-bg-warning { background: #e6c483 !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .badge.text-bg-success { background: #1e3a2a !important; color: #86efac !important; }
[data-bs-theme="dark"] .badge.text-bg-info { background: #1e3a4a !important; color: #93c5fd !important; }

/* Form controls */
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select { background: #2a303a !important; border-color: #4b5563 !important; color: #f1f5f9 !important; }
[data-bs-theme="dark"] .form-control::placeholder { color: #94a3b8 !important; opacity: 1; }
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus { border-color: #cbd5e1 !important; box-shadow: 0 0 0 .18rem rgba(203, 213, 225, .25) !important; background: #2a303a !important; color: #f1f5f9 !important; }
[data-bs-theme="dark"] .input-group-text { background: #2a303a !important; color: #e5e7eb !important; border-color: #4b5563 !important; }
[data-bs-theme="dark"] .form-label { color: #e5e7eb !important; }
[data-bs-theme="dark"] .form-check-label { color: #e5e7eb !important; }
[data-bs-theme="dark"] .form-check-input { background-color: #2a303a; border-color: #6b7280; }
[data-bs-theme="dark"] .form-check-input:checked { background-color: #cbd5e1; border-color: #cbd5e1; }

/* Dropdown */
[data-bs-theme="dark"] .dropdown-menu { background: #232830 !important; border-color: #353a45 !important; box-shadow: 0 14px 38px rgba(0, 0, 0, .55); }
[data-bs-theme="dark"] .dropdown-item { color: #e5e7eb !important; }
[data-bs-theme="dark"] .dropdown-item:hover,
[data-bs-theme="dark"] .dropdown-item:focus { background: #2a303a !important; color: #ffffff !important; }
[data-bs-theme="dark"] .dropdown-item.active,
[data-bs-theme="dark"] .dropdown-divider { border-color: #353a45 !important; }
[data-bs-theme="dark"] .dropdown-item.active { background: #2a303a !important; color: #e6c483 !important; }
[data-bs-theme="dark"] .mega-heading,
[data-bs-theme="dark"] .mega-year,
[data-bs-theme="dark"] .mega-link { color: #e5e7eb !important; }
[data-bs-theme="dark"] .mega-link.fw-bold.text-primary { color: #e6c483 !important; }

/* Tables */
[data-bs-theme="dark"] .table { --bs-table-color: #e5e7eb; --bs-table-bg: transparent; --bs-table-border-color: #353a45; --bs-table-hover-bg: #2a303a; }
[data-bs-theme="dark"] thead { background: #2a303a !important; }

/* Accordion */
[data-bs-theme="dark"] .accordion-item { background: #232830 !important; border-color: #353a45 !important; }
[data-bs-theme="dark"] .accordion-button { background: #232830 !important; color: #e5e7eb !important; }
[data-bs-theme="dark"] .accordion-button:not(.collapsed) { background: #2a303a !important; color: #e6c483 !important; }
[data-bs-theme="dark"] .accordion-button::after { filter: invert(.85) brightness(1.4); }
[data-bs-theme="dark"] .accordion-body { color: #d1d5db !important; }

/* Nav tabs */
[data-bs-theme="dark"] .nav-tabs { border-bottom-color: #353a45; }
[data-bs-theme="dark"] .nav-tabs .nav-link { color: #cbd5e1; border-color: transparent; }
[data-bs-theme="dark"] .nav-tabs .nav-link.active { background: #232830 !important; color: #e6c483 !important; border-color: #353a45 #353a45 transparent !important; }
[data-bs-theme="dark"] .tab-content { background: #232830 !important; border-color: #353a45 !important; color: #e5e7eb; }

/* Welcome-back personalized strip & info-card boxes */
[data-bs-theme="dark"] .info-card,
[data-bs-theme="dark"] .feature-card,
[data-bs-theme="dark"] .picked-card,
[data-bs-theme="dark"] .stat-card { background: #232830 !important; border-color: #353a45 !important; color: #e5e7eb !important; }
[data-bs-theme="dark"] .feature-card h6,
[data-bs-theme="dark"] .feature-card div { color: #e5e7eb !important; }
[data-bs-theme="dark"] .feature-card small { color: #adb5bd !important; }

/* Browse chips ("Office 2024 (PC)…") */
[data-bs-theme="dark"] .browse-chip,
[data-bs-theme="dark"] .btn.rounded-pill.bg-body,
[data-bs-theme="dark"] .btn.rounded-pill[class*="bg-light"] { background: #2a303a !important; color: #e5e7eb !important; border-color: #353a45 !important; }
[data-bs-theme="dark"] a.btn.rounded-pill { color: #e5e7eb; border-color: #353a45; background: #2a303a; }
[data-bs-theme="dark"] a.btn.rounded-pill:hover { color: #fff; background: #353a45; }

/* Hero refinements */
[data-bs-theme="dark"] .hero,
[data-bs-theme="dark"] .hero-stats div { color: #e5e7eb !important; }
[data-bs-theme="dark"] .hero-stats small { color: #adb5bd !important; }
[data-bs-theme="dark"] .hero h1 { color: #f8fafc !important; }
[data-bs-theme="dark"] .hero p,
[data-bs-theme="dark"] .hero li,
[data-bs-theme="dark"] .hero ul { color: #d1d5db !important; }

/* Hero floating chips / blobs in dark mode */
[data-bs-theme="dark"] .hero-chip { background: rgba(35, 40, 48, .92) !important; color: #e5e7eb !important; border-color: rgba(255, 255, 255, .08) !important; box-shadow: 0 10px 26px rgba(0, 0, 0, .45) !important; }
[data-bs-theme="dark"] .hero-chip small { color: #adb5bd !important; }
[data-bs-theme="dark"] .hero-chip b { color: #f1f5f9 !important; }
[data-bs-theme="dark"] .hero-chip-rating .hero-chip-star { background: linear-gradient(135deg, #e6c483, #d4b16a); color: #1a1d23; }
[data-bs-theme="dark"] .hero-chip-delivery i { background: linear-gradient(135deg, #fdba74, #f97316); color: #1a1d23; }
[data-bs-theme="dark"] .hero-name-card { background: #232830 !important; border-color: #353a45 !important; }
[data-bs-theme="dark"] .hero-name-card .hero-name-title { color: #f8fafc !important; }
[data-bs-theme="dark"] .hero-name-card .hero-name-eyebrow { color: #e6c483 !important; }
[data-bs-theme="dark"] .hero-name-card .hero-name-price { color: #e6c483 !important; }
[data-bs-theme="dark"] .hero-blob-a { background: rgba(230, 196, 131, .12); }
[data-bs-theme="dark"] .hero-blob-b { background: rgba(148, 163, 184, .12); }
[data-bs-theme="dark"] .hero-blob-c { background: rgba(230, 196, 131, .08); }
[data-bs-theme="dark"] .hero-grid { background-image: radial-gradient(rgba(255, 255, 255, .07) 1px, transparent 1px); }

/* Page head / breadcrumb */
[data-bs-theme="dark"] .page-head { background: linear-gradient(180deg, #1f232a 0%, #1a1d23 100%) !important; border-bottom-color: #353a45 !important; }
[data-bs-theme="dark"] .page-head h1,
[data-bs-theme="dark"] .page-head .h2 { color: #f8fafc !important; }
[data-bs-theme="dark"] .breadcrumb-item,
[data-bs-theme="dark"] .breadcrumb-item.active { color: #adb5bd !important; }
[data-bs-theme="dark"] .breadcrumb-item a { color: #cbd5e1 !important; }

/* Buttons used in dark hero / browse / "Welcome back" */
[data-bs-theme="dark"] .btn-link { color: #cbd5e1 !important; }
[data-bs-theme="dark"] .btn-link:hover { color: #fff !important; }
[data-bs-theme="dark"] .btn.btn-primary { background: linear-gradient(135deg, #94a3b8, #cbd5e1) !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .btn.btn-primary:hover { background: linear-gradient(135deg, #cbd5e1, #f1f5f9) !important; color: #0f172a !important; box-shadow: 0 8px 20px rgba(203, 213, 225, .25) !important; }
[data-bs-theme="dark"] .btn-elessi { background: linear-gradient(135deg, #94a3b8, #cbd5e1) !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .btn-elessi:hover { background: linear-gradient(135deg, #cbd5e1, #f1f5f9) !important; color: #0f172a !important; }
[data-bs-theme="dark"] .btn-elessi.added { background: linear-gradient(135deg, #16a34a, #15803d) !important; color: #fff !important; }

/* Sale prices / strike-through */
[data-bs-theme="dark"] .text-decoration-line-through { color: #94a3b8 !important; }

/* Reviews / star colors stay gold */
[data-bs-theme="dark"] .bi-star-fill, [data-bs-theme="dark"] .bi-star-half { color: #e6c483 !important; }

/* Cart popup */
[data-bs-theme="dark"] .cart-popup { background: #232830 !important; border-color: #353a45 !important; color: #e5e7eb; box-shadow: 0 24px 60px rgba(0, 0, 0, .65) !important; }
[data-bs-theme="dark"] .cart-popup-title { color: #f1f5f9 !important; }
[data-bs-theme="dark"] .cart-popup-name { color: #f1f5f9 !important; }
[data-bs-theme="dark"] .cart-popup-item { background: #2a303a !important; }
[data-bs-theme="dark"] .cart-popup-thumb { background: #f1f5f9; }
[data-bs-theme="dark"] .cart-popup-total { background: linear-gradient(135deg, #3a3326, #2a303a) !important; }
[data-bs-theme="dark"] .cart-popup-amount { color: #e6c483 !important; }
[data-bs-theme="dark"] .cart-popup-btn.ghost { color: #e5e7eb !important; border-color: #4b5563 !important; }
[data-bs-theme="dark"] .cart-popup-btn.ghost:hover { background: #2a303a !important; }
[data-bs-theme="dark"] .cart-popup-btn.primary { background: linear-gradient(135deg, #94a3b8, #cbd5e1) !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .cart-popup-btn.primary:hover { background: linear-gradient(135deg, #cbd5e1, #f1f5f9) !important; color: #0f172a !important; }
[data-bs-theme="dark"] .cart-popup-meta { color: #adb5bd !important; }
[data-bs-theme="dark"] .cart-popup-close { color: #adb5bd !important; }
[data-bs-theme="dark"] .cart-popup-close:hover { background: #2a303a !important; color: #fff !important; }

/* Toll-free FAB */
[data-bs-theme="dark"] .call-fab { background: #232830 !important; color: #f1f5f9 !important; border-color: #353a45 !important; box-shadow: 0 10px 26px rgba(0, 0, 0, .55), 0 0 0 3px rgba(230, 196, 131, .22) !important; }
[data-bs-theme="dark"] .call-fab:hover { color: #fff !important; box-shadow: 0 14px 32px rgba(0, 0, 0, .65), 0 0 0 6px rgba(230, 196, 131, .3) !important; }
[data-bs-theme="dark"] .call-fab .call-fab-icon { background: linear-gradient(135deg, #e6c483, #d4b16a) !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .call-fab .call-fab-lbl small { color: #e6c483 !important; }

/* Checkout v3 */
[data-bs-theme="dark"] .checkout-v3 { background: linear-gradient(180deg, #1a1d23 0%, #14171c 100%) !important; }
[data-bs-theme="dark"] .checkout-v3-banner { background: linear-gradient(135deg, #1f232a 0%, #2a303a 50%, #353a45 100%) !important; }
[data-bs-theme="dark"] .v3-card, [data-bs-theme="dark"] .v3-summary { background: #232830 !important; border-color: #353a45 !important; color: #e5e7eb !important; }
[data-bs-theme="dark"] .v3-card h6,
[data-bs-theme="dark"] .v3-summary h6 { color: #adb5bd !important; }
[data-bs-theme="dark"] .v3-card .v3-field label,
[data-bs-theme="dark"] .v3-summary .meta { color: #adb5bd !important; }
[data-bs-theme="dark"] .v3-sum-item .name { color: #f1f5f9 !important; }
[data-bs-theme="dark"] .v3-sum-total { background: linear-gradient(135deg, #3a3326, #2a303a) !important; }
[data-bs-theme="dark"] .v3-sum-total .v3-total-num { color: #e6c483 !important; }
[data-bs-theme="dark"] .v3-pay-tile { background: #2a303a !important; border-color: #353a45 !important; color: #e5e7eb !important; }
[data-bs-theme="dark"] .v3-pay-tile.active { border-color: #cbd5e1 !important; background: #353a45 !important; box-shadow: 0 0 0 3px rgba(203, 213, 225, .12) !important; }
[data-bs-theme="dark"] .v3-pay-btn { background: linear-gradient(135deg, #94a3b8, #cbd5e1) !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .v3-pay-btn:hover { background: linear-gradient(135deg, #cbd5e1, #f1f5f9) !important; color: #0f172a !important; }
[data-bs-theme="dark"] .v3-card-form { background: #2a303a !important; border-color: #353a45 !important; }
[data-bs-theme="dark"] .v3-card-form .v3-field input { background: #232830 !important; color: #f1f5f9 !important; border-color: #4b5563 !important; }
[data-bs-theme="dark"] .v3-card-form .v3-field input:focus { border-color: #e6c483 !important; box-shadow: 0 0 0 3px rgba(230, 196, 131, .25) !important; }
[data-bs-theme="dark"] .v3-card-form .v3-field.valid input { border-color: #4ade80 !important; background: rgba(74, 222, 128, .08) !important; }
[data-bs-theme="dark"] .v3-card-form .v3-field.invalid input { border-color: #f87171 !important; background: rgba(248, 113, 113, .08) !important; }
[data-bs-theme="dark"] .v3-pay-secure-note,
[data-bs-theme="dark"] .v3-trust-row { color: #adb5bd !important; }

/* Footer (already dark-ish; ensure text remains visible) */
[data-bs-theme="dark"] footer .text-secondary { color: #adb5bd !important; }
[data-bs-theme="dark"] footer a { color: #e5e7eb !important; }
[data-bs-theme="dark"] footer a:hover { color: #fff !important; }
[data-bs-theme="dark"] footer .form-control { background: #2a303a !important; color: #fff !important; border-color: #353a45 !important; }

/* Chat panel */
[data-bs-theme="dark"] #chat-panel { background: #232830 !important; border-color: #353a45 !important; color: #e5e7eb; }
[data-bs-theme="dark"] #chat-body { background: #1a1d23 !important; }
[data-bs-theme="dark"] .chat-msg.bot { background: #2a303a !important; color: #e5e7eb !important; border-color: #353a45 !important; }
[data-bs-theme="dark"] .chat-msg.user { background: linear-gradient(135deg, #475569, #64748b) !important; color: #fff !important; }
[data-bs-theme="dark"] .chat-chip { background: #2a303a !important; color: #e5e7eb !important; border-color: #353a45 !important; }
[data-bs-theme="dark"] .chat-chip:hover { background: #353a45 !important; }
[data-bs-theme="dark"] .chat-talk-band { background: #1f232a !important; color: #e5e7eb !important; }
[data-bs-theme="dark"] #chat-input { background: #2a303a !important; color: #e5e7eb !important; }

/* Section titles like "TOP RATED" or "TAILORED FOR RETURNING USERS" */
[data-bs-theme="dark"] .eyebrow, [data-bs-theme="dark"] .text-uppercase.text-secondary { color: #e6c483 !important; }

/* Product detail page */
[data-bs-theme="dark"] .product-img-wrap { background: #2a303a !important; }
[data-bs-theme="dark"] .os-badge { background: #2a303a !important; color: #e5e7eb !important; border: 1px solid #353a45; }

/* Generic background tertiary in dark */
[data-bs-theme="dark"] .product-img-wrap.bg-body-tertiary { background: #2a303a !important; }

/* Theme-toggle button icon */
[data-bs-theme="dark"] #theme-icon { color: #e6c483; }

/* Ask AI pill */
[data-bs-theme="dark"] .ask-ai-pill,
[data-bs-theme="dark"] .ask-ai-pill * { background: linear-gradient(90deg, #2a303a, #1f232a) !important; color: #e5e7eb !important; border-color: #353a45 !important; }

/* Hover lift on dark cards */
[data-bs-theme="dark"] .card:hover { box-shadow: 0 12px 30px rgba(0, 0, 0, .55) !important; }

/* Modal */
[data-bs-theme="dark"] .modal-content { background: #232830 !important; color: #e5e7eb !important; border-color: #353a45 !important; }
[data-bs-theme="dark"] .modal-header, [data-bs-theme="dark"] .modal-footer { border-color: #353a45 !important; }
[data-bs-theme="dark"] .btn-close { filter: invert(1) brightness(1.2); }


/* ================================================================
   PRODUCT CARD — COMPACT & ELEGANT (Jan 2026)
   Smaller image area, refined typography, lighter borders to
   match the soft, premium light palette.
   ================================================================ */
.product-card {
  border-radius: 12px !important;
  border: 1px solid #ececea !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, .03) !important;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  overflow: hidden;
}
.product-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(15, 23, 42, .08) !important;
  border-color: #d6d6d2 !important;
}
/* Smaller image area — fixed compact height, image fills properly */
.product-card .ratio-1x1 {
  --bs-aspect-ratio: 0 !important;
  aspect-ratio: auto !important;
  height: 160px !important;
  padding-bottom: 0 !important;
}
.product-card .product-img-wrap {
  background: #fbfbfa !important;
  border: none !important;
  padding: 10px !important;
  height: 160px !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
}
.product-card .product-3d {
  width: 100%;
  height: 100%;
  perspective: 700px;
}
.product-card .product-3d-stage {
  width: 100%;
  height: 100%;
  animation: none !important;
}
.product-card .product-3d-stage > img {
  max-height: 100% !important;
  max-width: 92% !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  object-fit: contain;
}
.product-card .product-3d-floor {
  bottom: 4%;
  left: 20%; right: 20%;
  height: 8px;
}
.product-card .product-3d-badge {
  bottom: 6px; left: 6px;
  font-size: .55rem;
  padding: 2px 7px;
}

/* Compact card body */
.product-card .card-body {
  padding: .6rem .75rem .75rem !important;
}
.product-card .card-body .mb-1.small {
  font-size: .7rem !important;
  margin-bottom: 3px !important;
  color: #94a3b8;
}
.product-card .card-body .mb-1.small .bi {
  font-size: .72rem;
}
.product-card .card-body .mb-1.small .text-secondary {
  font-size: .65rem;
  color: #9ca3af !important;
}

/* Refined product title — softer weight, smaller, 1-2 lines */
.product-card .product-title,
.product-card .card-body .product-title {
  font-size: .78rem !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  letter-spacing: -.005em;
  color: #374151;
  margin-bottom: 6px !important;
  -webkit-line-clamp: 2;
  min-height: 2.1em;
}
.product-card:hover .product-title { color: #1f2937; }

/* Price row */
.product-card .card-body .mb-3 {
  margin-bottom: 8px !important;
  font-size: .85rem;
}
.product-card .card-body .fw-bold.text-primary {
  font-size: .95rem !important;
  font-weight: 700 !important;
  color: #1f2937 !important;
  letter-spacing: -.01em;
}
.product-card .card-body .text-decoration-line-through {
  font-size: .72rem !important;
  color: #94a3b8 !important;
  margin-left: 4px !important;
}

/* Smaller, refined Add to Cart button */
.product-card .btn-elessi.add-to-cart-btn {
  padding: .42rem .8rem !important;
  font-size: .76rem !important;
  font-weight: 600 !important;
  letter-spacing: .005em;
  border-radius: 8px !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, .06) !important;
}
.product-card .btn-elessi.add-to-cart-btn:hover {
  box-shadow: 0 4px 12px rgba(71, 85, 105, .2) !important;
}
.product-card .btn-elessi.add-to-cart-btn .bi {
  font-size: .82rem;
}

/* Refined corner badges — smaller */
.product-card .badge.position-absolute {
  font-size: .58rem !important;
  font-weight: 700 !important;
  padding: 3px 7px !important;
  border-radius: 6px !important;
  letter-spacing: .02em;
  margin: 8px !important;
}
.product-card .badge.text-bg-primary {
  background: #f5f5f4 !important;
  color: #475569 !important;
  border: 1px solid #e7e7e3;
}
.product-card .badge.text-bg-danger {
  background: #1f2937 !important;
  color: #e8d6a8 !important;
  font-weight: 700 !important;
}

/* Star color — softer gold */
.product-card .bi-star-fill,
.product-card .bi-star-half { color: #c8a45f !important; font-size: .7rem; }
.product-card .bi-star { color: #e7e7e3 !important; font-size: .7rem; }

/* Optional: hide 360 badge on small product cards for a cleaner look (kept on detail) */
.product-card .product-3d-badge { display: none; }

/* Dark mode product card refinements */
[data-bs-theme="dark"] .product-card { border-color: #353a45 !important; box-shadow: 0 2px 8px rgba(0, 0, 0, .35) !important; }
[data-bs-theme="dark"] .product-card:hover { border-color: #4b5563 !important; box-shadow: 0 12px 28px rgba(0, 0, 0, .55) !important; }
[data-bs-theme="dark"] .product-card .product-img-wrap { background: #f8fafc !important; }
[data-bs-theme="dark"] .product-card .product-title { color: #e5e7eb !important; }
[data-bs-theme="dark"] .product-card:hover .product-title { color: #ffffff !important; }
[data-bs-theme="dark"] .product-card .card-body .fw-bold.text-primary { color: #f1f5f9 !important; }
[data-bs-theme="dark"] .product-card .badge.text-bg-primary { background: #2a303a !important; color: #e6c483 !important; border-color: #353a45; }
[data-bs-theme="dark"] .product-card .badge.text-bg-danger { background: #e6c483 !important; color: #1a1d23 !important; }
[data-bs-theme="dark"] .product-card .btn-elessi.add-to-cart-btn {
  background: linear-gradient(135deg, #94a3b8, #cbd5e1) !important;
  color: #1a1d23 !important;
}
[data-bs-theme="dark"] .product-card .btn-elessi.add-to-cart-btn:hover {
  background: linear-gradient(135deg, #cbd5e1, #f1f5f9) !important;
}
[data-bs-theme="dark"] .product-card .bi-star { color: #4b5563 !important; }

/* Make the grid tighter on large screens — already 4 columns; ensure smaller padding */
@media (min-width: 992px) {
  .bestseller-grid > .col,
  .row > [class*="col-xl-3"] {
    padding-left: 10px;
    padding-right: 10px;
  }
}
@media (max-width: 575px) {
  .product-card .product-title { font-size: .74rem !important; }
  .product-card .card-body .fw-bold.text-primary { font-size: .88rem !important; }
}


/* ================================================================
   HERO HEADLINE — REFINED LIGHT WEIGHT (Jan 2026)
   Soften the bold "Boost Productivity…" headline for a premium,
   editorial feel. Keep size/scale but reduce font-weight.
   ================================================================ */
.hero h1,
.hero .display-4 {
  font-weight: 400 !important;
  letter-spacing: -.02em !important;
  line-height: 1.12 !important;
  color: #1f2937 !important;
}
.hero h1 .accent,
.hero .display-4 .accent {
  font-weight: 500 !important;
  color: #8e7137 !important;
  font-style: normal;
}
/* Optional: emphasize the brand keyword "Microsoft Office 2024" subtly */
.hero h1 strong,
.hero .display-4 strong { font-weight: 600 !important; }

[data-bs-theme="dark"] .hero h1,
[data-bs-theme="dark"] .hero .display-4 { color: #f1f5f9 !important; }
[data-bs-theme="dark"] .hero h1 .accent,
[data-bs-theme="dark"] .hero .display-4 .accent { color: #e6c483 !important; }

/* Match hero supporting copy to lighter weight too */
.hero p.fs-5 { font-weight: 400 !important; color: #4b5563; }
[data-bs-theme="dark"] .hero p.fs-5 { color: #cbd5e1 !important; }
.hero ul.list-unstyled li { font-weight: 400 !important; }

/* Slightly smaller hero size for editorial balance */
.hero .display-4 { font-size: clamp(1.9rem, 3.4vw, 2.65rem) !important; }


/* ================================================================
   GLOBAL HEADLINE WEIGHT — REFINED & EDITORIAL (Jan 2026)
   Lighter, more elegant typography across all section headings.
   ================================================================ */

/* All headings — refined regular weight, soft slate color */
h1, h2, h3,
.h1, .h2, .h3,
.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
  font-weight: 400 !important;
  letter-spacing: -.02em !important;
  line-height: 1.18 !important;
  color: #1f2937;
}

/* H4-H6 stay a touch heavier for card/list titles */
h4, h5, h6, .h4, .h5, .h6 {
  font-weight: 500 !important;
  letter-spacing: -.01em !important;
}

/* Bootstrap fw-bold utility tones down to a refined medium */
.fw-bold { font-weight: 600 !important; }
.fw-semibold { font-weight: 500 !important; }

/* Section section titles ("Best Sellers", "Picked for you", "Welcome back…",
   "Why Choose Us", "Trusted Partner", etc.) */
section h2, section .h2,
.section h2, .section .h2 {
  font-weight: 400 !important;
  font-size: clamp(1.6rem, 2.6vw, 2.2rem) !important;
}

/* Card titles & product titles unaffected by the global override */
.card-title, .product-title { font-weight: 500 !important; }

/* "Welcome back — explore Office 2024 software" — the em-dash phrasing
   should read airy, so subdue dashes/colons */
.welcome-back-title, .picked-title, .bestseller-title {
  font-weight: 400 !important;
}

/* Eyebrow / kicker labels stay uppercase & spaced — these read elegant */
.eyebrow, small.eyebrow, .text-uppercase {
  font-weight: 600 !important;
  letter-spacing: .14em;
}

/* "Best Sellers", "Picked for you" badges/strong words can be slightly heavier
   inside the otherwise light headline */
h1 strong, h2 strong, h3 strong,
.display-4 strong, .display-5 strong {
  font-weight: 600 !important;
  color: inherit;
}

/* Accents (gold) inside headlines — soft, medium weight */
h1 .accent, h2 .accent, h3 .accent,
.display-4 .accent, .display-5 .accent {
  font-weight: 500 !important;
  color: #8e7137;
}

/* Hero stats — softer */
.hero-stats div { font-weight: 500 !important; letter-spacing: -.01em; }
.hero-stats .fs-3 { font-weight: 500 !important; }

/* Buttons — keep readable but refined */
.btn { font-weight: 500 !important; letter-spacing: 0; }
.btn-lg { font-weight: 500 !important; }

/* Brand wordmark — already light from earlier; ensure it stays */
.brand-text { font-weight: 500 !important; }
.brand-grad { font-weight: 500 !important; }

/* Footer/section subtitles read in regular weight */
.footer-dark h3, .footer-dark h5 { font-weight: 400 !important; }

/* Dark-mode refinement — same lighter weights with proper contrast */
[data-bs-theme="dark"] h1,
[data-bs-theme="dark"] h2,
[data-bs-theme="dark"] h3,
[data-bs-theme="dark"] .h1,
[data-bs-theme="dark"] .h2,
[data-bs-theme="dark"] .h3,
[data-bs-theme="dark"] .display-4,
[data-bs-theme="dark"] .display-5,
[data-bs-theme="dark"] .display-6 { color: #f1f5f9 !important; font-weight: 400 !important; }

[data-bs-theme="dark"] h1 .accent,
[data-bs-theme="dark"] h2 .accent,
[data-bs-theme="dark"] h3 .accent,
[data-bs-theme="dark"] .display-4 .accent { color: #e6c483 !important; }

