:root {
  color-scheme: light;
  --bg: #edf3fd;
  --bg-accent: #dbe7fb;
  --surface: #ffffff;
  --surface-muted: #f5f8fd;
  --surface-soft: #e9f0fb;
  --border: #d7e1ef;
  --border-strong: #b7c7dc;
  --text: #10213d;
  --text-muted: #5f7089;
  --accent: #154d97;
  --accent-strong: #0d356e;
  --accent-soft: #d9e6fb;
  --success-soft: #e3f4ea;
  --warning-soft: #fff3da;
  --danger-soft: #fee9e8;
  --sky-soft: #e6efff;
  --rose-soft: #fbe8ee;
  --indigo-soft: #e8eafd;
  --page-gradient-top: #f7faff;
  --page-gradient-mid: #f2f6fd;
  --topbar-bg: rgba(255, 255, 255, 0.96);
  --topbar-shadow: 0 6px 16px rgba(16, 33, 61, 0.04);
  --sidebar-bg-start: #081f43;
  --sidebar-bg-end: #0f3167;
  --sidebar-border: rgba(255, 255, 255, 0.08);
  --sidebar-text: #ecf3ff;
  --sidebar-text-strong: #ffffff;
  --sidebar-muted: rgba(236, 243, 255, 0.66);
  --sidebar-copy: rgba(236, 243, 255, 0.76);
  --sidebar-nav-color: rgba(236, 243, 255, 0.86);
  --sidebar-nav-hover-color: #ffffff;
  --sidebar-nav-hover-bg: rgba(255, 255, 255, 0.08);
  --sidebar-nav-hover-border: rgba(255, 255, 255, 0.08);
  --sidebar-nav-active-color: #0f3470;
  --sidebar-nav-active-bg: #ffffff;
  --sidebar-nav-active-border: rgba(255, 255, 255, 0.16);
  --sidebar-mark-bg: rgba(255, 255, 255, 0.14);
  --sidebar-mark-border: rgba(255, 255, 255, 0.18);
  --sidebar-mark-text: #ffffff;
  --sidebar-caret-color: rgba(236, 243, 255, 0.7);
  --sidebar-admin-bg: rgba(255, 255, 255, 0.08);
  --sidebar-admin-border: rgba(255, 255, 255, 0.12);
  --sidebar-admin-meta: rgba(236, 243, 255, 0.84);
  --profile-menu-link-bg: rgba(255, 255, 255, 0.05);
  --accent-soft-border: #c7d8f7;
  --button-primary-text: #ffffff;
  --button-primary-shadow: 0 10px 20px rgba(26, 79, 150, 0.16);
  --button-secondary-bg: #f6f9fe;
  --button-secondary-hover-bg: #eef4fd;
  --accent-gradient-start: #5b8fd6;
  --accent-progress-track: #dce7f7;
  --accent-glow: rgba(216, 230, 255, 0.56);
  --hero-radial-primary: rgba(26, 79, 150, 0.14);
  --hero-radial-secondary: rgba(91, 143, 214, 0.08);
  --hero-surface-end: #f7fbff;
  --dashboard-hero-radial-primary: rgba(26, 79, 150, 0.16);
  --dashboard-hero-radial-secondary: rgba(91, 143, 214, 0.08);
  --dashboard-hero-surface-end: #f7fbff;
  --hero-orbit-ring-a: rgba(13, 53, 110, 0.24);
  --hero-orbit-ring-b: rgba(21, 77, 151, 0.2);
  --hero-orbit-core-start: #0d356e;
  --hero-orbit-core-end: #154d97;
  --hero-orbit-core-shadow: rgba(13, 53, 110, 0.24);
  --surface-highlight-end: #f7fbff;
  --focus-outline: rgba(26, 79, 150, 0.14);
  --focus-border: #8fb0e2;
  --theme-preview-border: var(--border);
  --shadow: 0 12px 28px rgba(16, 33, 61, 0.07);
}

body[data-theme="blue"] {
  --accent: #154d97;
  --accent-strong: #0d356e;
  --accent-soft: #d9e6fb;
  --bg: #edf3fd;
  --bg-accent: #dbe7fb;
  --surface-muted: #f5f8fd;
  --surface-soft: #e9f0fb;
  --border: #d7e1ef;
  --border-strong: #b7c7dc;
  --text: #10213d;
  --text-muted: #5f7089;
  --page-gradient-top: #f7faff;
  --page-gradient-mid: #f2f6fd;
  --topbar-bg: rgba(255, 255, 255, 0.96);
  --topbar-shadow: 0 6px 16px rgba(16, 33, 61, 0.04);
  --sidebar-bg-start: #081f43;
  --sidebar-bg-end: #0f3167;
  --sidebar-border: rgba(255, 255, 255, 0.08);
  --sidebar-text: #ecf3ff;
  --sidebar-text-strong: #ffffff;
  --sidebar-muted: rgba(236, 243, 255, 0.66);
  --sidebar-copy: rgba(236, 243, 255, 0.76);
  --sidebar-nav-color: rgba(236, 243, 255, 0.86);
  --sidebar-nav-hover-color: #ffffff;
  --sidebar-nav-hover-bg: rgba(255, 255, 255, 0.08);
  --sidebar-nav-hover-border: rgba(255, 255, 255, 0.08);
  --sidebar-nav-active-color: #0f3470;
  --sidebar-nav-active-bg: #ffffff;
  --sidebar-nav-active-border: rgba(255, 255, 255, 0.16);
  --sidebar-mark-bg: rgba(255, 255, 255, 0.14);
  --sidebar-mark-border: rgba(255, 255, 255, 0.18);
  --sidebar-mark-text: #ffffff;
  --sidebar-caret-color: rgba(236, 243, 255, 0.7);
  --sidebar-admin-bg: rgba(255, 255, 255, 0.08);
  --sidebar-admin-border: rgba(255, 255, 255, 0.12);
  --sidebar-admin-meta: rgba(236, 243, 255, 0.84);
  --profile-menu-link-bg: rgba(255, 255, 255, 0.05);
  --accent-soft-border: #c7d8f7;
  --button-primary-shadow: 0 10px 20px rgba(26, 79, 150, 0.16);
  --button-secondary-bg: #f6f9fe;
  --button-secondary-hover-bg: #eef4fd;
  --accent-gradient-start: #5b8fd6;
  --accent-progress-track: #dce7f7;
  --accent-glow: rgba(216, 230, 255, 0.56);
  --hero-radial-primary: rgba(26, 79, 150, 0.14);
  --hero-radial-secondary: rgba(91, 143, 214, 0.08);
  --hero-surface-end: #f7fbff;
  --dashboard-hero-radial-primary: rgba(26, 79, 150, 0.16);
  --dashboard-hero-radial-secondary: rgba(91, 143, 214, 0.08);
  --dashboard-hero-surface-end: #f7fbff;
  --hero-orbit-ring-a: rgba(13, 53, 110, 0.24);
  --hero-orbit-ring-b: rgba(21, 77, 151, 0.2);
  --hero-orbit-core-start: #0d356e;
  --hero-orbit-core-end: #154d97;
  --hero-orbit-core-shadow: rgba(13, 53, 110, 0.24);
  --surface-highlight-end: #f7fbff;
  --focus-outline: rgba(26, 79, 150, 0.14);
  --focus-border: #8fb0e2;
}

body[data-theme="slate"] {
  --accent: #335c93;
  --accent-strong: #264773;
  --accent-soft: #d8e3f3;
  --bg: #edf2f7;
  --bg-accent: #dee7f2;
  --surface-muted: #f5f8fc;
  --surface-soft: #e8eef6;
  --border: #d3dde9;
  --border-strong: #b2c1d6;
  --text: #142337;
  --text-muted: #5e6d82;
  --page-gradient-top: #f7f9fc;
  --page-gradient-mid: #f0f4f9;
  --topbar-bg: rgba(250, 252, 255, 0.96);
  --topbar-shadow: 0 6px 16px rgba(22, 33, 51, 0.06);
  --sidebar-bg-start: #1d2533;
  --sidebar-bg-end: #2d3b50;
  --sidebar-border: rgba(255, 255, 255, 0.1);
  --sidebar-text: #edf2fb;
  --sidebar-text-strong: #ffffff;
  --sidebar-muted: rgba(237, 242, 251, 0.66);
  --sidebar-copy: rgba(237, 242, 251, 0.78);
  --sidebar-nav-color: rgba(237, 242, 251, 0.88);
  --sidebar-nav-hover-color: #ffffff;
  --sidebar-nav-hover-bg: rgba(255, 255, 255, 0.1);
  --sidebar-nav-hover-border: rgba(255, 255, 255, 0.1);
  --sidebar-nav-active-color: #243750;
  --sidebar-nav-active-bg: #ffffff;
  --sidebar-nav-active-border: rgba(255, 255, 255, 0.18);
  --sidebar-mark-bg: rgba(255, 255, 255, 0.16);
  --sidebar-mark-border: rgba(255, 255, 255, 0.2);
  --sidebar-mark-text: #ffffff;
  --sidebar-caret-color: rgba(237, 242, 251, 0.75);
  --sidebar-admin-bg: rgba(255, 255, 255, 0.1);
  --sidebar-admin-border: rgba(255, 255, 255, 0.14);
  --sidebar-admin-meta: rgba(237, 242, 251, 0.84);
  --profile-menu-link-bg: rgba(255, 255, 255, 0.08);
  --accent-soft-border: #b8cde8;
  --button-primary-shadow: 0 10px 20px rgba(38, 71, 115, 0.18);
  --button-secondary-bg: #f3f7fc;
  --button-secondary-hover-bg: #e9f0f9;
  --accent-gradient-start: #7090bb;
  --accent-progress-track: #d9e3f1;
  --accent-glow: rgba(206, 220, 240, 0.54);
  --hero-radial-primary: rgba(51, 92, 147, 0.14);
  --hero-radial-secondary: rgba(112, 144, 187, 0.08);
  --hero-surface-end: #f5f8fc;
  --dashboard-hero-radial-primary: rgba(51, 92, 147, 0.16);
  --dashboard-hero-radial-secondary: rgba(112, 144, 187, 0.08);
  --dashboard-hero-surface-end: #f5f8fc;
  --hero-orbit-ring-a: rgba(36, 55, 80, 0.24);
  --hero-orbit-ring-b: rgba(51, 92, 147, 0.2);
  --hero-orbit-core-start: #243750;
  --hero-orbit-core-end: #335c93;
  --hero-orbit-core-shadow: rgba(36, 55, 80, 0.24);
  --surface-highlight-end: #f5f8fc;
  --focus-outline: rgba(51, 92, 147, 0.14);
  --focus-border: #90adce;
}

