/* ============================================================
   Casa & Harmonia — Admin Styles
   ============================================================ */

/* ── LOGIN ─────────────────────────────────────────────────── */
body.login-body {
  background: linear-gradient(135deg, var(--sage-light) 0%, var(--terracotta-light) 100%);
  display: flex; align-items: center; justify-content: center;
  padding: 24px; min-height: 100vh;
}
.login-card {
  background: var(--warm-white); border-radius: var(--radius-xl);
  padding: 48px 40px; width: 100%; max-width: 420px;
  box-shadow: var(--shadow-lg); text-align: center;
}
.login-brand {
  font-family: var(--font-display); font-size: 36px; font-weight: 300;
  color: var(--charcoal); margin-bottom: 4px; letter-spacing: 1px;
}
.login-brand span { color: var(--terracotta); font-style: italic; }
.login-tagline { font-size: 13px; color: var(--charcoal-light); margin-bottom: 36px; }
.login-card .form-group { text-align: left; }
.login-divider { margin: 24px 0; border: none; border-top: 1px solid var(--border); }

/* ── LAYOUT ─────────────────────────────────────────────────── */
body.admin-body {
  display: grid;
  grid-template-columns: 240px 1fr;
  grid-template-rows: auto 1fr;
  min-height: 100vh;
  background: var(--cream);
}

