/* ============================================================================
   NOUS FOREZ — Styles organisation (single + archive)
   Design system Bauhaus : --noir #1F1F1F, --rose #F62DAE, --creme #F7F5F0,
                           --vert #63A46C, Bebas Neue + Inter
   Cards référence : bordure 2px solid noir, ombre 4px 4px 0 var(--noir) au hover
   ============================================================================ */

/* ─── Page single ──────────────────────────────────────────────────────────── */

.nf-single-orga {
    max-width: 1100px;
    margin: 40px auto;
    padding: 0 24px;
}

.nf-single-orga .nf-alert {
    padding: 14px 20px;
    margin-bottom: 24px;
    border: 2px solid var(--noir);
    background: var(--creme);
    font-size: 15px;
}
.nf-single-orga .nf-alert p { margin: 0; }
.nf-single-orga .nf-alert-success { background: #E8F5E9; border-color: var(--vert); }
.nf-single-orga .nf-alert-info    { background: #E8F0FE; }
.nf-single-orga .nf-alert-warning { background: #FFF4E0; border-color: #E8A020; }
.nf-single-orga .nf-alert-error   { background: #FDECEA; border-color: #C33; }

/* ─── Hero ────────────────────────────────────────────────────────────────── */

.nf-orga-hero {
    display: grid;
    grid-template-columns: 160px 1fr;
    gap: 32px;
    align-items: start;
    padding: 32px;
    background: #fff;
    border: 2px solid var(--noir);
    margin-bottom: 32px;
}

.nf-orga-hero-logo img,
.nf-orga-hero-logo .nf-logo-placeholder {
    width: 160px;
    height: 160px;
    object-fit: cover;
    border: 2px solid var(--noir);
    display: flex;
    align-items: center;
    justify-content: center;
}

.nf-logo-placeholder {
    background: var(--rose);
    color: #fff;
    font-family: var(--font-bebas);
    font-size: 80px;
    line-height: 1;
}

.nf-logo-placeholder-lg {
    width: 160px;
    height: 160px;
    font-size: 100px;
}

.nf-orga-hero-info h1 {
    font-family: var(--font-bebas);
    font-size: 48px;
    line-height: 1.05;
    letter-spacing: 1px;
    color: var(--noir);
    margin: 0 0 12px;
}

.nf-orga-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 14px 22px;
    font-size: 14px;
    margin: 12px 0;
    color: var(--gris);
}

.nf-meta-item { display: inline-flex; align-items: center; gap: 4px; }
.nf-meta-item a { color: var(--noir); border-bottom: 1px dotted var(--gris-mid); }
.nf-meta-item a:hover { color: var(--rose); border-color: var(--rose); }

.nf-orga-reseaux {
    display: flex;
    gap: 8px;
    margin: 12px 0 16px;
}

.nf-reseau-link {
    width: 36px;
    height: 36px;
    border: 2px solid var(--noir);
    background: var(--creme);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-bebas);
    font-size: 18px;
    color: var(--noir);
    transition: all .15s;
}

.nf-reseau-link:hover {
    background: var(--rose);
    color: #fff;
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--noir);
}

.nf-orga-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
}

/* ─── Badges ──────────────────────────────────────────────────────────────── */

