*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
p { margin: 0 0 1rem; }
ul, ol { margin: 0; padding-left: 1.2rem; }
h1, h2, h3, h4 { margin: 0 0 1rem; }

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

input, textarea, select {
  width: 100%;
}

input:focus, textarea:focus, select:focus, button:focus, a:focus {
  outline: none;
}

.km-shell {
  width: min(calc(100% - 32px), var(--km-shell));
  margin: 0 auto;
}

.km-main { padding-bottom: 4rem; }

.km-site-header {
  position: sticky;
  top: 0;
  z-index: 30;
}

body.admin-bar .km-site-header {
  top: 32px;
}

.km-site-header__inner {
  min-height: 82px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.km-brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.km-brand img {
  width: auto;
  height: 64px;
  max-width: 180px;
  object-fit: contain;
  border-radius: 0;
  box-shadow: 0 12px 30px rgba(0,0,0,.22);
}

.km-site-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.km-site-nav__item {
  position: relative;
  display: flex;
  align-items: center;
}

.km-site-nav a,
.km-site-nav__item > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1rem;
  font-size: 0.625rem;
  font-weight: var(--km-weight-bold);
  letter-spacing: 0.3em;
  text-transform: uppercase;
}

.km-site-nav a:not(.km-site-nav__link--portal-featured) {
  position: relative;
}

.km-site-nav a:not(.km-site-nav__link--portal-featured)::after {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 1rem;
  right: 1rem;
  height: 1px;
  background: var(--km-color-paper-100);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--km-transition-fast);
}

.km-site-nav a:not(.km-site-nav__link--portal-featured):hover::after,
.km-site-nav a:not(.km-site-nav__link--portal-featured):focus-visible::after {
  transform: scaleX(1);
}

.km-site-nav__submenu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  display: grid;
  min-width: 140px;
  padding: 0.4rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
  z-index: 40;
}

.km-site-nav__submenu a {
  padding: 0.7rem 0.9rem;
  border-radius: 12px;
}

.km-site-nav__item--submenu:hover .km-site-nav__submenu,
.km-site-nav__item--submenu:focus-within .km-site-nav__submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.km-site-footer__inner {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  padding: 2rem 0 3rem;
}

.km-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 1.5rem; }

.km-hero {
  width: min(calc(100% - 32px), var(--km-shell));
  margin: 2rem auto 0;
  padding: 2rem 2.1rem;
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(250px, 0.55fr);
  gap: 18px;
}

.km-hero__content {
  display: grid;
  align-content: start;
  gap: 0.2rem;
  min-width: 0;
}

.km-showcase-card { padding: 1.2rem 1.25rem; min-height: 100%; }
.km-showcase-card h3 {
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  margin-bottom: 0.55rem;
}

.km-showcase-card ul {
  display: grid;
  gap: 6px;
  margin-top: 0.55rem;
}

.km-trustbar { display: flex; flex-wrap: wrap; gap: 10px; margin-top: .8rem; }

.km-hero .km-lead {
  max-width: 58ch;
  margin-bottom: 0.3rem;
}

.km-section,
.km-final-cta {
  width: min(calc(100% - 32px), var(--km-shell));
  margin: 1.75rem auto 0;
  padding: 2.4rem 0;
}

.km-section--soft {
  padding: 2.4rem;
}

.km-section-heading { margin-bottom: 1.8rem; }
.km-two-column,
.km-feature-grid,
.km-benefits-list,
.km-testimonial-grid,
.km-pricing-grid,
.km-dashboard-grid {
  display: grid;
  gap: 20px;
}

.km-two-column { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.km-feature-grid,
.km-pricing-grid,
.km-dashboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.km-testimonial-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.km-benefits-list { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.km-feature-card,
.km-quote-card,
.km-panel,
.km-stat-card { padding: 1.6rem; }
.km-price-card__value { margin-bottom: 1rem; font-size: 2rem; }
.km-price-card__value small { font-size: .95rem; color: var(--km-muted); }
.km-plans-compare {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.km-plan-compare-card {
  position: relative;
  display: grid;
  gap: 1.1rem;
  padding: 1.5rem;
  background: rgba(31, 26, 62, 0.74);
  border: 1px solid var(--km-border);
  border-radius: var(--km-radius);
  box-shadow: 0 18px 50px rgba(0,0,0,0.18);
}
.km-plan-compare-card.is-featured {
  border-color: rgba(248, 224, 171, 0.32);
  box-shadow: 0 22px 56px rgba(180, 86, 255, 0.18);
  transform: translateY(-6px);
}
.km-plan-compare-card__tag {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--km-primary), var(--km-primary-2));
  color: #fff;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.km-plans-compare {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  align-items: stretch;
}
.km-plan-compare-card {
  position: relative;
  display: grid;
  gap: 1rem;
  height: 100%;
  padding: 1.4rem;
  border-radius: var(--km-radius-xl);
  border: 1px solid var(--km-border-soft);
  background: rgba(31, 26, 62, 0.72);
  box-shadow: var(--km-shadow);
}
.km-plan-compare-card--bronze {
  order: 1;
}
.km-plan-compare-card--prata {
  order: 2;
}
.km-plan-compare-card--ouro {
  order: 3;
}
.km-plan-compare-card.is-featured {
  transform: translateY(-10px) scale(1.02);
  border-color: rgba(248,224,171,0.34);
  box-shadow: 0 22px 44px rgba(0,0,0,0.28);
}
.km-plan-compare-card__header {
  display: grid;
  gap: 0.45rem;
}
.km-plan-compare-card__eyebrow {
  margin: 0;
  font-size: 0.76rem;
  letter-spacing: 0.16em;
}
.km-plan-compare-card__header h3 {
  margin: 0;
  font-size: clamp(1.35rem, 2vw, 1.7rem);
  line-height: 1.08;
}
.km-plan-compare-card__description {
  margin: 0;
  color: var(--km-muted);
  font-size: 0.94rem;
  line-height: 1.5;
  min-height: 4.3rem;
}
.km-plan-compare-card__matrix {
  display: grid;
  gap: 0;
  border: 1px solid var(--km-border-soft);
  border-radius: var(--km-radius-md);
  overflow: hidden;
}
.km-plan-compare-card__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 0.85rem 1rem;
  background: rgba(240,238,230,0.03);
  border-bottom: 1px solid rgba(240,238,230,0.06);
}
.km-plan-compare-card__row:last-child {
  border-bottom: 0;
}
.km-plan-compare-card__row span {
  color: var(--km-muted);
  font-size: 0.88rem;
}
.km-plan-compare-card__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.km-plan-compare-card__row strong {
  color: var(--km-text);
  font-size: 1rem;
  text-align: right;
  white-space: nowrap;
}
.km-plan-compare-card__footer {
  margin-top: auto;
  display: grid;
  gap: 0.85rem;
}
.km-plan-compare-card__footer .km-price-card__value {
  margin: 0;
}
.km-plan-compare-card__footer .km-button {
  width: 100%;
}
.km-button--plan-outline {
  background: transparent;
  border-color: rgba(248,224,171,0.18);
  color: var(--km-text);
}
.km-button--plan-outline:hover {
  border-color: rgba(248,224,171,0.32);
  background: rgba(248,224,171,0.08);
}
.km-compare-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  min-height: 28px;
  border-radius: 50%;
  font-weight: 800;
  line-height: 1;
}
.km-compare-check.is-yes {
  background: rgba(34,197,94,0.14);
  color: #8cf5b1;
}
.km-compare-check.is-no {
  background: rgba(240,238,230,0.08);
  color: var(--km-muted);
}
.km-inline-help {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.km-inline-help__trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  padding: 0;
  border: 1px solid rgba(248,224,171,0.18);
  border-radius: 50%;
  background: rgba(248,224,171,0.08);
  color: var(--km-accent);
  font-size: 0.68rem;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
}
.km-inline-help__tooltip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  width: min(260px, 70vw);
  padding: 0.8rem 0.9rem;
  border-radius: var(--km-portal-radius);
  border: 1px solid var(--km-border-soft);
  background: var(--km-bg);
  color: var(--km-text);
  font-size: 0.76rem;
  line-height: 1.45;
  box-shadow: var(--km-shadow-raised);
  opacity: 0;
  visibility: hidden;
  transform: translate(-50%, 6px);
  transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
  z-index: 8;
}
.km-inline-help:hover .km-inline-help__tooltip,
.km-inline-help:focus-within .km-inline-help__tooltip {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, 0);
}
.km-process-list { display: grid; gap: 14px; padding-left: 1.2rem; }
.km-quote-card cite { color: var(--km-accent); font-style: normal; }
.km-final-cta {
  padding: 2rem;
  display: grid;
  gap: 1.1rem;
  border-radius: var(--km-radius-xl);
  border: 1px solid var(--km-border-accent);
  background: linear-gradient(120deg, rgba(31, 26, 62, 0.96), rgba(180, 86, 255, 0.16));
}
.km-final-cta .km-actions {
  width: 100%;
  margin-top: 0;
}
.km-final-cta .km-button {
  width: 100%;
}

.km-faq-list { display: grid; gap: 12px; }
.km-faq-list details {
  padding: 1.1rem 1.2rem;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-soft);
  background: rgba(31, 26, 62, 0.58);
}

.km-page-hero {
  padding: 5rem 0 1.5rem;
  background: linear-gradient(180deg, rgba(31,26,62,0.72), transparent);
}

.km-page-content { padding: 0 0 2rem; }
.km-page-builder { display: grid; gap: 1rem; }
.km-contact-stack { display: grid; gap: 12px; align-content: start; }
.km-social-links { display: flex; flex-wrap: wrap; gap: 12px; }
.km-social-links .km-button { width: fit-content; }

.km-contact-form-wrap,
.km-auth-card {
  padding: 2rem;
  border-radius: var(--km-portal-radius);
  border: 1px solid var(--km-border);
  background: rgba(31, 26, 62, 0.76);
  box-shadow: var(--km-shadow);
}

