@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Lora:ital,wght@0,400;0,500;1,400;1,500&display=swap');

#astral-app, #astral-app * { box-sizing: border-box !important; }

#astral-app {
    display: block !important;
    background: #0a0812 !important;
    color: #f5f0e8 !important;
    font-family: 'Lora', Georgia, serif !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    max-width: 680px !important;
    margin: 0 auto !important;
    position: relative !important;
    padding: 0 !important;
}

#astral-app::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background-image:
        radial-gradient(1px 1px at 15% 20%, rgba(255,255,255,0.7) 0%, transparent 100%),
        radial-gradient(1px 1px at 80% 12%, rgba(255,255,255,0.5) 0%, transparent 100%),
        radial-gradient(1.5px 1.5px at 45% 65%, rgba(255,255,255,0.6) 0%, transparent 100%),
        radial-gradient(1px 1px at 60% 30%, rgba(255,255,255,0.4) 0%, transparent 100%),
        radial-gradient(1px 1px at 25% 80%, rgba(255,255,255,0.5) 0%, transparent 100%),
        radial-gradient(1px 1px at 90% 55%, rgba(255,255,255,0.35) 0%, transparent 100%),
        radial-gradient(ellipse at 50% 0%, rgba(107,63,160,0.4) 0%, transparent 55%) !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

#astral-app > * { position: relative !important; z-index: 1 !important; }

/* HEADER */
#astral-app .astral-header {
    text-align: center !important;
    padding: 48px 24px 36px !important;
    border-bottom: 1px solid rgba(201,168,76,0.2) !important;
    background: transparent !important;
    margin: 0 !important;
}

#astral-app .astral-logo-symbol {
    font-size: 38px !important;
    filter: drop-shadow(0 0 18px rgba(201,168,76,0.5)) !important;
    margin: 0 0 14px !important;
    display: block !important;
    color: #c9a84c !important;
    line-height: 1 !important;
    border: none !important; background: none !important; padding: 0 !important;
}

#astral-app .astral-title {
    font-family: 'Cinzel', serif !important;
    font-size: clamp(2rem, 6vw, 3.2rem) !important;
    font-weight: 700 !important;
    letter-spacing: 0.2em !important;
    color: #e8cc7a !important;
    text-shadow: 0 0 40px rgba(201,168,76,0.3) !important;
    margin: 0 0 10px !important;
    padding: 0 !important;
    line-height: 1.1 !important;
    border: none !important; background: none !important;
}

#astral-app .astral-subtitle {
    font-style: italic !important;
    color: rgba(245,240,232,0.6) !important;
    font-size: 1rem !important;
    letter-spacing: 0.04em !important;
    margin: 0 !important; padding: 0 !important;
    font-family: 'Lora', Georgia, serif !important;
    border: none !important; background: none !important;
}

/* BODY */
#astral-app .astral-body {
    padding: 36px 32px 40px !important;
    background: transparent !important;
    margin: 0 !important;
}

/* FORM */
#astral-app .astral-form-group { margin-bottom: 24px !important; }

#astral-app label,
#astral-app .astral-form-group label {
    display: block !important;
    font-size: 0.85rem !important;
    letter-spacing: 0.07em !important;
    color: rgba(245,240,232,0.6) !important;
    margin: 0 0 10px !important;
    padding: 0 !important;
    font-style: italic !important;
    font-family: 'Lora', Georgia, serif !important;
    font-weight: 400 !important;
    background: none !important; border: none !important;
}

#astral-app input[type="date"] {
    width: 100% !important;
    padding: 14px 18px !important;
    background: rgba(255,255,255,0.05) !important;
    border: 1px solid rgba(201,168,76,0.3) !important;
    border-radius: 6px !important;
    color: #f5f0e8 !important;
    font-family: 'Lora', Georgia, serif !important;
    font-size: 1.05rem !important;
    outline: none !important;
    box-shadow: none !important;
    display: block !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: border-color 0.25s, background 0.25s !important;
}

