:root {
  --nn-bg: #030305;
  --nn-panel: #07070b;
  --nn-border: rgba(139, 92, 246, 0.24);
  --nn-purple: #8b5cf6;
  --nn-green: #34d399;
  --nn-text: #f8fafc;
  --nn-muted: rgba(248, 250, 252, 0.62);
}

html,
body {
  background:
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--nn-purple) 30%, transparent), transparent 34%),
    radial-gradient(circle at 86% 20%, color-mix(in srgb, var(--nn-green) 14%, transparent), transparent 28%),
    linear-gradient(135deg, #030305 0%, #07070b 48%, #0c0714 100%) !important;
  color: var(--nn-text) !important;
}

.task-login #layout-content {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 100vh !important;
  padding: clamp(20px, 5vw, 56px) !important;
  overflow: hidden !important;
  background:
    linear-gradient(90deg, rgba(3, 3, 5, 0.94), rgba(3, 3, 5, 0.66)),
    url('/nullninja/login-art.png') center/cover no-repeat !important;
}

.task-login #layout-content::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(139, 92, 246, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(139, 92, 246, 0.08) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(to bottom, transparent 0%, black 16%, black 74%, transparent 100%);
}

.task-login #layout-content::after {
  content: "";
  position: fixed;
  right: clamp(18px, 8vw, 120px);
  bottom: clamp(12px, 8vh, 96px);
  width: min(330px, 34vw);
  aspect-ratio: 1;
  opacity: 0.22;
  background: url('/nullninja/mascot.png') center/contain no-repeat;
  filter: drop-shadow(0 0 38px color-mix(in srgb, var(--nn-purple) 40%, transparent));
  pointer-events: none;
}

.nn-login-shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, 430px);
  width: min(1120px, 100%);
  min-height: min(680px, calc(100vh - 72px));
  border: 1px solid rgba(139, 92, 246, 0.22);
  border-radius: 26px;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
    rgba(3, 3, 5, 0.72);
  box-shadow: 0 34px 120px rgba(0, 0, 0, 0.62), 0 0 70px rgba(139, 92, 246, 0.16);
  backdrop-filter: blur(20px);
}

.nn-login-visual {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100%;
  padding: clamp(28px, 4vw, 52px);
  background:
    linear-gradient(90deg, rgba(3, 3, 5, 0.18), rgba(3, 3, 5, 0.76)),
    url('/nullninja/login-art.png') center/cover no-repeat;
}

.nn-login-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 28% 18%, rgba(139, 92, 246, 0.34), transparent 34%),
    linear-gradient(180deg, rgba(3, 3, 5, 0.08), rgba(3, 3, 5, 0.78));
  pointer-events: none;
}

.nn-login-visual > * {
  position: relative;
  z-index: 1;
}

.nn-login-mark {
  width: min(280px, 62vw);
  height: auto;
  filter: drop-shadow(0 18px 46px rgba(139, 92, 246, 0.32));
}

.nn-login-copy {
  max-width: 530px;
}

.nn-login-copy h2 {
  margin: 16px 0 12px;
  color: #ffffff;
  font-size: clamp(34px, 5vw, 62px);
  line-height: 0.96;
  font-weight: 800;
  letter-spacing: 0;
}

.nn-login-copy p {
  max-width: 440px;
  margin: 0;
  color: rgba(248, 250, 252, 0.68);
  font-size: 15px;
  line-height: 1.65;
}

.nn-login-points {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
  padding: 0;
  list-style: none;
}

.nn-login-points li {
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  padding: 8px 11px;
  background: rgba(255, 255, 255, 0.045);
  color: rgba(248, 250, 252, 0.74);
  font-size: 11px;
}

.nn-login-side-footer {
  color: rgba(248, 250, 252, 0.48);
  font-size: 12px;
}

.nn-login-panel {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(24px, 4vw, 44px);
  background:
    radial-gradient(circle at 50% 0%, rgba(52, 211, 153, 0.1), transparent 32%),
    linear-gradient(180deg, rgba(7, 7, 11, 0.96), rgba(3, 3, 5, 0.98));
}

.nn-login-card {
  width: min(100%, 390px);
}

