:root {
  /* Brand and surface palette */
  --primary: #a21caf;
  --primary-hover: #86198f;
  --primary-fg: #ffffff;
  --secondary: #86198f;
  --accent: #c026d3;
  --header-bg: #3b0d4f;
  --header-link-color: #ffffff;
  --surface: #ffffff;
  --surface-muted: #f3f4f6;
  --surface-tint: #f3e8ff;
  --surface-tint-hover: #f5f3ff;
  --breadcrumbs-bg: var(--surface-tint);
  --body-fg: #111827;
  --body-bg: var(--surface-muted);
  --darkened-bg: var(--surface-muted);
  --hairline-color: #e5e7eb;
  --border-color: #d1d5db;
  --tint-border: #e9d5ff;
  --link-fg: #7e22ce;
  --link-hover-color: #6b21a8;
  --heading-color: #4a044e;
  --button-bg: var(--primary);
  --button-hover-bg: var(--primary-hover);
  --button-fg: #ffffff;
  --default-button-bg: var(--surface);
  --default-button-hover-bg: var(--surface-tint-hover);
  --default-button-fg: var(--secondary);
  --default-button-border-color: var(--tint-border);
  --selected-row: #f5e8ff;
  --message-success-bg: #f0fdf4;
  --message-warning-bg: #fffbeb;
  --message-error-bg: #fef2f2;
  --focus-ring: 0 0 0 3px rgba(126, 34, 206, 0.26);
  --elevated-shadow: 0 4px 12px rgba(16, 24, 40, 0.06);
  --soft-panel: var(--surface);
}

/* Sewaks branding sizing */
.sewaks-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.sewaks-logo {
  width: 22px;
  height: 22px;
  background: #fff;
  border-radius: 6px;
  padding: 2px;
}

.sewaks-wordmark {
  font-weight: 800;
  letter-spacing: 0.4px;
}

/* Hide default vendor footer (framework version line) */
#footer {
  display: none !important;
}

.sewaks-admin-subtitle {
  opacity: 0.8;
  font-size: 12px;
  margin-left: 6px;
}

/* Admin surface refresh */
body,
input,
textarea,
select,
button {
  font-family: var(--sewaks-font-sans);
}

body {
  background: var(--body-bg);
  color: var(--body-fg);
}

code,
pre,
.monospace {
  font-family: var(--sewaks-font-mono);
}

#header {
  background: var(--header-bg);
  box-shadow: var(--elevated-shadow);
}

#site-name a:link,
#site-name a:visited,
#user-tools,
#user-tools a {
  color: var(--header-link-color);
}

div.breadcrumbs {
  background: var(--breadcrumbs-bg);
  border: 0;
  border-bottom: 1px solid var(--tint-border);
  color: #374151;
}

div.breadcrumbs a {
  color: #7e22ce;
}

#content {
  background: var(--surface);
  border: 1px solid var(--hairline-color);
  border-radius: 14px;
  box-shadow: var(--elevated-shadow);
  margin-top: 14px;
  padding: 20px 24px;
}

a:link,
a:visited {
  color: var(--link-fg);
}

a:hover,
a:focus {
  color: var(--link-hover-color);
}

.module,
.inline-group {
  border: 1px solid var(--hairline-color);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(16, 24, 40, 0.04);
}

.module h2,
.module caption,
.inline-group h2 {
  background: var(--surface-tint);
  color: var(--heading-color);
  border-bottom: 1px solid var(--tint-border);
  font-weight: 700;
}

/* Forms and filters */
input,
textarea,
select,
.vTextField,
.vLargeTextField {
  border-radius: 10px;
  border: 1px solid var(--border-color);
  transition: box-shadow 0.16s ease, border-color 0.16s ease;
  color: var(--body-fg);
  background: var(--surface);
}

input:focus,
textarea:focus,
select:focus,
.vTextField:focus,
.vLargeTextField:focus {
  border-color: #a855f7;
  box-shadow: var(--focus-ring);
  outline: none;
}

#changelist-filter {
  border-left: 1px solid var(--hairline-color);
  background: var(--soft-panel);
}

#changelist-filter h2 {
  background: var(--surface-tint);
  color: var(--heading-color);
  border-bottom: 1px solid var(--tint-border);
}

#changelist-filter a {
  color: #4338ca;
}

#changelist-filter li.selected a {
  color: #111827;
  font-weight: 700;
}

/* Tables */
#result_list thead th {
  background: var(--surface-tint);
  border-bottom: 1px solid var(--tint-border);
  color: #1f2937;
}

#result_list tbody tr:hover {
  background: var(--surface-tint-hover);
}

#result_list tbody tr.selected {
  background: var(--selected-row);
}

/* Buttons */
.button,
input[type="submit"],
input[type="button"],
.submit-row input,
a.button {
  border-radius: 10px;
  border: 0;
  background: var(--button-bg);
  color: var(--button-fg);
  box-shadow: none;
  transition: background-color 0.15s ease;
}

.button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
.submit-row input:hover,
a.button:hover {
  background: var(--button-hover-bg);
  color: var(--button-fg);
}

.button.default,
input[type="submit"].default,
.submit-row input.default {
  background: var(--button-bg);
}

