:root {
  color-scheme: dark;
  --ink: #05070a;
  --panel: #10151c;
  --panel-2: #151b23;
  --line: rgba(132, 151, 173, 0.22);
  --text: #f6f7fb;
  --muted: #8c98a8;
  --soft: #5e6977;
  --cyan: #36d7ff;
  --amber: #f6b84b;
  --danger: #ff5d6c;
  --mint: #54e0a8;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at 78% 0%, rgba(54, 215, 255, 0.1), transparent 28rem),
    linear-gradient(135deg, #05070a 0%, #090d12 46%, #0b0f14 100%);
  color: var(--text);
}
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
button:disabled { cursor: not-allowed; opacity: .5; }
input, select, textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(0,0,0,.28);
  color: var(--text);
  padding: 10px 12px;
  outline: none;
}
input[type="range"] { accent-color: var(--cyan); padding: 0; }
textarea { min-height: 92px; resize: vertical; }
a { color: inherit; text-decoration: none; }

.landing {
  min-height: 100vh;
  overflow: hidden;
}
.landing-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 24px;
}
.landing-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 0;
  background: transparent;
  color: var(--text);
  font-weight: 950;
  font-size: 18px;
}
.landing-brand .brand-mark {
  width: 36px;
  height: 36px;
  border-radius: 9px;
}
.landing-hero-brand {
  display: inline-grid;
  gap: 8px;
  margin-bottom: 26px;
}
.landing-hero-brand .brand-line {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  color: var(--text);
  font-size: 30px;
  font-weight: 950;
}
.landing-hero-brand .brand-mark {
  width: 54px;
  height: 54px;
  border-radius: 14px;
}
.landing-hero-brand p {
  margin: 0 0 0 68px;
  color: var(--cyan);
  font-size: clamp(15px, 1.4vw, 20px);
  font-weight: 900;
}
.landing-nav nav {
  display: flex;
  align-items: center;
  gap: 24px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
}
.landing-nav-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}
.landing-login {
  color: #d8e0ec;
}
.landing-hero {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(480px, .85fr);
  gap: 44px;
  align-items: center;
  max-width: 1180px;
  min-height: calc(100vh - 92px);
  margin: 0 auto;
  padding: 54px 24px 88px;
}
.landing-copy h1 {
  max-width: 820px;
  font-size: clamp(56px, 8vw, 104px);
  line-height: .91;
  letter-spacing: 0;
}
.landing-lede {
  max-width: 660px;
  margin-top: 18px;
  color: #b7c1ce;
  font-size: 19px;
  line-height: 1.65;
}
.landing-trust-line {
  margin-top: 22px;
  color: var(--mint);
  font-size: 15px;
  font-weight: 900;
}
.landing-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 32px;
}
.landing-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 38px 24px 54px;
  border-top: 1px solid rgba(132,151,173,.16);
  color: var(--muted);
}
.landing-footer > div {
  display: grid;
  gap: 6px;
}
.landing-footer span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--text);
  font-weight: 950;
}
.landing-footer .brand-mark {
  width: 28px;
  height: 28px;
  border-radius: 8px;
}
.landing-footer p {
  margin: 0;
  font-size: 13px;
}
.landing-footer nav {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  font-size: 13px;
  font-weight: 850;
}
.landing-footer button,
.landing-footer a,
.legal-nav-link {
  border: 0;
  background: transparent;
  color: var(--muted);
  font-weight: 850;
  padding: 0;
}
.landing-footer button:hover,
.landing-footer a:hover,
.legal-nav-link:hover,
.legal-nav-link.active {
  color: var(--cyan);
}
.legal-page {
  overflow: visible;
}
.legal-topbar {
  position: relative;
}
.legal-topbar nav {
  gap: 18px;
}
.legal-hero {
  max-width: 980px;
  margin: 0 auto;
  padding: 76px 24px 34px;
}
.legal-hero > span {
  color: var(--cyan);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.legal-hero h1 {
  max-width: 800px;
  margin: 16px 0 18px;
  font-size: clamp(48px, 7vw, 86px);
  line-height: .96;
  letter-spacing: 0;
}
.legal-hero p {
  max-width: 820px;
  color: #bac6d4;
  font-size: 18px;
  line-height: 1.75;
}
.legal-meta {
  display: inline-grid;
  grid-template-columns: auto auto;
  gap: 10px;
  margin-top: 20px;
  padding: 10px 12px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 12px;
  background: rgba(16,21,28,.62);
  font-size: 13px;
}
.legal-meta strong {
  color: var(--soft);
}
.legal-meta em {
  color: var(--text);
  font-style: normal;
  font-weight: 850;
}
.legal-layout {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  gap: 24px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 20px 24px 72px;
  align-items: start;
}
.legal-aside {
  position: sticky;
  top: 18px;
  display: grid;
  gap: 12px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 18px;
  background: rgba(16,21,28,.62);
  padding: 18px;
}
.legal-aside strong {
  margin-bottom: 4px;
  color: var(--text);
  font-size: 14px;
}
.legal-aside .legal-nav-link {
  text-align: left;
}
.legal-support-link {
  margin-top: 8px;
  padding-top: 14px;
  border-top: 1px solid rgba(132,151,173,.14);
  color: var(--cyan);
  font-size: 13px;
  font-weight: 800;
  overflow-wrap: anywhere;
}
.legal-card {
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(54,215,255,.08), transparent 30%),
    rgba(16,21,28,.78);
  box-shadow: 0 22px 80px rgba(0,0,0,.24);
  padding: 10px;
}
.legal-section {
  padding: 26px;
  border-bottom: 1px solid rgba(132,151,173,.13);
}
.legal-section:last-child {
  border-bottom: 0;
}
.legal-section h2 {
  margin: 0 0 12px;
  font-size: 20px;
  letter-spacing: 0;
}
.legal-section p,
.legal-section li {
  color: #c4ceda;
  font-size: 15px;
  line-height: 1.75;
}
.legal-section p {
  margin: 0;
}
.legal-section ul {
  display: grid;
  gap: 9px;
  margin: 14px 0 0;
  padding-left: 22px;
}
.legal-section li::marker {
  color: var(--cyan);
}
.landing-product {
  border: 1px solid rgba(132,151,173,.22);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(54,215,255,.12), transparent 38%),
    rgba(16,21,28,.78);
  box-shadow: 0 30px 100px rgba(0,0,0,.38);
  padding: 18px;
}
.product-bar {
  display: flex;
  gap: 7px;
  padding: 4px 4px 18px;
}
.product-bar span {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.28);
}
.product-shell {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.product-warmap {
  min-height: 300px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px;
  background: rgba(5,7,10,.58);
  padding: 16px;
}
.product-warmap strong {
  display: block;
  margin-top: 10px;
  font-size: 24px;
}
.warmap-days {
  display: grid;
  grid-template-columns: repeat(5, minmax(72px, 1fr));
  gap: 10px;
  margin-top: 18px;
}
.warmap-day {
  min-height: 174px;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 14px;
  background: rgba(255,255,255,.028);
  padding: 8px 6px;
}
.warmap-day span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  color: var(--text);
  font-size: 10px;
  font-weight: 950;
}
.warmap-day span em {
  color: var(--cyan);
  font-size: 9px;
  font-style: normal;
}
.warmap-day i {
  display: block;
  max-width: 100%;
  margin-top: 8px;
  border: 1px solid rgba(54,215,255,.16);
  border-radius: 8px;
  background: rgba(54,215,255,.07);
  color: #dcecff;
  padding: 7px 3px;
  font-size: 8px;
  font-style: normal;
  font-weight: 850;
  line-height: 1.25;
  overflow: hidden;
  text-align: center;
  text-overflow: clip;
  white-space: nowrap;
}
.product-support {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.product-panel {
  min-height: 150px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: rgba(5,7,10,.52);
  padding: 16px;
}
.product-panel.wide {
  grid-column: 1 / -1;
}
.product-label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.product-panel strong {
  display: block;
  margin-top: 10px;
  font-size: 22px;
}
.product-panel p {
  margin-top: 12px;
  color: var(--muted);
  line-height: 1.5;
}
.product-task {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
  padding: 12px;
  border-radius: 12px;
  background: rgba(255,255,255,.045);
  color: #dbe4ee;
  font-weight: 850;
}
.product-task em {
  color: var(--cyan);
  font-style: normal;
}
.product-task.muted-task em {
  color: var(--mint);
}
.mini-bars {
  display: flex;
  align-items: end;
  gap: 9px;
  height: 92px;
  margin-top: 20px;
}
.mini-bars i {
  flex: 1;
  border-radius: 999px 999px 6px 6px;
  background: linear-gradient(180deg, var(--cyan), rgba(54,215,255,.18));
}
.landing-section {
  max-width: 1180px;
  margin: 0 auto;
  padding: 96px 24px;
}
.landing-proof {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  max-width: 1180px;
  margin: -34px auto 0;
  padding: 0 24px 78px;
}
.proof-head {
  grid-column: 1 / -1;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  padding: 0 2px 8px;
}
.proof-head span {
  color: var(--text);
  font-size: clamp(26px, 3vw, 42px);
  font-weight: 950;
  letter-spacing: 0;
}
.proof-head p {
  margin: 0;
  color: #9db6d4;
  font-size: 15px;
  font-weight: 850;
}
.proof-card {
  border: 1px solid rgba(54,215,255,.28);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(54,215,255,.18), rgba(27,112,230,.1)),
    rgba(16,21,28,.82);
  box-shadow: 0 18px 50px rgba(27,112,230,.12);
  padding: 18px;
}
.proof-card strong,
.proof-card span {
  display: block;
}
.proof-card strong {
  color: #f7fbff;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1;
}
.proof-card span {
  margin-top: 8px;
  color: #b8d9ff;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.landing-proof p {
  grid-column: 1 / -1;
  margin: 6px 0 0;
  color: #99a7b8;
  font-size: 13px;
  font-weight: 800;
}
.landing-section h2 {
  max-width: 720px;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1;
}
.landing-section p {
  max-width: 700px;
  margin-top: 18px;
  color: #aeb8c6;
  font-size: 18px;
  line-height: 1.7;
}
.split-section {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(320px, .65fr);
  gap: 48px;
  align-items: start;
  border-top: 1px solid rgba(255,255,255,.08);
}
.problem-list {
  display: grid;
  gap: 10px;
}
.problem-list span,
.founding-count {
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 12px;
  background: rgba(255,255,255,.035);
  color: #d8e2ef;
  padding: 14px 16px;
  font-weight: 900;
}
.section-head {
  display: grid;
  gap: 2px;
}
.solution-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 34px;
}
.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 34px;
}
.step-card {
  min-height: 210px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 18px;
  background: rgba(16,21,28,.72);
  padding: 20px;
}
.step-card span {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: rgba(54,215,255,.08);
  color: var(--cyan);
  font-weight: 950;
}
.step-card strong {
  display: block;
  margin-top: 20px;
  font-size: 20px;
}
.step-card p {
  margin-top: 12px;
  font-size: 15px;
  line-height: 1.55;
}
.solution-card {
  min-height: 250px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 18px;
  background: rgba(16,21,28,.72);
  padding: 24px;
}
.solution-card span {
  color: var(--cyan);
  font-size: 22px;
  font-weight: 950;
}
.solution-card p {
  margin-top: 22px;
  font-size: 16px;
}
.access-section {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(340px, .65fr);
  gap: 34px;
  align-items: center;
  margin-bottom: 58px;
  border: 1px solid rgba(54,215,255,.18);
  border-radius: 24px;
  background: rgba(54,215,255,.055);
}

