/*
 * Vorg — Forms & Tickets CSS
 * Palette : coral #E25B45 · teal #2C7873 · cream #F9F4EF · dark #1F2D30
 * Font    : Ubuntu (doit être chargée via le thème ou Elementor)
 */

:root {
    --vorg-coral:   #E25B45;
    --vorg-teal:    #2C7873;
    --vorg-cream:   #F9F4EF;
    --vorg-dark:    #1F2D30;
    --vorg-gray:    #6B7A7D;
    --vorg-border:  #DDD7D0;
    --vorg-radius:  8px;
    --vorg-font:    'Ubuntu', sans-serif;
}

/* ════════════════════════════════════════════
   PROGRESS BAR MULTI-STEP
════════════════════════════════════════════ */

.vorg-progress {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    position: relative;
    margin-bottom: 40px;
    padding: 0 8px;
    font-family: var(--vorg-font);
}

/* Ligne de fond */
.vorg-progress__bar {
    position: absolute;
    top: 20px;
    left: calc(12.5%);
    right: calc(12.5%);
    height: 3px;
    background: var(--vorg-border);
    border-radius: 999px;
    z-index: 0;
}

.vorg-progress__fill {
    height: 100%;
    background: var(--vorg-coral);
    border-radius: 999px;
    transition: width 0.4s ease;
    width: 0%;
}

/* Chaque étape */
.vorg-progress__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    flex: 1;
    z-index: 1;
    cursor: default;
}

.vorg-progress__bubble {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid var(--vorg-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    color: var(--vorg-gray);
    transition: all 0.3s ease;
}

.vorg-progress__label {
    font-size: 12px;
    color: var(--vorg-gray);
    text-align: center;
    transition: color 0.3s ease;
    line-height: 1.3;
}

/* État actif */
.vorg-progress__step.is-active .vorg-progress__bubble {
    background: var(--vorg-coral);
    border-color: var(--vorg-coral);
    color: #fff;
    box-shadow: 0 0 0 4px rgba(226, 91, 69, 0.15);
}
.vorg-progress__step.is-active .vorg-progress__label {
    color: var(--vorg-coral);
    font-weight: 600;
}

/* État complété */
.vorg-progress__step.is-completed .vorg-progress__bubble {
    background: var(--vorg-teal);
    border-color: var(--vorg-teal);
    color: #fff;
}
.vorg-progress__step.is-completed .vorg-progress__bubble::after {
    content: '✓';
}
.vorg-progress__step.is-completed .vorg-progress__bubble span {
    display: none;
}
.vorg-progress__step.is-completed .vorg-progress__label {
    color: var(--vorg-teal);
}

/* ════════════════════════════════════════════
   DASHBOARD TICKETS
════════════════════════════════════════════ */

.vorg-tickets-dashboard {
    font-family: var(--vorg-font);
    color: var(--vorg-dark);
}

.vorg-tickets__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 24px;
}

.vorg-tickets__header h2 {
    font-size: 22px;
    font-weight: 700;
    margin: 0;
}

