/*
 * Desapegos — main application stylesheet
 * Imports the design system tokens, then defines layout + component styles.
 */

/* ── layout ──────────────────────────────────────────── */

.ds-main-content {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--sp-4) var(--sp-4) var(--sp-16);
}

/* ── nav ─────────────────────────────────────────────── */

.ds-nav {
  background: var(--cream-100);
  border-bottom: 1px solid var(--hairline);
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(12px);
  background-color: rgba(255, 244, 236, 0.88);
}

.ds-nav__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--sp-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
}

.ds-nav__logo {
  height: 28px;
  display: block;
}

.ds-nav__links {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}

.ds-nav__link {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--small);
  font-weight: 600;
  color: var(--fg-2);
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease-out-soft), color var(--dur-fast) var(--ease-out-soft);
}

.ds-nav__link:hover {
  background: var(--bg-hover);
  color: var(--fg-1);
}

.ds-nav__link--active {
  background: var(--bg-raised);
  color: var(--cocoa-900);
  box-shadow: var(--shadow-sm);
}

.ds-nav__link--active i,
.ds-nav__link--active .ph {
  color: var(--peach-600);
}

.ds-nav__tail {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.ds-nav__user-email {
  font-size: var(--tiny);
  color: var(--fg-3);
}

/* ── flash notices ───────────────────────────────────── */

.ds-flash {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-md);
  font-size: var(--small);
  font-weight: 600;
  margin-bottom: var(--sp-4);
  border: 1px solid;
}

.ds-flash--success {
  background: var(--sage-100);
  color: var(--sage-700);
  border-color: var(--sage-300);
}

.ds-flash--danger {
  background: var(--clay-100);
  color: var(--clay-700);
  border-color: var(--clay-300);
}

.ds-flash--warning {
  background: var(--butter-100);
  color: var(--butter-700);
  border-color: var(--butter-300);
}

/* ── page header ─────────────────────────────────────── */

.ds-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--sp-6);
  flex-wrap: wrap;
  gap: var(--sp-3);
}

.ds-page-title {
  font-family: var(--font-display);
  font-size: var(--h-2);
  font-weight: 500;
  color: var(--fg-1);
  margin: 0;
  letter-spacing: -0.01em;
}

.ds-page-subtitle {
  font-size: var(--small);
  color: var(--fg-3);
  margin: var(--sp-1) 0 0;
}

/* ── buttons ─────────────────────────────────────────── */

.ds-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--small);
  font-weight: 700;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease-out-soft), transform var(--dur-fast) var(--ease-out-soft), box-shadow var(--dur-fast) var(--ease-out-soft);
}

.ds-btn:active {
  transform: scale(0.98);
}

.ds-btn--primary {
  background: var(--peach-300);
  color: var(--cocoa-900);
  box-shadow: var(--shadow-xs);
}

.ds-btn--primary:hover {
  background: var(--peach-400);
}

.ds-btn--primary:active {
  background: var(--peach-500);
  box-shadow: var(--shadow-xs);
}

.ds-btn--secondary {
  background: var(--bg-raised);
  color: var(--fg-1);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-xs);
}

.ds-btn--secondary:hover {
  background: var(--bg-hover);
}

.ds-btn--danger {
  background: var(--clay-100);
  color: var(--clay-700);
  border: 1px solid var(--clay-300);
}

.ds-btn--danger:hover {
  background: var(--clay-300);
  color: var(--clay-700);
}

.ds-btn--sm {
  padding: 5px 12px;
  font-size: var(--tiny);
}

/* ── cards ───────────────────────────────────────────── */

.ds-card {
  background: var(--bg-raised);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--sp-5);
  transition: box-shadow var(--dur-base) var(--ease-out-soft), transform var(--dur-base) var(--ease-out-soft);
}

.ds-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.ds-card--flat {
  box-shadow: none;
  border: 1px solid var(--border);
}

.ds-card--flat:hover {
  box-shadow: var(--shadow-sm);
  transform: none;
}

/* ── stat card ───────────────────────────────────────── */

.ds-stat {
  background: var(--bg-raised);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--sp-5);
}

.ds-stat__label {
  font-size: var(--tiny);
  color: var(--fg-3);
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0.04em;
}

.ds-stat__value {
  font-family: var(--font-display);
  font-size: 36px;
  color: var(--cocoa-900);
  margin-top: var(--sp-1);
  line-height: 1;
}