body[data-theme="forest"] {
  --accent: #1f7a5d;
  --accent-strong: #155640;
  --accent-soft: #d8efe7;
  --bg: #edf5f3;
  --bg-accent: #def1eb;
  --surface-muted: #f6faf8;
  --surface-soft: #e7f2ee;
  --border: #cfe3dc;
  --border-strong: #a6c7bc;
  --text: #122d28;
  --text-muted: #57756d;
  --page-gradient-top: #f7fbfa;
  --page-gradient-mid: #eef7f4;
  --topbar-bg: rgba(250, 255, 253, 0.96);
  --topbar-shadow: 0 6px 16px rgba(18, 48, 40, 0.06);
  --sidebar-bg-start: #0f3c31;
  --sidebar-bg-end: #17614e;
  --sidebar-border: rgba(255, 255, 255, 0.1);
  --sidebar-text: #eaf9f4;
  --sidebar-text-strong: #ffffff;
  --sidebar-muted: rgba(234, 249, 244, 0.68);
  --sidebar-copy: rgba(234, 249, 244, 0.8);
  --sidebar-nav-color: rgba(234, 249, 244, 0.88);
  --sidebar-nav-hover-color: #ffffff;
  --sidebar-nav-hover-bg: rgba(255, 255, 255, 0.1);
  --sidebar-nav-hover-border: rgba(255, 255, 255, 0.1);
  --sidebar-nav-active-color: #0f4a3d;
  --sidebar-nav-active-bg: #ffffff;
  --sidebar-nav-active-border: rgba(255, 255, 255, 0.18);
  --sidebar-mark-bg: rgba(255, 255, 255, 0.16);
  --sidebar-mark-border: rgba(255, 255, 255, 0.2);
  --sidebar-mark-text: #ffffff;
  --sidebar-caret-color: rgba(234, 249, 244, 0.76);
  --sidebar-admin-bg: rgba(255, 255, 255, 0.1);
  --sidebar-admin-border: rgba(255, 255, 255, 0.14);
  --sidebar-admin-meta: rgba(234, 249, 244, 0.84);
  --profile-menu-link-bg: rgba(255, 255, 255, 0.08);
  --accent-soft-border: #a8d8c7;
  --button-primary-shadow: 0 10px 20px rgba(21, 86, 64, 0.18);
  --button-secondary-bg: #f3faf7;
  --button-secondary-hover-bg: #e8f4ef;
  --accent-gradient-start: #44a88a;
  --accent-progress-track: #d4e8e1;
  --accent-glow: rgba(198, 230, 220, 0.54);
  --hero-radial-primary: rgba(31, 122, 93, 0.14);
  --hero-radial-secondary: rgba(72, 163, 134, 0.08);
  --hero-surface-end: #f4faf7;
  --dashboard-hero-radial-primary: rgba(31, 122, 93, 0.16);
  --dashboard-hero-radial-secondary: rgba(72, 163, 134, 0.08);
  --dashboard-hero-surface-end: #f4faf7;
  --hero-orbit-ring-a: rgba(15, 74, 61, 0.24);
  --hero-orbit-ring-b: rgba(31, 122, 93, 0.2);
  --hero-orbit-core-start: #155640;
  --hero-orbit-core-end: #1f7a5d;
  --hero-orbit-core-shadow: rgba(15, 74, 61, 0.24);
  --surface-highlight-end: #f4faf7;
  --focus-outline: rgba(31, 122, 93, 0.16);
  --focus-border: #6fac98;
}

body[data-theme="amber"] {
  --accent: #b0651f;
  --accent-strong: #7d4514;
  --accent-soft: #f5e3d2;
  --bg: #f9f1e7;
  --bg-accent: #f6e7d6;
  --surface-muted: #fbf6f0;
  --surface-soft: #f3e7d8;
  --border: #ead8c3;
  --border-strong: #d7bfa3;
  --text: #3a2515;
  --text-muted: #7c6249;
  --page-gradient-top: #fcf8f2;
  --page-gradient-mid: #f7efe4;
  --topbar-bg: rgba(255, 252, 247, 0.96);
  --topbar-shadow: 0 6px 16px rgba(63, 39, 20, 0.07);
  --sidebar-bg-start: #4a2911;
  --sidebar-bg-end: #7b4419;
  --sidebar-border: rgba(255, 255, 255, 0.1);
  --sidebar-text: #fdf2e7;
  --sidebar-text-strong: #ffffff;
  --sidebar-muted: rgba(253, 242, 231, 0.68);
  --sidebar-copy: rgba(253, 242, 231, 0.8);
  --sidebar-nav-color: rgba(253, 242, 231, 0.9);
  --sidebar-nav-hover-color: #ffffff;
  --sidebar-nav-hover-bg: rgba(255, 255, 255, 0.1);
  --sidebar-nav-hover-border: rgba(255, 255, 255, 0.1);
  --sidebar-nav-active-color: #6b3c16;
  --sidebar-nav-active-bg: #ffffff;
  --sidebar-nav-active-border: rgba(255, 255, 255, 0.2);
  --sidebar-mark-bg: rgba(255, 255, 255, 0.18);
  --sidebar-mark-border: rgba(255, 255, 255, 0.22);
  --sidebar-mark-text: #ffffff;
  --sidebar-caret-color: rgba(253, 242, 231, 0.78);
  --sidebar-admin-bg: rgba(255, 255, 255, 0.12);
  --sidebar-admin-border: rgba(255, 255, 255, 0.16);
  --sidebar-admin-meta: rgba(253, 242, 231, 0.86);
  --profile-menu-link-bg: rgba(255, 255, 255, 0.1);
  --accent-soft-border: #e2c5a5;
  --button-primary-shadow: 0 10px 20px rgba(125, 69, 20, 0.2);
  --button-secondary-bg: #fcf6ee;
  --button-secondary-hover-bg: #f6ebde;
  --accent-gradient-start: #cf8b4d;
  --accent-progress-track: #f0e2d1;
  --accent-glow: rgba(244, 222, 197, 0.54);
  --hero-radial-primary: rgba(176, 101, 31, 0.16);
  --hero-radial-secondary: rgba(214, 153, 99, 0.1);
  --hero-surface-end: #fcf6ef;
  --dashboard-hero-radial-primary: rgba(176, 101, 31, 0.17);
  --dashboard-hero-radial-secondary: rgba(214, 153, 99, 0.1);
  --dashboard-hero-surface-end: #fcf6ef;
  --hero-orbit-ring-a: rgba(107, 60, 22, 0.24);
  --hero-orbit-ring-b: rgba(176, 101, 31, 0.2);
  --hero-orbit-core-start: #7d4514;
  --hero-orbit-core-end: #b0651f;
  --hero-orbit-core-shadow: rgba(107, 60, 22, 0.24);
  --surface-highlight-end: #fcf6ef;
  --focus-outline: rgba(176, 101, 31, 0.16);
  --focus-border: #c89563;
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
}

html[data-font-size="small"] {
  font-size: 87.5%;
}

html[data-font-size="normal"] {
  font-size: 100%;
}

html[data-font-size="large"] {
  font-size: 112.5%;
}

body {
  margin: 0;
  min-height: 100vh;
  font-size: 1rem;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, var(--page-gradient-top) 0%, var(--page-gradient-mid) 20%, var(--bg) 100%);
}

a {
  color: inherit;
}

button,
input,
select,
textarea {
  font: inherit;
}

.shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 18rem minmax(0, 1fr);
}

.shell-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 1.5rem 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  overflow: hidden;
  background: linear-gradient(180deg, var(--sidebar-bg-start) 0%, var(--sidebar-bg-end) 100%);
  border-right: 1px solid var(--sidebar-border);
  color: var(--sidebar-text);
}

.sidebar-brand {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.95rem;
  align-items: start;
}

.brand-mark {
  width: 2.8rem;
  height: 2.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.95rem;
  background: var(--sidebar-mark-bg);
  border: 1px solid var(--sidebar-mark-border);
  color: var(--sidebar-mark-text);
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.sidebar-brand-copy {
  min-width: 0;
}

.sidebar-brand h1 {
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.15;
  color: var(--sidebar-text-strong);
}

.eyebrow {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  font-weight: 700;
}

.sidebar-kicker {
  margin: 0;
  color: var(--sidebar-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1.2;
}

.sidebar-label {
  margin: 0;
  color: var(--sidebar-muted);
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.25;
}

.sidebar-copy {
  margin: 0.5rem 0 0;
  color: var(--sidebar-copy);
  line-height: 1.55;
}

.sidebar-nav-scroll {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  overflow-y: auto;
  padding-right: 0.3rem;
  margin-right: -0.3rem;
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: rgba(196, 214, 239, 0.4) transparent;
}

.sidebar-nav-scroll::-webkit-scrollbar {
  width: 0.5rem;
}

.sidebar-nav-scroll::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(196, 214, 239, 0.38);
}

.sidebar-nav-scroll::-webkit-scrollbar-track {
  background: transparent;
}

.sidebar-section {
  display: block;
}

.sidebar-footer {
  margin-top: 0;
}

.nav-list {
  display: grid;
  gap: 0.24rem;
}

.nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
  padding: 0.74rem 0.86rem;
  border-radius: 0.88rem;
  text-decoration: none;
  color: var(--sidebar-nav-color);
  border: 1px solid transparent;
  font-size: 0.96rem;
  font-weight: 700;
  line-height: 1.25;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease;
}

.nav-link:hover,
.nav-link:focus-visible {
  color: var(--sidebar-nav-hover-color);
  background: var(--sidebar-nav-hover-bg);
  border-color: var(--sidebar-nav-hover-border);
}

.nav-link.is-active {
  color: var(--sidebar-nav-active-color);
  background: var(--sidebar-nav-active-bg);
  border-color: var(--sidebar-nav-active-border);
}

.nav-link.is-disabled {
  color: var(--sidebar-muted);
  cursor: not-allowed;
  opacity: 0.58;
}

.nav-link.is-disabled:hover,
.nav-link.is-disabled:focus-visible {
  color: var(--sidebar-muted);
  background: transparent;
  border-color: transparent;
}

.nav-lock-badge {
  flex: 0 0 auto;
  padding: 0.12rem 0.4rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1.2;
  text-transform: uppercase;
}

.nav-group {
  margin: 0;
  display: block;
}

.nav-group summary::-webkit-details-marker {
  display: none;
}

.nav-group summary::marker {
  content: "";
}

.nav-group-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.68rem 0.76rem;
  border-radius: 0.85rem;
  border: 1px solid transparent;
  color: var(--sidebar-muted);
  cursor: pointer;
  list-style: none;
  user-select: none;
  background: transparent;
  font-size: 0.96rem;
  font-weight: 800;
  line-height: 1.25;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease;
}

.nav-group-toggle:hover,
.nav-group-toggle:focus-visible {
  color: var(--sidebar-nav-hover-color);
  background: var(--sidebar-nav-hover-bg);
  border-color: var(--sidebar-nav-hover-border);
}

.nav-group-toggle.is-active {
  color: var(--sidebar-nav-hover-color);
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.06);
}

.nav-group[open] > .nav-group-toggle {
  color: var(--sidebar-text-strong);
}

.nav-group-toggle::after {
  content: "▾";
  font-size: 0.7rem;
  line-height: 1;
  color: var(--sidebar-caret-color);
  transition: transform 160ms ease;
}

.nav-group[open] > .nav-group-toggle::after {
  transform: rotate(180deg);
}

.nav-group > .nav-list {
  margin: 0.2rem 0 0.42rem 0.78rem;
  padding-left: 0.55rem;
  border-left: 1px solid rgba(196, 214, 239, 0.18);
}

.sidebar-admin {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.28rem;
  padding: 0.82rem 0.9rem;
  border-radius: 1rem;
  background: var(--sidebar-admin-bg);
  border: 1px solid var(--sidebar-admin-border);
  cursor: pointer;
  list-style: none;
}

.sidebar-admin strong {
  font-size: 0.94rem;
}

.sidebar-admin span {
  color: var(--sidebar-muted);
  word-break: break-word;
}

.sidebar-admin-copy {
  display: grid;
  gap: 0.14rem;
}

.profile-menu {
  position: relative;
  display: grid;
  gap: 0.55rem;
}