.task-login #login-form {
  width: 100%;
  margin: 0;
  padding: 0;
  border: 1px solid var(--nn-border);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(16, 16, 21, 0.95), rgba(3, 3, 5, 0.97)),
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--nn-purple) 16%, transparent), transparent 55%);
  box-shadow: none;
  backdrop-filter: blur(18px);
}

.task-login #logo {
  display: block !important;
  width: min(260px, 72vw) !important;
  max-width: 260px !important;
  height: auto !important;
  margin: 0 auto 18px !important;
  filter: drop-shadow(0 18px 44px color-mix(in srgb, var(--nn-purple) 24%, transparent));
}

.nn-login-brand {
  margin: 0 0 18px;
  padding: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.035);
}

.nn-login-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 7px;
  color: var(--nn-green);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.nn-login-kicker::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--nn-green);
  box-shadow: 0 0 16px var(--nn-green);
}

.nn-login-headline {
  color: #ffffff;
  font-size: 18px;
  line-height: 1.25;
  font-weight: 700;
}

.nn-login-subtitle {
  margin-top: 6px;
  color: var(--nn-muted);
  font-size: 12px;
  line-height: 1.5;
}

.task-login .box-inner {
  padding: 22px !important;
}

.task-login .propform table {
  width: 100% !important;
}

.task-login .propform td {
  display: block !important;
  width: 100% !important;
  padding: 0 !important;
}

.task-login .propform td.input {
  margin-bottom: 12px !important;
}

.task-login .propform td.title label {
  display: block;
  margin: 0 0 6px;
  color: var(--nn-muted) !important;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.task-login input.form-control,
input.form-control,
textarea.form-control,
select.form-control {
  min-height: 46px !important;
  border: 1px solid rgba(139, 92, 246, 0.24) !important;
  background: rgba(3, 3, 5, 0.86) !important;
  color: var(--nn-text) !important;
  border-radius: 10px !important;
}

.task-login input.form-control:focus,
input.form-control:focus,
textarea.form-control:focus,
select.form-control:focus {
  border-color: rgba(52, 211, 153, 0.65) !important;
  box-shadow: 0 0 0 0.2rem rgba(52, 211, 153, 0.12) !important;
}

button.mainaction,
.btn-primary,
.button.mainaction {
  border-color: color-mix(in srgb, var(--nn-green) 45%, transparent) !important;
  background: linear-gradient(135deg, var(--nn-green), var(--nn-purple)) !important;
  color: #030305 !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  box-shadow: 0 0 28px color-mix(in srgb, var(--nn-green) 18%, transparent) !important;
}

#login-footer,
#login-footer a,
.task-login #login-footer {
  margin-top: 14px !important;
  text-align: center !important;
  color: rgba(248, 250, 252, 0.5) !important;
}

#layout-menu,
#layout-menu .popover-header {
  background: #07070b !important;
  border-right: 1px solid var(--nn-border) !important;
}

#layout-menu .popover-header img,
#layout-menu #logo {
  max-width: 64px !important;
  max-height: 42px !important;
}

#taskmenu a {
  color: rgba(248, 250, 252, 0.62) !important;
}

#taskmenu a.selected,
#taskmenu a:hover {
  color: #ffffff !important;
  background: color-mix(in srgb, var(--nn-purple) 16%, transparent) !important;
}

#layout-sidebar,
#layout-list,
#layout-content,
#layout > div > .header,
#layout > div > .footer {
  background-color: var(--nn-panel) !important;
  color: var(--nn-text) !important;
  border-color: rgba(139, 92, 246, 0.18) !important;
}

.listing li.selected > a,
.listing tr.selected td {
  background-color: rgba(139, 92, 246, 0.18) !important;
  color: #ffffff !important;
}

.messagelist tr.unread td,
.listing tbody tr:hover td,
.listing li:hover > a {
  background-color: rgba(255, 255, 255, 0.035) !important;
}

@media (max-width: 860px) {
  .task-login #layout-content {
    padding: 16px !important;
    align-items: flex-start !important;
  }

  .nn-login-shell {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .nn-login-visual {
    min-height: 250px;
    padding: 26px;
  }

  .nn-login-copy h2 {
    font-size: 34px;
  }

  .nn-login-copy p {
    font-size: 13px;
  }

  .nn-login-side-footer {
    display: none;
  }

  .nn-login-panel {
    padding: 20px;
  }

  .task-login #layout-content::after {
    display: none;
  }
}