.km-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.km-form-grid__full { grid-column: 1 / -1; }
.km-alert { margin-bottom: 1rem; padding: .9rem 1rem; border-radius: var(--km-portal-radius-sm); }
.km-alert--success { background: rgba(34,197,94,0.12); color: #8cf5b1; }
.km-alert--warning { background: rgba(248,224,171,0.12); color: var(--km-accent); }
.km-alert--danger { background: rgba(239,71,111,0.12); color: #ff90a8; }
.km-auth-hero {
  position: relative;
  padding: 5rem 0 4rem;
  overflow: hidden;
}
.km-auth-hero::before {
  content: "";
  position: absolute;
  top: -120px;
  left: 50%;
  transform: translateX(-50%);
  width: 700px;
  height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(180, 86, 255, 0.14) 0%, transparent 68%);
  pointer-events: none;
}
.km-auth-hero__inner { max-width: 760px; }
.km-auth-card__brand {
  display: grid;
  gap: 0.7rem;
  margin-bottom: 1.2rem;
}
.km-auth-card__brand .km-eyebrow,
.km-auth-card__brand h2,
.km-auth-card__brand p {
  margin: 0;
}
.km-auth-card__logo {
  width: auto;
  height: 64px;
  max-width: min(100%, 240px);
  object-fit: contain;
}

.km-main--portal { padding-top: 2rem; }
.km-portal-shell {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}
.km-portal-sidebar-column {
  display: grid;
  gap: 18px;
  align-self: start;
  position: sticky;
  top: 104px;
}

body.admin-bar .km-portal-sidebar-column {
  top: 136px;
}

.km-portal-sidebar {
  position: static;
  padding: 1.5rem;
  border-radius: var(--km-radius-lg);
  border: 1px solid var(--km-border-soft);
  background: rgba(31, 26, 62, 0.85);
}

.km-portal-sidebar h1 {
  margin-bottom: 1rem;
  max-width: 100%;
  font-size: clamp(1.35rem, 2vw, 1.9rem);
  line-height: 1.12;
  letter-spacing: -0.03em;
  overflow-wrap: break-word;
  word-break: normal;
  text-wrap: balance;
}
.km-portal-sidebar__brand {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}
.km-portal-sidebar__brand.has-no-logo {
  grid-template-columns: minmax(0, 1fr);
}
.km-portal-sidebar__brand h1,
.km-portal-sidebar__brand-meta h1 {
  margin-bottom: 0;
  min-width: 0;
}
.km-portal-sidebar__eyebrow {
  margin: 0 0 0.2rem;
  font-size: 0.625rem;
}
.km-portal-sidebar__logo {
  width: 72px;
  height: 72px;
  object-fit: contain;
  border-radius: 0;
  border: 0;
  background: transparent;
  flex-shrink: 0;
}

.km-portal-menu { display: grid; gap: 8px; margin-top: 1.2rem; }
.km-portal-menu a {
  display: flex;
  align-items: center;
  padding: .85rem 1rem;
  border-radius: var(--km-portal-radius-sm);
  color: var(--km-muted);
  font-weight: 600;
}
.km-portal-menu a:hover,
.km-portal-menu a.is-current { background: rgba(248,224,171,0.08); color: var(--km-text); }
.km-portal-context {
  display: grid;
  gap: 0.45rem;
  margin-top: 1.2rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(240,238,230,0.08);
}
.km-portal-context__label {
  margin: 0;
  color: var(--km-muted);
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.km-portal-context strong {
  color: var(--km-text);
  font-size: 1rem;
}
.km-portal-context span {
  color: var(--km-muted);
  font-size: 0.88rem;
}
.km-portal-submenu {
  display: grid;
  gap: 8px;
  margin-top: 1.2rem;
}
.km-portal-submenu a {
  display: flex;
  align-items: center;
  padding: .85rem 1rem;
  border-radius: var(--km-portal-radius-sm);
  color: var(--km-muted);
  background: transparent;
  font-weight: 600;
}
.km-portal-submenu a:hover,
.km-portal-submenu a.is-current {
  background: rgba(248,224,171,0.08);
  color: var(--km-text);
}

.km-portal-content { display: grid; gap: 20px; }
.km-portal-header {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: start;
}
.km-portal-header__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.km-stats-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; min-width: 360px; }
.km-stat-card span { display: block; margin-bottom: .35rem; color: var(--km-muted); font-size: .84rem; }
.km-stat-card strong { font-size: 1.2rem; }
.km-list-clean { list-style: none; padding: 0; display: grid; gap: 12px; }
.km-list-clean li { color: var(--km-text); }
.km-dashboard-panel--overview {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 0.9rem;
  min-height: 372px;
}
.km-dashboard-panel--payments {
  max-height: 372px;
  overflow: hidden;
}
.km-dashboard-panel--payments h3,
.km-dashboard-panel--payments p {
  margin-bottom: 0;
}
.km-plan-summary {
  display: grid;
  align-content: start;
  gap: 0.9rem;
}
.km-plan-summary__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.85rem;
  flex-wrap: wrap;
}
.km-plan-summary__head .km-badge {
  flex-shrink: 0;
}
.km-plan-summary__description {
  margin: 0;
}
.km-payment-list {
  display: grid;
  gap: 0;
  min-width: 0;
  overflow: hidden;
  min-height: 0;
  border-radius: var(--km-portal-radius);
  border: 1px solid rgba(240,238,230,0.08);
  background: rgba(240,238,230,0.03);
}
.km-payment-row {
  --km-payment-row-columns: minmax(0, 1.15fr) 112px 116px;
  display: grid;
  grid-template-columns: var(--km-payment-row-columns);
  gap: 12px;
  align-items: center;
}
.km-payment-row--head {
  padding: 0.9rem 1rem 0.7rem;
  border-bottom: 1px solid rgba(240,238,230,0.08);
  border-radius: 0;
  background: transparent;
}
.km-payment-row--head .km-payment-row__cell {
  display: grid;
  gap: 0.2rem;
  min-width: 0;
  justify-items: center;
  text-align: center;
}
.km-payment-row--head .km-payment-row__cell span {
  color: var(--km-muted);
  font-size: 0.72rem;
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
}
.km-payment-list__items {
  gap: 0;
  height: 100%;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable;
}
.km-payment-list__items li {
  padding: 0;
}
.km-payment-row {
  padding: 0.9rem 1rem;
  border-radius: 0;
  border: 0;
  border-bottom: 1px solid rgba(240,238,230,0.08);
  background: transparent;
}
.km-payment-row__cell {
  display: grid;
  gap: 0.2rem;
  min-width: 0;
  justify-items: center;
  text-align: center;
}
.km-payment-row__cell small {
  display: none;
  margin: 0;
  color: var(--km-muted);
  font-size: 0.68rem;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.km-payment-row__cell strong,
.km-payment-row__cell span {
  color: var(--km-text);
  font-size: 0.92rem;
  line-height: 1.35;
  white-space: nowrap;
}
.km-payment-row__cell--status {
  justify-items: center;
}
.km-payment-row__cell--status .km-badge {
  min-width: 0;
  white-space: nowrap;
}
.km-payment-list__items li:last-child .km-payment-row {
  border-bottom: 0;
}
.km-price-inline { font-size: 1.15rem; font-weight: 700; color: var(--km-accent); }
.km-profile-actions {
  display: flex;
  justify-content: flex-end;
}
.km-profile-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.km-profile-strategy-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}
.km-profile-strategy-card {
  display: grid;
  align-content: start;
  min-height: 100%;
}
.km-profile-strategy-card h2 {
  margin-bottom: 0.6rem;
  font-size: clamp(1.05rem, 1.6vw, 1.2rem);
}
.km-profile-strategy-card p {
  margin: 0;
  color: var(--km-muted);
  white-space: pre-line;
}
.km-profile-links a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0.65rem 0.95rem;
  border-radius: 999px;
  background: rgba(248,224,171,0.08);
  border: 1px solid rgba(248,224,171,0.14);
  color: var(--km-accent);
}
.km-profile-logo-preview {
  width: 84px;
  height: 84px;
  object-fit: cover;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-soft);
  background: var(--km-surface-3);
  margin-top: 0.45rem;
}
.km-media-field {
  display: grid;
  gap: 10px;
}
.km-media-field__preview {
  display: grid;
  place-items: center;
  min-height: 116px;
  padding: 0.85rem;
  border-radius: var(--km-portal-radius);
  border: 1px dashed rgba(240,238,230,0.12);
  background: rgba(240,238,230,0.03);
  color: var(--km-muted);
  text-align: center;
}
.km-media-field__preview.has-image {
  padding: 0.6rem;
  border-style: solid;
}
.km-media-field__preview img {
  width: 100%;
  max-width: 180px;
  max-height: 140px;
  object-fit: contain;
  border-radius: 16px;
}
.km-media-field__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.km-links-editor {
  display: grid;
  gap: 12px;
}
.km-links-editor__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.km-links-editor__rows {
  display: grid;
  gap: 10px;
}
.km-links-editor__row {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}
.km-links-editor__row .km-button {
  white-space: nowrap;
}
.km-notes-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 1rem;
}
.km-notes-header .km-eyebrow,
.km-notes-header h2 {
  margin-bottom: 0.35rem;
}
.km-inline-form--note {
  gap: 16px;
}
.km-note-editor label {
  display: inline-block;
  margin-bottom: 0.55rem;
}
.km-note-editor__format {
  display: inline-flex !important;
  align-items: center;
  gap: 0;
  margin: 0 4px 0 0;
  padding: 0;
  border: 0;
  background: transparent;
  position: relative !important;
  vertical-align: top;
  flex: 0 0 auto;
  align-self: flex-start;
}
.km-note-editor__format-button {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  min-width: 122px;
  min-height: 28px;
  margin: 0;
  padding: 0.26rem 0.62rem;
  border-radius: 7px;
  border: 1px solid rgba(248, 224, 171, 0.08);
  background: rgba(255,255,255,0.04);
  color: #fff7ef !important;
  box-shadow: none;
  font-size: 0.76rem;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  text-align: left;
  white-space: nowrap;
}
.km-note-editor__format-button:hover,
.km-note-editor__format-button:focus,
.km-note-editor__format.is-open .km-note-editor__format-button {
  background: rgba(248,224,171,0.12);
  border-color: rgba(248,224,171,0.18);
}
.km-note-editor__format-button-text {
  display: inline-block;
  color: #fff7ef !important;
  -webkit-text-fill-color: #fff7ef !important;
  white-space: nowrap;
}
.km-note-editor__format-caret {
  width: 0;
  height: 0;
  border-left: 3.5px solid transparent;
  border-right: 3.5px solid transparent;
  border-top: 4.5px solid rgba(255, 247, 239, 0.86);
  flex: 0 0 auto;
}
.km-note-editor__format-menu {
  position: absolute !important;
  top: calc(100% + 6px);
  left: 0;
  z-index: 20;
  display: none;
  min-width: 170px;
  padding: 0.35rem;
  border-radius: var(--km-portal-radius);
  border: 1px solid var(--km-border-accent);
  background: var(--km-bg) !important;
  box-shadow: var(--km-shadow-raised);
  pointer-events: none;
  backdrop-filter: blur(14px);
}
.km-note-editor__format.is-open .km-note-editor__format-menu {
  display: grid !important;
  gap: 0.2rem;
  pointer-events: auto;
}
.km-note-editor__format-option {
  min-height: 30px;
  padding: 0.38rem 0.62rem;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: #fff7ef !important;
  -webkit-text-fill-color: #fff7ef !important;
  font-size: 0.8rem;
  font-weight: 500;
  line-height: 1.1;
  text-align: left;
  cursor: pointer;
  opacity: 1 !important;
}
.km-note-editor__format-option:hover,
.km-note-editor__format-option:focus,
.km-note-editor__format-option.is-active {
  background: rgba(248,224,171,0.12);
  color: #fff7ef !important;
  -webkit-text-fill-color: #fff7ef !important;
}
.km-note-editor .mce-toolbar-grp .mce-container-body > .km-note-editor__format {
  display: inline-flex;
  vertical-align: middle;
}
.km-note-editor .mce-toolbar-grp .mce-flow-layout,
.km-note-editor .mce-toolbar-grp .mce-container-body {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.km-note-editor .mce-toolbar-grp .mce-flow-layout-item {
  display: inline-flex !important;
  align-items: center;
}
.km-note-editor .mce-flow-layout-item.km-note-editor__format {
  margin: 0 4px 0 0;
  top: 0;
  align-self: center !important;
  transform: translateY(2px);
}
.km-note-editor__textarea {
  width: 100%;
  min-height: 320px;
  padding: 1.15rem 1.2rem;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-accent);
  background: linear-gradient(180deg, rgba(33, 27, 63, 0.98), rgba(22, 18, 44, 0.98));
  color: #fff7ef;
  resize: vertical;
}
.km-note-editor__textarea::placeholder {
  color: rgba(255, 247, 239, 0.45);
}
.km-note-editor .wp-editor-wrap {
  border-radius: var(--km-radius-md);
  overflow: hidden;
  border: 1px solid var(--km-border-accent);
  background: linear-gradient(180deg, rgba(33, 27, 63, 0.98), rgba(22, 18, 44, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    0 14px 34px rgba(15, 11, 31, 0.18);
}
.km-note-editor .wp-editor-tools {
  padding: 0.75rem 0.8rem 0;
  background: linear-gradient(180deg, rgba(43, 35, 77, 0.92), rgba(33, 27, 63, 0.92));
}
.km-note-editor .wp-switch-editor {
  border: 1px solid rgba(248, 224, 171, 0.1);
  background: rgba(255,255,255,0.04);
  color: rgba(255,247,239,0.66);
  border-radius: 12px 12px 0 0;
  box-shadow: none;
}
.km-note-editor .wp-switch-editor.switch-tmce,
.km-note-editor .wp-switch-editor.switch-html.active,
.km-note-editor .wp-switch-editor.active {
  background: rgba(248,224,171,0.14);
  color: #fff7ef;
  border-color: rgba(248,224,171,0.22);
}
.km-note-editor .wp-switch-editor.switch-html {
  display: none !important;
}
.km-note-editor .mce-toolbar-grp,
.km-note-editor .mce-panel,
.km-note-editor .mce-container-body,
.km-note-editor .quicktags-toolbar {
  background: rgba(255,255,255,0.03);
  border-color: rgba(248, 224, 171, 0.08);
}
.km-note-editor .mce-ico {
  color: #fff7ef !important;
}
.km-note-editor .mce-tinymce.mce-container.mce-panel,
.km-note-editor .mce-top-part,
.km-note-editor .mce-stack-layout {
  background: linear-gradient(180deg, rgba(33, 27, 63, 0.98), rgba(22, 18, 44, 0.98)) !important;
  border-color: rgba(248, 224, 171, 0.08) !important;
}
.km-note-editor .mce-tinymce.mce-container,
.km-note-editor .mce-panel,
.km-note-editor .mce-container,
.km-note-editor .mce-top-part::before {
  border: 0 !important;
  box-shadow: none !important;
}
.km-note-editor .mce-toolbar .mce-btn button,
.km-note-editor .quicktags-toolbar input {
  color: #fff7ef;
}
.km-note-editor .mce-btn,
.km-note-editor .mce-btn button,
.km-note-editor .mce-ico,
.km-note-editor .mce-caret {
  color: #fff7ef !important;
  opacity: 1 !important;
}
.km-note-editor .mce-listbox .mce-txt,
.km-note-editor .mce-listbox button .mce-txt,
.km-note-editor .mce-toolbar .mce-listbox .mce-txt,
.km-note-editor .mce-toolbar .mce-listbox button span,
.km-note-editor .mce-toolbar .mce-listbox button .mce-open,
.km-note-editor .mce-toolbar .mce-listbox button .mce-caret {
  color: #fff7ef !important;
  -webkit-text-fill-color: #fff7ef !important;
  opacity: 1 !important;
  text-shadow: none !important;
}
.km-note-editor .mce-toolbar .mce-listbox button {
  background: rgba(255,255,255,0.04) !important;
  color: #fff7ef !important;
  -webkit-text-fill-color: #fff7ef !important;
  opacity: 1 !important;
}
.km-note-editor .mce-selectbox,
.km-note-editor .mce-menubtn,
.km-note-editor .mce-listbox,
.km-note-editor .mce-toolbar .mce-menubtn,
.km-note-editor .mce-toolbar .mce-listbox {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(248, 224, 171, 0.08) !important;
  box-shadow: none !important;
}
.km-note-editor .mce-toolbar .mce-btn,
.km-note-editor .quicktags-toolbar input {
  border-color: rgba(248, 224, 171, 0.08);
  background: rgba(255,255,255,0.04);
  box-shadow: none;
  border-radius: 10px;
}
.km-note-editor .mce-toolbar .mce-btn button {
  padding: 0.34rem 0.46rem;
}
.km-note-editor .mce-toolbar .mce-btn:hover,
.km-note-editor .mce-toolbar .mce-btn.mce-active,
.km-note-editor .quicktags-toolbar input:hover {
  background: rgba(248,224,171,0.12);
  border-color: rgba(248,224,171,0.18);
}
.km-note-editor div.mce-edit-area {
  background: #1a1533;
  border-top-color: rgba(248, 224, 171, 0.08);
}
.km-note-editor iframe {
  background: #1a1533;
}
.km-note-editor .wp-editor-container textarea.wp-editor-area {
  background: #1a1533;
  color: #fff7ef;
  border: 0;
  padding: 1.1rem 1.15rem;
}
.km-note-editor .wp-editor-container {
  border-top: 1px solid rgba(248, 224, 171, 0.08);
  background: #1a1533;
}
.km-note-editor .mce-edit-area iframe,
.km-note-editor .mce-edit-area {
  background-color: #1a1533 !important;
}
.km-note-editor .mce-statusbar,
.km-note-editor .quicktags-toolbar + .wp-editor-container {
  background: rgba(24, 19, 50, 0.96);
  border-top-color: rgba(248, 224, 171, 0.08);
}
.km-note-editor .quicktags-toolbar {
  display: none !important;
}
.km-note-editor .mce-tinymce,
.km-note-editor .mce-top-part,
.km-note-editor .mce-edit-area,
.km-note-editor .mce-container-body,
.km-note-editor .mce-panel,
.km-note-editor .wp-editor-container,
.km-note-editor .wp-editor-wrap,
.km-note-editor .wp-editor-tabs,
.km-note-editor .wp-editor-tools,
.km-note-editor .mce-toolbar-grp {
  border-color: transparent !important;
  box-shadow: none !important;
}
.km-note-editor .mce-edit-area iframe {
  border: 0 !important;
}
.km-note-editor .mce-statusbar {
  display: none !important;
}
.km-note-editor .wp-editor-wrap.html-active .wp-editor-container {
  border-top: 0 !important;
}
.km-inline-form--note input[type="text"] {
  background: rgba(255,255,255,0.08);
  border-color: rgba(248, 224, 171, 0.12);
  color: #fff7ef;
}
.km-inline-form--note input[type="text"]:focus {
  background: rgba(255,255,255,0.12);
  border-color: rgba(248, 224, 171, 0.24);
}
.km-notes-stack {
  display: grid;
  gap: 16px;
}
.km-note-card {
  display: grid;
  gap: 14px;
  padding: 1.2rem 1.25rem;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-soft);
  background: var(--km-surface-3);
}
.km-note-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.km-note-card__head h3 {
  margin-bottom: 0.35rem;
}
.km-note-card__meta {
  margin: 0;
  font-size: 0.82rem;
  color: var(--km-muted);
}
.km-note-card__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.km-note-card__actions form {
  margin: 0;
}
.km-note-card__content > :last-child {
  margin-bottom: 0;
}
.km-payment-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 1rem;
}
.km-payment-actions .km-button {
  white-space: nowrap;
}
.km-payment-filters {
  display: grid;
  gap: 14px;
  padding: 1.2rem;
}
.km-payment-filters__head h3 {
  margin: 0;
  font-size: 1rem;
}
.km-payment-filters__group {
  display: grid;
  gap: 10px;
}
.km-payment-filters__label {
  margin: 0;
  color: var(--km-muted);
  font-size: 0.72rem;
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.km-payment-filters__options {
  display: grid;
  gap: 8px;
}
.km-checkbox-label--compact {
  align-items: center;
  gap: 10px;
}
.km-checkbox-label--compact span {
  white-space: nowrap;
}
.km-empty-filter-state {
  margin: 1rem 0 0;
  color: var(--km-muted);
}
.km-table__actions {
  width: 62px;
  text-align: right;
}
.km-icon-button {
  width: 38px;
  height: 38px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(240, 238, 230, 0.12);
  background: rgba(240, 238, 230, 0.05);
  color: var(--km-text);
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.km-icon-button:hover {
  transform: translateY(-1px);
  background: rgba(180, 86, 255, 0.12);
  border-color: rgba(180, 86, 255, 0.24);
}
.km-icon-button svg {
  width: 16px;
  height: 16px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.km-dashboard-hero {
  display: grid;
  gap: 0.95rem;
  padding: 1.15rem 1.2rem;
}
.km-dashboard-hero__intro {
  display: grid;
  gap: 0.3rem;
  max-width: 760px;
}
.km-dashboard-hero__intro .km-eyebrow {
  margin: 0;
}
.km-dashboard-hero__intro h2 {
  margin: 0;
  font-size: clamp(1.45rem, 2.4vw, 1.95rem);
  line-height: 1.08;
}
.km-dashboard-hero__intro p:last-child {
  margin: 0;
  color: var(--km-muted);
  max-width: 60ch;
  font-size: 0.94rem;
}
.km-dashboard-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(148px, 1fr));
  gap: 10px;
}
.km-dashboard-metric {
  min-height: 84px;
  display: grid;
  align-content: space-between;
  gap: 0.45rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid rgba(240,238,230,0.09);
  border-radius: var(--km-portal-radius);
  background: rgba(240,238,230,0.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}
.km-dashboard-metric span {
  color: var(--km-muted);
  font-size: 0.72rem;
  line-height: 1.25;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.km-dashboard-metric strong {
  margin: 0;
  font-size: clamp(1rem, 1.45vw, 1.16rem);
  line-height: 1.05;
  color: var(--km-text);
  word-break: break-word;
}
.km-dashboard-metric--highlight {
  background: linear-gradient(180deg, rgba(180,86,255,0.15), rgba(240,238,230,0.05));
  border-color: rgba(180,86,255,0.28);
}
.km-dashboard-metric--highlight strong {
  color: var(--km-accent-light);
}
.km-dashboard-metric--plan-bronze {
  background: linear-gradient(180deg, rgba(180, 120, 72, 0.22), rgba(74, 52, 35, 0.18));
  border-color: rgba(205, 133, 63, 0.34);
}
.km-dashboard-metric--plan-bronze strong {
  color: #f6d1aa;
}
.km-dashboard-metric--plan-prata {
  background: linear-gradient(180deg, rgba(203, 213, 225, 0.22), rgba(100, 116, 139, 0.18));
  border-color: rgba(203, 213, 225, 0.32);
}
.km-dashboard-metric--plan-prata strong {
  color: #f8fafc;
}
.km-dashboard-metric--plan-ouro {
  background: linear-gradient(180deg, rgba(255, 236, 179, 0.28), rgba(234, 179, 8, 0.2));
  border-color: rgba(250, 204, 21, 0.34);
}
.km-dashboard-metric--plan-ouro strong {
  color: #fff7d6;
}
.km-board-selector-panel {
  padding: 1.1rem 1.2rem;
}
.km-board-selector-panel__main {
  display: grid;
  gap: 14px;
}
.km-board-selector-panel__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.km-board-selector-panel__top-meta {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}
.km-board-selector-panel__intro {
  display: flex;
  align-items: center;
  min-width: 0;
}
.km-board-selector-panel__intro .km-eyebrow {
  margin: 0;
}
.km-board-selector-panel__controls {
  display: grid;
  gap: 12px;
  align-items: start;
}
.km-board-selector {
  min-width: 0;
  display: grid;
  gap: 0;
  width: 100%;
}
.km-board-status-dot {
  display: inline-flex;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(240,238,230,0.04);
}
.km-board-status-dot.is-active {
  background: #22c55e;
}
.km-board-status-dot.is-inactive {
  background: #ef476f;
}
.km-board-selector__fields {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 110px;
  gap: 8px;
}
.km-board-selector select {
  min-height: 46px;
  padding: 0.7rem 0.9rem;
  border-radius: var(--km-portal-radius);
  background: rgba(240,238,230,0.05);
}
.km-board-selector-panel__actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
}
.km-board-selector-panel .km-button {
  min-height: 46px;
  width: 100%;
}
.km-board-selector-panel .km-daily-planner__display-modes {
  flex-shrink: 0;
}
.km-board-summary-card {
  display: grid;
  gap: 0.9rem;
  padding: 1.15rem 1.2rem;
}
.km-planning-body {
  display: grid;
  gap: 20px;
  align-content: start;
  grid-auto-rows: max-content;
}
.km-planning-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.95rem 1.1rem;
  border-radius: calc(var(--km-card-radius) - 8px);
  border: 1px solid rgba(240,238,230,0.08);
  background: rgba(240,238,230,0.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}
.km-planning-controls__toggle {
  display: flex;
  align-items: center;
  min-width: 0;
}
.km-planning-controls__toggle .km-checkbox-label {
  min-height: 44px;
}
.km-planning-controls__toggle .km-checkbox-label input[type="checkbox"]:focus,
.km-planning-controls__toggle .km-checkbox-label input[type="checkbox"]:focus-visible {
  outline: none;
  box-shadow: none;
  border-color: transparent;
}
.km-planning-controls__toggle .km-checkbox-label span {
  white-space: nowrap;
}
.km-planning-display-modes {
  display: flex;
  justify-content: flex-end;
  flex: 0 0 auto;
  margin-top: 0;
}
.km-board-summary-card__header {
  padding-bottom: 0;
  border-bottom: 1px solid rgba(240,238,230,0.08);
}
.km-board-summary-card__toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  padding: 0 0 0.85rem;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}
.km-board-summary-card__toggle-copy {
  display: grid;
  gap: 0.2rem;
  min-width: 0;
}
.km-board-summary-card__header .km-eyebrow {
  margin: 0;
}
.km-board-summary-card__toggle-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: 1px solid rgba(240,238,230,0.12);
  border-radius: 999px;
  background: rgba(240,238,230,0.04);
  color: rgba(255,247,239,0.82);
  flex: 0 0 auto;
  transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}
.km-board-summary-card__toggle-icon svg {
  display: block;
  width: 0.95rem;
  height: 0.95rem;
  transition: transform 180ms ease;
}
.km-board-summary-card.is-expanded .km-board-summary-card__toggle-icon svg {
  transform: rotate(180deg);
}
.km-board-summary-card__toggle:hover .km-board-summary-card__toggle-icon,
.km-board-summary-card__toggle:focus-visible .km-board-summary-card__toggle-icon {
  background: rgba(240,238,230,0.08);
  border-color: rgba(240,238,230,0.18);
  color: #fff7ef;
}
.km-board-summary-card__toggle:focus,
.km-board-summary-card__toggle:focus-visible {
  outline: none;
  box-shadow: none;
}
.km-board-summary-card__content[hidden] {
  display: none;
}
.km-board-summary-card__header h2 {
  margin-bottom: 0.35rem;
  font-size: clamp(1.2rem, 1.7vw, 1.55rem);
  line-height: 1.08;
}
.km-board-summary-card__header p:last-child {
  margin: 0;
  max-width: 68ch;
  font-size: 0.94rem;
  color: var(--km-muted);
}
.km-board-summary-card__header .km-eyebrow:last-child {
  margin: 0;
  max-width: none;
  font-size: 0.82rem;
  color: var(--km-accent);
}
.km-board-summary-card__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.km-board-summary-item {
  display: grid;
  gap: 0.45rem;
  padding: 0.85rem 0.95rem;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-soft);
  background: var(--km-surface-3);
}
.km-board-summary-item h3 {
  margin: 0;
  font-size: 0.95rem;
}
.km-board-summary-item p {
  margin: 0;
  font-size: 0.92rem;
}
.km-board-summary-item .km-list-clean {
  gap: 6px;
}
.km-board-summary-item .km-list-clean li {
  font-size: 0.91rem;
}
.km-empty-board-state {
  display: grid;
  gap: 1rem;
}
.km-empty-board-state p {
  margin: 0;
}

.km-main--daily-planner-page .km-portal-shell--daily-planner {
  width: min(calc(100% - 24px), 1640px);
  grid-template-columns: 232px minmax(0, 1fr);
  gap: 18px;
}

.km-main--daily-planner-page .km-portal-sidebar-column {
  gap: 18px;
}

.km-main--daily-planner-page .km-portal-content {
  gap: 18px;
  min-width: 0;
}

.km-daily-planner-hero,
.km-daily-board-stage {
  display: grid;
  gap: 16px;
}

.km-daily-planner-hero {
  grid-template-columns: minmax(0, 1.2fr) auto;
  align-items: end;
  padding: 1.35rem 1.45rem;
  background:
    linear-gradient(135deg, rgba(43, 36, 80, 0.92), rgba(24, 20, 47, 0.94)),
    radial-gradient(circle at top right, rgba(180, 86, 255,0.16), transparent 34%);
}

