:root {
  --color-brand: #144552;
  --color-soft: #82c8d1;
  --color-soft-light: #c5e8ed;
  --color-soft-bg: #e8f5f7;
  --color-bg: #e8f5f7;
  --color-surface: #f7fbfc;
  --color-sidebar: #144552;
  --color-sidebar-hover: #1a5566;
  --color-sidebar-active: rgba(130, 200, 209, 0.22);
  --color-primary: #144552;
  --color-primary-hover: #0f3744;
  --color-primary-light: rgba(130, 200, 209, 0.3);
  --color-text: #1a2e35;
  --color-text-muted: #4a6670;
  --color-border: #a8d4db;
  --color-positive: #0d7a4e;
  --color-positive-bg: #e6f5ee;
  --color-negative: #c0392b;
  --color-negative-bg: #fdecea;
  --sidebar-width: 260px;
  --radius: 10px;
  --radius-sm: 6px;
  --font: 'IBM Plex Sans Arabic', system-ui, sans-serif;
  --icon-size-xs: 12px;
  --icon-size-sm: 14px;
  --icon-size-md: 16px;
  --icon-size-nav: 20px;
  --icon-btn-size: 28px;
  --icon-btn-size-lg: 30px;
}

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

html {
  font-size: 15px;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
}

body {
  font-family: var(--font);
  background: var(--color-bg);
  color: var(--color-text);
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
  max-width: 100vw;
}

/* ===== تسجيل الدخول ===== */
.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 50% -10%, rgba(130, 200, 209, 0.35) 0%, transparent 45%),
    linear-gradient(160deg, var(--color-brand) 0%, #2a7a8a 48%, var(--color-soft) 100%);
  padding: 1.5rem;
}

.login-wrapper {
  width: 100%;
  max-width: 420px;
}

.login-brand {
  text-align: center;
  margin-bottom: 1.75rem;
}

.login-logo-img {
  width: 100%;
  max-width: 260px;
  height: auto;
  display: block;
  margin: 0 auto 1rem;
  border-radius: 8px;
}

.login-brand-title {
  font-size: 1.45rem;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 0.03em;
  margin-bottom: 0.35rem;
}

.login-brand-tagline {
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.92rem;
}

.login-card {
  background: rgba(247, 251, 252, 0.97);
  border: 1px solid rgba(168, 212, 219, 0.65);
  border-radius: 18px;
  padding: 0 1.5rem 1.5rem;
  width: 100%;
  box-shadow: 0 24px 48px rgba(20, 69, 82, 0.22);
  backdrop-filter: blur(8px);
}

.login-tabs {
  display: flex;
  gap: 1.5rem;
  border-bottom: 1px solid var(--color-border);
  margin: 0 -1.5rem 1.35rem;
  padding: 0 1.5rem;
}

.login-tab {
  position: relative;
  padding: 1rem 0 0.85rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-text-muted);
}

.login-tab.is-active {
  color: var(--color-brand);
}

.login-tab.is-active::after {
  content: '';
  position: absolute;
  right: 0;
  left: 0;
  bottom: -1px;
  height: 2px;
  border-radius: 2px 2px 0 0;
  background: var(--color-soft);
}

.login-form .login-field {
  margin-bottom: 1.1rem;
}

.login-form label {
  display: block;
  font-weight: 500;
  margin-bottom: 0.45rem;
  font-size: 0.86rem;
  color: var(--color-text-muted);
}

.login-input-wrap {
  position: relative;
}

.login-input-wrap input {
  width: 100%;
  padding: 0.82rem 2.85rem 0.82rem 2.65rem;
  border: 1.5px solid var(--color-border);
  border-radius: 12px;
  font-family: var(--font);
  font-size: 0.95rem;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
  background: #fff;
  color: var(--color-text);
}

.login-input-wrap input:-webkit-autofill,
.login-input-wrap input:-webkit-autofill:hover,
.login-input-wrap input:-webkit-autofill:focus,
.login-input-wrap input:-webkit-autofill:active {
  -webkit-text-fill-color: var(--color-text) !important;
  caret-color: var(--color-text);
  border-color: var(--color-border);
  box-shadow: 0 0 0 1000px #f7fbfc inset !important;
  transition: background-color 9999s ease-out 0s;
}

.login-input-wrap input:focus:-webkit-autofill {
  border-color: var(--color-soft);
  box-shadow: 0 0 0 1000px #fff inset, 0 0 0 3px rgba(130, 200, 209, 0.28) !important;
}

.login-input-wrap input::placeholder {
  color: #7a9aa3;
}

.login-input-wrap input:focus {
  outline: none;
  border-color: var(--color-soft);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(130, 200, 209, 0.28);
}

.login-input-icon {
  position: absolute;
  top: 50%;
  right: 0.9rem;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  min-width: 18px;
  min-height: 18px;
  color: #6f919b;
  pointer-events: none;
  flex-shrink: 0;
}

.login-input-icon svg {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  flex-shrink: 0;
}

.login-password-toggle {
  position: absolute;
  top: 50%;
  left: 0.65rem;
  transform: translateY(-50%);
  width: 2rem;
  height: 2rem;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: #6f919b;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color 0.2s, background 0.2s;
}

.login-password-toggle:hover {
  color: var(--color-brand);
  background: rgba(130, 200, 209, 0.18);
}

.login-password-toggle svg {
  width: 1.1rem;
  height: 1.1rem;
}

.login-password-toggle .icon-eye-off {
  display: none;
}

.login-password-toggle.is-visible .icon-eye {
  display: none;
}

.login-password-toggle.is-visible .icon-eye-off {
  display: block !important;
}

.login-submit-btn {
  width: 100%;
  justify-content: center;
  gap: 0.55rem;
  padding: 0.9rem 1.25rem;
  margin-top: 0.35rem;
  border-radius: 999px;
  background: var(--color-soft);
  color: var(--color-brand);
  font-weight: 700;
  border: none;
  box-shadow: 0 10px 24px rgba(130, 200, 209, 0.35);
}

.login-submit-btn:hover {
  background: #9ad4dc;
  color: var(--color-primary-hover);
}

.login-submit-btn svg {
  width: 1.1rem;
  height: 1.1rem;
  transform: scaleX(-1);
}

.login-error {
  color: var(--color-negative);
  font-size: 0.85rem;
  text-align: center;
  margin-top: 0.85rem;
  padding: 0.55rem 0.75rem;
  border-radius: 10px;
  background: var(--color-negative-bg);
}

/* ===== الأزرار ===== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.7rem 1.25rem;
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.2s, transform 0.1s;
}

.btn:active {
  transform: scale(0.98);
}

.btn-primary {
  background: var(--color-primary);
  color: #fff;
}

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

.btn-full {
  width: 100%;
  justify-content: center;
  padding: 0.85rem;
  margin-top: 0.5rem;
}

.btn-sm {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
}

/* ===== ثبات أحجام الأيقونات (هاتف / آيباد / سطح المكتب) ===== */
.btn svg,
.sync-notice svg,
.view-toggle-btn svg,
.section-toolbar .btn svg,
.transactions-toolbar .btn svg,
.projects-toolbar .btn svg,
.page-header .btn svg,
.detail-section-header .btn svg,
.saved-invoices-toolbar svg,
.saved-invoice-detail-header .btn svg {
  width: var(--icon-size-md) !important;
  height: var(--icon-size-md) !important;
  min-width: var(--icon-size-md) !important;
  min-height: var(--icon-size-md) !important;
  max-width: var(--icon-size-md) !important;
  max-height: var(--icon-size-md) !important;
  flex-shrink: 0;
}

.btn-icon-edit svg,
.btn-icon-view svg,
.btn-icon-delete svg,
.table-actions svg {
  width: var(--icon-size-sm) !important;
  height: var(--icon-size-sm) !important;
  min-width: var(--icon-size-sm) !important;
  min-height: var(--icon-size-sm) !important;
  max-width: var(--icon-size-sm) !important;
  max-height: var(--icon-size-sm) !important;
  flex-shrink: 0;
}

.nav-icon {
  width: var(--icon-size-nav);
  height: var(--icon-size-nav);
  min-width: var(--icon-size-nav);
  min-height: var(--icon-size-nav);
  flex-shrink: 0;
}

.nav-icon svg {
  width: var(--icon-size-nav) !important;
  height: var(--icon-size-nav) !important;
  min-width: var(--icon-size-nav) !important;
  min-height: var(--icon-size-nav) !important;
  max-width: var(--icon-size-nav) !important;
  max-height: var(--icon-size-nav) !important;
  flex-shrink: 0;
}

.nav-chevron {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
  min-width: var(--icon-size-md);
  min-height: var(--icon-size-md);
  flex-shrink: 0;
}

.nav-chevron svg {
  width: var(--icon-size-md) !important;
  height: var(--icon-size-md) !important;
  min-width: var(--icon-size-md) !important;
  min-height: var(--icon-size-md) !important;
  max-width: var(--icon-size-md) !important;
  max-height: var(--icon-size-md) !important;
  flex-shrink: 0;
}

.btn-icon-edit,
.btn-icon-view {
  width: var(--icon-btn-size);
  height: var(--icon-btn-size);
  min-width: var(--icon-btn-size);
  min-height: var(--icon-btn-size);
  flex-shrink: 0;
}

.project-card-header .btn-icon-delete,
.project-card-header-actions .btn-icon-delete {
  width: var(--icon-btn-size-lg);
  height: var(--icon-btn-size-lg);
  min-width: var(--icon-btn-size-lg);
  min-height: var(--icon-btn-size-lg);
  flex-shrink: 0;
}

