/**
 * Neo-Brutalist CSS Framework
 * Raw, bold aesthetics for reseller metrics
 */

/* Reset and base styles */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  --black: #000000;
  --white: #FAFAFA;
  --electric-green: #00FF41;
  --warning-red: #FF0033;
  --acid-yellow: #FFFF00;
  --industrial-blue: #0066FF;
  --gray-dark: #333333;
  --gray-light: #CCCCCC;
  
  /* Typography scale */
  --text-mega: 4.5rem;
  --text-huge: 3rem;
  --text-large: 1.5rem;
  --text-base: 1rem;
  --text-small: 0.875rem;
  
  /* Shadows and borders */
  --shadow-brutal: 8px 8px 0px var(--black);
  --shadow-medium: 4px 4px 0px var(--black);
  --shadow-small: 2px 2px 0px var(--black);
  --border-thick: 4px solid var(--black);
  --border-medium: 2px solid var(--black);
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--white);
  color: var(--black);
  line-height: 1.2;
  font-weight: bold;
}

/* Typography system */
.text-mega {
  font-size: var(--text-mega);
  font-weight: 900;
  line-height: 0.9;
  text-transform: uppercase;
}

.text-huge {
  font-size: var(--text-huge);
  font-weight: 900;
  line-height: 0.9;
  text-transform: uppercase;
}

.text-large {
  font-size: var(--text-large);
  font-weight: bold;
  text-transform: uppercase;
}

.text-base {
  font-size: var(--text-base);
  font-weight: bold;
}

.text-small {
  font-size: var(--text-small);
  font-weight: normal;
}

/* Color utilities */
.text-green { color: var(--electric-green); }
.text-red { color: var(--warning-red); }
.text-yellow { color: var(--acid-yellow); }
.text-blue { color: var(--industrial-blue); }
.text-black { color: var(--black); }

.bg-green { background: var(--electric-green); }
.bg-red { background: var(--warning-red); }
.bg-yellow { background: var(--acid-yellow); }
.bg-blue { background: var(--industrial-blue); }
.bg-black { background: var(--black); color: var(--white); }
.bg-white { background: var(--white); }

/* Layout system */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2rem;
}

.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}

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

.flex {
  display: flex;
}

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

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

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

.gap-1 { gap: 0.5rem; }
.gap-2 { gap: 1rem; }
.gap-4 { gap: 2rem; }

/* Spacing utilities */
.p-1 { padding: 0.5rem; }
.p-2 { padding: 1rem; }
.p-3 { padding: 1.5rem; }
.p-4 { padding: 2rem; }

.m-1 { margin: 0.5rem; }
.m-2 { margin: 1rem; }
.m-3 { margin: 1.5rem; }
.m-4 { margin: 2rem; }

.mb-1 { margin-bottom: 0.5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
.mb-4 { margin-bottom: 2rem; }

.mt-2 { margin-top: 1rem; }
.mt-4 { margin-top: 2rem; }

/* Neo-brutalist components */
.brutal-card {
  background: var(--white);
  border: var(--border-thick);
  box-shadow: var(--shadow-brutal);
  padding: 2rem;
  position: relative;
}

.brutal-card-medium {
  background: var(--white);
  border: var(--border-medium);
  box-shadow: var(--shadow-medium);
  padding: 1.5rem;
  position: relative;
}

.brutal-card-small {
  background: var(--white);
  border: var(--border-medium);
  box-shadow: var(--shadow-small);
  padding: 1rem;
  position: relative;
}

/* ROI Hero Card */
.roi-hero {
  background: var(--black);
  color: var(--white);
  border: var(--border-thick);
  box-shadow: var(--shadow-brutal);
  padding: 3rem 2rem;
  text-align: center;
  position: relative;
  margin-bottom: 3rem;
}

.roi-hero::before {
  content: '';
  position: absolute;
  top: -8px;
  left: -8px;
  right: 8px;
  bottom: 8px;
  background: var(--electric-green);
  z-index: -1;
}

.roi-value {
  font-size: 6rem;
  font-weight: 900;
  line-height: 0.8;
  color: var(--electric-green);
  text-shadow: 4px 4px 0px var(--black);
  margin-bottom: 1rem;
}

.roi-label {
  font-size: 1.5rem;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  margin-bottom: 0.5rem;
}

.marketplace-badge {
  display: inline-block;
  background: var(--acid-yellow);
  color: var(--black);
  padding: 0.5rem 1rem;
  font-size: 1rem;
  font-weight: bold;
  text-transform: uppercase;
  border: 2px solid var(--black);
  box-shadow: var(--shadow-small);
}

/* Marketplace comparison cards */
.marketplace-card {
  background: var(--white);
  border: var(--border-thick);
  box-shadow: var(--shadow-brutal);
  padding: 2rem;
  position: relative;
  min-height: 300px;
}

.marketplace-card.winner::before {
  content: 'WINNER';
  position: absolute;
  top: -2px;
  right: -2px;
  background: var(--electric-green);
  color: var(--black);
  padding: 0.5rem 1rem;
  font-size: 0.75rem;
  font-weight: bold;
  border: 2px solid var(--black);
  box-shadow: var(--shadow-small);
  transform: rotate(12deg);
}

.marketplace-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: var(--border-medium);
}

.marketplace-name {
  font-size: 1.5rem;
  font-weight: 900;
  text-transform: uppercase;
}

