/* ==========================================================================
   FERMA FIIP — Reusable UI components
   Cards, tables, badges, KPIs, forms, timeline, states, login, error pages
   ========================================================================== */

/* ----- Cards ----- */
.ferma-card {
    background: var(--ferma-surface);
    border: 1px solid var(--ferma-border);
    border-radius: var(--ferma-radius);
    box-shadow: var(--ferma-shadow-sm);
    overflow: hidden;
}

.ferma-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.85rem 1.1rem;
    border-bottom: 1px solid var(--ferma-border);
    background: linear-gradient(0deg, var(--ferma-surface), var(--ferma-surface));
}

.ferma-card__title {
    margin: 0;
    font-size: 0.98rem;
    font-weight: 700;
    color: var(--ferma-text);
}

.ferma-card__hint {
    font-size: 0.78rem;
    color: var(--ferma-muted);
}

.ferma-card__body {
    padding: 1.1rem;
}

.ferma-card__body.p-0 {
    padding: 0;
}

.ferma-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}

.ferma-card--wide {
    grid-column: 1 / -1;
}

.ferma-subhead {
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--ferma-muted);
    margin: 0.75rem 0 0.3rem;
}

/* ----- KPI grid ----- */
.ferma-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(225px, 1fr));
    gap: 1rem;
}

.ferma-kpi {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    background: var(--ferma-surface);
    border: 1px solid var(--ferma-border);
    border-left: 4px solid var(--ferma-info);
    border-radius: var(--ferma-radius);
    box-shadow: var(--ferma-shadow-sm);
    padding: 0.95rem 1rem;
}

.ferma-kpi__icon {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    width: 46px;
    height: 46px;
    border-radius: var(--ferma-radius-sm);
    font-size: 1.3rem;
    background: var(--ferma-cloud);
    color: var(--ferma-info);
}

.ferma-kpi__body {
    min-width: 0;
}

.ferma-kpi__title {
    margin: 0;
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--ferma-muted);
}

.ferma-kpi__value {
    margin: 0.1rem 0 0;
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--ferma-text);
    line-height: 1.1;
}

.ferma-kpi__trend {
    margin: 0.15rem 0 0;
    font-size: 0.74rem;
    color: var(--ferma-muted);
}

.ferma-kpi--info { border-left-color: var(--ferma-info); }
.ferma-kpi--info .ferma-kpi__icon { color: var(--ferma-info); }
.ferma-kpi--success { border-left-color: var(--ferma-success); }
.ferma-kpi--success .ferma-kpi__icon { color: var(--ferma-success); background: #e7f3ec; }
.ferma-kpi--warning { border-left-color: var(--ferma-warning-amber); }
.ferma-kpi--warning .ferma-kpi__icon { color: var(--ferma-warning-amber); background: #fdf3e2; }
.ferma-kpi--danger { border-left-color: var(--ferma-danger); }
.ferma-kpi--danger .ferma-kpi__icon { color: var(--ferma-danger); background: #fbe9eb; }
.ferma-kpi--critical { border-left-color: var(--ferma-critical); }
.ferma-kpi--critical .ferma-kpi__icon { color: var(--ferma-critical); background: #fbe5e3; }
.ferma-kpi--neutral { border-left-color: var(--ferma-muted); }
.ferma-kpi--neutral .ferma-kpi__icon { color: var(--ferma-muted); }

/* ----- Charts ----- */
.ferma-chart {
    position: relative;
    height: 280px;
}

.ferma-chart canvas {
    max-height: 280px;
}

/* ----- Map placeholder ----- */
.ferma-map-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 0.4rem;
    min-height: 280px;
    border: 2px dashed var(--ferma-border);
    border-radius: var(--ferma-radius);
    background:
        repeating-linear-gradient(45deg, var(--ferma-cloud) 0 14px, #eef1f4 14px 28px);
    color: var(--ferma-muted);
    padding: 1.5rem;
}

.ferma-map-placeholder i {
    font-size: 2.2rem;
    color: var(--ferma-green);
}

.ferma-map-placeholder p {
    margin: 0;
    font-weight: 600;
    color: var(--ferma-road-asphalt);
}

/* Shown over a live Leaflet map when OSM tiles can't load (offline demo). The
   map library, markers and coordinates still work; only raster tiles need net. */
.ferma-map-offline-note {
    position: absolute;
    top: 8px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 450; /* above tiles, below Leaflet zoom controls (1000) */
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    max-width: 92%;
    padding: 0.4rem 0.7rem;
    border: 1px solid #f3d28a;
    border-radius: var(--ferma-radius);
    background: #fff7e6;
    color: #7a5a00;
    font-size: 0.8rem;
    font-weight: 600;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
    pointer-events: none;
}

.ferma-map-offline-note i {
    font-size: 1rem;
}

/* ----- Tables ----- */
.ferma-table {
    font-size: 0.86rem;
}

.ferma-table thead th {
    background: var(--ferma-cloud);
    color: var(--ferma-muted);
    text-transform: uppercase;
    font-size: 0.7rem;
    letter-spacing: 0.04em;
    border-bottom: 1px solid var(--ferma-border);
    white-space: nowrap;
}

.ferma-table tbody tr:hover {
    background: #fbfcfd;
}

.ferma-table__subject {
    font-weight: 600;
    color: var(--ferma-text);
}

.ferma-ref {
    background: var(--ferma-cloud);
    border: 1px solid var(--ferma-border);
    border-radius: 4px;
    padding: 0.05rem 0.4rem;
    font-size: 0.78rem;
    color: var(--ferma-road-asphalt);
}

.ferma-pagination {
    display: flex;
    justify-content: flex-end;
    padding: 0.75rem 1.1rem;
    border-top: 1px solid var(--ferma-border);
}

/* ----- Status badges (icon + label, never colour alone) ----- */
.ferma-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.74rem;
    font-weight: 600;
    padding: 0.18rem 0.5rem;
    border-radius: 999px;
    border: 1px solid transparent;
    white-space: nowrap;
}

.ferma-badge--neutral { background: #eef1f4; color: #424b53; border-color: #dde2e7; }
.ferma-badge--info { background: #e7f0ff; color: #0a58ca; border-color: #cfe0ff; }
.ferma-badge--success { background: #e7f3ec; color: #146c43; border-color: #c9e5d4; }
.ferma-badge--warning { background: #fdf3e2; color: #9a5b00; border-color: #f7e2bd; }
.ferma-badge--danger { background: #fbe9eb; color: #b02a37; border-color: #f3c9ce; }
.ferma-badge--critical { background: #fbe5e3; color: #842029; border-color: #f1bcb7; }

/* ----- Forms ----- */
.ferma-field {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    margin-bottom: 0.9rem;
}

.ferma-field__label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--ferma-text);
}

.ferma-field__control {
    position: relative;
    display: flex;
    align-items: center;
}

.ferma-field__icon {
    position: absolute;
    left: 0.7rem;
    color: var(--ferma-muted);
    pointer-events: none;
}

.ferma-field__control .form-control {
    padding-left: 2.2rem;
}

.ferma-field__error,
.field-validation-error {
    color: var(--ferma-danger);
    font-size: 0.76rem;
}

.input-validation-error {
    border-color: var(--ferma-danger) !important;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--ferma-green);
    box-shadow: 0 0 0 0.2rem rgba(0, 107, 63, 0.15);
}

.ferma-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 0 1rem;
}

.ferma-filter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0 1rem;
    align-items: end;
}

.ferma-filter-grid__actions {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.9rem;
}

.ferma-form__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    justify-content: flex-end;
}

.ferma-step {
    display: inline-grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--ferma-green);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 700;
    margin-right: 0.4rem;
}

/* ----- Upload placeholder ----- */
.ferma-upload {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    text-align: center;
    padding: 1.8rem;
    border: 2px dashed var(--ferma-border);
    border-radius: var(--ferma-radius);
    background: var(--ferma-cloud);
    color: var(--ferma-muted);
}

.ferma-upload i {
    font-size: 2rem;
    color: var(--ferma-green);
}

.ferma-upload p {
    margin: 0;
    font-weight: 600;
    color: var(--ferma-road-asphalt);
}

/* ----- Empty + loading states ----- */
.ferma-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    text-align: center;
    padding: 2.5rem 1.5rem;
    color: var(--ferma-muted);
}

.ferma-empty i {
    font-size: 2.4rem;
    color: var(--ferma-border);
}

.ferma-empty p {
    margin: 0;
    font-weight: 600;
    color: var(--ferma-road-asphalt);
}

.ferma-empty--inline {
    padding: 1.4rem;
}

.ferma-skeleton {
    position: relative;
    overflow: hidden;
    background: #eef1f4;
    border-radius: var(--ferma-radius-sm);
}

.ferma-skeleton::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.6), transparent);
    animation: ferma-shimmer 1.4s infinite;
}

