/* globals.css — StockEtsy Design System v5.0 */

:root {
  --primary:           #E8622A;
  --primary-hover:     #C94E1E;
  --primary-active:    #A33C16;
  --primary-50:        #FDF2EC;
  --primary-100:       #FAE0D0;
  --secondary:         #4A5568;
  --secondary-dark:    #2D3748;
  --accent:            #5B8A6F;
  --accent-hover:      #3D6B52;
  --accent-50:         #EEF5F1;
  --accent-100:        #D4E8DC;
  --bg:                #FAF8F5;
  --surface:           #FFFFFF;
  --surface-alt:       #F3F0EB;
  --border:            #E2DDD8;
  --text-primary:      #1C1917;
  --text-secondary:    #78716C;
  --text-placeholder:  #A8A29E;
  --warning:           #D97706;
  --error:             #DC2626;
  --info:              #3B82F6;
}

*, *::before, *::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background-color: #FAF8F5;
  color: #1C1917;
  margin: 0;
  padding: 0;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  line-height: 1.3;
}

.font-mono,
code,
.sku,
.price,
.stock-number {
  font-family: 'JetBrains Mono', 'Courier New', monospace;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="search"],
input[type="tel"],
input[type="url"],
select,
textarea {
  background-color: #FFFFFF !important;
  border: 2px solid #E2DDD8 !important;
  border-radius: 12px !important;
  padding: 10px 16px !important;
  color: #1C1917 !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 16px !important;
  min-height: 44px !important;
  outline: none !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
}

input::placeholder,
textarea::placeholder {
  color: #A8A29E !important;
  opacity: 1;
}

input:hover,
select:hover,
textarea:hover {
  border-color: #4A5568 !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: #E8622A !important;
  box-shadow: 0 0 0 4px rgba(232, 98, 42, 0.10) !important;
  background-color: #FFFFFF !important;
}

input:disabled,
select:disabled,
textarea:disabled {
  background-color: #F3F0EB !important;
  color: #78716C !important;
  cursor: not-allowed !important;
  border-color: #E2DDD8 !important;
}

input[type="number"].has-unit {
  padding-right: 56px !important;
}

select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2378716C' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  padding-right: 40px !important;
  cursor: pointer;
}

textarea {
  resize: vertical;
  min-height: 80px !important;
}

input[type="checkbox"],
input[type="radio"] {
  width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  border: 2px solid #E2DDD8 !important;
  border-radius: 4px !important;
  background-color: #FFFFFF !important;
  cursor: pointer;
  accent-color: #E8622A;
  padding: 0 !important;
}

input[type="checkbox"]:checked,
input[type="radio"]:checked {
  background-color: #E8622A !important;
  border-color: #E8622A !important;
}

input[type="range"] {
  background: transparent !important;
  border: none !important;
  min-height: 20px !important;
  padding: 0 !important;
  accent-color: #E8622A;
}

::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background: #F3F0EB;
}
::-webkit-scrollbar-thumb {
  background: #E2DDD8;
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
  background: #78716C;
}

:focus-visible {
  outline: 2px solid #E8622A;
  outline-offset: 2px;
}

a {
  transition: color 0.15s ease-out, text-decoration 0.15s ease-out;
}

button {
  transition: background-color 0.15s ease-out,
              border-color 0.15s ease-out,
              color 0.15s ease-out,
              box-shadow 0.15s ease-out;
}

.stock-critical {
  border-left: 4px solid #DC2626 !important;
  background-color: rgba(254, 242, 242, 0.5) !important;
}

.stock-warning {
  border-left: 4px solid #D97706 !important;
  background-color: rgba(255, 251, 235, 0.5) !important;
}

.stock-low {
  border-left: 3px solid #D97706 !important;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.fade-in {
  animation: fadeIn 0.2s ease-out forwards;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.6; transform: scale(0.8); }
}

.pulse-dot {
  animation: pulse-dot 1.5s ease-in-out infinite;
}

.nav-active {
  background-color: #FDF2EC !important;
  color: #E8622A !important;
  font-weight: 600 !important;
}

.kpi-accent-red    { border-left: 6px solid #DC2626 !important; }
.kpi-accent-amber  { border-left: 6px solid #D97706 !important; }
.kpi-accent-green  { border-left: 6px solid #5B8A6F !important; }
.kpi-accent-orange { border-left: 6px solid #E8622A !important; }
.kpi-accent-slate  { border-left: 6px solid #4A5568 !important; }

@media print {
  aside, header, footer, .no-print {
    display: none !important;
  }
  main {
    margin: 0 !important;
    padding: 0 !important;
  }
}

@media (max-width: 768px) {
  .sidebar-desktop {
    display: none;
  }
  .table-to-cards thead {
    display: none;
  }
  .table-to-cards tr {
    display: block;
    border: 1px solid #E2DDD8;
    border-radius: 12px;
    margin-bottom: 12px;
    padding: 12px;
    background: #FFFFFF;
  }
  .table-to-cards td {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    border: none;
  }
  .table-to-cards td::before {
    content: attr(data-label);
    font-weight: 600;
    color: #78716C;
    font-size: 12px;
  }
}
