/* PacketDial Configurator — wizard styles. CSS vars (--pdc-primary / --pdc-accent) are injected inline from settings. */

[x-cloak] { display: none !important; }

/* Visually hidden — for screen reader announcements. Mirrors WP core. */
.pdc-wizard .screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}

.pdc-wizard {
    --pdc-primary: #0b5fff;
    --pdc-accent: #08306b;
    --pdc-border: #d8dce5;
    --pdc-muted: #6b7280;
    --pdc-bg: #ffffff;
    --pdc-bg-soft: #f7f8fa;
    --pdc-radius: 8px;
    --pdc-radius-lg: 12px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: #1f2937;
    background: var(--pdc-bg);
    border: 1px solid var(--pdc-border);
    border-radius: var(--pdc-radius-lg);
    padding: 24px;
    max-width: 960px;
    margin: 24px auto;
}

.pdc-wizard__loading,
.pdc-wizard__error {
    text-align: center;
    padding: 48px 0;
    color: var(--pdc-muted);
}

/* Steps */
.pdc-steps {
    display: flex;
    list-style: none;
    margin: 0 0 24px;
    padding: 0;
    gap: 8px;
    flex-wrap: wrap;
}
.pdc-steps__item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--pdc-bg-soft);
    color: var(--pdc-muted);
    font-size: 13px;
}
.pdc-steps__item.is-current {
    background: var(--pdc-primary);
    color: #fff;
}
.pdc-steps__item.is-done {
    background: var(--pdc-accent);
    color: #fff;
}
.pdc-steps__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: rgba(255,255,255,0.3);
    font-weight: 600;
    font-size: 12px;
}
.pdc-steps__item:not(.is-current):not(.is-done) .pdc-steps__num {
    background: #e5e7eb;
    color: #374151;
}

/* Step container */
.pdc-step {
    padding: 16px 0 24px;
}
.pdc-step h2 {
    margin: 0 0 8px;
    font-size: 22px;
}
.pdc-step h2:focus { outline: none; }
.pdc-step h2:focus-visible { outline: 2px solid var(--pdc-primary); outline-offset: 4px; border-radius: 4px; }
.pdc-step__lead {
    margin: 0 0 24px;
    color: var(--pdc-muted);
}

/* Fields */
.pdc-field {
    display: block;
    margin-bottom: 16px;
}
.pdc-field__label {
    display: block;
    font-weight: 600;
    margin-bottom: 6px;
    font-size: 14px;
}
.pdc-input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--pdc-border);
    border-radius: var(--pdc-radius);
    font-size: 15px;
    background: #fff;
    color: inherit;
    box-sizing: border-box;
}
.pdc-input:focus {
    outline: 2px solid var(--pdc-primary);
    outline-offset: 1px;
    border-color: var(--pdc-primary);
}

.pdc-form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}
.pdc-form-grid .pdc-field { margin-bottom: 0; }
.pdc-field--full { grid-column: 1 / -1; }
@media (max-width: 600px) {
    .pdc-form-grid { grid-template-columns: 1fr; }
}

/* Cards */
.pdc-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}
.pdc-cards--grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
.pdc-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    background: var(--pdc-bg-soft);
    border: 2px solid transparent;
    border-radius: var(--pdc-radius);
    padding: 16px;
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s;
    font: inherit;
    color: inherit;
}
.pdc-card:hover {
    border-color: var(--pdc-border);
}
.pdc-card.is-selected {
    border-color: var(--pdc-primary);
    background: #fff;
    box-shadow: 0 1px 3px rgba(11, 95, 255, 0.15);
}
.pdc-card__tier {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--pdc-primary);
    font-weight: 700;
    margin-bottom: 4px;
}
.pdc-card__name {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
}
.pdc-card__meta {
    font-size: 13px;
    color: var(--pdc-muted);
    margin-bottom: 8px;
}
.pdc-card__price {
    display: block;
    font-size: 14px;
    margin-bottom: 8px;
}
.pdc-card__price strong { font-size: 18px; }
.pdc-card__per {
    color: var(--pdc-muted);
    font-size: 12px;
    margin-left: 4px;
}
.pdc-card__features {
    margin: 8px 0 0;
    padding-left: 18px;
    font-size: 13px;
    color: #374151;
}
.pdc-card__image {
    max-width: 100%;
    height: 100px;
    object-fit: contain;
    align-self: center;
    margin-bottom: 8px;
}
.pdc-card__discount {
    margin-top: 4px;
    font-size: 13px;
    color: var(--pdc-accent);
    font-weight: 600;
}

