/* ============================================================================
   SEAD CRM - DESIGN SYSTEM v3.0
   Minimalist, border-based, flat design - No gradients, no shadows
   ============================================================================ */

/* ============================================================================
   CSS RESET & BASE STYLES
   ============================================================================ */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

*:focus {
  outline: 2px solid #ee4810;
  outline-offset: 2px;
}

/* ============================================================================
   CSS VARIABLES - DESIGN TOKENS
   ============================================================================ */

:root {
  /* Colors - Brand */
  --brand-primary: #ee4810;
  --brand-hover: #d63f0d;
  --brand-light: #fff5f2;

  /* Colors - Background */
  --bg-primary: #FFFFFF;
  --bg-secondary: #F9FAFB;
  --bg-tertiary: #F3F4F6;

  /* Colors - Text */
  --text-primary: #000000;
  --text-secondary: #6B6B6B;
  --text-tertiary: #9CA3AF;

  /* Colors - Borders */
  --border-light: #F3F4F6;
  --border-default: #E5E7EB;
  --border-medium: #D1D5DB;
  --border-hover: #9CA3AF;
  --border-active: #ee4810;
  --border-strong: #4B5563;

  /* Colors - Status */
  --status-success: #10B981;
  --status-success-bg: #D1FAE5;
  --status-warning: #F59E0B;
  --status-warning-bg: #FEF3C7;
  --status-danger: #DC2626;
  --status-danger-bg: #FEE2E2;
  --status-info: #3B82F6;
  --status-info-bg: #DBEAFE;

  /* Spacing Scale (8px base) */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 12px;
  --space-lg: 16px;
  --space-xl: 24px;
  --space-2xl: 32px;
  --space-3xl: 48px;

  /* Border Radius */
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;
  --radius-xl: 12px;
  --radius-full: 9999px;

  /* Typography Scale */
  --font-size-xs: 12px;
  --font-size-sm: 14px;
  --font-size-base: 16px;
  --font-size-lg: 18px;
  --font-size-xl: 20px;
  --font-size-2xl: 24px;
  --font-size-3xl: 32px;

  /* Font Weights */
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 300ms ease;

  /* Z-index Scale */
  --z-header: 100;
  --z-dropdown: 200;
  --z-modal: 300;
  --z-toast: 400;
}

/* ============================================================================
   TYPOGRAPHY
   ============================================================================ */

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-regular);
  line-height: 1.6;
  color: var(--text-primary);
  background-color: var(--bg-secondary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-width: 320px; /* Prevent extreme narrow layouts */
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: var(--font-weight-semibold);
  line-height: 1.2;
  color: var(--text-primary);
}

h1 { font-size: var(--font-size-2xl); }
h2 { font-size: var(--font-size-xl); }
h3 { font-size: var(--font-size-lg); }
h4 { font-size: var(--font-size-base); }

p {
  margin-bottom: var(--space-md);
}

a {
  color: var(--brand-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--brand-hover);
  text-decoration: underline;
}

/* ============================================================================
   LAYOUT STRUCTURE
   ============================================================================ */

#app {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.main-content {
  flex: 1;
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
  padding: var(--space-xl);
}

/* Partners Panel */
.partners-panel {
  background: var(--bg-primary);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--border-default);
}

.panel-header-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  flex-wrap: wrap;
}

.panel-header-toolbar .search-box {
  flex: 1;
  min-width: 250px;
}

.panel-header-toolbar .sort-controls {
  padding: 0;
  flex-shrink: 0;
}

.panel-header-button-only {
  justify-content: flex-end;
}

.panel-header h2 {
  margin: 0;
  font-size: 2.25rem;  /* 36px - More prominent section titles */
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  letter-spacing: -0.02em;
}

/* ============================================================================
   HEADER & NAVIGATION
   ============================================================================ */

.header {
  position: sticky;
  top: 0;
  background: var(--bg-primary);
  border-bottom: 1px solid var(--border-default);
  z-index: var(--z-header);
}

.header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-xl);
  max-width: 1400px;
  margin: 0 auto;
}

.logo-container {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.logo {
  width: 56px;
  height: 56px;
  display: block;
}

.logo-title {
  font-size: 1.5rem;  /* 24px - Larger, more prominent */
  font-weight: var(--font-weight-bold);
  color: var(--brand-primary);
}

.header-search {
  flex: 1;
  max-width: 500px;
  margin: 0 var(--space-2xl);
  position: relative;
}

.search-input {
  width: 100%;
  padding: var(--space-md) var(--space-lg);
  padding-left: 40px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-sm);
  transition: border-color var(--transition-fast);
  background: var(--bg-secondary);
}

.search-input:focus {
  border-color: var(--border-active);
  background: var(--bg-primary);
}

.search-icon {
  position: absolute;
  left: var(--space-md);
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-tertiary);
  font-size: var(--font-size-sm);
}

.search-results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  max-height: 400px;
  overflow-y: auto;
  z-index: var(--z-dropdown);
  display: none;
}

.search-results.active {
  display: block;
}

.search-result-item {
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--border-light);
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.search-result-item:last-child {
  border-bottom: none;
}

.search-result-item:hover {
  background-color: var(--bg-secondary);
}

.search-result-name {
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  margin-bottom: 2px;
}

.search-result-email {
  font-size: var(--font-size-sm);
  color: var(--text-tertiary);
}

.user-menu {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
}

.user-info {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-full);
  background: var(--bg-secondary);
}

.user-icon {
  color: var(--brand-primary);
  font-size: var(--font-size-lg);
}

.user-name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
}

.stats-expand-btn {
  background: var(--brand-light);
  border-color: var(--brand-primary);
  color: var(--brand-primary);
}

.stats-expand-btn:hover {
  background: var(--brand-primary);
  color: white;
}

.admin-btn {
  background: var(--brand-light);
  border-color: var(--brand-primary);
  color: var(--brand-primary);
}

.admin-btn:hover {
  background: var(--brand-primary);
  color: white;
}

/* Stats Bar (Collapsible) */
.stats-bar-wrapper {
  background: var(--brand-light);
  border-bottom: 1px solid var(--border-default);
  width: 100%;
}

.stats-bar {
  padding: var(--space-md) var(--space-xl);
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1400px;
  margin: 0 auto;
}

.stats-container {
  display: flex;
  align-items: center;
  gap: var(--space-2xl);
  flex-wrap: wrap;
}

.stat-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-sm);
}

.stat-icon {
  color: var(--brand-primary);
}

.stat-value {
  font-size: 1.25rem;  /* 20px - Prominent numbers */
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
}

.stat-label {
  font-size: var(--font-size-sm);  /* 14px - Small labels */
  color: var(--text-tertiary);  /* Lighter gray for less emphasis */
}

.stats-toggle {
  background: none;
  border: none;
  color: var(--text-tertiary);
  cursor: pointer;
  padding: var(--space-sm);
  transition: color var(--transition-fast);
}

.stats-toggle:hover {
  color: var(--brand-primary);
}

/* Clickable Stat */
.stat-clickable {
  cursor: pointer;
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-md);
  transition: background var(--transition-fast);
}

.stat-clickable:hover {
  background: rgba(0, 0, 0, 0.05);
}

/* Overdue Tasks Dropdown */
.overdue-dropdown {
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  min-width: 320px;
  max-width: 420px;
  max-height: 400px;
  overflow-y: auto;
  z-index: 1000;
}

.overdue-dropdown-header {
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--border-default);
  position: sticky;
  top: 0;
  background: var(--bg-primary);
}

.overdue-dropdown-header h3 {
  margin: 0;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.overdue-task-list {
  padding: var(--space-sm);
}

.overdue-task-item {
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--transition-fast);
  margin-bottom: var(--space-xs);
}

.overdue-task-item:hover {
  background: var(--bg-secondary);
}

.overdue-task-item:last-child {
  margin-bottom: 0;
}

.overdue-task-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-xs);
}

.overdue-task-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  flex: 1;
}

.overdue-task-meta {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-size: var(--font-size-xs);
  color: var(--text-secondary);
}

.overdue-task-meta i {
  margin-right: var(--space-xs);
  color: var(--text-tertiary);
}

.overdue-task-date {
  color: var(--status-danger);
}

.overdue-empty-state {
  padding: var(--space-xl);
  text-align: center;
  color: var(--text-secondary);
}

.overdue-empty-state i {
  font-size: 2rem;
  color: var(--status-success);
  margin-bottom: var(--space-sm);
}

.overdue-empty-state p {
  margin: 0;
  font-size: var(--font-size-sm);
}

/* Calendar Dropdown Menu */
.calendar-dropdown-menu {
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  min-width: 180px;
  overflow: hidden;
}

.calendar-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  border: none;
  background: none;
  text-align: left;
  cursor: pointer;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  transition: background var(--transition-fast);
}

.calendar-dropdown-item:hover {
  background: var(--bg-secondary);
}

.calendar-dropdown-item i {
  width: 16px;
  color: var(--text-secondary);
}

/* Calendar Sent Button State */
.button.calendar-sent {
  background-color: var(--status-success-light, #e8f5e9);
  border-color: var(--status-success);
  color: var(--status-success);
}

.button.calendar-sent:hover:not(:disabled) {
  background-color: #c8e6c9;
}

/* Calendar Recipients List in Admin */
.calendar-recipients-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.calendar-recipient-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--border-light);
}

.calendar-recipient-item:last-child {
  border-bottom: none;
}

.calendar-recipient-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.calendar-recipient-email {
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
}

.calendar-recipient-name {
  font-size: var(--font-size-xs);
  color: var(--text-secondary);
}

.calendar-recipient-actions {
  display: flex;
  gap: var(--space-xs);
}

.calendar-settings-form {
  padding: var(--space-md);
}

.calendar-settings-form .form-group {
  margin-bottom: var(--space-md);
}

.calendar-settings-form .form-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
}

.calendar-settings-form .form-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  cursor: pointer;
}

