/* Migrated from components.css: legacy form/grid/autocomplete compatibility.
   Keep this before the modern standard-form rules below so newer rules win. */
.stack-form {
    display: grid;
    gap: 10px;
}

.grid-2,
.grid-3 {
    display: grid;
    gap: 10px;
}

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

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

label {
    display: grid;
    gap: 6px;
    min-width: 0;
    font-size: var(--label-size);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .14em;
}

input,
select,
textarea {
    width: 100%;
    min-height: var(--control-height);
    padding: 8px var(--control-padding-x);
    background: linear-gradient(180deg, var(--input-bg-2), var(--input-bg));
    color: var(--text);
    border: 1px solid rgba(183,170,114,.16);
    outline: none;
    transition: border-color var(--transition-fast), background-color var(--transition-fast), box-shadow var(--transition-fast), color var(--transition-fast);
}

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

input:hover,
select:hover,
textarea:hover {
    border-color: rgba(209,193,137,.28);
    background: #10130f;
}

input:focus,
select:focus,
textarea:focus {
    border-color: var(--focus);
    box-shadow: 0 0 0 1px rgba(221,208,161,.24) inset;
}

input[type="checkbox"] {
    width: 24px !important;
    min-width: 24px !important;
    max-width: 24px !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
    padding: 0 !important;
    margin: 0;
    box-sizing: border-box;
    accent-color: var(--success, var(--accent));
}

.compact-form,
.filter-form {
    width: 100%;
    max-width: none;
}

.filter-form .btn,
.filter-form label,
.filter-form select,
.filter-form input {
    width: 100%;
}

.inline-form > select {
    min-width: 180px;
}


.standard-control-row {
    display: flex;
    align-items: end;
    gap: 10px;
    flex-wrap: wrap;
}

.standard-control-row label {
    min-width: 0;
}

.standard-control-input {
    min-height: 34px;
}

.panel-subsection {
    border: 1px solid rgba(183,170,114,.14);
    padding: 12px;
    background: rgba(255,255,255,.018);
}

.check-row,
.toggle-row {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--text);
    text-transform: none;
    letter-spacing: .02em;
}

.check-row {
    justify-content: start;
}

.toggle-row {
    justify-content: space-between;
    padding: 8px 10px;
    border: 1px solid rgba(183,170,114,.12);
    border-radius: var(--radius-sm, 7px);
    background: rgba(255,255,255,.015);
}

.toggle-row > span {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 4px 8px;
    min-width: 0;
    font-size: 12px;
    line-height: 1.4;
}

.toggle-row > span strong {
    display: inline-block;
    margin: 0;
}

.toggle-row > span small {
    display: inline-block;
    margin: 0;
    color: var(--muted);
}

.small-check {
    align-self: center;
}

.permission-list,
.compact-toggle-list {
    display: grid;
    gap: 6px;
}

.repeat-row {
    display: grid;
    gap: 10px;
    align-items: end;
    margin-bottom: 10px;
}

.conversion-row {
    grid-template-columns: 1.1fr .8fr 1fr .7fr auto auto;
}

.meal-row {
    grid-template-columns: minmax(0, 1.9fr) minmax(110px, .8fr) minmax(110px, .8fr) auto;
}

.autocomplete-wrap {
    position: relative;
}

.autocomplete-input {
    padding-right: 36px;
}

.autocomplete-panel {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    z-index: 60;
    border: 1px solid rgba(183,170,114,.24);
    background: linear-gradient(180deg, rgba(18,21,15,.98), rgba(10,12,10,.99));
    box-shadow: var(--shadow);
    max-height: 280px;
    overflow: auto;
}

.autocomplete-item {
    display: grid;
    gap: 2px;
    padding: 9px 12px;
    border-bottom: 1px solid rgba(183,170,114,.10);
    cursor: pointer;
}

.autocomplete-item:hover,
.autocomplete-item.is-active {
    background: var(--hover-fill);
}

.autocomplete-main {
    display: block;
    color: var(--text);
    font-size: 13px;
}

.autocomplete-meta {
    display: block;
    color: var(--muted);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.autocomplete-empty {
    padding: 10px 12px;
    color: var(--muted);
    font-size: 12px;
}

.module-permission-accordion {
    display: grid;
    gap: 8px;
}

.module-permission-group {
    border: 1px solid rgba(183,170,114,.16);
    background: rgba(255,255,255,.015);
}

.module-permission-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 10px 14px;
    cursor: pointer;
    list-style: none;
}