.data-table .btn-icon-delete,
#project-detail-content .btn-icon-delete {
  width: var(--icon-btn-size);
  height: var(--icon-btn-size);
  min-width: var(--icon-btn-size);
  min-height: var(--icon-btn-size);
  flex-shrink: 0;
}

.project-status-select {
  background-size: var(--icon-size-xs) var(--icon-size-xs);
}

.login-password-toggle svg,
.login-submit-btn svg {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  flex-shrink: 0;
}

.bank-card-option-icon svg {
  width: var(--icon-size-nav) !important;
  height: var(--icon-size-nav) !important;
  min-width: var(--icon-size-nav) !important;
  min-height: var(--icon-size-nav) !important;
  max-width: var(--icon-size-nav) !important;
  max-height: var(--icon-size-nav) !important;
  flex-shrink: 0;
}

/* ===== التطبيق الرئيسي ===== */
#app {
  display: none !important;
  min-height: 100vh;
}

#app.authenticated {
  display: block !important;
  min-height: 100vh;
  width: 100%;
  max-width: 100vw;
  overflow-x: hidden;
}

#login-page.is-hidden {
  display: none !important;
}

/* ===== الشريط الجانبي ===== */
.sidebar {
  width: var(--sidebar-width);
  background: var(--color-sidebar);
  color: #e8edf2;
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  right: 0;
  left: auto;
  height: 100vh;
  z-index: 100;
  overflow-x: hidden;
}

.sidebar-header {
  padding: 1.25rem 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.sidebar-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
}

.brand-logo-sm {
  width: 100%;
  max-width: 190px;
  height: auto;
  display: block;
  border-radius: 6px;
}

.sidebar-brand-text {
  font-weight: 600;
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.9);
  letter-spacing: 0.03em;
  text-align: center;
}

.sidebar-nav {
  flex: 1;
  padding: 1rem 0.75rem;
  overflow-y: auto;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  width: 100%;
  padding: 0.7rem 0.85rem;
  border: none;
  background: transparent;
  color: #b8c5d3;
  font-family: var(--font);
  font-size: 0.9rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-align: right;
  transition: background 0.15s, color 0.15s;
  margin-bottom: 0.15rem;
}

.nav-item:hover {
  background: var(--color-sidebar-hover);
  color: #fff;
}

.nav-item.active {
  background: var(--color-sidebar-active);
  color: #fff;
  box-shadow: inset 3px 0 0 var(--color-soft);
}

.nav-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  min-width: 20px;
  min-height: 20px;
  opacity: 0.85;
}

.nav-icon svg {
  width: var(--icon-size-nav) !important;
  height: var(--icon-size-nav) !important;
  min-width: var(--icon-size-nav) !important;
  min-height: var(--icon-size-nav) !important;
  max-width: var(--icon-size-nav) !important;
  max-height: var(--icon-size-nav) !important;
  flex-shrink: 0;
}

.nav-chevron {
  margin-right: auto;
  width: var(--icon-size-md);
  height: var(--icon-size-md);
  min-width: var(--icon-size-md);
  min-height: var(--icon-size-md);
  flex-shrink: 0;
  transition: transform 0.2s;
}

.nav-group.open .nav-chevron {
  transform: rotate(180deg);
}

.nav-group.has-active > .nav-group-toggle {
  color: #fff;
  background: rgba(130, 200, 209, 0.12);
}

.nav-submenu {
  display: none;
  padding-right: 2.5rem;
  margin-bottom: 0.25rem;
}

.nav-group.open .nav-submenu {
  display: block;
}

.nav-subitem {
  display: block;
  width: 100%;
  padding: 0.5rem 0.85rem;
  border: none;
  background: transparent;
  color: #8fa3b8;
  font-family: var(--font);
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-align: right;
  transition: background 0.15s, color 0.15s;
}

.nav-subitem:hover,
.nav-subitem.active {
  background: rgba(130, 200, 209, 0.15);
  color: #fff;
}

.sidebar-footer {
  padding: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.sync-status {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.85rem;
  padding: 0.55rem 0.7rem;
  border-radius: 8px;
  font-size: 0.72rem;
  line-height: 1.4;
  color: #b8c7d6;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.sync-status::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: #8fa3b8;
}

.sync-status[data-status='syncing']::before {
  background: #f1c40f;
  box-shadow: 0 0 0 3px rgba(241, 196, 15, 0.2);
}

.sync-status[data-status='synced']::before {
  background: #2ecc71;
  box-shadow: 0 0 0 3px rgba(46, 204, 113, 0.18);
}

.sync-status[data-status='offline']::before {
  background: #e67e22;
  box-shadow: 0 0 0 3px rgba(230, 126, 34, 0.18);
}

.sync-status[data-status='conflict']::before {
  background: #3498db;
  box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.18);
}

.user-info {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.user-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--color-soft);
  color: var(--color-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.user-details {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
}

.user-name {
  font-size: 0.85rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.btn-logout {
  background: none;
  border: none;
  color: #8fa3b8;
  font-family: var(--font);
  font-size: 0.75rem;
  cursor: pointer;
  padding: 0;
  text-align: right;
}

.btn-logout:hover {
  color: #fff;
}

/* ===== المحتوى الرئيسي ===== */
.main-content {
  width: calc(100vw - var(--sidebar-width));
  max-width: calc(100vw - var(--sidebar-width));
  margin-right: var(--sidebar-width);
  margin-left: 0;
  padding: 2rem 2.5rem;
  background: var(--color-bg);
  min-height: 100vh;
  min-width: 0;
  box-sizing: border-box;
}

.page-header {
  margin-bottom: 1.75rem;
}

.page-header h2 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-sidebar);
}

.page-subtitle {
  color: var(--color-text-muted);
  font-size: 0.9rem;
  margin-top: 0.2rem;
}

.content-section {
  display: none !important;
}

.content-section.active {
  display: block !important;
}

.section-toolbar {
  margin-bottom: 1.25rem;
}

.projects-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
}

.project-view-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.2rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  flex-shrink: 0;
}

.view-toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: none;
  box-shadow: none;
  flex-shrink: 0;
}

.view-toggle-btn.is-active {
  background: var(--color-primary-light);
  color: var(--color-primary);
  border-color: transparent;
}

.project-filter-panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 1rem 1.15rem;
  margin-bottom: 1.25rem;
}

.project-filter-panel[hidden] {
  display: none !important;
}

.project-filter-fields {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: flex-end;
}

.filter-group {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 140px;
}

.filter-group label {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-text-muted);
}

.filter-group select {
  padding: 0.5rem 0.75rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.875rem;
  background: var(--color-bg);
  color: var(--color-text);
  cursor: pointer;
}

.filter-group select:focus {
  outline: none;
  border-color: var(--color-soft);
}

.project-filter-summary {
  margin-top: 0.75rem;
  font-size: 0.8rem;
  color: var(--color-text-muted);
}

.projects-empty-state {
  grid-column: 1 / -1;
  text-align: center;
  padding: 2.5rem 1.5rem;
  background: var(--color-surface);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius);
  color: var(--color-text-muted);
}

#toggle-project-filter-btn.is-active,
#toggle-transactions-filter-btn.is-active {
  background: var(--color-soft-bg);
  border-color: var(--color-soft);
  color: var(--color-primary);
}

.transactions-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
}

.transactions-search-wrap {
  flex: 1 1 220px;
  min-width: 0;
}

.transactions-search-input {
  width: 100%;
  padding: 0.55rem 0.85rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.875rem;
  background: var(--color-surface);
  color: var(--color-text);
}

.transactions-search-input:focus {
  outline: none;
  border-color: var(--color-soft);
  box-shadow: 0 0 0 3px rgba(42, 122, 138, 0.12);
}

.transactions-search-summary {
  margin: -0.5rem 0 1rem;
  font-size: 0.85rem;
  color: var(--color-text-muted);
}

.project-filter-fields input[type="date"],
.project-filter-fields input[type="number"],
.project-filter-fields .amount-input,
.client-form .amount-input,
.modal-form .amount-input {
  padding: 0.5rem 0.75rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.875rem;
  background: var(--color-bg);
  width: 100%;
}

.project-filter-fields input:focus {
  outline: none;
  border-color: var(--color-soft);
}

.transactions-monthly-grid {
  display: block;
}

.month-icons-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1.25rem;
}

.month-icon-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-height: 260px;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  cursor: pointer;
  overflow: hidden;
  background: #fff;
  text-align: center;
  transition: transform 0.2s, box-shadow 0.2s;
  font-family: var(--font);
}

.month-icon-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 28px rgba(20, 69, 82, 0.2);
}

.month-icon-card--compact {
  min-height: auto;
}

.month-icon-card--compact .month-icon-bottom {
  gap: 0.35rem;
  padding: 0.6rem 1rem 0.5rem;
}

.month-icon-card:focus-visible {
  outline: 2px solid var(--color-soft);
  outline-offset: 3px;
}

.month-icon-top {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 132px;
  padding: 1.35rem 1.25rem 1.15rem;
  color: #fff;
  overflow: hidden;
}

