/*
 * Breach BZ premium trust theme.
*/

:root {
  --breach-bg: #06050a;
  --breach-card: rgba(16, 14, 25, 0.86);
  --breach-card-strong: rgba(22, 18, 34, 0.94);
  --breach-line: rgba(255, 255, 255, 0.09);
  --breach-line-strong: rgba(168, 85, 247, 0.34);
  --breach-text: #f8f7ff;
  --breach-muted: rgba(248, 247, 255, 0.66);
  --breach-soft: rgba(248, 247, 255, 0.42);
  --breach-accent: #a855f7;
  --breach-accent-2: #d8b4fe;
  --breach-trust: #38d996;
  --breach-shadow: 0 24px 80px rgba(0, 0, 0, 0.44);
}

html {
  background: var(--breach-bg);
}

.breach-theme {
  min-height: 100vh;
  color: var(--breach-text);
  background:
    linear-gradient(180deg, rgba(6, 5, 10, 0.58), var(--breach-bg) 34rem),
    var(--breach-bg) !important;
  font-synthesis: none;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}

.breach-theme::selection {
  background: rgba(168, 85, 247, 0.42);
  color: #ffffff;
}

.breach-background {
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(6, 5, 10, 0.96), rgba(6, 5, 10, 0.52) 46%, rgba(6, 5, 10, 0.96)),
    linear-gradient(180deg, rgba(6, 5, 10, 0.16), var(--breach-bg) 72%),
    var(--breach-header-image) center top / min(150rem, 155vw) auto no-repeat;
  opacity: 0.46;
  filter: saturate(1.05) contrast(1.08);
}

.breach-background::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: 44px 44px;
  -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.46), transparent 72%);
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.46), transparent 72%);
}

.breach-shell {
  max-width: 1440px;
}

.breach-theme .bg-card,
.breach-theme .bg-background {
  background-color: var(--breach-card) !important;
}

.breach-theme .border-white\/5,
.breach-theme .border-white\/10 {
  border-color: var(--breach-line) !important;
}

.breach-theme .text-t-primary\/50 {
  color: var(--breach-soft) !important;
}

.breach-theme .text-t-primary\/60,
.breach-theme .text-t-primary\/70,
.breach-theme .text-t-primary\/75,
.breach-theme .text-t-primary\/80,
.breach-theme .text-t-primary\/90 {
  color: var(--breach-muted) !important;
}

.breach-theme .text-accent-400,
.breach-theme .text-accent-500,
.breach-theme .hover\:text-accent-500:hover {
  color: var(--breach-accent-2) !important;
}

.breach-theme .bg-accent-500,
.breach-theme .hover\:bg-accent-500:hover {
  background: linear-gradient(180deg, #b56bff, #7c3aed) !important;
  color: #ffffff !important;
}

.breach-theme .border-accent-500 {
  border-color: rgba(168, 85, 247, 0.64) !important;
}

.breach-header-card {
  overflow: hidden;
  border-color: var(--breach-line-strong) !important;
  background:
    linear-gradient(180deg, rgba(30, 24, 45, 0.82), rgba(13, 12, 20, 0.9)),
    rgba(13, 12, 20, 0.9) !important;
  box-shadow: var(--breach-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.07);
  backdrop-filter: blur(18px);
}

.breach-header-card h1,
.breach-theme footer p {
  letter-spacing: 0;
}

.breach-header-card img {
  max-height: 46px;
  border-radius: 8px;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1);
}

.breach-header-card p {
  color: var(--breach-muted);
}

.breach-header-stats {
  background: rgba(255, 255, 255, 0.025);
}

.breach-header-stats p:first-child {
  color: #ffffff !important;
}

.breach-header-stats p:last-child {
  color: var(--breach-soft) !important;
  font-size: 0.68rem;
}

.breach-nav {
  position: sticky;
  top: 0;
  z-index: 30;
  margin: 0.75rem 0 0;
  padding: 0.18rem 0;
  backdrop-filter: blur(16px);
}