/* Calendar Settings Section */
.calendar-settings-section {
  padding: 0;
}

.setting-row {
  margin-bottom: var(--space-sm);
}

.setting-status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--font-size-sm);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-sm);
  margin-top: var(--space-xs);
}

.setting-status.status-success {
  background: var(--status-success-light, #e8f5e9);
  color: var(--status-success);
}

.setting-status.status-warning {
  background: var(--status-warning-light, #fff3e0);
  color: var(--status-warning, #f57c00);
}

.section-divider {
  height: 1px;
  background: var(--border-default);
  margin: var(--space-md) 0;
}

.calendar-recipients-section {
  padding: 0 var(--space-md) var(--space-md);
}

.section-subtitle {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin: 0 0 var(--space-xs) 0;
}

.section-description {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  margin: 0 0 var(--space-md) 0;
}

.empty-state-small {
  text-align: center;
  padding: var(--space-lg);
  color: var(--text-secondary);
}

.empty-state-small i {
  font-size: 2rem;
  opacity: 0.5;
  margin-bottom: var(--space-sm);
}

.empty-state-small p {
  margin: 0;
  font-size: var(--font-size-sm);
}

.recipient-inactive {
  opacity: 0.6;
}

.recipient-inactive .calendar-recipient-email {
  text-decoration: line-through;
}

.button-muted {
  color: var(--text-tertiary) !important;
}

.button-muted:hover {
  color: var(--text-secondary) !important;
}

.button-danger-text {
  color: var(--status-error, #dc3545) !important;
}

.button-danger-text:hover {
  color: #c82333 !important;
  background: var(--status-error-light, #fee2e2);
}

.form-hint {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  margin-top: var(--space-xs);
  font-style: italic;
}

/* Quick Filters Bar */
.filters-bar {
  background: var(--bg-primary);
  border-bottom: 1px solid var(--border-default);
  padding: var(--space-md) var(--space-xl);
}

.filters-container {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.filter-chips {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
  background: var(--bg-primary);
  cursor: pointer;
  transition: all var(--transition-fast);
  min-height: 32px;
}

.filter-chip:hover {
  border-color: var(--border-hover);
  background: var(--bg-secondary);
}

.filter-chip.active {
  border-color: var(--border-active);
  background: var(--brand-light);
  color: var(--brand-primary);
}

.filter-chip-icon {
  font-size: var(--font-size-xs);
}

.filter-chip-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--text-tertiary);
  color: var(--bg-primary);
  font-size: 10px;
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.filter-chip-remove:hover {
  background: var(--brand-primary);
}

.filters-actions {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.sort-select {
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  background: var(--bg-primary);
  color: var(--text-secondary);
  cursor: pointer;
  min-height: 32px;
}

.sort-select:hover {
  border-color: var(--border-hover);
}

.sort-select:focus {
  border-color: var(--border-active);
}

/* ============================================================================
   TABS NAVIGATION
   ============================================================================ */

.tabs-nav {
  background: var(--bg-primary);
  border-bottom: 1px solid var(--border-default);
}

.tabs-container {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  gap: var(--space-sm);
  padding: 0 var(--space-xl);
}

.tab-button {
  padding: var(--space-lg) var(--space-xl);
  border: none;
  border-bottom: 2px solid transparent;
  background: none;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-height: 44px;
}

.tab-button:hover {
  color: var(--text-primary);
  background: var(--bg-secondary);
}

.tab-button.active {
  color: var(--brand-primary);
  border-bottom-color: var(--brand-primary);
}

.tab-icon {
  font-size: var(--font-size-base);
}

.tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  background: var(--status-danger);
  color: var(--bg-primary);
  font-size: 11px;
  font-weight: var(--font-weight-semibold);
  border-radius: var(--radius-full);
}

/* ============================================================================
   BUTTONS
   ============================================================================ */

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-xl);
  border: 2px solid transparent;
  border-radius: var(--radius-xl);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  transition: all 200ms ease;
  min-height: 44px;
  white-space: nowrap;
  line-height: 1;
}

.button i,
.button svg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  vertical-align: middle;
}

.button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Only add margin if button has text content after icon */
.button i:not(:only-child) {
  margin-right: var(--space-xs);
}

/* Primary Button - Sead Design System */
.button-primary {
  background: var(--brand-primary);
  color: var(--bg-primary);
  border-color: var(--brand-primary);
}

.button-primary:hover:not(:disabled) {
  background: transparent;
  color: var(--brand-primary);
  border-color: var(--brand-primary);
}

/* Secondary Button - Sead Design System */
.button-secondary {
  background: var(--bg-primary);
  color: var(--text-secondary);
  border: 1px solid var(--border-default);
  font-weight: var(--font-weight-medium);
}

.button-secondary:hover:not(:disabled) {
  background: #ffedd5;  /* orange-100 */
  color: #ea580c;  /* orange-600 */
  border: 1px solid #fdba74;  /* orange-300 */
}

/* Ghost Button */
.button-ghost {
  background: none;
  color: var(--text-secondary);
  border-color: transparent;
}

.button-ghost:hover:not(:disabled) {
  background: var(--bg-secondary);
  color: var(--text-primary);
}

/* Danger Button */
.button-danger {
  background: var(--status-danger);
  color: var(--bg-primary);
  border-color: var(--status-danger);
}

.button-danger:hover:not(:disabled) {
  background: var(--bg-primary);
  color: var(--status-danger);
  border-color: var(--status-danger);
}

/* Button Sizes */
.button-small {
  padding: var(--space-sm) var(--space-md);
  font-size: var(--font-size-xs);
  min-height: 32px;
}

.button-large {
  padding: var(--space-lg) var(--space-2xl);
  font-size: var(--font-size-base);
  min-height: 52px;
}

/* Icon Button */
.icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  margin: 0;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--bg-primary);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
  line-height: 1;
  vertical-align: middle;
}

.icon-button i,
.icon-button svg {
  display: block;
  margin: 0;
  padding: 0;
  line-height: 1;
  vertical-align: middle;
  width: 1em;
  height: 1em;
}

.icon-button:hover:not(:disabled) {
  border-color: var(--border-hover);
  color: var(--brand-primary);
  background: var(--bg-secondary);
}

.icon-button.danger {
  background: var(--status-danger);
  color: white;
  border-color: var(--status-danger);
}

.icon-button-success {
  background: var(--status-success-bg);
  color: var(--status-success);
  border-color: var(--status-success);
}

.icon-button-success:hover:not(:disabled) {
  background: var(--status-success);
  color: white;
  border-color: var(--status-success);
}

.icon-button.danger i,
.icon-button.danger svg {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
}

.icon-button.danger:hover:not(:disabled) {
  background: var(--status-danger-bg);
  color: var(--status-danger);
  border-color: var(--status-danger);
}

/* ============================================================================
   CARDS & PANELS
   ============================================================================ */

.card {
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  transition: border-color var(--transition-fast);
}

.card:hover {
  border-color: var(--border-hover);
}

.card.active {
  border-color: var(--border-active);
  border-width: 2px;
  padding: calc(var(--space-xl) - 1px);
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--border-light);
}

.card-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.card-actions {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.card-body {
  margin-bottom: var(--space-lg);
}

.card-footer {
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ============================================================================
   PARTNER CARDS
   ============================================================================ */

.partners-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.partner-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
  cursor: pointer;
}

.partner-card:hover {
  border-color: var(--border-hover);
}

.partner-card.expanded {
  background: #fff5f0; /* Light orange background when expanded */
  border-color: var(--border-active);
  cursor: default;
}

/* Dim non-selected partners when one is expanded */
.partners-list:has(.partner-card.expanded) .partner-card:not(.expanded) {
  opacity: 0.4;
  transition: opacity var(--transition-fast);
}

.partner-card-collapsed {
  padding: var(--space-lg);
}

.partner-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-lg);
  margin-bottom: var(--space-md);
  cursor: pointer;
}

.partner-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-lg);
  background: var(--brand-light);
  color: var(--brand-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  flex-shrink: 0;
}

.partner-info {
  flex: 1;
  min-width: 0;
}

.partner-name-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-sm);
  flex-wrap: wrap;
}

.partner-name {
  font-size: 1.125rem;  /* 18px - Prominent partner name */
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.partner-badges {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.partner-meta {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  font-size: var(--font-size-sm);  /* 14px */
  color: var(--text-tertiary);  /* Lighter gray for metadata */
  flex-wrap: wrap;
}

.partner-meta-item {
  display: flex;
  align-items: center;
  gap: 4px;
}

.partner-count-indicators {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-right: var(--space-md);
}

.count-indicator {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  padding: 6px 10px;
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
  transition: all 0.2s ease;
  white-space: nowrap;
}

.count-indicator:hover {
  background: var(--bg-tertiary);
}

.count-indicator i {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  display: inline-block;
  width: 14px;
  text-align: center;
  flex-shrink: 0;
}

.count-indicator span {
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  min-width: 16px;
  text-align: center;
  line-height: 1;
}

.partner-quick-actions {
  display: flex;
  gap: var(--space-sm);
}

/* Card-style sections in expanded view */
.partner-next-action {
  padding: var(--space-lg);
  background: var(--brand-light);
  border: 2px solid var(--brand-primary);
  border-radius: var(--radius-lg);
  margin: var(--space-xl);
  margin-bottom: var(--space-lg);
  transition: all 0.2s ease;
}

.partner-next-action:hover {
  /* No shadow on hover */
}

.next-action-label {
  font-size: var(--font-size-xs);
  color: var(--brand-primary);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--font-weight-semibold);
}

.next-action-content {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-base);
  color: var(--text-primary);
  font-weight: var(--font-weight-medium);
}

.next-action-content i {
  color: var(--brand-primary);
}

.partner-recent-note {
  padding: var(--space-lg);
  background: #f9fafb;
  border: 1px solid #d1d5db;
  border-radius: var(--radius-lg);
  margin: 0 var(--space-xl) var(--space-xl);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  transition: all 0.2s ease;
}