.button:not(.default),
input[type="button"],
a.button {
  background: var(--default-button-bg);
  color: var(--default-button-fg);
  border: 1px solid var(--default-button-border-color);
  box-shadow: none;
}

.button:not(.default):hover,
input[type="button"]:hover,
a.button:hover {
  background: var(--default-button-hover-bg);
  color: var(--link-hover-color);
}

/* Messages */
ul.messagelist li {
  border-radius: 10px;
  border: 1px solid transparent;
}

ul.messagelist li.success {
  background: var(--message-success-bg);
  border-color: #86efac;
}

ul.messagelist li.warning {
  background: var(--message-warning-bg);
  border-color: #fde68a;
}

ul.messagelist li.error {
  background: var(--message-error-bg);
  border-color: #fecaca;
}

/* Dashboard layout improvements */
.dashboard #content {
  padding-top: 24px;
}

.sewaks-admin-hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  padding: 18px;
  border: 1px solid var(--tint-border);
  border-radius: 14px;
  background: var(--surface-tint);
  margin-bottom: 16px;
}

.sewaks-admin-hero__left h1 {
  margin: 0 0 6px;
  color: var(--heading-color);
  font-size: 23px;
}

.sewaks-admin-hero__left p {
  margin: 0;
  color: #4b5563;
  max-width: 560px;
}

.sewaks-admin-hero__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.sewaks-admin-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.sewaks-kpi-card {
  background: var(--surface);
  border: 1px solid var(--hairline-color);
  border-radius: 12px;
  padding: 14px;
  box-shadow: 0 2px 6px rgba(16, 24, 40, 0.04);
}

.sewaks-kpi-label {
  display: block;
  color: #4b5563;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.sewaks-kpi-value {
  color: var(--heading-color);
  font-size: 18px;
  line-height: 1.2;
}

/* App list table on dashboard */
.dashboard .module table {
  border-radius: 0 0 12px 12px;
}

.dashboard .module tbody tr:hover {
  background: var(--surface-tint-hover);
}

/* Login page layout */
body.login {
  background: var(--surface-muted);
}

.login #content {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  margin-top: 30px;
}

.sewaks-login-shell {
  max-width: 520px;
  margin: 0 auto;
}

.sewaks-login-card {
  background: var(--surface);
  border: 1px solid var(--hairline-color);
  border-radius: 16px;
  box-shadow: var(--elevated-shadow);
  padding: 22px;
}

.sewaks-login-head {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 10px;
}

.sewaks-login-logo {
  width: 34px;
  height: 34px;
  background: var(--surface);
  border-radius: 10px;
  padding: 4px;
  border: 1px solid var(--tint-border);
}

.sewaks-login-head h1 {
  margin: 0;
  color: var(--heading-color);
  font-size: 22px;
}

.sewaks-login-head p {
  margin: 2px 0 0;
  color: #4b5563;
}

/* Responsive polish */
@media (max-width: 900px) {
  #content {
    padding: 16px;
  }

  .sewaks-admin-kpis {
    grid-template-columns: 1fr;
  }

  .sewaks-admin-hero {
    flex-direction: column;
    align-items: stretch;
  }
}

/* Changelist and form page layout improvements */
.sewaks-page-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 14px;
}

.sewaks-page-head h1 {
  margin: 0;
  color: var(--heading-color);
  font-size: 24px;
  line-height: 1.2;
}

.sewaks-page-subtitle {
  margin: 4px 0 0;
  color: #4b5563;
  font-size: 13px;
}

#changelist {
  position: relative;
}

#changelist .actions {
  position: sticky;
  top: 0;
  z-index: 20;
  background: var(--surface);
  border: 1px solid var(--hairline-color);
  border-radius: 10px;
  padding: 10px;
  margin-bottom: 10px;
}

#changelist-form .results {
  border: 1px solid var(--hairline-color);
  border-radius: 12px;
  overflow: hidden;
  background: var(--surface);
}

#changelist-search {
  background: var(--surface-muted);
  border: 1px solid var(--hairline-color);
  border-radius: 10px;
  padding: 10px;
  margin-bottom: 10px;
}

#changelist-search input[type="text"] {
  min-width: 320px;
}

.change-form #content-main .module,
.change-form #content-main .inline-group {
  margin-bottom: 14px;
}

.change-form .aligned .form-row {
  padding: 10px 12px;
  border-bottom: 1px solid #f1f5f9;
}

.change-form .aligned .form-row:last-child {
  border-bottom: 0;
}

.sewaks-form-tip {
  background: var(--surface-tint);
  border: 1px solid var(--tint-border);
  color: var(--heading-color);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 12px;
}

.help,
.helptext,
p.help,
.form-row .help {
  color: #374151;
}

.submit-row {
  position: sticky;
  bottom: 8px;
  z-index: 30;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(6px);
  border: 1px solid var(--hairline-color);
  border-radius: 12px;
  box-shadow: var(--elevated-shadow);
  padding: 10px 12px;
}

@media (max-width: 900px) {
  .sewaks-page-head {
    flex-direction: column;
  }

  #changelist-search input[type="text"] {
    min-width: 0;
    width: 100%;
  }

  .submit-row {
    position: static;
    backdrop-filter: none;
  }
}