.profile-menu summary::-webkit-details-marker {
  display: none;
}

.profile-menu-caret {
  align-self: center;
  color: var(--sidebar-caret-color);
  font-size: 0.8rem;
  transition: transform 160ms ease;
}

.profile-menu[open] .profile-menu-caret {
  transform: rotate(180deg);
}

.profile-menu-actions {
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100% + 0.55rem);
  display: grid;
  gap: 0.4rem;
  padding: 0.55rem;
  border-radius: 0.95rem;
  border: 1px solid var(--sidebar-admin-border);
  background: linear-gradient(180deg, var(--sidebar-bg-start) 0%, var(--sidebar-bg-end) 100%);
  box-shadow: 0 12px 28px rgba(5, 19, 41, 0.34);
  z-index: 10;
}

.profile-menu-actions .nav-link {
  padding: 0.68rem 0.82rem;
  background: var(--profile-menu-link-bg);
  border-radius: 0.86rem;
}

.profile-menu-actions form {
  margin: 0;
}

.profile-menu-button {
  width: 100%;
  justify-content: flex-start;
}

.sidebar-backdrop {
  display: none;
}

.shell-main {
  min-width: 0;
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.shell-topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.95rem 1.4rem;
  background: var(--topbar-bg);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(12px);
  box-shadow: var(--topbar-shadow);
}

.shell-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem;
  flex: 1;
}

.shell-breadcrumb-item {
  color: var(--text-muted);
  font-size: 0.9rem;
  font-weight: 700;
}

.shell-breadcrumb-item:last-of-type {
  color: var(--text);
}

.shell-breadcrumb-separator {
  color: var(--border-strong);
  font-weight: 700;
}

.shell-license {
  color: var(--text-muted);
  font-size: 0.82rem;
  font-weight: 700;
}

.shell-footer {
  margin-top: auto;
  padding-top: 0.95rem;
  border-top: 1px solid var(--border);
  color: var(--text-muted);
  font-size: 0.82rem;
  display: grid;
  justify-items: center;
  gap: 0.2rem;
  text-align: center;
}

.sidebar-toggle {
  display: none;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  border-radius: 999px;
  padding: 0.65rem 1rem;
  cursor: pointer;
}

.page-wrap {
  padding: clamp(1.25rem, 2vw, 1.75rem);
  min-height: 100%;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.page-content {
  display: grid;
  gap: 1.25rem;
  width: 100%;
}

.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem;
  min-height: 5.1rem;
}

.page-header-copy h1 {
  margin: 0.35rem 0 0;
  font-size: clamp(2rem, 4vw, 2.6rem);
  line-height: 1.05;
}

.page-subtitle {
  margin: 0.75rem 0 0;
  max-width: 34rem;
  color: var(--text-muted);
  line-height: 1.55;
}

.page-header-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.1rem;
}

.page-meta-date {
  color: var(--text-muted);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.page-meta-time {
  font-size: clamp(1.4rem, 3vw, 2.1rem);
  line-height: 1;
  font-weight: 700;
  letter-spacing: -0.04em;
}

.admin-chip,
.admin-role,
.status-badge,
.metric-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 0.3rem 0.62rem;
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1.1;
}

.admin-chip {
  background: var(--bg-accent);
  color: var(--accent-strong);
  border: 1px solid var(--accent-soft-border);
}

.admin-role {
  background: var(--surface-muted);
  border: 1px solid var(--border);
  color: var(--text-muted);
  text-transform: capitalize;
}

.grid-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
  gap: 1rem;
}

.top-status-grid {
  margin: 0;
  align-items: stretch;
  grid-auto-rows: 1fr;
}

.metric-card,
.panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 1.1rem;
  box-shadow: var(--shadow);
}

.metric-card {
  padding: 0.95rem 1rem;
  display: grid;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  border-top-width: 3px;
}

.top-status-grid .metric-card {
  padding: 0.88rem 0.92rem;
  gap: 0.46rem;
  height: 8.05rem;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.top-status-grid .metric-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.top-status-grid .metric-header {
  gap: 0.46rem;
}

.top-status-grid .metric-pill {
  padding: 0.24rem 0.5rem;
  font-size: 0.7rem;
}

.top-status-grid .metric-value {
  font-size: 1.58rem;
  line-height: 1.08;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  min-height: 2.4rem;
}

.top-status-grid .metric-value-compact {
  font-size: 1.14rem;
  line-height: 1.15;
}

.top-status-grid .metric-visual {
  display: none;
}

.top-status-grid .metric-icon {
  width: 2.05rem;
  height: 2.05rem;
  border-radius: 0.72rem;
  font-size: 0.7rem;
}

.top-status-grid .metric-note {
  font-size: 0.76rem;
  line-height: 1.3;
}

.top-status-grid .metric-detail {
  font-size: 0.82rem;
  line-height: 1.38;
  margin-top: auto;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  min-height: 2.24em;
}

.top-status-grid .metric-trend {
  display: none;
}

.metric-card::before {
  display: none;
}

.metric-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.metric-label {
  color: var(--text-muted);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 700;
}

.metric-pill {
  border: 1px solid transparent;
}

.metric-pill-accent {
  background: var(--bg-accent);
  color: var(--accent-strong);
}

.metric-pill-success {
  background: var(--success-soft);
  color: #166534;
}

.metric-pill-neutral {
  background: var(--surface-soft);
  color: var(--text-muted);
}

.metric-pill-warning {
  background: var(--warning-soft);
  color: #92400e;
}

.metric-pill-sky {
  background: var(--sky-soft);
  color: #1d4ed8;
}

.metric-visual {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.metric-note {
  color: var(--text-muted);
  font-size: 0.82rem;
  line-height: 1.35;
  text-align: left;
}

.metric-icon {
  width: 2.35rem;
  height: 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.8rem;
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.metric-icon-accent {
  background: var(--accent-soft);
  color: var(--accent-strong);
}

.metric-icon-success {
  background: var(--success-soft);
  color: #166534;
}

.metric-icon-neutral {
  background: var(--surface-soft);
  color: var(--text-muted);
}

.metric-icon-warning {
  background: var(--warning-soft);
  color: #92400e;
}

.metric-icon-sky {
  background: var(--sky-soft);
  color: #1d4ed8;
}

.metric-spark {
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  gap: 0.28rem;
  min-height: 2.8rem;
  flex: 1;
}

.metric-spark-bar {
  width: 0.48rem;
  border-radius: 999px;
  min-height: 0.7rem;
  opacity: 0.95;
}

.metric-spark-bar-accent {
  background: linear-gradient(180deg, var(--accent-gradient-start) 0%, var(--accent) 100%);
}

.metric-spark-bar-success {
  background: linear-gradient(180deg, #4ade80 0%, #16a34a 100%);
}

.metric-spark-bar-neutral {
  background: linear-gradient(180deg, #cbd5e1 0%, #64748b 100%);
}

.metric-spark-bar-warning {
  background: linear-gradient(180deg, #fbbf24 0%, #d97706 100%);
}

.metric-value {
  font-size: 1.72rem;
  line-height: 1;
}

.metric-value-compact {
  font-size: 1.25rem;
  line-height: 1.2;
  word-break: break-word;
}

.metric-detail,
.metric-trend {
  margin: 0;
  color: var(--text-muted);
  line-height: 1.35;
  font-size: 0.88rem;
}

.metric-trend {
  padding-top: 0.55rem;
  border-top: 1px solid var(--border);
}

.panel {
  padding: clamp(1.15rem, 1.6vw, 1.45rem);
}

.disclosure-panel {
  padding: 0;
  overflow: hidden;
}

.disclosure-summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.05rem 1.15rem;
}

.disclosure-summary::-webkit-details-marker {
  display: none;
}

.disclosure-summary .panel-title,
.disclosure-summary .eyebrow {
  margin-left: 0;
}

.disclosure-body {
  display: grid;
  gap: 1rem;
  padding: 0 1.15rem 1.15rem;
  border-top: 1px solid var(--border);
}

.ops-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(18rem, 22rem);
  gap: 1.2rem;
  overflow: hidden;
}

.ops-hero::before {
  content: "";
  position: absolute;
  inset: -4rem auto auto -3rem;
  width: 13rem;
  height: 13rem;
  border-radius: 999px;
  background: var(--accent-glow);
  filter: blur(12px);
  pointer-events: none;
}

.ops-hero-copy,
.ops-hero-aside {
  position: relative;
  z-index: 1;
}

.ops-hero-title {
  margin: 0.45rem 0 0;
  font-size: clamp(1.65rem, 3vw, 2.1rem);
  line-height: 1.12;
}

.ops-hero-text {
  margin: 0.9rem 0 0;
  color: var(--text-muted);
  line-height: 1.7;
  max-width: 44rem;
}

.ops-hero-aside {
  display: grid;
  align-content: start;
}

.hero-chip-row {
  margin-top: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.hero-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.48rem 0.82rem;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text-muted);
  font-size: 0.8rem;
  font-weight: 700;
}

.hero-chip-accent {
  background: rgba(231, 239, 253, 0.95);
  border-color: var(--accent-soft-border);
  color: var(--accent-strong);
}

.hero-chip-success {
  background: rgba(240, 253, 244, 0.95);
  border-color: #bbf7d0;
  color: #166534;
}

.hero-chip-warning {
  background: rgba(255, 251, 235, 0.95);
  border-color: #fde68a;
  color: #92400e;
}

.hero-chip-sky {
  background: rgba(239, 246, 255, 0.95);
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.ops-hero-infrastructure {
  background:
    radial-gradient(circle at top right, var(--hero-radial-primary), transparent 28%),
    radial-gradient(circle at bottom left, var(--hero-radial-secondary), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, var(--hero-surface-end) 100%);
}

.ops-hero-access {
  background:
    radial-gradient(circle at top right, var(--hero-radial-primary), transparent 28%),
    radial-gradient(circle at bottom left, var(--hero-radial-secondary), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, var(--hero-surface-end) 100%);
}

.ops-hero-settings {
  background:
    radial-gradient(circle at top right, var(--hero-radial-primary), transparent 28%),
    radial-gradient(circle at bottom left, var(--hero-radial-secondary), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, var(--hero-surface-end) 100%);
}

.ops-hero-accounting {
  background:
    radial-gradient(circle at top right, var(--hero-radial-primary), transparent 28%),
    radial-gradient(circle at bottom left, var(--hero-radial-secondary), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, var(--hero-surface-end) 100%);
}

.dashboard-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: flex-start;
  gap: 1.25rem;
  background:
    radial-gradient(circle at top right, var(--dashboard-hero-radial-primary), transparent 26%),
    radial-gradient(circle at bottom left, var(--dashboard-hero-radial-secondary), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, var(--dashboard-hero-surface-end) 100%);
}

.dashboard-hero-copy {
  max-width: 42rem;
}

.dashboard-hero-title {
  margin: 0.45rem 0 0;
  font-size: clamp(1.65rem, 3vw, 2.15rem);
  line-height: 1.12;
}

.dashboard-hero-text {
  margin: 0.9rem 0 0;
  color: var(--text-muted);
  line-height: 1.7;
}

.dashboard-hero-mode {
  margin: 0.8rem 0 0;
  color: var(--text-muted);
  font-size: 0.94rem;
  line-height: 1.5;
}

.dashboard-hero-mode strong {
  color: var(--text);
}

.dashboard-hero-meta {
  display: grid;
  justify-items: end;
  gap: 0.55rem;
}

.dashboard-hero-visual {
  display: grid;
  gap: 1rem;
  justify-items: center;
}

.hero-orbit {
  position: relative;
  width: 15rem;
  height: 15rem;
  display: grid;
  place-items: center;
}

.hero-orbit-ring {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  border: 1px dashed var(--hero-orbit-ring-a);
}

.hero-orbit-ring-b {
  inset: 1.5rem;
  border-color: var(--hero-orbit-ring-b);
}

.hero-orbit-core {
  position: relative;
  z-index: 2;
  width: 6.6rem;
  height: 6.6rem;
  border-radius: 2rem;
  display: grid;
  place-items: center;
  text-align: center;
  background: linear-gradient(135deg, var(--hero-orbit-core-start) 0%, var(--hero-orbit-core-end) 100%);
  color: #ffffff;
  box-shadow: 0 18px 32px var(--hero-orbit-core-shadow);
}

.hero-orbit-core strong {
  font-size: 1.35rem;
  line-height: 1;
}

.hero-orbit-core span {
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  opacity: 0.86;
}

.hero-orbit-node {
  position: absolute;
  z-index: 2;
  padding: 0.5rem 0.8rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  font-size: 0.82rem;
  font-weight: 700;
}

.hero-orbit-node-a {
  top: 0.8rem;
  right: 1rem;
  color: var(--accent-strong);
}

.hero-orbit-node-b {
  left: 0.4rem;
  top: 5.8rem;
  color: #1d4ed8;
}

.hero-orbit-node-c {
  right: 0.7rem;
  bottom: 1.4rem;
  color: #9a3412;
}

.hero-highlight-grid {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.hero-highlight {
  display: grid;
  gap: 0.3rem;
  padding: 0.9rem 0.95rem;
  border-radius: 1.1rem;
  border: 1px solid transparent;
  background: var(--surface);
}

.hero-highlight span {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.hero-highlight strong {
  font-size: 1.1rem;
}

.hero-highlight-accent {
  background: linear-gradient(135deg, var(--bg-accent) 0%, #ffffff 100%);
  border-color: var(--accent-soft-border);
}

.hero-highlight-sky {
  background: linear-gradient(135deg, #eff6ff 0%, #ffffff 100%);
  border-color: #bfdbfe;
}

.hero-highlight-warning {
  background: linear-gradient(135deg, #fffbeb 0%, #ffffff 100%);
  border-color: #fde68a;
}

.dashboard-date {
  color: var(--text-muted);
  font-size: 0.92rem;
  font-weight: 600;
}

.content-grid,
.dashboard-primary-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
  gap: 1rem;
}

.content-grid-single {
  grid-template-columns: minmax(0, 1fr);
}

.content-grid-equal {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.server-details-grid {
  grid-template-columns: minmax(0, 7fr) minmax(18rem, 3fr);
}

.dashboard-secondary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.dashboard-activity-layout {
  display: grid;
  grid-template-columns: minmax(28rem, clamp(34rem, 42vw, 54rem)) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  margin-top: 1rem;
}

.accounting-mode-card-grid {
  align-items: start;
}

.record-list-panel {
  width: 100%;
}

.record-list-shell,
.record-list {
  display: grid;
  gap: 0.65rem;
}

.record-filter-disclosure {
  border: 0;
  background: transparent;
}

.record-filter-summary {
  display: inline-flex;
  justify-content: flex-start;
  padding: 0;
  list-style: none;
  cursor: pointer;
}

.record-filter-summary::-webkit-details-marker {
  display: none;
}

.record-filter-summary::marker {
  content: "";
}

.record-filter-button {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 2.2rem;
  padding: 0.42rem 0.72rem;
  border: 1px solid var(--border);
  border-radius: 0.65rem;
  background: #ffffff;
  color: var(--accent-strong);
  box-shadow: 0 0.4rem 1rem rgba(15, 23, 42, 0.06);
  font-size: 0.78rem;
  font-weight: 800;
  text-decoration: none;
}

.record-filter-button::after {
  content: "";
  width: 0.42rem;
  height: 0.42rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transition: transform 0.16s ease;
}

.record-filter-summary:hover .record-filter-button,
.record-filter-summary:focus-visible .record-filter-button {
  border-color: var(--accent-soft-border);
  background: var(--button-secondary-hover-bg);
}

.record-filter-disclosure[open] .record-filter-button::after {
  transform: rotate(225deg) translateY(-1px);
}

.record-filter-disclosure .disclosure-body {
  margin-top: 0.75rem;
  padding: 0.9rem;
  border: 1px solid var(--border);
  border-radius: 0.95rem;
  background: var(--surface-muted);
}

.record-filter-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
  align-items: end;
}

.record-filter-field {
  display: grid;
  min-width: 0;
}

.record-filter-field-wide,
.record-filter-actions {
  grid-column: 1 / -1;
}

.record-filter-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
}

.record-filter-actions .button {
  width: 100%;
}

.record-list-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.2rem 0;
}

.record-toolbar-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.record-list-row {
  border: 1px solid var(--border);
  border-radius: 0.95rem;
  background: #ffffff;
  overflow: hidden;
}

.record-list-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.8rem;
  padding: 0.85rem 0.95rem;
  list-style: none;
  cursor: pointer;
}

.record-list-summary::-webkit-details-marker {
  display: none;
}

.record-list-summary::marker {
  content: "";
}

.record-list-main {
  min-width: 0;
}

.record-list-meta {
  font-size: 0.82rem;
}

.record-list-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.32rem 0.62rem;
  border: 1px solid var(--border);
  border-radius: 0.65rem;
  background: var(--surface-muted);
  color: var(--accent-strong);
  font-size: 0.78rem;
  font-weight: 700;
}

.record-list-row[open] .record-list-toggle-open,
.record-list-row:not([open]) .record-list-toggle-close {
  display: none;
}

.record-list-details {
  padding: 0.85rem 0.95rem;
  border-top: 1px solid var(--border);
  background: var(--surface-muted);
}

.record-list-kv {
  display: grid;
  gap: 0.45rem;
  margin: 0;
}

.record-list-kv-row {
  display: grid;
  grid-template-columns: 7rem minmax(0, 1fr);
  gap: 0.75rem;
}

.record-list-kv dt {
  color: var(--text-muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.record-list-kv dd {
  margin: 0;
  min-width: 0;
}

.record-list-subrecords {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.9rem;
}

.record-list-subrecords h4 {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.record-list-subrecord-list {
  display: grid;
  gap: 0.45rem;
}

.record-list-subrecord {
  display: grid;
  gap: 0.2rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  background: #ffffff;
}

.record-list-subrecord strong {
  font-size: 0.86rem;
}

.record-list-subrecord span {
  color: var(--text-muted);
  font-size: 0.78rem;
}

.record-list-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.6rem;
  margin-top: 0.85rem;
}

.record-list-actions form {
  display: inline-flex;
}

.accounting-tab-heading {
  margin-bottom: 1rem;
}

.accounting-live-device-grid {
  gap: 1.35rem;
  align-items: start;
}

.accounting-device-list,
.accounting-session-list {
  display: grid;
  gap: 0.75rem;
}

.accounting-device-card,
.accounting-session-card {
  display: grid;
  gap: 0.85rem;
  padding: 0.95rem;
  border: 1px solid var(--border);
  border-radius: 0.95rem;
  background: var(--surface);
}

.accounting-device-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.accounting-device-main {
  min-width: 0;
}

.accounting-device-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.5rem;
}

.accounting-device-meta,
.accounting-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 10rem), 1fr));
  gap: 0.65rem;
  margin: 0.75rem 0 0;
}

