/* ============================================================
   FINACLE — Searchable Select widget
   ============================================================ */
.ss-wrap {
    position: relative;
    width: 100%;
}

/* Keep the native select fully sized but transparent under the widget so
   - the form posts the value normally
   - HTML5 `required` validation popups anchor in a sensible position
   - the user cannot interact with it (widget handles all clicks). */
.ss-wrap > select.ss-native {
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    background: transparent;
    color: transparent;
    opacity: 0;
    pointer-events: none;
    z-index: -1;
}

.ss-control {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    text-align: left;
    background: #fff;
    cursor: pointer;
    padding-right: 2.1rem;
    position: relative;
    overflow: hidden;
}
.ss-control:focus {
    border-color: var(--nav, #0b2d6b);
    box-shadow: 0 0 0 0.15rem rgba(11,45,107,0.15);
    outline: none;
}
.ss-wrap.ss-open > .ss-control {
    border-color: var(--nav, #0b2d6b);
    box-shadow: 0 0 0 0.15rem rgba(11,45,107,0.15);
}
.ss-wrap.ss-disabled > .ss-control {
    background: #e9ecef;
    cursor: not-allowed;
}
.ss-label {
    flex: 1 1 auto;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ss-label.ss-placeholder { color: var(--muted, #6b7280); }

.ss-caret {
    position: absolute;
    right: 0.65rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--muted, #6b7280);
    pointer-events: none;
    font-size: 0.85rem;
}
.ss-wrap.ss-open .ss-caret { color: var(--nav, #0b2d6b); }

.ss-panel {
    position: absolute;
    z-index: 1080;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid var(--line, #e5e7eb);
    border-top: 3px solid var(--saffron, #ff9933);
    border-radius: 0 0 0.35rem 0.35rem;
    box-shadow: 0 8px 20px rgba(11, 45, 107, 0.12);
    display: none;
    overflow: hidden;
}
.ss-wrap.ss-open .ss-panel { display: block; }

.ss-search {
    padding: 0.5rem;
    border-bottom: 1px solid var(--line, #e5e7eb);
    background: #f9fafb;
}
.ss-search .form-control {
    height: 1.95rem;
    padding: 0.25rem 0.55rem;
    font-size: 0.85rem;
}

.ss-list {
    list-style: none;
    margin: 0;
    padding: 0.25rem 0;
    max-height: 260px;
    overflow-y: auto;
}
.ss-item {
    padding: 0.45rem 0.75rem;
    font-size: 0.88rem;
    color: var(--ink, #1f2937);
    cursor: pointer;
    line-height: 1.25;
    border-left: 3px solid transparent;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ss-item.ss-hl {
    background: #eef3fb;
    border-left-color: var(--saffron, #ff9933);
}
.ss-item.ss-selected {
    color: var(--nav, #0b2d6b);
    font-weight: 600;
}
.ss-item.ss-placeholder-item {
    color: var(--muted, #6b7280);
    font-style: italic;
}
.ss-item mark {
    background: #fff1c1;
    color: inherit;
    padding: 0;
    border-radius: 2px;
}

.ss-empty {
    display: none;
    padding: 0.75rem;
    color: var(--muted, #6b7280);
    font-size: 0.85rem;
    text-align: center;
}

/* ============================================================
   Form polish — applied broadly so every Create/Edit view in the
   app reads consistently. Targets `form .card` so inline search
   bars (form-inline / form .form-control-sm rows) are untouched.
   The `.elegant-form` selector is also kept as an explicit opt-in.
   ============================================================ */
form .card, .elegant-form .card {
    border: 1px solid var(--line);
    border-radius: 0.45rem;
    margin-bottom: 1rem;
    box-shadow: 0 1px 2px rgba(0,0,0,0.03);
    overflow: hidden;
}
form .card-header, .elegant-form .card-header {
    background: linear-gradient(180deg, #f9fafb 0%, #eef3fb 100%);
    border-bottom: 1px solid var(--line);
    padding: 0.6rem 1rem;
    color: var(--nav);
    font-weight: 600;
    font-size: 0.92rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
form .card-header > i:first-child,
.elegant-form .card-header > i:first-child { color: var(--saffron); }
form .card-header .ef-sub,
.elegant-form .card-header .ef-sub {
    margin-left: auto;
    font-weight: 400;
    font-size: 0.78rem;
    color: var(--muted);
}
form .card-body, .elegant-form .card-body {
    padding: 1rem 1rem 0.5rem;
    background: #fff;
}
form .form-group, .elegant-form .form-group { margin-bottom: 0.85rem; }
form:not(.form-inline) .card label,
.elegant-form label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--ink);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-bottom: 0.25rem;
    display: block;
}
form .card .form-control, .elegant-form .form-control {
    border: 1px solid var(--line);
    border-radius: 0.3rem;
    background: #fff;
}
form .card .form-control[disabled],
form .card .form-control[readonly],
.elegant-form .form-control[disabled],
.elegant-form .form-control[readonly] {
    background: #f5f7fa;
    color: var(--muted);
}

form .card .form-check, .elegant-form .form-check {
    background: #f9fafb;
    border: 1px solid var(--line);
    border-radius: 0.3rem;
    padding: 0.5rem 0.65rem 0.5rem 2rem;
    display: flex;
    align-items: center;
    min-height: 38px;
}
form .card .form-check-input, .elegant-form .form-check-input {
    margin-top: 0.25rem;
    margin-left: -1.4rem;
    transform: scale(1.15);
}
form .card .form-check-label, .elegant-form .form-check-label {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--ink);
    text-transform: none;
    letter-spacing: 0;
    margin: 0;
}

form .card .form-text, .elegant-form .form-text {
    font-size: 0.76rem;
    color: var(--muted);
    margin-top: 0.2rem;
}

/* ============================================================
   Cascading Head Picker — 9-level grid
   ============================================================ */
.head-picker {
    background: #fafbfd;
    border: 1px solid var(--line);
    border-radius: 0.45rem;
    padding: 0.6rem 0.75rem 0.4rem;
    margin-bottom: 0.5rem;
}
.head-picker .hp-fast {
    margin-bottom: 0.55rem;
}
.head-picker .hp-fast-row {
    display: flex; align-items: center; gap: 0.4rem;
    background: #fff;
    border: 1px solid var(--line);
    border-left: 3px solid var(--saffron);
    border-radius: 0.4rem;
    padding: 0.25rem 0.45rem;
}
.head-picker .hp-fast-icon i { color: var(--saffron); }
.head-picker .hp-fast-input {
    border: 0; box-shadow: none;
    flex: 1 1 auto;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.9rem;
}
.head-picker .hp-fast-input:focus { box-shadow: none; outline: none; }
.head-picker .hp-fast-clear { padding: 0 0.25rem; color: var(--muted); }
.head-picker .hp-fast-clear:hover { color: #b03030; }
.head-picker .hp-fast-suggest {
    margin-top: 0.35rem;
    background: #fafbfd;
    border: 1px dashed var(--line);
    border-radius: 0.35rem;
    padding: 0.4rem 0.55rem;
}
.head-picker .hp-fast-suggest-lbl {
    font-size: 0.7rem; font-weight: 600; color: var(--muted);
    text-transform: uppercase; letter-spacing: 0.3px;
    margin-bottom: 0.25rem;
}
.head-picker .hp-fast-suggest-list {
    display: flex; flex-wrap: wrap; gap: 0.3rem;
}
.head-picker .hp-fast-pill {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0.18rem 0.6rem;
    font-size: 0.78rem;
    color: var(--nav);
    cursor: pointer;
    transition: background 0.12s ease, border-color 0.12s ease;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}
.head-picker .hp-fast-pill:hover {
    background: #eef3fb;
    border-color: var(--nav);
}

.hp-fast-strip { margin-bottom: 0.5rem; }
.hp-fast-strip .hp-fast-status {
    margin-top: 0.25rem; padding: 0.25rem 0.4rem;
    font-size: 0.78rem; color: var(--ink);
    background: #fafbfd; border: 1px dashed var(--line);
    border-radius: 0.35rem;
}

.head-picker .hp-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.45rem 0.65rem;
}
@media (min-width: 1200px) {
    .head-picker .hp-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}
.head-picker .hp-cell { display: flex; flex-direction: column; min-width: 0; }
.head-picker .hp-label {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-bottom: 0.15rem;
}
.head-picker .hp-cell-mhd .hp-label { color: var(--nav); }
.head-picker .hp-select { font-size: 0.85rem; }
.head-picker .ss-wrap { font-size: 0.85rem; }

/* Sticky action bar at bottom of long edit forms. */
.form-actions {
    position: sticky;
    bottom: 0;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 0.4rem;
    padding: 0.65rem 1rem;
    margin-top: 1rem;
    box-shadow: 0 -2px 6px rgba(0,0,0,0.04);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    z-index: 5;
}
.form-actions .spacer { flex: 1 1 auto; }
