/* SMARTSHOPPER — LIST PAGE */
#smartshopper {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 100%;
}

/* Add Alert Form */
#smartshopperAdd {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 16px;
    background-color: var(--highlight);
    border-radius: 4px;
}

#smartshopperAddLoad {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

#smartshopperAddLoadUrl {
    flex: 1;
    min-width: 240px;
    border-radius: 4px;
    background-color: var(--black);
    color: var(--bone);
    border: 2px solid var(--faded-bone);
    padding: 10px 16px;
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
    transition: .3s ease;
}

#smartshopperAddLoadUrl:focus {
    outline: none;
    border-color: var(--secondary);
}

#smartshopperAddLoadButton {
    flex-shrink: 0;
    width: auto;
}

#smartshopperAddVariants:empty {
    display: none;
}

#smartshopperAddVariants {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding-top: 4px;
}

.smartshopperAddVariantsTitle {
    color: var(--bone);
    font-size: 16px;
}

.smartshopperAddVariantsHint {
    color: var(--faded-bone);
    font-family: VCR OSD Mono, sans-serif;
    font-size: 12px;
    letter-spacing: 1px;
    text-transform: uppercase;
}

/* Variant Card (repeats — stays class) */
.smartshopperAddVariantsCard {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    grid-template-rows: auto auto;
    grid-template-areas:
        "image title price stock"
        "image notify-stock notify-drop notify-drop";
    align-items: center;
    column-gap: 12px;
    row-gap: 6px;
    padding: 8px;
    background-color: var(--black);
    border: 2px solid var(--faded-bone);
    border-radius: 4px;
    transition: .3s ease;
}

.smartshopperAddVariantsCard:hover {
    border-color: var(--secondary);
}

.smartshopperAddVariantsCardImage {
    grid-area: image;
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: 4px;
    background-color: var(--highlight);
}

.smartshopperAddVariantsCardTitle {
    grid-area: title;
    color: var(--bone);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

.smartshopperAddVariantsCardPrice {
    grid-area: price;
    color: var(--bone);
    font-family: VCR OSD Mono, sans-serif;
    font-size: 13px;
    letter-spacing: 1px;
}

.smartshopperAddVariantsCardStock {
    grid-area: stock;
    text-transform: uppercase;
    font-family: VCR OSD Mono, sans-serif;
    font-size: 11px;
    letter-spacing: 1px;
}

.smartshopperAddVariantsCardStock.inStock {
    color: var(--green);
}

.smartshopperAddVariantsCardStock.outOfStock {
    color: var(--red);
}

.smartshopperAddVariantsCardCheckbox {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--bone);
    font-family: VCR OSD Mono, sans-serif;
    font-size: 13px;
    letter-spacing: 1px;
}

.smartshopperAddVariantsCardCheckbox:nth-of-type(1) {
    grid-area: notify-stock;
}

.smartshopperAddVariantsCardCheckbox:nth-of-type(2) {
    grid-area: notify-drop;
}

.smartshopperAddVariantsCardCheckbox input:disabled + .smartshopperAddVariantsCardInStockHint,
.smartshopperAddVariantsCardCheckbox:has(input:disabled) {
    color: var(--faded-bone);
}

.smartshopperAddVariantsCardInStockHint {
    color: var(--faded-bone);
    font-size: 11px;
    text-transform: uppercase;
    margin-left: 4px;
}

#smartshopperAddButton {
    align-self: flex-end;
    width: auto;
}

@media (max-width: 800px) {
    .smartshopperAddVariantsCard {
        grid-template-columns: auto 1fr;
        grid-template-areas:
            "image title"
            "image price"
            "image stock"
            "notify-stock notify-stock"
            "notify-drop notify-drop";
    }

    #smartshopperAddButton {
        align-self: stretch;
        width: 100%;
    }
}

/* Alerts List */
#smartshopperAlerts {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

#smartshopperAlertsEmpty {
    color: var(--faded-bone);
    padding: 20px 0;
}

/* Alert Card (repeats — stays class) */
.smartshopperAlertCard {
    background-color: var(--highlight);
    border-radius: 4px;
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: .3s ease;
}

.smartshopperAlertCard.inactive {
    opacity: 0.55;
}

/* Header — image, title, url, delete */
.smartshopperAlertCardHeader {
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto auto;
    grid-template-areas:
        "image title delete"
        "image url delete";
    column-gap: 12px;
    row-gap: 2px;
    align-items: center;
}

.smartshopperAlertCardHeaderImage {
    grid-area: image;
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: 4px;
    background-color: var(--black);
}

.smartshopperAlertCardHeaderImage.placeholder {
    visibility: hidden;
}

.smartshopperAlertCardHeaderTitle {
    grid-area: title;
    color: var(--bone);
    font-size: 15px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}

.smartshopperAlertCardHeaderUrl {
    grid-area: url;
    color: var(--faded-bone);
    font-family: VCR OSD Mono, sans-serif;
    font-size: 12px;
    letter-spacing: 1px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-decoration: underline;
    min-width: 0;
}

.smartshopperAlertCardHeaderUrl:hover {
    color: var(--secondary);
}

.smartshopperAlertCardHeaderDelete {
    grid-area: delete;
    width: auto;
    color: var(--faded-bone);
    padding: 4px;
}

.smartshopperAlertCardHeaderDelete:hover {
    color: var(--red);
}

/* Price — labeled input */
.smartshopperAlertCardPrice {
    display: flex;
    flex-direction: column;
    gap: 4px;
    max-width: 200px;
}

.smartshopperAlertCardPriceLabel {
    color: var(--faded-bone);
    font-family: VCR OSD Mono, sans-serif;
    font-size: 12px;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.smartshopperAlertCardPriceInput {
    background-color: var(--black);
    color: var(--bone);
    border: 2px solid var(--faded-bone);
    border-radius: 4px;
    padding: 6px 10px;
    font-family: VCR OSD Mono, sans-serif;
    letter-spacing: 1px;
    width: 100%;
}

.smartshopperAlertCardPriceInput:focus {
    outline: none;
    border-color: var(--secondary);
}

/* Actions — notify checkboxes, active toggle, save */
.smartshopperAlertCardActions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
}

.smartshopperAlertCardActionsInStock,
.smartshopperAlertCardActionsPriceDrop,
.smartshopperAlertCardActionsActive {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--bone);
    font-family: VCR OSD Mono, sans-serif;
    font-size: 14px;
    letter-spacing: 1px;
}

.smartshopperAlertCardActionsActive {
    margin-left: auto;
}

.smartshopperAlertCardActionsSave {
    width: auto;
    flex-shrink: 0;
}

@media (max-width: 800px) {
    .smartshopperAlertCardPrice {
        max-width: none;
    }

    .smartshopperAlertCardActionsActive {
        margin-left: 0;
    }

    .smartshopperAlertCardActionsSave {
        width: 100%;
    }
}
