* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

/* Client portal only: hide navigation items clients do not need */
body.portal-client-mode [data-client-hide] {
  display: none !important;
}

/* Prevent wrong portal navigation from flashing before admin/client role is ready */
body.portal-loading [data-nav-protected],
body.portal-loading [data-nav-login],
body:not(.portal-ready) [data-nav-protected],
body:not(.portal-ready) [data-nav-login] {
  visibility: hidden;
}

body:not(.portal-ready) .bottom-tab-bar {
  visibility: hidden;
}

body.portal-loading main {
  visibility: hidden;
}

body.portal-client-mode [data-admin-only],
body.portal-admin-mode [data-client-only] {
  display: none !important;
}

[hidden] {
  display: none !important;
}

body.portal-client-mode .composer-topline,
body.portal-client-mode .upload-button,
body.portal-client-mode #chat-upload,
body.portal-client-mode #file-status {
  display: none !important;
}

:root {
  --primary-color: #E8B4B8;
  --primary-hover: #d99aa0;
  --app-pink-soft: #fff4f6;
  --app-pink: #f5c7cc;
  --app-rose: #d97f8c;
  --app-ink: #253141;
  --app-muted: #687586;
  --app-card-border: rgba(232, 198, 202, 0.78);
  --app-shadow: 0 18px 42px rgba(125, 65, 75, 0.1);
}

body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(245, 199, 204, 0.42), transparent 28%),
    radial-gradient(circle at 90% 12%, rgba(255, 255, 255, 0.88), transparent 22%),
    linear-gradient(180deg, #fff9fa 0%, #f8eef1 52%, #fffdfd 100%);
  color: var(--app-ink);
}

.container {
  width: min(1120px, calc(100% - 2rem));
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(217, 226, 236, 0.9);
  padding: 1rem 0 1.1rem;
}

.site-header-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.9rem;
}

.site-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
}

.site-header h1 {
  margin: 0;
  font-size: 1.6rem;
  letter-spacing: -0.02em;
}

.header-brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.header-paw,
.header-logo-img {
  width: 1.65rem;
  height: 1.65rem;
  object-fit: contain;
  display: block;
  flex-shrink: 0;
}

.mobile-menu-button {
  display: none;
  width: 3rem;
  height: 3rem;
  padding: 0;
  border: 1px solid #ead4d7;
  border-radius: 16px;
  background: #ffffff;
  color: #7d4b52;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.28rem;
  transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.mobile-menu-button:hover {
  background: #fdf2f4;
  border-color: #e8c6ca;
  transform: translateY(-1px);
}

.mobile-menu-button span {
  display: block;
  width: 1.1rem;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.mobile-menu-button.is-open span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}

.mobile-menu-button.is-open span:nth-child(2) {
  opacity: 0;
}

.mobile-menu-button.is-open span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

.site-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body.portal-page .site-nav,
body.portal-page .mobile-menu-button {
  display: none !important;
}

body.client-agreement-lock .bottom-tab-bar,
body.client-agreement-lock .portal-sidebar,
body.client-agreement-lock .dashboard-sidebar {
  display: none !important;
}

.site-nav-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
}

.site-nav-group-label {
  display: none;
}

.site-nav a,
.site-nav .nav-disabled {
  color: #486581;
  text-decoration: none;
  padding: 0.6rem 0.9rem;
  border-radius: 999px;
  background: rgba(238, 242, 246, 0.92);
  border: 1px solid transparent;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.site-nav a:hover {
  background: #f6e7e9;
  border-color: #e8c6ca;
}

.site-nav a.active {
  background: var(--primary-color);
  color: #ffffff;
}

.site-nav .nav-disabled {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: #9aa6b2;
  cursor: not-allowed;
  background: rgba(246, 248, 250, 0.82);
  border-color: rgba(217, 226, 236, 0.85);
}

.nav-disabled small {
  display: inline-flex;
  align-items: center;
  min-height: 1.25rem;
  padding: 0.12rem 0.42rem;
  border-radius: 999px;
  background: #fff4f6;
  color: #b76d78;
  font-size: 0.68rem;
  font-weight: 850;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.site-nav-logout {
  display: none;
  width: 100%;
  border: 1px solid #ead4d7;
  border-radius: 16px;
  padding: 0.85rem 1rem;
  background: #ffffff;
  color: #7d4b52;
  font: inherit;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

.site-nav-logout:hover {
  background: #fdf2f4;
  border-color: #e8c6ca;
}

.panel {
  margin: 2rem 0 2.5rem;
  padding: 1.75rem;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(217, 226, 236, 0.95);
  border-radius: 24px;
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.06);
}

.panel h2 {
  margin-top: 0;
  margin-bottom: 0.55rem;
  font-size: clamp(1.8rem, 2.4vw, 2.2rem);
  letter-spacing: -0.03em;
}

.agreement-shell {
  width: min(960px, calc(100% - 2rem));
  margin: 2rem auto 3rem;
}

.agreement-card {
  padding: clamp(1.2rem, 4vw, 2rem);
  border: 1px solid rgba(232, 198, 202, 0.9);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 20px 52px rgba(125, 65, 75, 0.1);
}

.agreement-card-header {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: start;
  margin-bottom: 1.2rem;
}

.agreement-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 18px;
  background: #fff0f3;
  color: #9d5360;
  font-weight: 900;
  box-shadow: inset 0 0 0 1px rgba(232, 180, 184, 0.45);
}

.agreement-icon-logo img {
  width: 82%;
  height: 82%;
  object-fit: contain;
  display: block;
}

.agreement-card h2 {
  margin: 0.2rem 0 0.45rem;
  color: #243b53;
}

.agreement-card p {
  color: #637083;
}

.agreement-policy-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin: 1.4rem 0;
}

.agreement-policy-item {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.9rem;
  border: 1px solid rgba(217, 226, 236, 0.92);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255, 247, 248, 0.92), rgba(255, 255, 255, 0.92));
}

.agreement-policy-item span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 999px;
  background: #f8d9de;
  color: #7d414b;
  font-size: 0.68rem;
  font-weight: 900;
}

.agreement-policy-item h3 {
  margin: 0;
  color: #334e68;
  font-size: 0.95rem;
}

.agreement-form {
  display: grid;
  gap: 0.9rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(232, 198, 202, 0.68);
}

.agreement-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  padding: 0.9rem;
  border: 1px solid rgba(232, 198, 202, 0.86);
  border-radius: 18px;
  background: #fff8f9;
  color: #486581;
  font-weight: 750;
}

.agreement-checkbox input {
  width: 1.1rem;
  height: 1.1rem;
  margin-top: 0.12rem;
  accent-color: var(--primary-color);
  flex: 0 0 auto;
}

.agreement-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

.agreement-status-list {
  margin-top: 0.75rem;
}

.auth-shell {
  min-height: calc(100vh - 140px);
  display: grid;
  place-items: center;
  padding-block: 2rem 3rem;
}

.auth-card {
  width: min(100%, 460px);
  padding: 2rem;
  border: 1px solid rgba(217, 226, 236, 0.98);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 22px 48px rgba(15, 23, 42, 0.08);
}

.auth-intro {
  text-align: center;
  margin-bottom: 1.75rem;
}

.auth-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 5rem;
  height: 5rem;
  margin: 0 auto 1.1rem;
  border-radius: 50%;
  background: linear-gradient(160deg, #fce8eb 0%, #f0c5ca 55%, #e0a0a8 100%);
  border: 2px solid rgba(255, 255, 255, 0.6);
  color: #a84f5a;
  box-shadow:
    0 10px 28px rgba(184, 92, 106, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.75),
    inset 0 -2px 4px rgba(160, 70, 82, 0.12);
  position: relative;
  overflow: hidden;
}

/* Glossy top-highlight shine */
.auth-logo::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 14%;
  width: 70%;
  height: 42%;
  border-radius: 50%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.62) 0%, rgba(255, 255, 255, 0.04) 100%);
  pointer-events: none;
}

.auth-logo svg,
.auth-logo img {
  position: relative;
  width: 2.6rem;
  height: 2.6rem;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 1px 2px rgba(120, 40, 55, 0.18));
}

.auth-intro h2 {
  margin: 0 0 0.55rem;
  font-size: clamp(1.75rem, 4vw, 2.2rem);
  letter-spacing: -0.04em;
  line-height: 1.2;
}

.auth-intro p:last-child {
  margin: 0;
  color: #52606d;
  line-height: 1.6;
}

.auth-stack {
  display: grid;
  gap: 0.85rem;
}

.auth-provider-button,
.auth-email-button,
.auth-submit-button,
.auth-secondary-button,
.auth-reset-button {
  width: 100%;
  border-radius: 999px;
  padding: 0.95rem 1.1rem;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}

.auth-provider-button {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  justify-content: flex-start;
  border: 1px solid #ead4d7;
  background: #ffffff;
  color: #1f2933;
}

.auth-provider-button--primary {
  border-color: #e8c6ca;
  background: linear-gradient(180deg, #ffffff 0%, #fdf4f5 100%);
}

.auth-google-button {
  justify-content: center;
  gap: 0.75rem;
  padding: 1.05rem 1.25rem;
  background: linear-gradient(180deg, var(--primary-color) 0%, var(--primary-hover) 100%);
  border-color: var(--primary-hover);
  color: #ffffff;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: 0 8px 20px rgba(184, 92, 106, 0.22);
}

.auth-google-button:hover {
  filter: brightness(1.04);
  box-shadow: 0 12px 28px rgba(184, 92, 106, 0.3);
}

.auth-google-mark {
  background: rgba(255, 255, 255, 0.25);
  color: #ffffff;
  font-weight: 800;
}

.auth-provider-button--muted {
  opacity: 0.75;
  cursor: default;
}

.auth-provider-button:hover,
.auth-email-button:hover,
.auth-submit-button:hover,
.auth-secondary-button:hover,
.auth-reset-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
}

.auth-provider-button--muted:hover {
  transform: none;
  box-shadow: none;
}

.auth-provider-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 999px;
  background: #f8e8ea;
  color: #7d4b52;
  font-size: 0.95rem;
  font-weight: 700;
  flex-shrink: 0;
}

.auth-divider {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0.25rem 0;
}

.auth-divider::before {
  content: "";
  position: absolute;
  inset-inline: 0;
  top: 50%;
  border-top: 1px solid #eadcdf;
}

.auth-divider span {
  position: relative;
  padding: 0 0.85rem;
  background: rgba(255, 255, 255, 0.96);
  color: #7b8794;
  font-size: 0.92rem;
}

