[hidden] { display: none !important; }
/* Positive FX Admin - styles */

:root {
  /* Aligned to the public-site palette (aizome indigo + kintsugi gold) so
     the admin console reads as the same brand, not a different product. */
  --cream:     #f5f0e6;  /* shoji paper */
  --warm:      #ebdfc7;  /* warm wood */
  --clay:      #b8925a;  /* kintsugi gold */
  --clay-d:    #9a7540;  /* deep gold */
  --forest:    #3d5578;  /* softened aizome indigo */
  --forest-m:  #4d6788;  /* softer indigo accent */
  --sage:      #7a8a9a;  /* muted stone-indigo (replaces the leaf sage) */
  --mist:      #b8c5d4;  /* misty indigo */
  --ink:       #1a1f2b;  /* sumi ink */
  --body:      #2a3040;  /* body text */
  --status-ok:   #5d7590;
  --status-warn:  #c89146;
  --status-crit:  #b04a3a;
  --line: rgba(45, 64, 58, 0.12);
  --shadow-card: 0 1px 2px rgba(26, 31, 43, 0.04), 0 8px 24px rgba(26, 31, 43, 0.06);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: "DM Sans", sans-serif;
  background: var(--cream);
  color: var(--body);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3 { font-family: "Cormorant Garamond", serif; font-weight: 400; color: var(--forest); margin: 0; letter-spacing: -0.01em; }
h1 em, h2 em, h3 em { font-style: italic; color: var(--clay); font-weight: 400; }
.eyebrow { font-family: "DM Sans", sans-serif; font-size: 11px; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sage); margin: 0; }
a { color: var(--clay); text-decoration: none; }
a:hover { color: var(--clay-d); text-decoration: underline; }

