/* ==========================================================================
   Device Checker — "Architectural Ledger" Style
   Shares design tokens with my-account-modern.css for visual consistency.
   ========================================================================== */

.grcki-esim-device-checker {
    --dc-brand: #0D74CE;
    --dc-text: #092A48;
    --dc-headings: #001C33;
    --dc-icy: #F0F7FF;
    --dc-accent-light: #7DD3FC;
    --dc-surface: #F8FAFC;
    --dc-border: #E2E8F0;
    --dc-gray: #949494;
    --dc-grayed-out: #64748B;
    --dc-success-bg: #DCFCE7;
    --dc-success-text: #166534;
    --dc-error-bg: #FEE2E2;
    --dc-error-text: #991B1B;
    --dc-radius-card: 16px;
    --dc-radius-pill: 9999px;
    --dc-radius-input: 12px;
    --dc-shadow-card: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
    --dc-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    margin: 24px 0;
    font-family: var(--dc-font);
    color: var(--dc-text);
}

.grcki-esim-device-checker__shell {
    padding: 0;
}

.grcki-esim-device-checker__panel {
    position: relative;
    padding: 0;
}

/* --- Input --- */
.grcki-esim-device-form__field {
    position: relative;
}

.grcki-esim-device-form__input {
    width: 100%;
    min-height: 48px;
    padding: 0 48px 0 16px;
    border: 1px solid var(--dc-border);
    border-radius: var(--dc-radius-input);
    background: var(--dc-surface);
    color: var(--dc-text);
    font-family: var(--dc-font);
    font-size: 14px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.grcki-esim-device-form__input::placeholder {
    color: var(--dc-gray);
}

.grcki-esim-device-form__input:focus {
    outline: none;
    border-color: var(--dc-accent-light);
    box-shadow: 0 0 0 3px rgba(125, 211, 252, 0.15);
}

.grcki-esim-device-form__status {
    position: absolute;
    top: 50%;
    right: 16px;
    width: 16px;
    height: 16px;
    margin-top: -8px;
    border-radius: 50%;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.grcki-esim-device-form.is-loading .grcki-esim-device-form__status {
    opacity: 1;
    border: 2px solid rgba(13, 116, 206, 0.15);
    border-top-color: var(--dc-brand);
    animation: grcki-esim-device-spin 0.7s linear infinite;
}

/* --- Suggestions dropdown (frosted glass) --- */
.grcki-esim-device-suggestions {
    position: absolute;
    z-index: 20;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    padding: 8px;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(226, 232, 240, 0.5);
    border-radius: var(--dc-radius-card);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
    backdrop-filter: blur(20px);
}

.grcki-esim-device-suggestions__label {
    margin: 4px 10px 6px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--dc-grayed-out);
}

.grcki-esim-device-suggestions__item {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 10px 14px;
    border: 0;
    border-radius: 10px;
    background: transparent;
    text-align: left;
    color: var(--dc-text);
    font-family: var(--dc-font);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.16s ease;
}

.grcki-esim-device-suggestions__item:hover,
.grcki-esim-device-suggestions__item:focus {
    outline: none;
    background: var(--dc-icy);
}

.grcki-esim-device-suggestions__item-model {
    font-weight: 600;
}

.grcki-esim-device-suggestions__item-brand {
    font-size: 13px;
    color: var(--dc-gray);
}

/* --- Results area --- */
.grcki-esim-device-result {
    margin-top: 12px;
}

.grcki-esim-device-result__message,
.grcki-esim-device-result__empty {
    padding: 14px 16px;
    border-radius: var(--dc-radius-input);
    background: var(--dc-surface);
    color: var(--dc-grayed-out);
    font-size: 13px;
}

.grcki-esim-device-result__message.is-error {
    background: var(--dc-error-bg);
    color: var(--dc-error-text);
}

.grcki-esim-device-result__title {
    margin: 0 0 8px;
    font-size: 13px;
    font-weight: 600;
    color: var(--dc-grayed-out);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.grcki-esim-device-result__grid {
    display: grid;
    gap: 8px;
}

/* --- Device card (minimal: name + badge only) --- */
.grcki-esim-device-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    border-radius: var(--dc-radius-card);
    background: #FFFFFF;
    box-shadow: var(--dc-shadow-card);
    transition: box-shadow 0.2s ease;
}

.grcki-esim-device-card:hover {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.08);
}

.grcki-esim-device-card__name {
    margin: 0;
    font-size: 14px;
    font-weight: 500;
    color: var(--dc-text);
}

.grcki-esim-device-card__badge {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: var(--dc-radius-pill);
    background: var(--dc-success-bg);
    color: var(--dc-success-text);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.025em;
    text-transform: uppercase;
}

@keyframes grcki-esim-device-spin {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 640px) {
    .grcki-esim-device-form__input {
        min-height: 44px;
        padding-right: 44px;
    }

    .grcki-esim-device-card {
        padding: 10px 14px;
    }
}