.auth-email-button {
  border: 1px solid #ead4d7;
  background: linear-gradient(180deg, #fff8f9 0%, #fbeef0 100%);
  color: #7d4b52;
}

.login-form {
  display: grid;
  gap: 1rem;
  margin-top: 1.25rem;
}

.login-form.is-hidden {
  display: none;
}

.auth-form-title {
  margin: 0 0 0.25rem;
  font-size: 1rem;
  font-weight: 700;
  color: #7d4b52;
}

.auth-form-copy {
  margin: -0.15rem 0 0.15rem;
  color: #52606d;
  line-height: 1.5;
  font-size: 0.95rem;
}

.auth-demo-note {
  display: grid;
  gap: 0.2rem;
  padding: 0.85rem 1rem;
  border: 1px solid #eedfe2;
  border-radius: 16px;
  background: linear-gradient(180deg, #fffafb 0%, #fbeff1 100%);
  color: #52606d;
  font-size: 0.9rem;
}

.auth-demo-note strong {
  color: #7d4b52;
}

.auth-demo-note code {
  padding: 0.1rem 0.35rem;
  border-radius: 8px;
  background: #f8e8ea;
  color: #7d4b52;
  font-family: monospace;
  font-size: 0.88em;
}

.auth-shell .site-nav a:last-child {
  background: #ffffff;
}

.auth-field-group {
  display: grid;
  gap: 0.4rem;
}

.auth-field-hint {
  margin: 0;
  color: #52606d;
  font-size: 0.84rem;
  line-height: 1.4;
}

.auth-action-block {
  display: grid;
  gap: 0.55rem;
  padding: 0.9rem 1rem;
  border: 1px solid #eedfe2;
  border-radius: 16px;
  background: linear-gradient(180deg, #fffafb 0%, #fbeff1 100%);
}

.auth-action-block .auth-form-title {
  margin: 0;
}

.auth-action-block .auth-form-copy {
  margin: 0;
  font-size: 0.88rem;
}

.auth-panel {
  display: grid;
  gap: 1.1rem;
}

.auth-panel-title {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 700;
  color: #243b53;
}

.auth-panel-copy {
  margin: -0.4rem 0 0;
  color: #52606d;
  font-size: 0.95rem;
  line-height: 1.55;
}

.auth-panel .login-form {
  margin-top: 0;
}

.auth-panel .auth-inline-link {
  justify-self: start;
  font-size: 0.9rem;
}

.auth-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  border: 0;
  background: transparent;
  color: var(--primary-hover);
  font: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  justify-self: start;
}

.auth-back-link:hover {
  text-decoration: underline;
}

.login-form label {
  display: grid;
  gap: 0.45rem;
  font-weight: 600;
  color: #243b53;
}

.login-form input {
  width: 100%;
  padding: 0.9rem 1rem;
  border: 1px solid #e4d5d8;
  border-radius: 16px;
  background: #ffffff;
  font: inherit;
}

.auth-password-hint {
  margin: -0.35rem 0 0;
  color: #52606d;
  font-size: 0.86rem;
  line-height: 1.45;
}

.auth-submit-button {
  border: 0;
  background: linear-gradient(180deg, var(--primary-color) 0%, var(--primary-hover) 100%);
  color: #ffffff;
}

.auth-secondary-button {
  border: 1px solid #e8c6ca;
  background: #ffffff;
  color: var(--primary-hover);
}

.auth-recovery-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.auth-reset-button {
  border: 1px solid #e8c6ca;
  background: #fff7f8;
  color: var(--primary-hover);
  font-weight: 700;
}

.error-message {
  min-height: 1.25rem;
  margin: 0;
  color: #c53030;
  font-size: 0.95rem;
}

.auth-status {
  margin-top: 1rem;
}

.auth-footnote {
  margin: 1.25rem 0 0;
  padding: 0.85rem 1rem;
  border-radius: 14px;
  background: linear-gradient(180deg, #fffafb 0%, #faf1f2 100%);
  border: 1px solid #eedfe2;
  color: #52606d;
  text-align: center;
  font-size: 0.88rem;
  line-height: 1.55;
}

.auth-browser-warning {
  display: grid;
  gap: 0.35rem;
  margin-top: 1rem;
  padding: 0.95rem 1rem;
  border: 1px solid #f1d2c0;
  border-radius: 18px;
  background: linear-gradient(180deg, #fff8f2 0%, #fff2ea 100%);
  color: #7c4a3b;
}

.auth-browser-warning strong {
  font-size: 0.95rem;
}

.auth-browser-warning p {
  margin: 0;
  line-height: 1.5;
  font-size: 0.92rem;
}

.auth-inline-link {
  border: 0;
  background: transparent;
  color: var(--primary-hover);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  padding: 0;
}

@media (max-width: 420px) {
  .auth-recovery-actions {
    grid-template-columns: 1fr;
  }
}

.portal-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem;
  margin-bottom: 1.25rem;
}

.portal-heading--compact {
  margin-bottom: 0.25rem;
}

.portal-kicker {
  margin: 0 0 0.5rem;
  color: var(--primary-hover);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.portal-heading p:not(.portal-kicker),
.panel > p:not(.portal-kicker),
.section-heading p,
.section-banner p {
  margin: 0;
  color: #52606d;
  line-height: 1.6;
}

.portal-overview {
  display: grid;
  gap: 1.4rem;
}

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

.client-summary-card {
  padding: 1rem 1.1rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: linear-gradient(180deg, #fffafb 0%, #fbeff1 100%);
}

.client-summary-block,
.summary-stat {
  display: grid;
  gap: 0.5rem;
  align-content: start;
}

.summary-stat {
  padding: 1.1rem 1.2rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: linear-gradient(180deg, #fff8f9 0%, #fbeef0 100%);
}

.client-summary-label,
.summary-stat-label {
  color: #486581;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.client-summary-block strong,
.summary-stat strong {
  font-size: 1.05rem;
  letter-spacing: -0.02em;
  line-height: 1.45;
}

.hero-strip {
  display: grid;
  grid-template-columns: 1.1fr 1.4fr;
  gap: 1rem;
}

.hero-stat {
  padding: 1.1rem 1.2rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: linear-gradient(180deg, #fff8f9 0%, #fbeef0 100%);
}

.hero-stat strong {
  display: block;
  font-size: 1.02rem;
  letter-spacing: -0.02em;
}

.hero-stat-label {
  display: block;
  margin-bottom: 0.4rem;
  color: #486581;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.section-stack {
  display: grid;
  gap: 1rem;
}

.section-heading h3 {
  margin: 0 0 0.35rem;
  font-size: 1.15rem;
  letter-spacing: -0.02em;
}

.section-banner {
  padding: 1rem 1.1rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: linear-gradient(180deg, #fffafb 0%, #fbeff1 100%);
}

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

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

.dashboard-grid {
  align-items: stretch;
}

.info-card {
  padding: 1.1rem 1.15rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0%, #fff8f9 100%);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04);
}

.info-card h3 {
  margin: 0 0 0.55rem;
  font-size: 1rem;
  letter-spacing: -0.02em;
}

.info-card p {
  margin: 0;
  color: #52606d;
  line-height: 1.5;
  white-space: pre-line;
}

.info-card--soft {
  background: linear-gradient(180deg, #fffafb 0%, #fbeef0 100%);
}

.card-topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.8rem;
  margin-bottom: 0.55rem;
}

.status-pill,
.timestamp-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}

.status-pill {
  background: #f8e3e5;
  color: #7d4b52;
}

.status-pill--soft {
  background: #eef2f6;
  color: #486581;
}

.timestamp-chip {
  background: #f1f5f9;
  color: #52606d;
}

.checklist-card {
  display: grid;
  gap: 1rem;
}

.detail-list {
  display: grid;
  gap: 0.85rem;
}

.detail-row {
  display: grid;
  gap: 0.18rem;
}

.detail-label {
  color: #486581;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.detail-row p {
  margin: 0;
}

body.portal-client-mode #dashboard-care-notes-card,
body.portal-client-mode #dashboard-checklist-section {
  display: none;
}

.checklist {
  display: grid;
  gap: 0.75rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.checklist li {
  position: relative;
  padding-left: 2rem;
  color: #243b53;
  line-height: 1.5;
}

.checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.2rem;
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 999px;
  border: 2px solid var(--primary-color);
  background: linear-gradient(180deg, #ffffff 0%, #fdf2f4 100%);
  box-shadow: inset 0 0 0 3px #ffffff;
}

.empty-state-card {
  margin-top: 1rem;
  padding: 1.4rem;
  border: 1px dashed #e4cfd3;
  border-radius: 20px;
  background: linear-gradient(180deg, #fffdfd 0%, #faf1f2 100%);
  text-align: left;
}

.empty-state-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 5.5rem;
  margin-bottom: 0.85rem;
  padding: 0.35rem 0.8rem;
  border-radius: 999px;
  background: #f8e3e5;
  color: #7d4b52;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.empty-state-card h3 {
  margin: 0 0 0.45rem;
  font-size: 1.08rem;
  letter-spacing: -0.02em;
}

.empty-state-card p {
  margin: 0;
  color: #52606d;
  line-height: 1.6;
}

.invoice-summary-card {
  margin-top: 1rem;
  padding: 1.35rem;
  border: 1px solid #eedfe2;
  border-radius: 22px;
  background: linear-gradient(180deg, #fffdfd 0%, #fbeff1 100%);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.invoice-summary-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.invoice-label,
.invoice-muted {
  color: #486581;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.invoice-summary-header h3 {
  margin: 0.25rem 0 0.35rem;
  font-size: 1.25rem;
  letter-spacing: -0.02em;
}

.invoice-summary-header p {
  margin: 0;
  color: #52606d;
  line-height: 1.5;
}

.invoice-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.42rem 0.8rem;
  border-radius: 999px;
  background: #f8e3e5;
  color: #7d4b52;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.invoice-service-box {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
  margin-bottom: 1rem;
}

.invoice-service-box > div {
  display: grid;
  gap: 0.35rem;
  padding: 0.95rem 1rem;
  border: 1px solid #eedfe2;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
}

.invoice-pets-card {
  display: grid;
  gap: 0.75rem;
  margin-bottom: 1rem;
  padding: 1rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
}

.invoice-row--heading {
  padding-bottom: 0.65rem;
  border-bottom: 1px solid #eedfe2;
  color: #1f2933;
  font-weight: 700;
}

.invoice-pet-list {
  display: grid;
  gap: 0.55rem;
}

.invoice-pet-list p {
  margin: 0;
  color: #52606d;
  line-height: 1.5;
}

.invoice-pet-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.65rem 0.75rem;
  border-radius: 14px;
  background: #fff8f9;
  color: #52606d;
}

.invoice-pet-item strong {
  color: #1f2933;
}

.admin-payment-section {
  display: grid;
  gap: 0.9rem;
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: #fffdfd;
}

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

.admin-payment-section-title {
  margin: 0;
  color: #7d4b52;
  font-size: 0.9rem;
  font-weight: 900;
}

.admin-billed-pet-grid {
  display: grid;
  gap: 0.7rem;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.admin-billed-pet-card {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 180px;
  padding: 0.8rem 0.9rem;
  border: 1px solid #e4d5d8;
  border-radius: 14px;
  background: #ffffff;
  color: #1f2933;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.admin-billed-pet-card input {
  width: 1.05rem;
  height: 1.05rem;
  accent-color: #b85c6a;
  flex: 0 0 auto;
}

.admin-billed-pet-card.is-selected {
  border-color: #d99aa0;
  background: #fff8f9;
  box-shadow: 0 8px 20px rgba(184, 92, 106, 0.12);
}

.admin-billed-pet-name {
  font-weight: 800;
}

.admin-invoice-items-list {
  display: grid;
  gap: 0.75rem;
}

.admin-invoice-item-row {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(120px, 0.55fr) auto;
  gap: 0.75rem;
  align-items: end;
}

.admin-invoice-item-remove {
  min-height: 2.4rem;
  border: 1px solid #ead4d7;
  border-radius: 12px;
  padding: 0.58rem 0.75rem;
  background: #fff8f9;
  color: #7d4b52;
  font: inherit;
  font-size: 0.86rem;
  font-weight: 800;
  cursor: pointer;
  align-self: end;
}

.admin-add-invoice-item-button {
  width: auto;
  justify-self: start;
  margin-top: 0;
  padding-inline: 1rem;
}

.admin-notes-visibility {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  color: #52606d;
  font-weight: 800;
}

.admin-notes-visibility input {
  width: 1rem;
  height: 1rem;
  accent-color: #b85c6a;
}

.client-update-composer,
.client-updates-timeline-section {
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
  padding: 1.1rem;
  border: 1px solid #eedfe2;
  border-radius: 22px;
  background: linear-gradient(180deg, #fffdfd 0%, #fff6f7 100%);
}

.client-update-composer[hidden] {
  display: none;
}

.client-update-composer-header,
.client-updates-timeline-header,
.client-update-meta,
.client-update-actions,
.client-update-quick-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.client-update-composer-header,
.client-updates-timeline-header {
  justify-content: space-between;
}

.client-update-composer-header h3,
.client-updates-timeline-header h3 {
  margin: 0.25rem 0 0;
  font-size: 1.08rem;
}

.client-update-form-grid {
  display: grid;
  gap: 0.8rem;
}

.client-update-quick-actions,
.client-update-actions {
  flex-wrap: wrap;
}

.client-update-actions .invoice-pay-button {
  width: auto;
  min-width: 180px;
  margin-top: 0;
}

.client-updates-filter-bar {
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) repeat(2, minmax(150px, 0.8fr));
  gap: 0.8rem;
  padding: 0.95rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
}

.client-updates-filter-bar .admin-field {
  min-width: 0;
}

.client-update-admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  padding-top: 0.2rem;
}

.client-update-admin-actions .admin-toolbar-button,
.client-update-admin-actions .admin-save-button {
  width: auto;
  margin-top: 0;
}

.admin-toolbar-button--danger {
  border-color: #f1c4ca;
  color: #9f3a48;
  background: #fff8f9;
}

.admin-toolbar-button--primary {
  background: linear-gradient(180deg, #e8b4b8 0%, #d49198 100%);
  color: #ffffff;
  border-color: #d49198;
  font-weight: 700;
}

.admin-toolbar-button--primary:hover {
  background: linear-gradient(180deg, #d99aa0 0%, #c88491 100%);
  border-color: #c88491;
}

.client-update-card--editing {
  background: #fffdfd;
}

.client-updates-timeline {
  display: grid;
  gap: 0.85rem;
}

.client-update-card {
  display: grid;
  gap: 0.65rem;
  padding: 1rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.04);
}

.client-update-meta {
  justify-content: space-between;
  align-items: flex-start;
  color: #52606d;
  font-size: 0.86rem;
}

.client-update-type {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  background: #f8e3e5;
  color: #7d4b52;
  font-size: 0.76rem;
  font-weight: 800;
}

.client-update-card h3 {
  margin: 0;
  font-size: 1.02rem;
}

.client-update-card p,
.client-updates-empty {
  margin: 0;
  color: #52606d;
  line-height: 1.55;
}

.invoice-breakdown {
  display: grid;
  gap: 0.65rem;
  padding: 1rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
}

.invoice-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  color: #52606d;
}

.invoice-row strong {
  color: #1f2933;
}

.invoice-row--total {
  margin-top: 0.35rem;
  padding-top: 0.75rem;
  border-top: 1px solid #eedfe2;
  color: #52606d;
  font-size: 1rem;
  font-weight: 700;
}

.invoice-row--total strong {
  color: #52606d;
  font-size: 1.08rem;
}

.invoice-row--discount strong {
  color: #2f855a;
}

.invoice-print-button {
  background: #ffffff;
  color: var(--primary-color);
  border: 1px solid #ead1d6;
}

.invoice-row--total + .invoice-row + .invoice-row {
  margin-top: 0.35rem;
  padding: 0.8rem 0.9rem;
  border-radius: 14px;
  background: #fff8f9;
  color: #1f2933;
  font-size: 1.08rem;
  font-weight: 800;
}

.invoice-row--total + .invoice-row + .invoice-row strong {
  color: #7d4b52;
  font-size: 1.22rem;
}

.invoice-note {
  margin-top: 1rem;
  padding: 0.9rem 1rem;
  border: 1px solid #f1d2c0;
  border-radius: 16px;
  background: #fff8f2;
  color: #7c4a3b;
  line-height: 1.5;
  font-size: 0.95rem;
}

.invoice-pay-button {
  width: 100%;
  margin-top: 1rem;
  border: 0;
  border-radius: 999px;
  padding: 0.95rem 1.2rem;
  background: linear-gradient(180deg, var(--primary-color) 0%, var(--primary-hover) 100%);
  color: #ffffff;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.invoice-pay-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
  filter: brightness(1.03);
}

.invoice-pay-button:disabled {
  cursor: not-allowed;
  opacity: 0.62;
  transform: none;
  box-shadow: none;
}

.invoice-payment-note--received {
  border-color: #ead1d6;
  background: #fff8f9;
  color: #7d4b52;
  font-weight: 700;
}

@media print {
  body.printing-invoice * {
    visibility: hidden !important;
  }

  body.printing-invoice #invoice-summary-card,
  body.printing-invoice #invoice-summary-card * {
    visibility: visible !important;
  }

  body.printing-invoice #invoice-summary-card {
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    max-width: none;
    margin: 0;
    box-shadow: none;
    border: 0;
  }

  body.printing-invoice .site-header,
  body.printing-invoice .admin-toolbar,
  body.printing-invoice .invoice-actions,
  body.printing-invoice #invoice-payment-note {
    display: none !important;
  }
}

.admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: -0.25rem 0 1.1rem;
  padding: 0.9rem 1rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: linear-gradient(180deg, #fffafb 0%, #fbeff1 100%);
}

.admin-booking-calendar {
  display: grid;
  gap: 1rem;
  margin: 1rem 0 1.25rem;
  padding: 1rem;
  border: 1px solid #eedfe2;
  border-radius: 22px;
  background: linear-gradient(180deg, #fffdfd 0%, #fff6f7 100%);
  box-shadow: 0 14px 32px rgba(15, 23, 42, 0.04);
}

.admin-booking-calendar-header,
.admin-booking-calendar-actions {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.admin-booking-calendar-header {
  justify-content: space-between;
}

.admin-booking-calendar-header h3 {
  margin: 0.2rem 0 0;
  font-size: 1.18rem;
}

.admin-booking-calendar--workspace .admin-booking-calendar-header {
  position: sticky;
  top: 0;
  z-index: 30;
  padding: 0.75rem 0;
  background: linear-gradient(180deg, #fffdfd 0%, rgba(255, 246, 247, 0.96) 100%);
}

.admin-booking-calendar-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.admin-booking-calendar-view-switcher {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  width: fit-content;
  padding: 0.28rem;
  border: 1px solid #eedfe2;
  border-radius: 999px;
  background: #ffffff;
}

.admin-calendar-view-tab {
  min-height: 2.2rem;
  padding: 0.4rem 0.8rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #6b4d55;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 850;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.admin-calendar-view-tab.is-active {
  background: var(--primary-color);
  color: #ffffff;
  box-shadow: 0 8px 18px rgba(125, 65, 75, 0.12);
}

.admin-booking-calendar--collapsed .admin-booking-calendar-body {
  display: none;
}

.admin-booking-calendar-body {
  display: grid;
  gap: 0.5rem;
  overflow-x: auto;
  padding-bottom: 0.2rem;
}

.admin-booking-calendar-weekdays,
.admin-booking-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(130px, 1fr));
  gap: 0.45rem;
  min-width: 920px;
}

.admin-booking-calendar-weekdays span {
  color: #7b8794;
  font-size: 0.78rem;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
}

.admin-booking-calendar-day {
  min-height: 116px;
  padding: 0.5rem;
  border: 1px solid #efe2e4;
  border-radius: 14px;
  background: #ffffff;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.admin-booking-calendar-day--muted {
  background: #fbf7f8;
  color: #9aa5b1;
}

.admin-booking-calendar-day--today {
  border-color: #d99aa0;
  box-shadow: inset 0 0 0 2px rgba(217, 154, 160, 0.18);
}

.admin-booking-calendar-day--selected {
  border-color: #8f3443;
  background: #fff4f7;
  box-shadow: 0 0 0 4px rgba(183, 109, 120, 0.28), 0 10px 24px rgba(125, 65, 75, 0.12), inset 0 0 0 1px rgba(143, 52, 67, 0.45);
}

.admin-booking-calendar-date {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  min-height: 2rem;
  padding: 0 0.2rem;
  border-radius: 999px;
  color: #52606d;
  font-weight: 800;
}

.admin-booking-calendar-day--today .admin-booking-calendar-date {
  background: #f8e3e5;
  color: #7d4b52;
}

.admin-booking-calendar-day--selected .admin-booking-calendar-date {
  background: #7d414b;
  color: #ffffff;
}

.admin-booking-calendar-events {
  display: grid;
  gap: 0.4rem;
  margin-top: 0.45rem;
}

.admin-booking-calendar-event {
  display: grid;
  gap: 0.1rem;
  width: 100%;
  border: 1px solid transparent;
  border-radius: 12px;
  padding: 0.48rem 0.55rem;
  color: #1f2933;
  font: inherit;
  font-size: 0.78rem;
  line-height: 1.25;
  text-align: left;
  cursor: pointer;
}

.admin-booking-calendar-event strong,
.admin-booking-calendar-event span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-booking-calendar-event strong {
  font-size: 0.82rem;
}

.admin-booking-calendar-event-initials,
.admin-booking-calendar-event-client,
.admin-booking-calendar-event-service,
.admin-booking-calendar-event-payment {
  display: none;
}

.admin-booking-calendar-event-time {
  color: #52606d;
  font-size: 0.74rem;
  font-weight: 600;
  min-height: 0;
}

.admin-booking-calendar-event-time:empty,
.admin-booking-calendar-event-action:empty {
  display: none;
}

.admin-booking-calendar-event-action {
  font-size: 0.7rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.01em;
}

.admin-booking-calendar-event--dropoff .admin-booking-calendar-event-action {
  color: #166534;
}

.admin-booking-calendar-event--pickup .admin-booking-calendar-event-action {
  color: #9f1d2d;
}

.admin-booking-calendar-event--turnover .admin-booking-calendar-event-action {
  color: #5c4a12;
}

.admin-booking-calendar-event--dropoff {
  border-color: #76bd88;
  background: #f0faf3;
}

.admin-booking-calendar-event--stay {
  border-color: #c8d8f0;
  background: #f7f9fd;
}

.admin-booking-calendar-event--pickup {
  border-color: #e99aa4;
  background: #fff4f5;
}

.admin-booking-calendar-event--turnover {
  border-color: #c8b97a;
  background: linear-gradient(135deg, #f0faf3 0%, #fff4f5 100%);
}

.admin-booking-calendar-event--meetandgreet {
  border-color: #c4b5fd;
  background: #f5f3ff;
}

.admin-booking-calendar-event--meetandgreet .admin-booking-calendar-event-action {
  color: #5b21b6;
}

.admin-booking-calendar-event--availabilityblock {
  border-color: #a8b3c1;
  background: #f3f5f7;
}

.admin-booking-calendar-event--availabilityblock .admin-booking-calendar-event-action {
  color: #334155;
}

.admin-booking-calendar-event:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
}

.admin-booking-calendar-empty {
  color: #9aa5b1;
  font-size: 0.76rem;
}

.admin-booking-calendar-more {
  display: none;
}

.admin-booking-calendar-agenda {
  display: none;
}

.admin-booking-calendar--list-view .admin-booking-calendar-agenda,
.admin-booking-calendar--month-view .admin-booking-calendar-agenda,
.admin-booking-calendar--week-view .admin-booking-calendar-agenda {
  display: grid;
  gap: 0.85rem;
}

.admin-booking-calendar--month-view .admin-booking-calendar-agenda {
  display: none;
}

.admin-booking-calendar-week-overview {
  display: grid;
  grid-template-columns: repeat(7, minmax(150px, 1fr));
  gap: 0.65rem;
  min-width: 980px;
}

.admin-booking-calendar-week-day,
.admin-booking-calendar-day-details {
  display: grid;
  gap: 0.65rem;
  padding: 0.85rem;
  border: 1px solid #eedfe2;
  border-radius: 18px;
  background: #ffffff;
}

.admin-booking-calendar-week-day h4,
.admin-booking-calendar-day-details h4 {
  margin: 0;
  color: #7d3f4c;
  font-size: 0.95rem;
}

.admin-booking-calendar-day-details {
  margin-top: 0.35rem;
}

.admin-booking-calendar-day-details-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.admin-booking-calendar-day-details-close {
  display: none;
  border: 0;
  background: transparent;
  color: #7d4b52;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  cursor: pointer;
}

.admin-booking-calendar-event--agenda {
  position: relative;
}

.admin-booking-calendar-event--agenda strong,
.admin-booking-calendar-event--agenda span {
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}

.admin-booking-calendar-event--agenda .admin-booking-calendar-event-client,
.admin-booking-calendar-event--agenda .admin-booking-calendar-event-service,
.admin-booking-calendar-event--agenda .admin-booking-calendar-event-payment {
  display: block;
  color: #52606d;
  font-size: 0.74rem;
  font-weight: 700;
}

.admin-booking-calendar-event--agenda .admin-booking-calendar-event-client:empty,
.admin-booking-calendar-event--agenda .admin-booking-calendar-event-service:empty,
.admin-booking-calendar-event--agenda .admin-booking-calendar-event-payment:empty {
  display: none;
}

.admin-booking-calendar-unavailable-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-top: 0.15rem;
  padding: 0.12rem 0.45rem;
  border-radius: 4px;
  background: #334155;
  color: #f8fafc;
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  line-height: 1.5;
  text-transform: uppercase;
}

.admin-back-to-top {
  position: fixed;
  right: 1.15rem;
  bottom: 1.25rem;
  z-index: 95;
  min-width: 3.25rem;
  min-height: 2.6rem;
  padding: 0.45rem 0.75rem;
  border: 1px solid rgba(217, 154, 160, 0.72);
  border-radius: 999px;
  background: #ffffff;
  color: #7d4b52;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.14);
  font: inherit;
  font-size: 0.8rem;
  font-weight: 900;
  opacity: 0;
  pointer-events: none;
  transform: translateY(0.5rem);
  transition: opacity 0.2s ease, transform 0.2s ease, background-color 0.2s ease;
}

.admin-back-to-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.admin-back-to-top:hover {
  background: #fff4f6;
}

.admin-toolbar-group {
  display: flex;
  align-items: end;
  gap: 0.85rem;
  flex-wrap: wrap;
}

.admin-toolbar-group--actions {
  margin-left: auto;
}

.admin-toolbar-copy {
  margin: 0;
  color: #52606d;
  line-height: 1.5;
}

.admin-save-button {
  width: auto;
  min-width: 140px;
  padding-inline: 1.35rem;
}

.admin-form-grid {
  display: grid;
  gap: 0.9rem;
}

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

.admin-client-intake-sections {
  display: grid;
  gap: 1rem;
}

.admin-intake-section {
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
  border: 1px solid rgba(228, 213, 216, 0.9);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255, 250, 250, 0.98), rgba(255, 244, 247, 0.88));
}

.admin-intake-section-title {
  margin: 0;
  color: #7d3f4c;
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.admin-field {
  display: grid;
  gap: 0.45rem;
  min-width: 180px;
  flex: 1 1 180px;
}

.admin-field-label {
  color: #486581;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.admin-field--invalid .admin-field-label {
  color: #b85c6a;
}

.admin-control {
  width: 100%;
  padding: 0.85rem 0.95rem;
  border: 1px solid #e4d5d8;
  border-radius: 14px;
  background: #ffffff;
  color: #1f2933;
  font: inherit;
}

textarea.admin-control {
  min-height: 110px;
  resize: vertical;
}

@media (min-width: 641px) {
  input[type="date"].admin-control,
  input[type="time"].admin-control {
    box-sizing: border-box;
    min-height: 3rem;
    appearance: none;
    -webkit-appearance: none;
  }
}

.admin-control:focus {
  outline: none;
  border-color: #d99aa0;
  box-shadow: 0 0 0 3px rgba(232, 180, 184, 0.18);
}

.admin-control--invalid {
  border-color: #d88492;
  box-shadow: 0 0 0 3px rgba(216, 132, 146, 0.16);
}

.pet-profiles-widget {
  display: grid;
  gap: 0.6rem;
}

.pet-profiles-rows {
  display: grid;
  gap: 0.5rem;
}

.pet-profile-row {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 0.5rem;
  align-items: center;
}

.pet-profile-remove {
  padding: 0.5rem 0.75rem;
  border: 1px solid #e4d5d8;
  border-radius: 10px;
  background: transparent;
  color: #b85c6a;
  font: inherit;
  font-size: 0.8rem;
  cursor: pointer;
  white-space: nowrap;
}

.pet-profile-remove:hover {
  background: rgba(184, 92, 106, 0.08);
}

.pet-profile-add {
  justify-self: start;
  padding: 0.5rem 1rem;
  font-size: 0.85rem;
}

.admin-toolbar-button {
  width: auto;
  padding-inline: 1.2rem;
}

.admin-modal {
  position: fixed;
  inset: 0;
  z-index: 300;
  display: grid;
  place-items: center;
  padding: 1.25rem;
}

.admin-modal[hidden] {
  display: none;
}

.admin-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(6px);
}

.admin-modal-dialog {
  position: relative;
  width: min(920px, 100%);
  max-height: min(86vh, 900px);
  overflow: auto;
  padding: 1.4rem;
  border-radius: 24px;
  border: 1px solid #eedfe2;
  background: #fffdfd;
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.18);
}

.admin-modal-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.admin-modal-header h3 {
  margin: 0;
  font-size: 1.45rem;
  letter-spacing: -0.03em;
}

.admin-modal-close {
  border: 1px solid #ead4d7;
  border-radius: 999px;
  padding: 0.7rem 1rem;
  background: #ffffff;
  color: #7d4b52;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
}

.admin-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  margin-top: 1rem;
}

.admin-danger-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.55rem;
  padding: 0.65rem 1rem;
  border: 1.5px solid #fecaca;
  border-radius: 999px;
  background: #fee2e2;
  color: #991b1b;
  font: inherit;
  font-weight: 850;
  cursor: pointer;
}

.admin-danger-button:hover,
.admin-danger-button:focus-visible {
  border-color: #ef4444;
  background: #fecaca;
}

.admin-availability-block-dialog {
  width: min(720px, 100%);
}

.admin-availability-block-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.admin-availability-block-fields label {
  display: grid;
  gap: 0.35rem;
  color: #52606d;
  font-size: 0.8rem;
  font-weight: 850;
}

.admin-availability-block-fields input,
.admin-availability-block-fields select,
.admin-availability-block-fields textarea {
  width: 100%;
  border: 1px solid #d9e2ec;
  border-radius: 10px;
  padding: 0.55rem 0.65rem;
  background: #ffffff;
  color: #1f2933;
  font: inherit;
}

.admin-availability-block-fields textarea {
  resize: vertical;
}

.admin-availability-block-fields-full {
  grid-column: 1 / -1;
}

.messages-panel {
  display: grid;
  gap: 1.15rem;
}

.messages-layout.client-mode {
  grid-template-columns: 1fr;
}

body.portal-client-mode #client-sidebar,
body.portal-client-mode #page-role-label,
body.portal-client-mode .chat-mode-badge {
  display: none;
}

.messages-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 1.25rem;
  align-items: start;
}

.client-sidebar {
  display: grid;
  gap: 0.8rem;
  padding: 0.35rem;
  border: 1px solid #eedfe2;
  border-radius: 20px;
  background: linear-gradient(180deg, #fffafb 0%, #faf1f2 100%);
}

.client-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  border: 1px solid #d9e2ec;
  border-radius: 16px;
  padding: 0.9rem 1rem;
  background: rgba(255, 255, 255, 0.85);
  color: #1f2933;
  font: inherit;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}

.client-item:hover {
  transform: translateY(-1px);
  border-color: #e8c6ca;
  background: #ffffff;
}

.client-item.active {
  border-color: var(--primary-color);
  background: #f9e8ea;
  color: #7d4b52;
}

.unread-badge {
  min-width: 1.5rem;
  padding: 0.15rem 0.45rem;
  border-radius: 999px;
  background: #c53030;
  color: #ffffff;
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
}

.nav-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.15rem;
  height: 1.15rem;
  margin-left: 0.35rem;
  padding: 0 0.35rem;
  border-radius: 999px;
  background: #d92d20;
  color: white;
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1;
}

.nav-badge[hidden] {
  display: none !important;
}

.chat-panel {
  display: grid;
  gap: 1rem;
}

.chat-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 0 0.4rem;
  border-bottom: 1px solid #e4e7eb;
}

.chat-header h3 {
  margin: 0;
  font-size: 1.1rem;
}

.chat-context {
  margin: 0;
  color: #7b8794;
  font-size: 0.9rem;
}

.chat-mode-badge {
  margin: 0.35rem 0 0;
  display: inline-block;
  padding: 0.3rem 0.7rem;
  border-radius: 999px;
  background: #f8e3e5;
  color: #7d4b52;
  font-size: 0.82rem;
  font-weight: 700;
}

