:root {
    --bg: #f4efe6;
    --surface: #fffdf9;
    --surface-alt: #f8f2ea;
    --line: #d6c7b4;
    --text: #1f2933;
    --muted: #6b7280;
    --primary: #0f766e;
    --primary-dark: #115e59;
    --danger: #b42318;
    --success: #13795b;
    --info: #3056d3;
    --shadow: 0 20px 60px rgba(44, 33, 20, 0.12);
    --radius: 24px;
    --app-sidebar-width: 272px;
    --app-content-max-width: 1520px;
    --schedule-minute-height: 1.35px;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: "Trebuchet MS", "Segoe UI", sans-serif;
    color: var(--text);
    background:
        radial-gradient(circle at top left, rgba(15, 118, 110, 0.12), transparent 28%),
        radial-gradient(circle at top right, rgba(48, 86, 211, 0.1), transparent 24%),
        linear-gradient(180deg, var(--bg) 0%, #f8f5ef 100%);
}

a {
    color: inherit;
    text-decoration: none;
}

code {
    padding: 0.15rem 0.45rem;
    border-radius: 999px;
    background: rgba(15, 118, 110, 0.08);
    color: var(--primary-dark);
}

.auth-body {
    display: grid;
    place-items: center;
    padding: 2rem;
}

.auth-shell {
    width: min(100%, 460px);
}

.auth-shell-wide {
    width: min(100%, 1240px);
}

.login-card,
.panel,
.stat-card {
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: var(--radius);
    background: rgba(255, 253, 249, 0.92);
    box-shadow: var(--shadow);
}

.login-card {
    padding: 2rem;
    display: grid;
    gap: 1.5rem;
}

.app-shell {
    display: grid;
    grid-template-columns: var(--app-sidebar-width) minmax(0, 1fr);
    min-height: 100vh;
}

.sidebar {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 2rem 1.5rem;
    background: rgba(26, 35, 43, 0.96);
    color: #f7f7f4;
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
}

.sidebar-main {
    display: grid;
    gap: 1.5rem;
}

.sidebar-top {
    display: grid;
    gap: 1rem;
}

.sidebar-brand {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}

.sidebar-user-chip,
.sidebar-nav-short {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-weight: 700;
    flex-shrink: 0;
}

.sidebar-brand-copy,
.sidebar-footer-copy {
    min-width: 0;
}

.sidebar h1,
.topbar h2,
.login-card h1,
.panel-header h3 {
    margin: 0.35rem 0 0;
}

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

.sidebar-nav a {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.9rem 1rem;
    border-radius: 16px;
    color: rgba(255, 255, 255, 0.76);
    transition: 0.2s ease;
}

.sidebar-nav-short {
    width: 2rem;
    height: 2rem;
    font-size: 0.82rem;
}

.sidebar-nav-label,
.sidebar-footer-copy,
.sidebar-logout-label,
.sidebar-brand-copy {
    display: inline-block;
    overflow: hidden;
}

.sidebar-footer-copy,
.sidebar-brand-copy {
    display: block;
}

.sidebar-nav-label,
.sidebar-logout-label {
    white-space: nowrap;
}

.sidebar-nav a.active,
.sidebar-nav a:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
}

.sidebar-footer {
    display: grid;
    gap: 1rem;
}

.sidebar-user {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.sidebar-user-chip {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 0.95rem;
}

.sidebar-toggle,
.sidebar-logout-button {
    justify-content: flex-start;
}

.sidebar-toggle-chevron {
    width: 0.65rem;
    height: 0.65rem;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(135deg);
    transition: transform 0.2s ease;
}

.sidebar-logout-button .sidebar-nav-short {
    width: 1.8rem;
    height: 1.8rem;
    font-size: 0.74rem;
}

.main-panel {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    max-width: var(--app-content-max-width);
    margin-inline: auto;
    padding: 1.5rem 1.25rem 0;
}

.content {
    width: 100%;
    max-width: var(--app-content-max-width);
    margin-inline: auto;
    padding: 1.5rem 1.25rem 2rem;
}

.workspace-grid {
    display: grid;
    grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.workspace-grid-wide {
    grid-template-columns: minmax(420px, 560px) minmax(0, 1fr);
}

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

.schedule-create-first-row {
    display: grid;
    grid-template-columns: minmax(320px, 0.95fr) minmax(0, 1.05fr);
    gap: 0.72rem;
    align-items: start;
}

.schedule-create-primary-fields {
    display: grid;
    gap: 0.55rem;
}

.schedule-create-paired-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.schedule-create-second-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.72rem;
}

.schedule-create-form {
    gap: 0.62rem;
}

.schedule-create-form .form-actions {
    margin-top: 0.35rem;
    gap: 0.55rem;
}

.schedule-cancel-visit-button {
    margin-left: auto;
}

.schedule-toolbar {
    display: grid;
    grid-template-columns: auto auto minmax(240px, 1fr);
    gap: 0.8rem;
    align-items: end;
    margin-bottom: 0.75rem;
}

.schedule-view-toggle,
.schedule-range-controls {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.schedule-view-toggle .button.is-active {
    background: rgba(15, 118, 110, 0.16);
    border-color: rgba(15, 118, 110, 0.5);
    color: var(--primary-dark);
}

.schedule-range-controls input[type="date"] {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface);
    color: var(--text);
    padding: 0.55rem 0.7rem;
    font: inherit;
    min-height: 36px;
}

.schedule-range-controls select {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface);
    color: var(--text);
    padding: 0.5rem 0.62rem;
    font: inherit;
    min-height: 36px;
}

.schedule-block-duration-label {
    color: var(--muted);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.schedule-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    margin-bottom: 0.75rem;
}

.schedule-board.is-loading {
    opacity: 0.62;
    pointer-events: none;
}

.schedule-card {
    border: 1px solid rgba(214, 199, 180, 0.8);
    border-radius: 14px;
    background: rgba(248, 242, 234, 0.66);
    padding: 0.7rem 0.78rem;
    display: grid;
    gap: 0.45rem;
}

.schedule-card-compact {
    padding: 0.5rem 0.58rem;
    border-radius: 12px;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.4rem;
}

.schedule-card-main {
    display: grid;
    gap: 0.32rem;
}

.schedule-card:not(.schedule-card-compact) {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.6rem;
}

.schedule-card-header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 0.6rem;
}

.schedule-card-header strong {
    font-size: 0.92rem;
}

.schedule-card-complaint {
    margin: 0;
    color: var(--muted);
    line-height: 1.4;
}

.schedule-card-actions {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.schedule-card-compact .schedule-card-actions,
.schedule-card:not(.schedule-card-compact) .schedule-card-actions {
    flex-direction: column;
    align-items: stretch;
    flex-wrap: nowrap;
}

.schedule-card-compact .schedule-card-header strong {
    font-size: 0.84rem;
}

.schedule-card-compact .badge {
    padding: 0.2rem 0.45rem;
    font-size: 0.68rem;
}

.schedule-card-compact .row-subtext,
.schedule-card-compact .schedule-card-complaint {
    font-size: 0.74rem;
    line-height: 1.24;
}

.schedule-card-compact .table-button {
    padding: 0.38rem 0.52rem;
    font-size: 0.72rem;
}

.schedule-hour-grid {
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 16px;
    background: rgba(255, 253, 249, 0.86);
    overflow: auto;
}

.schedule-hour-grid-week .schedule-hour-grid-head {
    display: grid;
    grid-template-columns: 72px repeat(7, minmax(188px, 1fr));
    position: sticky;
    top: 0;
    z-index: 4;
    background: rgba(255, 253, 249, 0.97);
    border-bottom: 1px solid rgba(214, 199, 180, 0.7);
}

.schedule-hour-grid-body-timeline {
    display: grid;
}

.schedule-hour-grid-week .schedule-hour-grid-body-timeline {
    grid-template-columns: 72px repeat(7, minmax(188px, 1fr));
}

.schedule-hour-grid-day .schedule-hour-grid-body-timeline {
    grid-template-columns: 72px minmax(340px, 1fr);
}

.schedule-hour-grid-body-timeline-day {
    min-width: 412px;
}

.schedule-hour-axis-cell {
    text-transform: uppercase;
    border-right: 1px solid rgba(214, 199, 180, 0.7);
    padding: 0.48rem 0.4rem;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--muted);
    text-align: center;
    background: rgba(248, 242, 234, 0.82);
}

