/* 
 * Admin Smart Frontend v0.4.0
 * SMART Tools Design System lock
 * Minimalista contemporâneo soft-pastel
 */

:root {
  --st-bg-page: #F4F4F6;
  --st-bg-card: #FFFFFF;
  --st-bg-subtle: #F4F4F6;
  --st-bg-black: #1A1A1A;

  --st-text-primary: #1A1A1A;
  --st-text-secondary: #6B6B70;
  --st-text-tertiary: #9A9A9F;
  --st-text-on-black: #FFFFFF;

  --st-border: #EEEEF0;
  --st-border-strong: #E0E0E3;

  --st-blue-bg: #DCE9FB;
  --st-blue-text: #2563AB;
  --st-mint-bg: #D6F0E4;
  --st-mint-text: #2A8060;
  --st-pink-bg: #F9DDE6;
  --st-pink-text: #A03B5F;
  --st-lilac-bg: #D4C5F9;
  --st-lilac-text: #6B5BB8;
  --st-amber-bg: #FCE7C2;
  --st-amber-text: #C98920;
  --st-accent-lime: #C8F560;

  --st-font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --st-font-size-xs: 10px;
  --st-font-size-sm: 11px;
  --st-font-size-base: 13px;
  --st-font-size-md: 14px;
  --st-font-size-lg: 18px;
  --st-font-size-xl: 22px;
  --st-font-size-display: 28px;

  --st-font-weight-regular: 400;
  --st-font-weight-medium: 500;

  --st-line-height-tight: 1.2;
  --st-line-height-base: 1.5;
  --st-line-height-relaxed: 1.7;

  --st-space-1: 4px;
  --st-space-2: 8px;
  --st-space-3: 12px;
  --st-space-4: 16px;
  --st-space-5: 20px;
  --st-space-6: 24px;
  --st-space-8: 32px;

  --st-gap-cards: 14px;

  --st-radius-sm: 8px;
  --st-radius-md: 10px;
  --st-radius-lg: 16px;
  --st-radius-xl: 20px;
  --st-radius-pill: 999px;

  --st-shadow-none: none;
  --st-shadow-focus: 0 0 0 3px rgba(107, 91, 184, 0.15);

  --st-transition-fast: 120ms ease;
  --st-transition-base: 180ms ease;
}

html,
body {
  margin: 0 !important;
  min-height: 100% !important;
  background: var(--st-bg-page) !important;
  color: var(--st-text-primary) !important;
  font-family: var(--st-font-family) !important;
  font-size: var(--st-font-size-base) !important;
  font-weight: var(--st-font-weight-regular) !important;
  line-height: var(--st-line-height-base) !important;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

.asf-app,
.asf-app * {
  font-family: var(--st-font-family) !important;
  font-weight: var(--st-font-weight-regular);
}

.asf-app strong,
.asf-app h1,
.asf-app h2,
.asf-app h3,
.asf-app .asf-brand strong,
.asf-app .asf-card-link strong,
.asf-app .asf-table strong {
  font-weight: var(--st-font-weight-medium) !important;
}

body.admin-bar .asf-app {
  min-height: calc(100vh - 32px);
}

.asf-app {
  min-height: 100vh;
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--st-space-4);
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr);
  gap: var(--st-gap-cards);
  background: var(--st-bg-page) !important;
  color: var(--st-text-primary);
}

/* Sidebar branca, sem estilo escuro antigo */
.asf-sidebar {
  background: var(--st-bg-card) !important;
  color: var(--st-text-primary) !important;
  border-radius: var(--st-radius-lg);
  padding: var(--st-space-3) var(--st-space-2);
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 32px);
  border: none !important;
  box-shadow: none !important;
}

.asf-brand {
  display: flex;
  align-items: center;
  gap: var(--st-space-3);
  padding: var(--st-space-2) var(--st-space-3) var(--st-space-4);
  margin-bottom: var(--st-space-2);
  border-bottom: 0.5px solid var(--st-border);
}