.accounting-device-meta div,
.accounting-detail-grid div {
  display: grid;
  gap: 0.2rem;
}

.accounting-device-meta dt,
.accounting-detail-grid dt {
  color: var(--text-muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.accounting-device-meta dd,
.accounting-detail-grid dd {
  margin: 0;
  color: var(--text);
}

.accounting-device-row-options {
  margin-top: 0.65rem;
}

.accounting-event-setup {
  margin-bottom: 1rem;
}

.accounting-detail-hero .panel-actions {
  flex-wrap: wrap;
}

.record-list-footer {
  display: flex;
  justify-content: flex-end;
  padding-top: 0.35rem;
}

.record-list-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
}

.record-toolbar-label {
  color: var(--text-muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.record-list-panel-compact .record-list-shell,
.record-list-panel-compact .record-list {
  gap: 0.5rem;
}

.record-list-panel-compact .record-list-row {
  border-radius: 0.72rem;
}

.record-list-panel-compact .record-list-summary {
  gap: 0.65rem;
  padding: 0.62rem 0.78rem;
}

.record-list-panel-compact .resource-title-row {
  gap: 0.45rem;
}

.record-list-panel-compact .resource-title-row h3 {
  font-size: 0.98rem;
}

.record-list-panel-compact .record-list-meta {
  margin-top: 0.18rem;
  font-size: 0.76rem;
}

.record-list-panel-compact .record-list-details {
  padding: 0.7rem 0.78rem;
}

.content-grid-sidebar {
  align-items: start;
}

.side-panel-stack {
  display: grid;
  gap: 1.15rem;
  align-content: start;
}

.settings-main-stack {
  display: grid;
  gap: 1.15rem;
  align-content: start;
}

.panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem;
  margin-bottom: 1.2rem;
}

.panel-title {
  margin: 0.35rem 0 0;
  font-size: 1.2rem;
}

.form-page-panel {
  width: min(100%, 76rem);
}

.panel-actions {
  display: flex;
  gap: 0.65rem;
}

.panel > .resource-list,
.panel > .settings-sections,
.panel > .reference-list,
.panel > .theme-preview-grid {
  margin-top: 0.75rem;
}

.theme-preview-grid {
  display: grid;
  gap: 0.75rem;
}

.theme-preview-card {
  display: grid;
  grid-template-columns: 4.6rem minmax(0, 1fr);
  gap: 0.8rem;
  padding: 0.72rem;
  border-radius: 1rem;
  border: 1px solid var(--theme-preview-border);
  background: var(--surface);
}

.theme-preview-card.is-active {
  border-color: var(--accent-soft-border);
  box-shadow: var(--shadow);
}

.theme-preview-sidebar {
  min-height: 4.6rem;
  border-radius: 0.8rem;
  padding: 0.62rem;
  display: grid;
  align-content: space-between;
  border: 1px solid rgba(255, 255, 255, 0.16);
}

.theme-preview-sidebar-blue {
  background: linear-gradient(180deg, #081f43 0%, #0f3167 100%);
}

.theme-preview-sidebar-slate {
  background: linear-gradient(180deg, #1d2533 0%, #2d3b50 100%);
}

.theme-preview-sidebar-forest {
  background: linear-gradient(180deg, #0f3c31 0%, #17614e 100%);
}

.theme-preview-sidebar-amber {
  background: linear-gradient(180deg, #4a2911 0%, #7b4419 100%);
}

.theme-preview-mark {
  display: inline-flex;
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 0.55rem;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.18);
  color: #ffffff;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.theme-preview-lines {
  display: grid;
  gap: 0.22rem;
}

.theme-preview-lines span {
  display: block;
  height: 0.34rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.34);
}

.theme-preview-lines span:nth-child(2) {
  width: 85%;
}

.theme-preview-lines span:nth-child(3) {
  width: 68%;
}

.panel-tint-accent {
  background:
    linear-gradient(180deg, rgba(231, 239, 253, 0.92) 0%, #ffffff 100%);
  border-color: var(--accent-soft-border);
}

.panel-tint-warning {
  background:
    linear-gradient(180deg, rgba(255, 247, 232, 0.92) 0%, #ffffff 100%);
  border-color: #fde68a;
}

.readiness-list,
.mode-list,
.summary-list,
.reference-list,
.settings-sections,
.resource-list {
  display: grid;
  gap: 0.9rem;
}

.readiness-row,
.mode-card,
.summary-row,
.resource-card,
.reference-card,
.kv-card {
  border: 1px solid #dfe7f3;
  border-radius: 1.1rem;
  background: #ffffff;
}

.readiness-row,
.mode-card,
.resource-card,
.reference-card,
.kv-card {
  padding: 1rem 1.05rem;
}

.readiness-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(13rem, 15rem);
  gap: 1rem;
  align-items: center;
  position: relative;
  overflow: hidden;
}

.readiness-row::before,
.summary-row::before,
.mode-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 0.32rem;
  border-radius: inherit;
}

.readiness-copy strong,
.mode-copy strong {
  display: block;
  margin-bottom: 0.3rem;
}

.readiness-copy p,
.mode-copy p {
  margin: 0;
  color: var(--text-muted);
  line-height: 1.55;
}

.readiness-meta {
  display: grid;
  gap: 0.6rem;
}

.readiness-value {
  justify-self: end;
  font-weight: 700;
}

.progress-track {
  width: 100%;
  height: 0.5rem;
  border-radius: 999px;
  background: var(--accent-progress-track);
  overflow: hidden;
}

.progress-fill {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent-gradient-start) 0%, var(--accent) 100%);
}

.progress-fill-accent {
  background: linear-gradient(90deg, var(--accent-gradient-start) 0%, var(--accent) 100%);
}

.progress-fill-success {
  background: linear-gradient(90deg, #22c55e 0%, #16a34a 100%);
}

.progress-fill-sky {
  background: linear-gradient(90deg, #60a5fa 0%, #2563eb 100%);
}

.progress-fill-warning {
  background: linear-gradient(90deg, #f59e0b 0%, #d97706 100%);
}

.readiness-row-accent::before,
.summary-row-accent::before,
.mode-card-accent::before {
  background: linear-gradient(180deg, var(--accent-gradient-start) 0%, var(--accent) 100%);
}

.readiness-row-success::before,
.summary-row-success::before,
.mode-card-success::before {
  background: linear-gradient(180deg, #4ade80 0%, #16a34a 100%);
}

.readiness-row-sky::before,
.summary-row-sky::before,
.mode-card-sky::before {
  background: linear-gradient(180deg, #60a5fa 0%, #2563eb 100%);
}

.readiness-row-warning::before,
.summary-row-warning::before,
.mode-card-warning::before {
  background: linear-gradient(180deg, #fbbf24 0%, #d97706 100%);
}

.mode-card-rose::before {
  background: linear-gradient(180deg, #fb7185 0%, #e11d48 100%);
}

.mode-card-indigo::before {
  background: linear-gradient(180deg, #818cf8 0%, #4f46e5 100%);
}

.mode-card-neutral::before {
  background: linear-gradient(180deg, #cbd5e1 0%, #64748b 100%);
}

.mode-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding-left: 1.25rem;
  position: relative;
  overflow: hidden;
}

.mode-copy {
  min-width: 0;
  position: relative;
  padding-left: 1.35rem;
}

.mode-dot {
  position: absolute;
  left: 0;
  top: 0.2rem;
  width: 0.72rem;
  height: 0.72rem;
  border-radius: 999px;
}

.mode-dot-accent {
  background: var(--accent);
}

.mode-dot-warning {
  background: #d97706;
}

.mode-dot-sky {
  background: #2563eb;
}

.mode-dot-rose {
  background: #e11d48;
}

.mode-dot-indigo {
  background: #4f46e5;
}

.mode-dot-neutral {
  background: #64748b;
}

.summary-list {
  gap: 0.75rem;
}

.summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1rem;
  padding-left: 1.25rem;
  position: relative;
  overflow: hidden;
}

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

.summary-value {
  text-align: right;
}

.feature-list {
  margin: 0;
  padding-left: 1.2rem;
  display: grid;
  gap: 0.75rem;
  color: var(--text-muted);
  line-height: 1.6;
}

.ordered-list {
  list-style: decimal;
}

.compact-list {
  gap: 0.55rem;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.76rem 0.95rem;
  border-radius: 0.82rem;
  border: 1px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease;
}

.button-primary {
  background: var(--accent);
  color: var(--button-primary-text);
  box-shadow: var(--button-primary-shadow);
}

.button-primary:hover,
.button-primary:focus-visible {
  background: var(--accent-strong);
}

.button-success {
  background: #16834f;
  color: #ffffff;
  box-shadow: 0 10px 20px rgba(22, 131, 79, 0.18);
}

.button-success:hover,
.button-success:focus-visible {
  background: #10683e;
}

.button-secondary {
  background: var(--button-secondary-bg);
  color: var(--text);
  border-color: var(--border);
}

.button-secondary:hover,
.button-secondary:focus-visible {
  background: var(--button-secondary-hover-bg);
  border-color: var(--border-strong);
}

.button:disabled {
  opacity: 0.52;
  cursor: not-allowed;
  box-shadow: none;
}

.button.is-disabled,
.button[aria-disabled="true"] {
  opacity: 0.52;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
}

.form-footer-actions {
  justify-content: flex-end;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}

.resource-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.resource-main {
  min-width: 0;
}

.resource-title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.7rem;
}

.resource-title-row h3,
.settings-section-copy h3,
.reference-header h3 {
  margin: 0;
}

.resource-subtle,
.panel-footnote,
.empty-state {
  margin: 0.45rem 0 0;
  color: var(--text-muted);
  line-height: 1.55;
}

.resource-actions,
.table-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.panel-actions form,
.resource-actions form,
.table-actions form {
  margin: 0;
}

.resource-actions .button,
.table-actions .button {
  min-height: 2.45rem;
}

.server-operations-actions {
  display: grid;
  align-items: stretch;
}

.server-operations-actions .button,
.server-operations-actions form {
  width: 100%;
}

.mode-actions .button {
  min-width: 8.5rem;
}

.mode-pricing-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 21rem), 1fr));
  gap: 1rem;
  align-items: stretch;
  width: 100%;
}

.mode-pricing-card {
  border: 1px solid var(--border);
  border-radius: 1.1rem;
  background: #ffffff;
  padding: 1.1rem 1.12rem;
  display: grid;
  gap: 0.78rem;
}

.mode-pricing-card.is-active {
  border-color: #9cc2f4;
  box-shadow: 0 14px 28px rgba(18, 65, 130, 0.1);
  background: linear-gradient(180deg, #f3f8ff 0%, #ffffff 100%);
}

.mode-pricing-card.is-disabled {
  border-color: #d7dfeb;
  background: linear-gradient(180deg, #fbfcfe 0%, #ffffff 100%);
}

.mode-pricing-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.85rem;
}

.mode-pricing-kicker {
  margin: 0;
  font-size: 0.76rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 700;
}

.mode-pricing-header h3 {
  margin: 0.35rem 0 0;
}

.mode-pricing-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.45rem;
}

.mode-pricing-subtitle {
  margin: 0;
  color: var(--text-muted);
  line-height: 1.55;
}

.mode-feature-list {
  margin: 0;
  padding: 0 0 0 1rem;
  display: grid;
  gap: 0.32rem;
  color: var(--text-muted);
}

.mode-feature-list strong {
  color: var(--text);
  font-weight: 700;
}

.mode-pricing-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
}

.mode-pricing-actions form {
  margin: 0;
}

.quick-template-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.62rem;
  padding: 0.75rem 0 1rem;
}

.plan-template-card {
  font: inherit;
  color: inherit;
  text-align: left;
  cursor: pointer;
  border-radius: 0.85rem;
  gap: 0.48rem;
  padding: 0.88rem 0.95rem;
  box-shadow: none;
  justify-items: start;
}

.plan-template-card[hidden] {
  display: none;
}

.plan-template-list {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 15rem), 1fr));
  gap: 0.7rem;
}