@keyframes ferma-shimmer {
    100% { transform: translateX(100%); }
}

.ferma-loading {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--ferma-muted);
}

/* ----- Breadcrumb ----- */
.ferma-breadcrumb {
    margin-bottom: 0.6rem;
}

.ferma-breadcrumb__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
    list-style: none;
    margin: 0;
    padding: 0;
    font-size: 0.8rem;
}

.ferma-breadcrumb__item {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--ferma-muted);
}

.ferma-breadcrumb__item.is-active span {
    color: var(--ferma-text);
    font-weight: 600;
}

.ferma-breadcrumb__sep {
    font-size: 0.65rem;
    color: var(--ferma-border);
}

/* ----- Detail page ----- */
.ferma-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.ferma-detail-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.6rem 1.5rem;
    margin: 0;
}

.ferma-detail-list > div {
    display: flex;
    flex-direction: column;
}

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

.ferma-detail-list dd {
    margin: 0;
    color: var(--ferma-text);
}

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

/* ----- Workflow action panel + timeline ----- */
.ferma-action-panel {
    background: var(--ferma-surface);
    border: 1px solid var(--ferma-border);
    border-radius: var(--ferma-radius);
    box-shadow: var(--ferma-shadow-sm);
    padding: 1rem;
}

.ferma-action-panel__title {
    font-size: 0.95rem;
    font-weight: 700;
    margin: 0;
}

.ferma-action-panel__stage {
    font-size: 0.8rem;
    color: var(--ferma-muted);
    margin: 0.15rem 0 0.8rem;
}

.ferma-action-panel__actions {
    display: grid;
    gap: 0.5rem;
}

.ferma-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    justify-content: center;
}

.ferma-action-panel__hint {
    font-size: 0.74rem;
    margin: 0.8rem 0 0;
}

.ferma-timeline {
    list-style: none;
    margin: 0;
    padding: 0 0 0 0.4rem;
}

.ferma-timeline__item {
    position: relative;
    padding: 0 0 1rem 1.3rem;
    border-left: 2px solid var(--ferma-border);
}

.ferma-timeline__item:last-child {
    border-left-color: transparent;
    padding-bottom: 0;
}

.ferma-timeline__dot {
    position: absolute;
    left: -7px;
    top: 2px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--ferma-green);
    border: 2px solid var(--ferma-surface);
    box-shadow: 0 0 0 2px var(--ferma-border);
}

.ferma-timeline__stage {
    margin: 0;
    font-weight: 700;
    font-size: 0.86rem;
}

.ferma-timeline__meta {
    margin: 0;
    font-size: 0.74rem;
    color: var(--ferma-muted);
}

.ferma-timeline__note {
    margin: 0.2rem 0 0;
    font-size: 0.8rem;
}

/* ----- Login ----- */
.ferma-login__header {
    margin-bottom: 1.3rem;
}

.ferma-login__eyebrow {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--ferma-green);
    font-weight: 700;
}

.ferma-login__title {
    font-size: 1.25rem;
    font-weight: 800;
    margin: 0.25rem 0 0.4rem;
    color: var(--ferma-text);
}