.partner-recent-note:hover {
  border-color: #ee4810;
}

.recent-note-label {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--font-weight-semibold);
}

/* Partner Card Expanded State */
.partner-card-expanded {
  padding: 0;
  border-top: 1px solid var(--border-default);
}

.partner-card-expanded-header {
  padding: var(--space-xl);
  border-bottom: 1px solid var(--border-default);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.partner-expanded-info {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
}

.partner-expanded-actions {
  display: flex;
  gap: var(--space-sm);
}

/* Next Action Prominent Card */
.next-action-card {
  margin: var(--space-xl);
  padding: var(--space-xl);
  background: linear-gradient(to right, var(--brand-light), var(--bg-primary));
  border: 2px solid var(--brand-primary);
  border-radius: var(--radius-lg);
}

.next-action-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.next-action-card-icon {
  font-size: var(--font-size-2xl);
  color: var(--brand-primary);
}

.next-action-card-title {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--font-weight-semibold);
}

.next-action-card-content {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin-bottom: var(--space-lg);
}

.next-action-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-xl);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-lg);
}

.next-action-card-actions {
  display: flex;
  gap: var(--space-md);
}

.next-action-empty {
  text-align: center;
  padding: var(--space-2xl);
  color: var(--text-tertiary);
  font-size: var(--font-size-sm);
}

/* Contact Info Section */
.contact-section {
  padding: var(--space-xl);
  border-bottom: 1px solid var(--border-light);
}

.contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-lg);
}

.contact-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  overflow: hidden;
}

.contact-label {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--font-weight-medium);
}

.contact-value {
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  font-weight: var(--font-weight-medium);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}

.contact-value a {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
  max-width: 100%;
}

/* Collapsible Section - Card Style */
.collapsible-section {
  border: 1px solid #d1d5db;
  background: var(--bg-primary);
  border-radius: var(--radius-lg);
  margin: 0 var(--space-xl) var(--space-md);
  overflow: hidden;
  transition: all 0.2s ease;
}

.collapsible-section:first-child {
  margin-top: var(--space-xl);
}

.collapsible-section:hover {
  border-color: #ee4810;
}

.collapsible-section:last-child {
  margin-bottom: var(--space-xl);
}

.collapsible-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-xl);
  cursor: pointer;
  transition: all var(--transition-fast);
  user-select: none;
  background: var(--bg-primary);
}

.collapsible-header:hover {
  background: var(--brand-light);
}

.collapsible-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
}

.section-badges {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-left: var(--space-md);
}

.section-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 8px;
  background: var(--bg-secondary);
  color: var(--text-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  border-radius: var(--radius-full);
  line-height: 1;
}

.section-date-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  background: var(--bg-secondary);
  color: var(--text-secondary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  border-radius: var(--radius-sm);
  line-height: 1;
}

.collapsible-header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-left: auto;
  margin-right: var(--space-md);
}

.section-header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-left: auto;
}

.collapsible-toggle {
  color: var(--text-tertiary);
  transition: transform var(--transition-fast);
}

.collapsible-section.open .collapsible-toggle {
  transform: rotate(180deg);
}

.collapsible-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
}

.collapsible-section.open .collapsible-content {
  max-height: 5000px;
}

.collapsible-body {
  padding: var(--space-xl);
  padding-top: 0;
}

/* Tasks and Notes Lists in Accordion */
.tasks-list,
.notes-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.task-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--bg-secondary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition-base);
}

.task-item:hover {
  border-color: var(--border-hover);
}

/* Task done state - strikethrough and dimmed */
.task-item.task-done {
  opacity: 0.6;
  background: var(--bg-tertiary);
}

.task-item.task-done .task-title {
  text-decoration: line-through;
  color: var(--text-tertiary);
}

/* Task checkbox in header */
.task-checkbox {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--brand-primary);
  flex-shrink: 0;
  margin-top: 2px;
}

/* Task header actions container */
.task-header-actions {
  display: flex;
  gap: var(--space-sm);
  flex-shrink: 0;
  align-items: center;
  margin-left: auto;
}

/* Task item layout - content on left, actions on right */
.task-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-lg);
  padding: var(--space-md) var(--space-lg);
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
  transition: all 0.2s ease;
}

.task-item:hover {
  border-color: var(--border-hover);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* Task content area - takes full width minus actions */
.task-content-area {
  flex: 1;
  min-width: 0;
}

/* Task title row */
.task-title-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-bottom: var(--space-xs);
}

.task-title-text {
  font-weight: 600;
  font-size: var(--font-size-base);
  color: var(--text-primary);
}

.task-item.task-done .task-title-text {
  text-decoration: line-through;
  color: var(--text-tertiary);
}

.task-item.task-done {
  opacity: 0.7;
  background: var(--bg-secondary);
}

/* Task status badge */
.task-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 12px;
  text-transform: capitalize;
}

/* Status colors */
.task-status-badge.status-pending {
  background: #fef3c7;
  color: #b45309;
}

.task-status-badge.status-done {
  background: #d1fae5;
  color: #047857;
}

.task-status-badge.status-in-progress,
.task-status-badge.status-inprogress {
  background: #dbeafe;
  color: #1d4ed8;
}

.task-status-badge.status-cancelled,
.task-status-badge.status-canceled {
  background: #fee2e2;
  color: #b91c1c;
}

/* Task details content */
.task-details-content {
  margin-top: var(--space-xs);
}

.task-detail-item {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 2px;
}

.task-detail-item strong {
  color: var(--text-primary);
  font-weight: 500;
}

/* Task actions panel - right side */
.task-actions-panel {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  padding-top: 2px;
}

/* Task action checkbox */
.task-action-checkbox {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--brand-primary);
  border-radius: 4px;
}

/* Task action buttons - uniform icon buttons */
.task-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--bg-primary);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 14px;
}

.task-action-btn:hover {
  background: var(--bg-secondary);
  border-color: var(--border-hover);
  color: var(--brand-primary);
  transform: translateY(-1px);
}

.task-action-btn.calendar-sent {
  color: var(--status-success);
  border-color: var(--status-success);
}

.task-action-btn.calendar-sent:hover {
  background: rgba(34, 197, 94, 0.1);
  color: var(--status-success);
}

.task-action-btn-danger:hover {
  background: rgba(239, 68, 68, 0.1);
  border-color: var(--status-danger);
  color: var(--status-danger);
}

/* Tooltip styling for action buttons */
.task-action-btn[title],
.task-action-checkbox[title] {
  position: relative;
}

.task-content {
  flex: 1;
}

.task-actions {
  display: flex;
  gap: var(--space-sm);
  flex-shrink: 0;
}

.task-title {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
}

.task-title i {
  color: var(--text-tertiary);
}

.task-meta {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

.task-priority {
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
}

.task-priority.priority-high {
  background: var(--status-danger-bg);
  color: var(--status-danger);
}

.task-priority.priority-medium {
  background: var(--status-warning-bg);
  color: var(--status-warning);
}

.task-priority.priority-low {
  background: var(--status-info-bg);
  color: var(--status-info);
}

.note-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--bg-secondary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition-base);
}

.note-item:hover {
  border-color: var(--border-hover);
}

.note-content {
  flex: 1;
}

.note-actions {
  display: flex;
  gap: var(--space-sm);
  flex-shrink: 0;
}

.note-date {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  margin-bottom: var(--space-sm);
  font-weight: var(--font-weight-medium);
}

.note-text {
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  line-height: 1.6;
}

.empty-message {
  padding: var(--space-2xl);
  text-align: center;
  color: var(--text-tertiary);
  font-size: var(--font-size-sm);
  font-style: italic;
}

/* ============================================================================
   TIMELINE
   ============================================================================ */

.timeline-container {
  padding: var(--space-xl);
}

.timeline-filters {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--border-light);
}

.timeline {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.timeline-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.timeline-date-header {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-sm) 0;
}

.timeline-item {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--bg-secondary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition-fast);
}

.timeline-item:hover {
  border-color: var(--border-hover);
}

.timeline-icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: var(--font-size-sm);
}

.timeline-icon.task {
  background: var(--status-info-bg);
  color: var(--status-info);
}

.timeline-icon.note {
  background: var(--status-success-bg);
  color: var(--status-success);
}

.timeline-icon.status {
  background: var(--status-warning-bg);
  color: var(--status-warning);
}

.timeline-content {
  flex: 1;
  min-width: 0;
}

.timeline-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-sm);
}

.timeline-type {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--font-weight-medium);
}

.timeline-time {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
}

.timeline-text {
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
  line-height: 1.5;
}

.timeline-meta {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
}

.timeline-actions {
  display: flex;
  gap: var(--space-sm);
}

.timeline-empty {
  text-align: center;
  padding: var(--space-3xl);
  color: var(--text-tertiary);
}

.timeline-empty-icon {
  font-size: 48px;
  margin-bottom: var(--space-lg);
  opacity: 0.3;
}

.timeline-empty-text {
  font-size: var(--font-size-base);
  margin-bottom: var(--space-md);
}

/* ============================================================================
   TASKS & NOTES LISTS
   ============================================================================ */

.tasks-container,
.notes-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.task-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.task-group-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.task-group-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 8px;
  background: var(--bg-tertiary);
  color: var(--text-tertiary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  border-radius: var(--radius-full);
}

.task-card {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition-fast);
}

.task-card:hover {
  border-color: var(--border-hover);
}

.task-card.overdue {
  border-color: var(--status-danger);
  background: var(--status-danger-bg);
}

.task-checkbox {
  width: 20px;
  height: 20px;
  border: 2px solid var(--border-medium);
  border-radius: 4px;
  cursor: pointer;
  transition: all var(--transition-fast);
  flex-shrink: 0;
  margin-top: 2px;
}

.task-checkbox:hover {
  border-color: var(--brand-primary);
}

.task-checkbox.checked {
  background: var(--status-success);
  border-color: var(--status-success);
  position: relative;
}

