@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800;900&family=Lato:wght@400;700;900&family=Merriweather:wght@400;700;900&family=Montserrat:wght@400;700;900&family=Open+Sans:wght@400;700;800&family=Oswald:wght@400;700&family=Playfair+Display:wght@400;700;900&family=Poppins:wght@400;700;900&family=Roboto:wght@400;700;900&display=swap");

:root {
  font-family: Inter, system-ui, sans-serif;
  color-scheme: dark;
  --bg: #090b10;
  --panel: #111620;
  --panel-2: #151b26;
  --panel-3: #1b2431;
  --text: #f4f7fb;
  --muted: #8d9aad;
  --line: rgba(255, 255, 255, 0.09);
  --brand: #8db7ff;
  --heading: #dbe7ff;
  --brand-2: #b6c7ff;
  --brand-soft: rgba(141, 183, 255, 0.13);
  --warn: #ffd166;
  --danger: #ff6b6b;
  --ok: #51cf66;
  --radius: 7px;
  --shadow: 0 14px 34px rgba(0, 0, 0, 0.22);
  --shadow-soft: 0 1px 0 rgba(255, 255, 255, 0.04), 0 12px 28px rgba(0, 0, 0, 0.18);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at 20% 0%, rgba(141, 183, 255, 0.07), transparent 28%),
    linear-gradient(180deg, #0b0e14 0%, var(--bg) 36%);
  color: var(--text);
  font-size: 13px;
  letter-spacing: 0;
}

.auth-split {
  width: min(900px, 100%);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.install-card {
  width: min(520px, 100%);
}

.wide {
  width: 100%;
}

.admin-page {
  display: grid;
  gap: 18px;
}

.admin-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(420px, 1.15fr);
  gap: 18px;
  align-items: stretch;
  padding: 18px;
  border: 1px solid rgba(141, 183, 255, 0.18);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(141, 183, 255, 0.12), transparent 45%),
    rgba(255, 255, 255, 0.025);
  box-shadow: var(--shadow-soft);
}

.admin-hero h1 {
  margin: 4px 0 6px;
  font-size: clamp(28px, 4vw, 46px);
}

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

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

.admin-section .admin-list-title {
  margin-top: 0;
}

.admin-create-card {
  border-color: rgba(141, 183, 255, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.018));
}

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

.admin-shortcut-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  border-color: rgba(141, 183, 255, 0.18);
  transition: border-color 0.15s;
}

.admin-shortcut-card:hover {
  border-color: rgba(141, 183, 255, 0.45);
}

.admin-shortcut-card strong {
  font-size: 28px;
  font-weight: 800;
  color: var(--text);
}

.admin-shortcut-card span {
  font-size: 12px;
  color: var(--muted);
}

.plan-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
  margin-bottom: 20px;
}

.plan-card {
  cursor: pointer;
  transition: box-shadow 0.15s;
  border: 2px solid transparent;
}

.plan-card:hover {
  box-shadow: 0 2px 12px rgba(0,0,0,0.10);
}

.plan-card-selected {
  border-color: var(--accent);
}

.plan-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}

.plan-card-price {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 2px;
}

.plan-card-price small {
  font-size: 13px;
  font-weight: 400;
  color: var(--text-muted);
}

.plan-card-slug,
.plan-card-subs {
  font-size: 12px;
  margin-bottom: 2px;
}

.plan-feat-grid {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.plan-feat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 13px;
}

.myplan-meta-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.myplan-meta-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.myplan-feat-list {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}

.myplan-feat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 13px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--line);
  gap: 12px;
}

.myplan-feat-row:last-child {
  border-bottom: none;
}

.admin-table-head,
.admin-table-row {
  grid-template-columns: 1.4fr 1fr .62fr .62fr 1.25fr;
  gap: 8px;
  padding: 7px 10px;
}

.admin-approval-head,
.admin-approval-row {
  grid-template-columns: 1.5fr 1fr 0.7fr 220px;
  gap: 10px;
}

.admin-table-row input,
.admin-table-row select {
  width: 100%;
  min-height: 28px;
  padding: 4px 7px;
  font-size: 11px;
}

.small-checkbox-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--muted);
  cursor: pointer;
  white-space: nowrap;
}

.small-checkbox-label input { width: 14px; height: 14px; accent-color: var(--brand); flex-shrink: 0; }

.admin-account-cell {
  display: grid;
  gap: 6px;
}

.admin-account-cell small {
  color: var(--muted);
  font-size: 11px;
}

.admin-teams-head,
.admin-teams-row {
  grid-template-columns: 1.4fr .7fr .48fr 150px;
  gap: 8px;
  padding: 7px 10px;
}

.admin-teams-row {
  align-items: start;
}

.admin-teams-row input,
.admin-teams-row select {
  width: 100%;
  min-height: 28px;
  padding: 4px 7px;
  font-size: 11px;
}

.admin-table .row-actions,
.admin-teams-table .row-actions {
  gap: 6px;
}

.admin-table .small-button,
.admin-teams-table .small-button {
  min-height: 27px;
  padding: 0 7px;
  font-size: 11px;
}

.admin-list-title {
  margin-top: 18px;
  margin-bottom: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}

.compact-admin-table {
  box-shadow: none;
}

.compact-admin-table .table-head {
  padding: 8px 10px;
  font-size: 11px;
}

.compact-admin-table .row-actions {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}

.compact-admin-table .row-actions input[type="password"] {
  max-width: 120px;
}

.admin-team-members {
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.025);
}

.admin-team-members strong {
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
}

.admin-member-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.admin-member-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 26px;
  padding: 3px 7px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel-2);
  font-size: 12px;
}

.admin-member-pill em {
  color: var(--muted);
  font-style: normal;
}

.admin-member-pill button {
  min-width: 20px;
  min-height: 20px;
  padding: 0;
  border-color: rgba(255, 107, 107, 0.35);
  background: rgba(255, 107, 107, 0.12);
  color: #ffa8a8;
}

.admin-inline-add {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 120px auto;
  gap: 8px;
}

.admin-inline-add select {
  min-height: 30px;
  padding: 5px 8px;
  font-size: 12px;
}

.team-switcher {
  min-width: 180px;
  display: grid;
  gap: 4px;
}

.team-switcher span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.team-switcher select {
  height: 42px;
}

.admin-title {
  align-items: end;
}

.admin-metrics {
  margin-bottom: 18px;
}

.admin-create-grid {
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 16px;
  align-items: start;
}

.admin-workspace-panel {
  display: grid;
  grid-template-columns: 1fr minmax(220px, 320px);
  gap: 16px;
  align-items: end;
  margin-bottom: 18px;
}

.compact-title {
  margin: 0 0 12px;
}

.compact-title h2 {
  font-size: 18px;
}

.compact-form {
  gap: 10px;
}

.compact-form label span {
  font-size: 12px;
}

@media (max-width: 980px) {
  .admin-create-grid,
  .admin-workspace-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 880px) {
  .auth-split {
    grid-template-columns: 1fr;
  }
}

[hidden] {
  display: none !important;
}

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

button {
  cursor: pointer;
}

.login-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at 50% 20%, rgba(0, 116, 253, 0.16), transparent 34%),
    var(--bg);
}

.login-card {
  width: min(420px, 100%);
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow);
  display: grid;
  gap: 16px;
  text-align: center;
}

.login-logo {
  width: 118px;
  height: 118px;
  margin: 0 auto 4px;
  border-radius: 24px;
  object-fit: cover;
  border: 1px solid rgba(0, 116, 253, 0.28);
}

.login-card h1 {
  margin: 0;
}

.login-card p {
  margin: -10px 0 8px;
  color: var(--muted);
}

.login-card label {
  text-align: left;
}

.login-options {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.remember-user {
  display: flex;
  align-items: center;
  gap: 8px;
}

.remember-user input {
  width: 16px;
  min-height: 16px;
}

.remember-user span {
  margin: 0;
}

.link-button {
  border: 0;
  background: transparent;
  color: var(--brand);
  font-weight: 800;
  padding: 0;
}

.login-error {
  padding: 10px 12px;
  border: 1px solid rgba(255, 107, 107, 0.35);
  border-radius: var(--radius);
  background: rgba(255, 107, 107, 0.12);
  color: #ffa8a8;
  font-size: 13px;
  font-weight: 700;
}

.login-reset {
  padding: 10px 12px;
  border: 1px solid rgba(0, 116, 253, 0.35);
  border-radius: var(--radius);
  background: rgba(0, 116, 253, 0.1);
  color: var(--brand);
  font-size: 13px;
  font-weight: 700;
}

.app-shell {
  display: grid;
  grid-template-columns: 248px 1fr;
  height: 100vh;
  overflow: hidden;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 18px 16px;
  border-right: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(17, 22, 32, 0.98), rgba(9, 11, 16, 0.98));
  display: flex;
  flex-direction: column;
  gap: 18px;
  overflow-y: auto;
}

.sidebar-workspace-block {
  padding: 10px 14px 14px;
  border-top: 1px solid var(--line);
  margin-top: 8px;
}

.sidebar-workspace-label {
  display: block;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .7px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
}

.sidebar-workspace-block .team-card {
  margin: 0;
}

.sidebar-bottom {
  margin-top: auto;
  display: grid;
  gap: 12px;
}

.sidebar-profile-button {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  border-radius: var(--radius);
  padding: 10px;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  text-align: left;
}

.sidebar-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: var(--panel-2);
  color: var(--brand);
  border: 1px solid rgba(56, 217, 169, 0.3);
}

.sidebar-avatar img {
  width: 100%;
  height: 100%;
}

.sidebar-profile-text {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.sidebar-profile-text strong,
.sidebar-profile-text small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-profile-text small {
  color: var(--muted);
  font-size: 12px;
}

.brand {
  display: flex;
  align-items: center;
}

.brand-full-logo {
  display: block;
  width: 100%;
  max-width: 172px;
  height: auto;
}

.brand span,
.team-card span,
.eyebrow,
.muted {
  color: var(--muted);
}

.brand span,
.team-card span {
  display: block;
  font-size: 13px;
  margin-top: 2px;
}

.nav-list {
  display: grid;
  gap: 4px;
}

.nav-badge {
  margin-left: auto;
  background: #00d4c8;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  padding: 2px 6px;
  border-radius: 20px;
  min-width: 18px;
  text-align: center;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  background: transparent;
  color: var(--muted);
  text-align: left;
}

.nav-item svg,
.primary-button svg,
.ghost-button svg,
.search svg,
.icon-button svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
  flex: 0 0 auto;
}

.nav-item.active,
.nav-item:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.045);
  border-color: var(--line);
}

.nav-divider {
  height: 1px;
  background: var(--line);
  margin: 6px 0;
  opacity: 0.5;
}

.team-card {
  position: relative;
  min-height: 42px;
  padding: 7px 34px 7px 8px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.028);
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  transition: border-color 0.16s ease, background 0.16s ease;
}

.team-card:hover {
  border-color: rgba(105, 164, 255, 0.34);
  background: rgba(255, 255, 255, 0.045);
}