.km-daily-planner-hero__copy {
  display: grid;
  gap: 0.7rem;
}

.km-daily-planner-hero__copy p,
.km-daily-planner-hero__copy h2,
.km-daily-planner-toolbar__summary h3,
.km-daily-planner-toolbar__summary p {
  margin: 0;
}

.km-daily-planner-hero__actions,
.km-daily-planner-filters__footer {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.km-daily-planner-date-form {
  display: grid;
  grid-template-columns: auto minmax(198px, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.km-daily-planner-date-form input[type="date"] {
  min-height: 46px;
  width: 100%;
  min-width: 198px;
  padding: 0.75rem 0.9rem;
  border-radius: var(--km-portal-radius);
  background: rgba(240, 238, 230, 0.05);
}

.km-daily-planner-nav-button {
  min-width: 46px;
  min-height: 46px;
  padding: 0;
  display: grid;
  place-items: center;
  align-self: center;
}

.km-daily-planner-nav-button__icon {
  width: 1.22rem;
  height: 1.22rem;
  display: block;
  stroke: currentColor;
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
  transform: translateY(0);
}

.km-daily-planner-filters {
  padding: 1rem;
  gap: 0.9rem;
}

.km-daily-card-picker__filters p,
.km-daily-card-detail__info p {
  margin: 0;
}

.km-daily-planner-filters .km-card-toolbar__dropdowns {
  display: grid;
  gap: 10px;
}

.km-filter-text-field {
  width: 100%;
}

.km-filter-text-field__input {
  appearance: none;
  width: 100%;
  min-height: 44px;
  padding: 0.75rem 1rem;
  border-radius: var(--km-portal-radius);
  border: 1px solid var(--km-border-soft);
  background: var(--km-surface-3);
  color: var(--km-text);
  font: inherit;
  transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.km-filter-text-field__input::placeholder {
  color: var(--km-text);
  opacity: 1;
}

.km-filter-text-field__input:focus {
  outline: none;
  border-color: rgba(248,224,171,0.3);
  box-shadow: 0 0 0 3px rgba(248,224,171,0.08);
}

.km-daily-planner-filters .km-filter-dropdown__menu--field {
  min-width: 0;
  padding: 0.8rem;
}

.km-daily-planner-filters .km-filter-dropdown__menu--field input {
  width: 100%;
  min-height: 46px;
}

.km-daily-planner-filters__note {
  margin: 0;
  color: var(--km-muted);
  font-size: 0.9rem;
  line-height: 1.55;
}

.km-daily-planner {
  display: grid;
  gap: 0;
  padding: 1rem 1.15rem 1.15rem;
}

.km-daily-planner__head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  min-width: 0;
  padding: 0 0 1rem;
}

.km-daily-planner__display-modes {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0.3rem;
  border-radius: 999px;
  border: 1px solid rgba(240,238,230,0.08);
  background: rgba(240,238,230,0.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
}

.km-daily-planner__display-mode {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--km-muted);
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.km-daily-planner__display-mode:hover,
.km-daily-planner__display-mode:focus-visible {
  background: rgba(248,224,171,0.09);
  color: #fff7ef;
}

.km-daily-planner__display-mode.is-active {
  background: rgba(180,86,255,0.18);
  color: #ffffff;
  box-shadow: 0 10px 24px rgba(76, 29, 149, 0.24);
}

.km-daily-planner__display-mode svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.km-daily-planner__hint {
  margin: 0;
  max-width: 46ch;
  color: var(--km-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}

.km-daily-planner__add-column {
  position: static;
  margin-left: auto;
  align-self: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  color: #ffffff;
  cursor: pointer;
  background: linear-gradient(135deg, var(--km-primary), var(--km-primary-2));
  box-shadow: 0 10px 24px rgba(180, 86, 255,0.24);
  transform: none;
}

.km-daily-planner__add-column span {
  display: block;
  font-size: 1.6rem;
  line-height: 1;
  transform: translateY(-1px);
  pointer-events: none;
}

.km-daily-planner__viewport {
  overflow-x: auto;
  padding-bottom: 8px;
}

.km-daily-planner__columns {
  display: flex;
  gap: 16px;
  align-items: stretch;
  min-width: 100%;
}

.km-daily-column {
  flex: 1 0 308px;
  max-width: 368px;
  display: grid;
  grid-template-rows: minmax(86px, auto) minmax(0, 1fr);
  gap: 10px;
  min-height: 540px;
  padding: 1rem;
  border-radius: var(--km-radius-lg);
  border: 1px solid rgba(180, 86, 255,0.14);
  background:
    linear-gradient(180deg, rgba(31, 26, 62, 0.74), rgba(20, 17, 39, 0.9)),
    radial-gradient(circle at top center, rgba(180, 86, 255,0.08), transparent 45%);
  transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.km-daily-column__header {
  display: grid;
  gap: 8px;
}

.km-daily-column__header-main,
.km-daily-column__toolbar {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.km-daily-column__head-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
  align-content: start;
}

.km-daily-column__head-copy h3,
.km-daily-column__head-copy .km-eyebrow {
  margin: 0;
}

.km-daily-column__head-copy h3 {
  line-height: 1.14;
}

.km-daily-column__header-actions {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-shrink: 0;
}

.km-daily-column__toolbar {
  align-items: center;
  padding: 0;
}

.km-daily-column__toolbar .km-badge {
  flex-shrink: 0;
}

.km-daily-column__toolbar .km-badge,
.km-daily-column__toolbar .km-daily-column__add-card {
  margin-top: 0;
}

.km-daily-column__toolbar .km-button.km-button--primary.km-button--small.km-daily-column__add-card {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  flex: 0 0 32px;
  padding: 0;
  border-radius: 999px;
  aspect-ratio: 1 / 1;
  box-sizing: border-box;
  line-height: 1;
  margin-left: auto;
}

.km-daily-column__add-card-icon {
  display: block;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1;
  transform: translateY(-0.04em);
}

.km-daily-column__drag,
.km-daily-column__menu-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  min-height: 40px;
  border-radius: var(--km-portal-radius);
  border: 1px solid var(--km-border-strong);
  background: rgba(255, 255, 255, 0.03);
  color: var(--km-text);
  cursor: pointer;
}

.km-daily-column__drag {
  display: grid;
  place-items: center;
  padding: 0;
  min-width: 42px;
  min-height: 42px;
}

.km-daily-column__drag-icon {
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  line-height: 0;
}

.km-daily-column__drag-icon svg {
  display: block;
  width: 20px;
  height: 20px;
}

.km-daily-column__menu-trigger {
  letter-spacing: 0.08em;
  font-weight: 700;
  line-height: 1;
}

.km-daily-column__body {
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 438px;
  padding: 0.2rem;
  border-radius: var(--km-radius-md);
  transition: background 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.km-daily-column__body.is-drop-target {
  background: rgba(180, 86, 255,0.08);
  box-shadow: inset 0 0 0 1px rgba(180, 86, 255,0.28);
}

.km-daily-column__empty {
  padding: 1rem;
  border-radius: var(--km-portal-radius);
  border: 1px dashed var(--km-border-strong);
  background: rgba(16, 13, 30, 0.38);
  color: var(--km-muted);
}

.km-daily-column__empty p,
.km-daily-search__placeholder,
.km-daily-column-modal__hint,
.km-daily-column-modal__danger-text,
.km-daily-card-picker__hint,
.km-daily-card-detail__description p {
  margin: 0;
  color: var(--km-muted);
}

.km-daily-card {
  cursor: grab;
  height: auto;
  min-height: 0;
  padding: 0.8rem 0.95rem 0.58rem;
  gap: 0.48rem;
  border-radius: var(--km-radius-md);
  grid-template-rows: auto auto;
  align-content: start;
}

.km-daily-card__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px 12px;
  align-items: flex-start;
}

.km-daily-card__identity {
  display: grid;
  gap: 0.22rem;
  min-width: 0;
}

.km-daily-card__identity h4 {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.22;
}

.km-daily-card__header-meta {
  display: inline-flex;
  align-items: flex-start;
  justify-content: flex-end;
  min-width: max-content;
  padding-top: 0.02rem;
}

.km-daily-card__header-meta .km-card-date {
  text-align: right;
}

.km-daily-card__client {
  color: var(--km-muted);
  font-size: 0.82rem;
  line-height: 1.35;
}

.km-daily-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 7px;
  align-items: center;
}

.km-daily-card__compact-meta {
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 18px;
  padding-top: 0.02rem;
}

.km-daily-card__compact-indicators {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-width: 0;
}

.km-daily-card__status-text {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.km-daily-card__status-dot {
  width: 10px;
  height: 10px;
  min-width: 10px;
  border-radius: 999px;
  display: inline-block;
  background: var(--km-indicator-color, currentColor);
  opacity: 1;
  border: 0;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.16);
}

.km-daily-card__priority-triangle {
  width: 11px;
  height: 11px;
  display: inline-block;
  flex-shrink: 0;
  background: var(--km-indicator-color, currentColor);
  opacity: 1;
  clip-path: polygon(50% 0, 0 100%, 100% 100%);
}

.km-daily-card:focus-visible,
.km-daily-card:hover {
  border-color: rgba(180, 86, 255,0.24);
  box-shadow: 0 14px 28px rgba(7, 5, 17, 0.24);
}

.km-daily-card.is-dragging,
.km-daily-column.is-dragging {
  opacity: 0.45;
  transform: scale(0.985);
}

.km-daily-modal {
  width: min(100%, 1120px);
}

.km-modal__dialog.km-daily-card-picker-modal {
  width: min(100%, 1120px);
}

.km-daily-card-picker-modal,
.km-daily-card-detail-modal {
  display: grid;
  gap: 16px;
}

.km-daily-card-picker__header,
.km-daily-card-detail__header {
  display: grid;
  gap: 0.55rem;
}

.km-daily-card-picker__header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  column-gap: 1rem;
  padding-right: 4.6rem;
}

.km-daily-card-picker__header-copy {
  min-width: 0;
}

.km-daily-card-picker__header-actions {
  display: flex;
  justify-content: flex-end;
  align-items: end;
}

.km-daily-card-picker__header h3,
.km-daily-card-picker__header p,
.km-daily-card-detail__header h3,
.km-daily-card-detail__header p {
  margin: 0;
}

.km-daily-card-picker__filters {
  gap: 10px;
}

.km-daily-card-picker-toolbar {
  gap: 0.75rem;
  width: 100%;
}

.km-daily-card-picker-toolbar .km-card-toolbar__head h3 {
  margin: 0;
  font-size: 0.95rem;
}

.km-daily-card-picker-toolbar .km-card-toolbar__dropdowns {
  display: grid;
  gap: 10px;
  width: 100%;
}

.km-daily-card-picker-toolbar__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  width: 100%;
}

.km-daily-card-picker-toolbar__row {
  display: flex;
  flex-wrap: nowrap;
  gap: 12px;
  align-items: stretch;
  width: 100%;
}

.km-daily-card-picker-toolbar__row--primary {
  justify-content: space-between;
}

.km-daily-card-picker-toolbar__row--filters {
  justify-content: space-between;
}

.km-daily-card-picker-toolbar .km-filter-dropdown__trigger,
.km-daily-card-picker-toolbar .km-filter-text-field__input {
  min-height: 42px;
}

.km-daily-card-picker-toolbar .km-filter-dropdown__trigger {
  width: 100%;
  justify-content: space-between;
}

.km-modal .km-daily-card-picker-toolbar .km-filter-dropdown__menu {
  top: calc(100% + 10px);
  right: auto;
  bottom: auto;
  left: 0;
  width: max-content;
  min-width: max(100%, 220px);
  max-width: min(420px, calc(100vw - 48px));
  max-height: min(560px, calc(100vh - 180px));
  overflow-x: hidden;
  padding: 0.7rem;
  gap: 8px;
}

.km-daily-card-picker-toolbar .km-filter-dropdown__option {
  padding: 0.88rem 1rem;
  white-space: nowrap;
}

.km-daily-card-picker__search,
.km-daily-card-picker-toolbar .km-filter-dropdown,
.km-daily-card-picker__display-modes {
  min-width: 0;
}

.km-daily-card-picker__search {
  flex: 1 1 auto;
}

.km-daily-card-picker-toolbar__row--filters .km-filter-dropdown {
  flex: 1 1 0;
}

.km-daily-card-picker__toggle-field {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  width: max-content;
  max-width: 100%;
  min-width: max-content;
  min-height: 42px;
  margin: 0;
  padding: 0 0.95rem;
  border-radius: var(--km-portal-radius);
  border: 1px solid var(--km-border-soft);
  background: var(--km-surface-3);
  box-sizing: border-box;
}

.km-daily-card-picker__toggle-field .km-checkbox-label {
  min-height: 42px;
  width: auto;
  color: var(--km-text);
  font-size: 0.86rem;
  font-weight: 500;
  line-height: 1.3;
}

.km-daily-card-picker__toggle-field .km-checkbox-label span {
  white-space: nowrap;
}

.km-daily-card-picker__display-modes {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: flex-end;
  min-height: 42px;
  margin-top: 0;
}

.km-daily-card-picker__display-modes .km-daily-planner__display-modes {
  margin: 0;
}

.km-daily-picker-results {
  display: block;
  max-height: 54vh;
  overflow-y: auto;
  padding-right: 4px;
}

.km-daily-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 308px), 1fr));
  gap: 14px;
  align-items: stretch;
  justify-content: stretch;
}

.km-daily-picker-card {
  display: grid;
  height: 100%;
  min-height: 0;
  grid-template-rows: auto auto minmax(0, 1fr);
  align-content: start;
  gap: 8px;
  padding: 0.95rem;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease, opacity 0.18s ease;
}

.km-daily-picker-card .km-daily-card__identity h4,
.km-daily-picker-card .km-daily-card__client,
.km-daily-picker-card p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
}

.km-daily-picker-card .km-daily-card__identity h4 {
  -webkit-line-clamp: 2;
}

.km-daily-picker-card .km-daily-card__client {
  -webkit-line-clamp: 1;
}

.km-daily-picker-card p {
  -webkit-line-clamp: 2;
}

.km-daily-picker-card.is-disabled {
  opacity: 0.64;
  filter: saturate(0.55);
  border-style: dashed;
  background:
    linear-gradient(180deg, rgba(46, 45, 58, 0.96), rgba(30, 29, 40, 0.96)),
    radial-gradient(circle at top center, rgba(255, 255, 255, 0.03), transparent 46%);
}

.km-daily-picker-card.is-pending {
  pointer-events: none;
  opacity: 0.72;
}

.km-daily-picker-card:hover,
.km-daily-picker-card:focus-visible {
  border-color: rgba(180, 86, 255,0.24);
  box-shadow: 0 16px 28px rgba(7, 5, 17, 0.24);
  transform: translateY(-1px);
}

.km-daily-picker-card__state {
  background: rgba(255, 255, 255, 0.1);
}

:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card {
  gap: 0.38rem;
  padding: 0.8rem 0.95rem 0.56rem;
}

:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card__identity {
  gap: 0.18rem;
  padding-top: 0.28rem;
}

:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card__identity .km-card-category,
:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card__meta .km-badge,
:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card__header-meta {
  display: none;
}

:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card__identity h4 {
  font-size: 0.92rem;
  line-height: 1.18;
}

:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card__client {
  font-size: 0.78rem;
  line-height: 1.28;
}

:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card__meta {
  display: none;
}

:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-daily-card__compact-meta {
  display: flex;
  padding-top: 0.16rem;
}

:is(.km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-card-grid {
  gap: 14px;
}

:is(.km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-task-card p {
  display: none;
}

[data-km-daily-feedback]:empty,
[data-km-daily-picker-feedback]:empty {
  min-height: 0;
}

.km-daily-card-detail__body {
  display: grid;
  gap: 16px;
}

.km-daily-card-detail__info {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.km-daily-card-detail__info strong,
.km-daily-card-detail__description strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--km-text);
}

.km-daily-card-detail__info span {
  display: block;
  color: var(--km-muted);
}

.km-daily-card-detail__description {
  padding: 1rem;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-strong);
  background: var(--km-surface-3);
}

.km-daily-card-detail__actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 1380px) {
  .km-main--daily-planner-page .km-portal-shell--daily-planner {
    width: min(calc(100% - 22px), 1520px);
    grid-template-columns: 220px minmax(0, 1fr);
  }
}

@media (max-width: 1180px) {
  .km-main--daily-planner-page .km-portal-shell--daily-planner,
  .km-daily-planner-hero {
    grid-template-columns: 1fr;
  }

  .km-daily-planner-filters__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .km-daily-planner-filters__grid,
  .km-daily-card-detail__info {
    grid-template-columns: 1fr;
  }

  .km-daily-planner-hero__actions,
  .km-daily-planner-filters__footer,
  .km-daily-planner-date-form {
    flex-direction: column;
    align-items: stretch;
  }

  .km-daily-planner__head {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }

  .km-card-edit-modal__header {
    grid-template-columns: 1fr;
    padding-right: 3.9rem;
  }

  .km-card-edit-modal__header-actions .km-button {
    width: 100%;
  }

  .km-daily-card-picker-toolbar .km-card-toolbar__dropdowns,
  .km-daily-picker-grid {
    grid-template-columns: 1fr;
  }

  .km-daily-card-picker-toolbar__row,
  .km-daily-card-picker-toolbar__row--primary,
  .km-daily-card-picker-toolbar__row--filters {
    flex-direction: column;
    align-items: stretch;
  }

  .km-daily-card-picker__header {
    grid-template-columns: 1fr;
    padding-right: 3.9rem;
  }

  .km-daily-card-picker__header-actions {
    justify-content: flex-start;
  }

  .km-daily-card-picker__toggle-field {
    width: 100%;
    min-width: 0;
  }

  .km-daily-card-picker__toggle-field .km-checkbox-label {
    width: 100%;
  }

  .km-daily-card-picker__display-modes {
    width: 100%;
  }

  .km-daily-picker-card {
    grid-template-rows: auto auto 1fr;
  }

  .km-daily-planner__columns {
    min-width: max-content;
  }

  .km-daily-column {
    flex-basis: min(84vw, 310px);
  }

  .km-daily-card-detail__actions {
    grid-template-columns: 1fr;
  }

  .km-daily-planner__head {
    flex-wrap: wrap;
  }
}

