/* =====================================================
   DESIGN TOKENS
===================================================== */

:root {
    --bg: #f5f7fb;
    --card: #ffffff;
    --text: #1f2937;
    --muted: #6b7280;

    --line: #d9e0ea;
    --line-soft: #e9eef5;
    
    --accent: #2563eb;
    --accent-hover: #1d4ed8;
    --accent-soft: #eff6ff;

    --danger: #b91c1c;
    --danger-bg: #fef2f2;
    --danger-text: #991b1b;
    --danger-line: #fecaca;

    --radius: 16px;
    --radius-sm: 12px;

    --shadow-sm: 0 2px 8px rgba(15, 23, 42, 0.04);
    --shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
}

/* =====================================================
   BASE
===================================================== */

* {
    box-sizing: border-box;
}

html {
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    line-height: 1.5;
}

a {
    color: var(--accent);
    text-decoration: none;
}

a:hover {
    color: var(--accent-hover);
}


/* -------------------------------------------------
   Site Header / Global Navigation
------------------------------------------------- */

.site-header {
    padding: 14px 0 20px;
    margin-bottom: 28px;

    border-bottom: 1px solid var(--line);
}

.site-header-inner {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    min-width: 0;
    width: 100%;
}

.site-header-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    min-width: 0;
    width: 100%;
}

.site-header-brand {
    flex: 0 0 auto;
    min-width: 0;
}

.site-brand-link {
    display: inline-flex;
    align-items: flex-start;
    gap: 10px;

    color: var(--text);
    text-decoration: none;
}

.site-brand-link:hover {
    color: var(--text);
}

.site-brand-link:focus-visible,
.header-nav-pill:focus-visible,
.site-header-action:focus-visible,
.site-header-logout:focus-visible {
    outline: 3px solid rgba(37, 99, 235, 0.22);
    outline-offset: 3px;
}

.site-logo {
    width: 42px;
    height: 42px;
    object-fit: cover;
    border-radius: 10px;
    display: block;

    border: 1px solid var(--line);
    background: #fff;
}

.site-header-brand-stack {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.site-brand-text {
    font-size: 0.98rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    line-height: 1.2;
}

.site-header-context {
    color: var(--muted);
    font-size: 0.82rem;
    line-height: 1.3;
}

.site-header-nav {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 6px;
    flex-wrap: wrap;
    min-width: 0;
    width: 100%;
    padding-top: 2px;
}

.header-nav-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid transparent;
    border-radius: 999px;
    color: var(--muted);
    background: transparent;
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.header-nav-pill:hover {
    color: var(--text);
    background: #fff;
    border-color: var(--line);
    box-shadow: var(--shadow-sm);
}

.header-nav-pill-active,
.header-nav-pill-active:hover {
    color: var(--accent);
    background: var(--accent-soft);
    border-color: rgba(37, 99, 235, 0.18);
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.04);
}

.site-header-actions {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    flex-wrap: wrap;
    min-width: 0;
    width: 100%;
    padding-top: 2px;
}

.site-header-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--text);
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
    box-shadow: var(--shadow-sm);
    transition: background 0.16s ease, border-color 0.16s ease, color 0.16s ease, transform 0.08s ease;
}

.site-header-action:hover {
    color: var(--accent);
    border-color: rgba(37, 99, 235, 0.24);
    background: #f8fbff;
}

.site-header-action:active {
    transform: translateY(1px);
}

.site-header-user {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
    flex: 0 0 auto;
    min-width: 0;
}

.site-header .user-name {
    color: var(--muted);
    font-size: 0.88rem;
    padding-right: 0;
}

.site-header-logout {
    color: var(--muted);
    font-size: 0.86rem;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}

.site-header-logout:hover {
    color: var(--accent);
}

.page-header .header-links,
.page-header-right .header-links {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    flex-wrap: wrap;
}

.page-header .header-links a,
.page-header-right .header-links a {
    color: var(--text);
    font-size: 0.9rem;
    font-weight: 650;
    text-decoration: none;
}

.page-header .header-links a:hover,
.page-header-right .header-links a:hover {
    color: var(--accent);
}

@media (max-width: 760px) {

    .site-header-inner {
        gap: 10px;
    }

    .site-header-top-row {
        align-items: flex-start;
        flex-direction: column;
    }

    .site-header-nav {
        padding-top: 0;
    }

    .site-header-actions {
        padding-top: 0;
    }

    .site-header-user {
        justify-content: flex-start;
    }

    .header-nav-pill,
    .site-header-action {
        min-height: 36px;
    }

    .site-brand-text {
        display: inline;
    }

}


/* =====================================================
   LAYOUT
===================================================== */

.container {
    max-width: 1100px;
    margin: 36px auto 56px;
    padding: 0 20px;
}

.container-narrow {
    max-width: 760px;
}

.page-content {
    width: 100%;
    max-width: 920px;
    margin: 0 auto;
}

/* =====================================================
   HEADER SYSTEM (Unified)
===================================================== */

.page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
    margin-bottom: 24px;
}

.page-header-content {
    min-width: 0;
}

.action-row,
.page-actions,
.health-page-actions,
.health-actions,
.health-form-actions,
.health-inline-actions,
.daily-log-form-actions,
.inline-edit-actions,
.inventory-actions,
.inventory-record-actions,
.meds-form-actions,
.archive-log-actions,
.merge-actions,
.workspace-toolbar-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.action-row {
    gap: 10px;
}

.page-actions,
.health-page-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.page-subtitle {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 0.95rem;
}

.eyebrow {
    margin: 0 0 6px;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.page-header-left h1 {
    margin: 0;
    font-size: 1.9rem;
    line-height: 1.15;
    letter-spacing: -0.02em;
}

.page-header-left .muted {
    margin: 6px 0 0;
    font-size: 0.95rem;
}

.page-header-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
}



.user-name {
    color: var(--muted);
}

/* =====================================================
   CARDS
===================================================== */

.card,
.health-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 24px;
    overflow: hidden;
}

.health-card-header {
    margin-bottom: 16px;
}

.empty-state {
    color: var(--muted);
}

/* Section-style card (dashboard tables) */

.section {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
}

.section-header {
    padding: 16px 18px;
    border-bottom: 1px solid var(--line);
    font-weight: 600;
}

/* =====================================================
   BUTTONS
===================================================== */

.button,
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;

    min-height: 44px;
    padding: 0 15px;

    border: 1px solid transparent;
    border-radius: var(--radius-sm);

    background: var(--accent);
    color: #fff;

    font: inherit;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;

    transition: background 0.18s ease, transform 0.05s ease;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}

.button:hover,
.btn:hover {
    background: var(--accent-hover);
    color: #fff;
}

.button:active,
.btn:active {
    transform: translateY(1px);
}

/* Variants */

.button-secondary,
.btn-secondary {
    background: #fff;
    color: var(--text);
    border-color: var(--line);
}

.button-secondary:hover,
.btn-secondary:hover {
    background: #f8fafc;
    color: var(--text); /* ← add this */
}

.button-danger {
    background: var(--danger-bg);
    color: var(--danger);
    border-color: var(--danger-line);
}

/* =====================================================
   ALERTS
===================================================== */

.alert {
    margin-bottom: 18px;
    padding: 12px 14px;
    border: 1px solid var(--danger-line);
    border-radius: 10px;
    background: var(--danger-bg);
    color: var(--danger-text);
    font-size: 0.95rem;
}

.alert ul {
    margin: 0;
    padding-left: 18px;
}

/* =====================================================
   FORMS
===================================================== */

.form-row,
.field {
    margin-bottom: 18px;
}

label {
    display: block;
    margin-bottom: 6px;
    font-weight: 600;
    font-size: 0.95rem;
}

input,
textarea {
    width: 100%;
    padding: 11px 12px;
    border: 1px solid var(--line);
    border-radius: 10px;
    font: inherit;
    color: var(--text);
    background: #fff;
}

input[type="text"],
select {
    height: 40px;
    padding: 8px 12px;
    border-radius: 8px;
    border: 1px solid var(--border);
    font-size: 14px;
    background: #fff;
}

input:focus,
textarea:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(29,78,216,0.10);
}

textarea {
    min-height: 140px;
    resize: vertical;
}

.helper {
    margin-top: 6px;
    color: var(--muted);
    font-size: 0.9rem;
}

/* =====================================================
   TOOLBAR
===================================================== */

.toolbar {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;

    margin-bottom: 18px;
    padding: 14px;

    background: rgba(255,255,255,0.72);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    backdrop-filter: blur(6px);
}

.toolbar input[type="text"] {
    flex: 1 1 320px;
    min-width: 220px;
    height: 44px;
    padding: 0 14px;
}

/* =====================================================
   TABLES
===================================================== */

.table-wrap {
    width: 100%;
    overflow-x: auto;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 720px;
}

.data-table thead th {
    background: #f8fafc;
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--line);
}

.data-table th,
.data-table td {
    padding: 14px 16px;
    text-align: left;
}

.data-table tbody tr + tr td {
    border-top: 1px solid var(--line-soft);
}

/* Right-align actions column */
.data-table td:last-child {
    text-align: right;
}

/* Row actions */

.row-actions {
    display: inline-flex;
    gap: 8px;
}

.row-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    min-height: 32px;
    padding: 0 10px;

    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;

    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text);
}

/* Danger action (Delete) */
.row-actions a:last-child {
    color: var(--danger);
    background: var(--danger-bg);
    border-color: var(--danger-line);
}

/* =====================================================
   DASHBOARD GRID
===================================================== */

.grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.grid > .card {
    padding: 18px;
}

.grid h3 {
    margin: 0 0 10px;
    font-size: 0.95rem;
    color: var(--muted);
    font-weight: 600;
    text-transform: uppercase;
}

.grid .value {
    font-size: 1.6rem;
    font-weight: 600;
}

.grid .sub {
    margin-top: 6px;
    font-size: 0.9rem;
    color: var(--muted);
}

/* =====================================================
   LOGIN PAGE
===================================================== */

body.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.login-shell {
    width: 100%;
    max-width: 420px;
}

.login-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 28px;
}

.login-brand {
    margin-bottom: 22px;
    text-align: center;
}

.login-brand h1 {
    margin: 0 0 6px;
    font-size: 1.9rem;
}

.login-footer {
    margin-top: 16px;
    text-align: center;
    font-size: 0.9rem;
    color: var(--muted);
}

/* =====================================================
   RESPONSIVE
===================================================== */

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

@media (max-width: 760px) {
    .container {
        margin-top: 24px;
        padding: 0 14px 28px;
    }

    .page-header {
        align-items: stretch;
    }

    .page-header-right {
        align-items: stretch;
        width: 100%;
    }

    .page-actions,
    .health-page-actions {
        width: 100%;
        justify-content: stretch;
    }

    .card,
    .health-card {
        padding: 18px;
    }

    .toolbar input,
    .button,
    .btn {
        width: 100%;
    }

    .row-actions {
        justify-content: flex-end;
        width: 100%;
    }
}




/* =====================================================
   FOOTER
===================================================== */

.app-footer {
    margin-top: 40px;
    padding: 20px 0;
    border-top: 1px solid #e5e7eb;
    background: transparent;
}

.footer-inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.9rem;
    color: #6b7280;
}

.footer-left {
    font-weight: 500;
}

.footer-right {
    font-size: 0.85rem;
}

/* =====================================================
   FORM
===================================================== */
.form-card {
    max-width: 700px;
    margin: 0 auto;
}

.button-row {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-top: 24px;
    flex-wrap: wrap;
}



.detail-grid {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.detail-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.detail-label {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.detail-value {
    font-size: 1rem;
    line-height: 1.6;
}

.notes-block {
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fafbfd;
    min-height: 80px;
}



.page-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}

.summary-stat {
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 18px;
    background: #fafbfd;
}

.summary-value {
    margin-top: 6px;
    font-size: 1.15rem;
    font-weight: 600;
    line-height: 1.4;
}

.detail-section {
    margin-bottom: 24px;
}

.detail-meta {
    display: flex;
    gap: 40px;
    margin-bottom: 24px;
    padding-top: 12px;
    border-top: 1px solid var(--line);
}

/* =========================================
   HEALTH RESULTS MODULE
   Pages:
   - health_results_list.php
   - health_result_add.php
   - health_result_edit.php
   - health_test_view.php
========================================= */

/* ---------- Page Header / Title Row ---------- */

.page-header.health-header,
.health-page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.page-header.health-header h1,
.health-page-header h1 {
    margin: 0;
    font-size: 1.9rem;
    line-height: 1.2;
}

.page-header.health-header .page-subtitle,
.health-page-header .page-subtitle {
    margin-top: 6px;
    color: var(--muted);
    font-size: 0.98rem;
}

/* ---------- Action Area ---------- */

.health-actions,
.page-actions.health-actions {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

/* ---------- Top Summary / Metric Chips ---------- */

.health-summary,
.health-metric-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
}

.health-chip,
.metric-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 8px 14px;
    font-size: 0.92rem;
    color: var(--text);
    box-shadow: 0 1px 2px rgba(16, 24, 40, 0.03);
}

.health-chip strong,
.metric-chip strong {
    font-weight: 700;
    color: var(--text);
}

/* ---------- Toolbar / Filters ---------- */