.chat-thread {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  justify-content: flex-start;
  min-height: 180px;
  max-height: 540px;
  padding: 1rem;
  border: 1px solid #eedfe2;
  border-radius: 20px;
  background: linear-gradient(180deg, #fffdfd 0%, #faf1f2 100%);
  overflow-y: auto;
  scroll-behavior: smooth;
}

.client-date-divider {
  align-self: center;
  padding: 0.25rem 0.75rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid #eedfe2;
  color: #7b8794;
  font-size: 0.78rem;
  font-weight: 700;
}

.chat-message {
  display: flex;
  align-items: flex-start;
}

.chat-message.is-new .chat-bubble {
  animation: message-flash 2s ease forwards;
}

.chat-message.jjcare {
  justify-content: flex-start;
}

.chat-message.client {
  justify-content: flex-end;
}

.chat-bubble {
  max-width: min(78%, 420px);
  width: fit-content;
  align-self: flex-start;
  padding: 0.85rem 1rem;
  border-radius: 20px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.chat-message.jjcare .chat-bubble {
  background: linear-gradient(180deg, #fbeef0 0%, #f7e3e6 100%);
  color: #1f2933;
  border-bottom-left-radius: 6px;
}

.chat-message.client .chat-bubble {
  background: linear-gradient(180deg, var(--primary-color) 0%, var(--primary-hover) 100%);
  color: #ffffff;
  border-bottom-right-radius: 6px;
}

.chat-sender {
  margin: 0 0 0.35rem;
  font-size: 0.8rem;
  font-weight: 700;
}

.chat-text {
  margin: 0;
  line-height: 1.45;
}

.chat-time {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.76rem;
  font-weight: 600;
  opacity: 0.78;
  text-align: right;
}

.chat-media {
  display: block;
  width: 100%;
  max-width: 240px;
  border-radius: 16px;
  margin-top: 0.35rem;
  background: #d9e2ec;
  overflow: hidden;
}

.chat-video {
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.chat-form {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
  border: 1px solid #eedfe2;
  border-radius: 20px;
  background: linear-gradient(180deg, #fffafb 0%, #faf1f2 100%);
}

.composer-topline {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.composer-main {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  min-width: 0;
}

.upload-button,
.chat-form input {
  padding: 0.85rem 1rem;
  border: 1px solid #cbd2d9;
  font: inherit;
}

.upload-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #eef2f6;
  color: #486581;
  cursor: pointer;
  white-space: nowrap;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.upload-button:hover {
  background: #f7e6e8;
  color: #7d4b52;
}

.chat-upload-input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.file-status {
  min-width: 0;
  margin: 0;
  color: #7b8794;
  font-size: 0.86rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-form input {
  flex: 1;
  min-width: 0;
  border-radius: 999px;
  background: #ffffff;
}

.chat-form button {
  border: 0;
  border-radius: 999px;
  padding: 0.85rem 1.2rem;
  background: var(--primary-color);
  color: #ffffff;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  transition: filter 0.2s ease, transform 0.2s ease;
}

.chat-form button:hover {
  filter: brightness(1.04);
  transform: translateY(-1px);
}

#logout-button {
  border: 1px solid #ead4d7;
  border-radius: 999px;
  padding: 0.75rem 1rem;
  background: #ffffff;
  color: #7d4b52;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  flex-shrink: 0;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

#logout-button:hover {
  background: #fdf2f4;
  border-color: #e8c6ca;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.chat-toast {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 9999;
  padding: 0.85rem 1rem;
  border-radius: 999px;
  background: #1f2933;
  color: white;
  font-weight: 700;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.2);
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.chat-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes message-flash {
  0% {
    transform: translateY(6px);
    box-shadow: 0 0 0 0 rgba(232, 180, 184, 0.35);
    filter: brightness(1.05);
  }

  100% {
    transform: translateY(0);
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
    filter: brightness(1);
  }
}

@media (max-width: 640px) {
  .container {
    width: min(1120px, calc(100% - 1rem));
  }

  .site-header {
    padding: 0.75rem 0 0.8rem;
  }

  .site-header h1 {
    font-size: 1.02rem;
    line-height: 1.2;
  }

  .header-paw,
  .header-logo-img {
    width: 1.15rem;
    height: 1.15rem;
  }

  .site-header-top {
    align-items: center;
    margin-bottom: 0;
  }

  .site-header-actions {
    gap: 0.55rem;
  }

  .mobile-menu-button {
    display: inline-flex;
  }

  #logout-button {
    display: none;
  }

  .site-nav {
    display: none;
    margin-top: 0.75rem;
    padding: 0.8rem;
    gap: 0.55rem;
    border: 1px solid rgba(232, 198, 202, 0.95);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 16px 32px rgba(15, 23, 42, 0.08);
  }

  .site-nav.is-open {
    display: grid;
  }

  .site-nav-group {
    display: grid;
    gap: 0.42rem;
    padding: 0.72rem;
    border: 1px solid rgba(232, 198, 202, 0.72);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255, 246, 248, 0.94), rgba(255, 255, 255, 0.9));
  }

  .site-nav-group[hidden] {
    display: none;
  }

  .site-nav-group-label {
    display: block;
    padding: 0 0.12rem 0.15rem;
    color: #a66670;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .site-nav a {
    width: 100%;
    text-align: left;
    padding: 0.85rem 1rem;
    border-radius: 16px;
  }

  .site-nav .nav-disabled {
    justify-content: space-between;
    width: 100%;
    padding: 0.85rem 1rem;
    border-radius: 16px;
  }

  .site-nav-logout {
    display: block;
  }

  .agreement-shell {
    width: calc(100% - 1rem);
    margin: 0.75rem auto 1.25rem;
  }

  .agreement-card {
    padding: 1rem;
    border-radius: 22px;
  }

  .agreement-card-header {
    grid-template-columns: 1fr;
  }

  .agreement-policy-list {
    grid-template-columns: 1fr;
  }

  .agreement-actions .auth-submit-button,
  .agreement-actions .button-link {
    width: 100%;
  }

  .panel {
    margin: 0.85rem 0 1.25rem;
    padding: 1rem;
    border-radius: 20px;
  }

  .auth-shell {
    min-height: auto;
    padding-block: 0.85rem 1.75rem;
  }

  .auth-card {
    padding: 1.2rem;
    border-radius: 24px;
  }

  .messages-layout {
    grid-template-columns: 1fr;
  }

  .portal-heading,
  .portal-heading--compact {
    display: block;
    margin-bottom: 0.85rem;
  }

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

  .admin-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-toolbar-group,
  .admin-toolbar-group--actions {
    width: 100%;
    margin-left: 0;
  }

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

  .admin-save-button {
    width: 100%;
  }

  .admin-toolbar-button {
    width: 100%;
  }

  .admin-modal {
    padding: 0.75rem;
  }

  .admin-modal-dialog {
    padding: 1rem;
  }

  .admin-modal-actions {
    flex-direction: column;
  }

  .admin-availability-block-fields {
    grid-template-columns: 1fr;
  }

  .client-summary-card,
  .summary-strip {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .invoice-summary-header {
    display: grid;
  }

  .invoice-service-box {
    grid-template-columns: 1fr;
  }

  .admin-invoice-item-row {
    grid-template-columns: 1fr;
  }

  .admin-invoice-item-remove {
    justify-self: start;
  }

  .client-update-actions .invoice-pay-button {
    width: 100%;
  }

  .client-updates-filter-bar {
    grid-template-columns: 1fr;
  }

  .client-update-admin-actions .admin-toolbar-button,
  .client-update-admin-actions .admin-save-button {
    width: 100%;
  }

  .client-update-meta,
  .client-update-actions,
  .client-update-quick-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .card-topline {
    flex-direction: column;
    align-items: flex-start;
  }

  .hero-strip {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

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

  .client-item {
    justify-content: center;
    gap: 0.35rem;
    text-align: center;
    padding-inline: 0.5rem;
  }

  .chat-header {
    display: block;
  }

  .chat-context {
    margin-top: 0.5rem;
  }

  .chat-bubble {
    max-width: 88%;
  }

  .chat-media {
    max-width: 180px;
  }

  .chat-form {
    padding: 0.85rem;
  }

  .composer-topline,
  .composer-main {
    flex-direction: column;
    align-items: stretch;
  }

  .upload-button,
  .chat-form button {
    width: 100%;
  }

  .file-status {
    white-space: normal;
  }

  .chat-toast {
    left: 1rem;
    right: 1rem;
    max-width: none;
  }
}

.dashboard-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 20px 0 25px;
}

.button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 18px;
  border-radius: 999px;
  background: #e7a7ad;
  color: #ffffff;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid #e7a7ad;
  cursor: pointer;
}

.button-link--secondary {
  background: #eef3f8;
  color: #2e506f;
  border-color: #dfe8f1;
}

.button-link:hover,
.button-link:focus-visible {
  opacity: 0.9;
  text-decoration: none;
}

.button-link:disabled {
  cursor: wait;
  opacity: 0.68;
}

.client-request-dialog {
  width: min(760px, 100%);
  background:
    linear-gradient(135deg, rgba(255, 253, 253, 0.98), rgba(255, 246, 248, 0.96));
}

.client-request-copy {
  margin: 0.35rem 0 0;
  color: #687586;
  line-height: 1.5;
}

.client-request-form {
  display: grid;
  gap: 1rem;
}

.client-request-grid {
  align-items: start;
}

.client-request-policy {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(232, 198, 202, 0.9);
  border-radius: 18px;
  background: rgba(255, 244, 246, 0.72);
  color: #486581;
  line-height: 1.5;
}

.client-request-policy input {
  width: 1.1rem;
  height: 1.1rem;
  margin-top: 0.18rem;
  accent-color: var(--primary-hover);
  flex: 0 0 auto;
}

.client-request-policy--invalid {
  border-color: #d88492;
  box-shadow: 0 0 0 3px rgba(216, 132, 146, 0.14);
}

.client-request-status {
  min-height: 1.5rem;
  margin: 0;
  color: #687586;
  font-weight: 700;
  line-height: 1.5;
}

.client-request-status[data-tone="success"] {
  color: #2f7a52;
}

.client-request-status[data-tone="error"] {
  color: #b85c6a;
}

.client-request-actions {
  align-items: center;
}

#dashboard-messages-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 999px;
  background: #d92d20;
  color: #ffffff;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

#dashboard-messages-badge[hidden] {
  display: none !important;
}

@media (max-width: 640px) {
  .dashboard-action-row {
    flex-direction: column;
  }

  .button-link {
    width: 100%;
  }

  .client-request-dialog {
    padding: 1.05rem;
    border-radius: 20px;
  }

  .client-request-actions {
    flex-direction: column-reverse;
  }

  .client-request-actions .button-link {
    width: 100%;
  }
}

.portal-loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 9998;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: rgba(255, 248, 249, 0.72);
  backdrop-filter: blur(4px);
}

.portal-loading-active .portal-loading-overlay,
.portal-saving .portal-loading-overlay {
  display: flex;
}

.portal-loading-card {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  max-width: min(92vw, 420px);
  padding: 0.95rem 1.15rem;
  border: 1px solid #eedfe2;
  border-radius: 999px;
  background: #ffffff;
  color: #1f2933;
  font-size: 0.95rem;
  font-weight: 800;
  box-shadow: 0 18px 45px rgba(31, 41, 51, 0.16);
}

.portal-loading-spinner {
  width: 1.1rem;
  height: 1.1rem;
  border: 3px solid #eedfe2;
  border-top-color: #7d4b52;
  border-radius: 999px;
  animation: portal-spin 0.8s linear infinite;
  flex: 0 0 auto;
}


@keyframes portal-spin {
  to {
    transform: rotate(360deg);
  }
}

.portal-loading-retry {
  all: unset;
  cursor: pointer;
  color: #7d4b52;
  font-size: 0.85rem;
  font-weight: 700;
  text-decoration: underline;
  margin-left: 0.25rem;
  white-space: nowrap;
}

.invoice-due-today-row {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 16px;
  padding: 14px 16px;
  margin: 10px 0;
  box-shadow: 0 8px 20px rgba(194, 94, 24, 0.08);
}

.invoice-due-today-row span,
.invoice-due-today-row small {
  color: #9a3412;
  font-weight: 700;
}

.invoice-due-today-row strong,
.invoice-due-today-row #invoice-deposit-due {
  color: #9a3412;
  font-size: 1.15rem;
}

.invoice-payment-received-row {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 16px;
  padding: 14px 16px;
  margin: 10px 0;
  box-shadow: 0 8px 20px rgba(22, 101, 52, 0.08);
}

.invoice-payment-received-row span,
.invoice-payment-received-row small {
  color: #166534;
  font-weight: 700;
}

.invoice-payment-received-row strong,
.invoice-payment-received-row #invoice-deposit-due {
  color: #166534;
  font-size: 1.15rem;
}

.dashboard-pet-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 4px;
}

.dashboard-pet-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid #ead1d6;
  color: #243447;
  font-weight: 700;
  font-size: 0.95rem;
  box-shadow: 0 6px 14px rgba(125, 65, 75, 0.08);
}

.pet-breed-text {
  font-weight: 400;
  color: #6b7280;
  font-size: 0.875em;
}

@media (max-width: 640px) {
  .dashboard-pet-tags {
    flex-direction: column;
    align-items: flex-start;
  }

  .dashboard-pet-tag {
    width: 100%;
    justify-content: flex-start;
  }

  .pet-breed-text {
    display: block;
    margin-top: 2px;
    font-size: 0.8em;
  }
}

/* ============================================================
   MODERN DASHBOARD APP SURFACE
   ============================================================ */

.portal-overview {
  position: relative;
}

.portal-overview > * {
  animation: dashboard-card-enter 0.48s ease both;
}

.portal-overview > *:nth-child(2) { animation-delay: 0.04s; }
.portal-overview > *:nth-child(3) { animation-delay: 0.08s; }
.portal-overview > *:nth-child(4) { animation-delay: 0.12s; }
.portal-overview > *:nth-child(5) { animation-delay: 0.16s; }

.panel.portal-overview {
  border-color: rgba(255, 255, 255, 0.82);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 248, 249, 0.9)),
    radial-gradient(circle at 92% 8%, rgba(245, 199, 204, 0.25), transparent 28%);
  box-shadow: 0 24px 64px rgba(125, 65, 75, 0.12);
}

.admin-home,
.admin-home-grid,
.quick-actions {
  display: grid;
  gap: 1rem;
}

.admin-home {
  margin-bottom: 0.6rem;
}

.admin-home-hero,
.client-welcome-banner {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0.14)),
    linear-gradient(135deg, #ffe7eb 0%, #f7bdc5 48%, #fff6f7 100%);
  box-shadow: var(--app-shadow);
}

.admin-home-hero::before,
.client-welcome-banner::before {
  content: "";
  position: absolute;
  inset: -45% auto auto -20%;
  width: 70%;
  aspect-ratio: 1;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.34);
  transform: rotate(18deg);
}

.admin-home-hero::after,
.client-welcome-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 0%, rgba(255, 255, 255, 0.34) 42%, transparent 62%);
  transform: translateX(-120%);
  animation: dashboard-shine 8s ease-in-out infinite;
  pointer-events: none;
}

.admin-home-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.5rem;
}

.admin-home-hero > *,
.client-welcome-banner > * {
  position: relative;
  z-index: 1;
}

.admin-home-hero h2 {
  margin: 0 0 0.45rem;
  color: #6f3340;
  font-size: clamp(1.85rem, 4vw, 2.6rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.admin-home-hero p:last-child {
  margin: 0;
  color: #754f58;
  line-height: 1.55;
}

.admin-home-paw {
  display: grid;
  place-items: center;
  width: 5rem;
  height: 5rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.38);
  color: rgba(125, 65, 75, 0.42);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.admin-home-paw svg {
  width: 3.3rem;
  height: 3.3rem;
}

.admin-home-stats,
.client-stats-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
}

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

.app-stat-card,
.client-stat-card,
.summary-stat,
.hero-stat,
.info-card,
.app-section-card {
  border-color: var(--app-card-border);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 247, 248, 0.94) 100%);
  box-shadow: 0 12px 28px rgba(125, 65, 75, 0.07);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.app-stat-card:hover,
.client-stat-card:hover,
.summary-stat:hover,
.hero-stat:hover,
.info-card:hover,
.quick-action-card:hover,
.app-section-card:hover {
  border-color: rgba(217, 154, 160, 0.72);
  box-shadow: 0 18px 38px rgba(125, 65, 75, 0.12);
  transform: translateY(-2px);
}

.app-stat-card {
  display: grid;
  gap: 0.45rem;
  min-height: 132px;
  padding: 1rem;
}

.app-stat-icon,
.quick-action-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.15rem;
  height: 2.15rem;
  border-radius: 14px;
  background: linear-gradient(135deg, #ffe6ea, #f6c3ca);
  color: #7d414b;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.app-stat-label,
.client-stat-label {
  color: var(--app-muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.app-stat-card strong,
.client-stat-value {
  color: var(--app-ink);
  font-size: 1.55rem;
  font-weight: 900;
  letter-spacing: -0.04em;
}

.client-stat-value {
  font-size: 1rem;
  letter-spacing: -0.02em;
}

.admin-home-grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
}

.app-section-card {
  display: grid;
  gap: 1rem;
  padding: 1.1rem;
}

.app-section-heading {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
}

.app-section-heading h3 {
  margin: 0;
  color: var(--app-ink);
  font-size: 1.05rem;
  letter-spacing: -0.02em;
}

.app-section-heading span {
  flex: 0 0 auto;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  background: #fff0f2;
  color: #9d5360;
  font-size: 0.72rem;
  font-weight: 800;
}

.app-list {
  display: grid;
  gap: 0.7rem;
}

.app-list-item {
  display: grid;
  gap: 0.18rem;
  padding: 0.8rem 0.85rem;
  border: 1px solid rgba(238, 223, 226, 0.92);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

.app-list-item strong {
  color: var(--app-ink);
  font-size: 0.95rem;
}

.app-list-item span,
.app-empty-copy {
  margin: 0;
  color: var(--app-muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.app-list-item--alert {
  background: #fff4f4;
  border-color: #f3c9ce;
}

.app-list-item--warm {
  background: #fff7ed;
  border-color: #fed7aa;
}

#admin-attention-needed .app-list-item--warm {
  cursor: pointer;
  box-shadow: inset 4px 0 0 #f59e0b;
}

#admin-attention-needed .app-list-item--alert {
  box-shadow: inset 4px 0 0 #ef4444;
}

.app-list-item--clickable {
  cursor: pointer;
  transition: box-shadow 0.15s ease, background 0.15s ease;
}

#admin-attention-needed .app-list-item--clickable.app-list-item--alert:hover {
  background: #fff0f0;
  box-shadow: inset 4px 0 0 #ef4444, 0 3px 10px rgba(239, 68, 68, 0.12);
}

#admin-attention-needed .app-list-item--clickable.app-list-item--warm:hover {
  background: #fff3e0;
  box-shadow: inset 4px 0 0 #f59e0b, 0 3px 10px rgba(245, 158, 11, 0.12);
}

.app-list-item--soft {
  background: #f8fbff;
  border-color: #dbeafe;
}

.app-list-item-action {
  margin-top: 0.45rem;
  padding: 0.3rem 0.75rem;
  border: 1px solid #93c5fd;
  border-radius: 12px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  align-self: flex-start;
}

.app-list-item-action:hover {
  background: #dbeafe;
}

.quick-actions {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.quick-action-card {
  display: grid;
  gap: 0.75rem;
  align-content: center;
  min-height: 110px;
  padding: 1rem;
  border: 1px solid var(--app-card-border);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--app-ink);
  font: inherit;
  font-weight: 800;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(125, 65, 75, 0.07);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.dashboard-management-heading {
  margin-top: 0.75rem;
  padding-top: 0.95rem;
  border-top: 1px solid rgba(238, 223, 226, 0.9);
}

.dashboard-client-heading {
  margin-bottom: 0;
}

.client-welcome-banner {
  min-height: 156px;
  padding: 1.35rem 1.45rem;
}

.client-welcome-hi {
  color: #6f3340;
  font-size: clamp(1.55rem, 4vw, 2.25rem);
  letter-spacing: -0.04em;
}

.client-welcome-tagline {
  color: #754f58;
}

.client-avatar-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.85rem;
}

.pet-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.45rem;
  height: 2.45rem;
  padding: 0 0.7rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: #7d414b;
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
  box-shadow: 0 8px 18px rgba(125, 65, 75, 0.08);
}

.pet-avatar--soft {
  background: rgba(255, 240, 242, 0.88);
}

.pet-avatar--light {
  background: rgba(255, 255, 255, 0.45);
}

.client-welcome-paw {
  width: 5.2rem;
  height: 5.2rem;
  color: rgba(125, 65, 75, 0.3);
  opacity: 1;
}

.dashboard-action-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
  margin: 0;
}

.dashboard-action-row .button-link {
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.2;
}

.button-link {
  min-height: 56px;
  border-radius: 18px;
  background: linear-gradient(135deg, #df8d98 0%, #c86f7e 100%);
  border-color: transparent;
  box-shadow: 0 12px 24px rgba(200, 111, 126, 0.22);
}

.button-link--secondary {
  background: rgba(255, 255, 255, 0.82);
  color: #7d414b;
  border-color: var(--app-card-border);
  box-shadow: 0 10px 22px rgba(125, 65, 75, 0.07);
}

.dashboard-grid {
  gap: 1rem;
}

.info-card {
  padding: 1.15rem;
}

.status-pill,
.timestamp-chip,
.nav-unread-badge {
  animation: none;
}

.nav-unread-badge:not([hidden]) {
  animation: badge-pulse 2.2s ease-in-out infinite;
}

@keyframes dashboard-card-enter {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes dashboard-shine {
  0%, 62% {
    transform: translateX(-120%);
  }
  78%, 100% {
    transform: translateX(120%);
  }
}

@keyframes badge-pulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(217, 45, 32, 0.26);
  }
  50% {
    box-shadow: 0 0 0 7px rgba(217, 45, 32, 0);
  }
}

@media (max-width: 820px) {
  .admin-home-stats,
  .quick-actions,
  .dashboard-action-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-home-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .container {
    width: min(100% - 1rem, 1120px);
  }

  .panel.portal-overview {
    margin-top: 0.9rem;
    padding: 0.8rem;
    border-radius: 28px;
  }

  .admin-home-hero,
  .client-welcome-banner {
    padding: 1.15rem;
    border-radius: 24px;
  }

  .admin-home-paw {
    width: 3.8rem;
    height: 3.8rem;
    border-radius: 18px;
  }

  .admin-home-paw svg {
    width: 2.5rem;
    height: 2.5rem;
  }

  .admin-home-stats,
  .client-stats-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
  }

  .client-stats-strip .client-stat-card:first-child {
    grid-column: 1 / -1;
  }

  .app-stat-card,
  .client-stat-card,
  .quick-action-card {
    min-height: 104px;
    border-radius: 20px;
  }

  .app-stat-card strong {
    font-size: 1.35rem;
  }

  .quick-actions,
  .dashboard-action-row {
    grid-template-columns: 1fr;
  }

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

  .client-welcome-paw {
    width: 3.6rem;
    height: 3.6rem;
  }
}

/* ============================================================
   NAV BADGE (Care Requests notification count)
   ============================================================ */

.nav-unread-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: #dc2626;
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 700;
  line-height: 1;
  vertical-align: middle;
  margin-left: 4px;
}

/* hidden attribute must win over display:inline-flex */
.nav-unread-badge[hidden] {
  display: none !important;
}

/* When inside the active nav pill (pink background), invert to stay visible */
.site-nav a.active .nav-unread-badge {
  background: #ffffff;
  color: #7d414b;
}

/* Hide the Updates unread badge in admin mode — admins post updates,
   so an "unread" count on Updates is misleading for them */
body.portal-admin-mode .site-nav a[href="updates.html"] .nav-unread-badge {
  display: none !important;
}

/* ============================================================
   TOAST NOTIFICATION
   ============================================================ */

.cr-toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: #1f2933;
  color: #ffffff;
  border-radius: 14px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
  font-size: 0.92rem;
  font-weight: 500;
  max-width: 340px;
  cursor: pointer;
  transform: translateY(80px);
  opacity: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
  text-decoration: none;
}

.cr-toast.visible {
  transform: translateY(0);
  opacity: 1;
}

.cr-toast-icon {
  font-size: 1.3rem;
  flex-shrink: 0;
}

.cr-toast-text {
  flex: 1;
  line-height: 1.35;
}

.cr-toast-count {
  background: #dc2626;
  color: #fff;
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 0.78rem;
  font-weight: 700;
  flex-shrink: 0;
}