.plan-template-card.is-active {
  border-color: var(--primary);
  background: #f7faff;
  box-shadow: inset 0 0 0 1px rgba(43, 86, 166, 0.12);
}

.plan-template-heading {
  display: grid;
  justify-items: start;
  gap: 0.42rem;
}

.plan-template-heading h3 {
  margin: 0;
  font-size: 0.98rem;
}

.plan-type-badge {
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  min-height: 1.35rem;
  padding: 0.2rem 0.58rem;
  font-size: 0.72rem;
  font-weight: 750;
  line-height: 1;
}

.plan-type-badge--manual {
  background: #eef2f7;
  color: #344256;
}

.plan-type-badge--guest {
  background: #dff1ff;
  color: #15527c;
}

.plan-type-badge--staff {
  background: #dff6e8;
  color: #17633c;
}

.plan-type-badge--voucher {
  background: #fff1d6;
  color: #7a4a0a;
}

.plan-type-badge--vip {
  background: #efe8ff;
  color: #56328d;
}

.plan-type-badge--test {
  background: #edf0f4;
  color: #465365;
}

.plan-type-badge--campaign {
  background: #def7f4;
  color: #17635d;
}

.plan-type-badge--paid {
  background: #e5ebff;
  color: #314c9a;
}

.plan-type-badge--contractor,
.plan-type-badge--byod {
  background: #fff4ce;
  color: #6f5200;
}

.plan-template-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 0.28rem 0.42rem;
  margin: 0;
  color: var(--text-muted);
  font-size: 0.82rem;
  font-weight: 650;
  line-height: 1.35;
}

.plan-template-summary span:not(:last-child)::after {
  content: "\00b7";
  color: #9aa7ba;
  margin-left: 0.42rem;
}

.mode-primary-actions,
.mode-secondary-actions {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.62rem;
}

.mode-primary-actions {
  flex: 1 1 100%;
}

.mode-primary-actions .button {
  min-width: 6.9rem;
}

.mode-secondary-actions {
  padding-top: 0.12rem;
}

.theme-mode-list {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
}

.theme-mode-card {
  cursor: pointer;
  user-select: none;
}

.theme-mode-card .theme-preview-sidebar {
  margin-top: 0.2rem;
}

.mode-template-controls {
  margin-top: 0.15rem;
  padding-top: 0.8rem;
  border-top: 1px dashed var(--border);
  display: grid;
  gap: 0.55rem;
}

.mode-template-label {
  margin: 0;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--text-muted);
}

.mode-template-actions {
  display: grid;
  gap: 0.55rem;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  align-items: start;
}

.mode-template-actions > .button,
.mode-template-actions > form {
  margin: 0;
  width: 100%;
}

.mode-template-actions .button {
  width: 100%;
  justify-content: center;
  min-height: 2.45rem;
}

@media (min-width: 1120px) {
  .mode-template-actions {
    grid-template-columns: repeat(2, minmax(200px, 1fr));
  }
}

.section-nav-panel {
  display: grid;
  gap: 1rem;
}

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

.filter-chip-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.filter-chip-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.34rem 0.74rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface-muted);
  color: var(--text-muted);
  text-decoration: none;
  font-size: 0.76rem;
  font-weight: 700;
}

.filter-chip-link:hover,
.filter-chip-link:focus-visible {
  border-color: var(--border-strong);
  background: var(--button-secondary-hover-bg);
  color: var(--text);
}

