/* ===================================================================
 * Copilot Country Seattle — Admin Dashboard Styles
 * =================================================================== */

/* Admin Greeting */
.admin-greeting {
  background: linear-gradient(135deg, #e8f4fd, #f0faf5);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-lg);
  border-left: 4px solid var(--copilot-blue);
}
.admin-greeting h3 {
  margin: 0 0 0.25rem 0;
  color: var(--dark);
  font-size: 1.25rem;
}
.admin-greeting p {
  margin: 0;
  color: var(--gray);
  font-size: 0.95rem;
}

/* Login Screen */
.admin-login {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: linear-gradient(135deg, #1a2940 0%, #243553 50%, #0078D4 100%);
  padding: var(--space-md);
}

.admin-login-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-xl);
  max-width: 420px;
  width: 100%;
}

.admin-login-header {
  text-align: center;
  margin-bottom: var(--space-lg);
}

.admin-login-logo {
  width: 80px;
  margin-bottom: var(--space-sm);
}

.admin-login-header h1 {
  font-size: var(--font-size-xl);
  margin-bottom: 0.25rem;
}

.admin-login-header p {
  color: var(--charcoal-light);
  margin: 0;
}

.admin-error {
  background: #fef2f2;
  color: var(--error);
  padding: 0.75rem 1rem;
  border-radius: var(--radius);
  margin-bottom: var(--space-sm);
  font-size: var(--font-size-sm);
  border-left: 3px solid var(--error);
}

/* Admin Header */
.admin-header {
  background: var(--white);
  border-bottom: 3px solid transparent;
  border-image: var(--copilot-gradient-h) 1;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  position: sticky;
  top: 0;
  z-index: 100;
}

.admin-header-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 0;
}

.admin-header-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.admin-user-badge {
  font-size: var(--font-size-sm);
  color: var(--charcoal-light);
  padding: 0.25rem 0.75rem;
  background: var(--sand);
  border-radius: 20px;
}

/* Admin Layout */
.admin-layout {
  display: flex;
  min-height: calc(100vh - 70px);
}

/* Sidebar */
.admin-sidebar {
  width: 240px;
  background: #1a2940;
  color: var(--white);
  padding: var(--space-md) 0;
  flex-shrink: 0;
}

.admin-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}

.admin-nav li {
  margin: 0;
}

.admin-nav-btn {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.85rem 1.5rem;
  background: none;
  border: none;
  color: rgba(255,255,255,0.75);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: all 0.2s ease;
  border-left: 3px solid transparent;
}

.admin-nav-btn:hover {
  background: rgba(255,255,255,0.08);
  color: var(--white);
}

.admin-nav-btn.active {
  background: rgba(0,120,212,0.2);
  color: var(--white);
  border-left-color: var(--copilot-blue);
  font-weight: 600;
}

/* Main Content */
.admin-main {
  flex: 1;
  padding: var(--space-lg);
  background: var(--oat);
  overflow-y: auto;
}

/* Sections */
.admin-section {
  display: none;
}

.admin-section.active {
  display: block;
}

.admin-section h2 {
  margin-bottom: var(--space-lg);
  font-size: var(--font-size-2xl);
}

.admin-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-lg);
}

.admin-section-header h2 {
  margin-bottom: 0;
}

.admin-section-actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.bulk-import-preview {
  padding: 0.5rem 0;
}

.form-hint {
  display: block;
  color: var(--gray);
  font-size: 0.85rem;
  margin-top: 0.25rem;
}

/* Stats Cards */
.admin-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-md);
  margin-top: var(--space-md);
}

.admin-stat-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  text-align: center;
  box-shadow: var(--shadow);
  border-top: 3px solid var(--copilot-blue);
}

.admin-stat-number {
  font-size: 2.5rem;
  font-weight: 800;
  background: var(--copilot-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.admin-stat-label {
  color: var(--charcoal-light);
  font-size: var(--font-size-sm);
  margin-top: 0.25rem;
}

/* Tables */
.admin-table-container {
  overflow-x: auto;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
}

.admin-table thead {
  background: #1a2940;
  color: var(--white);
}

.admin-table th {
  padding: 0.85rem 1rem;
  text-align: left;
  font-size: var(--font-size-sm);
  font-weight: 600;
  white-space: nowrap;
}

.admin-table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--sand);
  font-size: var(--font-size-sm);
  vertical-align: middle;
}

.admin-table tbody tr:hover {
  background: var(--sand-light);
}

.admin-table tbody tr:last-child td {
  border-bottom: none;
}

.admin-thumb {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  object-position: top center;
}