.km-card-toolbar {
  display: grid;
  gap: 1rem;
}
.km-card-toolbar__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}
.km-card-toolbar__head h3 {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: inherit;
  font-size: 0.82rem;
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-weight: 700;
  color: var(--km-accent);
}
.km-card-toolbar__clear {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(255, 247, 239, 0.66);
  cursor: pointer;
}
.km-card-toolbar__clear:hover,
.km-card-toolbar__clear:focus-visible {
  color: #fff7ef;
}
.km-card-toolbar__head p:last-child {
  margin: 0;
}
.km-card-toolbar--right {
  width: 100%;
  padding: 1.2rem 1.25rem;
}
.km-card-toolbar--sidebar-compact {
  padding: 1rem;
  gap: 0.85rem;
}
.km-card-toolbar--sidebar-compact .km-card-toolbar__head h3 {
  align-self: center;
}
.km-card-toolbar--sidebar-compact .km-card-toolbar__dropdowns,
.km-card-toolbar--sidebar-compact .km-active-filters {
  justify-content: flex-start;
}
.km-card-toolbar--sidebar-compact .km-filter-dropdown {
  width: 100%;
}
.km-card-toolbar--sidebar-compact .km-filter-dropdown__trigger {
  width: 100%;
  justify-content: space-between;
}
.km-card-toolbar--sidebar-compact .km-filter-dropdown__menu {
  top: auto;
  right: auto;
  bottom: calc(100% + 10px);
  left: 0;
  width: 100%;
  min-width: 0;
  max-height: min(320px, calc(100vh - 180px));
  overflow-y: auto;
}
.km-active-filters--sidebar {
  gap: 8px;
}
.km-active-filters--sidebar .km-active-filter-chip {
  width: 100%;
  justify-content: space-between;
}
.km-card-toolbar__dropdowns {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
}
.km-card-toolbar__toggles {
  display: grid;
  gap: 8px;
}
.km-card-toolbar__toggle {
  padding-top: 0.1rem;
}
.km-card-toolbar__toggle .km-checkbox-label span {
  white-space: nowrap;
}
.km-filter-dropdown {
  position: relative;
}
.km-filter-dropdown__trigger {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(240,238,230,0.1);
  background: rgba(240,238,230,0.03);
  color: var(--km-text);
  cursor: pointer;
  transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease, color 0.18s ease;
}
.km-filter-dropdown__trigger::after {
  content: "+";
  color: var(--km-accent);
  font-size: 1rem;
  line-height: 1;
}
.km-filter-dropdown.is-open .km-filter-dropdown__trigger::after {
  content: "-";
}
.km-filter-dropdown.is-filter-active .km-filter-dropdown__trigger,
.km-filter-text-field.is-filter-active .km-filter-text-field__input {
  border-color: rgba(248,224,171,0.26);
  background: rgba(248,224,171,0.09);
  box-shadow: 0 0 0 3px rgba(248,224,171,0.08);
}
.km-filter-dropdown.is-filter-active .km-filter-dropdown__trigger::after {
  color: #fff7ef;
}
.km-filter-dropdown__menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 15;
  display: none;
  min-width: 220px;
  max-height: min(360px, calc(100vh - 140px));
  overflow-y: auto;
  padding: 0.55rem;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-soft);
  background: var(--km-bg);
  box-shadow: var(--km-shadow-raised);
}
.km-filter-dropdown.is-open .km-filter-dropdown__menu {
  display: grid;
  gap: 6px;
}
.km-filter-dropdown__option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.78rem 0.9rem;
  border: 1px solid transparent;
  border-radius: var(--km-portal-radius);
  background: var(--km-surface-3);
  color: var(--km-text);
  cursor: pointer;
  text-align: left;
}
.km-filter-dropdown__option:hover {
  border-color: rgba(248,224,171,0.14);
  background: rgba(248,224,171,0.08);
}
.km-filter-dropdown__option.is-active {
  border-color: rgba(180,86,255,0.28);
  background: rgba(180,86,255,0.14);
  color: #fff;
}
.km-filter-dropdown__option.is-active::after {
  content: "Ativo";
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--km-accent);
}
.km-active-filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}
.km-active-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(248,224,171,0.14);
  background: rgba(248,224,171,0.08);
  color: var(--km-accent);
  cursor: pointer;
}
.km-active-filter-chip span:last-child {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(248,224,171,0.12);
  font-size: 0.9rem;
  line-height: 1;
}
.km-card-empty-state {
  margin-bottom: 1rem;
}
.km-filter-hidden {
  display: none !important;
}

.km-table-wrap { overflow-x: auto; }
.km-table-wrap--payments {
  overflow-y: auto;
  max-height: calc(56px + (10 * 74px));
}
.km-table-wrap--payments thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--km-bg);
}
.km-table { width: 100%; border-collapse: collapse; min-width: 680px; }
.km-table th, .km-table td {
  text-align: left;
  vertical-align: middle;
  padding: 1rem;
  border-bottom: 1px solid rgba(240,238,230,0.08);
}
.km-table th { color: var(--km-muted); font-size: .82rem; text-transform: uppercase; letter-spacing: .08em; }
.km-table__col-client {
  min-width: 220px;
}
.km-table__col-client a,
.km-table__col-client span,
.km-table__col-status .km-badge {
  white-space: nowrap;
}
.km-table__col-status {
  min-width: 126px;
}
.km-payment-inline {
  display: flex;
  align-items: center;
  min-width: 0;
  width: 100%;
}
.km-payment-inline__control {
  min-width: 0;
  width: 100%;
  min-height: 40px;
  padding: 0.58rem 0.75rem;
  border-radius: var(--km-portal-radius);
  background: rgba(240, 238, 230, 0.05);
  font-size: 0.88rem;
  line-height: 1.2;
}
.km-payment-inline .km-inline-feedback {
  min-height: 1rem;
  font-size: 0.78rem;
  margin-top: 4px;
}
.km-payment-inline--date {
  max-width: 168px;
}
.km-payment-inline--status {
  position: relative;
  max-width: 156px;
  align-items: center;
}
.km-payment-inline--status .km-payment-inline__control {
  appearance: none;
  border: 0;
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.km-payment-inline--status .km-inline-feedback {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  margin-top: 0;
}
.km-payment-inline--status .km-payment-inline__control.is-paid,
.km-payment-inline--status .km-payment-inline__control.is-active,
.km-payment-inline--status .km-payment-inline__control.is-completed {
  background: rgba(34,197,94,0.14);
  color: #a7f3d0;
}
.km-payment-inline--status .km-payment-inline__control.is-overdue,
.km-payment-inline--status .km-payment-inline__control.is-rejected,
.km-payment-inline--status .km-payment-inline__control.is-closed {
  background: rgba(239,71,111,0.14);
  color: #ffb0c1;
}
.km-payment-inline--status .km-payment-inline__control.is-pending,
.km-payment-inline--status .km-payment-inline__control.is-paused,
.km-payment-inline--status .km-payment-inline__control.is-in-progress {
  background: rgba(248,224,171,0.14);
  color: #f8e0ab;
}
.km-payment-inline--status .km-payment-inline__control option {
  background: #17132d;
  color: var(--km-text);
}

.km-week-section { display: grid; gap: 16px; }
.km-week-section__head { display: flex; align-items: end; justify-content: space-between; gap: 12px; }
.km-card-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 18px; align-items: stretch; }
.km-task-card {
  --km-category-color: var(--km-accent);
  position: relative;
  overflow: hidden;
  padding: 1.15rem 1.15rem 0.94rem;
  display: grid;
  height: 100%;
  min-height: 0;
  grid-auto-flow: row;
  grid-auto-rows: max-content;
  align-content: start;
  gap: 12px;
}
.km-task-card .km-daily-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.km-task-card .km-daily-card__identity {
  display: grid;
  gap: 0.42rem;
  min-width: 0;
}
.km-task-card .km-daily-card__header-meta {
  display: inline-flex;
  align-items: center;
  min-height: 1.2rem;
}
.km-task-card[data-km-open-modal] {
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}
.km-task-card[data-km-open-modal]:hover,
.km-task-card[data-km-open-modal]:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(180, 86, 255,0.28);
  box-shadow: 0 18px 36px rgba(5, 3, 16, 0.4);
}
.km-task-card[data-km-open-modal]:focus-visible {
  outline: none;
}
.km-task-card::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 4px;
  background: var(--km-category-color);
}
.km-task-card--category-carrossel { --km-category-color: #f59e0b; }
.km-task-card--category-post { --km-category-color: #60a5fa; }
.km-task-card--category-reel { --km-category-color: #b456ff; }
.km-task-card--category-story { --km-category-color: #34d399; }
.km-card-category {
  display: inline-flex;
  align-items: center;
  min-height: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--km-category-color);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.km-card-date {
  color: var(--km-muted);
  font-size: 0.8rem;
  font-weight: 600;
  white-space: nowrap;
}
.km-task-card .km-daily-card__meta { display: flex; flex-wrap: wrap; gap: 8px; }
.km-task-card h4 { margin: 0; }
.km-task-card p { margin: 0; color: var(--km-muted); }
.km-task-card .km-button {
  min-height: 48px;
  margin-top: auto;
  align-self: stretch;
}

.km-admin-account-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-top: 1rem; }
.km-admin-account-card {
  display: grid;
  gap: 6px;
  padding: 1rem 1.1rem;
  border-radius: var(--km-portal-radius);
  border: 1px solid rgba(240,238,230,0.08);
  background: rgba(240,238,230,0.03);
}
.km-admin-account-card strong { color: var(--km-text); }
.km-admin-account-card span { color: var(--km-muted); }
.km-client-admin-card {
  gap: 0.7rem;
  min-height: 100%;
}
.km-client-admin-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.km-client-admin-card__head .km-badge {
  flex-shrink: 0;
}
.km-client-admin-card__action {
  margin-top: 0.35rem;
  color: var(--km-accent);
  font-weight: 700;
}


.km-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(4, 2, 10, 0.72);
  z-index: 100;
}

.km-modal.is-open { display: flex; }
.km-modal__dialog {
  width: min(100%, 920px);
  max-height: 90vh;
  overflow: auto;
  padding: 1.8rem;
  border-radius: var(--km-radius-lg);
  border: 1px solid var(--km-border-soft);
  background: var(--km-bg);
  position: relative;
}
.km-modal__close {
  --km-modal-close-border: rgba(240,238,230,0.1);
  --km-modal-close-bg: transparent;
  --km-modal-close-hover-border: rgba(240,238,230,0.18);
  --km-modal-close-hover-bg: rgba(240,238,230,0.08);
  --km-modal-close-hover-color: #fff;
  position: absolute;
  top: 16px;
  right: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1px solid var(--km-modal-close-border);
  background: var(--km-modal-close-bg);
  color: var(--km-text);
  font-size: 2rem;
  line-height: 1;
  transition: color 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}
.km-modal__close:hover,
.km-modal__close:focus-visible {
  border-color: var(--km-modal-close-hover-border);
  background: var(--km-modal-close-hover-bg);
  color: var(--km-modal-close-hover-color);
}
.km-modal__meta { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 1rem; }
.km-modal__actions { display: grid; gap: 18px; margin-top: 1rem; }
.km-inline-form { display: grid; gap: 12px; padding: 1.2rem; border-radius: var(--km-radius-md); background: var(--km-surface-3); border: 1px solid var(--km-border-soft); }
.km-modal__header {
  display: grid;
  gap: 0.7rem;
  padding-right: 4.4rem;
}
.km-modal__header-actions {
  margin: 0.55rem 0 0;
}
.km-modal__header .km-eyebrow:last-child {
  margin-bottom: 0;
}
.km-card-edit-modal {
  width: min(100%, 940px);
}
.km-card-edit-modal__header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 1rem 1.25rem;
  padding-bottom: 0.35rem;
}
.km-card-edit-modal__header-copy {
  display: grid;
  gap: 0.3rem;
  min-width: 0;
}
.km-card-edit-modal__header-copy h3 {
  margin: 0;
  font-size: 1.3rem;
  line-height: 1.15;
}
.km-card-edit-modal__header-actions {
  margin: 0;
}
.km-card-edit-modal__header--create {
  padding-bottom: 1.8rem;
}
.km-card-edit-modal__header-actions .km-button {
  min-height: 46px;
  white-space: nowrap;
}
.km-card-edit-modal__actions--create {
  margin-top: 0;
}
.km-card-edit-form__submit {
  width: 100%;
  min-height: 48px;
  margin-top: 0.45rem;
  justify-content: center;
}
.km-inline-form--profile {
  gap: 16px;
}
.km-profile-form-section {
  display: grid;
  gap: 14px;
  padding: 1rem 1.05rem;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-soft);
  background: var(--km-surface-3);
}
.km-profile-form-section__head {
  display: grid;
  gap: 4px;
  padding-bottom: 0.9rem;
  border-bottom: 1px solid rgba(240,238,230,0.08);
}
.km-profile-form-section__head .km-eyebrow,
.km-profile-form-section__head h4 {
  margin: 0;
}
.km-profile-form-section__head h4 {
  font-size: 1rem;
}
.km-profile-form-stack {
  display: grid;
  gap: 12px;
}
.km-profile-form-section .km-form-grid,
.km-profile-form-section .km-links-editor,
.km-profile-form-section .km-profile-form-stack {
  margin: 0;
}
.km-profile-form-section p {
  margin: 0;
}
.km-inline-form__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.25rem;
}
.km-inline-form__action-row {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 16px;
  margin-top: 0.8rem;
}
.km-inline-form__action-row > form {
  display: flex;
  align-items: stretch;
  margin: 0;
}
.km-inline-form__action-row .km-button {
  min-height: 48px;
}
.km-inline-form__danger {
  margin-top: 0;
}
.km-inline-form--compact { max-width: 320px; }
.km-approve-form {
  display: grid;
  gap: 10px;
}
.km-approve-form .km-button {
  width: 100%;
}
.km-checkbox-row { margin: 0; }
.km-checkbox-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}
.km-inline-form__checkbox-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 18px;
  align-items: center;
}
.km-inline-form__checkbox-grid .km-checkbox-row {
  min-height: 48px;
  display: flex;
  align-items: center;
  padding: 0.85rem 1rem;
  border-radius: var(--km-portal-radius);
  border: 1px solid var(--km-border-soft);
  background: var(--km-surface-3);
}
.km-checkbox-label input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  padding: 0;
  flex: 0 0 auto;
  accent-color: var(--km-primary);
}
.km-inline-form input[type="checkbox"] {
  width: auto;
  margin: 0;
  padding: 0;
  flex: 0 0 auto;
  accent-color: var(--km-primary);
}
.km-checkbox-label span {
  line-height: 1.25;
}
.km-inline-field {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.km-tag-select {
  position: relative;
  display: grid;
  gap: 8px;
  min-width: 0;
}
.km-tag-select__native {
  position: absolute;
  inset: auto;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: 0;
  opacity: 0;
  pointer-events: none;
}
.km-tag-select__trigger {
  width: 100%;
  min-height: 48px;
  padding: 0.65rem 0.8rem;
  border-radius: var(--km-portal-radius);
  border: 1px solid var(--km-border-brand);
  background: rgba(12, 10, 22, 0.44);
  color: var(--km-text);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  text-align: left;
}
.km-tag-select__trigger-value {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}
.km-tag-select__caret {
  width: 10px;
  height: 10px;
  flex: 0 0 auto;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-2px) rotate(45deg);
  opacity: 0.8;
  transition: transform 0.18s ease;
}
.km-tag-select.is-open .km-tag-select__caret {
  transform: translateY(2px) rotate(-135deg);
}
.km-tag-select__menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 12;
  display: none;
  gap: 8px;
  padding: 0.9rem;
  border-radius: var(--km-radius-md);
  border: 1px solid var(--km-border-strong);
  background: var(--km-bg);
  box-shadow: var(--km-shadow-raised);
}
.km-tag-select.is-open .km-tag-select__menu {
  display: grid;
}
.km-tag-select__option {
  padding: 0;
  border: 0;
  background: transparent;
  display: flex;
  justify-content: flex-start;
  text-align: left;
}
.km-tag-select__option .km-tag-select__badge,
.km-tag-select__trigger .km-tag-select__badge {
  max-width: 100%;
  min-height: 34px;
  justify-content: flex-start;
  white-space: normal;
}
.km-tag-select__option.is-active .km-tag-select__badge {
  box-shadow: 0 0 0 1px rgba(245, 243, 255, 0.18);
}
.km-inline-feedback { min-height: 1.2rem; font-size: .92rem; }
.km-inline-feedback.is-success { color: #8cf5b1; }
.km-inline-feedback.is-error { color: #ff90a8; }
.km-feedback-thread { display: grid; gap: 12px; margin-top: 1.2rem; }
.km-feedback-item { padding: 1rem; border-radius: var(--km-portal-radius); background: var(--km-surface-3); border: 1px solid var(--km-border-soft); }
.km-card-edit-form {
  gap: 14px;
}
.km-card-edit-form__grid {
  gap: 14px 18px;
  align-items: start;
}
.km-card-edit-form__grid > * {
  min-width: 0;
}
.km-card-edit-form__grid .km-tag-select,
.km-card-edit-form__grid .km-inline-field {
  align-content: start;
}
.km-card-edit-form__grid label {
  margin: 0;
  line-height: 1.25;
}
.km-card-edit-form__grid input[type="date"],
.km-card-edit-form .km-tag-select__trigger {
  min-height: 48px;
  height: 48px;
}
.km-card-edit-form__grid input[type="date"] {
  padding: 0.7rem 0.85rem;
}
.km-card-edit-form .km-tag-select__trigger {
  padding: 0.55rem 0.8rem;
  align-items: center;
}
.km-card-edit-form .km-tag-select__trigger-value {
  min-height: 100%;
}
.km-card-edit-form .km-tag-select__badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.8rem;
}
.km-card-edit-form__checkbox-grid {
  grid-template-columns: repeat(2, max-content);
  justify-content: start;
  gap: 8px 20px;
}
.km-card-edit-form__checkbox-grid .km-checkbox-row {
  min-height: auto;
  padding: 0;
  border: 0;
  background: transparent;
}
.km-card-edit-form__checkbox-grid .km-checkbox-label {
  width: auto;
  gap: 8px;
}
.km-card-edit-form__action-row > .km-inline-form__danger {
  flex: 1 1 0;
}
.km-card-edit-form__action-row > .km-card-edit-form__submit {
  flex: 2 1 0;
  width: 0;
}
.km-card-edit-form__action-row > .km-inline-form__danger .km-button,
.km-card-edit-form__action-row > .km-card-edit-form__submit {
  width: 100%;
}

.km-fab {
  position: fixed;
  right: 28px;
  bottom: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 62px;
  height: 62px;
  border: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--km-primary), var(--km-primary-2));
  color: var(--km-text);
  padding: 0;
  box-shadow: 0 14px 28px rgba(180, 86, 255,0.3);
  transition:
    background 0.18s ease,
    background-color 0.18s ease,
    box-shadow 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease;
}