#astral-app input[type="date"]:focus {
    border-color: rgba(201,168,76,0.7) !important;
    background: rgba(255,255,255,0.08) !important;
}

#astral-app input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(1) opacity(0.5) !important;
    cursor: pointer !important;
}

/* BUTTON */
#astral-app .astral-btn {
    width: 100% !important;
    padding: 16px !important;
    background: linear-gradient(135deg, rgba(107,63,160,0.5), rgba(201,168,76,0.2)) !important;
    border: 1px solid rgba(201,168,76,0.4) !important;
    border-radius: 6px !important;
    color: #e8cc7a !important;
    font-family: 'Cinzel', serif !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.22em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    box-shadow: none !important; text-shadow: none !important;
    display: block !important; text-align: center !important;
    line-height: 1.4 !important; text-decoration: none !important;
    outline: none !important;
    transition: all 0.3s !important;
}

#astral-app .astral-btn:hover,
#astral-app .astral-btn:focus {
    background: linear-gradient(135deg, rgba(107,63,160,0.72), rgba(201,168,76,0.35)) !important;
    border-color: rgba(201,168,76,0.7) !important;
    color: #e8cc7a !important; text-decoration: none !important;
    box-shadow: 0 0 24px rgba(201,168,76,0.1) !important;
}

/* SIGN REVEAL */
#astral-app .astral-sign-reveal {
    text-align: center !important;
    padding: 28px 24px 24px !important;
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(201,168,76,0.22) !important;
    border-radius: 8px !important;
    margin-bottom: 24px !important;
    animation: astralFade 0.55s ease !important;
    display: block !important;
}

#astral-app .astral-sign-symbol {
    font-size: 3rem !important;
    margin: 0 0 8px !important;
    filter: drop-shadow(0 0 14px rgba(201,168,76,0.45)) !important;
    display: block !important; color: #e8cc7a !important;
    line-height: 1.2 !important; border: none !important;
    background: none !important; padding: 0 !important;
}

#astral-app .astral-sign-name {
    font-family: 'Cinzel', serif !important;
    font-size: 1.4rem !important;
    color: #e8cc7a !important;
    letter-spacing: 0.12em !important;
    margin: 0 0 4px !important; padding: 0 !important;
    border: none !important; background: none !important;
    font-weight: 600 !important; display: block !important;
}

#astral-app .astral-sign-dates {
    font-style: italic !important;
    color: rgba(245,240,232,0.6) !important;
    font-size: 0.9rem !important;
    font-family: 'Lora', Georgia, serif !important;
    display: block !important;
}

/* DIVIDER */
#astral-app .astral-divider {
    text-align: center !important;
    color: #c9a84c !important;
    margin: 28px 0 !important;
    font-size: 1.1rem !important;
    letter-spacing: 0.3em !important;
    opacity: 0.4 !important;
    display: block !important;
    background: none !important; border: none !important; padding: 0 !important;
}

/* CARDS */
#astral-app .astral-card {
    background: rgba(30,23,48,0.62) !important;
    border: 1px solid rgba(155,114,200,0.24) !important;
    border-radius: 8px !important;
    padding: 28px !important;
    margin-bottom: 16px !important;
    position: relative !important;
    overflow: hidden !important;
    animation: astralFade 0.65s ease !important;
    display: block !important;
}

#astral-app .astral-card::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    height: 1px !important;
    background: linear-gradient(to right, transparent, #9b72c8, transparent) !important;
    display: block !important;
}

#astral-app .astral-card-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 14px !important;
    background: none !important; border: none !important; padding: 0 !important;
}

#astral-app .astral-card-domain {
    font-family: 'Cinzel', serif !important;
    font-size: 0.62rem !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    color: #9b72c8 !important;
    background: none !important; border: none !important; padding: 0 !important;
}