.month-icon-glow {
  position: absolute;
  inset: 0;
  opacity: 0.15;
  background: radial-gradient(circle at 30% 20%, #fff 0%, transparent 55%);
  pointer-events: none;
}

.month-icon-top.month-icon-variant-0 {
  background: linear-gradient(145deg, #144552 0%, #2a8a9a 100%);
}

.month-icon-top.month-icon-variant-1 {
  background: linear-gradient(145deg, #0d7a4e 0%, #34d399 100%);
}

.month-icon-top.month-icon-variant-2 {
  background: linear-gradient(145deg, #92610a 0%, #e8c547 100%);
  color: #3d2e04;
}

.month-icon-top.month-icon-variant-3 {
  background: linear-gradient(145deg, #6d28d9 0%, #a78bfa 100%);
}

.month-icon-bottom {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.55rem;
  padding: 0.95rem 1rem 0.85rem;
  background: #fff;
  color: var(--color-text);
}

.month-icon-content {
  position: relative;
  z-index: 1;
}

.month-icon-year {
  display: block;
  font-size: 1.15rem;
  font-weight: 500;
  opacity: 0.9;
  letter-spacing: 0.06em;
  margin-bottom: 0.25rem;
}

.month-icon-name {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.15;
  margin-bottom: 0.35rem;
}

.month-icon-count {
  display: block;
  font-size: 0.8rem;
  opacity: 0.85;
}

.month-icon-stats {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  width: 100%;
}

.month-stat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  width: 100%;
  padding: 0 0.15rem;
}

.month-stat-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.month-stat-value {
  font-size: 0.8rem;
  font-weight: 700;
  text-align: left;
}

.month-stat-net {
  margin-top: 0.15rem;
  padding-top: 0.55rem;
  border-top: 1px dashed var(--color-border);
}

.month-stat-net .month-stat-label {
  font-size: 0.78rem;
  font-weight: 700;
}

.month-stat-net .month-stat-value {
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.month-icon-hint {
  font-size: 0.72rem;
  color: var(--color-text-muted);
  text-align: center;
}

.month-detail-view {
  animation: fadeIn 0.25s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.month-detail-hero {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  margin-bottom: 1.25rem;
  padding: 1.5rem;
  background: linear-gradient(135deg, var(--color-brand) 0%, #2a7a8a 100%);
  border-radius: var(--radius);
  color: #fff;
}

.month-detail-icon {
  text-align: center;
}

.month-detail-year {
  display: block;
  font-size: 1.35rem;
  font-weight: 500;
  opacity: 0.9;
  letter-spacing: 0.08em;
}

.month-detail-name {
  display: block;
  font-size: 2.75rem;
  font-weight: 700;
  line-height: 1.1;
}

.month-detail-stats {
  color: #fff;
}

.month-detail-stats .amount-positive {
  color: #86efac;
}

.month-detail-stats .amount-negative {
  color: #fca5a5;
}

.month-txn-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
}

.month-txn-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  font-size: 0.82rem;
  font-weight: 600;
}

.month-txn-card .table-card {
  border: none;
  border-radius: 0;
}

.txn-project-number {
  font-size: 0.9rem;
  color: var(--color-primary);
}

.sync-notice {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.75rem 1rem;
  margin-bottom: 1.25rem;
  background: var(--color-soft-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-muted);
  font-size: 0.85rem;
}

.sync-notice svg {
  flex-shrink: 0;
  width: var(--icon-size-md) !important;
  height: var(--icon-size-md) !important;
  min-width: var(--icon-size-md) !important;
  min-height: var(--icon-size-md) !important;
  max-width: var(--icon-size-md) !important;
  max-height: var(--icon-size-md) !important;
  color: var(--color-primary);
}

.detail-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.project-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.project-detail-title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.3rem;
  margin-bottom: 0.15rem;
}

.project-detail-number {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.05em;
  line-height: 1.2;
}

.project-detail-name {
  font-size: 1.55rem;
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.45;
  letter-spacing: 0.01em;
  margin: 0;
}

.project-detail-header-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.card-panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 1.15rem 1.25rem;
  margin-bottom: 1.25rem;
}

.project-detail-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.85rem 1.25rem;
}

.project-detail-meta .meta-label {
  display: block;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-bottom: 0.2rem;
}

.project-detail-description {
  grid-column: 1 / -1;
  line-height: 1.6;
}

.detail-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.detail-section-header h3 {
  font-size: 1rem;
  font-weight: 600;
}

.detail-section .table-card {
  margin-bottom: 0;
}

.empty-table-cell {
  text-align: center;
  color: var(--color-text-muted);
  font-style: italic;
  padding: 1.5rem !important;
}

.table-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  justify-content: center;
}

.btn-icon-edit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--icon-btn-size);
  height: var(--icon-btn-size);
  min-width: var(--icon-btn-size);
  min-height: var(--icon-btn-size);
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  background: var(--color-surface);
  color: var(--color-primary);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.btn-icon-edit:hover {
  background: var(--color-soft-bg);
  border-color: var(--color-soft);
  color: var(--color-primary);
}

.btn-icon-view {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--icon-btn-size);
  height: var(--icon-btn-size);
  min-width: var(--icon-btn-size);
  min-height: var(--icon-btn-size);
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  background: var(--color-surface);
  color: var(--color-soft);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.btn-icon-view:hover {
  background: var(--color-soft-bg);
  border-color: var(--color-soft);
  color: var(--color-primary);
}

.data-table .btn-icon-delete,
#project-detail-content .btn-icon-delete {
  width: var(--icon-btn-size);
  height: var(--icon-btn-size);
  min-width: var(--icon-btn-size);
  min-height: var(--icon-btn-size);
  border-color: var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.data-table .btn-icon-delete:hover,
#project-detail-content .btn-icon-delete:hover {
  background: var(--color-negative);
  border-color: var(--color-negative);
  color: #fff;
}

.client-select-field {
  position: relative;
}

.client-select-field::before {
  content: '';
  position: absolute;
  left: 0.85rem;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a2e35' stroke-width='2'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 20c0-4 4-6 8-6s8 2 8 6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  pointer-events: none;
  z-index: 1;
}

.client-select {
  width: 100%;
  padding: 0.7rem 2.2rem 0.7rem 2.6rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.9rem;
  background-color: var(--color-bg);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231a2e35' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: left 0.85rem center;
  cursor: pointer;
}

.client-select:focus {
  outline: none;
  border-color: var(--color-soft);
  background-color: var(--color-surface);
}

.modal-form select:not(.client-select),
.client-form select:not(.client-select) {
  width: 100%;
  padding: 0.7rem 0.9rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.9rem;
  background: var(--color-bg);
}

.client-form select:not(.client-select):focus,
.modal-form select:not(.client-select):focus {
  outline: none;
  border-color: var(--color-soft);
  background: var(--color-surface);
}

.invoice-client-picker {
  margin-bottom: 0.65rem;
}

.invoice-picker-label {
  display: block;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: 0.35rem;
}

.invoice-new-client-fields {
  margin-bottom: 0.65rem;
}

.invoice-new-client-fields label {
  display: block;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-text-muted);
  margin-bottom: 0.35rem;
}

.invoice-new-client-fields input {
  width: 100%;
  padding: 0.55rem 0.7rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.85rem;
  background: #fff;
}

.client-type-select {
  min-width: 100px;
  padding: 0.35rem 0.6rem;
  border-radius: 20px;
  border: 1.5px solid transparent;
  font-family: var(--font);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231a2e35' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: left 0.45rem center;
  padding-left: 1.4rem;
}

.client-type-select:focus {
  outline: none;
  box-shadow: 0 0 0 2px var(--color-soft);
}

.client-type-premium {
  background: #fef9e7;
  color: #92610a;
  border-color: #e8c547;
}

.txn-type-badge {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}

.txn-type-revenue {
  background: var(--color-positive-bg);
  color: var(--color-positive);
}

.txn-type-expense {
  background: var(--color-negative-bg);
  color: var(--color-negative);
}

.client-type-normal {
  background: #e6f5ee;
  color: #0d7a4e;
  border-color: #86efac;
}

.client-type-volatile {
  background: #fdecea;
  color: #c0392b;
  border-color: #fca5a5;
}

.client-type-badge {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  border-radius: 20px;
  border: 1.5px solid transparent;
  font-size: 0.8rem;
  font-weight: 600;
  white-space: nowrap;
}

.client-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.client-detail-meta {
  margin-bottom: 1.25rem;
}


/* ===== الإحصائيات ===== */
.stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-top: 1.5rem;
  margin-bottom: 0;
}

.stat-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 1.25rem;
  border-top: 3px solid var(--color-soft);
}

.stat-label {
  display: block;
  font-size: 0.8rem;
  color: var(--color-text-muted);
  margin-bottom: 0.35rem;
}

.stat-value {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-text);
}

.stat-value.positive {
  color: var(--color-positive);
}

.stat-value.negative {
  color: var(--color-negative);
}

/* ===== الجداول ===== */
.table-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
}

.data-table th {
  background: var(--color-soft-light);
  padding: 0.85rem 1.25rem;
  text-align: right;
  font-weight: 600;
  font-size: 0.8rem;
  color: var(--color-text-muted);
  border-bottom: 1px solid var(--color-border);
}

.data-table td {
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid var(--color-border);
  font-size: 0.9rem;
}

.data-table tbody tr:last-child td {
  border-bottom: none;
}

.data-table tbody tr:hover {
  background: var(--color-primary-light);
}

.amount-positive {
  color: var(--color-positive);
  font-weight: 600;
}

.amount-negative {
  color: var(--color-negative);
  font-weight: 600;
}

/* ===== التبويبات ===== */
.tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.tab {
  padding: 0.55rem 1.25rem;
  border: 1.5px solid var(--color-border);
  background: var(--color-surface);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.875rem;
  cursor: pointer;
  transition: all 0.15s;
}

.tab:hover {
  border-color: var(--color-soft);
  background: var(--color-soft-bg);
}

.tab.active {
  background: var(--color-primary);
  color: #fff;
}