.asf-brand-mark {
  width: 34px;
  height: 34px;
  border-radius: var(--st-radius-pill);
  background: var(--st-bg-black) !important;
  color: var(--st-accent-lime) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--st-font-size-sm);
  font-weight: var(--st-font-weight-medium) !important;
  letter-spacing: -0.02em;
  flex-shrink: 0;
}

.asf-brand strong {
  display: block;
  font-size: var(--st-font-size-base);
  line-height: var(--st-line-height-tight);
  color: var(--st-text-primary);
}

.asf-brand small {
  display: block;
  color: var(--st-text-tertiary);
  font-size: var(--st-font-size-xs);
  margin-top: 2px;
}

/* Navegação */
.asf-nav {
  display: flex;
  flex-direction: column;
  gap: var(--st-space-1);
  padding: 0 !important;
}

.asf-nav a {
  display: flex;
  align-items: center;
  gap: var(--st-space-3);
  padding: 9px var(--st-space-3);
  border-radius: var(--st-radius-md);
  color: var(--st-text-secondary) !important;
  background: transparent !important;
  text-decoration: none;
  font-size: var(--st-font-size-base);
  transition: background var(--st-transition-fast), color var(--st-transition-fast);
}

.asf-nav a:hover {
  background: var(--st-bg-subtle) !important;
  color: var(--st-text-primary) !important;
}

.asf-nav a.active {
  background: var(--st-bg-subtle) !important;
  color: var(--st-text-primary) !important;
  font-weight: var(--st-font-weight-medium) !important;
}

/* Tabler icons por rota */
.asf-nav a::before {
  font-family: "tabler-icons";
  font-size: 16px;
  line-height: 1;
  color: currentColor;
  width: 18px;
  text-align: center;
}

.asf-nav a[href$="/app/"]::before { content: "\eaef"; }
.asf-nav a[href*="/compras/"]::before { content: "\eb0b"; }
.asf-nav a[href*="/ciclos/"]::before { content: "\ea53"; }
.asf-nav a[href*="/acompanhamento/"]::before { content: "\eabc"; }
.asf-nav a[href*="/indisponiveis/"]::before { content: "\ea06"; }

.asf-sidebar-footer {
  margin-top: auto;
  padding-top: var(--st-space-4);
  display: flex;
  flex-direction: column;
  gap: var(--st-space-1);
  border-top: 0.5px solid var(--st-border);
}

.asf-sidebar-footer a {
  color: var(--st-text-tertiary) !important;
  text-decoration: none;
  font-size: var(--st-font-size-sm);
  padding: var(--st-space-2) var(--st-space-3);
  border-radius: var(--st-radius-md);
}

.asf-sidebar-footer a:hover {
  background: var(--st-bg-subtle);
  color: var(--st-text-secondary) !important;
}

/* Main */
.asf-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--st-gap-cards);
}

.asf-topbar {
  background: var(--st-bg-card) !important;
  color: var(--st-text-primary) !important;
  border: none !important;
  border-radius: var(--st-radius-lg);
  padding: var(--st-space-5) var(--st-space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--st-space-4);
  box-shadow: none !important;
}

.asf-topbar h1 {
  margin: 0;
  font-size: var(--st-font-size-display);
  font-weight: var(--st-font-weight-medium) !important;
  letter-spacing: -0.5px;
  line-height: var(--st-line-height-tight);
  color: var(--st-text-primary);
}

.asf-topbar p {
  margin: var(--st-space-1) 0 0;
  color: var(--st-text-secondary);
  font-size: var(--st-font-size-base);
}

.asf-admin-link {
  background: var(--st-bg-subtle) !important;
  color: var(--st-text-secondary) !important;
  border: none !important;
  border-radius: var(--st-radius-pill);
  padding: var(--st-space-2) var(--st-space-4);
  font-size: var(--st-font-size-sm);
  text-decoration: none;
}

.asf-admin-link:hover {
  color: var(--st-text-primary) !important;
}

.asf-content {
  display: flex;
  flex-direction: column;
  gap: var(--st-gap-cards);
}