.filter-chip-link.is-active {
  background: var(--bg-accent);
  border-color: var(--accent-soft-border);
  color: var(--accent-strong);
}

.filter-chip-link.is-static {
  pointer-events: none;
  background: #ffffff;
  color: var(--text);
}

.record-limit-links .filter-chip-link {
  padding: 0.3rem 0.68rem;
}

.voucher-issue-panel {
  border-top-color: var(--success-border);
}

.voucher-next-card {
  display: grid;
  grid-template-columns: minmax(15rem, 0.85fr) minmax(0, 1.4fr) auto;
  gap: 1rem;
  align-items: center;
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 0.95rem;
  background: var(--surface-muted);
}

.voucher-next-code {
  display: grid;
  gap: 0.4rem;
}

.voucher-next-code code {
  display: inline-flex;
  width: max-content;
  max-width: 100%;
  padding: 0.35rem 0.55rem;
  border-radius: 0.55rem;
  background: #ffffff;
  color: var(--text);
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.voucher-next-details {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
  margin: 0;
}

.voucher-next-details div {
  display: grid;
  gap: 0.2rem;
}

.voucher-next-details dt {
  color: var(--text-muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.voucher-next-details dd {
  min-width: 0;
  margin: 0;
}

.voucher-card-print {
  border: 1px solid color-mix(in srgb, var(--border) 82%, var(--accent-soft-border));
  border-radius: 0.75rem;
  background: #ffffff;
  padding: 1.25rem;
  margin-bottom: 0.9rem;
  max-width: 34rem;
}

.voucher-card-brand {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 0.9rem;
}

.voucher-card-brand > div {
  display: grid;
  gap: 0.12rem;
}

.voucher-card-brand strong {
  font-size: 0.95rem;
}

.voucher-card-brand span {
  color: var(--text-muted);
  font-size: 0.82rem;
}

.voucher-brand-logo {
  display: block;
  width: auto;
  max-width: 7.5rem;
  max-height: 2.7rem;
  object-fit: contain;
}

.company-logo-preview {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 96px;
  height: 64px;
  margin-bottom: 0.5rem;
  padding: 0.5rem;
  border: 1px solid var(--line);
  border-radius: 0.5rem;
  background: #fff;
}

.company-logo-preview img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.voucher-brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.55rem;
  min-height: 2.55rem;
  color: var(--accent);
  font-weight: 800;
  letter-spacing: 0;
  font-size: 1.05rem;
}

.voucher-card-title {
  margin: 0 0 0.95rem;
  color: var(--text);
  font-size: 1.15rem;
  font-weight: 800;
}

.voucher-card-steps {
  display: grid;
  gap: 0.55rem;
  margin: 0 0 1rem;
}

.voucher-card-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.55rem;
  align-items: start;
}

.voucher-card-step > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.55rem;
  height: 1.55rem;
  border-radius: 999px;
  background: var(--bg-accent);
  color: var(--accent-strong);
  font-size: 0.82rem;
  font-weight: 800;
}

.voucher-card-step strong {
  display: block;
  font-size: 0.88rem;
}

.voucher-card-step p {
  margin: 0.08rem 0 0;
  color: var(--text-muted);
  font-size: 0.82rem;
}

.voucher-card-label {
  margin: 0;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.75rem;
  font-weight: 700;
}

.voucher-card-code {
  display: block;
  margin-top: 0.4rem;
  font-size: clamp(1.8rem, 5vw, 2.55rem);
  line-height: 1.1;
  letter-spacing: 0;
}

.voucher-card-hint {
  margin: 0.45rem 0 0;
  color: var(--text-muted);
}

.voucher-card-meta {
  margin: 0.9rem 0 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem 0.9rem;
}

.voucher-card-meta div {
  margin: 0;
}

.voucher-card-meta dt {
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.11em;
  color: var(--text-muted);
  font-weight: 700;
}

.voucher-card-meta dd {
  margin: 0.2rem 0 0;
  font-weight: 600;
}

.voucher-card-qr-block {
  display: grid;
  justify-items: center;
  gap: 0.4rem;
}

.voucher-card-qr-grid {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  align-items: start;
}

.voucher-qr-image {
  width: 7.1rem;
  height: 7.1rem;
  border: 1px solid var(--accent-soft-border);
  border-radius: 0.8rem;
  background: #ffffff;
  padding: 0.35rem;
}

.voucher-qr-hint {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.82rem;
  text-align: center;
}

.voucher-qr-label {
  margin: 0;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 800;
  text-align: center;
}

.voucher-sheet-print {
  margin-top: 0.95rem;
  display: grid;
  gap: 1rem;
}

.voucher-sheet-page {
  border: 1px dashed var(--accent-soft-border);
  border-radius: 1rem;
  background: #ffffff;
  padding: 0.9rem;
}

.voucher-sheet-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.voucher-sheet-card {
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  background: #ffffff;
  padding: 0.82rem;
}

.voucher-sheet-card .voucher-card-code {
  margin-top: 0.25rem;
  font-size: 1.55rem;
}

.voucher-sheet-card .voucher-card-title {
  margin-bottom: 0.55rem;
  font-size: 1rem;
}

.voucher-sheet-card .voucher-card-steps {
  gap: 0.35rem;
  margin-bottom: 0.65rem;
}

.voucher-sheet-card .voucher-card-step p {
  font-size: 0.75rem;
}

.voucher-sheet-card .voucher-card-meta {
  margin-top: 0.72rem;
  gap: 0.48rem 0.72rem;
}

.voucher-sheet-card .voucher-card-qr-block {
  gap: 0.3rem;
}

.voucher-sheet-card .voucher-qr-image {
  width: 5.6rem;
  height: 5.6rem;
}

.voucher-sheet-footer {
  margin: 0.62rem 0 0;
  color: var(--text-muted);
  font-size: 0.82rem;
  text-align: right;
}

.router-section-stack {
  display: grid;
  gap: 1rem;
}

.segmented-tabs-row {
  display: flex;
  justify-content: center;
  width: 100%;
  margin: 1.6rem 0 1.45rem;
  padding: 0.58rem;
  border: 1px solid color-mix(in srgb, var(--border) 74%, transparent);
  border-radius: 1.25rem;
  background: color-mix(in srgb, var(--surface-muted) 88%, var(--surface));
}

.segmented-tabs {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  width: fit-content;
  max-width: 100%;
  padding: 0.18rem;
  border-radius: 999px;
  background: transparent;
  overflow-x: auto;
}

.segmented-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.3rem;
  padding: 0.55rem 1.05rem;
  border: 1px solid transparent;
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface) 72%, transparent);
  color: color-mix(in srgb, var(--text) 72%, var(--text-muted));
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease,
    color 160ms ease;
}

.segmented-tab:hover,
.segmented-tab:focus-visible {
  background: color-mix(in srgb, var(--surface) 92%, var(--accent-soft));
  color: var(--text);
}

.segmented-tab.is-active,
.font-size-toggle-option input:checked + .segmented-tab {
  border-color: color-mix(in srgb, var(--accent) 42%, var(--border));
  background: var(--surface);
  color: var(--accent);
  box-shadow: 0 9px 22px rgba(15, 23, 42, 0.12);
}

.segmented-tab.is-disabled {
  color: var(--text-subtle);
  cursor: not-allowed;
  opacity: 0.58;
  pointer-events: none;
}

.page-tabs {
  display: grid;
  gap: 1.35rem;
}

.tab-panel {
  display: none;
}

.tab-panel.is-active {
  display: block;
}

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

.router-panel-section[hidden] {
  display: none !important;
}

.traffic-panel {
  display: grid;
  gap: 1rem;
}

.traffic-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.traffic-card {
  display: grid;
  gap: 0.95rem;
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background:
    radial-gradient(circle at top right, var(--hero-radial-primary), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, var(--hero-surface-end) 100%);
}

.traffic-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
}

.traffic-toolbar-field {
  min-width: min(18rem, 100%);
  max-width: 20rem;
}

.traffic-window-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.traffic-window-group .button.is-active,
[data-traffic-live-toggle].is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}

.traffic-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.9rem;
}

.traffic-card-header h3 {
  margin: 0.35rem 0 0;
  font-size: 1.08rem;
}

.traffic-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.traffic-stat {
  display: grid;
  gap: 0.3rem;
  padding: 0.75rem 0.8rem;
  border-radius: 0.9rem;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid var(--border);
}

.traffic-stat-label {
  color: var(--text-muted);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 700;
}

.traffic-stat strong {
  font-size: 1rem;
  line-height: 1.2;
}

.traffic-chart {
  width: 100%;
  height: 13rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(21, 77, 151, 0.12);
  background: linear-gradient(180deg, #fbfdff 0%, #f2f7ff 100%);
}

.traffic-chart-panel {
  display: grid;
  gap: 0.5rem;
}

.traffic-chart-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  color: var(--text-muted);
  font-size: 0.84rem;
}

.traffic-scale,
.traffic-window-label {
  color: var(--text-muted);
}

.traffic-footnote {
  margin-top: 0;
}

.settings-category-stack {
  display: grid;
  gap: 1rem;
  margin-top: 0.85rem;
}

.settings-category {
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 1.1rem;
  background:
    linear-gradient(180deg, rgba(248, 250, 252, 0.72) 0%, #ffffff 100%);
}

.settings-category-header {
  display: grid;
  gap: 0.25rem;
}

.settings-category-header h3 {
  margin: 0.25rem 0 0;
  font-size: 1.08rem;
}

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

.font-size-toggle {
  min-width: max-content;
  margin: 0;
  padding: 0;
  border: 0;
}

.font-size-toggle-label {
  margin-bottom: 0.4rem;
  color: var(--text-muted);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-align: right;
  text-transform: uppercase;
}

.font-size-toggle-options {
  display: inline-flex;
  gap: 0.35rem;
  padding: 0.24rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface);
}

.font-size-toggle-option {
  cursor: pointer;
}

.inline-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 2.4rem;
  padding: 0.35rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--muted);
  background: var(--surface);
  font-size: 0.82rem;
  font-weight: 750;
  cursor: pointer;
}

.inline-toggle input {
  width: 1rem;
  height: 1rem;
  accent-color: var(--accent);
}

.settings-section {
  display: grid;
  gap: 1rem;
  padding-top: 0.25rem;
}

.settings-section + .settings-section {
  border-top: 1px solid var(--border);
  padding-top: 1.25rem;
}

.license-page-grid {
  grid-template-columns: minmax(0, 0.9fr) minmax(26rem, 1.1fr);
}

.license-mode-list {
  display: grid;
  gap: 0.55rem;
  margin-bottom: 0.9rem;
}

.license-mode-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.72rem 0.8rem;
  border: 1px solid var(--border);
  border-radius: 0.8rem;
  background: var(--surface-soft);
  font-weight: 800;
}

.license-usage-card {
  display: grid;
  gap: 0.72rem;
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background: #ffffff;
}

.license-usage-main {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
}

.license-usage-main strong {
  font-size: 1.55rem;
  line-height: 1;
}

.license-breakdown-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 0.9rem;
}

.license-breakdown-card {
  display: grid;
  gap: 0.35rem;
  padding: 0.85rem;
  border: 1px solid var(--border);
  border-radius: 0.9rem;
  background: #ffffff;
}

.license-breakdown-card strong {
  font-size: 1.35rem;
  line-height: 1;
}

.license-breakdown-card p {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.82rem;
  line-height: 1.4;
}

.inline-edit-card {
  margin-top: 0.25rem;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background: #ffffff;
  overflow: hidden;
}