.login-page,
.admin-page {
  min-height: 100vh;
  padding: 24px;
}
.login-brand {
  margin: 0 auto;
  max-width: 1040px;
}
.login-wrap {
  display: grid;
  place-items: center;
  min-height: calc(100vh - 120px);
}
.standalone-auth,
.access-card,
.admin-panel {
  width: min(100%, 720px);
  border: 1px solid rgba(132,151,173,.2);
  border-radius: 20px;
  background: rgba(16,21,28,.82);
  box-shadow: 0 28px 90px rgba(0,0,0,.35);
}
.standalone-auth {
  display: grid;
  gap: 22px;
  padding: 28px;
}
.standalone-auth h2,
.access-card h1,
.admin-panel h1 {
  margin: 0;
  line-height: 1;
}
.standalone-auth p,
.access-card p {
  color: var(--muted);
  line-height: 1.6;
}
.access-card {
  margin: 18vh auto 0;
  padding: 34px;
}
.access-card h1 {
  margin-top: 18px;
  font-size: clamp(34px, 5vw, 62px);
}
.payment-required-card {
  width: min(100%, 980px);
  margin-top: 10vh;
}
.payment-plan-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 24px 0;
}
.payment-plan-card {
  display: grid;
  gap: 10px;
  align-content: start;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
  padding: 16px;
}
.payment-plan-card.selected {
  border-color: rgba(54,215,255,.44);
  background: rgba(54,215,255,.08);
}
.payment-plan-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.payment-plan-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.payment-plan-head em {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  border-radius: 999px;
  background: rgba(54,255,176,.12);
  color: var(--mint);
  padding: 3px 8px;
  font-size: 10px;
  font-style: normal;
  font-weight: 950;
  white-space: nowrap;
}
.payment-plan-card strong {
  font-size: 28px;
  line-height: 1;
}
.payment-plan-card small {
  min-height: 30px;
  color: var(--muted);
  line-height: 1.45;
}
.admin-page {
  max-width: 1180px;
  margin: 0 auto;
}
.admin-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 8px 0 28px;
}
.admin-panel {
  width: 100%;
  padding: 24px;
}
.admin-table {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}
.admin-user {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto auto;
  align-items: center;
  gap: 12px;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  padding: 14px;
}
.admin-backup-row {
  grid-template-columns: minmax(0, 1fr) auto auto auto;
}
.admin-bugs-layout {
  display: grid;
  grid-template-columns: minmax(280px, .9fr) minmax(0, 1.4fr);
  gap: 14px;
  margin-top: 18px;
}
.admin-bug-list {
  display: grid;
  align-content: start;
  gap: 8px;
}
.admin-bug-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 8px;
  width: 100%;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 12px;
  background: rgba(255,255,255,.03);
  color: var(--text);
  padding: 12px;
  text-align: left;
}
.admin-bug-row:hover,
.admin-bug-row.active {
  border-color: rgba(54,215,255,.42);
  background: rgba(54,215,255,.07);
}
.admin-bug-row span:first-child {
  min-width: 0;
}
.admin-bug-row strong,
.admin-bug-row em {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.admin-bug-row em,
.admin-bug-row small {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
}
.admin-bug-row small {
  grid-column: 1 / -1;
}
.admin-bug-detail {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 16px;
  background: rgba(255,255,255,.025);
  padding: 16px;
}
.bug-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 14px 0;
}
.bug-detail-grid div,
.bug-copy-block {
  border: 1px solid rgba(132,151,173,.14);
  border-radius: 12px;
  background: rgba(0,0,0,.12);
  padding: 10px;
}
.bug-detail-grid span,
.bug-copy-block span {
  display: block;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.bug-detail-grid strong,
.bug-copy-block p {
  display: block;
  margin-top: 5px;
  color: var(--text);
  overflow-wrap: anywhere;
}
.bug-copy-block {
  margin-top: 10px;
}
.bug-screenshot {
  display: block;
  margin-top: 12px;
  overflow: hidden;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 14px;
}
.bug-screenshot img {
  display: block;
  width: 100%;
  max-height: 300px;
  object-fit: contain;
  background: rgba(0,0,0,.28);
}
.bug-admin-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.bug-internal-note {
  display: block;
  margin-top: 12px;
}
.admin-audit {
  margin-top: 18px;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 14px;
  padding: 14px;
  background: rgba(255,255,255,.025);
}
.admin-audit summary {
  cursor: pointer;
  font-weight: 800;
}
.admin-pro-page {
  max-width: 1560px;
}
.admin-kpi-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.admin-kpi-card {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  padding: 16px;
}
.admin-kpi-card span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.admin-kpi-card strong {
  display: block;
  margin-top: 8px;
  color: var(--text);
  font-size: 26px;
  line-height: 1;
}
.admin-payment-defaults-panel {
  margin-bottom: 16px;
}
.admin-payment-defaults-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}
.admin-payment-default-card {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(132,151,173,.15);
  border-radius: 16px;
  background: rgba(255,255,255,.025);
  padding: 14px;
}
.admin-payment-default-card h3 {
  margin: 0;
  font-size: 15px;
}
.admin-payment-default-card label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.admin-toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 180px 180px;
  gap: 10px;
  margin: 18px 0;
}
.admin-status-board {
  display: grid;
  grid-template-columns: repeat(6, minmax(210px, 1fr));
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.admin-status-column {
  min-width: 210px;
  border: 1px solid rgba(132,151,173,.15);
  border-radius: 16px;
  background: rgba(5,9,14,.36);
}
.admin-column-head {
  display: flex;
  width: 100%;
  justify-content: space-between;
  gap: 10px;
  border: 0;
  border-bottom: 1px solid rgba(132,151,173,.13);
  background: transparent;
  color: var(--text);
  padding: 13px;
  text-align: left;
  cursor: pointer;
}
.admin-column-head span,
.admin-column-head small {
  display: block;
}
.admin-column-head small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 11px;
}
.admin-column-head em {
  display: inline-grid;
  place-items: center;
  min-width: 30px;
  height: 30px;
  border-radius: 999px;
  background: rgba(54,215,255,.12);
  color: var(--cyan);
  font-style: normal;
  font-weight: 900;
}
.admin-column-list {
  display: grid;
  gap: 8px;
  padding: 10px;
}
.admin-customer-card {
  display: grid;
  gap: 9px;
  width: 100%;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  color: var(--text);
  padding: 12px;
  text-align: left;
  cursor: pointer;
}
.admin-customer-card:hover,
.admin-customer-card.selected {
  border-color: rgba(54,215,255,.42);
  background: rgba(54,215,255,.075);
}
.admin-card-main strong,
.admin-card-main small,
.admin-card-grid em {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.admin-card-main small,
.admin-card-grid em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
}
.admin-card-grid {
  display: grid;
  gap: 4px;
}
.admin-due-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}
.admin-due-card {
  border: 1px solid rgba(132,151,173,.14);
  border-radius: 16px;
  background: rgba(255,255,255,.025);
  padding: 14px;
}
.admin-due-card h3 {
  margin: 0 0 10px;
}
.admin-due-card button {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  border: 0;
  border-top: 1px solid rgba(132,151,173,.1);
  background: transparent;
  color: var(--text);
  padding: 9px 0;
  text-align: left;
}
.admin-analytics-panel {
  margin-top: 16px;
}
.admin-analytics-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}
.admin-analytics-grid article {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(132,151,173,.15);
  border-radius: 16px;
  background: rgba(255,255,255,.025);
  padding: 16px;
}
.admin-analytics-grid span {
  color: var(--cyan);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.admin-analytics-grid strong {
  color: var(--text);
  font-size: 20px;
}
.admin-analytics-grid p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}
.admin-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-items: center;
  padding: 28px;
  background: rgba(3,7,12,.72);
  backdrop-filter: blur(18px);
}
.admin-user-modal {
  width: min(1120px, 96vw);
  max-height: min(88vh, 920px);
  overflow: auto;
  box-shadow: 0 30px 90px rgba(0,0,0,.5);
}
.admin-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
.admin-detail-grid fieldset {
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid rgba(132,151,173,.15);
  border-radius: 16px;
  background: rgba(255,255,255,.025);
  padding: 14px;
}
.admin-detail-grid legend {
  color: var(--cyan);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.admin-detail-grid label,
.admin-notes {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.admin-notes {
  margin-top: 14px;
}
.admin-effective-payment {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  gap: 8px 12px;
  margin-top: 4px;
  border: 1px solid rgba(54,215,255,.16);
  border-radius: 12px;
  background: rgba(54,215,255,.04);
  padding: 12px;
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
}
.admin-effective-payment strong {
  color: var(--text);
  overflow-wrap: anywhere;
}
.admin-effective-payment a,
.admin-effective-payment em {
  grid-column: 1 / -1;
  color: var(--cyan);
  font-style: normal;
  font-weight: 900;
  overflow-wrap: anywhere;
}
.admin-payment-entry {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr)) auto;
  gap: 10px;
  align-items: end;
  margin-top: 16px;
  border: 1px solid rgba(54,215,255,.18);
  border-radius: 16px;
  background: rgba(54,215,255,.045);
  padding: 14px;
}
.admin-payment-entry h3 {
  grid-column: 1 / -1;
  margin: 0;
}
.admin-payment-entry label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.admin-history-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.admin-history-row {
  display: grid;
  grid-template-columns: 1fr auto auto auto auto auto auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(132,151,173,.12);
  border-radius: 12px;
  background: rgba(0,0,0,.14);
  padding: 10px;
}
.admin-history-row small {
  grid-column: 1 / -1;
  color: var(--muted);
}
.compact-empty {
  padding: 12px;
}
.founding-count {
  display: inline-flex;
  margin-top: 24px;
  color: var(--cyan);
}
.form-error,
.form-success {
  border-radius: 12px;
  padding: 11px 12px;
  font-size: 13px;
  font-weight: 900;
}
.form-error {
  color: var(--danger);
  background: rgba(255,93,108,.1);
}
.form-success {
  color: var(--mint);
  background: rgba(84,224,168,.1);
}