/* ===== أقسام المصروفات ===== */
.expenses-category-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  padding: 0.35rem;
  background: var(--color-soft-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
}

.expenses-cat-tab {
  flex: 1 1 auto;
  min-width: 140px;
  padding: 0.7rem 1.1rem;
  border: 1.5px solid transparent;
  background: transparent;
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all 0.15s;
  text-align: center;
}

.expenses-cat-tab:hover {
  background: var(--color-surface);
  color: var(--color-primary);
}

.expenses-cat-tab.active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
  box-shadow: 0 2px 8px rgba(20, 69, 82, 0.2);
}

.expenses-panel {
  animation: fadeIn 0.2s ease;
  border-color: var(--color-primary);
}

/* ===== بطاقات المشاريع ===== */
.projects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 1.25rem;
  direction: ltr;
}

.projects-grid.projects-grid-list {
  display: block;
  direction: rtl;
}

.projects-list-card {
  overflow-x: auto;
}

.projects-table .project-list-number-cell {
  width: 1%;
  white-space: nowrap;
  vertical-align: middle;
}

.project-list-number-badge {
  display: inline-block;
  min-width: 4.5rem;
  padding: 0.35rem 0.65rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: var(--color-soft-bg);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--color-primary);
  text-align: center;
}

.projects-table .project-list-name-cell {
  min-width: 180px;
  max-width: 320px;
  vertical-align: middle;
}

.project-list-name {
  display: block;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.45;
  letter-spacing: 0.01em;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.projects-table .project-list-row {
  cursor: pointer;
}

.projects-table .project-list-status {
  min-width: 130px;
}

.projects-table .project-status-select {
  min-width: 110px;
}

.projects-table .project-list-actions {
  min-width: 280px;
}

.project-list-actions-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  align-items: center;
  justify-content: flex-start;
}

.project-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow 0.2s, border-color 0.2s;
}

.project-card:hover {
  border-color: var(--color-soft);
  box-shadow: 0 4px 18px rgba(20, 69, 82, 0.1);
}

.project-card:focus-visible {
  outline: 2px solid var(--color-soft);
  outline-offset: 2px;
}

.project-card-header {
  padding: 1.25rem;
  background: linear-gradient(135deg, var(--color-brand) 0%, #2a7a8a 100%);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.project-card-header h3 {
  font-size: 1rem;
  font-weight: 600;
}

.project-card-header-actions {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.project-card-header-start {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.45rem;
  flex-shrink: 0;
}

.project-card-number {
  font-size: 1.65rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #fff;
  line-height: 1.1;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
  direction: ltr;
}

.project-card-title-block {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.15rem;
}

.project-card-name {
  font-size: 1.05rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.94);
  line-height: 1.5;
  letter-spacing: 0.01em;
  overflow-wrap: anywhere;
  text-align: right;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.18);
}

.project-card-client {
  font-size: 0.78rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.35;
  letter-spacing: 0.01em;
  overflow-wrap: anywhere;
  text-align: right;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
}

.project-card-header-compact {
  align-items: flex-start;
  min-height: 3.5rem;
  padding: 0.75rem 1rem;
  gap: 0.75rem;
}

.project-card-header-compact .project-card-header-actions {
  width: auto;
  flex-shrink: 0;
  justify-content: flex-start;
}

.btn-icon-delete {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--icon-btn-size-lg);
  height: var(--icon-btn-size-lg);
  min-width: var(--icon-btn-size-lg);
  min-height: var(--icon-btn-size-lg);
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.btn-icon-delete:hover {
  background: rgba(192, 57, 43, 0.85);
  border-color: rgba(255, 255, 255, 0.5);
  color: #fff;
}

.delete-confirm-text {
  font-size: 0.95rem;
  line-height: 1.7;
  margin-bottom: 0.5rem;
}

.delete-confirm-warning {
  font-size: 0.85rem;
  color: var(--color-negative);
  background: var(--color-negative-bg);
  padding: 0.75rem 0.9rem;
  border-radius: var(--radius-sm);
  margin-bottom: 1rem;
  line-height: 1.6;
}

.project-status-select {
  border-radius: 20px;
  padding: 0.3rem 0.65rem;
  font-size: 0.75rem;
  font-family: var(--font);
  font-weight: 600;
  color: #fff;
  cursor: pointer;
  min-width: 110px;
  text-align: center;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-size: var(--icon-size-xs) var(--icon-size-xs);
  background-repeat: no-repeat;
  background-position: left 0.5rem center;
  padding-left: 1.5rem;
  border: 1px solid transparent;
  transition: background 0.2s, border-color 0.2s, box-shadow 0.2s;
}

.project-status-select.status-new {
  background-color: #2563eb;
  border-color: rgba(191, 219, 254, 0.55);
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.35);
}

.project-status-select.status-active {
  background-color: #0e7490;
  border-color: rgba(103, 232, 249, 0.5);
  box-shadow: 0 2px 8px rgba(14, 116, 144, 0.35);
}

.project-status-select.status-postponed {
  background-color: #d97706;
  border-color: rgba(253, 230, 138, 0.55);
  box-shadow: 0 2px 8px rgba(217, 119, 6, 0.35);
}

.project-status-select.status-completed {
  background-color: #0d7a4e;
  border-color: rgba(134, 239, 172, 0.55);
  box-shadow: 0 2px 8px rgba(13, 122, 78, 0.35);
  color: #fff;
}

.project-status-select:focus {
  outline: none;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.35);
}

.project-status-select option {
  color: var(--color-text);
  background: #fff;
  font-weight: 500;
}

.project-card-body {
  padding: 1rem 1.25rem;
}

.project-meta {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  margin-bottom: 0.85rem;
  line-height: 1.7;
}

.project-meta-centered {
  text-align: center;
}

.project-meta a {
  color: var(--color-primary);
  text-decoration: none;
}

.project-meta a:hover {
  text-decoration: underline;
}

.project-description {
  font-size: 0.85rem;
  color: var(--color-text);
  margin-bottom: 1rem;
  padding: 0.65rem 0.75rem;
  background: var(--color-soft-bg);
  border-radius: var(--radius-sm);
  line-height: 1.5;
}

.project-summary {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}

.project-summary-compact {
  margin-bottom: 0.85rem;
  padding-bottom: 0;
  border-bottom: none;
}

.project-summary-item {
  flex: 1;
  text-align: center;
}

.project-summary-item .label {
  display: block;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-bottom: 0.2rem;
}

.project-summary-item .value {
  font-weight: 700;
  font-size: 0.95rem;
}

.project-lists {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.project-list h4 {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-bottom: 0.5rem;
  padding-bottom: 0.35rem;
  border-bottom: 2px solid var(--color-border);
}

.project-list.revenues h4 {
  border-bottom-color: var(--color-positive);
  color: var(--color-positive);
}

.project-list.expenses h4 {
  border-bottom-color: var(--color-negative);
  color: var(--color-negative);
}

.project-list ul {
  list-style: none;
}

.project-list li {
  display: flex;
  justify-content: space-between;
  padding: 0.35rem 0;
  font-size: 0.8rem;
  border-bottom: 1px solid var(--color-soft-bg);
}

.project-list li.empty-list {
  justify-content: center;
  color: var(--color-text-muted);
  font-style: italic;
  border-bottom: none;
}

.project-list li span:last-child {
  font-weight: 600;
  white-space: nowrap;
}

/* ===== التقارير ===== */
.reports-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.25rem;
}

.report-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 1.5rem;
  border-right: 4px solid var(--color-soft);
}

.report-card h3 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: var(--color-sidebar);
}

.report-row {
  display: flex;
  justify-content: space-between;
  padding: 0.45rem 0;
  font-size: 0.875rem;
  border-bottom: 1px solid var(--color-bg);
}

.report-row:last-child {
  border-bottom: none;
  padding-top: 0.75rem;
  margin-top: 0.25rem;
  border-top: 2px solid var(--color-border);
  font-weight: 700;
}

.report-row .label {
  color: var(--color-text-muted);
}

.reports-summary {
  margin-top: 1.5rem;
}

.reports-summary-card {
  background: linear-gradient(135deg, var(--color-brand) 0%, #2a7a8a 100%);
  color: #fff;
  border-radius: var(--radius);
  padding: 1.35rem 1.5rem;
  box-shadow: 0 4px 20px rgba(20, 69, 82, 0.15);
}

.reports-summary-card h3 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: #fff;
}

.reports-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
}

.reports-summary-item {
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-sm);
  padding: 0.9rem 1rem;
  text-align: center;
}

.reports-summary-highlight {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.35);
}

.reports-summary-label {
  display: block;
  font-size: 0.78rem;
  opacity: 0.85;
  margin-bottom: 0.35rem;
}

.reports-summary-value {
  display: block;
  font-size: 1.15rem;
  font-weight: 700;
}

.reports-summary-card .amount-positive {
  color: #86efac;
}

.reports-summary-card .amount-negative {
  color: #fca5a5;
}

.report-profit {
  color: var(--color-positive);
}

.report-loss {
  color: var(--color-negative);
}


/* ===== نموذج تسجيل العميل ===== */
.form-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 2rem;
  max-width: 520px;
  border-top: 3px solid var(--color-soft);
}

.form-card-wide {
  max-width: 640px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  direction: ltr;
}

.form-row .form-group {
  direction: rtl;
}

@media (max-width: 600px) {
  .form-row {
    grid-template-columns: 1fr;
  }
}

.client-form .form-group {
  margin-bottom: 1.25rem;
}

.client-form label {
  display: block;
  font-weight: 500;
  margin-bottom: 0.4rem;
  font-size: 0.9rem;
}

