/**
 * Shopaliz Admin – Design system (SaaS-like, minimal, high readability)
 * Use with layout connected-ui.layout.twig and components in components/ui/
 */

:root {
  --ui-bg-page: #f5f5f7;
  --ui-bg-card: #ffffff;
  --ui-border: #e5e7eb;
  --ui-text: #111827;
  --ui-text-muted: #6b7280;
  --ui-primary: #2563eb;
  --ui-primary-hover: #1d4ed8;
  --ui-success: #059669;
  --ui-warning: #d97706;
  --ui-danger: #dc2626;
  --ui-info: #0284c7;
  --ui-neutral: #6b7280;
  --ui-space-1: 4px;
  --ui-space-2: 8px;
  --ui-space-3: 12px;
  --ui-space-4: 16px;
  --ui-space-5: 20px;
  --ui-space-6: 24px;
  --ui-space-8: 32px;
  --ui-space-10: 40px;
  --ui-radius: 8px;
  --ui-font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --ui-shadow: 0 1px 3px rgba(0,0,0,0.06);
  --ui-shadow-hover: 0 4px 6px -1px rgba(0,0,0,0.08);
  --ui-sidebar-width: 260px;
  --ui-header-height: 56px;
}

/* ----- Layout ----- */
.ui-app { display: flex; min-height: 100vh; background: var(--ui-bg-page); font-family: var(--ui-font); font-size: 14px; line-height: 1.5; color: var(--ui-text); }
.ui-sidebar { width: var(--ui-sidebar-width); flex-shrink: 0; background: var(--ui-bg-card); border-right: 1px solid var(--ui-border); display: flex; flex-direction: column; }
.ui-sidebar-brand { padding: var(--ui-space-4); border-bottom: 1px solid var(--ui-border); }
.ui-sidebar-brand img { height: 24px; display: block; }
.ui-sidebar-nav { flex: 1; padding: var(--ui-space-2); overflow-y: auto; }
.ui-sidebar-nav a { display: flex; align-items: center; padding: var(--ui-space-2) var(--ui-space-3); color: var(--ui-text); text-decoration: none; border-radius: var(--ui-radius); margin-bottom: 2px; }
.ui-sidebar-nav a:hover { background: var(--ui-bg-page); color: var(--ui-primary); }
.ui-sidebar-nav a.active { background: rgba(37,99,235,0.1); color: var(--ui-primary); font-weight: 500; }
.ui-sidebar-nav .nav-section { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ui-text-muted); padding: var(--ui-space-3) var(--ui-space-3) var(--ui-space-2); }
.ui-main { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.ui-header { height: var(--ui-header-height); background: var(--ui-bg-card); border-bottom: 1px solid var(--ui-border); display: flex; align-items: center; justify-content: space-between; padding: 0 var(--ui-space-6); flex-shrink: 0; }
.ui-header-title { font-size: 1.125rem; font-weight: 600; }
.ui-header-actions { display: flex; align-items: center; gap: var(--ui-space-3); }
.ui-content { flex: 1; padding: var(--ui-space-6); max-width: 1280px; width: 100%; margin: 0 auto; box-sizing: border-box; }

@media (max-width: 768px) {
  .ui-sidebar { position: fixed; left: 0; top: 0; bottom: 0; z-index: 100; transform: translateX(-100%); transition: transform 0.2s; }
  .ui-sidebar.open { transform: translateX(0); }
  .ui-content { padding: var(--ui-space-4); }
}

/* ----- Page header ----- */
.ui-page-header { margin-bottom: var(--ui-space-6); display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--ui-space-4); }
.ui-page-header h1 { font-size: 1.5rem; font-weight: 600; margin: 0; }
.ui-page-header .subtitle { font-size: 0.875rem; color: var(--ui-text-muted); margin-top: 2px; }
.ui-page-header-actions { display: flex; align-items: center; gap: var(--ui-space-2); }

/* ----- Card ----- */
.ui-card { background: var(--ui-bg-card); border-radius: var(--ui-radius); box-shadow: var(--ui-shadow); border: 1px solid var(--ui-border); overflow: hidden; }
.ui-card-header { padding: var(--ui-space-4) var(--ui-space-6); border-bottom: 1px solid var(--ui-border); font-weight: 600; font-size: 1rem; }
.ui-card-body { padding: var(--ui-space-6); }

