/*
  App UI Kit (Conical / "مخروطي")
  - Opt-in classes for a unified look across the system
  - Uses brand variables defined in Views/Shared/_Layout.cshtml
*/

:root {
  --app-ui-primary: var(--menu-card-primary, var(--home-card-primary, #000839));
  --app-ui-accent: var(--menu-card-accent, var(--home-card-accent, #C5A36A));
  --app-ui-primary-hover: color-mix(in srgb, var(--app-ui-primary) 92%, #000);
  --app-ui-accent-hover: color-mix(in srgb, var(--app-ui-accent) 88%, #fff);
  --app-ui-skew: -12deg;
  --app-ui-skew-inv: 12deg;
  --app-ui-cut: 14px;
  --app-ui-gap: 4px;
  --app-ui-shadow: 0 18px 48px rgba(2, 6, 23, 0.18);
  --app-ui-shadow-soft: 0 10px 24px rgba(15, 23, 42, 0.08);
  --app-ui-control-border: color-mix(in srgb, var(--app-ui-accent) 72%, var(--border-color));
  --app-ui-control-border-hover: color-mix(in srgb, var(--app-ui-accent) 90%, var(--border-color));

  /* Conical clip-path (mirrored automatically for RTL) */
  --app-ui-clip-ltr: polygon(var(--app-ui-cut) 0%, 100% 0%, calc(100% - var(--app-ui-cut)) 100%, 0% 100%);
  --app-ui-clip-rtl: polygon(0% 0%, calc(100% - var(--app-ui-cut)) 0%, 100% 100%, var(--app-ui-cut) 100%);
  --app-ui-clip: var(--app-ui-clip-ltr);
  --app-ui-control-clip: var(--app-ui-clip-ltr);

  /* Data grid clip-path (uses --app-dg-cut from the table scope) */
  --app-dg-clip-ltr: polygon(var(--app-dg-cut) 0%, 100% 0%, calc(100% - var(--app-dg-cut)) 100%, 0% 100%);
  --app-dg-clip-rtl: polygon(0% 0%, calc(100% - var(--app-dg-cut)) 0%, 100% 100%, var(--app-dg-cut) 100%);
  --app-dg-clip: var(--app-dg-clip-ltr);
}

:root:dir(rtl) {
  --app-ui-skew: 12deg;
  --app-ui-skew-inv: -12deg;
  --app-ui-clip: var(--app-ui-clip-rtl);
  --app-dg-clip: var(--app-dg-clip-rtl);
}

/* Hide empty ASP.NET validation summary blocks */
.validation-summary-valid {
  display: none !important;
}

/* ---------- Buttons ---------- */

.app-btn {
  --app-btn-bg: var(--app-ui-primary);
  --app-btn-bg-hover: var(--app-ui-primary-hover);
  --app-btn-fg: var(--app-ui-accent);
  --app-btn-border: color-mix(in srgb, var(--app-ui-accent) 45%, rgba(255, 255, 255, 0.12));

  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  min-height: 44px;
  padding: 0.75rem 1.25rem;

  border: none;
  background: transparent;
  color: var(--app-btn-fg);
  text-decoration: none;

  font-weight: 900;
  letter-spacing: 0.06em;
  user-select: none;
  cursor: pointer;
  white-space: nowrap;
  isolation: isolate;
}

.app-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--app-btn-bg);
  border: 1px solid var(--app-btn-border);
  box-shadow: var(--app-ui-shadow-soft);
  clip-path: var(--app-ui-clip);
  transition: background 220ms ease, border-color 220ms ease, transform 220ms ease, filter 220ms ease;
  z-index: -1;
}

.app-btn:hover::before {
  background: var(--app-btn-bg-hover);
  transform: translateY(-1px);
  filter: brightness(1.02);
}

.app-btn:active::before {
  transform: translateY(0);
  filter: brightness(0.98);
}

.app-btn:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--app-ui-accent) 55%, transparent);
  outline-offset: 5px;
}

.app-btn--block {
  width: 100%;
}

.app-btn--sm {
  min-height: 36px;
  padding: 0.5rem 0.95rem;
  font-size: 0.9rem;
}

.app-btn--lg {
  min-height: 52px;
  padding: 0.95rem 1.55rem;
  font-size: 1rem;
}

.app-btn--accent {
  --app-btn-bg: var(--app-ui-accent);
  --app-btn-bg-hover: var(--app-ui-accent-hover);
  --app-btn-fg: var(--app-ui-primary);
  --app-btn-border: color-mix(in srgb, var(--app-ui-primary) 22%, rgba(255, 255, 255, 0.12));
}

.app-btn--outline {
  --app-btn-bg: color-mix(in srgb, var(--surface-color) 92%, var(--bg-color));
  --app-btn-bg-hover: color-mix(in srgb, var(--surface-color) 84%, var(--bg-color));
  --app-btn-fg: var(--app-ui-primary);
  --app-btn-border: color-mix(in srgb, var(--app-ui-accent) 42%, var(--border-color));
}

.app-btn--danger {
  --app-btn-bg: #ef4444;
  --app-btn-bg-hover: color-mix(in srgb, #ef4444 82%, #000);
  --app-btn-fg: #fff;
  --app-btn-border: color-mix(in srgb, #ef4444 62%, rgba(255, 255, 255, 0.12));
}

.app-btn[disabled],
.app-btn:disabled,
.app-btn[aria-disabled="true"] {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
}

/* ---------- Icon action buttons (for tables) ---------- */

.app-icon-btn {
  --app-ib-bg: color-mix(in srgb, var(--surface-color) 92%, var(--bg-color));
  --app-ib-border: color-mix(in srgb, var(--border-color) 90%, transparent);
  --app-ib-fg: color-mix(in srgb, var(--text-color) 40%, transparent);
  --app-ib-bg-hover: var(--app-ui-primary);
  --app-ib-fg-hover: var(--app-ui-accent);
  --app-ib-border-hover: color-mix(in srgb, var(--app-ui-accent) 45%, rgba(255, 255, 255, 0.12));

  position: relative;
  width: 34px;
  height: 34px;
  display: inline-grid;
  place-items: center;
  border: none;
  background: transparent;
  color: var(--app-ib-fg);
  text-decoration: none;
  cursor: pointer;
  user-select: none;
  isolation: isolate;
}

.app-icon-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--app-ib-bg);
  border: 1px solid var(--app-ib-border);
  clip-path: var(--app-ui-clip);
  transition: background 200ms ease, border-color 200ms ease, transform 200ms ease, filter 200ms ease;
  z-index: -1;
}

.app-icon-btn:hover::before {
  background: var(--app-ib-bg-hover);
  border-color: var(--app-ib-border-hover);
  transform: translateY(-1px);
  filter: brightness(1.02);
}

.app-icon-btn:hover {
  color: var(--app-ib-fg-hover);
}

.app-icon-btn:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--app-ui-accent) 55%, transparent);
  outline-offset: 5px;
}

