

/* Global UI states */
:root {
    --esim-bg: #030b1c;
    --esim-surface: #111b33;
    --esim-tertiary: #121826;
    --esim-surface-hover: #16223f;
    --esim-surface-disabled: #2b3347;
    --esim-border: rgba(255, 255, 255, 0.20);
    --esim-border-soft: rgba(255, 255, 255, 0.10);
    --esim-border-active: #d6a85f;
    --esim-text: #ffffff;
    --esim-text-muted: #aab4c5;
    --esim-text-disabled: #60697c;
    --esim-accent: #d6a85f;
    --esim-accent-hover: #e0bc74;
    --esim-danger: #ff4d6d;
    --esim-error: #E5484D;
    --esim-radius-sm: 12px;
    --esim-radius-md: 16px;
    --esim-radius-lg: 20px;
    --esim-transition: 0.2s ease;
    --font-extra-bold: 700;
    --font-bold: 600;
    --font-medium: 500;
    --font-regular: 400;
    --leading-flat: 1;
    --leading-normal: 1.25;
    --leading-relaxed: 1.5;
    --leading-loose: 1.625;
    --container-sm: 980px;
    --container-md: 1240px;
    --container-lg: 1300px;
    --radius-xs: 4px;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --totals-color:var(--esim-surface);
    --transition-base: all 0.3s ease;
    --stroke-base: 1px solid var(--esim-text);
    --stroke-transparent: 1px solid transparent;
    --stroke-success: 1px solid #6bcf55;
    --stroke-error: 1px solid #f75e0b;
    --stroke-gray: 1px solid #cfcfcf59;
    --stroke-gray-2: hsla(0, 0%, 81%, .2);
    --stroke-filter: #2b2837;
    --input-border-color: #3d4c5e;
    --input-bg: transparent;
    --input-border: 1px solid;
    --shadow-base: rgba(99, 99, 99, .2) 0px 2px 8px 0px
}

/* Primary gold button */
.esim-btn,
button.esim-btn,
.elementor-button.esim-btn,
.woocommerce a.button.esim-btn,
.woocommerce button.button.esim-btn,
.woocommerce input.button.esim-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 52px;
    padding: 14px 30px;
    border: 1px solid transparent;
    border-radius: var(--esim-radius-sm);
    background: var(--esim-accent);
    color: var(--esim-text);
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    line-height: 1;
    font-weight: 600;
    text-decoration: none;
    box-shadow: none;
    transition: background-color var(--esim-transition), opacity var(--esim-transition), transform var(--esim-transition), border-color var(--esim-transition), color var(--esim-transition);
}

.esim-btn:hover,
button.esim-btn:hover,
.elementor-button.esim-btn:hover,
.woocommerce a.button.esim-btn:hover,
.woocommerce button.button.esim-btn:hover,
.woocommerce input.button.esim-btn:hover {
    background: var(--esim-accent-hover);
    color: var(--esim-text);
    transform: translateY(-1px);
}

.esim-btn:disabled,
.esim-btn.is-disabled,
button.esim-btn:disabled,
.elementor-button.esim-btn[aria-disabled="true"],
.woocommerce a.button.esim-btn.disabled,
.woocommerce button.button.esim-btn:disabled,
.woocommerce input.button.esim-btn:disabled {
    background: var(--esim-surface-disabled);
    color: var(--esim-text-disabled);
    border-color: transparent;
    pointer-events: none;
    transform: none;
}

/* Ghost / outline button */
.esim-btn-outline,
button.esim-btn-outline,
.elementor-button.esim-btn-outline,
.woocommerce a.button.esim-btn-outline,
.woocommerce button.button.esim-btn-outline,
.woocommerce input.button.esim-btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 52px;
    padding: 14px 30px;
    border: 1px solid var(--esim-border);
    border-radius: var(--esim-radius-sm);
    background: transparent;
    color: var(--esim-text);
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    line-height: 1;
    font-weight: 500;
    text-decoration: none;
    box-shadow: none;
    transition: border-color var(--esim-transition), color var(--esim-transition), background-color var(--esim-transition), opacity var(--esim-transition);
}

