.admin-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 280px 1fr;
  background: #f6f3fb;
  color: #2d2938;
}

.admin-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 28px;
  background: linear-gradient(180deg, #5d1b9f 0%, #a127ac 100%);
  color: #fff;
}

.admin-brand {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 34px;
  font-weight: 700;
  line-height: 1.05;
}

.admin-brand img,
.admin-login__card img {
  width: 72px;
  filter: invert(1);
}

.admin-sidebar nav {
  display: grid;
  gap: 10px;
}

.admin-sidebar nav a {
  padding: 13px 15px;
  border-radius: 12px;
  color: #fff;
}

.admin-sidebar nav a.is-active,
.admin-sidebar nav a:hover {
  background: rgba(255,255,255,.18);
}

.admin-main {
  min-width: 0;
  padding: 28px;
}

.admin-topbar,
.admin-panel__head,
.admin-stats,
.admin-filter,
.admin-form-grid {
  display: flex;
  gap: 16px;
  align-items: center;
}

.admin-topbar,
.admin-panel {
  border: 1px solid #ebe4f7;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 18px 50px rgba(93, 27, 159, .08);
}

.admin-topbar {
  justify-content: space-between;
  margin-bottom: 20px;
  padding: 18px 22px;
}

.admin-topbar p,
.admin-topbar h1 {
  margin: 0;
}

.admin-topbar p {
  color: #776f86;
}

.admin-topbar h1 {
  font-size: 24px;
  color: #2d2938;
}

.admin-notice {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin: 0 0 20px;
  padding: 16px 18px;
  border: 1px solid #d9c7ed;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(93, 27, 159, .12);
  animation: adminNoticeIn 260ms ease both;
}

.admin-notice > span {
  flex: 0 0 34px;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  font-weight: 900;
}

.admin-notice strong,
.admin-notice p {
  margin: 0;
}

.admin-notice strong {
  display: block;
  margin-bottom: 3px;
  color: #2d2938;
  font-size: 16px;
}

.admin-notice p {
  color: #5b5368;
}