.ferma-login__sub {
    font-size: 0.86rem;
    color: var(--ferma-muted);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.ferma-login__chip {
    background: var(--ferma-green);
    color: #fff;
    font-weight: 700;
    font-size: 0.68rem;
    padding: 0.1rem 0.45rem;
    border-radius: 999px;
    letter-spacing: 0.04em;
}

.ferma-login__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0.2rem 0 1.1rem;
    font-size: 0.84rem;
}

.ferma-login__forgot {
    font-size: 0.82rem;
    background: none;
    border: 0;
    padding: 0;
    color: var(--ferma-green, #006B3F);
    text-decoration: none;
    cursor: pointer;
}

.ferma-login__forgot:hover {
    text-decoration: underline;
}

.ferma-login__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.6rem;
    font-size: 0.95rem;
}

.ferma-login__notice {
    margin: 1rem 0 0;
    font-size: 0.76rem;
    color: var(--ferma-muted);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

/* ----- Error pages ----- */
.ferma-errorpage {
    text-align: center;
    padding: 1rem;
}

.ferma-errorpage__icon {
    font-size: 2.6rem;
    color: var(--ferma-green);
}

.ferma-errorpage__code {
    font-size: 3rem;
    font-weight: 800;
    margin: 0.4rem 0 0;
    color: var(--ferma-road-asphalt);
    letter-spacing: 0.04em;
}

.ferma-errorpage__title {
    font-size: 1.3rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
}

.ferma-errorpage__text {
    color: var(--ferma-muted);
    margin: 0 auto 1.3rem;
    max-width: 42ch;
}

.ferma-errorpage__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    justify-content: center;
}

.ferma-errorpage__corrid {
    margin-top: 1.2rem;
    font-size: 0.76rem;
    color: var(--ferma-muted);
}

/* ----- Print-friendly basics (future documents: certificates, memos) ----- */
@media print {
    .ferma-sidebar,
    .ferma-topbar,
    .ferma-footer,
    .ferma-sidebar-backdrop,
    .ferma-action-panel__actions,
    .ferma-skip-link {
        display: none !important;
    }

    .ferma-main,
    body {
        background: #fff !important;
    }

    .ferma-card {
        border-color: #000;
        box-shadow: none;
        break-inside: avoid;
    }

    a[href]::after {
        content: "";
    }
}

/* ==========================================================================
   Phase-2 component additions
   ========================================================================== */

/* ----- Login: wide card + demo profiles ----- */
.ferma-auth__formcard--wide { max-width: 920px; }

.ferma-login__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.4rem;
    margin-top: 0.5rem;
}

.ferma-login__demo {
    border-left: 1px solid var(--ferma-border);
    padding-left: 1.4rem;
    display: flex;
    flex-direction: column;
}

