/* =============================================================
   Kheper — Mon Nom en Hiéroglyphes
   ============================================================= */

/* ── Hero ────────────────────────────────────────────────────── */
.nom-hero {
    position: relative;
    text-align: center;
    padding: 3rem 1.5rem 2rem;
    overflow: hidden;
}

.nom-hero-bg {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    letter-spacing: 0.5em;
    color: rgba(201,168,76,0.04);
    pointer-events: none;
    user-select: none;
    white-space: nowrap;
    overflow: hidden;
}

/* ── Sélecteur de mode ───────────────────────────────────────── */
.mode-switch {
    display: flex;
    justify-content: center;
    gap: 0;
    max-width: 560px;
    margin: 0 auto 2.5rem;
    padding: 0 1.5rem;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--bg-card);
}

.mode-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.85rem 1rem;
    background: transparent;
    border: none;
    color: var(--text-muted);
    font-family: var(--font-title);
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all var(--transition);
    border-right: 1px solid var(--border);
    white-space: nowrap;
}

.mode-btn:last-child { border-right: none; }

.mode-btn:hover {
    color: var(--gold);
    background: var(--gold-glow);
}

.mode-btn.active {
    color: var(--gold);
    background: rgba(201,168,76,0.10);
}

.mode-icon {
    font-size: 1rem;
    line-height: 1;
}

/* ── Panneaux ────────────────────────────────────────────────── */
.mode-panel {
    max-width: 720px;
    margin: 0 auto 4rem;
    padding: 0 1.5rem;
}

/* ── Zone de saisie (Mode 1) ─────────────────────────────────── */
.input-zone {
    text-align: center;
    margin-bottom: 2rem;
}

.input-group {
    display: flex;
    gap: 0.5rem;
    max-width: 420px;
    margin: 0 auto 0.5rem;
}

.prenom-input {
    flex: 1;
    background: var(--bg-card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 1.1rem;
    padding: 0.7rem 1rem;
    outline: none;
    transition: border-color var(--transition), box-shadow var(--transition);
    min-width: 0;
}

.prenom-input::placeholder { color: var(--text-muted); }

.prenom-input:focus {
    border-color: var(--gold-dim);
    box-shadow: 0 0 0 3px var(--gold-glow);
}

.btn-composer {
    background: var(--gold-dim);
    border: 1px solid var(--gold-dim);
    border-radius: var(--radius);
    color: var(--bg);
    font-family: var(--font-title);
    font-size: 0.68rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    padding: 0.7rem 1.25rem;
    cursor: pointer;
    transition: all var(--transition);
    white-space: nowrap;
}

.btn-composer:hover {
    background: var(--gold);
    border-color: var(--gold);
}

.btn-composer:disabled {
    opacity: 0.5;
    cursor: wait;
}

.input-hint {
    font-size: 0.78rem;
    color: var(--text-muted);
    font-style: italic;
}

/* ── Erreur ──────────────────────────────────────────────────── */
.nom-error {
    text-align: center;
    color: #e07070;
    font-size: 0.88rem;
    padding: 0.6rem 1rem;
    background: rgba(220,80,80,0.08);
    border: 1px solid rgba(220,80,80,0.18);
    border-radius: var(--radius);
    margin-bottom: 1rem;
}

/* ── Cartouche CSS ───────────────────────────────────────────── */
.cartouche-zone {
    text-align: center;
}

.cartouche-outer {
    display: flex;
    justify-content: center;
    padding: 1.5rem 1.5rem 2.5rem; /* padding bas pour les barres du nœud */
}

.cartouche {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem 2.5rem;
    border: 3px solid var(--gold);
    border-radius: 999px;
    min-width: 200px;
    min-height: 90px;
    background: linear-gradient(
        135deg,
        rgba(201,168,76,0.04) 0%,
        rgba(201,168,76,0.07) 100%
    );
    box-shadow:
        0 0 0 6px rgba(201,168,76,0.06),
        0 0 30px rgba(201,168,76,0.08);
    animation: cartouche-glow 4s ease-in-out infinite;
}

@keyframes cartouche-glow {
    0%, 100% { box-shadow: 0 0 0 6px rgba(201,168,76,0.06), 0 0 20px rgba(201,168,76,0.06); }
    50%       { box-shadow: 0 0 0 6px rgba(201,168,76,0.10), 0 0 40px rgba(201,168,76,0.14); }
}

/* Nœud du cartouche — deux barres verticales à droite */
.cartouche::before {
    content: '';
    position: absolute;
    right: -14px;
    top: -10px;
    bottom: -10px;
    width: 4px;
    background: var(--gold);
    border-radius: 2px;
}

.cartouche::after {
    content: '';
    position: absolute;
    right: -23px;
    top: -10px;
    bottom: -10px;
    width: 4px;
    background: var(--gold);
    border-radius: 2px;
}

.cartouche-glyphs {
    font-size: 2.8rem;
    line-height: 1;
    letter-spacing: 0.12em;
    color: var(--gold-light);
    filter: drop-shadow(0 2px 6px rgba(201,168,76,0.35));
    font-family: var(--font-hieroglyph);
}

.cartouche-translit {
    font-family: var(--font-title);
    font-size: 0.78rem;
    letter-spacing: 0.25em;
    color: var(--gold-dim);
    text-transform: uppercase;
    margin-top: 0.25rem;
}

/* ── Boutons d'action ────────────────────────────────────────── */
.cartouche-actions {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 0.5rem;
}

.btn-tts,
.btn-download {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 1.2rem;
    border-radius: var(--radius);
    font-family: var(--font-title);
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all var(--transition);
    text-decoration: none;
    white-space: nowrap;
}

.btn-tts {
    background: transparent;
    border: 1px solid var(--border-light);
    color: var(--text-dim);
}

.btn-tts:hover {
    border-color: var(--gold-dim);
    color: var(--gold);
    background: var(--gold-glow);
}

.btn-tts.playing {
    border-color: var(--turquoise);
    color: var(--turquoise-light);
    background: rgba(20,143,119,0.08);
}

.btn-tts.loading {
    opacity: 0.55;
    cursor: wait;
}

.btn-tts:disabled { cursor: wait; }

.btn-download {
    background: rgba(201,168,76,0.10);
    border: 1px solid var(--gold-dim);
    color: var(--gold);
}

.btn-download:hover {
    background: rgba(201,168,76,0.18);
    border-color: var(--gold);
    color: var(--gold-light);
}

/* ── Zone de sélection (Mode 2) ──────────────────────────────── */
.select-zone {
    text-align: center;
    margin-bottom: 2rem;
}

.select-label {
    display: block;
    font-family: var(--font-title);
    font-size: 0.68rem;
    letter-spacing: 0.22em;
    color: var(--gold-dim);
    text-transform: uppercase;
    margin-bottom: 0.75rem;
}

.select-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 0.75rem;
}