.module-permission-summary::-webkit-details-marker {
    display: none;
}

.module-permission-summary::before {
    content: '▾';
    color: var(--muted);
    font-size: 12px;
    transform: rotate(-90deg);
    transition: transform .14s ease;
}

.module-permission-group[open] .module-permission-summary::before {
    transform: rotate(0deg);
}

.module-permission-title {
    flex: 1;
    color: var(--text);
    font-weight: 800;
    letter-spacing: .05em;
}

.module-select-all {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    margin: 0;
    color: var(--muted);
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.module-select-all span {
    white-space: nowrap;
}

.module-permission-list {
    padding: 0 14px 14px;
}

/* Standard segmented status controls used across edit drawers. */
.standard-status-control {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .5rem;
    margin: 0 0 .9rem;
}
.standard-status-choice {
    position: relative;
    display: block;
}
.standard-status-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.standard-status-choice span {
    display: block;
    border: 1px solid var(--border);
    background: var(--panel-2);
    padding: .65rem .75rem;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: .05em;
    cursor: pointer;
    color: var(--muted);
}
.standard-status-choice input:checked + span {
    border-color: var(--accent);
    color: var(--accent-2);
    background: rgba(183,170,114,.11);
}
.standard-status-control + .grid-2,
.standard-status-control + .grid-3,
.standard-status-control + .vehicle-drawer-section {
    margin-top: .35rem;
}
@media (max-width: 760px) {
    .standard-status-control {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .grid-2,
    .grid-3,
    .conversion-row,
    .meal-row,
    .detail-pairs-grid {
        grid-template-columns: 1fr;
    }
}


.standard-filter-bar {
    display: grid;
    grid-template-columns: minmax(220px, 1.4fr) minmax(150px, .7fr) minmax(150px, .7fr) minmax(140px, .6fr) auto;
    gap: 10px;
    align-items: end;
    margin: 0;
}

.standard-filter-bar label,
.standard-drawer label:not(.check-row):not(.toggle-row) {
    text-transform: none;
    letter-spacing: .01em;
    font-size: 12px;
    color: var(--muted);
}

.standard-filter-bar input,
.standard-filter-bar select,
.standard-drawer input,
.standard-drawer select,
.standard-drawer textarea {
    border-color: rgba(183,170,114,.12);
    background: rgba(5,7,7,.45);
}

.standard-input-with-icon {
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr);
    align-items: center;
    border: 1px solid rgba(183,170,114,.12);
    background: rgba(5,7,7,.45);
}

.standard-input-with-icon span {
    text-align: center;
    color: var(--muted);
}

.standard-input-with-icon input {
    border: 0;
    background: transparent;
    box-shadow: none;
}

.standard-form-grid-2,
.standard-form-grid-3,
.standard-form-grid-4 {
    display: grid;
    gap: 10px;
}

.standard-form-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.standard-form-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.standard-form-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.standard-section {
    border: 1px solid rgba(183,170,114,.12);
    background: rgba(255,255,255,.018);
    margin-bottom: 12px;
}

.standard-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 12px;
    border-bottom: 1px solid rgba(183,170,114,.10);
    background: rgba(0,0,0,.14);
}

.standard-section-header h3 {
    margin: 0;
    font-size: 14px;
    text-transform: none;
    letter-spacing: 0;
}

.standard-section-body {
    padding: 12px;
    display: grid;
    gap: 10px;
}

.standard-view-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.standard-view-field {
    border: 1px solid rgba(183,170,114,.10);
    background: rgba(0,0,0,.12);
    padding: 10px;
    min-height: 54px;
}

.standard-view-label {
    display: block;
    color: var(--muted);
    font-size: 11px;
    margin-bottom: 6px;
}

.standard-view-value {
    color: #e0dccd;
    font-size: 11px;
    font-weight: 400;
    overflow-wrap: anywhere;
}

/* V3 second-pass: dense standard forms and drawer field groups. */
.standard-filter-bar {
    grid-template-columns: minmax(260px, 1.7fr) minmax(150px, .7fr) minmax(150px, .7fr) auto auto;
    gap: 9px;
}

