/* ═══════════════════════════════════════════════════════════
   ALBOUNIANE — Inscription Particulier (signup)
   Charte héritée de style-index.css (chargé sur cette page).
   Aucune redéclaration de jetons ni de header : on évite tout
   conflit avec le header défini dans style-index.css.
═══════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════
   Section principale
   ═══════════════════════════════════════════════════════ */
.subscription-section {
    max-width: 820px;
    margin: calc(var(--header-height) + 3rem) auto 5rem;
    padding: 0 var(--gutter);
    animation: signupFadeIn 0.6s var(--ease) both;
}

@keyframes signupFadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}

.subscription-header {
    text-align: center;
    margin-bottom: calc(var(--space-unit) * 3);
}

/* eyebrow doré, comme .section-eyebrow de l'accueil */
.happy-subheading {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--gold-2);
    font-weight: 500;
    margin-bottom: var(--space-sm);
}
.happy-subheading::before,
.happy-subheading::after {
    content: '';
    width: 22px; height: 1px;
    background: var(--gold);
}

.happy-heading {
    font-family: var(--f-edit);
    font-weight: 400;
    font-size: clamp(2.2rem, 5vw, 3.4rem);
    letter-spacing: -0.02em;
    line-height: 1.06;
    color: var(--ink);
    margin: 0 auto var(--space-xs);
}

/* ═══════════════════════════════════════════════════════
   Formulaire — carte éditoriale crème
   ═══════════════════════════════════════════════════════ */
.subscription-form {
    position: relative;
    background: var(--paper);
    padding: clamp(1.8rem, 4vw, calc(var(--space-unit) * 3));
    border: 1px solid var(--line);
    border-radius: var(--border-radius-xl);
    box-shadow: var(--shadow-lg);
    transition: box-shadow 0.4s var(--ease), border-color 0.4s var(--ease);
    overflow: hidden;
}
.subscription-form::before {
    content: '';
    position: absolute;
    top: 0; inset-inline: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--gold) 30%, var(--gold) 70%, transparent);
}
.subscription-form:hover {
    box-shadow: var(--shadow-xl);
    border-color: var(--line-2);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg) var(--space-md);
}

.form-group {
    position: relative;
    margin-bottom: var(--space-sm);
    animation: signupSlideUp 0.5s var(--ease) forwards;
    opacity: 0;
}
@keyframes signupSlideUp {
    from { opacity: 0; transform: translateY(18px); }
    to   { opacity: 1; transform: translateY(0); }
}

.form-label {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: var(--space-xs);
    font-family: var(--f-mono);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--ink-mute);
}
.form-label::after {
    content: '*';
    color: var(--gold-2);
    font-size: 1em;
    margin-left: 2px;
}

.form-input {
    width: 100%;
    padding: 14px 16px;
    font-family: var(--f-ui);
    font-size: 1rem;
    color: var(--ink);
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--border-radius-md);
    transition: border-color 0.3s var(--ease), box-shadow 0.3s var(--ease), background 0.3s var(--ease);
}
.form-input::placeholder { color: var(--ink-soft); opacity: 1; }
.form-input:focus {
    border-color: var(--gold);
    background: var(--paper);
    box-shadow: 0 0 0 3px var(--gold-wash);
    outline: none;
}

.input-hint {
    display: block;
    font-size: 0.85rem;
    color: var(--ink-mute);
    margin-top: 4px;
    opacity: 0.85;
}

/* ─── Case à cocher conditions ─── */
.form-checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--space-xs);
    margin: var(--space-lg) 0;
    padding: var(--space-md);
    background: var(--gold-wash);
    border: 1px solid var(--line);
    border-inline-start: 3px solid var(--gold);
    border-radius: var(--border-radius-md);
    line-height: 1.5;
    animation: signupSlideUp 0.5s 0.5s var(--ease) forwards;
    opacity: 0;
}
.form-checkbox input {
    margin-top: 3px;
    flex-shrink: 0;
    accent-color: var(--gold-2);
}
.form-checkbox label { font-size: 0.92rem; color: var(--ink-2); }
.form-checkbox label a {
    color: var(--gold-2);
    text-decoration: underline;
    text-underline-offset: 2px;
    font-weight: 600;
}
.form-checkbox label a:hover { color: var(--ink); }