.km-fab:hover,
.km-fab:focus-visible {
  background: linear-gradient(135deg, #df69e7 0%, #c168ff 100%);
  color: var(--km-text);
  box-shadow: 0 18px 36px rgba(180, 86, 255,0.34);
}

.km-fab span {
  display: block;
  font-size: 2.25rem;
  line-height: 1;
  font-weight: 500;
  transform: translateY(-1px);
  pointer-events: none;
}

.km-modal-open { overflow: hidden; }

@media (max-width: 980px) {
  .km-hero,
  .km-portal-shell,
  .km-two-column,
  .km-feature-grid,
  .km-plans-compare,
  .km-pricing-grid,
  .km-testimonial-grid,
  .km-benefits-list,
  .km-dashboard-grid,
  .km-board-summary-card__grid,
  .km-card-grid,
  .km-form-grid,
  .km-admin-account-grid { grid-template-columns: 1fr; }
  .km-inline-form__checkbox-grid { grid-template-columns: 1fr; }
  .km-site-header__inner,
  .km-portal-header,
  .km-card-toolbar__head,
  .km-final-cta,
  .km-site-footer__inner { flex-direction: column; align-items: start; }
  .km-dashboard-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .km-board-selector-panel__top { align-items: center; }
  .km-board-selector-panel__controls { grid-template-columns: 1fr; }
  .km-board-selector-panel__actions,
  .km-board-selector { width: 100%; }
  .km-board-selector__fields { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .km-planning-controls {
    flex-direction: column;
    align-items: stretch;
  }
  .km-planning-controls__toggle {
    width: 100%;
  }
  .km-planning-display-modes { justify-content: stretch; width: 100%; }
  .km-planning-display-modes .km-daily-planner__display-modes { width: 100%; justify-content: space-between; }
  .km-card-toolbar--right {
    width: 100%;
  }
  .km-card-toolbar__dropdowns,
  .km-active-filters { justify-content: flex-start; }
  .km-stats-grid { min-width: 0; width: 100%; grid-template-columns: 1fr; }
  .km-portal-sidebar-column { gap: 14px; }
  .km-portal-sidebar-column { position: static; top: auto; }
  .km-portal-sidebar { position: static; }
  .km-portal-sidebar h1 { font-size: clamp(1.35rem, 5vw, 1.8rem); }
  .km-portal-sidebar__logo {
    width: 60px;
    height: 60px;
  }
  .km-board-selector { min-width: 0; width: 100%; }
  .km-plan-compare-card--prata { order: 1; }
  .km-plan-compare-card--bronze { order: 2; }
  .km-plan-compare-card--ouro { order: 3; }
  .km-plan-compare-card.is-featured {
    transform: none;
  }
  .km-profile-strategy-grid {
    grid-template-columns: 1fr;
  }
  .km-media-field__actions {
    flex-direction: column;
    align-items: stretch;
  }
  .km-links-editor__row {
    grid-template-columns: 1fr;
  }
  .km-links-editor__head {
    align-items: stretch;
    flex-direction: column;
  }
  .km-note-card__head {
    flex-direction: column;
  }
}

@media (max-width: 720px) {
  body.admin-bar .km-site-header {
    top: 46px;
  }
  body.admin-bar .km-portal-sidebar-column {
    top: 150px;
  }
  .km-brand img {
    height: 54px;
    max-width: 150px;
  }
  .km-dashboard-hero {
    padding: 1rem 0.95rem;
    gap: 0.8rem;
  }
  .km-dashboard-hero__intro h2 {
    font-size: clamp(1.3rem, 7vw, 1.65rem);
  }
  .km-dashboard-metrics { grid-template-columns: 1fr; }
  .km-dashboard-metric {
    min-height: 0;
    padding: 0.8rem 0.85rem;
    gap: 0.45rem;
  }
  .km-dashboard-panel--payments {
    min-height: 0;
    max-height: none;
  }
  .km-dashboard-panel--overview {
    min-height: 0;
  }
  .km-payment-row--head {
    display: none;
  }
  .km-payment-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 12px;
  }
  .km-payment-row__cell small {
    display: block;
  }
  .km-payment-row__cell--status {
    justify-items: start;
  }
  .km-hero { padding: 1.55rem; border-radius: 24px; }
  .km-hero__content h1 {
    max-width: none;
    font-size: clamp(1.55rem, 7vw, 2.15rem);
    line-height: 1.06;
  }
  .km-section, .km-final-cta { width: min(calc(100% - 24px), var(--km-shell)); }
  .km-table { min-width: 560px; }
  .km-site-nav { gap: 6px; }
  .km-site-nav a { padding: .55rem .8rem; }
}

.km-main--public {
  padding-top: 1rem;
}

.km-page-content--immersive {
  padding: 1.1rem 0 2.5rem;
}

.km-page-builder {
  gap: 1.4rem;
}

.km-landing,
.km-page-builder {
  display: grid;
}

.km-hero {
  margin-top: 1rem;
  padding: clamp(1.75rem, 3vw, 2.8rem);
  gap: 22px;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.76fr);
  border-radius: 34px;
  background:
    linear-gradient(134deg, rgba(31, 26, 62, 0.94), rgba(64, 42, 84, 0.78)),
    radial-gradient(circle at top right, rgba(248, 224, 171, 0.08), transparent 28%);
  box-shadow: var(--km-shadow-soft);
}

.km-hero__content {
  gap: 0.65rem;
}

.km-hero__content h1 {
  max-width: 11.2ch;
  margin-bottom: 0.35rem;
  font-size: clamp(2.35rem, 5vw, 4.35rem);
  line-height: 0.95;
  text-wrap: balance;
}

.km-hero .km-lead {
  max-width: 54ch;
  color: #ece5f4;
}

.km-showcase-card {
  padding: 1.5rem;
  background:
    linear-gradient(180deg, rgba(250, 246, 242, 0.08), rgba(250, 246, 242, 0.03));
}

.km-showcase-card__label {
  font-size: 0.76rem;
  letter-spacing: 0.16em;
}

.km-showcase-card ul {
  margin-top: 0.85rem;
  padding-left: 0;
  list-style: none;
}

.km-showcase-card li {
  position: relative;
  padding-left: 1.1rem;
  color: var(--km-text-soft);
}

.km-showcase-card li::before {
  content: "";
  position: absolute;
  top: 0.6rem;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--km-accent);
}

.km-section,
.km-final-cta {
  margin-top: 1.3rem;
  padding: var(--km-section-space) 0;
}

.km-section--soft {
  padding: clamp(1.6rem, 2.4vw, 2.3rem);
  border-radius: 30px;
  background:
    linear-gradient(180deg, rgba(250, 245, 238, 0.05), rgba(250, 245, 238, 0.02));
}

.km-section-heading {
  display: grid;
  gap: 0.7rem;
  margin-bottom: 1.5rem;
  max-width: 760px;
}

.km-section-heading .km-eyebrow,
.km-section-heading h2 {
  margin-bottom: 0;
}

.km-section-heading h2 {
  line-height: 1.02;
}

.km-two-column,
.km-feature-grid,
.km-benefits-list,
.km-pricing-grid,
.km-dashboard-grid,
.km-testimonial-grid {
  gap: 22px;
}

.km-two-column p,
.km-feature-card p {
  margin: 0;
}

.km-feature-card,
.km-quote-card,
.km-panel,
.km-stat-card {
  padding: 1.45rem;
}

.km-feature-card h3,
.km-panel h2,
.km-panel h3 {
  margin-bottom: 0.55rem;
}

.km-process-list {
  gap: 12px;
  padding-left: 1.1rem;
}

.km-final-cta {
  align-items: center;
  gap: 1rem;
  padding: 2rem 2.1rem;
  border-radius: 34px;
  background:
    linear-gradient(124deg, rgba(31, 26, 62, 0.98), rgba(88, 53, 106, 0.65));
}

.km-contact-form-wrap,
.km-auth-card,
.km-inline-form {
  padding: 1.45rem;
  border-radius: 28px;
  box-shadow: var(--km-shadow-card);
}

.km-contact-stack {
  gap: 14px;
}

.km-social-links .km-button {
  width: fit-content;
}

.km-page-content .km-page-builder > .km-section:first-child {
  padding-top: 2rem;
}

.km-page-content .km-page-builder > .km-section:first-child h2 {
  max-width: 12ch;
}

.km-page-content .km-page-builder > .km-section:first-child .km-lead,
.km-page-content .km-page-builder > .km-section:first-child p:not(.km-eyebrow) {
  max-width: 60ch;
}

.km-plans-compare {
  gap: 20px;
}

.km-plan-compare-card {
  padding: 1.55rem;
  gap: 1.1rem;
}

.km-plan-compare-card__description {
  min-height: 4.7rem;
}

.km-plan-compare-card__matrix {
  background: rgba(250, 247, 243, 0.03);
}

.km-plan-compare-card__row {
  min-height: 56px;
}

.km-plan-compare-card__label {
  color: var(--km-text-soft);
}

.km-portal-shell {
  grid-template-columns: 296px minmax(0, 1fr);
  gap: 26px;
}

.km-portal-sidebar-column {
  gap: 14px;
}

.km-portal-sidebar {
  padding: 1.05rem;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(29, 23, 58, 0.9), rgba(22, 18, 44, 0.94));
}

.km-portal-sidebar__brand {
  position: relative;
  margin-bottom: 0.7rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid rgba(240,238,230,0.06);
}

.km-portal-sidebar__brand-head {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.8rem;
}

.km-portal-sidebar__brand-meta {
  display: grid;
  gap: 0.12rem;
  flex: 1 1 auto;
  min-width: 0;
}

.km-portal-sidebar h1 {
  font-size: clamp(1.2rem, 1.7vw, 1.55rem);
  line-height: 1.04;
  margin: 0;
  min-width: 0;
}

.km-portal-sidebar__back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  margin-left: auto;
  margin-top: 0.05rem;
  border: 1px solid rgba(240, 238, 230, 0.12);
  border-radius: 999px;
  background: rgba(240, 238, 230, 0.04);
  color: rgba(255, 247, 239, 0.82);
  flex: 0 0 auto;
  line-height: 1;
  transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.km-portal-sidebar__back svg {
  display: block;
  width: 0.95rem;
  height: 0.95rem;
}

.km-portal-sidebar__back:hover,
.km-portal-sidebar__back:focus-visible {
  background: rgba(240, 238, 230, 0.08);
  border-color: rgba(240, 238, 230, 0.18);
  color: #fff7ef;
  transform: translateX(-1px);
}

.km-portal-menu,
.km-portal-submenu {
  gap: 8px;
}

.km-portal-menu a,
.km-portal-submenu a {
  display: flex;
  align-items: center;
  min-height: 42px;
  padding: 0.72rem 0.9rem;
  font-weight: 600;
}

.km-portal-context {
  margin-top: 0.65rem;
  padding-top: 0;
  border-top: 0;
}

.km-portal-content {
  gap: 22px;
}

.km-portal-header {
  align-items: flex-end;
}

.km-dashboard-hero {
  padding: 1.05rem 1.15rem;
  border-radius: 30px;
}

.km-dashboard-hero__intro {
  display: grid;
  gap: 0.28rem;
  margin-bottom: 0.9rem;
}

.km-dashboard-hero__intro .km-eyebrow,
.km-dashboard-hero__intro h2,
.km-dashboard-hero__intro p {
  margin: 0;
}

.km-dashboard-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  justify-content: stretch;
}

.km-dashboard-metric {
  min-height: 92px;
  min-width: 0;
  padding: 0.95rem 1rem;
  border-radius: var(--km-portal-radius);
  background: rgba(250,247,243,0.035);
  border: 1px solid rgba(248, 224, 171, 0.08);
  display: grid;
  grid-template-rows: auto 1fr;
  align-content: stretch;
  justify-items: stretch;
  text-align: left;
  gap: 0.46rem;
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.km-dashboard-metric span {
  display: block;
  max-width: 100%;
  margin: 0;
  font-size: 0.74rem;
  line-height: 1.16;
  color: var(--km-muted);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  text-wrap: balance;
}

.km-dashboard-metric strong {
  display: block;
  max-width: 100%;
  margin: auto 0;
  font-size: 1.38rem;
  line-height: 1;
  text-align: center;
  overflow-wrap: anywhere;
}

.km-plan-inline {
  margin: 0 0 0.5rem;
  font-size: 1rem;
  font-weight: 700;
}

.km-plan-inline--bronze {
  color: #f6d1aa;
}

.km-plan-inline--prata {
  color: #f8fafc;
}

.km-plan-inline--ouro {
  color: #fff7d6;
}

.km-board-selector-panel,
.km-board-summary-card {
  padding: 1.25rem 1.35rem;
  border-radius: 30px;
}

.km-board-selector-panel__top {
  align-items: flex-start;
}

.km-board-summary-card__grid {
  gap: 14px;
}

.km-board-summary-item {
  padding: 0.95rem 1rem;
  border-radius: 20px;
}

.km-card-toolbar--sidebar-compact {
  padding: 1rem;
  border-radius: 26px;
}

.km-filter-dropdown__trigger {
  min-height: 44px;
  border-radius: var(--km-portal-radius-sm);
}

.km-task-card {
  padding: 1.15rem 1.15rem 0.94rem;
  border-radius: 24px;
  gap: 10px;
}

:is(.km-daily-planner, .km-planning-body, .km-daily-picker-results)[data-card-display-mode="compact"] .km-task-card {
  padding-bottom: 0.82rem;
}

.km-task-card h4 {
  font-size: 1.02rem;
  line-height: 1.18;
}

.km-task-card p {
  font-size: 0.93rem;
}

.km-planning-body .km-task-card p {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.km-modal__dialog {
  border-radius: 30px;
  background: #16122d;
  box-shadow: var(--km-shadow-soft);
}

.km-inline-form {
  background: rgba(250,247,243,0.03);
}

.km-table {
  min-width: 100%;
}

.km-table th {
  font-size: 0.76rem;
  letter-spacing: 0.12em;
}

.km-table td,
.km-table th {
  padding: 0.95rem 1rem;
}

.km-table-wrap--payments {
  border-radius: 24px;
  border: 1px solid rgba(240,238,230,0.06);
  background: rgba(250,247,243,0.03);
}

.km-table-wrap--payments thead th {
  background: rgba(24, 19, 50, 0.96);
}

.km-payment-list {
  border-radius: 24px;
}

.km-note-card {
  border-radius: 24px;
}

.km-alert {
  border: 1px solid transparent;
}

.km-alert--success {
  border-color: rgba(34,197,94,0.15);
}

.km-alert--warning {
  border-color: rgba(248,224,171,0.16);
}

.km-alert--danger {
  border-color: rgba(239,71,111,0.16);
}

.km-auth-hero {
  padding: 4.5rem 0 4rem;
}

.km-auth-card__brand {
  gap: 0.9rem;
}

#km-login-form input[type="submit"] {
  min-height: 46px;
  border-radius: 999px;
  font-weight: 700;
  background: linear-gradient(135deg, #d556df 0%, #b456ff 100%);
  box-shadow: 0 14px 30px rgba(181, 86, 255, 0.22);
}

@media (max-width: 1120px) {
  .km-dashboard-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

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

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

  .km-portal-shell {
    grid-template-columns: 1fr;
  }

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

@media (max-width: 720px) {
  .km-shell {
    width: min(calc(100% - 24px), var(--km-shell));
  }

  .km-site-header__inner {
    min-height: 84px;
    align-items: flex-start;
  }

  .km-brand {
    width: 100%;
  }

  .km-brand__wordmark small {
    display: none;
  }

  .km-site-nav {
    width: 100%;
    justify-content: flex-start;
  }

  .km-hero__content h1,
  .km-page-content .km-page-builder > .km-section:first-child h2 {
    max-width: none;
  }

  .km-section,
  .km-final-cta {
    padding: 2.3rem 0;
  }

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

  .km-table-wrap--payments {
    border-radius: 20px;
  }
}

/* Visual refactor: seeded pages and portal polish */
.km-page-hero--default {
  padding: clamp(3.5rem, 5vw, 5.5rem) 0 1.25rem;
  background:
    radial-gradient(circle at top right, rgba(212, 99, 183, 0.14), transparent 32%),
    linear-gradient(180deg, rgba(31, 26, 62, 0.96), rgba(31, 26, 62, 0.9));
}

.km-page-hero--default .km-shell {
  display: grid;
  gap: 0.75rem;
}

.km-page-hero--default h1 {
  max-width: 12ch;
  margin: 0;
}

.km-hero--home-refresh {
  align-items: stretch;
}

.km-hero--home-refresh .km-hero__content {
  gap: 1.1rem;
}

.km-hero-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.km-hero-point {
  display: inline-flex;
  align-items: center;
  min-height: 2.4rem;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(248, 224, 171, 0.16);
  color: rgba(255, 248, 240, 0.88);
  font-size: 0.9rem;
}

.km-home-summary-list {
  display: grid;
  gap: 1rem;
}

.km-home-summary-list__item {
  display: grid;
  gap: 0.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.km-home-summary-list__item:first-child {
  padding-top: 0;
  border-top: 0;
}

.km-home-summary-list__item strong {
  font-size: 1rem;
  color: #fff6ed;
}

.km-home-summary-list__item span {
  color: rgba(255, 244, 238, 0.72);
  font-size: 0.95rem;
}

.km-mini-plan-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
}

.km-mini-plan-card {
  display: grid;
  gap: 0.9rem;
  padding: 1.35rem;
  border-radius: 22px;
  border: 1px solid rgba(248, 224, 171, 0.16);
  background: linear-gradient(180deg, rgba(53, 44, 90, 0.96) 0%, rgba(31, 26, 62, 0.98) 100%);
  box-shadow: 0 18px 42px rgba(24, 17, 48, 0.22);
}

.km-mini-plan-card--featured {
  background: linear-gradient(180deg, rgba(82, 56, 120, 0.98) 0%, rgba(41, 31, 83, 0.98) 100%);
  border-color: rgba(180, 86, 255, 0.32);
  transform: translateY(-6px);
}

.km-mini-plan-card .km-eyebrow,
.km-mini-plan-card h3,
.km-mini-plan-card p {
  margin: 0;
}

.km-mini-plan-card strong {
  font-size: 1rem;
}

.km-actions--center {
  justify-content: center;
  margin-top: 1.5rem;
}

.km-contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.84fr) minmax(0, 1.16fr);
  gap: 1.4rem;
  align-items: stretch;
}

.km-contact-sidebar {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 1rem;
}

.km-contact-form-column,
.km-contact-form-column .km-contact-form-wrap {
  height: 100%;
}

.km-contact-form-wrap {
  display: grid;
  gap: 1.25rem;
}

.km-contact-form-wrap .km-contact-form {
  display: grid;
  gap: 1rem;
}

.km-contact-form-wrap .km-form-grid {
  gap: 1rem;
}

.km-contact-stack {
  display: grid;
  gap: 0.85rem;
  margin-top: 1rem;
}

.km-contact-stack .km-social-links {
  margin-top: 0;
}

.km-social-links .km-button {
  width: fit-content;
}

.km-page-content--immersive .km-page-builder,
.km-page-content--immersive .entry-content {
  display: grid;
  gap: var(--km-section-space);
}

.km-page-content--immersive .km-page-builder > *,
.km-page-content--immersive .entry-content > * {
  margin: 0;
}

.km-page-builder--wide-sections > .km-section,
.km-page-builder--wide-sections > .km-final-cta {
  width: 100%;
  margin-left: 0;
  margin-right: 0;
}

.km-portal-content > .km-panel > h2:first-child,
.km-portal-content > .km-panel > h3:first-child,
.km-portal-content > .km-panel > .km-eyebrow:first-child {
  margin-top: 0;
}

.km-dashboard-grid,
.km-profile-strategy-grid,
.km-notes-stack {
  gap: 1.15rem;
}

.km-profile-links {
  gap: 0.85rem;
}

.km-profile-links a {
  min-height: 2.9rem;
  border-radius: 16px;
  background: rgba(53, 44, 90, 0.92);
  border: 1px solid rgba(248, 224, 171, 0.14);
  color: #fff7ef;
  box-shadow: 0 10px 24px rgba(19, 14, 39, 0.16);
}

.km-profile-links a:hover,
.km-profile-links a:focus-visible {
  background: rgba(69, 57, 116, 0.96);
  border-color: rgba(248, 224, 171, 0.26);
  color: #fff7ef;
}

.km-profile-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 1rem;
}

.km-profile-form-section {
  border-radius: 22px;
  background: rgba(43, 35, 77, 0.82);
  border: 1px solid rgba(248, 224, 171, 0.1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.km-profile-form-section__head {
  margin-bottom: 1rem;
}

.km-inline-form--profile,
.km-inline-form--note {
  gap: 1.1rem;
}

.km-inline-form--profile {
  background: rgba(25, 20, 49, 0.68);
  border-color: rgba(248, 224, 171, 0.08);
}

.km-inline-form--profile label,
.km-inline-form--profile h3,
.km-inline-form--profile h4,
.km-inline-form--profile p,
.km-inline-form--profile strong {
  color: #fff7ef;
}

.km-inline-form--profile .km-profile-form-section__head h4 {
  color: #fff7ef;
}

.km-inline-form--profile .km-profile-form-section__head .km-eyebrow {
  color: var(--km-accent-light);
}

.km-inline-form--profile input[type="text"],
.km-inline-form--profile input[type="email"],
.km-inline-form--profile input[type="url"],
.km-inline-form--profile input[type="date"],
.km-inline-form--profile input[type="number"],
.km-inline-form--profile select,
.km-inline-form--profile textarea {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(248, 224, 171, 0.12);
  color: #fff7ef;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.km-inline-form--profile input[readonly] {
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 247, 239, 0.62);
}

.km-inline-form--profile input::placeholder,
.km-inline-form--profile textarea::placeholder {
  color: rgba(255, 247, 239, 0.42);
}

.km-inline-form--profile input:focus,
.km-inline-form--profile select:focus,
.km-inline-form--profile textarea:focus {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(248, 224, 171, 0.26);
}

.km-inline-form__action-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  padding-top: 0.75rem;
}