.prenom-select {
    background: var(--bg-card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 1rem;
    padding: 0.7rem 2.5rem 0.7rem 1rem;
    outline: none;
    cursor: pointer;
    min-width: 260px;
    max-width: 100%;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C9A84C' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.9rem center;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.prenom-select:focus {
    border-color: var(--gold-dim);
    box-shadow: 0 0 0 3px var(--gold-glow);
}

.prenom-select option {
    background: var(--bg-card);
    color: var(--text);
}

/* ── Note Privilège ──────────────────────────────────────────── */
.privilege-note {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.82rem;
    color: var(--text-dim);
    background: rgba(20,143,119,0.06);
    border: 1px solid rgba(20,143,119,0.15);
    border-radius: var(--radius);
    padding: 0.5rem 0.9rem;
    margin-top: 0.25rem;
}

.priv-icon { font-size: 1rem; }

.link-gold {
    color: var(--turquoise-light);
    text-decoration: none;
    font-family: var(--font-title);
    font-size: 0.78rem;
    letter-spacing: 0.1em;
}

.link-gold:hover { color: var(--gold); text-decoration: underline; }

/* ── Résultat Mode 2 ─────────────────────────────────────────── */
.prenom-result {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.prenom-info {
    text-align: center;
    margin-bottom: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.prenom-nom {
    font-family: var(--font-title);
    font-size: 1.6rem;
    color: var(--gold);
    letter-spacing: 0.25em;
    text-transform: uppercase;
}

.prenom-translit {
    font-family: var(--font-title);
    font-size: 0.78rem;
    letter-spacing: 0.2em;
    color: var(--gold-dim);
}

.prenom-sens {
    font-family: var(--font-body);
    font-size: 1.05rem;
    color: var(--text-dim);
    font-style: italic;
}

.prenom-explication {
    font-size: 0.88rem;
    color: var(--text-muted);
    max-width: 480px;
    line-height: 1.65;
    border-left: 2px solid var(--border-light);
    padding-left: 0.75rem;
    text-align: left;
    margin-top: 0.25rem;
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 600px) {
    .mode-switch { flex-direction: column; border-radius: var(--radius); }
    .mode-btn { border-right: none; border-bottom: 1px solid var(--border); }
    .mode-btn:last-child { border-bottom: none; }
    .input-group { flex-direction: column; }
    .cartouche-glyphs { font-size: 2rem; }
    .cartouche { padding: 1rem 2rem; }
    .prenom-nom { font-size: 1.2rem; }
    .cartouche-actions { flex-direction: column; align-items: center; }
}
