/**
 * /assets/css/global.css
 * Reset, tipografia base e utilitários globais
 * Depende de: root.css (deve vir antes)
 */

/* ── Reset ─────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--fg-font);
  font-size: 0.9375rem;       /* 15px */
  line-height: 1.65;
  color: var(--fg-text);
  background: var(--fg-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, svg { display: block; max-width: 100%; }
a { color: var(--fg-primary); text-decoration: none; transition: var(--fg-transition); }
a:hover { color: var(--fg-primary-dark); }
button, input, select, textarea { font: inherit; }
ul, ol { list-style: none; }
h1,h2,h3,h4,h5,h6 { font-weight: 600; line-height: 1.3; color: var(--fg-text); }

/* ── Layout helpers ────────────────────────────────── */
.fg-container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--fg-space-lg);
}

.fg-flex        { display: flex; }
.fg-flex-center { display: flex; align-items: center; justify-content: center; }
.fg-flex-between{ display: flex; align-items: center; justify-content: space-between; }
.fg-flex-col    { display: flex; flex-direction: column; }
.fg-gap-sm      { gap: var(--fg-space-sm); }
.fg-gap-md      { gap: var(--fg-space-md); }
.fg-gap-lg      { gap: var(--fg-space-lg); }

/* ── Cards ─────────────────────────────────────────── */
.fg-card {
  background: var(--fg-card);
  border: 1px solid var(--fg-border);
  border-radius: var(--fg-radius-lg);
  box-shadow: var(--fg-shadow-sm);
  transition: var(--fg-transition);
}
.fg-card:hover { box-shadow: var(--fg-shadow); }

/* ── Formulários ───────────────────────────────────── */
.fg-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8125rem;   /* 13px */
  font-weight: 600;
  color: var(--fg-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}

.fg-input {
  width: 100%;
  height: 44px;
  padding: 0 14px;
  font-size: 0.9375rem;
  color: var(--fg-text);
  background: var(--fg-bg);
  border: 1.5px solid var(--fg-border-medium);
  border-radius: var(--fg-radius);
  outline: none;
  transition: var(--fg-transition);
}
.fg-input::placeholder { color: var(--fg-text-muted); }
.fg-input:hover { border-color: var(--fg-border-strong); }
.fg-input:focus {
  border-color: var(--fg-primary);
  background: var(--fg-primary-xxlight);
  box-shadow: 0 0 0 3px rgba(89,55,166,0.10);
}
.fg-input.is-error {
  border-color: var(--fg-danger);
  background: #fff8f8;
}

/* input com ícone à esquerda */
.fg-input-wrap { position: relative; }
.fg-input-wrap .fg-input { padding-left: 42px; }
.fg-input-wrap .fg-input-icon {
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--fg-text-muted);
  pointer-events: none;
  transition: var(--fg-transition);
}
.fg-input-wrap:focus-within .fg-input-icon { color: var(--fg-primary); }

/* toggle de senha */
.fg-input-wrap .fg-btn-toggle-pass {
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  color: var(--fg-text-muted);
  transition: var(--fg-transition);
}
.fg-btn-toggle-pass:hover { color: var(--fg-primary); }

/* ── Botões ─────────────────────────────────────────── */
.fg-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 22px;
  font-size: 0.9375rem;
  font-weight: 600;
  border-radius: var(--fg-radius);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: var(--fg-transition);
  white-space: nowrap;
  letter-spacing: 0.2px;
  text-decoration: none;
}
.fg-btn:active { transform: scale(0.98); }

.fg-btn-primary {
  background: var(--fg-primary);
  border-color: var(--fg-primary);
  color: var(--fg-text-on-primary);
}
.fg-btn-primary:hover {
  background: var(--fg-primary-dark);
  border-color: var(--fg-primary-dark);
  color: var(--fg-text-on-primary);
}

.fg-btn-ghost {
  background: transparent;
  border-color: var(--fg-border-medium);
  color: var(--fg-text-secondary);
}
.fg-btn-ghost:hover {
  border-color: var(--fg-primary);
  color: var(--fg-primary);
  background: var(--fg-primary-xxlight);
}