.nf-badge {
    display: inline-block;
    padding: 4px 10px;
    border: 2px solid var(--noir);
    background: var(--creme);
    font-family: var(--font-inter);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    line-height: 1.5;
    color: var(--noir);
}
.nf-badge-gray    { background: var(--gris-light); }
.nf-badge-green   { background: var(--vert); color: #fff; border-color: var(--vert); }
.nf-badge-amber   { background: #FFF4E0; border-color: #E8A020; color: #B87000; }
.nf-badge-membre  { background: var(--rose); color: #fff; border-color: var(--rose); }

/* ─── Onglets ─────────────────────────────────────────────────────────────── */

.nf-orga-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    border-bottom: 2px solid var(--noir);
    margin-bottom: 32px;
}

.nf-orga-nav-item {
    padding: 14px 22px;
    font-family: var(--font-bebas);
    font-size: 16px;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--gris-mid);
    border: 2px solid transparent;
    border-bottom: none;
    background: transparent;
    transition: all .12s;
    margin-bottom: -2px;
    position: relative;
}

.nf-orga-nav-item:hover {
    color: var(--noir);
    background: var(--creme);
}

.nf-orga-nav-item.active {
    color: var(--noir);
    background: #fff;
    border-color: var(--noir);
    border-bottom: 2px solid #fff;
    z-index: 2;
}

.nf-nav-badge {
    display: inline-block;
    background: var(--rose);
    color: #fff;
    font-family: var(--font-inter);
    font-size: 11px;
    padding: 1px 6px;
    margin-left: 6px;
    border-radius: 10px;
    vertical-align: middle;
}

/* ─── Body ────────────────────────────────────────────────────────────────── */

.nf-orga-body { background: #fff; border: 2px solid var(--noir); padding: 32px; }

.nf-orga-section { margin-bottom: 36px; }
.nf-orga-section:last-child { margin-bottom: 0; }

.nf-orga-section h2 {
    font-family: var(--font-bebas);
    font-size: 28px;
    letter-spacing: 1px;
    margin: 0 0 18px;
    color: var(--noir);
}

.nf-section-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 18px;
    flex-wrap: wrap;
    gap: 10px;
}

.nf-section-header h1 {
    font-family: var(--font-bebas);
    font-size: 40px;
    margin: 0;
}

.nf-orga-description {
    font-size: 17px;
    line-height: 1.65;
    color: var(--gris);
}

/* ─── Liste actions à venir (accueil) ──────────────────────────────────────── */

.nf-actions-liste {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 12px;
}

.nf-action-card-mini {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px;
    background: var(--creme);
    border: 2px solid var(--noir);
    transition: all .15s;
    color: var(--noir);
}

.nf-action-card-mini:hover {
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--noir);
    background: #fff;
}

.nf-action-date {
    font-family: var(--font-bebas);
    font-size: 18px;
    letter-spacing: .5px;
    background: var(--rose);
    color: #fff;
    padding: 8px 12px;
    border: 2px solid var(--noir);
    text-align: center;
    line-height: 1.1;
    white-space: nowrap;
}

.nf-action-info { flex: 1; display: flex; flex-direction: column; gap: 3px; font-size: 14px; }
.nf-action-info strong { font-size: 15px; line-height: 1.3; }

/* ─── Formulaire contact ──────────────────────────────────────────────────── */

.nf-orga-contact { padding-top: 24px; border-top: 2px solid var(--gris-light); }
.nf-contact-form { margin-top: 16px; }

/* ─── Boutons ─────────────────────────────────────────────────────────────── */

.nf-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 18px;
    border: 2px solid var(--noir);
    font-family: var(--font-bebas);
    font-size: 15px;
    letter-spacing: 1px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all .12s;
    line-height: 1.2;
    text-decoration: none;
}
.nf-btn-sm { padding: 6px 12px; font-size: 13px; }

.nf-btn-primary { background: var(--rose); color: #fff; }
.nf-btn-primary:hover { transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--noir); }