.schedule-hour-axis-column {
    border-right: 1px solid rgba(214, 199, 180, 0.64);
    background: rgba(248, 242, 234, 0.82);
}

.schedule-hour-axis {
    height: calc(60 * var(--schedule-minute-height));
    padding: 0.3rem 0.35rem 0;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--muted);
    text-align: center;
    border-top: 1px solid rgba(214, 199, 180, 0.55);
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

.schedule-hour-axis-column .schedule-hour-axis:first-child {
    border-top: 0;
}

.schedule-hour-day-head {
    padding: 0.5rem 0.54rem;
    border-left: 1px solid rgba(214, 199, 180, 0.64);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.36rem;
}

.schedule-hour-day-head strong {
    font-size: 0.82rem;
}

.schedule-hour-day-head span {
    font-size: 0.74rem;
    color: var(--muted);
}

.schedule-hour-cell {
    border-left: 1px solid rgba(214, 199, 180, 0.56);
    background: rgba(255, 253, 249, 0.88);
}

.schedule-hour-cell-timeline {
    padding: 0;
    position: relative;
    overflow: hidden;
}

.schedule-day-lane {
    position: relative;
    min-height: calc(var(--schedule-segment-count) * 15 * var(--schedule-minute-height));
}

.schedule-day-segments {
    display: grid;
    grid-template-rows: repeat(var(--schedule-segment-count), calc(15 * var(--schedule-minute-height)));
}

.schedule-segment {
    width: 100%;
    margin: 0;
    border: 0;
    border-top: 1px solid rgba(214, 199, 180, 0.42);
    background: rgba(255, 253, 249, 0.8);
    min-height: 0;
    padding: 0;
    font: inherit;
    color: transparent;
    line-height: 1;
}

.schedule-segment:nth-child(4n + 1) {
    border-top-color: rgba(214, 199, 180, 0.68);
}

.schedule-segment-free {
    cursor: pointer;
    transition: background-color 0.18s ease, color 0.18s ease;
}

.schedule-segment-free:hover {
    background: rgba(15, 118, 110, 0.1);
    color: var(--primary-dark);
}

.schedule-segment-busy {
    background: rgba(214, 199, 180, 0.18);
}

