:root {
  --ink: #2b2d42;
  --muted: #737d92;
  --soft-muted: #8d99ae;
  --paper: #edf2f4;
  --card: #ffffff;
  --line: #d7dee4;
  --sidebar: #2b2d42;
  --sidebar-soft: #35384f;
  --orange: #ff5c1f;
  --orange-dark: #ef233c;
  --orange-soft: #fff0ea;
  --green: #00a6a6;
  --green-soft: #e2f7f7;
  --yellow: #ff5c1f;
  --yellow-soft: #fff0ea;
  --purple: #8d99ae;
  --purple-soft: #edf2f4;
  --blue: #00a6a6;
  --blue-soft: #e2f7f7;
  --red: #ef233c;
  --shadow: 0 14px 40px rgba(43, 45, 66, 0.09);
  --radius: 18px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  min-height: 100vh;
  background: var(--paper);
  color: var(--ink);
  font-family: "DM Sans", Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
}

[hidden] {
  display: none !important;
}

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

button {
  color: inherit;
}

button,
a {
  -webkit-tap-highlight-color: transparent;
}

button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid rgba(255, 92, 31, 0.28);
  outline-offset: 2px;
}

.app-shell {
  min-height: 100vh;
}

.sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 30;
  display: flex;
  width: 248px;
  flex-direction: column;
  padding: 26px 16px 18px;
  overflow-y: auto;
  color: #f7f6f1;
  background:
    radial-gradient(circle at 25% 0%, rgba(255, 92, 31, 0.16), transparent 28%),
    var(--sidebar);
}

.sidebar-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 8px;
}

.brand {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 0;
  border: 0;
  color: #fff;
  background: transparent;
  font: 800 17px/1 "Manrope", sans-serif;
  letter-spacing: -0.02em;
  cursor: pointer;
}

.brand-mark {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border-radius: 12px 12px 12px 4px;
  background: var(--orange);
  box-shadow: 0 7px 18px rgba(255, 92, 31, 0.22);
}

.brand-mark img {
  width: 25px;
  height: 25px;
  object-fit: contain;
}

.close-sidebar {
  display: none !important;
  color: #fff;
}

.quick-add {
  display: flex;
  height: 46px;
  align-items: center;
  gap: 10px;
  margin: 32px 4px 22px;
  padding: 0 13px;
  border: 1px solid rgba(141, 153, 174, 0.25);
  border-radius: 12px;
  color: #fff;
  background: var(--sidebar-soft);
  cursor: pointer;
  transition: 0.2s ease;
}

.quick-add:hover {
  border-color: rgba(255, 92, 31, 0.55);
  background: #3c4059;
  transform: translateY(-1px);
}

.quick-add svg {
  color: var(--orange);
}

.quick-add kbd {
  margin-left: auto;
  padding: 3px 7px;
  border: 1px solid rgba(141, 153, 174, 0.32);
  border-radius: 6px;
  color: #c4cbd5;
  background: #242638;
  font-size: 10px;
}

.main-nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.nav-label {
  margin: 0 12px 7px;
  color: #8d99ae;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.nav-label-spaced {
  margin-top: 19px;
}

.nav-item {
  position: relative;
  display: flex;
  width: 100%;
  height: 43px;
  align-items: center;
  gap: 12px;
  padding: 0 12px;
  border: 0;
  border-radius: 11px;
  color: #b8c0cc;
  background: transparent;
  font-size: 13px;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  transition: 0.18s ease;
}

.nav-item:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.04);
}

.nav-item.active {
  color: #fff;
  background: #3a3d56;
  box-shadow: inset 3px 0 var(--orange);
}

.nav-item.active svg {
  color: var(--orange);
}

.nav-item svg {
  width: 17px;
  height: 17px;
}

.nav-count {
  margin-left: auto;
  padding: 2px 7px;
  border-radius: 999px;
  color: #8f9088;
  background: #282925;
  font-size: 10px;
}

.signal-dot {
  width: 6px;
  height: 6px;
  margin-left: auto;
  border-radius: 50%;
  background: var(--orange);
  box-shadow: 0 0 0 4px rgba(255, 92, 31, 0.15);
}

.sidebar-foot {
  margin-top: auto;
  padding-top: 24px;
}

.progress-card {
  margin: 0 4px 16px;
  padding: 14px;
  border: 1px solid rgba(141, 153, 174, 0.2);
  border-radius: 13px;
  background: #242638;
}

.progress-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #d6d5cf;
  font-size: 11px;
}

.progress-card-head strong {
  color: var(--orange);
}

.progress-track {
  height: 5px;
  margin: 11px 0 8px;
  overflow: hidden;
  border-radius: 99px;
  background: #45495f;
}

.progress-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--orange);
}

.progress-card p {
  margin: 0;
  color: #85867e;
  font-size: 10px;
}

.user-card {
  display: flex;
  width: 100%;
  align-items: center;
  gap: 10px;
  padding: 10px 7px;
  border: 0;
  border-radius: 12px;
  color: #fff;
  background: transparent;
  text-align: left;
  cursor: pointer;
}

.user-card:hover {
  background: rgba(255, 255, 255, 0.04);
}

.avatar {
  display: inline-grid;
  flex: 0 0 auto;
  width: 35px;
  height: 35px;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background: var(--purple);
  font-size: 11px;
  font-weight: 700;
}

.avatar-dark {
  border: 1px solid #4c4d47;
  background: #373833;
}

.avatar-orange {
  background: #ff5c1f;
}

.avatar-green {
  background: #00a6a6;
}

.avatar-blue {
  background: #8d99ae;
}

.avatar-yellow {
  background: #ff5c1f;
}

.avatar-pink {
  background: #ef233c;
}

.user-copy {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
}

.user-copy strong {
  font-size: 12px;
}

.user-copy small {
  margin-top: 2px;
  color: #85867e;
  font-size: 10px;
}

.user-card > svg {
  width: 14px;
  color: #6e6f68;
}

.main-content {
  min-height: 100vh;
  margin-left: 248px;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  height: 76px;
  align-items: center;
  justify-content: space-between;
  padding: 0 34px;
  border-bottom: 1px solid rgba(141, 153, 174, 0.24);
  background: rgba(237, 242, 244, 0.9);
  backdrop-filter: blur(16px);
}

.topbar-left,
.topbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.global-search {
  display: flex;
  width: min(360px, 40vw);
  height: 41px;
  align-items: center;
  gap: 10px;
  padding: 0 11px;
  border: 1px solid transparent;
  border-radius: 11px;
  color: #98978f;
  background: #e2e8ec;
  transition: 0.2s ease;
}

.global-search:focus-within {
  border-color: #d9d6cc;
  background: #fff;
  box-shadow: 0 5px 20px rgba(37, 35, 29, 0.05);
}

.global-search svg {
  width: 17px;
}

.global-search input {
  width: 100%;
  border: 0;
  outline: 0;
  color: var(--ink);
  background: transparent;
  font-size: 12px;
}

.global-search input::placeholder {
  color: #98978f;
}

kbd {
  font-family: inherit;
}

.global-search kbd {
  flex: 0 0 auto;
  padding: 3px 7px;
  border: 1px solid #d9d7d0;
  border-radius: 5px;
  color: #99978f;
  background: #f5f4f0;
  font-size: 9px;
}

.icon-button {
  display: inline-grid;
  width: 38px;
  height: 38px;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: 10px;
  background: transparent;
  cursor: pointer;
  transition: 0.18s ease;
}

.icon-button:hover {
  background: #e9e7e1;
}

.icon-button svg {
  width: 19px;
  height: 19px;
}

.notification-button {
  position: relative;
}

.notification-dot {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 6px;
  height: 6px;
  border: 1px solid var(--paper);
  border-radius: 50%;
  background: var(--orange);
}

.notification-count {
  position: absolute;
  top: -4px;
  right: -5px;
  display: grid;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  place-items: center;
  border: 2px solid var(--paper);
  border-radius: 999px;
  color: #fff;
  background: var(--orange);
  font-size: 9px;
  font-weight: 800;
}

.menu-button {
  display: none;
}

.primary-button,
.secondary-button,
.ghost-button {
  display: inline-flex;
  min-height: 39px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 15px;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: 0.18s ease;
}

.primary-button {
  border: 1px solid var(--orange);
  color: #fff;
  background: var(--orange);
  box-shadow: 0 5px 14px rgba(255, 92, 31, 0.24);
}

.primary-button:hover {
  border-color: var(--orange-dark);
  background: var(--orange-dark);
  transform: translateY(-1px);
}

.secondary-button {
  border: 1px solid var(--line);
  color: #56554f;
  background: #fff;
}

.secondary-button:hover,
.ghost-button:hover {
  border-color: #d5d2c8;
  background: #faf9f6;
}

.ghost-button {
  border: 1px solid transparent;
  color: #6d6c65;
  background: transparent;
}

.primary-button svg,
.secondary-button svg,
.ghost-button svg {
  width: 15px;
}

.view-container {
  max-width: 1500px;
  margin: 0 auto;
  padding: 34px;
  animation: viewIn 0.28s ease;
}

@keyframes viewIn {
  from {
    opacity: 0;
    transform: translateY(5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.page-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 25px;
}

.page-heading h1 {
  margin: 0 0 5px;
  font: 800 clamp(25px, 3vw, 34px)/1.15 "Manrope", sans-serif;
  letter-spacing: -0.045em;
}

.page-heading p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.heading-actions {
  display: flex;
  gap: 9px;
}

.date-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: #727169;
  background: #fff;
  font-size: 10px;
}

.date-pill svg {
  width: 13px;
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 16px;
}

.metric-card {
  position: relative;
  min-height: 138px;
  padding: 19px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 1px 1px rgba(37, 35, 29, 0.02);
}

.metric-card::after {
  position: absolute;
  right: -34px;
  bottom: -55px;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: var(--metric-glow, transparent);
  content: "";
}

.metric-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--muted);
  font-size: 11px;
  font-weight: 600;
}

.metric-icon {
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  border-radius: 8px;
  color: var(--metric-color, var(--orange));
  background: var(--metric-bg, var(--orange-soft));
}

.metric-icon svg {
  width: 14px;
}

.metric-value {
  margin: 15px 0 7px;
  font: 800 27px/1 "Manrope", sans-serif;
  letter-spacing: -0.04em;
}

.metric-foot {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #99978f;
  font-size: 10px;
}