.client-form input,
.client-form textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.95rem;
  background: var(--color-bg);
  transition: border-color 0.2s;
  resize: vertical;
}

.client-form input:focus,
.client-form textarea:focus {
  outline: none;
  border-color: var(--color-soft);
  background: var(--color-surface);
}

.client-form input[dir="ltr"] {
  text-align: left;
}

.form-error {
  color: var(--color-negative);
  font-size: 0.85rem;
  margin-bottom: 1rem;
}

.form-actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 0.5rem;
}

.btn-secondary {
  background: var(--color-surface);
  color: var(--color-text);
  border: 1.5px solid var(--color-border);
}

.btn-secondary:hover {
  background: var(--color-soft-bg);
  border-color: var(--color-soft);
}

.btn-success {
  background: var(--color-positive);
  color: #fff;
}

.btn-success:hover {
  background: #0a6340;
}

.btn-danger {
  background: var(--color-negative);
  color: #fff;
}

.btn-danger:hover {
  background: #a93226;
}

.btn-add-payment {
  background: #fff;
  color: var(--color-positive);
  border: 1.5px solid var(--color-positive);
}

.btn-add-payment:hover {
  background: var(--color-positive-bg);
  color: var(--color-positive);
}

.btn-add-expense {
  background: #fff;
  color: var(--color-negative);
  border: 1.5px solid var(--color-negative);
}

.btn-add-expense:hover {
  background: var(--color-negative-bg);
  color: var(--color-negative);
}

.project-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
  cursor: default;
}

.project-card-actions .btn {
  flex: 1;
  justify-content: center;
  min-width: 120px;
  font-size: 0.8rem;
  padding: 0.55rem 0.75rem;
}

/* ===== نافذة منبثقة ===== */
.modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}

.modal[hidden] {
  display: none !important;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 69, 82, 0.45);
}

.modal-dialog {
  position: relative;
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow-y: auto;
  background: var(--color-surface);
  border-radius: var(--radius);
  border: 1px solid var(--color-border);
  box-shadow: 0 12px 40px rgba(20, 69, 82, 0.2);
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 1.25rem;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-soft-bg);
}

.modal-header h3 {
  font-size: 1rem;
  font-weight: 600;
}

.modal-close {
  background: none;
  border: none;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0.15rem 0.4rem;
  border-radius: var(--radius-sm);
}

.modal-close:hover {
  color: var(--color-text);
  background: var(--color-border);
}

.modal-body {
  padding: 1.25rem;
}

.form-check {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  font-weight: 500;
}

.form-check input[type="checkbox"] {
  width: 1rem;
  height: 1rem;
  margin: 0;
  cursor: pointer;
}

.bank-card-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.4rem;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  background: var(--color-soft-bg);
  border: 1px solid var(--color-border);
  color: var(--color-primary);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.bank-card-field label {
  display: block;
  margin-bottom: 0.55rem;
}

.bank-card-options {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.bank-card-option {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-width: 5.5rem;
  padding: 0.7rem 0.85rem;
  border: 1.5px solid var(--color-border);
  border-radius: 12px;
  background: var(--color-surface);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, color 0.2s, box-shadow 0.2s;
}

.bank-card-option:hover {
  border-color: var(--color-soft);
  color: var(--color-primary);
}

.bank-card-option.is-selected {
  border-color: var(--color-primary);
  background: var(--color-soft-bg);
  color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(20, 69, 82, 0.12);
}

.bank-card-option-icon {
  display: inline-flex;
  width: 2rem;
  height: 2rem;
}

.bank-card-option-icon svg {
  width: var(--icon-size-nav) !important;
  height: var(--icon-size-nav) !important;
  min-width: var(--icon-size-nav) !important;
  min-height: var(--icon-size-nav) !important;
  max-width: var(--icon-size-nav) !important;
  max-height: var(--icon-size-nav) !important;
  flex-shrink: 0;
}

.bank-card-option-label {
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.modal-form .form-group {
  margin-bottom: 1rem;
}

.modal-form label {
  display: block;
  font-weight: 500;
  margin-bottom: 0.4rem;
  font-size: 0.9rem;
}

.modal-form input,
.modal-form textarea {
  width: 100%;
  padding: 0.7rem 0.9rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: 0.9rem;
  background: var(--color-bg);
}

.modal-form input:focus,
.modal-form textarea:focus {
  outline: none;
  border-color: var(--color-soft);
  background: var(--color-surface);
}

.modal-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  direction: ltr;
}

.modal-form .form-row .form-group {
  direction: rtl;
}

.modal-form .form-actions {
  margin-top: 0.25rem;
}

.description-autocomplete {
  position: relative;
}

.description-suggestions {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  left: 0;
  z-index: 30;
  margin: 0;
  padding: 0.35rem 0;
  list-style: none;
  max-height: 220px;
  overflow-y: auto;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  box-shadow: 0 8px 24px rgba(20, 69, 82, 0.12);
}

.description-suggestions li {
  padding: 0.55rem 0.9rem;
  font-size: 0.9rem;
  color: var(--color-text);
  cursor: pointer;
  transition: background 0.15s;
}

.description-suggestions li:hover,
.description-suggestions li.is-active {
  background: var(--color-soft-bg);
  color: var(--color-primary);
}

/* ===== فواتير منشأه ===== */
.saved-invoices-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.saved-invoices-create-btn {
  flex-shrink: 0;
}

.saved-invoices-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.85rem;
  margin-bottom: 1rem;
}

.saved-invoices-stat {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 0.9rem 1rem;
  box-shadow: 0 2px 8px rgba(20, 69, 82, 0.05);
}

.saved-invoices-stat-label {
  display: block;
  font-size: 0.8rem;
  color: var(--color-text-muted);
  margin-bottom: 0.25rem;
}

.saved-invoices-stat-value {
  font-size: 1.35rem;
  color: var(--color-brand);
  line-height: 1.2;
}

.saved-invoices-toolbar {
  margin-bottom: 1rem;
}

.saved-invoices-search-field {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius);
  padding: 0.55rem 0.85rem;
  color: var(--color-text-muted);
}

.saved-invoices-search-field:focus-within {
  border-color: var(--color-soft);
  box-shadow: 0 0 0 3px var(--color-primary-light);
}

.saved-invoices-search-field input {
  width: 100%;
  border: none;
  background: transparent;
  font-family: var(--font);
  font-size: 0.92rem;
  color: var(--color-text);
  outline: none;
}

.saved-invoices-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}

.saved-invoice-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 1rem 1.05rem;
  box-shadow: 0 2px 10px rgba(20, 69, 82, 0.06);
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s, transform 0.15s;
}

.saved-invoice-card:hover {
  border-color: var(--color-soft);
  box-shadow: 0 6px 18px rgba(20, 69, 82, 0.1);
  transform: translateY(-1px);
}

.saved-invoice-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.saved-invoice-card-label {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-bottom: 0.15rem;
}

.saved-invoice-card-number {
  font-size: 1rem;
  color: var(--color-brand);
  line-height: 1.3;
}

.saved-invoice-card-amount {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-brand);
  white-space: nowrap;
}

.saved-invoice-card-meta {
  display: grid;
  gap: 0.45rem;
  margin: 0 0 0.9rem;
}

.saved-invoice-card-meta div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}

.saved-invoice-card-meta dt {
  font-size: 0.78rem;
  color: var(--color-text-muted);
}

.saved-invoice-card-meta dd {
  font-size: 0.86rem;
  color: var(--color-text);
  text-align: left;
}

.saved-invoice-card-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--color-border);
}

.saved-invoices-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 2.5rem 1rem;
  background: var(--color-surface);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius);
  color: var(--color-text-muted);
}

.saved-invoices-empty .btn {
  margin-top: 0.85rem;
}

.saved-invoices-breadcrumb {
  margin-bottom: 0.75rem;
}

.saved-invoices-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: none;
  background: transparent;
  color: var(--color-brand);
  font-family: var(--font);
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
}

.saved-invoices-back-link:hover {
  color: var(--color-primary-hover);
}

.saved-invoice-detail-header {
  display: grid;
  gap: 0.85rem;
  margin-bottom: 1.25rem;
  padding: 1rem 1.1rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: 0 2px 10px rgba(20, 69, 82, 0.05);
}

.saved-invoice-detail-eyebrow {
  font-size: 0.78rem;
  color: var(--color-text-muted);
  margin-bottom: 0.15rem;
}

.saved-invoice-detail-header h2 {
  font-size: 1.35rem;
  color: var(--color-brand);
}

.saved-invoice-detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.saved-invoice-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  background: var(--color-soft-bg);
  border: 1px solid var(--color-border);
  font-size: 0.82rem;
  color: var(--color-text);
}

.saved-invoice-chip-total {
  font-weight: 700;
  color: var(--color-brand);
}

.saved-invoice-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.saved-invoice-preview-shell {
  background: linear-gradient(180deg, var(--color-soft-bg) 0%, var(--color-bg) 100%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 1.25rem 1rem 2rem;
}

.saved-invoice-preview-wrapper {
  padding-bottom: 0;
}

/* ===== الفاتورة ===== */
.invoice-paper {
  --invoice-accent: var(--color-brand);
  --invoice-accent-dark: var(--color-primary);
  --invoice-accent-soft: var(--color-soft-bg);
  --invoice-text: var(--color-text);
  --invoice-muted: var(--color-text-muted);
  --invoice-border: var(--color-border);
  --invoice-logo-color: var(--color-brand);
}

.invoice-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-bottom: 1.25rem;
}