.breach-nav a,
.breach-nav button,
.currency-selector .choices__inner {
  border-color: var(--breach-line) !important;
  background: rgba(12, 10, 18, 0.78) !important;
  color: var(--breach-muted) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.breach-nav a:hover,
.breach-nav button:hover {
  border-color: rgba(168, 85, 247, 0.46) !important;
  background: rgba(168, 85, 247, 0.12) !important;
  color: #ffffff !important;
}

.breach-nav a[class*="bg-accent-500"],
.breach-nav button[class*="bg-accent-500"] {
  border-color: rgba(216, 180, 254, 0.54) !important;
  background: rgba(168, 85, 247, 0.18) !important;
  color: #ffffff !important;
}

.breach-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(20rem, 0.8fr);
  align-items: stretch;
  min-height: 35rem;
  margin: 1.1rem 0 1.6rem;
  overflow: hidden;
  border: 1px solid rgba(168, 85, 247, 0.28);
  border-radius: 8px;
  background: #08060d;
  box-shadow: var(--breach-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  isolation: isolate;
}

.breach-hero__image {
  position: absolute;
  inset: 0;
  z-index: -2;
}

.breach-hero__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 58% center;
  filter: saturate(1.14) contrast(1.08);
  opacity: 0.9;
  transform: scale(1.015);
}

.breach-hero__shade {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(6, 5, 10, 0.98), rgba(6, 5, 10, 0.74) 42%, rgba(6, 5, 10, 0.18) 68%, rgba(6, 5, 10, 0.5)),
    linear-gradient(180deg, rgba(6, 5, 10, 0.1), rgba(6, 5, 10, 0.92));
}

.breach-hero__content {
  position: relative;
  z-index: 1;
  width: min(42rem, 100%);
  padding: 4.5rem 2.25rem 3rem;
}

.breach-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  gap: 0.55rem;
  margin-bottom: 1.6rem;
  padding: 0.55rem 0.72rem;
  border: 1px solid rgba(56, 217, 150, 0.24);
  border-radius: 8px;
  background: rgba(56, 217, 150, 0.08);
  color: rgba(248, 247, 255, 0.84);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0;
}

.breach-hero__eyebrow i {
  color: var(--breach-trust);
}

.breach-hero h1 {
  margin: 0;
  max-width: 12ch;
  color: #ffffff;
  font-size: 3.4rem;
  line-height: 0.96;
  font-weight: 800;
  letter-spacing: 0;
  text-shadow: 0 0 34px rgba(168, 85, 247, 0.42);
}

.breach-hero p {
  max-width: 36rem;
  margin: 1.3rem 0 0;
  color: rgba(248, 247, 255, 0.78);
  font-size: 1rem;
  line-height: 1.75;
}

.breach-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.8rem;
}

.breach-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.85rem;
  gap: 0.7rem;
  padding: 0.76rem 1.12rem;
  border-radius: 8px;
  border: 1px solid transparent;
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, color 160ms ease;
}

.breach-button:hover {
  transform: translateY(-1px);
}

.breach-button--primary {
  background: linear-gradient(180deg, #c084fc, #7c3aed);
  color: #ffffff;
  box-shadow: 0 14px 42px rgba(124, 58, 237, 0.34);
}

.breach-button--secondary {
  border-color: rgba(255, 255, 255, 0.13);
  background: rgba(255, 255, 255, 0.065);
  color: #ffffff;
}

.breach-button--secondary:hover {
  border-color: rgba(216, 180, 254, 0.42);
  background: rgba(168, 85, 247, 0.12);
}

.breach-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.breach-trust-row {
  margin-top: 1.8rem;
}

.breach-trust-row div {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 0.72rem;
  border: 1px solid rgba(255, 255, 255, 0.11);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.05);
  color: rgba(248, 247, 255, 0.78);
  font-size: 0.78rem;
  font-weight: 700;
}

.breach-trust-row i {
  color: var(--breach-trust);
}

.breach-hero__visual {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  padding: 3rem 2.25rem 3rem 0;
}