.nf-btn-secondary { background: var(--creme); color: var(--noir); }
.nf-btn-secondary:hover { background: #fff; transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--noir); }
.nf-btn-secondary.nf-following { background: var(--vert); color: #fff; border-color: var(--vert); }

.nf-btn-link {
    color: var(--rose);
    border-bottom: 1px dotted var(--rose);
    text-decoration: none;
    font-size: 14px;
}
.nf-btn-link:hover { color: var(--noir); border-color: var(--noir); }

.nf-btn:disabled { opacity: .6; cursor: not-allowed; transform: none !important; box-shadow: none !important; }

/* ─── Modale rejoindre ────────────────────────────────────────────────────── */

.nf-modale {
    position: fixed;
    inset: 0;
    background: rgba(31, 31, 31, .65);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    padding: 20px;
}

.nf-modale-content {
    background: #fff;
    border: 2px solid var(--noir);
    box-shadow: 8px 8px 0 var(--noir);
    padding: 32px;
    max-width: 720px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
}

.nf-modale-close {
    position: absolute;
    top: 12px;
    right: 16px;
    background: transparent;
    border: none;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: var(--noir);
}
.nf-modale-close:hover { color: var(--rose); }

.nf-modale-content h2 {
    font-family: var(--font-bebas);
    font-size: 32px;
    margin: 0 0 16px;
}

.nf-niveaux-choix {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
    margin: 18px 0;
}

.nf-niveau-card {
    border: 2px solid var(--noir);
    padding: 16px;
    background: var(--creme);
    cursor: pointer;
    transition: all .12s;
}
.nf-niveau-card:hover { background: #fff; transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--noir); }
.nf-niveau-card.nf-niveau-selected {
    background: var(--rose);
    color: #fff;
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--noir);
}
.nf-niveau-card h3 { font-family: var(--font-bebas); font-size: 22px; margin: 0 0 8px; letter-spacing: 1px; }
.nf-niveau-card ul { margin: 0; padding: 0; font-size: 13px; }
.nf-niveau-card ul li { padding: 2px 0; border-bottom: 1px dotted rgba(0,0,0,.15); }
.nf-niveau-card.nf-niveau-selected ul li { border-color: rgba(255,255,255,.3); }

/* ─── Formulaires globaux ─────────────────────────────────────────────────── */

.nf-form { display: flex; flex-direction: column; gap: 18px; }
.nf-form-group { display: flex; flex-direction: column; gap: 6px; }
.nf-form-group label {
    font-family: var(--font-bebas);
    font-size: 14px;
    letter-spacing: .8px;
    text-transform: uppercase;
    color: var(--noir);
}

.nf-form input[type=text],
.nf-form input[type=email],
.nf-form input[type=tel],
.nf-form input[type=url],
.nf-form input[type=date],
.nf-form input[type=number],
.nf-form select,
.nf-form textarea {
    padding: 10px 12px;
    border: 2px solid var(--noir);
    background: #fff;
    font-size: 15px;
    font-family: var(--font-inter);
    width: 100%;
}

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

.nf-form input:focus,
.nf-form select:focus,
.nf-form textarea:focus {
    outline: none;
    border-color: var(--rose);
    box-shadow: 4px 4px 0 var(--noir);
}

.nf-form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px; }

.nf-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding-top: 8px;
}

.nf-fieldset {
    border: 2px solid var(--noir);
    padding: 18px 20px 20px;
}
.nf-fieldset legend {
    font-family: var(--font-bebas);
    font-size: 16px;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 0 8px;
    background: var(--creme);
}

.nf-checkbox-label,
.nf-radio-label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 6px 0;
    cursor: pointer;
    font-size: 14px;
}
.nf-checkbox-label input,
.nf-radio-label input { margin-top: 3px; }

.nf-checkbox-group { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 4px 16px; }

.nf-error {
    color: #C33;
    font-size: 13px;
    margin: 4px 0 0;
}

.nf-empty {
    text-align: center;
    padding: 32px 20px;
    background: var(--creme);
    border: 2px dashed var(--gris-mid);
    color: var(--gris-mid);
}

.nf-empty-inline { color: var(--gris-mid); font-style: italic; }

.nf-form-intro {
    color: var(--gris-mid);
    font-size: 14px;
    margin-bottom: 12px;
}

/* ─── Dashboard create-orga page ──────────────────────────────────────────── */

.nf-dashboard {
    max-width: 920px;
    margin: 40px auto;
    padding: 0 24px;
}

/* ════════════════════════════════════════════════════════════════════════════
   ARCHIVE (répertoire des organisations)
   ════════════════════════════════════════════════════════════════════════════ */

.nf-archive-orgas {
    max-width: 1280px;
    margin: 40px auto;
    padding: 0 24px;
}