.trend {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  color: var(--green);
  font-weight: 700;
}

.trend.down {
  color: var(--red);
}

.trend.neutral {
  color: #62615b;
}

.trend svg {
  width: 11px;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.85fr);
  gap: 16px;
}

.stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.panel {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 1px 1px rgba(37, 35, 29, 0.02);
}

.panel-header {
  display: flex;
  min-height: 65px;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 0 19px;
  border-bottom: 1px solid #efede7;
}

.panel-header h2 {
  margin: 0;
  font: 700 14px/1.2 "Manrope", sans-serif;
}

.panel-header p {
  margin: 4px 0 0;
  color: var(--soft-muted);
  font-size: 10px;
}

.panel-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  flex-wrap: wrap;
}

.panel-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0;
  border: 0;
  color: var(--orange-dark);
  background: transparent;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
}

.panel-link svg {
  width: 12px;
}

.chart-wrap {
  padding: 18px 19px 13px;
}

.chart-meta {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 10px;
}

.chart-meta strong {
  font: 800 24px/1 "Manrope", sans-serif;
}

.chart-meta span {
  color: var(--green);
  font-size: 10px;
  font-weight: 700;
}

.revenue-chart {
  width: 100%;
  height: 185px;
  overflow: visible;
}

.chart-grid-line {
  stroke: #efede7;
  stroke-width: 1;
}

.chart-area {
  fill: url(#areaGradient);
}

.chart-line {
  fill: none;
  stroke: var(--orange);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.5;
}

.chart-dot {
  fill: #fff;
  stroke: var(--orange);
  stroke-width: 2;
}

.chart-labels {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  margin-top: -2px;
  color: #aaa89f;
  font-size: 9px;
  text-align: center;
}

.pipeline {
  padding: 16px 18px 19px;
}

.pipeline-bar {
  display: flex;
  height: 10px;
  gap: 3px;
  margin: 4px 0 18px;
  overflow: hidden;
  border-radius: 999px;
}

.pipeline-bar span {
  min-width: 6px;
  border-radius: inherit;
}

.pipeline-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

.pipeline-item {
  padding-right: 9px;
  border-right: 1px solid #efede7;
}

.pipeline-item:last-child {
  border: 0;
}

.pipeline-item p {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 6px;
  color: var(--muted);
  font-size: 9px;
}

.pipeline-item p::before {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--dot);
  content: "";
}

.pipeline-item strong {
  display: block;
  font: 700 14px/1 "Manrope", sans-serif;
}

.pipeline-item small {
  color: #a09f97;
  font-size: 9px;
}

.activity-list {
  padding: 4px 18px 9px;
}

.activity-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 11px;
  min-height: 61px;
  border-bottom: 1px solid #f0eee9;
}

.activity-item:last-child {
  border: 0;
}

.activity-icon {
  display: grid;
  width: 31px;
  height: 31px;
  place-items: center;
  border-radius: 9px;
  color: var(--activity-color);
  background: var(--activity-bg);
}

.activity-icon svg {
  width: 14px;
}

.activity-copy strong,
.activity-copy span {
  display: block;
}

.activity-copy strong {
  margin-bottom: 3px;
  font-size: 10px;
  font-weight: 600;
}

.activity-copy span {
  overflow: hidden;
  color: #95938b;
  font-size: 9px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.activity-time {
  color: #aaa89f;
  font-size: 9px;
}

.agenda-list {
  padding: 13px 18px 18px;
}

.agenda-date {
  display: grid;
  grid-template-columns: 35px 1fr;
  gap: 13px;
}

.agenda-date + .agenda-date {
  margin-top: 15px;
}

.day-badge {
  text-align: center;
}

.day-badge strong {
  display: block;
  font: 800 18px/1 "Manrope", sans-serif;
}

.day-badge span {
  color: #a3a198;
  font-size: 8px;
  font-weight: 700;
  text-transform: uppercase;
}

.agenda-event {
  position: relative;
  padding: 10px 12px;
  border-left: 3px solid var(--event-color);
  border-radius: 0 8px 8px 0;
  background: var(--event-bg);
}

.agenda-event + .agenda-event {
  margin-top: 7px;
}

.agenda-event strong {
  display: block;
  margin-bottom: 3px;
  font-size: 10px;
}

.agenda-event span {
  color: #8d8b82;
  font-size: 9px;
}

.table-panel {
  overflow: hidden;
}

.table-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 15px 18px;
  border-bottom: 1px solid var(--line);
}

.toolbar-search {
  display: flex;
  width: 280px;
  height: 38px;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #9e9c93;
  background: #faf9f6;
}

.toolbar-search svg {
  width: 15px;
}

.toolbar-search input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  font-size: 11px;
}

.toolbar-group {
  display: flex;
  gap: 8px;
}

.filter-select {
  height: 38px;
  padding: 0 29px 0 11px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #66645e;
  background: #fff;
  font-size: 11px;
}

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

.data-table th {
  padding: 12px 18px;
  color: #96948b;
  background: #faf9f6;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-align: left;
  text-transform: uppercase;
}

.data-table td {
  padding: 14px 18px;
  border-top: 1px solid #f0eee8;
  color: #66645e;
  font-size: 11px;
}

.data-table tbody tr {
  transition: 0.15s ease;
}

.data-table tbody tr:hover {
  background: #fcfbf8;
}

.table-person {
  display: flex;
  align-items: center;
  gap: 10px;
}

.table-person-copy strong,
.table-person-copy span {
  display: block;
}

.table-person-copy strong {
  margin-bottom: 2px;
  color: var(--ink);
  font-size: 11px;
}

.table-person-copy span {
  color: #a09e95;
  font-size: 9px;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 8px;
  border-radius: 999px;
  color: var(--status-color);
  background: var(--status-bg);
  font-size: 9px;
  font-weight: 700;
}

.status-pill::before {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  content: "";
}

.row-actions {
  display: flex;
  justify-content: flex-end;
}

.row-actions button {
  width: 30px;
  height: 30px;
}

.empty-state {
  padding: 60px 20px;
  color: var(--muted);
  text-align: center;
}

.empty-state-icon {
  display: grid;
  width: 48px;
  height: 48px;
  margin: 0 auto 13px;
  place-items: center;
  border-radius: 14px;
  color: var(--orange);
  background: var(--orange-soft);
}

.empty-state h3 {
  margin: 0 0 5px;
  color: var(--ink);
  font: 700 15px "Manrope", sans-serif;
}

.empty-state p {
  margin: 0;
  font-size: 11px;
}

.project-grid,
.apps-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 15px;
}

.project-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  padding: 12px 14px;
}

.project-toolbar .toolbar-search {
  flex: 1;
}

.project-tabs {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding: 10px;
  overflow-x: auto;
  border-color: rgba(215, 222, 228, 0.9);
  background: rgba(255, 255, 255, 0.82);
}

.project-tabs .project-tab {
  appearance: none;
  -webkit-appearance: none;
  display: flex;
  min-height: 44px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 13px;
  color: var(--muted);
  background: #fff;
  box-shadow: none;
  font-size: 11px;
  font-weight: 800;
  cursor: pointer;
  white-space: nowrap;
  transition: 0.18s ease;
}

.project-tabs .project-tab:hover {
  border-color: rgba(255, 92, 31, 0.28);
  color: var(--ink);
  background: #fbfaf8;
  transform: translateY(-1px);
}

.project-tabs .project-tab.active {
  border-color: rgba(255, 92, 31, 0.28);
  color: var(--tab-color);
  background: var(--tab-bg);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.7), 0 8px 18px rgba(43, 45, 66, 0.06);
}

.project-tabs .project-tab-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--tab-color);
}

.project-tabs .project-tab small {
  display: grid;
  min-width: 26px;
  height: 24px;
  place-items: center;
  border-radius: 8px;
  color: var(--muted);
  background: var(--paper);
  font-size: 10px;
}

.project-tabs .project-tab.active small {
  color: var(--tab-color);
  background: rgba(255, 255, 255, 0.75);
}

.project-toolbar-tabs {
  margin-bottom: 20px;
  padding: 14px 18px;
}

.project-result-count {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  padding: 0 12px;
  border-radius: 10px;
  color: var(--muted);
  background: var(--paper);
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}

.project-card {
  padding: 19px;
}

.project-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.project-company {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #89877f;
  font-size: 10px;
}

.company-logo {
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  border-radius: 8px;
  color: #fff;
  background: var(--logo-color);
  font-size: 10px;
  font-weight: 800;
}

.project-card h3 {
  min-height: 42px;
  margin: 16px 0 7px;
  font: 700 15px/1.4 "Manrope", sans-serif;
}

.project-card > p {
  display: -webkit-box;
  overflow: hidden;
  margin: 0;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.6;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.project-progress-head {
  display: flex;
  justify-content: space-between;
  margin: 20px 0 7px;
  color: #8f8d84;
  font-size: 9px;
}

.project-progress-head strong {
  color: var(--ink);
}

.project-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 17px;
  padding-top: 14px;
  border-top: 1px solid #efede7;
  color: #8e8c83;
  font-size: 9px;
}

.project-meta > span,
.lead-card-foot > span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.project-meta svg,
.lead-card-foot svg {
  width: 12px;
  height: 12px;
}

.mini-avatars {
  display: flex;
}

.mini-avatars .avatar {
  width: 25px;
  height: 25px;
  margin-left: -6px;
  border: 2px solid #fff;
  font-size: 7px;
}

.mini-avatars .avatar:first-child {
  margin-left: 0;
}

.kanban-board {
  display: grid;
  grid-template-columns: repeat(6, minmax(230px, 1fr));
  gap: 13px;
  overflow-x: auto;
  padding-bottom: 7px;
}

.kanban-column {
  min-height: 540px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: #eeede8;
}

.kanban-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 3px 3px 13px;
}

.kanban-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 11px;
  font-weight: 700;
}

.kanban-title::before {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--column-color);
  content: "";
}

.kanban-count {
  display: grid;
  width: 21px;
  height: 21px;
  place-items: center;
  border-radius: 6px;
  color: #8d8b83;
  background: #e2e1db;
  font-size: 9px;
}

.lead-card {
  margin-bottom: 9px;
  padding: 14px;
  border: 1px solid #e5e3dc;
  border-radius: 12px;
  background: #fff;
  cursor: grab;
  transition: 0.18s ease;
}

