.appointment {
  border: 0;
  border-left: 3px solid;
  text-align: left;
  color: var(--ink);
  font-family: Manrope, Arial, sans-serif;
  cursor: pointer;
}
.appointment:hover { filter: brightness(.97); box-shadow: 0 2px 8px #00000012; }
.appointment.cancelled { opacity: .55; text-decoration: line-through; }
.status-badge { position: absolute; right: 7px; bottom: 6px; padding: 2px 6px; border-radius: 10px; font-style: normal; font-size: 8px; text-decoration: none; }
.status-new { background: #e8e1d3; color: #806642; }
.status-confirmed { background: #dce5ed; color: #47647a; }
.status-arrived { background: #dce9dc; color: #476f4c; }
.status-cancelled { background: #eadbd8; color: #8a4c45; }
.appointment-summary { background: #ece8e0; border-radius: 5px; padding: 14px 16px; margin-bottom: 18px; color: #656761; font-size: 12px; line-height: 1.7; }
.status-field { display: block; font-size: 10px; font-weight: 700; letter-spacing: .5px; }
.status-field select { display: block; margin-top: 7px; width: 100%; background: #fff; border: 1px solid var(--line); border-radius: 5px; padding: 11px; font: 12px Manrope; color: var(--ink); }
.daily-report { display: grid; grid-template-columns: 1.25fr repeat(3, 1fr); background: #272a34; color: #fff; margin-bottom: 16px; border-radius: 0 0 8px 8px; overflow: hidden; }
.report-title, .report-metric { min-height: 94px; padding: 19px 22px; display: flex; flex-direction: column; justify-content: center; }
.report-title { background: #20232c; }
.report-title .eyebrow { color: #d0926e; }
.report-title strong { font: 18px Prata, serif; text-transform: capitalize; }
.report-metric { border-left: 1px solid #3d404a; }
.report-metric small { color: #999ca3; font-size: 8px; letter-spacing: 1.5px; }
.report-metric b { font: 22px Prata, serif; margin: 4px 0 2px; }
.report-metric span { color: #8f9299; font-size: 9px; }
@media(max-width:760px) { .daily-report { grid-template-columns: 1fr 1fr; } .report-title { grid-column: 1/-1; min-height: 70px; } .report-metric { padding: 15px; min-height: 82px; } }
.section-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.section-toolbar > p { color: var(--muted); margin: 0; }
.entity-grid { display: grid; grid-template-columns: repeat(3, minmax(220px, 1fr)); gap: 16px; }
.entity-card { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 22px; }
.entity-person { display: flex; align-items: center; gap: 12px; }
.entity-person i { width: 42px; height: 42px; border-radius: 50%; color: #fff; display: grid; place-items: center; font-style: normal; font-weight: 700; }
.entity-person h3 { margin: 0 0 3px; font: 18px Prata, serif; }
.entity-person span, .schedule-line small { color: var(--muted); font-size: 10px; }
.schedule-line { display: flex; flex-direction: column; gap: 4px; border-top: 1px solid #ebe9e3; border-bottom: 1px solid #ebe9e3; margin: 17px 0; padding: 13px 0; }
.schedule-line b { font-size: 12px; }
.chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chips span { background: #f0ede7; color: #63645f; border-radius: 12px; padding: 4px 8px; font-size: 9px; }
.chips em { color: var(--muted); font-size: 10px; }
.service-table, .utilization { background: #fff; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.service-head, .service-row { display: grid; grid-template-columns: 2fr 1fr 1fr 84px; align-items: center; padding: 16px 22px; }
.service-head { background: #f9f8f5; color: var(--muted); font-size: 9px; letter-spacing: 1px; }
.service-row { border-top: 1px solid #ebe9e3; font-size: 12px; }
.service-row b { font: 16px Prata, serif; }
.client-row-button { width: 100%; border: 0; background: #fff; text-align: left; color: var(--ink); font-family: Manrope; cursor: pointer; }
.client-row-button:hover { background: #faf9f6; }
.detail-phone { display: block; color: var(--muted); margin-top: 5px; font-size: 12px; }
.status-field textarea { display: block; margin-top: 7px; width: 100%; resize: vertical; background: #fff; border: 1px solid var(--line); border-radius: 5px; padding: 11px; font: 12px Manrope; }
.history-block { margin-top: 24px; }
.history-row { display: grid; grid-template-columns: 1.2fr 1.5fr auto; gap: 15px; align-items: center; padding: 13px 0; border-top: 1px solid var(--line); font-size: 11px; }
.history-row div { display: flex; flex-direction: column; gap: 3px; }
.history-row span { color: var(--muted); font-size: 9px; }
.status-text { width: fit-content; border-radius: 10px; padding: 2px 6px; }
.compact-empty { padding: 25px; }
.field-title { display: block; font-size: 9px; font-weight: 700; margin-bottom: 8px; }
.check-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.check-grid label { background: #fff; border: 1px solid var(--line); border-radius: 5px; padding: 9px; font-size: 10px; font-weight: 500; }
.check-grid input { width: auto; display: inline; margin: 0 7px 0 0; }
.month-picker { color: var(--muted); font-size: 9px; letter-spacing: 1px; }
.month-picker input { display: block; margin-top: 5px; background: #fff; border: 1px solid var(--line); border-radius: 5px; padding: 10px; font: 12px Manrope; }
.report-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; margin-bottom: 16px; }
.big-metric { background: #272a34; color: #fff; border-radius: 8px; padding: 23px; display: flex; flex-direction: column; gap: 8px; }
.big-metric small { color: #999ca3; font-size: 8px; letter-spacing: 1.5px; }
.big-metric b { font: 27px Prata, serif; }
.panel-head { display: flex; justify-content: space-between; align-items: center; padding: 20px 22px; }
.panel-head h2 { font-size: 21px; }.panel-head span { color: var(--muted); font-size: 10px; }
.util-row { display: grid; grid-template-columns: 180px 1fr 45px; gap: 18px; align-items: center; padding: 15px 22px; border-top: 1px solid #ebe9e3; }
.util-row > div:first-child { display: flex; flex-direction: column; gap: 3px; }.util-row span { color: var(--muted); font-size: 9px; }
.progress { height: 7px; border-radius: 5px; background: #ebe9e3; overflow: hidden; }.progress i { display: block; height: 100%; border-radius: 5px; }
@media(max-width:900px) { .entity-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:760px) { .entity-grid, .report-cards { grid-template-columns: 1fr; } .util-row { grid-template-columns: 120px 1fr 35px; gap: 8px; } .check-grid { grid-template-columns: 1fr; } }
.header-actions { display: flex; align-items: center; gap: 12px; }
.role-picker { color: var(--muted); font-size: 8px; letter-spacing: 1px; }
.role-picker select { display: block; margin-top: 4px; background: #fff; border: 1px solid var(--line); border-radius: 5px; padding: 8px 10px; font: 11px Manrope; min-width: 150px; }
#prepayment-field, #status-prepayment-field { display: none; }
.payment-edit { margin-top: 15px; }
.status-field input { display: block; margin-top: 7px; width: 100%; background: #fff; border: 1px solid var(--line); border-radius: 5px; padding: 11px; font: 12px Manrope; }
.free-windows { background: #fff; border: 1px solid var(--line); border-radius: 8px; margin-bottom: 16px; overflow: hidden; }
.free-master { display: grid; grid-template-columns: 120px 1fr; align-items: center; gap: 15px; padding: 12px 22px; border-top: 1px solid #ebe9e3; }
.free-master > div { display: flex; flex-wrap: wrap; gap: 7px; }
.free-master button { border: 1px solid #d7d3ca; color: #6d533f; background: #faf8f3; border-radius: 14px; padding: 5px 9px; font: 9px Manrope; cursor: pointer; }
.free-master button:not(:disabled):hover { border-color: #b87854; background: #f4e8df; }
.free-master button.unavailable { background:#eceef2; border-color:#e1e3e8; color:#a8adb7; cursor:not-allowed; opacity:.9; }
.free-master span, .day-off { color: var(--muted); font-size: 10px; }
.blocked-slot { background: repeating-linear-gradient(135deg,#f5f3ee,#f5f3ee 7px,#eeece6 7px,#eeece6 14px); }
.blocked-label { position: absolute; inset: 0; display: grid; place-items: center; color: #aaa79f; font-size: 9px; }
.schedule-line span { color: #9a7660; font-size: 9px; }
.master-mode .daily-report { grid-template-columns: 1.25fr repeat(3,1fr); }
@media(max-width:760px) { .header-actions { flex-direction: column; align-items: flex-end; } .role-picker select { min-width: 130px; } .free-master { grid-template-columns: 1fr; } }