/* Cards */
.asf-hero,
.asf-card {
  background: var(--st-bg-card) !important;
  color: var(--st-text-primary) !important;
  border-radius: var(--st-radius-lg);
  padding: var(--st-space-4) var(--st-space-5);
  border: none !important;
  box-shadow: none !important;
  margin: 0;
}

.asf-hero h2,
.asf-card h2 {
  margin: 0 0 var(--st-space-3);
  font-size: var(--st-font-size-lg);
  line-height: var(--st-line-height-tight);
  color: var(--st-text-primary);
}

.asf-hero p,
.asf-card p {
  margin: 0;
  color: var(--st-text-secondary);
  font-size: var(--st-font-size-base);
  line-height: var(--st-line-height-base);
}

.asf-kicker,
.asf-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--st-space-2);
  border-radius: var(--st-radius-pill);
  font-size: var(--st-font-size-xs);
  font-weight: var(--st-font-weight-regular) !important;
  margin-bottom: var(--st-space-3);
}

.asf-kicker,
.asf-badge--lilac {
  background: var(--st-lilac-bg) !important;
  color: var(--st-lilac-text) !important;
}

.asf-badge--blue { background: var(--st-blue-bg) !important; color: var(--st-blue-text) !important; }
.asf-badge--mint { background: var(--st-mint-bg) !important; color: var(--st-mint-text) !important; }
.asf-badge--pink { background: var(--st-pink-bg) !important; color: var(--st-pink-text) !important; }
.asf-badge--amber { background: var(--st-amber-bg) !important; color: var(--st-amber-text) !important; }

/* Grid */
.asf-grid {
  display: grid;
  gap: var(--st-gap-cards);
}

.asf-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.asf-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.asf-card-link {
  color: var(--st-text-primary);
  text-decoration: none;
}

.asf-card-link strong {
  display: block;
  font-size: var(--st-font-size-base);
  margin-bottom: var(--st-space-1);
}

.asf-card-link span,
.asf-muted {
  display: block;
  color: var(--st-text-secondary);
  font-size: var(--st-font-size-sm);
}

/* Métricas */
.asf-metric {
  min-height: 96px;
}

.asf-metric::before {
  content: "";
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: block;
  margin-bottom: var(--st-space-3);
}

.asf-grid-4 .asf-metric:nth-child(1)::before { background: var(--st-blue-bg); }
.asf-grid-4 .asf-metric:nth-child(2)::before { background: var(--st-lilac-bg); }
.asf-grid-4 .asf-metric:nth-child(3)::before { background: var(--st-mint-bg); }
.asf-grid-4 .asf-metric:nth-child(4)::before { background: var(--st-pink-bg); }

.asf-metric span {
  display: block;
  color: var(--st-text-tertiary);
  font-size: var(--st-font-size-xs);
  margin-bottom: var(--st-space-1);
}

.asf-metric strong {
  display: block;
  font-size: var(--st-font-size-xl);
  line-height: var(--st-line-height-tight);
  color: var(--st-text-primary);
}

.asf-metric.danger strong {
  color: var(--st-pink-text);
}

/* Botões */
.asf-button {
  background: var(--st-bg-black) !important;
  color: var(--st-text-on-black) !important;
  border: none !important;
  border-radius: var(--st-radius-pill);
  padding: var(--st-space-3) var(--st-space-5);
  font-family: inherit;
  font-size: var(--st-font-size-base);
  font-weight: var(--st-font-weight-medium) !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--st-space-2);
  text-decoration: none;
  transition: opacity var(--st-transition-fast), transform var(--st-transition-fast);
}

.asf-button:hover {
  opacity: 0.85;
}

.asf-button:active {
  transform: scale(0.98);
}

.asf-button.small {
  padding: var(--st-space-1) var(--st-space-3);
  font-size: var(--st-font-size-sm);
  font-weight: var(--st-font-weight-regular) !important;
}

.asf-button.ghost {
  background: var(--st-bg-subtle) !important;
  color: var(--st-text-primary) !important;
}

/* Card header */
.asf-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--st-space-4);
  margin-bottom: var(--st-space-4);
}

.asf-card-head h2 {
  margin: 0;
}