.schedule-day-events {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.schedule-event-placement {
    position: absolute;
    left: 0.2rem;
    right: 0.2rem;
    top: calc(var(--event-top-minutes) * var(--schedule-minute-height));
    height: max(calc(var(--event-duration-minutes) * var(--schedule-minute-height)), 20px);
    pointer-events: auto;
}

.schedule-event-placement .schedule-card {
    height: 100%;
    overflow: hidden;
}

.schedule-event-placement .schedule-card-compact {
    padding: 0.3rem 0.4rem;
    border-radius: 10px;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.2rem;
}

.schedule-event-placement .schedule-card-compact .schedule-card-main {
    min-width: 0;
}

.schedule-event-placement .schedule-card-compact .schedule-card-header strong {
    font-size: 0.76rem;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.schedule-event-placement .schedule-card-compact .badge {
    padding: 0.14rem 0.3rem;
    font-size: 0.62rem;
}

.schedule-event-placement .schedule-card-compact .row-subtext {
    font-size: 0.66rem;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.schedule-event-placement .schedule-card-compact .schedule-card-complaint {
    display: none;
}

.schedule-event-placement .schedule-card-compact .schedule-card-actions {
    position: absolute;
    inset: 0.16rem;
    border-radius: 8px;
    background: rgba(255, 253, 249, 0.95);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 0.22rem;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease;
}

.schedule-event-placement .schedule-card-compact:hover .schedule-card-actions,
.schedule-event-placement .schedule-card-compact:focus-within .schedule-card-actions {
    opacity: 1;
    pointer-events: auto;
}

.schedule-event-placement .schedule-card-compact .schedule-card-actions .table-button {
    width: 100%;
    max-width: 90px;
    padding: 0.26rem 0.38rem;
    font-size: 0.66rem;
}

.schedule-event-placement .schedule-card-horizontal .schedule-card-main-inline,
.schedule-event-placement .schedule-card-horizontal .schedule-card-main {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 0;
}

.schedule-event-placement .schedule-card-horizontal .schedule-card-header {
    justify-content: flex-start;
    min-width: 0;
}

.schedule-event-placement .schedule-card-horizontal .schedule-card-inline-title,
.schedule-event-placement .schedule-card-horizontal .schedule-card-header strong {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.schedule-event-placement .schedule-card-horizontal .schedule-card-inline-title {
    font-size: 0.76rem;
}

.schedule-event-placement .schedule-card-horizontal .schedule-card-inline-meta {
    min-width: 0;
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.66rem;
    color: var(--muted);
}

.schedule-event-placement .schedule-card-horizontal .badge {
    margin-left: auto;
}

.schedule-event-placement .schedule-card-title-only .schedule-card-main {
    display: block;
}

.schedule-event-placement .schedule-card-title-only .schedule-card-header {
    justify-content: flex-start;
}

.schedule-empty-slot-trigger {
    width: 100%;
    border: 1px dashed rgba(214, 199, 180, 0.9);
    border-radius: 10px;
    background: rgba(248, 242, 234, 0.58);
    color: var(--muted);
    padding: 0.2rem;
    font: inherit;
    font-size: 1.02rem;
    font-weight: 700;
    text-align: center;
    min-height: 64px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.schedule-empty-slot-trigger:hover {
    background: rgba(15, 118, 110, 0.08);
    border-color: rgba(15, 118, 110, 0.4);
    color: var(--primary-dark);
}

.schedule-block-card {
    grid-template-columns: minmax(0, 1fr);
    background: rgba(18, 95, 127, 0.1);
    border-color: rgba(18, 95, 127, 0.28);
}

.schedule-block-card .schedule-card-header strong {
    color: #0b4f70;
}

.schedule-block-card .schedule-card-complaint {
    color: #36586b;
}

.schedule-hour-day-empty {
    padding: 0.72rem 0.85rem;
    border-bottom: 1px solid rgba(214, 199, 180, 0.62);
    background: rgba(248, 242, 234, 0.52);
}

.schedule-week-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(210px, 1fr));
    gap: 0.7rem;
    overflow-x: auto;
    padding-bottom: 0.3rem;
}

.schedule-week-column {
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 14px;
    background: rgba(255, 253, 249, 0.86);
    min-width: 210px;
    display: grid;
    gap: 0.55rem;
    align-content: start;
}

.schedule-week-header {
    padding: 0.62rem 0.68rem;
    border-bottom: 1px solid rgba(214, 199, 180, 0.65);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem;
}

.schedule-week-header strong {
    font-size: 0.88rem;
}

.schedule-week-header span {
    font-size: 0.8rem;
    color: var(--muted);
}

.schedule-week-list {
    display: grid;
    gap: 0.58rem;
    padding: 0 0.62rem 0.62rem;
}

.schedule-week-item {
    display: grid;
    gap: 0.42rem;
}

.schedule-week-time {
    font-size: 0.78rem;
    color: var(--muted);
    font-weight: 700;
    letter-spacing: 0.02em;
}

.schedule-empty-slot {
    border: 1px dashed rgba(214, 199, 180, 0.85);
    border-radius: 12px;
    background: rgba(248, 242, 234, 0.5);
    padding: 0.75rem 0.55rem;
    text-align: center;
}

.sticky-panel {
    position: sticky;
    top: 1rem;
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
    margin-bottom: 1.5rem;
}

.client-360-stats-grid {
    gap: 0.9rem;
}

.client-360-stats-grid .stat-card {
    padding: 0.9rem 1rem;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.8rem;
}

.client-360-stats-grid .stat-card span {
    margin: 0;
    flex: 1;
}

.client-360-stats-grid .stat-card strong {
    margin: 0;
    flex-shrink: 0;
    text-align: right;
}

.client-360-stats-grid .stat-card strong {
    font-size: 1.7rem;
}

.details-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.details-grid-single {
    grid-template-columns: minmax(0, 1fr);
}

.details-grid-compact {
    align-items: start;
}

.stat-card {
    padding: 1.4rem;
}

.stat-card span,
.eyebrow {
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
}

.stat-card strong {
    display: block;
    margin: 0.65rem 0;
    font-size: 2rem;
}

.muted {
    color: var(--muted);
    line-height: 1.6;
}

.panel {
    padding: 1.4rem;
}

.panel-compact {
    padding: 1rem;
}

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

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

.module-history-section {
    min-width: 0;
}

.module-history-section-full {
    grid-column: 1 / -1;
}

.toolbar-stats {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

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

.info-item,
.linked-card,
.notes-block {
    border: 1px solid rgba(214, 199, 180, 0.7);
    border-radius: 18px;
    background: rgba(248, 242, 234, 0.72);
    padding: 1rem;
}

.info-item span,
.linked-card span,
.notes-block span {
    display: block;
    margin-bottom: 0.45rem;
    color: var(--muted);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.info-item strong,
.linked-card strong {
    display: block;
    font-size: 1.05rem;
}

.panel-compact .info-grid {
    gap: 0.7rem;
}

.panel-compact .info-item,
.panel-compact .notes-block {
    padding: 0.72rem 0.8rem;
    border-radius: 14px;
}

.panel-compact .info-item span,
.panel-compact .notes-block span,
.panel-compact .info-item-secondary {
    font-size: 0.74rem;
}

.panel-compact .info-item strong {
    font-size: 0.96rem;
}

.panel-compact .notes-block {
    margin-top: 0.7rem;
}

.panel-compact .notes-block p {
    line-height: 1.4;
}

.info-item-compact {
    align-content: start;
}

.info-item-secondary {
    display: block;
    margin-top: 0.8rem;
    margin-bottom: 0.45rem;
    color: var(--muted);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.notes-block {
    margin-top: 1rem;
}

.notes-block p,
.linked-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

.linked-card-muted {
    opacity: 0.82;
}

.field {
    display: grid;
    gap: 0.45rem;
}

.field label {
    font-weight: 700;
    font-size: 0.92rem;
}

.field-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.field-inline-meta,
.inline-meta-age {
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
    white-space: nowrap;
}

.field input,
.field select,
.field textarea {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: var(--surface);
    color: var(--text);
    padding: 0.85rem 1rem;
    font: inherit;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.12);
}

.compact-field {
    min-width: 220px;
}

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

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

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

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

.compact-client-profile-form,
.compact-visit-form {
    gap: 0.7rem;
}

.compact-client-profile-form .form-grid,
.compact-visit-form .form-grid {
    gap: 0.7rem;
}

.compact-client-profile-form .field,
.compact-visit-form .field {
    gap: 0.3rem;
}

.compact-client-profile-form .field label,
.compact-visit-form .field label {
    font-size: 0.84rem;
}

.compact-client-profile-form .field input,
.compact-client-profile-form .field select,
.compact-client-profile-form .field textarea,
.compact-visit-form .field input,
.compact-visit-form .field select,
.compact-visit-form .field textarea {
    padding: 0.62rem 0.8rem;
    border-radius: 12px;
}

.compact-client-profile-form .checkbox,
.compact-visit-form .checkbox {
    gap: 0.5rem;
}

.compact-client-profile-form .form-actions,
.compact-visit-form .form-actions {
    gap: 0.55rem;
}

.compact-client-profile-form .form-actions {
    align-items: flex-start;
}

.client-profile-autosave-status {
    display: block;
    margin: -0.15rem 0 0.5rem;
}

.client-profile-autosave-status[data-state="saving"] {
    color: var(--info);
}

.client-profile-autosave-status[data-state="saved"] {
    color: var(--success);
}

.client-profile-autosave-status[data-state="error"] {
    color: var(--danger);
}

.client-history-details {
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 16px;
    background: rgba(248, 242, 234, 0.55);
    overflow: hidden;
}

.client-history-summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 0.95rem;
}

.client-history-details[data-animating="true"] .client-history-body {
    will-change: height, opacity, transform;
}

.client-history-summary::-webkit-details-marker {
    display: none;
}

.client-history-body {
    opacity: 1;
    transform: translateY(0);
    transition:
        height 0.34s ease,
        opacity 0.28s ease,
        transform 0.34s ease;
}

.client-history-body[hidden] {
    display: block !important;
    height: 0;
    opacity: 0;
    overflow: hidden;
    transform: translateY(-0.3rem);
}

.client-history-grid {
    display: grid;
    gap: 0.8rem;
    padding: 0 0.95rem 0.95rem;
    border-top: 1px solid rgba(214, 199, 180, 0.65);
}

.history-checkbox-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.history-checkbox {
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 14px;
    padding: 0.7rem 0.85rem;
    background: rgba(255, 253, 249, 0.86);
}

.history-table-section {
    display: grid;
    gap: 0.55rem;
}

.history-table-header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 0.8rem;
}

.history-table-header h4 {
    margin: 0.2rem 0 0;
}

.history-table input {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface);
    color: var(--text);
    padding: 0.55rem 0.68rem;
    font: inherit;
    font-size: 0.85rem;
}

.history-table input:focus,
.history-table input[type="file"]:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.12);
}

.history-table input[type="file"] {
    padding: 0.42rem 0.52rem;
    background: rgba(255, 253, 249, 0.92);
}

.history-row-actions {
    width: 1%;
    white-space: nowrap;
}

.history-file-note {
    margin-bottom: 0.38rem;
    color: var(--muted);
    font-size: 0.78rem;
}

.history-file-link {
    display: inline-block;
    margin-bottom: 0.38rem;
    color: var(--primary-dark);
    font-size: 0.78rem;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 0.12rem;
}

.field-span-full {
    grid-column: 1 / -1;
}

.clinic-exam-section {
    display: grid;
    gap: 0.65rem;
    padding: 0.85rem 0.95rem;
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 16px;
    background: rgba(248, 242, 234, 0.55);
}

.clinic-exam-header h4 {
    margin: 0.2rem 0 0;
    font-size: 0.96rem;
}

.clinic-exam-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.7rem;
}

.compact-visit-form .clinic-exam-section {
    gap: 0.55rem;
    padding: 0.72rem 0.78rem;
    border-radius: 14px;
}

.compact-visit-form .clinic-exam-grid {
    gap: 0.55rem;
}

.form-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.checkbox {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}

.checkbox input {
    width: 1rem;
    height: 1rem;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border: 0;
    border-radius: 999px;
    padding: 0.85rem 1.2rem;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.15s ease, opacity 0.2s ease, background 0.2s ease;
}

.button:hover {
    transform: translateY(-1px);
}

.button:disabled {
    opacity: 0.65;
    cursor: wait;
}

.button-full {
    width: 100%;
}