.nf-archive-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 28px;
    padding-bottom: 18px;
    border-bottom: 2px solid var(--noir);
}

.nf-archive-header h1 {
    font-family: var(--font-bebas);
    font-size: 48px;
    line-height: 1;
    letter-spacing: 1px;
    margin: 0 0 6px;
}

.nf-archive-header p { margin: 0; color: var(--gris-mid); font-size: 15px; }

.nf-archive-filtres {
    background: #fff;
    border: 2px solid var(--noir);
    padding: 16px;
    margin-bottom: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.nf-archive-search {
    display: flex;
    gap: 8px;
}

.nf-archive-search input[type=text] {
    flex: 1;
    padding: 10px 14px;
    border: 2px solid var(--noir);
    background: var(--creme);
    font-size: 15px;
}

.nf-archive-search input:focus { outline: none; background: #fff; box-shadow: 4px 4px 0 var(--noir); }

.nf-archive-filtres-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.nf-archive-filtres-row select,
.nf-archive-filtres-row input[type=text] {
    padding: 8px 12px;
    border: 2px solid var(--noir);
    background: var(--creme);
    font-size: 14px;
    min-width: 160px;
}

.nf-archive-stats {
    color: var(--gris-mid);
    font-size: 14px;
    margin-bottom: 16px;
}

.nf-orgas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px;
}

.nf-orga-card-grid {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 2px solid var(--noir);
    color: var(--noir);
    text-decoration: none;
    transition: all .15s;
    overflow: hidden;
}

.nf-orga-card-grid:hover {
    transform: translate(-3px, -3px);
    box-shadow: 6px 6px 0 var(--noir);
}

.nf-orga-card-logo {
    height: 160px;
    background: var(--creme);
    border-bottom: 2px solid var(--noir);
    display: flex;
    align-items: center;
    justify-content: center;
}

.nf-orga-card-logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.nf-orga-card-logo .nf-logo-placeholder {
    width: 100%;
    height: 100%;
    font-size: 90px;
    border: none;
}

.nf-orga-card-body { padding: 16px; display: flex; flex-direction: column; gap: 8px; }

.nf-orga-card-body h2 {
    font-family: var(--font-bebas);
    font-size: 22px;
    line-height: 1.1;
    margin: 0;
    letter-spacing: .5px;
}

.nf-orga-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.nf-tag {
    display: inline-block;
    padding: 2px 8px;
    border: 1px solid var(--noir);
    background: var(--creme);
    font-size: 11px;
    font-weight: 500;
}
.nf-tag-type  { background: var(--rose); color: #fff; border-color: var(--rose); }
.nf-tag-theme { background: var(--gris-light); }

.nf-orga-adresse { font-size: 13px; color: var(--gris-mid); margin: 0; }
.nf-orga-desc    { font-size: 13px; color: var(--gris); margin: 0; line-height: 1.45; }

.nf-orga-card-footer {
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding-top: 8px;
}

/* ─── Pagination ──────────────────────────────────────────────────────────── */

.nf-pagination {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 32px;
}

.nf-pagination .page-numbers {
    padding: 8px 12px;
    border: 2px solid var(--noir);
    background: var(--creme);
    color: var(--noir);
    font-family: var(--font-bebas);
    font-size: 15px;
    text-decoration: none;
    transition: all .12s;
}
.nf-pagination .page-numbers:hover { background: #fff; transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--noir); }
.nf-pagination .page-numbers.current { background: var(--rose); color: #fff; border-color: var(--rose); }

/* ─── Responsive ──────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .nf-orga-hero {
        grid-template-columns: 1fr;
        padding: 20px;
    }
    .nf-orga-hero-logo {
        justify-self: center;
    }
    .nf-orga-hero-info h1 { font-size: 36px; }
    .nf-orga-body { padding: 20px; }
    .nf-archive-header h1 { font-size: 36px; }
    .nf-orga-nav-item { padding: 10px 14px; font-size: 14px; }
}