.lead-card:hover {
  border-color: #d4d1c7;
  box-shadow: 0 8px 18px rgba(37, 35, 29, 0.05);
  transform: translateY(-1px);
}

.lead-card:focus-visible {
  outline: 2px solid var(--orange);
  outline-offset: 2px;
}

.lead-card.dragging {
  opacity: 0.5;
}

.kanban-column.drag-over {
  outline: 2px dashed var(--orange);
  outline-offset: -5px;
}

.lead-card-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.lead-card h3 {
  margin: 0;
  font-size: 11px;
}

.lead-card p {
  margin: 4px 0 14px;
  color: #9b9990;
  font-size: 9px;
}

.lead-value {
  font: 700 13px "Manrope", sans-serif;
}

.lead-weighted {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: 7px;
  color: #99978f;
  font-size: 7px;
}

.lead-weighted strong {
  color: #5f5d56;
  font-size: 8px;
}

.lead-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 13px;
  padding-top: 11px;
  border-top: 1px solid #f0eee8;
  color: #99978e;
  font-size: 8px;
}

.lead-temp {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.lead-temp::before {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--temp-color);
  content: "";
}

.opportunity-detail-hero {
  margin-bottom: 16px;
}

.opportunity-control {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 170px 150px auto;
  align-items: end;
  gap: 14px;
  margin-bottom: 16px;
  padding: 17px 19px;
}

.opportunity-control h2 {
  margin: 0;
  font: 700 13px "Manrope", sans-serif;
}

.opportunity-control p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 8px;
}

.opportunity-control label {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 5px;
  color: #77756e;
  font-size: 8px;
  font-weight: 700;
}

.opportunity-control select,
.opportunity-control input {
  width: 100%;
  height: 36px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #55534d;
  background: #fff;
  font: 500 9px "DM Sans", sans-serif;
}

.opportunity-control label small {
  position: absolute;
  right: 10px;
  bottom: 11px;
  color: var(--muted);
  font-size: 8px;
}

.opportunity-control input {
  padding-right: 24px;
}

.opportunity-notes > p {
  min-height: 75px;
  margin: 0;
  padding: 5px 18px 17px;
  color: #67655f;
  font-size: 10px;
  line-height: 1.65;
  white-space: pre-line;
}

.opportunity-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 0 18px 18px;
}

.opportunity-meta span {
  padding: 10px;
  border-radius: 9px;
  color: #77756e;
  background: var(--paper);
  font-size: 8px;
}

.opportunity-meta strong {
  display: block;
  margin-bottom: 4px;
  color: #45433e;
  font-size: 8px;
}

.conversion-actions {
  display: grid;
  gap: 8px;
  padding: 5px 18px 18px;
}

.conversion-actions button {
  width: 100%;
}

.calendar-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 285px;
  gap: 16px;
}

.calendar-panel {
  overflow: hidden;
}

.calendar-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
}

.calendar-toolbar h2 {
  margin: 0;
  font: 700 15px "Manrope", sans-serif;
  text-transform: capitalize;
}

.calendar-nav {
  display: flex;
  gap: 5px;
}

.calendar-nav button {
  display: inline-grid;
  width: 31px;
  height: 31px;
  place-items: center;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
}

.calendar-nav svg {
  width: 14px;
  height: 14px;
}

.calendar-weekdays,
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}

.calendar-weekdays {
  border-bottom: 1px solid var(--line);
  background: #faf9f6;
}

.calendar-weekdays span {
  padding: 10px;
  color: #9a988f;
  font-size: 8px;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
}

.calendar-day {
  position: relative;
  min-height: 105px;
  padding: 9px;
  border-right: 1px solid #efede7;
  border-bottom: 1px solid #efede7;
  background: #fff;
  color: inherit;
  font-family: inherit;
  text-align: left;
  cursor: pointer;
}

.calendar-day:hover,
.calendar-day.selected {
  position: relative;
  z-index: 1;
  background: #fff7f2;
  box-shadow: inset 0 0 0 2px rgba(255, 92, 31, 0.42);
}

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

.calendar-day.muted {
  color: #c3c1ba;
  background: #fbfaf8;
}

.calendar-day.today .day-number {
  color: #fff;
  background: var(--orange);
}

.day-number {
  display: grid;
  width: 24px;
  height: 24px;
  place-items: center;
  border-radius: 7px;
  font-size: 9px;
  font-weight: 600;
}

.calendar-event {
  margin-top: 5px;
  padding: 5px 6px;
  overflow: hidden;
  border-left: 2px solid var(--event-color);
  border-radius: 4px;
  color: #5f5d57;
  background: var(--event-bg);
  font-size: 8px;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.today-panel {
  padding: 18px;
}

.today-panel h3 {
  margin: 0 0 4px;
  font: 700 14px "Manrope", sans-serif;
}

.today-panel > p {
  margin: 0 0 19px;
  color: var(--muted);
  font-size: 10px;
}

.selected-date-add {
  width: 100%;
  margin-top: 14px;
}

.timeline-item {
  position: relative;
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 10px;
  min-height: 73px;
}

.timeline-item:not(:last-child)::after {
  position: absolute;
  top: 30px;
  bottom: 2px;
  left: 45px;
  width: 1px;
  background: #e9e7e0;
  content: "";
}

.timeline-time {
  padding-top: 2px;
  color: #9b9991;
  font-size: 9px;
}

.timeline-event {
  position: relative;
  padding-left: 14px;
}

.timeline-event::before {
  position: absolute;
  top: 3px;
  left: 0;
  width: 7px;
  height: 7px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: var(--event-color);
  box-shadow: 0 0 0 1px var(--event-color);
  content: "";
}

.timeline-event strong {
  display: block;
  font-size: 10px;
}

.timeline-event span {
  display: block;
  margin-top: 4px;
  color: #96948b;
  font-size: 9px;
  line-height: 1.4;
}

.app-card {
  display: flex;
  min-height: 145px;
  flex-direction: column;
  padding: 18px;
  cursor: pointer;
  transition: 0.2s ease;
}

.app-card:hover {
  border-color: #d3d0c7;
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}

.app-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.app-card-actions {
  display: flex;
  align-items: center;
  gap: 3px;
}

.app-card-actions .icon-button {
  width: 29px;
  height: 29px;
}

.app-card-actions .icon-button svg {
  width: 13px;
}

.danger-icon {
  color: var(--red);
}

.danger-icon:hover {
  background: #fff0ee;
}

.danger-outline {
  color: var(--red);
  border-color: #efc8c4;
  background: #fff8f7;
}

.danger-outline:hover {
  border-color: var(--red);
  background: #fff0ee;
}

.app-logo {
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border-radius: 12px;
  color: var(--app-color);
  background: var(--app-bg);
  font: 800 13px "Manrope", sans-serif;
}

.app-logo svg {
  width: 20px;
}

.app-card h3 {
  margin: 6px 0 4px;
  font: 700 12px "Manrope", sans-serif;
}

.app-card p {
  margin: 0;
  color: #96948c;
  font-size: 9px;
}

.app-open {
  color: #aaa89f;
}

.app-open svg {
  width: 15px;
}

.app-category {
  margin-top: 13px;
  color: var(--orange-dark);
  font-size: 8px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.browser-window {
  margin-bottom: 18px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow);
}

.browser-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  border-bottom: 1px solid var(--line);
  background: #f9f8f5;
}

.browser-dots {
  display: flex;
  gap: 5px;
}

.browser-dots span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #d8d6cf;
}

.browser-address {
  display: flex;
  height: 32px;
  flex: 1;
  align-items: center;
  gap: 7px;
  padding: 0 10px;
  border: 1px solid #e2e0da;
  border-radius: 8px;
  background: #fff;
}

.browser-address svg {
  width: 13px;
  color: #9a988f;
}

.browser-address input {
  width: 100%;
  border: 0;
  outline: 0;
  color: #6f6d66;
  background: transparent;
  font-size: 10px;
}

.browser-external {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: #62615b;
  background: #fff;
  font-size: 9px;
  font-weight: 700;
  text-decoration: none;
}

.browser-go,
.browser-reload {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  border: 1px solid var(--orange);
  border-radius: 8px;
  color: #fff;
  background: var(--orange);
  font-size: 9px;
  font-weight: 800;
  cursor: pointer;
}

.browser-reload {
  border-color: var(--line);
  color: #62615b;
  background: #fff;
}

.browser-go svg,
.browser-reload svg {
  width: 13px;
}

.browser-external svg {
  width: 13px;
}

.browser-help {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 7px;
  padding: 9px 14px;
  border-top: 1px solid var(--line);
  color: #78766f;
  background: #faf9f6;
  font-size: 8px;
}

.browser-help span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.browser-help span:first-child {
  color: #327b5e;
  font-weight: 700;
  white-space: nowrap;
}

.browser-help svg {
  width: 12px;
}

.browser-frame {
  display: grid;
  min-height: 420px;
  place-items: center;
  background:
    linear-gradient(rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.94)),
    radial-gradient(circle at 50% 30%, var(--orange-soft), transparent 35%);
}

.browser-frame iframe {
  width: 100%;
  height: 520px;
  border: 0;
}

.browser-placeholder {
  max-width: 360px;
  padding: 45px 20px;
  text-align: center;
}

.browser-placeholder .empty-state-icon {
  width: 58px;
  height: 58px;
}

.browser-placeholder h3 {
  margin: 0 0 7px;
  font: 700 16px "Manrope", sans-serif;
}

.browser-placeholder p {
  margin: 0;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.6;
}

.mailbox-connect {
  display: grid;
  min-height: 360px;
  place-items: center;
  align-content: center;
  padding: 40px;
  text-align: center;
}

.mailbox-connect h2 {
  margin: 12px 0 7px;
  font: 700 17px "Manrope", sans-serif;
}

.mailbox-connect p {
  max-width: 480px;
  margin: 0 0 20px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.6;
}

.mailbox-layout {
  display: grid;
  min-height: 620px;
  grid-template-columns: minmax(280px, 0.72fr) minmax(0, 1.5fr);
  gap: 16px;
}

.mailbox-list-panel,
.mailbox-reader {
  overflow: hidden;
}

.mailbox-list-head,
.mailbox-reader-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
  border-bottom: 1px solid var(--line);
}

.mailbox-list-head h2,
.mailbox-reader-head h2 {
  margin: 0;
  font: 700 14px "Manrope", sans-serif;
}

.mailbox-list-head p,
.mailbox-reader-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 9px;
}