.app-icon-btn--accent {
  --app-ib-bg-hover: var(--app-ui-accent);
  --app-ib-fg-hover: var(--app-ui-primary);
  --app-ib-border-hover: color-mix(in srgb, var(--app-ui-accent) 72%, rgba(255, 255, 255, 0.12));
}

.app-icon-btn--danger {
  --app-ib-bg-hover: #ef4444;
  --app-ib-fg-hover: #fff;
  --app-ib-border-hover: color-mix(in srgb, #ef4444 72%, rgba(255, 255, 255, 0.12));
}

/* ---------- Form controls ---------- */

.app-input,
.app-select {
  min-height: 40px;
  padding: 0.55rem 0.85rem;
  --app-ui-control-outline: var(--app-ui-control-border);
  border: 1px solid var(--app-ui-control-outline);
  background: var(--app-control-background, var(--surface-color));
  color: var(--text-color);
  font-weight: 800;
  border-radius: 0;
  box-shadow: var(--app-control-inset-shadow, 2px -20px 20px 13px color-mix(in srgb, var(--surface-color) 72%, #e9dfdf) inset);
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

/* subtle hover (non-focus) */
.app-input:hover,
.app-select:hover {
  --app-ui-control-outline: var(--app-ui-control-border-hover);
}

@supports ((clip-path: polygon(0 0)) and (filter: drop-shadow(0 0 0 #000))) {
  .app-input,
  .app-select {
    clip-path: var(--app-ui-control-clip);
    border-color: transparent !important;
    filter:
      drop-shadow(1px 0 0 var(--app-ui-control-outline))
      drop-shadow(-1px 0 0 var(--app-ui-control-outline))
      drop-shadow(0 1px 0 var(--app-ui-control-outline))
      drop-shadow(0 -1px 0 var(--app-ui-control-outline));
  }
}

.app-input::placeholder {
  color: color-mix(in srgb, var(--secondary-text) 70%, transparent);
}

.app-input:focus,
.app-select:focus {
  --app-ui-control-outline: color-mix(in srgb, var(--app-ui-accent) 70%, var(--app-ui-control-border));
  box-shadow:
    var(--app-control-inset-shadow, 2px -20px 20px 13px color-mix(in srgb, var(--surface-color) 72%, #e9dfdf) inset),
    0 0 0 0.2rem color-mix(in srgb, var(--app-ui-accent) 18%, transparent);
}

.app-input[readonly],
.app-input:disabled,
.app-select:disabled {
  background: color-mix(in srgb, var(--app-control-background, var(--surface-color)) 88%, var(--bg-color));
  color: color-mix(in srgb, var(--text-color) 85%, transparent);
  --app-ui-control-outline: var(--border-color);
}

/* Bootstrap bridge: make all textboxes/selects follow the same conical shape by default */
.app-ui :is(.form-control, .form-select):not(.form-control-color):not([type="file"]) {
  min-height: 40px;
  padding: 0.55rem 0.85rem;
  --app-ui-control-outline: var(--app-ui-control-border);
  border: 1px solid var(--app-ui-control-outline);
  background: var(--app-control-background, var(--surface-color));
  color: var(--text-color);
  font-weight: 800;
  border-radius: 0;
  box-shadow: var(--app-control-inset-shadow, 2px -20px 20px 13px color-mix(in srgb, var(--surface-color) 72%, #e9dfdf) inset);
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.app-ui :is(.form-control, .form-select):not(.form-control-color):not([type="file"]):not(:focus):hover {
  --app-ui-control-outline: var(--app-ui-control-border-hover);
}

.app-ui :is(.form-control, .form-select):is(.form-control-sm, .form-select-sm) {
  min-height: 36px;
  padding: 0.5rem 0.75rem;
  font-size: 0.9rem;
}

.app-ui :is(.form-control, .form-select):is(.form-control-lg, .form-select-lg) {
  min-height: 52px;
  padding: 0.95rem 1.05rem;
  font-size: 1rem;
}

@supports ((clip-path: polygon(0 0)) and (filter: drop-shadow(0 0 0 #000))) {
  .app-ui :is(.form-control, .form-select):not(.form-control-color):not([type="file"]) {
    clip-path: var(--app-ui-control-clip);
    border-color: transparent !important;
    filter:
      drop-shadow(1px 0 0 var(--app-ui-control-outline))
      drop-shadow(-1px 0 0 var(--app-ui-control-outline))
      drop-shadow(0 1px 0 var(--app-ui-control-outline))
      drop-shadow(0 -1px 0 var(--app-ui-control-outline));
  }
}

.app-ui :is(.form-control, .form-select):not(.form-control-color):not([type="file"])::placeholder {
  color: color-mix(in srgb, var(--secondary-text) 70%, transparent);
}

.app-ui :is(.form-control, .form-select):not(.form-control-color):not([type="file"]):focus {
  --app-ui-control-outline: color-mix(in srgb, var(--app-ui-accent) 70%, var(--app-ui-control-border));
  box-shadow:
    var(--app-control-inset-shadow, 2px -20px 20px 13px color-mix(in srgb, var(--surface-color) 72%, #e9dfdf) inset),
    0 0 0 0.2rem color-mix(in srgb, var(--app-ui-accent) 18%, transparent);
}

.app-ui :is(.form-control, .form-select):not(.form-control-color):not([type="file"]):disabled,
.app-ui :is(.form-control, .form-select):not(.form-control-color):not([type="file"])[readonly] {
  background: color-mix(in srgb, var(--app-control-background, var(--surface-color)) 88%, var(--bg-color));
  color: color-mix(in srgb, var(--text-color) 85%, transparent);
  --app-ui-control-outline: var(--border-color);
}

/* Select2 bridge (Select2 wraps <select> into its own UI elements) */
.app-ui .select2-container .select2-selection--single,
.app-ui .select2-container .select2-selection--multiple {
  min-height: 40px;
  --app-ui-control-outline: var(--app-ui-control-border);
  border: 1px solid var(--app-ui-control-outline) !important;
  background: var(--app-control-background, var(--surface-color)) !important;
  color: var(--text-color) !important;
  font-weight: 800;
  border-radius: 0 !important;
  box-shadow: var(--app-control-inset-shadow, 2px -20px 20px 13px color-mix(in srgb, var(--surface-color) 72%, #e9dfdf) inset);
  transition: border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

@supports ((clip-path: polygon(0 0)) and (filter: drop-shadow(0 0 0 #000))) {
  .app-ui .select2-container .select2-selection--single,
  .app-ui .select2-container .select2-selection--multiple {
    clip-path: var(--app-ui-control-clip);
    border-color: transparent !important;
    filter:
      drop-shadow(1px 0 0 var(--app-ui-control-outline))
      drop-shadow(-1px 0 0 var(--app-ui-control-outline))
      drop-shadow(0 1px 0 var(--app-ui-control-outline))
      drop-shadow(0 -1px 0 var(--app-ui-control-outline));
  }
}

.app-ui .select2-container--default .select2-selection--single {
  height: 40px;
}

.app-ui .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 38px;
  padding-inline: 0.85rem 2.2rem;
  color: var(--text-color) !important;
}

.app-ui .select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: color-mix(in srgb, var(--secondary-text) 70%, transparent) !important;
}

.app-ui .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 38px;
  top: 1px;
  right: 0.65rem;
}

.app-ui .select2-container--default[dir="rtl"] .select2-selection--single .select2-selection__arrow {
  right: auto;
  left: 0.65rem;
}

.app-ui .select2-container--default.select2-container--focus .select2-selection--single,
.app-ui .select2-container--default.select2-container--focus .select2-selection--multiple,
.app-ui .select2-container--default.select2-container--open .select2-selection--single,
.app-ui .select2-container--default.select2-container--open .select2-selection--multiple {
  border-color: color-mix(in srgb, var(--app-ui-accent) 70%, var(--app-ui-control-border)) !important;
  box-shadow:
    var(--app-control-inset-shadow, 2px -20px 20px 13px color-mix(in srgb, var(--surface-color) 72%, #e9dfdf) inset),
    0 0 0 0.2rem color-mix(in srgb, var(--app-ui-accent) 18%, transparent);
}

/* ---------- Page heading (like provided sample) ---------- */

.app-page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
  padding-inline-start: 1rem;
  border-inline-start: 4px solid var(--app-ui-accent);
}

.app-page-head__title {
  margin: 0;
  font-size: 1.35rem;
  font-weight: 900;
  color: var(--app-ui-primary);
}

.app-page-head__sub {
  margin: 0.25rem 0 0;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  color: color-mix(in srgb, var(--secondary-text) 85%, transparent);
}

/* ---------- Panels / containers ---------- */

.app-panel {
  position: relative;
  background: var(--surface-color);
  border: 1px solid var(--border-color);
  box-shadow: var(--app-ui-shadow-soft);
  padding: 1rem;
}

@supports (clip-path: polygon(0 0)) {
  .app-panel {
    clip-path: var(--app-ui-clip);
  }
}

.app-panel--p0 {
  padding: 0;
}

/* Panel header (navy title bar) */
.app-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1rem;
  background: var(--app-ui-primary);
  color: #fff;
  border-bottom: 1px solid color-mix(in srgb, var(--app-ui-accent) 35%, rgba(255, 255, 255, 0.14));
  border-inline-start: 6px solid var(--app-ui-accent);
}

.app-panel-head__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  color: #fff;
}

.app-panel-head :is(a, button) {
  color: inherit;
}

/* ---------- Chips / badges ---------- */

.app-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 28px;
  padding: 0 0.7rem;
  font-size: 0.78rem;
  font-weight: 900;
  color: var(--app-ui-primary);
  background: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color));
  border: 1px solid color-mix(in srgb, var(--border-color) 90%, transparent);
  user-select: none;
}

@supports (clip-path: polygon(0 0)) {
  .app-chip {
    clip-path: var(--app-ui-clip);
  }
}

.app-chip--accent {
  color: var(--app-ui-accent);
  background: var(--app-ui-primary);
  border-color: color-mix(in srgb, var(--app-ui-accent) 45%, rgba(255, 255, 255, 0.12));
}

.app-chip--muted {
  color: var(--secondary-text);
  background: color-mix(in srgb, var(--surface-color) 88%, var(--bg-color));
}

/* ---------- Text helpers ---------- */

.app-text-primary {
  color: var(--app-ui-primary);
  font-weight: 900;
}

.app-text-accent {
  color: var(--app-ui-accent);
  font-weight: 900;
}

.app-text-muted {
  color: var(--secondary-text);
  font-weight: 800;
}

/* ---------- Journal entry totals (Create/Edit) ---------- */

.je-total-box {
  position: relative;
  padding: 1.15rem 1.25rem;
  background: var(--surface-color);
  border: 2px solid color-mix(in srgb, var(--app-ui-accent) 55%, var(--border-color));
  box-shadow: var(--app-ui-shadow-soft);
  transition: transform 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}

@supports (clip-path: polygon(0 0)) {
  .je-total-box {
    clip-path: var(--app-ui-clip);
  }
}

.je-total-box:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--app-ui-accent) 80%, var(--border-color));
  box-shadow: var(--app-ui-shadow);
}

.je-total-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 900;
  font-size: 0.85rem;
  color: var(--app-ui-primary);
  margin-bottom: 0.35rem;
}

.je-total-number {
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
  font-size: 1.55rem;
  font-weight: 900;
  color: var(--app-ui-primary);
  margin-bottom: 0.25rem;
}

.je-total-currency {
  font-size: 0.75rem;
  font-weight: 900;
  color: var(--secondary-text);
}

.je-total-text {
  font-size: 0.75rem;
  font-weight: 800;
  color: var(--secondary-text);
  line-height: 1.35;
}

.je-save-overlay {
  position: fixed;
  inset: 0;
  background: color-mix(in srgb, var(--bg-color) 55%, transparent);
  backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
}

.je-save-overlay__box {
  background: var(--surface-color);
  color: var(--text-color);
  border: 1px solid color-mix(in srgb, var(--app-ui-accent) 35%, var(--border-color));
  padding: 22px 26px;
  box-shadow: var(--app-ui-shadow);
  text-align: center;
  min-width: 240px;
}

@supports (clip-path: polygon(0 0)) {
  .je-save-overlay__box {
    clip-path: var(--app-ui-clip);
  }
}

/* ---------- Status pill (skewed) ---------- */

.app-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  padding: 0 0.7rem;
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  border: 1px solid color-mix(in srgb, var(--border-color) 80%, transparent);
  background: color-mix(in srgb, var(--surface-color) 88%, var(--bg-color));
  color: color-mix(in srgb, var(--text-color) 70%, transparent);
  user-select: none;
  white-space: nowrap;
}

@supports (clip-path: polygon(0 0)) {
  .app-status {
    clip-path: var(--app-ui-clip);
  }
}

.app-status--success {
  background: color-mix(in srgb, #22c55e 12%, transparent);
  border-color: color-mix(in srgb, #22c55e 28%, var(--border-color));
  color: #16a34a;
}

.app-status--warning {
  background: color-mix(in srgb, #f59e0b 14%, transparent);
  border-color: color-mix(in srgb, #f59e0b 30%, var(--border-color));
  color: #b45309;
}

.app-status--neutral {
  background: color-mix(in srgb, var(--secondary-text) 12%, transparent);
  border-color: color-mix(in srgb, var(--secondary-text) 22%, var(--border-color));
  color: color-mix(in srgb, var(--secondary-text) 92%, transparent);
}

/* ---------- Data grid / table (like provided React sample) ---------- */

:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) {
  --app-dg-header-h: 48px;
  --app-dg-cell-h: 56px;
  --app-dg-px: 14px;
  --app-dg-py: 10px;
  --app-dg-font: 0.9rem;
  --app-dg-gap: 4px;
  --app-dg-cut: 12px;
  --app-dg-pattern: none;
  --app-dg-border: color-mix(in srgb, var(--app-ui-accent) 72%, var(--border-color));
  --app-dg-border-strong: color-mix(in srgb, var(--app-ui-accent) 92%, var(--border-color));

  width: 100%;
  border-collapse: separate;
  border-spacing: var(--app-dg-gap) var(--app-dg-gap);
  border: 0 !important;
}

/* Optional subtle pattern (opt-in) */
.app-datagrid--pattern {
  --app-dg-pattern: radial-gradient(color-mix(in srgb, var(--app-ui-accent) 12%, transparent) 1px, transparent 1px);
}

.app-table-pattern {
  --app-dg-pattern: radial-gradient(color-mix(in srgb, var(--app-ui-accent) 12%, transparent) 1px, transparent 1px);
}

/* Tight/compact spacing between cells */
.app-table-tight {
  --app-dg-gap: 2px;
  --app-dg-header-h: 44px;
  --app-dg-cell-h: 52px;
  --app-dg-px: 12px;
  --app-dg-py: 9px;
}

/* Make table columns roomier (uses table-responsive horizontal scroll when needed) */
.app-table-wide {
  min-width: 1280px;
}

:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) th,
:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) td {
  position: relative;
  overflow: visible;
  vertical-align: middle;
  text-align: center;
  padding: var(--app-dg-py) var(--app-dg-px);
  font-size: var(--app-dg-font);
  isolation: isolate;
  border: 0 !important;
  background: transparent !important;
}

:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) thead th {
  height: var(--app-dg-header-h);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) thead th::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--app-ui-primary);
  background-image: var(--app-dg-pattern);
  background-size: 12px 12px;
  transform: skewX(var(--app-ui-skew));
  border: 1px solid color-mix(in srgb, var(--app-ui-accent) 86%, rgba(255, 255, 255, 0.12));
  box-shadow: var(--app-ui-shadow-soft);
  pointer-events: none;
  z-index: -1;
}

:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) tbody td {
  height: var(--app-dg-cell-h);
  color: var(--text-color);
  font-weight: 800;
}

:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) tbody td::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--surface-color);
  background-image: var(--app-dg-pattern);
  background-size: 10px 10px;
  transform: skewX(var(--app-ui-skew));
  border: 1px solid var(--app-dg-border);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--app-ui-accent) 12%, transparent) inset;
  transition: border-color 220ms ease, filter 220ms ease, box-shadow 220ms ease;
  pointer-events: none;
  z-index: -1;
}