.health-toolbar-card {
    margin-bottom: 20px;
}

.health-toolbar,
.toolbar.health-toolbar {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: end;
}

.health-toolbar .field,
.toolbar.health-toolbar .field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 180px;
    flex: 1 1 180px;
}

.health-toolbar label,
.toolbar.health-toolbar label {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--muted);
    margin: 0;
}

.health-toolbar input[type="text"],
.health-toolbar input[type="date"],
.health-toolbar select,
.toolbar.health-toolbar input[type="text"],
.toolbar.health-toolbar input[type="date"],
.toolbar.health-toolbar select {
    width: 100%;
}

.health-toolbar .toolbar-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

/* ---------- Results Table ---------- */

.health-table-wrap {
    overflow-x: auto;
    margin-top: 4px;
}

table.health-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 760px;
    background: var(--surface);
}

.health-table th,
.health-table td {
    padding: 13px 14px;
    text-align: left;
    vertical-align: middle;
    border-bottom: 1px solid var(--border-soft);
}

.health-table th {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--muted);
    background: #fafbfd;
    white-space: nowrap;
}

.health-table td {
    font-size: 0.96rem;
    color: var(--text);
}

.health-table tr:last-child td {
    border-bottom: none;
}

.health-table tr:hover td {
    background: #fcfdff;
}

/* ---------- Test Name / Metric Link ---------- */

.health-test-name,
.health-metric-name {
    font-weight: 700;
    color: var(--text);
    text-decoration: none;
}

.health-test-name:hover,
.health-metric-name:hover {
    text-decoration: underline;
}

/* ---------- Value Display ---------- */

.health-value {
    font-weight: 700;
    font-size: 1rem;
    color: var(--text);
    white-space: nowrap;
}

.health-unit {
    color: var(--muted);
    font-size: 0.92rem;
    margin-left: 4px;
}

.health-range-text {
    color: var(--muted);
    font-size: 0.92rem;
    white-space: nowrap;
}

/* ---------- Status Badges ---------- */

.health-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1;
    border: 1px solid transparent;
    white-space: nowrap;
}

.health-badge-normal {
    background: #edf8f0;
    color: #1e6a35;
    border-color: #cfead7;
}

.health-badge-high {
    background: #fff3e8;
    color: #9a4b00;
    border-color: #ffd7b5;
}

.health-badge-low {
    background: #eef4ff;
    color: #2457a6;
    border-color: #cfe0ff;
}

.health-badge-borderline {
    background: #fff8db;
    color: #8a6a00;
    border-color: #f3e39b;
}

.health-badge-unknown {
    background: #f3f5f8;
    color: #5f6b7a;
    border-color: #d9e0ea;
}

/* ---------- Small Meta Text ---------- */

.meta-text,
.health-meta,
.health-date-meta,
.health-note-meta {
    color: var(--muted);
    font-size: 0.9rem;
}

/* ---------- Empty State ---------- */

.health-empty {
    padding: 28px 20px;
    text-align: center;
    color: var(--muted);
    border: 1px dashed var(--border);
    border-radius: 14px;
    background: #fbfcfe;
}

.health-empty-title {
    display: block;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 6px;
}

.health-empty p {
    margin: 0;
}

/* ---------- Add/Edit Form ---------- */

.health-form-card {
    max-width: 900px;
}

.health-form {
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.health-form-section + .health-form-section {
    padding-top: 4px;
    border-top: 1px solid var(--border-soft);
}

.health-form-section h2,
.health-form-section h3 {
    margin: 0 0 14px 0;
    font-size: 1.08rem;
}

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

.health-form-grid .full-width {
    grid-column: 1 / -1;
}

.health-field {
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.health-field label {
    font-size: 0.92rem;
    font-weight: 600;
    color: var(--text);
    margin: 0;
}

.health-field .help-text {
    margin-top: 2px;
    font-size: 0.84rem;
    color: var(--muted);
}

.health-field input[type="text"],
.health-field input[type="number"],
.health-field input[type="date"],
.health-field select,
.health-field textarea {
    width: 100%;
}

.health-field textarea {
    min-height: 120px;
    resize: vertical;
}

.health-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding-top: 2px;
}

/* ---------- Errors / Notices ---------- */

.health-errors,
.health-alert {
    margin-bottom: 18px;
    padding: 14px 16px;
    border-radius: 12px;
    border: 1px solid #f1c3c3;
    background: #fff3f3;
    color: #8f2f2f;
}

.health-errors ul {
    margin: 8px 0 0 18px;
    padding: 0;
}

.health-notice {
    margin-bottom: 18px;
    padding: 14px 16px;
    border-radius: 12px;
    border: 1px solid #cfe0ff;
    background: #eef4ff;
    color: #2457a6;
}

/* ---------- Test View / Single Metric Page ---------- */

.health-test-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.health-test-title-wrap h1 {
    margin: 0;
    font-size: 1.85rem;
    line-height: 1.2;
}

.health-test-subtitle {
    margin-top: 6px;
    color: var(--muted);
    font-size: 0.98rem;
}

.health-test-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(140px, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}

.health-stat-card {
    padding: 18px;
    border: 1px solid #dbe3ee;
    border-radius: 16px;
    background: #ffffff;
    box-shadow:
        0 1px 2px rgba(0,0,0,0.04),
        0 8px 24px rgba(15,23,42,0.04);
}

.health-stat-label {
    display: block;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--muted);
    margin-bottom: 8px;
}

.health-stat-value {
    display: block;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--text);
    line-height: 1.2;
}

/* ---------- Result History List ---------- */

.health-history-card {
    margin-top: 20px;
}

.health-history-list {
    display: flex;
    flex-direction: column;
}

.health-history-item {
    display: grid;
    grid-template-columns: 140px 1fr auto;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid var(--border-soft);
    align-items: start;
}

.health-history-item:first-child {
    padding-top: 4px;
}

.health-history-item:last-child {
    border-bottom: none;
    padding-bottom: 4px;
}

.health-history-date {
    font-weight: 700;
    color: var(--text);
    white-space: nowrap;
}

.health-history-main {
    min-width: 0;
}

.health-history-value {
    font-size: 1.08rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 4px;
}

.health-history-range,
.health-history-notes,
.health-history-lab {
    color: var(--muted);
    font-size: 0.93rem;
    line-height: 1.5;
}

.health-history-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
}

/* ---------- Inline Key/Value Detail Blocks ---------- */

.health-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px 18px;
}

.health-detail-item {
    background: #fafbfd;
    border: 1px solid var(--border-soft);
    border-radius: 12px;
    padding: 14px 14px;
}

.health-detail-label {
    display: block;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--muted);
    margin-bottom: 6px;
}

.health-detail-value {
    font-size: 1rem;
    color: var(--text);
    font-weight: 600;
    word-break: break-word;
}

/* ---------- Notes Blocks ---------- */

.health-notes-block {
    margin-top: 18px;
    padding: 16px;
    border: 1px solid var(--border-soft);
    border-radius: 14px;
    background: #fcfdff;
}

.health-notes-block h3 {
    margin: 0 0 10px 0;
    font-size: 1rem;
}

.health-notes-block p,
.health-notes-block div {
    margin: 0;
    line-height: 1.6;
    color: var(--text);
}

/* ---------- Utility ---------- */

.health-inline-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

.health-muted {
    color: var(--muted);
}

.health-nowrap {
    white-space: nowrap;
}

.health-right {
    text-align: right;
}

/* ---------- Responsive ---------- */

@media (max-width: 980px) {
    .health-test-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .health-form-grid,
    .health-detail-grid {
        grid-template-columns: 1fr;
    }

    .health-history-item {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .health-history-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .page-header.health-header,
    .health-page-header,
    .health-test-header {
        flex-direction: column;
        align-items: stretch;
    }

    .health-actions,
    .page-actions.health-actions,
    .health-form-actions,
    .health-inline-actions,
    .health-toolbar .toolbar-actions {
        width: 100%;
    }

    .health-actions .button,
    .page-actions.health-actions .button,
    .health-form-actions .button,
    .health-toolbar .toolbar-actions .button {
        width: 100%;
        justify-content: center;
    }

    table.health-table {
        min-width: 620px;
    }

    .health-chip,
    .metric-chip {
        width: 100%;
        justify-content: space-between;
    }
}

/* Unified muted text */
.muted,
.text-muted {
    color: var(--muted);
    opacity: 0.9;
}

.submeta-text,
.archive-log-meta {
    color: var(--muted);
    font-size: 0.85rem;
}

.small {
    font-size: 0.8rem;
    line-height: 1.4;
}

.stack-xs > * + * {
    margin-top: 4px;
}


.status-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;

    padding: 5px 10px;
    border-radius: 999px;

    font-size: 0.8rem;
    font-weight: 600;

    background: #eef4ff;
    color: #1d4ed8;
}




.med-row {
    display: flex;
    align-items: center;
    gap: 10px;
}

.med-img {
    width: 28px;
    height: 28px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--line);
    background: #fff;
}

.med-placeholder {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    background: var(--line-soft);
}

.med-row a {
    display: inline-flex;
    align-items: center;
}

.med-img-lg {
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: #fff;
}

.med-placeholder-lg {
    width: 56px;
    height: 56px;
    border-radius: 10px;
    background: var(--line-soft);
}















.site-brand {
    font-weight: 700;
    font-size: 18px;
    color: var(--text);
    text-decoration: none;
}

.site-brand:hover {
    text-decoration: underline;
}



.user-name {
    font-size: 14px;
    color: var(--muted);
    margin-right: 8px;
}











.page-main {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
}

.page-intro {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;

    margin-bottom: 20px;
    flex-wrap: wrap;
}

.page-intro__content {
    max-width: 600px;
}

.page-intro__actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}





/* ---------- TABS ---------- */

.workspace-tabs {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px;
    background: #eef2f7;
    border: 1px solid #d9e1ec;
    border-radius: 999px;
}

.workspace-tab {
    appearance: none;
    border: none;
    background: transparent;
    color: #5f6b7a;
    font: inherit;
    font-size: 14px;
    font-weight: 600;
    line-height: 1;
    padding: 10px 14px;
    border-radius: 999px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition:
        background 0.18s ease,
        color 0.18s ease,
        box-shadow 0.18s ease,
        transform 0.18s ease;
}

.workspace-tab:hover {
    background: rgba(255, 255, 255, 0.65);
    color: #1f2937;
}

.workspace-tab.is-active {
    background: #ffffff;
    color: #1d4ed8;
    box-shadow: 0 1px 2px rgba(16, 24, 40, 0.06),
                0 4px 10px rgba(16, 24, 40, 0.08);
}

.workspace-tab:focus-visible {
    outline: 2px solid #93c5fd;
    outline-offset: 2px;
}

.workspace-tab-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    border-radius: 999px;
    background: rgba(95, 107, 122, 0.12);
    color: inherit;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

.workspace-tab.is-active .workspace-tab-count {
    background: #dbeafe;
    color: #1d4ed8;
}

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

.template-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 16px;
}

.template-card {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.template-choice-card {
    cursor: pointer;
}

.template-choice-card input[type="radio"] {
    width: auto;
    margin: 0;
}

.template-card-main,
.template-card-meta,
.template-card-actions {
    display: flex;
    gap: 8px;
}

.template-card-main {
    flex-direction: column;
}

.template-card-meta,
.template-card-actions {
    flex-wrap: wrap;
    align-items: center;
}

.template-card-meta {
    color: #64748b;
    font-size: 0.92rem;
}

.template-card-notes {
    overflow-wrap: anywhere;
}

.template-preview-list {
    margin-top: 20px;
}

.template-preview-item {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-top: 1px solid #e5e7eb;
}

.template-preview-item:first-of-type {
    border-top: 0;
}

.template-items-workspace {
    margin-top: 20px;
}

.template-items-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.template-items-header h2,
.template-add-items h3 {
    margin: 0 0 4px;
}

.template-items-header p {
    margin: 0;
}

.template-item-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.template-item-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: stretch;
    padding: 14px;
    border: 1px solid var(--line-soft);
    border-radius: 14px;
    background: #fbfcfe;
}

.template-item-edit-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: end;
}

.template-item-main,
.template-add-card,
.template-add-fields {
    display: flex;
    flex-direction: column;
}

.template-item-main {
    gap: 12px;
}

.template-item-title {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.template-item-title strong {
    overflow-wrap: anywhere;
}

.template-item-fields {
    display: grid;
    grid-template-columns: minmax(120px, 160px) minmax(220px, 1fr);
    gap: 12px;
}

.template-item-fields input,
.template-add-fields input,
.template-add-fields select {
    width: 100%;
}

.template-item-actions,
.template-item-remove-form {
    display: flex;
    align-items: end;
}

.template-item-remove-button {
    color: var(--danger-text);
    border-color: var(--danger-line);
    background: var(--danger-bg);
}

.template-add-items {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--line-soft);
}

.template-add-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-top: 12px;
}

.template-add-card {
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--line-soft);
    border-radius: 14px;
    background: #ffffff;
}