.mailbox-message-list {
  max-height: 560px;
  overflow-y: auto;
}

.mailbox-message {
  position: relative;
  display: flex;
  width: 100%;
  flex-direction: column;
  gap: 5px;
  padding: 14px 16px;
  border: 0;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  background: #fff;
  text-align: left;
  cursor: pointer;
}

.mailbox-message:hover,
.mailbox-message.active {
  background: #fff7f2;
}

.mailbox-message.unread::before {
  position: absolute;
  top: 19px;
  left: 6px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--orange);
  content: "";
}

.mailbox-message-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.mailbox-message-top strong {
  overflow: hidden;
  font-size: 10px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mailbox-message-top time,
.mailbox-message small {
  color: var(--muted);
  font-size: 8px;
}

.mailbox-subject {
  overflow: hidden;
  font-size: 9px;
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mailbox-status {
  display: flex;
  min-height: 160px;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 20px;
  color: var(--muted);
  font-size: 9px;
  text-align: center;
}

.mailbox-status svg {
  width: 15px;
}

.mailbox-error {
  color: var(--red);
}

.mailbox-reader {
  min-width: 0;
}

.mailbox-reader-head .eyebrow {
  color: var(--orange-dark);
}

.mailbox-recipient {
  padding: 11px 20px;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-size: 9px;
}

.mailbox-body {
  min-height: 360px;
  margin: 0;
  padding: 24px 22px;
  overflow: auto;
  color: #494842;
  background: #fff;
  font: 10px/1.7 "DM Sans", sans-serif;
  white-space: pre-wrap;
  word-break: break-word;
}

.mailbox-html {
  width: 100%;
  min-height: 430px;
  border: 0;
  background: #fff;
}

.mailbox-reader-empty {
  display: grid;
  min-height: 540px;
  place-items: center;
  align-content: center;
  padding: 30px;
  color: var(--muted);
  text-align: center;
}

.mailbox-reader-empty svg {
  width: 35px;
  margin-bottom: 10px;
  color: var(--orange);
}

.mailbox-reader-empty h2 {
  margin: 0 0 6px;
  color: var(--ink);
  font: 700 15px "Manrope", sans-serif;
}

.mailbox-reader-empty p {
  margin: 0;
  font-size: 9px;
}

.mailbox-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 14px 20px;
  border-top: 1px solid var(--line);
  font-size: 9px;
}

.mailbox-attachments strong {
  width: 100%;
}

.mailbox-attachments span,
.mailbox-attachments a {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 9px;
  border-radius: 8px;
  color: var(--ink);
  background: var(--paper);
  text-decoration: none;
}

.mailbox-attachments svg {
  width: 13px;
}

.compose-email-body {
  min-height: 260px !important;
}

.drive-connect {
  display: grid;
  min-height: 360px;
  place-items: center;
  align-content: center;
  padding: 40px;
  text-align: center;
}

.drive-connect h2 {
  margin: 12px 0 7px;
  font: 700 17px "Manrope", sans-serif;
}

.drive-connect p {
  max-width: 520px;
  margin: 0 0 20px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.6;
}

.drive-browser {
  overflow: hidden;
}

.drive-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
}

.drive-toolbar .toolbar-search {
  max-width: 320px;
}

.drive-path {
  display: flex;
  min-width: 0;
  align-items: center;
  gap: 4px;
  overflow-x: auto;
}

.drive-path > button,
.drive-path span,
.drive-path span button {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border: 0;
  color: #66645e;
  background: transparent;
  font-size: 9px;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
}

.drive-path svg {
  width: 13px;
}

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

.drive-item {
  display: grid;
  min-width: 0;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 72px;
  padding: 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  color: var(--ink);
  background: #fff;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
}

.drive-item:hover {
  border-color: #d5b8aa;
  background: #fffaf7;
}

.drive-file-icon {
  display: grid;
  width: 36px;
  height: 36px;
  place-items: center;
  border-radius: 9px;
  color: #00A6A6;
  background: #E2F7F7;
}

.drive-file-icon.folder {
  color: var(--orange);
  background: var(--orange-soft);
}

.drive-file-icon svg,
.drive-item > svg {
  width: 16px;
}

.drive-item > svg {
  color: var(--muted);
}

.drive-item strong,
.drive-item small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.drive-item strong {
  font-size: 10px;
}

.drive-item small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 8px;
}

.drive-status {
  display: flex;
  min-height: 320px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--muted);
  font-size: 10px;
}

.drive-error {
  color: var(--red);
}

.email-editor-toolbar {
  display: flex;
  gap: 5px;
  padding: 7px;
  border: 1px solid var(--line);
  border-bottom: 0;
  border-radius: 9px 9px 0 0;
  background: var(--paper);
}

.email-editor-toolbar button {
  display: grid;
  width: 30px;
  height: 28px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  cursor: pointer;
}

.email-editor-toolbar svg {
  width: 13px;
}

.email-editor {
  overflow-y: auto;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 0 0 9px 9px;
  outline: 0;
  background: #fbfaf8;
  font-size: 11px;
}

.analytics-grid {
  display: grid;
  grid-template-columns: 1.4fr 0.8fr;
  gap: 15px;
}

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

.donut-layout {
  display: flex;
  align-items: center;
  gap: 25px;
  padding: 25px;
}

.donut {
  position: relative;
  display: grid;
  width: 145px;
  height: 145px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 50%;
  background: conic-gradient(var(--orange) 0 42%, var(--green) 42% 70%, var(--purple) 70% 88%, #e8e6df 88%);
}

.donut::after {
  position: absolute;
  width: 92px;
  height: 92px;
  border-radius: 50%;
  background: #fff;
  content: "";
}

.donut-copy {
  position: relative;
  z-index: 1;
  text-align: center;
}

.donut-copy strong {
  display: block;
  font: 800 21px "Manrope", sans-serif;
}

.donut-copy span {
  color: #9b9990;
  font-size: 8px;
}

.legend {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 12px;
}

.legend-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 8px;
  font-size: 10px;
}

.legend-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--legend-color);
}

.legend-item span {
  color: var(--muted);
}

.legend-item strong {
  font-size: 10px;
}

.performance-list {
  padding: 18px;
}

.performance-item {
  display: grid;
  grid-template-columns: 95px 1fr 42px;
  align-items: center;
  gap: 12px;
  min-height: 40px;
  font-size: 9px;
}

.performance-bar {
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: #eeece6;
}

.performance-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--bar-color);
}

.performance-item strong {
  text-align: right;
}

.auth-screen {
  display: grid;
  min-height: 100vh;
  padding: 36px 20px;
  place-items: center;
  background:
    radial-gradient(circle at 15% 10%, rgba(255, 92, 31, 0.16), transparent 25%),
    radial-gradient(circle at 85% 85%, rgba(0, 166, 166, 0.12), transparent 30%),
    var(--paper);
}

.auth-brand {
  position: absolute;
  top: 30px;
  left: 34px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--ink);
  font: 800 19px "Manrope", sans-serif;
  letter-spacing: -0.02em;
}

.auth-brand .brand-mark {
  color: var(--ink);
}

.auth-card {
  width: min(430px, 100%);
  padding: 34px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(34, 32, 27, 0.12);
}

.auth-card h1 {
  margin: 0 0 9px;
  font: 800 28px/1.15 "Manrope", sans-serif;
  letter-spacing: -0.04em;
}

.auth-intro {
  margin: 0 0 25px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.auth-submit {
  width: 100%;
  min-height: 46px;
  margin-top: 5px;
}

.auth-submit:disabled {
  opacity: 0.65;
  cursor: wait;
}

.auth-error {
  margin: 0;
  padding: 10px 12px;
  border-radius: 9px;
  color: #a44942;
  background: #FFE8EC;
  font-size: 10px;
}

.auth-switch {
  display: block;
  margin: 18px auto 0;
  padding: 0;
  border: 0;
  color: var(--orange-dark);
  background: transparent;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
}

.auth-footnote {
  position: absolute;
  bottom: 24px;
  margin: 0;
  color: #96948b;
  font-size: 9px;
}

.clickable-row,
.project-card[data-open-project] {
  cursor: pointer;
}

.detail-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 16px;
  padding: 22px;
}

.detail-identity {
  display: flex;
  align-items: center;
  gap: 13px;
}

.detail-identity h2,
.project-detail-hero h2 {
  margin: 0 0 3px;
  font: 800 18px "Manrope", sans-serif;
}

.detail-identity p,
.project-detail-hero p {
  margin: 0;
  color: var(--muted);
  font-size: 10px;
}

.detail-avatar {
  width: 52px;
  height: 52px;
  font-size: 14px;
}

.detail-identity .status-pill {
  margin-left: 9px;
}

.detail-contact {
  display: flex;
  align-items: flex-end;
  flex-direction: column;
  gap: 8px;
  color: #77756d;
  font-size: 10px;
}

.detail-contact a,
.detail-contact span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: inherit;
  text-decoration: none;
}

.detail-contact svg {
  width: 13px;
}

.detail-metrics {
  margin-bottom: 16px;
}

.detail-grid,
.finance-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.8fr);
  gap: 16px;
}

.project-detail-hero {
  align-items: flex-start;
}

.project-detail-hero > div {
  max-width: 720px;
}

.project-detail-hero h2 {
  margin-top: 14px;
}

.project-detail-hero p {
  font-size: 11px;
  line-height: 1.6;
}

.notes-list,
.task-list {
  padding: 7px 18px 14px;
}

.note-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 11px;
  padding: 14px 0;
  border-bottom: 1px solid #f0eee8;
}

.note-item:last-child {
  border: 0;
}

.note-item p {
  margin: 0 0 5px;
  color: #56544e;
  font-size: 11px;
  line-height: 1.55;
}

.note-item small {
  color: #9c9a92;
  font-size: 9px;
}

.compact-list {
  padding: 6px 17px 12px;
}

.compact-item {
  display: grid;
  width: 100%;
  min-height: 58px;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  border: 0;
  border-bottom: 1px solid #f0eee8;
  background: transparent;
  text-align: left;
  cursor: pointer;
}

.compact-item:last-child {
  border-bottom: 0;
}

.compact-item.static {
  cursor: default;
}

.compact-item > svg {
  width: 14px;
  color: #aaa89f;
}

.compact-item strong,
.compact-item small {
  display: block;
}

.compact-item strong {
  color: var(--ink);
  font-size: 10px;
}