.vorg-tickets__filters {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

.vorg-tickets__filters select,
.vorg-tickets__filters input {
    padding: 8px 12px;
    border: 1px solid var(--vorg-border);
    border-radius: var(--vorg-radius);
    font-family: var(--vorg-font);
    font-size: 14px;
    background: #fff;
    color: var(--vorg-dark);
    outline: none;
    transition: border-color 0.2s;
}

.vorg-tickets__filters select:focus,
.vorg-tickets__filters input:focus {
    border-color: var(--vorg-teal);
}

.vorg-tickets__list {
    display: grid;
    gap: 14px;
}

.vorg-tickets__loading,
.vorg-empty {
    text-align: center;
    padding: 40px;
    color: var(--vorg-gray);
    font-size: 15px;
}

.vorg-error {
    color: var(--vorg-coral);
    padding: 16px;
    background: rgba(226, 91, 69, 0.06);
    border-radius: var(--vorg-radius);
    border-left: 3px solid var(--vorg-coral);
}

/* Carte ticket */
.vorg-ticket-card {
    background: #fff;
    border: 1px solid var(--vorg-border);
    border-radius: var(--vorg-radius);
    padding: 18px 20px;
    transition: box-shadow 0.2s, border-color 0.2s;
}

.vorg-ticket-card:hover {
    box-shadow: 0 4px 16px rgba(31, 45, 48, 0.08);
    border-color: var(--vorg-teal);
}

.vorg-ticket-card__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.vorg-ticket-card__id {
    font-size: 12px;
    color: var(--vorg-gray);
    font-weight: 500;
}

.vorg-ticket-card__subject {
    font-size: 16px;
    font-weight: 600;
    color: var(--vorg-dark);
    margin-bottom: 8px;
    line-height: 1.4;
}

.vorg-ticket-card__meta {
    font-size: 12px;
    color: var(--vorg-gray);
    margin-bottom: 14px;
}

.vorg-ticket-card__actions {
    display: flex;
    gap: 10px;
    align-items: center;
    padding-top: 14px;
    border-top: 1px solid var(--vorg-border);
}

.vorg-ticket-card__actions select {
    padding: 6px 10px;
    border: 1px solid var(--vorg-border);
    border-radius: 6px;
    font-family: var(--vorg-font);
    font-size: 13px;
    background: var(--vorg-cream);
}

/* Badges */
.vorg-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.vorg-badge--status.is-open       { background: #e8f5e9; color: #2e7d32; }
.vorg-badge--status.is-progress   { background: #fff3e0; color: #e65100; }
.vorg-badge--status.is-resolved   { background: #e3f2fd; color: #1565c0; }
.vorg-badge--status.is-closed     { background: #f5f5f5; color: #616161; }

.vorg-badge--priority.is-high     { background: rgba(226, 91, 69, 0.1); color: var(--vorg-coral); }
.vorg-badge--priority.is-normal   { background: rgba(44, 120, 115, 0.1); color: var(--vorg-teal); }
.vorg-badge--priority.is-low      { background: #f5f5f5; color: #9e9e9e; }

/* Boutons Vorg — specificite renforcee pour override Elementor + theme */
.vorg-form-wrap .vorg-btn,
.vorg-portal .vorg-btn,
.vorg-tickets-dashboard .vorg-btn,
button.vorg-btn {
    display: inline-flex !important;
    align-items: center !important;
    padding: 8px 18px !important;
    border: none !important;
    border-radius: var(--vorg-radius) !important;
    font-family: var(--vorg-font) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: opacity 0.2s, transform 0.1s !important;
    text-decoration: none !important;
    line-height: 1.5 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    box-shadow: none !important;
}

.vorg-form-wrap .vorg-btn:hover,
.vorg-portal .vorg-btn:hover,
button.vorg-btn:hover { opacity: 0.88 !important; }
.vorg-form-wrap .vorg-btn:active,
.vorg-portal .vorg-btn:active,
button.vorg-btn:active { transform: scale(0.98) !important; }

.vorg-form-wrap .vorg-btn--primary,
.vorg-portal .vorg-btn--primary,
button.vorg-btn--primary { background: var(--vorg-coral) !important; color: #fff !important; }

.vorg-form-wrap .vorg-btn--secondary,
.vorg-portal .vorg-btn--secondary,
button.vorg-btn--secondary { background: var(--vorg-cream) !important; color: var(--vorg-dark) !important; border: 1px solid var(--vorg-border) !important; }

/* Navigation formulaire — taille plus genereux */
.vorg-form-nav .vorg-btn {
    padding: 12px 28px !important;
    font-size: 15px !important;
    border-radius: 8px !important;
}

/* Responsive tickets */
@media (max-width: 600px) {
    .vorg-tickets__header { flex-direction: column; align-items: flex-start; }
    .vorg-progress__label { display: none; }
    .vorg-progress__bubble { width: 32px; height: 32px; font-size: 12px; }
    .vorg-progress__bar { top: 16px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   FORMULAIRES CUSTOM VORG (shortcode [vorg_form])
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Conteneur ─────────────────────────────────────────────────────────── */
.vorg-form-wrap {
    max-width: 640px;
    margin: 0 auto;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* ── Barre de progression (multi-step) ────────────────────────────────── */
.vorg-progress-bar {
    margin-bottom: 32px;
}

.vorg-progress-bar__track {
    height: 4px;
    background: var(--vorg-border, #DDD7D0);
    border-radius: 2px;
    margin-bottom: 16px;
    overflow: hidden;
}

.vorg-progress-bar__fill {
    height: 100%;
    background: var(--vorg-teal, #2C7873);
    border-radius: 2px;
    transition: width 0.4s ease;
}

.vorg-progress-bar__steps {
    display: flex;
    justify-content: space-between;
}

.vorg-progress-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}

.vorg-progress-step__num {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--vorg-border, #DDD7D0);
    color: #999;
    font-size: 13px;
    font-weight: 700;
    transition: all 0.3s ease;
}

.vorg-progress-step.active .vorg-progress-step__num,
.vorg-progress-step.completed .vorg-progress-step__num {
    background: var(--vorg-teal, #2C7873);
    color: #fff;
}

.vorg-progress-step__label {
    font-size: 12px;
    color: #999;
    text-align: center;
    max-width: 100px;
}

.vorg-progress-step.active .vorg-progress-step__label {
    color: var(--vorg-dark, #1F2D30);
    font-weight: 600;
}

/* ── Etapes ────────────────────────────────────────────────────────────── */
.vorg-form-step {
    display: none;
    animation: vorg-step-in 0.3s ease;
}

.vorg-form-step.active {
    display: block;
}

@keyframes vorg-step-in {
    from { opacity: 0; transform: translateX(20px); }
    to   { opacity: 1; transform: translateX(0); }
}

.vorg-form-step__title {
    font-size: 20px;
    font-weight: 600;
    color: var(--vorg-dark, #1F2D30);
    margin: 0 0 24px;
}

/* ── Champs ────────────────────────────────────────────────────────────── */
.vorg-field {
    margin-bottom: 20px;
}

.vorg-field label,
.vorg-field legend {
    display: block;
    font-weight: 600;
    font-size: 14px;
    color: var(--vorg-dark, #1F2D30);
    margin-bottom: 6px;
}

.vorg-field fieldset {
    border: none;
    padding: 0;
    margin: 0;
}

.vorg-required {
    color: var(--vorg-coral, #E25B45);
}

.vorg-form .vorg-input {
    width: 100%;
    padding: 11px 14px;
    font-size: 15px;
    border: 1px solid var(--vorg-border, #DDD7D0);
    border-radius: 8px;
    background: #fff;
    color: var(--vorg-dark, #1F2D30);
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
}

.vorg-form .vorg-input:focus {
    outline: none;
    border-color: var(--vorg-teal, #2C7873);
    box-shadow: 0 0 0 3px rgba(44, 120, 115, 0.15);
}

.vorg-form .vorg-input::placeholder {
    color: #B0A8A0;
}

.vorg-form .vorg-input--error {
    border-color: var(--vorg-coral, #E25B45) !important;
    box-shadow: 0 0 0 3px rgba(226, 91, 69, 0.15) !important;
}

.vorg-form select.vorg-input {
    appearance: auto;
}

.vorg-form textarea.vorg-input {
    resize: vertical;
    min-height: 80px;
}

.vorg-input--file {
    padding: 8px;
    background: var(--vorg-cream, #F9F4EF);
}

/* Radio / Checkbox */
.vorg-radio-label,
.vorg-checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    margin-bottom: 6px;
    background: var(--vorg-cream, #F9F4EF);
    border: 1px solid var(--vorg-border, #DDD7D0);
    border-radius: 8px;
    font-size: 14px;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
}

.vorg-radio-label:hover,
.vorg-checkbox-label:hover {
    border-color: var(--vorg-teal, #2C7873);
    background: #F0F9F8;
}

.vorg-radio-label input,
.vorg-checkbox-label input {
    accent-color: var(--vorg-teal, #2C7873);
}

/* Erreur champ */
.vorg-field-error {
    color: var(--vorg-coral, #E25B45);
    font-size: 13px;
    margin-top: 4px;
}

/* ── Navigation (boutons prev/next) ────────────────────────────────────── */
.vorg-form-nav {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-top: 28px;
    padding-top: 20px;
    border-top: 1px solid var(--vorg-border, #DDD7D0);
}

.vorg-form-nav .vorg-btn {
    padding: 12px 28px;
    font-size: 15px;
    border-radius: 8px;
}

.vorg-form-nav .vorg-btn--primary {
    margin-left: auto;
}

/* ── Succes ────────────────────────────────────────────────────────────── */
.vorg-form-success {
    text-align: center;
    padding: 48px 24px;
    animation: vorg-step-in 0.4s ease;
}

.vorg-form-success__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--vorg-teal, #2C7873);
    color: #fff;
    font-size: 32px;
    margin-bottom: 16px;
}

.vorg-form-success p {
    font-size: 18px;
    color: var(--vorg-dark, #1F2D30);
    font-weight: 500;
}

/* ── Erreur globale ────────────────────────────────────────────────────── */
.vorg-form-error {
    padding: 14px 18px;
    background: #FDEDEC;
    color: #C0392B;
    border: 1px solid #F5B7B1;
    border-radius: 8px;
    font-size: 14px;
    margin-bottom: 16px;
}

/* ── Responsive formulaires ────────────────────────────────────────────── */
@media (max-width: 600px) {
    .vorg-form-wrap {
        padding: 0 12px;
    }

    .vorg-progress-step__label {
        display: none;
    }

    .vorg-form-nav {
        flex-direction: column;
    }

    .vorg-form-nav .vorg-btn {
        width: 100%;
        justify-content: center;
    }

    .vorg-form-nav .vorg-btn--primary {
        margin-left: 0;
    }
}
