/* Portal layout enhancements (admin, client, shopper)
   Scope: only portals include this file to avoid site-wide impact */

:root {
  --portal-max: 1400px;
}

/* Shared containers */
.portal-container, .admin-wrap { max-width: var(--portal-max); margin: 20px auto; padding: 0 16px; }

/* Headers */
.portal-header, .admin-header {
  background: linear-gradient(135deg, var(--secondary-color), #1e3a5f);
  color: #fff;
  border-radius: 18px;
  padding: 28px 20px;
}
.portal-header h1, .admin-brand { margin: 0 0 6px 0; }
.portal-header p, .admin-header small { opacity: .9; }

/* Stats */
.portal-stats, .grid, .stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.stat-card, .stat { background: #fff; border-radius: 12px; padding: 18px; box-shadow: 0 2px 10px rgba(0,0,0,.06); text-align: center; }
.stat-card .number { font-size: 1.8rem; font-weight: 800; color: var(--secondary-color); }

/* Sections */
.orders-section, .admin-section, .portal-section { background: #fff; border-radius: 16px; box-shadow: 0 4px 18px rgba(0,0,0,.08); padding: 20px; margin: 16px 0; overflow-x: auto; }
.orders-header, .section-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }

/* Tabs (client filters, admin tabs) */
.filter-tabs, .admin-tabs { display: flex; gap: 10px; flex-wrap: nowrap; overflow-x: auto; padding-bottom: 6px; }
.filter-tab, .admin-tab { white-space: nowrap; }

/* Tables */
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: 12px; border-bottom: 1px solid #eceff3; text-align: left; vertical-align: top; }
.table thead th { background: #f8fafc; position: sticky; top: 0; z-index: 1; }
.table-min { min-width: 760px; }

/* Cards */
.order-card, .assignment-card { border: 2px solid #e5e7eb; border-radius: 12px; padding: 20px; margin-bottom: 14px; }
.order-card:hover, .assignment-card:hover { border-color: var(--primary-color); box-shadow: 0 4px 20px rgba(249,155,57,.12); }

/* Buttons */
.btn, .btn-action, .btn-sm { border-radius: 10px; font-weight: 700; }
.btn-primary, .btn-primary-action { background: var(--primary-color); color: #fff; border: none; }
.btn-secondary, .btn-secondary-action { background: #fff; border: 2px solid var(--secondary-color); color: var(--secondary-color); }

/* Badges */
.badge { padding: 6px 12px; border-radius: 999px; font-size: .85rem; font-weight: 700; }

/* Login pages */
/* Make the whole login page a flex column so the header stays on top,
   the login box centers in the available space, and the footer sticks to bottom */
.portal-login-page { display: flex; flex-direction: column; min-height: 100vh; align-items: stretch; justify-content: flex-start; padding: 0; background: none; }
.portal-login-page .main-footer { margin-top: auto; }

/* Override any legacy min-height rules from style.css with !important to avoid extra tall pages */
body.portal-login-page .login-container { min-height: auto !important; }
.portal-login-page .login-container { flex: 1; display: flex; align-items: center; justify-content: center; padding: 40px 16px; background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%); width: 100%; max-width: none; }
.portal-login-page .login-box { width: 100%; max-width: 420px; background: #fff; border-radius: 16px; box-shadow: 0 14px 40px rgba(0,0,0,.12); padding: 32px 28px; margin-left: auto; margin-right: auto; }
.portal-login-page .login-box h1 { text-align: center; color: var(--secondary-color); margin: 0 0 6px 0; font-size: 1.9rem; }
.portal-login-page .login-box p { text-align: center; color: var(--text-light); margin: 0 0 16px 0; }
.portal-login-page .form-group { margin-bottom: 14px; }
.portal-login-page .form-group label { font-weight: 600; margin-bottom: 6px; display: block; }
.portal-login-page .form-group input { width: 100%; padding: 12px; border: 2px solid #e5e7eb; border-radius: 10px; }
.portal-login-page .btn.btn-primary { width: 100%; padding: 14px; font-size: 1rem; }
.portal-login-page .demo-notice { background: #fff8e1; border: 1px solid #ffecb5; border-radius: 10px; padding: 14px; margin-bottom: 16px; }

/* Responsive tweaks */
@media (max-width: 960px) {
  .portal-header h1 { font-size: 1.6rem; }
  .orders-header { flex-direction: column; align-items: stretch; }
  .btn-action { width: 100%; text-align: center; }
}

@media (max-width: 640px) {
  .stat-card .number { font-size: 1.5rem; }
  .order-card, .assignment-card { padding: 16px; }
}