.compact-item small {
  margin-top: 3px;
  color: #98968e;
  font-size: 8px;
}

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

.compact-empty {
  margin: 0;
  padding: 22px 0;
  color: #9a988f;
  font-size: 10px;
  text-align: center;
}

.task-item {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  min-height: 58px;
  border-bottom: 1px solid #f0eee8;
}

.task-toggle {
  display: grid;
  cursor: pointer;
}

.task-item:last-child {
  border: 0;
}

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

.task-check {
  display: grid;
  width: 21px;
  height: 21px;
  place-items: center;
  border: 1px solid #d8d6ce;
  border-radius: 6px;
  color: transparent;
}

.task-check svg {
  width: 12px;
}

.task-toggle input:checked + .task-check {
  border-color: var(--green);
  color: #fff;
  background: var(--green);
}

.task-item:has(.task-toggle input:checked) .task-copy strong {
  color: #96948b;
  text-decoration: line-through;
}

.task-actions {
  display: flex;
  gap: 3px;
}

.task-actions .icon-button {
  width: 29px;
  height: 29px;
}

.invoice-row {
  grid-template-columns: auto minmax(0, 1fr) auto auto auto auto;
}

.task-item strong,
.task-item small {
  display: block;
}

.task-item strong {
  font-size: 10px;
}

.task-item small {
  margin-top: 4px;
  color: #99978f;
  font-size: 8px;
}

.campaign-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 13px;
  margin-bottom: 15px;
}

.campaign-kpi {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
}

.campaign-kpi strong,
.campaign-kpi span {
  display: block;
}

.campaign-kpi strong {
  font: 800 20px "Manrope", sans-serif;
}

.campaign-kpi div span {
  color: var(--muted);
  font-size: 9px;
}

.campaigns-panel {
  margin-bottom: 25px;
}

.campaigns-list {
  padding: 4px 18px 10px;
}

.campaign-row {
  display: grid;
  width: 100%;
  min-height: 67px;
  grid-template-columns: auto minmax(180px, 1fr) repeat(3, 75px) auto auto;
  align-items: center;
  gap: 12px;
  padding: 0;
  border: 0;
  border-bottom: 1px solid #f0eee8;
  background: transparent;
  text-align: left;
  cursor: pointer;
  transition: 0.15s ease;
}

.campaign-row:last-child {
  border: 0;
}

.campaign-row:hover {
  background: #fcfbf8;
}

.campaign-row > svg {
  width: 14px;
  color: #aaa89f;
}

.campaign-name strong,
.campaign-name small,
.campaign-stat strong,
.campaign-stat span {
  display: block;
}

.campaign-name strong {
  font-size: 10px;
}

.campaign-name small,
.campaign-stat span {
  margin-top: 3px;
  color: #99978f;
  font-size: 8px;
}

.campaign-stat strong {
  font: 700 12px "Manrope", sans-serif;
}

.section-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin: 0 0 12px;
}

.section-heading h2 {
  margin: 0;
  font: 700 15px "Manrope", sans-serif;
}

.section-heading p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 9px;
}

.campaign-detail-hero {
  margin-bottom: 16px;
}

.campaign-channel-icon {
  display: grid;
  width: 52px;
  height: 52px;
  place-items: center;
  border-radius: 14px;
  color: var(--orange);
  background: var(--orange-soft);
}

.campaign-channel-icon svg {
  width: 22px;
}

.campaign-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.7fr);
  gap: 16px;
}

.mailchimp-panel,
.mailchimp-workspace {
  margin-bottom: 16px;
}

.mailchimp-panel {
  display: grid;
  min-height: 92px;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 15px;
  padding: 18px 20px;
  border-color: #ffd2bf;
  background: linear-gradient(135deg, #fff 0%, #fff7f2 100%);
}

.mailchimp-panel h2,
.mailchimp-workspace h2 {
  margin: 0;
  font: 700 13px "Manrope", sans-serif;
}

.mailchimp-panel p,
.mailchimp-workspace p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 9px;
  line-height: 1.5;
}

.mailchimp-panel code,
.mailchimp-composer code {
  color: #b84416;
  font-size: 8px;
}

.mailchimp-mark {
  display: grid;
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 12px;
  color: #fff;
  background: var(--orange);
}

.mailchimp-mark svg {
  width: 19px;
}

.mailchimp-mark.large {
  width: 54px;
  height: 54px;
  margin: 0 auto 14px;
  border-radius: 16px;
}

.mailchimp-workspace {
  padding: 19px 20px;
  border-color: #ffd2bf;
}

.mailchimp-workspace-head,
.mailchimp-title {
  display: flex;
  align-items: center;
}

.mailchimp-workspace-head {
  justify-content: space-between;
  gap: 18px;
}

.mailchimp-title {
  gap: 12px;
}

.mailchimp-report-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 17px;
}

.mailchimp-report-grid > div {
  padding: 12px;
  border-radius: 10px;
  background: var(--paper);
}

.mailchimp-report-grid span,
.mailchimp-report-grid strong,
.mailchimp-report-grid small {
  display: block;
}

.mailchimp-report-grid span,
.mailchimp-report-grid small {
  color: var(--muted);
  font-size: 8px;
}

.mailchimp-report-grid strong {
  margin: 5px 0 2px;
  font: 800 17px "Manrope", sans-serif;
}

.mailchimp-settings {
  padding-bottom: 8px;
}

.warning-note {
  margin: 0 22px 16px;
  color: #8b621f;
  background: #fff4dc;
}

.mailchimp-composer {
  padding-top: 4px;
}

.mailchimp-composer-intro {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  padding: 13px;
  border-radius: 12px;
  background: #fff7f2;
}

.mailchimp-composer-intro strong,
.mailchimp-composer-intro p {
  display: block;
}

.mailchimp-composer-intro strong {
  font-size: 10px;
}

.mailchimp-composer-intro p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 8px;
}

.code-textarea {
  min-height: 260px !important;
  font: 9px/1.55 ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace !important;
}

.mailchimp-builder {
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr) minmax(300px, 0.85fr);
  align-items: start;
  gap: 13px;
}

.mailchimp-block-palette,
.mailchimp-canvas-panel,
.mailchimp-preview-panel {
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
}

.mailchimp-block-palette {
  background: #fffaf7;
}

.mailchimp-block-palette > strong,
.mailchimp-builder-head strong {
  color: var(--ink);
  font: 800 11px "Manrope", sans-serif;
}

.mailchimp-block-palette > p,
.mailchimp-builder-head small {
  display: block;
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 8px;
  line-height: 1.45;
}

.mailchimp-tools,
.mailchimp-block-list {
  display: grid;
  gap: 9px;
}

.mailchimp-tools {
  margin-top: 13px;
}

.mailchimp-tool {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 2px 9px;
  align-items: center;
  width: 100%;
  padding: 9px;
  border: 1px solid #f1ded5;
  border-radius: 12px;
  color: var(--ink);
  background: #fff;
  text-align: left;
  cursor: grab;
  transition: 0.18s ease;
}

.mailchimp-tool:hover {
  border-color: rgba(255, 92, 31, 0.45);
  transform: translateY(-1px);
  box-shadow: 0 10px 26px rgba(43, 45, 66, 0.08);
}

.mailchimp-tool:active {
  cursor: grabbing;
}

.mailchimp-tool > span {
  display: grid;
  width: 34px;
  height: 34px;
  grid-row: 1 / span 2;
  place-items: center;
  border-radius: 10px;
  color: #fff;
  background: var(--orange);
}

.mailchimp-tool svg {
  width: 16px;
}

.mailchimp-tool strong,
.mailchimp-tool small {
  display: block;
}

.mailchimp-tool strong {
  font-size: 9px;
}

.mailchimp-tool small {
  color: var(--muted);
  font-size: 7px;
  line-height: 1.35;
}

.mailchimp-builder-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 11px;
}

.mailchimp-block-list {
  min-height: 190px;
  border-radius: 16px;
}

.mailchimp-block-list.drag-over {
  outline: 2px dashed rgba(255, 92, 31, 0.45);
  outline-offset: 4px;
}

.mailchimp-block-card {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(43, 45, 66, 0.05);
  cursor: grab;
  transition: 0.18s ease;
}

.mailchimp-block-card.dragging {
  opacity: 0.58;
}

.mailchimp-block-card.drag-over {
  border-color: var(--orange);
  box-shadow: 0 0 0 3px rgba(255, 92, 31, 0.1);
}

.mailchimp-block-head {
  display: flex;
  align-items: center;
  gap: 8px;
}

.mailchimp-block-head strong {
  font-size: 10px;
}

.mailchimp-drag-handle {
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  border-radius: 9px;
  color: var(--muted);
  background: var(--paper);
}

.mailchimp-drag-handle svg {
  width: 15px;
}

.mailchimp-block-actions {
  display: flex;
  gap: 4px;
  margin-left: auto;
}

.mailchimp-block-actions .icon-button {
  width: 28px;
  height: 28px;
  border-radius: 9px;
}

.mailchimp-block-actions .icon-button:disabled {
  cursor: not-allowed;
  opacity: 0.34;
}

.mailchimp-block-fields {
  display: grid;
  gap: 9px;
  margin-top: 11px;
}

.mailchimp-block-fields label {
  display: grid;
  gap: 5px;
  color: #65635d;
  font-size: 9px;
  font-weight: 700;
}

.mailchimp-block-fields input,
.mailchimp-block-fields textarea {
  width: 100%;
  min-height: 38px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  outline: 0;
  color: var(--ink);
  background: #fbfaf8;
  font-size: 10px;
}

.mailchimp-block-fields textarea {
  min-height: 80px;
  resize: vertical;
}

.mailchimp-block-fields p {
  margin: 0;
  color: var(--muted);
  font-size: 9px;
}

.mailchimp-empty-builder {
  display: grid;
  min-height: 150px;
  place-items: center;
  padding: 18px;
  border: 1px dashed #d8d1ca;
  border-radius: 14px;
  color: var(--muted);
  background: #fbfaf8;
  font-size: 10px;
  text-align: center;
}

.mailchimp-empty-builder svg {
  width: 18px;
  margin-bottom: 6px;
  color: var(--orange);
}

.mailchimp-preview-frame {
  width: 100%;
  min-height: 500px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--paper);
}

.field > small {
  margin-top: 5px;
  color: var(--muted);
  font-size: 8px;
}