.button-primary {
    color: #fff;
    background: linear-gradient(135deg, var(--primary) 0%, #0f9d92 100%);
}

.button-secondary {
    color: var(--text);
    background: var(--surface-alt);
    border: 1px solid var(--line);
}

.button-danger {
    color: #fff;
    background: linear-gradient(135deg, var(--danger) 0%, #d64536 100%);
}

.table-button {
    padding: 0.6rem 0.9rem;
    font-size: 0.88rem;
}

.icon-button {
    min-width: 2.5rem;
    padding-inline: 0.7rem;
}

.icon-button span {
    line-height: 1;
    font-size: 1rem;
}

.table-wrap {
    overflow-x: auto;
}

.table-wrap table a:not(.button),
.history-file-link {
    color: #1d4ed8;
    text-decoration: underline;
    text-underline-offset: 0.12rem;
    font-weight: 700;
}

.table-wrap table a:not(.button):hover,
.history-file-link:hover {
    color: #1e40af;
}

.visit-expanded-row td {
    padding: 0;
    border-bottom: 0;
}

.visit-history-row {
    cursor: pointer;
    transition: background-color 0.18s ease;
}

.visit-history-row:hover td,
.visit-history-row:focus-visible td {
    background: rgba(15, 118, 110, 0.05);
}

.visit-history-row:focus-visible {
    outline: none;
}

.visit-history-row-expanded td {
    background: rgba(15, 118, 110, 0.08);
}

.visit-inline-cell {
    background: transparent;
}

.visit-inline-shell {
    padding: 1rem 0;
    opacity: 1;
    transform: translateY(0);
    transition:
        height 0.42s ease,
        opacity 0.32s ease,
        transform 0.42s ease;
}

.visit-expanded-row[data-animating="true"] .visit-inline-shell {
    will-change: height, opacity, transform;
}

.visit-inline-loading,
.visit-inline-error {
    border: 1px dashed rgba(214, 199, 180, 0.9);
    border-radius: 18px;
    padding: 1rem;
    background: rgba(248, 242, 234, 0.45);
}

.visit-inline-content {
    display: grid;
    gap: 1rem;
}

.history-module-tab-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.history-module-tab-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.35rem 0.72rem;
    border-radius: 999px;
    border: 1px solid rgba(214, 199, 180, 0.8);
    background: rgba(248, 242, 234, 0.72);
    color: var(--text);
    font-size: 0.8rem;
    font-weight: 700;
    text-decoration: none;
}

.history-module-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.history-module-card {
    display: grid;
    gap: 0.6rem;
    padding: 0.85rem 0.9rem;
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 14px;
    background: rgba(248, 242, 234, 0.58);
}

.history-module-full {
    width: 100%;
}

.history-module-card-header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 0.8rem;
}

.history-module-card-header h4 {
    margin: 0.2rem 0 0;
}

.history-module-note {
    margin: 0;
}

.history-module-list {
    margin: 0.35rem 0 0;
    padding-left: 1.1rem;
}

.history-module-list li {
    margin: 0.2rem 0;
}

.visit-inline-content .stats-grid {
    margin-bottom: 0;
}

.visit-inline-header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
}

.visit-inline-header h3 {
    margin: 0.25rem 0 0;
}

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

.visit-module-trigger-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
}

.visit-module-trigger {
    width: 100%;
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 18px;
    background: rgba(248, 242, 234, 0.72);
    box-shadow: 0 10px 24px rgba(44, 33, 20, 0.08);
    padding: 0.9rem 1.1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    text-align: left;
    cursor: pointer;
    transition: transform 0.15s ease, border-color 0.2s ease, background 0.2s ease;
}

.visit-module-trigger:hover {
    transform: translateY(-1px);
}

.visit-module-trigger.has-content {
    border-color: rgba(15, 118, 110, 0.22);
    background: rgba(15, 118, 110, 0.06);
}

.visit-module-trigger.has-content h3 {
    color: var(--primary-dark);
}

.visit-module-trigger.is-active {
    border-color: rgba(15, 118, 110, 0.42);
    background: rgba(15, 118, 110, 0.11);
}

.visit-module-trigger h3 {
    margin: 0;
}

.visit-module-trigger .lab-entry-chevron {
    transform: rotate(45deg);
}

.visit-module-trigger.is-active .lab-entry-chevron {
    transform: rotate(225deg);
}

.visit-module-shell {
    padding: 0;
    overflow: hidden;
    transition: height 0.38s ease, opacity 0.28s ease, transform 0.38s ease;
}

.visit-module-shell[hidden] {
    display: none !important;
}

.visit-module-shell[data-animating="true"] {
    will-change: height, opacity, transform;
}

.visit-module-panel-content {
    display: grid;
    gap: 1rem;
    padding: 1.2rem 1.4rem 1.4rem;
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.visit-module-panel-content[hidden] {
    display: none !important;
}

.compact-exploration-form {
    display: grid;
    gap: 0.75rem;
}

.exploration-stack {
    display: grid;
    gap: 0.75rem;
}

.exploration-group {
    display: grid;
    gap: 0.55rem;
}

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

.compact-exploration-form .field {
    gap: 0.3rem;
}

.compact-exploration-form .field label {
    font-size: 0.84rem;
}

.compact-exploration-form .field input,
.compact-exploration-form .field textarea {
    padding: 0.62rem 0.8rem;
    border-radius: 12px;
}

.exploration-field-wide textarea {
    min-height: 84px;
    resize: vertical;
}

.form-help {
    margin: 0 0 1rem;
}

.lab-entry-panel {
    padding: 0;
    overflow: hidden;
}

.lab-entry-summary {
    display: inline-flex;
    align-items: end;
    justify-content: flex-start;
    cursor: pointer;
    list-style: none;
    margin: 1rem 0 0.45rem 1rem;
    padding: 0.9rem 1.1rem;
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 18px;
    background: rgba(248, 242, 234, 0.72);
    box-shadow: 0 10px 24px rgba(44, 33, 20, 0.08);
}

.lab-entry-summary::-webkit-details-marker {
    display: none;
}

.lab-entry-chevron {
    width: 0.7rem;
    height: 0.7rem;
    border-right: 2px solid var(--muted);
    border-bottom: 2px solid var(--muted);
    transform: rotate(45deg);
    transition: transform 0.18s ease;
}

.lab-entry-panel[open] .lab-entry-chevron {
    transform: rotate(225deg);
}

.lab-entry-content {
    padding: 0 1.4rem 1.4rem;
    margin-top: 0.8rem;
    border-top: 1px solid rgba(214, 199, 180, 0.65);
    opacity: 1;
    transform: translateY(0);
    transition:
        height 0.38s ease,
        opacity 0.3s ease,
        transform 0.38s ease;
}

.lab-entry-panel[data-animating="true"] .lab-entry-content {
    will-change: height, opacity, transform;
}

.top-spaced {
    margin-top: 1rem;
}

.client-lab-panel {
    display: grid;
    gap: 0.7rem;
}

.visit-history-panel {
    margin-bottom: 1rem;
}

.compact-lab-form {
    display: grid;
    gap: 0.55rem;
}

.compact-lab-form .field label {
    font-size: 0.8rem;
}

.compact-lab-form .field input,
.compact-lab-form .field select {
    padding: 0.52rem 0.72rem;
    border-radius: 11px;
}

.compact-inline-field {
    max-width: 320px;
}

.compact-lab-form .lab-category-stack {
    gap: 0.45rem;
}

.compact-lab-form .lab-category-group {
    gap: 0.28rem;
}

.compact-lab-form .lab-subcategory-group {
    gap: 0.22rem;
}

.compact-lab-form .lab-category-head {
    padding: 0;
}

.compact-lab-form .lab-category-head h4 {
    font-size: 0.95rem;
    margin: 0.15rem 0 0;
}

.compact-lab-form .lab-subcategory-head {
    padding: 0 0.1rem;
}

.compact-lab-form .lab-subcategory-head h5 {
    margin: 0.1rem 0 0;
    font-size: 0.78rem;
    color: var(--muted);
    font-weight: 700;
}

.compact-lab-form .badge {
    padding: 0.18rem 0.45rem;
    font-size: 0.68rem;
}

.compact-lab-form .lab-grid {
    gap: 0.38rem;
}

.compact-lab-form .lab-card {
    padding: 0.28rem 0.38rem;
    gap: 0.35rem;
    border-radius: 10px;
}

.compact-lab-form .lab-card-head strong {
    font-size: 0.8rem;
    line-height: 1;
}

.compact-lab-form .lab-card-body {
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 0.28rem;
}

.compact-lab-form .lab-card-body input,
.compact-lab-form .lab-card-body select {
    padding: 0.24rem 0.42rem;
    min-height: 28px;
    border-radius: 8px;
    font-size: 0.78rem;
}

.lab-history-stack {
    display: grid;
    gap: 0.8rem;
}

.lab-history-visit {
    border: 1px solid rgba(214, 199, 180, 0.7);
    border-radius: 18px;
    background: rgba(248, 242, 234, 0.5);
    overflow: hidden;
}

.lab-history-toggle {
    width: 100%;
    border: 0;
    background: transparent;
    padding: 0.85rem 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    text-align: left;
    cursor: pointer;
}

.lab-history-summary {
    display: grid;
    gap: 0.2rem;
}

.lab-history-summary h4 {
    margin: 0.15rem 0 0;
}

.lab-history-body {
    padding: 0 1rem 1rem;
    display: grid;
    gap: 0.8rem;
}

.lab-card-readonly .lab-card-body {
    grid-template-columns: 72px minmax(0, 1fr);
}

.lab-card.lab-card-readonly.lab-card-calculated {
    background: rgba(222, 235, 243, 0.9);
    border-color: rgba(110, 146, 170, 0.5);
}

.lab-value-pill {
    min-height: 28px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
    color: var(--text);
    padding: 0.24rem 0.42rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.78rem;
    font-weight: 700;
}

.lab-value-pill-muted {
    color: var(--muted);
    font-weight: 600;
}

.empty-state-card {
    border: 1px dashed rgba(214, 199, 180, 0.9);
    border-radius: 18px;
    padding: 1rem;
    background: rgba(248, 242, 234, 0.45);
}

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

.lab-category-group {
    display: grid;
    gap: 0.75rem;
}

.lab-subcategory-group {
    display: grid;
    gap: 0.5rem;
}

.lab-category-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    padding: 0 0.15rem;
}