.marketplace-logo {
  width: 40px;
  height: 40px;
  background: var(--black);
  border: 2px solid var(--black);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  font-weight: bold;
}

.roi-display {
  text-align: center;
  margin-bottom: 2rem;
}

.roi-percentage {
  font-size: 3rem;
  font-weight: 900;
  line-height: 0.9;
  margin-bottom: 0.5rem;
}

.roi-percentage.positive {
  color: var(--electric-green);
}

.roi-percentage.negative {
  color: var(--warning-red);
}

.roi-percentage.neutral {
  color: var(--gray-dark);
}

.profit-amount {
  font-size: 1.25rem;
  font-weight: bold;
  text-transform: uppercase;
}

.monthly-earnings {
  font-size: 1rem;
  color: var(--gray-dark);
  text-transform: uppercase;
  margin-top: 0.5rem;
}

/* Buttons */
.brutal-btn {
  background: var(--industrial-blue);
  color: var(--white);
  border: var(--border-medium);
  box-shadow: var(--shadow-medium);
  padding: 1rem 2rem;
  font-size: 1rem;
  font-weight: bold;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.1s ease;
  text-decoration: none;
  display: inline-block;
}

.brutal-btn:hover {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0px var(--black);
}

.brutal-btn:active {
  transform: translate(4px, 4px);
  box-shadow: none;
}

.brutal-btn.primary {
  background: var(--electric-green);
  color: var(--black);
}

.brutal-btn.danger {
  background: var(--warning-red);
  color: var(--white);
}

.brutal-btn.warning {
  background: var(--acid-yellow);
  color: var(--black);
}

/* Product details section */
.product-details {
  background: var(--white);
  border: var(--border-medium);
  box-shadow: var(--shadow-medium);
  padding: 2rem;
  margin-bottom: 2rem;
}

.product-title {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 1rem;
  text-transform: uppercase;
}

.cost-comparison {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}

.cost-item {
  text-align: center;
  padding: 1rem;
  border: 2px solid var(--black);
  background: var(--white);
}

.cost-label {
  font-size: 0.875rem;
  color: var(--gray-dark);
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}

.cost-value {
  font-size: 1.5rem;
  font-weight: bold;
}

/* Fee breakdown bars */
.fee-breakdown {
  margin-top: 2rem;
}

.fee-bar {
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
  background: var(--gray-light);
  border: 2px solid var(--black);
  height: 40px;
  position: relative;
}

.fee-fill {
  background: var(--industrial-blue);
  height: 100%;
  border-right: 2px solid var(--black);
  display: flex;
  align-items: center;
  padding: 0 1rem;
  color: var(--white);
  font-weight: bold;
  font-size: 0.875rem;
}

.fee-label {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-weight: bold;
  color: var(--black);
}

/* Status badges */
.status-badge {
  display: inline-block;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: bold;
  text-transform: uppercase;
  border: 2px solid var(--black);
  box-shadow: var(--shadow-small);
}

.status-badge.profitable {
  background: var(--electric-green);
  color: var(--black);
}

.status-badge.marginal {
  background: var(--acid-yellow);
  color: var(--black);
}

.status-badge.unprofitable {
  background: var(--warning-red);
  color: var(--white);
}

.status-badge.not-analyzed {
  background: var(--gray-light);
  color: var(--black);
}

/* Loading states */
.loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4rem;
  font-size: 1.5rem;
  font-weight: bold;
  text-transform: uppercase;
}

.loading::after {
  content: '';
  width: 20px;
  height: 20px;
  border: 4px solid var(--black);
  border-top: 4px solid var(--electric-green);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-left: 1rem;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Error states */
.error-card {
  background: var(--warning-red);
  color: var(--white);
  border: var(--border-thick);
  box-shadow: var(--shadow-brutal);
  padding: 2rem;
  margin: 2rem 0;
}

.error-title {
  font-size: 1.5rem;
  font-weight: bold;
  text-transform: uppercase;
  margin-bottom: 1rem;
}

/* Action buttons area */
.action-bar {
  display: flex;
  gap: 1rem;
  padding: 2rem;
  border: var(--border-medium);
  background: var(--white);
  box-shadow: var(--shadow-medium);
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

/* Responsive design */
@media (max-width: 768px) {
  :root {
    --text-mega: 3rem;
    --text-huge: 2rem;
    --text-large: 1.25rem;
  }
  
  .container {
    padding: 1rem;
  }
  
  .grid-2, .grid-3, .grid-4 {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  
  .roi-hero {
    padding: 2rem 1rem;
  }
  
  .roi-value {
    font-size: 4rem;
  }
  
  .marketplace-card {
    min-height: auto;
    padding: 1.5rem;
  }
  
  .roi-percentage {
    font-size: 2rem;
  }
  
  .action-bar {
    flex-direction: column;
  }
  
  .brutal-btn {
    width: 100%;
    text-align: center;
  }
  
  .cost-comparison {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .roi-value {
    font-size: 3rem;
  }
  
  .roi-percentage {
    font-size: 1.5rem;
  }
  
  .marketplace-header {
    flex-direction: column;
    gap: 1rem;
    text-align: center;
  }
}

/* Print styles */
@media print {
  body {
    background: white;
    color: black;
  }
  
  .brutal-card,
  .marketplace-card,
  .roi-hero {
    box-shadow: none;
    border: 1px solid black;
  }
  
  .brutal-btn {
    display: none;
  }
}