.inline-edit-summary {
  list-style: none;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1rem;
  cursor: pointer;
}

.inline-edit-summary::-webkit-details-marker {
  display: none;
}

.inline-edit-copy {
  display: grid;
  gap: 0.35rem;
}

.inline-edit-value {
  font-size: 1.04rem;
  line-height: 1.25;
}

.inline-edit-facts {
  display: grid;
  gap: 0.2rem;
  color: var(--text-muted);
  font-size: 0.92rem;
  line-height: 1.45;
}

.inline-edit-facts strong {
  color: var(--text);
  font-weight: 700;
}

.inline-edit-action {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: 1px solid var(--accent-soft-border);
  border-radius: 999px;
  background: #eef4ff;
  color: var(--accent);
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.1;
  padding: 0.35rem 0.72rem;
  white-space: nowrap;
}

.inline-edit-icon {
  font-size: 0.88rem;
}

.inline-edit-card[open] .inline-edit-action {
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}

.inline-edit-body {
  border-top: 1px solid var(--border);
  padding: 0.85rem 1rem 0.95rem;
}

.inline-edit-form {
  padding-top: 0;
}

.form-grid,
.kv-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.15rem;
  align-items: start;
}

.form-field {
  display: grid;
  gap: 0.52rem;
  min-width: 0;
  align-self: stretch;
}

.form-grid > .form-field:not(.form-field-full) {
  grid-template-rows: auto auto minmax(1.25rem, auto) minmax(0, auto);
}

.form-field-full {
  grid-column: 1 / -1;
}

.field-label {
  font-weight: 700;
}

.field-help {
  color: var(--text-muted);
  font-size: 0.92rem;
  line-height: 1.45;
}

.field-error {
  color: #b91c1c;
  font-size: 0.9rem;
}

.input-field {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 0.82rem;
  background: var(--surface);
  padding: 0.84rem 0.95rem;
  color: var(--text);
}

.code-textarea {
  font-family: "Cascadia Mono", "Consolas", monospace;
  line-height: 1.25;
  white-space: pre;
}

.input-field:focus {
  outline: 2px solid var(--focus-outline);
  border-color: var(--focus-border);
}

.input-field.has-error {
  border-color: rgba(185, 28, 28, 0.35);
  background: #fff7f7;
}

.reference-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.85rem;
}

.reference-env {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--accent-strong);
  font-size: 0.8rem;
  font-weight: 700;
  white-space: nowrap;
}

.reference-value {
  margin: 0;
  font-weight: 700;
}

.tone-info {
  color: var(--accent);
}

.kv-list {
  margin: 0.85rem 0 0;
  display: grid;
  gap: 0.7rem;
}

.kv-row {
  display: grid;
  grid-template-columns: minmax(0, 11rem) minmax(0, 1fr);
  gap: 0.75rem;
}

.kv-row dt {
  color: var(--text-muted);
  text-transform: capitalize;
}

.kv-row dd {
  margin: 0;
  word-break: break-word;
}

.table-wrap {
  margin-top: 0.72rem;
  overflow-x: auto;
}

.table-wrap + .table-wrap {
  margin-top: 0.95rem;
}

.table-cell-stack {
  display: grid;
  gap: 0.45rem;
}

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

.data-table th,
.data-table td {
  padding: 0.82rem 0.8rem;
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.data-table th {
  background: var(--surface-muted);
  color: var(--text-muted);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 700;
}

.status-badge {
  text-transform: capitalize;
  background: var(--surface-soft);
  color: var(--text-muted);
  border: 1px solid transparent;
}

.portal-guided-page {
  gap: 1.35rem;
}

.portal-design-layout {
  width: min(100%, 126rem);
  display: grid;
  grid-template-columns: minmax(38rem, 1fr) minmax(38rem, 54rem);
  gap: 1.15rem;
  align-items: start;
}

.portal-design-editor,
.portal-design-preview {
  min-width: 0;
}

.portal-design-editor.form-page-panel {
  width: 100%;
}

.portal-guided-form {
  display: grid;
  gap: 1.35rem;
}

.portal-guided-form .page-tabs {
  gap: 1.55rem;
}

.portal-guided-form .tab-panel.is-active {
  display: grid;
  gap: 1.25rem;
}

.guided-section {
  display: grid;
  gap: 1.15rem;
  padding: clamp(1.15rem, 1.6vw, 1.45rem);
  border: 1px solid var(--border);
  border-radius: 1.1rem;
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-highlight-end) 100%);
}

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

.router-publication-panel code {
  font-size: 0.9em;
}

.portal-preview-card {
  position: sticky;
  top: 1rem;
  display: grid;
  gap: 1rem;
}

.portal-preview-card .panel-header {
  margin-bottom: 0;
}

.portal-preview-header {
  align-items: flex-start;
}

.portal-preview-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  justify-content: flex-end;
}

.portal-preview-action-bar {
  padding: 0.85rem;
  border: 1px solid var(--border);
  border-radius: 0.95rem;
  background: color-mix(in srgb, var(--surface-muted) 72%, #ffffff);
}

.portal-preview-card .guided-actions {
  margin: 0;
  justify-content: flex-start;
  padding-top: 0;
}

.portal-preview-card .guided-action-group {
  justify-content: flex-start;
}

.portal-preview-refresh-status {
  min-height: 1.25rem;
}

.portal-preview-updating,
.portal-preview-refresh-error {
  margin: 0;
}

.portal-preview-updating {
  color: var(--text-muted);
}

.portal-preview-refresh-error {
  color: #92400e;
}

.portal-preview-tabs {
  display: grid;
  gap: 0.85rem;
}

.portal-preview-panel.is-active {
  display: grid;
  gap: 0.55rem;
}

.portal-preview-frame-shell {
  min-height: 48rem;
  height: min(86vh, 72rem);
  border: 1px solid var(--border);
  border-radius: 0.95rem;
  background: #f8fafc;
  overflow: hidden;
}

.portal-preview-frame {
  width: 100%;
  height: 100%;
  border: 0;
  background: #ffffff;
}

.portal-design-preview.is-refreshing .portal-preview-frame {
  opacity: 0.72;
}

.portal-design-preview.has-preview-error .portal-preview-card {
  border-color: color-mix(in srgb, var(--warning-soft) 55%, var(--border));
}

.portal-preview-empty {
  min-height: 100%;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.portal-preview-path {
  text-align: center;
  margin: 0;
}

.portal-preview-warning {
  display: grid;
  gap: 0.4rem;
  padding: 0.85rem 0.95rem;
  border: 1px solid color-mix(in srgb, var(--warning-soft) 55%, var(--border));
  border-radius: 0.9rem;
  background: color-mix(in srgb, var(--warning-soft) 58%, #ffffff);
  color: #92400e;
}

.portal-preview-warning p {
  margin: 0;
}

.guided-advanced {
  display: block;
}

.guided-advanced-summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
}

.guided-advanced-summary::-webkit-details-marker {
  display: none;
}

.guided-advanced-body {
  display: grid;
  gap: 1.15rem;
  padding-top: 1.15rem;
  border-top: 1px solid var(--border);
  margin-top: 1.15rem;
}

.guided-advanced-block {
  display: grid;
  gap: 1rem;
  padding: 1.1rem;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background: var(--surface);
}

.portal-theme-note {
  margin: 0;
  padding: 0.95rem 1rem;
  border: 1px solid color-mix(in srgb, var(--accent-soft-border) 72%, transparent);
  border-radius: 0.95rem;
  background: color-mix(in srgb, var(--accent-soft) 72%, #ffffff);
  color: var(--text-muted);
  line-height: 1.5;
}

.field-checkbox-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.field-checkbox {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.78rem 0.85rem;
  border: 1px solid var(--border);
  border-radius: 0.85rem;
  background: var(--surface);
  color: var(--text-muted);
}

.portal-theme-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr));
  gap: 0.85rem;
}

.portal-theme-option {
  position: relative;
  display: block;
}

.portal-theme-option input {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.portal-theme-card {
  min-height: 6.2rem;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 0.95rem;
  padding: 0.95rem;
  border: 1px solid var(--border);
  border-radius: 0.95rem;
  background: var(--surface);
  cursor: pointer;
  transition: border-color 160ms ease, box-shadow 160ms ease, background-color 160ms ease;
}

.portal-theme-option input:checked + .portal-theme-card {
  border-color: var(--accent-soft-border);
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-highlight-end) 100%);
  box-shadow: var(--shadow);
}

.portal-theme-option input:focus-visible + .portal-theme-card {
  outline: 2px solid var(--focus-outline);
  outline-offset: 2px;
}

.portal-theme-swatch,
.portal-font-sample {
  width: 3.35rem;
  height: 3.35rem;
  border: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
  border-radius: 0.85rem;
}

.portal-theme-swatch {
  display: block;
}

.portal-theme-swatch-classic {
  background:
    linear-gradient(135deg, hsla(236, 0%, 54%, 1) 0%, transparent 70%),
    linear-gradient(25deg, hsla(221, 35%, 27%, 1) 10%, transparent 80%),
    linear-gradient(315deg, hsla(46, 37%, 84%, 1) 15%, transparent 80%),
    linear-gradient(245deg, hsla(191, 51%, 56%, 1) 100%, transparent 70%);
}

.portal-theme-swatch-deep_blue {
  background: linear-gradient(135deg, #0b1f3f 0%, #123d72 48%, #6f9fcb 100%);
}

.portal-theme-swatch-forest {
  background: linear-gradient(135deg, #0f3c31 0%, #1f7a5d 55%, #c6e7d8 100%);
}

.portal-design-card {
  grid-template-columns: minmax(5.6rem, 7rem) minmax(0, 1fr);
}

.portal-background-card {
  grid-template-columns: minmax(5.6rem, 7rem) minmax(0, 1fr);
}

.portal-design-sample {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
  border-radius: 0.85rem;
  background: var(--surface-soft);
}

.portal-design-sample span {
  position: absolute;
  inset: 28% 24%;
  border-radius: 0.28rem;
  background: #ffffff;
  box-shadow: 0 8px 18px rgba(16, 33, 61, 0.12);
}

.portal-design-sample span::before,
.portal-design-sample span::after {
  content: "";
  position: absolute;
  left: 18%;
  right: 18%;
  height: 0.32rem;
  border-radius: 999px;
  background: #c8d5e8;
}

.portal-design-sample span::before {
  top: 30%;
}

.portal-design-sample span::after {
  top: 54%;
  background: var(--accent);
}

.portal-design-sample-mikrotik_classic {
  background:
    linear-gradient(135deg, hsla(236, 0%, 54%, 1) 0%, transparent 70%),
    linear-gradient(25deg, hsla(221, 35%, 27%, 1) 10%, transparent 80%),
    linear-gradient(315deg, hsla(46, 37%, 84%, 1) 15%, transparent 80%),
    linear-gradient(245deg, hsla(191, 51%, 56%, 1) 100%, transparent 70%);
}

.portal-design-sample-mikrotik_classic span {
  inset: 18% 22%;
  background: transparent;
  box-shadow: none;
}

.portal-design-sample-mikrotik_classic span::before,
.portal-design-sample-mikrotik_classic span::after {
  background: rgba(255, 255, 255, 0.72);
}

.portal-design-sample-centered_card {
  background: linear-gradient(160deg, #edf4fb 0%, #d9e7f3 52%, #f8fbff 100%);
}

.portal-design-sample-venue_welcome {
  background: linear-gradient(90deg, #14293a 0 42%, #f8fafc 42% 100%);
}

.portal-design-sample-venue_welcome span {
  inset: 22% 11% 18% 52%;
  border-radius: 0.32rem;
}

.portal-design-sample-venue_welcome::before {
  content: "";
  position: absolute;
  inset: 24% 64% 40% 13%;
  border-radius: 999px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.82) 0 0) 0 0 / 100% 0.32rem no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.48) 0 0) 0 0.75rem / 72% 0.26rem no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.36) 0 0) 0 1.35rem / 86% 0.26rem no-repeat;
}