.esim-btn-outline:hover,
button.esim-btn-outline:hover,
.elementor-button.esim-btn-outline:hover,
.woocommerce a.button.esim-btn-outline:hover,
.woocommerce button.button.esim-btn-outline:hover,
.woocommerce input.button.esim-btn-outline:hover {
    border-color: var(--esim-accent);
    color: var(--esim-text);
    background: transparent;
}

.esim-btn-outline:disabled,
.esim-btn-outline.is-disabled,
button.esim-btn-outline:disabled,
.elementor-button.esim-btn-outline[aria-disabled="true"],
.woocommerce a.button.esim-btn-outline.disabled,
.woocommerce button.button.esim-btn-outline:disabled,
.woocommerce input.button.esim-btn-outline:disabled {
    border-color: rgba(255, 255, 255, 0.08);
    color: var(--esim-text-disabled);
    pointer-events: none;
}

/* Icon button */
.esim-icon-button,
button.esim-icon-button,
.elementor-button.esim-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--esim-text);
    border-radius: 8px;
    transition: color var(--esim-transition), opacity var(--esim-transition), background-color var(--esim-transition);
}

.esim-icon-button:hover,
button.esim-icon-button:hover,
.elementor-button.esim-icon-button:hover {
    color: var(--esim-accent);
    background: transparent;
}

.esim-icon-button:disabled,
.esim-icon-button.is-disabled,
button.esim-icon-button:disabled,
.elementor-button.esim-icon-button[aria-disabled="true"] {
    color: var(--esim-text-disabled);
    pointer-events: none;
}

/* Filter / segmented buttons */
.esim-chip,
button.esim-chip,
.elementor-button.esim-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 20px;
    border: 1px solid var(--esim-border);
    border-radius: var(--esim-radius-sm);
    background: transparent;
    color: var(--esim-text);
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    line-height: 1;
    font-weight: 500;
    text-decoration: none;
    transition: border-color var(--esim-transition), background-color var(--esim-transition), color var(--esim-transition);
}

.esim-chip:hover,
button.esim-chip:hover,
.elementor-button.esim-chip:hover {
    border-color: var(--esim-accent);
    color: var(--esim-text);
    background: transparent;
}

.esim-chip.is-active,
.esim-chip[aria-pressed="true"],
button.esim-chip.is-active,
.elementor-button.esim-chip.is-active {
    background: var(--esim-accent);
    border-color: var(--esim-accent);
    color: var(--esim-text);
}

/* Plan card */
.esim-plan-card {
    display: flex;
    align-items: center;
    gap: 20px;
    width: 100%;
    min-height: 98px;
    padding: 24px 20px;
    border: 1px solid transparent;
    border-radius: var(--esim-radius-md);
    background: var(--esim-surface);
    transition: border-color var(--esim-transition), background-color var(--esim-transition), box-shadow var(--esim-transition), transform var(--esim-transition);
    box-sizing: border-box;
}

.esim-plan-card:hover {
    background: var(--esim-surface-hover);
}

.esim-plan-card.is-active,
.esim-plan-card[aria-checked="true"],
.esim-plan-card.is-selected {
    border-color: var(--esim-accent);
    box-shadow: 0 0 0 1px rgba(214, 168, 95, 0.18);
}

.esim-plan-card__radio {
    flex: 0 0 28px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.35);
    position: relative;
    box-sizing: border-box;
}

.esim-plan-card.is-active .esim-plan-card__radio,
.esim-plan-card[aria-checked="true"] .esim-plan-card__radio,
.esim-plan-card.is-selected .esim-plan-card__radio {
    border-color: var(--esim-accent);
}

.esim-plan-card.is-active .esim-plan-card__radio::after,
.esim-plan-card[aria-checked="true"] .esim-plan-card__radio::after,
.esim-plan-card.is-selected .esim-plan-card__radio::after {
    content: "";
    position: absolute;
    inset: 5px;
    border-radius: 50%;
    background: var(--esim-accent);
}

