/**
 * Goodyear B2B Portal - Components
 * Reusable component styles
 */

/* ========================================
 * CARD COMPONENT
 * ======================================== */

.goodyear-card {
  background-color: var(--color-ui-white);
  padding: var(--spacing-xl);
  border-radius: var(--border-radius-md, 8px);
  border: 1px solid var(--border-medium, #D2D2D2);
}

.goodyear-card:hover {
  box-shadow: var(--shadow-lg);
}

.goodyear-card-sm {
  padding: var(--spacing-lg);
  border-radius: var(--border-radius-md);
}

.goodyear-card-lg {
  padding: var(--spacing-xxl);
  border-radius: var(--border-radius-xl);
}

.goodyear-card-bordered {
  border: var(--border-width) solid var(--border-color-primary);
}

/* ========================================
 * SECTION HEADER
 * ======================================== */

.goodyear-section-header {
  font-family: var(--font-family-heading);
  font-size: 24px;
  font-weight: var(--font-weight-bold);
  color: var(--color-ui-100);
  margin-bottom: var(--spacing-lg);
}

/* ========================================
 * DIVIDER
 * ======================================== */

.goodyear-divider {
  height: 1px;
  background-color: var(--border-color-primary);
  border: none;
  margin: var(--spacing-xl) 0;
}

.goodyear-divider-vertical {
  width: 1px;
  height: auto;
  background-color: var(--border-color-primary);
  margin: 0 var(--spacing-xl);
}

/* ========================================
 * BADGE
 * ======================================== */

.goodyear-badge {
  display: inline-block;
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: 12px;
  font-weight: var(--font-weight-semibold);
  border-radius: var(--border-radius-full);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.goodyear-badge-primary {
  background-color: var(--color-primary-100);
  color: var(--color-ui-white);
}

.goodyear-badge-secondary {
  background-color: var(--color-secondary-100);
  color: var(--color-ui-100);
}

.goodyear-badge-outline {
  background-color: transparent;
  border: 1px solid var(--color-primary-100);
  color: var(--color-primary-100);
}

/* ========================================
 * ALERT / NOTIFICATION
 * ======================================== */

.goodyear-alert {
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--border-radius-md);
  border-left: 4px solid;
  margin-bottom: var(--spacing-md);
}

.goodyear-alert-info {
  background-color: var(--color-primary-5);
  border-color: var(--color-primary-100);
  color: var(--color-primary-150);
}

.goodyear-alert-success {
  background-color: #e8f5e9;
  border-color: #4caf50;
  color: #1b5e20;
}

.goodyear-alert-warning {
  background-color: #fff3e0;
  border-color: #ff9800;
  color: #e65100;
}

.goodyear-alert-error {
  background-color: #ffebee;
  border-color: #f44336;
  color: #b71c1c;
}

/* ========================================
 * CONTAINER
 * ======================================== */

.goodyear-container {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--spacing-xl);
  padding-right: var(--spacing-xl);
}

.goodyear-container-fluid {
  width: 100%;
  padding-left: var(--spacing-xl);
  padding-right: var(--spacing-xl);
}

/* ========================================
 * GRID UTILITIES
 * ======================================== */

.goodyear-grid {
  display: grid;
  gap: var(--spacing-lg);
}

.goodyear-grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

.goodyear-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

.goodyear-grid-4 {
  grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1024px) {
  .goodyear-grid-3,
  .goodyear-grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 767px) {
  .goodyear-grid-2,
  .goodyear-grid-3,
  .goodyear-grid-4 {
    grid-template-columns: 1fr;
  }
}

/* ========================================
 * FLEX UTILITIES
 * ======================================== */

.goodyear-flex {
  display: flex;
}

.goodyear-flex-col {
  flex-direction: column;
}

.goodyear-flex-wrap {
  flex-wrap: wrap;
}

.goodyear-items-center {
  align-items: center;
}

.goodyear-items-start {
  align-items: flex-start;
}

.goodyear-items-end {
  align-items: flex-end;
}

.goodyear-justify-center {
  justify-content: center;
}

.goodyear-justify-between {
  justify-content: space-between;
}

.goodyear-justify-start {
  justify-content: flex-start;
}

.goodyear-justify-end {
  justify-content: flex-end;
}

/* ========================================
 * CASE PATH — closed step override
 * When the Closed step is also the current/active step, match the
 * complete-step success colour instead of the default action-color-primary.
 * ======================================== */
.slds-path__nav .gy-is-closed.slds-is-current::before,
.slds-path__nav .gy-is-closed.slds-is-current::after {
  background-image:
    linear-gradient(90deg, var(--system-success) 0.125rem, transparent 0.125rem),
    linear-gradient(90deg, var(--system-success) 0.125rem, transparent 0.125rem),
    linear-gradient(90deg, var(--system-success), var(--system-success)) !important;
}

.slds-path__nav .slds-is-active.gy-is-closed.slds-is-current {
    background: var(--system-success) !important;
}

.slds-path__nav .slds-is-active.gy-is-closed.slds-is-current:after, .slds-path__nav .slds-is-active.gy-is-closed.slds-is-current:before {
    background: var(--system-success);
}