@media (max-width: 480px) {
  .cr-toast {
    bottom: 16px;
    right: 16px;
    left: 16px;
    max-width: none;
  }
}

/* ============================================================
   PAYMENT REMINDER BANNER
   Shown to admins when auto-reminders are sent to clients.
   ============================================================ */

.payment-reminder-banner {
  background: #fff8ec;
  border: 1.5px solid #f3c96b;
  border-radius: 12px;
  padding: 1rem 1.1rem;
  margin-bottom: 1.25rem;
  font-size: 0.92rem;
}

.prb-header {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.prb-icon {
  font-size: 1.3rem;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 2px;
}

.prb-header > div {
  flex: 1;
}

.prb-title {
  display: block;
  font-size: 0.95rem;
  color: #7a5a00;
  margin-bottom: 0.2rem;
}

.prb-sub {
  margin: 0;
  color: #8a6e1a;
  font-size: 0.87rem;
}

.prb-dismiss {
  background: none;
  border: none;
  cursor: pointer;
  color: #a07c20;
  font-size: 1rem;
  padding: 0 0.25rem;
  line-height: 1;
  flex-shrink: 0;
}

.prb-dismiss:hover {
  color: #5a4000;
}

.prb-list {
  margin-top: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.prb-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  background: #fff3d6;
  border-radius: 8px;
  padding: 0.55rem 0.85rem;
  flex-wrap: wrap;
}

.prb-client-name {
  font-weight: 600;
  color: #4a3800;
  font-size: 0.9rem;
}

.prb-balance {
  font-weight: 400;
  color: #7a5a00;
  margin-left: 0.25rem;
}

.prb-email-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  background: #f3c96b;
  color: #4a3800;
  border: none;
  border-radius: 6px;
  padding: 0.35rem 0.75rem;
  font-size: 0.83rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}

.prb-email-btn:hover {
  background: #e8b84f;
  color: #3a2c00;
}

.prb-no-email {
  font-size: 0.8rem;
  color: #a07c20;
  font-style: italic;
}

@media (max-width: 600px) {
  .prb-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.4rem;
  }

  .prb-email-btn {
    width: 100%;
    justify-content: center;
  }
}

/* ============================================================
   ATTENTION NEEDED — PER-CLIENT PAYMENT CARDS
   ============================================================ */

.atn-card {
  background: #fff8ec;
  border: 1.5px solid #f3c96b;
  border-radius: 10px;
  padding: 0.8rem 0.9rem 0.7rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.atn-card + .atn-card {
  margin-top: 0.55rem;
}

.atn-card-header {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.atn-card-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.atn-card-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: #4a3800;
}

.atn-card-urgency {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  padding: 0.22rem 0.55rem;
  border-radius: 999px;
  flex-shrink: 0;
  text-transform: uppercase;
}

.atn-card-urgency--overdue {
  background: #fde8e8;
  color: #991b1b;
  border: 1px solid #fca5a5;
}

.atn-card-urgency--at-risk {
  background: #fff3cd;
  color: #92400e;
  border: 1px solid #fcd34d;
}

.atn-card-urgency--soon {
  background: #fff7e0;
  color: #7a5a00;
  border: 1px solid #f3c96b;
}

.atn-card-urgency--default {
  background: #f3f4f6;
  color: #374151;
  border: 1px solid #d1d5db;
}

.atn-card-meta {
  font-size: 0.82rem;
  color: #7a5a00;
  line-height: 1.4;
  margin-top: 0.1rem;
}

.atn-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.1rem;
}

.atn-btn {
  font-size: 0.8rem;
  font-weight: 700;
  padding: 0.32rem 0.7rem;
  border-radius: 6px;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
  white-space: nowrap;
  line-height: 1.3;
}

.atn-btn--open-client {
  background: #e7efff;
  color: #274c77;
  border-color: #c4d3ec;
}
.atn-btn--open-client:hover { background: #d0e0f8; }

.atn-btn--open-payments {
  background: #edf7ee;
  color: #14532d;
  border-color: #9bd4aa;
}
.atn-btn--open-payments:hover { background: #d9f0dc; }

.atn-btn--send-reminder {
  background: #fff3d6;
  color: #7a5a00;
  border-color: #f3c96b;
}
.atn-btn--send-reminder:hover { background: #ffe9ab; }

.atn-btn--copy-sms {
  background: #f3f4f6;
  color: #374151;
  border-color: #d1d5db;
}
.atn-btn--copy-sms:hover { background: #e5e7eb; }

.atn-btn--mark-paid {
  background: #dcfce7;
  color: #14532d;
  border-color: #86efac;
}
.atn-btn--mark-paid:hover { background: #bbf7d0; }
.atn-btn--mark-paid:disabled { opacity: 0.55; cursor: not-allowed; }

.atn-btn--cancel-booking {
  background: #fee2e2;
  color: #7f1d1d;
  border-color: #fca5a5;
}
.atn-btn--cancel-booking:hover { background: #fecaca; }
.atn-btn--cancel-booking:disabled { opacity: 0.55; cursor: not-allowed; }

.atn-card-badge-row {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  flex-wrap: wrap;
  margin-top: 0.15rem;
}

/* ── Admin Payment Command Center ── */
.admin-payment-command-section {
  margin-bottom: 2rem;
}

.admin-payment-command-header {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 0.9rem;
}

.admin-payment-command-title {
  font-size: 1rem;
  font-weight: 700;
  color: #253141;
  margin: 0;
}

.admin-payment-command-count {
  font-size: 0.78rem;
  font-weight: 700;
  color: #b85c6a;
  background: #fff0f2;
  border: 1px solid #f0c0c8;
  border-radius: 999px;
  padding: 0.14rem 0.55rem;
}

/* ── Booking status badges ── */
.booking-status-badge {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  padding: 0.18rem 0.5rem;
  border-radius: 999px;
  border: 1px solid transparent;
  text-transform: uppercase;
}

.booking-status-badge--awaiting-payment {
  background: #fef3c7;
  color: #78350f;
  border-color: #fcd34d;
}
.booking-status-badge--confirmed {
  background: #dcfce7;
  color: #14532d;
  border-color: #86efac;
}
.booking-status-badge--active-stay {
  background: #dbeafe;
  color: #1e3a5f;
  border-color: #93c5fd;
}
.booking-status-badge--at-risk {
  background: #fee2e2;
  color: #7f1d1d;
  border-color: #fca5a5;
}
.booking-status-badge--completed {
  background: #f3f4f6;
  color: #4b5563;
  border-color: #d1d5db;
}
.booking-status-badge--cancelled {
  background: #fce7f3;
  color: #831843;
  border-color: #f9a8d4;
}
.booking-status-badge--test-client {
  background: #f5f3ff;
  color: #4c1d95;
  border-color: #c4b5fd;
}
.booking-status-badge--inquiry,
.booking-status-badge--pending-approval {
  background: #f0fdf4;
  color: #166534;
  border-color: #bbf7d0;
}
.booking-status-badge--archived {
  background: #f9fafb;
  color: #6b7280;
  border-color: #e5e7eb;
}

@media (max-width: 480px) {
  .atn-card-actions {
    flex-direction: column;
  }
  .atn-btn {
    width: 100%;
    text-align: center;
  }
}

/* ============================================================
   CARE REQUESTS PAGE INVITE LINKS
   ============================================================ */

.cr-invite-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.cr-invite-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid #ead1d6;
  background: #f5ecee;
  color: #7d414b;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.12s, border-color 0.12s;
}

.cr-invite-link:hover {
  background: #ead1d6;
  border-color: #c47a88;
}

.cr-invite-message {
  display: block;
  margin-top: 8px;
  color: #9f1239;
}

/* ============================================================
   CARE REQUESTS PAGE
   ============================================================ */

.cr-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 16px;
}

.cr-card {
  background: #ffffff;
  border: 1px solid #ead1d6;
  border-radius: var(--radius-md, 12px);
  padding: 16px 20px;
  cursor: pointer;
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
  box-shadow: 0 2px 8px rgba(125, 65, 75, 0.06);
}

.cr-card:hover {
  border-color: #c47a88;
  box-shadow: 0 4px 16px rgba(125, 65, 75, 0.13);
}

.cr-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}

.cr-card-name {
  font-weight: 700;
  font-size: 1.05rem;
  color: #243447;
}

.cr-card-meta {
  font-size: 0.88rem;
  color: #6b7280;
  margin-bottom: 8px;
}

.cr-card-details {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

.cr-detail-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  background: #f5ecee;
  border: 1px solid #ead1d6;
  color: #7d414b;
  font-size: 0.82rem;
  font-weight: 600;
}

.cr-card-preview {
  font-size: 0.9rem;
  color: #4b5563;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  margin-bottom: 6px;
}

.cr-card-date {
  font-size: 0.8rem;
  color: #9ca3af;
  margin-top: 4px;
}

/* Status pills */
.cr-status-new {
  background: #dbeafe;
  color: #1d4ed8;
  border: 1px solid #bfdbfe;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.cr-status-contacted {
  background: #fef9c3;
  color: #854d0e;
  border: 1px solid #fde68a;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.cr-status-meetgreet {
  background: #ede9fe;
  color: #5b21b6;
  border: 1px solid #ddd6fe;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.cr-status-approved {
  background: #dcfce7;
  color: #166534;
  border: 1px solid #bbf7d0;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.cr-status-declined {
  background: #fee2e2;
  color: #991b1b;
  border: 1px solid #fecaca;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

/* Approval notice box inside detail modal */
.cr-approval-notice {
  background: #fffbeb;
  border: 1px solid #fcd34d;
  border-radius: 8px;
  padding: 14px 18px;
  font-size: 0.9rem;
  color: #78350f;
  margin: 12px 0;
  display: none;
}

.cr-approval-notice.visible {
  display: block;
}

/* Empty state */
.cr-empty {
  text-align: center;
  padding: 40px 20px;
  color: #9ca3af;
  font-size: 0.95rem;
}

/* Care requests filter toolbar */
.cr-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 4px;
}

.cr-filter-btn {
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid #ead1d6;
  background: #ffffff;
  color: #7d414b;
  font-size: 0.83rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
}

.cr-filter-btn:hover {
  background: #f5ecee;
  border-color: #c47a88;
}

.cr-filter-btn.active {
  background: #7d414b;
  color: #ffffff;
  border-color: #7d414b;
}

@media (max-width: 640px) {
  .cr-card-top {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  .cr-filter-bar {
    gap: 6px;
  }

  .cr-filter-btn {
    font-size: 0.78rem;
    padding: 5px 11px;
  }
}

/* ============================================================
   CLIENT WELCOME BANNER
   ============================================================ */

.client-welcome-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.4rem;
  border-radius: 20px;
  background: linear-gradient(135deg, #fdf2f4 0%, #f8e3e6 100%);
  border: 1px solid #eedfe2;
  box-shadow: 0 6px 18px rgba(184, 92, 106, 0.08);
}

.client-welcome-left {
  display: grid;
  gap: 0.2rem;
}

.client-welcome-hi {
  margin: 0;
  font-size: 1.35rem;
  font-weight: 800;
  color: #7d3f4c;
  letter-spacing: -0.02em;
}

.client-welcome-tagline {
  margin: 0;
  color: #7b4f58;
  font-size: 0.9rem;
  line-height: 1.4;
}

.client-welcome-paw {
  width: 2.8rem;
  height: 2.8rem;
  color: var(--primary-color);
  opacity: 0.6;
  flex-shrink: 0;
}

/* Hide the "Client: [Name]" stat box for clients — the heading already shows it */
body.portal-client-mode .summary-stat--client-label {
  display: none !important;
}

/* Style the pets stat full-width for clients */
body.portal-client-mode .summary-strip {
  grid-template-columns: 1fr;
}

body.portal-client-mode .summary-stat--pets {
  background: linear-gradient(180deg, #ffffff 0%, #fff8f9 100%);
}

body.portal-client-mode .summary-stat--pets .summary-stat-label::before {
  content: "Your ";
}

/* ============================================================
   CLIENT 3-STAT STRIP
   ============================================================ */

.client-stats-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.client-stat-card {
  display: grid;
  gap: 0.35rem;
  padding: 1rem 1.1rem;
  border: 1px solid #eedfe2;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #fff8f9 100%);
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
}

.client-stat-label {
  color: #486581;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.client-stat-value {
  font-size: 0.98rem;
  font-weight: 800;
  color: #1f2933;
  letter-spacing: -0.01em;
  line-height: 1.3;
}

.pwa-install-banner {
  display: none;
}

.pwa-install-modal[hidden] {
  display: none;
}

.pwa-install-modal {
  position: fixed;
  inset: 0;
  z-index: 320;
  display: grid;
  place-items: end center;
  padding: 1rem;
  padding-bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
}

.pwa-install-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.38);
  backdrop-filter: blur(5px);
}

.pwa-install-modal-dialog {
  position: relative;
  width: min(420px, 100%);
  padding: 1rem;
  border: 1px solid rgba(232, 198, 202, 0.95);
  border-radius: 22px;
  background: #fffdfd;
  box-shadow: 0 24px 56px rgba(125, 65, 75, 0.24);
}

.pwa-install-modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.8rem;
  margin-bottom: 0.85rem;
}

.pwa-install-modal-header h2 {
  margin: 0;
  color: #7d414b;
  font-size: 1.05rem;
  line-height: 1.25;
}

.pwa-install-modal-close {
  min-height: 2.25rem;
  padding: 0.45rem 0.7rem;
  border: 1px solid #ead4d7;
  border-radius: 999px;
  background: #ffffff;
  color: #7d4b52;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 800;
  cursor: pointer;
}

.pwa-install-steps {
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding-left: 1.25rem;
  color: #52606d;
  font-size: 0.94rem;
  line-height: 1.45;
}

@media (max-width: 900px) {
  .pwa-install-banner {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 0.8rem;
    width: min(560px, calc(100% - 1.5rem));
    margin: 0.75rem auto 0;
    padding: 0.78rem 0.82rem;
    padding-left: max(0.82rem, env(safe-area-inset-left, 0px));
    padding-right: max(0.82rem, env(safe-area-inset-right, 0px));
    border: 1px solid rgba(232, 198, 202, 0.95);
    border-radius: 18px;
    background: rgba(255, 253, 253, 0.98);
    box-shadow: 0 16px 34px rgba(125, 65, 75, 0.14);
  }

  .pwa-install-banner p {
    margin: 0;
    color: #394b59;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.35;
  }

  .pwa-install-banner-actions {
    display: flex;
    align-items: center;
    gap: 0.45rem;
  }

  .pwa-install-banner button {
    min-height: 2.35rem;
    border-radius: 999px;
    font: inherit;
    font-size: 0.78rem;
    font-weight: 800;
    cursor: pointer;
    white-space: nowrap;
  }

  .pwa-install-button {
    padding: 0.55rem 0.85rem;
    border: 1px solid var(--primary-hover);
    background: var(--primary-color);
    color: #ffffff;
    box-shadow: 0 8px 18px rgba(217, 154, 160, 0.22);
  }

  .pwa-install-dismiss {
    padding: 0.55rem 0.72rem;
    border: 1px solid #ead4d7;
    background: #ffffff;
    color: #7d4b52;
  }
}

/* ============================================================
   MOBILE BOTTOM TAB BAR
   ============================================================ */

.bottom-tab-bar {
  display: none; /* hidden on desktop */
}

.mobile-more-menu {
  display: none;
}

@media (max-width: 640px) {
  .mobile-more-menu {
    position: fixed;
    right: 0.9rem;
    bottom: calc(5rem + env(safe-area-inset-bottom, 0px));
    z-index: 260;
    width: min(220px, calc(100vw - 1.8rem));
    padding: 0.5rem;
    border: 1px solid rgba(232, 198, 202, 0.92);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 42px rgba(125, 65, 75, 0.18);
  }

  .mobile-more-menu.is-open {
    display: grid;
    gap: 0.35rem;
  }

  .mobile-more-menu a,
  .mobile-more-menu button {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 44px;
    padding: 0.72rem 0.85rem;
    border: 0;
    border-radius: 14px;
    background: transparent;
    color: #637083;
    font: inherit;
    font-weight: 800;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
  }

  .mobile-more-menu a:hover,
  .mobile-more-menu button:hover {
    background: #fff0f3;
    color: #7d414b;
  }

  .bottom-tab-bar {
    display: flex;
    align-items: stretch;
    justify-content: space-around;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 200;
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(12px);
    border-top: 1px solid rgba(232, 198, 202, 0.9);
    box-shadow: 0 -12px 30px rgba(125, 65, 75, 0.12);
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }

  .tab-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    gap: 0.22rem;
    padding: 0.65rem 0.25rem;
    color: #9aa5b1;
    text-decoration: none;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    transition: color 0.18s ease;
  }

  .tab-item--active,
  .tab-item:hover {
    color: var(--primary-hover);
  }

  .tab-item--active {
    background: radial-gradient(circle at center, rgba(217, 154, 160, 0.32), transparent 62%);
    text-shadow: 0 0 16px rgba(217, 154, 160, 0.58);
    font-weight: 700;
  }

  .tab-icon {
    width: 1.4rem;
    height: 1.4rem;
    stroke-width: 1.75;
  }

  /* Push main content up so tab bar doesn't overlap it */
  body:has(.bottom-tab-bar) main {
    padding-bottom: 4.5rem;
  }

  .client-stats-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
  }

  .client-stat-card {
    padding: 0.8rem 0.75rem;
  }

  .client-stat-value {
    font-size: 0.85rem;
  }

  .client-welcome-banner {
    padding: 1rem 1.1rem;
  }

  .client-welcome-hi {
    font-size: 1.15rem;
  }

  .client-welcome-paw {
    width: 2.2rem;
    height: 2.2rem;
  }
}

/* Final dashboard/mobile overrides keep the modern app shell above older portal rules. */
.panel.portal-overview {
  border-color: rgba(255, 255, 255, 0.82);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 248, 249, 0.9)),
    radial-gradient(circle at 92% 8%, rgba(245, 199, 204, 0.25), transparent 28%);
  box-shadow: 0 24px 64px rgba(125, 65, 75, 0.12);
}

.client-welcome-banner {
  min-height: 156px;
  padding: 1.35rem 1.45rem;
  border-radius: 24px;
}

.client-welcome-hi {
  color: #6f3340;
  font-size: clamp(1.55rem, 4vw, 2.25rem);
  letter-spacing: -0.04em;
}

.client-welcome-paw {
  width: 5.2rem;
  height: 5.2rem;
  color: rgba(125, 65, 75, 0.3);
  opacity: 1;
}

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

.client-stat-card {
  border-radius: 22px;
  box-shadow: 0 12px 28px rgba(125, 65, 75, 0.07);
}

.client-stat-value {
  color: var(--app-ink);
  font-size: 1rem;
  letter-spacing: -0.02em;
}

@media (max-width: 640px) {
  body:has(.bottom-tab-bar) main {
    padding-bottom: calc(5.25rem + env(safe-area-inset-bottom, 0px));
  }

  .client-welcome-banner {
    padding: 1.15rem;
  }

  .client-welcome-hi {
    font-size: 1.45rem;
  }

  .client-welcome-paw {
    width: 3.6rem;
    height: 3.6rem;
  }

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

  .client-stats-strip .client-stat-card:first-child {
    grid-column: 1 / -1;
  }
}

/* ============================================================
   TRUE DASHBOARD APP LAYOUT
   ============================================================ */

.dashboard-app {
  width: min(1440px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 1.4rem 0 2.5rem;
}

.dashboard-admin-shell,
.dashboard-data-shell {
  animation: dashboard-card-enter 0.42s ease both;
}

.dashboard-admin-shell {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 1.25rem;
  align-items: stretch;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.dashboard-sidebar,
.dashboard-main,
.dashboard-data-shell {
  border: 1px solid rgba(255, 255, 255, 0.72);
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 20px 54px rgba(125, 65, 75, 0.1);
  backdrop-filter: blur(16px);
}

.dashboard-sidebar {
  position: sticky;
  top: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  height: calc(100vh - 2.5rem);
  min-height: 680px;
  padding: 1.15rem;
  border-radius: 28px;
}

.dashboard-sidebar-brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.45rem;
  color: var(--app-ink);
  text-decoration: none;
}

.brand-mark,
.admin-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 2.8rem;
  height: 2.8rem;
  border-radius: 18px;
  background: linear-gradient(135deg, #ffdce2, #de8794);
  color: #ffffff;
  font-weight: 900;
  box-shadow: 0 12px 24px rgba(200, 111, 126, 0.22);
}

.brand-mark-logo,
.portal-user-avatar-logo,
.admin-avatar-logo,
.profile-avatar-placeholder-logo,
.client-pet-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.brand-mark-logo img,
.portal-user-avatar-logo img,
.admin-avatar-logo img,
.profile-avatar-placeholder-logo img,
.client-pet-avatar img {
  width: 82%;
  height: 82%;
  object-fit: contain;
  display: block;
}

.dashboard-sidebar-brand strong,
.dashboard-admin-user strong {
  display: block;
  color: var(--app-ink);
  line-height: 1.1;
}

.dashboard-sidebar-brand small,
.dashboard-admin-user small {
  display: block;
  color: var(--app-muted);
  font-size: 0.78rem;
  margin-top: 0.15rem;
}

.dashboard-sidebar-nav {
  display: grid;
  gap: 0.85rem;
}

.sidebar-nav-group {
  display: grid;
  gap: 0.35rem;
  padding-bottom: 0.78rem;
  border-bottom: 1px solid rgba(232, 198, 202, 0.52);
}

.sidebar-nav-group:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.sidebar-nav-label {
  display: block;
  padding: 0.1rem 0.25rem 0.22rem;
  color: #a66670;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dashboard-sidebar-nav a,
.dashboard-sidebar-nav .nav-disabled {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  min-height: 46px;
  padding: 0.75rem 0.85rem;
  border-radius: 16px;
  color: #637083;
  font-weight: 800;
  text-decoration: none;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.dashboard-sidebar-nav a::before,
.dashboard-sidebar-nav .nav-disabled::before {
  content: "";
  width: 0.58rem;
  height: 0.58rem;
  border-radius: 999px;
  background: #f0cbd0;
  box-shadow: 0 0 0 5px rgba(240, 203, 208, 0.24);
  flex: 0 0 auto;
}

.dashboard-sidebar-nav .nav-disabled {
  justify-content: flex-start;
  color: #a4adba;
  cursor: not-allowed;
}

.dashboard-sidebar-nav .nav-disabled small {
  margin-left: auto;
}

.dashboard-sidebar-nav a:hover,
.dashboard-sidebar-nav a.active {
  background: linear-gradient(135deg, rgba(255, 238, 241, 0.92), rgba(255, 255, 255, 0.74));
  color: #7d414b;
  box-shadow: 0 10px 22px rgba(125, 65, 75, 0.08);
  transform: translateX(2px);
}

.dashboard-sidebar-nav a.active {
  box-shadow: 0 0 0 1px rgba(232, 180, 184, 0.35), 0 12px 24px rgba(217, 154, 160, 0.16);
}

.dashboard-main {
  display: grid;
  gap: 1.15rem;
  min-width: 0;
  padding: 1.25rem;
  border-radius: 30px;
}

.dashboard-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.dashboard-search {
  position: relative;
  flex: 1 1 420px;
  max-width: 560px;
}

.dashboard-search span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.dashboard-search input {
  width: 100%;
  min-height: 48px;
  padding: 0.85rem 1rem;
  border: 1px solid rgba(232, 198, 202, 0.78);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
  color: var(--app-ink);
  font: inherit;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.dashboard-search input:focus {
  outline: none;
  border-color: #d99aa0;
  box-shadow: 0 0 0 4px rgba(232, 180, 184, 0.18);
}

.dashboard-admin-user {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  min-width: max-content;
}

.dashboard-date-pill {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 0.8rem;
  border-radius: 999px;
  background: rgba(255, 240, 242, 0.92);
  color: #8c4d58;
  font-size: 0.82rem;
  font-weight: 900;
}

.admin-home {
  gap: 1rem;
  margin: 0;
}

.admin-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(190px, 0.28fr);
  gap: 1rem;
}

.admin-home-hero,
.admin-date-card {
  min-height: 188px;
}

.admin-date-card {
  display: grid;
  align-content: center;
  gap: 0.55rem;
  padding: 1.15rem;
  border: 1px solid var(--app-card-border);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 248, 249, 0.92));
  box-shadow: 0 12px 28px rgba(125, 65, 75, 0.08);
}

.admin-date-card strong {
  color: var(--app-ink);
  font-size: 1.4rem;
  letter-spacing: -0.03em;
}

.admin-date-card small {
  color: var(--app-muted);
  line-height: 1.35;
}

.admin-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.9fr);
  align-items: start;
  gap: 1rem;
}