.standard-filter-bar label,
.standard-drawer label:not(.check-row):not(.toggle-row) {
    gap: 5px;
    font-size: 11px;
    letter-spacing: .02em;
    color: rgba(204,199,178,.70);
    text-transform: none;
}

.standard-filter-bar input,
.standard-filter-bar select,
.standard-drawer input,
.standard-drawer select,
.standard-drawer textarea {
    min-height: 38px;
    padding: 8px 10px;
    border-color: rgba(207,197,151,.13);
    background: linear-gradient(180deg, rgba(13,16,16,.92), rgba(8,10,10,.96));
    color: #ddd8c8;
}

.standard-filter-bar input:focus,
.standard-filter-bar select:focus,
.standard-drawer input:focus,
.standard-drawer select:focus,
.standard-drawer textarea:focus {
    border-color: rgba(218,205,151,.48);
    box-shadow: inset 0 0 0 1px rgba(218,205,151,.14);
}

.standard-input-with-icon {
    grid-template-columns: 28px minmax(0, 1fr);
    border-color: rgba(207,197,151,.13);
    background: rgba(8,10,10,.62);
}

.standard-form-grid-2,
.standard-form-grid-3,
.standard-form-grid-4 {
    gap: 9px;
}

.standard-section {
    margin-bottom: 11px;
    border-color: rgba(207,197,151,.105);
    background: rgba(255,255,255,.014);
}

.standard-section-header {
    min-height: 42px;
    padding: 9px 11px;
    border-bottom-color: rgba(207,197,151,.095);
    background: rgba(0,0,0,.16);
}

.standard-section-header h3 {
    color: #a9ca89;
    font-size: 13px;
    font-weight: 700;
}

.standard-section-body {
    padding: 11px;
    gap: 9px;
}

.standard-nutrition-section > .standard-muted {
    margin-bottom: 0;
    font-size: 12px;
    color: rgba(204,199,178,.66);
}

.standard-nutrient-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 9px;
}

.standard-nutrient-grid label {
    min-height: 74px;
    padding: 8px;
    border: 1px solid rgba(207,197,151,.095);
    background: rgba(0,0,0,.13);
}