@supports (clip-path: polygon(0 0)) {
  :where(
    .app-datagrid,
    .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
    .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
    .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
  ) thead th::before,
  :where(
    .app-datagrid,
    .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
    .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
    .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
  ) tbody td::before {
    transform: none;
    clip-path: var(--app-dg-clip);
  }
}

:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) tbody tr:hover td::before {
  border-color: var(--app-dg-border-strong);
  box-shadow: 0 14px 28px -22px rgba(2, 6, 23, 0.38);
  filter: brightness(1.01);
}

:where(
  .app-datagrid,
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
) tbody tr.app-dg-row--highlight td::before {
  border-color: var(--app-dg-border-strong);
  box-shadow: 0 14px 28px -22px rgba(2, 6, 23, 0.42);
  filter: brightness(1.02);
}

:where(
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid)
) tbody td:first-child::after {
  content: "";
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  width: 4px;
  background: var(--app-ui-accent);
  transform: skewX(var(--app-ui-skew));
  opacity: 0.4;
  transition: opacity 220ms ease;
  pointer-events: none;
  z-index: -1;
}

:where(
  .app-ui table.table.table-hover:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid),
  .app-ui table.table.table-striped:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid),
  .app-ui table.table.data-table:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid)
) tbody tr:hover td:first-child::after {
  opacity: 1;
}