.invoice-wrapper {
  display: flex;
  justify-content: center;
  padding-bottom: 2rem;
}

.invoice-paper {
  width: 100%;
  max-width: 178mm;
  background: #fff;
  border: 1px solid var(--invoice-border);
  border-radius: 4px;
  padding: 2rem 2.25rem;
  box-shadow: 0 4px 18px rgba(20, 69, 82, 0.1);
  color: var(--invoice-text);
}

.invoice-header {
  width: 100%;
  margin: 0 0 1.5rem;
}

.invoice-top-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 0.35rem;
  padding-top: 0.15rem;
}

.invoice-hero-panel {
  width: 100%;
  background: #fff;
  border-radius: 0;
  padding: 0 0 1rem;
  box-shadow: none;
  border-bottom: 2px solid var(--invoice-accent);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.65rem;
  text-align: center;
  color: var(--invoice-text);
}

.invoice-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
}

.invoice-logo-mark {
  display: block;
  width: min(420px, 95%);
  height: 165px;
  max-height: 175px;
  margin: 0 auto;
  background-color: var(--color-brand);
  -webkit-mask-image: url('../assets/caliper_logo.png');
  mask-image: url('../assets/caliper_logo.png');
  border: none;
  border-radius: 0;
  box-shadow: none;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
}

.invoice-logo-image,
.invoice-logo-print {
  display: none;
}

.invoice-doc-title {
  margin: 0;
  font-family: 'Cairo', var(--font);
  font-size: 1.35rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.06em;
  color: var(--invoice-accent);
}

.invoice-meta-inside {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding-top: 0;
  border-top: none;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  align-items: start;
}

.invoice-hero-panel .invoice-meta-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  margin-bottom: 0;
  font-size: 0.88rem;
  width: 100%;
}

.invoice-hero-panel .invoice-meta-row:last-child {
  margin-bottom: 0;
}

.invoice-hero-panel .invoice-meta-row label {
  color: var(--invoice-accent-dark);
  font-weight: 600;
  white-space: nowrap;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.invoice-hero-panel .invoice-field {
  color: var(--invoice-text);
  text-align: center;
  font-weight: 600;
}

.invoice-hero-panel .invoice-field:hover,
.invoice-hero-panel .invoice-field:focus {
  border-color: var(--invoice-accent);
  background: var(--invoice-accent-soft);
}

.invoice-hero-panel .invoice-number-display {
  color: #111;
  font-weight: 700;
}

.invoice-hero-panel input[type="date"] {
  color-scheme: light;
}

.invoice-meta-input {
  width: auto;
  min-width: 130px;
  max-width: 180px;
  text-align: center;
}

.invoice-field {
  display: block;
  width: 100%;
  border: 1px dashed transparent;
  background: transparent;
  font-family: var(--font);
  font-size: 0.9rem;
  color: var(--color-text);
  padding: 0.3rem 0.4rem;
  border-radius: var(--radius-sm);
  transition: border-color 0.15s, background 0.15s;
}

.invoice-field:hover,
.invoice-field:focus {
  border-color: var(--invoice-accent);
  background: var(--invoice-accent-soft);
  outline: none;
}

.invoice-number-display {
  cursor: default;
}

.invoice-footer-contact {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 0;
  margin-top: 0.5rem;
  padding-top: 0;
  border-top: none;
  color: var(--invoice-muted);
  text-align: center;
}

.invoice-footer-field {
  text-align: center;
  font-size: 0.82rem;
  color: var(--invoice-muted);
  max-width: none;
}

.invoice-footer-phone {
  display: block;
  width: 100%;
  margin: 0;
  text-align: center;
  white-space: nowrap;
  line-height: 1.3;
}

.invoice-phone-label {
  font-size: 0.82rem;
  color: var(--invoice-muted);
  white-space: nowrap;
  display: inline;
}

.invoice-phone-label::after {
  content: '\00a0';
}

.invoice-phone-number {
  display: inline;
  width: auto;
  min-width: 0;
  max-width: none;
  direction: ltr;
  unicode-bidi: plaintext;
  text-align: inherit;
}

.invoice-footer-phone .invoice-field,
.invoice-footer-phone input {
  display: inline !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: 0 !important;
  border: none !important;
  background: transparent !important;
  field-sizing: content;
  text-align: inherit !important;
}

.invoice-parties {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.invoice-party-card {
  min-width: 0;
  max-width: 100%;
  background: #fff;
  border: 1px solid var(--invoice-border);
  border-radius: 4px;
  padding: 1rem 1.1rem;
  overflow: hidden;
}

.invoice-party-card:first-child {
  width: 100%;
}

.invoice-party-card h4 {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--invoice-accent-dark);
  margin-bottom: 0.65rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid var(--invoice-border);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.invoice-select.client-select {
  font-size: 0.85rem;
  background-color: #fff;
}

.invoice-labeled-field {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.4rem;
  min-width: 0;
}

.invoice-field-label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--invoice-accent-dark);
  white-space: nowrap;
  flex-shrink: 0;
}

.invoice-labeled-field .invoice-field,
.invoice-labeled-field .invoice-view-value {
  flex: 1;
  min-width: 0;
  width: 0;
  text-align: right;
  margin-bottom: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.invoice-party-card .client-select-field,
.invoice-party-card .invoice-select {
  min-width: 0;
  max-width: 100%;
}

.invoice-field-phone {
  direction: ltr;
  text-align: right;
}

.invoice-title-block {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.5rem;
  min-width: 0;
}

.invoice-title-block .invoice-field {
  flex: 1;
  min-width: 0;
  width: 0;
  margin-bottom: 0;
}

.invoice-desc-block {
  margin-top: 0.5rem;
}

.invoice-desc-label {
  display: block;
  margin-bottom: 0.45rem;
}

.invoice-desc-content {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
}

.invoice-project-desc-field {
  flex: 1;
  min-height: 4rem;
  resize: vertical;
  text-align: right;
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  overflow-wrap: anywhere;
  cursor: default;
}

.invoice-desc-content .btn-icon-edit {
  flex-shrink: 0;
  margin-top: 0.2rem;
}

.invoice-desc-content .btn-icon-edit:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.invoice-items-panel {
  margin-bottom: 1.5rem;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 0;
}

.invoice-items-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.invoice-items-header h4 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--invoice-accent-dark);
}

.invoice-items-panel .invoice-table-wrap {
  margin-bottom: 0;
}

.invoice-table-wrap {
  margin-bottom: 1.5rem;
  overflow-x: auto;
}

.invoice-items-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
  border: 1px solid var(--invoice-border);
}

.invoice-items-table thead th {
  background: var(--invoice-accent);
  color: #fff;
  padding: 0.65rem 0.75rem;
  text-align: right;
  font-weight: 700;
  border-bottom: none;
}

.invoice-items-table thead th:first-child {
  width: 40px;
  text-align: center;
}

.invoice-items-table tbody td {
  padding: 0.45rem 0.5rem;
  border-bottom: 1px solid var(--invoice-border);
  vertical-align: middle;
}

.invoice-items-table tbody tr:last-child td {
  border-bottom: none;
}

.invoice-line-input {
  width: 100%;
  border: 1px dashed transparent;
  background: transparent;
  font-family: var(--font);
  font-size: 0.88rem;
  padding: 0.35rem 0.4rem;
  border-radius: var(--radius-sm);
}

.invoice-line-input:hover,
.invoice-line-input:focus {
  border-color: var(--invoice-accent);
  background: var(--invoice-accent-soft);
  outline: none;
}

.invoice-line-total {
  font-weight: 700;
  color: var(--invoice-text);
  white-space: nowrap;
}

.invoice-footer-area {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-top: 0.5rem;
}

.invoice-notes-panel {
  padding: 0;
  background: transparent;
  border: none;
  border-radius: 0;
}

.invoice-notes-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.65rem;
}

.invoice-notes-header h4 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--invoice-accent-dark);
}

.invoice-notes {
  width: 100%;
  border: 1px solid var(--invoice-border);
  border-radius: 4px;
  padding: 0.65rem 0.75rem;
  font-family: var(--font);
  font-size: 0.85rem;
  resize: vertical;
  min-height: 90px;
  background: var(--invoice-accent-soft);
  color: var(--invoice-text);
}

.invoice-notes:focus {
  border-color: var(--invoice-accent);
  outline: none;
  background: #fff;
}

.invoice-total-banner {
  background: #fff;
  border-radius: 0;
  padding: 0.85rem 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  text-align: right;
  color: var(--invoice-text);
  border-top: 2px solid var(--invoice-accent);
  border-bottom: 2px solid var(--invoice-accent);
  box-shadow: none;
}

.invoice-total-label {
  font-size: 0.95rem;
  font-weight: 700;
  opacity: 1;
  letter-spacing: 0.02em;
  color: var(--invoice-accent-dark);
}

.invoice-total-amount {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.03em;
  color: var(--invoice-accent-dark);
}

.invoice-thanks {
  text-align: center;
  margin-top: 1.75rem;
  color: var(--invoice-muted);
  font-size: 0.9rem;
  font-style: italic;
}

.invoice-paper-readonly .invoice-view-value {
  display: block;
  font-size: 0.9rem;
  color: #111;
  line-height: 1.5;
  white-space: pre-wrap;
}

.invoice-paper-readonly .invoice-view-desc {
  margin-top: 0.25rem;
}

.invoice-paper-readonly .invoice-view-notes {
  margin: 0;
  white-space: pre-wrap;
}

.invoice-paper-readonly .invoice-hero-panel .invoice-meta-label {
  color: var(--invoice-accent-dark);
  font-weight: 600;
  white-space: nowrap;
}