.recent-requests-card .app-section-heading a {
  color: #9d5360;
  font-size: 0.84rem;
  font-weight: 900;
  text-decoration: none;
}

#admin-upcoming-schedule {
  max-height: 300px;
  overflow-y: auto;
  overscroll-behavior: contain;
}

.dashboard-data-shell {
  display: grid;
  gap: 1rem;
  margin: 1.25rem 0 0;
  padding: 1.2rem;
  border-radius: 30px;
}

body.portal-admin-mode .dashboard-data-shell {
  margin-left: calc(260px + 1.25rem);
}

.dashboard-management-heading {
  margin: 0;
  padding: 0;
  border: 0;
}

.admin-client-summary,
.admin-status-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.client-app-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  min-height: 180px;
  padding: 1.35rem;
  border: 1px solid rgba(255, 255, 255, 0.75);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.08)),
    linear-gradient(135deg, #ffe4e9 0%, #efadb8 54%, #fff7f8 100%);
  box-shadow: var(--app-shadow);
}

.client-app-hero::after {
  content: "";
  position: absolute;
  right: -4rem;
  bottom: -5rem;
  width: 15rem;
  aspect-ratio: 1;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.28);
}

.client-app-hero > * {
  position: relative;
  z-index: 1;
  align-self: end;
}

.client-app-hero h2 {
  margin: 0 0 0.45rem;
  color: #6f3340;
  font-size: clamp(2rem, 6vw, 3.2rem);
  line-height: 1;
  letter-spacing: -0.05em;
}

.client-app-hero p:last-child {
  margin: 0;
  max-width: 38rem;
  color: #754f58;
  line-height: 1.55;
}

.client-pet-card {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 1rem;
  border: 1px solid var(--app-card-border);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 12px 28px rgba(125, 65, 75, 0.07);
}

.client-pet-avatar {
  display: grid;
  place-items: center;
  flex: 0 0 3.35rem;
  width: 3.35rem;
  height: 3.35rem;
  border-radius: 20px;
  background: linear-gradient(135deg, #ffe6ea, #f4b8c1);
  color: #8c4d58;
}

.client-pet-avatar svg,
.client-pet-avatar img {
  width: 2rem;
  height: 2rem;
  object-fit: contain;
  display: block;
}

.client-pet-card strong {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.35rem;
}

.client-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 1rem;
}

.client-dashboard-grid .update-card {
  grid-column: 1 / -1;
}

.client-dashboard-grid .info-card,
.dashboard-data-shell .info-card,
.dashboard-data-shell .summary-stat,
.dashboard-data-shell .client-stat-card,
.dashboard-data-shell .app-section-card {
  border-radius: 24px;
}

.client-dashboard-grid .info-card {
  border-color: rgba(217, 154, 160, 0.38);
  box-shadow: 0 10px 28px rgba(125, 65, 75, 0.08), 0 2px 6px rgba(125, 65, 75, 0.03);
}

@media (min-width: 901px) {
  body.portal-admin-mode:has(.dashboard-admin-shell) .site-header {
    display: none;
  }
}

@media (max-width: 1100px) {
  .dashboard-admin-shell {
    grid-template-columns: 220px minmax(0, 1fr);
  }

  body.portal-admin-mode .dashboard-data-shell {
    margin-left: calc(220px + 1.25rem);
  }

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

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

@media (max-width: 900px) {
  .dashboard-app {
    width: min(100% - 1rem, 900px);
    padding-top: 0.8rem;
  }

  .dashboard-admin-shell {
    display: block;
  }

  .dashboard-sidebar {
    display: none;
  }

  .dashboard-main,
  .dashboard-data-shell {
    padding: 0.85rem;
    border-radius: 28px;
  }

  body.portal-admin-mode .dashboard-data-shell {
    margin-left: 0;
  }

  .dashboard-topbar,
  .admin-hero-grid,
  .admin-dashboard-grid,
  .client-dashboard-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-topbar {
    display: grid;
  }
}

@media (max-width: 640px) {
  .dashboard-app {
    padding-bottom: calc(5.75rem + env(safe-area-inset-bottom, 0px));
  }

  .dashboard-main,
  .dashboard-data-shell {
    gap: 0.8rem;
    padding: 0.7rem;
    border-radius: 26px;
    box-shadow: 0 14px 36px rgba(125, 65, 75, 0.1);
  }

  .dashboard-search {
    display: none;
  }

  .dashboard-admin-user {
    justify-content: space-between;
    width: 100%;
  }

  .admin-home-hero,
  .client-app-hero {
    min-height: 168px;
    border-radius: 24px;
  }

  .admin-home-stats,
  .client-stats-strip,
  .quick-actions,
  .quick-actions--admin,
  .dashboard-action-row,
  .admin-client-summary,
  .admin-status-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .quick-actions--admin .quick-action-card:last-child,
  .dashboard-action-row .button-link:first-child {
    grid-column: 1 / -1;
  }

  .app-stat-card,
  .client-stat-card,
  .quick-action-card,
  .button-link {
    min-height: 96px;
  }

  .client-pet-card,
  .info-card,
  .app-section-card {
    border-radius: 22px;
  }

  .client-pet-card strong {
    display: block;
  }
}

/* ============================================================
   PORTAL-WIDE MODERN APP SHELL
   ============================================================ */

:root {
  --app-bg: #fff7f8;
  --app-surface: rgba(255, 255, 255, 0.82);
  --app-surface-strong: rgba(255, 255, 255, 0.94);
  --app-border: rgba(232, 198, 202, 0.74);
  --app-pink-glow: rgba(217, 154, 160, 0.2);
  --app-radius: 26px;
}

.portal-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 7% 4%, rgba(255, 226, 231, 0.72), transparent 30%),
    radial-gradient(circle at 92% 14%, rgba(255, 255, 255, 0.92), transparent 24%),
    linear-gradient(180deg, #fff9fa 0%, #f8eef1 56%, #fffdfd 100%);
}

.portal-app-shell {
  display: grid;
  grid-template-columns: 246px minmax(0, 1fr);
  gap: 1.25rem;
  width: min(1320px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 1.4rem 0 2.6rem;
}

.portal-sidebar {
  position: sticky;
  top: 7.1rem;
  align-self: start;
  display: grid;
  gap: 1.15rem;
  min-height: 520px;
  padding: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.76);
  border-radius: 28px;
  background: var(--app-surface);
  box-shadow: 0 20px 54px rgba(125, 65, 75, 0.1);
  backdrop-filter: blur(16px);
}

.portal-sidebar-brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.45rem;
  color: var(--app-ink);
  text-decoration: none;
}

.portal-sidebar-brand strong,
.portal-sidebar-brand small {
  display: block;
}

.portal-sidebar-brand small {
  margin-top: 0.16rem;
  color: var(--app-muted);
  font-size: 0.78rem;
}

.portal-sidebar-nav {
  display: grid;
  gap: 0.35rem;
}

.portal-sidebar-nav a,
.portal-sidebar-nav .nav-disabled {
  display: flex;
  align-items: center;
  gap: 0.68rem;
  min-height: 46px;
  padding: 0.75rem 0.85rem;
  border-radius: 16px;
  color: #637083;
  font-weight: 850;
  text-decoration: none;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.portal-sidebar-nav a::before,
.portal-sidebar-nav .nav-disabled::before {
  content: "";
  display: inline-flex;
  width: 0.62rem;
  height: 0.62rem;
  border-radius: 999px;
  background: #f3c8ce;
  box-shadow: 0 0 0 5px rgba(243, 200, 206, 0.24);
  flex: 0 0 auto;
}

.portal-sidebar-nav .nav-disabled {
  color: #a4adba;
  cursor: not-allowed;
}

.portal-sidebar-nav .nav-disabled small {
  margin-left: auto;
}

.portal-sidebar-nav a:hover,
.portal-sidebar-nav a.active {
  background: linear-gradient(135deg, rgba(255, 238, 241, 0.94), rgba(255, 255, 255, 0.76));
  color: #7d414b;
  box-shadow: 0 10px 22px rgba(125, 65, 75, 0.08);
  transform: translateX(2px);
}

.portal-sidebar-nav a.active {
  box-shadow: 0 0 0 1px rgba(232, 180, 184, 0.35), 0 12px 24px rgba(217, 154, 160, 0.16);
}

.portal-page .site-header-actions > #logout-button {
  display: none;
}

.logout-trigger[hidden] {
  display: none !important;
}

.portal-userbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.85rem;
  min-height: 52px;
  margin-bottom: 0.9rem;
}

.portal-userbar-profile,
.dashboard-admin-user {
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.portal-userbar-profile {
  min-width: 0;
  padding: 0.35rem 0.4rem 0.35rem 0.35rem;
  border: 1px solid rgba(232, 198, 202, 0.62);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 10px 22px rgba(125, 65, 75, 0.055);
}

.portal-userbar-profile strong,
.portal-userbar-profile small {
  display: block;
  line-height: 1.1;
}

.portal-userbar-profile strong {
  color: var(--app-ink);
  font-size: 0.92rem;
}

.portal-userbar-profile small {
  margin-top: 0.14rem;
  color: var(--app-muted);
  font-size: 0.76rem;
  font-weight: 750;
}

.portal-user-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 2.35rem;
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 16px;
  background: linear-gradient(135deg, #ffdce2, #de8794);
  color: #ffffff;
  font-size: 0.78rem;
  font-weight: 950;
  box-shadow: 0 10px 20px rgba(200, 111, 126, 0.18);
}

.portal-logout-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.35rem;
  padding: 0.62rem 0.95rem;
  border: 1px solid rgba(232, 198, 202, 0.86);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: #7d414b;
  font: inherit;
  font-size: 0.86rem;
  font-weight: 850;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(125, 65, 75, 0.055);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}

.portal-logout-button:hover,
.portal-logout-button:focus-visible {
  border-color: rgba(217, 154, 160, 0.85);
  background: #fff7f8;
  box-shadow: 0 14px 28px rgba(125, 65, 75, 0.1);
  transform: translateY(-1px);
}

.portal-logout-button:focus-visible,
.tab-item--logout:focus-visible {
  outline: 3px solid rgba(232, 180, 184, 0.32);
  outline-offset: 2px;
}

.portal-content.panel,
.care-requests-content .panel {
  margin: 0;
  padding: 1.25rem;
  border: 1px solid rgba(255, 255, 255, 0.76);
  border-radius: 30px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 248, 249, 0.9)),
    radial-gradient(circle at 92% 8%, rgba(245, 199, 204, 0.23), transparent 28%);
  box-shadow: 0 24px 64px rgba(125, 65, 75, 0.12);
  backdrop-filter: blur(14px);
}

.care-requests-content {
  display: grid;
  gap: 1rem;
}

.portal-content > *,
.care-requests-content .panel > * {
  animation: dashboard-card-enter 0.44s ease both;
}

.portal-heading {
  padding: 0.1rem;
}

.portal-heading h2 {
  margin-bottom: 0.45rem;
  color: var(--app-ink);
  letter-spacing: -0.045em;
}

.section-banner {
  border-color: var(--app-border);
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(255, 246, 248, 0.96), rgba(255, 255, 255, 0.82));
  box-shadow: 0 10px 22px rgba(125, 65, 75, 0.055);
}

.app-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.35rem;
  height: 2.35rem;
  margin-bottom: 0.85rem;
  border-radius: 16px;
  background: linear-gradient(135deg, #ffe6ea, #f5bbc4);
  color: #7d414b;
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  box-shadow: 0 10px 22px rgba(200, 111, 126, 0.14);
}

.info-card,
.invoice-summary-card,
.client-update-composer,
.client-updates-timeline-section,
.cr-card,
.admin-toolbar,
.empty-state-card,
.chat-form,
.chat-thread,
.client-sidebar,
.profile-hero-card {
  border-color: var(--app-border);
  border-radius: 24px;
  background: var(--app-surface-strong);
  box-shadow: 0 12px 28px rgba(125, 65, 75, 0.07);
}

.info-card,
.invoice-summary-card,
.client-update-card,
.cr-card,
.profile-hero-card {
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.info-card:hover,
.invoice-summary-card:hover,
.client-update-card:hover,
.cr-card:hover,
.profile-hero-card:hover {
  transform: translateY(-2px);
  border-color: rgba(217, 154, 160, 0.72);
  box-shadow: 0 18px 38px rgba(125, 65, 75, 0.12);
}

.site-nav a.active {
  box-shadow: 0 0 0 1px rgba(217, 154, 160, 0.25), 0 10px 22px rgba(217, 154, 160, 0.22);
}

/* Messages */
.messages-panel {
  min-height: min(760px, calc(100vh - 10rem));
}

.messages-layout {
  grid-template-columns: minmax(240px, 0.34fr) minmax(0, 1fr);
}

.client-sidebar {
  align-content: start;
  min-height: 560px;
  padding: 0.7rem;
  background: linear-gradient(180deg, rgba(255, 251, 252, 0.96), rgba(255, 244, 246, 0.88));
}

.client-item {
  border-color: rgba(232, 198, 202, 0.7);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 8px 18px rgba(125, 65, 75, 0.055);
}

.client-item::before {
  content: "";
  width: 2rem;
  height: 2rem;
  border-radius: 14px;
  background: linear-gradient(135deg, #ffe8eb, #f6bec7);
  flex: 0 0 auto;
}

.client-item.active {
  border-color: #d99aa0;
  background: linear-gradient(135deg, #fff1f3, #ffffff);
  box-shadow: 0 12px 24px rgba(217, 154, 160, 0.16);
}

.unread-badge:not(:empty),
.nav-badge:not([hidden]) {
  animation: badge-pulse 2.2s ease-in-out infinite;
}

.chat-panel {
  min-width: 0;
  padding: 1rem;
  border: 1px solid var(--app-border);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.76);
}

.chat-header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.85rem;
  padding: 0 0 0.9rem;
  border-bottom-color: rgba(232, 198, 202, 0.82);
}

.chat-header .app-card-icon {
  margin: 0;
}

.chat-thread {
  min-height: 420px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 246, 248, 0.86));
}

.chat-bubble {
  border-radius: 22px;
}

.chat-message.jjcare .chat-bubble {
  background: #ffffff;
  border: 1px solid rgba(232, 198, 202, 0.72);
  color: var(--app-ink);
}

.chat-message.client .chat-bubble {
  background: linear-gradient(135deg, #df8d98, #c86f7e);
}

.chat-form button,
.invoice-pay-button,
.button-link {
  box-shadow: 0 12px 24px rgba(200, 111, 126, 0.18);
}

/* Care requests */
.request-status-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.request-status-strip span {
  display: grid;
  gap: 0.25rem;
  min-height: 86px;
  padding: 0.9rem;
  border: 1px solid var(--app-border);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.84);
  color: var(--app-muted);
  font-size: 0.86rem;
  line-height: 1.4;
}

.request-status-strip strong {
  color: var(--app-ink);
  font-size: 1rem;
}

.cr-list {
  gap: 0.85rem;
}

.cr-card {
  display: grid;
  gap: 0.65rem;
  padding: 1rem;
  cursor: pointer;
}

.cr-card-top {
  margin: 0;
}

.cr-card-name {
  margin: 0;
  letter-spacing: -0.02em;
}

.cr-card-meta,
.cr-card-preview,
.cr-card-date {
  margin: 0;
  line-height: 1.45;
}

.cr-detail-chip,
.cr-status-new,
.cr-status-contacted,
.cr-status-meetgreet,
.cr-status-approved,
.cr-status-declined,
.invoice-status-pill,
.status-pill,
.timestamp-chip,
.client-update-type {
  border-radius: 999px;
  font-weight: 850;
}

.cr-status-new {
  background: #fff0f2;
  border-color: #f3c8ce;
  color: #9d5360;
}

.cr-status-contacted {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #9a5a18;
}

.cr-status-approved {
  background: #f0fdf4;
  border-color: #bbf7d0;
  color: #166534;
}

.cr-status-declined {
  background: #fef2f2;
  border-color: #fecaca;
  color: #991b1b;
}

/* Payments */
.payments-panel .portal-grid {
  margin-bottom: 1rem;
}

.billing-summary-card {
  min-height: 160px;
}

.invoice-summary-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 246, 248, 0.92));
}

.invoice-service-box > div,
.invoice-pets-card,
.invoice-breakdown {
  border-color: var(--app-border);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.78);
}

.invoice-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.invoice-actions .invoice-pay-button {
  margin-top: 0;
}

.invoice-pay-button--secondary {
  border: 1px solid var(--app-border);
  background: rgba(255, 255, 255, 0.88);
  color: #7d414b;
}

/* Updates */
.updates-panel .portal-grid {
  margin-bottom: 1rem;
}

.client-updates-timeline-section {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 246, 248, 0.9));
}

.client-updates-timeline {
  position: relative;
  padding-left: 1rem;
}

.client-updates-timeline::before {
  content: "";
  position: absolute;
  left: 0.15rem;
  top: 0.35rem;
  bottom: 0.35rem;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(180deg, #f5bbc4, rgba(245, 187, 196, 0));
}

.client-update-card {
  position: relative;
  border-color: var(--app-border);
  border-radius: 22px;
}

.client-update-card::before {
  content: "";
  position: absolute;
  left: -1.13rem;
  top: 1.1rem;
  width: 0.7rem;
  height: 0.7rem;
  border: 3px solid #fff7f8;
  border-radius: 999px;
  background: #d99aa0;
}

.empty-state-card {
  border-style: dashed;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(255, 246, 248, 0.74));
}

.empty-state-icon {
  min-width: 0;
  height: 2.35rem;
  border-radius: 16px;
  background: linear-gradient(135deg, #ffe6ea, #f5bbc4);
}

/* Profile */
.profile-hero-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 1rem;
  background: linear-gradient(135deg, rgba(255, 240, 243, 0.96), rgba(255, 255, 255, 0.86));
}

.profile-avatar-placeholder {
  display: grid;
  place-items: center;
  flex: 0 0 4.6rem;
  width: 4.6rem;
  height: 4.6rem;
  border-radius: 24px;
  background: linear-gradient(135deg, #ffdce2, #de8794);
  color: #ffffff;
  font-size: 1.35rem;
  font-weight: 950;
  box-shadow: 0 14px 28px rgba(200, 111, 126, 0.2);
}

.profile-hero-card h3,
.profile-hero-card p {
  margin: 0;
}

.profile-hero-card h3 {
  margin-top: 0.25rem;
  font-size: 1.25rem;
  letter-spacing: -0.025em;
}

.profile-hero-card p {
  margin-top: 0.3rem;
  color: var(--app-muted);
  line-height: 1.55;
}

.profile-info-card {
  min-height: 190px;
}

.profile-info-card--wide {
  grid-column: 1 / -1;
}

.profile-policy-intro {
  margin: 0 0 1rem;
  color: var(--app-muted);
  font-size: 0.9rem;
}

.profile-policy-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.65rem;
}

.policy-card {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.85rem 1rem;
  background: var(--app-pink-soft);
  border: 1px solid var(--app-card-border);
  border-radius: 14px;
  text-decoration: none;
  color: var(--app-ink);
  font-weight: 500;
  font-size: 0.9rem;
  transition: background 0.15s, border-color 0.15s;
  min-height: 52px;
}

.policy-card:hover,
.policy-card:focus-visible {
  background: #fce8eb;
  border-color: var(--app-pink);
  text-decoration: none;
}

.policy-card-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--app-rose);
  display: flex;
  align-items: center;
  justify-content: center;
}

.policy-card-icon svg {
  width: 18px;
  height: 18px;
}

.policy-card-label {
  flex: 1;
  line-height: 1.3;
}

.policy-card-arrow {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  color: var(--app-muted);
}

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