.app-datagrid--accent-firstcol tbody td:first-child::after {
  content: "";
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  width: 4px;
  background: var(--app-ui-accent);
  transform: skewX(var(--app-ui-skew));
  opacity: 0.4;
  transition: opacity 220ms ease;
  pointer-events: none;
  z-index: -1;
}

.app-datagrid--accent-firstcol tbody tr:hover td:first-child::after {
  opacity: 1;
}

:where(
  .app-datagrid--compact,
  .app-ui table.table.table-sm.table-hover:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-sm.table-striped:not(.app-table-plain):not(.app-datagrid),
  .app-ui table.table.table-sm.data-table:not(.app-table-plain):not(.app-datagrid)
) {
  --app-dg-header-h: 44px;
  --app-dg-cell-h: 52px;
  --app-dg-px: 12px;
  --app-dg-py: 9px;
  --app-dg-font: 0.88rem;
  --app-dg-gap: 4px;
  --app-dg-cut: 10px;
}

/* ---------- Pagination (opt-in) ---------- */

.app-pagination .page-link {
  position: relative;
  border: 1px solid color-mix(in srgb, var(--border-color) 90%, transparent);
  background: color-mix(in srgb, var(--surface-color) 90%, var(--bg-color));
  color: var(--text-color);
  font-weight: 900;
  min-width: 40px;
  text-align: center;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

@supports (clip-path: polygon(0 0)) {
  .app-pagination .page-link {
    clip-path: var(--app-ui-clip);
  }
}

.app-pagination .page-link:hover {
  background: var(--app-ui-primary);
  color: var(--app-ui-accent);
  border-color: color-mix(in srgb, var(--app-ui-accent) 45%, rgba(255, 255, 255, 0.12));
  transform: translateY(-1px);
}

.app-pagination .page-item.active .page-link {
  background: var(--app-ui-primary);
  color: var(--app-ui-accent);
  border-color: color-mix(in srgb, var(--app-ui-accent) 45%, rgba(255, 255, 255, 0.12));
}

.app-pagination .page-item.disabled .page-link {
  opacity: 0.55;
}

/* ---------- Empty state ---------- */

.app-empty {
  padding: 2.25rem 1.25rem;
  text-align: center;
  color: var(--secondary-text);
}

.app-empty__icon {
  width: 64px;
  height: 64px;
  margin: 0 auto 0.75rem;
  display: grid;
  place-items: center;
  color: var(--app-ui-accent);
  background: color-mix(in srgb, var(--app-ui-primary) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--app-ui-accent) 20%, var(--border-color));
}