.template-add-card-header {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.template-add-fields {
    gap: 12px;
}

@media (max-width: 760px) {
    .template-item-card,
    .template-item-edit-form,
    .template-add-grid {
        grid-template-columns: 1fr;
    }

    .template-item-fields {
        grid-template-columns: 1fr;
    }

    .template-item-actions,
    .template-item-actions .btn,
    .template-item-remove-form,
    .template-item-remove-form .btn {
        width: 100%;
    }
}

.template-select-card {
    margin-bottom: 16px;
}

@media (max-width: 640px) {
    .workspace-tabs {
        max-width: 100%;
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
    }
}









/* ---------- FOOD ITEM SELECTOR ---------- */

#add-food-item-results button {
    font-size: 14px;
    line-height: 1.3;
}

#add-food-item-results {
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}




/* ---------- Account_view.PHP PAGE TABLE ---------- */

.table-scroll {
    width: 100%;
    overflow-x: auto;
    padding-bottom: 0.35rem;
}

.account-activity-table {
    min-width: 1120px;
}

.account-activity-table th,
.account-activity-table td {
    white-space: nowrap;
}






/* ---------- STORES.PHP PAGE TABLE ---------- */

.page-header-row {
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
    margin-bottom:20px;
}

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

.compact-table th {
    text-align:left;
    padding:0 0 12px 0;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:#64748b;
}

.compact-table td {
    padding:10px 0;
    border-top:1px solid #e2e8f0;
    vertical-align:middle;
}

.store-cell {
    display:flex;
    align-items:center;
    gap:12px;
}

.store-thumb {
    width:36px;
    height:36px;
    object-fit:cover;
    border-radius:8px;
    flex-shrink:0;
}

.store-thumb-placeholder {
    background:#f1f5f9;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#94a3b8;
    font-size:12px;
}

.store-name {
    font-weight:600;
    text-decoration:none;
}

.table-action-link {
    font-size:14px;
    font-weight:600;
    text-decoration:none;
}


















/* ---------- INVENTORY.PHP PAGE TABLE ---------- */

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

.compact-table th {
    text-align:left;
    padding:0 0 12px 0;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:#64748b;
}

.compact-table td {
    padding:12px 0;
    border-top:1px solid #e2e8f0;
    vertical-align:middle;
}

.inventory-item-cell {
    display:flex;
    align-items:center;
    gap:12px;
}

.inventory-thumb {
    width:44px;
    height:44px;
    border-radius:10px;
    object-fit:cover;
    flex-shrink:0;
}

.inventory-thumb-placeholder {
    background:#f1f5f9;
}

.inventory-item-name {
    font-weight:600;
    text-decoration:none;
}

.inventory-meta {
    display:flex;
    flex-direction:column;
    gap:4px;
}

.table-inline-actions {
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    gap:6px;
}

.table-action-link {
    font-size:14px;
    font-weight:600;
    text-decoration:none;
}







.inline-edit-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(160px, 1fr));
    gap: 12px;
    align-items: end;
}

.inline-edit-grid label {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
    font-weight: 600;
    color: #666;
}

.inline-edit-actions {
    display: flex;
    gap: 8px;
}







/* ---------- OVERLAPPING IMAGES CSS ---------- */

.store-visit-icon-stack {
    position: relative;
    width: 52px;
    height: 52px;
    flex-shrink: 0;
}

.store-visit-primary-icon {
    width: 42px;
    height: 42px;
    object-fit: cover;
    border-radius: 10px;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    border: 2px solid #fff;
    background: #fff;
}

.store-visit-secondary-icon {
    width: 24px;
    height: 24px;
    object-fit: cover;
    border-radius: 8px;
    position: absolute;
    bottom: 0;
    right: 0;
    border: 2px solid #fff;
    background: #fff;
    box-shadow: 0 2px 5px rgba(0,0,0,0.15);
}


/* ---------- SPENDING DASHBOARD PAGE ----------- */

.spending-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.spending-section-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 1rem;
}

.spending-section-stack > .card {
    width: 100%;
}

.spending-stat-card .spending-stat-label {
    font-size: 0.85rem;
    color: var(--muted);
    margin-bottom: 0.35rem;
}

.spending-stat-card .spending-stat-value {
    font-size: 1.7rem;
    font-weight: 700;
    line-height: 1.1;
}

.spending-bars {
    display: grid;
    gap: 0.65rem;
}

.spending-bar-row {
    display: grid;
    grid-template-columns: 70px 1fr 90px;
    gap: 0.75rem;
    align-items: center;
}

.spending-bar-date,
.spending-bar-value {
    font-size: 0.9rem;
    color: var(--muted);
}

.spending-bar-value {
    text-align: right;
}

.spending-bar-track {
    height: 12px;
    border-radius: 999px;
    background: var(--surface-muted, #eef1f3);
    overflow: hidden;
}

.spending-bar-fill {
    height: 100%;
    border-radius: 999px;
    background: var(--accent, #406c5a);
}

.spending-list {
    display: grid;
    gap: 0.75rem;
}

.spending-list-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border, #e5e7eb);
}

.spending-list-row:last-child {
    border-bottom: 0;
}

.spending-list-amount {
    text-align: right;
    flex-shrink: 0;
}

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

    .spending-bar-row {
        grid-template-columns: 60px 1fr 75px;
    }
}

.spending-breakdown-body {
    max-height: 420px;   /* adjust to taste */
    overflow-y: auto;
}

.spending-breakdown-body table thead th {
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 1;
}

.spending-breakdown-body {
    scroll-behavior: smooth;
}



/* ---------- DAILY LOG VIEW PAGE ---------- */

.daily-log-header {
    margin-bottom: 20px;
}

.daily-log-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.daily-log-stat-card {
    padding: 18px;
}

.daily-log-stat-label {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 6px;
}

.daily-log-stat-value {
    font-size: 1.45rem;
    font-weight: 700;
    line-height: 1.2;
}

.daily-log-note-preview {
    font-size: 1rem;
    line-height: 1.45;
    max-height: 3rem;
    overflow: hidden;
}

.daily-log-add-panel {
    margin-bottom: 1rem;
}

.daily-log-section-heading {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.daily-log-section-heading h2 {
    margin: 0 0 4px 0;
}

.daily-log-section-heading p {
    margin: 0;
}

.daily-log-add-grid {
    display: grid;
    gap: 12px;
    align-items: end;
}

.daily-log-add-grid-food {
    grid-template-columns: minmax(260px, 2fr) minmax(120px, 0.8fr) minmax(120px, 0.8fr) auto;
}

.daily-log-add-grid-store {
    grid-template-columns: minmax(200px, 1.4fr) minmax(200px, 1.4fr) minmax(120px, 0.7fr) minmax(200px, 1.2fr) auto;
}

.daily-log-search-results {
    border: 1px solid var(--line);
    border-radius: 10px;
    max-height: 220px;
    overflow-y: auto;
    background: #fff;
    margin-top: 8px;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.05);
}

.daily-log-form-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

.daily-log-panel-note {
    margin: 12px 0 0 0;
}

.daily-log-workspace {
    margin-top: 1rem;
}

.daily-log-workspace-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}

.daily-log-workspace-header h2 {
    margin: 0 0 4px 0;
}

.daily-log-workspace-header p {
    margin: 0;
}

.daily-log-workspace-controls {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}

.daily-log-tab-actions {
    margin: 0;
}

.daily-log-entry-list,
.daily-log-store-list {
    display: grid;
    gap: 0.85rem;
}

.daily-log-food-row,
.daily-log-store-card {
    border: 1px solid var(--line-soft);
    border-radius: 14px;
    background: #fbfcfe;
}

.daily-log-food-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 120px auto;
    gap: 1rem;
    align-items: center;
    padding: 14px;
}

.daily-log-store-card {
    padding: 14px;
}

.daily-log-store-topline {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 120px auto;
    gap: 1rem;
    align-items: flex-start;
}

.daily-log-entry-main {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.daily-log-entry-text {
    min-width: 0;
}

.daily-log-entry-text strong {
    display: block;
    line-height: 1.3;
}

.daily-log-entry-metric {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    white-space: nowrap;
}

.daily-log-entry-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: wrap;
}

.daily-log-entry-actions form,
.daily-log-purchased-item form {
    margin: 0;
}

.daily-log-purchased-items {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--line-soft);
    display: grid;
    gap: 8px;
}

.daily-log-purchased-item {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
}

.daily-log-purchased-thumb {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    object-fit: cover;
    flex-shrink: 0;
}

.daily-log-purchased-name {
    font-size: 0.92rem;
    min-width: 0;
}

.daily-log-purchased-name strong {
    display: inline;
}

.daily-log-purchased-notes {
    margin-top: 2px;
    font-size: 0.85rem;
    line-height: 1.35;
}

.daily-log-purchased-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.daily-log-purchased-item-edit {
    padding: 10px;
    border: 1px solid var(--line-soft);
    border-radius: 12px;
    background: #fff;
}

.daily-log-purchased-item-edit form {
    margin: 0;
}

.daily-log-purchased-edit-grid {
    display: grid;
    grid-template-columns: minmax(90px, 120px) minmax(180px, 1fr) auto;
    gap: 10px;
    align-items: end;
}

.daily-log-purchased-edit-grid label {
    display: block;
    margin-bottom: 4px;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 700;
}

.daily-log-purchased-edit-grid input {
    min-height: 36px;
    padding: 7px 10px;
    border-radius: 8px;
}

.daily-log-purchased-edit-actions {
    align-items: flex-end;
}

.daily-log-small-button {
    min-height: 32px;
    padding: 0 10px;
    font-size: 0.82rem;
}

.daily-log-no-items {
    font-size: 0.92rem;
}

.daily-log-inline-edit {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fff;
    padding: 14px;
}

.daily-log-empty {
    padding: 24px;
    border: 1px dashed var(--line);
    border-radius: 14px;
    background: #fbfcfe;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

@media (max-width: 980px) {
    .daily-log-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .daily-log-add-grid-food,
    .daily-log-add-grid-store,
    .daily-log-food-row,
    .daily-log-store-topline {
        grid-template-columns: 1fr;
    }

    .daily-log-entry-metric {
        align-items: flex-start;
    }

    .daily-log-entry-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .daily-log-summary-grid {
        grid-template-columns: 1fr;
    }

    .daily-log-workspace-controls {
        width: 100%;
        align-items: stretch;
    }

    .daily-log-tab-actions {
        width: 100%;
    }

    .daily-log-tab-actions .btn {
        width: 100%;
    }

    .daily-log-purchased-item {
        grid-template-columns: 34px minmax(0, 1fr);
    }

    .daily-log-purchased-item form {
        grid-column: 2;
    }

    .daily-log-purchased-actions {
        grid-column: 2;
        justify-content: flex-start;
    }

    .daily-log-purchased-edit-grid {
        grid-template-columns: 1fr;
    }

    .daily-log-purchased-edit-actions {
        align-items: stretch;
    }
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
}

.summary-item {
    padding: 16px;
    border-radius: 12px;
    background: #f9fafb;
}

.summary-label {
    font-size: 12px;
    color: #6b7280;
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.summary-value {
    font-size: 22px;
    font-weight: 600;
    color: #1f2937;
}

.summary-note {
    font-size: 12px;
    color: #6b7280;
    margin-top: 4px;
}

.list-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 16px;
    border-bottom: 1px solid #e5e7eb;
}

.list-row-main {
    display: flex;
    flex-direction: column;
}

.list-row-title {
    font-weight: 600;
    color: #1f2937;
}

.list-row-sub {
    font-size: 13px;
    color: #6b7280;
    margin-top: 2px;
}

.list-row-actions {
    display: flex;
    gap: 8px;
}

.section-heading {
    font-size: 14px;
    font-weight: 600;
    color: #6b7280;
    margin: 16px 0 8px;
}

.btn-small {
    padding: 6px 10px;
    font-size: 13px;
}

.pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 16px;
    gap: 12px;
}

.pagination-info {
    font-size: 13px;
    color: #6b7280;
}

.list-row:first-of-type {
    border-top: 1px solid #e5e7eb;
}

.edit-row {
    padding: 12px 16px;
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
}

.card-header {
    padding: 16px;
    border-bottom: 1px solid #e5e7eb;
}

.section-heading {
    font-size: 13px;
    font-weight: 600;
    color: #6b7280;
    margin: 20px 0 8px;
}

.daily-log-row-wrapper {
    margin-bottom: 1rem;
}


/* ---------- INVENTORY PAGE ---------- */

.inventory-header {
    margin-bottom: 20px;
}

.inventory-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.inventory-stat-card {
    padding: 18px;
}

.inventory-stat-label {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 6px;
}

.inventory-stat-value {
    font-size: 1.45rem;
    font-weight: 700;
    line-height: 1.2;
}

.inventory-control-card {
    margin-bottom: 1rem;
}

.inventory-control-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.inventory-control-top h2,
.inventory-results-header h2 {
    margin: 0 0 4px 0;
}

.inventory-control-top p,
.inventory-results-header p {
    margin: 0;
}

.inventory-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.inventory-filter-bar {
    display: grid;
    grid-template-columns: minmax(240px, 1fr) 180px auto auto;
    gap: 10px;
    align-items: center;
}

.inventory-results-header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

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

.inventory-record-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;

    padding: 14px;
    border: 1px solid var(--line-soft);
    border-radius: 14px;
    background: #fbfcfe;
}

