/* ============================================================
   OPERATIONS SHARED STYLES
   Used across all /ops/* pages.
   Calm, clear, non-enterprise operational UI.
   ============================================================ */

/* ── Page header (used by all ops pages) ──────────────── */
.ops-page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-5);
    border-bottom: 1px solid var(--color-neutral-100);
    flex-wrap: wrap;
}

.ops-page-title {
    font-size: var(--text-2xl);
    font-weight: var(--weight-semibold);
    color: var(--color-text-primary);
    margin: 0 0 var(--space-1);
    font-family: var(--font-persian);
    line-height: var(--leading-snug);
}

.ops-page-subtitle {
    font-size: var(--text-sm);
    color: var(--color-text-tertiary);
    margin: 0;
    font-family: var(--font-persian);
}

/* ── Ops item card (request / visit / emergency / report) ── */
.ops-item {
    background-color: var(--color-bg-surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xs);
    border: 1px solid var(--color-neutral-100);
    border-inline-start: 3px solid transparent;
    padding: var(--space-4) var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    animation: card-enter var(--duration-normal) var(--ease-enter) both;
}

.ops-item--pending    { border-inline-start-color: var(--color-amber-400); }
.ops-item--inprogress { border-inline-start-color: var(--color-rose-400); }
.ops-item--completed  { border-inline-start-color: var(--color-sage-400); }
.ops-item--emergency  { border-inline-start-color: var(--color-emergency-500); background: linear-gradient(135deg, var(--color-emergency-50) 0%, #fff 30%); }

.ops-item__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
    flex-wrap: wrap;
}

.ops-item__title-area {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    flex: 1;
    min-width: 0;
}

.ops-item__icon { font-size: var(--text-lg); flex-shrink: 0; line-height: 1.3; }

.ops-item__title {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--color-text-primary);
    margin: 0;
    font-family: var(--font-persian);
    line-height: var(--leading-snug);
}

.ops-item__elder {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    margin: 0;
    font-family: var(--font-persian);
}

/* ── Status badge ─────────────────────────────────────── */
.ops-badge {
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    padding: 2px var(--space-2);
    border-radius: var(--radius-full);
    font-family: var(--font-persian);
    white-space: nowrap;
    flex-shrink: 0;
}

.ops-badge--pending    { background: var(--color-neutral-100); color: var(--color-neutral-700); }
.ops-badge--assigned   { background: var(--color-amber-100);   color: var(--color-amber-700); }
.ops-badge--inprogress { background: var(--color-rose-100);    color: var(--color-rose-700); }
.ops-badge--completed  { background: var(--color-sage-100);    color: var(--color-sage-700); }
.ops-badge--emergency  { background: var(--color-emergency-100); color: var(--color-emergency-700); }
.ops-badge--high       { background: var(--color-amber-100);   color: var(--color-amber-700); }

/* ── Footer row: meta + actions ───────────────────────── */
.ops-item__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-neutral-100);
    flex-wrap: wrap;
}

.ops-item__meta {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
    font-family: var(--font-persian);
    flex-wrap: wrap;
}

.ops-item__companion {
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    color: var(--color-rose-700);
    font-family: var(--font-persian);
}

/* ── Action button ─────────────────────────────────────── */
.ops-action-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-2) var(--space-4);
    background-color: var(--color-rose-600);
    color: #fff;
    border: none;
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    font-family: var(--font-persian);
    cursor: pointer;
    white-space: nowrap;
    transition: background-color var(--duration-fast) var(--ease-standard);
    min-height: 36px;
}

.ops-action-btn:hover { background-color: var(--color-rose-700); }
.ops-action-btn:disabled { background-color: var(--color-neutral-200); color: var(--color-neutral-500); cursor: default; }

.ops-action-btn--sage { background-color: var(--color-sage-600); }
.ops-action-btn--sage:hover { background-color: var(--color-sage-700); }

.ops-action-btn--amber { background-color: var(--color-amber-600); }
.ops-action-btn--amber:hover { background-color: var(--color-amber-700); }

/* ── Section list ─────────────────────────────────────── */
.ops-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

