/* CA Central — design tokens (espelho de deliveries/ca-central/fase-0/design-system/design-tokens.md) */

:root {
  /* brand */
  --ca-lavender: #B83FFF;
  --ca-lavender-bright: #C87DFF;
  --ca-lavender-deep: #9B4DCA;
  --ca-purple-deep: #6B2E91;
  --ca-purple-darker: #4A1968;
  --ca-paper-dark: #2A1438;

  /* surfaces */
  --surface-0: #0D0D0D;
  --surface-1: #131114;
  --surface-2: #1A1A1A;
  --surface-3: #221F26;
  --surface-overlay: rgba(184, 63, 255, 0.06);

  /* borders */
  --border-subtle: rgba(255, 255, 255, 0.06);
  --border-default: rgba(255, 255, 255, 0.10);
  --border-strong: rgba(184, 63, 255, 0.30);
  --border-brand: rgba(184, 63, 255, 0.55);

  /* text */
  --text-primary: rgba(255, 255, 255, 0.96);
  --text-secondary: rgba(255, 255, 255, 0.72);
  --text-tertiary: rgba(255, 255, 255, 0.50);
  --text-disabled: rgba(255, 255, 255, 0.28);
  --text-on-brand: #FFFFFF;

  /* status pecas */
  --status-planned: #6B7280;
  --status-captured: #3B82F6;
  --status-editing: #F59E0B;
  --status-approval: #A855F7;
  --status-published: #10B981;
  --status-failed: #EF4444;

  /* tipo */
  --type-reel: #B83FFF;
  --type-post: #EC4899;
  --type-story: #06B6D4;

  /* semantic */
  --success: #10B981;
  --warning: #F59E0B;
  --error: #EF4444;
  --info: #3B82F6;

  /* space */
  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px;
  --space-5: 24px; --space-6: 32px; --space-7: 48px; --space-8: 64px;
  --space-9: 96px; --space-10: 128px;

  /* radius */
  --radius-sm: 4px; --radius-md: 8px; --radius-lg: 12px;
  --radius-xl: 16px; --radius-pill: 999px;

  /* motion */
  --ease-out: cubic-bezier(0.23, 1, 0.32, 1);
  --duration-fast: 150ms;
  --duration-base: 220ms;
  --duration-slow: 320ms;
}

/* ============ reset base ============ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  background: var(--surface-0);
  color: var(--text-primary);
  font-family: 'DM Sans', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  line-height: 1.55;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--ca-lavender); text-decoration: none; transition: color var(--duration-fast) var(--ease-out); }
a:hover { color: var(--ca-lavender-bright); }

/* ============ tipografia ============ */
.eyebrow {
  font-family: 'Cinzel', serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.h1 {
  font-family: 'Cinzel', serif;
  font-weight: 700;
  font-size: 28px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-primary);
  margin: 0;
}
.h2 {
  font-family: 'Cinzel', serif;
  font-weight: 600;
  font-size: 20px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-primary);
  margin: 0;
}
.h3 {
  font-family: 'Cinzel', serif;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-primary);
  margin: 0;
}
.subtle-italic {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-weight: 400;
  color: var(--text-secondary);
}
.script {
  font-family: 'Pinyon Script', cursive;
  font-weight: 400;
  color: var(--ca-lavender-bright);
}
.display-num {
  font-family: 'Bodoni Moda', serif;
  font-style: italic;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 0.95;
}

/* ============ layout ============ */
.shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--space-7) var(--space-5);
}
@media (max-width: 768px) {
  .shell { padding: var(--space-5) var(--space-4); }
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: var(--space-7);
}
.brand {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
}
.brand .mark { font-family: 'Cinzel', serif; font-weight: 800; font-size: 18px; letter-spacing: 0.20em; color: var(--ca-lavender); }
.brand .div { color: var(--text-tertiary); }
.brand .sub { font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--text-secondary); font-size: 16px; }

/* ============ card ============ */
.card {
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  transition: border-color var(--duration-base) var(--ease-out), background var(--duration-base) var(--ease-out);
}
.card:hover { border-color: var(--border-strong); background: var(--surface-2); }
.card-grid {
  display: grid;
  gap: var(--space-4);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

/* ============ chips/status ============ */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  background: var(--surface-overlay);
  color: var(--text-secondary);
  border: 1px solid var(--border-default);
}
.chip-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

.chip[data-status="planejado"]            { color: var(--status-planned); }
.chip[data-status="captado"]              { color: var(--status-captured); }
.chip[data-status="em_edicao"]            { color: var(--status-editing); }
.chip[data-status="aguardando_aprovacao"] { color: var(--status-approval); }
.chip[data-status="aprovado"]             { color: var(--ca-lavender-bright); }
.chip[data-status="publicado"]            { color: var(--status-published); }
.chip[data-status="rejeitado"]            { color: var(--status-failed); }

.chip[data-tipo="reel"]  { color: var(--type-reel); }
.chip[data-tipo="post"]  { color: var(--type-post); }
.chip[data-tipo="story"] { color: var(--type-story); }

/* ============ footer ============ */
.footer {
  margin-top: var(--space-8);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-subtle);
  font-size: 12px;
  color: var(--text-tertiary);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
}

/* ============ utils ============ */
.mt-4 { margin-top: var(--space-4); }
.mt-5 { margin-top: var(--space-5); }
.mt-7 { margin-top: var(--space-7); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.row { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
.muted { color: var(--text-secondary); }
.tertiary { color: var(--text-tertiary); }

.empty {
  border: 1px dashed var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-7);
  text-align: center;
  color: var(--text-tertiary);
}