.km-links-editor {
  padding: 1rem;
  border-radius: 18px;
  background: rgba(31, 26, 62, 0.48);
  border: 1px solid rgba(248, 224, 171, 0.08);
}

.km-links-editor__head {
  gap: 0.75rem;
}

.km-links-editor__row {
  gap: 0.75rem;
  align-items: center;
}

.km-links-editor__row select,
.km-links-editor__row input[type="url"] {
  margin: 0;
}

.km-note-card__head {
  gap: 1rem;
}

.km-note-card__content {
  color: var(--km-muted);
  line-height: 1.75;
}

.km-note-editor .wp-editor-wrap {
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(248, 224, 171, 0.16);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.km-note-editor .wp-editor-tools,
.km-note-editor .mce-toolbar-grp,
.km-note-editor .quicktags-toolbar {
  background: rgba(31, 26, 62, 0.96);
}

.km-note-editor .wp-editor-container,
.km-note-editor .wp-editor-container textarea.wp-editor-area,
.km-note-editor div.mce-edit-area {
  background: rgba(45, 39, 76, 0.96);
}

.km-note-editor .mce-toolbar .mce-btn button,
.km-note-editor .quicktags-toolbar input {
  border-radius: 10px;
}

.km-plan-compare-card__header {
  min-height: 11rem;
}

.km-plan-compare-card__footer {
  margin-top: auto;
}

.km-plan-compare-card__row {
  min-height: 3.5rem;
}

@media (max-width: 1120px) {
  .km-mini-plan-grid,
  .km-contact-layout {
    grid-template-columns: 1fr;
  }

  .km-mini-plan-card--featured {
    transform: none;
  }
}

@media (max-width: 720px) {
  .km-hero-points {
    gap: 0.55rem;
  }

  .km-hero-point {
    width: 100%;
    justify-content: center;
  }

  .km-inline-form__action-row {
    flex-direction: column;
    align-items: stretch;
  }

  .km-inline-form__action-row > * {
    width: 100%;
  }
}


@media (max-width: 980px) {
  .km-hero,
  .km-portal-shell,
  .km-dashboard-metrics,
  .km-mini-plan-grid,
  .km-contact-layout {
    grid-template-columns: 1fr;
  }
}

/* Prototype fidelity for rebuilt public pages */
.km-proto-band {
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  padding: 4.6rem 0;
}

.km-proto-band--soft {
  background: var(--km-bg-elevated);
  border-top: 1px solid var(--km-border-soft);
  border-bottom: 1px solid var(--km-border-soft);
}

.km-proto-hero {
  padding-top: 3.8rem;
  padding-bottom: 3.2rem;
  background: var(--km-bg);
  border-top: 0;
  border-bottom: 1px solid rgba(180, 86, 255,0.14);
}

.home .km-main--public {
  padding-top: 0;
}

.home .km-proto-hero {
  padding-top: 1.5rem;
}

.km-proto-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.72fr) minmax(280px, 0.58fr);
  gap: 30px;
  align-items: stretch;
}

.km-proto-hero__content,
.km-proto-hero__visual {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.km-proto-hero__content {
  padding: 0;
}

.km-proto-hero__content h1 {
  margin-bottom: 1.1rem;
  max-width: 21ch;
  line-height: 1.02;
  font-size: clamp(2rem, 3.5vw, 3.05rem);
}

.km-proto-hero__content h1 em {
  font-family: var(--km-display);
  color: var(--km-accent);
  font-style: italic;
}

.km-proto-hero__visual {
  position: relative;
  padding: 0.2rem 0.4rem;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.km-km-photo-slot {
  width: min(100%, 340px);
  position: relative;
}

.km-km-photo-slot__image-wrap {
  width: 100%;
  min-height: 460px;
  border-radius: 220px 220px 170px 170px;
  border: 1px solid rgba(180, 86, 255,0.26);
  background: linear-gradient(180deg, rgba(42, 36, 80, 0.75), rgba(31, 26, 62, 0.92));
  overflow: hidden;
  position: relative;
}

.km-km-photo-slot__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.km-km-photo-slot__placeholder {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.4rem;
  text-align: center;
  padding: 1.2rem;
}

.km-km-photo-slot__placeholder strong {
  color: var(--km-text);
  font-family: var(--km-display);
  font-size: 1.15rem;
  font-weight: 400;
}

.km-km-photo-slot__placeholder span {
  color: var(--km-muted);
  font-size: 0.85rem;
}

.km-km-photo-slot__image-wrap.has-image .km-km-photo-slot__placeholder {
  display: none;
}

.km-proto-float {
  position: absolute;
  padding: 0.65rem 0.9rem;
  border-radius: 12px;
  border: 1px solid rgba(180, 86, 255,0.2);
  background: rgba(31, 26, 62, 0.9);
  color: var(--km-muted);
  font-size: 0.78rem;
  line-height: 1.45;
}

.km-proto-float--top,
.km-proto-float--bottom { display: none; }

.km-proto-hero__content .km-lead {
  max-width: 52ch;
  font-size: 1.02rem;
  line-height: 1.78;
  margin-bottom: 0.25rem;
}

.km-proto-hero__content .km-actions {
  margin-top: 1.25rem;
  margin-bottom: 0.9rem;
  gap: 14px;
}

.km-proto-hero__meta {
  margin-top: 1.2rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(180, 86, 255,0.2);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.km-proto-hero__meta-item {
  display: grid;
  gap: 4px;
}

.km-proto-hero__meta-item strong {
  color: var(--km-text);
  font-size: 0.96rem;
  font-weight: 600;
}

.km-proto-hero__meta-item span {
  color: var(--km-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}

.km-section-heading--center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.km-proto-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.km-proto-logos span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0.55rem 1rem;
  border-radius: 999px;
  background: rgba(42, 36, 80, 0.9);
  border: 1px solid rgba(180, 86, 255,0.2);
  color: var(--km-muted);
  font-size: 0.82rem;
  letter-spacing: 0.03em;
}

.km-proto-grid {
  display: grid;
  gap: 16px;
}

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

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

.km-proto-card {
  border: 1px solid rgba(180, 86, 255,0.14);
  border-radius: 18px;
  background: rgba(42, 36, 80, 0.86);
  box-shadow: 0 14px 36px rgba(5, 3, 16, 0.32);
  padding: 1.2rem;
}

.km-proto-card span {
  display: inline-block;
  margin-bottom: 0.45rem;
  font-family: var(--km-display);
  font-size: 1.45rem;
  color: rgba(180, 86, 255,0.55);
}

.km-proto-card h3 {
  margin-bottom: 0.45rem;
}

.km-proto-card p {
  margin: 0;
}

.km-audience-section {
  position: relative;
}

.km-audience-section .km-shell {
  position: relative;
}

.km-audience-section__layout {
  display: grid;
  grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
  gap: clamp(1.2rem, 3vw, 2.8rem);
  align-items: start;
}

.km-audience-section__heading {
  display: grid;
  gap: 0.8rem;
  margin-bottom: 0;
  max-width: 18rem;
}

.km-audience-section__heading h2 {
  max-width: 10ch;
  line-height: 1.06;
}

.km-audience-section__list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: audience-item;
  border-top: 1px solid rgba(180, 86, 255,0.14);
  border-left: 1px solid rgba(180, 86, 255,0.14);
}

.km-audience-item {
  counter-increment: audience-item;
  position: relative;
  min-width: 0;
  padding: 1.35rem 1.35rem 1.35rem 3.4rem;
  border-right: 1px solid rgba(180, 86, 255,0.14);
  border-bottom: 1px solid rgba(180, 86, 255,0.14);
}

.km-audience-item::before {
  content: counter(audience-item, decimal-leading-zero);
  position: absolute;
  top: 1.3rem;
  left: 1.35rem;
  color: rgba(180, 86, 255,0.72);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.16em;
}

.km-audience-item p {
  margin: 0;
  color: rgba(245, 243, 255, 0.88);
  font-size: 0.98rem;
  line-height: 1.8;
  max-width: 32ch;
}

.km-page-hero.km-proto-band {
  padding-top: 5.2rem;
  padding-bottom: 2.1rem;
}

.km-page-content.km-proto-band {
  padding-top: 2.2rem;
}

.km-contact-layout--proto .km-contact-form-wrap {
  height: 100%;
}

.km-about-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(260px, 0.7fr);
  gap: 28px;
  align-items: center;
}

.km-about-hero__content {
  display: grid;
  gap: 0.9rem;
}

.km-about-hero__content h1 {
  max-width: 14ch;
}

.km-about-hero__content .km-lead {
  max-width: 58ch;
}

.km-about-hero__visual {
  display: grid;
  justify-items: end;
}

.km-about-photo-slot {
  width: min(100%, 320px);
}

.km-about-photo-slot .km-km-photo-slot__image-wrap {
  min-height: 420px;
}

.km-about-story {
  display: grid;
  gap: 1.6rem;
}

.km-about-story__intro {
  display: grid;
  gap: 0.7rem;
  max-width: 760px;
}

.km-about-story__intro .km-eyebrow,
.km-about-story__intro h2,
.km-about-story__intro p {
  margin: 0;
}

.km-about-story__intro h2 {
  max-width: 18ch;
}

.km-about-story__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(280px, 0.7fr);
  gap: 1.2rem;
}

.km-about-story__panel,
.km-about-note,
.km-contact-form-intro,
.km-contact-side-note {
  display: grid;
  gap: 0.9rem;
}

.km-about-story__panel p,
.km-about-note p,
.km-contact-form-intro p,
.km-contact-side-note p {
  margin: 0;
}

.km-about-note__list,
.km-contact-checklist {
  display: grid;
  gap: 0.85rem;
}

.km-about-note__list li,
.km-contact-checklist li {
  position: relative;
  padding-left: 1.25rem;
  color: var(--km-text-soft);
}

.km-about-note__list li::before,
.km-contact-checklist li::before {
  content: "";
  position: absolute;
  top: 0.72rem;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--km-accent);
  box-shadow: 0 0 0 6px rgba(248, 224, 171, 0.08);
}

.km-contact-hero {
  display: grid;
  gap: 0.85rem;
}

.km-contact-hero h1 {
  max-width: 14ch;
}

.km-contact-hero .km-lead {
  max-width: 62ch;
}

.km-contact-form-column {
  display: grid;
  gap: 1rem;
}

.km-contact-form-intro {
  padding: 1.45rem;
}

.km-contact-form-intro .km-eyebrow,
.km-contact-form-intro h3,
.km-contact-form-intro p {
  margin: 0;
}

.km-contact-side-note {
  height: 100%;
  min-height: 100%;
}

@media (max-width: 980px) {
  .km-proto-band {
    padding: 3.4rem 0;
  }

  .km-proto-hero__grid,
  .km-proto-grid--three,
  .km-proto-grid--two {
    grid-template-columns: 1fr;
  }

  .km-about-hero,
  .km-about-story__grid {
    grid-template-columns: 1fr;
  }

  .km-about-hero__visual {
    justify-items: start;
  }

  .km-proto-hero {
    padding-top: 3.1rem;
  }

  .home .km-proto-hero {
    padding-top: 1.2rem;
  }

  .km-proto-hero__content h1 {
    max-width: none;
    font-size: clamp(2rem, 8.2vw, 3.35rem);
  }

  .km-proto-hero__meta {
    grid-template-columns: 1fr;
  }
}

/* Global heading spacing pass: wider and less line breaks */
.km-shell {
  width: min(calc(100% - 28px), 1240px);
}

h1,
h2 {
  letter-spacing: -0.015em;
  text-wrap: normal;
}

.km-proto-hero__content h1,
.km-hero__content h1,
.km-page-hero--default h1,
.km-page-content .km-page-builder > .km-section:first-child h2,
.km-section-heading h2,
.km-dashboard-hero__intro h2,
.km-board-summary-card__header h2 {
  max-width: none;
}

.km-proto-hero__content h1,
.km-page-hero--default h1 {
  line-height: 1.08;
}

.km-proto-hero__content h1 {
  font-size: clamp(1.9rem, 3.6vw, 2.85rem);
  max-width: 24ch;
}

.km-proto-hero__content .km-lead,
.km-lead {
  max-width: 74ch;
}

.km-proto-band {
  padding: 5.1rem 0;
}

.km-page-hero.km-proto-band {
  padding-top: 5.8rem;
  padding-bottom: 2.6rem;
}

@media (max-width: 980px) {
  .km-shell {
    width: min(calc(100% - 22px), 1240px);
  }

  .km-proto-band {
    padding: 3.4rem 0;
  }

  .km-audience-section__heading {
    max-width: 34rem;
  }

  .km-audience-section__heading h2 {
    max-width: none;
  }

  .km-audience-section__layout {
    grid-template-columns: 1fr;
    gap: 1.6rem;
  }

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

  .km-proto-hero__content h1,
  .km-page-hero--default h1 {
    line-height: 1.1;
  }

  .km-proto-hero__content h1 {
    max-width: none;
    font-size: clamp(1.7rem, 6.8vw, 2.3rem);
  }
}

/* Landing specific refinements requested */
.km-proto-hero .km-hero-points {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.78rem;
  margin: 1.1rem 0 0;
  padding: 0;
  max-width: 42rem;
  list-style: none;
}

.km-proto-hero .km-hero-point {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 0;
  margin: 0;
  padding: 0.9rem 1rem 0.9rem 1.7rem;
  border: 1px solid rgba(180, 86, 255,0.14);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.025);
  color: rgba(245, 243, 255, 0.92);
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.45;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.km-proto-hero .km-hero-point::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 1rem;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: rgba(180, 86, 255,0.92);
  box-shadow: 0 0 0 4px rgba(180, 86, 255,0.12);
  transform: translateY(-50%);
}

.km-site-nav a.km-site-nav__link--portal-featured,
.km-site-nav__item > a.km-site-nav__link--portal-featured {
  min-height: 46px;
  padding: 0.72rem 1.12rem;
  border-radius: var(--km-public-radius);
  border-color: transparent;
  background: var(--km-button-primary-bg);
  color: var(--km-button-primary-color);
  box-shadow: var(--km-button-primary-shadow);
}

.km-site-nav a.km-site-nav__link--portal-featured:hover,
.km-site-nav a.km-site-nav__link--portal-featured:focus-visible,
.km-site-nav__item:hover > a.km-site-nav__link--portal-featured,
.km-site-nav__item:focus-within > a.km-site-nav__link--portal-featured {
  border-color: transparent;
  background: var(--km-button-primary-hover-bg);
  color: var(--km-button-primary-color);
  box-shadow: var(--km-button-primary-shadow-hover);
}

.km-proto-logos--compact {
  justify-content: flex-start;
  gap: 0.55rem 0.7rem;
}

.km-proto-logos--compact span {
  min-height: 34px;
  padding: 0.42rem 0.78rem;
  border-color: rgba(180, 86, 255,0.16);
  background: rgba(42, 36, 80, 0.68);
  color: rgba(245, 243, 255, 0.8);
  font-size: 0.76rem;
  letter-spacing: 0.05em;
}

.km-proposal-section {
  position: relative;
}

.km-proposal-section__frame {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: clamp(1.5rem, 3.2vw, 3rem);
  padding: clamp(1.4rem, 3vw, 2rem);
  border-top: 1px solid rgba(180, 86, 255,0.16);
  border-bottom: 1px solid rgba(180, 86, 255,0.16);
  background: transparent;
}

.km-proposal-section__frame::before {
  display: none;
}

.km-proposal-section__heading {
  position: relative;
  z-index: 1;
  align-self: start;
  max-width: 34rem;
  margin-bottom: 0;
}

.km-proposal-section__heading h2 {
  max-width: 16ch;
}

.km-proposal-section__body {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
  align-content: start;
}

.km-proposal-section__text {
  margin: 0;
  padding-left: 1rem;
  border-left: 1px solid rgba(180, 86, 255,0.18);
}

.km-proposal-section__text::before {
  display: none;
}

.km-proposal-section__text p {
  margin: 0;
  max-width: 34rem;
  color: rgba(245, 243, 255, 0.84);
  font-size: 0.99rem;
  line-height: 1.8;
}

.km-proposal-section__text:first-child p {
  color: rgba(245, 243, 255, 0.92);
}

.km-home-clients .km-shell {
  display: grid;
  gap: 2rem;
}

.km-home-clients__heading {
  display: grid;
  justify-items: center;
  gap: 0.8rem;
  max-width: 42rem;
  margin: 0 auto;
}

.km-home-clients__heading .km-eyebrow,
.km-home-clients__heading h2,
.km-home-clients__heading p {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.km-home-clients__heading p {
  max-width: 34rem;
  margin-bottom: 0;
}

.km-home-clients .km-proto-logos--compact {
  justify-content: center;
  gap: 0.95rem 1rem;
  max-width: 52rem;
  margin: 0 auto;
}

.km-home-clients .km-proto-logos--compact span {
  min-height: 40px;
  padding: 0.62rem 1.05rem;
  border-color: rgba(180, 86, 255,0.18);
  background: rgba(255, 255, 255, 0.02);
  color: rgba(245, 243, 255, 0.88);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.025);
}

.km-plans-compare--home {
  gap: 18px;
  padding-top: 0.9rem;
}

.km-plans-compare--home .km-plan-compare-card {
  gap: 0.9rem;
  padding: 1.35rem;
}

.km-plans-compare--home .km-plan-compare-card.is-featured {
  padding-top: 1.35rem;
  transform: translateY(-10px) scale(1.02);
}

.km-plans-compare--home .km-plan-compare-card__tag {
  top: 0;
  transform: translate(-50%, -50%);
}

.km-plans-compare--home .km-plan-compare-card__description {
  min-height: 0;
  font-size: 0.92rem;
  line-height: 1.6;
}

.km-plans-compare--home .km-plan-compare-card__footer {
  gap: 0.75rem;
}

.km-plans-compare--home .km-plan-compare-card__footer .km-button {
  width: 100%;
}

@media (max-width: 720px) {
  .km-proto-hero .km-hero-points {
    grid-template-columns: 1fr;
    max-width: none;
  }

  .km-audience-section__list {
    grid-template-columns: 1fr;
  }

  .km-audience-section__heading {
    max-width: none;
  }

  .km-audience-item {
    padding: 1.25rem 1rem 1.25rem 3rem;
  }

  .km-audience-item::before {
    left: 1rem;
  }

  .km-proposal-section__frame {
    padding: 1.2rem 0;
  }

  .km-proposal-section__text {
    padding-left: 0.9rem;
  }

  .km-proposal-section__body {
    grid-template-columns: 1fr;
  }

  .km-home-clients .km-shell {
    gap: 1.5rem;
  }

  .km-home-clients .km-proto-logos--compact {
    gap: 0.7rem 0.75rem;
  }

  .km-home-clients .km-proto-logos--compact span {
    min-height: 38px;
    padding: 0.55rem 0.9rem;
    font-size: 0.74rem;
  }
}