.admin-notice--success {
  border-color: #c9ead9;
  background: linear-gradient(135deg, #fff 0%, #f1fbf5 100%);
}

.admin-notice--success > span {
  background: #11935b;
}

.admin-notice--error {
  border-color: #ffd1cf;
  background: linear-gradient(135deg, #fff 0%, #fff5f5 100%);
}

.admin-notice--error > span {
  background: #b42318;
}

.admin-panel {
  padding: 24px;
}

.admin-panel h2 {
  margin: 0;
  font-size: 34px;
  color: #5d1b9f;
}

.admin-panel h3 {
  margin: 28px 0 14px;
  font-size: 22px;
}

.admin-panel__head {
  justify-content: space-between;
  margin-bottom: 18px;
  flex-wrap: wrap;
}

.admin-button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: 42px;
  padding: 0 18px;
  border: 0;
  border-radius: 12px;
  background: linear-gradient(90deg, #5d1b9f, #a127ac);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.admin-link {
  border: 0;
  background: transparent;
  color: #5d1b9f;
  cursor: pointer;
  font-weight: 700;
}

.admin-link.danger {
  color: #b42318;
}

.admin-filter,
.admin-form-grid {
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.admin-filter input,
.admin-filter select,
.admin-form-grid input,
.admin-form-grid select,
.admin-form-grid textarea,
.admin-settings-stack input,
.admin-settings-stack select,
.admin-settings-stack textarea,
.admin-table-wrap input,
.admin-table-wrap select,
.admin-login__card input {
  min-height: 42px;
  border: 1px solid #ded3ef;
  border-radius: 10px;
  padding: 9px 12px;
  background: #fff;
  color: #2d2938;
}

.admin-form-grid label {
  display: grid;
  gap: 7px;
  min-width: min(100%, 260px);
  color: #5b5368;
  font-weight: 700;
}

.admin-form-grid--stack {
  align-items: end;
}

.admin-form-grid--stack .admin-button,
.admin-form-panel .admin-form-grid .admin-button {
  align-self: end;
}

.admin-date-filter {
  display: grid;
  gap: 4px;
  color: #5b5368;
  font-size: 13px;
  font-weight: 800;
}

.admin-filter--orders {
  display: grid;
  grid-template-columns:
    minmax(96px, 1fr)
    minmax(120px, 1.15fr)
    minmax(110px, .95fr)
    minmax(120px, 1fr)
    minmax(132px, 1fr)
    minmax(118px, .8fr)
    minmax(118px, .8fr)
    auto;
  gap: 12px;
  align-items: end;
}

.admin-filter--orders input,
.admin-filter--orders select,
.admin-filter--orders .admin-date-filter {
  width: 100%;
  min-width: 0;
}

.admin-filter--orders .admin-button {
  min-width: 92px;
  align-self: end;
  white-space: nowrap;
}

.admin-filter--payments {
  display: grid;
  grid-template-columns:
    minmax(150px, 220px)
    minmax(138px, 200px)
    minmax(120px, 160px)
    minmax(120px, 160px)
    auto;
  gap: 12px;
  align-items: end;
  justify-content: start;
}

.admin-filter--payments input,
.admin-filter--payments select,
.admin-filter--payments .admin-date-filter {
  width: 100%;
  min-width: 0;
}

.admin-filter--payments .admin-button {
  min-width: 96px;
  align-self: end;
  white-space: nowrap;
}

.admin-form-grid textarea {
  min-height: 98px;
}

.admin-settings-stack {
  display: grid;
  gap: 16px;
}

.admin-settings-stack label,
.admin-credential-card label,
.admin-inline-form label {
  display: grid;
  gap: 7px;
  color: #5b5368;
  font-weight: 700;
}

.admin-stats {
  align-items: stretch;
  flex-wrap: wrap;
  margin-bottom: 22px;
}

.admin-stats div {
  flex: 1 1 220px;
  padding: 18px;
  border-radius: 16px;
  background: #f5effc;
}

.admin-stats span {
  display: block;
  color: #756d83;
  margin-bottom: 8px;
}

.admin-stats b {
  font-size: 26px;
}

.admin-chart-card {
  overflow: visible;
  padding: 22px;
  border-radius: 22px;
  background:
    radial-gradient(circle at 18% 12%, rgba(161, 39, 172, .16), transparent 28%),
    linear-gradient(135deg, #fbf8ff 0%, #f3eafc 100%);
  border: 1px solid #eadcf6;
}

.admin-chart-card__head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  margin-bottom: 18px;
}

.admin-chart-card h3 {
  margin: 0 0 4px;
  font-size: 24px;
  color: #2d2938;
}

.admin-chart-card p {
  margin: 0;
  color: #756d83;
}

.admin-ring {
  --ring: calc(var(--ratio) * 1%);
  position: relative;
  flex: 0 0 108px;
  width: 108px;
  height: 108px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: conic-gradient(#5d1b9f 0 var(--ring), #d9c7ed var(--ring) 100%);
  box-shadow: 0 14px 28px rgba(93, 27, 159, .18);
  animation: adminRing 900ms ease both;
}

.admin-ring::before {
  content: "";
  position: absolute;
  inset: 13px;
  border-radius: 50%;
  background: #fff;
}

.admin-ring span {
  position: relative;
  z-index: 1;
  font-size: 22px;
  font-weight: 800;
  color: #2d2938;
}

.admin-chart-legend {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  margin-bottom: 16px;
  color: #5b5368;
  font-weight: 700;
}

.admin-chart-legend i {
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-right: 6px;
  border-radius: 4px;
  vertical-align: -1px;
}

.admin-chart-legend .is-orders { background: #cbb8f0; }
.admin-chart-legend .is-paid { background: #6b1fb0; }

.admin-combo-chart {
  min-height: 220px;
  display: flex;
  align-items: end;
  gap: 8px;
  padding: 22px 10px 34px;
  border-radius: 18px;
  background: rgba(255,255,255,.64);
  overflow-x: auto;
}

.admin-combo-chart__day {
  position: relative;
  flex: 1 1 22px;
  min-width: 18px;
  display: flex;
  align-items: end;
  justify-content: center;
  gap: 4px;
  height: 165px;
}

.admin-combo-chart__bar {
  position: relative;
  width: min(14px, calc(50% - 2px));
  min-width: 5px;
  height: var(--h);
  border-radius: 10px 10px 4px 4px;
  box-shadow: 0 8px 18px rgba(93, 27, 159, .16);
  transform-origin: bottom;
  animation: adminGrowY .8s cubic-bezier(.2,.8,.2,1) both;
}

.admin-combo-chart__bar::after {
  content: none;
}

.admin-combo-chart__bar.is-orders { background: #cab5ee; }
.admin-combo-chart__bar.is-paid { background: linear-gradient(180deg, #5d1b9f, #a127ac); }

.admin-chart-tooltip {
  position: fixed;
  z-index: 1000;
  max-width: min(260px, calc(100vw - 24px));
  padding: 9px 11px;
  border-radius: 11px;
  background: #2d2938;
  color: #fff;
  box-shadow: 0 14px 30px rgba(45, 41, 56, .24);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.3;
  pointer-events: none;
  transform: translateY(0);
  animation: adminTooltipIn 120ms ease both;
}

.admin-chart-tooltip[hidden] {
  display: none;
}

.admin-combo-chart small {
  position: absolute;
  left: 50%;
  bottom: -24px;
  transform: translateX(-50%);
  color: #756d83;
  font-size: 11px;
}

.admin-table-wrap {
  overflow-x: auto;
}

.admin-table-wrap table {
  width: 100%;
  border-collapse: collapse;
  min-width: 840px;
}

.admin-table-wrap table.admin-table--wide {
  min-width: 1080px;
}

.admin-table-wrap th,
.admin-table-wrap td {
  padding: 12px;
  border-bottom: 1px solid #eee7f8;
  text-align: left;
  vertical-align: top;
}

.admin-table-wrap th {
  color: #5d1b9f;
  background: #f8f3fd;
}

.admin-inline-form {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) minmax(150px, 220px) auto;
  gap: 10px;
  align-items: end;
}

.admin-row-actions {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-muted {
  color: #756d83;
}

.admin-status {
  display: inline-flex;
  padding: 5px 10px;
  border-radius: 999px;
  background: #f2e8fa;
  color: #5d1b9f;
  font-weight: 800;
}

.admin-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 18px 0;
}

.admin-tabs a {
  padding: 10px 14px;
  border-radius: 999px;
  background: #f3edf9;
  color: #5d1b9f;
  font-weight: 700;
}

.admin-tabs a.is-active {
  background: #5d1b9f;
  color: #fff;
}

.admin-log {
  max-height: 560px;
  overflow: auto;
  padding: 14px;
  border-radius: 14px;
  background: #171321;
  color: #e9def5;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 13px;
}

.admin-log p {
  margin: 0 0 10px;
}

.admin-log-empty {
  color: #bfb3d5;
}

.admin-log-switch {
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 14px;
  padding: 14px;
  border-radius: 16px;
  background: #f8f3fd;
}

.admin-toggle {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  color: #2d2938;
}

.admin-toggle input {
  position: absolute;
  opacity: 0;
}

.admin-toggle span {
  position: relative;
  width: 54px;
  height: 30px;
  border-radius: 999px;
  background: #d8c7eb;
  transition: background 160ms ease;
}

.admin-toggle span::after {
  content: "";
  position: absolute;
  top: 4px;
  left: 4px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 4px 10px rgba(45, 41, 56, .18);
  transition: transform 160ms ease;
}

.admin-toggle input:checked + span {
  background: linear-gradient(90deg, #5d1b9f, #a127ac);
}

.admin-toggle input:checked + span::after {
  transform: translateX(24px);
}

.admin-mode-switch {
  display: inline-grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: min(100%, 520px);
  padding: 6px;
  border-radius: 16px;
  background: #f2e8fa;
}

.admin-mode-switch label {
  cursor: pointer;
}

.admin-mode-switch input {
  position: absolute;
  opacity: 0;
}

.admin-mode-switch span {
  display: flex;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border-radius: 12px;
  color: #5d1b9f;
  font-weight: 800;
  transition: background 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

.admin-mode-switch input:checked + span {
  background: #fff;
  color: #2d2938;
  box-shadow: 0 10px 22px rgba(93, 27, 159, .14);
}

.admin-credentials-grid,
.admin-card-grid,
.admin-role-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.admin-credential-card,
.admin-edit-card,
.admin-create-card,
.admin-role-card {
  padding: 18px;
  border: 1px solid #eadff6;
  border-radius: 18px;
  background: #fbf9fe;
}

.admin-credential-card {
  display: grid;
  gap: 13px;
}

.admin-credential-card h3,
.admin-edit-card h3,
.admin-create-card h3,
.admin-role-card h3 {
  margin: 0 0 8px;
  color: #5d1b9f;
}

.admin-seo-form {
  max-width: 760px;
}

.admin-seo-form textarea {
  min-height: 120px;
}

.admin-edit-card {
  display: grid;
  gap: 12px;
}

.admin-edit-card__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.admin-edit-card__head span {
  padding: 5px 10px;
  border-radius: 999px;
  background: #eee3f8;
  color: #5d1b9f;
  font-weight: 800;
  font-size: 13px;
}

.admin-create-card {
  margin-top: 20px;
}

.admin-subhead {
  margin-top: 14px;
}

.admin-role-card p {
  margin: 0;
  color: #5b5368;
  word-break: break-word;
}

.admin-permissions-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.admin-permissions-grid label {
  display: flex;
  gap: 8px;
  align-items: center;
  min-height: 42px;
  padding: 10px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid #eadff6;
}

.admin-empty {
  width: 100%;
  align-self: center;
  text-align: center;
  color: #756d83;
  font-weight: 700;
}

.admin-login {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
  background: linear-gradient(135deg, #5d1b9f, #bd27b6);
}

.admin-login__card {
  width: min(100%, 420px);
  display: grid;
  gap: 16px;
  padding: 30px;
  border-radius: 22px;
  background: #fff;
}

.admin-login__card img {
  filter: none;
}

.admin-login__card h1 {
  margin: 0;
  color: #5d1b9f;
}

.admin-login__card label {
  display: grid;
  gap: 8px;
}

.admin-alert {
  padding: 12px;
  border-radius: 12px;
  background: #fee4e2;
  color: #9f1f17;
}

@keyframes adminGrow {
  from { width: 0; }
}

@keyframes adminGrowY {
  from { transform: scaleY(0); }
}

@keyframes adminRing {
  from { clip-path: inset(0 100% 0 0 round 50%); }
  to { clip-path: inset(0 0 0 0 round 50%); }
}

@keyframes adminNoticeIn {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes adminTooltipIn {
  from {
    opacity: 0;
    transform: translateY(5px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 900px) {
  .admin-shell {
    grid-template-columns: 1fr;
  }

  .admin-sidebar {
    position: static;
    height: auto;
  }

  .admin-sidebar nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-main {
    padding: 16px;
  }

  .admin-chart-card__head,
  .admin-credentials-grid,
  .admin-card-grid,
  .admin-role-grid,
  .admin-inline-form,
  .admin-filter--orders,
  .admin-filter--payments,
  .admin-permissions-grid {
    grid-template-columns: 1fr;
  }

  .admin-chart-card__head {
    display: grid;
  }

  .admin-ring {
    width: 96px;
    height: 96px;
  }

  .admin-combo-chart {
    gap: 9px;
  }

  .admin-combo-chart__day {
    flex: 0 0 28px;
    min-width: 28px;
  }

  .admin-combo-chart__bar::after {
    min-width: 180px;
  }
}