.consent-check,
.confirmation-check {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: #66645e;
  background: var(--paper);
  font-size: 9px;
  line-height: 1.5;
}

.consent-check {
  margin: 2px 22px 0;
}

.confirmation-check {
  max-width: 410px;
  margin: 0 auto 18px;
  text-align: left;
}

.delivery-options {
  display: grid;
  gap: 9px;
  margin-bottom: 15px;
}

.delivery-options label {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: flex-start;
  gap: 10px;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: 11px;
  cursor: pointer;
}

.delivery-options strong,
.delivery-options small {
  display: block;
}

.delivery-options strong {
  font-size: 10px;
}

.delivery-options small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 8px;
}

.checklist-list {
  display: grid;
  gap: 8px;
  margin: 16px 0;
  text-align: left;
}

.checklist-list > div {
  padding: 10px 11px;
  border: 1px solid #efc8c4;
  border-radius: 9px;
  background: #fff8f7;
}

.checklist-list strong,
.checklist-list span {
  display: block;
}

.checklist-list strong {
  color: var(--red);
  font-size: 9px;
}

.checklist-list span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 8px;
  line-height: 1.5;
}

.campaign-targets-panel {
  overflow: hidden;
}

.target-toolbar {
  flex-wrap: wrap;
  background: #fff;
}

.target-toolbar .toolbar-search {
  width: min(430px, 100%);
}

.target-result-count {
  margin-left: auto;
  color: var(--muted);
  font-size: 9px;
  font-weight: 700;
  white-space: nowrap;
}

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

.target-table {
  min-width: 1060px;
}

.target-contact-info,
.target-next-action {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.target-contact-info span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: #85837b;
  font-size: 9px;
}

.target-contact-info svg {
  width: 11px;
  height: 11px;
}

.target-next-action strong,
.target-next-action span {
  display: block;
}

.target-next-action strong {
  font-size: 9px;
}

.target-next-action span {
  color: #9b9991;
  font-size: 8px;
}

.target-status-select {
  min-width: 135px;
  height: 31px;
  padding: 0 24px 0 9px;
  border: 0;
  border-radius: 999px;
  color: var(--status-color);
  background: var(--status-bg);
  font-size: 9px;
  font-weight: 700;
}

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

.target-actions a {
  color: var(--green);
  background: var(--green-soft);
}

.small-button {
  min-height: 31px;
  padding: 0 9px;
  white-space: nowrap;
}

.campaign-activity-list {
  padding: 5px 18px 12px;
}

.campaign-activity {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  padding: 13px 0;
  border-bottom: 1px solid #f0eee8;
}

.campaign-activity:last-child {
  border: 0;
}

.campaign-activity strong {
  font-size: 10px;
}

.campaign-activity p {
  margin: 4px 0;
  color: #77756e;
  font-size: 9px;
  line-height: 1.45;
}

.campaign-activity small {
  color: #9b9991;
  font-size: 8px;
}

.call-contact-card {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  padding: 12px;
  border-radius: 11px;
  background: #f7f6f2;
}

.call-contact-card strong,
.call-contact-card span {
  display: block;
}

.call-contact-card strong {
  font-size: 11px;
}

.call-contact-card div span {
  margin-top: 3px;
  color: #8f8d85;
  font-size: 9px;
}

.appointment-scheduler {
  display: grid;
  gap: 13px;
  padding: 14px;
  border: 1px solid #dbe7e7;
  border-radius: 15px;
  background: linear-gradient(135deg, #fff 0%, #f3fbfb 100%);
}

.appointment-scheduler-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.appointment-scheduler-head strong,
.appointment-scheduler-head span {
  display: block;
}

.appointment-scheduler-head strong {
  font-size: 11px;
}

.appointment-scheduler-head span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 9px;
}

.appointment-agenda {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: #fff;
}

.appointment-agenda-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--ink);
}

.appointment-agenda-head strong {
  font-size: 10px;
}

.appointment-agenda-head span,
.appointment-busy-list {
  color: var(--muted);
  font-size: 8px;
}

.appointment-slots {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(62px, 1fr));
  gap: 7px;
}

.appointment-slot {
  min-height: 31px;
  border: 1px solid #d8eeee;
  border-radius: 9px;
  color: #177b78;
  background: #effafa;
  font-size: 9px;
  font-weight: 800;
  cursor: pointer;
}

.appointment-slot:hover,
.appointment-slot.selected {
  border-color: var(--teal);
  color: #fff;
  background: var(--teal);
}

.appointment-slot.busy {
  cursor: not-allowed;
  color: #9b9991;
  background: #efeee9;
  opacity: 0.72;
}

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

.appointment-busy-list strong {
  color: var(--ink);
}

.integrations-panel {
  margin-bottom: 16px;
}

.integration-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 18px;
  padding: 5px 19px 12px;
}

.integration-item {
  display: grid;
  min-height: 74px;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 11px;
  border-bottom: 1px solid #f0eee8;
}

.integration-item strong {
  font-size: 10px;
}

.integration-item p {
  margin: 4px 0 0;
  color: #98968e;
  font-size: 8px;
}

.integration-item .secondary-button {
  min-height: 32px;
  padding: 0 10px;
  font-size: 9px;
}

.transaction-list {
  padding: 5px 18px 12px;
}

.project-finance-list {
  padding: 4px 18px 12px;
}

.project-finance-row {
  display: grid;
  width: 100%;
  min-height: 68px;
  grid-template-columns: auto minmax(160px, 1fr) auto 95px 125px auto;
  align-items: center;
  gap: 11px;
  padding: 0;
  border: 0;
  border-bottom: 1px solid var(--line);
  background: transparent;
  text-align: left;
  cursor: pointer;
}

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

.project-finance-row:hover {
  background: #fcfbf8;
}

.project-finance-row strong,
.project-finance-row small {
  display: block;
}

.project-finance-row strong {
  font-size: 9px;
}

.project-finance-row small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 8px;
}

.project-finance-row > svg {
  width: 13px;
  color: #aaa89f;
}

.finance-footnote {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-top: 14px;
  padding: 11px 13px;
  border-radius: 10px;
  color: #66645e;
  background: #EDF2F4;
  font-size: 9px;
}

.finance-footnote svg {
  width: 14px;
}

.transaction-row {
  display: grid;
  min-height: 66px;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 11px;
  border-bottom: 1px solid #f0eee8;
}

.transaction-row:last-child {
  border: 0;
}

.transaction-row strong,
.transaction-row small {
  display: block;
}

.transaction-row strong {
  font-size: 10px;
}

.transaction-row small {
  margin-top: 4px;
  color: #99978f;
  font-size: 8px;
}

.amount-positive {
  color: var(--green);
}

.amount-negative {
  color: #77756e;
}

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

.settings-card {
  display: flex;
  min-height: 265px;
  flex-direction: column;
  align-items: flex-start;
  padding: 21px;
}

.settings-icon {
  display: grid;
  width: 37px;
  height: 37px;
  margin-bottom: 17px;
  place-items: center;
  border-radius: 10px;
  color: var(--purple);
  background: var(--purple-soft);
}

.settings-icon.green {
  color: var(--green);
  background: var(--green-soft);
}

.settings-icon.orange {
  color: var(--orange);
  background: var(--orange-soft);
}

.settings-icon svg {
  width: 17px;
}

.settings-card h2 {
  margin: 0 0 6px;
  font: 700 14px "Manrope", sans-serif;
}

.settings-card > div > p {
  margin: 0;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.5;
}

.account-box {
  display: flex;
  width: 100%;
  align-items: center;
  gap: 10px;
  margin-top: auto;
  padding: 13px;
  border-radius: 11px;
  background: #f7f6f2;
}

.account-box strong,
.account-box span {
  display: block;
}

.account-box strong {
  font-size: 10px;
}

.account-box div span {
  margin-top: 3px;
  color: #96948c;
  font-size: 8px;
}

.data-health {
  display: grid;
  width: 100%;
  grid-template-columns: repeat(4, 1fr);
  margin: 18px 0;
  border: 1px solid var(--line);
  border-radius: 11px;
}

.data-health span {
  padding: 10px 5px;
  border-right: 1px solid var(--line);
  color: #99978f;
  font-size: 7px;
  text-align: center;
}

.data-health span:last-child {
  border: 0;
}

.data-health strong {
  display: block;
  margin-bottom: 3px;
  color: var(--ink);
  font-size: 13px;
}

.settings-lines {
  width: 100%;
  margin: 14px 0;
}

.settings-lines div {
  display: flex;
  justify-content: space-between;
  padding: 7px 0;
  border-bottom: 1px solid #f0eee8;
  font-size: 9px;
}

.settings-lines strong {
  color: var(--orange-dark);
}

.settings-card > button {
  margin-top: auto;
}

.settings-goal-form {
  display: grid;
  width: 100%;
  gap: 8px;
  margin-top: auto;
}

.settings-goal-form label {
  color: var(--muted);
  font-size: 9px;
  font-weight: 700;
}

.settings-goal-form input {
  width: 100%;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 9px;
  outline: 0;
  background: var(--paper);
}

.settings-data-actions {
  display: flex;
  width: 100%;
  gap: 8px;
  margin-top: auto;
}

.settings-data-actions button {
  flex: 1;
}

.company-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 15px;
  padding: 12px 14px;
}

.company-toolbar .toolbar-search {
  flex: 1;
}

.company-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 15px;
}

.company-card {
  display: grid;
  width: 100%;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
  padding: 15px;
  color: var(--ink);
  text-align: left;
  cursor: pointer;
}

.company-card:hover {
  border-color: rgba(255, 92, 31, 0.35);
  box-shadow: 0 10px 28px rgba(43, 45, 66, 0.08);
}

.company-card > svg {
  width: 15px;
  color: var(--muted);
}

.company-card-copy,
.company-card-value {
  min-width: 0;
}

.company-card-copy strong,
.company-card-copy small,
.company-card-value strong,
.company-card-value small {
  display: block;
}

.company-card-copy strong {
  margin-bottom: 4px;
  font-size: 12px;
}

.company-card-copy small,
.company-card-value small {
  color: var(--muted);
  font-size: 9px;
}

.company-card-value {
  text-align: right;
}

.company-card-value strong {
  margin-bottom: 4px;
  color: var(--orange-dark);
  font-size: 12px;
}