.km-section-heading .km-eyebrow {
  text-align: left;
  justify-content: flex-start;
}

.km-section-heading h2,
.km-section-heading p {
  text-align: left;
  margin-left: 0;
  margin-right: 0;
}

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

.km-client-card {
  border: 1px solid rgba(180, 86, 255,0.16);
  border-radius: 16px;
  background: rgba(42, 36, 80, 0.8);
  padding: 1rem 1rem 1.05rem;
  display: grid;
  gap: 6px;
}

.km-client-card strong {
  color: var(--km-text);
  font-family: var(--km-display);
  font-size: 1.08rem;
  font-weight: 400;
}

.km-client-card span {
  color: var(--km-muted);
  font-size: 0.86rem;
  line-height: 1.5;
}

@media (max-width: 980px) {
  .km-proposal-section__frame {
    grid-template-columns: 1fr;
    gap: 1.6rem;
  }

  .km-proposal-section__body {
    grid-template-columns: 1fr;
  }

  .km-proposal-section__heading h2,
  .km-proposal-section__text p {
    max-width: none;
  }

  .km-clients-grid {
    grid-template-columns: 1fr;
  }
}

/* Shared hover feedback for button families without color-state changes. */
.km-button,
.km-filter-dropdown__trigger,
.km-daily-planner__add-column,
.km-daily-column__drag,
.km-daily-column__menu-trigger,
.km-admin-account-card {
  transition:
    background 0.18s ease,
    background-color 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.18s ease;
}

.km-button--primary:hover,
.km-button--primary:focus-visible {
  background: var(--km-button-primary-bg-hover);
  box-shadow: var(--km-button-primary-shadow-hover);
}

.km-button--secondary:hover,
.km-button--secondary:focus-visible {
  background: rgba(180, 86, 255,0.18);
  border-color: rgba(180, 86, 255,0.4);
  color: var(--km-text);
}

.km-button--ghost:hover,
.km-button--ghost:focus-visible {
  background: rgba(245, 243, 255, 0.08);
  border-color: rgba(245, 243, 255, 0.3);
  color: #fff7ef;
}

.km-button--danger:hover,
.km-button--danger:focus-visible {
  background: rgba(239, 71, 111, 0.22);
  border-color: rgba(239, 71, 111, 0.36);
  color: #ffd4de;
}

.km-button--success:hover,
.km-button--success:focus-visible {
  background: #2dc86c;
  box-shadow: 0 14px 32px rgba(34, 197, 94, 0.28);
}

.km-filter-dropdown__trigger:hover,
.km-filter-dropdown__trigger:focus-visible {
  background: rgba(248, 224, 171, 0.08);
  border-color: rgba(248, 224, 171, 0.18);
  color: #fff7ef;
}

.km-filter-dropdown__trigger:hover::after,
.km-filter-dropdown__trigger:focus-visible::after {
  color: #fff7ef;
}

.km-daily-planner__add-column:hover,
.km-daily-planner__add-column:focus-visible {
  background: linear-gradient(135deg, #df69e7 0%, #c168ff 100%);
  box-shadow: 0 12px 28px rgba(180, 86, 255,0.3);
}

.km-daily-column__drag:hover,
.km-daily-column__drag:focus-visible,
.km-daily-column__menu-trigger:hover,
.km-daily-column__menu-trigger:focus-visible {
  background: rgba(180, 86, 255,0.12);
  border-color: rgba(180, 86, 255,0.32);
  color: #fff7ef;
}

.km-admin-account-card:hover,
.km-admin-account-card:focus-visible {
  background: rgba(180, 86, 255,0.1);
  border-color: rgba(180, 86, 255,0.24);
}

.km-admin-account-card:hover .km-client-admin-card__action,
.km-admin-account-card:focus-visible .km-client-admin-card__action {
  color: #fff7ef;
}

.km-meetings-layout {
  display: grid;
  grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

.km-meeting-detail-stack {
  display: grid;
  gap: 20px;
}

.km-meeting-detail-topbar {
  display: flex;
  justify-content: flex-start;
}

.km-meeting-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 1rem;
}

.km-meeting-section-head h3,
.km-meeting-section-head p {
  margin: 0;
}

.km-meeting-section-head > div {
  display: grid;
  gap: 0.28rem;
}

.km-meeting-list {
  display: grid;
  gap: 14px;
}

.km-meeting-card {
  display: grid;
  gap: 14px;
  padding: 1.15rem 1.2rem;
  border-radius: 22px;
  border: 1px solid rgba(240, 238, 230, 0.08);
  background: rgba(240, 238, 230, 0.03);
  color: var(--km-text);
  text-decoration: none;
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.km-meeting-card:hover,
.km-meeting-card:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(180, 86, 255,0.24);
  background: rgba(240, 238, 230, 0.05);
}

.km-meeting-card__head,
.km-meeting-detail-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.km-meeting-card__head h4,
.km-meeting-detail-card__head h2 {
  margin: 0;
}

.km-meeting-card__head > div:first-child,
.km-meeting-detail-card__head > div:first-child {
  display: grid;
  gap: 0.35rem;
}

.km-meeting-card__eyebrow {
  margin: 0;
  color: var(--km-muted);
  font-size: 0.8rem;
}

.km-meeting-card__badges,
.km-meeting-detail-card__badges {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.km-meeting-card__meta-grid,
.km-meeting-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.km-meeting-card__meta-grid > div,
.km-meeting-summary-item {
  display: grid;
  gap: 0.28rem;
  padding: 0.85rem 0.95rem;
  border-radius: 18px;
  border: 1px solid rgba(240, 238, 230, 0.06);
  background: rgba(240, 238, 230, 0.03);
}

.km-meeting-card__meta-grid span,
.km-meeting-summary-item span {
  color: var(--km-muted);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.km-meeting-card__meta-grid strong,
.km-meeting-summary-item strong {
  color: var(--km-text);
  font-size: 0.96rem;
  line-height: 1.3;
}

.km-meeting-card__reason {
  margin: 0;
  color: var(--km-muted);
  font-size: 0.9rem;
}

.km-meeting-detail-card,
.km-meeting-empty-state,
.km-meeting-empty-notes,
.km-meeting-reason,
.km-meeting-response-pending {
  display: grid;
  gap: 0.9rem;
}

.km-meeting-reason,
.km-meeting-response-pending,
.km-meeting-empty-state,
.km-meeting-empty-notes {
  padding: 1rem 1.05rem;
  border-radius: 18px;
  border: 1px solid rgba(240, 238, 230, 0.08);
  background: rgba(240, 238, 230, 0.03);
}

.km-meeting-reason h3,
.km-meeting-response-pending p,
.km-meeting-empty-state h4,
.km-meeting-empty-state p,
.km-meeting-empty-notes p {
  margin: 0;
}

.km-meeting-decision-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.km-meeting-history {
  display: grid;
  gap: 12px;
}

.km-meeting-history__item {
  display: grid;
  gap: 0.2rem;
  padding: 0.95rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(240, 238, 230, 0.08);
  background: rgba(240, 238, 230, 0.03);
}

.km-meeting-history__item strong,
.km-meeting-history__item p,
.km-meeting-history__item span {
  margin: 0;
}

.km-meeting-history__item p {
  color: var(--km-text);
}

.km-meeting-history__item span {
  color: var(--km-muted);
  font-size: 0.84rem;
}

.km-badge.is-requested {
  background: rgba(248, 224, 171, 0.12);
  color: var(--km-accent);
}

.km-badge.is-rescheduled {
  background: rgba(180, 86, 255,0.14);
  color: #c4b5fd;
}

.km-badge.is-cancelled,
.km-badge.is-past {
  background: rgba(148, 163, 184, 0.14);
  color: #d7e1ec;
}

.km-meeting-detail-card__reschedule-row {
  display: flex;
  justify-content: flex-end;
  padding-top: 0.25rem;
}

.km-meeting-reason--reschedule {
  border-color: rgba(180, 86, 255,0.18);
}

.km-meeting-reason__by {
  font-size: 0.82rem;
  color: var(--km-muted);
}

.km-meeting-history__item--reschedule {
  border-color: rgba(180, 86, 255,0.18);
}

.km-meeting-history__reschedule-dates {
  color: var(--km-muted);
  font-size: 0.88rem;
}

.km-meeting-history__reschedule-reason {
  color: var(--km-muted);
  font-size: 0.88rem;
  font-style: italic;
}

.km-meeting-reschedule-form {
  display: grid;
  gap: 1.2rem;
  margin-top: 1.4rem;
}

.km-meeting-reschedule-form__actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}

.km-meeting-reject-options {
  display: grid;
  gap: 1rem;
  margin-top: 1.4rem;
}

.km-modal__dialog--narrow {
  width: min(100%, 560px);
}

@media (max-width: 1024px) {
  .km-meetings-layout,
  .km-meeting-decision-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 680px) {
  .km-meeting-card__head,
  .km-meeting-detail-card__head {
    flex-direction: column;
  }

  .km-meeting-card__meta-grid,
  .km-meeting-summary-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .km-meeting-reschedule-form__actions {
    flex-direction: column-reverse;
  }
}


/* ==========================================================================
   INICIO + PLANOS — Visual Refactor
   Layout, composition, and motion system matching the design references.
   All values use km-tokens.css custom properties.
   ========================================================================== */


/* ── ENTRANCE ANIMATION ───────────────────────────────────────────────────── */

@keyframes km-fade-up {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.km-anim-fade-up {
  opacity: 0;
  animation: km-fade-up 0.8s ease forwards var(--km-delay, 0s);
}


/* ── HERO CENTERED (Início) ──────────────────────────────────────────────── */

.km-hero-centered {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--km-space-12) var(--km-page-gutter);
  overflow: hidden;
  background: var(--km-bg);
  border-bottom: 1px solid var(--km-border-soft);
}

.km-hero-glow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%);
  width: 600px;
  height: 600px;
  background: radial-gradient(ellipse, rgba(180, 86, 255, 0.18) 0%, transparent 65%);
  pointer-events: none;
}

.km-hero-centered__shell {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.km-hero-centered .km-eyebrow {
  margin-bottom: var(--km-space-5);
}

.km-hero-centered h1 {
  max-width: 16ch;
  font-size: clamp(2.5rem, 6.5vw, 5.125rem);
  font-weight: 500;
  line-height: 1.06;
  letter-spacing: -0.04em;
  margin-bottom: var(--km-space-6);
}

.km-hero-centered__lead {
  font-size: 0.94rem;
  max-width: 42ch;
  text-align: center;
  margin: 0 auto var(--km-space-9);
  line-height: var(--km-line-height-copy);
  color: var(--km-text-muted);
}

.km-hero-centered .km-actions--center {
  margin-top: 0;
}

/* Scroll indicator */

.km-scroll-indicator {
  position: absolute;
  bottom: var(--km-space-9);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--km-space-3);
  z-index: 1;
}

.km-scroll-indicator span {
  font-size: 0.56rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--km-color-ink-700);
}

.km-scroll-line {
  width: 1px;
  height: 44px;
  background: linear-gradient(to bottom, var(--km-color-brand-500), transparent);
  animation: km-scroll-pulse 2.2s ease-in-out infinite;
}

@keyframes km-scroll-pulse {
  0%, 100% { opacity: 0.2; transform: scaleY(0.8) translateY(-4px); }
  50%       { opacity: 1;   transform: scaleY(1)   translateY(4px);  }
}


/* ── PARA QUEM É GRID ────────────────────────────────────────────────────── */

.km-pq-section {
  padding-top: var(--km-section-space);
  padding-bottom: var(--km-section-space);
}

.km-pq-section .km-eyebrow {
  display: block;
  margin-bottom: var(--km-space-5);
}

.km-pq-section__title {
  max-width: 20ch;
  margin-bottom: var(--km-space-9);
}

.km-pq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--km-border-soft);
}

.km-pq-item {
  background: var(--km-bg-elevated);
  padding: var(--km-space-8) var(--km-space-7);
  display: flex;
  gap: var(--km-space-5);
  align-items: flex-start;
  transition: background var(--km-transition-base);
}

.km-pq-item:hover {
  background: rgba(42, 36, 80, 0.95);
}

.km-pq-num {
  font-family: var(--km-font-display);
  font-size: 0.82rem;
  font-style: italic;
  color: var(--km-color-brand-500);
  opacity: 0.5;
  flex-shrink: 0;
  margin-top: 0.1rem;
  line-height: 1.8;
}

.km-pq-text {
  font-size: 0.84rem;
  color: var(--km-text-muted);
  line-height: 1.85;
  margin: 0;
}

.km-pq-text strong {
  display: block;
  color: var(--km-text);
  font-weight: 400;
  margin-bottom: var(--km-space-1);
}


/* ── FRASE DE IMPACTO ────────────────────────────────────────────────────── */

.km-frase-impacto {
  padding: var(--km-section-space) var(--km-page-gutter);
  border-top: 1px solid var(--km-border-soft);
  border-bottom: 1px solid var(--km-border-soft);
}

.km-frase-impacto__inner {
  text-align: center;
}

/* Override global blockquote border-left for centered impact quote */
.km-frase-impacto__quote {
  font-family: var(--km-font-display);
  font-size: clamp(1.5rem, 3.5vw, 3.25rem);
  font-weight: 400;
  font-style: italic;
  line-height: 1.22;
  letter-spacing: -0.02em;
  color: var(--km-text);
  max-width: 22ch;
  margin: 0 auto var(--km-space-6);
  border-left: none;
  padding-left: 0;
}

.km-frase-impacto__quote em {
  color: var(--km-color-accent-300);
}

.km-frase-autor {
  font-size: 0.62rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--km-color-ink-700);
  margin: 0;
}


/* ── NÚMEROS / STATS BAR ─────────────────────────────────────────────────── */

.km-numeros {
  padding: var(--km-space-11) var(--km-page-gutter);
}

.km-numeros-inner {
  display: flex;
  justify-content: center;
  max-width: 700px;
  margin: 0 auto;
}

.km-num-item {
  flex: 1;
  padding: var(--km-space-5) var(--km-space-7);
  text-align: center;
  border-right: 1px solid var(--km-border-soft);
}

.km-num-item:last-child {
  border-right: none;
}

.km-num-value {
  font-family: var(--km-font-display);
  font-size: clamp(2.5rem, 4vw, 3.25rem);
  font-weight: 400;
  font-style: italic;
  color: var(--km-color-accent-300);
  line-height: 1;
  margin-bottom: var(--km-space-2);
}

.km-num-label {
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--km-text-muted);
  margin: 0;
}


/* ── DIFERENCIAIS ────────────────────────────────────────────────────────── */

.km-dif-section {
  padding-top: var(--km-section-space);
  padding-bottom: var(--km-section-space);
}

.km-dif-section .km-eyebrow {
  display: block;
  margin-bottom: var(--km-space-5);
}

.km-dif-section__title {
  max-width: 20ch;
  margin-bottom: 0;
}

.km-dif-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--km-border-soft);
  margin-top: var(--km-space-9);
}

.km-dif-item {
  background: var(--km-bg);
  padding: clamp(1.8rem, 3vw, 2.75rem) clamp(1.5rem, 2.5vw, 2.25rem);
  transition: background var(--km-transition-base);
  position: relative;
  overflow: hidden;
}

.km-dif-item:hover {
  background: var(--km-bg-elevated);
}

.km-dif-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--km-color-brand-500), transparent);
  opacity: 0;
  transition: opacity var(--km-transition-base);
}

.km-dif-item:hover::before {
  opacity: 1;
}

.km-dif-title {
  font-family: var(--km-font-display);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: var(--km-space-3);
  color: var(--km-text);
}

.km-dif-text {
  font-size: 0.84rem;
  color: var(--km-text-muted);
  line-height: 1.85;
  margin: 0;
}


/* ── FEEDBACKS / TESTIMONIALS ────────────────────────────────────────────── */

.km-feedbacks-section {
  padding-top: var(--km-section-space);
  padding-bottom: var(--km-section-space);
}

.km-feedbacks-section .km-eyebrow {
  display: block;
  margin-bottom: var(--km-space-5);
}

.km-feedbacks-section__title {
  max-width: 20ch;
  margin-bottom: 0;
}

.km-feedback-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1px;
  background: var(--km-border-soft);
  margin-top: var(--km-space-9);
}

.km-feedback-item {
  background: var(--km-bg);
  padding: clamp(1.5rem, 2.5vw, 2.25rem) clamp(1.2rem, 2vw, 1.75rem);
  transition: background var(--km-transition-base);
}

.km-feedback-item:hover {
  background: var(--km-bg-elevated);
}

.km-feedback-stars {
  color: var(--km-color-accent-300);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  margin-bottom: var(--km-space-4);
}

.km-feedback-text {
  font-family: var(--km-font-display);
  font-size: 0.94rem;
  font-style: italic;
  font-weight: 400;
  color: var(--km-text);
  line-height: 1.8;
  margin-bottom: var(--km-space-5);
  opacity: 0.88;
}

.km-feedback-author strong {
  display: block;
  font-family: var(--km-font-ui);
  font-size: 0.84rem;
  font-weight: 400;
  color: var(--km-text);
  margin-bottom: var(--km-space-1);
}

.km-feedback-author span {
  font-size: 0.62rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--km-color-ink-700);
}


/* ── PLANOS PREVIEW (home strip) ─────────────────────────────────────────── */

.km-planos-preview-section {
  padding-top: var(--km-section-space);
  padding-bottom: var(--km-section-space);
  text-align: center;
}

.km-planos-preview-section .km-eyebrow {
  display: block;
  margin-bottom: var(--km-space-5);
}

.km-planos-preview-section__title {
  max-width: 22ch;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0;
}

/* Transform km-plans-compare into an editorial horizontal strip */
.km-planos-preview-section .km-plans-compare {
  display: flex;
  gap: 1px;
  background: var(--km-border-soft);
  border-radius: 0;
  max-width: var(--km-shell-narrow);
  margin: clamp(2rem, 4vw, 3.5rem) auto 0;
  text-align: left;
}

.km-planos-preview-section .km-plan-compare-card {
  flex: 1;
  min-width: 0;
  border-radius: 0;
  border: none;
  background: var(--km-bg);
  padding: clamp(1.5rem, 2.5vw, 2.25rem) clamp(1.2rem, 2vw, 1.75rem);
  gap: 0.8rem;
  box-shadow: none;
  transition: background var(--km-transition-base);
  position: relative;
  overflow: hidden;
  transform: none !important;
}

.km-planos-preview-section .km-plan-compare-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--km-color-brand-500), transparent);
  opacity: 0;
  transition: opacity var(--km-transition-base);
}

.km-planos-preview-section .km-plan-compare-card:hover {
  background: var(--km-bg-elevated);
}

.km-planos-preview-section .km-plan-compare-card:hover::before,
.km-planos-preview-section .km-plan-compare-card.is-featured::before {
  opacity: 1;
}

.km-planos-preview-section .km-plan-compare-card.is-featured {
  background: rgba(37, 31, 72, 0.98);
}

.km-planos-preview-section .km-plan-compare-card__tag {
  position: static;
  display: inline-block;
  transform: none;
  font-size: 0.56rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  border-radius: 0;
  background: transparent;
  color: var(--km-color-brand-500);
  border: 1px solid var(--km-border-brand);
  padding: var(--km-space-1) var(--km-space-2);
  margin-bottom: var(--km-space-2);
}

.km-planos-preview-section .km-plan-compare-card__eyebrow {
  font-size: 0.56rem;
  letter-spacing: 0.3em;
  color: var(--km-color-ink-700);
  margin-bottom: var(--km-space-2);
}

