﻿/* ═══════════════════════════════════════════════════
   CampSphere – Camp Manager Dashboard Styles
   ═══════════════════════════════════════════════════ */

/* ── Sidebar ──────────────────────────────────────── */
.cm-sidebar {
  transition: width .3s cubic-bezier(.4,0,.2,1), transform .3s cubic-bezier(.4,0,.2,1);
}

/* Calendar mode switch (day/week/month) */
.cm-cal-mode-switch {
  display: inline-flex;
  align-items: center;
  background: #fff;
  border: 1px solid #e7e5e4;
  border-radius: .85rem;
  padding: .2rem;
  gap: .2rem;
}

.cm-cal-mode-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .45rem .7rem;
  border-radius: .65rem;
  font-size: .72rem;
  font-weight: 700;
  color: #57534e;
  border: 1px solid transparent;
  transition: all .18s ease;
}

.cm-cal-mode-btn:hover {
  background: #fafaf9;
  color: #292524;
}

.cm-cal-mode-btn--active {
  background: linear-gradient(135deg, rgba(5,150,105,.14), rgba(5,150,105,.08));
  color: #047857;
  border-color: rgba(5,150,105,.28);
  box-shadow: 0 2px 8px rgba(5,150,105,.15);
}

/* Grid modes */
.cm-cal-grid {
  display: grid;
}