.table-company-link {
  padding: 0;
  border: 0;
  color: var(--purple);
  background: transparent;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.current-contact {
  border-color: rgba(255, 92, 31, 0.25);
  background: #fffaf7;
}

.forecast-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 20px;
}

.forecast-summary > div {
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: var(--paper);
}

.forecast-summary span,
.forecast-summary strong,
.forecast-summary small {
  display: block;
}

.forecast-summary span,
.forecast-summary small {
  color: var(--muted);
  font-size: 9px;
}

.forecast-summary strong {
  margin: 7px 0 5px;
  font: 800 18px "Manrope", sans-serif;
}

.backup-import-note {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 13px;
  margin-bottom: 16px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: var(--paper);
}

.backup-import-note strong,
.backup-import-note p {
  display: block;
}

.backup-import-note strong {
  margin-bottom: 4px;
  font-size: 12px;
}

.backup-import-note p {
  margin: 0;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.55;
}

.backup-confirm {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-top: 14px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.5;
}

.backup-confirm input {
  margin-top: 2px;
  accent-color: var(--orange);
}

.danger-card {
  border-color: #ecd9d6;
}

.team-panel {
  margin-top: 16px;
  overflow: hidden;
}

.team-list {
  padding: 0 20px 10px;
}

.team-row {
  display: grid;
  min-height: 70px;
  grid-template-columns: 36px minmax(190px, 1fr) 115px 170px 36px;
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid #f0eee8;
}

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

.team-person strong,
.team-person span {
  display: block;
}

.team-person strong {
  font-size: 10px;
}

.team-person span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 9px;
}

.seat-status,
.role-pill {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: 5px;
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 8px;
  font-weight: 700;
}

.active-seat {
  color: #327b5e;
  background: var(--green-soft);
}

.pending-seat {
  color: #a66e16;
  background: var(--yellow-soft);
}

.role-pill {
  color: #6650a0;
  background: var(--purple-soft);
}

.team-role-select {
  width: 100%;
  height: 34px;
  padding: 0 28px 0 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: #62615b;
  background: #fff;
  font-size: 9px;
}

.team-footnote {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 12px 20px;
  border-top: 1px solid var(--line);
  color: #77756e;
  background: #faf9f6;
  font-size: 8px;
}

.team-footnote svg {
  width: 13px;
}

.integration-modal {
  padding: 27px;
  text-align: center;
}

.integration-modal h3 {
  margin: 0 0 8px;
  font: 700 16px "Manrope", sans-serif;
}

.integration-modal > p {
  margin: 0 auto 16px;
  max-width: 390px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.6;
}

.google-setup-list {
  display: grid;
  gap: 8px;
  margin: 18px 0;
  text-align: left;
}

.google-setup-list span {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 11px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: #696760;
  background: var(--paper);
  font-size: 9px;
  line-height: 1.5;
}

.google-setup-list strong {
  color: var(--orange-dark);
}

.google-setup-list code {
  padding: 1px 4px;
  border-radius: 4px;
  color: #554693;
  background: var(--purple-soft);
  font-size: 8px;
}

.security-note {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 20px;
  padding: 11px;
  border-radius: 9px;
  color: #43715d;
  background: var(--green-soft);
  font-size: 9px;
  text-align: left;
}

.security-note svg {
  width: 14px;
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  visibility: hidden;
  padding: 20px;
  place-items: center;
  background: rgba(25, 25, 22, 0.48);
  opacity: 0;
  backdrop-filter: blur(5px);
  transition: 0.2s ease;
}

.modal-backdrop.open {
  visibility: visible;
  opacity: 1;
}

.modal {
  width: min(520px, 100%);
  max-height: min(760px, calc(100vh - 40px));
  overflow-y: auto;
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 30px 80px rgba(27, 26, 23, 0.25);
  transform: translateY(10px) scale(0.98);
  transition: 0.2s ease;
}

.modal-wide {
  width: min(900px, 100%);
}

.modal-mailchimp-builder {
  width: min(1180px, 100%);
}

.modal-document {
  width: min(1040px, 100%);
}

.modal-notifications {
  width: min(620px, 100%);
}

.notifications-modal {
  padding: 0 22px 22px;
}

.notifications-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 52px;
  color: var(--muted);
  font-size: 10px;
}

.notification-list {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 14px;
}

.notification-item {
  position: relative;
  display: grid;
  width: 100%;
  min-height: 78px;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 13px 15px;
  border: 0;
  border-bottom: 1px solid var(--line);
  background: #fff;
  text-align: left;
  cursor: pointer;
}

.notification-item:last-child {
  border-bottom: 0;
}

.notification-item:hover,
.notification-item.unread {
  background: #fffaf7;
}

.notification-item strong,
.notification-item small,
.notification-item time {
  display: block;
}

.notification-item strong {
  margin-bottom: 4px;
  font-size: 10px;
}

.notification-item small {
  color: #77756e;
  font-size: 9px;
}

.notification-item time {
  margin-top: 5px;
  color: #aaa89f;
  font-size: 8px;
}

.notification-unread-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--orange);
}

.invite-success,
.confirmation-modal {
  padding: 26px;
  text-align: center;
}

.invite-success h3,
.confirmation-modal h3 {
  margin: 0 0 8px;
  font: 700 16px "Manrope", sans-serif;
}

.invite-success > p,
.confirmation-modal > p {
  margin: 0 auto 18px;
  max-width: 410px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.6;
}

.invite-link {
  display: flex;
  gap: 8px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: var(--paper);
}

.invite-link input {
  min-width: 0;
  flex: 1;
  border: 0;
  outline: 0;
  color: #68665f;
  background: transparent;
  font-size: 9px;
}

.danger-state {
  color: var(--red);
  background: #fff0ee;
}

.danger-button {
  border-color: var(--red);
  background: var(--red);
  box-shadow: none;
}

.danger-button:hover {
  border-color: #ad4e47;
  background: #ad4e47;
}

.bulk-import {
  padding: 20px 23px 23px;
}

.bulk-intro {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}

.bulk-intro p {
  max-width: 650px;
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.bulk-intro > div {
  flex: 1;
}

.bulk-filters {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 15px;
  margin-bottom: 16px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--paper);
}

.bulk-search {
  grid-column: span 2;
}

.bulk-result-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 10px;
}

.bulk-result-head strong {
  font-size: 14px;
}

.bulk-select-all,
.bulk-client-row {
  position: relative;
}

.bulk-select-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 13px;
  cursor: pointer;
}

.bulk-select-all input,
.bulk-client-row > input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.bulk-select-all .task-check,
.bulk-client-row .task-check {
  flex: 0 0 auto;
}

.bulk-select-all input:checked + .task-check,
.bulk-client-row > input:checked + .task-check {
  border-color: var(--purple);
  color: #fff;
  background: var(--purple);
}

.bulk-results {
  max-height: 320px;
  margin-bottom: 16px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
}

.bulk-client-row {
  display: grid;
  grid-template-columns: 21px 34px minmax(220px, 1fr) 110px 75px 100px;
  align-items: center;
  gap: 12px;
  min-width: 720px;
  padding: 13px 15px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 0.18s ease;
}

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

.bulk-client-row:hover {
  background: var(--paper);
}

.bulk-client-main {
  min-width: 0;
}

.bulk-client-main strong,
.bulk-client-main small,
.bulk-client-metric strong,
.bulk-client-metric small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bulk-client-main strong {
  margin-bottom: 3px;
  font-size: 14px;
}

.bulk-client-main small,
.bulk-client-metric {
  color: var(--muted);
  font-size: 12px;
}

.bulk-client-metric {
  text-align: right;
}

.bulk-empty {
  padding: 34px 20px;
  color: var(--muted);
  text-align: center;
}

.bulk-empty svg,
.bulk-empty strong,
.bulk-empty span {
  display: block;
  margin: 0 auto;
}

.bulk-empty svg {
  width: 24px;
  margin-bottom: 10px;
}

.bulk-empty strong {
  margin-bottom: 4px;
  color: var(--ink);
}

.bulk-settings {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.csv-import {
  padding: 20px 23px 23px;
}

.csv-import-intro {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 16px;
}

.csv-import-intro > div {
  flex: 1;
}

.csv-import-intro strong,
.csv-import-intro p {
  display: block;
}

.csv-import-intro strong {
  margin-bottom: 4px;
  font-size: 13px;
}

.csv-import-intro p {
  margin: 0;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.55;
}

.csv-dropzone {
  display: grid;
  min-height: 125px;
  place-items: center;
  align-content: center;
  gap: 7px;
  padding: 20px;
  border: 1.5px dashed #d9b6a5;
  border-radius: 16px;
  color: var(--orange);
  background: #fffaf7;
  text-align: center;
  cursor: pointer;
  transition: 0.18s ease;
}

.csv-dropzone:hover {
  border-color: var(--orange);
  background: #fff5ef;
}

.csv-dropzone > svg {
  width: 25px;
}

.csv-dropzone strong {
  color: var(--ink);
  font-size: 13px;
}

.csv-dropzone span {
  color: var(--muted);
  font-size: 10px;
}

.csv-dropzone input {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
}

.csv-import-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 15px;
  margin: 15px 0 9px;
  padding: 11px 13px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: var(--paper);
}

.csv-import-summary strong {
  font-size: 11px;
}

.csv-import-summary span {
  color: var(--muted);
  font-size: 9px;
}

.csv-preview-scroll {
  max-height: 260px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 12px;
}

.csv-preview-table {
  width: 100%;
  min-width: 700px;
  border-collapse: collapse;
}

.csv-preview-table th,
.csv-preview-table td {
  max-width: 170px;
  padding: 9px 10px;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  color: #65635d;
  font-size: 9px;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.csv-preview-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  color: var(--ink);
  background: #f7f6f2;
  font-weight: 800;
}

.csv-preview-table tr:last-child td {
  border-bottom: 0;
}

.csv-row-error {
  background: #fff6f5;
}

.csv-valid,
.csv-invalid {
  display: inline-flex;
  padding: 4px 7px;
  border-radius: 999px;
  font-size: 8px;
  font-weight: 800;
}

.csv-valid {
  color: #327b5e;
  background: var(--green-soft);
}

.csv-invalid {
  color: var(--red);
  background: #ffecef;
}

.csv-preview-note {
  margin: 8px 2px 0;
  color: var(--muted);
  font-size: 9px;
}

.modal-backdrop.open .modal {
  transform: translateY(0) scale(1);
}

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 22px 23px 17px;
  border-bottom: 1px solid var(--line);
}