.app { display: flex; min-height: 100vh; }
.sidebar {
  width: 264px; flex: 0 0 264px; padding: 24px 20px;
  border-right: 1px solid rgba(255,255,255,.08);
  background: rgba(5,7,10,.86);
}
.brand { display: flex; align-items: center; gap: 11px; margin-bottom: 28px; }
.brand-mark {
  display: grid; place-items: center; width: 42px; height: 42px; border-radius: 10px;
  border: 1px solid rgba(255,46,187,.28); background: #080a0f;
  box-shadow: 0 0 0 1px rgba(255,255,255,.04), 0 12px 30px rgba(0,0,0,.2);
  overflow: hidden;
  color: var(--text); font-weight: 900; font-size: 19px;
}
.brand-mark img {
  display: block;
  width: 100%;
  height: 100%;
}
.brand-title { font-size: 18px; font-weight: 950; line-height: 1; }
.brand-version { color: #697586; font-size: 10px; font-weight: 800; margin-top: 5px; }
.nav { display: grid; gap: 8px; }
.nav-group { display: grid; gap: 8px; margin-top: 20px; }
.brand + .nav-group { margin-top: 0; }
.nav-section {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.nav button {
  border: 1px solid transparent; border-radius: 10px; background: transparent; color: #a7b0bd;
  padding: 11px 12px; text-align: left; font-weight: 800; display: flex; justify-content: space-between;
}
.nav button.active { color: var(--cyan); background: rgba(54,215,255,.11); border-color: rgba(54,215,255,.2); }
.sidebar-meter { margin-top: 34px; padding: 16px; border-radius: 12px; border: 1px solid var(--line); background: rgba(255,255,255,.035); }
.shell { flex: 1; min-width: 0; }
.topbar {
  display: flex; justify-content: space-between; gap: 16px; align-items: center;
  padding: 22px 32px; border-bottom: 1px solid rgba(255,255,255,.08);
}
.app-top-identity {
  display: none;
  align-items: center;
  gap: 9px;
  margin-bottom: 10px;
  color: var(--text);
  font-size: 15px;
  font-weight: 950;
}
.app-top-identity .brand-mark {
  width: 30px;
  height: 30px;
  border-radius: 8px;
}
.date { color: var(--muted); font-size: 14px; }
h1, h2, h3, p { margin: 0; }
h1 { margin-top: 3px; font-size: 31px; }
.actions { display: flex; gap: 10px; flex-wrap: wrap; }
.actions.compact { justify-content: flex-end; }
.btn {
  border: 1px solid var(--line); border-radius: 10px; background: rgba(255,255,255,.035);
  color: var(--text); padding: 10px 14px; font-weight: 900;
}
.btn:hover { border-color: rgba(54,215,255,.55); color: var(--cyan); }
.btn.primary { background: var(--cyan); border-color: var(--cyan); color: #001018; }
.btn.quiet { color: var(--muted); }
.btn.danger { border-color: rgba(255,93,108,.34); color: var(--danger); }
.btn.danger:hover { background: rgba(255,93,108,.12); border-color: rgba(255,93,108,.7); color: var(--danger); }
.top-actions { align-items: center; }
.status-pill {
  border-radius: 999px;
  padding: 9px 13px;
  border: 1px solid rgba(54,215,255,.24);
  background: rgba(54,215,255,.08);
  color: var(--cyan);
  font-weight: 900;
  font-size: 13px;
}
.status-pill.done { border-color: rgba(84,224,168,.22); background: rgba(84,224,168,.08); color: var(--mint); }
.status-pill.warn { border-color: rgba(246,184,75,.26); background: rgba(246,184,75,.08); color: var(--amber); }
.status-pill.risk { border-color: rgba(255,93,108,.28); background: rgba(255,93,108,.08); color: var(--danger); }
.auth-chip {
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  color: #dbe4ee;
  max-width: 220px;
  overflow: hidden;
  padding: 9px 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 900;
}
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 30;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(8px);
}
.modal {
  width: min(100%, 520px);
  border: 1px solid rgba(132,151,173,.22);
  border-radius: 18px;
  background: rgba(16,21,28,.96);
  box-shadow: 0 32px 100px rgba(0,0,0,.5);
  padding: 22px;
}
.bug-report-modal {
  width: min(100%, 640px);
}
.bug-report-form {
  gap: 12px;
  margin-top: 14px;
}
.bug-report-form textarea,
.bug-internal-note textarea {
  min-height: 92px;
  resize: vertical;
}
.required {
  margin-left: 6px;
  color: var(--cyan);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.bug-file-row,
.bug-context {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.bug-file-row {
  justify-content: space-between;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 10px;
  padding: 9px 10px;
  color: var(--muted);
  font-size: 12px;
}
.bug-context {
  margin: 14px 0;
}
.bug-context span {
  border: 1px solid rgba(54,215,255,.16);
  border-radius: 999px;
  background: rgba(54,215,255,.07);
  color: #b9d8e4;
  padding: 6px 9px;
  font-size: 11px;
  font-weight: 900;
}
.offday-choice-modal {
  width: min(100%, 620px);
}
.offday-choice-grid {
  display: grid;
  gap: 12px;
  margin-top: 16px;
}
.offday-choice-card {
  display: grid;
  gap: 6px;
  width: 100%;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  color: var(--text);
  padding: 15px;
  text-align: left;
  cursor: pointer;
}
.offday-choice-card:hover {
  border-color: rgba(54,215,255,.45);
  background: rgba(54,215,255,.075);
}
.schedule-removal-modal {
  width: min(100%, 540px);
}
.schedule-removal-preview {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 16px 0 12px;
  border: 1px solid rgba(132,151,173,.17);
  border-radius: 11px;
  background: rgba(255,255,255,.03);
  padding: 13px;
}
.schedule-removal-preview.remove {
  border-color: rgba(255,93,108,.2);
  background: rgba(255,93,108,.045);
}
.schedule-removal-preview.restore {
  border-color: rgba(54,215,255,.2);
  background: rgba(54,215,255,.045);
}
.schedule-removal-preview span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.schedule-removal-actions {
  justify-content: flex-end;
  margin-top: 18px;
}
.offday-choice-card strong {
  font-size: 14px;
}
.offday-choice-card span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}
.client-update-popup {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 35;
  width: min(360px, calc(100vw - 32px));
  border: 1px solid rgba(54,215,255,.2);
  border-radius: 14px;
  background: rgba(12,17,23,.94);
  box-shadow: 0 22px 70px rgba(0,0,0,.38);
  padding: 16px;
  backdrop-filter: blur(14px);
}
.client-update-kicker {
  color: var(--cyan);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.client-update-popup strong {
  display: block;
  margin-top: 7px;
  color: var(--text);
  font-size: 15px;
}
.client-update-popup p {
  margin-top: 8px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}
.client-update-tip {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 10px;
}
.client-update-actions {
  display: flex;
  gap: 8px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.auth-panel {
  display: grid;
  grid-template-columns: minmax(0, .85fr) minmax(320px, 1.15fr);
  gap: 20px;
  padding: 22px 32px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(8,12,16,.72);
}
.auth-panel h2 {
  font-size: 22px;
}
.auth-panel p {
  margin-top: 8px;
  max-width: 640px;
  color: var(--muted);
  line-height: 1.55;
}
.auth-form {
  display: grid;
  gap: 10px;
}
.backup-list-wrap {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(132,151,173,.14);
  border-radius: 14px;
  background: rgba(0,0,0,.14);
}
.backup-section-head, .backup-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.backup-row {
  padding: 10px;
  border: 1px solid rgba(132,151,173,.12);
  border-radius: 12px;
  background: rgba(255,255,255,.025);
}
.backup-row > div:first-child {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.backup-list {
  display: grid;
  gap: 8px;
}
.content {
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(340px, 380px); gap: 20px;
  padding: 28px 32px; max-height: calc(100vh - 88px); overflow: auto;
}
.content.dashboard-content { grid-template-columns: minmax(0, 1fr); }
.dashboard-content { padding-top: 34px; }
.maincol, .sidecol { display: grid; gap: 20px; align-content: start; min-width: 0; }
.panel {
  border: 1px solid var(--line); border-radius: 16px;
  background: linear-gradient(180deg, rgba(21,27,35,.95), rgba(13,17,23,.95));
  box-shadow: 0 18px 70px rgba(0,0,0,.28);
  padding: 20px;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}
.panel.subtle { background: rgba(16,21,28,.86); box-shadow: none; }
.focus-panel { padding: 26px; }
.dashboard-planner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 24px;
  align-items: start;
}
.dashboard-main, .dashboard-side {
  display: grid;
  gap: 24px;
  min-width: 0;
}
.side-card { padding: 18px; box-shadow: none; background: rgba(16,21,28,.84); }
.hero { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 20px; align-items: center; min-width: 0; }
.kicker { color: var(--cyan); font-size: 14px; font-weight: 800; }
.hero h2 { margin-top: 8px; max-width: 780px; font-size: 38px; line-height: 1.05; }
.hero p { margin-top: 12px; max-width: 690px; color: var(--muted); line-height: 1.65; font-size: 14px; }
.metrics { display: grid; grid-template-columns: repeat(3, 96px); gap: 12px; text-align: center; }
.metric { border: 1px solid var(--line); border-radius: 12px; background: rgba(255,255,255,.035); padding: 16px 10px; }
.metric strong { display: block; font-size: 30px; }
.metric span { color: var(--muted); font-size: 11px; font-weight: 900; text-transform: uppercase; }
.bar { height: 8px; border-radius: 999px; overflow: hidden; background: rgba(255,255,255,.09); margin-top: 14px; }
.fill { height: 100%; border-radius: inherit; background: var(--cyan); }
.fill.warn { background: var(--amber); }
.fill.risk { background: var(--danger); }
.fill.done { background: var(--mint); }
.grid2 { display: grid; grid-template-columns: 1.15fr .85fr; gap: 20px; }
.panel-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 14px; }
.panel-head.relaxed { margin-bottom: 20px; }
.panel-head h3 { font-size: 18px; }
.muted { color: var(--muted); }
.tiny { font-size: 12px; font-weight: 800; }
.title-input, .sub-input {
  border-color: transparent;
  background: transparent;
  padding: 0;
  border-radius: 6px;
}
.title-input { font-size: 20px; font-weight: 900; }
.sub-input { margin-top: 4px; color: var(--muted); font-size: 13px; }
.title-input:focus, .sub-input:focus { border-color: rgba(54,215,255,.45); background: rgba(0,0,0,.18); padding: 6px 8px; }
.task-row, .insight, .project-card, .task-edit, .review-card {
  border: 1px solid var(--line); border-radius: 12px; background: rgba(0,0,0,.2); padding: 12px;
}
.task-row { width: 100%; display: flex; align-items: center; gap: 12px; text-align: left; color: var(--text); margin-top: 10px; }
.task-row.calm {
  margin-top: 12px;
  padding: 16px;
  border-color: rgba(132,151,173,.18);
  background: rgba(255,255,255,.025);
}
.task-row.calm:hover,
.task-row.calm.active {
  border-color: rgba(54,215,255,.42);
  background: rgba(54,215,255,.055);
}
.focus-project {
  display: grid;
  gap: 12px;
  width: 100%;
  margin-top: 12px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 14px;
  background: rgba(255,255,255,.025);
  color: var(--text);
  padding: 18px;
  text-align: left;
}
.focus-project:hover,
.focus-project.active {
  border-color: rgba(54,215,255,.42);
  background: rgba(54,215,255,.055);
}
.focus-project-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}
.focus-project-head span {
  min-width: 0;
}
.focus-project-head strong,
.focus-project-head small {
  display: block;
}
.focus-project-head small,
.focus-load {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.focus-project-head em {
  color: var(--cyan);
  font-size: 24px;
  font-style: normal;
  font-weight: 950;
}
.focus-project ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 18px;
  color: #dbe4ef;
  line-height: 1.35;
}
.focus-task-list {
  display: grid;
  gap: 8px;
}
.focus-task-row {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  padding: 8px;
  border: 1px solid rgba(132,151,173,.12);
  border-radius: 10px;
  background: rgba(255,255,255,.025);
}
.focus-task-row:hover {
  border-color: rgba(54,215,255,.22);
  background: rgba(54,215,255,.045);
}
.focus-task-row.done {
  border-color: rgba(84,224,168,.22);
  background: rgba(84,224,168,.06);
}
.focus-task-row strong,
.focus-task-row small {
  display: block;
}
.focus-task-row small {
  margin-top: 2px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}
.check { width: 22px; height: 22px; flex: 0 0 22px; display: grid; place-items: center; border: 1px solid #566273; border-radius: 6px; transition: transform .18s ease, background .18s ease, border-color .18s ease; }
.task-row .check,
.focus-task-row .check { background: transparent; color: var(--text); padding: 0; }
.check.done { background: var(--mint); border-color: var(--mint); color: #00150c; font-weight: 900; animation: complete-pop .34s ease both; }
.grow { flex: 1; min-width: 0; }
.grow strong, .grow span { display: block; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.badge { border-radius: 7px; padding: 5px 8px; font-size: 12px; font-weight: 900; background: rgba(54,215,255,.1); color: var(--cyan); white-space: nowrap; }
.quiet-badge { background: rgba(255,255,255,.055); color: #c5ceda; }
.split-btn,
.event-split {
  border: 1px solid rgba(132,151,173,.24);
  border-radius: 7px;
  background: rgba(255,255,255,.045);
  color: #c5ceda;
  padding: 5px 8px;
  font-size: 11px;
  font-weight: 900;
}
.split-btn:hover,
.event-split:hover {
  border-color: rgba(54,215,255,.5);
  color: var(--cyan);
  background: rgba(54,215,255,.08);
}
.event-card-actions {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.event-remove {
  display: grid;
  place-items: center;
  width: 23px;
  height: 23px;
  border: 1px solid rgba(255,93,108,.2);
  border-radius: 7px;
  background: rgba(255,93,108,.035);
  color: rgba(255,157,166,.72);
  padding: 0;
  font-size: 15px;
  line-height: 1;
}
.event-remove:hover,
.month-action.remove:hover {
  border-color: rgba(255,93,108,.5);
  background: rgba(255,93,108,.1);
  color: #ffb7be;
}
.badge.warn { background: rgba(246,184,75,.14); color: var(--amber); }
.badge.risk { background: rgba(255,93,108,.14); color: var(--danger); }
.badge.done { background: rgba(84,224,168,.14); color: var(--mint); }
.effort-total-badge {
  display: inline-grid;
  gap: 2px;
  padding: 8px 10px;
  text-align: left;
  white-space: normal;
  min-width: 132px;
}
.effort-total-badge span,
.effort-total-badge small {
  color: var(--muted);
  font-size: 10px;
  line-height: 1.1;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.effort-total-badge strong {
  color: currentColor;
  font-size: 13px;
  line-height: 1.15;
}
.effort-total-badge small {
  letter-spacing: 0;
  text-transform: none;
}
.stack { display: grid; gap: 12px; }
.projects { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; }
.projects.relaxed-projects { grid-template-columns: repeat(2, minmax(0,1fr)); margin-top: 14px; }
.current-projects-panel {
  margin-top: 18px;
}
.finished-projects-panel {
  margin-top: 14px;
}
.finished-projects-panel > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  cursor: pointer;
  list-style: none;
}
.finished-projects-panel > summary::-webkit-details-marker {
  display: none;
}
.finished-projects-panel > summary > span:first-child {
  display: grid;
  gap: 4px;
}
.finished-projects-panel > summary strong {
  color: var(--text);
  font-size: 15px;
}
.finished-projects-panel[open] > summary {
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(132,151,173,.14);
}
.project-card {
  display: grid;
  gap: 11px;
  width: 100%;
  text-align: left;
  color: var(--text);
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.project-card:hover,
.project-card.active {
  border-color: rgba(54,215,255,.62);
  background: rgba(54,215,255,.07);
}
.project-card:hover {
  transform: translateY(-1px);
}
.project-top { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; }
.project-title { font-weight: 900; }
.project-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}
.project-card-meta span {
  border-radius: 999px;
  background: rgba(255,255,255,.045);
  padding: 5px 8px;
}
.project-template-panel {
  margin-bottom: 14px;
}
.project-template-toolbar {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) auto minmax(220px, 1fr) auto;
  gap: 10px;
  align-items: center;
}
.project-template-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.project-template-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 10px;
  background: rgba(255,255,255,.035);
  padding: 10px;
}
.project-template-card strong,
.project-template-card span {
  display: block;
}
.template-card-actions {
  display: flex;
  align-items: center;
  gap: 7px;
}
.empty.compact {
  padding: 12px 0 0;
}
.timeline-head { align-items: flex-start; }
.timeline-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}
.compact-add-task {
  padding: 8px 11px;
}
.range-switch {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(0,0,0,.24);
}
.range-switch button {
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: var(--muted);
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 900;
}
.range-switch button.active {
  background: var(--cyan);
  color: #001018;
}
.month-nav {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(0,0,0,.18);
}
.month-nav strong {
  min-width: 118px;
  text-align: center;
  color: var(--text);
  font-size: 12px;
}
.month-nav button {
  border: 0;
  border-radius: 7px;
  background: rgba(255,255,255,.05);
  color: var(--muted);
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}
.month-nav button:hover {
  background: rgba(54,215,255,.1);
  color: var(--text);
}
.timeline-wrap { overflow-x: auto; }
.timeline { min-width: 1240px; display: grid; grid-template-columns: repeat(7, minmax(170px,1fr)); gap: 12px; }
.timeline.wide { min-width: 2300px; grid-template-columns: repeat(14, minmax(155px,1fr)); }
.day { min-height: 285px; border: 1px solid var(--line); border-radius: 12px; background: rgba(0,0,0,.2); padding: 12px; transition: border-color .16s ease, background .16s ease; }
.day.drag-over { border-color: rgba(54,215,255,.7); background: rgba(54,215,255,.08); }
.day.offday {
  border-color: rgba(255,93,108,.28);
  background: repeating-linear-gradient(135deg, rgba(255,93,108,.07) 0 10px, rgba(0,0,0,.2) 10px 20px);
}
.day-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; }
.day-actions { display: flex; flex-direction: column; gap: 6px; align-items: flex-end; }
.day-name { font-weight: 900; }
.day-date { color: var(--muted); font-size: 12px; margin-top: 3px; }
.offday-label {
  display: inline-flex;
  margin-top: 6px;
  border: 1px solid rgba(255,93,108,.3);
  border-radius: 999px;
  background: rgba(255,93,108,.1);
  color: #ffc4cb;
  padding: 3px 7px;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
}
.offday-toggle {
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  padding: 4px 8px;
  font-size: 10px;
  font-weight: 950;
  cursor: pointer;
}
.offday-toggle.active {
  border-color: rgba(255,93,108,.36);
  background: rgba(255,93,108,.14);
  color: #ffd9dd;
}
.event { position: relative; width: 100%; border: 1px solid var(--line); border-radius: 9px; background: rgba(255,255,255,.04); padding: 9px; margin-top: 8px; color: var(--text); text-align: left; cursor: grab; transition: border-color .18s ease, background .18s ease, opacity .18s ease, transform .18s ease; }
.event:hover { border-color: rgba(54,215,255,.42); background: rgba(54,215,255,.055); }
.event.done { border-color: rgba(84,224,168,.34); background: rgba(84,224,168,.07); animation: complete-card .38s ease both; }
.event.removed-event {
  display: grid;
  gap: 4px;
  border-style: dashed;
  border-color: rgba(132,151,173,.14);
  background: rgba(255,255,255,.012);
  color: rgba(198,208,220,.34);
  opacity: .48;
  cursor: pointer;
  box-shadow: none;
}
.event.removed-event:hover {
  border-color: rgba(132,151,173,.3);
  background: rgba(255,255,255,.025);
  color: rgba(224,232,241,.62);
  opacity: .78;
}
.removed-event-label {
  color: inherit;
  font-size: 8px;
  font-weight: 950;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.removed-event-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
}
.removed-event-title em {
  flex: 0 0 auto;
  color: inherit;
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
}
.event.merge-ready { border-color: rgba(84,224,168,.72); background: rgba(84,224,168,.09); }
.event:active, .event.dragging { cursor: grabbing; opacity: .72; }
.event.reorder-before,
.event.reorder-after {
  border-color: rgba(54,215,255,.45);
  background: rgba(54,215,255,.065);
}
.event.reorder-before::before,
.event.reorder-after::after {
  content: "";
  position: absolute;
  left: 6px;
  right: 6px;
  height: 30px;
  border: 1px dashed rgba(54,215,255,.72);
  border-radius: 9px;
  background: rgba(54,215,255,.08);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), 0 0 18px rgba(54,215,255,.08);
  pointer-events: none;
  animation: reorder-ghost .16s ease both;
}
.event.reorder-before::before { top: -38px; }
.event.reorder-after::after { bottom: -38px; }
.event-title { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 12px; font-weight: 900; }
.event-check {
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border: 1px solid rgba(132,151,173,.46);
  border-radius: 6px;
  background: rgba(0,0,0,.18);
  color: #00150c;
  padding: 0;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.event-check:hover {
  border-color: rgba(84,224,168,.65);
  transform: scale(1.06);
}
.event-check.done {
  border-color: var(--mint);
  background: var(--mint);
  animation: complete-pop .34s ease both;
}
.event-meta { margin-top: 5px; color: var(--muted); font-size: 11px; }
.event-submeta { margin-top: 4px; color: #697586; font-size: 10px; display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.event-split { padding: 3px 7px; font-size: 10px; cursor: pointer; }
.drop-hint {
  margin-top: 8px;
  border: 1px dashed rgba(54,215,255,.36);
  border-radius: 9px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  padding: 8px;
  text-align: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .16s ease;
}
.day.drag-over .drop-hint { opacity: 1; }
@keyframes complete-pop {
  0% { transform: scale(.82); }
  55% { transform: scale(1.12); }
  100% { transform: scale(1); }
}
@keyframes complete-card {
  0% { transform: translateY(0); }
  45% { transform: translateY(-1px); }
  100% { transform: translateY(0); }
}
@keyframes reorder-ghost {
  from { opacity: 0; transform: scaleY(.84); }
  to { opacity: 1; transform: scaleY(1); }
}
.warmap-panel { padding: 16px; }
.timeline.dashboard {
  min-width: 0;
  gap: 8px;
}
.timeline.dashboard.range-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.timeline.dashboard.range-7 { grid-template-columns: repeat(7, minmax(0, 1fr)); }
.timeline.dashboard.range-30 { grid-template-columns: repeat(7, minmax(0, 1fr)); }
.calendar-weekday {
  color: var(--muted);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 0 8px 2px;
}
.timeline.dashboard .day {
  min-height: 132px;
  padding: 8px;
  border-radius: 10px;
}
.timeline.dashboard .day-head {
  margin-bottom: 7px;
}
.timeline.dashboard .day-name {
  font-size: 12px;
}
.timeline.dashboard .day-date {
  font-size: 10px;
}
.timeline.dashboard .day-actions {
  gap: 4px;
}
.timeline.dashboard .badge {
  padding: 3px 6px;
  font-size: 10px;
}
.timeline.dashboard .offday-toggle {
  padding: 3px 6px;
  font-size: 9px;
}
.timeline.dashboard .offday-label {
  padding: 2px 6px;
  font-size: 9px;
}
.timeline.dashboard .event {
  margin-top: 5px;
  padding: 6px;
  border-radius: 7px;
}
.timeline.dashboard .event-title {
  font-size: 10px;
}
.timeline.dashboard .event-meta {
  font-size: 9px;
}
.timeline.dashboard.range-30 .day {
  min-height: 158px;
  overflow: visible;
}
.timeline.dashboard.range-30 .month-pad {
  min-height: 158px;
  border-style: dashed;
  background: rgba(255,255,255,.018);
  opacity: .45;
  pointer-events: none;
}
.day-add-task {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 8px;
  background: rgba(255,255,255,.045);
  color: var(--muted);
  font-size: 15px;
  font-weight: 950;
  cursor: pointer;
}
.day-add-task:hover {
  border-color: rgba(54,215,255,.45);
  background: rgba(54,215,255,.08);
  color: var(--text);
}
.manual-task-panel {
  display: grid;
  gap: 14px;
  width: min(620px, calc(100vw - 32px));
  max-height: calc(100vh - 44px);
  overflow-y: auto;
  border: 1px solid rgba(132,151,173,.24);
  border-radius: 16px;
  background: #0b1016;
  box-shadow: 0 30px 90px rgba(0,0,0,.5);
  padding: 18px;
}
.manual-task-overlay {
  position: fixed;
  inset: 0;
  z-index: 220;
  display: grid;
  place-items: center;
  background: rgba(3,5,8,.66);
  backdrop-filter: blur(10px);
  padding: 16px;
}
.manual-task-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}
.manual-task-head h3 {
  margin-top: 5px;
  font-size: 24px;
}
.manual-task-head p {
  margin-top: 6px;
}
.project-edit-modal {
  width: min(920px, calc(100vw - 32px));
  padding: 22px;
}
.project-edit-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.project-edit-summary > div {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 12px;
  background: rgba(255,255,255,.03);
  padding: 12px;
}
.project-edit-summary span,
.project-edit-summary strong {
  display: block;
}
.project-edit-summary strong {
  margin-top: 4px;
}
.project-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.project-edit-grid .task-row {
  min-height: 45px;
  margin-top: 0;
}
.project-edit-notes {
  grid-column: 1 / -1;
}
.project-edit-notes textarea {
  min-height: 112px;
  resize: vertical;
}
.project-workflow-note {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.manual-task-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 10px;
}
.manual-preset-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  border: 1px solid rgba(54,215,255,.14);
  border-radius: 12px;
  background: rgba(54,215,255,.045);
  padding: 10px;
}
.manual-preset-list > span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}
.manual-preset-chip {
  display: inline-flex;
  align-items: stretch;
  overflow: hidden;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 10px;
  background: rgba(255,255,255,.035);
}
.manual-preset-chip button {
  border: 0;
  background: transparent;
  color: var(--text);
}
.manual-preset-chip button:first-child {
  display: grid;
  gap: 2px;
  padding: 7px 9px;
  text-align: left;
}
.manual-preset-chip strong,
.manual-preset-chip span {
  display: block;
}
.manual-preset-chip span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
}
.manual-preset-chip .preset-delete {
  width: 30px;
  border-left: 1px solid rgba(132,151,173,.14);
  color: var(--muted);
  font-weight: 950;
}
.manual-preset-chip .preset-delete:hover {
  color: var(--danger);
  background: rgba(255,93,108,.08);
}
.manual-task-options summary {
  cursor: pointer;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.manual-task-optional {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}
.manual-task-optional .manual-notes {
  grid-column: 1 / -1;
}
.manual-preset-save {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}
.manual-task-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}
.manual-event {
  border-color: rgba(54,215,255,.22);
  background: rgba(54,215,255,.055);
}
.access-flow {
  display: grid;
  gap: 10px;
}
.access-flow span {
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 12px;
  background: rgba(5,7,10,.22);
  color: #d8e2ef;
  padding: 13px 14px;
  font-weight: 900;
}
.access-flow .btn {
  margin-top: 8px;
}
.access-flow p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}
.manual-task-row {
  border-color: rgba(54,215,255,.18);
}
.timeline.dashboard.range-30 .event {
  padding: 5px;
}
.timeline.dashboard.range-30 .day-head {
  margin-bottom: 5px;
}
.timeline.dashboard.range-30 .day-actions {
  flex-direction: row;
  align-items: center;
}
.timeline.dashboard.range-30 .offday-toggle {
  padding: 2px 5px;
  font-size: 8px;
}
.timeline.dashboard.range-30 .month-event {
  margin-top: 4px;
  padding: 6px 7px;
  border-radius: 7px;
  cursor: pointer;
}
.month-event-top,
.month-event-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-width: 0;
  gap: 6px;
}
.month-event-top {
  color: var(--text);
  font-size: 10px;
  font-weight: 950;
  line-height: 1.15;
}
.month-event-top strong {
  color: var(--cyan);
  font-size: 10px;
  flex: 0 0 auto;
}
.month-event-bottom {
  margin-top: 3px;
  color: var(--muted);
  font-size: 9px;
  font-weight: 800;
  line-height: 1.1;
}
.month-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  opacity: 0;
  transition: opacity .16s ease;
}
.month-event:hover .month-actions,
.month-event:focus-within .month-actions {
  opacity: 1;
}
.month-check {
  width: 14px;
  height: 14px;
  flex-basis: 14px;
  border-radius: 4px;
  font-size: 9px;
}
.month-action {
  border: 1px solid rgba(132,151,173,.22);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  padding: 1px 5px;
  font-size: 8px;
  font-weight: 950;
  cursor: pointer;
}
.month-more {
  width: 100%;
  margin-top: 5px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 7px;
  background: rgba(255,255,255,.025);
  color: var(--muted);
  padding: 4px 6px;
  font-size: 10px;
  font-weight: 900;
  cursor: pointer;
}
.month-more:hover {
  border-color: rgba(54,215,255,.35);
  color: var(--text);
}
.month-hidden {
  display: none;
}
.month-hidden.open {
  display: block;
}
.form-grid { display: grid; gap: 12px; }
.project-intake {
  gap: 18px;
}
.intake-section {
  display: grid;
  gap: 12px;
}
.intake-section.optional {
  border-top: 1px solid rgba(132,151,173,.16);
  padding-top: 18px;
}
.folded-intake {
  border-radius: 12px;
}
.folded-intake .intake-heading {
  cursor: pointer;
  padding: 12px 14px;
  border: 1px solid rgba(132,151,173,.14);
  border-radius: 12px;
  background: rgba(255,255,255,.025);
}
.folded-intake .intake-heading:hover {
  border-color: rgba(54,215,255,.28);
  background: rgba(54,215,255,.045);
}
.folded-intake .intake-heading::-webkit-details-marker {
  display: none;
}
.folded-intake .intake-heading::before {
  content: "+";
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border: 1px solid rgba(132,151,173,.2);
  border-radius: 7px;
  color: var(--cyan);
  font-weight: 950;
}
.folded-intake[open] .intake-heading {
  margin-bottom: 12px;
}
.folded-intake[open] .intake-heading::before {
  content: "-";
}
.intake-heading {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 14px;
}
.intake-heading span {
  color: var(--text);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.intake-heading small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  text-align: right;
}
.intake-fields {
  display: grid;
  gap: 12px;
}
.inline-client-create {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(54,215,255,.18);
  border-radius: 12px;
  background: rgba(54,215,255,.055);
}
.inline-client-create summary {
  cursor: pointer;
  color: var(--text);
  font-size: 12px;
  font-weight: 900;
}
.inline-client-create[open] summary {
  margin-bottom: 10px;
}
.existing-client-edit {
  background: rgba(255,255,255,.035);
  border-color: rgba(132,151,173,.18);
}
.workflow-intro {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}
.workflow-intro h2 {
  margin: 4px 0 6px;
  font-size: 24px;
}
.workflow-panel {
  margin-top: 14px;
}
.workflow-panel-head {
  align-items: flex-start;
}
.workflow-list {
  display: grid;
  gap: 12px;
}
.workflow-card {
  margin-top: 0;
  overflow: hidden;
}
.workflow-card-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
}
.workflow-fold-toggle,
.client-fold-toggle {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 10px;
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-weight: 950;
}
.workflow-fold-toggle:hover,
.client-fold-toggle:hover {
  border-color: rgba(54,215,255,.45);
  background: rgba(54,215,255,.08);
}
.workflow-card-title {
  min-width: 0;
}
.workflow-card-title h3 {
  margin: 0 0 4px;
  font-size: 18px;
}
.workflow-card-title p {
  margin: 0;
}
.workflow-card-badges {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}
.workflow-card-body {
  display: grid;
  gap: 18px;
  padding-top: 18px;
  margin-top: 18px;
  border-top: 1px solid rgba(132,151,173,.14);
}
.workflow-actions-row {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 8px;
}
.workflow-assignment-block,
.workflow-section-block {
  display: grid;
  gap: 10px;
}
.section-label {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.workflow-client-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.workflow-client-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  padding: 8px 11px;
  font-size: 12px;
  font-weight: 900;
}
.workflow-client-chip.active {
  border-color: rgba(54,215,255,.42);
  background: rgba(54,215,255,.09);
  color: var(--text);
}
.workflow-client-chip input {
  width: auto;
}
.workflow-section-list {
  display: grid;
  gap: 9px;
}
.workflow-section-row {
  display: grid;
  grid-template-columns: minmax(170px, 1fr) minmax(230px, 1.15fr) 90px auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(132,151,173,.14);
  border-radius: 12px;
  background: rgba(0,0,0,.16);
  padding: 10px;
}
.workflow-effort-control {
  grid-template-columns: minmax(120px, 1fr) 82px;
}
.workflow-settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 14px 0;
}
.field-label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.field-label span {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.field-label em {
  color: var(--cyan);
  font-size: 10px;
  font-style: normal;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.strategy-field {
  display: grid;
  gap: 9px;
}
.strategy-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.strategy-card {
  display: grid;
  gap: 7px;
  min-height: 96px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 12px;
  background: rgba(0,0,0,.18);
  color: var(--text);
  padding: 13px;
  text-align: left;
}
.strategy-card:hover,
.strategy-card.active {
  border-color: rgba(54,215,255,.54);
  background: rgba(54,215,255,.07);
}
.strategy-card span {
  font-weight: 900;
}
.strategy-card em {
  display: inline-block;
  margin-left: 5px;
  color: var(--cyan);
  font-size: 10px;
  font-style: normal;
  text-transform: uppercase;
}
.strategy-card small {
  color: var(--muted);
  line-height: 1.35;
}
.attention-line {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.attention-line span { color: var(--muted); font-weight: 800; }
.attention-line strong { font-size: 28px; }
.soft-bar { margin-top: 10px; }
.compact-stack { gap: 10px; }
.notice, .move-suggestion {
  border-radius: 12px;
  padding: 12px;
  border: 1px solid rgba(132,151,173,.16);
  background: rgba(0,0,0,.18);
  color: #c8d1dd;
  line-height: 1.5;
  font-size: 14px;
}
.notice.calm { color: var(--mint); border-color: rgba(84,224,168,.18); background: rgba(84,224,168,.055); }
.notice.warn { color: var(--amber); border-color: rgba(246,184,75,.2); background: rgba(246,184,75,.06); }
.move-suggestion { color: #d6deea; }
.auth-debug-panel {
  display: grid;
  gap: 8px;
  margin-top: 20px;
  padding: 14px;
  border: 1px solid rgba(54,215,255,.24);
  border-radius: 14px;
  background: rgba(0,0,0,.24);
  color: #dce7f4;
  text-align: left;
}
.auth-debug-panel > strong {
  color: var(--cyan);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.auth-debug-panel div {
  display: grid;
  grid-template-columns: minmax(150px, .55fr) minmax(0, 1fr);
  gap: 10px;
  align-items: baseline;
}
.auth-debug-panel span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.auth-debug-panel code {
  overflow-wrap: anywhere;
  color: var(--text);
  font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
  font-size: 12px;
}
.smart-suggestions {
  border-color: rgba(54,215,255,.22);
  background: linear-gradient(180deg, rgba(54,215,255,.055), rgba(0,0,0,.18));
}
.suggestion-dot {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(54,215,255,.18);
  color: var(--cyan);
  font-size: 12px;
  font-weight: 950;
}
.suggestion-card {
  border: 1px solid rgba(132,151,173,.14);
  border-radius: 12px;
  background: rgba(0,0,0,.18);
  padding: 12px;
}
.suggestion-card strong {
  display: block;
  font-size: 13px;
}
.suggestion-card p {
  margin: 7px 0 11px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}
.deadline-list { display: grid; gap: 8px; }
.active-project-list { display: grid; gap: 9px; }
.active-project-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 12px;
  width: 100%;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 12px;
  background: rgba(0,0,0,.16);
  color: var(--text);
  padding: 12px;
  text-align: left;
}
.active-project-row:hover {
  border-color: rgba(54,215,255,.35);
  background: rgba(54,215,255,.045);
}
.active-project-row span,
.deadline-rich > span:first-child {
  min-width: 0;
}
.active-project-row strong,
.active-project-row small {
  display: block;
}
.active-project-row small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.active-project-row em {
  color: var(--cyan);
  font-style: normal;
  font-weight: 950;
}
.active-project-row .bar {
  grid-column: 1 / -1;
  margin-top: 0;
}
.deadline-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  width: 100%;
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 12px;
  background: rgba(0,0,0,.16);
  color: var(--text);
  padding: 12px;
  text-align: left;
}
.deadline-row span span { display: block; margin-top: 3px; color: var(--muted); font-size: 12px; }
.deadline-row em { color: var(--cyan); font-style: normal; font-weight: 900; }
.deadline-rich {
  align-items: flex-start;
}
.deadline-progress {
  display: grid;
  justify-items: end;
  gap: 6px;
}
.deadline-progress em {
  font-size: 18px;
}
.move-date-label {
  display: grid;
  gap: 8px;
  margin-top: 14px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.icon-btn {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,.03);
  color: var(--muted);
  font-size: 18px;
}
.progressive {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}
.progressive details {
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 14px;
  background: rgba(16,21,28,.72);
  padding: 0;
  overflow: hidden;
}
.progressive summary {
  cursor: pointer;
  padding: 16px 18px;
  font-weight: 900;
  color: #d8e0eb;
}
.progressive details > .panel,
.progressive details > .projects,
.progressive details > .analytics-lite {
  margin: 0 16px 16px;
}
.quiet-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.quiet-metrics div {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 12px;
  background: rgba(0,0,0,.18);
  padding: 16px;
}
.quiet-metrics strong {
  display: block;
  font-size: 28px;
}
.quiet-metrics span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.inspiration-bank {
  display: grid;
  gap: 18px;
}
.inspiration-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: 22px;
  align-items: center;
}
.inspiration-hero h2 {
  margin-top: 7px;
  font-size: 38px;
}
.inspiration-hero p {
  margin-top: 8px;
  max-width: 720px;
  line-height: 1.55;
}
.inspiration-hero-actions,
.inspiration-capture-actions {
  display: grid;
  gap: 10px;
}
.inspiration-hero-actions {
  grid-template-columns: minmax(0, 1fr) 160px;
}
.inspiration-hero-actions .range-switch,
.inspiration-hero-actions .btn {
  width: 100%;
}
.inspiration-search {
  width: 100%;
}
.inspiration-capture {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 560px);
  gap: 18px;
  align-items: center;
  border-style: dashed;
}
.inspiration-capture:focus,
.inspiration-capture.drag-over {
  border-color: rgba(54,215,255,.64);
  background: rgba(54,215,255,.055);
  outline: none;
}
.inspiration-capture strong {
  display: block;
  font-size: 20px;
}
.inspiration-capture p {
  margin-top: 6px;
}
.inspiration-capture-actions {
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
}
.inspiration-results.grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.inspiration-results.list {
  display: grid;
  gap: 12px;
}
.inspiration-card {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 14px;
  background: rgba(16,21,28,.86);
  overflow: hidden;
}
.inspiration-results.list .inspiration-card {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  align-items: start;
}
.inspiration-media {
  background: rgba(0,0,0,.24);
}
.inspiration-results.list .inspiration-media {
  min-height: 0;
}
.inspiration-media img {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
}
.inspiration-image-button {
  width: 100%;
  height: auto;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: zoom-in;
}
.inspiration-link-preview {
  display: grid;
  align-content: center;
  gap: 8px;
  width: 100%;
  height: 100%;
  color: var(--text);
  padding: 18px;
  text-decoration: none;
}
.inspiration-link-preview span {
  color: var(--cyan);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.inspiration-link-preview strong {
  overflow-wrap: anywhere;
  line-height: 1.35;
}
.inspiration-meta {
  display: grid;
  gap: 10px;
  padding: 12px;
}
.inspiration-title {
  min-width: 0;
  border-color: transparent;
  background: transparent;
  padding: 0;
  font-weight: 900;
}
.inspiration-title:focus {
  border-color: rgba(54,215,255,.42);
  background: rgba(0,0,0,.18);
  padding: 7px 8px;
}
.inspiration-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.inspiration-fields input:last-child {
  grid-column: 1 / -1;
}
.inspiration-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 70;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 16px;
  background: rgba(2,5,8,.94);
  padding: 20px;
}
.inspiration-fullscreen-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  color: var(--text);
}
.inspiration-fullscreen-top strong,
.inspiration-fullscreen-top span {
  display: block;
}
.inspiration-fullscreen-top span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.inspiration-fullscreen-stage {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 0;
  overflow: hidden;
}
.inspiration-fullscreen-stage img {
  align-self: center;
  justify-self: center;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 24px 90px rgba(0,0,0,.5);
}
.inspiration-cycle {
  position: absolute;
  top: 50%;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 50%;
  background: rgba(5,10,15,.78);
  color: var(--text);
  font-size: 24px;
  line-height: 1;
  transform: translateY(-50%);
  backdrop-filter: blur(10px);
}
.inspiration-cycle:hover {
  border-color: rgba(54,215,255,.52);
  background: rgba(16,32,42,.92);
}
.inspiration-cycle.previous {
  left: 14px;
}
.inspiration-cycle.next {
  right: 14px;
}
.two { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.client-panel-head {
  align-items: center;
}
.client-title-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  flex: 1;
}
.client-fold-toggle {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  border: 1px solid rgba(132,151,173,.2);
  border-radius: 9px;
  background: rgba(255,255,255,.035);
  color: var(--text);
  font-size: 16px;
  font-weight: 900;
}
.client-fold-toggle:hover {
  border-color: rgba(54,215,255,.55);
  color: var(--cyan);
}
.client-panel.folded {
  padding-bottom: 14px;
}
.client-panel.folded .panel-head {
  margin-bottom: 0;
}
.client-panel-body {
  margin-top: 14px;
}
.template-add {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  margin: 16px 0;
}
.template-save-box {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(260px, 520px);
  gap: 14px;
  align-items: center;
  border: 1px solid rgba(54,215,255,.18);
  border-radius: 12px;
  background: rgba(54,215,255,.045);
  padding: 14px;
  margin: 14px 0;
}
.template-save-box strong {
  display: block;
}
.template-save-box p {
  margin-top: 4px;
}
.template-save-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
}
.checkline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}
.allocation-toolbar {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
  margin: 14px 0 8px;
  flex-wrap: wrap;
}
.allocation-toolbar label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  min-width: min(280px, 100%);
}
.template-task { display: grid; grid-template-columns: minmax(160px, 1.1fr) minmax(160px, 1fr) 82px auto; gap: 12px; align-items: center; }
.allocation-row {
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255,255,255,.025);
}
.allocation-control {
  display: grid;
  grid-template-columns: minmax(80px, 1fr) auto;
  align-items: center;
  gap: 8px;
}
.allocation-control.percent-control {
  grid-template-columns: minmax(120px, 1fr) 82px;
}
.percent-preview {
  justify-self: end;
  color: var(--cyan);
  font-weight: 950;
}
.section-name {
  border-color: transparent;
  background: rgba(255,255,255,.025);
  font-weight: 900;
}
.section-name:focus {
  border-color: rgba(54,215,255,.45);
  background: rgba(0,0,0,.18);
}
.task-edit { display: grid; gap: 10px; }
.task-edit-head { display: flex; justify-content: space-between; gap: 8px; align-items: center; }
.mini-actions { display: flex; gap: 6px; }
.mini-actions button { border: 1px solid var(--line); border-radius: 7px; background: rgba(255,255,255,.03); color: var(--muted); padding: 4px 8px; }
.mini-actions .danger-text { color: var(--danger); border-color: rgba(255,93,108,.24); }
.empty { border: 1px dashed var(--line); border-radius: 12px; padding: 16px; color: var(--muted); }
.learning { border: 1px solid rgba(84,224,168,.22); border-radius: 12px; padding: 12px; color: var(--mint); background: rgba(84,224,168,.07); line-height: 1.55; font-size: 14px; }
.learning.warn { border-color: rgba(246,184,75,.24); color: var(--amber); background: rgba(246,184,75,.07); }
.mobile-nav { display: none; gap: 8px; overflow-x: auto; padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,.08); }
.mobile-nav button { white-space: nowrap; }
.nav-section {
  margin: 22px 0 9px;
  color: #657283;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}
.crm-shell {
  display: grid;
  gap: 20px;
}
.crm-tabs {
  display: inline-flex;
  width: fit-content;
  gap: 5px;
  padding: 5px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(0,0,0,.22);
}
.crm-tabs button {
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--muted);
  padding: 10px 14px;
  font-weight: 900;
}
.crm-tabs button.active {
  background: var(--cyan);
  color: #001018;
}
.crm-dashboard,
.crm-log-view {
  display: grid;
  gap: 18px;
}
.crm-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.crm-hero h2 {
  margin-top: 7px;
  font-size: 34px;
}
.crm-kpi-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}
.crm-kpi-card {
  min-height: 142px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 15px;
  background: rgba(16,21,28,.86);
  padding: 17px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.crm-kpi-card.money {
  border-color: rgba(84,224,168,.28);
  background: linear-gradient(180deg, rgba(84,224,168,.1), rgba(16,21,28,.88));
}
.crm-kpi-card.good {
  border-color: rgba(84,224,168,.24);
}
.crm-kpi-card.warn {
  border-color: rgba(246,184,75,.32);
  background: linear-gradient(180deg, rgba(246,184,75,.08), rgba(16,21,28,.88));
}
.crm-kpi-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.crm-kpi-card strong {
  color: var(--text);
  font-size: 30px;
  line-height: 1;
  white-space: nowrap;
}
.crm-kpi-card small {
  color: #7c8999;
  font-size: 12px;
  font-weight: 850;
  line-height: 1.35;
}
.client-health-section {
  display: grid;
  gap: 17px;
}
.client-health-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}
.client-health-head h3 {
  margin-top: 7px;
  font-size: 24px;
}
.client-health-head p {
  margin-top: 6px;
  max-width: 760px;
  line-height: 1.55;
}
.client-health-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.client-health-card {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 15px;
  background: rgba(0,0,0,.16);
  padding: 15px;
  display: grid;
  gap: 15px;
}
.client-health-card.good {
  border-color: rgba(84,224,168,.22);
}
.client-health-card.warn {
  border-color: rgba(246,184,75,.26);
}
.client-health-card.bad {
  border-color: rgba(255,93,108,.26);
}
.client-health-card.churned {
  border-color: rgba(255,93,108,.42);
  background: linear-gradient(180deg, rgba(255,93,108,.12), rgba(0,0,0,.18));
}
.client-health-card.churned .client-rank {
  border-color: rgba(255,93,108,.4);
  background: rgba(255,93,108,.12);
  color: #ff9aa5;
}
.client-health-card.churned .client-health-top h3 {
  color: #ffd9dd;
}
.client-health-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.client-health-top h3 {
  margin-top: 5px;
  font-size: 20px;
}
.client-rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 24px;
  border: 1px solid rgba(54,215,255,.32);
  border-radius: 999px;
  background: rgba(54,215,255,.09);
  color: var(--cyan);
  font-size: 12px;
  font-weight: 950;
}
.client-health-top span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}
.health-score {
  width: 68px;
  height: 68px;
  flex: 0 0 68px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 15px;
  display: grid;
  place-items: center;
  align-content: center;
  background: rgba(255,255,255,.035);
}
.health-score.good {
  border-color: rgba(84,224,168,.32);
  color: var(--mint);
}
.health-score.warn {
  border-color: rgba(246,184,75,.34);
  color: var(--yellow);
}
.health-score.bad {
  border-color: rgba(255,93,108,.34);
  color: var(--danger);
}
.health-score strong {
  font-size: 24px;
  line-height: 1;
}
.health-score small {
  color: var(--muted);
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
}
.client-health-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.client-health-metrics div {
  border: 1px solid rgba(132,151,173,.12);
  border-radius: 11px;
  background: rgba(255,255,255,.025);
  padding: 11px;
}
.client-health-metrics span {
  display: block;
  color: #7c8999;
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.client-health-metrics strong {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 18px;
}
.client-health-actions {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(84,224,168,.14);
  border-radius: 12px;
  background: rgba(84,224,168,.045);
}
.client-health-actions > span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.client-health-actions p {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 7px;
  margin: 0;
  color: #cbd7e5;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
}
.client-health-actions p span {
  color: var(--mint);
  font-weight: 950;
}
.pricing-opportunities-section {
  display: grid;
  gap: 17px;
}
.pricing-opportunity-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.pricing-opportunity-card {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 15px;
  background: rgba(255,255,255,.032);
  padding: 16px;
  display: grid;
  gap: 14px;
}
.pricing-opportunity-card.high {
  border-color: rgba(84,224,168,.24);
}
.pricing-opportunity-card.medium {
  border-color: rgba(246,184,75,.24);
}
.pricing-opportunity-card.churned {
  border-color: rgba(255,93,108,.42);
  background: linear-gradient(180deg, rgba(255,93,108,.12), rgba(255,255,255,.026));
}
.pricing-opportunity-card.churned h3 {
  color: #ffd9dd;
}
.pricing-opportunity-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
}
.pricing-opportunity-top h3 {
  margin-top: 5px;
  font-size: 20px;
}
.pricing-reasons {
  display: grid;
  gap: 8px;
}
.pricing-reasons span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}
.pricing-opportunity-card p {
  color: var(--text);
  line-height: 1.5;
  font-weight: 850;
}
.crm-stat-details {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 16px;
  overflow: hidden;
  background: rgba(16,21,28,.7);
}
.crm-stat-details summary {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  cursor: pointer;
  list-style: none;
}
.crm-stat-details summary::-webkit-details-marker {
  display: none;
}
.crm-stat-details summary::before {
  content: ">";
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 1px solid rgba(132,151,173,.2);
  border-radius: 8px;
  color: var(--muted);
  font-weight: 950;
  transition: transform 160ms ease;
}
.crm-stat-details[open] summary::before {
  transform: rotate(90deg);
}
.crm-stat-details summary span {
  margin-right: auto;
  color: var(--text);
  font-size: 18px;
  font-weight: 950;
}
.crm-stat-details summary small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}
.crm-stat-details .crm-year-panel {
  border: 0;
  border-top: 1px solid rgba(132,151,173,.14);
  border-radius: 0;
}
.crm-focus-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.crm-focus-card {
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 14px;
  background: rgba(16,21,28,.86);
  padding: 16px;
  min-height: 152px;
}
.crm-focus-card.money {
  border-color: rgba(84,224,168,.26);
  background: linear-gradient(180deg, rgba(84,224,168,.09), rgba(16,21,28,.88));
}
.crm-focus-card.warn {
  border-color: rgba(255,194,87,.28);
  background: linear-gradient(180deg, rgba(255,194,87,.08), rgba(16,21,28,.88));
}
.crm-focus-card.done {
  border-color: rgba(84,224,168,.24);
}
.crm-focus-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  min-height: 34px;
}
.crm-focus-title span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.crm-focus-card em {
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 950;
  white-space: nowrap;
}
.crm-focus-card em.done { color: var(--mint); }
.crm-focus-card em.warn { color: var(--yellow); }
.crm-focus-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(132,151,173,.14);
}
.crm-focus-split div {
  min-width: 0;
}
.crm-focus-split div + div {
  border-left: 1px solid rgba(132,151,173,.12);
  padding-left: 12px;
}
.crm-focus-split small {
  display: block;
  color: #697586;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.crm-focus-split strong {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font-size: 24px;
  line-height: 1;
  white-space: nowrap;
}
.crm-focus-split em {
  display: block;
  margin-top: 8px;
  white-space: normal;
}
.reliability-card {
  display: grid;
  gap: 18px;
}
.reliability-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}
.reliability-top h2 {
  margin-top: 8px;
  font-size: 52px;
  line-height: 1;
}
.reliability-top h2 small {
  color: var(--muted);
  font-size: 20px;
}
.reliability-top p {
  max-width: 660px;
  margin-top: 8px;
  line-height: 1.55;
}
.reliability-breakdown {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.reliability-row {
  border: 1px solid rgba(132,151,173,.16);
  border-radius: 13px;
  background: rgba(0,0,0,.16);
  padding: 13px;
}
.reliability-row span {
  display: block;
  min-height: 34px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.35;
}
.reliability-row strong {
  display: block;
  margin-top: 4px;
  font-size: 24px;
}
.reliability-insights {
  display: grid;
  gap: 10px;
}
.month-select {
  max-width: 170px;
}
.crm-metric-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  overflow: visible;
}
.core-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.crm-metric {
  position: relative;
  z-index: 1;
  min-height: 104px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 15px;
  background: rgba(16,21,28,.86);
  padding: 16px;
}
.crm-metric:hover,
.crm-metric:focus-within {
  z-index: 90;
}
.crm-metric span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}
.crm-metric strong {
  display: block;
  margin-top: 15px;
  font-size: 28px;
}
.crm-metric.good {
  border-color: rgba(84,224,168,.22);
}
.crm-metric.warn {
  border-color: rgba(246,184,75,.28);
}
.crm-metric::after {
  content: attr(data-tooltip);
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: calc(100% + 8px);
  z-index: 100;
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  border: 1px solid rgba(132,151,173,.24);
  border-radius: 10px;
  background: #0b1016;
  color: #d7dfeb;
  padding: 10px;
  font-size: 12px;
  line-height: 1.45;
  white-space: pre-line;
  box-shadow: 0 18px 40px rgba(0,0,0,.34);
  transition: opacity 140ms ease, transform 140ms ease;
}
.crm-metric:hover::after {
  opacity: 1;
  transform: translateY(0);
}
.crm-year-panel {
  overflow: visible;
  padding: 0;
}
.crm-year-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 22px;
  border-bottom: 1px solid rgba(132,151,173,.14);
  background: linear-gradient(135deg, rgba(21,31,43,.92), rgba(12,17,24,.94));
}
.crm-year-head h3 {
  margin-top: 7px;
  font-size: 24px;
}
.crm-year-head p {
  margin-top: 6px;
}
.crm-year-scroll {
  overflow-x: auto;
  overflow-y: visible;
  position: relative;
  z-index: 1;
}
.crm-year-table {
  width: 100%;
  min-width: 1420px;
  border-collapse: separate;
  border-spacing: 0;
}
.crm-year-table th,
.crm-year-table td {
  border-bottom: 1px solid rgba(132,151,173,.1);
  padding: 10px 12px;
  text-align: right;
  white-space: nowrap;
}
.crm-year-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #070b10;
  color: #f2f7ff;
  font-size: 12px;
  font-weight: 950;
}
.crm-year-table thead th:first-child,
.crm-year-table .metric-key {
  position: sticky;
  left: 0;
  z-index: 3;
  text-align: left;
}
.crm-year-table thead th:first-child {
  background: #070b10;
}
.crm-year-table td {
  background: rgba(255,255,255,.018);
  color: #eaf1fb;
  font-variant-numeric: tabular-nums;
  transition: background 140ms ease, color 140ms ease;
}
.crm-year-table .metric-key {
  width: 210px;
  background: #101821;
  color: #d9e7f7;
  font-size: 12px;
  font-weight: 900;
}
.crm-year-table .metric-key:hover,
.crm-year-table .metric-key:focus-within {
  z-index: 90;
}
.crm-year-table .metric-key::after {
  content: attr(data-tooltip);
  position: absolute;
  left: 12px;
  top: calc(100% + 6px);
  z-index: 100;
  width: 260px;
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  border: 1px solid rgba(132,151,173,.24);
  border-radius: 10px;
  background: #0b1016;
  color: #d7dfeb;
  padding: 10px;
  font-size: 12px;
  line-height: 1.45;
  white-space: pre-line;
  box-shadow: 0 18px 40px rgba(0,0,0,.34);
  transition: opacity 140ms ease, transform 140ms ease;
}
.crm-year-table .metric-key:hover::after {
  opacity: 1;
  transform: translateY(0);
}
.crm-year-table .ytd {
  background: rgba(255,255,255,.032);
  color: #f3f6fb;
  font-weight: 950;
}
.crm-year-table .client-tenure-row td {
  color: #b9c5d4;
  font-size: 12px;
}
.crm-year-table .client-tenure-row .metric-key {
  color: #e5eefb;
  font-weight: 950;
}
.crm-section-row th {
  position: sticky;
  left: 0;
  z-index: 4;
  padding: 11px 12px;
  text-align: left;
  color: white;
  font-size: 12px;
  letter-spacing: .02em;
}
.crm-section-row.crm-financials th {
  background: linear-gradient(90deg, rgba(27,112,230,.95), rgba(32,211,153,.72));
}
.crm-section-row.crm-projects th {
  background: linear-gradient(90deg, rgba(27,112,230,.95), rgba(72,111,255,.7));
}
.crm-section-row.crm-deadlines th {
  background: linear-gradient(90deg, rgba(27,112,230,.95), rgba(246,184,75,.68));
}
.crm-section-row.crm-clients th {
  background: linear-gradient(90deg, rgba(27,112,230,.95), rgba(171,122,255,.68));
}
.crm-section-row.crm-core th {
  background: linear-gradient(90deg, rgba(27,112,230,.95), rgba(76,211,194,.68));
}
.crm-year-table tr.crm-financials td:not(.metric-key):not(.ytd) {
  color: #e8fff8;
}
.crm-year-table td.neutral {
  background: rgba(255,255,255,.035);
  color: #f7fbff;
}
.crm-year-table td.good {
  background: rgba(45,194,126,.1);
  color: #d8ffe9;
}
.crm-year-table td.strong-good {
  background: rgba(45,194,126,.2);
  color: #b9ffd7;
  font-weight: 950;
}
.crm-year-table td.bad {
  background: rgba(255,93,108,.1);
  color: #ffd9dd;
}
.crm-year-table td.strong-bad {
  background: rgba(255,93,108,.2);
  color: #ffc4cb;
  font-weight: 950;
}
.crm-tools,
.crm-roster {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
}
.crm-tool-selects {
  display: flex;
  gap: 10px;
  align-items: center;
}
.crm-add-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 160px 130px auto;
  gap: 10px;
  align-items: center;
}
.crm-log-list {
  display: grid;
  gap: 12px;
}
.crm-log-card {
  padding: 0;
  overflow: hidden;
}
.crm-log-summary {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 14px;
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--text);
  padding: 15px;
  text-align: left;
  cursor: pointer;
}
.crm-log-summary:hover {
  background: rgba(54,215,255,.045);
}
.crm-log-fold {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border: 1px solid rgba(132,151,173,.18);
  border-radius: 9px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  font-weight: 950;
}
.crm-log-main {
  min-width: 0;
}
.crm-log-main strong,
.crm-log-main small {
  display: block;
}
.crm-log-main small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.crm-log-money {
  color: var(--mint);
  font-size: 18px;
  font-weight: 950;
}
.crm-log-date {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}
.crm-log-body {
  display: grid;
  gap: 14px;
  padding: 0 15px 15px;
}
.crm-log-section {
  display: grid;
  gap: 13px;
  border: 1px solid rgba(132,151,173,.14);
  border-radius: 12px;
  background: rgba(0,0,0,.14);
  padding: 13px;
}
.crm-log-section .section-label {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #eaf3ff;
  font-size: 13px;
  letter-spacing: .04em;
  padding: 8px 10px;
  border: 1px solid rgba(54,215,255,.16);
  border-radius: 10px;
  background: rgba(54,215,255,.07);
}
.crm-log-section .section-label::before {
  content: "";
  width: 4px;
  height: 18px;
  border-radius: 999px;
  background: var(--cyan);
  box-shadow: 0 0 16px rgba(54,215,255,.32);
}
.crm-log-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.crm-log-grid.links {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.crm-performance-field {
  align-self: stretch;
}
.crm-performance-control {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.crm-performance-labels {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}
.crm-performance-labels span:last-child {
  text-align: right;
}
.crm-performance-labels strong {
  color: #eaf3ff;
  font-size: 11px;
  letter-spacing: 0;
  text-transform: none;
  white-space: nowrap;
}
.crm-performance-control input[type="range"] {
  height: 24px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  padding: 0;
  accent-color: var(--mint);
}
.crm-performance-control input[type="range"]::-webkit-slider-runnable-track {
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--danger), var(--amber), var(--mint));
}
.crm-performance-control input[type="range"]::-webkit-slider-thumb {
  width: 18px;
  height: 18px;
  margin-top: -5px;
  border: 2px solid #051018;
  border-radius: 999px;
  background: #f6f7fb;
  box-shadow: 0 0 0 2px rgba(255,255,255,.18);
  cursor: grab;
  -webkit-appearance: none;
}
.crm-performance-control input[type="range"]::-moz-range-track {
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--danger), var(--amber), var(--mint));
}
.crm-performance-control input[type="range"]::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border: 2px solid #051018;
  border-radius: 999px;
  background: #f6f7fb;
  cursor: grab;
}
.crm-performance-control.compact {
  min-width: 170px;
}
.crm-performance-control.compact .crm-performance-labels {
  font-size: 9px;
}
.crm-performance-control[data-performance-tone="bad"] .crm-performance-labels strong {
  color: #ff9ca5;
}
.crm-performance-control[data-performance-tone="ok"] .crm-performance-labels strong {
  color: #ffd58b;
}
.crm-performance-control[data-performance-tone="good"] .crm-performance-labels strong {
  color: #8ff0c6;
}
.crm-derived-stack {
  display: flex;
  align-items: end;
  flex-wrap: wrap;
  gap: 8px;
}
.crm-log-actions {
  display: flex;
  justify-content: flex-end;
}
.table-panel {
  padding: 0;
}
.crm-table-wrap {
  overflow: auto;
}
.crm-table {
  width: 100%;
  min-width: 1380px;
  border-collapse: collapse;
}
.crm-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: #102746;
  color: #eaf3ff;
  font-size: 12px;
  text-align: left;
  padding: 10px;
  white-space: nowrap;
}
.crm-table td {
  border-top: 1px solid rgba(132,151,173,.12);
  padding: 7px;
  background: rgba(255,255,255,.018);
}
.crm-table input,
.crm-table select {
  min-width: 110px;
  border-radius: 7px;
  padding: 7px 8px;
  font-size: 12px;
}
.crm-derived {
  display: inline-flex;
  align-items: center;
  min-height: 31px;
  border: 1px solid rgba(132,151,173,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.035);
  color: #eaf1fb;
  padding: 6px 9px;
  font-size: 12px;
  font-weight: 900;
}
.crm-derived.good {
  border-color: rgba(45,194,126,.28);
  background: rgba(45,194,126,.1);
  color: #b9ffd7;
}
.crm-derived.bad {
  border-color: rgba(255,93,108,.32);
  background: rgba(255,93,108,.1);
  color: #ffc4cb;
}
.client-table {
  min-width: 1680px;
}
.monthly-project-table {
  min-width: 2260px;
}
.mini-danger {
  border: 1px solid rgba(255,93,108,.3);
  border-radius: 7px;
  background: rgba(255,93,108,.08);
  color: var(--danger);
  padding: 7px 9px;
  font-size: 12px;
  font-weight: 900;
}