.fg-btn-block { width: 100%; }
.fg-btn-sm { height: 36px; padding: 0 16px; font-size: 0.875rem; }

/* ── Alertas ─────────────────────────────────────────── */
.fg-alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--fg-radius);
  font-size: 0.875rem;
  line-height: 1.5;
  border: 1px solid transparent;
}
.fg-alert svg { flex-shrink: 0; margin-top: 1px; width: 16px; height: 16px; }
.fg-alert-success { background: var(--fg-success-bg); color: var(--fg-success-text); border-color: rgba(16,185,129,0.25); }
.fg-alert-danger  { background: var(--fg-danger-bg);  color: var(--fg-danger-text);  border-color: rgba(239,68,68,0.25); }
.fg-alert-warning { background: var(--fg-warning-bg); color: var(--fg-warning-text); border-color: rgba(245,158,11,0.25); }
.fg-alert-info    { background: var(--fg-info-bg);    color: var(--fg-info-text);    border-color: rgba(59,130,246,0.25); }

/* ── Badges de perfil ────────────────────────────────── */
.fg-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}
.fg-badge-admin   { background: var(--fg-badge-admin-bg);   color: var(--fg-badge-admin-text); }
.fg-badge-gestor  { background: var(--fg-badge-gestor-bg);  color: var(--fg-badge-gestor-text); }
.fg-badge-usuario { background: var(--fg-badge-user-bg);    color: var(--fg-badge-user-text); }
.fg-badge-func    { background: var(--fg-badge-func-bg);    color: var(--fg-badge-func-text); }

/* ── Utilitários de texto ─────────────────────────────── */
.fg-text-muted    { color: var(--fg-text-muted); }
.fg-text-secondary{ color: var(--fg-text-secondary); }
.fg-text-brand    { color: var(--fg-primary); }
.fg-text-sm       { font-size: 0.8125rem; }
.fg-text-xs       { font-size: 0.75rem; }
.fg-fw-600        { font-weight: 600; }

/* ── Divisor ─────────────────────────────────────────── */
.fg-divider {
  border: none;
  border-top: 1px solid var(--fg-border);
  margin: var(--fg-space-md) 0;
}

/* ── Spinner de carregamento ─────────────────────────── */
.fg-spinner {
  width: 18px;
  height: 18px;
  border: 2.5px solid rgba(255,255,255,0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: fg-spin 0.65s linear infinite;
}
@keyframes fg-spin { to { transform: rotate(360deg); } }

/* ── Responsivo base ─────────────────────────────────── */
@media (max-width: 768px) {
  .fg-hidden-mobile { display: none !important; }
}
@media (min-width: 769px) {
  .fg-hidden-desktop { display: none !important; }
}

/* ── Indicadores do endpoint estoque ─────────────────────────────────── */
.stock-indicators{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
  margin:0 0 14px;
}

.stock-dot{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.8125rem;
  font-weight:800;
  color:var(--fg-text);
  background:#fff;
  border:1px solid var(--fg-border);
  border-radius:999px;
  padding:6px 10px;
  box-shadow:0 4px 12px rgba(15,23,42,.06);
}

.stock-dot::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:999px;
  display:inline-block;
}

.stock-dot.red::before{ background:#ef4444; }
.stock-dot.yellow::before{ background:#f59e0b; }
.stock-dot.green::before{ background:#22c55e; }


/* ── Toogle Simples ─────────────────────────────────── */

.switch {
  position: relative;
  display: inline-block;
  width: 40px;
  height: 20px;
}

.switch input { display:none; }

.slider {
  position: absolute;
  cursor: pointer;
  background: #ccc;
  border-radius: 20px;
  top: 0; left: 0; right: 0; bottom: 0;
}

.slider:before {
  content: "";
  position: absolute;
  height: 16px; width: 16px;
  left: 2px; top: 2px;
  background: white;
  border-radius: 50%;
  transition: .2s;
}

input:checked + .slider {
  background: #22c55e;
}

input:checked + .slider:before {
  transform: translateX(20px);
}