.inventory-record-main {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.inventory-record-thumb {
    width: 54px;
    height: 54px;
    border-radius: 12px;
    object-fit: cover;
    flex-shrink: 0;
}

.inventory-record-content {
    min-width: 0;
}

.inventory-record-title-row {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    flex-wrap: wrap;
}

.inventory-record-title {
    font-weight: 700;
    color: var(--text);
    text-decoration: none;
    line-height: 1.3;
}

.inventory-record-title:hover {
    color: var(--accent);
}

.inventory-type-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 9px;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
    border: 1px solid var(--line);
    background: #fff;
    color: var(--muted);
}

.inventory-type-food {
    background: #eff6ff;
    color: #1d4ed8;
    border-color: #bfdbfe;
}

.inventory-type-store {
    background: #f0fdf4;
    color: #166534;
    border-color: #bbf7d0;
}

.inventory-record-badges {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 7px;
}

.inventory-record-meta {
    margin-top: 7px;
    font-size: 0.9rem;
}

.inventory-record-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.inventory-empty {
    padding: 24px;
    border: 1px dashed var(--line);
    border-radius: 14px;
    background: #fbfcfe;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

@media (max-width: 980px) {
    .inventory-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

    .inventory-record-card {
        grid-template-columns: 1fr;
    }

    .inventory-record-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .inventory-summary-grid {
        grid-template-columns: 1fr;
    }

    .inventory-actions,
    .inventory-record-actions {
        width: 100%;
    }

    .inventory-actions .btn,
    .inventory-record-actions .btn {
        width: 100%;
    }
}

/* ---------- STORE PROFILE / EDIT PAGE ---------- */

.store-profile-header {
    margin-bottom: 20px;
}

.store-profile-hero {
    margin-bottom: 1rem;
}

.store-profile-main {
    display: flex;
    align-items: center;
    gap: 18px;
}

.store-profile-photo {
    width: 86px;
    height: 86px;
    border-radius: 18px;
    object-fit: cover;
    border: 1px solid var(--line);
    background: #fff;
    flex-shrink: 0;
}

.store-profile-photo-placeholder {
    background: var(--line-soft);
}

.store-profile-title-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.store-profile-title-row h2 {
    margin: 0;
}

.store-profile-title-row + p {
    margin: 6px 0 0 0;
}

.store-profile-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.store-profile-stat-card {
    padding: 18px;
}

.store-profile-stat-label {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 6px;
}

.store-profile-stat-value {
    font-size: 1.45rem;
    font-weight: 700;
    line-height: 1.2;
}

.store-profile-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 1rem;
    margin-bottom: 1rem;
}

.store-profile-edit-card h2,
.store-profile-activity-card h2,
.store-profile-items-card h2 {
    margin: 0 0 4px 0;
}

.store-profile-edit-card p,
.store-profile-activity-card p,
.store-profile-items-card p {
    margin: 0 0 1rem 0;
}

.store-profile-edit-card .form-group {
    margin-bottom: 16px;
}

.store-profile-help-text {
    margin: 8px 0 0 0;
    font-size: 0.9rem;
}

.store-profile-checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px;
}

.store-profile-checkbox-label input {
    width: auto;
}

.store-profile-visit-list {
    display: grid;
    gap: 0.75rem;
}

.store-profile-visit-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--line-soft);
}

.store-profile-visit-row:last-child {
    border-bottom: 0;
}

.store-profile-visit-amount {
    font-weight: 700;
    white-space: nowrap;
}

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

.store-profile-item-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line-soft);
    border-radius: 14px;
    background: #fbfcfe;
}

.store-profile-item-thumb {
    width: 46px;
    height: 46px;
    border-radius: 10px;
    object-fit: cover;
    flex-shrink: 0;
}

.store-profile-item-text {
    min-width: 0;
}

.store-profile-item-text strong {
    display: block;
    line-height: 1.3;
}

.store-profile-empty {
    padding: 20px;
    border: 1px dashed var(--line);
    border-radius: 14px;
    background: #fbfcfe;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

@media (max-width: 980px) {
    .store-profile-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

    .store-profile-item-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .store-profile-main {
        align-items: flex-start;
    }

    .store-profile-stat-grid {
        grid-template-columns: 1fr;
    }

    .store-profile-visit-row {
        flex-direction: column;
    }
}


/* ---------- Health Results History -------------- */

/* --------------------------------------------------
   Health Results History Summary Cards
-------------------------------------------------- */

.health-history-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin: 24px 0 28px;
}

.health-history-summary-grid .stat-card {
    background: var(--card-bg, #ffffff);
    border: 1px solid var(--border-color, #d8e0ea);
    border-radius: 18px;
    padding: 18px 20px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.health-history-summary-grid .stat-label {
    margin-bottom: 8px;
    color: var(--text-muted);
    font-size: 0.9rem;
    font-weight: 700;
}

.health-history-summary-grid .stat-value {
    color: var(--text);
    font-size: 1.85rem;
    font-weight: 800;
    line-height: 1;
}

@media (max-width: 900px) {
    .health-history-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .health-history-summary-grid {
        grid-template-columns: 1fr;
    }
}

.health-history-summary-grid {
    margin-bottom: 20px;
}

.health-history-filter-card {
    margin-bottom: 20px;
}

.health-history-filter-form {
    display: grid;
    grid-template-columns: minmax(260px, 2fr) minmax(200px, 1fr) minmax(220px, 1fr) auto;
    gap: 14px;
    align-items: end;
}

.health-history-search-field {
    min-width: 0;
}

.health-history-filter-actions {
    margin-top: 0;
    justify-content: flex-end;
}

.health-history-card {
    margin-bottom: 24px;
}

.health-history-table td {
    vertical-align: middle;
}

.health-history-test-cell {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.health-history-notes-row td {
    border-top: 0;
    padding-top: 0;
}

.health-history-note {
    margin: 0 0 10px;
    padding: 10px 12px;
    border-radius: 12px;
    background: var(--surface-muted);
    color: var(--text-muted);
    font-size: 0.92rem;
    line-height: 1.4;
}

.table-entity-link {
    font-weight: 700;
    color: var(--text);
    text-decoration: none;
}

.table-entity-link:hover {
    text-decoration: underline;
}

.table-primary-text {
    font-weight: 650;
    color: var(--text);
}

.soft-pill {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 4px 9px;
    border-radius: 999px;
    background: var(--surface-muted);
    color: var(--text-muted);
    font-size: 0.82rem;
    font-weight: 650;
    white-space: nowrap;
}

.actions-column {
    width: 180px;
}

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

    .health-history-filter-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 680px) {
    .health-history-filter-form {
        grid-template-columns: 1fr;
    }

    .health-history-filter-actions .button {
        width: 100%;
    }

    .health-history-note {
        margin-left: 0;
    }
}


/* --------- Health Test View ---------- */

.test-view {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.test-view-header,
.test-view-header-main,
.test-view-actions,
.test-view-snapshot-main,
.test-view-history-main,
.test-view-history-side {
    display: flex;
}

.test-view-header {
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    flex-wrap: wrap;
}

.test-view-header-main {
    align-items: center;
    gap: 20px;
    min-width: 0;
}

.test-view-header-content {
    min-width: 0;
}

.test-view-eyebrow {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b;
}

.test-view-title {
    margin: 0;
    font-size: 34px;
    line-height: 1.1;
    color: #0f172a;
}

.test-view-subtitle {
    margin-top: 6px;
    color: #64748b;
    font-size: 15px;
}

.test-view-actions {
    gap: 10px;
    flex-wrap: wrap;
}

.test-view-image {
    width: 100px;
    height: 100px;
    object-fit: cover;
    border-radius: 18px;
    border: 1px solid #dbe3ef;
    background: #ffffff;
    flex-shrink: 0;
}

.test-view-snapshot-card {
    padding: 24px;
}

.test-view-snapshot-main {
    justify-content: space-between;
    gap: 30px;
    align-items: flex-start;
    flex-wrap: wrap;
}

.test-view-snapshot-label {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #64748b;
}

.test-view-snapshot-value {
    margin-top: 8px;
    font-size: 42px;
    line-height: 1;
    font-weight: 700;
    color: #0f172a;
}

.test-view-snapshot-date {
    margin-top: 10px;
    color: #64748b;
    font-size: 15px;
}

.test-view-snapshot-meta-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
    flex: 1;
    min-width: 280px;
}

.test-view-mini-stat {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 16px;
}

.test-view-mini-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #64748b;
}

.test-view-mini-value {
    margin-top: 6px;
    font-size: 16px;
    font-weight: 600;
    color: #0f172a;
}

.test-view-card {
    padding: 22px;
}

.test-view-section-subtitle {
    margin-top: 4px;
    font-size: 14px;
    color: #64748b;
}

.test-view-detail-grid {
    margin-top: 18px;

    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 16px;
}

.test-view-detail-item {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 16px;
}

.test-view-detail-full {
    grid-column: 1 / -1;
}

.test-view-detail-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #64748b;
}

.test-view-detail-value {
    margin-top: 6px;
    color: #0f172a;
    line-height: 1.5;
}

.test-view-history-list {
    margin-top: 18px;

    display: flex;
    flex-direction: column;
}

.test-view-history-item {
    padding: 18px 0;
    border-bottom: 1px solid #e5e7eb;
}

.test-view-history-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.test-view-history-main {
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
}

.test-view-history-date-block {
    min-width: 150px;
}

.test-view-history-date {
    font-weight: 700;
    color: #0f172a;
}

.test-view-history-time {
    margin-top: 4px;
    font-size: 13px;
    color: #64748b;
}

.test-view-history-value-block {
    flex: 1;
    min-width: 0;
}

.test-view-history-value {
    font-size: 22px;
    font-weight: 700;
    color: #0f172a;
}

.test-view-history-meta {
    margin-top: 6px;
    font-size: 14px;
    color: #64748b;
}

.test-view-history-side {
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
    flex-shrink: 0;
}

.test-view-history-reference {
    font-size: 13px;
    color: #64748b;
    text-align: right;
}

.test-view-history-notes {
    margin-top: 14px;
    padding: 14px;
    border-radius: 12px;
    background: #f8fafc;
    color: #334155;
    line-height: 1.6;
    font-size: 14px;
}

.test-view-empty-state {
    margin-top: 18px;
    color: #64748b;
}

@media (max-width: 900px) {

    .test-view-history-main {
        flex-direction: column;
    }

    .test-view-history-side {
        align-items: flex-start;
    }

    .test-view-history-reference {
        text-align: left;
    }

}

@media (max-width: 700px) {

    .test-view-header {
        flex-direction: column;
        align-items: stretch;
    }

    .test-view-header-main {
        align-items: flex-start;
    }

    .test-view-image {
        width: 82px;
        height: 82px;
        border-radius: 14px;
    }

    .test-view-title {
        font-size: 28px;
    }

    .test-view-snapshot-value {
        font-size: 34px;
    }

}

@media (max-width: 560px) {

    .test-view-snapshot-meta-grid {
        grid-template-columns: 1fr;
    }

    .test-view-detail-grid {
        grid-template-columns: 1fr;
    }

}


/* ---------- FOOD ITEM PROFILE / EDIT PAGE ---------- */

.food-item-profile-header {
    margin-bottom: 20px;
}

.food-item-profile-hero {
    margin-bottom: 1rem;
}

.food-item-profile-main {
    display: flex;
    align-items: center;
    gap: 18px;
}

.food-item-profile-photo {
    width: 86px;
    height: 86px;
    border-radius: 18px;
    object-fit: cover;
    border: 1px solid var(--line);
    background: #fff;
    flex-shrink: 0;
}

.food-item-profile-photo-placeholder {
    background: var(--line-soft);
}

.food-item-profile-title-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.food-item-profile-title-row h2 {
    margin: 0;
}

.food-item-profile-title-row + p {
    margin: 6px 0 0 0;
}

.food-item-profile-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.food-item-profile-stat-card {
    padding: 18px;
}

.food-item-profile-stat-label {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 6px;
}

.food-item-profile-stat-value {
    font-size: 1.45rem;
    font-weight: 700;
    line-height: 1.2;
}

.food-item-profile-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: 1rem;
    margin-bottom: 1rem;
}

.food-item-profile-edit-card h2,
.food-item-profile-activity-card h2,
.food-item-profile-purchases-card h2 {
    margin: 0 0 4px 0;
}

.food-item-profile-edit-card p,
.food-item-profile-activity-card p,
.food-item-profile-purchases-card p {
    margin: 0 0 1rem 0;
}

.food-item-profile-edit-card .form-group {
    margin-bottom: 16px;
}

.food-item-profile-help-text {
    margin: 8px 0 0 0;
    font-size: 0.9rem;
}

.food-item-profile-log-list,
.food-item-profile-purchase-list {
    display: grid;
    gap: 0.75rem;
}

.food-item-profile-log-row,
.food-item-profile-purchase-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--line-soft);
}

.food-item-profile-log-row {
    color: var(--text);
    text-decoration: none;
}

.food-item-profile-log-row:hover strong {
    color: var(--accent);
}

.food-item-profile-log-row:last-child,
.food-item-profile-purchase-row:last-child {
    border-bottom: 0;
}

.food-item-profile-log-calories,
.food-item-profile-purchase-meta {
    font-weight: 700;
    white-space: nowrap;
    text-align: right;
}