.task-checkbox.checked::after {
  content: '✓';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 14px;
  font-weight: bold;
}

.task-content {
  flex: 1;
  min-width: 0;
}

.task-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--space-sm);
  gap: var(--space-md);
}

.task-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  flex: 1;
}

.task-card.completed .task-title {
  text-decoration: line-through;
  color: var(--text-tertiary);
}

.task-badges {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.task-description {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-md);
  line-height: 1.5;
}

.task-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.task-meta {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
  flex-wrap: wrap;
}

.task-meta-item {
  display: flex;
  align-items: center;
  gap: 4px;
}

.task-partner-link {
  color: var(--brand-primary);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: color var(--transition-fast);
}

.task-partner-link:hover {
  color: var(--brand-hover);
  text-decoration: underline;
}

.task-actions {
  display: flex;
  gap: var(--space-sm);
}

/* Note Card */
.note-card {
  padding: var(--space-lg);
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-left: 3px solid var(--status-success);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition-fast);
}

.note-card:hover {
  border-color: var(--border-hover);
  border-left-color: var(--status-success);
}

.note-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
}

.note-meta {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
}

.note-actions {
  display: flex;
  gap: var(--space-sm);
}

.note-text {
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  line-height: 1.6;
  white-space: pre-wrap;
}

/* ============================================================================
   BADGES & STATUS
   ============================================================================ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  border-radius: var(--radius-full);
  white-space: nowrap;
}

/* Status Badges */
.badge-status {
  background: var(--bg-tertiary);
  color: var(--text-primary);
  border: 1px solid var(--border-default);
}

.badge-status.prospect {
  background: var(--status-info-bg);
  color: var(--status-info);
  border-color: var(--status-info);
}

.badge-status.active {
  background: var(--status-success-bg);
  color: var(--status-success);
  border-color: var(--status-success);
}

.badge-status.at-risk {
  background: var(--status-warning-bg);
  color: var(--status-warning);
  border-color: var(--status-warning);
}

.badge-status.blocked,
.badge-status.churned {
  background: var(--status-danger-bg);
  color: var(--status-danger);
  border-color: var(--status-danger);
}

/* Priority Badges */
.badge-priority {
  background: var(--bg-tertiary);
  color: var(--text-primary);
}

.badge-priority.high {
  background: var(--status-danger-bg);
  color: var(--status-danger);
}

.badge-priority.medium {
  background: var(--status-warning-bg);
  color: var(--status-warning);
}

.badge-priority.low {
  background: var(--status-info-bg);
  color: var(--status-info);
}

/* Category Badge */
.badge-category {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  border: 1px solid var(--border-light);
}

/* ============================================================================
   FORMS
   ============================================================================ */

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.form-label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
}

.form-label-required::after {
  content: '*';
  color: var(--status-danger);
  margin-left: 4px;
}

.form-input,
.form-select,
.form-textarea {
  padding: var(--space-md);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  font-size: var(--font-size-sm);
  font-family: inherit;
  color: var(--text-secondary);  /* Greyish text for form elements */
  background: var(--bg-primary);
  transition: border-color 200ms ease;
  min-height: 44px;
}

.form-input:focus {
  color: var(--text-primary);  /* Darker when focused/typing */
}

.form-select {
  padding-right: 36px;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236B6B6B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px;
  appearance: none;
  cursor: pointer;
}

.form-input:hover,
.form-select:hover,
.form-textarea:hover {
  border-color: var(--border-hover);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--border-active);
  outline: none;
}

.form-input:disabled,
.form-select:disabled,
.form-textarea:disabled {
  background: var(--bg-tertiary);
  color: var(--text-tertiary);
  cursor: not-allowed;
}

.form-textarea {
  min-height: 120px;
  resize: vertical;
  line-height: 1.5;
}

.form-help {
  font-size: var(--font-size-xs);
  color: var(--text-tertiary);
}

.form-error {
  font-size: var(--font-size-xs);
  color: var(--status-danger);
}

/* Search Box - Sead Design System */
.search-box {
  width: 100%;
  padding: var(--space-md);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  font-size: var(--font-size-sm);
  font-family: var(--font-family);
  background: var(--bg-primary);
  color: var(--text-primary);
  transition: border-color 200ms ease;
  min-height: 44px;
}

.search-box:hover {
  border-color: var(--border-hover);
}

.search-box:focus {
  border-color: var(--border-active);
  outline: none;
}

.search-box::placeholder {
  color: var(--text-tertiary);
}

/* Sort Controls */
.sort-controls {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 0;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.sort-controls label {
  font-size: 0.875rem;  /* 14px - Small label */
  font-weight: var(--font-weight-medium);
  color: var(--text-tertiary);  /* Lighter gray for labels */
  flex-shrink: 0;
}

.form-checkbox-group {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) 0;
}

.form-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
  padding: var(--space-sm) 0;
}

.form-checkbox input[type="checkbox"] {
  width: 20px;
  height: 20px;
  cursor: pointer;
  flex-shrink: 0;
}

.form-checkbox span {
  font-size: var(--font-size-base);
  color: var(--text-primary);
  user-select: none;
}

.form-actions {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--border-light);
}

/* ============================================================================
   MODALS
   ============================================================================ */

.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-modal);
  padding: var(--space-xl);
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-modal);
  padding: var(--space-xl);
}

.modal-content {
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  overflow: auto;
  position: relative;
  padding: var(--space-xl);
  resize: both;
  min-width: 300px;
  min-height: 200px;
}

.modal-content h2 {
  margin-top: 0;
  margin-bottom: var(--space-xl);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.close {
  position: absolute;
  top: var(--space-lg);
  right: var(--space-lg);
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: none;
  color: var(--text-tertiary);
  font-size: var(--font-size-2xl);
  cursor: pointer;
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
  line-height: 1;
}

.close:hover {
  background: var(--bg-secondary);
  color: var(--text-primary);
}

.modal-header {
  padding: var(--space-xl);
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
}

.modal-close {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: none;
  color: var(--text-tertiary);
  font-size: var(--font-size-xl);
  cursor: pointer;
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}

.modal-close:hover {
  background: var(--bg-secondary);
  color: var(--text-primary);
}

.modal-body {
  padding: var(--space-xl);
}

.modal-footer {
  padding: var(--space-xl);
  border-top: 1px solid var(--border-light);
  display: flex;
  justify-content: flex-end;
  gap: var(--space-md);
}

/* Confirmation Modal - Minimalistic delete confirmation */
.confirmation-modal {
  max-width: 400px;
  padding: var(--space-2xl);
  text-align: center;
}

.confirmation-message {
  font-size: var(--font-size-lg);
  color: var(--text-primary);
  margin-bottom: var(--space-2xl);
  line-height: 1.5;
}

.confirmation-actions {
  display: flex;
  gap: var(--space-md);
  justify-content: center;
}

.confirmation-actions .button {
  min-width: 100px;
  flex: 1;
  max-width: 150px;
}

/* ============================================================================
   TOAST NOTIFICATIONS
   ============================================================================ */

.toast-container {
  position: fixed;
  top: var(--space-xl);
  right: var(--space-xl);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  max-width: 400px;
}

.toast {
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  animation: slideInRight 0.3s ease;
}

.toast.success {
  border-color: var(--status-success);
  background: var(--status-success-bg);
}

.toast.error {
  border-color: var(--status-danger);
  background: var(--status-danger-bg);
}

.toast.warning {
  border-color: var(--status-warning);
  background: var(--status-warning-bg);
}

.toast.info {
  border-color: var(--status-info);
  background: var(--status-info-bg);
}

.toast-icon {
  font-size: var(--font-size-lg);
  flex-shrink: 0;
}

.toast.success .toast-icon { color: var(--status-success); }
.toast.error .toast-icon { color: var(--status-danger); }
.toast.warning .toast-icon { color: var(--status-warning); }
.toast.info .toast-icon { color: var(--status-info); }

.toast-content {
  flex: 1;
  min-width: 0;
}

.toast-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  margin-bottom: 4px;
}

.toast.success .toast-title { color: var(--status-success); }
.toast.error .toast-title { color: var(--status-danger); }
.toast.warning .toast-title { color: var(--status-warning); }
.toast.info .toast-title { color: var(--status-info); }

.toast-message {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

.toast-close {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: none;
  color: var(--text-tertiary);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
  flex-shrink: 0;
}

.toast-close:hover {
  background: var(--bg-secondary);
  color: var(--text-primary);
}

@keyframes slideInRight {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

/* ============================================================================
   SKELETON LOADERS
   ============================================================================ */

.skeleton {
  background: linear-gradient(
    90deg,
    var(--bg-tertiary) 0%,
    var(--border-light) 50%,
    var(--bg-tertiary) 100%
  );
  background-size: 200% 100%;
  animation: skeletonLoading 1.5s ease-in-out infinite;
  border-radius: var(--radius-md);
}

@keyframes skeletonLoading {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.skeleton-card {
  padding: var(--space-lg);
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}

.skeleton-line {
  height: 16px;
  margin-bottom: var(--space-md);
}

.skeleton-line.short {
  width: 40%;
}

.skeleton-line.medium {
  width: 60%;
}

.skeleton-line.long {
  width: 80%;
}

.skeleton-circle {
  width: 48px;
  height: 48px;
  border-radius: 50%;
}

.skeleton-button {
  height: 44px;
  width: 120px;
  border-radius: var(--radius-md);
}

/* ============================================================================
   EMPTY STATES
   ============================================================================ */

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-3xl);
  text-align: center;
}

.empty-state-icon {
  font-size: 80px;
  color: var(--text-tertiary);
  opacity: 0.2;
  margin-bottom: var(--space-xl);
}

.empty-state-title {
  font-size: 1.875rem;  /* 30px - Large, prominent */
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin-bottom: var(--space-md);
  letter-spacing: -0.01em;
}

.empty-state-description {
  font-size: var(--font-size-base);
  color: var(--text-tertiary);  /* Lighter gray for less emphasis */
  margin-bottom: var(--space-xl);
  max-width: 400px;
  line-height: 1.6;
}

.empty-state-action {
  margin-top: var(--space-lg);
}

/* ============================================================================
   LOADING SCREEN
   ============================================================================ */

.loading-screen {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--bg-secondary);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.loading-logo {
  width: 200px;
  height: 200px;
  margin-bottom: var(--space-2xl);
  animation: pulse 2s ease-in-out infinite;
}

.loading-spinner {
  width: 48px;
  height: 48px;
  border: 3px solid var(--border-light);
  border-top-color: var(--brand-primary);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.loading-text {
  margin-top: var(--space-xl);
  font-size: var(--font-size-base);
  color: var(--brand-primary);
  font-weight: var(--font-weight-medium);
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.8; transform: scale(1.05); }
}

/* ============================================================================
   LOGIN SCREEN
   ============================================================================ */

.login-container {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl);
  background: var(--bg-secondary);
}