/* Mobile app surface */
@media (max-width: 900px) {
  .portal-app-shell {
    grid-template-columns: 1fr;
    width: min(100% - 1rem, 900px);
    padding-top: 0.8rem;
  }

  .portal-sidebar {
    display: none;
  }

  .portal-content.panel,
  .care-requests-content .panel {
    padding: 0.85rem;
    border-radius: 28px;
  }

  .messages-layout,
  .chat-header,
  .request-status-strip,
  .invoice-actions {
    grid-template-columns: 1fr;
  }

  .client-sidebar {
    min-height: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .chat-panel {
    padding: 0.75rem;
    border-radius: 24px;
  }
}

@media (max-width: 640px) {
  .portal-page .site-header {
    border-bottom-color: rgba(232, 198, 202, 0.65);
    background: rgba(255, 255, 255, 0.82);
  }

  .portal-app-shell {
    width: min(100% - 0.8rem, 640px);
    padding-bottom: calc(5.9rem + env(safe-area-inset-bottom, 0px));
  }

  .portal-content.panel,
  .care-requests-content .panel {
    padding: 0.72rem;
    border-radius: 26px;
  }

  .portal-heading h2 {
    font-size: 1.72rem;
  }

  .section-banner,
  .info-card,
  .invoice-summary-card,
  .client-update-composer,
  .client-updates-timeline-section,
  .empty-state-card,
  .profile-hero-card {
    border-radius: 22px;
  }

  .client-sidebar {
    grid-template-columns: 1fr;
  }

  .client-item {
    justify-content: flex-start;
    text-align: left;
  }

  .chat-thread {
    min-height: 360px;
    max-height: 58vh;
  }

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

  .invoice-summary-header,
  .invoice-row {
    align-items: flex-start;
  }

  .invoice-row {
    flex-direction: column;
    gap: 0.25rem;
  }

  .profile-hero-card {
    align-items: flex-start;
  }

  .profile-avatar-placeholder {
    flex-basis: 3.6rem;
    width: 3.6rem;
    height: 3.6rem;
    border-radius: 20px;
    font-size: 1rem;
  }

  .profile-info-card--wide {
    grid-column: auto;
  }

  .portal-userbar {
    display: none;
  }

  .bottom-tab-bar {
    margin: 0.45rem;
    left: 0;
    right: 0;
    bottom: 0;
    border: 1px solid rgba(232, 198, 202, 0.9);
    border-radius: 24px;
    box-shadow: 0 -8px 32px rgba(125, 65, 75, 0.16);
  }

  .tab-item {
    min-height: 64px;
    border-radius: 20px;
  }

  .bottom-tab-bar .tab-item--logout {
    border: 0;
    background: transparent;
    color: #9d5360;
    font: inherit;
    cursor: pointer;
  }

  .bottom-tab-bar .tab-item--logout:hover,
  .bottom-tab-bar .tab-item--logout:active {
    background: radial-gradient(circle at center, rgba(232, 180, 184, 0.22), transparent 58%);
    color: var(--primary-hover);
  }

  .bottom-tab-bar .tab-item--more {
    border: 0;
    background: transparent;
    font: inherit;
    cursor: pointer;
  }
}

@media (max-width: 900px) {
  .admin-toolbar {
    flex-wrap: wrap;
  }

  .admin-toolbar-group--actions {
    margin-left: 0;
  }

  .admin-booking-calendar {
    padding: 0.85rem;
    gap: 0.85rem;
    margin-bottom: calc(8.75rem + env(safe-area-inset-bottom, 0px));
  }

  .admin-booking-calendar-header,
  .admin-booking-calendar-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .admin-booking-calendar--workspace .admin-booking-calendar-header {
    top: 0;
    margin: -0.85rem -0.85rem 0;
    padding: 0.85rem;
    border-bottom: 1px solid rgba(238, 223, 226, 0.9);
  }

  .admin-booking-calendar-actions .admin-toolbar-button {
    width: 100%;
  }

  .admin-booking-calendar-view-switcher {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    width: 100%;
    border-radius: 18px;
  }

  .admin-calendar-view-tab {
    min-height: 2.45rem;
    padding: 0.45rem 0.5rem;
  }

  .admin-booking-calendar-availability {
    padding: 0.8rem;
  }

  .admin-booking-calendar-availability-fields {
    grid-template-columns: 1fr;
  }

  .admin-booking-calendar-availability-fields .admin-toolbar-button {
    width: 100%;
  }

  .admin-booking-calendar-availability-day dl {
    grid-template-columns: 1fr;
  }

  .admin-booking-calendar-availability-day dt {
    margin-top: 0.2rem;
  }

  .admin-booking-calendar-legend-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .admin-booking-calendar-legend {
    display: flex;
    max-height: 0;
    opacity: 0;
    transform: translateY(-0.25rem);
    pointer-events: none;
  }

  .admin-booking-calendar--legend-open .admin-booking-calendar-legend {
    max-height: 12rem;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  .admin-booking-calendar-body {
    overflow-x: visible;
    padding-bottom: 1.25rem;
  }

  .admin-booking-calendar-weekdays,
  .admin-booking-calendar-grid {
    display: none;
  }

  .admin-booking-calendar--list-view .admin-booking-calendar-agenda,
  .admin-booking-calendar--week-view .admin-booking-calendar-agenda {
    display: grid;
    gap: 0.85rem;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-weekdays {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.25rem;
    min-width: 0;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.25rem;
    min-width: 0;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-day {
    min-height: 5.25rem;
    padding: 0.48rem 0.4rem;
    border-radius: 12px;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-weekdays span {
    font-size: 0.65rem;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-date {
    min-width: 1.9rem;
    min-height: 1.9rem;
    font-size: 0.78rem;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-events {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.18rem;
    margin-top: 0.25rem;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.35rem;
    height: 1.35rem;
    min-height: 0;
    padding: 0;
    border-radius: 999px;
    font-size: 0.56rem;
    font-weight: 900;
    line-height: 1;
    text-align: center;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event strong,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-client,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-service,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-payment,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-time,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-action,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-source-badge {
    display: none;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-initials {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: 100%;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event:nth-of-type(n + 4) {
    display: none;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 1.35rem;
    min-width: 1.35rem;
    padding: 0 0.22rem;
    border-radius: 999px;
    background: #f0f4f8;
    color: #52606d;
    font-size: 0.58rem;
    font-weight: 900;
    line-height: 1;
  }

  .admin-booking-calendar--month-view::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 119;
    background: rgba(31, 41, 51, 0.24);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
  }

  .admin-booking-calendar--month-view.admin-booking-calendar--day-details-open::before {
    opacity: 1;
    pointer-events: auto;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-day-details {
    position: fixed;
    right: 0;
    bottom: calc(8.35rem + env(safe-area-inset-bottom, 0px));
    left: 0;
    z-index: 120;
    max-height: min(72vh, 34rem);
    margin: 0;
    padding: 1rem;
    border-radius: 22px 22px 0 0;
    box-shadow: 0 -18px 38px rgba(15, 23, 42, 0.18);
    overflow-y: auto;
    pointer-events: none;
    transform: translateY(110%);
    transition: transform 0.24s ease;
    visibility: hidden;
  }

  .admin-booking-calendar--month-view.admin-booking-calendar--day-details-open .admin-booking-calendar-day-details {
    pointer-events: auto;
    transform: translateY(0);
    visibility: visible;
  }

  .admin-booking-calendar-day-details-close {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
  }

  .admin-booking-calendar-week-overview {
    grid-template-columns: 1fr;
    min-width: 0;
  }

  .admin-booking-calendar-agenda-day {
    display: grid;
    gap: 0.65rem;
    padding: 0.85rem;
    border: 1px solid #eedfe2;
    border-radius: 18px;
    background: #ffffff;
  }

  .admin-booking-calendar-agenda-day h4 {
    margin: 0;
    color: #7d3f4c;
    font-size: 0.95rem;
  }

  .admin-booking-calendar-agenda-events {
    display: grid;
    gap: 0.55rem;
  }

  .admin-booking-calendar-event--agenda {
    min-height: 58px;
    padding: 0.75rem 0.9rem;
    font-size: 0.88rem;
  }

  .admin-booking-calendar-event--agenda strong {
    font-size: 0.95rem;
  }

  .admin-booking-calendar-capacity {
    font-size: 0.58rem;
  }

  .admin-booking-calendar-bottom-controls {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.45rem;
    position: fixed;
    right: 0;
    bottom: calc(4.4rem + env(safe-area-inset-bottom, 0px));
    left: 0;
    z-index: 190;
    padding: 0.55rem 0.75rem;
    border-top: 1px solid rgba(232, 198, 202, 0.9);
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(12px);
    box-shadow: 0 -10px 24px rgba(125, 65, 75, 0.1);
  }

  .admin-booking-calendar-bottom-controls .admin-toolbar-button {
    min-height: 2.4rem;
    padding: 0.45rem 0.35rem;
    font-size: 0.82rem;
    font-weight: 700;
  }

  .admin-calendar-mobile-nav-btn:first-child,
  .admin-calendar-mobile-nav-btn:last-child {
    font-size: 1.05rem;
  }

  .admin-booking-calendar-agenda-empty {
    margin: 0;
    padding: 1rem;
    border: 1px solid #eedfe2;
    border-radius: 18px;
    background: #ffffff;
    color: #52606d;
    line-height: 1.45;
  }

  .admin-back-to-top {
    right: 1rem;
    bottom: calc(6.1rem + env(safe-area-inset-bottom, 0px));
  }
}

/* ── Calendar Workspace Page ─────────────────────────────────── */

.calendar-panel {
  display: grid;
  align-content: start;
  gap: 0;
}

.calendar-page-heading {
  margin-bottom: 0.25rem;
}

.admin-booking-calendar--workspace {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.admin-booking-calendar--workspace .admin-booking-calendar-header {
  padding-bottom: 0.85rem;
  border-bottom: 1px solid #eedfe2;
  margin-bottom: 0.85rem;
}

.admin-booking-calendar--workspace .admin-booking-calendar-body {
  overflow-x: auto;
}

@media (max-width: 900px) {
  .admin-booking-calendar--workspace {
    margin-bottom: calc(8.75rem + env(safe-area-inset-bottom, 0px));
  }

  .admin-booking-calendar--workspace .admin-booking-calendar-header {
    top: 0;
    margin: -0.85rem -0.85rem 0;
    padding: 0.85rem;
    border-bottom: 1px solid rgba(238, 223, 226, 0.9);
  }

  .admin-booking-calendar--workspace .admin-booking-calendar-actions {
    display: none;
  }

  .admin-booking-calendar--workspace .admin-booking-calendar-body {
    overflow-x: visible;
    padding-bottom: 1.25rem;
  }

  .admin-booking-calendar-availability-results {
    max-height: min(58vh, 31rem);
  }

  .admin-booking-calendar-availability-summary {
    top: 0;
    border-radius: 12px;
  }

  .admin-booking-calendar-availability-summary-head {
    display: grid;
    gap: 0.18rem;
  }

  .admin-booking-calendar-availability-day summary {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .admin-booking-calendar-availability-day summary .admin-booking-calendar-capacity {
    grid-column: 1;
    width: fit-content;
  }

  .admin-booking-calendar-availability-day summary > span:last-child {
    grid-column: 2;
    grid-row: 2;
    justify-self: end;
  }

  .admin-booking-calendar-availability-day dl {
    grid-template-columns: 1fr;
  }
}

/* ── Dashboard Compact Upcoming Card ─────────────────────────── */

.admin-upcoming-card {
  margin: 1rem 0 0;
}

.admin-upcoming-calendar-link {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.8rem;
  border: 1.5px solid #d99aa0;
  border-radius: 999px;
  color: #7d414b;
  font-size: 0.78rem;
  font-weight: 800;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease;
  white-space: nowrap;
}

.admin-upcoming-calendar-link:hover {
  background: #fff4f6;
  border-color: #b76d78;
}

.admin-upcoming-list {
  display: grid;
  gap: 0.55rem;
}

.admin-upcoming-day {
  display: grid;
  gap: 0.35rem;
}

.admin-upcoming-day-label {
  color: #52606d;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.admin-upcoming-events {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}

.admin-upcoming-pill {
  display: inline-block;
  padding: 0.28rem 0.6rem;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.3;
}

.admin-upcoming-pill--dropoff {
  background: #f0faf3;
  border: 1px solid #76bd88;
  color: #166534;
}

.admin-upcoming-pill--pickup {
  background: #fff4f5;
  border: 1px solid #e99aa4;
  color: #9f1d2d;
}

.admin-upcoming-pill--stay {
  background: #f7f9fd;
  border: 1px solid #c8d8f0;
  color: #1e40af;
}

.admin-upcoming-pill--turnover {
  background: linear-gradient(135deg, #f0faf3 0%, #fff4f5 100%);
  border: 1px solid #c8b97a;
  color: #5c4a12;
}

.admin-upcoming-pill--meetandgreet {
  background: #f5f3ff;
  border: 1px solid #c4b5fd;
  color: #5b21b6;
}

/* Launch-readiness polish */
.auth-intro .portal-kicker {
  font-size: 0.9rem;
  letter-spacing: 0.08em;
}

.auth-logo,
.auth-intro .portal-kicker,
.auth-intro h2,
.auth-google-button {
  animation: auth-enter 0.52s ease both;
}

.auth-intro .portal-kicker {
  animation-delay: 0.08s;
}

.auth-intro h2 {
  animation-delay: 0.16s;
}

.auth-google-button {
  animation-delay: 0.24s;
}

.app-stat-card:has(#admin-stat-unread-messages),
.app-stat-card:has(#admin-stat-pending-requests),
.app-stat-card:has(#admin-stat-pending-payments),
.app-section-card:has(#admin-today-schedule),
.app-section-card--attention-open,
.recent-requests-card {
  border-color: rgba(217, 154, 160, 0.95);
  box-shadow: 0 18px 40px rgba(125, 65, 75, 0.12);
}

.app-list-item-headline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.app-list-item-badge {
  flex: 0 0 auto;
  padding: 0.28rem 0.56rem;
  border-radius: 999px;
  background: #f8fbff;
  color: #365a7a;
  font-size: 0.7rem;
  font-weight: 900;
  line-height: 1.2;
}

.app-list-item--dropoff {
  border-color: #86c99b;
  background: linear-gradient(180deg, #f0fff4 0%, #ffffff 100%);
}

.app-list-item--pickup {
  border-color: #ee9ca5;
  background: linear-gradient(180deg, #fff3f4 0%, #ffffff 100%);
}

.app-list-item--active {
  border-color: #b8c7e6;
  background: linear-gradient(180deg, #f4f8ff 0%, #ffffff 100%);
}

.app-list-item-badge--dropoff {
  background: #dff7e6;
  color: #166534;
}

.app-list-item-badge--pickup {
  background: #ffe0e3;
  color: #9f1d2d;
}

.app-list-item-badge--active {
  background: #e7efff;
  color: #274c77;
}
.app-list-item-badge--payment-pending {
  background: #fef3c7;
  color: #78350f;
}

.admin-booking-calendar-note {
  margin: 0.35rem 0 0;
  color: var(--app-muted);
  font-size: 0.84rem;
  line-height: 1.45;
}

.admin-booking-calendar-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  overflow: hidden;
  transition: max-height 0.22s ease, opacity 0.18s ease, transform 0.18s ease;
}

.admin-booking-calendar-legend-shell {
  display: grid;
  gap: 0.5rem;
}

.admin-booking-calendar-mobile-month {
  display: none;
}

.admin-booking-calendar-legend-toggle {
  display: none;
  min-height: 2.35rem;
  width: fit-content;
  padding: 0.45rem 0.8rem;
  border: 1px solid #d9e2ec;
  border-radius: 999px;
  background: #ffffff;
  color: #41546a;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 850;
  cursor: pointer;
}

.admin-booking-calendar-availability {
  display: grid;
  gap: 0.75rem;
  padding: 0.85rem;
  border: 1px solid #e2ead8;
  border-radius: 14px;
  background: #fbfdf8;
}

.admin-booking-calendar-availability h4,
.admin-booking-calendar-availability p {
  margin: 0;
}

.admin-booking-calendar-availability-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.admin-booking-calendar-availability-close {
  display: none;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.24rem 0.68rem;
  border: 1.5px solid rgba(217, 154, 160, 0.9);
  border-radius: 999px;
  background: #fff7f8;
  color: #7d414b;
  font: inherit;
  font-size: 0.74rem;
  font-weight: 850;
  line-height: 1;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.admin-booking-calendar--availability-open .admin-booking-calendar-availability-close {
  display: inline-flex;
}

.admin-booking-calendar-availability-close:hover,
.admin-booking-calendar-availability-close:focus-visible {
  border-color: #b76d78;
  background: #fff0f2;
  color: #63313a;
}

.admin-booking-calendar-availability-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 13rem)) auto;
  align-items: end;
  gap: 0.65rem;
}

.admin-booking-calendar-availability-fields label {
  display: grid;
  gap: 0.3rem;
  color: #52606d;
  font-size: 0.78rem;
  font-weight: 800;
}

.admin-booking-calendar-availability-fields input {
  min-height: 2.55rem;
  width: 100%;
  border: 1px solid #d9e2ec;
  border-radius: 10px;
  padding: 0.45rem 0.65rem;
  background: #ffffff;
  color: #1f2933;
  font: inherit;
}

.admin-booking-calendar-availability-result:empty {
  display: none;
}

.admin-booking-calendar-availability-results {
  max-height: min(64vh, 34rem);
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 0.15rem;
}

.admin-booking-calendar-availability-summary {
  position: sticky;
  top: 0;
  z-index: 5;
  display: grid;
  gap: 0.6rem;
  padding: 0.75rem;
  border: 1px solid #d7e8ca;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 10px 22px rgba(79, 90, 53, 0.08);
}

.admin-booking-calendar-availability-summary-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  color: #4f5a35;
  font-size: 0.82rem;
  font-weight: 850;
}

.admin-booking-calendar-availability-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.admin-booking-calendar-availability-metrics span {
  display: inline-flex;
  gap: 0.25rem;
  padding: 0.35rem 0.55rem;
  border-radius: 999px;
  background: #f7faf2;
  color: #41546a;
  font-size: 0.76rem;
  font-weight: 800;
}

.admin-booking-calendar-availability-recommendation {
  margin: 0;
  padding: 0.55rem 0.65rem;
  border-radius: 10px;
  background: #ecfdf3;
  color: #166534;
  font-size: 0.86rem;
  font-weight: 900;
}

.admin-booking-calendar-availability-summary[data-recommendation-level="filling"] .admin-booking-calendar-availability-recommendation {
  background: #fef9c3;
  color: #854d0e;
}

.admin-booking-calendar-availability-summary[data-recommendation-level="full"] .admin-booking-calendar-availability-recommendation {
  background: #fee2e2;
  color: #991b1b;
}

.admin-booking-calendar-availability-summary[data-recommendation-level="over"] .admin-booking-calendar-availability-recommendation {
  background: #450a0a;
  color: #fca5a5;
}

.admin-booking-calendar-availability-summary[data-recommendation-level="blocked"] .admin-booking-calendar-availability-recommendation {
  background: #1f2937;
  color: #f8fafc;
}

.admin-booking-calendar-availability-days {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.65rem;
}

.admin-booking-calendar-availability-day {
  display: grid;
  gap: 0;
  padding: 0;
  border: 1px solid #e2ead8;
  border-radius: 12px;
  background: #ffffff;
  overflow: hidden;
}

.admin-booking-calendar-availability-day summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto auto;
  align-items: center;
  gap: 0.55rem;
  min-height: 3.4rem;
  padding: 0.7rem 0.75rem;
  cursor: pointer;
  list-style: none;
}

.admin-booking-calendar-availability-day summary::-webkit-details-marker {
  display: none;
}

.admin-booking-calendar-availability-day summary::after {
  content: "+";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 999px;
  background: #f0f4f8;
  color: #52606d;
  font-weight: 900;
}

.admin-booking-calendar-availability-day[open] summary::after {
  content: "−";
}

.admin-booking-calendar-availability-day-main {
  display: grid;
  gap: 0.15rem;
  min-width: 0;
}

.admin-booking-calendar-availability-day-main strong {
  margin: 0;
  color: #4f5a35;
  font-size: 0.85rem;
}

.admin-booking-calendar-availability-day-main span,
.admin-booking-calendar-availability-day summary > span:last-child {
  min-width: 0;
  color: #52606d;
  font-size: 0.76rem;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-booking-calendar-availability-day dl {
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: 0.3rem 0.65rem;
  margin: 0;
  padding: 0 0.75rem 0.75rem;
  font-size: 0.78rem;
}

.admin-booking-calendar-availability-day dt {
  color: #52606d;
  font-weight: 850;
}

.admin-booking-calendar-availability-day dd {
  min-width: 0;
  margin: 0;
  overflow-wrap: anywhere;
}

.admin-booking-calendar-availability-meet-greet {
  display: grid;
  gap: 0.1rem;
  margin-bottom: 0.45rem;
}

.admin-booking-calendar-availability-meet-greet:last-child {
  margin-bottom: 0;
}

.admin-booking-calendar-legend-item {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0.35rem 0.65rem;
  border: 1px solid #d9e2ec;
  border-radius: 999px;
  background: #ffffff;
  color: #41546a;
  font-size: 0.76rem;
  font-weight: 850;
}

.admin-booking-calendar-legend-item--dropoff {
  border-color: #9bd4aa;
  background: #ecf8ef;
  color: #166534;
}

.admin-booking-calendar-legend-item--pickup {
  border-color: #efb4bb;
  background: #fff0f1;
  color: #9f1d2d;
}

.admin-booking-calendar-legend-item--stay {
  border-color: #c4d3ec;
  background: #f4f8ff;
  color: #274c77;
}

.admin-booking-calendar-legend-item--meetandgreet {
  border-color: #c4b5fd;
  background: #f5f3ff;
  color: #5b21b6;
}

.admin-booking-calendar-legend-item--availabilityblock {
  border-color: #a8b3c1;
  background: #f3f5f7;
  color: #334155;
}

.admin-booking-calendar-legend .admin-booking-calendar-source-badge {
  min-height: 2rem;
  padding: 0.35rem 0.65rem;
  font-size: 0.76rem;
  font-weight: 850;
}

.admin-booking-calendar-event--dropoff {
  border-color: #76bd88;
  background: #f0faf3;
}

.admin-booking-calendar-event--stay {
  border-color: #c8d8f0;
  background: #f7f9fd;
}

.admin-booking-calendar-event--pickup {
  border-color: #e99aa4;
  background: #fff4f5;
}

.admin-booking-calendar-event--meetandgreet {
  border-color: #c4b5fd;
  background: #f5f3ff;
}

.admin-booking-calendar-event--availabilityblock {
  border-color: #a8b3c1;
  background: #f3f5f7;
}

.admin-booking-calendar-event--availabilityblock .admin-booking-calendar-event-action {
  color: #334155;
}

.admin-booking-calendar-unavailable-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-top: 0.15rem;
  padding: 0.12rem 0.45rem;
  border-radius: 4px;
  background: #334155;
  color: #f8fafc;
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  line-height: 1.5;
  text-transform: uppercase;
}

.admin-booking-calendar-source-badge {
  display: inline-flex;
  align-items: center;
  margin-top: 0.15rem;
  padding: 0.1rem 0.4rem;
  border-radius: 4px;
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  line-height: 1.5;
  text-transform: uppercase;
}

.admin-booking-calendar-source-badge--jjcare {
  background: #fef3c7;
  color: #78350f;
}

.admin-booking-calendar-source-badge--rover {
  background: #1c1917;
  color: #e7e5e4;
}

.admin-booking-calendar-day-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.25rem;
}

.admin-booking-calendar-capacity {
  padding: 0.1rem 0.35rem;
  border-radius: 4px;
  background: #f0f4f8;
  color: #627282;
  font-size: 0.62rem;
  font-weight: 800;
  line-height: 1.5;
  white-space: nowrap;
}

/* Graduated capacity colors */
.admin-booking-calendar-capacity[data-capacity-level="light"] {
  background: #dcfce7;
  color: #166534;
}

.admin-booking-calendar-capacity[data-capacity-level="filling"] {
  background: #fef9c3;
  color: #854d0e;
}

.admin-booking-calendar-capacity[data-capacity-level="full"],
.admin-booking-calendar-capacity[data-full="true"] {
  background: #fee2e2;
  color: #991b1b;
}

.admin-booking-calendar-capacity[data-capacity-level="over"] {
  background: #450a0a;
  color: #fca5a5;
}

/* Capacity badge inside day-details header */
.admin-booking-calendar-capacity--detail {
  font-size: 0.72rem;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
}

/* Day details heading row (date + capacity badge) */
.admin-booking-calendar-day-details-heading-wrap {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  min-width: 0;
}

.admin-booking-calendar-day-details-heading-wrap h4 {
  margin: 0;
}

/* Event wrapper (event card + ICS button) */
.admin-booking-calendar-event-wrap {
  display: grid;
  gap: 0.4rem;
}

.admin-booking-calendar-block-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.admin-booking-calendar-selected-event {
  display: grid;
  gap: 0.55rem;
  padding: 0.75rem;
  border: 1px solid #efd2d7;
  border-radius: 8px;
  background: #fff8f9;
}

.admin-booking-calendar-selected-event h5 {
  margin: 0;
  color: #7d3f4c;
  font-size: 0.86rem;
}

.admin-booking-calendar-selected-event-list {
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  gap: 0.35rem 0.7rem;
  margin: 0;
  font-size: 0.8rem;
}

.admin-booking-calendar-selected-event-list dt {
  color: #7d4b52;
  font-weight: 800;
}

.admin-booking-calendar-selected-event-list dd {
  min-width: 0;
  margin: 0;
  color: #33272a;
  overflow-wrap: anywhere;
}

/* Add to Calendar .ics export button */
.admin-booking-calendar-ics-button {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.3rem 0.75rem;
  border: 1.5px solid #d99aa0;
  border-radius: 999px;
  background: #fff;
  color: #7d414b;
  font: inherit;
  font-size: 0.72rem;
  font-weight: 800;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
  width: fit-content;
}

.admin-booking-calendar-ics-button::before {
  content: "+";
  font-size: 0.9rem;
  font-weight: 900;
  line-height: 1;
}

.admin-booking-calendar-ics-button:hover {
  background: #fff4f6;
  border-color: #b76d78;
}

.admin-booking-calendar-ics-helper {
  max-width: 28rem;
  margin: -0.15rem 0 0;
  color: #6b7280;
  font-size: 0.72rem;
  line-height: 1.35;
}

.admin-booking-calendar-bottom-controls {
  display: none;
}

@media (max-width: 900px) {
  .admin-booking-calendar-legend-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .admin-booking-calendar-legend-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.45rem;
    position: sticky;
    top: 4.45rem;
    z-index: 25;
    padding: 0.35rem 0;
    background: rgba(255, 253, 253, 0.96);
  }

  .admin-booking-calendar-mobile-month {
    display: inline-flex;
    align-items: center;
    min-width: 0;
    width: fit-content;
    min-height: 1.8rem;
    padding: 0.18rem 0.62rem;
    border: 1px solid rgba(217, 226, 236, 0.9);
    border-radius: 999px;
    background: #ffffff;
    color: #41546a;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1.2;
    white-space: nowrap;
  }

  .admin-booking-calendar-legend {
    grid-column: 1 / -1;
    display: flex;
    max-height: 0;
    opacity: 0;
    transform: translateY(-0.25rem);
    pointer-events: none;
  }

  .admin-booking-calendar--legend-open .admin-booking-calendar-legend {
    max-height: 12rem;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  .admin-booking-calendar-availability-results {
    max-height: min(58vh, 31rem);
  }

  .admin-booking-calendar-availability {
    padding: 0.8rem;
  }

  .admin-booking-calendar--availability-open .admin-booking-calendar-availability-close {
    min-height: 1.9rem;
  }

  .admin-booking-calendar-availability-fields {
    grid-template-columns: 1fr;
  }

  .admin-booking-calendar-availability-fields .admin-toolbar-button {
    width: 100%;
  }

  .admin-booking-calendar-availability-summary-head {
    display: grid;
    gap: 0.18rem;
  }

  .admin-booking-calendar-availability-day summary {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .admin-booking-calendar-availability-day summary .admin-booking-calendar-capacity {
    grid-column: 1;
    width: fit-content;
  }

  .admin-booking-calendar-availability-day summary > span:last-child {
    grid-column: 2;
    grid-row: 2;
    justify-self: end;
  }

  .admin-booking-calendar-availability-day dl {
    grid-template-columns: 1fr;
  }

  .admin-booking-calendar-availability-day dt {
    margin-top: 0.2rem;
  }

  .admin-booking-calendar-bottom-controls {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.45rem;
    position: fixed;
    right: 0;
    bottom: calc(4.4rem + env(safe-area-inset-bottom, 0px));
    left: 0;
    z-index: 190;
    padding: 0.55rem 0.75rem;
    border-top: 1px solid rgba(232, 198, 202, 0.9);
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(12px);
    box-shadow: 0 -10px 24px rgba(125, 65, 75, 0.1);
  }

  .admin-booking-calendar-bottom-controls .admin-toolbar-button {
    min-height: 2.4rem;
    padding: 0.45rem 0.35rem;
    font-size: 0.82rem;
    font-weight: 700;
  }

  .admin-calendar-mobile-nav-btn:first-child,
  .admin-calendar-mobile-nav-btn:last-child {
    font-size: 1.05rem;
  }
}

@media (max-width: 768px) {
  body.portal-page-calendar {
    overflow-x: hidden;
  }

  .portal-page-calendar .site-header,
  .calendar-workspace-shell,
  .calendar-workspace-panel,
  #calendar-workspace-body,
  .admin-booking-calendar,
  .admin-booking-calendar--workspace,
  .admin-booking-calendar-body {
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  .calendar-workspace-shell {
    width: min(100% - 0.5rem, 768px);
    gap: 0;
  }

  .calendar-workspace-panel {
    overflow-x: hidden;
    padding-inline: 0.5rem;
    border-radius: 20px;
  }

  .admin-booking-calendar,
  .admin-booking-calendar--workspace {
    gap: 0.65rem;
    margin: 0 0 calc(5.75rem + env(safe-area-inset-bottom, 0px));
    padding: 0;
    overflow-x: hidden;
  }

  .admin-booking-calendar--workspace .admin-booking-calendar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-width: 0;
    margin: 0 0 0.45rem;
    padding: 0.45rem 0.05rem 0.55rem;
    border-bottom: 1px solid rgba(238, 223, 226, 0.86);
    background: rgba(255, 253, 253, 0.96);
  }

  .admin-booking-calendar-header > div:first-child {
    min-width: 0;
  }

  .admin-booking-calendar-header .portal-kicker {
    margin-bottom: 0.05rem;
    font-size: 0.66rem;
  }

  .admin-booking-calendar-header h3 {
    margin: 0;
    font-size: 1rem;
    line-height: 1.15;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-booking-calendar-view-switcher {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.18rem;
    width: 100%;
    padding: 0.18rem;
    border-radius: 14px;
  }

  .admin-calendar-view-tab {
    min-height: 2.1rem;
    padding: 0.35rem 0.25rem;
    font-size: 0.72rem;
  }

  .admin-booking-calendar-body {
    gap: 0.28rem;
    overflow-x: hidden;
    padding-bottom: 0;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-weekdays,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.16rem;
    width: 100%;
    min-width: 0;
    max-width: 100%;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-weekdays span {
    min-width: 0;
    font-size: 0.62rem;
    line-height: 1.2;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-day {
    position: relative;
    min-width: 0;
    min-height: 96px;
    padding: 0.28rem 0.22rem;
    border-radius: 9px;
    overflow: hidden;
    transform: none;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-day--selected {
    box-shadow: inset 0 0 0 2px rgba(143, 52, 67, 0.45);
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-day-header {
    align-items: flex-start;
    gap: 0.1rem;
    min-width: 0;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-date {
    min-width: 1.35rem;
    min-height: 1.35rem;
    padding: 0;
    font-size: 0.72rem;
    line-height: 1;
    flex: 0 0 auto;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-capacity {
    flex: 0 1 auto;
    max-width: 2.65rem;
    margin-top: 0;
    padding: 0.08rem 0.18rem;
    border-radius: 999px;
    font-size: 0.54rem;
    line-height: 1.25;
    overflow: hidden;
    text-overflow: clip;
    white-space: nowrap;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-events {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.12rem;
    max-width: 100%;
    margin-top: 0.22rem;
    overflow: hidden;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-more {
    width: 1.1rem;
    min-width: 1.1rem;
    height: 1.1rem;
    max-width: 1.1rem;
    padding: 0;
    border-width: 1px;
    font-size: 0.54rem;
    line-height: 1;
    overflow: hidden;
    transform: none;
    box-shadow: none;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #f0f4f8;
    color: #52606d;
    font-weight: 900;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event:nth-of-type(n + 4) {
    display: none;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-initials {
    max-width: 100%;
    overflow: hidden;
    text-overflow: clip;
    white-space: nowrap;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event strong,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-client,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-service,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-payment,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-time,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-event-action,
  .admin-booking-calendar--month-view .admin-booking-calendar-grid .admin-booking-calendar-source-badge {
    display: none;
  }

  .admin-booking-calendar-bottom-controls {
    position: static;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.35rem;
    width: 100%;
    max-width: 100%;
    margin-top: 0.65rem;
    padding: 0.45rem 0 0;
    padding-bottom: env(safe-area-inset-bottom, 0px);
    border-top: 1px solid rgba(232, 198, 202, 0.72);
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
  }

  .admin-booking-calendar-bottom-controls .admin-toolbar-button {
    min-width: 0;
    min-height: 2.35rem;
    padding: 0.42rem 0.2rem;
    border-radius: 12px;
    font-size: 0.76rem;
    white-space: nowrap;
  }

  .admin-booking-calendar--month-view.admin-booking-calendar--day-details-open .admin-booking-calendar-bottom-controls {
    display: none;
  }

  .admin-booking-calendar--month-view .admin-booking-calendar-day-details {
    right: 0.35rem;
    bottom: calc(5.7rem + env(safe-area-inset-bottom, 0px));
    left: 0.35rem;
    max-width: calc(100vw - 0.7rem);
    border-radius: 18px 18px 0 0;
  }
}

.app-list-item-badge--source-jjcare {
  background: #fef3c7;
  color: #78350f;
}

.app-list-item-badge--source-rover {
  background: #1c1917;
  color: #e7e5e4;
}

.admin-client-source--jjcare {
  background: #fef3c7;
  color: #78350f;
}

.admin-client-source--rover {
  background: #1c1917;
  color: #e7e5e4;
}


.client-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
}

.client-item-copy {
  display: grid;
  min-width: 0;
  gap: 0.12rem;
}

.client-item-name,
.client-item-preview {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.client-item-name {
  color: var(--app-ink);
  font-weight: 900;
}

.client-item-preview,
.client-item-time {
  color: var(--app-muted);
  font-size: 0.76rem;
  font-weight: 650;
}

.client-item-time {
  justify-self: end;
  white-space: nowrap;
}

.client-item:has(.unread-badge:not([hidden])) {
  border-color: #d92d20;
  background: linear-gradient(135deg, #fff1f3, #ffffff);
  box-shadow: 0 14px 30px rgba(217, 45, 32, 0.16);
}

.unread-badge,
.nav-badge,
.nav-unread-badge {
  box-shadow: 0 0 0 2px #ffffff, 0 8px 16px rgba(217, 45, 32, 0.22);
}

.request-status-strip {
  margin-bottom: 1rem;
}

#cr-toolbar {
  margin-top: 0;
  margin-bottom: 1rem;
}

.request-status-strip span:nth-child(1) {
  border-color: #f3b6c1;
  background: #fff0f5;
}

.request-status-strip span:nth-child(2) {
  border-color: #f4c26d;
  background: #fff8e6;
}

.request-status-strip span:nth-child(3) {
  border-color: #8fd5a4;
  background: #f0fff4;
}

.request-status-strip span:nth-child(4),
.cr-status-declined {
  border-color: #d1d5db;
  background: #f8fafc;
  color: #4b5563;
}

/* Admin CRM workspace */
.clients-panel,
.settings-panel {
  display: grid;
  gap: 1rem;
}

.admin-crm-shell {
  grid-template-columns: 240px minmax(0, 1fr);
}

.clients-management-layout {
  display: grid;
  grid-template-columns: 330px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.clients-directory,
.client-workspace {
  min-width: 0;
}

.clients-directory {
  position: sticky;
  top: 1rem;
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
  border: 1px solid var(--app-card-border);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 12px 28px rgba(125, 65, 75, 0.07);
}

.clients-directory-header,
.client-workspace-header {
  display: grid;
  gap: 0.8rem;
}

.clients-directory-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.clients-directory-header h3 {
  margin: 0.15rem 0 0;
  font-size: 1.1rem;
}

.clients-search-field {
  margin: 0;
}

.clients-directory-list {
  display: grid;
  gap: 0.55rem;
  max-height: 58vh;
  overflow-x: hidden;
  overflow-y: auto;
  padding-right: 0.15rem;
}

.admin-client-row {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  width: 100%;
  padding: 0.85rem;
  border: 1px solid rgba(232, 198, 202, 0.72);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--app-ink);
  font: inherit;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(125, 65, 75, 0.05);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.admin-client-row:hover,
.admin-client-row:focus-visible,
.admin-client-row.is-selected {
  border-color: #d99aa0;
  box-shadow: 0 12px 26px rgba(217, 154, 160, 0.16);
  transform: translateY(-1px);
}

/* Row 1: client name (flex-grow) + stage/status badge (right) */
.admin-client-row-top,
/* Row 2: pets/service text (flex-grow) + source & booking badges (right) */
.admin-client-row-bottom {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  min-width: 0;
}

.admin-client-row-top strong {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-client-row-bottom small {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--app-muted);
  font-size: 0.78rem;
  line-height: 1.35;
}

/* Source + booking-status badges sit together on the right of row 2 */
.admin-client-badges {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  flex-shrink: 0;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.admin-client-status,
.admin-client-source {
  flex-shrink: 0;
  font-size: 0.68rem;
}

.client-workspace {
  display: grid;
  gap: 1rem;
}

.client-workspace-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.55rem;
  border: 1px solid rgba(232, 198, 202, 0.72);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.9);
}

.client-workspace-tabs a {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  color: #637083;
  font-size: 0.84rem;
  font-weight: 850;
  text-decoration: none;
}

.client-workspace-tabs a:hover {
  background: #fff5f7;
  color: #7d414b;
}

.client-workspace-tabs a.active {
  background: #ffe0e7;
  color: #5a2230;
  font-weight: 900;
  box-shadow: 0 2px 10px rgba(125, 65, 75, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.client-workspace-future-grid,
.settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.portal-page-clients .admin-toolbar {
  margin: 0;
}

.portal-page-clients .client-pet-card {
  align-items: flex-start;
  padding: 1.15rem 1.25rem;
  border-color: rgba(217, 154, 160, 0.62);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 18px 44px rgba(125, 65, 75, 0.12), 0 2px 6px rgba(125, 65, 75, 0.05);
}

.portal-page-clients .client-pet-card .summary-stat-label {
  font-size: 0.7rem;
  color: #a8bac8;
  letter-spacing: 0.06em;
}

.portal-page-clients #dashboard-client-name {
  font-size: 1.22rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-top: 0.1rem;
  line-height: 1.25;
}

.portal-page-clients #dashboard-pet-names {
  font-size: 0.9rem;
  font-weight: 750;
}

@media (max-width: 1100px) {
  .clients-management-layout {
    grid-template-columns: 1fr;
  }

  .clients-directory {
    position: static;
  }

  .clients-directory-list {
    max-height: none;
  }
}

@media (max-width: 900px) {
  .admin-crm-shell {
    grid-template-columns: 1fr;
  }

  /* Tablet: tighter client card */
  .admin-client-row {
    padding: 0.75rem 0.82rem;
    gap: 0.22rem;
  }

  .admin-client-row-top {
    align-items: flex-start;
    gap: 0.4rem;
  }

  .admin-client-row-bottom {
    align-items: flex-start;
  }
}

@media (max-width: 640px) {
  .clients-directory,
  .client-workspace-tabs {
    border-radius: 20px;
  }

  .client-workspace-future-grid,
  .settings-grid {
    grid-template-columns: 1fr;
  }

  /* ── Mobile client card refinements ── */

  /* 1. Tighter gap between cards */
  .clients-directory-list {
    gap: 0.42rem;
  }

  /* 2. Compact card: less padding, tighter radius */
  .admin-client-row {
    padding: 0.58rem 0.68rem;
    gap: 0.22rem;
    border-radius: 15px;
  }

  /* 3. Row 1 — name + stage badge */
  .admin-client-row-top {
    align-items: flex-start;
    gap: 0.4rem;
  }

  /* Stronger name emphasis */
  .admin-client-row-top strong {
    font-size: 0.92rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    line-height: 1.25;
  }

  /* Stage badge: compact, optically aligned */
  .admin-client-status {
    margin-top: 0.06rem;
    font-size: 0.64rem;
    padding: 0.18rem 0.46rem;
    flex-shrink: 0;
  }

  /* 4. Row 2 — stack text above badges vertically */
  .admin-client-row-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.26rem;
  }

  /* 5. Pets/service: full width, wraps up to 2 lines */
  .admin-client-row-bottom small {
    flex: none;
    width: 100%;
    white-space: normal;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: clip;
    font-size: 0.75rem;
    line-height: 1.35;
  }

  /* 6. Badges: compact horizontal row */
  .admin-client-badges {
    gap: 0.22rem;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  /* 7. Source + booking badges: compact */
  .admin-client-source,
  .admin-client-booking-badge {
    font-size: 0.62rem;
    padding: 0.16rem 0.46rem;
  }
}

@keyframes auth-enter {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

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

@media (max-width: 640px) {
  .client-item {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .client-item-time {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .auth-logo,
  .auth-intro .portal-kicker,
  .auth-intro h2,
  .auth-google-button,
  .portal-overview > *,
  .portal-content > *,
  .care-requests-content .panel > *,
  .nav-unread-badge:not([hidden]),
  .unread-badge:not(:empty),
  .nav-badge:not([hidden]) {
    animation: none !important;
  }
}

/* ============================================================
   MOBILE CLIENTS PAGE — USABILITY ENHANCEMENTS
   Parts 1–4: selector, sticky header, collapsible sections, actions
   ============================================================ */

/* Directory header right column (count + toggle) */
.clients-directory-header-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.42rem;
}

/* Mobile directory toggle — hidden on desktop */
.mobile-dir-toggle {
  display: none;
}

/* Mobile sticky client bar — hidden on desktop */
.mobile-client-sticky-bar {
  display: none;
}

/* Collapsible section toggle button — hidden on desktop */
.mobile-collapse-btn {
  display: none;
}

@media (max-width: 900px) {

  /* ── Part 1: Directory collapse toggle ── */

  .mobile-dir-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.3rem 0.72rem;
    border: 1px solid var(--app-card-border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    color: #7d414b;
    font: inherit;
    font-size: 0.76rem;
    font-weight: 800;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s ease, border-color 0.15s ease;
  }

  .mobile-dir-toggle:hover {
    background: #fff0f2;
    border-color: #d99aa0;
  }

  .clients-directory-list.is-mobile-collapsed,
  .clients-search-field.is-mobile-collapsed {
    display: none;
  }

  /* ── Part 2: Sticky selected client bar ── */

  .mobile-client-sticky-bar:not([hidden]) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    position: sticky;
    top: 3.8rem;
    z-index: 80;
    padding: 0.6rem 0.9rem;
    margin-bottom: 0.75rem;
    border: 1px solid rgba(217, 154, 160, 0.5);
    border-radius: 16px;
    background: rgba(255, 253, 254, 0.99);
    backdrop-filter: blur(12px);
    box-shadow: 0 8px 28px rgba(125, 65, 75, 0.15);
  }

  .mobile-sticky-inner {
    display: grid;
    gap: 0.08rem;
    min-width: 0;
  }

  .mobile-sticky-name {
    font-size: 0.9rem;
    font-weight: 800;
    color: var(--app-ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .mobile-sticky-pets {
    font-size: 0.74rem;
    color: var(--app-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .mobile-sticky-status {
    flex-shrink: 0;
    font-size: 0.72rem;
  }

  /* ── Part 3: Collapsible section buttons ── */

  .mobile-collapse-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.24rem 0.65rem;
    border: 1px solid var(--app-card-border);
    border-radius: 999px;
    background: transparent;
    color: #7d414b;
    font: inherit;
    font-size: 0.73rem;
    font-weight: 800;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s ease;
    flex-shrink: 0;
  }

  .mobile-collapse-btn:hover {
    background: #fff0f2;
  }

  /* Heading row in collapsible cards becomes flex to hold the toggle */
  [data-mobile-collapsible] > h3 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0;
  }

  /* Collapse body visibility */
  [data-mobile-collapsible].is-mobile-collapsed .mobile-collapse-body {
    display: none;
  }

  /* When collapsed, restore normal margin to the card */
  [data-mobile-collapsible].is-mobile-collapsed > h3 {
    margin-bottom: 0;
  }

  /* Give the collapse body a top margin so content isn't flush with heading */
  .mobile-collapse-body {
    margin-top: 0.65rem;
  }

  /* ── Part 4: Tablet action buttons — compact flex wrap ── */

  /* On tablet, let action buttons fill width evenly so they fit in 2 columns */
  .portal-page-clients .admin-toolbar-group--actions {
    width: 100%;
    flex-wrap: wrap;
  }

  .portal-page-clients .admin-toolbar-group--actions .admin-toolbar-button {
    flex: 1 1 auto;
    min-width: 130px;
  }
}

@media (max-width: 640px) {
  /* Tighter sticky bar on small phones */
  .mobile-client-sticky-bar:not([hidden]) {
    top: 3.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 14px;
  }

  .mobile-sticky-name {
    font-size: 0.86rem;
  }
}

/* ============================================================
   PUSH NOTIFICATION TOAST
   ============================================================ */

.push-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(80px);
  z-index: 9999;
  padding: 13px 20px;
  border-radius: 12px;
  font-size: 0.92rem;
  font-weight: 500;
  color: #fff;
  opacity: 0;
  transition: transform 0.3s ease, opacity 0.3s ease;
  white-space: nowrap;
  pointer-events: none;
}

.push-toast.visible {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

.push-toast--success {
  background: #16a34a;
}

.push-toast--error {
  background: #dc2626;
}

@media (max-width: 480px) {
  .push-toast {
    left: 16px;
    right: 16px;
    bottom: 16px;
    transform: translateY(80px);
    white-space: normal;
  }

  .push-toast.visible {
    transform: translateY(0);
  }
}

/* ── Booking History / Timeline ── */

.booking-history-section {
  margin-top: 1.5rem;
  padding-bottom: 0.5rem;
}

.booking-history-heading {
  margin-bottom: 1rem;
}

.booking-history-heading .portal-kicker {
  margin-bottom: 0.15rem;
}

.booking-history-heading h3 {
  font-size: 1rem;
  font-weight: 700;
  margin: 0;
}

.booking-section-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted, #6b7280);
  margin: 1rem 0 0.5rem;
}

.booking-history-card {
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: 10px;
  padding: 1rem;
  margin-bottom: 0.75rem;
}

.booking-history-card-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.75rem;
  flex-wrap: wrap;
}

.booking-history-dates {
  font-size: 0.82rem;
  color: var(--color-muted, #6b7280);
  font-weight: 500;
}

.booking-history-details {
  gap: 0.4rem;
}

.booking-accordion {
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: 8px;
  margin-bottom: 0.5rem;
  background: var(--color-surface, #fff);
  overflow: hidden;
}

.booking-accordion-summary {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  user-select: none;
  color: var(--color-text, #111827);
  list-style: none;
}

.booking-accordion-summary::-webkit-details-marker {
  display: none;
}

.booking-accordion-summary::before {
  content: "▶";
  font-size: 0.6rem;
  color: var(--color-muted, #6b7280);
  transition: transform 0.15s ease;
  flex-shrink: 0;
}

.booking-accordion[open] > .booking-accordion-summary::before {
  transform: rotate(90deg);
}

.booking-accordion-body {
  padding: 0.25rem 1rem 0.75rem;
  border-top: 1px solid var(--color-border, #e5e7eb);
}

.booking-status-badge--upcoming {
  background: #eff6ff;
  color: #1e40af;
  border-color: #bfdbfe;
}

.booking-status-badge--active {
  background: #dbeafe;
  color: #1e3a5f;
  border-color: #93c5fd;
}

#admin-booking-timeline .detail-list {
  margin-top: 0;
}

#admin-booking-timeline-list .booking-section-label:first-child {
  margin-top: 0.25rem;
}

.admin-client-notes-form {
  display: grid;
  gap: 0.75rem;
}

.admin-client-section-status {
  margin: 0.35rem 0 0;
  color: var(--color-muted, #6b7280);
  font-size: 0.9rem;
  line-height: 1.45;
}

#admin-archive-control .admin-save-button:disabled {
  cursor: default;
  opacity: 0.65;
}

.admin-client-section-status--danger {
  color: #9f3a48;
  font-weight: 500;
}

.admin-save-button--delete {
  background: #fff8f9;
  color: #9f3a48;
  border: 1.5px solid #f1c4ca;
  margin-top: 0.6rem;
}

.admin-save-button--delete:hover:not(:disabled) {
  background: #fdeef0;
  border-color: #e8a0aa;
  color: #7d2535;
}

.admin-save-button--delete:disabled {
  cursor: default;
  opacity: 0.65;
}

/* ============================================================
   PWA / APP-LIKE UX POLISH
   Touch, scroll, and interaction improvements for mobile.
   ============================================================ */

/* Eliminate 300ms tap delay on interactive elements */
.tab-item,
.quick-action-card,
.admin-client-row,
.app-stat-card,
.admin-calendar-view-tab,
.admin-booking-calendar-day,
.admin-booking-calendar-event,
.mobile-more-menu a,
.mobile-more-menu button,
.button-link,
.invoice-pay-button {
  touch-action: manipulation;
}

/* Remove tap highlight flash on mobile (keep focus styles for a11y) */
.tab-item,
.quick-action-card,
.admin-client-row,
.admin-booking-calendar-day,
.mobile-more-menu a,
.mobile-more-menu button {
  -webkit-tap-highlight-color: transparent;
}

/* Overscroll containment on portal main content */
main {
  overscroll-behavior-y: contain;
}

@media (max-width: 640px) {
  /* Ensure mobile more-menu never overflows the viewport on short phones */
  .mobile-more-menu {
    max-height: calc(100dvh - 7rem - env(safe-area-inset-bottom, 0px));
    overflow-y: auto;
    overscroll-behavior: contain;
  }

  /* Slightly looser padding on portal content for better readability */
  .portal-content.panel,
  .care-requests-content .panel {
    padding: 0.85rem;
  }

  /* Invoice action buttons: full-width on small mobile for easier tapping */
  .invoice-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.65rem;
  }

  /* Booking history cards: comfortable touch spacing */
  .booking-history-card {
    padding: 0.85rem;
    border-radius: 14px;
    margin-bottom: 0.6rem;
  }

  .booking-history-card-header {
    gap: 0.45rem;
  }

  /* Admin home stats: slightly taller touch targets */
  .app-stat-card {
    min-height: 88px;
  }

  /* Quick actions text: prevent wrapping on narrow screens */
  .quick-action-card span:last-child {
    font-size: 0.78rem;
    line-height: 1.2;
    text-align: center;
  }

  /* Admin dashboard grid: single column for breathing room */
  .admin-dashboard-grid {
    grid-template-columns: 1fr;
    gap: 0.7rem;
  }

  /* Push-toast: clear tab bar on mobile */
  .cr-toast,
  .push-toast {
    bottom: calc(5.5rem + env(safe-area-inset-bottom, 0px));
  }
}

@media (max-width: 380px) {
  .pwa-install-banner {
    grid-template-columns: 1fr;
  }

  .pwa-install-banner-actions {
    flex-wrap: wrap;
  }
}

/* ============================================================
   PHASE 2 — PAYMENT TRACKING & REVENUE SYSTEM
   Admin-only: revenue tracking card, net earned display,
   per-booking payment editor in the timeline.
   ============================================================ */

/* Booking selector — sits above the revenue card on payments.html */
.admin-booking-selector-card {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-top: 1.25rem;
  padding: 0.85rem 1.25rem;
  background: #f0f5f0;
  border: 1.5px solid #c2d6c2;
  border-radius: 14px;
}

.admin-booking-selector-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: #5d6640;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.admin-booking-selector {
  width: 100%;
  font-size: 0.9rem;
  padding: 0.5rem 0.75rem;
  border-radius: 8px;
  border: 1.5px solid #b0c4b0;
  background: #fff;
  color: #1a2e1a;
}

/* Admin Revenue Tracking Card (payments.html) */
.admin-revenue-tracking-card {
  margin-top: 1.25rem;
  border: 2px solid #d4e2d4;
  border-radius: 18px;
  padding: 1.25rem 1.5rem;
  background: #f7fbf7;
}

.admin-revenue-tracking-title {
  margin: 0 0 0.2rem;
  font-size: 1rem;
  font-weight: 800;
  color: #2d4a2d;
}

.admin-revenue-source-label {
  margin: 0 0 1rem;
  font-size: 0.82rem;
  color: #5d6640;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.admin-booking-actions-card {
  margin-top: 1.25rem;
  border: 2px solid #ead7d0;
  border-radius: 18px;
  padding: 1.25rem 1.5rem;
  background: #fffaf8;
}

.admin-booking-actions-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem;
  margin: 0.9rem 0 1rem;
}

.admin-booking-actions-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.65rem 0.75rem;
  border: 1px solid #ead7d0;
  border-radius: 8px;
  background: #fff;
  font-size: 0.85rem;
}

.admin-booking-actions-meta-row span {
  color: var(--app-muted);
}

.admin-booking-actions-meta-row strong {
  color: #3b2a24;
  text-align: right;
}

.admin-booking-actions-buttons {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.6rem;
}

.admin-booking-action-btn {
  width: 100%;
}

.admin-booking-action-btn--danger {
  background: #7f1d1d;
  border-color: #7f1d1d;
  color: #fff;
}

.admin-booking-action-btn--danger:hover:not(:disabled) {
  background: #991b1b;
}

.admin-booking-actions-status {
  min-height: 1.2em;
  margin: 0.55rem 0 0;
  color: var(--color-muted, #6b7280);
  font-size: 0.85rem;
}

/* Net Earned display — prominent read-only field */
.admin-net-earned-display {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  margin: 0.5rem 0;
  background: #eaf4ea;
  border: 1.5px solid #8db88d;
  border-radius: 12px;
}

.admin-net-earned-label {
  font-weight: 800;
  font-size: 0.9rem;
  color: #2d4a2d;
  white-space: nowrap;
}

.admin-net-earned-value {
  flex: 1;
  font-weight: 800;
  font-size: 1.05rem;
  color: #2d6a2d;
  background: transparent;
  border: none;
  outline: none;
  cursor: default;
  text-align: right;
}

/* Save button for revenue section */
.admin-revenue-save-btn {
  margin-top: 0.75rem;
  width: 100%;
}

.admin-revenue-save-status {
  margin: 0.4rem 0 0;
  font-size: 0.85rem;
  color: var(--color-muted, #6b7280);
  min-height: 1.2em;
}

/* ── Rover booking summary card (payments page, Rover source) ── */
.admin-rover-booking-summary {
  margin-top: 1.25rem;
  border: 2px solid #d4e2d4;
  border-radius: 18px;
  padding: 1.25rem 1.5rem;
  background: #f7fbf7;
}

.admin-rover-summary-body {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  margin-top: 0.75rem;
}

.admin-rover-summary-row {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
}

.admin-rover-summary-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: #5d6640;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  min-width: 7rem;
  flex-shrink: 0;
}

.admin-rover-summary-value {
  font-size: 0.9rem;
  color: #1a2e1a;
}

/* ── Per-booking inline payment editor (booking timeline) ── */
.booking-payment-edit-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.75rem;
  padding: 0.4rem 0.85rem;
  border: 1.5px solid #8db88d;
  border-radius: 8px;
  background: #f7fbf7;
  color: #2d4a2d;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.booking-payment-edit-toggle:hover {
  background: #eaf4ea;
  border-color: #5d6640;
}

.booking-payment-editor {
  margin-top: 0.9rem;
  padding: 1rem;
  border: 1.5px solid #d4e2d4;
  border-radius: 12px;
  background: #f7fbf7;
}

.booking-payment-editor-title {
  margin: 0 0 0.75rem;
  font-size: 0.83rem;
  font-weight: 800;
  color: #5d6640;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.booking-payment-editor-grid {
  margin-bottom: 0.75rem;
}

.booking-payment-editor-save {
  margin-top: 0.5rem;
  width: 100%;
}

.booking-payment-editor-status {
  margin: 0.35rem 0 0;
  font-size: 0.82rem;
  color: var(--color-muted, #6b7280);
  min-height: 1.1em;
}

/* ============================================================
   PAYMENT COMMAND CENTER (Phase 3A)
   ============================================================ */

/* Summary cards row */
.pcc-summary-cards {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.pcc-summary-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.pcc-summary-group__label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--app-muted);
  margin: 0;
}

.pcc-summary-group__cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
}

.pcc-summary-group--footer .pcc-summary-group__cards {
  grid-template-columns: repeat(2, 1fr);
}

.pcc-card {
  background: #fff;
  border: 1px solid var(--app-card-border);
  border-radius: 10px;
  padding: 1rem 1.1rem;
  box-shadow: 0 2px 8px rgba(125, 65, 75, 0.06);
}

.pcc-card__label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--app-muted);
  margin: 0 0 0.3rem;
}

.pcc-card__value {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--app-ink);
  margin: 0;
  line-height: 1.1;
}

.pcc-card__sub {
  font-size: 0.72rem;
  color: var(--app-muted);
  margin: 0.25rem 0 0;
}

.pcc-card--rover       .pcc-card__value { color: #2563eb; }
.pcc-card--sixxpaws    .pcc-card__value { color: #5d6640; }
.pcc-card--outstanding .pcc-card__value { color: #b85c6a; }
.pcc-card--attention   .pcc-card__value { color: #92400e; }
.pcc-card--fees        .pcc-card__value { color: #92400e; }
.pcc-card--refunds     .pcc-card__value { color: #b45309; }
.pcc-card--net         .pcc-card__value { color: #15803d; }
.pcc-card--rover-fees  .pcc-card__value { color: #6d28d9; }

/* Export / action row */
.pcc-export-row {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
  flex-wrap: wrap;
}

.pcc-export-btn {
  font-size: 0.76rem;
  font-weight: 600;
  padding: 0.4rem 0.9rem;
  border: 1px solid var(--app-card-border);
  border-radius: 6px;
  background: #fff;
  color: var(--app-ink);
  cursor: pointer;
  transition: background 0.12s;
}

.pcc-export-btn:hover {
  background: #f3f4f6;
}

.pcc-export-btn--print {
  background: #f8fafc;
}

/* Filter pills */
.pcc-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 1rem;
}

.pcc-filter-btn {
  font-size: 0.76rem;
  font-weight: 600;
  padding: 0.3rem 0.75rem;
  border: 1px solid var(--app-card-border);
  border-radius: 999px;
  background: #fff;
  color: var(--app-muted);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}

.pcc-filter-btn:hover {
  background: #f3f4f6;
  color: var(--app-ink);
}

.pcc-filter-btn--active {
  background: var(--app-ink);
  color: #fff;
  border-color: var(--app-ink);
}

/* Table wrapper + CSS-driven filters */
.pcc-table-wrap {
  overflow-x: auto;
  border-radius: 10px;
  border: 1px solid var(--app-card-border);
}

/* Date / search / sort controls */
.pcc-controls {
  margin-bottom: 1rem;
}

.pcc-date-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.75rem;
}

.pcc-custom-range {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.75rem;
  padding: 0.75rem;
  background: #fafafa;
  border: 1px solid var(--app-card-border);
  border-radius: 8px;
}

.pcc-custom-label {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--app-muted);
}

.pcc-date-input {
  font-size: 0.83rem;
  padding: 0.3rem 0.5rem;
  border: 1px solid var(--app-card-border);
  border-radius: 6px;
  background: #fff;
  color: var(--app-ink);
}

.pcc-apply-btn {
  font-size: 0.76rem;
  font-weight: 600;
  padding: 0.32rem 0.9rem;
  border: 1px solid #5d6640;
  border-radius: 6px;
  background: #5d6640;
  color: #fff;
  cursor: pointer;
  align-self: flex-end;
  transition: background 0.12s;
}

.pcc-apply-btn:hover {
  background: #4a5234;
}

.pcc-search-sort-row {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 0.75rem;
  flex-wrap: wrap;
}

.pcc-search-input {
  flex: 1;
  min-width: 200px;
  font-size: 0.83rem;
  padding: 0.38rem 0.65rem;
  border: 1px solid var(--app-card-border);
  border-radius: 6px;
  background: #fff;
  color: var(--app-ink);
}

.pcc-search-input:focus {
  outline: none;
  border-color: #5d6640;
  box-shadow: 0 0 0 2px rgba(93, 102, 64, 0.15);
}

.pcc-sort-select {
  font-size: 0.83rem;
  padding: 0.38rem 0.6rem;
  border: 1px solid var(--app-card-border);
  border-radius: 6px;
  background: #fff;
  color: var(--app-ink);
  cursor: pointer;
}

/* Pagination */
.pcc-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 0.85rem 0 0.25rem;
}

.pcc-page-btn {
  font-size: 0.78rem;
  font-weight: 600;
  padding: 0.3rem 0.8rem;
  border: 1px solid var(--app-card-border);
  border-radius: 6px;
  background: #fff;
  color: var(--app-ink);
  cursor: pointer;
  transition: background 0.12s;
}

.pcc-page-btn:hover:not(:disabled) {
  background: #f0f9ff;
  border-color: #93c5fd;
  color: #1e3a5f;
}

.pcc-page-btn:disabled {
  opacity: 0.4;
  cursor: default;
}

.pcc-page-info {
  font-size: 0.8rem;
  color: var(--app-muted);
  white-space: nowrap;
}

/* Empty state */
.pcc-empty {
  padding: 2rem 0;
  text-align: center;
}

/* Mobile card list — hidden on desktop, shown on mobile */
.pcc-card-list {
  display: none;
  flex-direction: column;
  gap: 0;
}

.pcc-card-item {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid rgba(232, 198, 202, 0.35);
}

.pcc-card-item:last-child { border-bottom: none; }

.pcc-card-item__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 0.4rem;
}

.pcc-card-item__client {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.pcc-card-item__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem 0.4rem;
  align-items: center;
  margin-bottom: 0.5rem;
}

.pcc-card-item__revenue {
  margin-bottom: 0.5rem;
}

.pcc-card-item__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.pcc-card-item__attn {
  flex: 1;
}

/* Table styles */
.pcc-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  min-width: 680px;
}

.pcc-table thead th {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--app-muted);
  padding: 0.55rem 0.6rem;
  text-align: left;
  background: #fafafa;
  border-bottom: 1px solid var(--app-card-border);
  white-space: nowrap;
}

.pcc-table tbody tr {
  border-bottom: 1px solid rgba(232, 198, 202, 0.35);
  transition: background 0.1s;
}

.pcc-table tbody tr:last-child { border-bottom: none; }
.pcc-table tbody tr:hover { background: #fff9fa; }

.pcc-table td {
  padding: 0.6rem 0.6rem;
  vertical-align: middle;
  color: var(--app-ink);
}

/* Sticky Action column — always visible even when table scrolls horizontally */
.pcc-table th:last-child,
.pcc-table td:last-child {
  position: sticky;
  right: 0;
  z-index: 1;
}
.pcc-table thead th:last-child {
  background: #fafafa;
}
.pcc-table tbody td:last-child {
  background: #fff;
  box-shadow: -2px 0 5px rgba(0, 0, 0, 0.04);
}
.pcc-table tbody tr:hover td:last-child {
  background: #fff9fa;
}

/* Cell content helpers */
.pcc-client-name {
  font-weight: 700;
  white-space: nowrap;
}

.pcc-table .pcc-client-name {
  display: inline-block;
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: bottom;
}

.pcc-pets {
  color: var(--app-muted);
  font-size: 0.78rem;
  white-space: nowrap;
  display: inline-block;
  max-width: 100px;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: bottom;
}

.pcc-dates {
  white-space: nowrap;
  font-size: 0.8rem;
}

/* Source badge */
.pcc-source-badge {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 0.14rem 0.48rem;
  border-radius: 999px;
  white-space: nowrap;
}

.pcc-source-badge--rover {
  background: #dbeafe;
  color: #1e3a5f;
  border: 1px solid #93c5fd;
}

.pcc-source-badge--sixxpaws {
  background: #f0fdf4;
  color: #166534;
  border: 1px solid #86efac;
}

/* Payment status pill */
.pcc-pay-status {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 0.14rem 0.48rem;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  white-space: nowrap;
  border: 1px solid transparent;
}

.pcc-pay-status--paid     { background: #dcfce7; color: #14532d; border-color: #86efac; }
.pcc-pay-status--unpaid   { background: #fee2e2; color: #7f1d1d; border-color: #fca5a5; }
.pcc-pay-status--partial  { background: #fef3c7; color: #78350f; border-color: #fcd34d; }
.pcc-pay-status--pending  { background: #fef3c7; color: #78350f; border-color: #fcd34d; }
.pcc-pay-status--unknown  { background: #f3f4f6; color: #6b7280; border-color: #d1d5db; }

/* Revenue / amount cell */
.pcc-revenue {
  font-size: 0.79rem;
  line-height: 1.5;
}

.pcc-revenue-line {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  min-width: 0;
}

.pcc-revenue-label { color: var(--app-muted); }
.pcc-revenue-value { font-weight: 600; }
.pcc-revenue-total { color: #5d6640; }

/* Attention tag */
.pcc-attn-tag {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 0.14rem 0.48rem;
  border-radius: 999px;
  white-space: nowrap;
  border: 1px solid transparent;
}

.pcc-attn-tag--review    { background: #fef3c7; color: #78350f; border-color: #fcd34d; }
.pcc-attn-tag--attention { background: #fee2e2; color: #7f1d1d; border-color: #fca5a5; }

/* Action button */
.pcc-action-btn {
  font-size: 0.76rem;
  font-weight: 600;
  padding: 0.3rem 0.65rem;
  border: 1px solid var(--app-card-border);
  border-radius: 6px;
  background: #fff;
  color: var(--app-ink);
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
  white-space: nowrap;
}

.pcc-action-btn:hover {
  background: #f0f9ff;
  border-color: #93c5fd;
  color: #1e3a5f;
}

/* Loading state */
.pcc-loading {
  padding: 1.5rem 0;
  text-align: center;
}

/* Responsive: stack summary cards 2-up on narrow screens */
@media (max-width: 680px) {
  .pcc-summary-group__cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 360px) {
  .pcc-summary-group__cards {
    grid-template-columns: 1fr;
  }
}

/* Revenue Tracker page layout */
.portal-page-revenue .portal-content {
  padding-bottom: 3rem;
}

/* Print: show revenue table, hide nav and controls */
@media print {
  body.portal-page-revenue .site-header,
  body.portal-page-revenue .portal-sidebar,
  body.portal-page-revenue .bottom-tab-bar,
  body.portal-page-revenue .mobile-more-menu,
  body.portal-page-revenue #pcc-controls,
  body.portal-page-revenue #pcc-filters,
  body.portal-page-revenue .pcc-export-row,
  body.portal-page-revenue .pcc-action-btn,
  body.portal-page-revenue .pcc-pagination,
  body.portal-page-revenue .portal-userbar {
    display: none !important;
  }
  body.portal-page-revenue .portal-content {
    padding: 1rem;
    max-width: none;
  }
  body.portal-page-revenue .pcc-table        { display: table !important; }
  body.portal-page-revenue .pcc-card-list    { display: none !important; }
  body.portal-page-revenue .pcc-table-wrap   { border: none; overflow: visible; }
  body.portal-page-revenue .pcc-summary-group__cards { grid-template-columns: repeat(4, 1fr); }
}

/* Mobile: swap table for stacked cards */
@media (max-width: 768px) {
  .pcc-table { display: none; }
  .pcc-card-list { display: flex; }

  .pcc-table-wrap {
    overflow-x: visible;
  }

  .pcc-filters {
    flex-wrap: wrap;
    gap: 0.4rem 0.35rem;
  }

  .admin-payment-command-section {
    margin-bottom: 1rem;
  }

  .pcc-card-item__revenue .pcc-revenue-line {
    min-width: 0;
  }

  .pcc-search-sort-row {
    flex-direction: column;
    align-items: stretch;
  }

  .pcc-search-input {
    min-width: unset;
  }

  .pcc-sort-select {
    width: 100%;
  }

  .pcc-pagination {
    padding: 0.75rem 0.5rem;
    gap: 0.5rem;
  }

  .pcc-page-info {
    font-size: 0.72rem;
  }

  .pcc-custom-range {
    gap: 0.5rem;
  }

  .admin-booking-actions-meta,
  .admin-booking-actions-buttons {
    grid-template-columns: 1fr;
  }
}