#astral-app .astral-stars {
    display: flex !important; gap: 4px !important;
    background: none !important; border: none !important; padding: 0 !important;
}

#astral-app .astral-star {
    width: 6px !important; height: 6px !important;
    border-radius: 50% !important;
    background: rgba(201,168,76,0.25) !important;
    display: inline-block !important;
    padding: 0 !important; margin: 0 !important; border: none !important; flex-shrink: 0 !important;
}

#astral-app .astral-star.on { background: #c9a84c !important; }

#astral-app .astral-card-text {
    font-size: 1.05rem !important;
    line-height: 1.85 !important;
    color: rgba(245,240,232,0.85) !important;
    font-weight: 400 !important;
    margin: 0 !important; padding: 0 !important;
    font-family: 'Lora', Georgia, serif !important;
    background: none !important; border: none !important;
}

#astral-app .astral-lucky {
    display: flex !important; gap: 10px !important;
    flex-wrap: wrap !important; margin: 16px 0 0 !important;
    background: none !important; border: none !important; padding: 0 !important;
}

#astral-app .astral-lucky-pill {
    padding: 5px 14px !important;
    border: 1px solid rgba(201,168,76,0.3) !important;
    border-radius: 20px !important;
    font-size: 0.78rem !important;
    color: #e8cc7a !important;
    letter-spacing: 0.06em !important;
    background: transparent !important;
    font-family: 'Cinzel', serif !important;
    display: inline-block !important;
}

@keyframes astralFade {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 480px) {
    #astral-app .astral-body  { padding: 24px 18px 32px !important; }
    #astral-app .astral-title { font-size: 2rem !important; }
    #astral-app .astral-card  { padding: 20px 16px !important; }
}

/* Conseil du jour */
#astral-app .astral-conseil {
    margin: 16px 0 0 !important;
    padding: 14px 18px !important;
    border-left: 2px solid rgba(201,168,76,0.4) !important;
    font-style: italic !important;
    color: rgba(245,240,232,0.7) !important;
    font-size: 0.95rem !important;
    line-height: 1.7 !important;
    background: rgba(201,168,76,0.04) !important;
    border-radius: 0 4px 4px 0 !important;
    font-family: 'Lora', Georgia, serif !important;
}

/* État chargement bouton */
#astral-app .astral-btn:disabled {
    opacity: 0.8 !important;
    cursor: wait !important;
    animation: astralPulse 1.8s ease-in-out infinite !important;
}

@keyframes astralPulse {
    0%, 100% { border-color: rgba(201,168,76,0.38); }
    50%       { border-color: rgba(201,168,76,0.75); box-shadow: 0 0 20px rgba(201,168,76,0.15) !important; }
}

/* Message erreur */
#astral-app .astral-error {
    background: rgba(200,50,50,0.12) !important;
    border: 1px solid rgba(200,50,50,0.32) !important;
    border-radius: 6px !important;
    padding: 12px 16px !important;
    color: #f5a0a0 !important;
    font-size: 0.9rem !important;
    margin-top: 14px !important;
    display: block !important;
    font-family: 'Lora', Georgia, serif !important;
}

/* ── Bloc email post-tirage ───────────────────────────────────────────────── */
#astral-app .astral-email-block {
    margin-top: 28px !important;
    animation: astralFade 0.7s ease !important;
    display: block !important;
}

#astral-app .astral-email-inner {
    background: rgba(107,63,160,0.12) !important;
    border: 1px solid rgba(155,114,200,0.28) !important;
    border-radius: 10px !important;
    padding: 28px 28px 22px !important;
    text-align: center !important;
    position: relative !important;
    overflow: hidden !important;
}

#astral-app .astral-email-inner::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    height: 1px !important;
    background: linear-gradient(to right, transparent, #9b72c8, transparent) !important;
}

#astral-app .astral-email-icon {
    font-size: 1.8rem !important;
    color: #c9a84c !important;
    margin-bottom: 10px !important;
    display: block !important;
    filter: drop-shadow(0 0 10px rgba(201,168,76,0.35)) !important;
    line-height: 1 !important;
    border: none !important; background: none !important; padding: 0 !important;
}