@media (max-width: 1180px) {
  .landing-hero,
  .split-section,
  .access-section { grid-template-columns: 1fr; }
  .landing-hero { min-height: auto; padding-top: 38px; }
  .landing-product { max-width: 680px; }
  .product-shell { grid-template-columns: 1fr; }
  .product-support { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .landing-proof,
  .steps-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .legal-layout { grid-template-columns: 1fr; }
  .legal-aside {
    position: static;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .legal-aside strong,
  .legal-support-link { grid-column: 1 / -1; }
  .content { grid-template-columns: 1fr; max-height: none; }
  .sidecol { grid-row: auto; }
  .projects { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .crm-kpi-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .client-health-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .pricing-opportunity-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .crm-focus-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .crm-metric-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .crm-add-row { grid-template-columns: 1fr 1fr; }
  .crm-log-grid,
  .crm-log-grid.links { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .reliability-breakdown { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dashboard-planner { grid-template-columns: 1fr; }
  .dashboard-side { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .selected-task { grid-column: 1 / -1; }
  .strategy-grid { grid-template-columns: 1fr; }
  .crm-log-summary { grid-template-columns: 30px minmax(0, 1fr); }
  .crm-log-money,
  .crm-log-date { grid-column: 2; }
  .crm-log-grid,
  .crm-log-grid.links { grid-template-columns: 1fr; }
  .inspiration-results.grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .inspiration-hero,
  .inspiration-capture { grid-template-columns: 1fr; }
  .inspiration-capture-actions { grid-template-columns: auto minmax(0, 1fr) auto; }
  .admin-kpi-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .admin-payment-defaults-grid,
  .payment-plan-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-status-board { grid-template-columns: repeat(3, minmax(220px, 1fr)); }
  .admin-due-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-analytics-grid { grid-template-columns: 1fr; }
  .admin-payment-entry { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
  .landing-nav { align-items: flex-start; flex-direction: column; }
  .landing-nav nav { width: 100%; justify-content: space-between; gap: 12px; }
  .landing-nav-actions { width: 100%; margin-left: 0; }
  .landing-nav-actions .btn { flex: 1; }
  .landing-hero,
  .landing-section,
  .legal-hero,
  .legal-layout { padding-left: 16px; padding-right: 16px; }
  .landing-hero-brand .brand-line { font-size: 24px; }
  .landing-hero-brand .brand-mark { width: 46px; height: 46px; }
  .landing-hero-brand p { margin-left: 60px; }
  .landing-copy h1 { font-size: 52px; }
  .landing-lede { font-size: 17px; }
  .admin-top,
  .admin-user,
  .admin-bugs-layout,
  .bug-admin-actions,
  .bug-detail-grid { grid-template-columns: 1fr; }
  .admin-top { align-items: flex-start; flex-direction: column; }
  .admin-user { align-items: stretch; }
  .admin-kpi-grid,
  .admin-payment-defaults-grid,
  .payment-plan-grid,
  .admin-toolbar,
  .admin-detail-grid,
  .admin-due-grid,
  .admin-payment-entry,
  .admin-history-row { grid-template-columns: 1fr; }
  .admin-status-board { grid-template-columns: 1fr; }
  .warmap-days {
    grid-template-columns: repeat(5, minmax(86px, 1fr));
    overflow-x: auto;
    padding-bottom: 4px;
  }
  .warmap-day { min-height: auto; }
  .landing-proof,
  .steps-grid,
  .solution-grid { grid-template-columns: 1fr; }
  .proof-head { align-items: flex-start; flex-direction: column; }
  .product-support { grid-template-columns: 1fr; }
  .landing-footer {
    align-items: flex-start;
    flex-direction: column;
    padding-left: 16px;
    padding-right: 16px;
  }
  .legal-hero { padding-top: 44px; }
  .legal-hero h1 { font-size: 44px; }
  .legal-hero p { font-size: 16px; }
  .legal-card { border-radius: 18px; }
  .legal-section { padding: 20px; }
  .legal-aside { grid-template-columns: 1fr; }
  .access-section { border-radius: 0; border-left: 0; border-right: 0; }
  .app { display: block; }
  .sidebar { display: none; }
  .mobile-nav { display: flex; }
  .app-top-identity { display: inline-flex; }
  .topbar { padding: 18px 16px; align-items: flex-start; flex-direction: column; }
  .auth-panel { grid-template-columns: 1fr; padding: 18px 16px; }
  .content { padding: 16px; }
  .hero, .grid2 { grid-template-columns: 1fr; }
  .metrics, .projects, .projects.relaxed-projects, .dashboard-side, .quiet-metrics, .crm-kpi-grid, .client-health-grid, .pricing-opportunity-grid, .crm-focus-grid, .crm-metric-grid, .core-metrics, .crm-add-row, .workflow-settings-grid, .project-edit-grid, .project-edit-summary { grid-template-columns: 1fr; }
  .workflow-intro { align-items: stretch; flex-direction: column; }
  .crm-hero, .crm-tools, .crm-roster, .crm-year-head, .crm-tool-selects { align-items: stretch; flex-direction: column; }
  .crm-stat-details summary { align-items: flex-start; flex-direction: column; }
  .crm-stat-details summary::before { position: absolute; right: 16px; }
  .reliability-top { align-items: stretch; flex-direction: column; }
  .reliability-breakdown { grid-template-columns: 1fr; }
  .crm-tabs { width: 100%; }
  .crm-tabs button { flex: 1; }
  .month-select { max-width: none; }
  .template-task,
  .workflow-section-row,
  .workflow-card-head { grid-template-columns: 1fr; }
  .two { grid-template-columns: 1fr; }
  .hero h2 { font-size: 30px; }
  .focus-panel { padding: 18px; }
  .timeline.dashboard.range-3,
  .timeline.dashboard.range-7 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .timeline.dashboard.range-30.calendar-month {
    min-width: 760px;
    grid-template-columns: repeat(7, minmax(0, 1fr));
  }
  .range-switch { width: 100%; }
  .range-switch button { flex: 1; }
  .inspiration-results.grid,
  .inspiration-results.list .inspiration-card,
  .inspiration-capture-actions,
  .inspiration-hero-actions,
  .inspiration-fields,
  .template-save-box,
  .template-save-actions,
  .manual-task-main,
  .manual-preset-save,
  .manual-task-optional { grid-template-columns: 1fr; }
  .inspiration-fields input:last-child { grid-column: auto; }
}