.food-item-profile-purchase-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.food-item-profile-empty {
    padding: 20px;
    border: 1px dashed var(--line);
    border-radius: 14px;
    background: #fbfcfe;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

@media (max-width: 980px) {
    .food-item-profile-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .food-item-profile-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .food-item-profile-main {
        align-items: flex-start;
    }

    .food-item-profile-stat-grid {
        grid-template-columns: 1fr;
    }

    .food-item-profile-log-row,
    .food-item-profile-purchase-row {
        flex-direction: column;
    }

    .food-item-profile-log-calories,
    .food-item-profile-purchase-meta {
        text-align: left;
        align-items: flex-start;
    }
}




/* ---------- MEDICATION_VIEW.PHP PAGE ---------- */


.stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(160px, 1fr));
    gap: 16px;
}

@media (max-width: 800px) {
    .stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.med-view {
    display: flex;
    flex-direction: column;
    gap: 24px;
}


.med-view-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    flex-wrap: wrap;
}

.med-view-header-main {
    display: flex;
    align-items: center;
    gap: 20px;
    min-width: 0;
}

.med-view-header-content {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.med-view-eyebrow {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b;
}

.med-view-title {
    margin: 0;
    font-size: 32px;
    line-height: 1.1;
    font-weight: 700;
    color: #0f172a;
}

.med-view-subtitle {
    color: #64748b;
    font-size: 15px;
}

.med-view-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.med-view-image,
.med-view-image-placeholder {
    width: 110px;
    height: 110px;
    border-radius: 20px;
    flex-shrink: 0;
}

.med-view-image {
    object-fit: cover;
    border: 1px solid #dbe3ef;
    background: #ffffff;
}

.med-view-image-placeholder {
    background:
        linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
    border: 1px solid #dbe3ef;
}

.med-view-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
}

.med-view-stat-card {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 18px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.med-view-stat-value {
    font-size: 34px;
    line-height: 1;
    font-weight: 700;
    color: #0f172a;
}

.med-view-stat-label {
    font-size: 14px;
    color: #64748b;
}

.med-view-card {
    padding: 22px;
}

.med-view-section-subtitle {
    margin-top: 4px;
    font-size: 14px;
    color: #64748b;
}

.med-view-30-day-grid {
    display: grid;
    grid-template-columns: repeat(15, 1fr);
    gap: 8px;
    margin-top: 18px;
}

.med-view-day {
    height: 40px;
    border-radius: 12px;
    border: 1px solid #dbe3ef;
    background: #f8fafc;
    color: #94a3b8;

    display: flex;
    align-items: center;
    justify-content: center;

    font-size: 13px;
    font-weight: 700;

    transition:
        background 0.15s ease,
        border-color 0.15s ease,
        color 0.15s ease;
}

.med-view-day-taken {
    background: #e8f5ee;
    border-color: #b7dfc7;
    color: #166534;
}

.med-view-day-today {
    border-width: 2px;
    border-color: #2563eb;
}

.med-view-history-list {
    display: flex;
    flex-direction: column;
    margin-top: 10px;
}

.med-view-history-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;

    padding: 16px 0;

    border-bottom: 1px solid #e5e7eb;
}

.med-view-history-row:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.med-view-history-main {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.med-view-history-icon {
    width: 38px;
    height: 38px;
    border-radius: 999px;

    background: #e8f5ee;
    color: #166534;

    display: flex;
    align-items: center;
    justify-content: center;

    font-weight: 700;
    font-size: 15px;

    flex-shrink: 0;
}

.med-view-history-content {
    min-width: 0;
}

.med-view-history-date {
    font-weight: 600;
    color: #0f172a;
}

.med-view-history-meta {
    margin-top: 3px;
    font-size: 14px;
    color: #64748b;
}

.med-view-history-time {
    font-size: 14px;
    color: #64748b;
    white-space: nowrap;
}


.med-view-empty-state {
    padding: 18px 0;
    color: #64748b;
}


@media (max-width: 900px) {

    .med-view-30-day-grid {
        grid-template-columns: repeat(10, 1fr);
    }

}

@media (max-width: 640px) {

    .med-view-header {
        flex-direction: column;
        align-items: stretch;
    }

    .med-view-header-main {
        align-items: flex-start;
    }

    .med-view-image,
    .med-view-image-placeholder {
        width: 84px;
        height: 84px;
        border-radius: 16px;
    }

    .med-view-title {
        font-size: 26px;
    }

    .med-view-stat-grid {
        grid-template-columns: 1fr 1fr;
    }

    .med-view-30-day-grid {
        grid-template-columns: repeat(6, 1fr);
    }

    .med-view-history-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .med-view-history-time {
        padding-left: 52px;
    }

}


/* ------- Medications Page --------- */

.meds-page {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.meds-page-header,
.meds-card-header-row,
.meds-list-item,
.meds-list-main,
.meds-list-actions,
.meds-form-actions,
.meds-current-image-row {
    display: flex;
    align-items: center;
}

.meds-page-header,
.meds-card-header-row,
.meds-list-item {
    justify-content: space-between;
    gap: 20px;
}

.meds-page-header {
    flex-wrap: wrap;
}

.meds-page-eyebrow {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b;
}

.meds-page-title {
    margin: 0;
    font-size: 32px;
    line-height: 1.1;
    color: #0f172a;
}

.meds-page-subtitle,
.meds-section-subtitle,
.meds-list-meta,
.meds-current-image-text {
    color: #64748b;
    font-size: 14px;
}

.meds-page-subtitle {
    margin-top: 6px;
    font-size: 15px;
}

.meds-page-layout {
    display: grid;
    grid-template-columns: minmax(280px, 420px) 1fr;
    gap: 20px;
    align-items: start;
}

.meds-form-card,
.meds-list-card {
    padding: 22px;
}

.meds-card-header h2 {
    margin: 0;
}

.meds-form {
    margin-top: 18px;
}

.meds-alert {
    margin-top: 16px;
}

.meds-current-image-row {
    gap: 10px;
    margin: 14px 0;
}

.meds-current-image {
    width: 44px;
    height: 44px;
    object-fit: cover;
    border-radius: 10px;
    border: 1px solid #dbe3ef;
}

.meds-form-actions {
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 18px;
}

.meds-count-pill {
    padding: 6px 10px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #475569;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
}

.meds-empty-state {
    margin-top: 18px;
    color: #64748b;
}

.meds-list {
    margin-top: 18px;
    display: flex;
    flex-direction: column;
}

.meds-list-item {
    padding: 16px 0;
    border-bottom: 1px solid #e5e7eb;
}

.meds-list-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.meds-list-main {
    gap: 14px;
    min-width: 0;
    color: inherit;
    text-decoration: none;
}

.meds-list-main:hover .meds-list-name {
    text-decoration: underline;
}

.meds-list-image,
.meds-list-image-placeholder {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    flex-shrink: 0;
}

.meds-list-image {
    object-fit: cover;
    border: 1px solid #dbe3ef;
    background: #ffffff;
}

.meds-list-image-placeholder {
    border: 1px solid #dbe3ef;
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
}

.meds-list-content {
    min-width: 0;
}

.meds-list-name {
    font-weight: 700;
    color: #0f172a;
}

.meds-list-actions {
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.meds-remove-link {
    color: #b91c1c;
    font-size: 14px;
    text-decoration: none;
    font-weight: 600;
}

.meds-remove-link:hover {
    text-decoration: underline;
}

.button-small {
    padding: 7px 10px;
    font-size: 13px;
}

@media (max-width: 900px) {

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

}

@media (max-width: 700px) {

    .meds-list-item {
        align-items: flex-start;
        flex-direction: column;
    }

    .meds-list-actions {
        justify-content: flex-start;
        width: 100%;
    }

}

@media (max-width: 560px) {

    .meds-page-header,
    .meds-card-header-row {
        align-items: flex-start;
        flex-direction: column;
    }

}


/* -------------------------------------------------
   Health Test Edit
------------------------------------------------- */

.health-test-icon-panel {
    display: flex;
    gap: 20px;
    align-items: flex-start;
    padding: 18px;
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 16px;
    background: var(--surface-subtle, #fcfcfd);
}

.health-test-edit-icon {
    width: 88px;
    height: 88px;
    object-fit: cover;
    border-radius: 18px;
    flex-shrink: 0;
    display: block;
    background: #fff;
    border: 1px solid var(--border-color, #e5e7eb);
}

.health-test-icon-controls {
    flex: 1;
    min-width: 0;
    display: grid;
    gap: 14px;
}

.health-test-toggle {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 500;
    cursor: pointer;
}

.health-test-toggle input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;
}

@media (max-width: 640px) {
    .health-test-icon-panel {
        flex-direction: column;
        align-items: flex-start;
    }

    .health-test-edit-icon {
        width: 72px;
        height: 72px;
        border-radius: 16px;
    }
}


/* -------------------------------------------------
   Health Result Edit
------------------------------------------------- */

.health-edit-shell {
    display: grid;
    gap: 18px;
}

.health-edit-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 18px;
    padding: 20px;
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15, 23, 42, 0.08));
}

.health-edit-card-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
}

.health-edit-card-header h2 {
    margin: 0;
    font-size: 1rem;
}

.health-edit-card-header p {
    margin: 4px 0 0;
    color: var(--muted-text, #64748b);
    font-size: 0.9rem;
}

.health-edit-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.health-edit-span-2 {
    grid-column: 1 / -1;
}

.health-edit-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    padding-top: 4px;
}

@media (max-width: 720px) {
    .health-edit-card {
        padding: 16px;
        border-radius: 14px;
    }

    .health-edit-grid {
        grid-template-columns: 1fr;
    }

    .health-edit-span-2 {
        grid-column: auto;
    }

    .health-edit-actions {
        flex-direction: column;
    }

    .health-edit-actions .button {
        width: 100%;
        justify-content: center;
    }
}


/* -------------------------------------------------
   Health Results List
------------------------------------------------- */

.health-results-overview {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.health-results-summary-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 18px;
    padding: 18px;
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15, 23, 42, 0.08));
}

.health-results-summary-label {
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--muted-text, #64748b);
    margin-bottom: 10px;
}

.health-results-summary-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 8px;
}

.health-results-summary-note {
    color: var(--muted-text, #64748b);
    font-size: 0.92rem;
}

.health-results-filter-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 18px;
    padding: 18px;
    margin-bottom: 20px;
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15, 23, 42, 0.08));
}

.health-results-filter-form {
    display: grid;
    grid-template-columns: 2fr 1fr auto;
    gap: 16px;
    align-items: end;
}

.health-results-filter-search {
    min-width: 0;
}

.health-results-filter-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}

.health-results-list-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 18px;
    padding: 20px;
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15, 23, 42, 0.08));
}

.health-results-list-header {
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
}

.health-results-list-header h2 {
    margin: 0 0 4px;
    font-size: 1.05rem;
}

.health-results-list-header p {
    margin: 0;
    color: var(--muted-text, #64748b);
    font-size: 0.92rem;
}

.health-results-list {
    display: grid;
    gap: 14px;
}

.health-result-row {
    display: grid;
    grid-template-columns: minmax(260px, 1.5fr) minmax(320px, 1fr) auto;
    gap: 18px;
    align-items: center;
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 16px;
    padding: 16px;
    background: var(--surface-subtle, #fcfcfd);
}

.health-result-row-main {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}

.health-result-row-image {
    width: 58px;
    height: 58px;
    border-radius: 14px;
    object-fit: cover;
    flex-shrink: 0;
    display: block;
}

.health-result-row-title-block {
    min-width: 0;
}

.health-result-row-kicker {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--muted-text, #64748b);
    margin-bottom: 4px;
    font-weight: 600;
}

.health-result-row-title-block h3 {
    margin: 0 0 4px;
    font-size: 1rem;
    line-height: 1.2;
}

.health-result-row-title-block h3 a {
    text-decoration: none;
    color: inherit;
}

.health-result-row-title-block p {
    margin: 0;
    color: var(--muted-text, #64748b);
    font-size: 0.9rem;
}

.health-result-row-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.health-result-metric {
    min-width: 0;
}

.health-result-metric span {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--muted-text, #64748b);
    margin-bottom: 5px;
    font-weight: 600;
}

.health-result-metric strong {
    font-size: 0.95rem;
    line-height: 1.3;
}

.health-result-row-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

@media (max-width: 1100px) {
    .health-result-row {
        grid-template-columns: 1fr;
    }

    .health-result-row-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 800px) {
    .health-results-overview {
        grid-template-columns: 1fr;
    }

    .health-results-filter-form {
        grid-template-columns: 1fr;
    }

    .health-results-filter-actions {
        width: 100%;
    }

    .health-results-filter-actions .button {
        flex: 1;
        justify-content: center;
    }

    .health-result-row-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .health-result-row {
        padding: 14px;
    }

    .health-result-row-main {
        align-items: flex-start;
    }

    .health-result-row-image {
        width: 50px;
        height: 50px;
        border-radius: 12px;
    }

    .health-result-row-metrics {
        grid-template-columns: 1fr;
    }

    .health-result-row-actions {
        flex-direction: column;
    }

    .health-result-row-actions .button {
        width: 100%;
        justify-content: center;
    }
}







/* -------------------------------------------------
   Dashboard
------------------------------------------------- */

.dashboard-hero,
.dashboard-section-card,
.dashboard-insight-card,
.dashboard-stat-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 18px;
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15, 23, 42, 0.08));
}

