/* ── Bons cadeaux ── */

.gc-subtitle {
    color: var(--text-light);
    font-size: 0.95rem;
    margin-bottom: 24px;
}

/* Packages */
.gc-packages {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.gc-package {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    border: 2px solid var(--border);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s;
    gap: 12px;
}

@media (min-width: 600px) {
    .gc-package { padding: 20px 24px; }
}

.gc-package:hover {
    border-color: var(--primary);
    background: rgba(230, 126, 34, 0.03);
}

.gc-package.selected {
    border-color: var(--primary);
    background: #fef9f3;
    box-shadow: 0 0 0 3px rgba(230, 126, 34, 0.15);
}

.gc-package-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.gc-package-title {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text);
}

.gc-package-detail {
    font-size: 0.85rem;
    color: var(--text-light);
}

.gc-package-price {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--primary);
    white-space: nowrap;
}

@media (min-width: 600px) {
    .gc-package-price { font-size: 1.4rem; }
}

/* Recap achat */
.gc-recap {
    background: #fef9f3;
    border: 2px solid var(--primary-light);
    border-radius: var(--radius);
    padding: 16px 20px;
    margin-top: 16px;
}

/* Code display */
.gc-code-display {
    background: #f0f0f0;
    border: 2px dashed var(--primary);
    border-radius: var(--radius);
    padding: 20px;
    margin: 20px auto;
    max-width: 320px;
    text-align: center;
}

.gc-code-value {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--primary-dark);
    letter-spacing: 2px;
    font-family: 'Courier New', monospace;
    word-break: break-all;
}

@media (min-width: 600px) {
    .gc-code-value { font-size: 1.8rem; }
}

.gc-code-label {
    font-size: 0.85rem;
    color: var(--text-light);
    margin-top: 8px;
}

/* Gift code field in reservation */
.gift-code-section {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}

/* Gift-code-row : empilé sur mobile, en ligne sur desktop */
.gift-code-row {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: stretch;
}

.gift-code-row .form-group {
    flex: 1;
    margin-bottom: 0;
}

.gift-code-row .btn {
    width: 100%;
    padding: 12px 20px;
    font-size: 0.9rem;
    white-space: nowrap;
    height: 46px;
}

@media (min-width: 600px) {
    .gift-code-row {
        flex-direction: row;
        align-items: flex-end;
    }
    .gift-code-row .btn { width: auto; }
}

.gc-validation-msg {
    font-size: 0.85rem;
    margin-top: 8px;
    padding: 8px 12px;
    border-radius: 6px;
}

.gc-validation-msg.success {
    background: #e8f8ef;
    color: var(--success);
    border: 1px solid #27ae60;
}

.gc-validation-msg.error {
    background: #fde8e8;
    color: var(--danger);
    border: 1px solid var(--danger);
}

/* Recap deduction */
.recap-row.deduction {
    color: var(--success);
    font-weight: 600;
}

/* ── NB ──
   Ce fichier est désormais écrit en mobile-first.
   Les règles ci-dessus utilisent `min-width: 600px` pour
   élargir progressivement depuis le mobile. */