/* Inputs */
.asf-form-inline {
  display: flex;
  align-items: center;
  gap: var(--st-space-3);
  flex-wrap: wrap;
}

.asf-form-inline input,
.asf-form-inline select {
  background: var(--st-bg-subtle) !important;
  border: none !important;
  border-radius: var(--st-radius-pill);
  padding: var(--st-space-2) var(--st-space-4);
  font-family: inherit;
  font-size: var(--st-font-size-base);
  color: var(--st-text-primary);
  outline: none;
  min-width: 260px;
  transition: box-shadow var(--st-transition-fast);
}

.asf-form-inline input::placeholder {
  color: var(--st-text-tertiary);
}

.asf-form-inline input:focus,
.asf-form-inline select:focus {
  box-shadow: var(--st-shadow-focus);
}

/* Tabela */
.asf-table-wrap {
  overflow: auto;
}

.asf-table {
  width: 100%;
  font-size: var(--st-font-size-sm);
  border-collapse: collapse;
}

.asf-table thead th {
  font-size: var(--st-font-size-xs);
  font-weight: var(--st-font-weight-regular) !important;
  color: var(--st-text-tertiary);
  text-align: left;
  padding: 0 0 var(--st-space-3);
  border-bottom: 0.5px solid var(--st-border);
}

.asf-table tbody td {
  padding: var(--st-space-3) 0;
  border-bottom: 0.5px solid var(--st-bg-subtle);
  color: var(--st-text-primary);
}

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

.asf-table small {
  display: block;
  color: var(--st-text-tertiary);
  font-size: var(--st-font-size-xs);
  margin-top: 2px;
}

/* Status pills */
.asf-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--st-space-1);
  font-size: var(--st-font-size-xs);
  color: var(--st-blue-text);
  background: transparent !important;
  border-radius: 0;
  padding: 0;
  font-weight: var(--st-font-weight-regular) !important;
}

.asf-pill::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
}

.asf-pill.danger {
  color: var(--st-pink-text);
}

/* Steps */
.asf-steps {
  display: flex;
  flex-direction: column;
  gap: var(--st-gap-cards);
}

.asf-step {
  display: flex;
  align-items: flex-start;
  gap: var(--st-space-3);
  background: var(--st-bg-subtle) !important;
  border: none !important;
  border-radius: var(--st-radius-md);
  padding: var(--st-space-3);
}

.asf-step > span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--st-text-tertiary);
  margin-top: 6px;
  flex-shrink: 0;
}

.asf-step.current > span { background: var(--st-lilac-text); }
.asf-step.completed > span { background: var(--st-mint-text); }

.asf-step strong {
  display: block;
  font-size: var(--st-font-size-base);
  color: var(--st-text-primary);
}

.asf-step small {
  display: block;
  margin-top: 2px;
  font-size: var(--st-font-size-xs);
  color: var(--st-text-tertiary);
}

/* Ciclo */
.asf-cycle-layout {
  display: grid;
  grid-template-columns: minmax(260px, 340px) 1fr;
  gap: var(--st-gap-cards);
  align-items: start;
}

.asf-cycle-main {
  min-height: 420px;
}

.asf-step-header {
  margin-bottom: var(--st-space-5);
}

.asf-step-header h2 {
  margin: var(--st-space-2) 0 var(--st-space-1);
}

/* Icon circles */
.asf-icon-circle {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.asf-icon-circle i {
  font-size: 18px;
}

.asf-icon-circle--blue { background: var(--st-blue-bg); color: var(--st-blue-text); }
.asf-icon-circle--mint { background: var(--st-mint-bg); color: var(--st-mint-text); }
.asf-icon-circle--pink { background: var(--st-pink-bg); color: var(--st-pink-text); }
.asf-icon-circle--lilac { background: var(--st-lilac-bg); color: var(--st-lilac-text); }
.asf-icon-circle--amber { background: var(--st-amber-bg); color: var(--st-amber-text); }

/* Importador */
.asf-stock-step {
  display: none;
}

.asf-stock-step.is-active {
  display: block;
}

.asf-company-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--st-gap-cards);
}