.login-card {
  width: 100%;
  max-width: 400px;
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  padding: var(--space-3xl);
}

.login-logo {
  width: 120px;
  height: 120px;
  margin: 0 auto var(--space-xl);
  display: block;
}

.login-title {
  text-align: center;
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--brand-primary);
  margin-bottom: var(--space-2xl);
}

.login-step {
  margin-bottom: var(--space-xl);
}

.login-step-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--text-secondary);
  margin-bottom: var(--space-lg);
}

.login-2fa-input {
  text-align: center;
  font-size: var(--font-size-2xl);
  letter-spacing: 0.5em;
  font-weight: var(--font-weight-semibold);
}

.login-link {
  text-align: center;
  margin-top: var(--space-lg);
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

.login-link button {
  background: none;
  border: none;
  color: var(--brand-primary);
  cursor: pointer;
  font-weight: var(--font-weight-medium);
  transition: color var(--transition-fast);
}

.login-link button:hover {
  color: var(--brand-hover);
  text-decoration: underline;
}

/* 2FA Setup */
.twofa-setup {
  text-align: center;
}

.twofa-qr {
  display: flex;
  justify-content: center;
  margin: var(--space-xl) 0;
  padding: var(--space-xl);
  background: var(--bg-secondary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}

.twofa-secret {
  padding: var(--space-md);
  background: var(--bg-tertiary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  font-family: monospace;
  font-size: var(--font-size-sm);
  color: var(--text-primary);
  margin: var(--space-lg) 0;
  word-break: break-all;
}

.twofa-backup-codes {
  margin-top: var(--space-xl);
  padding: var(--space-xl);
  background: var(--status-warning-bg);
  border: 1px solid var(--status-warning);
  border-radius: var(--radius-lg);
}

.twofa-backup-title {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--status-warning);
  margin-bottom: var(--space-md);
}

.twofa-backup-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.twofa-backup-code {
  padding: var(--space-sm);
  background: var(--bg-primary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-sm);
  font-family: monospace;
  font-size: var(--font-size-sm);
  text-align: center;
}

/* ============================================================================
   MOBILE NAVIGATION
   ============================================================================ */

.mobile-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--bg-primary);
  border-top: 1px solid var(--border-default);
  z-index: var(--z-header);
  padding: var(--space-sm) 0;
}

.mobile-nav-items {
  display: flex;
  justify-content: space-around;
  align-items: center;
}

.mobile-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: var(--space-sm) var(--space-md);
  border: none;
  background: none;
  color: var(--text-tertiary);
  font-size: var(--font-size-xs);
  cursor: pointer;
  transition: color var(--transition-fast);
  min-width: 72px;
}

.mobile-nav-item:active {
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
}

.mobile-nav-item.active {
  color: var(--brand-primary);
}

.mobile-nav-icon {
  font-size: var(--font-size-xl);
}

/* Hamburger Menu */
.hamburger-button {
  display: none;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  border: none;
  background: none;
  color: var(--text-primary);
  font-size: var(--font-size-xl);
  cursor: pointer;
}

.hamburger-menu {
  position: fixed;
  top: 0;
  right: -100%;
  width: 280px;
  height: 100vh;
  background: var(--bg-primary);
  border-left: 1px solid var(--border-default);
  z-index: var(--z-modal);
  transition: right var(--transition-slow);
  overflow-y: auto;
}

.hamburger-menu.open {
  right: 0;
}

.hamburger-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: calc(var(--z-modal) - 1);
  display: none;
}

.hamburger-overlay.active {
  display: block;
}

.hamburger-header {
  padding: var(--space-xl);
  border-bottom: 1px solid var(--border-light);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.hamburger-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
}

.hamburger-items {
  padding: var(--space-md) 0;
}

.hamburger-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-lg) var(--space-xl);
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  font-size: var(--font-size-base);
  color: var(--text-primary);
  cursor: pointer;
  transition: background-color var(--transition-fast);
  min-height: 48px;
}

.hamburger-item:hover {
  background: var(--bg-secondary);
}

.hamburger-item-icon {
  font-size: var(--font-size-lg);
  width: 24px;
  text-align: center;
}

/* ============================================================================
   RESPONSIVE DESIGN
   ============================================================================ */

@media (max-width: 1024px) {
  :root {
    --space-xs: 4px;
    --space-sm: 8px;
    --space-md: 12px;
    --space-lg: 16px;
    --space-xl: 20px;
    --space-2xl: 24px;
    --space-3xl: 32px;
  }

  .header-search {
    max-width: 300px;
    margin: 0 var(--space-lg);
  }

  /* User Cards Grid - Tablet */
  .user-cards-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
    gap: var(--space-md);
  }
}