.team-card strong {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-size: 12px;
  font-weight: 650;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workspace-switcher-icon {
  width: 28px;
  height: 28px;
  margin: 0;
  border: 1px solid rgba(105, 164, 255, 0.23);
  border-radius: 7px;
  background: rgba(56, 139, 253, 0.1);
  color: #79afff !important;
  display: grid !important;
  place-items: center;
  font-size: 10px !important;
  font-weight: 750;
}

.workspace-switcher-chevron {
  position: absolute;
  right: 11px;
  top: 50%;
  margin: 0;
  color: var(--muted);
  font-size: 15px !important;
  transform: translateY(-56%);
}

.team-card select {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.single-link-editor {
  display: grid;
  gap: 8px;
}

.single-link-editor > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
}

.single-link-add {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.single-link-value {
  min-width: 0;
  padding: 7px 8px 7px 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.025);
  display: grid;
  grid-template-columns: minmax(0, 1fr) 30px;
  align-items: center;
  gap: 8px;
}

.single-link-value a {
  overflow: hidden;
  color: var(--brand);
  font-size: 12px;
  text-decoration: none;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 5;
  min-height: 72px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--line);
  background: rgba(9, 11, 16, 0.78);
  backdrop-filter: blur(18px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.eyebrow {
  margin: 0 0 4px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: 0;
  font-size: clamp(22px, 2.4vw, 30px);
  color: var(--heading);
}

h2 {
  font-size: 18px;
  color: var(--heading);
}

h3 {
  font-size: 14px;
  color: var(--heading);
}

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

.language-picker {
  position: relative;
  flex: 0 0 auto;
}

.language-current,
.language-menu button {
  width: 36px;
  height: 36px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  display: inline-grid;
  place-items: center;
  font-size: 18px;
  line-height: 1;
  filter: saturate(0.9);
}

.language-current:hover,
.language-menu button:hover {
  border-color: rgba(141, 183, 255, 0.55);
  background: rgba(141, 183, 255, 0.12);
  filter: saturate(1);
}

.language-menu {
  position: absolute;
  z-index: 100;
  top: calc(100% + 7px);
  right: 0;
  padding: 5px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #151a23;
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.38);
  display: flex;
  gap: 4px;
}

.language-menu[hidden],
.language-menu button[hidden] {
  display: none;
}

.language-menu button {
  width: 34px;
  height: 32px;
  border-color: transparent;
  background: transparent;
}

.language-current:focus-visible,
.language-menu button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
}

.search {
  width: min(330px, 32vw);
  height: 38px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 0 12px;
  color: var(--muted);
}

.search input {
  min-width: 0;
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
}

.primary-button,
.ghost-button,
.icon-button {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--text);
  background: var(--panel-2);
}

.primary-button {
  min-height: 31px;
  padding: 0 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border-color: rgba(141, 183, 255, 0.48);
  background: linear-gradient(180deg, #a8c8ff, #75a5ff);
  color: #07111f;
  font-size: 12px;
  font-weight: 800;
}

.ghost-button {
  min-width: 38px;
  min-height: 31px;
  padding: 0 9px;
  background: rgba(255, 255, 255, 0.035);
  font-size: 12px;
}

.danger-button {
  border-color: rgba(255, 107, 107, 0.35);
  color: #ffa8a8;
}

.icon-button {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
}

.content {
  padding: 22px;
  padding-bottom: 60px;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}

.grid {
  display: grid;
  gap: 13px;
}

.grid.cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.grid.cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.dashboard-stack {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 13px;
}

.card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.025));
  box-shadow: var(--shadow-soft);
}

.card.pad {
  padding: 14px;
}

.metric {
  min-height: 108px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.metric strong {
  display: block;
  font-size: 24px;
}

.metric span,
.small {
  color: var(--muted);
  font-size: 13px;
}

.dashboard-view {
  font-size: 14px;
}

.dashboard-view .card.pad {
  padding: 14px;
}

.dashboard-view .metric {
  min-height: 108px;
}

.dashboard-view .metric strong {
  font-size: 24px;
}

.dashboard-view .metric span,
.dashboard-view .metric em,
.dashboard-view .muted,
.dashboard-view .small {
  font-size: 12px;
}

.dashboard-view .section-title {
  margin: 18px 0 10px;
}

.dashboard-view .section-title h2 {
  font-size: 18px;
}

.dashboard-view .table-row,
.dashboard-view .table-head {
  gap: 10px;
  padding: 10px 12px;
}

.dashboard-view .table-row {
  font-size: 13px;
}

.dashboard-view .badge {
  min-height: 22px;
  padding: 3px 8px;
  font-size: 11px;
}

.dashboard-achievements-title {
  margin-top: 24px;
}

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

.achievement-card {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 6px;
  min-height: 96px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025));
}

.achievement-card span,
.achievement-card em {
  position: relative;
  z-index: 1;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.achievement-card strong {
  position: relative;
  z-index: 1;
  font-size: 26px;
  line-height: 1;
}

.achievement-bookings {
  --achievement-glow: rgba(245, 158, 11, 0.22);
}
.achievement-social {
  --achievement-glow: rgba(236, 72, 153, 0.2);
}

.achievement-tracks {
  --achievement-glow: rgba(99, 102, 241, 0.24);
}

.achievement-releases {
  --achievement-glow: rgba(81, 207, 102, 0.2);
}

.achievement-mail {
  --achievement-glow: rgba(249, 115, 22, 0.22);
}

.dashboard-view .timeline {
  gap: 8px;
}

.dashboard-view .timeline-item {
  grid-template-columns: 70px 1fr;
  gap: 10px;
  padding: 10px;
  font-size: 13px;
}

.section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 20px 0 10px;
}

.section-title:first-child {
  margin-top: 0;
}

.section-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.segmented {
  display: inline-flex;
  min-height: 31px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
}

.segmented button {
  min-width: 54px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.segmented button.active {
  background: #eef4ff;
  color: #101826;
}

.table {
  max-height: 520px;
  overflow: auto;
  border-radius: var(--radius);
}

.table .table-head {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--panel);
}

.table-row,
.table-head {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 0.8fr;
  gap: 11px;
  align-items: center;
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
}

.admin-accounts-head,
.admin-accounts-row {
  grid-template-columns: 0.9fr 1fr 1.4fr 0.9fr 0.65fr 0.65fr 32px;
  gap: 8px;
  padding: 7px 10px;
}

.admin-workspaces-head,
.admin-workspaces-row {
  grid-template-columns: 1.6fr 0.8fr 0.5fr 0.7fr 32px;
  gap: 8px;
  padding: 7px 10px;
}

.billing-invoice-table-head,
.billing-invoice-table-row {
  grid-template-columns: 1.2fr 1.2fr 1fr 0.9fr 0.9fr;
  gap: 8px;
  padding: 7px 10px;
}

.table-row:last-child {
  border-bottom: 0;
}

.table-row {
  transition: background 0.14s ease, border-color 0.14s ease;
}

.clickable-row:hover,
.table-row:hover {
  background: rgba(255, 255, 255, 0.035);
}

.selected-row {
  background: rgba(141, 183, 255, 0.11);
}