@supports (clip-path: polygon(0 0)) {
  .app-empty__icon {
    clip-path: var(--app-ui-clip);
  }
}

.app-empty__title {
  margin: 0.25rem 0 0;
  font-size: 1.15rem;
  font-weight: 900;
  color: var(--app-ui-primary);
}

.app-empty__text {
  margin: 0.5rem 0 1.25rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--secondary-text) 92%, transparent);
}

@media (prefers-reduced-motion: reduce) {
  .app-btn::before,
  .app-icon-btn::before,
  :where(
    .app-datagrid,
    .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
    .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
    .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
  ) thead th::before,
  :where(
    .app-datagrid,
    .app-ui table.table.table-hover:not(.app-table-plain):not(.app-datagrid),
    .app-ui table.table.table-striped:not(.app-table-plain):not(.app-datagrid),
    .app-ui table.table.data-table:not(.app-table-plain):not(.app-datagrid)
  ) tbody td::before,
  :where(
    .app-ui table.table.table-hover:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid),
    .app-ui table.table.table-striped:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid),
    .app-ui table.table.data-table:not(.app-table-plain):not(.app-table-no-accent):not(.app-datagrid)
  ) tbody td:first-child::after,
  .app-datagrid--accent-firstcol tbody td:first-child::after {
    transition: none !important;
  }
}
