:root {
  --sw-icon-stroke: #B9823A;
  --sw-icon-bg: rgba(185, 130, 58, .10);
  --sw-icon-border: rgba(185, 130, 58, .45);
}

.sw-icon {
  width: 48px;
  height: 48px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  color: var(--sw-icon-stroke);
  background: var(--sw-icon-bg);
  border: 1px solid var(--sw-icon-border);
  border-radius: 14px;
}

.sw-icon svg {
  width: 26px;
  height: 26px;
  display: block;
}

.sw-icon--bare {
  background: transparent;
  border: 0;
  border-radius: 0;
}

.sw-spec-card .sw-icon,
.sw-application-card .sw-icon {
  margin-bottom: 14px;
}

@media (max-width: 991px) {
  .sw-icon {
    width: 42px;
    height: 42px;
    border-radius: 12px;
  }

  .sw-icon svg {
    width: 24px;
    height: 24px;
  }
}

@media (max-width: 575px) {
  .sw-icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
  }

  .sw-icon svg {
    width: 21px;
    height: 21px;
  }
}


/* Batch 6 integration hardening */
.sw-icon svg {
  stroke: currentColor;
  fill: none;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sw-icon svg * {
  vector-effect: non-scaling-stroke;
}

.sw-product-hero .sw-icon,
.sw-product-tabs .sw-icon,
.sw-sticky-quote .sw-icon {
  color: var(--sw-gold-2, #D0A15A);
  background: rgba(185, 130, 58, .14);
  border-color: rgba(185, 130, 58, .50);
}

.sw-quick-specs .sw-icon {
  margin: 0;
}

.sw-mini-card--image .sw-icon {
  margin-bottom: 12px;
}