.table-head {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.sort-heading {
  min-width: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: left;
  text-transform: inherit;
}

.sort-heading:hover {
  color: var(--text);
}

.table-row-actions,
.table-head-actions {
  grid-template-columns: 1.35fr 0.9fr 1fr 0.8fr 92px;
}

.receipts-grid .table-head,
.receipts-grid .table-row {
  grid-template-columns: 96px minmax(0, 1.5fr) minmax(0, 1fr) minmax(0, 0.9fr) 60px 96px;
}

.mileage-grid .table-head,
.mileage-grid .table-row {
  grid-template-columns: 96px minmax(0, 1.7fr) 90px minmax(0, 1fr) 72px minmax(0, 0.9fr) 96px;
}

.receipts-grid .table-row > span,
.mileage-grid .table-row > span {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.demo-tracks-head,
.demo-tracks-row {
  grid-template-columns: 40px 1.4fr 0.9fr 0.75fr 0.5fr 0.65fr;
  border-left: 3px solid transparent;
}
.demo-tracks-row.track-demo         { border-left-color: #94a3b8; }
.demo-tracks-row.track-production   { border-left-color: #7dd3fc; }
.demo-tracks-row.track-recording    { border-left-color: #f9a8d4; }
.demo-tracks-row.track-mix          { border-left-color: #5eead4; }
.demo-tracks-row.track-master       { border-left-color: #c4b5fd; }
.demo-tracks-row.track-revision     { border-left-color: #fdba74; }
.demo-tracks-row.track-label-check  { border-left-color: #fde047; }
.demo-tracks-row.track-ready        { border-left-color: #86efac; }

.contact-table-head,
.contact-table-row {
  grid-template-columns: 1fr 1fr 1fr 0.85fr 1fr;
}

.promo-table-head,
.promo-table-row {
  grid-template-columns: 1.15fr 0.8fr 1fr 0.75fr;
}

.promo-template-table-head,
.promo-template-table-row {
  grid-template-columns: 1.4fr 0.9fr 0.6fr;
}

.release-table-head,
.release-table-row {
  grid-template-columns: 1.2fr 0.8fr 1fr 0.8fr;
}

.release-title-cell {
  display: flex;
  align-items: center;
  min-width: 0;
  gap: 10px;
}

.release-title-cell strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.release-cover-thumb {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  border: 1px solid var(--line);
  border-radius: 5px;
  background: var(--panel-3);
  object-fit: cover;
}

.release-cover-detail {
  display: block;
  width: min(240px, 100%);
  aspect-ratio: 1;
  border-radius: var(--radius);
  object-fit: cover;
}

.uploaded-image-placeholder {
  display: block;
  background:
    linear-gradient(135deg, transparent 46%, var(--line) 47%, var(--line) 53%, transparent 54%),
    var(--panel-3);
}

.release-promo-template-picker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}

.release-promo-template-picker .mail-template-card {
  display: grid;
  min-height: 92px;
  gap: 6px;
  align-content: center;
  text-align: left;
}

.release-promo-template-picker span {
  color: var(--muted);
  font-size: 12px;
}

.search-table-head,
.search-table-row {
  grid-template-columns: 0.8fr 1.2fr 1.6fr 120px;
}

.label-check-table-head,
.label-check-table-row {
  grid-template-columns: 1.2fr 0.85fr 1fr 0.8fr;
}

.social-posts-head,
.social-posts-row {
  grid-template-columns: 24px 1.15fr 1.15fr 0.85fr 0.9fr 0.7fr;
}

.social-select-cell {
  display: flex;
  justify-content: center;
  align-items: center;
}

.premium-row-checkbox {
  width: 13px;
  height: 13px;
  min-height: 13px;
  padding: 0;
  margin: 0;
  accent-color: var(--brand);
  opacity: 0.78;
  cursor: pointer;
}

.premium-row-checkbox:hover,
.premium-row-checkbox:checked {
  opacity: 1;
}

.social-bulk-bar,
.invoice-archive-filter {
  display: flex;
  align-items: end;
  gap: 10px;
  flex-wrap: wrap;
}

.social-bulk-bar select,
.invoice-archive-filter label {
  max-width: 220px;
}

.invoice-download-page {
  break-after: page;
  margin-bottom: 28px;
}

.calendar-items-table {
  max-height: 472px;
  overflow-y: auto;
}

.invoices-table {
  max-height: 472px;
  overflow-y: auto;
}

.invoice-table-head,
.invoice-table-row {
  grid-template-columns: 0.9fr 1fr 1fr 0.8fr;
}

.invoice-table-head {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--panel);
}

.contracts-table {
  max-height: 472px;
  overflow-y: auto;
}

.contracts-table-head,
.contracts-table-row {
  grid-template-columns: 1.25fr 1fr 0.7fr 0.9fr 0.8fr 180px;
}

.contracts-table-head {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--panel);
}

.calendar-items-head,
.calendar-items-row {
  grid-template-columns: 0.9fr 1.25fr 0.85fr 1fr 0.75fr;
}

.bookings-table-head,
.bookings-table-row {
  grid-template-columns: 1.15fr 0.75fr 0.75fr 0.8fr 1.2fr 0.75fr;
}

.booking-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 0.9fr);
  gap: 16px;
  align-items: start;
}

.booking-map-card {
  min-height: 420px;
}

.booking-map-card iframe {
  width: 100%;
  min-height: 330px;
  border: 0;
  border-radius: var(--radius);
  background: var(--panel-2);
}

.booking-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 16px;
  margin-bottom: 12px;
}

.booking-filter-chips button {
  min-height: 22px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.026);
  color: var(--text);
  font-size: 10.5px;
  font-weight: 800;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}

.booking-filter-chips button.active {
  border-color: var(--brand);
  background: var(--brand);
  color: #061018;
}

.booking-filter-chips .booking-type-alle { border-color: rgba(255,255,255,.2); }
.booking-filter-chips .booking-type-alle.active { background: rgba(255,255,255,.85); border-color: rgba(255,255,255,.85); color: #061018; }

.booking-filter-chips .booking-type-liveact { border-color: rgba(0,116,253,.5); }
.booking-filter-chips .booking-type-liveact.active { background: #0074fd; border-color: #0074fd; color: #fff; }

.booking-filter-chips .booking-type-dj-set { border-color: rgba(99,102,241,.5); }
.booking-filter-chips .booking-type-dj-set.active { background: #6366f1; border-color: #6366f1; color: #fff; }

.booking-filter-chips .booking-type-meeting { border-color: rgba(99,102,241,.5); }
.booking-filter-chips .booking-type-meeting.active { background: #6366f1; border-color: #6366f1; color: #fff; }

.booking-filter-chips .booking-type-studio { border-color: rgba(14,165,233,.5); }
.booking-filter-chips .booking-type-studio.active { background: #0ea5e9; border-color: #0ea5e9; color: #fff; }

.booking-filter-chips .booking-type-fotoshoot { border-color: rgba(244,114,182,.5); }
.booking-filter-chips .booking-type-fotoshoot.active { background: #f472b6; border-color: #f472b6; color: #fff; }

.booking-filter-chips .booking-type-other { border-color: rgba(148,163,184,.5); }
.booking-filter-chips .booking-type-other.active { background: #94a3b8; border-color: #94a3b8; color: #fff; }

.calendar-item-picker {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.calendar-item-picker button {
  min-height: 56px;
}

.inline-release-planner {
  margin-top: 12px;
}

.linked-track-list {
  display: grid;
  gap: 9px;
}

.linked-track-card {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--text);
  background: rgba(255, 255, 255, 0.025);
  text-align: left;
}

.linked-track-card span,
.linked-track-card small {
  display: block;
  color: var(--muted);
  margin-top: 3px;
}

.inline-file-upload {
  padding: 0;
  border: 0;
  background: transparent;
}

.calendar-items-head {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--panel);
}

.row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.promo-send-report {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.promo-send-report-block {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.03);
  padding: 12px;
}

.promo-send-report-block > div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--text);
}

.promo-send-report-block span,
.promo-send-report-block p,
.promo-send-report-block li {
  color: var(--muted);
}

.promo-send-report-block p {
  margin: 6px 0 0;
}

.promo-send-report-block ul {
  margin: 8px 0 0;
  padding-left: 18px;
}

.promo-send-report-block li + li {
  margin-top: 4px;
}

.item-title {
  color: var(--text);
  font-weight: 760;
}

.small-button {
  min-height: 26px;
  padding: 0 7px;
  font-size: 11px;
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 22px;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--panel-3);
  color: var(--text);
  font-size: 11px;
  font-weight: 800;
}

.badge.ok {
  background: rgba(81, 207, 102, 0.16);
  color: #8ce99a;
}

.badge.draft {
  background: rgba(148, 163, 184, 0.16);
  color: #cbd5e1;
}

.badge.progress {
  background: rgba(56, 189, 248, 0.16);
  color: #7dd3fc;
}

.badge.review {
  background: rgba(251, 191, 36, 0.18);
  color: #fde68a;
}

.badge.ready {
  background: rgba(168, 85, 247, 0.18);
  color: #d8b4fe;
}

.badge.archive {
  background: rgba(100, 116, 139, 0.18);
  color: #cbd5e1;
}

.badge.warn {
  background: rgba(255, 209, 102, 0.16);
  color: #ffe08a;
}

.badge.danger {
  background: rgba(255, 107, 107, 0.16);
  color: #ffa8a8;
}

.badge.info {
  background: rgba(92, 124, 250, 0.18);
  color: #bac8ff;
}

.badge.track-demo {
  background: rgba(148, 163, 184, 0.16);
  color: #cbd5e1;
}

.badge.track-production {
  background: rgba(14, 165, 233, 0.18);
  color: #7dd3fc;
}

.badge.track-recording {
  background: rgba(236, 72, 153, 0.16);
  color: #f9a8d4;
}

.badge.track-mix {
  background: rgba(45, 212, 191, 0.16);
  color: #5eead4;
}

.badge.track-master {
  background: rgba(139, 92, 246, 0.18);
  color: #c4b5fd;
}

.badge.track-revision {
  background: rgba(249, 115, 22, 0.18);
  color: #fdba74;
}

.badge.track-label-check {
  background: rgba(234, 179, 8, 0.18);
  color: #fde047;
}

.badge.track-ready {
  background: rgba(34, 197, 94, 0.18);
  color: #86efac;
}

.badge.track-idee {
  background: rgba(100, 116, 139, 0.16);
  color: #94a3b8;
}

.badge.track-artwork {
  background: rgba(217, 70, 239, 0.16);
  color: #e879f9;
}

.badge.track-ingepland {
  background: rgba(245, 158, 11, 0.18);
  color: #fcd34d;
}

.badge.track-live {
  background: rgba(16, 185, 129, 0.18);
  color: #6ee7b7;
}

.primary-button:hover,
.ghost-button:hover,
.icon-button:hover {
  filter: brightness(1.06);
  border-color: rgba(141, 183, 255, 0.34);
}

.task-check {
  display: flex;
  align-items: center;
  gap: 9px;
}

.task-check input {
  width: 16px;
  min-height: 16px;
}

.task-done strong {
  color: var(--muted);
  text-decoration: line-through;
}

.task-checkbox-only {
  justify-content: center;
}

.task-status {
  display: grid;
  gap: 6px;
}

.task-status select {
  min-height: 34px;
}

.task-builder {
  display: grid;
  gap: 10px;
}

.task-builder > span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.task-builder-list {
  display: grid;
  gap: 8px;
}

.task-builder-row,
.task-builder-add {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px 140px 130px 96px;
  gap: 8px;
  align-items: center;
}

.task-builder-row {
  grid-template-columns: minmax(0, 1fr) minmax(130px, 0.45fr);
  grid-template-areas:
    "title title"
    "owner status"
    "date remove";
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.task-builder-row .task-check {
  grid-area: title;
  gap: 8px;
}

.task-builder-row .task-check input[type="text"] {
  min-width: 0;
  width: 100%;
  flex: 1;
}

.task-builder-row select[name="taskOwner"] {
  grid-area: owner;
}

.task-builder-row select[name="taskStatus"] {
  grid-area: status;
}

.task-builder-row input[name="taskDate"] {
  grid-area: date;
}

.task-builder-row [data-remove-task] {
  grid-area: remove;
}

.task-empty-state {
  margin: 0;
  padding: 12px 0;
}

.release-track-picker {
  display: grid;
  gap: 8px;
}

.release-title-picker {
  display: grid;
  gap: 8px;
}

.release-title-picker > span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.release-title-suggestions {
  display: grid;
  gap: 6px;
}

.release-title-suggestions button {
  display: grid;
  gap: 3px;
  width: 100%;
  min-height: 42px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  color: var(--text);
  text-align: left;
}

.release-title-suggestions button:hover {
  border-color: var(--brand);
}

.release-title-suggestions span {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
}

.release-track-picker > span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.release-track-option {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.release-track-option input {
  width: 16px;
  min-height: 16px;
}

.release-track-option span {
  margin: 0;
  color: var(--text);
}

.task-builder-add {
  grid-template-columns: minmax(0, 1fr) minmax(150px, 0.55fr);
  grid-template-areas:
    "title title"
    "status owner"
    "date button";
  align-items: stretch;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.02);
}

.task-builder-add #newTaskTitle {
  grid-area: title;
}

.task-builder-add #newTaskStatus {
  grid-area: status;
}

.task-builder-add #newTaskOwner {
  grid-area: owner;
}

.task-builder-add #newTaskDate {
  grid-area: date;
}

.task-builder-add [data-add-task] {
  grid-area: button;
  min-height: 40px;
}

.collaborator-picker {
  display: grid;
  gap: 10px;
}

.collaborator-picker > span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.collaborator-selected {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 34px;
}

.collaborator-empty {
  margin: 0;
  align-self: center;
}

.collaborator-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 28px;
  padding: 5px 9px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 999px;
  background: rgba(10, 14, 20, 0.72);
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

.collaborator-chip span {
  margin: 0;
  color: var(--muted);
}

.collaborator-suggestions {
  display: grid;
  gap: 6px;
}

.collaborator-suggestions button {
  display: grid;
  gap: 3px;
  width: 100%;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.025);
  color: var(--text);
  text-align: left;
}

.collaborator-suggestions button:hover {
  border-color: var(--brand);
}

.collaborator-suggestions span {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
}

.track-task-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.track-detail-task-layout {
  display: grid;
  grid-template-columns: minmax(340px, 0.85fr) minmax(520px, 1.15fr);
  gap: 16px;
  align-items: start;
  margin-top: 42px;
}

.track-detail-task-layout > section {
  min-width: 0;
}

.task-table-head,
.task-table-row {
  grid-template-columns: 58px minmax(160px, 1.2fr) 120px 130px 150px 96px;
}

.task-table-row {
  align-items: center;
}

.calendar {
  display: grid;
  grid-template-columns: repeat(7, minmax(120px, 1fr));
  border: 1px solid rgba(255, 255, 255, 0.075);
  border-radius: 10px;
  overflow: auto;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(255, 255, 255, 0.01));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
}

.week-calendar .day {
  min-height: 420px;
}

.calendar-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
  padding: 9px 12px !important;
  border-color: rgba(255, 255, 255, 0.075);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.012));
}

.calendar-toolbar strong {
  text-align: center;
  text-transform: capitalize;
  font-size: 13px;
}

.calendar-filters {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
  padding: 9px 12px !important;
  border-color: rgba(255, 255, 255, 0.075);
  background: rgba(255, 255, 255, 0.018);
}

.calendar-filters span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.calendar-filters button {
  min-height: 22px;
  padding: 0 9px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.026);
  color: var(--text);
  font-size: 10.5px;
  font-weight: 800;
}

.calendar-filters button.active {
  border-color: var(--brand);
  background: var(--brand);
  color: #061018;
}

.calendar-sync-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(260px, 1.5fr) auto;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}

.calendar-sync-title {
  display: flex;
  align-items: center;
  gap: 8px;
}

.calendar-sync-title h3 {
  margin: 0 0 4px;
}

.calendar-sync-card p {
  margin: 0;
}

.calendar-sync-card input {
  width: 100%;
  font-size: 12px;
}

.help-icon-button {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--muted);
  font-weight: 900;
}

.calendar-help-panel {
  display: none;
  position: absolute;
  left: 14px;
  bottom: calc(100% + 8px);
  max-width: 520px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow);
  z-index: 4;
}

.calendar-help-panel p {
  margin: 8px 0 0;
}

.calendar-sync-card:focus-within .calendar-help-panel,
.calendar-sync-card:hover .calendar-help-panel {
  display: block;
}

.chat-widget {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 30;
  display: grid;
  justify-items: end;
  gap: 10px;
}

.chat-toggle {
  min-width: 86px;
  min-height: 48px;
  border: 1px solid rgba(56, 217, 169, 0.45);
  border-radius: 999px;
  background: var(--brand);
  color: #061018;
  font-weight: 900;
  box-shadow: var(--shadow);
  position: relative;
}

.chat-toggle strong {
  position: absolute;
  top: -7px;
  right: -3px;
  min-width: 22px;
  height: 22px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #ff5a5f;
  color: white;
  font-size: 12px;
}

.chat-panel {
  width: min(360px, calc(100vw - 28px));
  height: 460px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow);
  overflow: hidden;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

.chat-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px;
  border-bottom: 1px solid var(--line);
}

.chat-header span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  margin-top: 2px;
}

.chat-messages {
  padding: 12px;
  display: grid;
  align-content: start;
  gap: 10px;
  overflow-y: auto;
}

.chat-message {
  max-width: 86%;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.chat-message.mine {
  justify-self: end;
  border-color: rgba(56, 217, 169, 0.45);
  background: rgba(56, 217, 169, 0.12);
}

.chat-message div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-size: 11px;
}

.chat-message p {
  margin: 5px 0 0;
  white-space: pre-wrap;
}