.km-planos-preview-section .km-plan-compare-card__header h3 {
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  margin-bottom: var(--km-space-2);
}

.km-planos-preview-section .km-plan-compare-card__description {
  font-size: 0.82rem;
  color: var(--km-text-muted);
  line-height: 1.75;
  min-height: 0;
  margin: 0;
}

.km-planos-preview-section .km-plan-compare-card__footer {
  margin-top: var(--km-space-5);
}

.km-planos-preview-section .km-plan-compare-card__footer .km-button {
  width: 100%;
}

.km-planos-link-wrap {
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
}

.km-planos-link {
  display: inline-block;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--km-text);
  border: 1px solid rgba(240, 238, 230, 0.15);
  padding: var(--km-space-4) var(--km-space-8);
  text-decoration: none;
  transition: border-color var(--km-transition-base), color var(--km-transition-base);
}

.km-planos-link:hover {
  border-color: var(--km-color-brand-500);
  color: var(--km-color-brand-500);
}


/* ── CTA FINAL CENTERED (Início) ─────────────────────────────────────────── */

.km-cta-final-centered {
  position: relative;
  text-align: center;
  overflow: hidden;
  padding: var(--km-section-space) var(--km-page-gutter);
}

.km-cta-final-glow {
  position: absolute;
  bottom: -80px;
  left: 50%;
  transform: translateX(-50%);
  width: 700px;
  height: 500px;
  background: radial-gradient(ellipse, rgba(180, 86, 255, 0.08) 0%, transparent 65%);
  pointer-events: none;
}

.km-cta-final-centered__inner {
  position: relative;
  z-index: 1;
}

.km-cta-final-centered .km-eyebrow {
  display: block;
  color: var(--km-color-ink-700);
  margin-bottom: var(--km-space-5);
}

.km-cta-final-centered h2 {
  max-width: 22ch;
  margin: 0 auto var(--km-space-4);
}

.km-cta-final-centered__sub {
  font-size: 0.88rem;
  color: var(--km-text-muted);
  line-height: var(--km-line-height-copy);
  max-width: 42ch;
  margin: 0 auto var(--km-space-9);
}

.km-cta-final-centered .km-actions--center {
  margin-top: 0;
}


/* ── PLANS PAGE — CENTERED HERO ──────────────────────────────────────────── */

.km-plans-hero {
  position: relative;
  padding: clamp(4.5rem, 7vw, 6rem) var(--km-page-gutter) clamp(2rem, 4vw, 3.5rem);
  text-align: center;
  overflow: hidden;
  background: var(--km-bg);
}

.km-plans-hero .km-hero-glow {
  top: -120px;
  transform: translateX(-50%);
  width: 800px;
  height: 600px;
  background: radial-gradient(ellipse, rgba(180, 86, 255, 0.10) 0%, transparent 65%);
}

.km-plans-hero__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.km-plans-hero .km-eyebrow {
  margin-bottom: var(--km-space-7);
}

.km-plans-hero h1 {
  max-width: 20ch;
  margin-bottom: var(--km-space-6);
}

.km-plans-hero__lead {
  font-size: 0.94rem;
  max-width: 48ch;
  text-align: center;
  margin: 0 auto;
  color: var(--km-text-muted);
}


/* ── PLANS PAGE — JOURNEY BREADCRUMB ─────────────────────────────────────── */

.km-plans-journey {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  row-gap: var(--km-space-2);
  padding: var(--km-space-5) var(--km-page-gutter) clamp(2rem, 4vw, 3.5rem);
  border-bottom: 1px solid var(--km-border-soft);
}

.km-j-step {
  font-size: 0.62rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--km-text-muted);
  padding: var(--km-space-2) var(--km-space-5);
  border: 1px solid transparent;
  white-space: nowrap;
  transition: color var(--km-transition-base), border-color var(--km-transition-base);
  cursor: default;
}

.km-j-step:hover {
  color: var(--km-text);
  border-color: var(--km-border-brand);
}

.km-j-arrow {
  color: var(--km-color-ink-700);
  font-size: 0.9rem;
  padding: 0 var(--km-space-1);
  flex-shrink: 0;
}


/* ── PLANS PAGE — PLANS GRID SECTION ─────────────────────────────────────── */

.km-plans-grid-section {
  padding-top: clamp(2.5rem, 4vw, 4rem);
  padding-bottom: clamp(2.5rem, 4vw, 4rem);
}

/* Make plans-page compare cards match the reference bordered card grid */
.km-plans-compare--plans-page {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--km-border-soft);
  border-radius: 0;
}

.km-plans-compare--plans-page .km-plan-compare-card {
  border-radius: 0;
  border: none;
  background: var(--km-bg);
  padding: clamp(1.8rem, 3vw, 2.75rem) clamp(1.5rem, 2.5vw, 2.25rem);
  box-shadow: none;
  transition: background var(--km-transition-base);
  position: relative;
  overflow: hidden;
  transform: none !important;
}

.km-plans-compare--plans-page .km-plan-compare-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--km-color-brand-500), transparent);
  opacity: 0;
  transition: opacity var(--km-transition-base);
}

.km-plans-compare--plans-page .km-plan-compare-card:hover {
  background: var(--km-bg-elevated);
}

.km-plans-compare--plans-page .km-plan-compare-card:hover::before,
.km-plans-compare--plans-page .km-plan-compare-card.is-featured::before {
  opacity: 1;
}

.km-plans-compare--plans-page .km-plan-compare-card.is-featured {
  background: rgba(37, 31, 72, 0.98);
}

.km-plans-compare--plans-page .km-plan-compare-card__tag {
  position: static;
  display: inline-block;
  transform: none;
  margin-bottom: var(--km-space-3);
  font-size: 0.56rem;
  letter-spacing: 0.2em;
  border-radius: 0;
  background: var(--km-color-brand-500);
  color: #fff;
  padding: var(--km-space-1) var(--km-space-3);
}

.km-plans-compare--plans-page .km-plan-compare-card__header {
  gap: 0.6rem;
  margin-bottom: var(--km-space-5);
}

.km-plans-compare--plans-page .km-plan-compare-card__header h3 {
  font-size: clamp(1.3rem, 2vw, 1.75rem);
  line-height: 1.1;
}

.km-plans-compare--plans-page .km-plan-compare-card__eyebrow {
  font-size: 0.56rem;
  letter-spacing: 0.3em;
  color: var(--km-color-ink-700);
}

.km-plans-compare--plans-page .km-plan-compare-card__description {
  font-size: 0.82rem;
  line-height: 1.75;
  min-height: 0;
  margin-bottom: var(--km-space-6);
}

.km-plans-compare--plans-page .km-plan-compare-card__matrix {
  border-radius: 0;
  border-color: var(--km-border-soft);
  margin-bottom: var(--km-space-7);
}

.km-plans-compare--plans-page .km-plan-compare-card__row {
  padding: var(--km-space-3) var(--km-space-4);
  background: transparent;
  border-bottom-color: var(--km-border-soft);
}

.km-plans-compare--plans-page .km-plan-compare-card__row span {
  font-size: 0.8rem;
}

.km-plans-compare--plans-page .km-plan-compare-card__footer .km-button {
  width: 100%;
}


/* ── PLANS PAGE — BOTTOM CTA ─────────────────────────────────────────────── */

.km-plans-bottom-cta {
  position: relative;
  text-align: center;
  overflow: hidden;
  padding: clamp(4rem, 6vw, 6rem) var(--km-page-gutter);
}

.km-plans-bottom-glow {
  position: absolute;
  bottom: -60px;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(180, 86, 255, 0.07) 0%, transparent 70%);
  pointer-events: none;
}

.km-plans-bottom-cta__inner {
  position: relative;
  z-index: 1;
}

.km-plans-bottom-cta .km-eyebrow {
  display: block;
  color: var(--km-color-ink-700);
  margin-bottom: var(--km-space-5);
}

.km-plans-bottom-cta h2 {
  max-width: 20ch;
  margin: 0 auto var(--km-space-4);
}

.km-plans-bottom-cta__sub {
  font-size: 0.88rem;
  color: var(--km-text-muted);
  line-height: var(--km-line-height-copy);
  max-width: 42ch;
  margin: 0 auto var(--km-space-9);
}

.km-plans-bottom-cta .km-actions--center {
  margin-top: 0;
}


/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */

@media (max-width: 860px) {
  .km-pq-grid,
  .km-dif-grid {
    grid-template-columns: 1fr;
  }

  .km-feedback-grid {
    grid-template-columns: 1fr 1fr;
  }

  .km-numeros-inner {
    flex-direction: column;
  }

  .km-num-item {
    border-right: none;
    border-bottom: 1px solid var(--km-border-soft);
    padding: var(--km-space-5) var(--km-space-4);
  }

  .km-num-item:last-child {
    border-bottom: none;
  }

  .km-plans-compare--plans-page {
    grid-template-columns: 1fr;
  }

  .km-plans-journey {
    display: none;
  }

  .km-planos-preview-section .km-plans-compare {
    flex-direction: column;
  }
}

@media (max-width: 600px) {
  .km-feedback-grid {
    grid-template-columns: 1fr;
  }

  .km-hero-centered h1 {
    font-size: clamp(2rem, 10vw, 2.6rem);
  }
}


/* ==========================================================================
   QUEM SOU — Visual Refactor
   Layout, composition, and motion matching cereia-quem-sou.html reference.
   All values use km-tokens.css custom properties.
   ========================================================================== */


/* ── HERO ────────────────────────────────────────────────────────────────── */

.km-qs-hero {
  position: relative;
  text-align: center;
  padding: clamp(4.5rem, 8vw, 7rem) var(--km-page-gutter) var(--km-section-space);
  overflow: hidden;
  background: var(--km-bg);
  border-bottom: 1px solid var(--km-border-soft);
}

.km-qs-hero .km-hero-glow {
  top: 0;
  transform: translate(-50%, -35%);
  width: 600px;
  height: 400px;
}

.km-qs-hero__shell {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 780px;
  margin: 0 auto;
}

.km-qs-hero .km-eyebrow {
  margin-bottom: var(--km-space-6);
}

.km-qs-hero h1 {
  font-size: clamp(2.5rem, 6vw, 4.4rem);
  font-weight: 500;
  line-height: 1.06;
  letter-spacing: -0.04em;
  margin-bottom: var(--km-space-6);
  max-width: 18ch;
}

.km-qs-hero h1 em {
  font-family: var(--km-font-display);
  color: var(--km-color-accent-300);
  font-style: italic;
}

.km-qs-hero__sub {
  font-size: 0.94rem;
  color: var(--km-text-muted);
  line-height: var(--km-line-height-copy);
  max-width: 44ch;
  margin: 0 auto;
}


/* ── DIVIDER ─────────────────────────────────────────────────────────────── */

.km-qs-divider {
  padding: 0;
}

.km-qs-divider hr {
  border: none;
  border-top: 1px solid var(--km-border-soft);
  margin: 0;
}


/* ── MANIFESTO ───────────────────────────────────────────────────────────── */

.km-qs-manifesto {
  padding: var(--km-section-space) 0;
}

.km-qs-manifesto__inner {
  max-width: 780px;
  margin: 0 auto;
  padding: 0 var(--km-page-gutter);
}

.km-qs-manifesto .km-eyebrow {
  display: block;
  margin-bottom: var(--km-space-7);
}

.km-qs-manifesto p {
  font-size: var(--km-font-size-md);
  color: var(--km-text);
  line-height: 2;
  margin-bottom: var(--km-space-6);
  font-weight: 300;
}

.km-qs-manifesto p:last-child {
  margin-bottom: 0;
}

.km-qs-pull-quote {
  font-family: var(--km-font-display);
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  font-style: italic;
  font-weight: 400;
  color: var(--km-color-accent-300);
  line-height: 1.7;
  border-left: 2px solid rgba(248, 224, 171, 0.3);
  padding: var(--km-space-2) 0 var(--km-space-2) var(--km-space-8);
  margin: var(--km-space-11) 0;
}

.km-qs-pull-quote em {
  color: var(--km-color-accent-300);
}


/* ── KARINA: centered portrait ───────────────────────────────────────────── */

.km-qs-karina {
  padding: var(--km-section-space) 0;
}

.km-qs-karina__inner {
  max-width: 780px;
  margin: 0 auto;
  padding: 0 var(--km-page-gutter);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--km-space-9);
}

/* Circular photo with spinning orbit ring */
.km-qs-photo-wrap {
  position: relative;
  width: 200px;
  height: 200px;
  flex-shrink: 0;
}

.km-qs-photo-ring {
  position: absolute;
  inset: -10px;
  border-radius: 50%;
  border: 1px solid var(--km-border-strong);
  animation: km-qs-spin 18s linear infinite;
  pointer-events: none;
}

.km-qs-photo-ring::after {
  content: '';
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  border: 1px dashed rgba(180, 86, 255, 0.1);
}

@keyframes km-qs-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

.km-qs-photo-img {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  object-fit: cover;
  object-position: top center;
  display: block;
  position: relative;
  z-index: 1;
  filter: grayscale(10%) contrast(1.05);
  /* Gradient accent overlay via box-shadow trick */
  box-shadow:
    0 0 0 3px rgba(180, 86, 255, 0.18),
    0 18px 40px rgba(7, 5, 18, 0.32);
}

.km-qs-photo-placeholder {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--km-bg-elevated), var(--km-bg));
  border: 1px solid var(--km-border-strong);
  display: grid;
  place-items: center;
  position: relative;
  z-index: 1;
}

.km-qs-photo-placeholder strong {
  font-family: var(--km-font-display);
  font-size: 0.9rem;
  font-weight: 400;
  color: var(--km-text-muted);
}

.km-qs-karina__bio {
  max-width: 520px;
}

.km-qs-karina__name {
  font-family: var(--km-font-display);
  font-size: clamp(1.6rem, 3vw, 2.1rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: var(--km-space-2);
  color: var(--km-text);
}

.km-qs-karina__role {
  font-size: 0.625rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--km-color-brand-500);
  font-weight: 600;
  margin-bottom: var(--km-space-6);
}

.km-qs-karina__bio p {
  font-size: var(--km-font-size-sm);
  color: var(--km-text-muted);
  line-height: 1.95;
  margin-bottom: var(--km-space-4);
}

.km-qs-karina__bio p:last-child {
  margin-bottom: 0;
}


/* ── PROCESSO: horizontal timeline ──────────────────────────────────────── */

.km-qs-processo {
  padding: var(--km-section-space) 0;
  border-top: 1px solid var(--km-border-soft);
  border-bottom: 1px solid var(--km-border-soft);
  overflow: hidden;
}

.km-qs-processo__header {
  text-align: center;
  padding: 0 var(--km-page-gutter) var(--km-space-11);
  max-width: 600px;
  margin: 0 auto;
}

.km-qs-processo__header .km-eyebrow {
  display: block;
  margin-bottom: var(--km-space-5);
}

.km-qs-processo__header h2 {
  font-size: clamp(1.6rem, 3.5vw, 3rem);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin-bottom: var(--km-space-4);
}

.km-qs-processo__header h2 em {
  font-family: var(--km-font-display);
  color: var(--km-color-accent-300);
  font-style: italic;
}

.km-qs-processo__header p {
  font-size: var(--km-font-size-sm);
  color: var(--km-text-muted);
  line-height: 1.8;
  margin: 0;
}

/* Horizontal scroll timeline */
.km-qs-timeline {
  display: flex;
  gap: 0;
  padding: 0 var(--km-space-11);
  position: relative;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.km-qs-timeline::-webkit-scrollbar {
  display: none;
}

/* Connecting line */
.km-qs-timeline::before {
  content: '';
  position: absolute;
  top: 28px;
  left: calc(var(--km-space-11) + 28px);
  right: calc(var(--km-space-11) + 28px);
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    var(--km-border-strong),
    var(--km-color-brand-500),
    var(--km-border-strong),
    transparent
  );
  pointer-events: none;
}

.km-qs-tl-step {
  flex: 1;
  min-width: 180px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 var(--km-space-5);
}

.km-qs-tl-dot {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid var(--km-border-strong);
  background: var(--km-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--km-space-7);
  position: relative;
  z-index: 1;
  flex-shrink: 0;
  transition: border-color var(--km-transition-base), background var(--km-transition-base);
}

.km-qs-tl-dot:hover {
  border-color: var(--km-color-brand-500);
  background: var(--km-bg-elevated);
}

.km-qs-tl-dot span {
  font-family: var(--km-font-display);
  font-size: 0.875rem;
  font-style: italic;
  color: var(--km-color-brand-500);
  opacity: 0.8;
}

.km-qs-tl-title {
  font-family: var(--km-font-display);
  font-size: 1.05rem;
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: var(--km-space-3);
  color: var(--km-text);
}

.km-qs-tl-text {
  font-size: 0.75rem;
  color: var(--km-text-muted);
  line-height: 1.85;
  margin: 0;
}

.km-qs-tl-text em {
  font-style: italic;
  color: var(--km-text);
  opacity: 0.7;
}

/* Scroll hint (mobile only) */
.km-qs-timeline-hint {
  display: none;
  text-align: center;
  font-size: 0.625rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--km-color-ink-700);
  margin-top: var(--km-space-11);
}


/* ── VALORES ─────────────────────────────────────────────────────────────── */

.km-qs-valores {
  padding: var(--km-section-space) var(--km-page-gutter);
  text-align: center;
  background: var(--km-bg-elevated);
  border-top: 1px solid var(--km-border-soft);
  border-bottom: 1px solid var(--km-border-soft);
}

.km-qs-valores__inner {
  max-width: 960px;
  margin: 0 auto;
}

.km-qs-valores .km-eyebrow {
  display: block;
  margin-bottom: var(--km-space-6);
}

.km-qs-valores__title {
  font-size: clamp(1.5rem, 3vw, 2.75rem);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin-bottom: var(--km-space-11);
}

.km-qs-valores__title em {
  font-family: var(--km-font-display);
  color: var(--km-color-accent-300);
  font-style: italic;
}

.km-qs-valores-row {
  display: flex;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}

.km-qs-valor {
  padding: var(--km-space-8) var(--km-space-9);
  border-right: 1px solid var(--km-border-soft);
  text-align: left;
  flex: 1;
  min-width: 180px;
  transition: background var(--km-transition-base);
}

.km-qs-valor:last-child {
  border-right: none;
}

.km-qs-valor:hover {
  background: rgba(180, 86, 255, 0.04);
}

.km-qs-valor__word {
  font-family: var(--km-font-display);
  font-size: 1.35rem;
  font-style: italic;
  font-weight: 400;
  color: var(--km-color-accent-300);
  margin-bottom: var(--km-space-3);
}

.km-qs-valor__desc {
  font-size: 0.75rem;
  color: var(--km-text-muted);
  line-height: 1.85;
  margin: 0;
}


/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */

@media (max-width: 700px) {
  .km-qs-timeline {
    padding: 0 var(--km-page-gutter);
  }

  .km-qs-timeline::before {
    left: calc(var(--km-page-gutter) + 28px);
    right: calc(var(--km-page-gutter) + 28px);
  }

  .km-qs-timeline-hint {
    display: block;
  }

  .km-qs-tl-step {
    min-width: 160px;
  }

  .km-qs-valores-row {
    flex-direction: column;
  }

  .km-qs-valor {
    border-right: none;
    border-bottom: 1px solid var(--km-border-soft);
    padding: var(--km-space-6) 0;
  }

  .km-qs-valor:last-child {
    border-bottom: none;
  }
}