.dashboard-hero {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: center;
    padding: 22px;
    margin-bottom: 20px;
}

.dashboard-hero-label {
    margin: 0 0 6px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted-text, #64748b);
}

.dashboard-hero h2 {
    margin: 0 0 6px;
}

.dashboard-hero p {
    margin: 0;
    color: var(--muted-text, #64748b);
}

.dashboard-hero-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.dashboard-stat-grid {
    display: grid;

    grid-template-columns:
        repeat(5, minmax(0, 1fr));

    gap: 16px;

    margin-top: 20px;
}

.dashboard-stat-card {
    padding: 18px;
}

.dashboard-stat-card span {
    display: block;
    margin-bottom: 10px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--muted-text, #64748b);
}

.dashboard-stat-card strong {
    display: block;
    font-size: 1.65rem;
    line-height: 1.1;
}

.dashboard-stat-card small {
    display: block;
    margin-top: 8px;
    color: var(--muted-text, #64748b);
}

.dashboard-insight-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.dashboard-insight-card,
.dashboard-section-card {
    padding: 20px;
    margin-bottom: 20px;
}

.dashboard-card-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
}

.dashboard-card-header h2 {
    margin: 0 0 4px;
    font-size: 1.05rem;
}

.dashboard-card-header p {
    margin: 0;
    color: var(--muted-text, #64748b);
    font-size: 0.92rem;
}

.dashboard-insight-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 16px;
}

.dashboard-mini-list {
    display: grid;
    gap: 10px;
    margin: 0;
}

.dashboard-mini-list div {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
}

.dashboard-mini-list div:last-child {
    border-bottom: 0;
}

.dashboard-mini-list dt {
    color: var(--muted-text, #64748b);
    font-size: 0.9rem;
}

.dashboard-mini-list dd {
    margin: 0;
    font-weight: 700;
    text-align: right;
}

.dashboard-med-list,
.dashboard-log-list {
    display: grid;
    gap: 12px;
}

.dashboard-med-row,
.dashboard-log-row,
.dashboard-log-edit-row {
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 16px;
    background: var(--surface-subtle, #fcfcfd);
}

.dashboard-med-row {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
    padding: 14px;
}

.dashboard-med-main {
    display: flex;
    align-items: center;
    gap: 12px;
}

.dashboard-med-img,
.dashboard-med-placeholder {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    flex-shrink: 0;
}

.dashboard-med-img {
    object-fit: cover;
    display: block;
}

.dashboard-med-placeholder {
    background: var(--border-color, #e5e7eb);
}

.dashboard-log-row {
    display: grid;
    grid-template-columns: 90px 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 14px;
}

.dashboard-log-date span,
.dashboard-log-date small {
    display: block;
}

.dashboard-log-date span {
    font-weight: 700;
}

.dashboard-log-date small {
    margin-top: 3px;
    color: var(--muted-text, #64748b);
}

.dashboard-log-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.dashboard-log-metrics span {
    display: block;
    margin-bottom: 5px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--muted-text, #64748b);
}

.dashboard-log-metrics strong {
    font-size: 0.95rem;
}

.dashboard-log-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.dashboard-log-edit-row {
    padding: 14px;
}

.dashboard-inline-edit-form {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
    gap: 14px;
    align-items: end;
}

.dashboard-inline-edit-actions {
    display: flex;
    gap: 8px;
}

@media (max-width: 1000px) {
    .dashboard-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

    .dashboard-log-row {
        grid-template-columns: 1fr;
    }

    .dashboard-log-actions {
        justify-content: flex-start;
    }

    .dashboard-inline-edit-form {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .dashboard-hero {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .dashboard-hero-top {
    margin-bottom: 18px;
}

.dashboard-hero-date {
    margin-bottom: 2px;
}

.dashboard-hero h1 {
    font-size: 1.8rem;
    margin: 0;
}

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

    .dashboard-card-header,
    .dashboard-med-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .dashboard-log-metrics {
        grid-template-columns: 1fr;
    }

    .dashboard-hero-actions,
    .dashboard-inline-edit-actions,
    .dashboard-log-actions {
        width: 100%;
        flex-direction: column;
    }

    .dashboard-hero-actions .button,
    .dashboard-inline-edit-actions .button,
    .dashboard-log-actions .button {
        width: 100%;
        justify-content: center;
    }
}


/* -------------------------------------------------
   Daily Logs
------------------------------------------------- */

.daily-logs-overview {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 20px;
}

.daily-logs-summary-card,
.daily-logs-filter-card,
.daily-logs-list-card,
.daily-log-row,
.daily-log-edit-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15, 23, 42, 0.08));
}

.daily-logs-summary-card {
    border-radius: 18px;
    padding: 18px;
}

.daily-logs-summary-label {
    margin-bottom: 10px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--muted-text, #64748b);
}

.daily-logs-summary-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 8px;
}

.daily-logs-summary-date {
    font-size: 1.4rem;
}

.daily-logs-summary-note {
    color: var(--muted-text, #64748b);
    font-size: 0.92rem;
}

.daily-logs-filter-card {
    border-radius: 18px;
    padding: 18px;
    margin-bottom: 20px;
}

.daily-logs-filter-form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 16px;
    align-items: end;
}

.daily-logs-filter-search {
    min-width: 0;
}

.daily-logs-filter-actions {
    display: flex;
    gap: 10px;
}

.daily-logs-list-card {
    border-radius: 20px;
    padding: 20px;
}

.daily-logs-list {
    display: grid;
    gap: 14px;
}

.daily-logs-list-header {
    margin-bottom: 16px;
}

.daily-logs-list-header h2 {
    margin: 0 0 4px;
}

.daily-logs-list-header p {
    margin: 0;
    color: var(--muted-text, #64748b);
}

.daily-logs-group-heading,
.daily-log-group-heading {
    margin-top: 10px;
    margin-bottom: 2px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--muted-text, #64748b);
}

.daily-log-row {
    border-radius: 18px;
    padding: 14px 16px;
    background: var(--surface-subtle, #fcfcfd);
}

.daily-log-row.daily-log-display-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
    align-items: flex-start;
}

.daily-log-row-main {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
}

.daily-log-row-title-block {
    display: grid;
    gap: 6px;
}

.daily-log-row-kicker {
    color: var(--muted-text, #64748b);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    line-height: 1.2;
    text-transform: uppercase;
}

.daily-log-row-date {
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.25;
}

.daily-log-row-context {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.daily-log-row-metrics {
    display: flex;
    align-items: center;
    gap: 8px 16px;
    flex-wrap: wrap;
}

.daily-log-row-metrics .daily-log-metric {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
    min-height: 0;
    padding: 0;
    background: transparent;
    border-radius: 0;
}

.daily-log-row-metrics .daily-log-metric span {
    display: inline;
    margin: 0;
    color: var(--muted-text, #64748b);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    line-height: 1.2;
    text-transform: uppercase;
}

.daily-log-row-metrics .daily-log-metric strong {
    font-size: 0.95rem;
    line-height: 1.25;
}

.daily-log-row-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.daily-log-row-actions .button-small {
    min-height: 34px;
    padding: 0 11px;
    font-size: 0.84rem;
}

.daily-log-edit-card {
    border-radius: 18px;
    padding: 16px;
    background: var(--surface-subtle, #fcfcfd);
}

.daily-log-inline-edit-form {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
    gap: 14px;
    align-items: end;
}

.daily-log-inline-edit-actions {
    display: flex;
    gap: 8px;
}

@media (max-width: 1000px) {

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

    .daily-log-row.daily-log-display-row {
        grid-template-columns: 1fr;
    }

    .daily-log-row-actions {
        justify-content: flex-start;
    }

    .daily-log-inline-edit-form {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {

    .daily-logs-overview {
        grid-template-columns: 1fr;
    }

    .daily-logs-filter-form {
        grid-template-columns: 1fr;
    }

    .daily-logs-filter-actions {
        width: 100%;
    }

    .daily-logs-filter-actions .button {
        flex: 1;
        justify-content: center;
    }

    .daily-log-row-actions,
    .daily-log-inline-edit-actions {
        width: 100%;
        flex-direction: column;
    }

    .daily-log-row-actions .button,
    .daily-log-inline-edit-actions .button {
        width: 100%;
        justify-content: center;
    }
}





/* ==================================================
   Shared Health Page Stats
   ================================================== */

.health-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin: 24px 0;
}

.health-stat-card {
    padding: 18px;
    border: 1px solid #dbe3ee;
    border-radius: 16px;
    background: #ffffff;
    box-shadow:
        0 1px 2px rgba(0,0,0,0.04),
        0 8px 24px rgba(15,23,42,0.04);
}

.stat-label {
    margin-bottom: 8px;
    font-size: 0.78rem;
    font-weight: 800;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.stat-value {
    font-size: 2rem;
    font-weight: 800;
    line-height: 1.1;
    color: var(--text);
}

.stat-value-sm {
    font-size: 1.15rem;
}

.stat-note {
    margin-top: 8px;
    font-size: 0.88rem;
    color: var(--muted);
}

@media (max-width: 900px) {
    .health-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .health-stat-grid {
        grid-template-columns: 1fr;
    }
}

/* ==================================================
   Archived Logs
================================================== */

.archive-log-list {
    display: grid;
    gap: 14px;
}

.archive-month-divider {
    margin: 24px 0 4px;
    font-size: 0.82rem;
    font-weight: 900;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.archive-log-card {
    padding: 18px 20px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--card);
    box-shadow: none;
}

.archive-log-main {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) auto;
    align-items: start;
    gap: 20px;
}

.archive-log-date {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--text);
}

.archive-log-meta {
    margin-top: 5px;
    font-size: 0.85rem;
    color: var(--muted);
}

.archive-log-metrics {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.metric-pill {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 6px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #f8fafc;
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--text);
}

.archive-log-notes {
    margin-top: 14px;
    padding: 12px;
    border-radius: var(--radius-sm);
    background: #f8fafc;
    color: var(--text);
    line-height: 1.45;
}

.archive-log-actions {
    margin-top: 16px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.archive-inline-form {
    margin: 0;
}

.archive-edit-header {
    margin-bottom: 14px;
}

.archive-edit-header h3 {
    margin: 0 0 4px;
    font-size: 1rem;
}

.archive-edit-header p {
    margin: 0;
    color: var(--muted);
    font-size: 0.9rem;
}

@media (max-width: 700px) {
    .archive-log-main {
        grid-template-columns: 1fr;
    }

    .archive-log-metrics,
    .archive-log-actions {
        justify-content: flex-start;
    }
}




/* -------------------------------------------------
   Inventory Add Page
------------------------------------------------- */

.inventory-add-page {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.inventory-add-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}

.inventory-add-header h1 {
    margin: 4px 0 6px;
    font-size: 2rem;
    line-height: 1.1;
}

.inventory-add-header p {
    margin: 0;
    max-width: 720px;
}

.inventory-add-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.inventory-add-card {
    padding: 22px;
}

.inventory-add-tabs-wrap {
    margin-bottom: 22px;
}

.inventory-add-panel-grid {
    display: grid;
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}

.inventory-add-guidance {
    padding: 20px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: #f8fafc;
}

.inventory-add-guidance h2 {
    margin: 0 0 10px;
    font-size: 1.05rem;
}

.inventory-add-guidance p {
    margin: 0 0 18px;
    line-height: 1.6;
}

.inventory-add-helper-list {
    display: grid;
    gap: 14px;
}

.inventory-add-helper-list div {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.inventory-add-helper-list strong {
    font-size: 0.95rem;
    color: var(--text);
}

.inventory-add-helper-list span {
    font-size: 0.9rem;
    color: var(--muted);
    line-height: 1.45;
}

.inventory-add-form-area {
    min-width: 0;
}

.inventory-add-form-header {
    margin-bottom: 18px;
}

.inventory-add-form-header h2 {
    margin: 0 0 6px;
    font-size: 1.2rem;
}

.inventory-add-form-header p {
    margin: 0;
}

.inventory-add-form {
    max-width: 560px;
}

@media (max-width: 900px) {

    .inventory-add-panel-grid {
        grid-template-columns: 1fr;
    }

}

@media (max-width: 640px) {

    .inventory-add-header {
        flex-direction: column;
        align-items: stretch;
    }

    .inventory-add-actions {
        width: 100%;
    }

    .inventory-add-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .inventory-add-card {
        padding: 18px;
    }

}


/* -------------------------------------------------
   Daily Log Add Page
------------------------------------------------- */

.daily-log-add-page {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.daily-log-add-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}

.daily-log-add-header h1 {
    margin: 4px 0 6px;
    font-size: 2rem;
    line-height: 1.1;
}

.daily-log-add-header p {
    margin: 0;
    max-width: 720px;
}

.daily-log-add-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.daily-log-add-card {
    padding: 22px;
}

.daily-log-add-grid {
    display: grid;
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}

.daily-log-add-guidance {
    padding: 20px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: #f8fafc;
}

.daily-log-add-guidance h2 {
    margin: 0 0 10px;
    font-size: 1.05rem;
}

.daily-log-add-guidance p {
    margin: 0 0 18px;
    line-height: 1.6;
}

.daily-log-add-helper-list {
    display: grid;
    gap: 14px;
}

.daily-log-add-helper-list div {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.daily-log-add-helper-list strong {
    font-size: 0.95rem;
    color: var(--text);
}

.daily-log-add-helper-list span {
    font-size: 0.9rem;
    color: var(--muted);
    line-height: 1.45;
}

.daily-log-add-form-area {
    min-width: 0;
}

.daily-log-add-form-header {
    margin-bottom: 18px;
}

.daily-log-add-form-header h2 {
    margin: 0 0 6px;
    font-size: 1.2rem;
}

.daily-log-add-form-header p {
    margin: 0;
}

.daily-log-add-form {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.daily-log-add-field-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    align-items: start;
}

.daily-log-add-calories-note {
    padding: 16px;
    border: 1px dashed var(--line);
    border-radius: 14px;
    background: #fbfcfe;
}

.daily-log-add-calories-label {
    margin-bottom: 6px;
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--muted);
}

.daily-log-add-notes-row textarea {
    min-height: 180px;
}

@media (max-width: 900px) {

    .daily-log-add-grid {
        grid-template-columns: 1fr;
    }

}

@media (max-width: 700px) {

    .daily-log-add-field-grid {
        grid-template-columns: 1fr;
    }

}

@media (max-width: 640px) {

    .daily-log-add-header {
        flex-direction: column;
        align-items: stretch;
    }

    .daily-log-add-actions {
        width: 100%;
    }

    .daily-log-add-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .daily-log-add-card {
        padding: 18px;
    }

}

/* -------------------------------------------------
   Inventory Categories Page
------------------------------------------------- */

.inventory-categories-page {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.inventory-categories-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}

.inventory-categories-header h1 {
    margin: 4px 0 6px;
    font-size: 2rem;
    line-height: 1.1;
}

.inventory-categories-header p {
    margin: 0;
    max-width: 720px;
}

.inventory-categories-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.inventory-categories-layout {
    display: grid;
    grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.inventory-categories-sidebar,
.inventory-categories-main {
    min-width: 0;
}

.inventory-categories-add-card,
.inventory-categories-list-card {
    padding: 22px;
}

.inventory-categories-card-header {
    margin-bottom: 18px;
}

.inventory-categories-card-header h2 {
    margin: 0 0 6px;
    font-size: 1.15rem;
}

.inventory-categories-card-header p {
    margin: 0;
}

.inventory-categories-form {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.inventory-categories-list {
    display: grid;
    gap: 14px;
}

.inventory-category-row {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    gap: 14px;
    min-width: 0;

    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #fbfcfe;
}

.inventory-category-edit-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-width: 0;
    max-width: 100%;
}

.inventory-category-main {
    display: grid;
    grid-template-columns:
        minmax(0, 1fr)
        minmax(120px, 160px)
        minmax(110px, 140px);
    gap: 16px;
    align-items: end;
    min-width: 0;
    max-width: 100%;
}

.inventory-category-name-area,
.inventory-category-type-area,
.inventory-category-count-area {
    min-width: 0;
}

.inventory-category-count {
    display: flex;
    align-items: center;

    min-height: 44px;
    padding: 0 14px;

    border: 1px solid var(--line);
    border-radius: 12px;

    background: #fff;

    font-weight: 700;
}

.inventory-category-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
    min-width: 0;
    max-width: 100%;
}

.inventory-category-delete-form {
    display: flex;
    justify-content: flex-end;
    margin: 0;
    max-width: 100%;
}

.inventory-categories-empty {
    padding: 24px;
    border: 1px dashed var(--line);
    border-radius: 16px;
    background: #fbfcfe;

    display: flex;
    flex-direction: column;
    gap: 6px;
}

.inventory-categories-empty strong {
    font-size: 1rem;
}

.inventory-categories-empty span {
    color: var(--muted);
}

@media (max-width: 1100px) {

    .inventory-category-main {
        grid-template-columns: 1fr;
    }

    .inventory-category-actions,
    .inventory-category-delete-form {
        justify-content: flex-start;
    }

}

@media (max-width: 980px) {

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

}

@media (max-width: 760px) {

    .inventory-category-main {
        grid-template-columns: 1fr;
    }

    .inventory-category-actions {
        justify-content: flex-start;
    }

}

@media (max-width: 640px) {

    .inventory-categories-header {
        flex-direction: column;
        align-items: stretch;
    }

    .inventory-categories-actions {
        width: 100%;
    }

    .inventory-categories-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .inventory-categories-add-card,
    .inventory-categories-list-card {
        padding: 18px;
    }

    .inventory-category-actions {
        flex-direction: column;
        width: 100%;
    }

    .inventory-category-delete-form {
        width: 100%;
    }

    .inventory-category-actions .btn,
    .inventory-category-delete-form .btn {
        width: 100%;
        justify-content: center;
    }

}


/* -------------------------------------------------
   Profile Page
------------------------------------------------- */

.profile-page {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.profile-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}

.profile-header h1 {
    margin: 4px 0 6px;
    font-size: 2rem;
    line-height: 1.1;
}

.profile-header p {
    margin: 0;
    max-width: 720px;
}

.profile-header-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.profile-layout {
    display: grid;
    grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.profile-sidebar,
.profile-main {
    min-width: 0;
}

.profile-summary-card,
.profile-info-card,
.profile-main-card,
.profile-results-card {
    padding: 22px;
}

.profile-sidebar {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.profile-card-header,
.profile-main-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}

.profile-card-header h2,
.profile-main-header h2 {
    margin: 0 0 4px;
    font-size: 1.15rem;
}

.profile-main-header p,
.profile-card-header p {
    margin: 0;
}

.profile-summary-list {
    display: grid;
    gap: 14px;
}

.profile-summary-item {
    display: flex;
    flex-direction: column;
    gap: 4px;

    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 14px;

    background: #fbfcfe;
}

.profile-summary-label {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--muted);
}

.profile-formula-list {
    display: grid;
    gap: 16px;
    margin-top: 18px;
}

.profile-formula-list div {
    display: flex;
    flex-direction: column;
    gap: 6px;

    padding: 14px;
    border-radius: 14px;

    background: #f8fafc;
    border: 1px solid var(--line);
}

.profile-formula-list strong {
    font-size: 0.92rem;
}

.profile-formula-list span {
    font-size: 0.9rem;
    color: var(--muted);
    line-height: 1.5;
}

.profile-display-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}

.profile-display-item {
    display: flex;
    flex-direction: column;
    gap: 6px;

    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 16px;

    background: #fbfcfe;
}

.profile-display-item span {
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--muted);
}

.profile-display-item strong {
    font-size: 1rem;
}

.profile-form {
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.profile-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 18px;
}

.profile-results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
}

.profile-result-stat {
    display: flex;
    flex-direction: column;
    gap: 6px;

    padding: 22px 18px;

    border: 1px solid var(--line);
    border-radius: 18px;

    background: linear-gradient(
        to bottom,
        #ffffff,
        #f8fafc
    );
}

.profile-result-stat span {
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--muted);
}

.profile-result-stat strong {
    font-size: 2rem;
    line-height: 1;
}

.profile-result-stat small {
    color: var(--muted);
    font-size: 0.85rem;
}

.alert-success {
    border-left: 4px solid #16a34a;
}

@media (max-width: 980px) {

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

}

@media (max-width: 640px) {

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

    .profile-header-actions {
        width: 100%;
    }

    .profile-header-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .profile-summary-card,
    .profile-info-card,
    .profile-main-card,
    .profile-results-card {
        padding: 18px;
    }

    .profile-result-stat strong {
        font-size: 1.7rem;
    }

}

/* -------------------------------------------------
   Merge Page
------------------------------------------------- */

.merge-page {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.merge-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}

.merge-header h1 {
    margin: 4px 0 6px;
    font-size: 2rem;
    line-height: 1.1;
}

.merge-header p {
    margin: 0;
    max-width: 720px;
}

.merge-header-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.merge-layout {
    display: grid;
    grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.merge-warning-card,
.merge-main-card {
    padding: 22px;
}

.merge-warning-card {
    position: relative;
    overflow: hidden;
}

.merge-warning-label {
    display: inline-flex;
    align-items: center;

    margin-bottom: 14px;
    padding: 6px 10px;

    border-radius: 999px;

    background: #fef2f2;
    color: #991b1b;

    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.merge-warning-card h2,
.merge-card-header h2 {
    margin: 0 0 8px;
    font-size: 1.2rem;
}

.merge-card-header {
    margin-bottom: 18px;
}

.merge-card-header p {
    margin: 0;
}

.merge-warning-card p {
    margin-top: 0;
    line-height: 1.6;
}

.merge-source-box {
    display: flex;
    flex-direction: column;
    gap: 6px;

    margin: 20px 0;
    padding: 18px;

    border: 1px solid #fecaca;
    border-radius: 16px;

    background: #fff5f5;
}

.merge-source-box span {
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #991b1b;
}

.merge-source-box strong {
    font-size: 1.1rem;
    line-height: 1.3;
}

.merge-impact-list {
    display: grid;
    gap: 14px;
}

.merge-impact-list div {
    display: flex;
    flex-direction: column;
    gap: 4px;

    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 14px;

    background: #fbfcfe;
}

.merge-impact-list strong {
    font-size: 1.1rem;
}

.merge-impact-list span {
    color: var(--muted);
    font-size: 0.88rem;
}

.merge-form {
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.merge-explanation-box {
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 16px;

    background: #f8fafc;
}

.merge-explanation-box strong {
    display: block;
    margin-bottom: 8px;
}

.merge-explanation-box p {
    margin: 0;
    line-height: 1.6;
    color: var(--muted);
}

.merge-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

@media (max-width: 980px) {

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

}

@media (max-width: 640px) {

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

    .merge-header-actions {
        width: 100%;
    }

    .merge-header-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .merge-warning-card,
    .merge-main-card {
        padding: 18px;
    }

    .merge-actions {
        flex-direction: column;
    }

    .merge-actions .btn {
        width: 100%;
        justify-content: center;
    }

}


/* =====================================================
   STORE VISIT ITEM ADD
===================================================== */

.sv-add-item-page {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.sv-add-item-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;

    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-color);
}

.sv-add-item-eyebrow {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 0.45rem;
}

.sv-add-item-title {
    margin: 0 0 0.5rem;
    font-size: 2rem;
    line-height: 1.1;
}

.sv-add-item-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;

    color: var(--text-muted);
    font-size: 0.95rem;
}

.sv-add-item-alert ul {
    margin-top: 0.75rem;
    margin-bottom: 0;
    padding-left: 1.25rem;
}

.sv-add-item-form {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.sv-add-item-card .health-card-body {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.sv-add-item-workspace-card .health-card-body {
    gap: 1.1rem;
}

.sv-add-item-workspace-form {
    gap: 1rem;
}

.sv-add-item-helper {
    margin: 0.35rem 0 0;
}

.sv-add-item-type-control {
    max-width: 260px;
}

.sv-add-item-workspace-section {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    padding-top: 1rem;
    border-top: 1px solid #edf2f7;
}

.sv-add-item-section-header h3 {
    margin: 0 0 0.25rem;
    font-size: 1rem;
}

.sv-add-item-section-header p {
    margin: 0;
}

.sv-add-item-checklist {
    display: flex;
    flex-direction: column;
    max-height: 360px;
    overflow-y: auto;
    overflow-x: hidden;
    border: 1px solid #dbe3ef;
    border-radius: 14px;
    background: #fff;
}

.sv-add-item-checklist .sv-add-item-check {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 0.6rem;
    min-width: 0;
    min-height: 0;
    height: auto;
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid #edf2f7;
    font-size: 0.92rem;
    font-weight: 400;
    line-height: 1.3;
    cursor: pointer;
}

.sv-add-item-checklist .sv-add-item-check[hidden] {
    display: none;
}

.sv-add-item-checklist .sv-add-item-check:last-child {
    border-bottom: 0;
}

.sv-add-item-checklist .sv-add-item-check input[type="checkbox"] {
    display: inline-block;
    width: auto;
    height: auto;
    margin: 0;
    flex: 0 0 auto;
}

.sv-add-item-checklist .sv-add-item-check-text {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    justify-content: flex-start;
    gap: 0.45rem;
    width: auto;
    min-width: 0;
    max-width: 100%;
    line-height: 1.3;
    overflow: visible;
}

.sv-add-item-checklist .sv-add-item-check-name {
    display: inline;
    font-size: 0.92rem;
    font-weight: 650;
    line-height: 1.25;
    color: var(--text);
    overflow-wrap: anywhere;
}

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

.sv-add-item-final-actions {
    padding-top: 1rem;
    border-top: 1px solid #edf2f7;
}

@media (max-width: 700px) {

    .sv-add-item-header {
        flex-direction: column;
    }

}

.sv-add-item-card {
    padding: 1.5rem;
    background: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

.sv-add-item-card .health-card-header {
    margin-bottom: 1.25rem;
}

.sv-add-item-card .health-card-header h2 {
    margin: 0;
}

.sv-add-item-card .health-card-body {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.sv-add-item-card {
    padding: 1.5rem;
    background: #ffffff;
    border: 1px solid #dbe3ef;
    border-radius: 18px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

@media (max-width: 700px) {
    .sv-add-item-checklist .sv-add-item-check-text {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.1rem;
    }
}



/* =====================================================
   SPENDING DASHBOARD TABS
===================================================== */

#spending-breakdown {
    scroll-margin-top: 1rem;
}





/* =====================================================
RECURRING EXPENSES
===================================================== */

.form-grid {
    display: grid;
    grid-template-columns: 1fr 220px;
    gap: 1rem;
    margin-bottom: 1rem;
}

.recurring-expenses-filter-form .form-grid {
    grid-template-columns: minmax(260px, 420px) minmax(150px, 180px);
    justify-content: start;
    align-items: end;
    gap: 12px;
}

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

@media (max-width: 700px) {
    .form-grid {
        grid-template-columns: 1fr;
    }

    .recurring-expenses-filter-form .form-grid {
        grid-template-columns: 1fr;
    }

    .form-actions {
        flex-direction: column;
    }

    .form-actions .button,
    .form-actions .btn {
        width: 100%;
    }
}

.btn-primary {
    background: #2563eb;
    color: #fff;
}

.btn-secondary {
    background: #e5e7eb;
    color: #111;
}

.table-responsive > .compact-table td,
.table-responsive > .compact-table th {
    padding: 0.5rem 0.75rem;
}

.table-responsive {
    width: 100%;
    overflow-x: auto;
}

.table-responsive > .compact-table {
    width: 100%;
    min-width: 900px;
    border-collapse: collapse;
}

.table-responsive > .compact-table td,
.table-responsive > .compact-table th {
    white-space: nowrap;
}

.actions-column a {
    display: block;
}



/* ======= */

/* --------------------------------------------------
   Daily Log History
-------------------------------------------------- */

.daily-log-history-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.daily-log-group-heading {
    margin-top: 10px;
    margin-bottom: -4px;

    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;

    color: var(--text-muted, #6b7280);
}

.daily-log-card {
    background: #fff;

    border: 1px solid #e5e7eb;
    border-radius: 16px;

    padding: 18px 20px;

    transition:
        border-color 0.15s ease,
        box-shadow 0.15s ease,
        transform 0.15s ease;
}

.daily-log-card:hover {
    border-color: #d1d5db;

    box-shadow:
        0 4px 12px rgba(0,0,0,0.04);
}

.daily-log-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;

    margin-bottom: 18px;
}

.daily-log-date {
    font-size: 1rem;
    font-weight: 700;
    color: #111827;
}

.daily-log-subtitle {
    margin-top: 4px;

    font-size: 0.88rem;
    color: #6b7280;
}

.daily-log-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.daily-log-metric {
    background: #f9fafb;

    border-radius: 12px;

    padding: 14px 16px;
}

.daily-log-metric-label {
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;

    color: #6b7280;

    margin-bottom: 6px;
}

.daily-log-metric-value {
    font-size: 1.15rem;
    font-weight: 700;

    color: #111827;
}

.daily-log-edit-card {
    margin-top: 12px;
}

@media (max-width: 760px) {

    .daily-log-card-header {
        flex-direction: column;
        align-items: stretch;
    }

    .daily-log-metrics {
        grid-template-columns: 1fr;
    }

}


.daily-log-card-actions {
    display: flex;
    align-items: center;
    gap: 10px;

    flex-wrap: wrap;
}



/* Daily Log Action Buttons */

.daily-log-card-actions .btn-small,
.daily-log-card-actions .btn-secondary,
.daily-log-card-actions .btn {
    appearance: none;
    border: none;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    min-height: 38px;

    padding: 0 14px;

    border-radius: 10px;

    font-size: 0.88rem;
    font-weight: 600;
    text-decoration: none;

    cursor: pointer;

    transition:
        background 0.15s ease,
        border-color 0.15s ease,
        color 0.15s ease,
        transform 0.15s ease;
}

/* View */

.daily-log-card-actions .btn-small {
    background: #2563eb;
    color: #fff;
}

.daily-log-card-actions .btn-small:hover {
    background: #1d4ed8;
}

/* Edit */

.daily-log-card-actions .btn-secondary {
    background: #f3f4f6;
    color: #111827;

    border: 1px solid #d1d5db;
}

.daily-log-card-actions .btn-secondary:hover {
    background: #e5e7eb;
}

/* Archive */

.daily-log-card-actions a.btn-secondary:last-child {
    background: #fff;
    color: #991b1b;

    border: 1px solid #fecaca;
}

.daily-log-card-actions a.btn-secondary:last-child:hover {
    background: #fef2f2;
}

/* Small interaction polish */

.daily-log-card-actions a:hover,
.daily-log-card-actions button:hover {
    transform: translateY(-1px);
}




/* random */

.daily-logs-overview {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.daily-logs-summary-card {
    background: var(--card-bg, #fff);
    border-radius: 16px;
    padding: 20px;
    box-shadow: var(--card-shadow);
}

.daily-logs-summary-label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-muted);
    margin-bottom: 8px;
}

.daily-logs-summary-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
}

.daily-logs-summary-note {
    margin-top: 8px;
    color: var(--text-muted);
    font-size: 0.9rem;
}

.daily-logs-alert {
    margin-bottom: 20px;
}

.daily-logs-alert-list {
    margin: 8px 0 0;
    padding-left: 18px;
}













/* =========================================================
   FOOD WORKSPACE
========================================================= */

.workspace-feed {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.workspace-entry {
    overflow: hidden;
}

.workspace-entry-layout {
    display: flex;
    gap: 20px;
    align-items: flex-start;
}

.workspace-thumb-wrap {
    flex: 0 0 140px;
}

.workspace-thumb {
    width: 140px;
    height: 140px;

    object-fit: cover;

    border-radius: 14px;

    border: 1px solid #d7dbe3;

    background: #f3f5f8;

    display: block;
}

.workspace-thumb-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;

    font-size: 40px;
    color: #9aa3b2;
}

.workspace-entry-main {
    flex: 1 1 auto;
    min-width: 0;
}

.workspace-entry-top {
    display: flex;
    justify-content: space-between;
    gap: 20px;
}

.workspace-entry-title {
    margin: 0 0 8px;
    font-size: 1.1rem;
    line-height: 1.3;
}

.workspace-entry-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;

    margin-bottom: 8px;

    font-size: 0.92rem;
    color: #5f6b7a;
}

.workspace-entry-submeta {
    font-size: 0.85rem;
    color: #7b8794;
}

.workspace-actions {
    flex: 0 0 auto;
}

.workspace-toolbar-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
}

.workspace-toolbar-actions {
    margin-top: 18px;
    display: flex;
    gap: 10px;
}



/* =========================================================
   DASHBOARD V2
========================================================= */

.dashboard-shell {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.dashboard-hero {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 22px;
    padding: 32px;
    border-radius: 24px;

    background:
        linear-gradient(
            135deg,
            #ffffff 0%,
            #f5f7fb 100%
        );

    border: 1px solid #dbe2ea;
}

.dashboard-hero-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    margin-bottom: 0;
    width: 100%;
}

.dashboard-hero h1 {
    margin: 0 0 8px;
    font-size: 2rem;
    line-height: 1.1;
}

.dashboard-hero-date {
    color: #667085;
    font-size: 0.95rem;
}

.dashboard-stat-grid {
    display: grid;

    grid-template-columns:
        repeat(auto-fit, minmax(180px, 1fr));

    gap: 18px;

    margin-top: 28px;
}

.compact-dashboard-stats {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
    margin-top: 0;
    width: 100%;
}

.dashboard-stat {
    padding: 12px 14px;
    border-radius: 14px;
}

.dashboard-stat-value {
    font-size: 1.25rem;
}

.dashboard-stat {
    background: rgba(255,255,255,0.7);

    border: 1px solid #e1e6ed;
}

.dashboard-stat-label {
    font-size: 0.82rem;
    color: #667085;

    margin-bottom: 6px;
}

.dashboard-stat-value {
    font-weight: 700;
}

.dashboard-main-grid {
    display: grid;

    grid-template-columns:
        minmax(0, 2fr)
        minmax(320px, 1fr);

    gap: 24px;

    align-items: start;
}

.dashboard-stack {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.workspace-dashboard-grid {
    display: grid;

    grid-template-columns:
        repeat(auto-fit, minmax(260px, 1fr));

    gap: 18px;
}

.workspace-dashboard-card {
    display: flex;
    gap: 18px;

    padding: 20px;

    border-radius: 20px;

    transition:
        transform 0.18s ease,
        box-shadow 0.18s ease;
}

.workspace-dashboard-card:hover {
    transform: translateY(-2px);

    box-shadow:
        0 10px 24px rgba(15, 23, 42, 0.08);
}

.workspace-dashboard-icon {
    font-size: 2rem;
    flex: 0 0 auto;
}

.workspace-dashboard-content h3 {
    margin: 0 0 8px;
}

.workspace-dashboard-content p {
    margin: 0;
    color: #667085;
    line-height: 1.5;
}

.workspace-dashboard-meta {
    margin-top: 12px;

    font-size: 0.85rem;
    font-weight: 600;

    color: #2563eb;
}

.dashboard-day-feed {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.dashboard-day-card {
    padding: 20px;
}

.dashboard-day-top {
    display: flex;
    justify-content: space-between;
    align-items: center;

    margin-bottom: 18px;
}

.dashboard-day-metrics {
    display: grid;

    grid-template-columns:
        repeat(auto-fit, minmax(140px, 1fr));

    gap: 16px;
}

.dashboard-day-metrics span {
    display: block;

    font-size: 0.8rem;
    color: #667085;

    margin-bottom: 4px;
}

.dashboard-day-metrics strong {
    font-size: 1rem;
}

.dashboard-recent-days-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.dashboard-recent-day-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 16px;
    border-radius: 16px;
    background: var(--surface-subtle, #fcfcfd);
}

.dashboard-recent-day-main {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 0;
}

.dashboard-recent-day-title-block {
    display: grid;
    gap: 6px;
}

.dashboard-recent-day-date {
    font-size: 1rem;
}

.dashboard-recent-day-metrics {
    display: flex;
    align-items: center;
    gap: 8px 14px;
    flex-wrap: wrap;
}

.dashboard-recent-day-metrics .daily-log-metric {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
    min-width: 0;
}

.dashboard-recent-day-metrics .daily-log-metric span {
    display: inline;
    margin: 0;
    color: var(--muted-text, #64748b);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.dashboard-recent-day-metrics .daily-log-metric strong {
    font-size: 0.92rem;
    line-height: 1.25;
}

.dashboard-recent-day-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.dashboard-side-card {
    padding: 22px;
}

.dashboard-section-title {
    margin: 0 0 6px;
}

.dashboard-section-subtitle {
    margin: 0 0 20px;
    color: #667085;
}

@media (max-width: 1100px) {

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

    .dashboard-recent-day-card {
        grid-template-columns: 1fr;
    }

    .dashboard-recent-day-actions {
        justify-content: flex-start;
    }

}

@media (max-width: 900px) {

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

}

@media (max-width: 640px) {

    .dashboard-hero {
        padding: 22px;
    }

    .dashboard-hero-top {
        flex-direction: column;
        align-items: flex-start;
    }

    .dashboard-hero-top .page-actions {
        width: 100%;
    }

    .dashboard-hero-top .page-actions .btn {
        flex: 1;
        justify-content: center;
    }

    .compact-dashboard-stats {
        grid-template-columns: 1fr;
    }

    .dashboard-recent-day-actions {
        width: 100%;
        flex-direction: column;
    }

    .dashboard-recent-day-actions .btn {
        width: 100%;
        justify-content: center;
    }

}

.workspace-dense .card {
    padding: 16px;
}

.workspace-dense .table td {
    padding: 10px 12px;
}

.workspace-dense .summary-item {
    padding: 12px;
}




/* =====================================================
   STORE VISIT EDIT PAGE

   Store Visits Workspace
   Page-Specific Image Stack
========================================= */

.store-visits-workspace-thumb-wrap {
    flex-shrink: 0;
    width: 78px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    overflow: visible;
}

.store-visits-workspace-icon-stack {
    position: relative;
    width: 68px;
    height: 68px;
    overflow: visible;
}

/* Main Store Image */
.store-visits-workspace-primary-icon {
    width: 58px;
    height: 58px;
    border-radius: 16px;
    object-fit: cover;
    display: block;

    background: #f8fafc;
    border: 1px solid #dbe3ec;

    box-shadow:
        0 4px 10px rgba(15, 23, 42, 0.08),
        0 1px 2px rgba(15, 23, 42, 0.06);
}

/* Placeholder */
.store-visits-workspace-primary-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;

    font-size: 1.5rem;
    color: #64748b;

    background: #f8fafc;
}

/* Fulfillment / Secondary Store */
.store-visits-workspace-secondary-icon {
    position: absolute;

    right: -4px;
    bottom: -4px;

    width: 30px;
    height: 30px;

    border-radius: 10px;
    object-fit: cover;

    background: #fff;

    border: 2px solid #fff;

    box-shadow:
        0 2px 6px rgba(15, 23, 42, 0.16),
        0 1px 2px rgba(15, 23, 42, 0.08);
}