.ferma-login__demo-title {
    font-size: 0.98rem;
    font-weight: 800;
    margin: 0 0 0.2rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.ferma-login__demo-title i { color: var(--ferma-green); }

.ferma-login__demo-sub {
    font-size: 0.8rem;
    color: var(--ferma-muted);
    margin: 0 0 0.8rem;
}

.ferma-demo-list {
    display: grid;
    gap: 0.6rem;
    overflow-y: auto;
    max-height: 52vh;
    padding-right: 0.3rem;
}

.ferma-demo-card {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.6rem 0.8rem;
    align-items: start;
    border: 1px solid var(--ferma-border);
    border-radius: var(--ferma-radius);
    padding: 0.8rem;
    background: var(--ferma-surface);
    transition: border-color var(--ferma-transition), box-shadow var(--ferma-transition);
}

.ferma-demo-card:hover {
    border-color: var(--ferma-green);
    box-shadow: var(--ferma-shadow-sm);
}

.ferma-demo-card__icon {
    grid-row: span 2;
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: var(--ferma-cloud);
    color: var(--ferma-green);
    font-size: 1.2rem;
}

.ferma-demo-card__body { display: flex; flex-direction: column; gap: 0.1rem; min-width: 0; }
.ferma-demo-card__role { font-weight: 700; font-size: 0.9rem; }
.ferma-demo-card__meta { font-size: 0.75rem; color: var(--ferma-muted); }
.ferma-demo-card__meta--muted { color: #9aa3aa; }
.ferma-demo-card__desc { font-size: 0.78rem; color: var(--ferma-text); margin-top: 0.2rem; }

.ferma-demo-card__btn {
    grid-column: 1 / -1;
    background: var(--ferma-green);
    color: #fff;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
}
.ferma-demo-card__btn:hover { background: var(--ferma-green-dark); color: #fff; }

.ferma-login__demo-foot {
    margin-top: 0.9rem;
    font-size: 0.74rem;
    color: var(--ferma-muted);
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

@media (max-width: 760px) {
    .ferma-login__grid { grid-template-columns: 1fr; }
    .ferma-login__demo { border-left: 0; padding-left: 0; border-top: 1px solid var(--ferma-border); padding-top: 1rem; }
}

/* ----- Toasts ----- */
.ferma-toast-host {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 2000;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    max-width: min(380px, 92vw);
}

.ferma-toast {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    background: var(--ferma-surface);
    border: 1px solid var(--ferma-border);
    border-left: 4px solid var(--ferma-info);
    border-radius: var(--ferma-radius);
    box-shadow: var(--ferma-shadow-lg);
    padding: 0.7rem 0.85rem;
    transform: translateX(120%);
    opacity: 0;
    transition: transform 0.22s ease, opacity 0.22s ease;
}

.ferma-toast.is-visible { transform: translateX(0); opacity: 1; }
.ferma-toast.is-leaving { transform: translateX(120%); opacity: 0; }
.ferma-toast > i { font-size: 1.1rem; margin-top: 1px; }
.ferma-toast__msg { flex: 1 1 auto; font-size: 0.85rem; }
.ferma-toast__close {
    background: none; border: 0; font-size: 1.1rem; line-height: 1;
    color: var(--ferma-muted); cursor: pointer; padding: 0 0.1rem;
}
.ferma-toast--success { border-left-color: var(--ferma-success); }
.ferma-toast--success > i { color: var(--ferma-success); }
.ferma-toast--info { border-left-color: var(--ferma-info); }
.ferma-toast--info > i { color: var(--ferma-info); }
.ferma-toast--warning { border-left-color: var(--ferma-warning-amber); }
.ferma-toast--warning > i { color: var(--ferma-warning-amber); }
.ferma-toast--danger { border-left-color: var(--ferma-danger); }
.ferma-toast--danger > i { color: var(--ferma-danger); }

/* ----- Dashboard toolbar + clickable KPI ----- */
.ferma-dash-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.ferma-dash-toolbar__refreshed {
    margin: 0;
    font-size: 0.8rem;
    color: var(--ferma-muted);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

#dashRefreshBtn.is-loading { pointer-events: none; opacity: 0.85; }

.ferma-kpi { position: relative; text-decoration: none; color: inherit; transition: transform var(--ferma-transition), box-shadow var(--ferma-transition); }
.ferma-kpi:hover { text-decoration: none; transform: translateY(-2px); box-shadow: var(--ferma-shadow-md); }
.ferma-kpi__go {
    position: absolute;
    top: 0.6rem;
    right: 0.6rem;
    color: var(--ferma-border);
    transition: color var(--ferma-transition), transform var(--ferma-transition);
}
.ferma-kpi:hover .ferma-kpi__go { color: var(--ferma-green); transform: translateX(2px); }

.ferma-kpi__trend { display: inline-flex; align-items: center; gap: 0.25rem; }
.ferma-kpi__trend--up { color: var(--ferma-success); }
.ferma-kpi__trend--down { color: var(--ferma-danger); }
.ferma-kpi__trend--flat { color: var(--ferma-muted); }

/* ----- Map legend + marker dots ----- */
.ferma-map-legend {
    display: flex;
    gap: 0.9rem;
    flex-wrap: wrap;
    font-size: 0.76rem;
    color: var(--ferma-muted);
}
.ferma-map-legend__item { display: inline-flex; align-items: center; gap: 0.3rem; }
.ferma-marker-dot { width: 11px; height: 11px; border-radius: 50%; border: 2px solid #fff; box-shadow: 0 0 0 1px var(--ferma-border); }
.ferma-marker-dot--low { background: var(--ferma-success); }
.ferma-marker-dot--medium { background: var(--ferma-warning-amber); }
.ferma-marker-dot--high { background: var(--ferma-danger); }
.ferma-marker-dot--critical { background: var(--ferma-critical); }

/* ----- Card header actions ----- */
.ferma-card__headeractions { display: flex; gap: 0.5rem; align-items: center; }

/* ----- Evidence grid ----- */
.ferma-evidence-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 0.8rem;
}
.ferma-evidence-card {
    margin: 0;
    border: 1px solid var(--ferma-border);
    border-radius: var(--ferma-radius);
    overflow: hidden;
    background: var(--ferma-surface);
}
.ferma-evidence-card__thumb {
    height: 96px;
    display: grid;
    place-items: center;
    font-size: 2rem;
    color: var(--ferma-green);
    background: repeating-linear-gradient(45deg, var(--ferma-cloud) 0 12px, #eef1f4 12px 24px);
}
.ferma-evidence-card__body { padding: 0.55rem 0.65rem; display: flex; flex-direction: column; gap: 0.1rem; }
.ferma-evidence-card__name { font-weight: 600; font-size: 0.8rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ferma-evidence-card__caption { font-size: 0.76rem; color: var(--ferma-text); }
.ferma-evidence-card__meta { font-size: 0.7rem; color: var(--ferma-muted); }

/* ----- Upload list ----- */
.ferma-upload { cursor: pointer; }
.ferma-upload.is-dragover { border-color: var(--ferma-green); background: #eef6f1; }
.ferma-upload-list { list-style: none; margin: 0.7rem 0 0; padding: 0; display: grid; gap: 0.4rem; }
.ferma-upload-list__item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.6rem;
    border: 1px solid var(--ferma-border);
    border-radius: var(--ferma-radius-sm);
    background: var(--ferma-surface);
    font-size: 0.82rem;
}
.ferma-upload-list__name { flex: 1 1 auto; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ferma-upload-list__size { color: var(--ferma-muted); font-size: 0.74rem; }

/* ----- Comments thread ----- */
.ferma-comments { list-style: none; margin: 0 0 1rem; padding: 0; display: grid; gap: 0.9rem; }
.ferma-comment { display: flex; gap: 0.6rem; }
.ferma-comment__avatar {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: var(--ferma-road-asphalt);
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
}
.ferma-comment__body { flex: 1 1 auto; background: var(--ferma-cloud); border: 1px solid var(--ferma-border); border-radius: var(--ferma-radius); padding: 0.55rem 0.7rem; }
.ferma-comment__meta { margin: 0 0 0.2rem; font-size: 0.8rem; }
.ferma-comment__text { margin: 0; font-size: 0.86rem; }
.ferma-comment-form { margin-top: 0.5rem; }

/* ----- Audit list ----- */
.ferma-audit { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.6rem; }
.ferma-audit__item { display: flex; gap: 0.3rem; }
.ferma-audit__bullet { color: var(--ferma-green); font-size: 1.2rem; line-height: 1; }
.ferma-audit__action { margin: 0; font-weight: 600; font-size: 0.84rem; }
.ferma-audit__meta { margin: 0; font-size: 0.74rem; color: var(--ferma-muted); }
.ferma-audit__detail { margin: 0.1rem 0 0; font-size: 0.78rem; }

/* ----- Timeline stage states ----- */
.ferma-timeline__item.is-done .ferma-timeline__dot { background: var(--ferma-success); box-shadow: 0 0 0 2px var(--ferma-success); }
.ferma-timeline__item.is-current .ferma-timeline__dot { background: var(--ferma-info); box-shadow: 0 0 0 3px rgba(13,110,253,0.25); }
.ferma-timeline__item.is-pending .ferma-timeline__dot { background: #fff; box-shadow: 0 0 0 2px var(--ferma-border); }
.ferma-timeline__item.is-pending .ferma-timeline__stage { color: var(--ferma-muted); }
.ferma-timeline__item.is-current .ferma-timeline__stage { color: var(--ferma-info); font-weight: 700; }

/* ----- Row flash after action ----- */
@keyframes ferma-row-flash { from { background: rgba(25,135,84,0.18); } to { background: transparent; } }
.ferma-row-flash > td { animation: ferma-row-flash 1.2s ease-out; }

/* ----- Dashboard panels (activity / priority / pending actions) ----- */
.ferma-panels {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1rem;
}
.ferma-card__title i { color: var(--ferma-green); margin-right: 0.25rem; }

.ferma-feed { list-style: none; margin: 0; padding: 0.4rem 0; }
.ferma-feed__item { display: flex; gap: 0.6rem; padding: 0.55rem 1rem; }
.ferma-feed__item + .ferma-feed__item { border-top: 1px solid var(--ferma-border); }
.ferma-feed__icon {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    font-size: 0.9rem;
}
.ferma-feed__icon--info { background: #e7f0ff; color: var(--ferma-info); }
.ferma-feed__icon--success { background: #e7f3ec; color: var(--ferma-success); }
.ferma-feed__icon--warning { background: #fdf3e2; color: var(--ferma-warning-amber); }
.ferma-feed__icon--danger { background: #fbe9eb; color: var(--ferma-danger); }
.ferma-feed__icon--critical { background: #fbe5e3; color: var(--ferma-critical); }
.ferma-feed__body { display: flex; flex-direction: column; min-width: 0; }
.ferma-feed__text { font-size: 0.83rem; color: var(--ferma-text); text-decoration: none; }
a.ferma-feed__text:hover { color: var(--ferma-green); text-decoration: underline; }
.ferma-feed__time { font-size: 0.72rem; color: var(--ferma-muted); margin-top: 0.1rem; }

.ferma-priority { list-style: none; margin: 0; padding: 0; }
.ferma-priority__item + .ferma-priority__item { border-top: 1px solid var(--ferma-border); }
.ferma-priority__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    padding: 0.6rem 1rem;
    text-decoration: none;
    color: var(--ferma-text);
}
.ferma-priority__link:hover { background: var(--ferma-cloud); }
.ferma-priority__body { display: flex; flex-direction: column; min-width: 0; }
.ferma-priority__road { font-weight: 600; font-size: 0.84rem; }
.ferma-priority__meta { font-size: 0.74rem; color: var(--ferma-muted); }

.ferma-actions-list { list-style: none; margin: 0; padding: 0; }
.ferma-actions-list li + li { border-top: 1px solid var(--ferma-border); }
.ferma-actions-list__item {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.6rem 1rem;
    text-decoration: none;
    color: var(--ferma-text);
}
.ferma-actions-list__item:hover { background: var(--ferma-cloud); }
.ferma-actions-list__item > .bi-chevron-right { color: var(--ferma-border); margin-left: auto; }
.ferma-actions-list__item:hover > .bi-chevron-right { color: var(--ferma-green); }
.ferma-actions-list__icon {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 8px;
    background: var(--ferma-cloud);
    color: var(--ferma-green);
}
.ferma-actions-list__body { display: flex; flex-direction: column; min-width: 0; }
.ferma-actions-list__title { font-weight: 600; font-size: 0.84rem; }
.ferma-actions-list__detail { font-size: 0.74rem; color: var(--ferma-muted); }

/* ----- Module placeholder pages ----- */
.ferma-module__banner {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: linear-gradient(120deg, rgba(0,107,63,0.06), rgba(246,195,67,0.08));
    border: 1px solid var(--ferma-border);
    border-radius: var(--ferma-radius);
    padding: 1rem 1.1rem;
    margin-bottom: 1rem;
}
.ferma-module__banner-icon {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    width: 54px;
    height: 54px;
    border-radius: 12px;
    background: var(--ferma-green);
    color: #fff;
    font-size: 1.5rem;
}
.ferma-module__banner-body { flex: 1 1 auto; min-width: 0; }
.ferma-module__statusbadge { margin-bottom: 0.3rem; }
.ferma-module__banner-text { margin: 0; font-size: 0.86rem; color: var(--ferma-text); }
.ferma-module__back { flex: 0 0 auto; }

.ferma-module__grid {
    display: grid;
    grid-template-columns: minmax(0, 2.2fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}
@media (max-width: 991.98px) {
    .ferma-module__grid { grid-template-columns: 1fr; }
    .ferma-module__banner { flex-wrap: wrap; }
}
.ferma-module__actions { display: grid; gap: 0.5rem; }

.ferma-checklist { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.5rem; }
.ferma-checklist li { display: flex; align-items: center; gap: 0.5rem; font-size: 0.85rem; }
.ferma-checklist li.is-done { color: var(--ferma-text); }
.ferma-checklist li.is-done i { color: var(--ferma-success); }
.ferma-checklist li.is-pending { color: var(--ferma-muted); }
.ferma-checklist li.is-pending i { color: var(--ferma-warning-amber); }

/* ----- Login: divider + compact demo selector ----- */
.ferma-login__divider {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    margin: 1.2rem 0 1rem;
    color: var(--ferma-muted);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ferma-login__divider::before,
.ferma-login__divider::after {
    content: "";
    flex: 1 1 auto;
    height: 1px;
    background: var(--ferma-border);
}

.ferma-login__demo { margin: 0; }
.ferma-login__demo .ferma-field__label {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-bottom: 0.35rem;
    font-size: 0.8rem;
    font-weight: 600;
}
.ferma-login__demo .ferma-field__label i { color: var(--ferma-green); }
.ferma-login__demo-desc {
    min-height: 2.2em;
    margin: 0.45rem 0 0.7rem;
    font-size: 0.78rem;
    color: var(--ferma-muted);
}

.ferma-btn-outline {
    background: transparent;
    border: 1px solid var(--ferma-green);
    color: var(--ferma-green);
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
}
.ferma-btn-outline:hover:not(:disabled) { background: var(--ferma-green); color: #fff; }
.ferma-btn-outline:disabled { opacity: 0.55; cursor: not-allowed; }

/* Access denied detail block */
.ferma-errorpage__detail {
    display: inline-grid;
    gap: 0.4rem;
    text-align: left;
    margin: 0 auto 1.2rem;
    padding: 0.8rem 1rem;
    border: 1px solid var(--ferma-border);
    border-radius: var(--ferma-radius);
    background: var(--ferma-cloud);
    font-size: 0.84rem;
}
.ferma-errorpage__detail > div { display: flex; gap: 0.8rem; justify-content: space-between; }
.ferma-errorpage__detail span { color: var(--ferma-muted); }

/* ----- Details toolbar + interactive evidence ----- */
.ferma-detail-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}
.ferma-detail-toolbar__right { display: flex; gap: 0.5rem; }

/* Evidence card is now a button; keep card look, add affordance */
button.ferma-evidence-card {
    text-align: left;
    cursor: pointer;
    padding: 0;
    width: 100%;
    transition: border-color var(--ferma-transition), box-shadow var(--ferma-transition);
}
button.ferma-evidence-card:hover { border-color: var(--ferma-green); box-shadow: var(--ferma-shadow-sm); }
.ferma-evidence-card__thumb { position: relative; }
.ferma-evidence-card__zoom {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 24px;
    height: 24px;
    display: grid;
    place-items: center;
    border-radius: 6px;
    background: rgba(17,24,39,0.55);
    color: #fff;
    font-size: 0.8rem;
    opacity: 0;
    transition: opacity var(--ferma-transition);
}
button.ferma-evidence-card:hover .ferma-evidence-card__zoom { opacity: 1; }

.ferma-evidence-preview {
    display: grid;
    place-items: center;
    gap: 0.3rem;
    min-height: 180px;
    border: 2px dashed var(--ferma-border);
    border-radius: var(--ferma-radius);
    background: repeating-linear-gradient(45deg, var(--ferma-cloud) 0 12px, #eef1f4 12px 24px);
    color: var(--ferma-muted);
    margin-bottom: 0.6rem;
}
.ferma-evidence-preview i { font-size: 2.4rem; color: var(--ferma-green); }
.ferma-evidence-preview p { margin: 0; }

/* Upload list remove button */
.ferma-upload-list__remove {
    background: none;
    border: 0;
    color: var(--ferma-muted);
    font-size: 1.2rem;
    line-height: 1;
    cursor: pointer;
    padding: 0 0.2rem;
    margin-left: auto;
}
.ferma-upload-list__remove:hover { color: var(--ferma-danger); }

/* ----- Citizen reports intake ----- */
.ferma-statuspair { display: inline-flex; align-items: center; gap: 0.35rem; flex-wrap: wrap; }
.ferma-statuspair__label { font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--ferma-muted); }
.ferma-anon-tag {
    display: inline-block; margin-left: 0.3rem; font-size: 0.62rem; text-transform: uppercase;
    letter-spacing: 0.04em; color: var(--ferma-muted); background: var(--ferma-cloud);
    border: 1px solid var(--ferma-border); border-radius: 999px; padding: 0 0.35rem;
}
.ferma-field--check { display: flex; align-items: end; padding-bottom: 0.9rem; }

.ferma-verify-line { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; margin: 0 0 0.5rem; }

.ferma-dup-warning { color: var(--ferma-warning-amber); font-weight: 600; font-size: 0.85rem; margin: 0 0 0.5rem; display: flex; align-items: center; gap: 0.35rem; }
.ferma-dup-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.4rem; }
.ferma-dup-list li { display: flex; gap: 0.5rem; align-items: center; font-size: 0.82rem; flex-wrap: wrap; }

.ferma-cr-actionform { margin: 0; }

/* Print: hide internal shell chrome on detail/intake print */
@media print {
    .ferma-detail-toolbar,
    .ferma-action-panel__actions,
    .ferma-comment-form { display: none !important; }
}

/* ==========================================================================
   Finance & Revenue
   ========================================================================== */
.ferma-money { font-variant-numeric: tabular-nums; white-space: nowrap; font-weight: 600; }
.ferma-money--lg { font-size: 1.25rem; font-weight: 800; color: var(--ferma-green-dark); }
.ferma-kpi--currency .ferma-kpi__value { font-variant-numeric: tabular-nums; }

/* Utilization progress bar */
.ferma-progress {
    position: relative;
    height: 8px;
    width: 92px;
    max-width: 100%;
    border-radius: 999px;
    background: var(--ferma-cloud);
    border: 1px solid var(--ferma-border);
    overflow: hidden;
    display: inline-block;
    vertical-align: middle;
}
.ferma-progress__bar { display: block; height: 100%; background: var(--ferma-green); }
.ferma-progress.is-high .ferma-progress__bar { background: var(--ferma-warning-amber); }
.ferma-progress.is-over .ferma-progress__bar { background: var(--ferma-danger); }
.ferma-progress__label { font-size: 0.74rem; color: var(--ferma-muted); margin-left: 0.4rem; vertical-align: middle; }

/* Channel chip */
.ferma-channel {
    display: inline-block; font-size: 0.74rem; padding: 0.1rem 0.5rem; border-radius: 999px;
    background: var(--ferma-cloud); border: 1px solid var(--ferma-border); color: var(--ferma-road-asphalt);
}

/* Over-budget alert cards */
.ferma-overbudget-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1rem; }
.ferma-overbudget-card {
    display: flex; align-items: center; gap: 0.7rem; padding: 0.9rem 1rem;
    background: #fbe9eb; border: 1px solid #f3c9ce; border-left: 4px solid var(--ferma-danger); border-radius: var(--ferma-radius);
}
.ferma-overbudget-card > i { font-size: 1.5rem; color: var(--ferma-danger); }
.ferma-overbudget-card__title { margin: 0; font-weight: 700; font-size: 0.9rem; }
.ferma-overbudget-card__meta { margin: 0; font-size: 0.78rem; color: var(--ferma-muted); }

/* Risk alerts + fee compliance */
.ferma-feecompliance { display: flex; flex-direction: column; padding: 0.6rem 0.8rem; margin-bottom: 0.8rem; border: 1px solid var(--ferma-border); border-radius: var(--ferma-radius-sm); background: var(--ferma-cloud); }
.ferma-feecompliance strong { font-size: 1.6rem; font-weight: 800; color: var(--ferma-green-dark); }
.ferma-risklist { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.5rem; }
.ferma-risklist__item { display: flex; gap: 0.6rem; padding: 0.55rem 0.7rem; border-radius: var(--ferma-radius-sm); border: 1px solid var(--ferma-border); }
.ferma-risklist__item > i { font-size: 1.1rem; margin-top: 1px; }
.ferma-risklist__item.is-danger { background: #fbe9eb; border-color: #f3c9ce; } .ferma-risklist__item.is-danger > i { color: var(--ferma-danger); }
.ferma-risklist__item.is-warning { background: #fdf3e2; border-color: #f7e2bd; } .ferma-risklist__item.is-warning > i { color: var(--ferma-warning-amber); }
.ferma-risklist__item.is-info { background: #e7f0ff; border-color: #cfe0ff; } .ferma-risklist__item.is-info > i { color: var(--ferma-info); }
.ferma-risklist__title { margin: 0; font-weight: 600; font-size: 0.84rem; }
.ferma-risklist__detail { margin: 0; font-size: 0.76rem; color: var(--ferma-muted); }

/* Doc list */
.ferma-doclist { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.4rem; }
.ferma-doclist li { display: flex; align-items: center; gap: 0.5rem; font-size: 0.86rem; }
.ferma-doclist li > i { color: var(--ferma-green); }

/* Report catalog */
.ferma-report-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1rem; }
.ferma-report-card { padding: 1.1rem; display: flex; flex-direction: column; gap: 0.5rem; }
.ferma-report-card__head { display: flex; align-items: center; gap: 0.6rem; }
.ferma-report-card__icon { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 9px; background: var(--ferma-cloud); color: var(--ferma-green); font-size: 1.1rem; }
.ferma-report-card__title { margin: 0; font-size: 0.98rem; font-weight: 700; }
.ferma-report-card__desc { margin: 0; font-size: 0.82rem; color: var(--ferma-muted); flex: 1 1 auto; }
.ferma-report-card__range { display: flex; align-items: center; gap: 0.4rem; }
.ferma-report-card__actions { display: flex; flex-wrap: wrap; gap: 0.4rem; }

/* Pay-fee wrapper */
.ferma-paywrap { max-width: 640px; }

/* Modal preview helpers (used by finance.js via SweetAlert) */
.ferma-modal-dl { display: grid; gap: 0.3rem; margin: 0.5rem 0; }
.ferma-modal-dl > div { display: flex; justify-content: space-between; gap: 1rem; border-bottom: 1px dashed var(--ferma-border); padding-bottom: 0.25rem; }
.ferma-modal-dl dt { color: var(--ferma-muted); font-size: 0.82rem; }
.ferma-modal-dl dd { margin: 0; font-weight: 600; font-size: 0.85rem; }
.ferma-cert-preview { border: 1px solid var(--ferma-border); border-radius: var(--ferma-radius); padding: 1rem; background: repeating-linear-gradient(45deg, #fff 0 16px, #fcfdfd 16px 32px); }
.ferma-cert-preview__seal { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ferma-green); font-weight: 800; margin: 0 0 0.4rem; }
.ferma-modal-actions { margin-top: 0.6rem; display: flex; gap: 0.4rem; }
.ferma-modal-table { width: 100%; font-size: 0.85rem; border-collapse: collapse; }
.ferma-modal-table th, .ferma-modal-table td { text-align: left; padding: 0.35rem 0.5rem; border-bottom: 1px solid var(--ferma-border); }

/* Risk alert: make body flex and add dismiss button */
.ferma-risklist__item > div { flex: 1 1 auto; min-width: 0; }
.ferma-risklist__dismiss { background: none; border: 0; color: var(--ferma-muted); font-size: 1.1rem; line-height: 1; cursor: pointer; padding: 0 0.2rem; align-self: flex-start; }
.ferma-risklist__dismiss:hover { color: var(--ferma-danger); }

/* ==========================================================================
   Demo Control Center & Demo Script
   ========================================================================== */
.ferma-democtl-banner {
    display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
    background: linear-gradient(120deg, rgba(0,107,63,0.08), rgba(246,195,67,0.10));
    border: 1px solid var(--ferma-border); border-radius: var(--ferma-radius);
    padding: 1rem 1.1rem; margin-bottom: 1rem;
}
.ferma-democtl-banner__icon { flex: 0 0 auto; display: grid; place-items: center; width: 54px; height: 54px; border-radius: 12px; background: var(--ferma-green); color: #fff; font-size: 1.5rem; }
.ferma-democtl-banner__body { flex: 1 1 280px; min-width: 0; }
.ferma-democtl-banner__actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }

.ferma-democtl-profiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 0.8rem; }
.ferma-democtl-profile {
    display: grid; grid-template-columns: auto 1fr; gap: 0.5rem 0.7rem; align-items: start;
    border: 1px solid var(--ferma-border); border-radius: var(--ferma-radius); padding: 0.8rem; background: var(--ferma-surface);
    transition: border-color var(--ferma-transition), box-shadow var(--ferma-transition);
}
.ferma-democtl-profile:hover { border-color: var(--ferma-green); box-shadow: var(--ferma-shadow-sm); }
.ferma-democtl-profile__icon { grid-row: span 2; display: grid; place-items: center; width: 40px; height: 40px; border-radius: 10px; background: var(--ferma-cloud); color: var(--ferma-green); font-size: 1.15rem; }
.ferma-democtl-profile__body { display: flex; flex-direction: column; min-width: 0; }
.ferma-democtl-profile__role { font-weight: 700; font-size: 0.88rem; }
.ferma-democtl-profile__meta { font-size: 0.74rem; color: var(--ferma-muted); }
.ferma-democtl-profile__perms { font-size: 0.72rem; color: var(--ferma-green); }
.ferma-democtl-profile .ferma-btn-outline { grid-column: 1 / -1; }

.ferma-democtl-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 1rem; }
.ferma-democtl-links { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 0.4rem; }
.ferma-democtl-links a { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 0.7rem; border-radius: var(--ferma-radius-sm); border: 1px solid var(--ferma-border); text-decoration: none; color: var(--ferma-text); font-size: 0.84rem; }
.ferma-democtl-links a:hover { background: var(--ferma-cloud); color: var(--ferma-green-dark); }
.ferma-democtl-links a > i { color: var(--ferma-green); }
.ferma-democtl-actions { display: grid; gap: 0.5rem; }

.ferma-democtl-h2 { font-size: 1.2rem; font-weight: 800; margin: 0 0 0.7rem; display: flex; align-items: center; gap: 0.4rem; }
.ferma-democtl-h2 > i { color: var(--ferma-green); }
.ferma-democtl-flows { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1rem; }
.ferma-flow-card { padding: 1rem; display: flex; flex-direction: column; }
.ferma-flow-card__head { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.6rem; }
.ferma-flow-card__num { display: grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; background: var(--ferma-green); color: #fff; font-weight: 700; font-size: 0.8rem; }
.ferma-flow-card__icon { color: var(--ferma-green); font-size: 1.1rem; }
.ferma-flow-card__title { margin: 0; font-size: 0.98rem; font-weight: 700; }
.ferma-flow-card__steps { margin: 0 0 0.8rem; padding-left: 1.1rem; flex: 1 1 auto; }
.ferma-flow-card__steps li { font-size: 0.82rem; margin-bottom: 0.2rem; }
.ferma-flow-card__actions { display: flex; flex-wrap: wrap; gap: 0.4rem; }

.ferma-script__section caption { display: none; }
.ferma-script__actions { display: flex; gap: 0.6rem; flex-wrap: wrap; margin-top: 0.5rem; }

/* ===== Contractor Workspace — Progress Updates ===== */
.ferma-progress-page { display: block; }

.ferma-req { color: var(--ferma-danger); font-weight: 700; }

/* Project details summary card (auto-filled after selection) */
.ferma-project-summary {
    margin-top: 0.9rem;
    padding: 1rem;
    border: 1px solid var(--ferma-border);
    border-left: 4px solid var(--ferma-green);
    border-radius: var(--ferma-radius);
    background: var(--ferma-cloud);
}
.ferma-project-summary__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.7rem 1.2rem;
}
.ferma-project-summary__grid > div { display: flex; flex-direction: column; gap: 0.1rem; }
.ferma-project-summary__grid span {
    font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--ferma-muted);
}
.ferma-project-summary__grid strong { color: var(--ferma-road-asphalt); font-size: 0.92rem; }

/* Large progress bar with a "last reported" tick marker */
.ferma-progress--lg { display: block; width: 100%; height: 14px; }
.ferma-progress--lg .ferma-progress__bar { transition: width 0.25s ease; }
.ferma-progress--lg .ferma-progress__bar.is-invalid { background: var(--ferma-danger); }
.ferma-progress__last {
    position: absolute; top: -2px; bottom: -2px; width: 2px;
    background: var(--ferma-road-asphalt); opacity: 0.65;
}

/* Safety incident radios */
.ferma-radio-row { display: flex; flex-wrap: wrap; gap: 1.2rem; margin-top: 0.35rem; }
.ferma-radio { display: inline-flex; align-items: center; gap: 0.4rem; margin: 0; cursor: pointer; }

/* Evidence dropzone input + meta */
.ferma-upload { position: relative; }
.ferma-upload__input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.ferma-upload small { color: var(--ferma-muted); font-size: 0.74rem; }
.ferma-upload-list__cat {
    flex: 0 0 auto; font-size: 0.72rem; color: var(--ferma-green);
    background: #eef6f1; border-radius: 999px; padding: 0.05rem 0.5rem;
}

/* Submission action bar */
.ferma-progress-actions {
    display: flex; flex-wrap: wrap; gap: 0.75rem;
    align-items: center; justify-content: space-between;
}
.ferma-progress-actions__primary { display: flex; flex-wrap: wrap; gap: 0.6rem; }

/* Recent progress: previous → new delta */
.ferma-progress-delta { display: inline-flex; align-items: center; gap: 0.35rem; white-space: nowrap; }
.ferma-progress-delta strong { color: var(--ferma-green); }

/* Row action group */
.ferma-rowactions { display: inline-flex; flex-wrap: wrap; gap: 0.35rem; justify-content: flex-end; }

/* Evidence preview modal list */
.ferma-evidence-modal { list-style: none; margin: 0 0 0.75rem; padding: 0; display: grid; gap: 0.5rem; }
.ferma-evidence-modal li {
    display: grid; grid-template-columns: auto 1fr; gap: 0.15rem 0.5rem; align-items: center;
    padding: 0.5rem 0.65rem; border: 1px solid var(--ferma-border); border-radius: var(--ferma-radius);
}
.ferma-evidence-modal li i { grid-row: 1 / span 2; color: var(--ferma-green); }
.ferma-evidence-modal__name { font-weight: 600; color: var(--ferma-road-asphalt); }
.ferma-evidence-modal__meta { grid-column: 2; font-size: 0.76rem; color: var(--ferma-muted); }
.ferma-evidence-modal__desc { grid-column: 2; font-size: 0.8rem; }

@media (max-width: 640px) {
    .ferma-progress-actions { flex-direction: column; align-items: stretch; }
    .ferma-progress-actions__primary { justify-content: stretch; }
    .ferma-progress-actions__primary .btn { flex: 1 1 auto; }
}