.invoice-paper-readonly .invoice-hero-panel .invoice-view-value {
  color: #111;
  font-weight: 700;
  text-align: center;
}

.invoice-paper-readonly .invoice-meta-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  margin-bottom: 0;
  font-size: 0.88rem;
  width: 100%;
}

.invoice-paper-readonly .invoice-meta-row:last-child {
  margin-bottom: 0;
}

.invoice-footer-contact .invoice-field {
  display: inline-block;
  width: auto;
  max-width: none;
}

.invoice-paper-readonly .invoice-footer-contact {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 0;
  color: #666;
  border-top: none;
  padding-top: 0;
}

/* معاينة الطباعة — إخفاء الواجهة وتوسيط الورقة فقط */
body.invoice-export-mode {
  background: #eceff1 !important;
}

body.invoice-export-mode .sidebar,
body.invoice-export-mode .invoice-toolbar,
body.invoice-export-mode .page-header,
body.invoice-export-mode .section-toolbar {
  display: none !important;
}

body.invoice-export-mode .main-content {
  margin: 0 !important;
  max-width: 100% !important;
  padding: 2rem 1.5rem !important;
  background: #eceff1 !important;
}

body.invoice-export-mode .invoice-wrapper {
  display: flex;
  justify-content: center;
  padding: 0;
}

body.invoice-export-mode #invoice-paper,
body.invoice-export-mode #saved-invoice-view-paper {
  margin: 0 auto;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

@media print {
  @page {
    size: A4 portrait;
    margin: 10mm;
  }

  html, body {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    background: #fff !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
  }

  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) #app,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .app {
    min-height: 0 !important;
    height: auto !important;
  }

  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .sidebar,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .login-page,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .invoice-toolbar,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .page-header,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .section-toolbar,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .saved-invoices-page-header,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .saved-invoices-summary,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .saved-invoices-toolbar,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .saved-invoices-breadcrumb,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .saved-invoice-detail-header,
  body.invoice-export-mode:not(.print-month-expenses):not(.print-project-detail) .main-content > .content-section {
    display: none !important;
  }

  body.invoice-export-mode:not(.print-saved-invoice):not(.print-month-expenses):not(.print-project-detail) #section-invoice {
    display: block !important;
  }

  body.invoice-export-mode.print-saved-invoice #section-invoices-created {
    display: block !important;
  }

  body.invoice-export-mode.print-saved-invoice #section-invoice,
  body.invoice-export-mode:not(.print-saved-invoice) #section-invoices-created {
    display: none !important;
  }

  body.invoice-export-mode.print-saved-invoice #invoices-created-list-view {
    display: none !important;
  }

  .invoice-wrapper,
  .invoice-wrapper *,
  .saved-invoice-preview-shell,
  .saved-invoice-preview-shell *,
  #invoice-paper,
  #invoice-paper *,
  #saved-invoice-view-paper,
  #saved-invoice-view-paper * {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
  }

  .saved-invoice-preview-shell {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .saved-invoice-preview-wrapper {
    padding: 0 !important;
    margin: 0 !important;
  }

  .main-content {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    background: #fff !important;
  }

  body.invoice-export-mode #section-invoice,
  body.invoice-export-mode #section-invoices-created {
    min-height: 0 !important;
    height: auto !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .invoice-wrapper {
    display: block !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    page-break-after: avoid !important;
    break-after: avoid-page !important;
    background: #fff !important;
  }

  #invoice-paper,
  #saved-invoice-view-paper {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 6mm 8mm !important;
    border: 0.4pt solid var(--color-border) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: #fff !important;
    font-size: 10pt;
    line-height: 1.4;
    color: var(--color-text) !important;
    --invoice-accent: var(--color-brand);
    --invoice-accent-dark: var(--color-primary);
    --invoice-accent-soft: var(--color-soft-bg);
    --invoice-text: var(--color-text);
    --invoice-muted: var(--color-text-muted);
    --invoice-border: var(--color-border);
    --invoice-logo-color: var(--color-brand);
    page-break-inside: avoid !important;
    break-inside: avoid !important;
    page-break-after: avoid !important;
    break-after: avoid-page !important;
    box-sizing: border-box;
  }

  .invoice-header {
    width: 100% !important;
    margin: 0 0 5mm !important;
  }

  .invoice-hero-panel {
    padding: 0 0 4mm !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    gap: 3mm !important;
    background: #fff !important;
    color: #1f1f1f !important;
    border-bottom: 0.8pt solid #144552 !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  .invoice-doc-title {
    color: #144552 !important;
    -webkit-text-fill-color: #144552 !important;
    font-family: 'Cairo', var(--font) !important;
    font-size: 12pt !important;
    font-weight: 600 !important;
    margin: 0 !important;
  }

  .invoice-top-logo {
    margin-bottom: 2.5mm !important;
    padding-top: 0 !important;
  }

  .invoice-logo-mark {
    display: none !important;
  }

  .invoice-logo-image,
  .invoice-logo-print {
    display: block !important;
    width: 95mm !important;
    height: auto !important;
    max-height: 42mm !important;
    margin: 0 auto !important;
    object-fit: contain !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
  }

  .invoice-meta-inside {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding-top: 0 !important;
    border-top: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 2mm !important;
  }

  .invoice-hero-panel .invoice-meta-row {
    flex-direction: column !important;
    align-items: center !important;
    margin-bottom: 0 !important;
    font-size: 8.5pt !important;
    gap: 0.5mm !important;
  }

  .invoice-hero-panel .invoice-meta-row label,
  .invoice-hero-panel .invoice-meta-label,
  .invoice-hero-panel .invoice-field,
  .invoice-hero-panel .invoice-number-display,
  .invoice-hero-panel .invoice-view-value,
  .invoice-hero-panel input[type="date"] {
    color: #111 !important;
    -webkit-text-fill-color: #111 !important;
  }

  .invoice-hero-panel .invoice-meta-row label,
  .invoice-hero-panel .invoice-meta-label {
    opacity: 1;
    color: #144552 !important;
    -webkit-text-fill-color: #144552 !important;
    font-weight: 600;
    text-transform: uppercase !important;
    font-size: 7.5pt !important;
    letter-spacing: 0.04em !important;
  }

  .invoice-hero-panel .invoice-number-display,
  .invoice-hero-panel .invoice-view-value {
    font-weight: 700;
  }

  .invoice-hero-panel input[type="date"]::-webkit-datetime-edit,
  .invoice-hero-panel input[type="date"]::-webkit-datetime-edit-fields-wrapper,
  .invoice-hero-panel input[type="date"]::-webkit-datetime-edit-text,
  .invoice-hero-panel input[type="date"]::-webkit-datetime-edit-month-field,
  .invoice-hero-panel input[type="date"]::-webkit-datetime-edit-day-field,
  .invoice-hero-panel input[type="date"]::-webkit-datetime-edit-year-field {
    color: #111 !important;
    -webkit-text-fill-color: #111 !important;
  }

  .invoice-parties {
    grid-template-columns: minmax(0, 1fr) minmax(0, 2fr) !important;
    gap: 4mm !important;
    margin-bottom: 5mm !important;
  }

  .invoice-party-card {
    padding: 3mm 3.5mm !important;
    border: 0.4pt solid var(--color-border) !important;
    background: #fff !important;
    border-radius: 4px !important;
  }

  .invoice-party-card h4,
  .invoice-notes-header h4 {
    margin-bottom: 2.5mm !important;
    padding-bottom: 1.5mm !important;
    font-size: 8.5pt !important;
    color: #144552 !important;
    -webkit-text-fill-color: #144552 !important;
    border-bottom: 0.3pt solid #144552 !important;
    letter-spacing: 0.04em;
  }

  .invoice-field-label {
    font-size: 8.5pt !important;
    color: #144552 !important;
    -webkit-text-fill-color: #144552 !important;
    font-weight: 600;
  }

  .invoice-labeled-field,
  .invoice-desc-block {
    margin-bottom: 2mm !important;
  }

  .invoice-project-desc-field {
    min-height: auto !important;
    font-size: 8.5pt !important;
    border: none !important;
    background: transparent !important;
  }

  .invoice-items-panel.has-items {
    display: block !important;
    visibility: visible !important;
    background: transparent;
    border: none;
    padding: 0;
    margin-bottom: 4mm !important;
  }

  .invoice-items-panel:not(.has-items),
  .invoice-items-panel[hidden]:not(.has-items) {
    display: none !important;
    visibility: hidden !important;
  }

  .invoice-notes-panel.has-notes {
    display: block !important;
    visibility: visible !important;
    background: transparent;
    border: none;
    padding: 0;
    margin-bottom: 4mm !important;
  }

  .invoice-notes-panel:not(.has-notes),
  .invoice-notes-panel[hidden]:not(.has-notes) {
    display: none !important;
    visibility: hidden !important;
  }

  .invoice-footer-area {
    gap: 4mm !important;
    margin-top: 2mm !important;
  }

  .invoice-thanks {
    margin-top: 4mm !important;
    font-size: 8.5pt !important;
    color: var(--color-text-muted) !important;
    font-style: italic;
    text-align: center !important;
  }

  .invoice-footer-contact {
    margin-top: 2mm !important;
    padding-top: 0 !important;
    font-size: 8pt !important;
    border-top: none !important;
    color: var(--color-text-muted) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    gap: 0 !important;
    text-align: center !important;
  }

  .invoice-footer-phone {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding: 0 !important;
    text-align: center !important;
    white-space: nowrap !important;
    line-height: 1.2 !important;
  }

  .invoice-phone-label,
  .invoice-phone-number,
  .invoice-footer-phone .invoice-field,
  .invoice-footer-phone input {
    color: var(--color-text-muted) !important;
    font-size: 8pt !important;
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    flex: none !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    display: inline !important;
    vertical-align: baseline !important;
    text-align: inherit !important;
    field-sizing: content !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  .invoice-phone-label::after {
    content: '\00a0' !important;
  }

  .invoice-phone-number,
  .invoice-footer-phone input {
    direction: ltr !important;
    unicode-bidi: plaintext !important;
  }

  .invoice-footer-field {
    border: none !important;
    background: transparent !important;
    color: var(--color-text-muted) !important;
    text-align: center !important;
    padding: 0 !important;
    max-width: none !important;
  }

  .invoice-items-table {
    font-size: 8.5pt !important;
    border: 0.4pt solid var(--color-border) !important;
    border-radius: 0 !important;
    overflow: hidden;
  }

  .invoice-items-table thead th {
    padding: 2mm 2.5mm !important;
    background: transparent !important;
    background-color: transparent !important;
    color: #144552 !important;
    -webkit-text-fill-color: #144552 !important;
    border: 0.5pt solid #144552 !important;
    border-bottom-width: 1pt !important;
    font-weight: 700;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  .invoice-total-banner {
    padding: 3mm 0 !important;
    border-radius: 0 !important;
    background: #fff !important;
    color: #1f1f1f !important;
    border-top: 0.8pt solid #144552 !important;
    border-bottom: 0.8pt solid #144552 !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    text-align: right !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  .invoice-total-label {
    font-size: 9.5pt !important;
    color: #144552 !important;
    -webkit-text-fill-color: #144552 !important;
    opacity: 1;
    font-weight: 700;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  .invoice-total-amount {
    font-size: 16pt !important;
    color: #144552 !important;
    -webkit-text-fill-color: #144552 !important;
    font-weight: 700;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  .invoice-items-table tbody td {
    padding: 1.8mm 2.5mm !important;
    border-bottom: 0.3pt solid var(--color-border) !important;
  }

  .invoice-items-table tbody tr:last-child td {
    border-bottom: none !important;
  }

  .invoice-line-total {
    font-weight: 700;
    color: #111 !important;
  }

  .no-print {
    display: none !important;
  }

  .invoice-field,
  .invoice-line-input,
  .invoice-notes {
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
    color: inherit !important;
  }

  .invoice-hero-panel .invoice-field,
  .invoice-hero-panel .invoice-number-display,
  .invoice-hero-panel .invoice-view-value {
    color: #111 !important;
    -webkit-text-fill-color: #111 !important;
  }

  .invoice-notes {
    border: 0.4pt solid var(--color-border) !important;
    padding: 2.5mm !important;
    border-radius: 0 !important;
    background: #fff !important;
    color: #111 !important;
  }

  .invoice-view-value {
    color: #111 !important;
  }
}

/* ===== طباعة مصروفات الشهر ===== */
.expenses-print-sheet {
  display: none;
}

@media print {
  body.print-month-expenses * {
    visibility: hidden;
  }

  body.print-month-expenses #expenses-print-sheet,
  body.print-month-expenses #expenses-print-sheet * {
    visibility: visible;
  }

  body.print-month-expenses #expenses-print-sheet {
    display: block !important;
    position: absolute;
    inset: 0;
    width: 100%;
    padding: 0;
    background: #fff !important;
  }

  .expenses-print-inner {
    width: 100%;
    color: #1a2e35;
    font-size: 10.5pt;
    line-height: 1.5;
  }

  .expenses-print-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12mm;
    margin-bottom: 8mm;
    padding-bottom: 4mm;
    border-bottom: 0.6pt solid #a8d4db;
  }

  .expenses-print-header h1 {
    margin: 0 0 2mm;
    font-size: 18pt;
    color: #144552;
  }

  .expenses-print-subtitle {
    margin: 0;
    font-size: 12pt;
    color: #4a6570;
  }

  .expenses-print-meta {
    display: flex;
    flex-direction: column;
    gap: 1.5mm;
    text-align: left;
    font-size: 9pt;
    color: #5a6b7d;
  }

  .expenses-print-table {
    width: 100%;
    border-collapse: collapse;
  }

  .expenses-print-table th,
  .expenses-print-table td {
    border: 0.5pt solid #d8eef2;
    padding: 2.5mm 3mm;
    text-align: right;
    vertical-align: top;
  }

  .expenses-print-table th {
    background: #e8f4f7 !important;
    color: #144552 !important;
    font-weight: 700;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .expenses-print-table tfoot td {
    background: #f4fafb !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .expenses-print-month-section {
    margin-bottom: 8mm;
    page-break-inside: avoid;
  }

  .expenses-print-month-title {
    margin: 0 0 3mm;
    font-size: 13pt;
    color: #144552;
    padding-bottom: 2mm;
    border-bottom: 0.4pt solid #d8eef2;
  }

  .expenses-print-grand-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 6mm;
    padding: 4mm 5mm;
    border: 0.6pt solid #a8d4db;
    border-radius: 2mm;
    background: #e8f4f7 !important;
    font-size: 12pt;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  body.print-project-detail * {
    visibility: hidden;
  }

  body.print-project-detail #project-print-sheet,
  body.print-project-detail #project-print-sheet * {
    visibility: visible;
  }

  body.print-project-detail #project-print-sheet {
    display: block !important;
    position: absolute;
    inset: 0;
    width: 100%;
    padding: 0;
    background: #fff !important;
  }

  body.print-clients-list * {
    visibility: hidden;
  }

  body.print-clients-list #clients-print-sheet,
  body.print-clients-list #clients-print-sheet * {
    visibility: visible;
  }

  body.print-clients-list #clients-print-sheet {
    display: block !important;
    position: absolute;
    inset: 0;
    width: 100%;
    padding: 0;
    background: #fff !important;
  }

  .project-print-meta-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3mm 5mm;
    margin-bottom: 6mm;
    padding: 4mm 5mm;
    border: 0.5pt solid #d8eef2;
    border-radius: 2mm;
    background: #f8fcfd !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .project-print-meta-item .meta-label {
    display: block;
    font-size: 8.5pt;
    color: #5a6b7d;
    margin-bottom: 1mm;
  }

  .project-print-summary {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 3mm;
    margin-bottom: 6mm;
  }

  .project-print-summary-item {
    padding: 3mm 4mm;
    border: 0.5pt solid #d8eef2;
    border-radius: 2mm;
    background: #f4fafb !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .project-print-summary-item .meta-label {
    display: block;
    font-size: 8.5pt;
    color: #5a6b7d;
    margin-bottom: 1.5mm;
  }

  .project-print-section {
    margin-bottom: 7mm;
    page-break-inside: avoid;
  }

  .project-print-section-title {
    margin: 0 0 3mm;
    font-size: 13pt;
    color: #144552;
    padding-bottom: 2mm;
    border-bottom: 0.4pt solid #d8eef2;
  }

  .project-print-empty {
    margin: 0;
    padding: 3mm 4mm;
    color: #5a6b7d;
    font-size: 10pt;
    border: 0.5pt dashed #d8eef2;
    border-radius: 2mm;
  }
}