.breach-hero__visual::before {
  content: "";
  position: absolute;
  inset: 3rem 2rem 3rem 0;
  border-left: 1px solid rgba(216, 180, 254, 0.18);
  background:
    linear-gradient(90deg, rgba(168, 85, 247, 0.12), transparent 40%),
    linear-gradient(rgba(255, 255, 255, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.045) 1px, transparent 1px);
  background-size: auto, 34px 34px, 34px 34px;
  opacity: 0.55;
}

.breach-hero__visual img {
  position: relative;
  width: min(21rem, 30vw);
  min-width: 13rem;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 8px;
  opacity: 0.82;
  filter: drop-shadow(0 0 34px rgba(168, 85, 247, 0.42)) saturate(1.08);
}

.breach-hero__signal {
  position: absolute;
  right: 2rem;
  bottom: 2.25rem;
  padding: 0.78rem 0.9rem;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 8px;
  background: rgba(8, 7, 13, 0.74);
  box-shadow: 0 16px 44px rgba(0, 0, 0, 0.34);
  backdrop-filter: blur(14px);
}

.breach-hero__signal span,
.breach-hero__signal strong {
  display: block;
  letter-spacing: 0;
}

.breach-hero__signal span {
  color: var(--breach-muted);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
}

.breach-hero__signal strong {
  margin-top: 0.25rem;
  color: #ffffff;
  font-size: 1rem;
}

.breach-components > .component,
.breach-theme .component > div.py-6,
.breach-theme .component > div.py-6.lg\:py-8 {
  position: relative;
}

.breach-theme h1,
.breach-theme h2,
.breach-theme h3,
.breach-theme h4 {
  letter-spacing: 0;
}

.breach-theme h2,
.breach-theme .component h1 {
  color: #ffffff !important;
}

.breach-theme .component h2[class*="border-l-accent"] {
  padding-left: 0.95rem !important;
  border-left-color: var(--breach-accent-2) !important;
}

.breach-theme input,
.breach-theme textarea,
.breach-theme select,
.breach-theme .choices .choices__inner {
  border: 1px solid var(--breach-line) !important;
  background: rgba(255, 255, 255, 0.045) !important;
  color: #ffffff !important;
}

.breach-theme input:focus,
.breach-theme textarea:focus,
.breach-theme select:focus {
  border-color: rgba(216, 180, 254, 0.54) !important;
  box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.16) !important;
}

.breach-theme input[x-model="searchTerm"] {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.breach-product-card {
  overflow: hidden;
  border-color: var(--breach-line) !important;
  background:
    linear-gradient(180deg, rgba(28, 23, 42, 0.86), rgba(12, 10, 18, 0.94)),
    var(--breach-card-strong) !important;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.055);
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.breach-product-card:hover {
  transform: translateY(-3px);
  border-color: rgba(216, 180, 254, 0.42) !important;
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.34), 0 0 0 1px rgba(168, 85, 247, 0.13);
}

.breach-product-card__inner {
  display: flex;
  flex-direction: column;
}

.breach-product-card__media {
  margin-bottom: 0 !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.012)),
    rgba(0, 0, 0, 0.28);
}

.breach-product-card__media::after {
  content: "";
  position: absolute;
  inset: 0.5rem;
  border-radius: 8px;
  box-shadow: inset 0 -72px 70px rgba(0, 0, 0, 0.38);
  pointer-events: none;
}

.breach-product-card__media img,
.breach-product-card__media svg {
  transition: transform 220ms ease, filter 220ms ease;
}

.breach-product-card:hover .breach-product-card__media img {
  transform: scale(1.025);
  filter: saturate(1.08);
}

.breach-product-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding-top: 1rem !important;
}

.breach-product-card__body h3 {
  color: #ffffff;
  font-size: 1.02rem;
}

.breach-product-card__body > p {
  min-height: 1.35rem;
}

.breach-product-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: auto;
  padding-top: 0.35rem;
}

.breach-product-card__footer p {
  min-width: 0;
}