.chat-empty {
  margin: 0;
}

.chat-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  padding: 12px;
  border-top: 1px solid var(--line);
}

.calendar-filters .filter-boekingen {
  border-color: rgba(0, 116, 253, 0.45);
}

.calendar-filters .filter-boekingen.active {
  background: #0074fd;
}

.calendar-filters .filter-meeting {
  border-color: rgba(99, 102, 241, 0.55);
}

.calendar-filters .filter-meeting.active {
  background: #6366f1;
}

.calendar-filters .filter-studio {
  border-color: rgba(14, 165, 233, 0.55);
}

.calendar-filters .filter-studio.active {
  background: #0ea5e9;
}

.calendar-filters .filter-fotoshoot {
  border-color: rgba(244, 114, 182, 0.55);
}

.calendar-filters .filter-fotoshoot.active {
  background: #f472b6;
}

.calendar-filters .filter-other {
  border-color: rgba(148, 163, 184, 0.55);
}

.calendar-filters .filter-other.active {
  background: #94a3b8;
}

.calendar-filters .filter-releases {
  border-color: rgba(81, 207, 102, 0.45);
}

.calendar-filters .filter-releases.active {
  background: #51cf66;
}

.calendar-filters .filter-release-deadline {
  border-color: rgba(168, 85, 247, 0.55);
}
.calendar-filters .filter-release-deadline.active {
  background: #a855f7;
}
.calendar-filters .filter-track-deadline {
  border-color: rgba(255, 209, 102, 0.55);
}
.calendar-filters .filter-track-deadline.active {
  background: #ffd166;
}

.calendar-filters .filter-social {
  border-color: rgba(236, 72, 153, 0.55);
}

.calendar-filters .filter-social.active {
  background: #ec4899;
}

.calendar-filters .filter-artwork {
  border-color: rgba(168, 85, 247, 0.55);
}

.calendar-filters .filter-artwork.active {
  background: #a855f7;
}

.calendar-filters .filter-master {
  border-color: rgba(45, 212, 191, 0.55);
}

.calendar-filters .filter-master.active {
  background: #2dd4bf;
}

.calendar-filters .filter-upload {
  border-color: rgba(249, 115, 22, 0.55);
}

.calendar-filters .filter-upload.active {
  background: #f97316;
}

.day {
  height: 176px;
  min-height: 176px;
  padding: 8px;
  border-right: 1px solid rgba(255, 255, 255, 0.065);
  border-bottom: 1px solid rgba(255, 255, 255, 0.065);
  background: linear-gradient(180deg, rgba(21, 27, 38, 0.92), rgba(14, 19, 28, 0.94));
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.day:hover,
.hour-row:hover {
  background: linear-gradient(180deg, rgba(28, 37, 54, 0.98), rgba(16, 23, 34, 0.98));
}

.day.outside-month {
  background: linear-gradient(180deg, rgba(13, 17, 24, 0.78), rgba(10, 14, 20, 0.82));
}

.day.outside-month > strong {
  color: rgba(148, 163, 184, 0.42);
}

.day.outside-month .event,
.day.outside-month .day-scroll-button {
  opacity: 0.48;
}

.day.outside-month:hover {
  background: linear-gradient(180deg, rgba(20, 27, 39, 0.9), rgba(13, 19, 28, 0.92));
}

.day.is-today {
  background: linear-gradient(180deg, rgba(141, 183, 255, 0.14), rgba(141, 183, 255, 0.05));
  box-shadow: inset 0 0 0 2px rgba(141, 183, 255, 0.6);
}

.day.is-today:hover {
  background: linear-gradient(180deg, rgba(141, 183, 255, 0.2), rgba(141, 183, 255, 0.09));
}

.day.is-today > strong {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 9px;
  background: var(--brand);
  color: #0b1220;
  font-weight: 700;
}

.day:nth-child(7n) {
  border-right: 0;
}

.day strong {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 11px;
  line-height: 1;
  letter-spacing: 0;
}

.event {
  display: block;
  width: 100%;
  min-height: 32px;
  padding: 5px 7px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 6px;
  background: rgba(56, 217, 169, 0.14);
  color: var(--text);
  font-size: 10.5px;
  line-height: 1.15;
  text-align: left;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
  overflow: hidden;
}

.event .interface-copy {
  display: block;
  margin-bottom: 2px;
  color: var(--muted);
  font-size: 8.5px;
  line-height: 1;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.event-title-text {
  display: block;
  font-size: 10.5px;
  font-weight: 500;
  color: var(--text);
  text-transform: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.event-boekingen {
  background: rgba(0, 116, 253, 0.18);
  border-left: 3px solid #0074fd;
}

.event-meeting {
  background: rgba(99, 102, 241, 0.18);
  border-left: 3px solid #6366f1;
}

.event-studio {
  background: rgba(14, 165, 233, 0.18);
  border-left: 3px solid #0ea5e9;
}

.event-fotoshoot {
  background: rgba(244, 114, 182, 0.18);
  border-left: 3px solid #f472b6;
}

.event-other {
  background: rgba(148, 163, 184, 0.18);
  border-left: 3px solid #94a3b8;
}

.event-releases {
  background: rgba(81, 207, 102, 0.16);
  border-left: 3px solid #51cf66;
}

.event-track-deadline {
  background: rgba(255, 209, 102, 0.16);
  border-left: 3px solid #ffd166;
}

.event-release-deadline {
  background: rgba(168, 85, 247, 0.18);
  border-left: 3px solid #a855f7;
}

.event-social {
  background: rgba(236, 72, 153, 0.18);
  border-left: 3px solid #ec4899;
}

.day-event-scroll {
  display: grid;
  grid-template-rows: 16px 108px 16px;
  gap: 4px;
}

.day-event-static {
  display: grid;
  align-content: start;
  gap: 6px;
  height: 140px;
  overflow: hidden;
}

.day-event-list {
  display: grid;
  align-content: start;
  gap: 6px;
  height: 108px;
  max-height: 108px;
  overflow-y: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
}

.day-event-list::-webkit-scrollbar {
  display: none;
}

.day-scroll-button {
  display: grid;
  place-items: center;
  min-height: 16px;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.4);
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.day-scroll-button:hover {
  background: rgba(141, 183, 255, 0.12);
  border-color: rgba(141, 183, 255, 0.3);
  color: rgba(255, 255, 255, 0.85);
}

.event.active {
  border-color: var(--brand);
  box-shadow: 0 0 0 1px rgba(0, 116, 253, 0.32);
}

.event + .event {
  margin-top: 0;
}

.day-schedule {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--panel);
}

.hour-row {
  display: grid;
  grid-template-columns: 86px 1fr;
  min-height: 54px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 0.15s ease;
}

.hour-row:last-child {
  border-bottom: 0;
}

.hour-row strong {
  padding: 12px;
  border-right: 1px solid var(--line);
  color: var(--muted);
  font-size: 12px;
}

.hour-row > div {
  padding: 8px;
}

.split-view {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 16px;
}

.release-detail-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.release-archive-track-detail {
  display: grid;
  grid-template-columns: minmax(340px, 0.9fr) minmax(520px, 1.1fr);
  gap: 16px;
  align-items: start;
}

.timeline {
  display: grid;
  gap: 12px;
}

.timeline-item {
  display: grid;
  grid-template-columns: 82px 1fr;
  gap: 12px;
  align-items: start;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
}

.invoice-preview {
  background: #ffffff;
  color: #111827;
  border-radius: var(--radius);
  padding: 0;
}

.invoice-preview .muted {
  color: #64748b;
}

.invoice-document {
  width: min(100%, 794px);
  min-height: 1123px;
  margin: 0 auto;
  padding: 34px;
  border: 1px solid #d7dce5;
  font-family: Arial, Helvetica, sans-serif;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.18);
  aspect-ratio: 210 / 297;
}

.invoice-field-logo {
  max-width: 200px;
  max-height: 80px;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 6px;
}

.invoice-field h2 {
  margin: 0;
  color: var(--invoice-accent, #111827);
  font-size: 28px;
  letter-spacing: 1.2px;
}

.invoice-field strong,
.invoice-footer-note strong {
  color: #111827;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
}

.invoice-field p,
.invoice-footer-note p {
  margin: 0;
  color: #334155;
  font-size: 12px;
  line-height: 1.55;
}

.invoice-client-name {
  color: #111827;
  font-size: 18px;
  font-weight: 800;
}

.invoice-lines {
  width: 100%;
  margin-top: 24px;
  border-collapse: collapse;
  font-size: 12px;
}

.invoice-lines th {
  padding: 11px 10px;
  background: var(--invoice-accent, #111827);
  color: #ffffff;
  text-align: left;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.invoice-lines th:not(:first-child),
.invoice-lines td:not(:first-child) {
  text-align: right;
}

.invoice-lines td {
  padding: 13px 10px;
  border-bottom: 1px solid #e2e8f0;
  color: #111827;
}

.invoice-total-block {
  width: min(320px, 100%);
  margin: 22px 0 0 auto;
  display: grid;
  gap: 8px;
}

.invoice-total-block div {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: #334155;
  font-size: 12px;
}

.invoice-grand-total {
  margin-top: 4px;
  padding-top: 10px;
  border-top: 2px solid var(--invoice-accent, #111827);
  color: #111827 !important;
  font-size: 16px !important;
}

.invoice-document.light-header .invoice-lines th {
  background: #eef2f7;
  color: var(--invoice-accent, #111827);
  border-top: 1px solid #d7dce5;
  border-bottom: 1px solid #d7dce5;
}

.invoice-document.compact-invoice {
  padding: 26px;
}

.invoice-document.compact-invoice .invoice-lines {
  margin-top: 18px;
}

.invoice-block-list {
  display: grid;
  gap: 18px;
}

.invoice-title-block h2 {
  margin: 0;
  color: var(--invoice-accent, #111827);
  font-size: 30px;
  letter-spacing: 0;
}

.invoice-info-block {
  display: grid;
  gap: 6px;
}

.invoice-info-block strong,
.invoice-meta-grid strong {
  color: #111827;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
}

.invoice-info-block p,
.invoice-meta-grid p,
.invoice-custom-text {
  margin: 0;
  color: #334155;
  font-size: 12px;
  line-height: 1.55;
}

.invoice-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 24px;
  padding: 14px 0;
  border-top: 2px solid var(--invoice-accent, #111827);
  border-bottom: 1px solid #e2e8f0;
}

.invoice-divider {
  width: 100%;
  border: 0;
  border-top: 1px solid #e2e8f0;
}

.invoice-spacer {
  height: 28px;
}

.invoice-two-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.invoice-two-columns p {
  margin: 0;
  padding: 12px;
  border-radius: 10px;
  background: #f8fafc;
  color: #334155;
  font-size: 12px;
  line-height: 1.55;
}

.invoice-template-builder .invoice-preview {
  overflow: auto;
}

.invoice-template-builder #invoiceTemplatePreview {
  display: grid;
  justify-items: center;
  min-width: 0;
}

.invoice-template-builder #invoiceTemplatePreview .invoice-document {
  transform: scale(0.82);
  transform-origin: top center;
  margin-bottom: -190px;
}

.invoice-builder-layout {
  grid-template-columns: minmax(520px, 1fr) 360px;
}

.invoice-editable-block {
  padding: 4px;
}

.invoice-block-editor {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--builder-line, var(--line));
  border-radius: var(--radius);
  background: var(--builder-panel-2, var(--panel-2));
}

.template-logo-upload input {
  padding: 8px;
}

.invoice-field-controls {
  display: grid;
  gap: 8px;
}

.invoice-field-controls h3 {
  margin: 4px 0;
}

.invoice-field-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.invoice-field-control label {
  display: flex;
  align-items: center;
  gap: 9px;
}

.invoice-field-control input[type="checkbox"] {
  width: 16px;
  min-height: 16px;
}

.invoice-field-control label span {
  margin: 0;
  color: var(--text);
}

.invoice-footer-note {
  margin-top: 30px;
  padding-top: 16px;
  border-top: 1px solid #e2e8f0;
}

.detail-list {
  display: grid;
  gap: 10px;
  margin: 0 0 18px;
}

.detail-list > div {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}

.detail-list > div:last-child {
  border-bottom: 0;
}

.detail-list dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

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

.track-detail-card {
  display: grid;
  gap: 14px;
}

/* Track cover gradient placeholder */
.track-cover-gradient {
  display: flex !important;
  align-items: center;
  justify-content: center;
}

.track-cover-emoji {
  font-size: 64px;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

.release-cover-thumb.track-cover-gradient .track-cover-emoji,
.db-track-thumb.track-cover-gradient .track-cover-emoji {
  font-size: 16px;
}

/* Track detail — visual layout */
.track-detail-visual {
  display: grid;
  grid-template-columns: 200px 1fr 1fr;
  gap: 20px;
  align-items: start;
}

.track-cover-large {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  border-radius: var(--radius);
  object-fit: cover;
  background: var(--panel-3);
}

.track-cover-large.uploaded-image-placeholder {
  background:
    linear-gradient(135deg, transparent 46%, var(--line) 47%, var(--line) 53%, transparent 54%),
    var(--panel-3);
}

.track-phases-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.track-phase-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 13px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background .15s;
}

.track-phase-item:hover {
  background: var(--panel-3);
}

.track-phase-item.active {
  background: rgba(98, 124, 255, .12);
  border-color: rgba(98, 124, 255, .3);
  color: var(--brand-text, #8b9fff);
  font-weight: 600;
}

.track-phase-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid var(--muted);
  flex-shrink: 0;
  transition: background .15s, border-color .15s;
}

.track-phase-item.active .track-phase-dot {
  background: var(--brand);
  border-color: var(--brand);
}

/* Track info boxes */
.track-info-boxes {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-top: 4px;
}

.track-info-box {
  background: var(--panel-3);
  border-radius: var(--radius);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.track-info-box > span {
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .6px;
  color: var(--muted);
  text-transform: uppercase;
}

.track-info-box > strong {
  font-size: 15px;
  font-weight: 600;
}

/* Track detail action row */
.track-detail-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  padding-top: 4px;
}

/* Progress bar in table */
.track-progress-cell {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--muted);
}

.track-progress-bar {
  flex: 1;
  height: 6px;
  background: var(--panel-3);
  border-radius: 99px;
  overflow: hidden;
  min-width: 60px;
}

.track-progress-bar > div {
  height: 100%;
  background: var(--brand);
  border-radius: 99px;
  transition: width .3s;
}

.track-detail-header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}

.track-detail-header h2 {
  margin-bottom: 4px;
}

.inline-detail-list.editing {
  gap: 8px;
}

.inline-detail-list.editing > div {
  align-items: center;
  padding: 9px 10px;
  border: 1px solid rgba(98, 124, 255, 0.22);
  border-radius: var(--radius);
  background: rgba(98, 124, 255, 0.055);
}

.inline-detail-list.editing > div:last-child {
  border-bottom: 1px solid rgba(98, 124, 255, 0.22);
}

.inline-detail-list input,
.inline-detail-list select,
.inline-detail-list textarea,
.inline-table-input {
  width: 100%;
  min-width: 0;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.04);
  outline: none;
}

.inline-detail-list textarea {
  min-height: 84px;
  resize: vertical;
}

.inline-detail-list input:focus,
.inline-detail-list select:focus,
.inline-detail-list textarea:focus,
.inline-table-input:focus {
  border-color: rgba(98, 124, 255, 0.8);
  box-shadow: 0 0 0 3px rgba(98, 124, 255, 0.12);
}

.inline-table-input {
  padding: 7px 9px;
  border-radius: 9px;
  font: inherit;
}

.inline-link-list-editor,
.inline-link-list-editor > div,
.contact-link-list {
  display: grid;
  gap: 8px;
}

.collaborators-editor {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  width: min(320px, 100%);
  padding: 0;
  border: 0;
  background: transparent;
}

.contact-search-picker {
  display: grid;
  gap: 8px;
  width: min(320px, 100%);
}

.hidden-contact-search {
  display: none;
}

.collaborator-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.inline-collaborator-select {
  min-height: 32px;
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.025);
  font-size: 13px;
  font-weight: 800;
}