/* ── Filter pills ─────────────────────────────────────── */
.ops-filter-row {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin-bottom: var(--space-5);
}

.ops-filter-pill {
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-full);
    border: 1.5px solid var(--color-neutral-200);
    background: transparent;
    font-size: var(--text-sm);
    font-family: var(--font-persian);
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: all var(--duration-fast) var(--ease-standard);
    font-weight: var(--weight-medium);
    min-height: 36px;
}

.ops-filter-pill:hover { border-color: var(--color-rose-400); color: var(--color-rose-700); }

.ops-filter-pill--active {
    background-color: var(--color-rose-600);
    border-color: var(--color-rose-600);
    color: #fff;
}

@keyframes card-enter {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── ops-action-btn danger outline ───────────────────────── */
.ops-action-btn--danger {
    background-color: var(--color-emergency-600);
    color: #fff;
}
.ops-action-btn--danger:hover { background-color: var(--color-emergency-700); }

.ops-action-btn--danger-outline {
    background-color: transparent;
    color: var(--color-emergency-600);
    border: 1.5px solid var(--color-emergency-400);
}
.ops-action-btn--danger-outline:hover {
    background-color: var(--color-emergency-100);
    border-color: var(--color-emergency-600);
}

/* ── Coordinator Dashboard — Incoming queue section ──────── */
.ops-cpd-incoming {
    margin-bottom: var(--space-6);
    border: 1.5px solid var(--color-amber-400);
    border-radius: var(--radius-lg);
    padding: var(--space-4) var(--space-5);
    background: linear-gradient(135deg, var(--color-amber-100) 0%, #fff 40%);
    animation: card-enter var(--duration-normal) var(--ease-enter) both;
}

.ops-cpd-incoming__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-4);
    gap: var(--space-3);
}

.ops-cpd-incoming__title {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--color-amber-700);
    font-family: var(--font-persian);
}

.ops-cpd-incoming__count {
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    color: var(--color-amber-700);
    background: var(--color-amber-200);
    padding: 2px var(--space-2);
    border-radius: var(--radius-full);
    font-family: var(--font-persian);
    white-space: nowrap;
}

.ops-cpd-incoming-item {
    background-color: var(--color-bg-surface);
    border: 1px solid var(--color-amber-200);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    animation: card-enter var(--duration-normal) var(--ease-enter) both;
}

.ops-cpd-incoming-item__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
    flex-wrap: wrap;
}

.ops-cpd-incoming-item__info {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    min-width: 0;
    flex: 1;
}

.ops-cpd-incoming-item__family {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--color-text-primary);
    font-family: var(--font-persian);
}

.ops-cpd-incoming-item__title-text {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    font-family: var(--font-persian);
}

.ops-cpd-incoming-item__type {
    font-size: var(--text-xs);
    color: var(--color-text-tertiary);
    font-family: var(--font-persian);
}

.ops-cpd-incoming-item__submitted {
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    color: var(--color-amber-700);
    background: var(--color-amber-100);
    padding: 2px var(--space-2);
    border-radius: var(--radius-full);
    font-family: var(--font-persian);
    white-space: nowrap;
    flex-shrink: 0;
    align-self: flex-start;
}

.ops-cpd-incoming-item__footer {
    display: flex;
    justify-content: flex-end;
}

/* ── Plan Workspace — Review banner & forms ──────────────── */
.ops-cpw-review-banner {
    background: var(--color-amber-100);
    border: 1px solid var(--color-amber-400);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--color-amber-700);
    font-family: var(--font-persian);
    margin-bottom: var(--space-3);
}

.ops-cpw-review-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-4);
}

.ops-cpw-review-form {
    background: var(--color-neutral-50);
    border: 1px solid var(--color-neutral-200);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}

.ops-cpw-revision-notice {
    background: var(--color-amber-100);
    border: 1px solid var(--color-amber-400);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    margin-bottom: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.ops-cpw-revision-notice__label {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--color-amber-700);
    font-family: var(--font-persian);
}

.ops-cpw-revision-notice__note {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    font-family: var(--font-persian);
    margin: 0;
    line-height: var(--leading-relaxed);
}