@media (max-width: 768px) {
  /* Typography adjustments */
  h1 { font-size: var(--font-size-xl); }
  h2 { font-size: var(--font-size-lg); }
  h3 { font-size: var(--font-size-base); }

  /* Layout adjustments */
  .main-content {
    padding: var(--space-md);
    padding-top: calc(60px + var(--space-md)); /* Space for fixed search bar */
    padding-bottom: 80px; /* Space for mobile nav */
  }

  /* Header adjustments */
  .header-main {
    padding: var(--space-md);
  }

  .logo {
    width: 36px;
    height: 36px;
  }

  .logo-title {
    font-size: var(--font-size-base);
  }

  /* Mobile search - position below header */
  .header-search {
    position: fixed;
    top: 60px; /* Below header */
    left: 0;
    right: 0;
    max-width: 100%;
    margin: 0;
    padding: var(--space-md);
    background: var(--bg-primary);
    border-bottom: 1px solid var(--border-default);
    z-index: 900;
  }

  .header-search .search-input {
    width: 100%;
    font-size: var(--font-size-sm);
    padding: var(--space-md);
    padding-left: 40px;
  }

  .user-name {
    display: none;
  }

  .user-menu {
    gap: var(--space-sm);
  }

  .user-info {
    padding: var(--space-xs) var(--space-sm);
  }

  .hamburger-button {
    display: flex;
  }

  /* Stats bar */
  .stats-bar-wrapper {
    margin-top: calc(60px + 60px); /* Header (60px) + Search bar (~60px) */
  }

  .stats-bar {
    padding: var(--space-md);
    flex-direction: column;
    align-items: flex-start;
  }

  .stats-container {
    gap: var(--space-md);
  }

  /* Filters bar */
  .filters-bar {
    padding: var(--space-md);
  }

  .filters-container {
    flex-direction: column;
    align-items: stretch;
  }

  .filter-chips {
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
  }

  /* Tabs */
  .tabs-nav {
    display: none; /* Use mobile nav instead */
  }

  /* Partners Panel */
  .partners-panel {
    padding: var(--space-md);
    border-radius: var(--radius-md);
    gap: var(--space-md);
  }

  .panel-header {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-md);
    padding-bottom: var(--space-md);
  }

  .panel-header-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .panel-header-toolbar .search-box {
    min-width: 100%;
    order: 1;
  }

  .panel-header-toolbar .sort-controls {
    order: 2;
  }

  .panel-header-toolbar .button {
    order: 3;
    width: 100%;
  }

  .panel-header h2 {
    font-size: var(--font-size-lg);
  }

  .panel-header button {
    width: 100%;
  }

  /* Sort controls */
  .sort-controls {
    flex-wrap: wrap;
    gap: var(--space-sm);
  }

  .sort-controls label {
    font-size: var(--font-size-xs);
  }

  .sort-controls select {
    flex: 1;
    min-width: 120px;
  }

  /* Search box */
  .search-box {
    font-size: var(--font-size-sm);
    padding: var(--space-sm) var(--space-md);
    min-height: 44px; /* Touch-friendly target */
  }

  /* Buttons */
  .button {
    padding: var(--space-sm) var(--space-md);
    font-size: var(--font-size-sm);
    min-height: 44px; /* Touch-friendly target */
  }

  .button-small {
    padding: 6px var(--space-sm);
    font-size: var(--font-size-xs);
    min-height: 40px;
  }

  /* Form elements */
  .form-input,
  .form-select {
    font-size: var(--font-size-sm);
    padding: var(--space-sm) var(--space-md);
    min-height: 44px; /* Touch-friendly target */
  }

  /* Empty state */
  .empty-state {
    padding: var(--space-xl) var(--space-md);
  }

  .empty-state-icon {
    font-size: 48px;
    width: 60px;
    height: 60px;
  }

  .empty-state-title {
    font-size: var(--font-size-lg);
  }

  .empty-state-description {
    font-size: var(--font-size-sm);
  }

  /* Cards */
  .card {
    padding: var(--space-lg);
  }

  .partner-card-collapsed {
    padding: var(--space-md);
    min-height: 80px; /* Ensure adequate touch target for card */
  }

  .partner-avatar {
    width: 40px;
    height: 40px;
    font-size: var(--font-size-lg);
  }

  .partner-name {
    font-size: var(--font-size-base);
    /* Allow wrapping to 2 lines max on mobile */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
  }

  .contact-grid {
    grid-template-columns: 1fr;
  }

  /* Timeline */
  .timeline-item {
    flex-direction: column;
    padding: var(--space-md);
  }

  .timeline-icon {
    align-self: flex-start;
  }

  /* Tasks & Notes */
  .task-card {
    padding: var(--space-md);
  }

  .task-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  /* Forms */
  .form-actions {
    flex-direction: column;
  }

  .form-actions .button {
    width: 100%;
  }

  /* Modals */
  .modal {
    max-width: 100%;
    margin: 0;
    border-radius: 0;
  }

  .modal-overlay {
    padding: 0;
  }

  .modal-content {
    max-width: 90%;
    margin: var(--space-md);
  }

  .confirmation-modal {
    max-width: 90%;
    padding: var(--space-xl);
  }

  .confirmation-message {
    font-size: var(--font-size-base);
    margin-bottom: var(--space-xl);
  }

  .confirmation-actions {
    flex-direction: row;
    gap: var(--space-sm);
  }

  .confirmation-actions .button {
    min-width: 80px;
  }

  /* Show mobile nav */
  .mobile-nav {
    display: block;
  }

  /* Toast container */
  .toast-container {
    left: var(--space-md);
    right: var(--space-md);
    max-width: none;
  }

  /* Admin Section - Mobile */
  .admin-container {
    padding: 0;
    padding-bottom: var(--space-md);
  }

  .admin-back-button {
    margin-bottom: var(--space-md);
    width: 100%;
  }

  .admin-card {
    padding: var(--space-lg);
    margin-bottom: var(--space-lg);
  }

  .admin-card-icon {
    width: 48px;
    height: 48px;
    font-size: 1.5rem;
  }

  .admin-card-title {
    font-size: 1.5rem;
  }

  .admin-card-subtitle {
    font-size: var(--font-size-sm);
  }

  .admin-card-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-card-title-group {
    width: 100%;
  }

  .admin-button-group {
    width: 100%;
    flex-direction: column;
  }

  .admin-button-group .button {
    width: 100%;
  }

  .admin-card-description {
    padding: var(--space-md);
  }

  /* User Cards Grid - Mobile */
  .user-cards-grid {
    grid-template-columns: 1fr;
    gap: var(--space-md);
    width: 100%;
  }

  .user-card {
    padding: var(--space-md);
  }

  .user-card-header {
    flex-wrap: wrap;
  }

  .user-card-name {
    font-size: var(--font-size-base);
  }

  .user-card-actions {
    width: 100%;
    justify-content: center;
    margin-top: var(--space-xs);
  }

  /* Login */
  .login-card {
    padding: var(--space-xl);
  }

  .twofa-backup-list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  /* Extra small screens */
  .main-content {
    padding: var(--space-sm);
    padding-top: calc(60px + 60px); /* Header (60px) + Search bar (~60px with padding) */
    padding-bottom: 80px; /* Space for mobile nav */
  }

  .stats-bar-wrapper {
    margin-top: calc(60px + 60px); /* Header (60px) + Search bar (~60px) */
  }

  .partners-panel {
    padding: var(--space-sm);
    border: none;
    border-radius: 0;
  }

  .panel-header {
    padding-bottom: var(--space-sm);
  }

  .panel-header h2 {
    font-size: var(--font-size-base);
  }

  .search-box {
    font-size: var(--font-size-xs);
    padding: 8px var(--space-sm);
  }

  .sort-controls {
    gap: 6px;
  }

  .form-select {
    font-size: var(--font-size-xs);
    padding: 8px var(--space-sm);
    padding-right: 28px;
  }

  .button {
    font-size: var(--font-size-xs);
    padding: 8px var(--space-sm);
  }

  .confirmation-modal {
    padding: var(--space-lg);
  }

  .confirmation-message {
    font-size: var(--font-size-sm);
  }

  .empty-state {
    padding: var(--space-lg) var(--space-sm);
  }

  .empty-state-icon {
    font-size: 36px;
    width: 48px;
    height: 48px;
  }

  .empty-state-title {
    font-size: var(--font-size-base);
  }

  .empty-state-description {
    font-size: var(--font-size-xs);
  }

  .partner-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-sm);
  }

  /* Partner card layout adjustments */
  .partner-card-header {
    flex-wrap: wrap;
    gap: var(--space-md);
  }

  .partner-card-header > .partner-avatar,
  .partner-card-header > .partner-info {
    flex: 1 1 auto;
  }

  .partner-info {
    min-width: 200px; /* Ensure enough space for name */
  }

  .partner-name {
    /* Allow wrapping to 2 lines max */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
  }

  .partner-count-indicators,
  .partner-quick-actions {
    flex: 0 0 100%;
    margin-top: var(--space-sm);
    margin-right: 0;
  }

  .partner-count-indicators {
    order: 3;
  }

  .partner-quick-actions {
    order: 4;
    justify-content: flex-start;
  }

  .button-group {
    flex-direction: column;
  }

  .button-group .button {
    width: 100%;
  }

  .header-main {
    padding: var(--space-sm);
  }

  .logo {
    width: 32px;
    height: 32px;
  }

  .logo-title {
    font-size: var(--font-size-sm);
  }

  .stats-bar-wrapper {
    margin-top: calc(60px + 60px); /* Header (60px) + Search bar (~60px) */
  }

  .stats-bar {
    padding: var(--space-sm);
  }

  .stat-item {
    font-size: var(--font-size-xs);
  }

  .stat-value {
    font-size: var(--font-size-lg);
  }

  /* Admin Section - Extra Small Screens */
  .admin-container {
    padding: 0;
    padding-bottom: var(--space-sm);
  }

  .admin-back-button {
    margin-bottom: var(--space-sm);
    font-size: var(--font-size-sm);
    width: 100%;
  }

  .admin-card {
    padding: var(--space-md);
    border-radius: var(--radius-md);
  }

  .admin-card-icon {
    width: 40px;
    height: 40px;
    font-size: 1.25rem;
  }

  .admin-card-title {
    font-size: 1.25rem;
  }

  .admin-card-subtitle {
    font-size: var(--font-size-xs);
  }

  .admin-card-description {
    padding: var(--space-sm);
    font-size: var(--font-size-xs);
  }

  .description-item {
    font-size: var(--font-size-xs);
  }

  /* User cards - extra small screens */
  .user-card {
    padding: var(--space-sm);
  }

  .user-avatar {
    width: 40px;
    height: 40px;
    font-size: 1rem;
  }

  .user-card-actions {
    gap: 6px;
  }

  .user-card-actions .icon-button {
    padding: 8px;
    min-width: 40px;
    min-height: 40px;
  }
}

/* ============================================================================
   EXTRA SMALL SCREENS - iPhone SE and similar (375px and below)
   ============================================================================ */