.inline-detail-list .inline-collaborator-select,
.inline-collaborator-select {
  width: fit-content;
  min-width: 180px;
  max-width: 100%;
  cursor: pointer;
}

.inline-collaborator-select:focus {
  border-color: rgba(56, 217, 169, 0.45);
  background: rgba(56, 217, 169, 0.08);
}

.collaborator-search-panel {
  display: grid;
  gap: 7px;
  width: min(280px, 100%);
  padding: 0;
  border: 0;
  background: transparent;
}

.collaborator-search-panel input {
  min-height: 38px;
  width: 100%;
}

.collaborator-search-panel[hidden] {
  display: none;
}

.inline-collaborator-dropdown {
  display: grid;
  gap: 2px;
  overflow: hidden;
  width: 100%;
  max-height: 180px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(12, 15, 26, 0.96);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22);
}

.inline-collaborator-dropdown:empty {
  display: none;
}

.inline-collaborator-dropdown button {
  width: 100%;
  min-height: 34px;
  padding: 8px 10px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  text-align: left;
}

.inline-collaborator-dropdown button:hover {
  background: rgba(98, 124, 255, 0.16);
}

.inline-collaborator-dropdown .muted {
  margin: 0;
  padding: 9px 10px;
  font-size: 13px;
}

.billing-form-preview {
  margin-top: 4px;
}

.billing-preview-block {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-muted);
  background: var(--bg-subtle, rgba(0,0,0,0.04));
  border-radius: 6px;
  padding: 10px 12px;
}

.inline-link-list-editor label {
  margin: 0;
}

.contact-link-list a {
  color: var(--text);
  text-decoration: none;
  word-break: break-word;
}

.contact-link-list a:hover {
  color: var(--accent);
}

.campaign-template-picker {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  gap: 16px;
  align-items: center;
}

.detail-bottom-tools {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  padding-top: 2px;
}

.booking-invoice-row {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.history-toggle-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  min-height: 36px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.025);
}

.history-toggle-button svg {
  width: 15px;
  height: 15px;
  fill: currentColor;
}

.history-toggle-button:hover,
.history-toggle-button.active {
  color: var(--text);
  border-color: rgba(98, 124, 255, 0.42);
  background: rgba(98, 124, 255, 0.09);
}

.track-task-add-row {
  border-top: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.018);
}

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

.track-history {
  display: grid;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}

.track-history h3 {
  margin: 0;
}

.track-history > div {
  display: grid;
  gap: 2px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.025);
}

.track-history span {
  color: var(--muted);
  font-size: 12px;
}

.checklist {
  display: grid;
  gap: 9px;
}