.admin-tag {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  background: var(--sand);
  border-radius: 12px;
  font-size: 0.75rem;
  margin: 0.1rem;
  white-space: nowrap;
}

.admin-actions {
  white-space: nowrap;
}

.admin-actions .btn {
  margin-right: 0.25rem;
}

.admin-btn-danger {
  color: var(--error) !important;
  border-color: var(--error) !important;
}

.admin-btn-danger:hover {
  background: var(--error) !important;
  color: var(--white) !important;
}

/* Role badges */
.admin-role-badge {
  display: inline-block;
  padding: 0.2rem 0.65rem;
  border-radius: 12px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.admin-role-admin {
  background: rgba(119, 25, 170, 0.15);
  color: var(--accent);
}

.admin-role-editor {
  background: rgba(0, 120, 212, 0.15);
  color: var(--copilot-blue);
}

/* Empty state */
.admin-empty {
  text-align: center;
  padding: var(--space-xl);
  color: var(--charcoal-light);
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
}

.admin-help-text {
  font-size: var(--font-size-sm);
  color: var(--charcoal-light);
  margin-bottom: var(--space-md);
}

/* Gallery admin grid */
.admin-gallery-month {
  margin-top: var(--space-lg);
  margin-bottom: var(--space-sm);
  color: var(--copilot-blue);
}

.admin-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.admin-gallery-card {
  background: var(--white);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}

.admin-gallery-img {
  width: 100%;
  height: 140px;
  object-fit: cover;
  object-position: top center;
}

.admin-gallery-info {
  padding: 0.6rem;
  font-size: 0.8rem;
}

.admin-gallery-info strong {
  display: block;
  margin-bottom: 0.4rem;
  line-height: 1.3;
}

.admin-gallery-actions {
  display: flex;
  gap: 0.25rem;
}

.admin-gallery-actions .btn {
  font-size: 0.7rem;
  padding: 0.2rem 0.5rem;
}

/* Slider admin */
.admin-slider-thumb {
  width: 120px;
  height: 60px;
  object-fit: cover;
  border-radius: var(--radius);
}

.admin-order-btns {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.admin-order-btns .btn {
  padding: 0.1rem 0.5rem;
  font-size: 0.7rem;
  line-height: 1.2;
}

.admin-cell-truncate {
  max-width: 200px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Modal */
.admin-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.admin-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
}

.admin-modal-content {
  position: relative;
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  max-width: 700px;
  width: 95%;
  max-height: 90vh;
  overflow-y: auto;
}

.admin-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--sand);
  position: sticky;
  top: 0;
  background: var(--white);
  z-index: 1;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.admin-modal-header h3 {
  margin: 0;
  font-size: var(--font-size-lg);
}

.admin-modal-close {
  background: none;
  border: none;
  font-size: 1.5rem;
  cursor: pointer;
  color: var(--charcoal-light);
  padding: 0.25rem;
  line-height: 1;
}

.admin-modal-close:hover {
  color: var(--charcoal);
}

.admin-modal-body {
  padding: 1.5rem;
}

/* Forms inside admin */
.admin-form .form-group {
  margin-bottom: var(--space-sm);
}

.admin-form .form-label {
  display: block;
  margin-bottom: 0.3rem;
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--charcoal);
}

.admin-form .form-input,
.admin-form .form-textarea,
.admin-form .form-select {
  width: 100%;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--sand);
  border-radius: var(--radius);
  font-size: var(--font-size-sm);
  font-family: inherit;
  transition: border-color 0.2s;
}

.admin-form .form-input:focus,
.admin-form .form-textarea:focus,
.admin-form .form-select:focus {
  outline: none;
  border-color: var(--copilot-blue);
  box-shadow: 0 0 0 3px rgba(0,120,212,0.15);
}

.admin-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
}

/* Responsive */
@media (max-width: 768px) {
  .admin-layout {
    flex-direction: column;
  }

  .admin-sidebar {
    width: 100%;
    padding: 0;
  }

  .admin-nav {
    display: flex;
    overflow-x: auto;
    padding: 0.5rem;
  }

  .admin-nav-btn {
    white-space: nowrap;
    padding: 0.6rem 1rem;
    border-left: none;
    border-bottom: 2px solid transparent;
    font-size: 0.8rem;
  }

  .admin-nav-btn.active {
    border-left: none;
    border-bottom-color: var(--copilot-blue);
  }

  .admin-main {
    padding: var(--space-sm);
  }

  .admin-form-grid {
    grid-template-columns: 1fr;
  }

  .admin-header-right {
    gap: 0.4rem;
  }

  .admin-header-content {
    flex-wrap: wrap;
    gap: 0.5rem;
  }
}