/* ── SIDEBAR ─────────────────────────────────────────────────── */
.admin-sidebar {
  background: var(--charcoal); color: #fff;
  grid-row: 1 / -1;
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.sidebar-brand {
  padding: 28px 24px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.sidebar-brand-name {
  font-family: var(--font-display); font-size: 20px; font-weight: 400;
  color: #fff; line-height: 1.2; letter-spacing: .5px;
}
.sidebar-brand-name span { color: #D4A878; font-style: italic; }
.sidebar-brand-sub {
  font-size: 11px; color: rgba(255,255,255,.35); margin-top: 4px;
  text-transform: uppercase; letter-spacing: 1.5px;
}
.sidebar-nav { padding: 16px 12px; flex: 1; }
.nav-section-label {
  font-size: 10px; font-weight: 500; color: rgba(255,255,255,.3);
  text-transform: uppercase; letter-spacing: 1.5px; padding: 10px 12px 4px;
}
.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: var(--radius-md);
  color: rgba(255,255,255,.65); font-size: 14px;
  cursor: pointer; transition: all var(--transition);
  margin-bottom: 2px; border: none; background: none;
  width: 100%; text-align: left; font-family: var(--font-body);
}
.nav-item:hover { background: rgba(255,255,255,.08); color: #fff; }
.nav-item.active { background: var(--terracotta); color: #fff; }
.nav-icon { font-size: 16px; width: 20px; text-align: center; }
.nav-badge {
  margin-left: auto; background: var(--terracotta);
  color: #fff; font-size: 11px; font-weight: 600;
  padding: 2px 7px; border-radius: 10px; min-width: 20px; text-align: center;
}
.nav-item.active .nav-badge { background: rgba(255,255,255,.3); }
.sidebar-footer {
  padding: 12px; border-top: 1px solid rgba(255,255,255,.1);
}

/* ── TOPBAR ─────────────────────────────────────────────────── */
.admin-topbar {
  background: var(--warm-white); border-bottom: 1px solid var(--border);
  padding: 16px 32px;
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; z-index: 50;
}
.topbar-title { font-family: var(--font-display); font-size: 26px; font-weight: 400; }

/* ── CONTENT ─────────────────────────────────────────────────── */
.admin-content { padding: 32px; overflow-y: auto; }
.admin-section { display: none; }
.admin-section.active { display: block; animation: fadeIn .2s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; gap: 16px; }
.section-title { font-family: var(--font-display); font-size: 28px; font-weight: 400; }

/* ── STATS ─────────────────────────────────────────────────── */
.stats-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px; margin-bottom: 28px;
}
.stat-card {
  background: var(--warm-white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 20px 24px; box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition);
}
.stat-card:hover { box-shadow: var(--shadow-md); }
.stat-label {
  font-size: 12px; font-weight: 500; color: var(--charcoal-light);
  text-transform: uppercase; letter-spacing: .8px; margin-bottom: 8px;
}
.stat-value { font-family: var(--font-display); font-size: 32px; font-weight: 300; line-height: 1; }
.stat-sub   { font-size: 12px; color: var(--charcoal-light); margin-top: 4px; }

/* ── ALERT BANNER ─────────────────────────────────────────── */
.alert-banner {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border-radius: var(--radius-md); margin-bottom: 20px;
}
.alert-banner.warning { background: var(--warning-bg); border: 1px solid #E8D090; }
.alert-banner.danger  { background: var(--danger-bg); border: 1px solid #E8BCBC; }
.alert-banner.info    { background: var(--info-bg); border: 1px solid #B8CCEE; }

/* ── PRODUCT THUMB ─────────────────────────────────────────── */
.product-thumb {
  width: 44px; height: 44px; border-radius: var(--radius-sm);
  object-fit: cover; border: 1px solid var(--border);
}

/* ── UNIT COST DISPLAY ─────────────────────────────────────── */
.unit-cost-display {
  padding: 10px 14px; background: var(--cream);
  border-radius: var(--radius-md);
  font-weight: 500; font-family: var(--font-display); font-size: 16px;
}

/* ── SETTINGS ─────────────────────────────────────────────── */
.settings-card {
  background: var(--warm-white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 28px; margin-bottom: 20px;
  max-width: 560px;
}
.settings-card-title {
  font-family: var(--font-display); font-size: 20px; font-weight: 400;
  margin-bottom: 20px; padding-bottom: 14px; border-bottom: 1px solid var(--border);
}
.whatsapp-preview {
  background: var(--success-bg); border: 1px solid #B8D8C4;
  border-radius: var(--radius-md); padding: 12px 16px;
  font-size: 13px; color: var(--success); margin-top: 8px; display: none;
}

/* ── DASHBOARD GRID ────────────────────────────────────────── */
.dashboard-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 4px;
}
.dashboard-card {
  background: var(--warm-white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
}
.dashboard-card-header {
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  font-family: var(--font-display); font-size: 17px; font-weight: 400;
  display: flex; align-items: center; justify-content: space-between;
}

/* ── SEARCH BAR (admin) ────────────────────────────────────── */
.admin-search-bar {
  display: flex; gap: 12px; align-items: center; margin-bottom: 16px; flex-wrap: wrap;
}
.admin-search-bar input { max-width: 300px; }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 900px) {
  body.admin-body { grid-template-columns: 1fr; }
  .admin-sidebar {
    height: auto; position: relative;
    flex-direction: row; overflow-x: auto; grid-row: auto;
  }
  .sidebar-brand  { padding: 12px 16px; border-bottom: none; border-right: 1px solid rgba(255,255,255,.1); flex-shrink: 0; }
  .sidebar-nav    { display: flex; flex-direction: row; padding: 8px; overflow-x: auto; flex: none; }
  .nav-section-label { display: none; }
  .nav-item       { padding: 8px 10px; margin-bottom: 0; margin-right: 2px; white-space: nowrap; }
  .sidebar-footer { display: none; }
  .admin-topbar   { padding: 14px 20px; position: relative; }
  .admin-content  { padding: 20px; }
  .stats-grid     { grid-template-columns: 1fr 1fr; }
  .dashboard-grid { grid-template-columns: 1fr; }
  .grid-2         { grid-template-columns: 1fr; }
}

/* ── ADMIN MOBILE FIXES ──────────────────────────────────────── */
@media (max-width: 480px) {
  /* Sidebar horizontal compacta */
  .sidebar-brand-name { font-size: 16px; }
  .sidebar-brand-sub  { display: none; }
  .nav-item { font-size: 12px; padding: 8px; }
  .nav-icon { font-size: 14px; }

  /* Topbar */
  .admin-topbar { padding: 12px 16px; }
  .topbar-title { font-size: 20px; }
  .admin-topbar .flex-gap .btn { display: none; } /* esconde botões extras */

  /* Content */
  .admin-content { padding: 16px 12px; }
  .section-title { font-size: 22px; }
  .section-header { flex-wrap: wrap; gap: 8px; }

  /* Stats */
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .stat-value { font-size: 24px; }

  /* Dashboard grid */
  .dashboard-grid { grid-template-columns: 1fr; gap: 16px; }

  /* Tabela — scroll horizontal */
  .table-wrapper { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  table { min-width: 400px; }
  td, th { padding: 10px 12px; font-size: 13px; }

  /* Modais */
  .modal { padding: 20px 16px; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .grid-2 { grid-template-columns: 1fr; }
  .grid-2 .form-group[style*="span 2"] { grid-column: span 1; }

  /* Settings */
  .settings-card { padding: 20px 16px; }
}

/* ── CHECKBOX FIX ────────────────────────────────────────────── */
.settings-card input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px;
  cursor: pointer;
  accent-color: var(--terracotta);
  flex-shrink: 0;
}

/* ── CAMPOS DE IMAGEM POR COR ───────────────────────────────── */
.color-img-field {
  background: var(--cream);
  border-radius: var(--radius-md);
  padding: 12px;
  border: 1px solid var(--border);
  margin-bottom: 10px;
}

/* ── FEATURED CHECKBOX FIX ───────────────────────────────────── */
#pm-featured {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  cursor: pointer;
  accent-color: var(--terracotta);
  flex-shrink: 0;
}

/* ── CHECKBOX GERAL FIX ─────────────────────────────────────── */
input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  cursor: pointer;
  accent-color: var(--terracotta);
  flex-shrink: 0;
}