.checklist label {
  display: flex;
  align-items: center;
  gap: 9px;
  min-height: 34px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.checklist input {
  width: 16px;
  min-height: 16px;
}

.checklist .done span {
  color: var(--muted);
  text-decoration: line-through;
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.chips span {
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}

.contact-group-buttons button {
  min-height: 36px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

.contact-group-buttons button.active {
  border-color: var(--brand);
  background: var(--brand);
  color: #061018;
}

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

.billing-field-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.billing-field-row > label,
.billing-field-row > .billing-field {
  flex: 1 1 160px;
  min-width: 140px;
}

.billing-field-row > label.wide,
.billing-field-row > .billing-field.wide {
  flex: 2 1 260px;
}

.billing-field-row-single {
  flex-wrap: nowrap;
  overflow-x: auto;
  padding-bottom: 6px;
}

.billing-field-row-single > label,
.billing-field-row-single > .billing-field {
  flex: 0 0 150px;
  min-width: 150px;
}

.billing-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.billing-field > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.fixed-form-value,
.fixed-inline-value {
  display: flex;
  align-items: center;
  min-height: 42px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
}

.invoice-line-builder {
  display: grid;
  gap: 9px;
}

.invoice-line-builder > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.invoice-line-builder-head,
.invoice-line-builder-row {
  display: grid;
  grid-template-columns: minmax(180px, 1.8fr) 90px 130px 90px 44px;
  gap: 8px;
  align-items: center;
}

.invoice-line-builder-head {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.invoice-line-builder-row input,
.invoice-line-builder-row select {
  width: 100%;
  min-width: 0;
}

.invoice-line-summary {
  display: grid;
  gap: 7px;
}

.invoice-line-summary div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
}

.invoice-line-summary div:last-child {
  border-bottom: 0;
}

.profile-form {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

/* automail editor */
.automail-editor-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

.automail-preview-panel {
  position: sticky;
  top: 20px;
}

.automail-mail-preview {
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--line);
}

@media (max-width: 900px) {
  .automail-editor-layout {
    grid-template-columns: 1fr;
  }
  .automail-preview-panel {
    position: static;
  }
}

/* workspace modal */
.workspace-modal {
  max-width: 460px;
}

.workspace-modal-logo-row {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 16px;
}

.workspace-modal-logo-preview {
  min-height: 90px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  display: grid;
  place-items: center;
}

.workspace-logo-placeholder {
  font-size: 24px;
  font-weight: 800;
  color: var(--muted);
}

.workspace-modal-logo-actions {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.workspace-modal-logo-actions h3 {
  font-size: 13px;
  font-weight: 700;
  margin: 0;
}

.workspace-modal-field {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 16px;
}

.workspace-modal-field label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: 12px;
}

.workspace-modal-switcher {
  padding-bottom: 4px;
}

.workspace-switch-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: var(--text);
  font-size: 13px;
  cursor: pointer;
  text-align: left;
  transition: background 0.15s;
}

.workspace-switch-btn:hover {
  background: var(--panel-2);
}

.workspace-switch-btn.active {
  border-color: rgba(141,183,255,0.3);
  background: rgba(141,183,255,0.07);
}

.workspace-switch-icon {
  width: 26px;
  height: 26px;
  border-radius: 6px;
  background: rgba(56,139,253,0.15);
  color: #79afff;
  display: grid;
  place-items: center;
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
}

.workspace-switch-check {
  margin-left: auto;
  color: #79afff;
  font-size: 13px;
}

.workspace-logo-settings {
  display: grid;
  grid-template-columns: minmax(140px, 220px) minmax(0, 1fr);
  gap: 20px;
  align-items: center;
}

.workspace-logo-preview {
  min-height: 120px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  display: grid;
  place-items: center;
}

.workspace-logo-image {
  display: block;
  width: 100%;
  max-width: 180px;
  max-height: 90px;
  object-fit: contain;
}

.workspace-logo-image.uploaded-image-placeholder {
  width: 90px;
  height: 54px;
}

.workspace-logo-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.workspace-logo-controls > div {
  flex: 1 0 100%;
}

.workspace-logo-controls h3,
.workspace-logo-controls p {
  margin: 0;
}

.workspace-logo-controls p {
  margin-top: 5px;
}

.profile-photo-panel {
  display: grid;
  gap: 12px;
}

.profile-photo-preview {
  aspect-ratio: 1;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.profile-photo-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.15s ease, object-position 0.15s ease;
}

.profile-photo-preview span {
  color: var(--brand);
  font-size: 56px;
  font-weight: 900;
}

.profile-upload input {
  padding: 8px;
}

.photo-controls {
  display: grid;
  gap: 8px;
}

.social-links-editor {
  display: grid;
  gap: 8px;
}

#profileSocialLinks {
  display: grid;
  gap: 8px;
}

.profile-social-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.profile-social-preview a {
  color: var(--brand);
  font-size: 12px;
}

.clickable-row {
  cursor: pointer;
}

.row-select-button {
  border: 0;
  background: transparent;
  padding: 0;
  color: inherit;
  text-align: left;
}

.row-select-button {
  font-weight: 800;
}

.inline-status-select {
  border: 1px solid transparent;
  cursor: pointer;
  width: fit-content;
  max-width: 140px;
  appearance: none;
  -webkit-appearance: none;
  padding-right: 22px;
  background-image: linear-gradient(45deg, transparent 50%, currentColor 50%), linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position: calc(100% - 12px) 50%, calc(100% - 7px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
}

.inline-status-select.draft {
  background-color: rgba(148, 163, 184, 0.16);
  border-color: rgba(148, 163, 184, 0.3);
  color: #cbd5e1;
}

.inline-status-select.progress {
  background-color: rgba(56, 189, 248, 0.16);
  border-color: rgba(56, 189, 248, 0.34);
  color: #7dd3fc;
}

.inline-status-select.review {
  background-color: rgba(251, 191, 36, 0.18);
  border-color: rgba(251, 191, 36, 0.38);
  color: #fde68a;
}

.inline-status-select.ready {
  background-color: rgba(168, 85, 247, 0.18);
  border-color: rgba(168, 85, 247, 0.38);
  color: #d8b4fe;
}

.inline-status-select.ok {
  background-color: rgba(81, 207, 102, 0.16);
  border-color: rgba(81, 207, 102, 0.34);
  color: #8ce99a;
}

.inline-status-select.danger {
  background-color: rgba(255, 107, 107, 0.16);
  border-color: rgba(255, 107, 107, 0.36);
  color: #ffa8a8;
}

.inline-status-select.info {
  background-color: rgba(92, 124, 250, 0.18);
  border-color: rgba(92, 124, 250, 0.36);
  color: #bac8ff;
}

.inline-status-select.track-demo {
  background-color: rgba(148, 163, 184, 0.16);
  border-color: rgba(148, 163, 184, 0.34);
  color: #cbd5e1;
}

.inline-status-select.track-production {
  background-color: rgba(14, 165, 233, 0.18);
  border-color: rgba(14, 165, 233, 0.42);
  color: #7dd3fc;
}

.inline-status-select.track-recording {
  background-color: rgba(236, 72, 153, 0.16);
  border-color: rgba(236, 72, 153, 0.4);
  color: #f9a8d4;
}

.inline-status-select.track-mix {
  background-color: rgba(45, 212, 191, 0.16);
  border-color: rgba(45, 212, 191, 0.42);
  color: #5eead4;
}

.inline-status-select.track-master {
  background-color: rgba(139, 92, 246, 0.18);
  border-color: rgba(139, 92, 246, 0.42);
  color: #c4b5fd;
}

.inline-status-select.track-revision {
  background-color: rgba(249, 115, 22, 0.18);
  border-color: rgba(249, 115, 22, 0.44);
  color: #fdba74;
}

.inline-status-select.track-label-check {
  background-color: rgba(234, 179, 8, 0.18);
  border-color: rgba(234, 179, 8, 0.44);
  color: #fde047;
}

.inline-status-select.track-ready {
  background-color: rgba(34, 197, 94, 0.18);
  border-color: rgba(34, 197, 94, 0.42);
  color: #86efac;
}

.inline-status-select.track-idee {
  background-color: rgba(100, 116, 139, 0.16);
  border-color: rgba(100, 116, 139, 0.34);
  color: #94a3b8;
}

.inline-status-select.track-artwork {
  background-color: rgba(217, 70, 239, 0.16);
  border-color: rgba(217, 70, 239, 0.38);
  color: #e879f9;
}

.inline-status-select.track-ingepland {
  background-color: rgba(245, 158, 11, 0.18);
  border-color: rgba(245, 158, 11, 0.42);
  color: #fcd34d;
}

.inline-status-select.track-live {
  background-color: rgba(16, 185, 129, 0.18);
  border-color: rgba(16, 185, 129, 0.42);
  color: #6ee7b7;
}

.campaign-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.campaign-tabs button {
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--text);
  border-radius: var(--radius);
  padding: 9px 12px;
  font-weight: 800;
}

.campaign-tabs button.active {
  border-color: rgba(141, 183, 255, 0.55);
  background: rgba(141, 183, 255, 0.1);
  color: var(--brand);
}

.campaign-tabs .primary-button {
  border-color: rgba(141, 183, 255, 0.48);
  background: linear-gradient(180deg, #a8c8ff, #75a5ff);
  color: #07111f;
  padding: 0 10px;
  min-height: 31px;
  font-size: 12px;
  align-self: center;
}

.campaign-tabs span {
  color: var(--muted);
  font-size: 12px;
  margin-left: 6px;
}

.social-campaign-panel {
  display: grid;
  grid-template-columns: minmax(240px, 420px) 1fr;
  gap: 12px;
  align-items: end;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.03);
  padding: 14px;
}

.social-campaign-panel label {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  margin-bottom: 6px;
}

.social-campaign-summary {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 12px;
}

.social-campaign-summary strong {
  color: var(--text);
}

.social-dashboard {
  display: grid;
  grid-template-columns: 1.1fr 1.4fr;
  gap: 12px;
  align-items: stretch;
}

.social-hero-card,
.social-stat-grid,
.social-type-strip {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  padding: 14px;
}

.social-hero-card {
  background: linear-gradient(135deg, rgba(56, 217, 169, 0.16), rgba(0, 116, 253, 0.12));
}

.social-hero-card span,
.social-stat-grid span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.social-hero-card h3 {
  margin: 6px 0;
}

.social-hero-card p {
  margin: 0;
  color: var(--muted);
}

.social-stat-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.social-stat-grid div {
  display: grid;
  gap: 4px;
}

.social-stat-grid strong {
  font-size: 24px;
}

.social-type-strip {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.social-type-strip span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 10px;
  background: var(--panel-2);
}

.release-notes-list {
  display: grid;
  gap: 10px;
}

.release-notes-list label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.release-notes-list label.done span {
  color: var(--muted);
  text-decoration: line-through;
}

.release-note-add,
.data-tools-card {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.release-note-add input {
  flex: 1;
  min-width: 180px;
}

.link-list-editor {
  display: grid;
  gap: 8px;
}

.link-list-editor > div {
  display: grid;
  gap: 8px;
}

.inline-file-link-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.file-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.file-button input {
  display: none;
}

.mail-artwork-image {
  width: var(--image-desktop-width, 100%);
  height: var(--image-height, auto);
  max-height: none;
  object-fit: cover;
  border-radius: var(--image-radius, var(--radius));
  margin-bottom: 14px;
}

.mail-sized-image {
  display: block;
  margin-right: auto;
  margin-left: auto;
}

.mail-block-logo {
  object-fit: contain;
}

.inline-checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
}

.inline-checkbox-grid label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.inline-checkbox-grid input {
  width: 16px;
  min-height: 16px;
}

.inline-checkbox-grid span {
  margin: 0;
  color: var(--text);
}

label span {
  display: block;
  margin-bottom: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.compact-filter {
  display: flex;
  align-items: center;
  gap: 8px;
}

.compact-filter span {
  margin: 0;
}

.compact-filter select {
  min-width: 150px;
}

.compact-filter input {
  max-width: 320px;
}

input,
select,
textarea {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  color: var(--text);
  padding: 8px 10px;
}

input[type="file"] {
  padding: 8px 10px;
}

textarea {
  min-height: 104px;
  resize: vertical;
}

.wide {
  grid-column: 1 / -1;
}

.file-upload small {
  display: block;
  margin-top: 7px;
  color: var(--muted);
  font-size: 12px;
}

.file-link {
  color: var(--brand);
  font-weight: 800;
  text-decoration: none;
}

.file-link:hover {
  text-decoration: underline;
}

.mail-preview {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: var(--radius);
  background: var(--mail-bg, #eef3fb);
  font-family: var(--mail-font, Inter, Arial, sans-serif);
  text-align: var(--mail-align, left);
}

.mail-preview-header {
  display: grid;
  gap: 6px;
  padding: 20px;
  border-radius: var(--radius) var(--radius) 0 0;
  background: var(--mail-accent, var(--brand));
  color: #fff;
}

.mail-preview-logo {
  width: 54px;
  height: 54px;
  border-radius: 14px;
  object-fit: cover;
}

.mail-preview-header small {
  color: rgba(255, 255, 255, 0.78);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.mail-preview-header h3 {
  margin: 0;
  color: #fff;
  font-size: var(--mail-title-size, 24px);
}

.mail-preview-header span {
  color: rgba(255, 255, 255, 0.82);
  font-size: 13px;
}

.mail-preview-header strong {
  color: #fff;
  font-size: 20px;
}

.mail-preview-body {
  min-height: 220px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 0 0 var(--radius) var(--radius);
  background: var(--mail-content, #fff);
  color: var(--mail-text, #111827);
  font-size: var(--mail-body-size, 16px);
  line-height: 1.6;
}

.mail-preview-body strong {
  color: var(--mail-text, #111827);
}

.mail-preview-button {
  display: inline-flex;
  min-height: 40px;
  align-items: center;
  justify-content: center;
  margin-top: 10px;
  padding: 0 16px;
  border-radius: var(--radius);
  background: var(--mail-button, var(--mail-accent, var(--brand)));
  color: var(--mail-button-text, #fff);
  font-weight: 900;
  text-decoration: none;
}

.mail-builder-stage.mobile-preview .mail-sized-image {
  width: var(--image-mobile-width, var(--image-desktop-width, 100%));
}

.mail-preview-footer {
  padding: 12px 16px;
  color: var(--muted);
  font-size: 12px;
  text-align: center;
}

.template-preset-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.mail-editor-controls {
  display: grid;
  gap: 14px;
  position: sticky;
  top: 96px;
}

.mail-editor-controls h3 {
  margin: 0;
}

.editor-control-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.mail-block-editor {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.mail-block-editor > div {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}

.mail-block-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.mail-block-title {
  margin: 0 0 10px;
  color: var(--mail-text, #111827);
  font-size: calc(var(--mail-title-size, 24px) * 0.78);
}

.mail-block-divider {
  border: 0;
  border-top: 1px solid rgba(17, 24, 39, 0.18);
  margin: 18px 0;
}

.mail-block-links p {
  margin: 6px 0 0;
}

.mail-image-placeholder {
  display: grid;
  min-height: 140px;
  place-items: center;
  border: 1px dashed rgba(17, 24, 39, 0.22);
  border-radius: var(--radius);
  color: var(--muted);
  font-weight: 800;
}

.mail-auto-placeholder {
  opacity: 0.55;
  border-style: dashed !important;
  cursor: default;
}

.mail-builder {
  display: grid;
  gap: 16px;
}

.mail-builder-hero {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: flex-end;
  justify-content: space-between;
  padding: 22px;
  border: 1px solid rgba(17, 24, 39, 0.08);
  border-radius: 18px;
  background: linear-gradient(135deg, #ffffff 0%, #eef6ff 48%, #f8f5ff 100%);
  box-shadow: 0 18px 45px rgba(17, 24, 39, 0.08);
}

.mail-builder-hero h2 {
  margin: 4px 0;
  font-size: 30px;
}

.mail-builder-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

.mail-template-strip {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
}

.mail-template-card {
  min-height: 52px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: linear-gradient(180deg, #fff, #f7f9fc);
  color: var(--text);
  font-weight: 900;
  cursor: pointer;
}

.mail-template-card:hover {
  border-color: var(--brand);
  box-shadow: 0 10px 25px rgba(0, 116, 253, 0.12);
}

.mail-builder-layout {
  display: grid;
  grid-template-columns: minmax(420px, 1fr) minmax(380px, 0.34fr);
  gap: 16px;
  align-items: start;
}

.mail-builder-stage {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 18px;
  border: 1px solid rgba(17, 24, 39, 0.08);
  border-radius: 18px;
  background: #f2f5f9;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.mail-builder-stage #promoPreviewMount {
  width: min(100%, 760px);
  margin: 0 auto;
}

.mail-builder-stage.mobile-preview #promoPreviewMount {
  width: min(100%, 390px);
}

.mail-builder-stage .mail-preview {
  border-radius: 22px;
  background: var(--mail-bg, #eef3fb);
  box-shadow: 0 24px 65px rgba(17, 24, 39, 0.16);
}

.mail-editable-block {
  position: relative;
  margin: 6px 0;
  border: 1px solid transparent;
  border-radius: 14px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.mail-editable-block:hover,
.mail-editable-block.selected {
  border-color: var(--brand);
  background: rgba(0, 116, 253, 0.04);
  box-shadow: 0 0 0 3px rgba(0, 116, 253, 0.1);
}

.mail-editable-block [contenteditable="true"] {
  outline: 0;
  cursor: text;
}

.mail-block-tools {
  position: absolute;
  top: -13px;
  right: 10px;
  display: none;
  gap: 4px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  box-shadow: var(--shadow);
}

.mail-editable-block:hover .mail-block-tools,
.mail-editable-block.selected .mail-block-tools {
  display: flex;
}

.mail-add-panel {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px dashed rgba(0, 116, 253, 0.45);
  border-radius: 18px;
  background: #fff;
}

.mail-add-panel > div:first-child {
  display: grid;
  gap: 2px;
}

.mail-add-panel span {
  color: var(--muted);
  font-size: 13px;
}

.mail-add-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.mail-add-button {
  display: grid;
  gap: 6px;
  justify-items: center;
  min-height: 72px;
  padding: 10px 8px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #f8fafc;
  color: var(--text);
  font-size: 12px;
  font-weight: 900;
  cursor: grab;
}

.mail-add-button span {
  display: grid;
  width: 26px;
  height: 26px;
  place-items: center;
  border-radius: 50%;
  background: var(--brand);
  color: #fff;
  font-size: 18px;
}

.mail-add-button:hover {
  border-color: var(--brand);
  background: #fff;
}

.mail-builder-side {
  position: sticky;
  top: 88px;
  min-width: 0;
}

.mail-quote {
  margin: 0;
  padding: 14px 16px;
  border-left: 4px solid var(--mail-accent, var(--brand));
  color: var(--mail-text, #111827);
  font-size: 18px;
  font-weight: 800;
}

.mail-video-link {
  display: grid;
  min-height: 86px;
  place-items: center;
  border-radius: 16px;
  background: #111827;
  color: #fff;
  font-weight: 900;
  text-decoration: none;
}

.mail-spacer {
  height: 30px;
}

.mail-two-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.mail-two-columns p {
  margin: 0;
  padding: 12px;
  border-radius: 12px;
  background: rgba(17, 24, 39, 0.04);
}

.mail-column-editor {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.mail-column-editor > div {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.025);
}

.mail-column-item-editor {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--builder-line, var(--line));
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
}

.mail-column-item-editor input {
  width: 100%;
}

.mail-column-item-editor > div:first-child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.mail-column-item-editor > div:first-child strong {
  color: var(--builder-text, var(--text));
}

.language-recipient-list {
  display: grid;
  gap: 8px;
}

.language-recipient-list > div {
  display: grid;
  grid-template-columns: 1fr 110px 1.6fr;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.language-recipient-list span,
.language-recipient-list small {
  color: var(--muted);
}

.mail-archive-preview {
  width: min(100%, 760px);
  margin: 0 auto;
}

.mail-builder {
  --builder-bg: #0b1120;
  --builder-panel: #111827;
  --builder-panel-2: #172033;
  --builder-line: rgba(255, 255, 255, 0.12);
  --builder-text: #f8fafc;
  --builder-muted: #aebbd0;
}

.mail-builder .muted,
.mail-builder .eyebrow,
.mail-template-strip > strong,
.mail-add-panel > div:first-child strong {
  color: var(--builder-muted);
}

.mail-builder-hero {
  border-color: var(--builder-line);
  background: linear-gradient(135deg, #0b1120 0%, #13213a 54%, #1d1536 100%);
  box-shadow: 0 18px 45px rgba(2, 6, 23, 0.24);
}

.mail-builder-hero h2 {
  color: var(--builder-text);
}

.mail-template-strip,
.mail-builder-stage,
.mail-add-panel,
.mail-builder-side .card {
  border-color: var(--builder-line);
  background: var(--builder-panel);
  color: var(--builder-text);
}

.mail-builder-stage {
  background: #07101f;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.mail-template-card,
.mail-add-button,
.mail-block-editor {
  border-color: var(--builder-line);
  background: var(--builder-panel-2);
  color: var(--builder-text);
}

.mail-template-card:hover,
.mail-add-button:hover {
  border-color: #4da3ff;
  background: #1f2a44;
  box-shadow: 0 10px 25px rgba(0, 116, 253, 0.18);
}

.mail-builder label span,
.mail-builder .mail-editor-controls h3,
.mail-builder .mail-block-editor strong {
  color: var(--builder-text);
}

.mail-builder input,
.mail-builder textarea,
.mail-builder select {
  border-color: var(--builder-line);
  background: #0b1220;
  color: var(--builder-text);
}

.mail-builder input::placeholder,
.mail-builder textarea::placeholder {
  color: var(--builder-muted);
}

.mail-builder .segmented {
  background: #0b1220;
  border-color: var(--builder-line);
}

.mail-builder .segmented button {
  color: var(--builder-muted);
}

.mail-builder .segmented button.active {
  background: #ffffff;
  color: #0b1120;
}

.mail-builder .ghost-button {
  border-color: var(--builder-line);
  background: rgba(255, 255, 255, 0.04);
  color: var(--builder-text);
}

.mail-builder .mail-block-tools {
  border-color: var(--builder-line);
  background: #0f172a;
}

.mail-editable-block:hover,
.mail-editable-block.selected {
  border-color: #4da3ff;
  background: rgba(77, 163, 255, 0.08);
  box-shadow: 0 0 0 3px rgba(77, 163, 255, 0.14);
}

.compact-mail {
  gap: 8px;
  padding: 10px;
}

.compact-mail .mail-preview-header,
.compact-mail .mail-preview-body {
  padding: 12px;
}

.checkbox-group {
  display: grid;
  gap: 8px;
}

.checkbox-group > span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.checkbox-group > div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.checkbox-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.checkbox-group label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

.checkbox-group input {
  width: 16px;
  min-height: 16px;
}

.checkbox-group label span {
  margin: 0;
  color: var(--text);
  font-size: 13px;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 20;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(0, 0, 0, 0.62);
}

.modal {
  position: relative;
  width: min(620px, 100%);
  max-height: calc(100vh - 40px);
  overflow: auto;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow);
}

.modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
}

.mobile-menu {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
}

.mobile-menu span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 4px auto;
  background: var(--text);
}

.toast {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 30;
  max-width: 360px;
  padding: 13px 15px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  box-shadow: var(--shadow);
}

@media print {
  @page {
    size: A4;
    margin: 0;
  }

  html,
  body {
    height: 297mm;
    max-height: 297mm;
    overflow: hidden;
  }

  body * {
    visibility: hidden;
  }

  .invoice-preview,
  .invoice-preview * {
    visibility: visible;
  }

  .invoice-preview {
    position: absolute;
    top: 0;
    left: 0;
    width: 210mm;
    min-height: 297mm;
    padding: 15mm 20mm;
    box-sizing: border-box;
    margin: 0;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: #fff;
  }
}

@media (max-width: 1120px) {
  .grid.cols-4,
  .grid.cols-3,
  .split-view {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .achievement-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .track-task-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .track-detail-task-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 800px) {
  html, body {
    overflow-x: hidden;
  }

  .app-shell {
    grid-template-columns: 1fr;
    overflow: visible;
  }
  .main {
    grid-column: 1 / -1;
    grid-row: 1;
    width: 100%;
    min-width: 0;
    overflow: hidden;
  }
  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    width: 280px;
    height: 100vh;
    z-index: 9999;
    transform: translateX(-100%);
    transition: transform 200ms ease;
  }
  .sidebar.open {
    transform: translateX(0);
  }

  .mobile-menu {
    display: block;
  }

  /* Dashboard layout: 1 kolom op mobiel */
  .db-layout {
    grid-template-columns: 1fr;
  }

  .db-hero {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 16px;
  }

  .db-hero-stats {
    width: 100%;
    flex-wrap: wrap;
  }

  .db-hero-stat {
    flex: 1;
    min-width: 70px;
  }

  .topbar {
    align-items: flex-start;
    padding: 14px;
  }

  .topbar-actions {
    width: 100%;
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .search {
    order: 3;
    width: 100%;
  }

  .content {
    padding: 14px;
  }

  .section-title {
    align-items: flex-start;
    flex-direction: column;
  }

  .section-actions,
  .segmented {
    width: 100%;
  }

  .segmented button,
  .section-actions .primary-button {
    flex: 1;
  }

  .grid.cols-4,
  .grid.cols-3,
  .grid.cols-2,
  .dashboard-stack,
  .achievement-grid,
  .track-task-list,
  .split-view,
  .release-detail-layout,
  .booking-detail-layout,
  .profile-form,
  .workspace-logo-settings,
  .mail-builder-layout,
  .social-dashboard,
  .social-campaign-panel,
  .calendar-sync-card,
  .calendar-item-picker,
  .task-builder-row,
  .task-builder-add,
  .form-grid {
    grid-template-columns: 1fr;
  }

  .task-builder-row {
    grid-template-areas:
      "title"
      "owner"
      "status"
      "date"
      "remove";
  }

  .task-builder-add {
    grid-template-areas:
      "title"
      "status"
      "owner"
      "date"
      "button";
  }

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

  .mail-builder-side {
    position: static;
  }

  .mail-builder-stage {
    padding: 10px;
  }

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

  .mail-two-columns {
    grid-template-columns: 1fr;
  }

  .language-recipient-list > div {
    grid-template-columns: 1fr;
  }

  .table-head {
    display: none;
  }

  .table-row {
    grid-template-columns: 1fr;
    gap: 7px;
  }

  .table-row-actions,
  .table-head-actions,
  .demo-tracks-head,
  .demo-tracks-row,
  .contact-table-head,
  .contact-table-row,
  .promo-table-head,
  .promo-table-row,
  .promo-template-table-head,
  .promo-template-table-row,
  .release-table-head,
  .release-table-row,
  .search-table-head,
  .search-table-row,
  .label-check-table-head,
  .label-check-table-row,
  .social-posts-head,
  .social-posts-row,
  .calendar-items-head,
  .calendar-items-row,
  .bookings-table-head,
  .bookings-table-row,
  .invoice-table-head,
  .invoice-table-row,
  .contracts-table-head,
  .contracts-table-row,
  .task-table-head,
  .task-table-row {
    grid-template-columns: 1fr;
  }

  .detail-list div {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .campaign-template-picker {
    grid-template-columns: 1fr;
  }

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

  .chat-widget {
    right: 14px;
    bottom: 14px;
  }

  .chat-panel {
    height: 420px;
  }
}
.admin-landing-panel{display:flex;align-items:center;justify-content:space-between;gap:24px}
.admin-landing-panel h2{margin:3px 0 7px}
.admin-landing-panel .primary-button{text-decoration:none;white-space:nowrap}
.admin-landing-contact-head,.admin-landing-contact-row{grid-template-columns:minmax(210px,1.2fr) minmax(180px,1fr) minmax(260px,1.8fr) 130px 100px}
.admin-landing-contact-row{align-items:start}
.admin-landing-contact-row small{display:block;margin-top:4px}
.admin-landing-contact-row a{color:var(--brand);text-decoration:none}
.admin-contact-message{white-space:pre-wrap;line-height:1.5;max-height:92px;overflow:auto}

@media(max-width:900px){
  .admin-landing-panel{align-items:flex-start;flex-direction:column}
  .admin-landing-contacts{overflow-x:auto}
  .admin-landing-contact-head,.admin-landing-contact-row{min-width:980px}
}

.location-dropdown{background:rgba(22,24,30,.92)!important;backdrop-filter:blur(6px)}
.location-option{padding:8px 12px;cursor:pointer;font-size:13px;line-height:1.4;border-bottom:1px solid rgba(255,255,255,.08);color:var(--text)}
.location-option:last-child{border-bottom:none}
.location-option:hover{background:rgba(255,255,255,.08)}

/* ─── KALENDER 2-KOLOM LAYOUT ────────────────────────────── */
.cal-layout{display:grid;grid-template-columns:1fr 280px;gap:20px;align-items:start}
.cal-main{min-width:0}
.cal-sidebar{min-width:0;position:sticky;top:20px}
.calendar-toolbar-inline{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600}
.calendar-toolbar-inline .ghost-button{padding:4px 10px;font-size:16px;font-weight:700}
.cal-upcoming-list{height:480px;overflow-y:scroll;display:flex;flex-direction:column;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.18) transparent}
.cal-upcoming-list::-webkit-scrollbar{width:4px}
.cal-upcoming-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:2px}
.cal-upcoming-row{display:flex;align-items:center;gap:9px;padding:8px 4px;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;transition:opacity .1s;font-size:12.5px;border-radius:6px}
.cal-upcoming-row:last-child{border-bottom:none}
.cal-upcoming-row:hover{opacity:.75}
.cal-upcoming-row.is-today{background:rgba(141,183,255,.06)}
.cal-upcoming-date{display:flex;flex-direction:column;align-items:center;min-width:26px;flex-shrink:0}
.cal-upcoming-date strong{font-size:13px;font-weight:700;line-height:1;color:var(--brand-2)}
.cal-upcoming-date small{font-size:9px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-muted)}
.cal-upcoming-bar{width:3px;height:28px;border-radius:2px;flex-shrink:0;background:rgba(141,183,255,.4)}
.cal-upcoming-body{flex:1;min-width:0}
.cal-upcoming-title{display:block;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-upcoming-meta{display:block;font-size:11px}
.cal-upcoming-row .event-boekingen,.cal-upcoming-row .event-booking{background:rgba(0,116,253,.7)}
.cal-upcoming-row .event-releases,.cal-upcoming-row .event-release{background:rgba(251,191,36,.7)}
.cal-upcoming-row .event-release-deadline{background:rgba(168,85,247,.7)}
.cal-upcoming-row .event-track-deadline{background:rgba(251,146,60,.7)}
.cal-upcoming-row .event-meeting{background:rgba(99,102,241,.7)}
.cal-upcoming-row .event-studio{background:rgba(14,165,233,.7)}
.cal-upcoming-row .event-fotoshoot{background:rgba(244,114,182,.7)}
.cal-upcoming-row .event-other{background:rgba(148,163,184,.7)}
.cal-upcoming-row .event-social{background:rgba(236,72,153,.7)}
.cal-subscribe{display:flex;flex-direction:column;gap:6px}
.cal-subscribe-btn{font-size:12px!important;justify-content:flex-start}
@media(max-width:900px){.cal-layout{grid-template-columns:1fr}}

/* ─── DASHBOARD HERO ─────────────────────────────────────── */
.db-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  background:
    radial-gradient(ellipse at 80% 50%, rgba(141,183,255,0.10), transparent 55%),
    radial-gradient(ellipse at 10% 100%, rgba(141,183,255,0.06), transparent 45%),
    var(--panel-2);
  border: 1px solid rgba(141,183,255,0.13);
  border-radius: 12px;
  padding: 24px 28px;
  margin-bottom: 24px;
}
.db-hero h1 {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.3px;
  margin-bottom: 4px;
}
.db-hero-stats {
  display: flex;
  gap: 2px;
  flex-shrink: 0;
}
.db-hero-stat {
  padding: 10px 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 8px;
  text-align: center;
  min-width: 80px;
  transition: border-color 0.15s;
}
.db-hero-stat:hover { border-color: rgba(141,183,255,0.25); }
.db-hero-stat strong {
  display: block;
  font-size: 20px;
  font-weight: 700;
  color: var(--brand-2);
  line-height: 1.1;
  margin-bottom: 3px;
}
.db-hero-stat span { font-size: 11px; color: var(--text-muted); font-weight: 500; text-transform: uppercase; letter-spacing: 0.4px; }

/* ─── DASHBOARD 2-COLUMN LAYOUT ──────────────────────────── */
.db-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 20px;
  align-items: start;
}
.db-main { min-width: 0; }
.db-sidebar { min-width: 0; }

/* ─── TAKEN LIJST ─────────────────────────────────────────── */
.db-task-list {
  padding: 0;
  max-height: 320px;
  overflow-y: auto;
}
.db-task-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  cursor: pointer;
  transition: background 0.12s;
  font-size: 13px;
}
.db-task-row:last-child { border-bottom: none; }
.db-task-row:hover { background: var(--panel-3); }
.db-task-check {
  width: 15px;
  height: 15px;
  border: 1.5px solid rgba(255,255,255,0.2);
  border-radius: 4px;
  flex-shrink: 0;
}
.db-task-check.done { background: var(--ok); border-color: var(--ok); }
.db-task-title { flex: 1; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.db-task-track { font-size: 12px; flex-shrink: 0; }
.db-task-date { flex-shrink: 0; font-size: 11px; }

/* ─── TAKEN PAGINA ────────────────────────────────────────── */
.taken-table { padding: 0; }

.taken-head,
.taken-row {
  display: grid;
  grid-template-columns: 22px 1.6fr 1fr 0.9fr 0.7fr;
  align-items: center;
  gap: 12px;
  padding: 9px 16px;
  font-size: 13px;
}

.taken-head {
  font-size: 10.5px;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .4px;
  border-bottom: 1px solid var(--line);
}

.taken-row {
  border-bottom: 1px solid rgba(255,255,255,.04);
  cursor: pointer;
  transition: background .12s;
}

.taken-row:last-child { border-bottom: none; }
.taken-row:hover { background: var(--panel-3); }

.taken-check {
  width: 15px;
  height: 15px;
  border: 1.5px solid rgba(255,255,255,.2);
  border-radius: 4px;
  flex-shrink: 0;
}

.taken-check.done { background: var(--ok); border-color: var(--ok); }
.taken-title { font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.taken-track, .taken-owner { font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.taken-date { font-size: 11px; }

/* ─── RECENTE TRACKS ──────────────────────────────────────── */
.db-track-list { padding: 0; }
.db-track-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  cursor: pointer;
  transition: background 0.12s;
}
.db-track-row:last-child { border-bottom: none; }
.db-track-row:hover { background: var(--panel-3); }
.db-track-thumb {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  object-fit: cover;
  color: rgba(255,255,255,.5);
}
.db-track-thumb svg { width: 50%; height: 50%; fill: currentColor; }
.db-track-info { flex: 1; min-width: 0; }
.db-track-info strong { display: block; font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.db-track-info span { font-size: 11.5px; }

/* ─── RELEASE GRID ────────────────────────────────────────── */
.db-release-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
}
.db-release-card {
  background: var(--panel);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.15s;
}
.db-release-card:hover { border-color: rgba(141,183,255,0.3); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.35); }
.db-release-art {
  width: 100%;
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.db-release-info { padding: 8px 10px 10px; }
.db-release-info strong { display: block; font-size: 12.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 2px; }
.db-release-info span { font-size: 11px; }

/* ─── MINI KALENDER ───────────────────────────────────────── */
.db-mini-cal { background: var(--panel); border: 1px solid rgba(255,255,255,0.07); border-radius: 10px; padding: 14px; }
.db-mini-cal-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; font-size: 13px; font-weight: 600; }
.db-mini-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.db-mini-cal-dayname { text-align: center; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px; color: var(--text-muted); padding: 3px 0 5px; }
.db-mini-cal-day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11.5px;
  border-radius: 5px;
  cursor: pointer;
  color: var(--text);
  transition: background 0.1s;
  position: relative;
}
.db-mini-cal-day:hover { background: var(--panel-3); }
.db-mini-cal-day.other-month { opacity: 0.25; pointer-events: none; }
.db-mini-cal-day.today { background: var(--brand); color: #07080d; font-weight: 700; }
.db-mini-cal-day.has-event::after { content: ''; position: absolute; bottom: 2px; left: 50%; transform: translateX(-50%); width: 3px; height: 3px; border-radius: 50%; background: var(--brand); }
.db-mini-cal-day.today::after { display: none; }

/* ─── AANKOMENDE EVENTS ───────────────────────────────────── */
.db-upcoming { display: flex; flex-direction: column; gap: 0; }
.db-upcoming-row {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  cursor: pointer;
  transition: background 0.1s;
  font-size: 12.5px;
}
.db-upcoming-row:last-child { border-bottom: none; }
.db-upcoming-row:hover { opacity: 0.8; }
.db-upcoming-date { display: flex; flex-direction: column; align-items: center; min-width: 28px; flex-shrink: 0; }
.db-upcoming-date strong { font-size: 13px; font-weight: 700; line-height: 1; color: var(--brand-2); }
.db-upcoming-date small { font-size: 9px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--text-muted); }
.db-upcoming-bar { width: 3px; height: 28px; border-radius: 2px; flex-shrink: 0; background: var(--brand-soft); }
.db-upcoming-body { flex: 1; min-width: 0; }
.db-upcoming-title { display: block; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.db-upcoming-cat { display: block; font-size: 11px; }

/* Kleurbalk per categorie */
.db-upcoming-row .event-boekingen, .db-upcoming-row .event-booking { background: rgba(0,116,253,.7); }
.db-upcoming-row .event-releases, .db-upcoming-row .event-release { background: rgba(251,191,36,.7); }
.db-upcoming-row .event-release-deadline { background: rgba(168,85,247,.7); }
.db-upcoming-row .event-track-deadline { background: rgba(251,146,60,.7); }
.db-upcoming-row .event-meeting { background: rgba(99,102,241,.7); }
.db-upcoming-row .event-studio { background: rgba(14,165,233,.7); }
.db-upcoming-row .event-fotoshoot { background: rgba(244,114,182,.7); }
.db-upcoming-row .event-other { background: rgba(148,163,184,.7); }
.db-upcoming-row .event-social { background: rgba(236,72,153,.7); }

/* ─── SIDEBAR OVERLAY (mobiel) ───────────────────────────────────── */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(0, 0, 0, 0.55);
  pointer-events: none;
}
.sidebar-overlay.visible {
  display: block;
  pointer-events: auto;
}

/* ─── TELEFOON (≤ 480px) ─────────────────────────────────────────── */
@media (max-width: 480px) {

  /* Modal: bottom sheet */
  .modal-backdrop {
    padding: 0;
    align-items: flex-end;
  }
  .modal {
    width: 100%;
    max-height: 92vh;
    border-radius: 16px 16px 0 0;
    padding: 16px 14px 24px;
  }

  /* Topbar compacter */
  .topbar {
    min-height: 56px;
    padding: 10px 12px;
    gap: 10px;
  }
  .topbar h1 {
    font-size: 17px;
  }
  .topbar .eyebrow {
    display: none;
  }
  .topbar-actions {
    gap: 6px;
  }

  /* Content minder padding */
  .content {
    padding: 10px;
    padding-bottom: 40px;
  }

  /* Touch targets: min 44px */
  input, select, button {
    min-height: 44px;
  }
  textarea {
    min-height: 80px;
  }
  .small-button {
    min-height: 32px !important;
  }

  /* Dashboard layout: 1 kolom */
  .db-layout {
    grid-template-columns: 1fr;
  }
  .db-hero {
    flex-direction: column;
    align-items: flex-start;
    padding: 14px 16px;
    gap: 12px;
  }
  .db-hero-stats {
    width: 100%;
  }
  .db-hero-stat {
    flex: 1;
    min-width: 60px;
    padding: 8px 10px;
  }

  /* Cal & db sidebars: 1 kolom */
  .db-layout,
  .cal-layout {
    grid-template-columns: 1fr;
  }

  /* Mileage tabel: data-labels tonen */
  .mileage-grid .table-row > span[data-label]::before {
    content: attr(data-label);
    display: block;
    font-size: 10px;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 2px;
  }

  /* Section title buttons full width */
  .section-title {
    gap: 8px;
  }
  .section-actions {
    width: 100%;
    flex-wrap: wrap;
  }
  .section-actions > * {
    flex: 1;
    text-align: center;
    justify-content: center;
  }

  /* Kaartjes iets minder padding */
  .card.pad {
    padding: 14px;
  }
  .metric-card {
    padding: 14px;
  }
}