.asf-company-card {
  background: var(--st-bg-subtle) !important;
  border: none !important;
  border-radius: var(--st-radius-lg);
  padding: var(--st-space-5);
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  color: var(--st-text-primary);
  transition: box-shadow var(--st-transition-fast), background var(--st-transition-fast);
}

.asf-company-card:hover,
.asf-company-card.is-selected {
  box-shadow: var(--st-shadow-focus);
  background: var(--st-bg-card) !important;
}

.asf-company-card strong,
.asf-company-card small {
  display: block;
}

.asf-company-card strong {
  margin-top: var(--st-space-3);
  font-size: var(--st-font-size-base);
}

.asf-company-card small {
  color: var(--st-text-tertiary);
  font-size: var(--st-font-size-sm);
  margin-top: var(--st-space-1);
}

.asf-upload-zone {
  min-height: 240px;
  background: var(--st-bg-subtle) !important;
  border: none !important;
  border-radius: var(--st-radius-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--st-space-2);
  text-align: center;
  cursor: pointer;
  transition: box-shadow var(--st-transition-fast), background var(--st-transition-fast);
}

.asf-upload-zone:hover,
.asf-upload-zone.is-over,
.asf-upload-zone.is-ready {
  background: var(--st-bg-card) !important;
  box-shadow: var(--st-shadow-focus);
}

.asf-upload-zone strong {
  font-weight: var(--st-font-weight-medium) !important;
}

.asf-upload-zone small {
  color: var(--st-text-tertiary);
}

.asf-stock-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--st-space-2);
  margin-top: var(--st-space-5);
}

.asf-done-box {
  min-height: 260px;
  display: grid;
  place-items: center;
  text-align: center;
  gap: var(--st-space-2);
  background: var(--st-bg-subtle) !important;
  border-radius: var(--st-radius-lg);
  padding: var(--st-space-8);
}

.asf-done-box h2 {
  margin: 0;
}

.asf-placeholder-soft {
  display: flex;
  flex-direction: column;
  gap: var(--st-space-2);
  background: var(--st-bg-subtle) !important;
  border-radius: var(--st-radius-lg);
  padding: var(--st-space-5);
}

.asf-placeholder-soft strong {
  font-weight: var(--st-font-weight-medium) !important;
}

.asf-placeholder-soft small {
  color: var(--st-text-tertiary);
}

/* Login */
.asf-login-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--st-space-4);
  background: var(--st-bg-page);
  font-family: var(--st-font-family);
}

.asf-login-card {
  width: min(560px, 100%);
  background: var(--st-bg-card);
  border-radius: var(--st-radius-xl);
  padding: var(--st-space-8);
  border: none !important;
  box-shadow: none !important;
}

.asf-login-card h1 {
  font-size: var(--st-font-size-display);
  line-height: var(--st-line-height-tight);
  margin: 0 0 var(--st-space-3);
  letter-spacing: -0.5px;
}

.asf-login-card p {
  color: var(--st-text-secondary);
  font-size: var(--st-font-size-base);
  margin-bottom: var(--st-space-6);
}

/* Responsivo */
@media (max-width: 900px) {
  .asf-app {
    grid-template-columns: 1fr;
    padding: var(--st-space-3);
  }

  .asf-sidebar {
    min-height: auto;
  }

  .asf-nav {
    flex-direction: row;
    overflow-x: auto;
    padding-bottom: var(--st-space-2) !important;
  }

  .asf-nav a {
    flex: 0 0 auto;
  }

  .asf-grid-3,
  .asf-grid-4,
  .asf-cycle-layout,
  .asf-company-grid {
    grid-template-columns: 1fr;
  }

  .asf-topbar {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  .asf-topbar h1 {
    font-size: var(--st-font-size-xl);
  }

  .asf-card-head {
    align-items: flex-start;
    flex-direction: column;
  }
}


/* Admin bar fix v0.4.1 */
html {
  margin-top: 0 !important;
}

#wpadminbar {
  display: none !important;
}

body.admin-bar .asf-app {
  min-height: 100vh;
}