.ds-stat__sub {
  font-size: var(--tiny);
  color: var(--fg-3);
  margin-top: var(--sp-2);
  font-weight: 600;
}

/* ── table ───────────────────────────────────────────── */

.ds-table-wrap {
  background: var(--bg-raised);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.ds-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--small);
}

.ds-table thead {
  background: var(--cream-100);
}

.ds-table th {
  text-align: left;
  padding: 10px 20px;
  font-weight: 700;
  color: var(--fg-3);
  font-size: var(--tiny);
  border-bottom: 1px solid var(--hairline);
}

.ds-table td {
  padding: 14px 20px;
  color: var(--fg-2);
  border-bottom: 1px solid var(--hairline);
}

.ds-table tbody tr:last-child td {
  border-bottom: none;
}

.ds-table tbody tr:hover td {
  background: var(--cream-50);
}

/* ── table toolbar ───────────────────────────────────── */

.ds-table-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--hairline);
  flex-wrap: wrap;
  gap: var(--sp-3);
}

.ds-table-title {
  font-family: var(--font-body);
  font-size: var(--body);
  font-weight: 700;
  color: var(--cocoa-900);
  margin: 0;
}

/* ── form ────────────────────────────────────────────── */

.ds-form-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

.ds-label {
  font-family: var(--font-body);
  font-size: var(--small);
  font-weight: 700;
  color: var(--fg-1);
}

.ds-input,
.ds-select,
.ds-textarea {
  font-family: var(--font-body);
  font-size: var(--small);
  color: var(--fg-1);
  background: var(--bg-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 9px 14px;
  width: 100%;
  box-sizing: border-box;
  transition: border-color var(--dur-fast) var(--ease-out-soft), box-shadow var(--dur-fast) var(--ease-out-soft);
}

.ds-input:focus,
.ds-select:focus,
.ds-textarea:focus {
  outline: none;
  border-color: var(--peach-400);
  box-shadow: var(--shadow-focus);
}

.ds-input::placeholder {
  color: var(--fg-4);
}

.ds-textarea {
  resize: vertical;
  min-height: 100px;
}

/* ── badge / chip ────────────────────────────────────── */

.ds-badge {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: var(--radius-pill);
}

.ds-badge--peach   { background: var(--peach-100);  color: var(--peach-700);  }
.ds-badge--sage    { background: var(--sage-100);   color: var(--sage-700);   }
.ds-badge--butter  { background: var(--butter-100); color: var(--butter-700); }
.ds-badge--clay    { background: var(--clay-100);   color: var(--clay-700);   }
.ds-badge--cocoa   { background: var(--bone-100);   color: var(--cocoa-700);  }

/* ── empty state ─────────────────────────────────────── */

.ds-empty {
  text-align: center;
  padding: var(--sp-16) var(--sp-8);
  color: var(--fg-3);
}

.ds-empty img {
  width: 64px;
  opacity: 0.55;
  margin-bottom: var(--sp-4);
}

.ds-empty p {
  font-size: var(--small);
  margin: 0 0 var(--sp-4);
}

/* ── grid helpers ────────────────────────────────────── */

.ds-grid-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}

.ds-grid-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--sp-4);
}

/* ── product thumbnail ───────────────────────────────── */

.ds-product-thumb {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: linear-gradient(160deg, var(--peach-100), var(--blush-200));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}

.ds-product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ds-product-thumb--placeholder img {
  width: 60%;
  height: 60%;
  object-fit: contain;
  opacity: 0.6;
}

/* ── link ────────────────────────────────────────────── */

a.ds-link {
  color: var(--peach-700);
  text-decoration: none;
  font-weight: 600;
  transition: color var(--dur-fast);
}

a.ds-link:hover {
  color: var(--peach-600);
  text-decoration: underline;
}

/* ── sign-in / marketing page override ──────────────── */

.ds-auth-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-8);
  background: var(--bg);
}

.ds-auth-card {
  background: var(--bg-raised);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: var(--sp-10);
  width: 100%;
  max-width: 420px;
}

.ds-auth-logo {
  height: 36px;
  display: block;
  margin: 0 auto var(--sp-8);
}

/* ── divider ─────────────────────────────────────────── */

.ds-divider {
  border: none;
  border-top: 1px solid var(--hairline);
  margin: var(--sp-4) 0;
}