.esim-plan-card__content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    width: 100%;
}

.esim-plan-card__left,
.esim-plan-card__right {
    display: flex;
    flex-direction: column;
}

.esim-plan-card__title,
.esim-plan-card__price {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 28px;
    line-height: 1.15;
    font-weight: 600;
    color: var(--esim-text);
}

.esim-plan-card__meta,
.esim-plan-card__subprice {
    margin-top: 6px;
    font-family: "Manrope", sans-serif;
    font-size: 20px;
    line-height: 1.2;
    font-weight: 500;
    color: var(--esim-text-muted);
}

.esim-plan-card__right {
    text-align: right;
    margin-left: auto;
}

/* Inputs */
.esim-field {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.esim-field__label {
    font-family: "Manrope", sans-serif;
    font-size: 16px;
    line-height: 1.3;
    font-weight: 500;
    color: var(--esim-text-muted);
}

.esim-input,
input.esim-input,
textarea.esim-input,
select.esim-input {
    width: 100%;
    min-height: 56px;
    padding: 16px 18px;
    border-radius: var(--esim-radius-sm);
    border: 1px solid transparent;
    background: var(--esim-surface);
    color: var(--esim-text);
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 16px;
    line-height: 1;
    font-weight: 500;
    box-sizing: border-box;
    outline: none;
    transition: border-color var(--esim-transition), box-shadow var(--esim-transition), background-color var(--esim-transition), color var(--esim-transition);
}

.esim-input::placeholder,
input.esim-input::placeholder,
textarea.esim-input::placeholder {
    color: var(--esim-text-muted);
}

.esim-input:hover,
input.esim-input:hover,
textarea.esim-input:hover,
select.esim-input:hover {
    background: var(--esim-surface-hover);
}

.esim-input:focus,
.esim-input.is-active,
input.esim-input:focus,
textarea.esim-input:focus,
select.esim-input:focus {
    border-color: var(--esim-accent);
    box-shadow: 0 0 0 1px rgba(214, 168, 95, 0.18);
}

.esim-input.is-error,
input.esim-input.is-error,
textarea.esim-input.is-error,
select.esim-input.is-error {
    border-color: var(--esim-danger);
    box-shadow: 0 0 0 1px rgba(255, 77, 109, 0.14);
}

.esim-field__error {
    font-family: "Manrope", sans-serif;
    font-size: 14px;
    line-height: 1.4;
    font-weight: 500;
    color: var(--esim-danger);
}

@media (max-width: 1024px) {
    .esim-plan-card {
        min-height: 88px;
        padding: 20px 18px;
        gap: 16px;
    }

    .esim-plan-card__title,
    .esim-plan-card__price {
        font-size: 24px;
    }

    .esim-plan-card__meta,
    .esim-plan-card__subprice {
        font-size: 18px;
    }
}

@media (max-width: 767px) {
    .esim-btn,
    .esim-btn-outline,
    .esim-chip,
    button.esim-btn,
    button.esim-btn-outline,
    button.esim-chip,
    .elementor-button.esim-btn,
    .elementor-button.esim-btn-outline,
    .elementor-button.esim-chip {
        min-height: 48px;
        font-size: 15px;
        padding: 12px 20px;
    }

    .esim-plan-card {
        min-height: 82px;
        padding: 18px 16px;
        gap: 14px;
    }

    .esim-plan-card__radio {
        flex-basis: 24px;
        width: 24px;
        height: 24px;
    }

    .esim-plan-card__content {
        gap: 14px;
    }

    .esim-plan-card__title,
    .esim-plan-card__price {
        font-size: 20px;
    }

    .esim-plan-card__meta,
    .esim-plan-card__subprice {
        font-size: 16px;
        margin-top: 4px;
    }

    .esim-input,
    input.esim-input,
    textarea.esim-input,
    select.esim-input {
        min-height: 48px;
        font-size: 15px;
    }
}