.eyebrow {
  margin: 0 0 4px;
  color: var(--orange-dark);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.modal-header h2 {
  margin: 0;
  font: 800 19px "Manrope", sans-serif;
  letter-spacing: -0.03em;
}

.choice-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  padding: 22px;
}

.choice-card {
  display: flex;
  min-height: 95px;
  flex-direction: column;
  align-items: flex-start;
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: #fff;
  cursor: pointer;
  transition: 0.18s ease;
}

.choice-card:hover {
  border-color: rgba(255, 92, 31, 0.45);
  background: #fffaf7;
}

.choice-card span:first-child {
  display: grid;
  width: 30px;
  height: 30px;
  margin-bottom: 12px;
  place-items: center;
  border-radius: 8px;
  color: var(--orange);
  background: var(--orange-soft);
}

.choice-card svg {
  width: 15px;
}

.choice-card strong {
  font-size: 11px;
}

.choice-card small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 9px;
  text-align: left;
}

.form {
  padding: 21px 23px 23px;
}

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

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

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

.field label {
  color: #65635d;
  font-size: 10px;
  font-weight: 700;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  min-height: 40px;
  padding: 9px 11px;
  border: 1px solid var(--line);
  border-radius: 9px;
  outline: 0;
  color: var(--ink);
  background: #fbfaf8;
  font-size: 11px;
}

.field textarea {
  min-height: 85px;
  resize: vertical;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: rgba(255, 92, 31, 0.55);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(255, 92, 31, 0.08);
}

.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 9px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.document-preview {
  padding: 0 22px 22px;
}

.document-preview-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.document-preview-head strong {
  display: block;
  font: 800 16px/1.2 "Manrope", sans-serif;
}

.document-preview-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 11px;
}

.document-frame {
  display: block;
  width: 100%;
  height: min(68vh, 720px);
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--paper);
}

.document-preview-empty {
  display: grid;
  min-height: 280px;
  place-items: center;
  padding: 28px;
  border: 1px dashed var(--line);
  border-radius: 16px;
  color: var(--muted);
  background: #fbfaf8;
  text-align: center;
}

.document-preview-empty svg {
  width: 38px;
  color: var(--orange);
}

.document-preview-empty h3 {
  margin: 10px 0 4px;
  color: var(--ink);
}

.document-actions a {
  text-decoration: none;
}

.email-attachment-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 14px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fbfaf8;
  color: var(--muted);
  font-size: 11px;
}

.email-attachment-preview strong,
.email-attachment-preview span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.email-attachment-preview strong {
  color: var(--ink);
}

.email-attachment-preview svg {
  width: 14px;
  color: var(--orange);
}

.monthly-results-table {
  padding: 16px;
  overflow-x: auto;
}

.monthly-results-head,
.monthly-results-row {
  display: grid;
  grid-template-columns: 115px repeat(6, minmax(120px, 1fr));
  min-width: 860px;
  gap: 10px;
  align-items: center;
}

.monthly-results-head {
  padding: 0 0 10px;
  color: var(--muted);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.monthly-results-row {
  padding: 12px 0;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 11px;
}

.monthly-results-row strong {
  color: var(--ink);
}

.toast {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 200;
  display: flex;
  visibility: hidden;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border: 1px solid #dfe9e3;
  border-radius: 11px;
  color: #355e4c;
  background: #f2faf5;
  box-shadow: 0 15px 35px rgba(37, 35, 29, 0.13);
  font-size: 11px;
  font-weight: 600;
  opacity: 0;
  transform: translateY(10px);
  transition: 0.25s ease;
}

.toast.show {
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
}

.toast-icon {
  display: grid;
  width: 22px;
  height: 22px;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background: var(--green);
}

.toast-icon svg {
  width: 12px;
}

.sidebar-overlay {
  display: none;
}

@media (max-width: 1120px) {
  .metrics-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .project-grid,
  .apps-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .campaign-summary {
    grid-template-columns: repeat(2, 1fr);
  }

  .analytics-grid {
    grid-template-columns: 1fr;
  }

  .analytics-grid .wide {
    grid-column: auto;
  }
}

@media (max-width: 900px) {
  .company-grid,
  .forecast-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .team-row {
    grid-template-columns: 36px minmax(160px, 1fr) 100px 145px 36px;
  }

  .sidebar {
    transform: translateX(-100%);
    transition: 0.25s ease;
  }

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

  .close-sidebar,
  .menu-button {
    display: grid !important;
  }

  .sidebar-overlay {
    position: fixed;
    inset: 0;
    z-index: 25;
    background: rgba(26, 26, 23, 0.4);
  }

  .sidebar-overlay.open {
    display: block;
  }

  .main-content {
    margin-left: 0;
  }

  .dashboard-grid,
  .calendar-layout,
  .detail-grid,
  .finance-grid,
  .campaign-detail-grid,
  .mailbox-layout {
    grid-template-columns: 1fr;
  }

  .mailbox-message-list {
    max-height: 330px;
  }

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

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

  .campaign-row {
    grid-template-columns: auto minmax(150px, 1fr) repeat(2, 60px) auto auto;
  }

  .campaign-row .campaign-stat:nth-child(5) {
    display: none;
  }

  .mailchimp-workspace-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .project-finance-list {
    overflow-x: auto;
  }

  .project-finance-row {
    min-width: 720px;
  }

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

  .agenda-date + .agenda-date {
    margin-top: 0;
  }
}

@media (max-width: 650px) {
  .company-grid,
  .forecast-summary {
    grid-template-columns: 1fr;
  }

  .company-card {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .company-card-value {
    grid-column: 2;
    text-align: left;
  }

  .bulk-import {
    padding: 16px;
  }

  .bulk-intro,
  .bulk-result-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .bulk-filters,
  .bulk-settings {
    grid-template-columns: 1fr;
  }

  .bulk-search {
    grid-column: auto;
  }

  .browser-dots,
  .browser-external span,
  .browser-reload span {
    display: none;
  }

  .browser-external,
  .browser-reload {
    padding: 0 8px;
  }

  .browser-help,
  .csv-import-intro,
  .csv-import-summary {
    align-items: flex-start;
    flex-direction: column;
  }

  .csv-import {
    padding: 16px;
  }

  .mailbox-reader-head {
    flex-direction: column;
  }

  .project-toolbar,
  .company-toolbar,
  .drive-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .drive-toolbar .toolbar-search {
    max-width: none;
  }

  .drive-grid {
    grid-template-columns: 1fr;
  }

  .mailbox-reader-head .secondary-button {
    width: 100%;
  }

  .csv-import-intro .secondary-button {
    width: 100%;
  }

  .team-list {
    padding: 0 15px 10px;
  }

  .team-row {
    grid-template-columns: 34px 1fr auto;
    gap: 9px;
    padding: 12px 0;
  }

  .team-row .seat-status {
    grid-column: 2;
  }

  .team-row .team-role-select,
  .team-row .role-pill {
    grid-column: 2;
  }

  .team-row > .icon-button,
  .team-row > span:last-child {
    grid-column: 3;
    grid-row: 1;
  }

  .invite-link {
    flex-direction: column;
  }

  .invite-link input {
    min-height: 36px;
  }

  .auth-brand {
    top: 22px;
    left: 20px;
  }

  .auth-card {
    padding: 25px 20px;
  }

  .auth-footnote {
    right: 20px;
    bottom: 16px;
    left: 20px;
    text-align: center;
  }

  .topbar {
    height: 67px;
    padding: 0 16px;
  }

  .global-search {
    width: 42px;
    padding: 0 12px;
  }

  .global-search input,
  .global-search kbd {
    display: none;
  }

  .global-search:focus-within {
    position: absolute;
    z-index: 3;
    right: 16px;
    left: 58px;
    width: auto;
  }

  .global-search:focus-within input {
    display: block;
  }

  .topbar-actions .primary-button span:not([data-icon]) {
    display: none;
  }

  .view-container {
    padding: 24px 15px;
  }

  .page-heading {
    align-items: flex-start;
    flex-direction: column;
  }

  .page-heading h1 {
    font-size: 26px;
  }

  .heading-actions {
    width: 100%;
  }

  .heading-actions > * {
    flex: 1;
  }

  .metrics-grid {
    grid-template-columns: 1fr;
  }

  .metric-card {
    min-height: 125px;
  }

  .pipeline-list {
    grid-template-columns: repeat(2, 1fr);
    row-gap: 16px;
  }

  .pipeline-item:nth-child(2) {
    border: 0;
  }

  .agenda-list {
    grid-template-columns: 1fr;
  }

  .project-grid,
  .apps-grid,
  .settings-grid,
  .campaign-summary,
  .integration-grid {
    grid-template-columns: 1fr;
  }

  .detail-hero {
    align-items: flex-start;
    flex-direction: column;
  }

  .opportunity-control {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .detail-identity {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .detail-contact {
    align-items: flex-start;
  }

  .campaigns-panel {
    overflow-x: auto;
  }

  .campaigns-list {
    min-width: 600px;
  }

  .mailchimp-panel {
    grid-template-columns: auto 1fr;
  }

  .mailchimp-panel .primary-button {
    grid-column: 2;
    justify-self: start;
  }

  .mailchimp-report-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .mailchimp-preview-frame {
    min-height: 360px;
  }

  .campaign-row {
    grid-template-columns: auto minmax(160px, 1fr) repeat(3, 65px) auto auto;
  }

  .campaign-row .campaign-stat:nth-child(5) {
    display: block;
  }

  .integration-item {
    grid-template-columns: auto 1fr;
  }

  .integration-item .secondary-button {
    grid-column: 2;
    justify-self: start;
  }

  .table-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .toolbar-search {
    width: 100%;
  }

  .toolbar-group {
    overflow-x: auto;
  }

  .target-result-count {
    margin-left: 0;
  }

  .table-panel {
    overflow-x: auto;
  }

  .data-table {
    min-width: 720px;
  }

  .calendar-day {
    min-height: 76px;
    padding: 5px;
  }

  .calendar-event {
    max-width: 10px;
    height: 5px;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: var(--event-color);
    font-size: 0;
  }

  .donut-layout {
    align-items: stretch;
    flex-direction: column;
  }

  .donut {
    margin: 0 auto;
  }

  .form-grid,
  .choice-grid {
    grid-template-columns: 1fr;
  }

  .choice-grid {
    padding: 16px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
}