.lab-category-head h4 {
    margin: 0.25rem 0 0;
}

.lab-subcategory-head {
    padding: 0 0.2rem;
}

.lab-subcategory-head h5 {
    margin: 0;
    font-size: 0.82rem;
    color: var(--muted);
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

table {
    width: 100%;
    border-collapse: collapse;
}

.bulk-entry-table input {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--surface);
    color: var(--text);
    padding: 0.7rem 0.85rem;
    font: inherit;
}

.bulk-entry-table input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.12);
}

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

.lab-card {
    border: 1px solid rgba(214, 199, 180, 0.8);
    border-radius: 14px;
    background: rgba(248, 242, 234, 0.72);
    padding: 0.55rem 0.65rem;
    display: flex;
    align-items: center;
    gap: 0.55rem;
}

.lab-card-head strong {
    display: block;
    font-size: 0.9rem;
    line-height: 1.15;
}

.lab-card-head strong[data-reference-tooltip-trigger] {
    cursor: help;
}

.lab-card-body {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 0.5rem;
    align-items: center;
    flex: 1;
}

.lab-card-out-of-range {
    border-color: rgba(180, 35, 24, 0.55);
    background: rgba(180, 35, 24, 0.08);
}

.lab-card-out-of-range .lab-card-head strong {
    color: var(--danger);
}

.lab-card-body input,
.lab-card-body select {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface);
    color: var(--text);
    padding: 0.46rem 0.58rem;
    font: inherit;
    font-size: 0.88rem;
}

.lab-card-out-of-range .lab-card-body input,
.lab-card-out-of-range .lab-card-body select {
    border-color: rgba(180, 35, 24, 0.4);
}

.lab-card-body input:focus,
.lab-card-body select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.12);
}

.lab-unit-select {
    cursor: pointer;
}

.lab-unit-text[readonly] {
    background: rgba(248, 242, 234, 0.9);
    color: var(--muted);
    cursor: default;
}

.lab-result-input {
    text-align: center;
}

.patient-portal-card {
    width: min(100%, 1180px);
    margin: 0 auto;
    display: grid;
    gap: 1rem;
}

.patient-mobile-tab-panel {
    display: grid;
    gap: 1rem;
}

.patient-mobile-tab-panel[hidden] {
    display: none !important;
}

.patient-mobile-tab-panel.is-entering,
.patient-mobile-tab-panel.is-leaving {
    display: grid;
    will-change: opacity, transform;
}

.patient-mobile-tab-panel.is-entering.is-forward {
    animation: patient-tab-panel-in-forward 0.24s ease-out both;
}

.patient-mobile-tab-panel.is-entering.is-backward {
    animation: patient-tab-panel-in-backward 0.24s ease-out both;
}

.patient-mobile-tab-panel.is-leaving {
    pointer-events: none;
}

.patient-mobile-tab-panel.is-leaving.is-forward {
    animation: patient-tab-panel-out-forward 0.18s ease both;
}

.patient-mobile-tab-panel.is-leaving.is-backward {
    animation: patient-tab-panel-out-backward 0.18s ease both;
}

