/* [project]/app/web/src/app/globals.css [app-client] (css) */
:root {
  --page: #aab5c5;
  --canvas: #edf2f6;
  --surface: #fff;
  --surface-soft: #f7f9fb;
  --ink: #202637;
  --muted: #667085;
  --faint: #9aa5b5;
  --line: #7e8ea338;
  --red: #df4b33;
  --blue: #5fa2cc;
  --dark: #1f2639;
  --green: #3c8d73;
  --shadow: 0 24px 70px #3744542e;
  --soft-shadow: 0 18px 42px #5363751f;
}

* {
  box-sizing: border-box;
}

html {
  background: var(--canvas);
  height: 100%;
  overflow: hidden;
}

body {
  background: var(--canvas);
  height: 100%;
  min-height: 0;
  color: var(--ink);
  letter-spacing: 0;
  overscroll-behavior: none;
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif;
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

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

button {
  cursor: pointer;
}

.app-shell {
  height: 100dvh;
  min-height: 0;
  padding: 0;
  overflow: hidden;
}

.app-frame {
  height: 100dvh;
  min-height: 0;
  box-shadow: none;
  background: radial-gradient(circle at 34% 8%, #ffffff9e, #0000 26%), linear-gradient(135deg, #eef3f7 0%, #e4ebf1 100%);
  border: 0;
  border-radius: 0;
  grid-template-rows: auto minmax(0, 1fr);
  display: grid;
  overflow: hidden;
}

.topbar {
  grid-template-columns: auto minmax(320px, 1fr) minmax(360px, auto);
  align-items: center;
  gap: 22px;
  min-height: 78px;
  padding: 16px clamp(20px, 3.2vw, 34px) 10px;
  display: grid;
}

.brand {
  align-items: center;
  gap: 10px;
  min-width: 160px;
  display: inline-flex;
}

.brand-mark {
  background: var(--red);
  color: #fff;
  border-radius: 12px;
  place-items: center;
  width: 34px;
  height: 34px;
  display: grid;
  box-shadow: 0 12px 26px #df4b3345;
}

.brand-title {
  letter-spacing: .01em;
  font-size: 15px;
  font-weight: 800;
}

.nav-list {
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
  min-width: 0;
  padding-bottom: 4px;
  display: flex;
  overflow: visible;
}

.nav-list::-webkit-scrollbar {
  display: none;
}

.nav-item {
  color: #4a5262;
  flex: none;
  align-items: center;
  gap: 6px;
  min-height: 36px;
  padding: 0 6px;
  font-size: 14px;
  font-weight: 500;
  transition: color .18s, transform .18s;
  display: inline-flex;
  position: relative;
}

.nav-group {
  flex: none;
  position: relative;
}

.nav-group-trigger {
  color: #4a5262;
  background: none;
  border: 0;
  align-items: center;
  gap: 6px;
  min-height: 36px;
  padding: 0 8px;
  font-size: 14px;
  font-weight: 640;
  transition: color .18s, transform .18s, background .18s;
  display: inline-flex;
  position: relative;
}

.nav-item:after, .nav-group-trigger:after {
  content: "";
  background: none;
  height: 1px;
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
}

.nav-item:hover, .nav-item.active, .nav-group:hover .nav-group-trigger, .nav-group:focus-within .nav-group-trigger, .nav-group.active .nav-group-trigger {
  color: var(--ink);
  transform: translateY(-1px);
}

.nav-item.active:after, .nav-group.active .nav-group-trigger:after {
  background: #20263759;
}

.nav-group-menu {
  z-index: 25;
  background: #fffffff7;
  border: 1px solid #ffffffdb;
  border-radius: 18px;
  width: 236px;
  padding: 8px;
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  box-shadow: 0 24px 60px #37445433;
}

.nav-group:hover .nav-group-menu, .nav-group:focus-within .nav-group-menu {
  gap: 4px;
  display: grid;
}

.nav-group-menu:before {
  content: "";
  background: #fffffff7;
  border-top: 1px solid #ffffffdb;
  border-left: 1px solid #ffffffdb;
  width: 12px;
  height: 12px;
  position: absolute;
  top: -6px;
  left: 22px;
  transform: rotate(45deg);
}

.nav-group-menu a {
  border-radius: 12px;
  gap: 3px;
  padding: 10px;
  transition: background .16s, transform .16s;
  display: grid;
}

.nav-group-menu a:hover, .nav-group-menu a.active {
  background: #edf2f6eb;
  transform: translateY(-1px);
}

.nav-group-menu a strong {
  color: #263144;
  font-size: 13px;
}

.nav-group-menu a span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.topbar-actions {
  justify-content: flex-end;
  align-items: center;
  gap: 11px;
  min-width: 0;
  display: flex;
}

.topbar-actions form {
  margin: 0;
}

.topbar-tool {
  display: inline-flex;
  position: relative;
}

.global-search {
  width: min(330px, 32vw);
  min-width: 0;
  position: relative;
}

.search-box {
  color: #657183;
  background: #ffffffb8;
  border: 1px solid #ffffffbd;
  border-radius: 17px;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-width: 0;
  min-height: 40px;
  padding: 0 14px;
  display: flex;
  box-shadow: 0 12px 28px #5c6c7e14;
}

.search-box input {
  width: 100%;
  min-width: 0;
  color: var(--ink);
  background: none;
  border: 0;
  outline: 0;
  font-size: 14px;
}

.search-box input::placeholder {
  color: #9aa5b5;
}

.search-results {
  z-index: 30;
  background: #fffffff7;
  border: 1px solid #ffffffdb;
  border-radius: 18px;
  width: min(460px, 74vw);
  max-height: min(430px, 70vh);
  padding: 8px;
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  overflow-y: auto;
  box-shadow: 0 24px 60px #37445433;
}

.search-result, .search-empty {
  width: 100%;
  color: var(--ink);
  text-align: left;
  background: none;
  border: 0;
  border-radius: 13px;
}

.search-result {
  cursor: pointer;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 10px;
  transition: background .16s, transform .16s;
  display: grid;
}

.search-result:hover, .search-result:focus-visible {
  background: #edf2f6eb;
  outline: 0;
  transform: translateY(-1px);
}

.search-result-main {
  gap: 3px;
  min-width: 0;
  display: grid;
}

.search-result-main strong {
  color: #263144;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  overflow: hidden;
}

.search-result-main span {
  color: var(--muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  line-height: 1.35;
  overflow: hidden;
}

.search-result-type {
  color: #526174;
  white-space: nowrap;
  background: #e2eaf1eb;
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 11px;
  font-weight: 760;
}

.search-empty {
  color: var(--muted);
  padding: 14px 12px;
  font-size: 13px;
}

.icon-button, .collapse-button, .round-add {
  color: #3c4658;
  background: #ffffffb8;
  border: 0;
  place-items: center;
  transition: transform .18s, background .18s;
  display: grid;
}

.icon-button {
  border-radius: 14px;
  width: 40px;
  height: 40px;
  box-shadow: 0 12px 28px #5c6c7e14;
}

.icon-button:hover, .icon-button.active, .collapse-button:hover, .round-add:hover {
  background: #fff;
  transform: translateY(-1px);
}

.icon-button:disabled {
  cursor: progress;
  opacity: .58;
}

.topbar-popover {
  z-index: 20;
  background: #fffffff5;
  border: 1px solid #ffffffdb;
  border-radius: 18px;
  width: 260px;
  padding: 10px;
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  box-shadow: 0 24px 60px #37445433;
}

.topbar-tool:hover .topbar-popover, .topbar-tool:focus-within .topbar-popover {
  display: block;
}

.topbar-tool:hover .icon-button, .topbar-tool:focus-within .icon-button {
  background: #fff;
  transform: translateY(-1px);
}

.topbar-popover:before {
  content: "";
  background: #fffffff5;
  border-top: 1px solid #ffffffdb;
  border-left: 1px solid #ffffffdb;
  width: 12px;
  height: 12px;
  position: absolute;
  top: -6px;
  right: 18px;
  transform: rotate(45deg);
}

.popover-head {
  border-bottom: 1px solid var(--line);
  gap: 3px;
  margin-bottom: 6px;
  padding: 8px 10px 10px;
  display: grid;
}

.popover-head strong {
  color: var(--ink);
  font-size: 14px;
}

.popover-head span, .topbar-popover a span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.topbar-popover a {
  border-radius: 12px;
  gap: 3px;
  padding: 10px;
  transition: background .16s, transform .16s;
  display: grid;
}

.topbar-popover a:hover {
  background: #edf2f6e6;
  transform: translateY(-1px);
}

.topbar-popover a strong {
  color: #263144;
  font-size: 13px;
}

.avatar {
  color: #fff;
  background: linear-gradient(145deg, #ffffff7a, #0000), #1f2639;
  border-radius: 50%;
  place-items: center;
  width: 40px;
  height: 40px;
  font-weight: 800;
  display: grid;
  box-shadow: 0 14px 28px #1f26392e;
}

.main-area {
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  padding: 0 clamp(20px, 3.2vw, 34px) 24px;
  display: flex;
  overflow: hidden;
}

.page-head {
  flex: none;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin: 2px 0 16px;
  display: flex;
}

.login-page {
  background: radial-gradient(circle at 28% 18%, #ffffffc2, #0000 24%), linear-gradient(135deg, #eef3f7 0%, #e4ebf1 100%);
  place-items: center;
  min-height: 100dvh;
  padding: 24px;
  display: grid;
}

.login-panel {
  width: min(440px, 100%);
  box-shadow: var(--soft-shadow);
  background: #ffffffc7;
  border: 1px solid #ffffffc2;
  border-radius: 22px;
  padding: 28px;
}

.login-panel h1 {
  margin-top: 6px;
}

.login-panel p, .login-error {
  color: var(--muted);
  line-height: 1.45;
}

.login-error {
  color: #9d2e22;
  background: #df4b3314;
  border: 1px solid #df4b3347;
  border-radius: 14px;
  margin: 16px 0 0;
  padding: 11px 12px;
  font-size: 13px;
}

.login-error.neutral {
  color: var(--muted);
  background: #ffffffb3;
  border-color: #273b5529;
}

.login-form {
  gap: 14px;
  margin-top: 20px;
  display: grid;
}

.login-form label {
  color: var(--muted);
  gap: 7px;
  font-size: 12px;
  font-weight: 760;
  display: grid;
}

.login-form input {
  border: 1px solid var(--line);
  min-height: 44px;
  color: var(--ink);
  background: #ffffffe0;
  border-radius: 14px;
  outline: 0;
  padding: 0 13px;
}

.login-form button {
  background: var(--dark);
  color: #fff;
  border: 0;
  border-radius: 999px;
  min-height: 44px;
  font-weight: 800;
}

.login-secondary-link {
  color: #405b78;
  text-align: center;
  text-underline-offset: 4px;
  font-size: 13px;
  font-weight: 760;
  text-decoration: underline;
}

.eyebrow {
  color: #697789;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 800;
}

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

h1 {
  margin-bottom: 0;
  font-size: clamp(26px, 3.4vw, 38px);
  font-weight: 760;
  line-height: 1.12;
}

.page-copy {
  color: var(--muted);
  max-width: 700px;
  margin: 6px 0 0;
  font-size: 14px;
  line-height: 1.42;
}

.dashboard-grid {
  grid-template-columns: minmax(0, 1.34fr) minmax(320px, .9fr);
  grid-template-areas: "tracker recent"
                       "connect proposal"
                       "premium proposal";
  gap: clamp(16px, 2vw, 20px);
  display: grid;
}

.tracker-card, .recent-panel, .connect-panel, .premium-panel, .proposal-card, .card, .table-panel, .upload-panel {
  box-shadow: var(--soft-shadow);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  background: #ffffffc2;
  border: 1px solid #ffffffb8;
}

.tracker-card {
  border-radius: 28px;
  grid-area: tracker;
  min-height: clamp(300px, 41vw, 350px);
  padding: clamp(22px, 2.2vw, 26px);
}

.recent-panel {
  box-shadow: none;
  background: none;
  border-color: #0000;
  border-radius: 28px;
  grid-area: recent;
  padding: 5px 2px 0;
}

.connect-panel {
  box-shadow: none;
  background: none;
  border-color: #0000;
  border-radius: 28px;
  grid-area: connect;
  padding: 0;
}

.premium-panel {
  background: radial-gradient(circle at 90% 20%, #fffc, #0000 26%), radial-gradient(circle at 100% 100%, #55697e30, #0000 34%), #ffffff85;
  border-radius: 28px;
  grid-area: premium;
  align-content: space-between;
  min-height: 138px;
  padding: 22px;
  display: grid;
}

.proposal-card {
  border-radius: 28px;
  grid-area: proposal;
  padding: 22px;
}

.card-head, .panel-title-row {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  display: flex;
}

.card-kicker {
  color: #3b4657;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  font-weight: 720;
  display: flex;
}

.tracker-card h2 {
  letter-spacing: -.02em;
  margin: 6px 0;
  font-size: clamp(30px, 3.8vw, 46px);
  font-weight: 740;
  line-height: 1;
}

.tracker-card p {
  color: var(--muted);
  max-width: 560px;
  font-size: 14px;
  line-height: 1.42;
}

.soft-select {
  color: #4b5668;
  background: #ffffffc7;
  border: 1px solid #dae1e8f2;
  border-radius: 18px;
  justify-content: center;
  align-items: center;
  gap: 6px;
  min-width: 88px;
  min-height: 38px;
  display: inline-flex;
  box-shadow: 0 12px 24px #57657514;
}

.tracker-body {
  grid-template-columns: 190px minmax(0, 1fr);
  align-items: end;
  gap: 26px;
  min-height: 200px;
  display: grid;
}

.growth-value {
  font-size: 40px;
  font-weight: 760;
  line-height: 1;
}

.growth-copy {
  color: var(--muted);
  max-width: 190px;
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.35;
}

.mini-chart {
  grid-template-columns: repeat(7, minmax(32px, 1fr));
  align-items: end;
  gap: 14px;
  min-height: 190px;
  padding: 24px 2px 0;
  display: grid;
  position: relative;
}

.chart-day {
  grid-template-rows: 1fr 40px;
  place-items: end center;
  height: 178px;
  display: grid;
}

.chart-line {
  background: linear-gradient(#b8c3cf2e, #ccd4de);
  width: 2px;
  min-height: 54px;
  position: relative;
}

.chart-line span {
  background: #6e9ec1;
  border-radius: 50%;
  width: 10px;
  height: 10px;
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: 0 6px 18px #6e9ec14d;
}

.chart-label {
  color: #4b5668;
  background: #e5ebf1;
  border-radius: 50%;
  place-items: center;
  width: 36px;
  height: 36px;
  font-weight: 650;
  display: grid;
}

.chart-label.active {
  background: var(--dark);
  color: #fff;
  box-shadow: 0 12px 28px #1f263947;
}

.chart-tooltip {
  background: var(--dark);
  color: #fff;
  border-radius: 15px;
  padding: 7px 11px;
  font-size: 13px;
  font-weight: 700;
  position: absolute;
  top: 8px;
  left: 38%;
  transform: translateX(-50%);
}

.panel-title-row h2 {
  margin: 0;
  font-size: 20px;
  line-height: 1.2;
}

.panel-title-row a, .date-chip {
  color: #4f5b6f;
  font-size: 14px;
}

.date-chip {
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.project-list {
  gap: 12px;
  margin-top: 16px;
  display: grid;
}

.project-row {
  border-bottom: 1px solid var(--line);
  grid-template-columns: 46px minmax(0, 1fr) 38px;
  align-items: start;
  gap: 12px;
  padding-bottom: 14px;
  display: grid;
}

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

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

.project-icon {
  color: #fff;
  border-radius: 14px;
  place-items: center;
  width: 42px;
  height: 42px;
  display: grid;
}

.tone-1 {
  background: var(--red);
}

.tone-2 {
  color: #1f2639;
  background: #dfe6ed;
}

.tone-3 {
  background: var(--blue);
}

.project-title {
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  font-weight: 750;
  display: flex;
}

.project-title span, .person-name span {
  background: var(--dark);
  color: #fff;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 700;
}

.project-rate {
  color: #697789;
  margin-top: 3px;
  font-size: 14px;
}

.project-tags {
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
  display: flex;
}

.project-tags span {
  color: #5e6a7d;
  background: #ffffff94;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
}

.collapse-button, .round-add {
  border-radius: 50%;
  width: 34px;
  height: 34px;
}

.person-row {
  border: 1px solid var(--line);
  background: #ffffff61;
  border-radius: 28px;
  grid-template-columns: 46px minmax(0, 1fr) 38px;
  align-items: center;
  gap: 12px;
  min-height: 68px;
  margin-top: 9px;
  padding: 9px 11px;
  display: grid;
}

.person-avatar {
  width: 40px;
  height: 40px;
  color: var(--dark);
  background: linear-gradient(145deg, #fff, #d8e1ea);
  border-radius: 50%;
  place-items: center;
  font-weight: 800;
  display: grid;
}

.person-name {
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-weight: 760;
  display: flex;
}

.person-name span {
  background: var(--red);
}

.person-row:nth-of-type(3) .person-name span {
  background: var(--blue);
}

.premium-panel h2 {
  margin-bottom: 6px;
  font-size: 20px;
}

.premium-panel p {
  color: var(--muted);
  max-width: 360px;
  font-size: 13px;
  line-height: 1.35;
}

.upgrade-link {
  color: #283244;
  background: #ffffffe0;
  border-radius: 999px;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  max-width: 290px;
  min-height: 38px;
  padding: 0 18px;
  font-weight: 760;
  display: inline-flex;
  box-shadow: 0 16px 32px #4c5b6c1a;
}

.proposal-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 22px;
  display: grid;
}

.proposal-metric {
  border-left: 2px solid #d6dee7;
  padding-left: 13px;
}

.proposal-metric.red {
  border-color: var(--red);
}

.proposal-metric.dark {
  border-color: var(--dark);
}

.proposal-metric strong {
  margin-top: 4px;
  font-size: 26px;
  display: block;
}

.tiny-bars {
  align-items: end;
  gap: 4px;
  height: 44px;
  margin-top: 10px;
  display: flex;
}

.tiny-bars span {
  background: #c5ced9;
  border-radius: 999px;
  width: 2px;
  height: 32px;
}

.proposal-metric.red .tiny-bars span {
  background: #ca725f;
}

.proposal-metric.dark .tiny-bars span {
  background: #283244;
}

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

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

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

.card, .table-panel, .upload-panel {
  border-radius: 28px;
}

.card {
  padding: 22px;
}

.metric-label, .muted {
  color: var(--muted);
}

.metric-label {
  font-size: 13px;
}

.metric-value {
  margin-top: 8px;
  font-size: 30px;
  font-weight: 760;
}

.metric-note {
  color: var(--muted);
  margin-top: 8px;
  font-size: 13px;
}

.section-title {
  flex: none;
  margin: 14px 0 10px;
  font-size: 20px;
}

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

.workflow-step {
  grid-template-columns: 40px 1fr;
  align-items: start;
  gap: 12px;
  display: grid;
}

.step-index {
  width: 34px;
  height: 34px;
  color: var(--dark);
  background: #e6edf4;
  border-radius: 50%;
  place-items: center;
  font-weight: 800;
  display: grid;
}

.step-title {
  font-weight: 760;
}

.step-copy {
  color: var(--muted);
  margin-top: 4px;
  line-height: 1.5;
}

.table-panel {
  -webkit-overflow-scrolling: touch;
  flex: auto;
  max-width: 100%;
  min-height: 0;
  overflow: auto;
}

table {
  border-collapse: collapse;
  width: 100%;
  min-width: 720px;
}

th, td {
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
  padding: 14px 16px;
  font-size: 14px;
}

th {
  z-index: 2;
  color: #5b6676;
  text-transform: uppercase;
  background: #ffffff70;
  font-size: 12px;
  font-weight: 800;
  position: sticky;
  top: 0;
}

tr:last-child td {
  border-bottom: 0;
}

.badge {
  border-radius: 999px;
  align-items: center;
  min-height: 24px;
  padding: 3px 9px;
  font-size: 12px;
  font-weight: 760;
  display: inline-flex;
}

.badge.neutral {
  color: #566274;
  background: #e6ebf0;
}

.badge.info {
  color: #376f92;
  background: #dcecf6;
}

.badge.success {
  color: #2e755e;
  background: #dfeee8;
}

.badge.warning {
  color: #8a5a1e;
  background: #f3e8d8;
}

.badge.danger {
  color: #9d3727;
  background: #f5dfda;
}

.upload-panel {
  flex: none;
  gap: 16px;
  max-width: 760px;
  padding: 24px;
  display: grid;
}

.form-row {
  gap: 8px;
  display: grid;
}

.form-row label {
  color: #3d4858;
  font-size: 13px;
  font-weight: 760;
}

.form-row input, .form-row select {
  width: 100%;
  min-height: 46px;
  color: var(--ink);
  background: #ffffffb8;
  border: 1px solid #b7c2cfcc;
  border-radius: 16px;
  outline: 0;
  padding: 10px 13px;
}

.form-row input:focus, .form-row select:focus, .search-box:focus-within {
  border-color: #5fa2ccd9;
  box-shadow: 0 0 0 4px #5fa2cc1f;
}

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

.form-actions button {
  background: var(--dark);
  color: #fff;
  border: 0;
  border-radius: 17px;
  min-height: 44px;
  padding: 0 18px;
  font-weight: 760;
}

.form-actions button:disabled {
  cursor: progress;
  opacity: .72;
}

.form-status {
  color: var(--muted);
  font-size: 13px;
}

.company-settings-grid {
  grid-template-columns: minmax(280px, .82fr) minmax(360px, 1.18fr);
  gap: 18px;
  min-height: 0;
  padding-bottom: 8px;
  display: grid;
  overflow: auto;
}

.company-settings-panel {
  box-shadow: var(--soft-shadow);
  background: #ffffffc2;
  border: 1px solid #ffffffb8;
  border-radius: 22px;
  align-self: start;
  padding: 22px;
}

.status-pill {
  border-radius: 999px;
  align-items: center;
  min-height: 30px;
  padding: 0 11px;
  font-size: 12px;
  font-weight: 820;
  display: inline-flex;
}

.status-pill.pass {
  color: #2e755e;
  background: #dfeee8;
}

.status-pill.warning {
  color: #8a5a1e;
  background: #f3e8d8;
}

.company-master-summary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
  display: grid;
}

.company-master-summary div {
  background: #ffffff94;
  border: 1px solid #dae1e8d1;
  border-radius: 16px;
  gap: 5px;
  min-width: 0;
  padding: 14px;
  display: grid;
}

.company-master-summary span, .ocr-suggestion span, .ocr-suggestion small, .company-profile-form label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 760;
}

.company-master-summary strong, .ocr-suggestion strong {
  overflow-wrap: anywhere;
  color: #263144;
  min-width: 0;
  font-size: 15px;
}

.ocr-suggestion {
  background: #dcecf67a;
  border: 1px solid #5fa2cc3d;
  border-radius: 18px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  margin-top: 16px;
  padding: 14px;
  display: grid;
}

.ocr-suggestion div {
  gap: 4px;
  min-width: 0;
  display: grid;
}

.ocr-suggestion button, .company-form-actions button {
  background: var(--dark);
  color: #fff;
  border: 0;
  border-radius: 999px;
  min-height: 38px;
  padding: 0 16px;
  font-size: 13px;
  font-weight: 800;
}

.ocr-suggestion button:disabled, .company-form-actions button:disabled {
  cursor: progress;
  opacity: .68;
}

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

.company-profile-form .panel-title-row, .company-profile-form .span-2, .company-form-actions {
  grid-column: 1 / -1;
}

.company-profile-form label {
  gap: 7px;
  display: grid;
}

.company-profile-form input, .company-profile-form select {
  width: 100%;
  min-height: 44px;
  color: var(--ink);
  background: #ffffffc7;
  border: 1px solid #b7c2cfcc;
  border-radius: 15px;
  outline: 0;
  padding: 0 13px;
}

.company-profile-form input:focus, .company-profile-form select:focus {
  border-color: #5fa2ccd9;
  box-shadow: 0 0 0 4px #5fa2cc1f;
}

.company-form-actions {
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: 2px;
  display: flex;
}

.company-form-actions span {
  color: var(--muted);
  font-size: 13px;
}

.empty-state, .error-box {
  padding: 24px;
  line-height: 1.6;
}

.empty-state {
  color: var(--muted);
}

.error-box {
  color: #7a2922;
  background: #fff1eee6;
  border: 1px solid #c7574659;
  border-radius: 22px;
}

.accounting-head {
  align-items: center;
}

.period-toolbar {
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  display: inline-flex;
}

.period-chip, .primary-action, .panel-count {
  white-space: nowrap;
  border-radius: 999px;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  font-size: 13px;
  font-weight: 760;
  display: inline-flex;
}

.period-chip {
  color: #4f5b6f;
  background: #ffffff94;
  border: 1px solid #ffffffb8;
  padding: 0 14px;
}

.primary-action {
  background: var(--dark);
  color: #fff;
  padding: 0 16px;
  box-shadow: 0 14px 30px #1f26392e;
}

.secondary-action {
  border: 1px solid var(--line);
  color: #3f4b5e;
  white-space: nowrap;
  background: #ffffffa3;
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  min-height: 38px;
  padding: 0 15px;
  font-size: 13px;
  font-weight: 760;
  display: inline-flex;
}

.accounting-workspace {
  grid-template-columns: minmax(0, 1.36fr) minmax(340px, .86fr);
  grid-template-areas: "closing review"
                       "summary review"
                       "risk documents"
                       "reports documents";
  gap: 16px;
  display: grid;
}

.operations-panel, .summary-card {
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  background: #ffffffb8;
  border: 1px solid #ffffffb8;
  box-shadow: 0 16px 38px #5363751a;
}

.operations-panel {
  border-radius: 22px;
  padding: 20px;
}

.closing-panel {
  grid-area: closing;
}

.review-panel {
  grid-area: review;
}

.risk-panel {
  grid-area: risk;
}

.document-panel {
  grid-area: documents;
}

.report-panel {
  grid-area: reports;
}

.operations-panel .panel-title-row {
  align-items: center;
  margin-bottom: 16px;
}

.operations-panel .panel-title-row a {
  color: #425066;
  align-items: center;
  gap: 5px;
  min-height: 34px;
  font-size: 13px;
  font-weight: 760;
  display: inline-flex;
}

.operations-panel h2 {
  margin: 0;
  font-size: 20px;
  line-height: 1.2;
}

.panel-count {
  color: #4f5b6f;
  background: #e8eef4c7;
  min-height: 32px;
  padding: 0 12px;
}

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

.close-step {
  border: 1px solid var(--line);
  background: #ffffff85;
  border-radius: 16px;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 72px;
  padding: 10px;
  display: grid;
}

.step-status-icon, .row-icon, .summary-icon {
  color: #fff;
  background: var(--dark);
  place-items: center;
  display: grid;
}

.step-status-icon, .row-icon {
  border-radius: 12px;
  width: 36px;
  height: 36px;
}

.close-step-title, .row-title {
  color: var(--ink);
  font-weight: 800;
}

.close-step .muted, .row-meta, .row-sub {
  font-size: 12px;
}

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

.summary-card {
  border-radius: 20px;
  align-content: space-between;
  gap: 12px;
  min-height: 128px;
  padding: 16px;
  display: grid;
}

.summary-icon {
  border-radius: 13px;
  width: 36px;
  height: 36px;
}

.summary-card.blue .summary-icon {
  background: var(--blue);
}

.summary-card.red .summary-icon {
  background: var(--red);
}

.summary-card.green .summary-icon {
  background: var(--green);
}

.summary-card.neutral .summary-icon {
  background: #6b7688;
}

.review-list, .risk-list, .document-list, .export-list {
  gap: 10px;
  display: grid;
}

.review-row, .document-row {
  border-bottom: 1px solid var(--line);
  grid-template-columns: 38px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 74px;
  padding: 10px 0;
  display: grid;
}

.review-row:last-child, .document-row:last-child, .risk-row:last-child {
  border-bottom: 0;
}

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

.row-meta, .row-sub {
  color: var(--muted);
  margin-top: 3px;
  line-height: 1.35;
}

.risk-row {
  border-bottom: 1px solid var(--line);
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 12px;
  padding: 12px 0;
  display: grid;
}

.risk-row p {
  color: var(--muted);
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.45;
}

.document-status-stack {
  justify-items: end;
  gap: 6px;
  display: grid;
}

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

.report-item {
  border: 1px solid var(--line);
  background: #ffffff80;
  border-radius: 16px;
  min-height: 96px;
  padding: 14px;
}

.report-item strong {
  margin-top: 8px;
  font-size: 28px;
  line-height: 1;
  display: block;
}

.report-item span, .empty-inline {
  color: var(--muted);
  margin-top: 8px;
  font-size: 12px;
  display: block;
}

.export-list {
  margin-top: 12px;
}

.export-row {
  color: #425066;
  grid-template-columns: minmax(0, 1fr) minmax(0, .9fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 38px;
  font-size: 13px;
  display: grid;
}

@media (max-width: 1160px) {
  .topbar {
    grid-template-columns: auto minmax(0, 1fr);
    grid-template-areas: "brand actions"
                         "nav nav";
    align-items: center;
    gap: 12px;
    padding-bottom: 14px;
  }

  .brand {
    grid-area: brand;
  }

  .nav-list {
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    grid-area: nav;
    justify-content: flex-start;
    gap: 10px;
    padding-bottom: 2px;
    overflow: visible;
  }

  .nav-list::-webkit-scrollbar {
    display: none;
  }

  .nav-item, .nav-group-trigger {
    background: #ffffff75;
    border-radius: 999px;
    flex: none;
    min-height: 38px;
    padding: 0 12px;
  }

  .nav-item:after, .nav-group-trigger:after {
    display: none;
  }

  .nav-item.active, .nav-group.active .nav-group-trigger {
    background: #ffffffc7;
    box-shadow: 0 10px 24px #5c6c7e14;
  }

  .topbar-actions {
    flex-wrap: nowrap;
    grid-area: actions;
    justify-content: flex-end;
  }

  .global-search {
    width: min(420px, 42vw);
  }

  .dashboard-grid {
    grid-template: "tracker"
                   "recent"
                   "connect"
                   "premium"
                   "proposal"
                   / 1fr;
    height: auto;
  }

  .tracker-card {
    min-height: auto;
  }

  .tracker-body {
    grid-template-columns: minmax(150px, .38fr) minmax(0, 1fr);
    min-height: 178px;
  }

  .mini-chart {
    min-height: 174px;
  }

  .chart-day {
    height: 162px;
  }

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

  .accounting-head {
    align-items: flex-start;
  }

  .period-toolbar {
    justify-content: flex-start;
  }

  .accounting-workspace {
    grid-template-columns: 1fr;
    grid-template-areas: "closing"
                         "summary"
                         "review"
                         "risk"
                         "documents"
                         "reports";
  }

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

@media (max-width: 760px) {
  .app-shell {
    padding: 0;
  }

  .app-frame {
    border-radius: 0;
    min-height: 100dvh;
  }

  .topbar {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas: "brand"
                         "actions"
                         "nav";
    gap: 10px;
    min-height: auto;
    padding-top: 12px;
  }

  .topbar, .main-area {
    padding-left: 16px;
    padding-right: 16px;
  }

  .brand {
    min-width: 0;
  }

  .brand-mark {
    border-radius: 11px;
    width: 32px;
    height: 32px;
  }

  .brand-title {
    font-size: 14px;
  }

  .topbar-actions {
    grid-template-columns: minmax(0, 1fr) 40px 40px 40px;
    gap: 8px;
    width: 100%;
    display: grid;
  }

  .global-search {
    width: 100%;
  }

  .search-box {
    border-radius: 15px;
    width: 100%;
    min-height: 38px;
  }

  .search-results {
    width: min(100%, 100vw - 32px);
  }

  .nav-list {
    gap: 8px;
    margin: 0 -2px;
  }

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

  .nav-item, .nav-group-trigger {
    min-height: 38px;
    padding: 0 11px;
    font-size: 13px;
  }

  .nav-group-menu {
    width: 220px;
  }

  .page-head {
    margin: 0 0 12px;
  }

  h1 {
    letter-spacing: 0;
    font-size: clamp(24px, 8vw, 30px);
  }

  .page-copy {
    max-width: none;
    font-size: 13px;
    line-height: 1.5;
  }

  .dashboard-grid {
    gap: 14px;
  }

  .tracker-card, .proposal-card, .premium-panel {
    border-radius: 22px;
    padding: 18px;
  }

  .card, .table-panel, .upload-panel {
    border-radius: 22px;
  }

  .card-head {
    align-items: stretch;
    gap: 10px;
  }

  .soft-select {
    align-self: flex-start;
    min-height: 36px;
  }

  .tracker-card h2 {
    letter-spacing: 0;
    margin-top: 5px;
    font-size: clamp(26px, 9vw, 34px);
  }

  .tracker-card p {
    font-size: 13px;
  }

  .tracker-body {
    grid-template-columns: 1fr;
    gap: 12px;
    min-height: 0;
  }

  .growth-block {
    align-items: flex-end;
    gap: 12px;
    display: flex;
  }

  .growth-value {
    font-size: 32px;
  }

  .growth-copy {
    max-width: none;
    margin-top: 0;
    font-size: 13px;
  }

  .mini-chart {
    grid-template-columns: repeat(7, minmax(24px, 1fr));
    gap: 8px;
    min-height: 150px;
    padding-top: 18px;
  }

  .chart-day {
    grid-template-rows: 1fr 34px;
    height: 142px;
  }

  .chart-label {
    width: 32px;
    height: 32px;
    font-size: 13px;
  }

  .chart-tooltip {
    padding: 6px 10px;
    font-size: 12px;
    top: 0;
    left: 50%;
  }

  .project-list {
    gap: 10px;
    margin-top: 12px;
  }

  .project-row {
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 10px;
    padding-bottom: 12px;
  }

  .project-row .collapse-button {
    display: none;
  }

  .project-icon {
    border-radius: 12px;
    width: 38px;
    height: 38px;
  }

  .project-rate {
    font-size: 13px;
  }

  .person-row {
    border-radius: 22px;
    grid-template-columns: 40px minmax(0, 1fr) 36px;
    min-height: 62px;
    padding: 8px;
  }

  .person-avatar {
    width: 36px;
    height: 36px;
  }

  .collapse-button, .round-add {
    width: 34px;
    height: 34px;
  }

  .premium-panel {
    min-height: 126px;
  }

  .proposal-card {
    padding-bottom: 16px;
  }

  .panel-title-row {
    align-items: flex-start;
    gap: 10px;
  }

  .panel-title-row h2, .premium-panel h2 {
    font-size: 18px;
  }

  .date-chip {
    white-space: nowrap;
    font-size: 13px;
  }

  .proposal-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 16px;
  }

  .proposal-metric {
    padding-left: 9px;
  }

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

  .tiny-bars {
    gap: 2px;
    height: 34px;
    margin-top: 8px;
  }

  .tiny-bars span {
    height: 24px;
  }

  .upload-panel {
    max-width: none;
    padding: 18px;
  }

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

  .form-status {
    flex-basis: 100%;
  }

  .grid.cols-4, .grid.cols-2 {
    grid-template-columns: 1fr;
  }

  .accounting-head {
    gap: 12px;
  }

  .period-toolbar {
    width: 100%;
  }

  .period-chip, .primary-action {
    min-height: 40px;
  }

  .primary-action {
    flex: auto;
    justify-content: center;
  }

  .operations-panel {
    border-radius: 20px;
    padding: 16px;
  }

  .operations-panel .panel-title-row {
    margin-bottom: 12px;
  }

  .operations-panel h2 {
    font-size: 18px;
  }

  .close-step-grid, .report-grid {
    grid-template-columns: 1fr;
  }

  .close-step {
    grid-template-columns: 34px minmax(0, 1fr) auto;
    min-height: 66px;
    padding: 9px;
  }

  .step-status-icon, .row-icon, .summary-icon {
    border-radius: 12px;
    width: 34px;
    height: 34px;
  }

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

  .summary-card {
    border-radius: 18px;
    min-height: 118px;
    padding: 14px;
  }

  .review-row, .document-row {
    grid-template-columns: 36px minmax(0, 1fr);
    align-items: start;
  }

  .review-row .badge, .document-status-stack {
    grid-column: 2;
    justify-self: start;
  }

  .document-status-stack {
    flex-wrap: wrap;
    justify-content: flex-start;
    display: flex;
  }

  .risk-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .risk-row .badge {
    justify-self: start;
  }

  .export-row {
    border-top: 1px solid var(--line);
    grid-template-columns: 1fr;
    align-items: start;
    gap: 4px;
    padding: 8px 0;
  }

  th, td {
    padding: 12px 14px;
  }
}

@media (max-width: 420px) {
  .topbar, .main-area {
    padding-left: 12px;
    padding-right: 12px;
  }

  .topbar-actions {
    grid-template-columns: minmax(0, 1fr) 38px 38px 38px;
    gap: 7px;
  }

  .icon-button, .avatar {
    width: 38px;
    height: 38px;
  }

  .search-box {
    padding: 0 10px;
  }

  .tracker-card, .proposal-card, .premium-panel, .card, .upload-panel {
    padding: 16px;
  }

  .proposal-metrics {
    gap: 7px;
  }

  .period-toolbar {
    grid-template-columns: 1fr;
    display: grid;
  }

  .period-chip {
    justify-content: center;
  }

  .summary-strip {
    grid-template-columns: 1fr;
  }

  .summary-card {
    min-height: 104px;
  }

  table {
    min-width: 660px;
  }
}

.app-frame:has(.fit-screen) {
  grid-template-rows: auto minmax(0, 1fr);
  height: 100dvh;
  min-height: 0;
  display: grid;
}

.main-area.fit-screen {
  flex-direction: column;
  min-height: 0;
  padding-bottom: 14px;
  display: flex;
  overflow: hidden;
}

.mvp-error {
  min-height: 0;
}

.mvp-header {
  flex: none;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  min-height: 70px;
  margin: 0 0 10px;
  display: flex;
}

.mvp-header h1 {
  letter-spacing: 0;
  font-size: clamp(25px, 2.6vw, 34px);
}

.mvp-header p {
  max-width: 820px;
  color: var(--muted);
  margin: 5px 0 0;
  font-size: 13px;
  line-height: 1.35;
}

.mvp-shell {
  flex: auto;
  grid-template: "metrics metrics metrics" 84px
                 "modules flow queue" minmax(0, 1fr)
                 "modules records reports" minmax(0, 1fr)
                 / minmax(360px, 1.14fr) minmax(310px, .92fr) minmax(300px, .86fr);
  gap: 12px;
  min-height: 0;
  display: grid;
  overflow: hidden;
}

.mvp-metrics {
  grid-area: metrics;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  min-height: 0;
  display: grid;
}

.mvp-metric, .mvp-panel {
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  background: #ffffffb8;
  border: 1px solid #ffffffb8;
  box-shadow: 0 14px 32px #5363751a;
}

.mvp-metric {
  border-radius: 18px;
  grid-template-rows: auto auto;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 3px 10px;
  min-width: 0;
  padding: 13px 15px;
  display: grid;
}

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

.mvp-metric strong {
  grid-area: 1 / 2 / span 2;
  font-size: 30px;
  line-height: 1;
}

.mvp-panel {
  border-radius: 20px;
  flex-direction: column;
  min-height: 0;
  padding: 16px;
  display: flex;
  overflow: hidden;
}

.mvp-modules {
  grid-area: modules;
}

.mvp-flow {
  grid-area: flow;
}

.mvp-queue {
  grid-area: queue;
}

.mvp-records {
  grid-area: records;
}

.mvp-reports {
  grid-area: reports;
}

.mvp-panel-head {
  flex: none;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
  display: flex;
}

.mvp-panel-head h2 {
  margin: 4px 0 0;
  font-size: 18px;
  line-height: 1.15;
}

.mvp-panel-head a {
  color: #425066;
  align-items: center;
  gap: 5px;
  min-height: 30px;
  font-size: 13px;
  font-weight: 760;
  display: inline-flex;
}

.mvp-module-grid {
  flex: 1;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-height: 0;
  display: grid;
}

.mvp-module {
  border: 1px solid var(--line);
  background: #ffffff85;
  border-radius: 14px;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 8px;
  min-height: 0;
  padding: 8px;
  transition: border-color .16s, background .16s, transform .16s;
  display: grid;
}

.mvp-module:hover {
  background: #ffffffc7;
  border-color: #5fa2cc6b;
  transform: translateY(-1px);
}

.mvp-module strong, .mvp-step strong, .mvp-list-row strong {
  color: var(--ink);
  font-size: 13px;
  line-height: 1.25;
  display: block;
}

.mvp-module span, .mvp-step span, .mvp-list-row span, .mvp-empty, .mvp-risk-line span {
  color: var(--muted);
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.35;
  display: block;
}

.mvp-module span {
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
}

.mvp-module em {
  color: #425066;
  background: #20263714;
  border-radius: 999px;
  padding: 3px 7px;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
}

.mvp-step-list, .mvp-compact-list {
  flex: 1;
  align-content: start;
  gap: 8px;
  min-height: 0;
  display: grid;
}

.mvp-step, .mvp-list-row {
  border-bottom: 1px solid var(--line);
  align-items: center;
  gap: 9px;
  min-height: 50px;
  display: grid;
}

.mvp-step {
  grid-template-columns: 34px minmax(0, 1fr) auto;
  padding-bottom: 8px;
}

.mvp-list-row {
  color: #3d4858;
  grid-template-columns: 24px minmax(0, 1fr) auto;
  padding-bottom: 9px;
}

.mvp-step:last-child, .mvp-list-row:last-child {
  border-bottom: 0;
}

.mvp-empty {
  border: 1px dashed #7e8ea352;
  border-radius: 14px;
  align-items: center;
  min-height: 74px;
  padding: 14px;
  display: flex;
}

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

.mvp-report-grid div {
  border: 1px solid var(--line);
  background: #ffffff85;
  border-radius: 14px;
  min-height: 68px;
  padding: 10px;
}

.mvp-report-grid span {
  color: var(--muted);
  font-size: 12px;
}

.mvp-report-grid strong {
  margin-top: 6px;
  font-size: 25px;
  line-height: 1;
  display: block;
}

.mvp-risk-line {
  border-top: 1px solid var(--line);
  align-items: center;
  gap: 9px;
  min-height: 40px;
  margin-top: 12px;
  padding-top: 10px;
  display: flex;
}

.module-page-head {
  flex: none;
  margin-top: 0;
}

.module-shell {
  flex: auto;
  grid-template-columns: minmax(300px, 360px) minmax(0, 1fr);
  align-items: stretch;
  gap: 16px;
  min-height: 0;
  display: grid;
  overflow: hidden;
}

.module-side-panel {
  scrollbar-width: thin;
  background: #ffffffbd;
  border: 1px solid #ffffffb8;
  border-radius: 18px;
  grid-template-rows: auto auto auto auto;
  align-content: start;
  gap: 14px;
  min-width: 0;
  min-height: 0;
  padding: 16px;
  display: grid;
  overflow: hidden auto;
  box-shadow: 0 14px 32px #5363751a;
}

.module-side-panel::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.module-create-panel::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.module-table-wrap::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.table-panel::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.module-side-panel::-webkit-scrollbar-thumb {
  background: #56627452;
  border: 3px solid #ffffffb8;
  border-radius: 999px;
}

.module-create-panel::-webkit-scrollbar-thumb {
  background: #56627452;
  border: 3px solid #ffffffb8;
  border-radius: 999px;
}

.module-table-wrap::-webkit-scrollbar-thumb {
  background: #56627452;
  border: 3px solid #ffffffb8;
  border-radius: 999px;
}

.table-panel::-webkit-scrollbar-thumb {
  background: #56627452;
  border: 3px solid #ffffffb8;
  border-radius: 999px;
}

.module-context-grid {
  border-bottom: 1px solid #7e8ea32e;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: minmax(58px, auto);
  gap: 8px;
  padding-bottom: 14px;
  display: grid;
}

.module-context, .module-create-panel, .module-table-panel, .period-lock-panel, .bank-reconciliation-panel, .module-automation-panel {
  background: #ffffffbd;
  border: 1px solid #ffffffb8;
  border-radius: 18px;
  box-shadow: 0 14px 32px #5363751a;
}

.module-context {
  min-height: 0;
  box-shadow: none;
  background: #f8fafcad;
  border-color: #7e8ea329;
  padding: 12px 13px;
  overflow: hidden;
}

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

.module-context span, .module-section-head span, .module-field span, .module-form-actions span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 720;
}

.module-context strong {
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-top: 5px;
  font-size: 16px;
  line-height: 1.1;
  display: block;
  overflow: hidden;
}

.module-create-panel, .module-table-panel, .period-lock-panel, .bank-reconciliation-panel, .module-automation-panel {
  min-width: 0;
  padding: 16px;
}

.module-side-panel .module-create-panel, .module-side-panel .period-lock-panel, .module-side-panel .bank-reconciliation-panel, .module-side-panel .module-automation-panel {
  box-shadow: none;
  background: none;
  border: 0;
  border-top: 1px solid #7e8ea32e;
  border-radius: 0;
  padding: 14px 0 0;
}

.module-side-panel .period-lock-panel:first-child, .module-side-panel .bank-reconciliation-panel:first-child, .module-side-panel .module-create-panel:first-child, .module-side-panel .module-automation-panel:first-child {
  border-top: 0;
  padding-top: 0;
}

.module-create-panel {
  scrollbar-width: thin;
  min-height: auto;
  overflow: auto;
}

.module-close-summary {
  border-top: 1px solid #7e8ea32e;
  border-bottom: 1px solid #7e8ea32e;
  grid-template-columns: minmax(170px, 220px) minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  padding: 10px 0 12px;
  display: grid;
}

.module-close-summary > div:first-child {
  gap: 3px;
  display: grid;
}

.module-close-summary span, .module-close-summary small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 680;
}

.module-close-summary strong {
  color: #263144;
  font-size: 16px;
}

.module-close-steps {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  display: grid;
}

.module-close-steps span {
  background: #ffffff85;
  border: 1px solid #7e8ea32e;
  border-radius: 12px;
  gap: 3px;
  min-width: 0;
  padding: 9px 10px;
  display: grid;
}

.module-close-steps span.complete {
  background: #2ea77f14;
  border-color: #2ea77f42;
}

.module-close-steps span.pending {
  background: #df4b330f;
  border-color: #df4b3338;
}

.module-close-steps strong {
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  overflow: hidden;
}

.module-close-steps small {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}

.module-section-head {
  margin-bottom: 10px;
}

.module-section-head h2 {
  margin: 3px 0 0;
  font-size: 18px;
  line-height: 1.15;
}

.module-form {
  gap: 10px;
  display: grid;
}

.module-form-grid {
  grid-template-columns: 1fr;
  gap: 8px;
  display: grid;
}

.module-field {
  gap: 6px;
  display: grid;
}

.module-field input, .module-field select, .module-field textarea {
  border: 1px solid var(--line);
  width: 100%;
  min-height: 36px;
  color: var(--ink);
  background: #ffffffd6;
  border-radius: 12px;
  outline: 0;
  padding: 0 12px;
}

.module-field textarea {
  resize: vertical;
  min-height: 98px;
  padding: 10px 12px;
  line-height: 1.45;
}

.module-field input:focus, .module-field select:focus, .module-field textarea:focus {
  border-color: #5fa2ccb8;
  box-shadow: 0 0 0 3px #5fa2cc24;
}

.module-form-actions {
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  min-height: 38px;
  display: flex;
}

.module-form-actions button {
  background: var(--dark);
  color: #fff;
  border: 0;
  border-radius: 999px;
  min-height: 36px;
  padding: 0 16px;
  font-size: 13px;
  font-weight: 780;
}

.module-form-actions button:disabled {
  opacity: .65;
}

.module-hint, .module-empty {
  color: var(--muted);
  background: #ffffff75;
  border: 1px dashed #7e8ea357;
  border-radius: 14px;
  padding: 14px;
  font-size: 13px;
  line-height: 1.5;
}

.module-table-panel {
  flex-direction: column;
  min-height: 0;
  display: flex;
  overflow: hidden;
}

.module-table-wrap {
  border: 1px solid var(--line);
  background: #ffffff8f;
  border-radius: 14px;
  flex: auto;
  min-height: 0;
  overflow: auto;
}

.module-table {
  border-collapse: collapse;
  width: 100%;
  min-width: 760px;
}

.module-table th, .module-table td {
  text-align: left;
  white-space: nowrap;
  border-bottom: 1px solid #7e8ea32e;
  padding: 12px 13px;
  font-size: 13px;
}

.module-table th {
  z-index: 1;
  color: #526174;
  background: #f5f8fbf5;
  font-size: 12px;
  font-weight: 820;
  position: sticky;
  top: 0;
}

.module-table td {
  color: #2e3848;
}

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

.module-row-actions {
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.module-row-actions button, .permission-actions button, .inline-action button {
  border: 1px solid var(--line);
  color: #2f3b4d;
  background: #ffffffbd;
  border-radius: 999px;
  min-height: 30px;
  padding: 0 11px;
  font-size: 12px;
  font-weight: 780;
}

.module-row-actions button:disabled, .inline-action button:disabled {
  opacity: .52;
}

.module-row-actions span, .module-muted-action, .permission-actions span, .inline-action span {
  color: var(--muted);
  font-size: 12px;
}

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

.permission-actions {
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-width: 0;
  display: inline-flex;
}

.permission-actions select {
  border: 1px solid var(--line);
  color: #2f3b4d;
  background: #ffffffc7;
  border-radius: 999px;
  outline: 0;
  min-height: 30px;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 760;
}

.permission-actions button:disabled {
  opacity: .52;
}

.permission-actions .temporary-password {
  color: #263144;
  white-space: normal;
  word-break: break-all;
  background: #ffffffc7;
  border: 1px solid #273b552e;
  border-radius: 12px;
  flex-basis: 100%;
  max-width: 360px;
  padding: 8px 10px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 12px;
}

.module-inline-link {
  color: #285f8f;
  text-underline-offset: 3px;
  font-weight: 760;
  text-decoration: underline;
}

.attachment-upload-form {
  border-top: 1px solid var(--line);
  margin-top: 14px;
  padding-top: 14px;
}

.invoice-payment-actions, .bank-match-actions {
  grid-template-columns: 92px auto;
  align-items: center;
  gap: 7px;
  display: inline-grid;
}

.bank-match-actions {
  grid-template-columns: 112px auto;
}

.bank-match-actions-row {
  flex-wrap: wrap;
  max-width: 230px;
  display: inline-flex;
}

.invoice-payment-actions input, .bank-match-actions input {
  border: 1px solid var(--line);
  width: 92px;
  min-height: 30px;
  color: var(--ink);
  background: #ffffffbd;
  border-radius: 999px;
  outline: 0;
  padding: 0 10px;
  font-size: 12px;
}

.bank-match-actions input {
  width: 112px;
}

.invoice-payment-actions button, .bank-match-actions button {
  background: var(--dark);
  color: #fff;
  border: 0;
  border-radius: 999px;
  min-height: 30px;
  padding: 0 11px;
  font-size: 12px;
  font-weight: 780;
}

.bank-match-actions .bank-match-secondary {
  border: 1px solid var(--line);
  color: #2f3b4d;
  background: #ffffffbd;
}

.invoice-payment-actions button:disabled, .bank-match-actions button:disabled {
  opacity: .52;
}

.invoice-payment-actions span, .bank-match-actions span {
  color: var(--muted);
  white-space: normal;
  grid-column: 1 / -1;
  max-width: 220px;
  font-size: 12px;
}

.period-lock-panel, .bank-reconciliation-panel, .module-automation-panel {
  gap: 11px;
  display: grid;
}

.period-lock-topline {
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  display: flex;
}

.period-lock-topline .module-section-head {
  margin-bottom: 0;
}

.period-lock-status {
  background: #f8fafca8;
  border: 1px solid #7e8ea329;
  border-radius: 12px;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  min-height: 62px;
  padding: 11px 12px;
  display: flex;
}

.period-lock-status span, .period-close-checks span, .period-lock-panel p {
  color: var(--muted);
  font-size: 12px;
}

.period-lock-status strong {
  color: #1f2a3d;
  margin-top: 3px;
  font-size: 20px;
  line-height: 1.05;
  display: block;
}

.period-lock-progress-value {
  color: #263144;
  font-size: 24px;
  font-weight: 840;
  line-height: 1;
}

.period-lock-progress {
  gap: 5px;
  display: grid;
}

.period-lock-progress span {
  background: #7e8ea32e;
  border-radius: 999px;
  height: 7px;
  display: block;
  overflow: hidden;
}

.period-lock-progress i {
  border-radius: inherit;
  background: linear-gradient(90deg, #3c8d73, #5fa2cc);
  height: 100%;
  display: block;
}

.period-close-checks {
  border-top: 1px solid #7e8ea32e;
  gap: 0;
  padding-top: 9px;
  display: grid;
}

.close-checks-head, .close-check {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  display: grid;
}

.close-checks-head strong {
  color: #263144;
  font-size: 13px;
}

.close-check {
  border-bottom: 1px solid #7e8ea31f;
  border-radius: 0;
  grid-template-columns: 26px minmax(0, 1fr);
  min-height: 42px;
  padding: 8px 0;
}

.close-check:last-child {
  border-bottom: 0;
}

.close-check-marker {
  border-radius: 50%;
  place-items: center;
  width: 24px;
  height: 24px;
  font-size: 12px;
  font-weight: 860;
  display: grid;
}

.close-check.complete .close-check-marker {
  color: #21795f;
  background: #2ea77f24;
}

.close-check.pending .close-check-marker {
  color: #9d2e22;
  background: #df4b331f;
}

.close-check-copy {
  gap: 2px;
  min-width: 0;
  display: grid;
}

.close-check strong {
  color: #263144;
  font-size: 12px;
}

.close-check small {
  color: var(--muted);
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  overflow: hidden;
}

.period-lock-button {
  background: var(--dark);
  color: #fff;
  border: 0;
  border-radius: 12px;
  min-height: 38px;
  font-size: 13px;
  font-weight: 780;
}

.bank-reconciliation-summary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  display: grid;
}

.bank-reconciliation-summary div, .automation-metrics div {
  background: #ffffff85;
  border: 1px solid #7e8ea333;
  border-radius: 14px;
  min-height: 58px;
  padding: 10px;
}

.bank-reconciliation-summary span, .bank-reconciliation-panel p, .automation-metrics span, .module-automation-panel p {
  color: var(--muted);
  font-size: 12px;
}

.bank-reconciliation-summary strong, .automation-metrics strong {
  margin-top: 5px;
  font-size: 17px;
  line-height: 1.1;
  display: block;
}

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

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

.automation-actions button, .bank-reconciliation-button {
  background: var(--dark);
  color: #fff;
  border: 0;
  border-radius: 999px;
  min-height: 40px;
  font-size: 13px;
  font-weight: 780;
}

.period-lock-button:disabled, .bank-reconciliation-button:disabled, .automation-actions button:disabled {
  cursor: not-allowed;
  opacity: .48;
}

.period-lock-panel p, .bank-reconciliation-panel p, .module-automation-panel p {
  margin: 0;
  line-height: 1.45;
}

.period-lock-panel p {
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
}

@media (max-height: 790px) and (min-width: 901px) {
  .topbar {
    min-height: 66px;
    padding-top: 10px;
    padding-bottom: 8px;
  }

  .mvp-header {
    min-height: 56px;
    margin-bottom: 8px;
  }

  .mvp-header p {
    display: none;
  }

  .mvp-shell {
    grid-template-rows: 72px minmax(0, 1fr) minmax(0, 1fr);
    gap: 10px;
  }

  .mvp-panel {
    padding: 13px;
  }

  .mvp-panel-head {
    margin-bottom: 8px;
  }

  .mvp-module {
    padding: 8px;
  }

  .mvp-step, .mvp-list-row {
    min-height: 44px;
    padding-bottom: 6px;
  }

  .mvp-report-grid div {
    min-height: 58px;
  }
}

@media (max-width: 900px) {
  .app-frame:has(.fit-screen) {
    overflow: hidden;
  }

  .main-area.fit-screen {
    padding-bottom: 12px;
  }

  .mvp-header {
    align-items: flex-start;
    gap: 10px;
    min-height: 82px;
    margin-bottom: 8px;
  }

  .mvp-header p {
    display: none;
  }

  .mvp-shell {
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 12px;
    padding-bottom: 2px;
    display: flex;
    overflow: auto hidden;
  }

  .mvp-shell::-webkit-scrollbar {
    display: none;
  }

  .mvp-metrics, .mvp-panel {
    scroll-snap-align: start;
    flex: 0 0 min(88vw, 390px);
    height: 100%;
  }

  .mvp-metrics {
    grid-template-columns: 1fr;
    grid-auto-rows: minmax(70px, 1fr);
    display: grid;
  }

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

  .mvp-report-grid {
    grid-template-columns: 1fr;
  }
}

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

  .module-shell {
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 12px;
    padding-bottom: 2px;
    display: flex;
    overflow: auto hidden;
  }

  .module-shell::-webkit-scrollbar {
    display: none;
  }

  .module-side-panel, .module-table-panel {
    scroll-snap-align: start;
    flex: 0 0 min(88vw, 620px);
    height: 100%;
  }

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

  .module-close-summary {
    grid-template-columns: 1fr;
  }

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

  .module-table-panel {
    min-height: 0;
  }
}

@media (max-width: 760px) {
  .page-head {
    gap: 10px;
  }

  .module-page-head .page-copy {
    display: none;
  }

  .module-shell {
    gap: 10px;
  }

  .module-side-panel, .module-table-panel {
    flex-basis: min(88vw, 430px);
  }

  .module-create-panel, .module-table-panel, .period-lock-panel, .bank-reconciliation-panel, .module-automation-panel {
    padding: 14px;
  }

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

@media (max-width: 520px) {
  .company-profile-form, .company-master-summary, .ocr-suggestion {
    grid-template-columns: 1fr;
  }

  .mvp-header {
    min-height: 114px;
    display: grid;
  }

  .mvp-header h1 {
    font-size: 24px;
  }

  .mvp-header .period-toolbar {
    grid-template-columns: 1fr 1fr;
    width: 100%;
    display: grid;
  }

  .mvp-header .period-chip, .mvp-header .primary-action {
    justify-content: center;
    padding: 0 10px;
  }

  .mvp-metrics, .mvp-panel {
    flex-basis: min(86vw, 340px);
  }

  .module-context-grid {
    grid-template-columns: 1fr;
  }

  .module-page-head {
    display: grid;
  }
}

/*# sourceMappingURL=app_web_src_app_globals_090~e9x.css.map*/