.standard-nutrient-grid input {
    min-height: 34px;
    padding-inline: 8px;
    font-size: 11px;
    font-weight: 400;
    color: #efead8;
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.standard-view-grid {
    gap: 9px;
}

.standard-view-field {
    min-height: 52px;
    padding: 9px;
    border-color: rgba(207,197,151,.095);
    background: rgba(0,0,0,.13);
}

.standard-view-label {
    margin-bottom: 5px;
    color: rgba(204,199,178,.68);
    font-size: 11px;
}

.standard-view-value {
    color: #e4dfcf;
    font-size: 11px;
    font-weight: 400;
}

.standard-drawer .conversion-row {
    align-items: end;
    gap: 8px;
}

.check-row.small-check {
    min-height: 38px;
    align-items: center;
}

/* V3 third-pass: compact library filters and dark native dropdown menus. */
.standard-filter-bar.is-library-filter {
    grid-template-columns: minmax(260px, 1fr) minmax(150px, 220px) auto auto;
}

select,
select option,
select optgroup {
    background-color: #0d1111;
    color: #ddd8c8;
}

select option:checked {
    background-color: #293022;
    color: #f1ead3;
}

/* V3 fourth-pass: native dropdown menu colors and right-aligned section actions. */
.standard-filter-bar select option,
.standard-drawer select option,
select option {
    background: #0c1010;
    color: #ddd8c8;
}

.standard-filter-bar select optgroup,
.standard-drawer select optgroup,
select optgroup {
    background: #0c1010;
    color: #c9bd83;
}

.standard-section-actions {
    justify-content: flex-end;
}

/* V3 sixth-pass: meal drawer support. */
.standard-prewrap {
    white-space: pre-wrap;
}

.inline-action-form {
    margin: 0;
    display: inline-flex;
}

.standard-drawer .meal-row {
    display: grid;
    grid-template-columns: minmax(0, 1.8fr) minmax(90px, .45fr) minmax(110px, .55fr) auto;
    gap: 8px;
    align-items: end;
    padding: 9px;
    border: 1px solid rgba(207,197,151,.095);
    background: rgba(0,0,0,.13);
}

.autocomplete-main i {
    color: #f1d55f;
    font-size: .95em;
}

@media (max-width: 760px) {
    .standard-drawer .meal-row {
        grid-template-columns: 1fr;
    }
}

/* V3 seventh-pass: standardized autocomplete. */
.autocomplete-wrap {
    position: relative;
    min-width: 0;
}

.autocomplete-input,
.ingredient-lookup,
.meal-lookup {
    width: 100%;
}

.autocomplete-panel {
    position: absolute;
    z-index: 80;
    left: 0;
    right: 0;
    top: calc(100% + 4px);
    max-height: 280px;
    overflow-y: auto;
    border: 1px solid rgba(207, 197, 151, .18);
    background: linear-gradient(180deg, rgba(15, 18, 18, .99), rgba(8, 10, 10, .99));
    box-shadow: 0 18px 40px rgba(0, 0, 0, .46), inset 0 1px 0 rgba(255, 255, 255, .025);
    padding: 4px;
}

.autocomplete-panel[hidden],
.autocomplete-panel.hidden {
    display: none !important;
}

.autocomplete-item,
.autocomplete-option {
    width: 100%;
    display: grid;
    gap: 2px;
    min-height: 42px;
    padding: 7px 9px;
    border: 0;
    border-left: 3px solid transparent;
    background: transparent;
    color: #dedacc;
    text-align: left;
    cursor: pointer;
}

.autocomplete-item:hover,
.autocomplete-item.is-active,
.autocomplete-option:hover,
.autocomplete-option.is-active {
    border-left-color: rgba(169, 161, 95, .72);
    background: rgba(129, 139, 78, .13);
    color: #f1ead3;
}

.autocomplete-main {
    color: inherit;
    font-size: 12.5px;
    font-weight: 700;
    line-height: 1.2;
}

.autocomplete-meta {
    color: rgba(204, 199, 178, .66);
    font-size: 11px;
    line-height: 1.2;
}

.autocomplete-empty {
    padding: 10px;
    color: rgba(204, 199, 178, .68);
    font-size: 12px;
}

/* V3 ninth-pass: meal ingredient rows and wired permission toggles. */
.standard-drawer .meal-row.repeat-row {
    font-size: 11px;
    font-weight: 400;
}

.standard-drawer .meal-row.repeat-row input,
.standard-drawer .meal-row.repeat-row select,
.standard-drawer .meal-row.repeat-row .autocomplete-input {
    font-size: 11px;
    font-weight: 400;
}

.standard-permission-form {
    display: grid;
    gap: 10px;
}

.permission-member-row {
    position: relative;
    cursor: pointer;
}

.permission-native-check {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    opacity: 0;
    pointer-events: none;
}

.permission-checkbox {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 24px;
    border: 1px solid rgba(179, 106, 95, .45);
    background: rgba(179, 106, 95, .14);
    color: #e8b1a9;
}

.permission-checkbox .permission-on-icon {
    display: none;
}

.permission-checkbox .permission-off-icon {
    display: inline-block;
}

.permission-native-check:checked + .permission-checkbox {
    border-color: rgba(126, 159, 105, .50);
    background: rgba(126, 159, 105, .16);
    color: #b7d99d;
}

.permission-native-check:checked + .permission-checkbox .permission-on-icon {
    display: inline-block;
}

.permission-native-check:checked + .permission-checkbox .permission-off-icon {
    display: none;
}

.permission-member-row:focus-within {
    box-shadow: inset 0 0 0 1px rgba(218, 205, 151, .28);
}

.standard-permission-actions {
    margin-top: 4px;
    padding-inline: 0;
    padding-bottom: 0;
    border-top: 0;
    background: transparent;
}


.permission-member-row:has(.permission-native-check:checked) .permission-checkbox {
    border-color: rgba(126, 159, 105, .50);
    background: rgba(126, 159, 105, .16);
    color: #b7d99d;
}

.permission-member-row:has(.permission-native-check:not(:checked)) .permission-checkbox {
    border-color: rgba(179, 106, 95, .45);
    background: rgba(179, 106, 95, .14);
    color: #e8b1a9;
}

.permission-member-row:has(.permission-native-check:checked) .permission-on-icon {
    display: inline-block;
}

.permission-member-row:has(.permission-native-check:checked) .permission-off-icon {
    display: none;
}

.permission-member-row:has(.permission-native-check:not(:checked)) .permission-on-icon {
    display: none;
}

.permission-member-row:has(.permission-native-check:not(:checked)) .permission-off-icon {
    display: inline-block;
}

/* Explicit class states are required for live permission toggles.
   :has() handles initial load, but the JS toggles these classes immediately. */
.permission-member-row.is-on .permission-checkbox {
    border-color: rgba(126, 159, 105, .50) !important;
    background: rgba(126, 159, 105, .16) !important;
    color: #b7d99d !important;
}

.permission-member-row.is-on .permission-on-icon {
    display: inline-block !important;
}

.permission-member-row.is-on .permission-off-icon {
    display: none !important;
}

.permission-member-row.is-off .permission-checkbox {
    border-color: rgba(179, 106, 95, .48) !important;
    background: rgba(179, 106, 95, .16) !important;
    color: #e8b1a9 !important;
}

.permission-member-row.is-off .permission-on-icon {
    display: none !important;
}

.permission-member-row.is-off .permission-off-icon {
    display: inline-block !important;
}


/* V3 twelfth-pass: drawer input text standardization. */
.standard-drawer input,
.standard-drawer select,
.standard-drawer textarea,
.standard-drawer .autocomplete-input {
    font-size: 11px;
}

/* V3 fourteenth-pass: force consistent drawer typography. */
.standard-drawer input,
.standard-drawer select,
.standard-drawer textarea,
.standard-drawer .autocomplete-input,
.standard-drawer .standard-view-value,
.standard-drawer .standard-prewrap,
.standard-drawer .assignment-meta,
.standard-drawer .autocomplete-main {
    font-size: 11px !important;
    font-weight: 400 !important;
}

.standard-drawer input[type="number"],
.standard-drawer .standard-nutrient-grid input {
    font-size: 11px !important;
    font-weight: 400 !important;
}

/* V3 thirtieth-pass: keep remove controls aligned in repeat edit rows. */
.standard-drawer .repeat-row {
    align-items: stretch;
}

.standard-drawer .conversion-row {
    align-items: stretch;
    grid-template-columns: minmax(0, 1fr) minmax(108px, .75fr) minmax(0, 1fr) minmax(108px, .75fr) 38px;
}

.standard-drawer .repeat-row > .standard-icon-only-btn,
.standard-drawer .conversion-row > .standard-icon-only-btn,
.standard-drawer .meal-row.repeat-row > .standard-icon-only-btn {
    align-self: stretch;
    width: 38px;
    min-width: 38px;
    min-height: 38px;
    height: auto;
    padding: 0;
    display: inline-grid;
    place-items: center;
    line-height: 1;
}

.standard-drawer .repeat-row > .standard-icon-only-btn i,
.standard-drawer .conversion-row > .standard-icon-only-btn i,
.standard-drawer .meal-row.repeat-row > .standard-icon-only-btn i {
    line-height: 1;
}

@media (max-width: 760px) {
    .standard-drawer .conversion-row {
        grid-template-columns: 1fr 1fr 38px;
    }

    .standard-drawer .conversion-row select:nth-of-type(1),
    .standard-drawer .conversion-row input:nth-of-type(1),
    .standard-drawer .conversion-row select:nth-of-type(2),
    .standard-drawer .conversion-row input:nth-of-type(2) {
        min-width: 0;
    }
}

/* Meal planner optimizer tags */
.meal-plan-type-field {
    display: grid;
    gap: 7px;
    margin: 10px 0;
}

.standard-label-text {
    display: block;
    color: var(--standard-label, #cfc7a8);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.meal-plan-checkboxes {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.meal-plan-checkboxes label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 0;
    min-height: auto;
}

.standard-form-actions {
    margin-top: 12px;
    justify-content: flex-start;
}


/* Checkbox rows use the standard 24px checkbox size; spacing belongs on the row gap. */
.toggle-row > input[type="checkbox"]:not(.permission-native-check):not(.owner-tier-toggle-input),
.check-row > input[type="checkbox"]:not(.permission-native-check):not(.owner-tier-toggle-input) {
    width: 24px;
    min-width: 24px;
    height: 24px;
    min-height: 24px;
    flex: 0 0 24px;
    margin: 0;
    border-radius: var(--radius-sm, 6px);
}