.cm-cal-grid--month {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.cm-cal-grid--week {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.cm-cal-grid--day {
  grid-template-columns: minmax(0, 1fr);
}

.cm-cal-cell--weekmode {
  min-height: 170px;
}

.cm-cal-cell--daymode {
  min-height: 420px;
}

@media (max-width: 639px) {
  .cm-cal-mode-switch {
    width: 100%;
    justify-content: space-between;
  }

  .cm-cal-mode-btn {
    flex: 1 1 0;
  }

  .cm-cal-cell--weekmode {
    min-height: 92px;
  }

  .cm-cal-cell--daymode {
    min-height: 92px;
  }

  .cm-cal-cell--weekmode .cm-cal-weekday-inline {
    display: none;
  }
}
.cm-sidebar.collapsed { width: 72px; }
.cm-sidebar.collapsed .cm-label { display: none; }
.cm-sidebar.collapsed .cm-logo-text { display: none; }

/* ── Mobile sidebar ──────────────────────────────── */
@media (max-width: 1023px) {
  .cm-sidebar {
    position: fixed;
    inset-block: 0;
    left: 0;
    z-index: 50;
    transform: translateX(-100%);
  }
  .cm-sidebar.mobile-open { transform: translateX(0); }
}

/* ── Sidebar nav link active ─────────────────────── */
.cm-nav-link {
  position: relative;
  transition: all .2s ease;
}
.cm-nav-link.active {
  background: rgba(249, 115, 22, .12);
  color: #f97316;
}
.cm-nav-link.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: #f97316;
}

/* ── Stat card gradient borders ──────────────────── */
.stat-card {
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: 0 0 4px 4px;
}
.stat-card.stat-green::before  { background: linear-gradient(90deg, #059669, #10b981); }
.stat-card.stat-amber::before  { background: linear-gradient(90deg, #d97706, #f59e0b); }
.stat-card.stat-blue::before   { background: linear-gradient(90deg, #0284c7, #0ea5e9); }
.stat-card.stat-purple::before { background: linear-gradient(90deg, #7c3aed, #a78bfa); }

/* ── Table row hover ─────────────────────────────── */
.cm-table-row {
  transition: background .15s ease;
}
.cm-table-row:hover {
  background: #f5f5f4;
}

/* ── Badge status pulse ──────────────────────────── */
.badge-pulse {
  position: relative;
}
.badge-pulse::after {
  content: '';
  position: absolute;
  top: -1px;
  right: -1px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #059669;
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .5; transform: scale(1.4); }
}

/* ── Card hover lift ─────────────────────────────── */
.cm-card-lift {
  transition: transform .25s ease, box-shadow .25s ease;
}
.cm-card-lift:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px rgba(0,0,0,.08);
}

/* ── Empty state illustration ────────────────────── */
.cm-empty-state {
  background: radial-gradient(ellipse at center, rgba(5,150,105,.04) 0%, transparent 70%);
}

/* ── Mobile bottom nav ───────────────────────────── */
.cm-bottom-nav {
  box-shadow: 0 -4px 12px rgba(0,0,0,.06);
}

/* ── Smooth content transition ───────────────────── */
.cm-fade-in {
  animation: cmFadeIn .4s ease-out;
}
@keyframes cmFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════════════
   Calendar (Camp Manager)
   ═══════════════════════════════════════════════════ */

/* Legacy hatched-pattern used by legend swatch and inside cells */
.cm-cal-blocked {
  background: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 4px,
    rgba(239,68,68,.08) 4px,
    rgba(239,68,68,.08) 8px
  );
}

/* ── Cell grid: equal-size cells with responsive aspect ratio ── */
.cm-cal-cell {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: .25rem;
  min-height: 64px;
  border-right: 1px solid #f5f5f4;
  border-bottom: 1px solid #f5f5f4;
  background: #ffffff;
  transition: background-color .15s ease, box-shadow .15s ease;
  overflow: hidden;
  min-width: 0;
}

@media (min-width: 480px) {
  .cm-cal-cell {
    padding: .4rem;
    min-height: 84px;
  }
}

@media (min-width: 640px) {
  .cm-cal-cell {
    padding: .65rem;
    min-height: 120px;
  }
}

@media (min-width: 1024px) {
  .cm-cal-cell {
    padding: .75rem;
    min-height: 140px;
  }
}

/* Remove right border on last column (every 7th cell), bottom on last row */
.cm-cal-cell:nth-child(7n) {
  border-right: none;
}

.cm-cal-cell--empty {
  background: repeating-linear-gradient(
    135deg,
    #fafaf9,
    #fafaf9 6px,
    #f5f5f4 6px,
    #f5f5f4 12px
  );
  pointer-events: none;
}

.cm-cal-cell:hover:not(.cm-cal-cell--empty) {
  background-color: #fafaf9;
}

.cm-cal-cell--booked {
  background-color: rgba(5, 150, 105, .04);
}

.cm-cal-cell--booked:hover {
  background-color: rgba(5, 150, 105, .075);
}

.cm-cal-cell--blocked {
  background:
    linear-gradient(rgba(254, 226, 226, .25), rgba(254, 226, 226, .25)),
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 5px,
      rgba(239,68,68,.09) 5px,
      rgba(239,68,68,.09) 10px
    );
}

.cm-cal-cell--blocked:hover {
  background:
    linear-gradient(rgba(254, 226, 226, .35), rgba(254, 226, 226, .35)),
    repeating-linear-gradient(
      -45deg,
      transparent,
      transparent 5px,
      rgba(239,68,68,.12) 5px,
      rgba(239,68,68,.12) 10px
    );
}

.cm-cal-cell--today {
  background: linear-gradient(180deg, rgba(252, 211, 77, .12) 0%, rgba(252, 211, 77, .04) 100%);
  box-shadow: inset 0 0 0 2px rgba(245, 158, 11, .45);
  z-index: 1;
}

.cm-cal-cell--today.cm-cal-cell--booked {
  background: linear-gradient(180deg, rgba(252, 211, 77, .14) 0%, rgba(5, 150, 105, .04) 100%);
}

/* Day number */
.cm-cal-day-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.2rem;
  height: 1.2rem;
  font-size: 11px;
  font-weight: 700;
  color: #57534e;
  letter-spacing: -.01em;
}

@media (min-width: 640px) {
  .cm-cal-day-number {
    min-width: 1.4rem;
    height: 1.4rem;
    font-size: .75rem;
  }
}

.cm-cal-day-number--today {
  background: #f59e0b;
  color: #fff;
  border-radius: 999px;
  padding: 0 .4rem;
  box-shadow: 0 2px 6px rgba(245, 158, 11, .35);
}

/* Status pills (top-right of each cell) */
.cm-cal-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .15rem;
  min-width: 1.05rem;
  height: 1.05rem;
  padding: 0 .35rem;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .02em;
  line-height: 1;
}

.cm-cal-pill--booked {
  background: rgba(5, 150, 105, .14);
  color: #047857;
  border: 1px solid rgba(5, 150, 105, .25);
}

.cm-cal-pill--blocked {
  background: rgba(239, 68, 68, .12);
  color: #b91c1c;
  border: 1px solid rgba(239, 68, 68, .25);
  padding: 0 .25rem;
}

/* Booking chip inside a day cell */
.cm-cal-booking-chip {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: .25rem;
  padding: .2rem .35rem;
  border-radius: .375rem;
  background: #fff;
  border: 1px solid rgba(5, 150, 105, .22);
  font-size: 10px;
  font-weight: 600;
  color: #44403c;
  line-height: 1.2;
  transition: all .15s ease;
  min-width: 0;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
}

.cm-cal-booking-chip > span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1 1 auto;
  min-width: 0;
}

@media (min-width: 640px) {
  .cm-cal-booking-chip {
    padding: .25rem .45rem;
    border-radius: .5rem;
    font-size: 11px;
    gap: .35rem;
  }
}

.cm-cal-booking-chip:hover {
  border-color: rgba(5, 150, 105, .55);
  background: rgba(5, 150, 105, .06);
  color: #047857;
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(5, 150, 105, .12);
}

.cm-cal-booking-chip i {
  color: #059669;
}

/* "+N more" overflow button */
.cm-cal-more-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .2rem;
  padding: .2rem .4rem;
  border-radius: .375rem;
  background: linear-gradient(135deg, #059669, #047857);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .03em;
  border: none;
  cursor: pointer;
  transition: all .18s ease;
  box-shadow: 0 2px 6px rgba(5, 150, 105, .25);
  white-space: nowrap;
}

@media (min-width: 640px) {
  .cm-cal-more-btn {
    padding: .25rem .5rem;
    border-radius: .5rem;
    font-size: 10px;
    gap: .25rem;
  }
}

.cm-cal-more-btn:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(5, 150, 105, .35);
}

.cm-cal-more-btn:active {
  transform: translateY(0);
}

/* On very small screens, simplify chip + button */
@media (max-width: 479px) {
  .cm-cal-booking-chip i {
    display: none;
  }
  .cm-cal-more-btn__icon,
  .cm-cal-more-btn__label {
    display: none;
  }
}

/* ── Day Bookings Modal ────────────────────────── */
.cm-cal-modal {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.cm-cal-modal.hidden {
  display: none;
}

.cm-cal-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  animation: cmModalFade .2s ease-out;
}

.cm-cal-modal__card {
  position: relative;
  width: 100%;
  max-width: 28rem;
  max-height: calc(100vh - 2rem);
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 1rem;
  border: 1px solid #e7e5e4;
  padding: 1rem;
  box-shadow: 0 20px 50px rgba(15, 23, 42, .25);
  animation: cmModalIn .25s cubic-bezier(.4,0,.2,1);
}

@media (min-width: 640px) {
  .cm-cal-modal__card {
    padding: 1.25rem;
  }
}

@keyframes cmModalFade {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes cmModalIn {
  from { opacity: 0; transform: translateY(12px) scale(.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Progress bar animation ──────────────────────── */
.cm-progress-bar {
  transition: width .8s cubic-bezier(.4,0,.2,1);
}

/* ── Notification dot ────────────────────────────── */
.cm-notif-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ef4444;
  position: absolute;
  top: -2px;
  right: -2px;
  border: 2px solid white;
}

/* ── Mobile sidebar overlay ──────────────────────── */
.cm-overlay {
  background: rgba(0,0,0,.4);
  backdrop-filter: blur(2px);
  transition: opacity .3s ease;
}

/* ── Message bubbles (CampManager) ──────────────── */
.cm-bubble-sent {
  background: #059669;
  color: white;
  border-radius: 18px 18px 4px 18px;
}

.cm-bubble-received {
  background: #f5f5f4;
  color: #44403c;
  border-radius: 18px 18px 18px 4px;
}

/* ── Message shell / mobile keyboard support ────── */
.cm-msg-shell {
  min-height: 0;
}

.cm-thread-panel {
  min-height: 0;
}

.cm-compose-bar {
  position: sticky;
  bottom: 0;
  z-index: 20;
  backdrop-filter: blur(8px) saturate(130%);
  -webkit-backdrop-filter: blur(8px) saturate(130%);
}

@media (max-width: 639px) {
  .cm-msg-shell {
    height: calc(100dvh - 170px) !important;
    border-radius: 1rem;
  }

  .cm-compose-bar {
    padding-bottom: calc(.75rem + env(safe-area-inset-bottom) + var(--cm-kb-offset, 0px));
    background: rgba(255, 255, 255, .92);
  }
}

/* ═══════════════════════════════════════════════════
   Auth Pages Styles
   ═══════════════════════════════════════════════════ */

/* ── Auth body background ────────────────────────── */
.cm-auth-body {
  background: linear-gradient(135deg, #fafaf9 0%, #f5f5f4 50%, #fafaf9 100%);
}

/* ── Auth card entrance ──────────────────────────── */
.cm-auth-card {
  animation: authCardIn .5s cubic-bezier(.4,0,.2,1);
}
@keyframes authCardIn {
  from { opacity: 0; transform: translateY(16px) scale(.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Auth input focus glow ───────────────────────── */
.cm-auth-input {
  transition: all .2s ease;
  background: white;
}

.relative > .cm-auth-input {
  padding-left: 2.35rem;
}

.relative > .cm-auth-input[type="password"] {
  padding-right: 2.5rem;
}

.relative > .cm-auth-input.font-mono {
  padding-left: 2.35rem;
}

.cm-auth-input:focus {
  background: white;
  box-shadow: 0 0 0 3px rgba(5,150,105,.08);
}

/* ── Auth button hover & active ──────────────────── */
.cm-auth-btn {
  transition: all .25s ease;
  position: relative;
  overflow: hidden;
}
.cm-auth-btn:hover {
  transform: translateY(-1px);
}
.cm-auth-btn:active {
  transform: translateY(0);
}

/* ═══════════════════════════════════════════════════
   Booking Pages Styles
   ═══════════════════════════════════════════════════ */

.cm-booking-search {
  background: #fff;
}

.cm-booking-search:focus {
  box-shadow: 0 0 0 3px rgba(5, 150, 105, .08);
}

.cm-booking-detail-link,
.cm-booking-action-link {
  transition: all .2s ease;
}

.cm-booking-detail-link:hover,
.cm-booking-action-link:hover {
  transform: translateY(-1px);
}

.cm-booking-detail-hero img {
  transition: transform .35s ease;
}

.cm-booking-detail-hero:hover img {
  transform: scale(1.02);
}

.cm-rule-item {
  line-height: 1.6;
  align-items: flex-start;
}

.cm-rule-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.cm-rule-bullet {
  margin-top: .45rem;
}

.cm-rule-text {
  flex: 1;
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.cm-status-form {
  background: #fafaf9;
  border: 1px solid #e7e5e4;
  border-radius: .85rem;
  padding: .75rem;
}

.cm-status-select:focus {
  box-shadow: 0 0 0 3px rgba(5, 150, 105, .08);
}

.cm-status-submit-btn {
  transition: all .2s ease;
}

.cm-status-submit-btn:hover {
  transform: translateY(-1px);
}

.cm-cancel-reason-input:focus {
  box-shadow: 0 0 0 3px rgba(239, 68, 68, .12);
}

/* Refund amount input on cancel page */
.cm-refund-block {
  background: linear-gradient(180deg, rgba(16, 185, 129, .05), #ffffff);
  border: 1px solid rgba(16, 185, 129, .22);
  border-radius: .9rem;
  padding: .85rem .95rem;
}

.cm-refund-input-wrap {
  position: relative;
}

.cm-refund-prefix,
.cm-refund-suffix {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  color: #78716c;
  font-size: .8rem;
  font-weight: 600;
  pointer-events: none;
}

.cm-refund-prefix { left: .75rem; }
.cm-refund-suffix { right: .85rem; font-size: .7rem; letter-spacing: .04em; color: #a8a29e; }

.cm-refund-input {
  background: #fff;
}

.cm-refund-input:focus {
  box-shadow: 0 0 0 3px rgba(16, 185, 129, .14);
}

/* Hide spinners on the number input */
.cm-refund-input::-webkit-outer-spin-button,
.cm-refund-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.cm-refund-input[type=number] {
  -moz-appearance: textfield;
}

/* Cancellation card on Booking Detail (camp owner) */
.cm-cancel-card {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(254, 226, 226, .35) 0%, #ffffff 38%);
  border-color: rgba(252, 165, 165, .55) !important;
}

.cm-cancel-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, #ef4444, #f97316);
}

.cm-refund-chip {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .3rem .65rem;
  border-radius: 999px;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #065f46;
  background: rgba(16, 185, 129, .12);
  border: 1px solid rgba(5, 150, 105, .32);
  white-space: nowrap;
}

.cm-refund-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  padding: .75rem .9rem;
  border-radius: .75rem;
  background: linear-gradient(165deg, rgba(16, 185, 129, .1), rgba(255, 255, 255, .9));
  border: 1px solid rgba(16, 185, 129, .25);
}

.cm-refund-row-label {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .73rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #065f46;
}

.cm-refund-row-label svg {
  color: #059669;
}

.cm-refund-row-value {
  font-size: 1.05rem;
  font-weight: 800;
  color: #047857;
}

.cm-refund-row-currency {
  font-size: .68rem;
  font-weight: 700;
  color: #65a30d;
  margin-left: .15rem;
}

.cm-refund-row-empty {
  font-size: .85rem;
  font-weight: 600;
  color: #a8a29e;
  font-style: italic;
}

/* Inline refund issue / update form */
.cm-refund-form-block {
  background: linear-gradient(180deg, rgba(16, 185, 129, .05), #ffffff);
  border: 1px dashed rgba(5, 150, 105, .4);
  border-radius: .9rem;
  padding: .9rem 1rem;
}

.cm-refund-form {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  align-items: stretch;
}

.cm-refund-form .cm-refund-input-wrap {
  flex: 1 1 220px;
  min-width: 200px;
}

.cm-refund-form .cm-refund-input {
  width: 100%;
  background: #fff;
}

.cm-refund-save-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .6rem 1rem;
  border-radius: .75rem;
  background: linear-gradient(135deg, #059669, #047857);
  color: #fff;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .01em;
  border: none;
  box-shadow: 0 6px 14px rgba(5, 150, 105, .22);
  transition: transform .18s ease, box-shadow .2s ease, filter .2s ease;
  white-space: nowrap;
}

.cm-refund-save-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
  box-shadow: 0 10px 20px rgba(5, 150, 105, .28);
}

.cm-refund-save-btn:active {
  transform: translateY(0);
}

/* "Cancelled By" chip */
.cm-cancelled-by-chip {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .3rem .6rem;
  border-radius: 999px;
  font-size: .73rem;
  font-weight: 700;
  letter-spacing: .02em;
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cm-cancelled-by-chip--client {
  background: linear-gradient(135deg, rgba(244, 114, 182, .14), rgba(236, 72, 153, .12));
  color: #9d174d;
  border: 1px solid rgba(236, 72, 153, .3);
}

.cm-cancelled-by-chip--client svg {
  color: #db2777;
}

.cm-cancelled-by-chip--owner {
  background: linear-gradient(135deg, rgba(217, 119, 6, .14), rgba(180, 83, 9, .12));
  color: #92400e;
  border: 1px solid rgba(217, 119, 6, .32);
}

.cm-cancelled-by-chip--owner svg {
  color: #d97706;
}

.cm-cancelled-by-chip--neutral {
  background: rgba(231, 229, 228, .6);
  color: #78716c;
  border: 1px solid #e7e5e4;
}

/* ═══════════════════════════════════════════════════
   Booking Detail — Payment & Note
   ═══════════════════════════════════════════════════ */

.cm-payment-card {
  position: relative;
  overflow: hidden;
}

.cm-payment-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #d97706, #059669, #0ea5e9);
}

.cm-payment-card--transfer::before {
  height: 4px;
  background: linear-gradient(90deg, #6b9cc9, #93c5fd, #bfdbfe);
}

.cm-payment-card--cash::before {
  height: 4px;
  background: linear-gradient(90deg, #047857, #059669, #34d399);
}

.cm-payment-card--neutral::before {
  height: 4px;
  background: linear-gradient(90deg, #78716c, #a8a29e);
}

.cm-payment-card--transfer {
  border-color: rgba(207, 232, 252, .95) !important;
  background: linear-gradient(180deg, rgba(240, 247, 252, .5) 0%, #ffffff 40%);
  box-shadow: 0 1px 3px rgba(59, 130, 246, .05);
}

.cm-payment-card--cash {
  border-color: rgba(5, 150, 105, .28) !important;
  background: linear-gradient(180deg, rgba(5, 150, 105, .055) 0%, #ffffff 42%);
  box-shadow: 0 1px 0 rgba(5, 150, 105, .08), 0 12px 28px rgba(5, 150, 105, .06);
}

.cm-pm-chip {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .3rem .65rem;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space: nowrap;
}

.cm-pm-chip-transfer {
  background: #f0f7fc;
  color: #3a6ea5;
  border: 1px solid #cfe8fc;
}

.cm-pm-chip-cash {
  background: linear-gradient(135deg, rgba(16, 185, 129, .12), rgba(5, 150, 105, .1));
  color: #065f46;
  border: 1px solid rgba(52, 211, 153, .42);
}

.cm-pm-chip-none {
  background: rgba(231, 229, 228, .6);
  color: #78716c;
  border: 1px solid #e7e5e4;
}

.cm-etransfer-box {
  display: flex;
  gap: .7rem;
  align-items: center;
  background: #fafafa;
  border: 1px solid #e7e5e4;
  border-radius: .9rem;
  padding: .8rem .9rem;
  transition: border-color .2s ease, background .2s ease;
}

.cm-etransfer-box:hover {
  border-color: #cbd5e1;
}

.cm-etransfer-icon {
  width: 36px;
  height: 36px;
  border-radius: .6rem;
  background: #64748b;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: none;
}

/* E-Transfer email row — soft blue when payment method is transfer */
.cm-payment-card--transfer .cm-etransfer-box {
  background: #f7fafc;
  border-color: #cfe8fc;
}

.cm-payment-card--transfer .cm-etransfer-box:hover {
  border-color: #b8dbf9;
  background: #f0f7fc;
}

.cm-payment-card--transfer .cm-etransfer-icon {
  background: linear-gradient(145deg, #6b9cc9, #5588b8);
  box-shadow: 0 2px 8px rgba(58, 110, 165, .18);
}

/* Cash bookings: neutral email container if ever shown (fallback) */
.cm-payment-card--cash .cm-etransfer-box {
  background: #fafafa;
  border-color: #e7e5e4;
}

.cm-payment-card--cash .cm-etransfer-icon {
  background: linear-gradient(145deg, #059669, #047857);
  box-shadow: 0 2px 8px rgba(5, 150, 105, .15);
}

.cm-note-box {
  background: linear-gradient(180deg, #fafaf9 0%, #ffffff 100%);
  border: 1px solid #e7e5e4;
  border-radius: .9rem;
  padding: .85rem .9rem;
  transition: border-color .2s ease;
}

.cm-note-box:hover {
  border-color: rgba(5, 150, 105, .25);
}

/* Payment method stat boxes — green vs blue highlight */

.cm-pm-method-box {
  border-radius: .85rem;
  padding: .85rem 1rem;
  border-width: 1.5px;
  border-style: solid;
  transition: transform .18s ease, box-shadow .2s ease, border-color .2s ease;
}

.cm-pm-method-box--inactive {
  background: #fafaf9;
  border-color: #e7e5e4;
}

.cm-pm-method-box--inactive .cm-pm-method-label {
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #a8a29e;
}

.cm-pm-method-box--inactive .cm-pm-method-value {
  font-size: 1rem;
  font-weight: 700;
  color: #78716c;
}

.cm-pm-method-box--inactive svg {
  color: #d6d3d1;
}

.cm-pm-method-box--cash-active {
  background: linear-gradient(165deg, rgba(16, 185, 129, .18), rgba(255, 255, 255, .97));
  border-color: rgba(5, 150, 105, .52);
  box-shadow: 0 6px 18px rgba(5, 150, 105, .14);
}

.cm-pm-method-box--cash-active:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(5, 150, 105, .18);
}

.cm-pm-method-box--cash-active .cm-pm-method-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #065f46;
}

.cm-pm-method-box--cash-active .cm-pm-method-value {
  font-size: 1.1rem;
  font-weight: 800;
  color: #047857;
}

.cm-pm-method-box--cash-active svg {
  color: #059669;
}

/* Only this box gets a soft blue accent */
.cm-pm-method-box--transfer-active {
  background: #f7fafc;
  border-color: #cfe8fc;
  box-shadow: none;
}

.cm-pm-method-box--transfer-active:hover {
  transform: none;
  border-color: #b8dbf9;
  background: #f0f7fc;
}

.cm-pm-method-box--transfer-active .cm-pm-method-label {
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #64748b;
}

.cm-pm-method-box--transfer-active .cm-pm-method-value {
  font-size: 1.05rem;
  font-weight: 700;
  color: #3a6ea5;
}

.cm-pm-method-box--transfer-active svg {
  color: #6b9cc9;
}