@media (max-width: 375px) {
  /* Partner card optimizations for very small screens */
  .partner-avatar {
    width: 36px;
    height: 36px;
    font-size: var(--font-size-base);
  }

  .partner-card-collapsed {
    padding: var(--space-sm);
  }

  .partner-card-header {
    gap: var(--space-sm);
  }

  /* Optimize partner name display */
  .partner-name {
    font-size: var(--font-size-sm);
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  /* Minimize count indicators - show icons only, touch-friendly */
  .count-indicator {
    padding: 8px 10px;
    min-width: 40px;
    min-height: 40px;
    justify-content: center;
  }

  .count-indicator i {
    margin: 0;
  }

  /* Hide count text labels on extra small screens */
  .count-indicator > span:not(.count-number) {
    display: none;
  }

  /* Compact quick actions - maintain touch-friendly sizes */
  .partner-quick-actions {
    gap: 6px;
  }

  .partner-quick-actions .icon-button {
    width: 40px;
    height: 40px;
    min-width: 40px;
    padding: 8px;
    font-size: var(--font-size-sm);
  }

  /* Make partner info take more space */
  .partner-info {
    min-width: 150px;
    flex: 1 1 auto;
  }

  /* Adjust header search for extra small screens */
  .header-search {
    padding: var(--space-sm);
  }

  .header-search .search-input {
    padding: 10px;
    padding-left: 36px;
    font-size: var(--font-size-xs);
  }

  .search-icon {
    left: 10px;
    font-size: var(--font-size-xs);
  }

  /* Ensure main content has proper spacing */
  .main-content {
    padding-top: calc(60px + 54px); /* Header (60px) + Search bar height (~54px) */
  }

  .stats-bar-wrapper {
    margin-top: calc(60px + 54px); /* Header (60px) + Search bar (~54px) */
  }

  /* Admin Section - iPhone SE */
  .admin-container {
    padding: 0;
    padding-bottom: 8px;
  }

  .admin-back-button {
    margin-bottom: 8px;
    font-size: 0.875rem;
    padding: 8px 12px;
    width: 100%;
  }

  .admin-card {
    padding: var(--space-sm);
    margin-bottom: var(--space-md);
  }

  .admin-card-icon {
    width: 36px;
    height: 36px;
    font-size: 1.125rem;
  }

  .admin-card-title {
    font-size: 1.125rem;
  }

  .admin-card-header {
    margin-bottom: var(--space-md);
    gap: var(--space-sm);
  }

  .admin-card-title-group {
    gap: var(--space-sm);
  }

  .admin-button-group {
    gap: var(--space-sm);
  }

  /* User cards - iPhone SE and similar */
  .user-avatar {
    width: 36px;
    height: 36px;
    font-size: 0.9rem;
  }

  .user-card-name {
    font-size: var(--font-size-sm);
  }

  .user-badge {
    font-size: 0.625rem;
    padding: 3px 8px;
  }
}

/* ============================================================================
   ULTRA SMALL SCREENS - 320px and below (iPhone SE mini, small Android)
   ============================================================================ */

@media (max-width: 320px) {
  /* Main content - ultra compact */
  .main-content {
    padding: 6px;
    padding-top: calc(60px + 48px); /* Header (60px) + Search bar height (~48px) */
    padding-bottom: 70px;
  }

  .stats-bar-wrapper {
    margin-top: calc(60px + 48px); /* Header (60px) + Search bar (~48px) */
  }

  /* Admin Container - Ultra compact */
  .admin-container {
    padding: 0;
    padding-bottom: 6px;
  }

  .admin-back-button {
    margin-bottom: 6px;
    font-size: 0.75rem;
    padding: 6px 10px;
    width: 100%;
  }

  /* Admin Cards - Ultra compact */
  .admin-card {
    padding: 8px;
    margin-bottom: 12px;
    border-radius: 8px;
  }

  .admin-card-header {
    margin-bottom: 12px;
    gap: 8px;
  }

  .admin-card-title-group {
    gap: 8px;
  }

  .admin-card-icon {
    width: 32px;
    height: 32px;
    font-size: 1rem;
  }

  .admin-card-title {
    font-size: 1rem;
    line-height: 1.3;
    word-break: break-word;
  }

  .admin-card-subtitle {
    font-size: 0.75rem;
    line-height: 1.3;
  }

  .admin-button-group {
    gap: 6px;
  }

  .admin-button-group .button {
    font-size: 0.75rem;
    padding: 10px 12px;
    min-height: 40px;
  }

  .admin-card-description {
    padding: 8px;
    font-size: 0.75rem;
  }

  .description-item {
    font-size: 0.75rem;
    margin-bottom: 6px;
  }

  /* User cards - ultra compact */
  .user-cards-grid {
    gap: 8px;
  }

  .user-card {
    padding: 8px;
  }

  .user-avatar {
    width: 32px;
    height: 32px;
    font-size: 0.875rem;
  }

  .user-card-name {
    font-size: 0.875rem;
  }

  .user-badge {
    font-size: 0.625rem;
    padding: 2px 6px;
  }

  .user-card-actions .icon-button {
    padding: 6px;
    min-width: 36px;
    min-height: 36px;
    font-size: 0.875rem;
  }

  /* Partner cards */
  .partner-card-collapsed {
    padding: 8px;
  }

  .partner-avatar {
    width: 32px;
    height: 32px;
    font-size: 0.875rem;
  }

  .partner-name {
    font-size: 0.875rem;
  }

  /* Header */
  .header-main {
    padding: 6px;
  }

  .logo {
    width: 28px;
    height: 28px;
  }

  .logo-title {
    font-size: 0.75rem;
  }

  /* Search */
  .header-search {
    padding: 6px;
  }

  .header-search .search-input {
    padding: 8px;
    padding-left: 32px;
    font-size: 0.75rem;
  }

  .search-icon {
    left: 8px;
  }

  /* Buttons - ensure minimum touch targets */
  .button {
    font-size: 0.75rem;
    padding: 10px;
    min-height: 44px;
  }

  .button-small {
    font-size: 0.7rem;
    padding: 8px;
    min-height: 40px;
  }

  /* Back button */
  .back-button {
    font-size: 0.875rem;
    padding: 8px 12px;
  }
}

/* ============================================================================
   PRINT STYLES
   ============================================================================ */

@media print {
  .header,
  .filters-bar,
  .tabs-nav,
  .mobile-nav,
  .button,
  .icon-button,
  .toast-container {
    display: none !important;
  }

  .card,
  .partner-card,
  .task-card,
  .note-card {
    border: 1px solid #000;
    break-inside: avoid;
  }

  body {
    background: white;
  }
}

/* ============================================================================
   UTILITY CLASSES
   ============================================================================ */

.hidden {
  display: none !important;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.flex {
  display: flex;
}

.flex-col {
  flex-direction: column;
}

.items-center {
  align-items: center;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.gap-sm {
  gap: var(--space-sm);
}

.gap-md {
  gap: var(--space-md);
}

.gap-lg {
  gap: var(--space-lg);
}

/* ============================================================================
   ADMIN VIEW STYLES
   ============================================================================ */

.admin-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--space-2xl) var(--space-xl);
  box-sizing: border-box;
  width: 100%;
}

.admin-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  margin-bottom: var(--space-2xl);
  transition: all var(--transition-fast);
}

.admin-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
  gap: var(--space-lg);
}

.admin-card-title-group {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  flex: 1;
}

.admin-card-icon {
  width: 60px;
  height: 60px;
  border-radius: var(--radius-lg);
  background: var(--brand-light);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--brand-primary);
  font-size: 1.75rem;
  flex-shrink: 0;
}

.admin-card-title {
  font-size: 1.875rem;
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin: 0 0 var(--space-xs) 0;
  line-height: 1.2;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}

.admin-card-subtitle {
  font-size: var(--font-size-base);
  color: var(--text-secondary);
  margin: 0;
  line-height: 1.4;
}

.admin-button-group {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.admin-card-description {
  padding: var(--space-lg);
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--brand-primary);
}

.description-item {
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: var(--space-sm);
}

.description-item:last-child {
  margin-bottom: 0;
}

.description-item strong {
  color: var(--text-primary);
  font-weight: var(--font-weight-semibold);
}

/* User Cards Grid */
.users-list-container {
  margin-top: var(--space-lg);
}

.user-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 280px), 1fr));
  gap: var(--space-lg);
  width: 100%;
  overflow: hidden;
}

.user-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: all var(--transition-fast);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  box-sizing: border-box;
  width: 100%;
}

.user-card:hover {
  border-color: var(--brand-primary);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.user-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex: 1;
}

.user-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: var(--brand-light);
  color: var(--brand-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: var(--font-weight-bold);
  flex-shrink: 0;
}

.user-details {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.user-card-name {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  line-height: 1.2;
}

.user-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  width: fit-content;
}

.user-badge.admin {
  background: var(--brand-light);
  color: var(--brand-primary);
  border: 1px solid var(--brand-primary);
}

.user-badge.user {
  background: var(--bg-secondary);
  color: var(--text-secondary);
  border: 1px solid var(--border-default);
}

.user-badges-container {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
}

.user-badge.twofa-enabled {
  background: var(--status-success-bg);
  color: var(--status-success);
  border: 1px solid var(--status-success);
}

.user-badge.twofa-disabled {
  background: var(--bg-secondary);
  color: var(--text-tertiary);
  border: 1px solid var(--border-light);
}

.user-card-actions {
  display: flex;
  gap: var(--space-sm);
  justify-content: flex-end;
}

.admin-back-button {
  margin-bottom: var(--space-xl);
}

.w-full {
  width: 100%;
}

.mb-0 { margin-bottom: 0; }
.mb-sm { margin-bottom: var(--space-sm); }
.mb-md { margin-bottom: var(--space-md); }
.mb-lg { margin-bottom: var(--space-lg); }
.mb-xl { margin-bottom: var(--space-xl); }

.mt-0 { margin-top: 0; }
.mt-sm { margin-top: var(--space-sm); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }

/* ============================================================================
   TWO-FACTOR AUTHENTICATION (2FA) STYLES - SEAD DESIGN SYSTEM
   ============================================================================ */

/* 2FA Modal Container */
.twofa-modal {
  padding: var(--space-xl);
}

/* 2FA Header */
.twofa-header {
  text-align: center;
  margin-bottom: var(--space-xl);
}

.twofa-header h2 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  margin: var(--space-md) 0;
}

.twofa-header p {
  color: var(--text-secondary);
  font-size: var(--font-size-base);
}

.twofa-status-text {
  margin-top: var(--space-sm);
}

/* 2FA Icons - Following Sead Design System */
.twofa-icon-success {
  font-size: 3rem;
  color: var(--status-success);
}

.twofa-icon-warning {
  font-size: 3rem;
  color: var(--text-tertiary);
}

.twofa-icon-primary {
  font-size: 3rem;
  color: var(--brand-primary);
}

/* 2FA Info Section */
.twofa-info {
  background: var(--bg-secondary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-xl);
}

.twofa-info p {
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: var(--space-md);
}

.twofa-info p:last-child {
  margin-bottom: 0;
}

/* 2FA Benefits List */
.twofa-benefits {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0 0 0;
}

.twofa-benefits li {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--text-secondary);
  padding: var(--space-sm) 0;
}

.twofa-benefits li i {
  color: var(--status-success);
  font-size: var(--font-size-base);
}

/* 2FA Setup Steps */
.twofa-setup-steps {
  margin-top: var(--space-xl);
}

.twofa-step {
  display: flex;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
  padding-bottom: var(--space-2xl);
  border-bottom: 1px solid var(--border-light);
}

.twofa-step:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.twofa-step-number {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: var(--brand-primary);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-lg);
}

.twofa-step-content {
  flex: 1;
}

.twofa-step-content h3 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
}

.twofa-step-content p {
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: var(--space-md);
}

/* QR Code Container */
.twofa-qr-container {
  display: flex;
  justify-content: center;
  margin: var(--space-xl) 0;
  padding: var(--space-lg);
  background: white;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}

.twofa-qr-code {
  max-width: 280px;
  width: 100%;
  height: auto;
  display: block;
}

.twofa-manual-code {
  text-align: center;
  color: var(--text-secondary);
  font-size: var(--font-size-sm);
}

.twofa-manual-code code {
  background: var(--bg-secondary);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-sm);
  font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;
  color: var(--brand-primary);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.05em;
}

/* 2FA Token Input */
.twofa-token-input {
  text-align: center;
  font-size: var(--font-size-2xl);
  font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;
  letter-spacing: 0.2em;
  font-weight: var(--font-weight-semibold);
}

.form-help {
  font-size: var(--font-size-sm);
  color: var(--text-tertiary);
  margin-top: var(--space-xs);
  text-align: center;
}

/* Backup Codes Display */
.twofa-backup-warning {
  background: #fff7ed;
  border: 2px solid #f97316;
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-xl);
  display: flex;
  gap: var(--space-md);
  align-items: start;
}

.twofa-backup-warning i {
  color: #f97316;
  font-size: var(--font-size-xl);
  flex-shrink: 0;
  margin-top: 2px;
}

