/**
 * Guest Posting Styles — HM Classifieds
 *
 * Styles for: choice screen, benefits banner, guest badge,
 * guest info step, management page.
 *
 * UNLAYERED — these need to beat BuddyX parent theme specificity.
 *
 * @since 1.2.0
 */

/* =========================================================================
   CHOICE SCREEN
   ========================================================================= */

.hm-choice-screen {
    max-width: 800px;
    margin: 0 auto;
    padding: 2rem 0;
}

.hm-choice-screen__header {
    text-align: center;
    margin-bottom: 2rem;
}

.hm-choice-screen__header h2 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--hm-neutral-900, #111827);
    margin: 0 0 0.5rem;
}

.hm-choice-screen__header p {
    color: var(--hm-neutral-600, #4b5563);
    font-size: 1.05rem;
    margin: 0;
}

.hm-choice-screen__options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

@media (max-width: 640px) {
    .hm-choice-screen__options {
        grid-template-columns: 1fr;
    }
}

/* =========================================================================
   CHOICE CARDS
   ========================================================================= */

.hm-choice-card {
    background: var(--hm-neutral-50, #f9fafb);
    border: 2px solid var(--hm-neutral-200, #e5e7eb);
    border-radius: 12px;
    padding: 2rem 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    position: relative;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.hm-choice-card:hover {
    border-color: var(--hm-neutral-300, #d1d5db);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
}

.hm-choice-card--recommended {
    border-color: var(--hm-primary-400, #f59e0b);
    background: var(--hm-primary-50, #fffbeb);
}

.hm-choice-card--recommended:hover {
    border-color: var(--hm-primary-500, #d97706);
    box-shadow: 0 4px 16px rgba(217, 119, 6, 0.15);
}

.hm-choice-card__badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--hm-primary-500, #d97706);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.hm-choice-card__icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--hm-neutral-100, #f3f4f6);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    color: var(--hm-neutral-500, #6b7280);
}

.hm-choice-card--recommended .hm-choice-card__icon {
    background: var(--hm-primary-100, #fef3c7);
    color: var(--hm-primary-600, #b45309);
}

.hm-choice-card__title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--hm-neutral-900, #111827);
    margin: 0 0 0.5rem;
}

.hm-choice-card__desc {
    color: var(--hm-neutral-600, #4b5563);
    font-size: 0.9rem;
    margin: 0 0 1rem;
    line-height: 1.5;
}

.hm-choice-card__features {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
    text-align: left;
    width: 100%;
}

.hm-choice-card__features li {
    color: var(--hm-neutral-600, #4b5563);
    font-size: 0.85rem;
    padding: 0.35rem 0;
    padding-left: 1.5rem;
    position: relative;
}

.hm-choice-card__features li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--hm-success-500, #22c55e);
    font-weight: 700;
}

.hm-choice-card__actions {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    width: 100%;
    align-items: center;
}

.hm-choice-card__actions .hm-btn {
    width: 100%;
    justify-content: center;
}

.hm-choice-card__register-link {
    font-size: 0.85rem;
    color: var(--hm-primary-600, #b45309);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.hm-choice-card__register-link:hover {
    color: var(--hm-primary-700, #92400e);
}

/* =========================================================================
   BENEFITS BANNER
   ========================================================================= */

.hm-benefits-banner {
    background: var(--hm-primary-50, #fffbeb);
    border: 1px solid var(--hm-primary-200, #fde68a);
    border-radius: 10px;
    padding: 1.25rem 1.5rem;
    margin-top: 1.5rem;
}

.hm-benefits-banner__header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    color: var(--hm-primary-700, #92400e);
}

.hm-benefits-banner__header strong {
    font-size: 0.95rem;
}

.hm-benefits-banner__list {
    list-style: none;
    padding: 0;
    margin: 0 0 1rem;
}

.hm-benefits-banner__list li {
    color: var(--hm-neutral-700, #374151);
    font-size: 0.85rem;
    padding: 0.25rem 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.hm-benefits-banner__list li i {
    color: var(--hm-primary-500, #d97706);
    font-size: 1rem;
    width: 18px;
    flex-shrink: 0;
}

.hm-benefits-banner__cta {
    display: inline-flex;
}

/* =========================================================================
   GUEST BADGE (Archive Cards + Single Page)
   ========================================================================= */

.hm-guest-badge {
    display: inline-flex;
    align-items: center;
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--hm-neutral-500, #6b7280);
    background: var(--hm-neutral-100, #f3f4f6);
    border: 1px solid var(--hm-neutral-200, #e5e7eb);
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
    vertical-align: middle;
    margin-left: 0.25rem;
    line-height: 1.4;
}

.hm-listing-card__seller-avatar--guest {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--hm-neutral-100, #f3f4f6);
    color: var(--hm-neutral-400, #9ca3af);
}

.hm-listing-card__seller-avatar--guest svg {
    width: 14px;
    height: 14px;
}

/* =========================================================================
   GUEST SELLER CARD (Single Listing Page)
   ========================================================================= */

.hm-seller-card--guest .hm-seller-card__avatar--guest {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--hm-neutral-100, #f3f4f6);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.hm-seller-card__contact-info {
    padding: 0.75rem 0;
}

.hm-seller-card__phone-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--hm-primary-600, #b45309);
    font-weight: 500;
    font-size: 0.95rem;
    text-decoration: none;
}

.hm-seller-card__phone-link:hover {
    color: var(--hm-primary-700, #92400e);
    text-decoration: underline;
}

.hm-seller-card__guest-note {
    display: flex;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: var(--hm-neutral-50, #f9fafb);
    border-radius: 8px;
    margin-top: 0.75rem;
}

.hm-seller-card__guest-note i {
    color: var(--hm-neutral-400, #9ca3af);
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 0.1rem;
}

.hm-seller-card__guest-note p {
    margin: 0;
    font-size: 0.8rem;
    color: var(--hm-neutral-600, #4b5563);
    line-height: 1.5;
}

.hm-seller-card__guest-note a {
    color: var(--hm-primary-600, #b45309);
}

/* =========================================================================
   GUEST INFO STEP (Step 4)
   ========================================================================= */

.hm-step-guest-info .hm-form-field__required {
    color: var(--hm-danger-500, #ef4444);
    margin-left: 2px;
}

.hm-step-guest-info .hm-form-field__optional {
    color: var(--hm-neutral-400, #9ca3af);
    font-size: 0.85em;
    font-weight: 400;
}

.hm-guest-benefits-inline {
    margin-top: 1rem;
}

/* =========================================================================
   GUEST MANAGEMENT PAGE
   ========================================================================= */

.hm-guest-manage {
    max-width: 640px;
    margin: 0 auto;
    padding: 2rem 0;
}

.hm-guest-manage__header {
    margin-bottom: 1.5rem;
}

.hm-guest-manage__header h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--hm-neutral-900, #111827);
    margin: 0 0 0.5rem;
}

.hm-guest-manage__header p {
    color: var(--hm-neutral-600, #4b5563);
    margin: 0;
}

.hm-guest-manage__card {
    background: #fff;
    border: 1px solid var(--hm-neutral-200, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
}

.hm-guest-manage__image {
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.hm-guest-manage__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hm-guest-manage__details {
    padding: 1.5rem;
}

.hm-guest-manage__title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--hm-neutral-900, #111827);
    margin: 0 0 0.75rem;
}

.hm-guest-manage__meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.hm-guest-manage__price {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--hm-success-600, #16a34a);
}

.hm-guest-manage__post-status {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
}

.hm-guest-manage__post-status--pending {
    background: var(--hm-warning-100, #fef3c7);
    color: var(--hm-warning-700, #a16207);
}

.hm-guest-manage__post-status--publish {
    background: var(--hm-success-100, #dcfce7);
    color: var(--hm-success-700, #15803d);
}

.hm-guest-manage__post-status--expired {
    background: var(--hm-neutral-100, #f3f4f6);
    color: var(--hm-neutral-500, #6b7280);
}

.hm-guest-manage__listing-status {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.hm-guest-manage__status-label {
    font-size: 0.85rem;
    color: var(--hm-neutral-500, #6b7280);
}

.hm-guest-manage__status-value {
    font-weight: 600;
    font-size: 0.85rem;
}

.hm-guest-manage__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.hm-guest-manage__pending-note {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--hm-warning-700, #a16207);
    background: var(--hm-warning-50, #fffbeb);
    padding: 0.75rem 1rem;
    border-radius: 8px;
    font-size: 0.9rem;
    margin-bottom: 1rem;
}

.hm-guest-manage__pending-note i {
    font-size: 1.2rem;
    flex-shrink: 0;
}

.hm-guest-manage__divider {
    border: none;
    border-top: 1px solid var(--hm-neutral-200, #e5e7eb);
    margin: 1rem 0;
}

.hm-guest-manage__danger-zone {
    margin-bottom: 1rem;
}

.hm-guest-manage__footer {
    margin-top: 2rem;
}

.hm-guest-manage__deleted {
    text-align: center;
    padding: 3rem 1.5rem;
}

.hm-guest-manage__deleted h3 {
    font-size: 1.25rem;
    margin: 1rem 0 0.5rem;
    color: var(--hm-neutral-900, #111827);
}

.hm-guest-manage__deleted p {
    color: var(--hm-neutral-600, #4b5563);
    margin: 0 0 1.5rem;
}

/* =========================================================================
   GUEST REVIEW NOTICE
   ========================================================================= */

.hm-review-notice--guest {
    background: var(--hm-warning-50, #fffbeb);
    border-color: var(--hm-warning-200, #fde68a);
}

.hm-review-notice--guest i {
    color: var(--hm-warning-500, #eab308);
}

/* =========================================================================
   SUCCESS SCREEN — GUEST ENHANCEMENTS
   ========================================================================= */

.hm-post-form__success-benefits {
    margin-top: 2rem;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}

/* =========================================================================
   BUTTON HELPERS
   ========================================================================= */

.hm-btn--outline {
    background: transparent;
    border: 1.5px solid var(--hm-neutral-300, #d1d5db);
    color: var(--hm-neutral-700, #374151);
}

.hm-btn--outline:hover {
    border-color: var(--hm-neutral-400, #9ca3af);
    background: var(--hm-neutral-50, #f9fafb);
}

.hm-btn--success {
    background: var(--hm-success-600, #16a34a);
    color: #fff;
    border: none;
}

.hm-btn--success:hover {
    background: var(--hm-success-700, #15803d);
}

.hm-btn--warning {
    background: var(--hm-warning-500, #eab308);
    color: #fff;
    border: none;
}

.hm-btn--warning:hover {
    background: var(--hm-warning-600, #ca8a04);
}

.hm-btn--danger {
    background: var(--hm-danger-500, #ef4444);
    color: #fff;
    border: none;
}

.hm-btn--danger:hover {
    background: var(--hm-danger-600, #dc2626);
}

.hm-btn--sm {
    font-size: 0.85rem;
    padding: 0.4rem 0.85rem;
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */

@media (max-width: 480px) {
    .hm-choice-screen {
        padding: 1rem 0;
    }

    .hm-choice-card {
        padding: 1.5rem 1rem;
    }

    .hm-guest-manage {
        padding: 1rem 0;
    }

    .hm-guest-manage__details {
        padding: 1rem;
    }

    .hm-guest-manage__actions {
        flex-direction: column;
    }

    .hm-guest-manage__actions .hm-btn {
        width: 100%;
        justify-content: center;
    }
}

/* =========================================================================
   ACCESSIBILITY
   ========================================================================= */

@media (prefers-reduced-motion: reduce) {
    .hm-choice-card {
        transition: none;
    }
}