.breach-product-card__cta {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  gap: 0.38rem;
  color: rgba(248, 247, 255, 0.78);
  font-size: 0.78rem;
  font-weight: 800;
}

.breach-product-card__cta i {
  color: var(--breach-accent-2);
  font-size: 0.72rem;
  transition: transform 160ms ease;
}

.breach-product-card:hover .breach-product-card__cta i {
  transform: translateX(2px);
}

.breach-theme .badges > div,
.breach-theme .badges > a {
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.25);
}

.breach-checkout-panel,
.breach-product-page .lg\:w-3\/5 > .bg-card,
.breach-theme aside .sticky,
.breach-theme footer {
  border-color: var(--breach-line) !important;
  background:
    linear-gradient(180deg, rgba(28, 23, 42, 0.74), rgba(13, 12, 20, 0.91)),
    var(--breach-card) !important;
  box-shadow: 0 18px 58px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.breach-checkout-panel > div:first-child {
  border-bottom: 1px solid var(--breach-line);
  background: rgba(255, 255, 255, 0.035) !important;
}

.breach-checkout-panel button,
.breach-theme a[class*="bg-accent-500"],
.breach-theme button[class*="bg-accent-500"] {
  box-shadow: 0 12px 34px rgba(124, 58, 237, 0.26);
}

.breach-theme button,
.breach-theme a {
  transition-duration: 180ms !important;
}

.breach-theme button:disabled {
  box-shadow: none !important;
}

.breach-theme .editor {
  color: rgba(248, 247, 255, 0.82) !important;
}

.breach-theme .editor a {
  color: var(--breach-accent-2);
}

.breach-theme .fixed .bg-background,
.breach-theme .fixed .bg-card {
  background-color: rgba(10, 8, 15, 0.96) !important;
  backdrop-filter: blur(18px);
}

.breach-theme footer {
  margin-top: 1.5rem;
  overflow: hidden;
}

.breach-theme footer a:hover {
  color: #ffffff !important;
}

.breach-theme .splide__arrow {
  background: rgba(168, 85, 247, 0.2) !important;
}

.breach-theme .splide__arrow:hover {
  background: rgba(168, 85, 247, 0.34) !important;
}

@media (max-width: 900px) {
  .breach-hero {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .breach-hero__shade {
    background:
      linear-gradient(180deg, rgba(6, 5, 10, 0.52), rgba(6, 5, 10, 0.97)),
      linear-gradient(90deg, rgba(6, 5, 10, 0.9), rgba(6, 5, 10, 0.4));
  }

  .breach-hero__content {
    padding: 3.4rem 1.35rem 1.35rem;
  }

  .breach-hero h1 {
    font-size: 2.5rem;
  }

  .breach-hero__visual {
    min-height: 13rem;
    justify-content: flex-start;
    padding: 0 1.35rem 1.35rem;
  }

  .breach-hero__visual::before {
    inset: 0 1.35rem 1.35rem;
  }

  .breach-hero__visual img {
    width: 11rem;
    min-width: 11rem;
  }

  .breach-hero__signal {
    right: 1.35rem;
    bottom: 1.35rem;
  }

}

@media (max-width: 560px) {
  .breach-shell {
    padding: 0.75rem !important;
  }

  .breach-header-card > div {
    align-items: stretch;
  }

  .breach-header-card a {
    justify-content: flex-start !important;
  }

  .breach-hero {
    margin-top: 0.65rem;
  }

  .breach-hero__content {
    padding: 2.65rem 1rem 1rem;
  }

  .breach-hero h1 {
    font-size: 2.08rem;
    line-height: 1.02;
  }

  .breach-hero p {
    font-size: 0.94rem;
    line-height: 1.62;
  }

  .breach-hero__visual {
    display: none;
  }

  .breach-hero__actions,
  .breach-trust-row {
    display: grid;
    grid-template-columns: 1fr;
  }

  .breach-button,
  .breach-trust-row div {
    width: 100%;
  }

  .breach-product-card__footer {
    align-items: flex-start;
    flex-direction: column;
  }
}