/* ----- Table ----- */
.ui-table-wrap { overflow-x: auto; }
.ui-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.ui-table th { text-align: left; padding: var(--ui-space-3) var(--ui-space-4); background: var(--ui-bg-page); font-weight: 600; color: var(--ui-text-muted); border-bottom: 1px solid var(--ui-border); white-space: nowrap; }
.ui-table td { padding: var(--ui-space-3) var(--ui-space-4); border-bottom: 1px solid var(--ui-border); vertical-align: middle; }
.ui-table tbody tr:hover { background: #fafafa; }
.ui-table tbody tr:last-child td { border-bottom: 0; }
.ui-table .ui-table-actions { white-space: nowrap; }

/* ----- Badge ----- */
.ui-badge { display: inline-flex; align-items: center; padding: 2px 8px; font-size: 12px; font-weight: 500; border-radius: 9999px; }
.ui-badge--success { background: rgba(5,150,105,0.12); color: var(--ui-success); }
.ui-badge--warning { background: rgba(217,119,6,0.12); color: var(--ui-warning); }
.ui-badge--danger { background: rgba(220,38,38,0.12); color: var(--ui-danger); }
.ui-badge--info { background: rgba(2,132,199,0.12); color: var(--ui-info); }
.ui-badge--neutral { background: rgba(107,114,128,0.15); color: var(--ui-neutral); }

/* ----- Buttons ----- */
.ui-btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--ui-space-2); padding: 8px 16px; font-size: 0.875rem; font-weight: 500; font-family: inherit; border-radius: var(--ui-radius); border: 1px solid transparent; cursor: pointer; text-decoration: none; transition: background 0.15s, color 0.15s, border-color 0.15s; }
.ui-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.ui-btn--primary { background: var(--ui-primary); color: #fff; border-color: var(--ui-primary); }
.ui-btn--primary:hover:not(:disabled) { background: var(--ui-primary-hover); border-color: var(--ui-primary-hover); }
.ui-btn--secondary { background: var(--ui-bg-card); color: var(--ui-text); border-color: var(--ui-border); }
.ui-btn--secondary:hover:not(:disabled) { background: var(--ui-bg-page); }
.ui-btn--ghost { background: transparent; color: var(--ui-text); }
.ui-btn--ghost:hover:not(:disabled) { background: var(--ui-bg-page); }
.ui-btn--danger { background: var(--ui-danger); color: #fff; border-color: var(--ui-danger); }
.ui-btn--danger:hover:not(:disabled) { background: #b91c1c; border-color: #b91c1c; }
.ui-btn--sm { padding: 6px 12px; font-size: 0.8125rem; }

/* ----- Form ----- */
.ui-form-group { margin-bottom: var(--ui-space-4); }
.ui-form-label { display: block; font-size: 0.875rem; font-weight: 500; color: var(--ui-text); margin-bottom: var(--ui-space-2); }
.ui-form-label .required { color: var(--ui-danger); }
.ui-input, .ui-select, .ui-textarea { width: 100%; max-width: 400px; padding: 8px 12px; font-size: 0.875rem; font-family: inherit; border: 1px solid var(--ui-border); border-radius: var(--ui-radius); background: var(--ui-bg-card); color: var(--ui-text); box-sizing: border-box; }
.ui-input:focus, .ui-select:focus, .ui-textarea:focus { outline: none; border-color: var(--ui-primary); box-shadow: 0 0 0 3px rgba(37,99,235,0.15); }
.ui-input.is-invalid, .ui-select.is-invalid, .ui-textarea.is-invalid { border-color: var(--ui-danger); }
.ui-form-error { font-size: 0.8125rem; color: var(--ui-danger); margin-top: var(--ui-space-1); }
.ui-textarea { min-height: 80px; resize: vertical; }
.ui-toggle { display: flex; align-items: center; gap: var(--ui-space-2); }
.ui-toggle input { width: 40px; height: 22px; accent-color: var(--ui-primary); cursor: pointer; }
.ui-checkbox { display: flex; align-items: center; gap: var(--ui-space-2); }
.ui-checkbox input { width: 18px; height: 18px; accent-color: var(--ui-primary); cursor: pointer; }

/* ----- Alert ----- */
.ui-alert { padding: var(--ui-space-4); border-radius: var(--ui-radius); border: 1px solid transparent; margin-bottom: var(--ui-space-4); }
.ui-alert--info { background: rgba(2,132,199,0.08); border-color: rgba(2,132,199,0.3); color: #0369a1; }
.ui-alert--warn { background: rgba(217,119,6,0.08); border-color: rgba(217,119,6,0.3); color: #b45309; }
.ui-alert--error { background: rgba(220,38,38,0.08); border-color: rgba(220,38,38,0.3); color: #b91c1c; }
.ui-alert--success { background: rgba(5,150,105,0.08); border-color: rgba(5,150,105,0.3); color: #047857; }

/* ----- Empty state ----- */
.ui-empty-state { text-align: center; padding: var(--ui-space-10) var(--ui-space-6); }
.ui-empty-state-icon { font-size: 2.5rem; color: var(--ui-border); margin-bottom: var(--ui-space-4); }
.ui-empty-state h3 { font-size: 1rem; font-weight: 600; margin: 0 0 var(--ui-space-2); color: var(--ui-text); }
.ui-empty-state p { font-size: 0.875rem; color: var(--ui-text-muted); margin: 0 0 var(--ui-space-4); max-width: 360px; margin-left: auto; margin-right: auto; }
.ui-empty-state .ui-btn { margin-top: var(--ui-space-2); }

/* ----- Pagination ----- */
.ui-pagination { display: flex; align-items: center; justify-content: center; gap: var(--ui-space-2); flex-wrap: wrap; padding: var(--ui-space-4) 0; }
.ui-pagination a, .ui-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 36px; height: 36px; padding: 0 8px; font-size: 0.875rem; color: var(--ui-text); text-decoration: none; border: 1px solid var(--ui-border); border-radius: var(--ui-radius); background: var(--ui-bg-card); }
.ui-pagination a:hover { background: var(--ui-bg-page); border-color: var(--ui-border); }
.ui-pagination .current { background: var(--ui-primary); color: #fff; border-color: var(--ui-primary); }
.ui-pagination .disabled { opacity: 0.5; pointer-events: none; }
.ui-pagination-info { font-size: 0.8125rem; color: var(--ui-text-muted); margin-right: var(--ui-space-4); }

/* ----- Filters bar ----- */
.ui-filters { display: flex; flex-wrap: wrap; align-items: center; gap: var(--ui-space-3); margin-bottom: var(--ui-space-4); }
.ui-filters .ui-input { max-width: 240px; }
.ui-filters .ui-select { max-width: 160px; }

/* ----- Deployment timeline (states) ----- */
.ui-timeline-step { padding: var(--ui-space-4); border-radius: var(--ui-radius); border-left: 4px solid var(--ui-border); background: #fafafa; margin-bottom: var(--ui-space-3); }
.ui-timeline-step.completed { border-left-color: var(--ui-success); background: rgba(5,150,105,0.04); }
.ui-timeline-step.current { border-left-color: var(--ui-primary); background: rgba(37,99,235,0.04); }
.ui-timeline-step.failed { border-left-color: var(--ui-danger); background: rgba(220,38,38,0.04); }
.ui-timeline-step h4 { font-size: 0.875rem; font-weight: 600; margin: 0 0 var(--ui-space-2); }
.ui-logs-toggle { margin-top: var(--ui-space-3); }
.ui-logs-content { font-family: ui-monospace, monospace; font-size: 12px; background: #1e293b; color: #e2e8f0; padding: var(--ui-space-4); border-radius: var(--ui-radius); max-height: 200px; overflow-y: auto; white-space: pre-wrap; word-break: break-all; }

/* ----- User menu dropdown ----- */
.ui-user-menu { position: relative; }
.ui-user-menu-trigger { display: flex; align-items: center; gap: var(--ui-space-2); padding: var(--ui-space-2) var(--ui-space-3); border: none; background: none; cursor: pointer; font-size: 0.875rem; color: var(--ui-text); border-radius: var(--ui-radius); }
.ui-user-menu-trigger:hover { background: var(--ui-bg-page); }
.ui-user-menu-dropdown { position: absolute; top: 100%; right: 0; margin-top: 4px; min-width: 180px; background: var(--ui-bg-card); border: 1px solid var(--ui-border); border-radius: var(--ui-radius); box-shadow: var(--ui-shadow-hover); z-index: 50; padding: var(--ui-space-2); display: none; }
.ui-user-menu.open .ui-user-menu-dropdown { display: block; }
.ui-user-menu-dropdown a { display: block; padding: var(--ui-space-2) var(--ui-space-3); font-size: 0.875rem; color: var(--ui-text); text-decoration: none; border-radius: 4px; }
.ui-user-menu-dropdown a:hover { background: var(--ui-bg-page); }