@keyframes patient-tab-panel-in-forward {
    from {
        opacity: 0;
        transform: translateX(0.9rem);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes patient-tab-panel-in-backward {
    from {
        opacity: 0;
        transform: translateX(-0.9rem);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes patient-tab-panel-out-forward {
    from {
        opacity: 1;
        transform: translateX(0);
    }

    to {
        opacity: 0;
        transform: translateX(-0.55rem);
    }
}

@keyframes patient-tab-panel-out-backward {
    from {
        opacity: 1;
        transform: translateX(0);
    }

    to {
        opacity: 0;
        transform: translateX(0.55rem);
    }
}

@media (prefers-reduced-motion: reduce) {
    .patient-mobile-tab-panel.is-entering,
    .patient-mobile-tab-panel.is-leaving {
        animation: none;
        transform: none;
    }
}

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

.patient-desktop-tab {
    border: 1px solid rgba(96, 146, 171, 0.45);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.9);
    color: #124f6c;
    padding: 0.62rem 0.8rem;
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.patient-desktop-tab.is-active {
    background: rgba(14, 116, 144, 0.16);
    border-color: rgba(14, 116, 144, 0.46);
    color: #0a4f77;
}

.patient-mobile-nav {
    display: none;
}

.patient-portal-page {
    background:
        radial-gradient(circle at top left, rgba(14, 116, 144, 0.22), transparent 32%),
        radial-gradient(circle at top right, rgba(2, 132, 199, 0.2), transparent 30%),
        linear-gradient(180deg, #e8f6ff 0%, #d9eefc 100%);
}

.patient-portal-page .patient-portal-card {
    border-color: rgba(93, 150, 181, 0.45);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 24px 56px rgba(12, 74, 110, 0.16);
}

.patient-portal-page .eyebrow {
    color: #0f5f7f;
}

.patient-portal-page .muted {
    color: #3e6478;
}

.patient-portal-page .badge.badge-info {
    background: rgba(6, 95, 70, 0.14);
    color: #0f5132;
    border-color: rgba(6, 95, 70, 0.25);
}

.patient-portal-page .badge.badge-muted {
    background: rgba(8, 47, 73, 0.08);
    color: #0f425c;
    border-color: rgba(8, 47, 73, 0.2);
}

.patient-portal-page .patient-profile-panel,
.patient-portal-page .patient-visit-card {
    border-color: rgba(96, 146, 171, 0.5);
    background: rgba(240, 249, 255, 0.7);
}

.patient-portal-page .patient-profile-content,
.patient-portal-page .patient-visit-body {
    border-top-color: rgba(96, 146, 171, 0.34);
}

.patient-portal-page .patient-section {
    border-color: rgba(99, 154, 181, 0.38);
    background: rgba(255, 255, 255, 0.92);
}

.patient-portal-page .patient-mini-grid div,
.patient-portal-page .patient-exploration-block {
    border-color: rgba(110, 165, 191, 0.35);
    background: rgba(231, 246, 255, 0.56);
}

.patient-portal-page .patient-table th {
    color: #155678;
}

.patient-portal-page .patient-table td {
    border-bottom-color: rgba(97, 146, 171, 0.25);
}

.patient-portal-page a {
    color: #0b5d8b;
}

.patient-portal-page a:hover {
    color: #0a4f77;
}

.patient-portal-page .button.button-secondary {
    color: #fff;
    border-color: transparent;
    background: linear-gradient(135deg, #0f766e 0%, #0284c7 100%);
}

.patient-portal-page .button.button-secondary:hover {
    background: linear-gradient(135deg, #0d675f 0%, #0369a1 100%);
}

.patient-portal-header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 1rem;
}

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

.patient-profile-panel {
    border: 1px solid rgba(214, 199, 180, 0.8);
    border-radius: 16px;
    background: rgba(248, 242, 234, 0.55);
    overflow: hidden;
}

.patient-profile-summary {
    list-style: none;
    cursor: default;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 0.8rem 0.9rem;
}

.patient-profile-summary::-webkit-details-marker {
    display: none;
}

.patient-profile-content {
    padding: 0.9rem;
    opacity: 1;
    transform: translateY(0);
    transition:
        height 0.36s ease,
        opacity 0.28s ease,
        transform 0.36s ease;
}

.patient-visit-stack {
    display: grid;
    gap: 0.75rem;
}

.patient-visit-group {
    display: grid;
    gap: 0.6rem;
}

.patient-visit-group + .patient-visit-group {
    margin-top: 0.35rem;
    padding-top: 0.55rem;
    border-top: 1px solid rgba(96, 146, 171, 0.28);
}

.patient-visit-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
}

.patient-visit-group-header h3 {
    margin: 0;
    font-size: 0.96rem;
}

.patient-stack-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
}

.patient-stack-header h2 {
    margin: 0;
    font-size: 1.1rem;
}

.patient-visit-card {
    border: 1px solid rgba(214, 199, 180, 0.8);
    border-radius: 16px;
    background: rgba(248, 242, 234, 0.55);
    overflow: hidden;
}

.patient-visit-summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 0.8rem 0.9rem;
}

.patient-visit-summary::-webkit-details-marker {
    display: none;
}

.patient-visit-summary p {
    margin: 0.3rem 0 0;
}

.patient-visit-summary-badges {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.patient-visit-body {
    display: grid;
    gap: 0.7rem;
    padding: 0 0.9rem 0.9rem;
    border-top: 1px solid rgba(214, 199, 180, 0.65);
    opacity: 1;
    transform: translateY(0);
    transition:
        height 0.36s ease,
        opacity 0.28s ease,
        transform 0.36s ease;
}

.patient-profile-panel[data-animating="true"] .patient-profile-content,
.patient-visit-card[data-animating="true"] .patient-visit-body {
    will-change: height, opacity, transform;
}

.patient-section {
    border: 1px solid rgba(214, 199, 180, 0.75);
    border-radius: 14px;
    background: rgba(255, 253, 249, 0.9);
    padding: 0.75rem;
    display: grid;
    gap: 0.55rem;
}

.patient-section h3 {
    margin: 0;
    font-size: 0.95rem;
}

.patient-section h4 {
    margin: 0;
    font-size: 0.88rem;
}

.patient-note {
    margin: 0;
    line-height: 1.5;
    color: var(--text);
}

.patient-mini-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.patient-mini-grid div {
    border: 1px solid rgba(214, 199, 180, 0.65);
    border-radius: 10px;
    padding: 0.45rem 0.5rem;
    background: rgba(248, 242, 234, 0.5);
    display: grid;
    gap: 0.2rem;
}

.patient-mini-grid span {
    font-size: 0.74rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.patient-mini-grid strong {
    font-size: 0.92rem;
}

.patient-table th,
.patient-table td {
    padding: 0.55rem 0.45rem;
    font-size: 0.82rem;
    text-align: left;
    vertical-align: top;
}

.patient-table th {
    font-size: 0.74rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.patient-exploration-block {
    border: 1px solid rgba(214, 199, 180, 0.65);
    border-radius: 10px;
    padding: 0.55rem 0.6rem;
    background: rgba(248, 242, 234, 0.45);
}

.patient-exploration-block ul {
    margin: 0.45rem 0 0;
    padding-left: 1rem;
    display: grid;
    gap: 0.3rem;
}

.patient-schedule-card {
    width: min(100%, 720px);
    max-width: 720px;
    margin: 0 auto;
    gap: 0.85rem;
}

.patient-schedule-card h2 {
    margin: 0;
    font-size: 1.2rem;
    line-height: 1.2;
}

.patient-schedule-header {
    display: grid;
    gap: 0.25rem;
}

.patient-schedule-header .eyebrow,
.patient-schedule-header .muted {
    margin: 0;
}

.patient-booking-form {
    display: grid;
    gap: 0.85rem;
}

.patient-booking-progress {
    margin: 0;
    padding: 0.28rem;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.28rem;
    border: 1px solid rgba(99, 154, 181, 0.28);
    border-radius: 18px;
    background: rgba(231, 246, 255, 0.45);
}

.patient-booking-progress li {
    border: 1px solid transparent;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.68);
    color: #2d5f79;
    text-align: center;
    padding: 0.55rem 0.35rem;
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 0.25rem;
    min-height: 4.15rem;
    transition: background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease;
}

.patient-booking-progress-index {
    width: 1.55rem;
    height: 1.55rem;
    border-radius: 999px;
    border: 1px solid rgba(99, 154, 181, 0.32);
    background: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #4f7588;
}

.patient-booking-progress-label {
    font-size: 0.82rem;
    font-weight: 700;
}

.patient-booking-progress li.is-active {
    border-color: rgba(14, 116, 144, 0.5);
    background: #fff;
    color: #0a4f77;
    box-shadow: 0 8px 22px rgba(8, 47, 73, 0.1);
}

.patient-booking-progress li.is-active .patient-booking-progress-index {
    border-color: transparent;
    background: linear-gradient(135deg, #0f766e 0%, #0284c7 100%);
    color: #fff;
}

.patient-booking-progress li.is-complete {
    border-color: rgba(15, 118, 110, 0.4);
    background: rgba(15, 118, 110, 0.12);
    color: #0f5f7f;
}

.patient-booking-progress li.is-complete .patient-booking-progress-index {
    border-color: rgba(15, 118, 110, 0.34);
    color: #0f766e;
}

.patient-booking-step {
    display: none;
    gap: 0.85rem;
}

.patient-booking-step.is-active {
    display: grid;
}

.patient-booking-step.is-entering,
.patient-booking-step.is-leaving {
    display: grid;
    will-change: opacity, transform;
}

.patient-booking-step.is-entering.is-forward {
    animation: patient-booking-step-in-forward 0.34s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.patient-booking-step.is-entering.is-backward {
    animation: patient-booking-step-in-backward 0.34s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.patient-booking-step.is-leaving {
    pointer-events: none;
}

.patient-booking-step.is-leaving.is-forward {
    animation: patient-booking-step-out-forward 0.24s ease both;
}

.patient-booking-step.is-leaving.is-backward {
    animation: patient-booking-step-out-backward 0.24s ease both;
}

.patient-booking-step-header {
    border: 1px solid rgba(99, 154, 181, 0.28);
    border-radius: 16px;
    background:
        radial-gradient(circle at top right, rgba(14, 116, 144, 0.12), transparent 36%),
        rgba(240, 249, 255, 0.74);
    padding: 0.78rem;
    display: grid;
    gap: 0.25rem;
}

.patient-booking-step-header h3,
.patient-section .patient-booking-step-header h3 {
    margin: 0;
    color: #0f425c;
    font-size: 1rem;
    line-height: 1.25;
}

.patient-booking-step-header p {
    margin: 0;
    color: #3e6478;
    line-height: 1.45;
    font-size: 0.86rem;
}

.patient-booking-step-kicker {
    color: #0f766e;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

@keyframes patient-booking-step-in-forward {
    from {
        opacity: 0;
        transform: translateX(1.2rem);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes patient-booking-step-in-backward {
    from {
        opacity: 0;
        transform: translateX(-1.2rem);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes patient-booking-step-out-forward {
    from {
        opacity: 1;
        transform: translateX(0);
    }

    to {
        opacity: 0;
        transform: translateX(-0.85rem);
    }
}

@keyframes patient-booking-step-out-backward {
    from {
        opacity: 1;
        transform: translateX(0);
    }

    to {
        opacity: 0;
        transform: translateX(0.85rem);
    }
}

@media (prefers-reduced-motion: reduce) {
    .patient-booking-step.is-entering,
    .patient-booking-step.is-leaving {
        animation: none;
        transform: none;
    }
}

.patient-booking-step label {
    margin: 0;
    font-size: 0.76rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--muted);
}

.patient-booking-step > .form-field,
.patient-booking-grid .form-field {
    display: grid;
    gap: 0.4rem;
}

.patient-booking-step select,
.patient-booking-step input {
    width: 100%;
    border: 1px solid rgba(99, 154, 181, 0.4);
    border-radius: 12px;
    background: #fff;
    color: var(--text);
    min-height: 3rem;
    padding: 0.66rem 0.74rem;
    font: inherit;
}

.patient-booking-step select:focus,
.patient-booking-step input:focus {
    outline: none;
    border-color: rgba(14, 116, 144, 0.55);
    box-shadow: 0 0 0 4px rgba(14, 116, 144, 0.13);
}

.patient-booking-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.6rem;
}

.patient-booking-summary-card {
    border: 1px solid rgba(99, 154, 181, 0.38);
    border-radius: 16px;
    background: rgba(231, 246, 255, 0.5);
    padding: 0.72rem;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.patient-booking-summary-card div {
    border: 1px solid rgba(99, 154, 181, 0.25);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.8);
    padding: 0.48rem 0.55rem;
    display: grid;
    gap: 0.22rem;
}

.patient-booking-summary-card span {
    color: var(--muted);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.patient-booking-summary-card strong {
    font-size: 0.9rem;
}

.patient-booking-next-steps {
    border: 1px dashed rgba(99, 154, 181, 0.45);
    border-radius: 12px;
    background: rgba(231, 246, 255, 0.38);
    padding: 0.55rem 0.6rem;
    display: grid;
    gap: 0.4rem;
}

.patient-booking-next-title {
    margin: 0;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #4f7588;
}

.patient-booking-next-item {
    border: 1px solid rgba(99, 154, 181, 0.28);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.78);
    padding: 0.4rem 0.5rem;
    display: grid;
    gap: 0.12rem;
}

.patient-booking-next-item span {
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #4f7588;
}

.patient-booking-next-item strong {
    font-size: 0.82rem;
    color: #124f6c;
}

.patient-booking-slot-picker {
    border: 1px solid rgba(99, 154, 181, 0.36);
    border-radius: 16px;
    background: rgba(231, 246, 255, 0.36);
    padding: 0.72rem;
    display: grid;
    gap: 0.6rem;
}

.patient-booking-slot-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.6rem;
}

.patient-booking-slot-header h3 {
    margin: 0;
    font-size: 0.88rem;
}

.patient-booking-slot-header .muted {
    font-size: 0.76rem;
}

.patient-booking-slots {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
    gap: 0.45rem;
}

.patient-booking-slots.is-loading {
    opacity: 0.6;
}

.patient-booking-slot-button {
    border: 1px solid rgba(99, 154, 181, 0.42);
    border-radius: 12px;
    background: #fff;
    color: #124f6c;
    min-height: 2.85rem;
    padding: 0.55rem 0.5rem;
    font: inherit;
    font-size: 0.82rem;
    font-weight: 700;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.patient-booking-slot-button:hover {
    border-color: rgba(14, 116, 144, 0.48);
    background: rgba(14, 116, 144, 0.12);
}

.patient-booking-slot-button.is-selected {
    border-color: transparent;
    background: linear-gradient(135deg, #0f766e 0%, #0284c7 100%);
    color: #fff;
    box-shadow: 0 9px 20px rgba(8, 47, 73, 0.16);
}

.patient-booking-slot-empty {
    margin: 0;
    grid-column: 1 / -1;
    border: 1px dashed rgba(99, 154, 181, 0.35);
    border-radius: 10px;
    padding: 0.48rem 0.56rem;
    background: rgba(255, 255, 255, 0.7);
}

.patient-booking-selected-time {
    margin: 0;
    border: 1px solid rgba(15, 118, 110, 0.28);
    border-radius: 12px;
    background: rgba(15, 118, 110, 0.12);
    color: #0f5132;
    padding: 0.55rem 0.62rem;
    font-size: 0.84rem;
    font-weight: 800;
}

.patient-booking-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.55rem;
}

.patient-booking-actions .button:disabled {
    cursor: not-allowed;
    transform: none;
}

.patient-schedule-card.is-booking-success .patient-booking-progress,
.patient-schedule-card.is-booking-success .patient-note {
    display: none;
}

.patient-booking-success-panel {
    border: 1px solid rgba(15, 118, 110, 0.24);
    border-radius: 16px;
    background:
        radial-gradient(circle at top, rgba(15, 118, 110, 0.12), transparent 42%),
        rgba(240, 253, 250, 0.92);
    padding: 1rem;
    display: grid;
    justify-items: center;
    gap: 0.85rem;
    text-align: center;
}

.patient-booking-success-panel[hidden] {
    display: none;
}

.patient-booking-success-panel.is-visible {
    animation: patient-booking-success-in 0.44s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.patient-booking-success-mark {
    width: 4.2rem;
    height: 4.2rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #0f766e 0%, #0284c7 100%);
    box-shadow: 0 16px 34px rgba(8, 47, 73, 0.16);
    position: relative;
}

.patient-booking-success-panel.is-visible .patient-booking-success-mark {
    animation: patient-booking-success-pop 0.48s 0.08s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.patient-booking-success-mark::after {
    content: "";
    position: absolute;
    left: 1.36rem;
    top: 1.15rem;
    width: 1.25rem;
    height: 1.95rem;
    border: solid #fff;
    border-width: 0 0.32rem 0.32rem 0;
    transform: rotate(45deg);
}

.patient-booking-success-copy {
    display: grid;
    gap: 0.25rem;
}

.patient-booking-success-copy h3 {
    margin: 0;
    color: #0f425c;
    font-size: 1.12rem;
    line-height: 1.25;
}

.patient-booking-success-details {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.patient-booking-success-details div {
    border: 1px solid rgba(15, 118, 110, 0.18);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.78);
    padding: 0.55rem 0.6rem;
    display: grid;
    gap: 0.2rem;
    text-align: left;
}

.patient-booking-success-details span {
    color: #3e6478;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.patient-booking-success-details strong {
    color: #0f425c;
    font-size: 0.9rem;
}

@keyframes patient-booking-success-in {
    from {
        opacity: 0;
        transform: translateY(0.8rem);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes patient-booking-success-pop {
    from {
        opacity: 0;
        transform: scale(0.82);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

@media (prefers-reduced-motion: reduce) {
    .patient-booking-success-panel.is-visible,
    .patient-booking-success-panel.is-visible .patient-booking-success-mark {
        animation: none;
        transform: none;
    }
}

@media (max-width: 980px) {
    .history-module-grid {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 1024px) {
    .patient-profile-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .patient-visit-body {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .patient-section-full {
        grid-column: 1 / -1;
    }
}

@media (max-width: 900px) {
    .module-history-grid {
        grid-template-columns: 1fr;
    }

    .patient-portal-page {
        padding-bottom: calc(6.2rem + env(safe-area-inset-bottom));
    }

    .patient-portal-card {
        padding: 1rem 0.9rem 6rem;
        gap: 0.8rem;
        border-radius: 20px;
    }

    .patient-mobile-tab-panel {
        display: none;
    }

    .patient-mobile-tab-panel.is-active {
        display: grid;
    }

    .patient-desktop-nav {
        display: none;
    }

    .patient-mobile-nav {
        position: fixed;
        left: 50%;
        bottom: calc(0.55rem + env(safe-area-inset-bottom));
        transform: translateX(-50%);
        width: min(calc(100% - 1rem), 560px);
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.35rem;
        padding: 0.42rem;
        border: 1px solid rgba(96, 146, 171, 0.45);
        border-radius: 18px;
        background: rgba(255, 255, 255, 0.96);
        box-shadow: 0 16px 34px rgba(8, 47, 73, 0.22);
        backdrop-filter: blur(4px);
        z-index: 60;
    }

    .patient-mobile-nav-item {
        border: 0;
        border-radius: 14px;
        background: transparent;
        color: #2b5f79;
        display: grid;
        justify-items: center;
        align-content: center;
        gap: 0.18rem;
        padding: 0.5rem 0.3rem;
        min-height: 56px;
        cursor: pointer;
        font: inherit;
        font-weight: 700;
    }

    .patient-mobile-nav-item svg {
        width: 1.15rem;
        height: 1.15rem;
        fill: currentColor;
    }

    .patient-mobile-nav-item span {
        font-size: 0.68rem;
        letter-spacing: 0.01em;
        line-height: 1;
    }

    .patient-mobile-nav-item.is-active {
        color: #0a4f77;
        background: rgba(14, 116, 144, 0.14);
    }
}

@media (max-width: 720px) {
    .patient-profile-grid,
    .patient-mini-grid {
        grid-template-columns: 1fr;
    }

    .patient-booking-grid,
    .patient-booking-summary-card,
    .patient-booking-success-details {
        grid-template-columns: 1fr;
    }

    .patient-booking-progress {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .patient-booking-progress li {
        min-height: 3.85rem;
        padding: 0.48rem 0.22rem;
    }

    .patient-booking-progress-label {
        font-size: 0.74rem;
    }

    .patient-booking-slot-header {
        align-items: start;
        flex-direction: column;
        gap: 0.15rem;
    }

    .patient-booking-slots {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .patient-booking-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .patient-booking-actions .button {
        width: 100%;
    }

    .patient-booking-actions .button:only-child {
        grid-column: 1 / -1;
    }

    .patient-portal-header {
        flex-direction: column;
        align-items: start;
    }

    .patient-stack-header {
        flex-direction: column;
        align-items: start;
    }

    .patient-table th,
    .patient-table td {
        padding: 0.45rem 0.35rem;
        font-size: 0.78rem;
    }
}

th,
td {
    padding: 0.95rem 0.85rem;
    text-align: left;
    border-bottom: 1px solid rgba(214, 199, 180, 0.55);
    vertical-align: top;
}

th {
    color: var(--muted);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.row-subtext,
.empty-cell {
    color: var(--muted);
    font-size: 0.92rem;
}

.actions-cell {
    display: flex;
    gap: 0.6rem;
    justify-content: flex-end;
}

.badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: 999px;
    padding: 0.35rem 0.7rem;
    font-size: 0.8rem;
    font-weight: 700;
}

.badge-success {
    background: rgba(19, 121, 91, 0.12);
    color: var(--success);
}

.badge-muted {
    background: rgba(107, 114, 128, 0.14);
    color: #4b5563;
}

.badge-info {
    background: rgba(48, 86, 211, 0.12);
    color: var(--info);
}

.alert {
    margin-bottom: 1rem;
    border-radius: 16px;
    padding: 0.9rem 1rem;
    font-weight: 700;
}

.alert.success {
    background: rgba(19, 121, 91, 0.12);
    color: var(--success);
}

.alert.error {
    background: rgba(180, 35, 24, 0.12);
    color: var(--danger);
}

.error-text {
    margin: 0;
    color: var(--danger);
    font-size: 0.85rem;
}

.hidden {
    display: none !important;
}

.login-help {
    border-top: 1px solid rgba(214, 199, 180, 0.75);
    padding-top: 1rem;
    color: var(--muted);
}

@media (max-width: 1100px) {
    .app-shell,
    .workspace-grid,
    .stats-grid,
    .details-grid {
        grid-template-columns: 1fr;
    }

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

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

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

    .sticky-panel {
        position: static;
    }

    .sidebar {
        gap: 2rem;
    }
}

@media (max-width: 980px) {
    .schedule-create-first-row,
    .schedule-create-second-row {
        grid-template-columns: 1fr;
    }

    .schedule-create-paired-row {
        grid-template-columns: 1fr;
    }

    .schedule-toolbar {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .schedule-meta {
        flex-direction: column;
        align-items: start;
    }

    .schedule-hour-grid-week .schedule-hour-grid-head,
    .schedule-hour-grid-week .schedule-hour-grid-body-timeline {
        grid-template-columns: 62px repeat(7, minmax(170px, 1fr));
    }

    .schedule-hour-grid-day .schedule-hour-grid-body-timeline {
        grid-template-columns: 62px minmax(250px, 1fr);
    }

    .schedule-hour-axis-cell {
        padding: 0.4rem 0.3rem;
    }

    .schedule-hour-axis {
        padding: 0.4rem 0.3rem;
    }

    .schedule-event-placement {
        left: 0.14rem;
        right: 0.14rem;
    }
}

@media (min-width: 1101px) {
    .app-shell {
        transition: grid-template-columns 0.22s ease;
    }

    .sidebar,
    .sidebar-nav a,
    .sidebar-brand-copy,
    .sidebar-footer-copy,
    .sidebar-toggle,
    .sidebar-logout-button {
        transition: all 0.22s ease;
    }

    .app-shell.sidebar-collapsed {
        grid-template-columns: 92px minmax(0, 1fr);
    }

    .app-shell.sidebar-collapsed .sidebar {
        align-items: center;
        padding-inline: 0.9rem;
    }

    .app-shell.sidebar-collapsed .sidebar-main,
    .app-shell.sidebar-collapsed .sidebar-footer {
        width: 100%;
    }

    .app-shell.sidebar-collapsed .sidebar-top {
        justify-items: center;
    }

    .app-shell.sidebar-collapsed .sidebar-brand {
        justify-content: center;
    }

    .app-shell.sidebar-collapsed .sidebar-brand-copy,
    .app-shell.sidebar-collapsed .sidebar-nav-label,
    .app-shell.sidebar-collapsed .sidebar-footer-copy,
    .app-shell.sidebar-collapsed .sidebar-logout-label {
        width: 0;
        opacity: 0;
        pointer-events: none;
    }

    .app-shell.sidebar-collapsed .sidebar-nav a,
    .app-shell.sidebar-collapsed .sidebar-toggle,
    .app-shell.sidebar-collapsed .sidebar-logout-button {
        justify-content: center;
        padding-inline: 0.7rem;
    }

    .app-shell.sidebar-collapsed .sidebar-user {
        justify-content: center;
    }

    .app-shell.sidebar-collapsed .sidebar-toggle-chevron {
        transform: rotate(-45deg);
    }
}

@media (max-width: 720px) {
    .auth-body,
    .content,
    .topbar,
    .sidebar {
        padding: 1rem;
    }

    .panel,
    .login-card,
    .stat-card {
        border-radius: 20px;
    }

    .panel-header,
    .topbar,
    .form-actions,
    .actions-cell {
        align-items: stretch;
        flex-direction: column;
    }

    .form-grid,
    .info-grid,
    .linked-grid,
    .lab-grid,
    .clinic-exam-grid,
    .history-checkbox-grid,
    .exploration-grid,
    .visit-module-trigger-row {
        grid-template-columns: 1fr;
    }

    .lab-card {
        align-items: stretch;
        flex-direction: column;
    }

    .lab-card-body {
        grid-template-columns: 72px minmax(0, 1fr);
        width: 100%;
    }

    .lab-history-toggle {
        align-items: stretch;
        flex-direction: column;
    }

    .visit-inline-header {
        align-items: stretch;
        flex-direction: column;
    }

    .schedule-hour-grid-day .schedule-hour-grid-body-timeline {
        grid-template-columns: 1fr;
    }

    .schedule-hour-grid-day .schedule-hour-axis-column {
        display: none;
    }

    .schedule-hour-grid-day .schedule-hour-cell-timeline {
        border-left: 0;
    }

    .schedule-hour-grid-day .schedule-hour-axis {
        text-align: left;
        border-right: 0;
        border-bottom: 1px solid rgba(214, 199, 180, 0.6);
        padding: 0.45rem 0.65rem;
    }
}