.portal-background-sample {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--border) 72%, transparent);
  border-radius: 0.85rem;
  background: var(--surface-soft);
}

.portal-background-sample-none {
  background:
    linear-gradient(135deg, rgba(148, 163, 184, 0.18) 0 25%, transparent 25% 50%, rgba(148, 163, 184, 0.18) 50% 75%, transparent 75%),
    #ffffff;
  background-size: 1rem 1rem, auto;
}

.portal-background-sample-beach_resort {
  background: linear-gradient(160deg, #7fd3eb 0%, #bfe8ef 45%, #f7dba7 46%, #dca36b 100%);
}

.portal-background-sample-ocean_cliff {
  background: linear-gradient(145deg, #114a66 0%, #2f88a2 48%, #d8e9de 49%, #7f8b68 100%);
}

.portal-background-sample-mountain_lake {
  background: linear-gradient(145deg, #193954 0%, #5c8391 45%, #dfe8df 46%, #274433 100%);
}

.portal-background-sample-city_night {
  background: linear-gradient(155deg, #0b1220 0%, #1d3558 48%, #f4b661 50%, #111827 100%);
}

.portal-background-sample-cafe {
  background: linear-gradient(150deg, #55351f 0%, #a0663a 48%, #efe0c5 49%, #3f2a1f 100%);
}

.portal-background-sample-business_lounge {
  background: linear-gradient(150deg, #1d2938 0%, #64748b 44%, #e2e8f0 45%, #f8fafc 100%);
}

.field-checkbox-grid-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.portal-theme-copy {
  display: grid;
  gap: 0.28rem;
  min-width: 0;
}

.portal-theme-copy strong {
  color: var(--text);
}

.portal-theme-copy span {
  color: var(--text-muted);
  line-height: 1.35;
}

.portal-font-sample {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-soft);
  color: var(--accent-strong);
  font-size: 1.2rem;
  font-weight: 800;
}

.portal-font-sample-classic {
  font-family: sans-serif, Arial;
}

.portal-font-sample-modern {
  font-family: "Segoe UI", Roboto, Arial, sans-serif;
}

.portal-font-sample-rounded {
  font-family: "Trebuchet MS", Verdana, Arial, sans-serif;
}

.guided-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  padding-top: 0.15rem;
}

.guided-action-group {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.65rem;
}

.guided-action-group form {
  display: inline-flex;
}

.portal-conditional-field[hidden] {
  display: none !important;
}

.html-preview-code {
  overflow: auto;
  max-height: 68vh;
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background: #0b1220;
  color: #dbeafe;
  font-size: 0.84rem;
  line-height: 1.55;
  white-space: pre-wrap;
}

.status-not_tested,
.status-unknown {
  background: var(--warning-soft);
  color: #a16207;
}

.status-reachable,
.status-healthy,
.status-active,
.status-available {
  background: var(--success-soft);
  color: #166534;
}

.status-managed {
  background: var(--bg-accent);
  color: var(--accent-strong);
}

.status-accent {
  background: var(--bg-accent);
  color: var(--accent-strong);
}

.status-success {
  background: var(--success-soft);
  color: #166534;
}

.status-warning {
  background: var(--warning-soft);
  color: #92400e;
}

.status-sky {
  background: var(--sky-soft);
  color: #1d4ed8;
}

.status-used {
  background: var(--sky-soft);
  color: #1d4ed8;
}

.status-unreachable,
.status-disabled,
.status-locked,
.status-expired {
  background: var(--danger-soft);
  color: #b91c1c;
}

.status-degraded {
  background: #ffedd5;
  color: #c2410c;
}

.alert {
  padding: 0.95rem 1.05rem;
  border-radius: 1rem;
  border: 1px solid transparent;
}

.alert-success {
  background: var(--success-soft);
  border-color: #bbf7d0;
  color: #166534;
}

.alert-warning {
  background: #ffedd5;
  border-color: #fed7aa;
  color: #c2410c;
}

.alert-error,
.alert-danger {
  background: var(--danger-soft);
  border-color: #fecaca;
  color: #b91c1c;
}

.alert-info {
  background: var(--sky-soft);
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.metric-card-accent {
  background: #ffffff;
  border-top-color: var(--accent);
}

.metric-card-success {
  background: #ffffff;
  border-top-color: #16a34a;
}

.metric-card-sky {
  background: #ffffff;
  border-top-color: #2563eb;
}

.metric-card-neutral {
  background: #ffffff;
  border-top-color: #64748b;
}

.metric-card-warning {
  background: #ffffff;
  border-top-color: #d97706;
}

@media (max-width: 1180px) {
  .grid-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .content-grid,
  .content-grid-equal,
  .server-details-grid,
  .traffic-grid,
  .portal-design-layout,
  .dashboard-primary-grid,
  .dashboard-activity-layout,
  .dashboard-secondary-grid,
  .kv-grid {
    grid-template-columns: 1fr;
  }

  .readiness-row {
    grid-template-columns: 1fr;
  }

  .readiness-value {
    justify-self: start;
  }

  .dashboard-hero {
    grid-template-columns: 1fr;
  }

  .ops-hero {
    grid-template-columns: 1fr;
  }

  .dashboard-hero-meta {
    justify-items: start;
  }

  .hero-highlight-grid {
    grid-template-columns: 1fr;
  }

  .theme-selection-header {
    display: grid;
  }

  .font-size-toggle-label {
    text-align: left;
  }

  .portal-preview-card {
    position: static;
  }

  .portal-preview-action-bar {
    position: sticky;
    bottom: 0.75rem;
    z-index: 4;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.16);
  }

  .portal-preview-frame-shell {
    height: min(82vh, 58rem);
    min-height: 34rem;
  }

  .voucher-next-card {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .voucher-next-card .panel-actions {
    justify-content: flex-start;
  }

  .voucher-next-details {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .record-filter-form,
  .record-filter-actions,
  .record-list-kv-row,
  .accounting-device-card {
    grid-template-columns: 1fr;
  }

  .voucher-next-details {
    grid-template-columns: 1fr;
  }
}

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

  .shell-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: min(20rem, calc(100vw - 3rem));
    transform: translateX(-100%);
    transition: transform 180ms ease;
    z-index: 40;
  }

  .sidebar-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    opacity: 0;
    pointer-events: none;
    background: rgba(15, 23, 42, 0.25);
    border: 0;
    transition: opacity 180ms ease;
    z-index: 30;
  }

  .sidebar-open .shell-sidebar {
    transform: translateX(0);
  }

  .sidebar-open .sidebar-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  .sidebar-toggle {
    display: inline-flex;
  }

  .page-header,
  .shell-topbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .page-header-meta {
    align-items: flex-start;
  }

  .ops-hero-aside {
    width: 100%;
  }
}

@media (max-width: 680px) {
  .page-wrap,
  .shell-topbar {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .grid-cards,
  .form-grid,
  .field-checkbox-grid,
  .field-checkbox-grid-two,
  .traffic-stats,
  .license-breakdown-grid,
  .voucher-card-qr-grid,
  .voucher-sheet-grid {
    grid-template-columns: 1fr;
  }

  .resource-actions,
  .resource-actions form,
  .resource-actions .button,
  .table-actions,
  .table-actions form,
  .table-actions .button {
    width: 100%;
  }

  .shell-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .shell-breadcrumb,
  .summary-row,
  .mode-card,
  .resource-card,
  .reference-header,
  .hero-chip-row,
  .section-nav-header,
  .traffic-toolbar,
  .traffic-chart-meta {
    flex-direction: column;
    align-items: flex-start;
  }

  .kv-row {
    grid-template-columns: 1fr;
    gap: 0.25rem;
  }

  .metric-visual {
    align-items: flex-start;
    flex-direction: column;
  }

  .metric-spark {
    width: 100%;
    justify-content: flex-start;
  }

  .portal-guided-form,
  .portal-guided-form .page-tabs,
  .portal-guided-form .tab-panel.is-active {
    gap: 1rem;
  }

  .guided-section {
    padding: 1rem;
  }

  .guided-advanced-block {
    padding: 0.95rem;
  }
}

@media print {
  body {
    background: #ffffff;
  }

  .shell-sidebar,
  .shell-topbar,
  .page-header-meta,
  .shell-footer,
  .alert,
  .panel-actions {
    display: none !important;
  }

  .shell {
    display: block;
  }

  .shell-main,
  .page-wrap {
    display: block;
    padding: 0;
  }

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

  .panel {
    border: 0;
    box-shadow: none;
    padding: 0;
  }

  .voucher-sheet-page {
    border: 0;
    border-radius: 0;
    padding: 0;
    break-after: page;
    page-break-after: always;
  }

  .voucher-sheet-page:last-child {
    break-after: auto;
    page-break-after: auto;
  }

  .voucher-sheet-grid {
    gap: 0.42rem;
  }

  .voucher-sheet-card,
  .voucher-card-print {
    break-inside: avoid;
    page-break-inside: avoid;
  }
}

.input-field-inline {
  min-width: 220px;
  width: 100%;
}

.auth-shell {
  margin: 0;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 4vw, 2.5rem);
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.8) 0 1px, transparent 1.4px),
    radial-gradient(circle at 10% 10%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 40%),
    radial-gradient(circle at 90% 20%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 46%),
    linear-gradient(160deg, var(--page-gradient-top), var(--page-gradient-mid));
  background-size: 18px 18px, auto, auto, auto;
  color: var(--text);
}

.auth-main {
  width: min(460px, 100%);
  display: grid;
  justify-items: center;
  gap: 1.05rem;
}

.auth-logo-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 5.4rem;
  min-height: 4rem;
}

.auth-logo-image {
  display: block;
  width: auto;
  max-width: min(15rem, 70vw);
  max-height: 5.2rem;
  object-fit: contain;
  border-radius: 0.55rem;
  filter: drop-shadow(0 12px 20px rgba(15, 23, 42, 0.15));
}

.auth-logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4.4rem;
  height: 4.4rem;
  border-radius: 1.1rem;
  background: linear-gradient(135deg, var(--accent-strong), var(--accent));
  color: #ffffff;
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  box-shadow: 0 18px 32px rgba(15, 23, 42, 0.18);
}

.auth-card {
  width: 100%;
  padding: clamp(1.25rem, 3.2vw, 2rem);
  border-radius: 1.35rem;
}

.auth-card-intro {
  text-align: center;
  display: grid;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}

.auth-title {
  margin: 0;
  color: var(--accent-strong);
  font-size: clamp(1.8rem, 4vw, 2.25rem);
  line-height: 1.05;
}

.auth-subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.45;
}

.auth-form {
  margin-top: 0.75rem;
}

.auth-actions {
  margin-top: 0.5rem;
}

.auth-actions .button {
  width: 100%;
  justify-content: center;
  min-height: 3rem;
}

.auth-footer {
  color: var(--text-muted);
  font-size: 0.86rem;
  display: grid;
  gap: 0.2rem;
  justify-items: center;
  text-align: center;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