/* ─── Bouton — or de la charte ─── */
.submit-button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin: var(--space-lg) auto 0;
    max-width: 420px;
    width: 100%;
    padding: 17px 36px;
    font-family: var(--f-ui);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink);
    background: var(--gold);
    border: 1px solid var(--gold);
    border-radius: var(--border-radius-sm);
    cursor: pointer;
    transition: all 0.3s var(--ease);
    box-shadow: var(--shadow-sm);
}
.submit-button:hover {
    background: var(--gold-2);
    border-color: var(--gold-2);
    transform: translateY(-2px);
    box-shadow: var(--shadow-gold);
}
.submit-button:active { transform: translateY(0); }

/* ─── Erreurs ─── */
.error-message {
    color: var(--danger);
    font-size: 0.85rem;
    margin-top: 4px;
    font-weight: 500;
}
.form-input:invalid:not(:placeholder-shown) {
    border-color: var(--danger);
    background: #FBF0EE;
}

/* ─── Alertes ─── */
.alert {
    padding: 14px 16px;
    border-radius: var(--border-radius-md);
    margin-bottom: var(--space-lg);
    font-size: 0.92rem;
    line-height: 1.5;
    border: 1px solid transparent;
    box-shadow: var(--shadow-sm);
}
.alert-danger { background: #FBF0EE; color: var(--danger); border-color: #ECCFC9; }
.alert-info   { background: var(--bg-2); color: var(--ink-2); border-color: var(--line); }

/* ═══════════════════════════════════════════════════════
   Responsive
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .happy-heading { font-size: 2rem; }
    .subscription-form { padding: var(--space-lg); }
    .form-grid { grid-template-columns: 1fr; gap: var(--space-md); }
    .submit-button { width: 100%; max-width: none; }
}

/* Délais d'animation en cascade */
.form-group:nth-child(1) { animation-delay: 0.08s; }
.form-group:nth-child(2) { animation-delay: 0.14s; }
.form-group:nth-child(3) { animation-delay: 0.20s; }
.form-group:nth-child(4) { animation-delay: 0.26s; }
.form-group:nth-child(5) { animation-delay: 0.32s; }
.form-group:nth-child(6) { animation-delay: 0.38s; }
.form-group:nth-child(7) { animation-delay: 0.44s; }
.form-group:nth-child(8) { animation-delay: 0.50s; }

/* ═══════════════════════════════════════════════════════
   HEADER — état solide dès le chargement
   Ces pages n'ont pas de hero sombre ni le script de scroll :
   le header doit adopter d'emblée son apparence « scrolled »
   (fond crème + liens encre), sinon les liens clairs restent
   invisibles sur le fond crème. La spécificité reprend celle de
   style-index.css (.main-header:not(.scrolled) …) et l'emporte
   par l'ordre de chargement. Portée limitée à cette page :
   index.ejs n'est pas affecté.
   ═══════════════════════════════════════════════════════ */
.main-header:not(.scrolled) {
    background: rgba(252, 250, 245, 0.94);
    backdrop-filter: blur(20px) saturate(1.4);
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
    border-bottom-color: var(--line);
}
.main-header:not(.scrolled) .logo-text { color: var(--ink); }
.main-header:not(.scrolled) .logo-tag {
    color: var(--ink-mute);
    border-inline-start-color: var(--line-2);
}
.main-header:not(.scrolled) .nav-link { color: var(--ink-2); }
.main-header:not(.scrolled) .nav-link:hover,
.main-header:not(.scrolled) .nav-link.active { color: var(--ink); }
.main-header:not(.scrolled) .menu-line { background: var(--ink); }
.main-header:not(.scrolled) .logo-mark { border-color: var(--gold); }
.main-header:not(.scrolled) .logo-mark::after { background: var(--gold); }
.main-header:not(.scrolled) .language-trigger {
    background: var(--paper);
    border-color: var(--line);
}
.main-header:not(.scrolled) .language-current .language-code { color: var(--ink-2); }
.main-header:not(.scrolled) .language-chevron { color: var(--ink-mute); }