/* Quantity stepper */
.pdc-qty {
    display: inline-flex;
    align-items: center;
    margin-top: 8px;
    border: 1px solid var(--pdc-border);
    border-radius: var(--pdc-radius);
    overflow: hidden;
}
.pdc-qty__btn {
    width: 32px;
    height: 32px;
    background: var(--pdc-bg-soft);
    border: 0;
    font-size: 18px;
    cursor: pointer;
    color: inherit;
}
.pdc-qty__btn:hover { background: var(--pdc-border); }
.pdc-qty__input {
    width: 48px;
    height: 32px;
    text-align: center;
    border: 0;
    border-left: 1px solid var(--pdc-border);
    border-right: 1px solid var(--pdc-border);
    background: #fff;
    font-size: 14px;
    -moz-appearance: textfield;
}
.pdc-qty__input::-webkit-outer-spin-button,
.pdc-qty__input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* List rows (addons) */
.pdc-list { display: flex; flex-direction: column; gap: 8px; }
.pdc-list__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border: 1px solid var(--pdc-border);
    border-radius: var(--pdc-radius);
    background: #fff;
}
.pdc-list__row.is-selected {
    border-color: var(--pdc-primary);
    background: var(--pdc-bg-soft);
}
.pdc-list__main { display: flex; flex-direction: column; }
.pdc-list__name { font-weight: 600; }
.pdc-list__meta { font-size: 13px; color: var(--pdc-muted); margin-top: 2px; }

/* Toggle */
.pdc-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

/* Summary */
.pdc-summary {
    width: 100%;
    border-collapse: collapse;
    margin-top: 8px;
}
.pdc-summary th,
.pdc-summary td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--pdc-border);
    text-align: left;
    font-size: 14px;
}
.pdc-summary__qty, .pdc-summary__price, .pdc-summary__total { text-align: right; white-space: nowrap; }
.pdc-summary tfoot th, .pdc-summary tfoot td {
    background: var(--pdc-bg-soft);
    font-weight: 600;
}
.pdc-summary__grand th, .pdc-summary__grand td {
    background: var(--pdc-primary);
    color: #fff;
    font-size: 15px;
}
.pdc-summary__suffix {
    font-size: 12px;
    color: var(--pdc-muted);
    margin-left: 4px;
}
.pdc-summary__row--term_discount td,
.pdc-summary__row--term_discount span { color: #047857; }

/* Footer / nav */
.pdc-wizard__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    border-top: 1px solid var(--pdc-border);
    padding-top: 16px;
    margin-top: 16px;
    flex-wrap: wrap;
}
.pdc-running-total { font-size: 14px; color: var(--pdc-muted); }
.pdc-running-total strong { color: #111827; margin-right: 4px; }
.pdc-running-total__sep { margin: 0 8px; }

.pdc-wizard__nav { display: flex; gap: 8px; margin-left: auto; }
.pdc-btn {
    padding: 10px 18px;
    border-radius: var(--pdc-radius);
    border: 1px solid var(--pdc-border);
    background: var(--pdc-bg-soft);
    color: inherit;
    font-weight: 600;
    cursor: pointer;
    font-size: 14px;
}
.pdc-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.pdc-btn--primary {
    background: var(--pdc-primary);
    border-color: var(--pdc-primary);
    color: #fff;
}
.pdc-btn--primary:hover:not(:disabled) {
    background: var(--pdc-accent);
    border-color: var(--pdc-accent);
}
.pdc-btn--ghost {
    background: transparent;
    border-color: var(--pdc-border);
}

.pdc-consent {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin-top: 16px;
    font-size: 14px;
    color: var(--pdc-muted);
}

/* Honeypot — must be invisible to users but visible to bots */
.pdc-honeypot {
    position: absolute !important;
    left: -9999px !important;
    top: auto !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

.pdc-empty {
    padding: 24px;
    text-align: center;
    color: var(--pdc-muted);
    background: var(--pdc-bg-soft);
    border-radius: var(--pdc-radius);
}

.pdc-form-error {
    color: #b91c1c;
    margin-top: 12px;
}

.pdc-recalculating {
    margin-top: 12px;
    color: var(--pdc-muted);
    font-style: italic;
    font-size: 13px;
}

.pdc-step--success {
    text-align: center;
    padding: 48px 0;
}