/* ============ LOGIN ============ */
.login-shell { min-height: 100vh; display: grid; place-items: center; padding: 24px; background: radial-gradient(ellipse at top left, rgba(61, 85, 120, 0.08), transparent 50%), radial-gradient(ellipse at bottom right, rgba(184, 146, 90, 0.07), transparent 50%), var(--cream); }
.login-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 40px 36px; width: 100%; max-width: 420px; box-shadow: var(--shadow-card); }
.login-card h1 { font-size: 38px; margin: 8px 0 28px; }
.login-card label { display: block; margin-bottom: 16px; }
.login-card label span { display: block; font-size: 13px; font-weight: 500; color: var(--forest); margin-bottom: 6px; }
.login-card input[type="password"] { width: 100%; padding: 12px 14px; border: 1px solid var(--line); border-radius: 8px; font-family: inherit; font-size: 15px; background: var(--cream); color: var(--ink); transition: border-color 0.15s; }
.login-card input:focus { outline: none; border-color: var(--clay); }
.login-card button[type="submit"] { width: 100%; padding: 13px; margin-top: 8px; background: var(--forest); color: #fff; border: none; border-radius: 8px; font-family: inherit; font-size: 14px; font-weight: 500; letter-spacing: 0.04em; cursor: pointer; transition: background 0.15s; }
.login-card button[type="submit"]:hover { background: var(--ink); }
.login-error { color: var(--status-crit); font-size: 13px; margin: 12px 0 0; }
.login-note { margin: 24px 0 0; font-size: 12px; color: var(--sage); text-align: center; }

/* ============ TOPBAR ============ */
.topbar { display: flex; align-items: center; justify-content: space-between; padding: 16px 32px; background: var(--forest); color: var(--mist); position: sticky; top: 0; z-index: 50; border-bottom: 1px solid rgba(168,191,172,0.12); }
.brand { display: flex; align-items: center; gap: 10px; }
.brand-mark { display: inline-grid; place-items: center; width: 32px; height: 32px; border-radius: 8px; background: var(--clay); color: #fff; font-weight: 600; font-size: 12px; letter-spacing: 0.06em; }
.brand-mark-img { width: 40px; height: 40px; object-fit: contain; display: block; filter: grayscale(0.4) contrast(0.9); }
.brand-admin-badge {
  display: inline-block;
  font-family: 'Montserrat', 'DM Sans', sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: #fff;
  background: var(--clay);
  padding: 3px 7px;
  border-radius: 3px;
  margin-left: 4px;
  line-height: 1;
  text-transform: uppercase;
}
.brand-name { font-family: "Cormorant Garamond", serif; font-size: 20px; color: #fff; }
.brand-name em { color: var(--mist); font-style: italic; }
.topbar-datetime { font-family: "DM Sans", sans-serif; font-size: 13px; font-weight: 500; color: var(--clay); letter-spacing: 0.02em; }
.topbar-nav { display: flex; align-items: center; gap: 24px; }
.topbar-nav a { color: var(--mist); font-size: 13px; font-weight: 500; letter-spacing: 0.02em; padding: 6px 0; border-bottom: 2px solid transparent; transition: color 0.15s, border-color 0.15s; }
.topbar-nav a:hover, .topbar-nav a.active { color: #fff; border-bottom-color: var(--clay); text-decoration: none; }
.topbar-nav .ghost { background: transparent; border: 1px solid rgba(168,191,172,0.3); color: var(--mist); padding: 6px 14px; border-radius: 6px; font-family: inherit; font-size: 12px; cursor: pointer; transition: background 0.15s, color 0.15s; }
.topbar-nav .ghost:hover { background: rgba(255,255,255,0.08); color: #fff; }

/* ============ BRAND WATERMARK + VINES ============ */
/* Brand mark pinned to the top-right so most of it remains visible even
   when cards cover the middle. Bleeds slightly off the right edge so it
   feels like the identity of the workspace, not an unused illustration. */
.brand-watermark {
  position: fixed;
  top: 72px;                /* sit just below topbar */
  right: -90px;             /* bleed partially off-screen right */
  width: min(640px, 55vw);
  height: min(640px, 55vw);
  z-index: 0;
  pointer-events: none;
  background: url('/brand-mark-xl.png') no-repeat center center;
  background-size: contain;
  opacity: 0.11;
  filter: sepia(0.2) saturate(0.8) brightness(0.9);
  -webkit-user-select: none;
  user-select: none;
}
/* Warm radial glow behind the watermark — makes it feel like an intentional
   spotlight rather than a floating PNG. */
.brand-watermark::before {
  content: '';
  position: absolute;
  inset: -15%;
  background: radial-gradient(circle, rgba(184, 146, 90, 0.12) 0%, transparent 62%);
  pointer-events: none;
  z-index: -1;
}
@media (max-width: 900px) {
  .brand-watermark { opacity: 0.06; right: -30%; top: 100px; }
}

.vines-bg { position: fixed; inset: 0; width: 100vw; height: 100vh; z-index: 0; pointer-events: none; opacity: 0.5; }
#dash-view { position: relative; }
.dash { position: relative; z-index: 1; }

/* ============ DASHBOARD ============ */
/* Overview tab is tuned to fit a MacBook Air 13" viewport (~720–768px usable
   height after the topbar) without scrolling. If new cards are added, either
   compact existing ones or move the addition to a dedicated tab. */
.dash { max-width: 1280px; margin: 0 auto; padding: 24px 32px 96px; }
.dash-head { margin-bottom: 16px; }
.dash-head h2 { font-size: 28px; margin-top: 4px; line-height: 1.15; }
.grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.span-2 { grid-column: span 2; }
.span-full { grid-column: 1 / -1; }

/* ============ CARDS ============ */
.card { background: rgba(255, 255, 255, 0.96); border: 1px solid var(--line); border-radius: 12px; padding: 18px 20px; display: flex; flex-direction: column; min-height: 150px; box-shadow: var(--shadow-card); backdrop-filter: blur(6px); }
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 12px; }
.card-body { flex: 1; }
.card-foot { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); font-size: 12px; }
.refresh { background: transparent; border: 1px solid var(--line); border-radius: 6px; width: 26px; height: 26px; cursor: pointer; color: var(--sage); font-size: 14px; transition: background 0.15s, transform 0.3s; }
.refresh:hover { background: var(--cream); color: var(--clay); }
.refresh.spinning { transform: rotate(360deg); }
.count { background: var(--cream); color: var(--forest); padding: 2px 10px; border-radius: 999px; font-size: 12px; font-weight: 500; }
.loading, .placeholder { color: var(--sage); font-size: 13px; font-style: italic; }

/* ============ STATUS PILLS ============ */
.status { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 500; }
.status::before { content: ""; width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.status.ok { background: rgba(93, 117, 144,0.12); color: var(--status-ok); }
.status.ok::before { background: var(--status-ok); }
.status.warn { background: rgba(200,145,70,0.14); color: var(--status-warn); }
.status.warn::before { background: var(--status-warn); }
.status.crit { background: rgba(176,74,58,0.12); color: var(--status-crit); }
.status.crit::before { background: var(--status-crit); }

/* ============ AR FILING BANNER ============ */
.ar-filing-banner { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 12px; padding: 10px 14px; background: rgba(200,145,70,0.10); border: 1px solid rgba(200,145,70,0.25); border-radius: 8px; }
.ar-filing-text { font-size: 13px; color: var(--body); line-height: 1.4; }
.ar-filing-text strong { color: var(--forest); }
.ar-mark-filed { flex-shrink: 0; padding: 6px 14px; font-size: 12px; font-weight: 600; font-family: inherit; color: #fff; background: var(--status-ok); border: none; border-radius: 6px; cursor: pointer; transition: opacity 0.15s; }
.ar-mark-filed:hover { opacity: 0.85; }
.ar-mark-filed:disabled { opacity: 0.5; cursor: not-allowed; }

/* ============ DETAIL ROWS ============ */
.detail-rows { display: grid; gap: 8px; margin-top: 12px; }
.detail-row { display: flex; justify-content: space-between; align-items: baseline; font-size: 13px; gap: 12px; }
.detail-row dt { color: var(--sage); margin: 0; }
.detail-row dd { color: var(--forest); margin: 0; font-weight: 500; text-align: right; }
.big-number { font-family: "Cormorant Garamond", serif; font-size: 42px; color: var(--forest); line-height: 1; }
.big-number .unit { font-family: "DM Sans", sans-serif; font-size: 13px; color: var(--sage); font-weight: 400; margin-left: 6px; }

/* ============ CE PROGRESS BAR ============ */
.progress { background: var(--cream); border-radius: 999px; height: 8px; overflow: hidden; margin: 14px 0 8px; }
.progress-bar { height: 100%; background: linear-gradient(90deg, var(--forest-m), var(--clay)); border-radius: 999px; transition: width 0.6s; }

/* ============ APPOINTMENTS LAYOUT ============ */
.span-3 { grid-column: span 3; }

/* ============ CALENDAR ============ */
.cal-nav { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.cal-month-label { font-family: "Cormorant Garamond", serif; font-size: 18px; font-weight: 600; color: var(--forest); }
.cal-prev, .cal-next { background: none; border: 1px solid var(--line); border-radius: 6px; width: 32px; height: 32px; font-size: 18px; color: var(--forest); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.15s; }
.cal-prev:hover, .cal-next:hover { background: var(--warm); }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cal-header { text-align: center; font-size: 10px; font-weight: 600; color: var(--sage); text-transform: uppercase; letter-spacing: 0.06em; padding: 4px 0 6px; }
.cal-day { text-align: center; padding: 5px 2px; font-size: 12px; color: var(--body); border-radius: 6px; cursor: pointer; position: relative; transition: background 0.12s; }
.cal-day:hover { background: var(--warm); }
.cal-day.empty { cursor: default; }
.cal-day.empty:hover { background: none; }
.cal-day.today span { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border: 2px solid var(--sage); border-radius: 50%; }
.cal-day.selected { background: var(--forest); color: #fff; }
.cal-day.selected.today span { border-color: #fff; }
.cal-day.has-appts::after { content: ""; display: block; width: 4px; height: 4px; border-radius: 50%; background: var(--clay); margin: 1px auto 0; }
.cal-day.selected.has-appts::after { background: var(--warm); }
.cal-day.blackout { color: var(--status-crit); text-decoration: line-through; opacity: 0.6; }
.cal-day.blackout:hover { background: rgba(176,74,58,0.08); }
.cal-day.selected.blackout { background: rgba(176,74,58,0.2); color: var(--status-crit); }

.day-label { font-size: 12px; font-weight: 600; color: var(--sage); text-transform: uppercase; letter-spacing: 0.06em; margin: 0 0 4px; padding-bottom: 8px; border-bottom: 1px solid var(--line); }

/* ============ APPOINTMENT / MESSAGE ROWS ============ */
.appt-row, .msg-row { display: grid; grid-template-columns: 56px 1fr auto; gap: 14px; padding: 10px 0; border-bottom: 1px solid var(--line); align-items: center; }
.appt-row:last-child, .msg-row:last-child { border-bottom: none; }
.appt-row.clickable { cursor: pointer; border-radius: 6px; padding: 10px 8px; margin: 0 -8px; }
.appt-row.clickable:hover { background: var(--cream); }
.appt-row.compact { padding: 8px 0; }
.appt-time, .msg-when { text-align: center; font-size: 11px; color: var(--sage); text-transform: uppercase; letter-spacing: 0.06em; line-height: 1.2; }
.appt-time strong, .msg-when strong { display: block; font-family: "Cormorant Garamond", serif; font-size: 20px; color: var(--forest); font-weight: 400; margin-bottom: 1px; }
.appt-meta strong, .msg-meta strong { display: block; color: var(--forest); font-size: 13px; font-weight: 500; }
.appt-meta span, .msg-meta span { color: var(--sage); font-size: 12px; }
.appt-action, .msg-action { font-size: 12px; }

/* ============ MODAL ============ */
.modal-overlay { position: fixed; inset: 0; background: rgba(26,35,24,0.45); display: flex; align-items: center; justify-content: center; z-index: 100; padding: 24px; }
.modal-card { background: #fff; border-radius: 14px; padding: 28px 32px; max-width: 480px; width: 100%; box-shadow: 0 16px 48px rgba(26,35,24,0.18); position: relative; }
.modal-close { position: absolute; top: 14px; right: 14px; background: none; border: none; font-size: 24px; color: var(--sage); cursor: pointer; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; border-radius: 6px; transition: background 0.15s; }
.modal-close:hover { background: var(--cream); color: var(--forest); }
.modal-body h3 { font-size: 24px; margin: 4px 0 16px; }

/* ============ MESSAGES TABS ============ */
.msgs-tabs { display: flex; gap: 4px; }
.msgs-tab { padding: 4px 12px; font-size: 12px; font-family: inherit; font-weight: 500; color: var(--sage); background: none; border: 1px solid var(--line); border-radius: 6px; cursor: pointer; transition: all 0.15s; }
.msgs-tab:hover { background: var(--cream); }
.msgs-tab.active { background: var(--forest); color: #fff; border-color: var(--forest); }

/* ============ MESSAGE DETAIL + REPLY ============ */
.msg-row { cursor: pointer; border-radius: 6px; padding: 10px 8px; margin: 0 -8px; }
.msg-row:hover { background: var(--cream); }
.msg-row.unread .msg-meta strong { color: var(--ink); font-weight: 600; }
.msg-row.unread .msg-meta strong::before { content: ""; display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--clay); margin-right: 6px; vertical-align: middle; }
.msg-arrow { font-size: 20px; color: var(--sage); font-weight: 300; }
.msg-action { display: inline-flex; align-items: center; gap: 8px; }
.msg-delete-btn {
  background: var(--cream);
  border: 1px solid var(--line);
  color: var(--sage);
  font-size: 15px;
  line-height: 1;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  padding: 0;
}
.msg-delete-btn:hover { background: #f5d4cf; color: #b04a3a; border-color: #b04a3a; }
.msg-delete-btn:focus-visible { outline: 2px solid var(--clay); outline-offset: 2px; }
.msg-time { font-size: 11px; color: var(--sage); }
.msg-back { background: none; border: none; font-family: inherit; font-size: 13px; font-weight: 500; color: var(--clay); cursor: pointer; padding: 0; margin-bottom: 16px; }
.msg-back:hover { text-decoration: underline; }
.msg-original { background: var(--warm); border-radius: 8px; padding: 16px; margin-bottom: 16px; }
.msg-original-head { display: flex; flex-direction: column; gap: 2px; margin-bottom: 12px; }
.msg-original-head strong { color: var(--forest); font-size: 15px; }
.msg-original-head span { color: var(--sage); font-size: 12px; }
.msg-body { font-size: 14px; line-height: 1.6; color: var(--body); margin: 0; }
.reply-sent { background: rgba(93, 117, 144,0.06); border-left: 3px solid var(--status-ok); border-radius: 0 8px 8px 0; padding: 12px 16px; margin-bottom: 12px; }
.reply-sent-label { font-size: 11px; color: var(--sage); margin: 0 0 6px; text-transform: uppercase; letter-spacing: 0.06em; }
.reply-sent-body { font-size: 13px; line-height: 1.5; color: var(--body); margin: 0; }
.reply-section { margin-top: 16px; }
.template-picker { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.template-btn { padding: 6px 12px; font-size: 12px; font-family: inherit; font-weight: 500; color: var(--forest); background: var(--warm); border: 1px solid var(--line); border-radius: 6px; cursor: pointer; transition: background 0.15s, border-color 0.15s; }
.template-btn:hover { background: var(--mist); color: #fff; }
.template-btn.active { background: var(--forest); color: #fff; border-color: var(--forest); }
.reply-area { width: 100%; font-family: inherit; font-size: 13px; line-height: 1.5; color: var(--body); background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 12px; resize: vertical; }
.reply-area:focus { outline: none; border-color: var(--sage); }
.reply-actions { display: flex; align-items: center; gap: 10px; margin-top: 10px; flex-wrap: wrap; }
.reply-send, .reply-schedule-toggle, .reply-schedule-send { padding: 8px 18px; font-size: 13px; font-weight: 600; font-family: inherit; color: #fff; background: var(--forest); border: none; border-radius: 6px; cursor: pointer; transition: opacity 0.15s; }
.reply-send:hover, .reply-schedule-send:hover { opacity: 0.85; }
.reply-send:disabled, .reply-schedule-send:disabled { opacity: 0.5; cursor: not-allowed; }
.reply-schedule-toggle { background: var(--warm); color: var(--forest); border: 1px solid var(--line); }
.reply-schedule-toggle:hover { background: var(--mist); color: #fff; }
.reply-status { font-size: 12px; }
.reply-status.ok { color: var(--status-ok); }
.reply-status.crit { color: var(--status-crit); }

/* ============ SCHEDULE PICKER ============ */
.schedule-picker { display: flex; align-items: center; gap: 10px; margin-top: 10px; flex-wrap: wrap; }
.sched-date, .sched-time { padding: 7px 10px; font-family: inherit; font-size: 13px; border: 1px solid var(--line); border-radius: 6px; background: #fff; color: var(--body); }
.sched-date:focus, .sched-time:focus { outline: none; border-color: var(--sage); }
.sched-cancel { padding: 4px 10px; font-size: 11px; font-family: inherit; font-weight: 500; color: var(--status-crit); background: rgba(176,74,58,0.08); border: 1px solid rgba(176,74,58,0.2); border-radius: 4px; cursor: pointer; }
.sched-cancel:hover { background: rgba(176,74,58,0.15); }
.msg-detail-footer { display: flex; justify-content: flex-end; margin-top: 20px; padding-top: 14px; border-top: 1px solid var(--line); }
.msg-detail-delete { padding: 6px 14px; font-size: 12px; font-family: inherit; font-weight: 500; color: var(--status-crit); background: rgba(176,74,58,0.08); border: 1px solid rgba(176,74,58,0.2); border-radius: 4px; cursor: pointer; transition: background 0.15s; }
.msg-detail-delete:hover { background: rgba(176,74,58,0.15); }
.msg-restore-btn { padding: 4px 10px; font-size: 11px; font-family: inherit; font-weight: 500; color: var(--status-ok); background: rgba(93, 117, 144,0.08); border: 1px solid rgba(93, 117, 144,0.2); border-radius: 4px; cursor: pointer; margin-right: 6px; }
.msg-restore-btn:hover { background: rgba(93, 117, 144,0.15); }
.msg-hard-delete-btn { padding: 4px 10px; font-size: 11px; font-family: inherit; font-weight: 500; color: var(--status-crit); background: rgba(176,74,58,0.08); border: 1px solid rgba(176,74,58,0.2); border-radius: 4px; cursor: pointer; }
.msg-hard-delete-btn:hover { background: rgba(176,74,58,0.15); }
.msg-row.deleted-row .msg-meta strong { color: var(--sage); }

/* ============ BLOG ============ */
.btn-new-post {
  padding: 5px 14px;
  font-size: 12px;
  font-family: inherit;
  font-weight: 600;
  color: #fff;
  background: var(--forest);
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: opacity 0.15s;
}
.btn-new-post:hover { opacity: 0.85; }

.blog-overview-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
  gap: 12px;
}
.blog-overview-row:last-child { border-bottom: none; }
.blog-overview-row strong { font-size: 13px; color: var(--forest); font-weight: 500; }
.blog-overview-row span { font-size: 11px; color: var(--sage); white-space: nowrap; }
.blog-overview-row div { display: flex; align-items: baseline; gap: 8px; }
.blog-overview-views { font-size: 10px !important; color: var(--mist) !important; font-weight: 400; }
.blog-overview-label { font-size: 10px; font-weight: 600; color: var(--status-warn); text-transform: uppercase; letter-spacing: 0.1em; margin: 8px 0 2px; }
.blog-overview-row.scheduled strong { color: var(--sage); font-weight: 400; }

.blog-filters { display: flex; gap: 8px; margin-bottom: 20px; flex-wrap: wrap; align-items: center; }
.blog-filter-btn { padding: 5px 14px; font-size: 12px; font-family: inherit; font-weight: 500; color: var(--forest); background: var(--cream); border: 1px solid var(--line); border-radius: 999px; cursor: pointer; transition: all 0.15s; }
.blog-filter-btn:hover { background: var(--warm); }
.blog-filter-btn.active { background: var(--forest); color: #fff; border-color: var(--forest); }
.blog-filter-count { font-size: 10px; opacity: 0.7; margin-left: 2px; }

/* Page-size picker — sits to the right of the filter chips */
.blog-page-size { margin-left: auto; }
.blog-page-size select {
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  color: var(--forest);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 5px 10px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.blog-page-size select:hover { border-color: var(--clay); }
.blog-page-size select:focus { outline: none; border-color: var(--clay); }

/* Pagination strip at the bottom of the blog table */
.blog-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 18px;
  padding: 12px 4px 0;
  border-top: 1px solid var(--line);
}
.blog-page-btn {
  padding: 6px 14px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  color: var(--forest);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.blog-page-btn:hover:not(:disabled) { background: var(--warm); border-color: var(--clay); }
.blog-page-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.blog-page-indicator {
  font-size: 12px;
  color: var(--sage);
  font-weight: 500;
  letter-spacing: 0.02em;
}
.blog-page-range { color: var(--body); opacity: 0.6; }
.blog-discard-btn { padding: 8px 16px; font-size: 13px; font-family: inherit; color: var(--sage); background: none; border: 1px solid var(--line); border-radius: 6px; cursor: pointer; transition: background 0.15s; }
.blog-discard-btn:hover { background: var(--cream); color: var(--status-crit); }
.blog-table {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}
.blog-row {
  display: grid;
  grid-template-columns: 1fr 110px 80px 150px 140px;
  gap: 20px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  align-items: center;
}
.blog-row:last-child { border-bottom: none; }
.blog-row:not(.blog-row-head):hover { background: var(--cream); }
.blog-row-head {
  background: var(--cream);
  padding: 10px 18px;
  border-bottom: 1px solid var(--line);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sage);
}
.blog-row-head > div { text-align: left; }
.blog-row-head > div:nth-child(3) { text-align: center; }
.blog-row-title { min-width: 0; }
.blog-row-title strong { display: block; font-size: 14px; color: var(--forest); font-weight: 600; margin-bottom: 3px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.blog-row-title span { display: block; font-size: 12px; color: var(--sage); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; line-height: 1.4; }
.blog-row-meta { display: flex; align-items: center; }
.blog-row-date { font-size: 12px; color: var(--sage); white-space: nowrap; }
.blog-row-views { text-align: center; }
.blog-row-views strong { font-family: "Cormorant Garamond", serif; font-size: 22px; font-weight: 600; color: var(--forest); line-height: 1; }
.blog-row-views-dash { color: var(--line); font-size: 16px; }
.blog-row-actions { display: flex; gap: 6px; justify-content: flex-end; }
.blog-edit, .blog-delete {
  padding: 4px 10px;
  font-size: 11px;
  font-family: inherit;
  font-weight: 500;
  border-radius: 4px;
  cursor: pointer;
  border: 1px solid var(--line);
  background: var(--cream);
  color: var(--forest);
  transition: background 0.15s;
}
.blog-edit:hover { background: var(--warm); }
.blog-delete { color: var(--status-crit); background: rgba(176,74,58,0.06); border-color: rgba(176,74,58,0.2); }
.blog-delete:hover { background: rgba(176,74,58,0.12); }
.blog-restore { color: var(--status-ok) !important; background: rgba(93, 117, 144,0.06) !important; border-color: rgba(93, 117, 144,0.2) !important; }
.blog-restore:hover { background: rgba(93, 117, 144,0.12) !important; }

.blog-title-input {
  width: 100%;
  padding: 12px 14px;
  font-family: "Cormorant Garamond", serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--forest);
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  margin-bottom: 12px;
}
.blog-title-input:focus { outline: none; border-color: var(--sage); }

.blog-editor-wrap {
  display: grid;
  grid-template-columns: 44px 1fr;
}
.editor-toolbar {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 8px 6px;
  background: var(--cream);
  border: 1px solid var(--line);
  border-right: none;
  border-radius: 8px 0 0 8px;
  position: sticky;
  top: 80px;
  align-self: start;
}
.editor-toolbar button {
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
  color: var(--forest);
  transition: background 0.12s;
}
.editor-toolbar button:hover { background: var(--warm); }

.toolbar-unlink-btn { color: var(--status-crit) !important; }

.blog-meta-row { margin-bottom: 12px; }
.blog-meta-label { display: block; font-size: 11px; font-weight: 600; color: var(--sage); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 6px; }
.blog-meta-input { width: 100%; padding: 8px 12px; font-family: inherit; font-size: 13px; border: 1px solid var(--line); border-radius: 6px; color: var(--body); }
.blog-meta-input:focus { outline: none; border-color: var(--sage); }
.topic-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.topic-chip { display: inline-flex; align-items: center; cursor: pointer; }
.topic-chip input { display: none; }
.topic-chip span { padding: 4px 12px; font-size: 12px; font-weight: 500; color: var(--forest); background: var(--cream); border: 1px solid var(--line); border-radius: 999px; transition: all 0.15s; }
.topic-chip input:checked + span { background: var(--forest); color: #fff; border-color: var(--forest); }
.topic-chip:hover span { background: var(--warm); }
.topic-chip input:checked:hover + span { opacity: 0.85; }
.blog-schedule-picker { display: flex; gap: 8px; align-items: center; }
.blog-sched-date, .blog-sched-time { padding: 6px 10px; font-family: inherit; font-size: 13px; border: 1px solid var(--line); border-radius: 6px; }

.blog-contenteditable {
  min-height: 400px;
  padding: 20px 24px;
  border: 1px solid var(--line);
  border-radius: 0 8px 8px 0;
  background: #fff;
  font-size: 15px;
  line-height: 1.7;
  color: var(--body);
  outline: none;
}
.blog-contenteditable:focus { border-color: var(--sage); }
.blog-contenteditable img { max-width: 100%; height: auto; border-radius: 8px; margin: 12px 0; }
.blog-contenteditable h2 { font-family: "Cormorant Garamond", serif; font-size: 24px; color: var(--forest); margin: 16px 0 8px; }
.blog-contenteditable h3 { font-family: "Cormorant Garamond", serif; font-size: 20px; color: var(--forest); margin: 12px 0 6px; }

.blog-save-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 14px;
}
.blog-status-select {
  padding: 7px 10px;
  font-family: inherit;
  font-size: 13px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fff;
  color: var(--body);
}
.blog-save-btn {
  padding: 8px 20px;
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  color: #fff;
  background: var(--forest);
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: opacity 0.15s;
}
.blog-save-btn:hover { opacity: 0.85; }
.blog-save-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.blog-save-status { font-size: 12px; }
.blog-save-status.ok { color: var(--status-ok); }
.blog-save-status.crit { color: var(--status-crit); }

/* ============ BLACKOUT SCHEDULE ============ */
.blackout-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 16px; }
.blackout-col { }
.blackout-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--line); gap: 12px; }
.blackout-row:last-child { border-bottom: none; }
.blackout-meta strong { display: block; font-size: 13px; color: var(--forest); font-weight: 500; }
.blackout-meta span { font-size: 11px; color: var(--sage); }
.blackout-del { background: none; border: 1px solid var(--line); color: var(--status-crit); font-size: 16px; width: 28px; height: 28px; border-radius: 4px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.blackout-del:hover { background: rgba(176,74,58,0.08); }
.blackout-presets { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; padding-top: 12px; border-top: 1px solid var(--line); }
.blackout-preset { padding: 6px 14px; font-size: 12px; font-family: inherit; font-weight: 500; color: var(--forest); background: var(--cream); border: 1px solid var(--line); border-radius: 999px; cursor: pointer; }
.blackout-preset:hover { background: var(--warm); }
.blackout-tab { padding: 8px 14px; font-family: inherit; font-size: 13px; font-weight: 500; color: var(--sage); background: none; border: none; border-bottom: 2px solid transparent; cursor: pointer; }
.blackout-tab.active { color: var(--forest); border-bottom-color: var(--clay); }
@media (max-width: 900px) { .blackout-grid { grid-template-columns: 1fr; } }

/* ============ EMPTY STATES ============ */
.empty { text-align: center; padding: 24px 12px; color: var(--sage); font-size: 13px; }

/* ============ RESPONSIVE ============ */
@media (max-width: 980px) {
  .grid { grid-template-columns: repeat(2, 1fr); }
  .span-2 { grid-column: span 2; }
  .span-full { grid-column: 1 / -1; }
  .appts-split { grid-template-columns: 1fr; }
  .appts-cal-col { border-right: none; padding-right: 0; border-bottom: 1px solid var(--line); padding-bottom: 16px; }
}
@media (max-width: 640px) {
  .topbar { padding: 14px 18px; flex-wrap: wrap; gap: 12px; }
  .topbar-nav { gap: 14px; flex-wrap: wrap; }
  .topbar-nav a { font-size: 12px; }
  .dash { padding: 24px 18px 60px; }
  .dash-head h2 { font-size: 28px; }
  .grid { grid-template-columns: 1fr; gap: 14px; }
  .span-2, .span-3, .span-full { grid-column: span 1; }
  .card { padding: 18px 18px; min-height: auto; }
  .login-card { padding: 32px 24px; }
  .login-card h1 { font-size: 32px; }
}

/* =============================================
   CLIENTS TAB
   ============================================= */
.card-clients .card-head { gap: 16px; flex-wrap: wrap; }
.clients-search-wrap { flex: 1; min-width: 220px; max-width: 420px; }
.clients-search {
  width: 100%;
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-family: inherit;
  font-size: 13px;
  background: var(--cream);
  color: var(--ink);
  transition: border-color 0.15s, background 0.15s;
}
.clients-search:focus { outline: none; border-color: var(--clay); background: #fff; }

.clients-filter-chips { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.chip-filter {
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 12px;
  font-family: inherit;
  font-size: 12px;
  color: var(--sage);
  cursor: pointer;
  transition: all 0.15s;
}
.chip-filter:hover { color: var(--forest); border-color: var(--sage); }
.chip-filter.active { background: var(--forest); color: #fff; border-color: var(--forest); }

.clients-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  overflow-y: auto;
  max-height: 70vh;
  padding-right: 4px;
}
.clients-list::-webkit-scrollbar { width: 6px; }
.clients-list::-webkit-scrollbar-thumb { background: rgba(122, 138, 154,0.25); border-radius: 3px; }

.client-row {
  display: grid;
  grid-template-columns: 38px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.1s;
  border: 1px solid transparent;
}
.client-row:hover { background: var(--cream); }
.client-row.active { background: var(--cream); border-color: var(--clay); }

.client-row-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--sage), var(--forest-m));
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.client-row.active .client-row-avatar { background: linear-gradient(135deg, var(--clay), var(--clay-d)); }

.client-row-main { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.client-row-top { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.client-row-top strong { color: var(--forest); font-size: 14px; font-weight: 600; }
.client-row-sub { font-size: 12px; color: var(--sage); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.client-row-stats { display: flex; gap: 8px; flex-wrap: wrap; font-size: 11px; color: var(--sage); margin-top: 2px; }
.client-row-stats span { display: inline-block; }
.client-row-stats .pill-upcoming {
  background: var(--clay);
  color: #fff;
  padding: 1px 8px;
  border-radius: 999px;
  font-weight: 500;
}
.client-row-time { font-size: 11px; color: var(--sage); white-space: nowrap; align-self: flex-start; }

.tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--warm);
  color: var(--forest);
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
}
.tag.tag-sm { padding: 1px 7px; font-size: 10px; }
.tag.tag-more { background: transparent; color: var(--sage); }
.tag-del {
  background: transparent;
  border: none;
  color: var(--sage);
  font-size: 13px;
  line-height: 1;
  padding: 0;
  cursor: pointer;
  transition: color 0.15s;
}
.tag-del:hover { color: var(--status-crit); }

/* Appointment modal actions */
.appt-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.appt-reschedule-btn, .appt-cancel-btn {
  padding: 8px 18px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.appt-reschedule-btn { background: var(--forest); color: #fff; border: none; }
.appt-reschedule-btn:hover { background: var(--forest-m); }
.appt-cancel-btn { background: transparent; color: var(--status-crit); border: 1px solid rgba(176,74,58,0.3); }
.appt-cancel-btn:hover { background: rgba(176,74,58,0.08); border-color: var(--status-crit); }

.appt-reschedule-picker, .appt-cancel-picker {
  margin-top: 18px;
  padding: 16px;
  background: var(--cream);
  border-radius: 8px;
}
.appt-picker-label { font-size: 12px; font-weight: 500; color: var(--forest); margin: 0 0 10px; text-transform: uppercase; letter-spacing: 0.08em; }
.appt-picker-row { display: flex; gap: 10px; margin-bottom: 10px; }
.appt-picker-row input {
  flex: 1;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  color: var(--ink);
}
.appt-picker-row input:focus { outline: none; border-color: var(--clay); }
.appt-cancel-reason {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  resize: vertical;
  margin-bottom: 10px;
}
.appt-cancel-reason:focus { outline: none; border-color: var(--clay); }
.appt-picker-notify { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--body); margin-bottom: 10px; cursor: pointer; }
.appt-picker-actions { display: flex; justify-content: flex-end; gap: 8px; }
.appt-picker-cancel {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--sage);
  padding: 6px 14px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  cursor: pointer;
}
.appt-picker-cancel:hover { background: #fff; color: var(--forest); }
.appt-picker-save, .appt-picker-confirm-cancel {
  padding: 6px 16px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  border: none;
  color: #fff;
}
.appt-picker-save { background: var(--forest); }
.appt-picker-save:hover { background: var(--forest-m); }
.appt-picker-save:disabled, .appt-picker-confirm-cancel:disabled { opacity: 0.6; cursor: not-allowed; }
.appt-picker-confirm-cancel { background: var(--status-crit); }
.appt-picker-confirm-cancel:hover { background: #8c3a2e; }
.appt-picker-status { margin: 8px 0 0; font-size: 12px; }
.appt-picker-status.crit { color: var(--status-crit); }

/* Clickable client stat pills */
.stat-clickable {
  cursor: pointer;
  font-family: inherit;
  text-align: center;
  transition: background 0.15s, border-color 0.15s, transform 0.1s;
}
.stat-clickable:hover { background: #fff; border-color: var(--clay); }
.stat-clickable.active { background: var(--forest); border-color: var(--forest); }
.stat-clickable.active strong, .stat-clickable.active span { color: #fff; }

.timeline-filter-note {
  margin: 0 0 10px;
  padding: 6px 12px;
  background: rgba(184, 146, 90,0.08);
  border-left: 3px solid var(--clay);
  border-radius: 4px;
  font-size: 12px;
  color: var(--body);
}
.timeline-filter-note strong { color: var(--clay-d); }
.timeline-clear-btn {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--sage);
  padding: 3px 12px;
  border-radius: 999px;
  font-family: inherit;
  font-size: 11px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.timeline-clear-btn:hover { background: var(--cream); color: var(--forest); }

/* Messages sub-tab counts */
.msgs-tab-count {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 7px;
  background: var(--clay);
  color: #fff;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 600;
  min-width: 16px;
  text-align: center;
  line-height: 1.4;
}
.msgs-tab[data-msgs-view="scheduled"] .msgs-tab-count,
.msgs-tab[data-msgs-view="deleted"] .msgs-tab-count,
.msgs-tab[data-msgs-view="sent"] .msgs-tab-count { background: var(--sage); }
.msgs-tab.active .msgs-tab-count { background: var(--forest); }

/* Full-screen client detail modal */
body.modal-open { overflow: hidden; }
.client-modal-overlay {
  align-items: stretch;
  justify-content: center;
  padding: 24px;
}
.client-modal-card {
  width: 100%;
  max-width: 1200px;
  max-height: none;
  height: calc(100vh - 48px);
  padding: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
}
.client-modal-close {
  position: absolute;
  top: 14px;
  right: 18px;
  z-index: 2;
  background: var(--cream);
  border: 1px solid var(--line);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  font-size: 20px;
  color: var(--sage);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background 0.15s, color 0.15s, transform 0.15s;
}
.client-modal-close:hover { background: #fff; color: var(--status-crit); transform: scale(1.05); }
.client-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 32px 40px;
}
.client-modal-body::-webkit-scrollbar { width: 8px; }
.client-modal-body::-webkit-scrollbar-thumb { background: rgba(122, 138, 154,0.3); border-radius: 4px; }
.client-modal-body::-webkit-scrollbar-track { background: transparent; }

.client-detail { position: relative; }

/* Source badges (detail header) */
.client-source-badges { display: flex; gap: 6px; margin-top: 8px; flex-wrap: wrap; }
.badge-src {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.badge-src-booking { background: rgba(184, 146, 90,0.15); color: var(--clay-d); }
.badge-src-message { background: rgba(77, 103, 136,0.15); color: var(--forest-m); }
.badge-src-manual { background: rgba(122, 138, 154,0.15); color: var(--sage); }
.badge-src-unknown { background: rgba(61, 85, 120,0.08); color: var(--sage); }

/* Source pips (inline in list rows) */
.source-pip {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  margin: 0 1px;
}
.source-pip.pip-booking { background: var(--clay); }
.source-pip.pip-message { background: var(--forest-m); }
.source-pip.pip-manual { background: var(--sage); }

.client-detail-head {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 20px;
}
.client-detail-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--clay), var(--clay-d));
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}
.client-detail-ident { flex: 1; min-width: 0; }
.client-name-edit {
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  font-weight: 600;
  color: var(--forest);
  margin: 0 0 4px;
  outline: none;
  padding: 2px 4px;
  border-radius: 4px;
  cursor: text;
}
.client-name-edit:hover { background: var(--cream); }
.client-name-edit:focus { background: var(--cream); box-shadow: 0 0 0 2px var(--clay); }
.client-aliases { margin: 2px 0; font-size: 12px; color: var(--sage); font-style: italic; }
.client-contact { margin: 4px 0 0; font-size: 13px; color: var(--body); }
.client-contact a { color: var(--clay); font-weight: 500; }
.client-extra-phones { color: var(--sage); font-size: 11px; cursor: help; }

.client-stats-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-bottom: 24px;
}
.stat-pill {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: center;
}
.stat-pill strong {
  font-family: "Cormorant Garamond", serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--forest);
  line-height: 1;
}
.stat-pill span {
  font-size: 10px;
  color: var(--sage);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
}

.client-section {
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.client-section:last-child { border-bottom: none; padding-bottom: 0; }
.client-section-h {
  font-family: "DM Sans", sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: var(--sage);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin: 0 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.count-inline {
  background: var(--cream);
  color: var(--forest);
  padding: 1px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.02em;
}
.empty-inline { font-size: 12px; color: var(--sage); font-style: italic; }
.empty { font-size: 13px; color: var(--sage); font-style: italic; padding: 8px 0; margin: 0; }

.section-hipaa-hint {
  margin: -4px 0 10px;
  padding: 6px 10px;
  background: rgba(200,145,70,0.07);
  border-left: 2px solid rgba(200,145,70,0.6);
  border-radius: 0 4px 4px 0;
  font-size: 11px;
  font-style: italic;
  color: var(--sage);
  display: flex;
  align-items: center;
  gap: 6px;
  line-height: 1.5;
}
.hipaa-hint-icon {
  color: var(--status-warn);
  font-style: normal;
  font-size: 12px;
  line-height: 1;
  flex-shrink: 0;
}

.client-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.client-section-head .client-section-h { margin: 0; }
.basic-edit-btn {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--forest);
  padding: 4px 14px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.basic-edit-btn:hover { background: var(--cream); border-color: var(--clay); color: var(--clay); }

.basic-display { margin: 0; }
.basic-subcards {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 14px;
  align-items: stretch;
}
.basic-subcard {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 16px 16px;
  background: #fff;
  position: relative;
}
.basic-subcard.sub-client {
  background: linear-gradient(180deg, rgba(77, 103, 136,0.05), transparent 40%);
  border-color: rgba(77, 103, 136,0.25);
}
.basic-subcard.sub-emergency {
  background: linear-gradient(180deg, rgba(176,74,58,0.05), transparent 40%);
  border-color: rgba(176,74,58,0.3);
}
.basic-subcard-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.basic-subcard-icon {
  font-size: 14px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 6px;
}
.sub-client .basic-subcard-icon { background: rgba(77, 103, 136,0.12); color: var(--forest-m); }
.sub-emergency .basic-subcard-icon { background: rgba(176,74,58,0.15); color: var(--status-crit); }

.basic-subcard-title {
  margin: 0;
  font-family: "DM Sans", sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.basic-subcard-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* 2-col layout inside Client card */
.client-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 20px;
}
.client-col { display: flex; flex-direction: column; gap: 10px; }
.client-2col.edit-mode .client-col { gap: 10px; }

.basic-row { display: flex; flex-direction: column; gap: 1px; }
.basic-row dt {
  font-size: 10px;
  color: var(--sage);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  margin: 0;
}
.basic-row dd {
  margin: 0;
  font-size: 13px;
  color: var(--body);
  line-height: 1.4;
  word-break: break-word;
}
.basic-row-multiline dd { white-space: pre-line; }

/* Emails (view mode: stacked mailto links, no chrome) */
.emails-view-dd {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.emails-view-dd .email-chip-text {
  color: var(--clay);
  text-decoration: none;
  word-break: break-all;
  font-size: 13px;
}
.emails-view-dd .email-chip-text:hover { text-decoration: underline; }
.emails-view-dd .email-chip-alt {
  color: var(--body);
  font-size: 12px;
}

/* Emails (edit mode: chips + add input, confined to editor) */
.emails-block {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.emails-block .basic-field-label { margin-bottom: 2px; }
.emails-list { display: flex; flex-wrap: wrap; gap: 5px; }
.email-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 4px 3px 10px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 12px;
  max-width: 100%;
}
.email-chip.primary { border-color: rgba(77, 103, 136,0.3); background: rgba(77, 103, 136,0.06); }
.email-chip .email-chip-text {
  color: var(--body);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 200px;
}
.email-primary-tag {
  display: inline-block;
  padding: 1px 7px;
  background: var(--forest-m);
  color: #fff;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 999px;
}
.email-del {
  background: transparent;
  border: none;
  color: var(--sage);
  font-size: 13px;
  line-height: 1;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
}
.email-del:hover { color: var(--status-crit); background: rgba(176,74,58,0.1); }
.email-add-input {
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  background: #fff;
  color: var(--ink);
  transition: border-color 0.15s;
}
.email-add-input:focus { outline: none; border-color: var(--clay); }
.email-add-input::placeholder { color: rgba(122, 138, 154,0.6); font-style: italic; }

/* Basic grid variants */
.basic-grid-single { grid-template-columns: 1fr; }

.basic-row { display: flex; flex-direction: column; gap: 2px; }
.basic-row dt {
  font-size: 10px;
  color: var(--sage);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  margin: 0;
}
.basic-row dd {
  margin: 0;
  font-size: 13px;
  color: var(--body);
  line-height: 1.4;
  word-break: break-word;
}

.basic-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px 16px;
}
.basic-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.basic-field-wide { grid-column: span 2; }
.basic-field-label {
  font-size: 10px;
  color: var(--sage);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
}
.basic-field-input {
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  color: var(--ink);
  transition: border-color 0.15s, background 0.15s, box-shadow 0.3s;
}
.basic-field-textarea { resize: vertical; min-height: 54px; font-family: inherit; }
.basic-field-input::placeholder { color: rgba(122, 138, 154,0.55); font-style: italic; }
.basic-field-input:focus { outline: none; border-color: var(--clay); }

.basic-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed var(--line);
}
.basic-cancel {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--sage);
  padding: 8px 18px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.basic-cancel:hover { background: var(--cream); color: var(--forest); }
.basic-save {
  background: var(--forest);
  color: #fff;
  border: none;
  padding: 8px 22px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.15s;
}
.basic-save:hover { background: var(--forest-m); }
.basic-save:disabled { opacity: 0.6; cursor: not-allowed; }

/* Make-primary button inside email chip */
.email-make-primary {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--sage);
  padding: 2px 8px;
  border-radius: 999px;
  font-family: inherit;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.email-make-primary:hover { background: var(--forest); color: #fff; border-color: var(--forest); }
.email-make-primary:disabled { opacity: 0.5; cursor: not-allowed; }

/* Compose new message modal */
.compose-card {
  width: 100%;
  max-width: 560px;
  padding: 28px 30px 24px;
  position: relative;
}
.compose-card h3 {
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  font-weight: 600;
  color: var(--forest);
  margin: 4px 0 14px;
}
.compose-form { display: flex; flex-direction: column; gap: 12px; }
.compose-body {
  resize: vertical;
  min-height: 140px;
  font-family: inherit;
}
.compose-match {
  margin-top: 4px;
  padding: 4px 10px;
  display: inline-block;
  background: rgba(77, 103, 136,0.1);
  color: var(--forest-m);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  align-self: flex-start;
}

/* Compose To field dropdown */
.compose-to-wrap {
  position: relative;
}
.compose-to-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 20;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 10px 28px rgba(26,35,24,0.12);
  max-height: 260px;
  overflow-y: auto;
  padding: 4px;
}
.compose-to-dropdown::-webkit-scrollbar { width: 6px; }
.compose-to-dropdown::-webkit-scrollbar-thumb { background: rgba(122, 138, 154,0.3); border-radius: 3px; }
.compose-to-option {
  display: grid;
  grid-template-columns: 30px 1fr;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.12s;
}
.compose-to-option:hover { background: var(--cream); }
.compose-to-avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--sage), var(--forest-m));
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.compose-to-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.compose-to-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--forest);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.compose-to-email {
  font-size: 11px;
  color: var(--sage);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Compose template chips */
.compose-template-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.compose-template-btn {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--forest);
  padding: 5px 12px;
  border-radius: 999px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.compose-template-btn:hover { background: var(--cream); border-color: var(--sage); }
.compose-template-btn.active { background: var(--forest); color: #fff; border-color: var(--forest); }
.compose-schedule-picker {
  padding: 10px 12px;
  background: var(--cream);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.compose-schedule-row {
  display: flex;
  gap: 8px;
}
.compose-schedule-row input,
.compose-schedule-row select {
  flex: 1;
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
}
.compose-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 4px;
}
.compose-cancel {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--sage);
  padding: 8px 18px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  cursor: pointer;
}
.compose-cancel:hover { background: var(--cream); color: var(--forest); }
.compose-schedule-toggle {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--forest);
  padding: 8px 16px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
}
.compose-schedule-toggle:hover { background: var(--cream); border-color: var(--sage); }
.compose-schedule-toggle.active { background: var(--forest); color: #fff; border-color: var(--forest); }
.compose-send {
  background: var(--clay);
  color: #fff;
  border: none;
  padding: 8px 22px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.15s;
}
.compose-send:hover { background: var(--clay-d); }
.compose-send:disabled { opacity: 0.7; cursor: not-allowed; }
.compose-status { margin: 4px 0 0; font-size: 12px; }
.compose-status.ok { color: var(--status-ok); }
.compose-status.crit { color: var(--status-crit); }
.compose-close {
  position: absolute;
  top: 14px;
  right: 14px;
  background: transparent;
  border: none;
  font-size: 22px;
  color: var(--sage);
  cursor: pointer;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  transition: background 0.15s, color 0.15s;
}
.compose-close:hover { background: var(--cream); color: var(--status-crit); }

/* Sent row kind badges */
.sent-kind-badge {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 999px;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-right: 6px;
  vertical-align: baseline;
}
.sent-kind-badge.reply { background: rgba(122, 138, 154,0.15); color: var(--forest-m); }
.sent-kind-badge.outbound { background: rgba(184, 146, 90,0.15); color: var(--clay-d); }
.sent-subject { font-style: italic; color: var(--body); font-weight: 500; }

/* New client modal */
.new-client-card {
  width: 100%;
  max-width: 440px;
  padding: 32px 32px 28px;
  position: relative;
}
.new-client-card h3 {
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  font-weight: 600;
  color: var(--forest);
  margin: 6px 0 8px;
}
.new-client-sub { font-size: 13px; color: var(--sage); line-height: 1.5; margin: 0 0 20px; }
.new-client-form { display: flex; flex-direction: column; gap: 14px; }
.new-client-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 8px;
}
.new-client-cancel {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--sage);
  padding: 8px 18px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  cursor: pointer;
}
.new-client-cancel:hover { background: var(--cream); color: var(--forest); }
.new-client-submit {
  background: var(--clay);
  color: #fff;
  border: none;
  padding: 8px 22px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.15s;
}
.new-client-submit:hover { background: var(--clay-d); }
.new-client-submit:disabled { opacity: 0.7; cursor: not-allowed; }
.new-client-error {
  margin: 8px 0 0;
  font-size: 12px;
  color: var(--status-crit);
}
.new-client-close {
  position: absolute;
  top: 14px;
  right: 14px;
  background: transparent;
  border: none;
  font-size: 22px;
  color: var(--sage);
  cursor: pointer;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  transition: background 0.15s, color 0.15s;
}
.new-client-close:hover { background: var(--cream); color: var(--status-crit); }

.tag-editor { display: flex; flex-direction: column; gap: 10px; }
.clients-settings-btn {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--sage);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.2s;
}
.clients-settings-btn:hover { background: var(--cream); color: var(--forest); border-color: var(--forest); transform: rotate(30deg); }

/* Clients settings modal */
.clients-settings-card {
  width: 100%;
  max-width: 520px;
  padding: 28px 30px 24px;
  position: relative;
  max-height: 90vh;
  overflow-y: auto;
}
.clients-settings-card h3 {
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  font-weight: 600;
  color: var(--forest);
  margin: 4px 0 18px;
}
.clients-settings-close {
  position: absolute;
  top: 14px;
  right: 14px;
  background: transparent;
  border: none;
  font-size: 22px;
  color: var(--sage);
  cursor: pointer;
  width: 28px;
  height: 28px;
  border-radius: 50%;
}
.clients-settings-close:hover { background: var(--cream); color: var(--status-crit); }
.settings-section {
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.settings-section:last-of-type { border-bottom: none; }
.settings-section-title {
  font-family: "DM Sans", sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin: 0 0 4px;
}
.settings-section-sub {
  font-size: 12px;
  color: var(--sage);
  margin: 0 0 10px;
  line-height: 1.5;
}
.settings-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 8px;
  min-height: 24px;
}
.settings-tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--warm);
  color: var(--forest);
  padding: 3px 4px 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
}
.settings-tag-del {
  background: transparent;
  border: none;
  color: var(--sage);
  font-size: 13px;
  line-height: 1;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
}
.settings-tag-del:hover { color: var(--status-crit); background: rgba(176,74,58,0.1); }
.settings-tag-add-row {
  display: flex;
  gap: 6px;
}
.settings-tag-add-row .basic-field-input { flex: 1; }
.settings-inline-btn {
  background: var(--forest);
  color: #fff;
  border: none;
  padding: 7px 14px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
}
.settings-inline-btn:hover { background: var(--forest-m); }
.settings-select {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  color: var(--ink);
}
.settings-export-btn {
  background: transparent;
  border: 1px solid var(--clay);
  color: var(--clay);
  padding: 8px 18px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.settings-export-btn:hover { background: var(--clay); color: #fff; }
.settings-export-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.settings-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}
.settings-cancel {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--sage);
  padding: 8px 18px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
}
.settings-cancel:hover { background: var(--cream); color: var(--forest); }
.settings-save {
  background: var(--clay);
  color: #fff;
  border: none;
  padding: 8px 22px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
}
.settings-save:hover { background: var(--clay-d); }
.settings-save:disabled { opacity: 0.7; cursor: not-allowed; }
.settings-status { margin: 10px 0 0; font-size: 12px; text-align: right; }
.settings-status.ok { color: var(--status-ok); }
.settings-status.crit { color: var(--status-crit); }

.tag-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
  padding: 8px 10px;
  background: rgba(61, 85, 120,0.035);
  border-radius: 6px;
}
.tag-suggestions-label {
  font-size: 10px;
  color: var(--sage);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  margin-right: 4px;
}
.tag-suggest-btn {
  background: #fff;
  border: 1px dashed var(--line);
  color: var(--forest);
  padding: 3px 10px;
  border-radius: 999px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.tag-suggest-btn:hover { background: var(--forest); color: #fff; border-color: var(--forest); border-style: solid; }
.tag-suggest-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.tag-list { display: flex; flex-wrap: wrap; gap: 6px; }
.tag-input-row { display: flex; }
.tag-input {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  background: var(--cream);
  color: var(--ink);
  transition: border-color 0.15s, background 0.15s;
}
.tag-input:focus { outline: none; border-color: var(--clay); background: #fff; }

.fields-editor { display: flex; flex-direction: column; gap: 8px; }
.fields-list { display: flex; flex-direction: column; gap: 6px; }
.field-row {
  display: grid;
  grid-template-columns: 160px 1fr 28px;
  gap: 8px;
  align-items: center;
}
.field-row .field-key {
  font-size: 12px;
  color: var(--forest);
  font-weight: 500;
  padding: 7px 10px;
  background: var(--cream);
  border-radius: 6px;
  border: 1px solid transparent;
}
.field-val, .field-new-key, .field-new-val {
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  color: var(--ink);
  transition: border-color 0.15s;
}
.field-val:focus, .field-new-key:focus, .field-new-val:focus { outline: none; border-color: var(--clay); }
.field-del {
  background: transparent;
  border: none;
  color: var(--sage);
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
}
.field-del:hover { color: var(--status-crit); background: rgba(176,74,58,0.08); }

.field-add-row {
  display: grid;
  grid-template-columns: 160px 1fr auto;
  gap: 8px;
  margin-top: 6px;
  padding-top: 10px;
  border-top: 1px dashed var(--line);
}
.field-add-btn {
  padding: 7px 16px;
  background: var(--forest);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.15s;
}
.field-add-btn:hover { background: var(--forest-m); }

.notes-editor { display: flex; flex-direction: column; gap: 10px; }
.note-input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  color: var(--ink);
  resize: vertical;
  min-height: 68px;
  transition: border-color 0.15s;
}
.note-input:focus { outline: none; border-color: var(--clay); }
.note-actions { display: flex; justify-content: flex-end; }
.note-add-btn {
  padding: 7px 18px;
  background: var(--clay);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.15s;
}
.note-add-btn:hover { background: var(--clay-d); }
.note-add-btn:disabled { opacity: 0.6; cursor: not-allowed; }

.notes-list { display: flex; flex-direction: column; gap: 8px; }
.note-item {
  background: var(--cream);
  border-left: 3px solid var(--clay);
  padding: 10px 14px;
  border-radius: 6px;
}
.note-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.note-when { font-size: 11px; color: var(--sage); font-weight: 500; }
.note-del {
  background: transparent;
  border: none;
  color: var(--sage);
  font-size: 14px;
  line-height: 1;
  cursor: pointer;
  transition: color 0.15s;
}
.note-del:hover { color: var(--status-crit); }
.note-body { margin: 0; font-size: 13px; color: var(--body); line-height: 1.5; white-space: pre-wrap; word-break: break-word; }

.timeline { display: flex; flex-direction: column; gap: 0; position: relative; }
.timeline::before {
  content: "";
  position: absolute;
  left: 9px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: var(--line);
  pointer-events: none;
}
.timeline-ev {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 12px;
  padding: 8px 4px 8px 0;
  border-radius: 6px;
  position: relative;
  transition: background 0.15s;
}
.timeline-ev.clickable { cursor: pointer; }
.timeline-ev.clickable:hover { background: var(--cream); }
.timeline-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin: 8px 5px 0 5px;
  background: var(--sage);
  box-shadow: 0 0 0 3px #fff;
  position: relative;
  z-index: 1;
}
.timeline-dot.appt { background: var(--clay); }
.timeline-dot.msg { background: var(--forest-m); }
.timeline-dot.intake { background: var(--sage); box-shadow: 0 0 0 3px #fff, 0 0 0 4px rgba(122, 138, 154, 0.4); }
.timeline-body { min-width: 0; }
.timeline-top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.timeline-top strong { font-size: 13px; color: var(--forest); }
.timeline-meta { font-size: 12px; color: var(--sage); margin-top: 2px; }

@media (max-width: 900px) {
  .client-modal-overlay { padding: 12px; }
  .client-modal-body { padding: 20px 20px; }
  .client-stats-row { grid-template-columns: repeat(2, 1fr); }
  .field-row, .field-add-row { grid-template-columns: 1fr; }
  .basic-grid { grid-template-columns: 1fr; }
  .basic-subcards { grid-template-columns: 1fr; }
  .client-2col { grid-template-columns: 1fr; }
  .basic-field-wide { grid-column: span 1; }
  .card-clients .card-head { flex-wrap: wrap; }
  .clients-search-wrap { order: 3; flex-basis: 100%; max-width: none; }
}

/* ============ THERAPIST QUOTE STRIP (bottom of viewport on overview tab) ============
   NOT a card. Pinned to the bottom of the viewport and shown only on the
   Overview tab. Feels like a quiet line of footnote wisdom, not a module. */
.dash-footer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 20;
  padding: 14px 32px 16px;
  pointer-events: auto;
  background: linear-gradient(180deg, rgba(245, 240, 230, 0) 0%, rgba(245, 240, 230, 0.85) 35%, rgba(245, 240, 230, 0.98) 100%);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-top: 1px solid rgba(184, 146, 90, 0.18);
  text-align: center;
}
.dash-footer[hidden] { display: none; }
.quote-rotator {
  position: relative;
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  max-width: 960px;
  margin: 0 auto;
}
.quote-rotator .quote {
  position: absolute;
  inset: 0;
  margin: 0;
  padding: 0 16px;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 1.4s ease-in-out, transform 1.4s ease-in-out;
  display: flex;
  flex-direction: row;
  gap: 14px;
  justify-content: center;
  align-items: baseline;
  flex-wrap: wrap;
  pointer-events: none;
}
.quote-rotator .quote[data-active] {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.quote-rotator .quote p {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: clamp(14px, 1.3vw, 17px);
  line-height: 1.45;
  color: var(--body);
  margin: 0;
  font-weight: 400;
}
.quote-rotator .quote p::before { content: '"'; color: var(--clay); opacity: 0.55; margin-right: 1px; }
.quote-rotator .quote p::after  { content: '"'; color: var(--clay); opacity: 0.55; margin-left: 1px; }
.quote-rotator .quote cite {
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  font-style: normal;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--clay);
  font-weight: 500;
  white-space: nowrap;
}
.quote-rotator-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 8px;
}
.quote-rotator-dots button {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: rgba(184, 146, 90, 0.28);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background 0.3s ease, transform 0.3s ease;
}
.quote-rotator-dots button[data-active] {
  background: var(--clay);
  transform: scale(1.4);
}
.quote-rotator-dots button:hover { background: var(--clay-d); }
@media (max-width: 720px) {
  .dash-footer { padding: 10px 16px 12px; }
  .quote-rotator .quote { flex-direction: column; gap: 4px; align-items: center; }
  .quote-rotator .quote p { font-size: 13px; line-height: 1.35; }
}
@media (prefers-reduced-motion: reduce) {
  .quote-rotator .quote { transition: opacity 0.2s linear; transform: none !important; }
}