/* ===== استجابة الشاشات ===== */
@media (max-width: 1024px) {
  html {
    font-size: 15px;
  }
}

@media (max-width: 768px) {
  .sidebar {
    width: 100%;
    height: auto;
    position: relative;
    right: auto;
    left: auto;
  }

  .main-content {
    width: 100%;
    max-width: 100%;
    margin-right: 0;
    margin-left: 0;
    padding: 1.25rem;
  }

  #app.authenticated {
    display: block !important;
  }

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

  .project-lists {
    grid-template-columns: 1fr;
  }

  .invoice-parties {
    grid-template-columns: 1fr;
  }

  .invoice-total-amount {
    font-size: 1.6rem;
  }

  .invoice-header {
    width: 100%;
    margin: 0 0 1.25rem;
  }

  /* ثبات الأيقونات على الهاتف والآيباد — نفس الأحجام بالبكسل */
  :root {
    --icon-size-xs: 12px;
    --icon-size-sm: 14px;
    --icon-size-md: 16px;
    --icon-size-nav: 20px;
    --icon-btn-size: 28px;
    --icon-btn-size-lg: 30px;
  }
}

.split-allocation-panel {
  margin-top: 0.5rem;
  padding: 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-soft-bg);
}

.split-allocation-panel h4 {
  margin: 0 0 0.75rem;
  font-size: 0.92rem;
  color: var(--color-brand);
}

.split-allocation-rows {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.split-allocation-row {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 0.8fr) auto;
  gap: 0.75rem;
  align-items: end;
}

.split-allocation-row .form-group {
  margin-bottom: 0;
}

.split-allocation-summary {
  margin-top: 0.75rem;
  font-size: 0.88rem;
  color: var(--color-text-muted);
}

.split-allocation-summary.is-valid {
  color: var(--color-success, #1b7f5c);
}

.split-allocation-summary.is-invalid {
  color: var(--color-danger, #b42318);
}

.txn-split-summary {
  margin-top: 0.25rem;
  font-size: 0.78rem;
  color: var(--color-text-muted);
}

.split-revenue-badge {
  display: inline-block;
  margin-right: 0.35rem;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  background: rgba(20, 69, 82, 0.1);
  color: var(--color-brand);
  font-size: 0.72rem;
  font-weight: 600;
}

@media (max-width: 720px) {
  .split-allocation-row {
    grid-template-columns: 1fr;
  }
}