#astral-app .astral-email-title {
    font-family: 'Cinzel', serif !important;
    font-size: 0.85rem !important;
    letter-spacing: 0.12em !important;
    color: #e8cc7a !important;
    margin: 0 0 6px !important;
    padding: 0 !important;
    border: none !important; background: none !important;
}

#astral-app .astral-email-sub {
    font-size: 0.88rem !important;
    color: rgba(245,240,232,0.58) !important;
    font-style: italic !important;
    margin: 0 0 18px !important;
    padding: 0 !important;
    font-family: 'Lora', Georgia, serif !important;
    border: none !important; background: none !important;
}

#astral-app .astral-email-row {
    display: flex !important;
    gap: 10px !important;
    margin-bottom: 10px !important;
}

#astral-app input#astral-email-input {
    flex: 1 !important;
    padding: 12px 16px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(201,168,76,0.28) !important;
    border-radius: 6px !important;
    color: #f5f0e8 !important;
    font-family: 'Lora', Georgia, serif !important;
    font-size: 0.98rem !important;
    outline: none !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    width: auto !important;
    display: block !important;
    transition: border-color 0.25s !important;
}

#astral-app input#astral-email-input:focus {
    border-color: rgba(201,168,76,0.65) !important;
    background: rgba(255,255,255,0.09) !important;
}

#astral-app .astral-btn-send {
    padding: 12px 20px !important;
    background: linear-gradient(135deg, rgba(107,63,160,0.55), rgba(201,168,76,0.22)) !important;
    border: 1px solid rgba(201,168,76,0.4) !important;
    border-radius: 6px !important;
    color: #e8cc7a !important;
    font-family: 'Cinzel', serif !important;
    font-size: 0.68rem !important;
    letter-spacing: 0.14em !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    box-shadow: none !important; text-shadow: none !important;
    text-decoration: none !important; outline: none !important;
    transition: all 0.25s !important;
    flex-shrink: 0 !important;
}

#astral-app .astral-btn-send:hover {
    background: linear-gradient(135deg, rgba(107,63,160,0.72), rgba(201,168,76,0.35)) !important;
    border-color: rgba(201,168,76,0.68) !important;
}

#astral-app .astral-btn-send:disabled {
    opacity: 0.6 !important; cursor: wait !important;
}

#astral-app .astral-email-msg:not([hidden]):not([style*="display: none"]) {
    font-size: 0.88rem !important;
    border-radius: 5px !important;
    padding: 10px 14px !important;
    margin: 8px 0 0 !important;
    display: block !important;
    font-family: 'Lora', Georgia, serif !important;
    border: none !important;
    text-align: left !important;
}

#astral-app .astral-email-err {
    background: rgba(200,50,50,0.12) !important;
    border: 1px solid rgba(200,50,50,0.3) !important;
    color: #f5a0a0 !important;
}

#astral-app .astral-email-ok {
    background: rgba(50,160,80,0.12) !important;
    border: 1px solid rgba(50,160,80,0.3) !important;
    color: #90d4a0 !important;
    text-align: center !important;
    font-size: 0.9rem !important;
}

#astral-app .astral-email-rgpd {
    font-size: 0.72rem !important;
    color: rgba(245,240,232,0.32) !important;
    margin: 12px 0 0 !important;
    padding: 0 !important;
    font-style: italic !important;
    font-family: 'Lora', Georgia, serif !important;
    border: none !important; background: none !important;
}

@media (max-width: 480px) {
    #astral-app .astral-email-row { flex-direction: column !important; }
    #astral-app .astral-btn-send  { width: 100% !important; }
}

/* Force masquage des éléments hidden — priorité absolue */
#astral-app [hidden],
#astral-app [style*="display: none"] {
    display: none !important;
}