.twofa-backup-warning p {
  color: #7c2d12;
  margin: 0;
  line-height: 1.6;
}

.twofa-backup-codes {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--space-sm);
  background: var(--bg-secondary);
  padding: var(--space-lg);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-xl);
  border: 1px solid var(--border-default);
}

.twofa-backup-code {
  background: white;
  padding: var(--space-md);
  border-radius: var(--radius-sm);
  text-align: center;
  font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  border: 1px solid var(--border-light);
  letter-spacing: 0.05em;
  font-size: var(--font-size-sm);
}

/* 2FA Login Modal */
.twofa-login {
  max-width: 500px;
  margin: 0 auto;
}

.twofa-backup-option {
  text-align: center;
  margin: var(--space-lg) 0;
}

.button-ghost {
  background: transparent;
  border: none;
  color: var(--brand-primary);
  padding: var(--space-sm) var(--space-md);
  font-weight: var(--font-weight-medium);
  transition: all var(--transition-fast);
}

.button-ghost:hover {
  background: var(--brand-light);
  color: var(--brand-primary);
}

.button-small {
  font-size: var(--font-size-sm);
  padding: var(--space-xs) var(--space-sm);
  min-height: 36px;
}

/* Responsive 2FA Styles */
@media (max-width: 768px) {
  .twofa-modal {
    padding: var(--space-lg);
  }

  .twofa-header h2 {
    font-size: var(--font-size-xl);
  }

  .twofa-step {
    flex-direction: column;
    gap: var(--space-md);
  }

  .twofa-step-number {
    width: 36px;
    height: 36px;
    font-size: var(--font-size-base);
  }

  .twofa-qr-code {
    max-width: 220px;
  }

  .twofa-token-input {
    font-size: var(--font-size-xl);
  }

  .twofa-backup-codes {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: var(--space-xs);
    padding: var(--space-md);
  }

  .twofa-backup-code {
    padding: var(--space-sm);
    font-size: 0.75rem;
  }
}

@media (max-width: 480px) {
  .twofa-modal {
    padding: var(--space-md);
  }

  .twofa-header h2 {
    font-size: var(--font-size-lg);
  }

  .twofa-icon-success,
  .twofa-icon-warning,
  .twofa-icon-primary {
    font-size: 2rem;
  }

  .twofa-qr-code {
    max-width: 180px;
  }

  .twofa-backup-codes {
    grid-template-columns: 1fr;
  }
}

/* ============================================================================
   PASSKEY STYLES
   ============================================================================ */

/* Login Divider */
.login-divider {
  text-align: center;
  margin: var(--space-xl) 0;
  position: relative;
  color: var(--text-tertiary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.login-divider::before,
.login-divider::after {
  content: '';
  position: absolute;
  top: 50%;
  width: calc(50% - 30px);
  height: 1px;
  background: var(--border-default);
}

.login-divider::before {
  left: 0;
}

.login-divider::after {
  right: 0;
}

/* Passkey Button */
.passkey-button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
}

/* Passkey List */
.passkey-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin: var(--space-xl) 0;
  max-height: 400px;
  overflow-y: auto;
}

.passkey-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg);
  background: var(--bg-secondary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
}

.passkey-item:hover {
  border-color: var(--border-hover);
  box-shadow: var(--shadow-sm);
}

.passkey-info {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex: 1;
}

.passkey-info i {
  font-size: var(--font-size-2xl);
  color: var(--brand-primary);
}

.passkey-name {
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin-bottom: var(--space-xs);
}

.passkey-date {
  font-size: var(--font-size-sm);
  color: var(--text-tertiary);
}

/* Empty State Small */
.empty-state-small {
  text-align: center;
  padding: var(--space-2xl);
  color: var(--text-tertiary);
}

.empty-state-small i {
  font-size: 3rem;
  color: var(--text-tertiary);
  opacity: 0.5;
  margin-bottom: var(--space-md);
}

.empty-state-small p {
  margin: 0;
  font-weight: var(--font-weight-medium);
}

/* Modal Wide */
.modal-wide {
  max-width: 600px;
}

/* Responsive Passkey Styles */
@media (max-width: 768px) {
  .passkey-list {
    max-height: 300px;
  }

  .passkey-item {
    padding: var(--space-md);
  }

  .modal-wide {
    max-width: 100%;
  }
}

@media (max-width: 480px) {
  .passkey-info {
    gap: var(--space-sm);
  }

  .passkey-info i {
    font-size: var(--font-size-xl);
  }

  .passkey-item {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-md);
  }

  .passkey-item .icon-button {
    align-self: flex-end;
  }
}

/* ============================================================================
   PHOTO GALLERY
   ============================================================================ */

.photo-gallery-section {
  margin-top: var(--space-lg);
}

.photo-gallery-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
}

.photo-gallery-header h4 {
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: var(--text-primary);
}

.photo-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.photo-item {
  position: relative;
  aspect-ratio: 1;
  border: 2px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.photo-item:hover {
  border-color: var(--border-active);
}

.photo-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.photo-actions {
  position: absolute;
  top: var(--space-xs);
  right: var(--space-xs);
  display: flex;
  gap: var(--space-xs);
  opacity: 0;
  transition: opacity 0.2s ease;
}

.photo-item:hover .photo-actions {
  opacity: 1;
}

.photo-actions .button {
  min-width: auto;
  padding: var(--space-xs);
}

/* Responsive - Tablets */
@media (max-width: 768px) {
  .photo-gallery {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: var(--space-sm);
  }

  .photo-actions {
    opacity: 1; /* Always show on touch devices */
  }
}

/* Responsive - Mobile */
@media (max-width: 480px) {
  .photo-gallery {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
  }

  .photo-gallery-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-sm);
  }

  .photo-gallery-header .button {
    width: 100%;
  }
}

/* ============================================================================
   PHOTO MODAL
   ============================================================================ */

/* Larger modal for photos */
.modal:has(.photo-modal-content) .modal-content {
  max-width: 90vw;
  width: 800px;
  max-height: 90vh;
  height: 600px;
}

.photo-modal-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  width: 100%;
  height: 100%;
  overflow: auto;
}

.photo-modal-content h2 {
  font-size: var(--font-size-xl);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0;
  word-break: break-word;
}

.photo-modal-image {
  width: 100%;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border: 2px solid var(--border-default);
  border-radius: var(--radius-md);
  background-color: var(--bg-secondary);
  flex-shrink: 1;
}

.photo-modal-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  padding: var(--space-md);
  background-color: var(--bg-secondary);
  border: 2px solid var(--border-default);
  border-radius: var(--radius-md);
}

.photo-modal-info p {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--text-secondary);
}

.photo-modal-info strong {
  color: var(--text-primary);
  font-weight: 600;
}

/* Responsive - Mobile */
@media (max-width: 768px) {
  .modal:has(.photo-modal-content) .modal-content {
    width: 90vw;
    height: 70vh;
  }
}

@media (max-width: 480px) {
  .modal:has(.photo-modal-content) .modal-content {
    width: 95vw;
    height: 60vh;
    min-width: 250px;
  }

  .photo-modal-content h2 {
    font-size: var(--font-size-lg);
  }

  .photo-modal-info {
    padding: var(--space-sm);
  }
}

/* ============================================================================
   OVERDUE NOTIFICATIONS AND TASK HIGHLIGHT
   ============================================================================ */

/* Overdue Notifications Section */
.overdue-notifications-section {
  margin-top: var(--space-md);
}

.overdue-notifications-section .section-subtitle {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.overdue-notifications-section .section-subtitle i {
  color: var(--warning-color);
}

.overdue-actions-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

/* Template Editor Modal */
.template-textarea {
  font-family: 'Monaco', 'Consolas', 'Courier New', monospace;
  font-size: var(--font-size-sm);
  line-height: 1.5;
  min-height: 300px;
  resize: vertical;
}

.template-placeholders {
  background: var(--bg-secondary);
  padding: var(--space-sm);
  border-radius: var(--radius-sm);
  margin-top: var(--space-sm);
}

.template-placeholders .form-hint {
  margin: 0;
  line-height: 1.6;
}

/* Notification Logs Table */
.notification-logs-container {
  max-height: 400px;
  overflow-y: auto;
  margin: var(--space-md) 0;
}

.notification-logs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-sm);
}

.notification-logs-table th,
.notification-logs-table td {
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  border-bottom: 1px solid var(--border-color);
}

.notification-logs-table th {
  background: var(--bg-secondary);
  font-weight: 600;
  position: sticky;
  top: 0;
}

.notification-logs-table .log-error {
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text-muted);
}

.log-status {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  font-weight: 500;
}

.log-status-success {
  background: rgba(16, 185, 129, 0.1);
  color: var(--success-color);
}

.log-status-failure {
  background: rgba(239, 68, 68, 0.1);
  color: var(--error-color);
}

.log-status-partial {
  background: rgba(245, 158, 11, 0.1);
  color: var(--warning-color);
}

/* Task Highlight Animation */
.task-highlighted {
  animation: task-highlight 3s ease-out;
}

@keyframes task-highlight {
  0%, 30% {
    background-color: rgba(245, 158, 11, 0.2);
    box-shadow: 0 0 0 3px var(--warning-color);
  }
  100% {
    background-color: transparent;
    box-shadow: none;
  }
}

/* Loading state for modals */
.loading-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl);
  color: var(--text-muted);
}

.loading-state i {
  font-size: 2rem;
  margin-bottom: var(--space-md);
}

/* Mobile responsiveness for overdue notifications */
@media (max-width: 768px) {
  .overdue-actions-row {
    flex-direction: column;
  }

  .overdue-actions-row .button {
    width: 100%;
    justify-content: center;
  }

  .notification-logs-table {
    font-size: var(--font-size-xs);
  }

  .notification-logs-table th,
  .notification-logs-table td {
    padding: var(--space-xs) var(--space-sm);
  }

  .template-textarea {
    min-height: 200px;
  }
}

/* ============================================================================
   END OF STYLESHEET
   ============================================================================ */
