* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

:root {
    --bg: #f6f7f7;
    --surface: #ffffff;
    --surface-soft: #e9f0f1;
    --text: #2f2f2f;
    --muted: #6b6b6b;
    --primary: #2f6473;
    --primary-dark: #1f4652;
    --dark: #333333;
    --border: #dde5e7;
    --shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
    --radius: 18px;
    --max-width: 1300px;
}

body {
    font-family: Arial, sans-serif;
    background-color: var(--bg);
    color: var(--text);
    line-height: 1.5;
}

img {
    display: block;
    max-width: 100%;
}

/* HEADER */

.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.04);
}

.header-inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 1rem 2rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 2rem;
}

.header-content {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.site-logo {
    width: 120px;
    height: auto;
    border-radius: 18px;
}

.site-branding {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.site-branding h1 {
    font-size: 1.9rem;
    color: var(--text);
    font-weight: 700;
}

.site-branding p {
    font-size: 0.98rem;
    color: var(--muted);
}

.navigation ul {
    display: flex;
    align-items: center;
    gap: 1.4rem;
    list-style: none;
}

.navigation a {
    text-decoration: none;
    font-size: 1rem;
    color: var(--text);
    font-weight: 600;
    transition: color 0.25s ease;
}

.navigation a:hover {
    color: var(--primary);
}

/* HERO */

.hero {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 5rem 2rem 4rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 3rem;
}

.hero-content {
    width: 50%;
    max-width: 620px;
    padding: 2.2rem;
    border-radius: var(--radius);
    background: linear-gradient(180deg, #e9f0f1 0%, #e3ecee 100%);
    box-shadow: var(--shadow);
    border: 1px solid #dde5e7;
}

.tagline {
    display: inline-block;
    font-size: 0.9rem;
    color: #2f6473;
    background-color: #e3eef0;
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 1rem;
    font-weight: 700;
}

.hero-content h2 {
    font-size: 3.2rem;
    line-height: 1.1;
    color: var(--primary);
    margin-bottom: 1rem;
}

.hero-content p {
    font-size: 1.12rem;
    color: #262626;
    margin-bottom: 1rem;
    line-height: 1.7;
}

.cta-buttons {
    display: flex;
    gap: 1rem;
    margin-top: 1.4rem;
    flex-wrap: wrap;
}

.cta-button {
    display: inline-block;
    padding: 0.9rem 1.5rem;
    background-color: var(--primary);
    color: white;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 700;
    border-radius: 10px;
    transition: background-color 0.3s ease, transform 0.3s ease;
}

.cta-button:hover {
    background-color: var(--primary-dark);
    transform: translateY(-2px);
}

.cta-button-secondary {
    background-color: var(--dark);
}

.cta-button-secondary:hover {
    background-color: #555;
}

.hero-features {
    display: flex;
    gap: 1.2rem;
    flex-wrap: wrap;
    margin-top: 1.4rem;
}

.hero-features span {
    color: var(--muted);
    font-size: 0.95rem;
    font-weight: 500;
    background: none;
    border: none;
    padding: 0;
    border-radius: 0;
    position: relative;
    padding-left: 0.9rem;
}

.hero-features span::before {
    content: "";
    width: 5px;
    height: 5px;
    background-color: var(--primary);
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.hero-image {
    width: 50%;
    display: flex;
    justify-content: flex-end;
}

.hero-image img {
    width: 92%;
    border-radius: 22px;
    box-shadow: 0 18px 35px rgba(0, 0, 0, 0.12);
    transition: transform 0.3s ease;
}

.hero-image img:hover {
    transform: scale(1.02);
}

/* SECTIONS */

.materiaux-section,
.fonctionnement-section,
.contact-section {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 2rem;
}

.section-title {
    text-align: center;
    margin-bottom: 2rem;
}

.section-title h2 {
    font-size: 2.2rem;
    color: var(--text);
    margin-bottom: 0.5rem;
}

.section-title p {
    font-size: 1.08rem;
    color: var(--muted);
}

/* CARDS */

.cards-grid {
    display: flex;
    justify-content: center;
    gap: 2rem;
    flex-wrap: wrap;
}

.card {
    width: 30%;
    min-width: 260px;
    background-color: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.3rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.materiaux-section .card {
    min-height: 400px;
}

.card:hover {
    transform: translateY(-6px);
    box-shadow: 0 16px 30px rgba(0, 0, 0, 0.12);
}

.card-image {
    width: 100%;
    height: 200px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 1rem;
}

.card-img {
    width: 80%;
    max-width: 220px;
    max-height: 190px;
    object-fit: contain;
    border-radius: 12px;
}

.card h3 {
    font-size: 1.4rem;
    color: var(--primary);
    margin: 1rem 0 0.5rem;
}

.card p {
    font-size: 1rem;
    color: var(--muted);
    line-height: 1.6;
}

/* STEPS */

.fonctionnement-section {
    background-color: #e9f0f1;
    border-radius: 28px;
    margin-top: 2rem;
}

.steps-grid {
    display: flex;
    justify-content: center;
    gap: 2rem;
    flex-wrap: wrap;
}

.step-card {
    width: 30%;
    min-width: 260px;
    background-color: white;
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    text-align: center;
}

.step-number {
    width: 46px;
    height: 46px;
    margin: 0 auto 1rem;
    border-radius: 50%;
    background-color: var(--primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

.step-card h3 {
    color: var(--primary);
    margin-bottom: 0.7rem;
    font-size: 1.35rem;
}

.step-card p {
    color: var(--muted);
    line-height: 1.6;
}

/* CONTACT */

.contact-card {
    max-width: 500px;
    margin: 0 auto;
    background-color: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 2rem;
    text-align: center;
}

.contact-card h3 {
    color: var(--primary);
    margin-bottom: 1rem;
    font-size: 1.5rem;
}

.contact-card p {
    color: var(--muted);
    margin-bottom: 0.5rem;
}

/* FOOTER */

.site-footer {
    margin-top: 3rem;
    background-color: white;
    border-top: 1px solid var(--border);
    padding: 1.5rem 2rem;
    text-align: center;
    color: var(--muted);
}

/* RESPONSIVE */

@media (max-width: 980px) {
    .header-inner,
    .hero {
        flex-direction: column;
        align-items: flex-start;
    }

    .hero-content,
    .hero-image {
        width: 100%;
        max-width: 100%;
    }

    .hero-image {
        justify-content: center;
    }

    .navigation ul {
        flex-wrap: wrap;
    }

    .card,
    .step-card {
        width: 100%;
    }

    .hero-content h2 {
        font-size: 2.5rem;
    }
}

@media (max-width: 640px) {
    .header-inner,
    .hero,
    .materiaux-section,
    .fonctionnement-section,
    .contact-section {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .site-logo {
        width: 90px;
    }

    .site-branding h1 {
        font-size: 1.5rem;
    }

    .hero-content {
        padding: 1.4rem;
    }

    .hero-content h2 {
        font-size: 2rem;
    }

    .section-title h2 {
        font-size: 1.8rem;
    }
}
/* PAGES INTERNES */

.page-main {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 3rem 2rem 4rem;
}

.page-hero {
    margin-bottom: 2rem;
}

.annonces-section {
    padding-top: 1rem;
}

.annonces-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
    align-items: stretch;
}

.annonce-card {
    background-color: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.5rem;
    border: 1px solid var(--border);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.annonce-badge {
    display: inline-block;
    background-color: #e9f0f1;
    color: var(--primary);
    font-size: 0.88rem;
    font-weight: 700;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    margin-bottom: 1rem;
}

.annonce-card h3 {
    font-size: 1.5rem;
    color: var(--text);
    margin-bottom: 1rem;
}

.annonce-meta {
    list-style: none;
    margin-bottom: 1rem;
    color: var(--muted);
}

.annonce-meta li {
    margin-bottom: 0.35rem;
}

.annonce-card p {
    color: var(--muted);
    line-height: 1.6;
    margin-bottom: 1.2rem;
}

.annonce-button {
    font-size: 0.95rem;
    margin-top: auto;
}

.form-section {
    padding-top: 1rem;
}

.form-card {
    background-color: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 2rem;
    border: 1px solid var(--border);
    max-width: 900px;
    margin: 0 auto;
}

.form-row {
    display: flex;
    gap: 1.2rem;
    margin-bottom: 1rem;
}

.form-group {
    display: flex;
    flex-direction: column;
    flex: 1;
    margin-bottom: 1rem;
}

.form-group label {
    margin-bottom: 0.5rem;
    font-weight: 700;
    color: var(--text);
}

.form-group input,
.form-group select,
.form-group textarea {
    padding: 0.9rem 1rem;
    border: 1px solid var(--border);
    border-radius: 10px;
    font-size: 1rem;
    background-color: #fff;
    color: var(--text);
}

.form-group textarea {
    min-height: 140px;
    resize: vertical;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(210, 105, 30, 0.12);
}

.form-actions {
    margin-top: 1rem;
}

@media (max-width: 900px) {
    .form-row {
        flex-direction: column;
        gap: 0;
    }
}
/* AMÉLIORATIONS PRO MYSQL */
.navigation a.active {
    color: var(--primary);
}

.card-topline {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.detail-card {
    max-width: 900px;
    margin: 0 auto;
}

.contact-panel {
    margin-top: 1.5rem;
    padding: 1.2rem;
    border-radius: 16px;
    background: #e9f0f1;
    border: 1px solid #dde5e7;
}

.contact-panel h3 {
    color: var(--primary);
    margin-bottom: 0.5rem;
}

.inline-actions {
    display: flex;
    gap: 0.8rem;
    flex-wrap: wrap;
    align-items: center;
    margin-top: 1.2rem;
}

.inline-form {
    display: inline-flex;
    margin: 0;
}

.inline-form button {
    border: none;
    cursor: pointer;
    font-family: inherit;
}

.status-badge {
    display: inline-block;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: #e8f4ea;
    color: #245b2f;
    font-weight: 700;
    font-size: 0.88rem;
    margin-bottom: 1rem;
}

.status-badge.recuperee {
    background: #e9f0f1;
    color: #6b6b6b;
}

.status-badge.expiree {
    background: #fdecec;
    color: #8a1f1f;
}

.delivery-badge {
    display: inline-block;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: #eef6ff;
    color: #285b7a;
    font-weight: 800;
    font-size: 0.88rem;
    margin-bottom: 1rem;
}

.search-card .form-row:last-child {
    margin-bottom: 0;
}

.annonce-card {
    position: relative;
}

.annonce-card .annonce-badge,
.annonce-card .status-badge {
    margin-bottom: 0;
}

.form-card a,
.empty-state a,
.annonce-card a {
    word-break: break-word;
}

@media (max-width: 900px) {
    .annonces-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .header-inner {
        align-items: center;
    }

    .navigation {
        width: 100%;
    }

    .navigation ul {
        width: 100%;
        justify-content: center;
        gap: 0.6rem;
    }

    .navigation a {
        display: inline-block;
        padding: 0.45rem 0.65rem;
        border-radius: 999px;
        background: #e9f0f1;
        font-size: 0.92rem;
    }

    .hero {
        padding-top: 2rem;
        gap: 1.5rem;
    }

    .hero-content h2 {
        font-size: 2.1rem;
    }

    .hero-content p {
        font-size: 1rem;
    }

    .cta-button {
        width: 100%;
        text-align: center;
    }

    .inline-actions,
    .inline-form {
        width: 100%;
    }

    .inline-form button,
    .inline-actions a {
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    .search-actions {
        width: 100%;
    }
}


/* CARTE HERO ACCUEIL MAT’LOCAL */
.hero-card {
    width: 92%;
    background-color: white;
    border-radius: 22px;
    box-shadow: var(--shadow);
    border: 1px solid var(--border);
    padding: 2rem;
}
.hero-card-badge {
    display: inline-block;
    background-color: #e8f4ea;
    color: #245b2f;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    margin-bottom: 1rem;
}
.hero-card h3 {
    color: var(--primary);
    margin-bottom: 1rem;
    font-size: 1.6rem;
}
.hero-card p {
    color: var(--text);
    margin-bottom: 1rem;
    line-height: 1.7;
}
.hero-card ul {
    list-style: none;
    margin-top: 1rem;
}
.hero-card li {
    color: var(--muted);
    margin-bottom: 0.5rem;
}
@media (max-width: 980px) {
    .hero-card {
        width: 100%;
        max-width: 620px;
    }
}
@media (max-width: 640px) {
    .hero-card {
        width: 100%;
        padding: 1.4rem;
        border-radius: 18px;
    }
    .hero-card h3 {
        font-size: 1.35rem;
    }
    .hero-card p,
    .hero-card li {
        font-size: 0.95rem;
    }
    .hero-card-badge {
        font-size: 0.8rem;
    }
}

/* RÉSUMÉ DE RECHERCHE AVEC RAYON */
.search-summary {
    max-width: 1000px;
    margin: 0 auto 1.5rem;
    padding: 1rem 1.2rem;
    border-radius: 14px;
    background-color: #e9f0f1;
    border: 1px solid var(--border);
    color: var(--muted);
    text-align: center;
}

.search-summary strong {
    color: var(--text);
}


/* PAGINATION ET TRI */
.pagination {
    max-width: 1000px;
    margin: 2rem auto 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pagination-link,
.pagination-dots {
    min-width: 42px;
    padding: 0.7rem 0.9rem;
    border-radius: 12px;
    border: 1px solid var(--border);
    background-color: var(--surface);
    color: var(--text);
    text-decoration: none;
    font-weight: 700;
    text-align: center;
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.04);
}

.pagination-link:hover {
    color: white;
    background-color: var(--primary);
    border-color: var(--primary);
}

.pagination-link.active {
    color: white;
    background-color: var(--primary);
    border-color: var(--primary);
}

.pagination-dots {
    background: transparent;
    box-shadow: none;
    color: var(--muted);
}

@media (max-width: 640px) {
    .pagination {
        justify-content: stretch;
    }

    .pagination-link,
    .pagination-dots {
        flex: 1 1 auto;
        min-width: 44px;
    }
}
/* NOTE DE RESPONSABILITÉ */

.responsibility-note {
    max-width: 1000px;
    margin: 0 auto 1.5rem;
    padding: 1rem 1.2rem;
    border-radius: 14px;
    background-color: #f4f7f8;
    border: 1px solid var(--border);
    color: var(--muted);
    text-align: center;
    font-size: 0.95rem;
}

.responsibility-note p {
    margin: 0;
    line-height: 1.6;
}


/* RECHERCHE D'ADRESSE MODERNE */
.search-card {
    max-width: 1100px;
    margin: 0 auto 1.6rem;
    padding: 1.6rem;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid var(--border);
    border-radius: 20px;
    box-shadow: var(--shadow);
}

.search-card .form-row {
    align-items: flex-start;
}

.address-search-group {
    position: relative;
    flex: 2;
    z-index: 20;
}

.address-search-group input[type="text"] {
    min-height: 54px;
    padding-left: 2.8rem;
    background:
        linear-gradient(90deg, rgba(47, 100, 115, 0.08), rgba(255, 255, 255, 0) 35%),
        #fff;
    border: 1px solid #cfdadc;
    box-shadow: 0 8px 18px rgba(47, 100, 115, 0.06);
}

.address-search-group::before {
    content: "⌕";
    position: absolute;
    left: 1rem;
    top: 2.75rem;
    color: var(--primary);
    font-size: 1.2rem;
    font-weight: 700;
    pointer-events: none;
    z-index: 2;
}

.address-suggestions {
    display: none;
    position: absolute;
    z-index: 999;
    top: calc(100% - 1.35rem);
    left: 0;
    right: 0;
    width: 100%;
    max-height: 340px;
    overflow-y: auto;
    padding: 0.5rem;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid var(--border);
    border-radius: 18px;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.16);
}

.address-suggestions.visible {
    display: flex !important;
    flex-direction: column;
    gap: 0.35rem;
}

.address-suggestions-title {
    padding: 0.45rem 0.65rem 0.25rem;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.address-suggestion-item {
    appearance: none;
    display: grid !important;
    grid-template-columns: 38px minmax(0, 1fr);
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    padding: 0.8rem;
    border: 1px solid transparent;
    border-radius: 14px;
    background: #fff;
    color: var(--text);
    text-align: left;
    cursor: pointer;
    font-family: inherit;
    box-shadow: none;
}

.address-suggestion-item:hover,
.address-suggestion-item:focus {
    background: #f4f8f9;
    border-color: #cfdadc;
    outline: none;
}

.address-suggestion-icon {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #e9f0f1;
    color: var(--primary);
    font-size: 1.1rem;
    font-weight: 800;
}

.address-suggestion-content {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.address-suggestion-label {
    display: block;
    color: var(--text);
    font-size: 0.98rem;
    line-height: 1.3;
    white-space: normal;
}

.address-suggestion-meta {
    display: block;
    color: var(--muted);
    font-size: 0.86rem;
    line-height: 1.3;
}

.address-suggestion-empty {
    padding: 0.9rem 1rem;
    color: var(--muted);
    font-size: 0.92rem;
    line-height: 1.45;
}

.field-help {
    margin-top: 0.45rem;
    color: var(--muted);
    font-size: 0.88rem;
    line-height: 1.4;
}

.reset-link {
    color: var(--muted);
    text-decoration: none;
    font-weight: 700;
}

.reset-link:hover {
    color: var(--primary);
}

@media (max-width: 900px) {
    .search-card {
        padding: 1.1rem;
        border-radius: 20px;
    }

    .address-suggestions {
        position: static;
        margin-top: 0.55rem;
        max-height: 300px;
    }

    .address-search-group::before {
        top: 2.65rem;
    }
}

/* AJUSTEMENT ERGONOMIE ANNONCES + RECHERCHE */
.annonces-section {
    max-width: 1200px;
    margin: 0 auto;
}

.search-card,
.search-summary,
.annonces-grid,
.pagination,
.empty-state {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

.search-card {
    position: relative;
    padding: 1.45rem;
    margin-bottom: 1.6rem;
    border-radius: 26px;
    background:
        linear-gradient(135deg, rgba(47, 100, 115, 0.08), rgba(255, 255, 255, 0) 35%),
        rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.08);
}

.search-card .form-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.85fr);
    gap: 1.15rem;
    margin-bottom: 1rem;
}

.search-card .form-group {
    margin-bottom: 0;
}

.search-card label {
    font-size: 0.95rem;
    letter-spacing: 0.01em;
}

.search-card input,
.search-card select {
    min-height: 54px;
    border-radius: 14px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.search-card input:focus,
.search-card select:focus {
    box-shadow: 0 0 0 4px rgba(47, 100, 115, 0.12);
}

.search-actions {
    justify-content: flex-end;
    padding-top: 1.75rem;
}

.search-actions .cta-button {
    width: 100%;
    min-height: 54px;
    border: none;
    cursor: pointer;
    border-radius: 14px;
    box-shadow: 0 10px 20px rgba(47, 100, 115, 0.18);
}

.reset-link {
    width: fit-content;
    margin-top: 0.55rem;
    padding: 0.25rem 0;
}

.search-summary {
    margin-bottom: 1.6rem;
    border-radius: 18px;
    background: linear-gradient(180deg, #edf4f5, #e7f0f1);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.04);
}

.annonces-grid {
    gap: 1.6rem;
}

.annonce-card {
    overflow: hidden;
    padding: 1.55rem;
    border-radius: 24px;
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.07);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.annonce-card:hover {
    transform: translateY(-4px);
    border-color: #cfdadc;
    box-shadow: 0 20px 42px rgba(0, 0, 0, 0.10);
}

.annonce-card h3 {
    font-size: 1.55rem;
    margin: 0.85rem 0 1rem;
}

.card-topline {
    margin-bottom: 0;
}

.annonce-badge,
.status-badge,
.delivery-badge {
    padding: 0.45rem 0.85rem;
    font-size: 0.84rem;
}

.annonce-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
    margin-bottom: 1.1rem;
}

.annonce-meta li {
    margin: 0;
    padding: 0.65rem 0.75rem;
    border-radius: 14px;
    background-color: #f6f8f9;
    border: 1px solid #edf1f2;
    font-size: 0.93rem;
}

.annonce-card p {
    padding-top: 0.2rem;
    margin-bottom: 1.25rem;
}

.annonce-card .inline-actions {
    margin-top: auto;
}

.annonce-button {
    width: 100%;
    text-align: center;
    border-radius: 14px;
}

@media (max-width: 900px) {
    .annonces-section {
        max-width: 100%;
    }

    .search-card .form-row {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .search-actions {
        padding-top: 0;
    }

    .annonce-meta {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .search-card {
        border-radius: 20px;
    }

    .annonce-card {
        border-radius: 20px;
        padding: 1.2rem;
    }
}

/* PAGE DÉTAIL ANNONCE MODERNISÉE */
.detail-page-main {
    padding-top: 2.4rem;
}

.detail-shell,
.detail-empty-state {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.detail-hero-card,
.detail-section-card,
.detail-empty-state {
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid var(--border);
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.08);
    border-radius: 28px;
}

.detail-hero-card {
    padding: 1.7rem;
    margin-bottom: 1.6rem;
    background:
        linear-gradient(135deg, rgba(47, 100, 115, 0.10), rgba(255, 255, 255, 0) 42%),
        rgba(255, 255, 255, 0.98);
}

.detail-hero-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.4rem;
}

.detail-back-link {
    color: var(--primary);
    text-decoration: none;
    font-weight: 800;
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
    background-color: #edf4f5;
    border: 1px solid #dbe8ea;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

.detail-back-link:hover {
    transform: translateY(-2px);
    background-color: #e5f0f2;
}

.detail-eyebrow {
    display: inline-block;
    color: var(--primary);
    font-weight: 800;
    font-size: 0.88rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.45rem;
}

.detail-title-block h2 {
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 1.05;
    color: var(--text);
    margin-bottom: 0.65rem;
}

.detail-title-block p {
    color: var(--muted);
    font-size: 1.08rem;
    margin-bottom: 1.45rem;
}

.detail-meta-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.75rem;
}

.detail-meta-item {
    min-height: 92px;
    padding: 0.85rem;
    border-radius: 18px;
    background-color: #f6f8f9;
    border: 1px solid #edf1f2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.25rem;
}

.detail-meta-item span {
    color: var(--muted);
    font-size: 0.86rem;
    font-weight: 700;
}

.detail-meta-item strong {
    color: var(--text);
    font-size: 1rem;
    line-height: 1.25;
}

.detail-content-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.75fr);
    gap: 1.6rem;
    align-items: start;
}

.detail-section-card {
    padding: 1.6rem;
    border-radius: 26px;
}

.detail-section-card h3 {
    color: var(--primary);
    font-size: 1.45rem;
    margin-bottom: 0.8rem;
}

.detail-description-text {
    color: var(--muted);
    line-height: 1.75;
    font-size: 1.02rem;
    padding: 1rem;
    border-radius: 18px;
    background-color: #f8fafb;
    border: 1px solid #edf1f2;
    min-height: 180px;
}

.detail-contact-card {
    position: sticky;
    top: 120px;
    background:
        linear-gradient(180deg, #edf4f5, #ffffff 58%),
        #ffffff;
}

.detail-contact-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background-color: var(--primary);
    color: white;
    font-size: 1.35rem;
    margin-bottom: 1rem;
}

.detail-contact-card p {
    color: var(--muted);
    line-height: 1.6;
    margin-bottom: 1rem;
}

.detail-contact-value {
    padding: 0.95rem 1rem;
    border-radius: 16px;
    background-color: #ffffff;
    border: 1px solid #dbe8ea;
    color: var(--text);
    font-weight: 800;
    word-break: break-word;
}

.detail-contact-value a {
    color: var(--primary);
    text-decoration: none;
}

.detail-contact-value a:hover {
    text-decoration: underline;
}

.detail-empty-state {
    padding: 2rem;
    text-align: center;
}

.detail-empty-state h3 {
    color: var(--text);
    font-size: 2rem;
    margin-bottom: 0.5rem;
}

.detail-empty-state p {
    color: var(--muted);
}

@media (max-width: 1050px) {
    .detail-meta-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .detail-content-grid {
        grid-template-columns: 1fr;
    }

    .detail-contact-card {
        position: static;
    }
}

@media (max-width: 760px) {
    .detail-page-main {
        padding-top: 1.2rem;
    }

    .detail-hero-card,
    .detail-section-card,
    .detail-empty-state {
        border-radius: 20px;
    }

    .detail-hero-card,
    .detail-section-card {
        padding: 1.2rem;
    }

    .detail-hero-top {
        flex-direction: column;
    }

    .detail-back-link {
        width: 100%;
        text-align: center;
    }

    .detail-meta-grid {
        grid-template-columns: 1fr;
    }

    .detail-content-grid {
        gap: 1rem;
    }
}

/* PAGE DÉPOSER UNE ANNONCE MODERNISÉE */
.deposit-page-main {
    padding-top: 2.4rem;
}

.deposit-title {
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.5rem;
}

.deposit-title .detail-eyebrow {
    margin-bottom: 0.6rem;
}

.deposit-card,
.deposit-alert {
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
}

.deposit-card {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
}

.deposit-section-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 24px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.07);
    padding: 1.6rem;
}

.deposit-section-heading {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.2rem;
}

.deposit-section-heading h3 {
    color: var(--text);
    font-size: 1.35rem;
    margin-bottom: 0.2rem;
}

.deposit-section-heading p {
    color: var(--muted);
    line-height: 1.55;
}

.deposit-step {
    flex: 0 0 auto;
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: #e9f0f1;
    color: var(--primary);
    font-weight: 800;
    border: 1px solid var(--border);
}

.deposit-address-group {
    margin-bottom: 1rem;
}

.privacy-choice {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    padding: 1rem;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, #f8fbfb 0%, #eef5f6 100%);
    cursor: pointer;
}

.privacy-choice input {
    width: 20px;
    height: 20px;
    margin-top: 0.15rem;
    accent-color: var(--primary);
}

.privacy-choice span {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.privacy-choice strong {
    color: var(--text);
}

.privacy-choice small {
    color: var(--muted);
    line-height: 1.45;
}

.deposit-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 1rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 22px;
    padding: 1rem 1.2rem;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.06);
}

.deposit-actions .cta-button {
    min-width: 230px;
    text-align: center;
    border: none;
    cursor: pointer;
    font-family: inherit;
}

.detail-route-button {
    width: 100%;
    text-align: center;
    margin-top: 1.1rem;
}

.detail-route-help {
    display: block;
    margin-top: 0.75rem;
    text-align: center;
}

@media (max-width: 760px) {
    .deposit-section-card {
        padding: 1.2rem;
        border-radius: 20px;
    }

    .deposit-section-heading {
        flex-direction: column;
        gap: 0.7rem;
    }

    .privacy-choice {
        padding: 0.9rem;
    }

    .deposit-actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .deposit-actions .cta-button,
    .deposit-actions .reset-link {
        width: 100%;
        text-align: center;
    }
}

/* REPRISE PROPRE : MES ANNONCES + CARTES PROPRIÉTAIRE */
.owner-page-main {
    padding-top: 4rem;
}

.owner-page-main .page-hero {
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2rem;
}

.annonce-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
    margin: 1rem 0 1.1rem;
}

.annonce-info-pill {
    min-width: 0;
    padding: 0.78rem 0.9rem;
    border-radius: 16px;
    background-color: #f6f8f9;
    border: 1px solid #e8eef0;
    color: var(--muted);
    line-height: 1.35;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.annonce-info-pill strong {
    color: var(--text);
    font-weight: 800;
}

.annonce-info-pill.warning {
    background-color: #fff8e8;
    border-color: #f0dca8;
    color: #6b5520;
}

.owner-annonce-card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.owner-annonce-card h3 {
    margin-top: 0.8rem;
}

.owner-annonce-card p {
    margin-top: 0.2rem;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.owner-annonce-card .inline-actions {
    margin-top: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 0.75rem;
    align-items: stretch;
}

.owner-annonce-card .inline-actions > .cta-button:first-child {
    width: 100%;
}

.owner-annonce-card .inline-form,
.owner-annonce-card .inline-form button {
    height: 100%;
}

.owner-annonce-card .inline-form button,
.owner-annonce-card .inline-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 900px) {
    .annonce-info-grid {
        grid-template-columns: 1fr;
    }

    .owner-annonce-card .inline-actions {
        grid-template-columns: 1fr;
    }

    .owner-annonce-card .inline-form,
    .owner-annonce-card .inline-form button,
    .owner-annonce-card .inline-actions a {
        width: 100%;
    }
}

/* DÉPÔT MULTI-ANNONCES */
.materials-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.material-entry {
    padding: 1.1rem;
    border-radius: 20px;
    border: 1px solid #e2eaec;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbfb 100%);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.04);
}

.material-entry-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.material-entry-header strong {
    color: var(--primary);
    font-size: 1.05rem;
}

.material-remove-button,
.add-material-button {
    appearance: none;
    border: 0;
    border-radius: 999px;
    font-family: inherit;
    font-weight: 800;
    cursor: pointer;
}

.material-remove-button {
    padding: 0.45rem 0.75rem;
    background-color: #fdecec;
    color: #8a1f1f;
}

.material-remove-button:hover {
    background-color: #f9dada;
}

.add-material-button {
    width: 100%;
    margin-top: 1rem;
    padding: 0.95rem 1rem;
    background-color: #e9f0f1;
    color: var(--primary);
    border: 1px dashed #b9cdd2;
}

.add-material-button:hover {
    background-color: #dfeaec;
}

.multi-material-section .form-row:last-child {
    margin-bottom: 0;
}

@media (max-width: 760px) {
    .material-entry {
        padding: 0.95rem;
        border-radius: 18px;
    }

    .material-entry-header {
        flex-direction: column;
        align-items: stretch;
        gap: 0.65rem;
    }

    .material-remove-button {
        width: 100%;
        text-align: center;
    }
}

/* ALIGNEMENT BADGES + OPTIONS DÉPÔT ÉPURÉES */
.card-topline {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.card-topline .annonce-badge,
.card-topline .status-badge,
.card-topline .delivery-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    margin: 0 !important;
    line-height: 1;
    white-space: nowrap;
    vertical-align: middle;
}

.delivery-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border-radius: 999px;
    background: #eef6ff;
    color: #285b7a;
    font-weight: 800;
}

.privacy-options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
    margin-top: 0.9rem;
}

.privacy-options .privacy-choice {
    height: 100%;
    margin: 0;
}

.deposit-section-card .field-help {
    margin-bottom: 0;
}

@media (max-width: 760px) {
    .card-topline {
        gap: 0.45rem;
    }

    .card-topline .annonce-badge,
    .card-topline .status-badge,
    .card-topline .delivery-badge {
        flex: 1 1 auto;
        min-width: fit-content;
        min-height: 36px;
    }

    .privacy-options {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }
}

/* CORRECTION FINALE : cartes annonces sans doublon et sans débordement */
.annonce-card,
.owner-annonce-card,
.detail-section-card,
.detail-hero-card {
    min-width: 0;
}

.annonce-card h3,
.owner-annonce-card h3,
.detail-title-block h2,
.annonce-meta li,
.annonce-info-pill,
.detail-meta-item,
.detail-meta-item strong,
.detail-description-text,
.annonce-card p,
.owner-annonce-card p {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
}

.annonce-meta li,
.annonce-info-pill,
.detail-meta-item {
    white-space: normal;
}

.annonce-meta li strong,
.annonce-info-pill strong,
.detail-meta-item span {
    overflow-wrap: normal;
    word-break: normal;
}

.annonce-card p,
.owner-annonce-card p,
.detail-description-text {
    white-space: normal;
}

.card-topline {
    min-width: 0;
}

.card-topline .annonce-badge,
.card-topline .status-badge,
.card-topline .delivery-badge {
    max-width: 100%;
    text-align: center;
}

@media (max-width: 520px) {
    .card-topline .annonce-badge,
    .card-topline .status-badge,
    .card-topline .delivery-badge {
        flex: 1 1 100%;
        white-space: normal;
        line-height: 1.25;
    }
}

/* AJUSTEMENT HEADER MOBILE : titre mieux centré + onglets plus lisibles */
@media (max-width: 900px) {
    .site-header {
        position: sticky;
        top: 0;
    }

    .header-inner {
        padding: 0.5rem 0.85rem 0.6rem;
        gap: 0.5rem;
        align-items: center;
    }

    .header-content {
        width: 100%;
        display: grid;
        grid-template-columns: 52px minmax(0, 1fr) 52px;
        align-items: center;
        gap: 0.55rem;
    }

    .site-logo {
        width: 52px;
        border-radius: 13px;
        justify-self: start;
    }

    .site-branding {
        align-items: center;
        text-align: center;
        min-width: 0;
    }

    .site-branding h1 {
        font-size: 1.35rem;
        line-height: 1.05;
        margin: 0;
        white-space: nowrap;
    }

    .site-branding p {
        display: none;
    }

    .navigation {
        width: 100%;
        overflow-x: auto;
        padding-bottom: 0.05rem;
        scrollbar-width: none;
    }

    .navigation::-webkit-scrollbar {
        display: none;
    }

    .navigation ul {
        width: max-content;
        min-width: 100%;
        display: flex;
        flex-wrap: nowrap;
        justify-content: center;
        gap: 0.45rem;
        padding: 0 0.05rem;
    }

    .navigation a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 42px;
        padding: 0.62rem 0.9rem;
        border-radius: 999px;
        background: #e9f0f1;
        color: var(--text);
        font-size: 1.02rem;
        font-weight: 800;
        line-height: 1;
        white-space: nowrap;
        border: 1px solid #dbe6e8;
    }

    .navigation a.active {
        background: var(--primary);
        color: #fff;
        border-color: var(--primary);
    }

    .page-main,
    .deposit-page-main,
    .detail-page-main,
    .owner-page-main {
        padding-top: 1.25rem;
    }
}

@media (max-width: 520px) {
    .header-inner {
        padding: 0.45rem 0.7rem 0.55rem;
    }

    .header-content {
        grid-template-columns: 46px minmax(0, 1fr) 46px;
    }

    .site-logo {
        width: 46px;
        border-radius: 12px;
    }

    .site-branding h1 {
        font-size: 1.28rem;
    }

    .navigation ul {
        justify-content: flex-start;
    }

    .navigation a {
        min-height: 44px;
        padding: 0.66rem 0.95rem;
        font-size: 1.04rem;
    }
}


/* OPTIMISATION MOBILE : CARTES ANNONCES COMPACTES SANS TOUCHER AU HEADER */
@media (max-width: 760px) {
    .annonces-section .annonces-grid {
        gap: 0.9rem;
    }

    .annonces-section .annonce-card {
        padding: 0.95rem;
        border-radius: 18px;
        box-shadow: 0 10px 24px rgba(0, 0, 0, 0.07);
    }

    .annonces-section .card-topline {
        display: flex;
        flex-wrap: nowrap;
        align-items: center;
        gap: 0.3rem;
        width: 100%;
        min-width: 0;
        overflow: visible;
        margin-bottom: 0.65rem;
    }

    .annonces-section .card-topline .annonce-badge,
    .annonces-section .card-topline .status-badge,
    .annonces-section .card-topline .delivery-badge {
        flex: 0 1 auto;
        min-width: 0;
        min-height: 28px;
        padding: 0.3rem 0.38rem;
        font-size: 0.68rem;
        line-height: 1.1;
        white-space: nowrap;
        overflow: visible;
        text-overflow: clip;
        border-radius: 999px;
        letter-spacing: -0.01em;
    }

    .annonces-section .card-topline .delivery-badge {
        flex-shrink: 0;
    }

    .annonces-section .annonce-card h3 {
        font-size: 1.18rem;
        margin: 0.45rem 0 0.65rem;
        line-height: 1.2;
    }

    .annonces-section .annonce-meta {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.4rem;
        margin-bottom: 0.7rem;
    }

    .annonces-section .annonce-meta li {
        padding: 0.48rem 0.55rem;
        border-radius: 12px;
        font-size: 0.82rem;
        line-height: 1.25;
    }

    .annonces-section .annonce-card p {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        padding-top: 0;
        margin-bottom: 0.85rem;
        font-size: 0.9rem;
        line-height: 1.45;
        max-height: 2.65rem;
    }

    .annonces-section .inline-actions {
        margin-top: 0.2rem;
    }

    .annonces-section .annonce-button {
        min-height: 42px;
        padding: 0.72rem 1rem;
        border-radius: 12px;
        font-size: 0.92rem;
    }
}

@media (max-width: 390px) {
    .annonces-section .card-topline {
        gap: 0.2rem;
    }

    .annonces-section .card-topline .annonce-badge,
    .annonces-section .card-topline .status-badge,
    .annonces-section .card-topline .delivery-badge {
        font-size: 0.61rem;
        padding-left: 0.24rem;
        padding-right: 0.24rem;
        letter-spacing: -0.025em;
    }

    .annonces-section .annonce-meta {
        grid-template-columns: 1fr;
    }
}


/* MESSAGE DE BIENVENUE CENTRÉ */
.welcome-message,
.alert-success {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto 1.4rem;
    padding: 1.2rem 1.4rem;
    text-align: center;
    border-radius: 22px;
    background: linear-gradient(180deg, #eef6f7 0%, #ffffff 100%);
    border: 1px solid var(--border);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.06);
}

.welcome-message h3,
.alert-success h3 {
    margin: 0 0 0.35rem;
    color: var(--primary);
    font-size: 1.35rem;
}

.welcome-message p,
.alert-success p {
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

@media (max-width: 760px) {
    .welcome-message,
    .alert-success {
        padding: 1rem;
        border-radius: 18px;
    }

    .welcome-message h3,
    .alert-success h3 {
        font-size: 1.15rem;
    }
}


/* CORRECTION MOBILE : cartes annonces homogènes et description réellement limitée */
@media (max-width: 760px) {
    .annonces-section .annonces-grid {
        gap: 0.85rem;
    }

    .annonces-section .annonce-card {
        padding: 0.9rem;
        border-radius: 18px;
        min-width: 0;
    }

    .annonces-section .card-topline {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.28rem;
        align-items: stretch;
        width: 100%;
        margin-bottom: 0.55rem;
    }

    .annonces-section .card-topline .annonce-badge,
    .annonces-section .card-topline .status-badge,
    .annonces-section .card-topline .delivery-badge {
        width: 100%;
        min-width: 0;
        min-height: 30px;
        padding: 0.28rem 0.26rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 0.66rem;
        line-height: 1.08;
        text-align: center;
        white-space: nowrap;
        overflow: visible;
        border-radius: 999px;
        letter-spacing: -0.025em;
    }

    .annonces-section .card-topline .delivery-badge {
        font-size: 0.62rem;
    }

    .annonces-section .annonce-card h3 {
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        min-height: 2.85em;
        max-height: 2.85em;
        font-size: 1.15rem;
        line-height: 1.28;
        margin: 0.35rem 0 0.55rem;
    }

    .annonces-section .annonce-meta {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.38rem;
        margin-bottom: 0.62rem;
    }

    .annonces-section .annonce-meta li {
        min-height: 44px;
        padding: 0.45rem 0.5rem;
        border-radius: 12px;
        font-size: 0.8rem;
        line-height: 1.22;
        overflow: hidden;
    }

    .annonces-section .annonce-description-preview,
    .annonces-section .annonce-card > p {
        display: -webkit-box !important;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden !important;
        min-height: 2.7em;
        height: 2.7em;
        max-height: 2.7em;
        padding-top: 0;
        margin: 0 0 0.75rem;
        font-size: 0.88rem;
        line-height: 1.35;
        white-space: normal;
    }

    .annonces-section .inline-actions {
        margin-top: 0;
    }

    .annonces-section .annonce-button {
        min-height: 40px;
        padding: 0.68rem 0.95rem;
        border-radius: 12px;
        font-size: 0.9rem;
    }
}

@media (max-width: 390px) {
    .annonces-section .card-topline {
        gap: 0.22rem;
    }

    .annonces-section .card-topline .annonce-badge,
    .annonces-section .card-topline .status-badge,
    .annonces-section .card-topline .delivery-badge {
        font-size: 0.58rem;
        padding-left: 0.18rem;
        padding-right: 0.18rem;
    }

    .annonces-section .card-topline .delivery-badge {
        font-size: 0.55rem;
    }

    .annonces-section .annonce-meta {
        grid-template-columns: 1fr;
    }
}

/* OPTIMISATION ANNONCES MOBILE/TABLETTE : champs courts sur les cartes */
@media (max-width: 900px) {
    .annonces-section .annonce-card {
        display: flex;
        flex-direction: column;
        min-height: 0;
    }

    .annonces-section .card-topline {
        display: flex;
        align-items: center;
        flex-wrap: nowrap;
        gap: 0.35rem;
        width: 100%;
        overflow: hidden;
        margin-bottom: 0.65rem;
    }

    .annonces-section .card-topline .annonce-badge,
    .annonces-section .card-topline .status-badge,
    .annonces-section .card-topline .delivery-badge {
        flex: 0 1 auto;
        min-width: 0;
        min-height: 28px;
        padding: 0.32rem 0.48rem;
        font-size: 0.74rem;
        line-height: 1.05;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        margin: 0 !important;
    }

    .annonces-section .card-topline .delivery-badge {
        flex: 1 1 auto;
        min-width: 118px;
    }

    .annonces-section .annonce-card h3 {
        min-height: 2.7em;
        max-height: 2.7em;
        margin: 0.45rem 0 0.7rem;
        font-size: 1.18rem;
        line-height: 1.35;
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
    }

    .annonces-section .annonce-meta {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.45rem;
        margin-bottom: 0.75rem;
    }

    .annonces-section .annonce-meta li {
        min-width: 0;
        height: 54px;
        max-height: 54px;
        margin: 0;
        padding: 0.5rem 0.55rem;
        display: flex;
        flex-direction: column;
        justify-content: center;
        overflow: hidden;
        border-radius: 12px;
    }

    .annonces-section .annonce-meta li strong {
        display: block;
        min-width: 0;
        margin-bottom: 0.12rem;
        font-size: 0.74rem;
        line-height: 1.1;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .annonces-section .annonce-meta-value {
        display: block;
        min-width: 0;
        max-width: 100%;
        font-size: 0.84rem;
        line-height: 1.18;
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 1;
        -webkit-box-orient: vertical;
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .annonces-section .annonce-description-preview {
        min-height: 2.75em;
        max-height: 2.75em;
        margin-bottom: 0.8rem;
        font-size: 0.9rem;
        line-height: 1.35;
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
    }

    .annonces-section .annonce-card .inline-actions {
        margin-top: auto;
    }

    .annonces-section .annonce-button {
        min-height: 42px;
        padding: 0.72rem 1rem;
    }
}

@media (max-width: 420px) {
    .annonces-section .card-topline {
        gap: 0.25rem;
    }

    .annonces-section .card-topline .annonce-badge,
    .annonces-section .card-topline .status-badge,
    .annonces-section .card-topline .delivery-badge {
        padding-left: 0.38rem;
        padding-right: 0.38rem;
        font-size: 0.7rem;
    }

    .annonces-section .card-topline .delivery-badge {
        min-width: 112px;
    }
}

/* FILTRE LIVRAISON POSSIBLE - PAGE ANNONCES */
.search-checkbox-option {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    margin-top: 0.75rem;
    padding: 0.78rem 0.9rem;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: linear-gradient(180deg, #f8fbfb 0%, #eef5f6 100%);
    color: var(--text);
    font-weight: 800;
    line-height: 1.25;
    cursor: pointer;
    user-select: none;
}

.search-checkbox-option input {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    accent-color: var(--primary);
}

.search-checkbox-option span {
    min-width: 0;
    overflow-wrap: anywhere;
}

@media (max-width: 760px) {
    .search-checkbox-option {
        width: 100%;
        justify-content: flex-start;
        margin-top: 0.65rem;
        padding: 0.72rem 0.82rem;
        font-size: 0.92rem;
    }
}


/* CARTES ANNONCES HOMOGÈNES : limite quantité / lieu / infos sur toutes les tailles */
.annonces-section .annonce-card {
    min-width: 0;
}

.annonces-section .annonce-card h3 {
    min-height: 2.7em;
    max-height: 2.7em;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.annonces-section .annonce-meta {
    align-items: stretch;
}

.annonces-section .annonce-meta li {
    min-width: 0;
    min-height: 58px;
    height: 58px;
    max-height: 58px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
}

.annonces-section .annonce-meta li strong {
    display: block;
    min-width: 0;
    max-width: 100%;
    margin-bottom: 0.14rem;
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.annonces-section .annonce-meta-value {
    display: -webkit-box;
    min-width: 0;
    max-width: 100%;
    line-height: 1.22;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.annonces-section .annonce-description-preview,
.annonces-section .annonce-card > p {
    display: -webkit-box !important;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden !important;
    min-height: 2.8em;
    height: 2.8em;
    max-height: 2.8em;
    line-height: 1.4;
    white-space: normal;
}

.annonces-section .annonce-card .inline-actions {
    margin-top: auto;
}

@media (max-width: 900px) {
    .annonces-section .annonce-meta li {
        min-height: 54px;
        height: 54px;
        max-height: 54px;
    }

    .annonces-section .annonce-description-preview,
    .annonces-section .annonce-card > p {
        min-height: 2.7em;
        height: 2.7em;
        max-height: 2.7em;
        line-height: 1.35;
    }
}

@media (max-width: 420px) {
    .annonces-section .annonce-meta li {
        min-height: 50px;
        height: 50px;
        max-height: 50px;
    }
}

/* CORRECTION FINALE HEADER MOBILE/TABLETTE - base validée */
@media (max-width: 900px) {
    .site-header {
        position: sticky;
        top: 0;
        z-index: 1000;
    }

    .header-inner {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0.48rem !important;
        padding: 0.48rem 0.85rem 0.58rem !important;
    }

    .header-content {
        width: 100% !important;
        display: grid !important;
        grid-template-columns: 52px minmax(0, 1fr) 52px !important;
        align-items: center !important;
        gap: 0.55rem !important;
    }

    .site-logo {
        width: 52px !important;
        height: auto !important;
        border-radius: 13px !important;
        justify-self: start !important;
    }

    .site-branding {
        min-width: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
    }

    .site-branding h1 {
        margin: 0 !important;
        font-size: 1.35rem !important;
        line-height: 1.05 !important;
        white-space: nowrap !important;
        text-align: center !important;
    }

    .site-branding p {
        display: none !important;
    }

    .navigation {
        width: 100% !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        padding-bottom: 0.05rem !important;
        scrollbar-width: none !important;
    }

    .navigation::-webkit-scrollbar {
        display: none !important;
    }

    .navigation ul {
        width: max-content !important;
        min-width: 100% !important;
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 0.45rem !important;
        padding: 0 0.05rem !important;
        margin: 0 !important;
        list-style: none !important;
    }

    .navigation li {
        flex: 0 0 auto !important;
    }

    .navigation a {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-height: 42px !important;
        padding: 0.62rem 0.9rem !important;
        border-radius: 999px !important;
        background: #e9f0f1 !important;
        color: var(--text) !important;
        border: 1px solid #dbe6e8 !important;
        font-size: 1.02rem !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        white-space: nowrap !important;
        text-decoration: none !important;
    }

    .navigation a.active {
        background: var(--primary) !important;
        color: #ffffff !important;
        border-color: var(--primary) !important;
    }

    .page-main,
    .deposit-page-main,
    .detail-page-main,
    .owner-page-main {
        padding-top: 1.25rem !important;
    }
}

@media (max-width: 520px) {
    .header-inner {
        padding: 0.43rem 0.7rem 0.53rem !important;
        gap: 0.42rem !important;
    }

    .header-content {
        grid-template-columns: 46px minmax(0, 1fr) 46px !important;
    }

    .site-logo {
        width: 46px !important;
        border-radius: 12px !important;
    }

    .site-branding h1 {
        font-size: 1.28rem !important;
    }

    .navigation ul {
        justify-content: flex-start !important;
    }

    .navigation a {
        min-height: 44px !important;
        padding: 0.66rem 0.95rem !important;
        font-size: 1.04rem !important;
    }
}

/* ACCUEIL PROPRE - exemple annonce + bloc présentation */
.home-hero .hero-card {
    width: 100%;
    max-width: 560px;
}

.home-example-card {
    text-align: left;
    padding: 1.55rem;
    border-radius: 26px;
    background:
        linear-gradient(135deg, rgba(47, 100, 115, 0.08), rgba(255, 255, 255, 0) 38%),
        #ffffff;
}

.home-example-header {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.home-example-card .hero-card-badge {
    margin: 0;
}

.home-example-badges {
    width: 100%;
    margin: 0;
    gap: 0.45rem;
}

.home-example-badges .annonce-badge,
.home-example-badges .status-badge,
.home-example-badges .delivery-badge {
    min-height: 34px;
    margin: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    white-space: nowrap;
}

.home-example-card h3 {
    margin: 0 0 0.75rem;
    font-size: clamp(1.35rem, 2.5vw, 1.75rem);
    color: var(--primary);
}

.home-example-description {
    margin: 0 0 1rem;
    color: var(--text);
    line-height: 1.65;
}

.home-example-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.home-example-info {
    min-width: 0;
    padding: 0.78rem 0.85rem;
    border-radius: 16px;
    background: #f6f8f9;
    border: 1px solid #e8eef0;
}

.home-example-info span {
    display: block;
    margin-bottom: 0.2rem;
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.home-example-info strong {
    display: block;
    color: var(--text);
    font-size: 0.98rem;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.home-info-section {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 2rem 2.5rem;
}

.home-info-card,
.home-info-mini-card {
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    border-radius: 24px;
}

.home-info-card-main {
    padding: 1.7rem;
    margin-bottom: 1rem;
    background:
        linear-gradient(135deg, rgba(47, 100, 115, 0.09), rgba(255, 255, 255, 0) 40%),
        #ffffff;
}

.home-info-card h2 {
    color: var(--text);
    font-size: clamp(1.7rem, 3vw, 2.35rem);
    line-height: 1.15;
    margin-bottom: 0.75rem;
}

.home-info-card p {
    max-width: 900px;
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.75;
}

.home-info-mini-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.home-info-mini-card {
    padding: 1.1rem;
}

.home-info-mini-card strong {
    display: block;
    color: var(--primary);
    font-size: 1.05rem;
    margin-bottom: 0.4rem;
}

.home-info-mini-card p {
    color: var(--muted);
    line-height: 1.55;
}

@media (max-width: 980px) {
    .home-hero .hero-card {
        max-width: 100%;
    }

    .home-info-mini-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .home-info-section {
        padding: 0 1rem 2rem;
    }

    .home-example-card,
    .home-info-card-main,
    .home-info-mini-card {
        border-radius: 20px;
    }

    .home-example-card {
        padding: 1.2rem;
    }

    .home-example-grid {
        grid-template-columns: 1fr;
    }

    .home-example-badges .annonce-badge,
    .home-example-badges .status-badge,
    .home-example-badges .delivery-badge {
        flex: 1 1 auto;
        font-size: 0.78rem;
        padding: 0.42rem 0.58rem;
    }

    .home-info-card-main {
        padding: 1.25rem;
    }

    .home-info-card p {
        font-size: 0.98rem;
    }
}

/* PHOTOS D'ANNONCES - ajout sécurisé */
.annonce-photo-wrap {
    width: 100%;
    height: 150px;
    margin: -0.35rem -0.35rem 1rem;
    border-radius: 18px;
    overflow: hidden;
    background: #e9f0f1;
    border: 1px solid #edf1f2;
}

.annonce-photo {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.detail-photo-wrap {
    width: 100%;
    max-width: 420px;
    aspect-ratio: 1 / 1;
    margin: 1rem auto 1.25rem;
    border-radius: 22px;
    overflow: hidden;
    background: #e9f0f1;
    border: 1px solid #edf1f2;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.075);
}

.detail-photo {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.owner-photo-row {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
    margin-bottom: 0.9rem;
}

.owner-annonce-photo {
    width: 96px;
    height: 76px;
    display: block;
    object-fit: cover;
    border-radius: 16px;
    background: #e9f0f1;
    border: 1px solid #edf1f2;
}

.photo-upload-group input[type="file"] {
    padding: 0.75rem 1rem;
    background: #f8fbfb;
}

.optional-label {
    color: var(--muted);
    font-weight: 600;
    font-size: 0.9em;
}

.photo-current-preview {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr);
    gap: 0.9rem;
    align-items: center;
    padding: 0.85rem;
    margin-bottom: 0.8rem;
    border-radius: 18px;
    background: #f8fbfb;
    border: 1px solid var(--border);
}

.photo-preview-img {
    width: 120px;
    height: 86px;
    display: block;
    object-fit: cover;
    border-radius: 14px;
    background: #e9f0f1;
}

.simple-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    margin-top: 0.7rem;
    color: var(--muted);
    font-weight: 700;
    cursor: pointer;
}

.simple-checkbox input {
    width: 18px;
    height: 18px;
    margin-top: 0.15rem;
    accent-color: var(--primary);
}

@media (max-width: 900px) {
    .annonce-photo-wrap {
        height: 138px;
        margin-bottom: 0.8rem;
        border-radius: 16px;
    }

    .detail-photo-wrap {
        max-width: 400px;
    }
}

@media (max-width: 520px) {
    .annonce-photo-wrap {
        height: 118px;
        margin: -0.2rem -0.2rem 0.75rem;
        border-radius: 15px;
    }

    .detail-photo-wrap {
        max-width: 340px;
        border-radius: 18px;
        margin: 0.85rem auto 1rem;
    }

    .detail-photo {
        height: 100%;
    }

    .owner-photo-row {
        grid-template-columns: 82px minmax(0, 1fr);
        gap: 0.7rem;
    }

    .owner-annonce-photo {
        width: 82px;
        height: 66px;
        border-radius: 14px;
    }

    .photo-current-preview {
        grid-template-columns: 1fr;
    }

    .photo-preview-img {
        width: 100%;
        height: 150px;
    }
}

/* Page annonces : distance mise en valeur + page détail : image carrée équilibrée */
.annonces-section .annonce-distance {
    margin-top: 0.45rem;
    padding-left: 0.55rem;
    border-left: 3px solid var(--primary);
}

.annonces-section .annonce-distance strong {
    color: var(--primary-dark);
}

.annonces-section .annonce-distance .distance-value {
    color: var(--primary-dark);
    font-size: 1.04rem;
    font-weight: 800;
}

.detail-page-main .detail-photo-wrap {
    width: min(100%, 420px) !important;
    max-width: 420px !important;
    aspect-ratio: 1 / 1 !important;
    margin: 1rem auto 1.25rem !important;
    border-radius: 22px !important;
    overflow: hidden !important;
}

.detail-page-main .detail-photo {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
}

.detail-meta-distance strong {
    color: var(--primary-dark);
    font-weight: 800;
}

@media (max-width: 600px) {
    .detail-page-main .detail-photo-wrap {
        width: min(100%, 340px) !important;
        max-width: 340px !important;
        margin: 0.85rem auto 1rem !important;
        border-radius: 18px !important;
    }
}

/* SIGNALEMENT D'ANNONCE */
.detail-report-link {
    display: block;
    margin-top: 0.8rem;
    color: var(--muted);
    font-size: 0.92rem;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
}

.detail-report-link:hover {
    color: var(--primary-dark);
    text-decoration: underline;
}

.report-page-main {
    padding-top: 4rem;
}

.report-section {
    max-width: 780px;
    margin: 0 auto;
}

.report-card h2 {
    margin: 0.35rem 0 0.6rem;
    color: var(--primary-dark);
}

.report-intro {
    color: var(--muted);
    line-height: 1.6;
    margin-bottom: 1.2rem;
}

.report-annonce-summary {
    display: grid;
    gap: 0.25rem;
    padding: 1rem;
    margin-bottom: 1.2rem;
    background: #f6f8f7;
    border: 1px solid var(--border);
    border-radius: 16px;
}

.report-annonce-summary strong {
    color: var(--primary-dark);
}

.report-annonce-summary span {
    color: var(--muted);
}

.report-hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.message {
    padding: 0.95rem 1rem;
    margin: 1rem 0;
    border-radius: 14px;
    font-weight: 700;
    line-height: 1.5;
}

.message p {
    margin: 0.2rem 0;
}

.success-message {
    color: #1f5f3b;
    background: #eaf7ef;
    border: 1px solid #ccebd7;
}

.error-message {
    color: #8a2d1c;
    background: #fff0eb;
    border: 1px solid #f3cbbf;
}

.report-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 1rem;
}

.report-actions .cta-button {
    border: none;
    cursor: pointer;
    font-family: inherit;
}

@media (max-width: 640px) {
    .report-page-main {
        padding-top: 2rem;
    }

    .report-card {
        padding: 1.2rem;
        border-radius: 20px;
    }

    .report-actions {
        flex-direction: column-reverse;
        align-items: stretch;
    }

    .report-actions .cta-button,
    .report-actions .reset-link {
        width: 100%;
        text-align: center;
    }
}


/* CORRECTION PHOTOS RESPONSIVE - version serveur 2026-05-24
   Objectif : affichage homogène des photos, même avec des images téléphone. */
.annonces-section .annonce-photo-wrap,
.owner-page-main .annonce-photo-wrap {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 4 / 3 !important;
    margin: -0.35rem -0.35rem 1rem !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    background: #e9f0f1 !important;
    border: 1px solid #edf1f2 !important;
}

.annonces-section .annonce-photo,
.owner-page-main .annonce-photo {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
    object-position: center center !important;
}

/* Page détail : carré stable, plus grand que les miniatures, sans déformation. */
.detail-page-main .detail-photo-wrap {
    width: min(100%, 420px) !important;
    max-width: 420px !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important;
    margin: 1rem auto 1.25rem !important;
    border-radius: 22px !important;
    overflow: hidden !important;
    background: #e9f0f1 !important;
    border: 1px solid #edf1f2 !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.075) !important;
}

.detail-page-main .detail-photo {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
    object-position: center center !important;
}

@media (max-width: 600px) {
    .annonces-section .annonce-photo-wrap,
    .owner-page-main .annonce-photo-wrap {
        aspect-ratio: 4 / 3 !important;
        margin: -0.2rem -0.2rem 0.9rem !important;
        border-radius: 16px !important;
    }

    .detail-page-main .detail-photo-wrap {
        width: min(100%, 340px) !important;
        max-width: 340px !important;
        margin: 0.85rem auto 1rem !important;
        border-radius: 18px !important;
    }
}

/* Correctif serveur : kilomètres remis en valeur dans l'onglet Annonces */
.annonces-section .annonce-card .annonce-meta li.annonce-distance {
    margin-top: 0.55rem !important;
    padding: 0.45rem 0.65rem !important;
    border-left: 4px solid var(--primary) !important;
    border-radius: 10px !important;
    background: rgba(47, 100, 115, 0.06) !important;
}

.annonces-section .annonce-card .annonce-meta li.annonce-distance strong {
    color: var(--primary-dark) !important;
    font-weight: 800 !important;
}

.annonces-section .annonce-card .annonce-meta li.annonce-distance .distance-value {
    color: var(--primary-dark) !important;
    font-size: 1.08rem !important;
    font-weight: 900 !important;
}

/* RESTAURATION PHOTOS - rendu identique à la version de référence validée
   Les règles ci-dessous neutralisent les essais précédents trop grands en serveur. */
.annonces-section .annonce-photo-wrap {
    width: 100% !important;
    height: 150px !important;
    aspect-ratio: auto !important;
    margin: -0.35rem -0.35rem 1rem !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    background: #e9f0f1 !important;
    border: 1px solid #edf1f2 !important;
}

.annonces-section .annonce-photo {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
    object-position: center center !important;
}

.owner-photo-row {
    display: grid !important;
    grid-template-columns: 96px minmax(0, 1fr) !important;
    gap: 0.85rem !important;
    align-items: start !important;
    margin-bottom: 0.9rem !important;
}

.owner-annonce-photo {
    width: 96px !important;
    height: 76px !important;
    display: block !important;
    object-fit: cover !important;
    object-position: center center !important;
    border-radius: 16px !important;
    background: #e9f0f1 !important;
    border: 1px solid #edf1f2 !important;
}

.detail-page-main .detail-photo-wrap {
    width: 100% !important;
    max-width: 420px !important;
    aspect-ratio: 1 / 1 !important;
    margin: 1rem auto 1.25rem !important;
    border-radius: 22px !important;
    overflow: hidden !important;
    background: #e9f0f1 !important;
    border: 1px solid #edf1f2 !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.075) !important;
}

.detail-page-main .detail-photo {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
    object-position: center center !important;
}

@media (max-width: 900px) {
    .annonces-section .annonce-photo-wrap {
        height: 138px !important;
        margin-bottom: 0.8rem !important;
        border-radius: 16px !important;
    }

    .detail-page-main .detail-photo-wrap {
        max-width: 400px !important;
    }
}

@media (max-width: 520px) {
    .annonces-section .annonce-photo-wrap {
        height: 118px !important;
        margin: -0.2rem -0.2rem 0.75rem !important;
        border-radius: 15px !important;
    }

    .detail-page-main .detail-photo-wrap {
        max-width: 340px !important;
        border-radius: 18px !important;
        margin: 0.85rem auto 1rem !important;
    }

    .owner-photo-row {
        grid-template-columns: 82px minmax(0, 1fr) !important;
        gap: 0.7rem !important;
    }

    .owner-annonce-photo {
        width: 82px !important;
        height: 66px !important;
        border-radius: 14px !important;
    }
}

/* CHOIX DU BESOIN SUR LA PAGE ANNONCES */
.annonces-choice-hero {
    text-align: left;
    max-width: 1200px;
    margin: 0 auto 1.5rem;
}

.annonces-choice-hero h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    color: var(--text);
    margin-bottom: 0.5rem;
}

.annonces-choice-hero p {
    color: var(--muted);
    font-size: 1.08rem;
}

.search-mode-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.2rem;
}

.search-mode-card {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1rem;
    min-height: 130px;
    padding: 1.3rem;
    border: 1px solid var(--border);
    border-radius: 22px;
    background: var(--surface);
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.search-mode-card:hover {
    transform: translateY(-2px);
    border-color: var(--primary);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
}

.search-mode-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.search-mode-card.is-selected {
    border-color: var(--primary);
    background: linear-gradient(135deg, rgba(47, 100, 115, 0.12), rgba(255, 255, 255, 0.95));
    box-shadow: 0 14px 34px rgba(47, 100, 115, 0.12);
}

.search-mode-card.is-selected::after {
    content: "✓";
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: var(--primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
}

.search-mode-icon {
    width: 64px;
    height: 64px;
    flex: 0 0 64px;
    border-radius: 20px;
    background: #e9f0f1;
    color: var(--primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    font-weight: 800;
}

.search-mode-content {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding-right: 2rem;
}

.search-mode-content strong {
    color: var(--text);
    font-size: 1.2rem;
}

.search-mode-card.is-selected .search-mode-content strong {
    color: var(--primary);
}

.search-mode-content small {
    color: var(--muted);
    font-size: 0.98rem;
    line-height: 1.45;
}

.search-mode-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-bottom: 1rem;
    padding: 0.55rem 0.85rem;
    border-radius: 999px;
    background: #e9f0f1;
    color: var(--muted);
    font-size: 0.92rem;
    font-weight: 700;
}

.search-mode-badge::before {
    content: "";
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: var(--primary);
}

.search-mode-badge strong {
    color: var(--primary);
}

.search-bottom-row {
    align-items: center;
}

.search-bottom-row .search-checkbox-option {
    margin-top: 0;
}

@media (max-width: 760px) {
    .annonces-choice-hero {
        text-align: center;
    }

    .search-mode-grid {
        grid-template-columns: 1fr;
    }

    .search-mode-card {
        min-height: auto;
        align-items: flex-start;
        padding: 1.1rem;
    }

    .search-mode-icon {
        width: 52px;
        height: 52px;
        flex-basis: 52px;
        font-size: 1.45rem;
    }

    .search-mode-content {
        padding-right: 1.5rem;
    }

    .search-mode-content strong {
        font-size: 1.05rem;
    }
}

/* AJUSTEMENTS ANNONCES — PRIORITÉ RECHERCHE + MOBILE */
.search-mode-badge span {
    color: var(--muted);
}

.search-mode-badge strong {
    line-height: 1.35;
}

@media (max-width: 760px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    .page-main {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .annonces-choice-hero {
        text-align: left;
        margin-bottom: 1rem;
        padding-inline: 0.25rem;
    }

    .annonces-choice-hero h2 {
        font-size: 1.8rem;
        line-height: 1.15;
    }

    .annonces-choice-hero p {
        font-size: 0.98rem;
        line-height: 1.45;
    }

    .search-mode-grid {
        grid-template-columns: 1fr;
        gap: 0.75rem;
        margin-bottom: 0.85rem;
    }

    .search-mode-card {
        min-height: auto;
        padding: 1rem;
        gap: 0.8rem;
        align-items: flex-start;
        border-radius: 18px;
    }

    .search-mode-icon {
        width: 46px;
        height: 46px;
        flex: 0 0 46px;
        border-radius: 15px;
        font-size: 1.35rem;
    }

    .search-mode-content {
        padding-right: 1.4rem;
        min-width: 0;
    }

    .search-mode-content strong {
        font-size: 1rem;
        line-height: 1.25;
    }

    .search-mode-content small {
        font-size: 0.9rem;
        line-height: 1.35;
    }

    .search-mode-card.is-selected::after {
        top: 0.75rem;
        right: 0.75rem;
        width: 24px;
        height: 24px;
        font-size: 0.85rem;
    }

    .search-mode-badge {
        width: 100%;
        justify-content: flex-start;
        align-items: flex-start;
        flex-wrap: wrap;
        border-radius: 16px;
        line-height: 1.35;
        gap: 0.35rem;
        padding: 0.65rem 0.8rem;
    }

    .search-card {
        width: 100%;
        padding: 1rem;
        border-radius: 20px;
        margin-bottom: 1.2rem;
    }

    .search-card .form-row,
    .search-row,
    .search-grid,
    .filters-grid,
    .form-grid {
        grid-template-columns: 1fr !important;
        gap: 0.85rem;
    }

    .search-card input,
    .search-card select {
        width: 100%;
        min-height: 48px;
        font-size: 1rem;
    }

    .address-search-group::before {
        top: 2.55rem;
    }

    .search-actions,
    .form-actions {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
        padding-top: 0;
    }

    .search-actions .cta-button,
    .form-actions .cta-button,
    .search-actions .btn,
    .form-actions .btn,
    .search-actions button,
    .form-actions button {
        width: 100%;
        min-height: 48px;
        justify-content: center;
        text-align: center;
    }

    .reset-link {
        width: 100%;
        text-align: center;
        margin-top: 0;
        padding: 0.6rem 0;
    }

    .site-header,
    .header-inner,
    .header-content,
    .main-nav {
        max-width: 100%;
    }
}

@media (max-width: 380px) {
    .page-main {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

    .search-mode-card {
        padding: 0.9rem;
    }

    .search-mode-icon {
        width: 42px;
        height: 42px;
        flex-basis: 42px;
    }
}


/* CORRECTION MOBILE — FILTRE LIVRAISON POSSIBLE PAGE ANNONCES */
.search-card .delivery-filter,
.delivery-filter {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0.65rem !important;
    width: auto !important;
    max-width: 100% !important;
    min-height: 48px !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0.85rem 1rem !important;
    border: 1px solid var(--border) !important;
    border-radius: 16px !important;
    background: var(--surface) !important;
    color: var(--text) !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    cursor: pointer !important;
    white-space: normal !important;
    writing-mode: horizontal-tb !important;
    text-orientation: mixed !important;
    box-sizing: border-box !important;
}

.search-card .delivery-filter input,
.delivery-filter input {
    appearance: auto !important;
    display: inline-block !important;
    width: 18px !important;
    min-width: 18px !important;
    max-width: 18px !important;
    height: 18px !important;
    min-height: 18px !important;
    max-height: 18px !important;
    flex: 0 0 18px !important;
    margin: 0 !important;
    padding: 0 !important;
    accent-color: var(--primary) !important;
}

.search-card .delivery-filter span,
.delivery-filter span {
    display: inline-block !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: 100% !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    writing-mode: horizontal-tb !important;
    text-orientation: mixed !important;
    line-height: 1.2 !important;
}

@media (max-width: 760px) {
    .search-bottom-row .form-group:first-child {
        width: 100% !important;
        min-height: auto !important;
    }

    .search-card .delivery-filter,
    .delivery-filter {
        display: flex !important;
        flex-direction: row !important;
        width: 100% !important;
        min-height: 48px !important;
        height: auto !important;
        padding: 0.9rem 1rem !important;
        align-items: center !important;
        justify-content: flex-start !important;
        border-radius: 16px !important;
    }

    .search-card .delivery-filter input,
    .delivery-filter input {
        width: 18px !important;
        min-width: 18px !important;
        max-width: 18px !important;
        height: 18px !important;
        min-height: 18px !important;
        max-height: 18px !important;
        flex: 0 0 18px !important;
    }

    .search-card .delivery-filter span,
    .delivery-filter span {
        display: inline-block !important;
        writing-mode: horizontal-tb !important;
        text-orientation: mixed !important;
        white-space: normal !important;
        word-break: normal !important;
        overflow-wrap: normal !important;
        line-height: 1.2 !important;
        text-align: left !important;
    }
}

/* ACCUEIL MODERNE - ajout non destructif */
.home-main {
    overflow-x: hidden;
}

.home-main .section-title {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}

.home-hero {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 5rem 2rem 3rem;
}

.home-hero-content {
    position: relative;
    overflow: hidden;
    padding: clamp(2rem, 5vw, 4.5rem);
    border: 1px solid var(--border);
    border-radius: 34px;
    background:
        radial-gradient(circle at 92% 12%, rgba(47, 100, 115, 0.15), transparent 32%),
        linear-gradient(135deg, #ffffff 0%, #e9f0f1 100%);
    box-shadow: var(--shadow);
}

.home-hero-content::after {
    content: "";
    position: absolute;
    right: -90px;
    bottom: -110px;
    width: 270px;
    height: 270px;
    border-radius: 999px;
    border: 44px solid rgba(47, 100, 115, 0.08);
    pointer-events: none;
}

.home-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.45rem 0.85rem;
    margin-bottom: 1.25rem;
    border-radius: 999px;
    background: rgba(47, 100, 115, 0.1);
    color: var(--primary);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.home-eyebrow::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--primary);
}

.home-hero-content h2 {
    max-width: 860px;
    color: var(--text);
    font-size: clamp(2.35rem, 5vw, 4.6rem);
    line-height: 1.02;
    margin-bottom: 1.25rem;
    letter-spacing: -0.045em;
}

.home-hero-text {
    max-width: 830px;
    color: var(--muted);
    font-size: clamp(1.05rem, 2vw, 1.25rem);
    line-height: 1.75;
    margin-bottom: 0;
}

.home-hero-actions {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    margin-top: 2rem;
}

.home-primary-action,
.home-secondary-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0.95rem 1.35rem;
    border-radius: 16px;
    font-weight: 800;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.home-primary-action {
    background: var(--primary);
    color: #ffffff;
    box-shadow: 0 14px 26px rgba(47, 100, 115, 0.22);
}

.home-primary-action:hover {
    background: var(--primary-dark);
    transform: translateY(-2px);
}

.home-secondary-action {
    background: rgba(255, 255, 255, 0.72);
    color: var(--primary);
    border: 1px solid rgba(47, 100, 115, 0.25);
}

.home-secondary-action:hover {
    border-color: var(--primary);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
    transform: translateY(-2px);
}

.home-paths,
.home-benefits,
.home-steps,
.home-final-cta {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 2rem;
}

.home-paths-grid,
.home-benefits-grid,
.home-steps-grid {
    display: grid;
    gap: 1.2rem;
}

.home-paths-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-benefits-grid,
.home-steps-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-path-card,
.home-benefit-card,
.home-step-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 24px;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.06);
}

.home-path-card {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    min-height: 180px;
    padding: 1.5rem;
    color: inherit;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.home-path-card:hover {
    transform: translateY(-3px);
    border-color: var(--primary);
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.1);
}

.home-path-card-primary {
    border-color: rgba(47, 100, 115, 0.35);
    background: linear-gradient(135deg, rgba(47, 100, 115, 0.1), #ffffff 62%);
}

.home-card-icon,
.home-benefit-icon,
.home-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 54px;
    height: 54px;
    border-radius: 18px;
    background: var(--surface-soft);
    color: var(--primary);
    font-size: 1.55rem;
    font-weight: 900;
}

.home-path-card h3,
.home-benefit-card h3,
.home-step-card h3 {
    color: var(--text);
    font-size: 1.25rem;
    margin-bottom: 0.45rem;
}

.home-path-card p,
.home-benefit-card p,
.home-step-card p,
.home-final-cta p {
    color: var(--muted);
    line-height: 1.65;
}

.home-benefits {
    padding-top: 2.5rem;
}

.home-benefit-card,
.home-step-card {
    padding: 1.5rem;
}

.home-benefit-icon {
    margin-bottom: 1rem;
}

.home-steps {
    margin-top: 1rem;
}

.home-steps-grid {
    counter-reset: home-steps;
}

.home-step-card {
    position: relative;
}

.home-step-number {
    width: 46px;
    height: 46px;
    margin-bottom: 1rem;
    border-radius: 999px;
    background: var(--primary);
    color: #ffffff;
    font-size: 1.05rem;
}

.home-final-cta {
    margin-top: 2rem;
    margin-bottom: 1rem;
    text-align: center;
}

.home-final-cta {
    max-width: min(1180px, calc(100% - 4rem));
    padding: 2.5rem;
    border-radius: 28px;
    border: 1px solid rgba(47, 100, 115, 0.16);
    background: linear-gradient(135deg, var(--primary), var(--primary-dark));
    color: #ffffff;
    box-shadow: 0 18px 40px rgba(47, 100, 115, 0.18);
}

.home-final-cta h2 {
    font-size: clamp(1.75rem, 4vw, 2.7rem);
    margin-bottom: 0.7rem;
}

.home-final-cta p {
    color: rgba(255, 255, 255, 0.86);
    max-width: 640px;
    margin: 0 auto 1.4rem;
}

.home-final-cta .home-primary-action {
    background: #ffffff;
    color: var(--primary);
    box-shadow: none;
}

.home-final-cta .home-primary-action:hover {
    background: var(--surface-soft);
}

@media (max-width: 900px) {
    .home-hero {
        padding: 3rem 1.25rem 1.5rem;
    }

    .home-paths,
    .home-benefits,
    .home-steps {
        padding: 1.5rem 1.25rem;
    }

    .home-paths-grid,
    .home-benefits-grid,
    .home-steps-grid {
        grid-template-columns: 1fr;
    }

    .home-final-cta {
        max-width: calc(100% - 2.5rem);
    }
}

@media (max-width: 560px) {
    .home-hero {
        padding-top: 2rem;
    }

    .home-hero-content {
        padding: 1.35rem;
        border-radius: 24px;
    }

    .home-hero-content::after {
        display: none;
    }

    .home-hero-content h2 {
        font-size: 2.15rem;
        line-height: 1.08;
    }

    .home-hero-text {
        font-size: 1rem;
        line-height: 1.58;
    }

    .home-hero-actions {
        flex-direction: column;
        gap: 0.75rem;
    }

    .home-primary-action,
    .home-secondary-action {
        width: 100%;
        min-height: 50px;
        padding: 0.9rem 1rem;
    }

    .home-path-card {
        min-height: auto;
        padding: 1rem;
        gap: 0.8rem;
        border-radius: 20px;
    }

    .home-card-icon,
    .home-benefit-icon {
        width: 46px;
        height: 46px;
        border-radius: 15px;
        font-size: 1.3rem;
    }

    .home-path-card h3,
    .home-benefit-card h3,
    .home-step-card h3 {
        font-size: 1.08rem;
        line-height: 1.25;
    }

    .home-path-card p,
    .home-benefit-card p,
    .home-step-card p {
        font-size: 0.95rem;
        line-height: 1.45;
    }

    .home-benefit-card,
    .home-step-card {
        padding: 1.1rem;
        border-radius: 20px;
    }

    .home-final-cta {
        max-width: calc(100% - 2rem);
        padding: 1.5rem 1rem;
        border-radius: 22px;
    }
}

/* ACCUEIL SIMPLIFIÉ - moins de boutons, plus de lisibilité */
.home-main-refined {
    overflow-x: hidden;
}

.home-hero-refined {
    padding-top: 4rem;
    padding-bottom: 2rem;
}

.home-hero-content-refined {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.55fr);
    align-items: center;
    gap: clamp(1.5rem, 4vw, 3rem);
}

.home-hero-copy {
    position: relative;
    z-index: 1;
}

.home-hero-secondary {
    margin-top: 1rem;
    color: var(--muted);
    font-weight: 700;
    line-height: 1.5;
}

.home-hero-secondary a,
.home-inline-link {
    color: var(--primary);
    font-weight: 900;
    text-decoration: none;
}

.home-hero-secondary a:hover,
.home-inline-link:hover {
    color: var(--primary-dark);
    text-decoration: underline;
}

.home-hero-panel {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 0.9rem;
}

.home-panel-card,
.home-panel-row,
.home-panel-note {
    border: 1px solid rgba(47, 100, 115, 0.14);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.78);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.06);
}

.home-panel-card-main {
    padding: 1.25rem;
}

.home-panel-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    margin-bottom: 0.9rem;
    border-radius: 18px;
    background: rgba(47, 100, 115, 0.12);
    color: var(--primary);
    font-size: 1.45rem;
    font-weight: 900;
}

.home-panel-card-main strong,
.home-panel-card-main small {
    display: block;
}

.home-panel-card-main strong {
    color: var(--text);
    font-size: 1.12rem;
    margin-bottom: 0.3rem;
}

.home-panel-card-main small,
.home-panel-note {
    color: var(--muted);
    line-height: 1.45;
}

.home-panel-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
    padding: 0.85rem;
    color: var(--primary);
    font-weight: 850;
    font-size: 0.9rem;
}

.home-panel-note {
    padding: 1rem;
    font-weight: 750;
}

.home-section {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 2rem;
}

.home-usage-section {
    padding-top: 2.5rem;
}

.home-usage-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.2rem;
}

.home-usage-card {
    min-height: 210px;
    padding: 1.5rem;
    border: 1px solid var(--border);
    border-radius: 26px;
    background: var(--surface);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.055);
}

.home-usage-card:first-child {
    background: linear-gradient(135deg, rgba(47, 100, 115, 0.08), #ffffff 64%);
    border-color: rgba(47, 100, 115, 0.18);
}

.home-usage-card .home-card-icon {
    margin-bottom: 1rem;
}

.home-usage-card h3 {
    color: var(--text);
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}

.home-usage-card p {
    color: var(--muted);
    line-height: 1.65;
}

.home-usage-card .home-inline-link {
    display: inline-flex;
    margin-top: 0.9rem;
}

.home-final-cta-refined {
    background: transparent;
    color: var(--text);
    border: 1px solid var(--border);
    box-shadow: none;
    padding: 2rem;
}

.home-final-cta-refined p {
    color: var(--muted);
    margin-bottom: 0.5rem;
}

.home-final-cta-refined .home-final-link {
    display: inline-flex;
    margin-top: 0.4rem;
}

@media (max-width: 900px) {
    .home-hero-content-refined {
        grid-template-columns: 1fr;
    }

    .home-hero-panel {
        grid-template-columns: 1fr;
    }

    .home-section {
        padding: 1.5rem 1.25rem;
    }

    .home-usage-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .home-hero-refined {
        padding-top: 1.5rem;
    }

    .home-hero-content-refined {
        gap: 1.1rem;
    }

    .home-hero-actions {
        align-items: stretch;
    }

    .home-hero-secondary {
        font-size: 0.95rem;
    }

    .home-panel-row {
        grid-template-columns: 1fr;
    }

    .home-usage-card {
        min-height: auto;
        padding: 1.1rem;
        border-radius: 20px;
    }

    .home-usage-card h3 {
        font-size: 1.08rem;
        line-height: 1.25;
    }

    .home-usage-card p {
        font-size: 0.95rem;
        line-height: 1.5;
    }

    .home-final-cta-refined {
        padding: 1.4rem 1rem;
    }
}

/* ACCUEIL ÉQUILIBRÉ - haut de page en deux blocs, sans CTA répétitif */
.home-main-balanced {
    overflow-x: hidden;
}

.home-top-grid {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: clamp(1.5rem, 4vw, 3rem) 2rem 1.5rem;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    gap: clamp(1rem, 3vw, 1.6rem);
    align-items: stretch;
}

.home-main-panel,
.home-info-panel {
    position: relative;
    border: 1px solid rgba(47, 100, 115, 0.14);
    border-radius: 30px;
    background: var(--surface);
    box-shadow: 0 16px 42px rgba(0, 0, 0, 0.07);
    overflow: hidden;
}

.home-main-panel {
    padding: clamp(1.5rem, 4vw, 2.5rem);
    background:
        radial-gradient(circle at top right, rgba(47, 100, 115, 0.14), transparent 34%),
        linear-gradient(135deg, rgba(47, 100, 115, 0.08), rgba(255, 255, 255, 0.98) 58%);
}

.home-info-panel {
    padding: clamp(1.3rem, 3vw, 2rem);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 250, 250, 0.96));
}

.home-main-panel .home-eyebrow,
.home-info-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 1rem;
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
    background: rgba(47, 100, 115, 0.1);
    color: var(--primary);
    font-size: 0.82rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.home-main-panel h2,
.home-info-panel h2 {
    color: var(--text);
    line-height: 1.05;
    margin-bottom: 1rem;
}

.home-main-panel h2 {
    max-width: 760px;
    font-size: clamp(2rem, 5vw, 3.7rem);
    letter-spacing: -0.055em;
}

.home-info-panel h2 {
    font-size: clamp(1.45rem, 2.6vw, 2.2rem);
    letter-spacing: -0.035em;
}

.home-main-panel .home-hero-text,
.home-info-panel > p {
    color: var(--muted);
    line-height: 1.72;
    margin: 0;
}

.home-main-panel .home-hero-text {
    max-width: 780px;
    font-size: 1.08rem;
}

.home-main-actions {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    margin-top: 1.55rem;
}

.home-secondary-text-link {
    margin: 1rem 0 0;
    color: var(--muted);
    font-size: 0.98rem;
    font-weight: 750;
    line-height: 1.5;
}

.home-secondary-text-link a {
    color: var(--primary);
    font-weight: 900;
    text-decoration: none;
}

.home-secondary-text-link a:hover {
    color: var(--primary-dark);
    text-decoration: underline;
}

.home-info-list {
    display: grid;
    gap: 0.85rem;
    margin-top: 1.25rem;
}

.home-info-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.85rem;
    align-items: flex-start;
    padding: 1rem;
    border: 1px solid rgba(47, 100, 115, 0.12);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.78);
}

.home-info-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 15px;
    background: rgba(47, 100, 115, 0.11);
    color: var(--primary);
    font-size: 1.25rem;
    font-weight: 900;
}

.home-info-item h3 {
    margin: 0 0 0.25rem;
    color: var(--text);
    font-size: 1.02rem;
}

.home-info-item p {
    margin: 0;
    color: var(--muted);
    line-height: 1.45;
    font-size: 0.95rem;
}

.home-main-balanced .home-section {
    padding-top: 1.5rem;
}

@media (max-width: 900px) {
    .home-top-grid {
        grid-template-columns: 1fr;
        padding-inline: 1.25rem;
    }
}

@media (max-width: 560px) {
    .home-top-grid {
        padding: 1rem 1rem 0.75rem;
        gap: 0.9rem;
    }

    .home-main-panel,
    .home-info-panel {
        border-radius: 22px;
        padding: 1.15rem;
    }

    .home-main-panel h2 {
        font-size: clamp(1.85rem, 11vw, 2.5rem);
        line-height: 1.08;
    }

    .home-info-panel h2 {
        font-size: 1.35rem;
        line-height: 1.15;
    }

    .home-main-panel .home-hero-text,
    .home-info-panel > p {
        font-size: 0.95rem;
        line-height: 1.5;
    }

    .home-main-actions,
    .home-main-actions .home-primary-action {
        width: 100%;
    }

    .home-main-actions .home-primary-action {
        justify-content: center;
        min-height: 48px;
        padding-inline: 1rem;
        text-align: center;
    }

    .home-secondary-text-link {
        font-size: 0.92rem;
    }

    .home-info-list {
        gap: 0.7rem;
        margin-top: 1rem;
    }

    .home-info-item {
        padding: 0.85rem;
        border-radius: 18px;
        gap: 0.7rem;
    }

    .home-info-icon {
        width: 38px;
        height: 38px;
        border-radius: 14px;
        font-size: 1.1rem;
    }

    .home-info-item h3 {
        font-size: 0.98rem;
    }

    .home-info-item p {
        font-size: 0.9rem;
    }
}

/* ACCUEIL - affinage hiérarchie visuelle hero 2 blocs */
.home-main-balanced .home-top-grid {
    grid-template-columns: minmax(0, 1.42fr) minmax(280px, 0.78fr);
    gap: clamp(1rem, 2.4vw, 1.45rem);
    align-items: stretch;
}

.home-main-balanced .home-main-panel {
    min-height: 420px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(2rem, 5vw, 3.35rem);
    border-color: rgba(47, 100, 115, 0.18);
    background:
        radial-gradient(circle at 88% 12%, rgba(47, 100, 115, 0.18), transparent 30%),
        radial-gradient(circle at 10% 95%, rgba(47, 100, 115, 0.08), transparent 30%),
        linear-gradient(135deg, rgba(47, 100, 115, 0.11), rgba(255, 255, 255, 0.98) 56%);
    box-shadow: 0 22px 55px rgba(19, 44, 52, 0.1);
}

.home-main-balanced .home-info-panel {
    align-self: center;
    min-height: auto;
    padding: clamp(1.25rem, 3vw, 1.75rem);
    border-radius: 26px;
    border-color: rgba(47, 100, 115, 0.13);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 250, 0.96));
    box-shadow: 0 16px 38px rgba(19, 44, 52, 0.075);
}

.home-main-balanced .home-main-panel .home-eyebrow {
    width: fit-content;
    margin-bottom: 1.15rem;
}

.home-main-balanced .home-main-panel h2 {
    max-width: 820px;
    font-size: clamp(2.35rem, 5.4vw, 4.25rem);
    line-height: 0.98;
    letter-spacing: -0.065em;
    margin-bottom: 1.2rem;
}

.home-main-balanced .home-main-panel .home-hero-text {
    max-width: 760px;
    font-size: clamp(1rem, 1.2vw, 1.14rem);
    line-height: 1.7;
}

.home-main-balanced .home-primary-action {
    min-height: 52px;
    padding: 0.95rem 1.35rem;
    border-radius: 16px;
    box-shadow: 0 14px 28px rgba(47, 100, 115, 0.18);
}

.home-main-balanced .home-info-kicker {
    margin-bottom: 0.85rem;
    padding: 0.35rem 0.65rem;
    font-size: 0.74rem;
}

.home-main-balanced .home-info-panel h2 {
    font-size: clamp(1.35rem, 2.1vw, 1.8rem);
    line-height: 1.08;
    letter-spacing: -0.045em;
    margin-bottom: 0.65rem;
}

.home-main-balanced .home-info-panel > p {
    font-size: 0.94rem;
    line-height: 1.5;
}

.home-main-balanced .home-info-list {
    gap: 0.7rem;
    margin-top: 1rem;
}

.home-main-balanced .home-info-item {
    padding: 0.85rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.86);
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.home-main-balanced .home-info-item:hover {
    transform: translateY(-2px);
    border-color: rgba(47, 100, 115, 0.24);
    box-shadow: 0 10px 22px rgba(19, 44, 52, 0.07);
}

.home-main-balanced .home-info-icon {
    width: 38px;
    height: 38px;
    border-radius: 14px;
    font-size: 1.08rem;
}

.home-main-balanced .home-info-item h3 {
    font-size: 0.98rem;
    margin-bottom: 0.15rem;
}

.home-main-balanced .home-info-item p {
    font-size: 0.88rem;
    line-height: 1.35;
}

.home-main-balanced .home-section {
    padding-top: clamp(1.25rem, 3vw, 2.1rem);
}

@media (max-width: 900px) {
    .home-main-balanced .home-top-grid {
        grid-template-columns: 1fr;
    }

    .home-main-balanced .home-main-panel {
        min-height: auto;
    }

    .home-main-balanced .home-info-panel {
        align-self: stretch;
    }
}

@media (max-width: 560px) {
    .home-main-balanced .home-main-panel,
    .home-main-balanced .home-info-panel {
        padding: 1.15rem;
        border-radius: 22px;
    }

    .home-main-balanced .home-main-panel h2 {
        font-size: clamp(2rem, 10.5vw, 2.75rem);
        line-height: 1.03;
        letter-spacing: -0.052em;
    }

    .home-main-balanced .home-main-panel .home-hero-text {
        font-size: 0.95rem;
        line-height: 1.52;
    }

    .home-main-balanced .home-info-panel h2 {
        font-size: 1.3rem;
    }

    .home-main-balanced .home-info-panel > p,
    .home-main-balanced .home-info-item p {
        font-size: 0.88rem;
    }
}

/* ACCUEIL - optimisation finale du haut de page */
.home-main-balanced .home-top-grid {
    grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.72fr);
    gap: clamp(1rem, 2.6vw, 1.55rem);
}

.home-main-balanced .home-main-panel {
    min-height: 390px;
    padding: clamp(1.8rem, 4.4vw, 3rem);
    justify-content: center;
}

.home-main-balanced .home-main-panel h2 {
    margin-top: 0;
    margin-bottom: 1rem;
    font-size: clamp(2.3rem, 5.1vw, 4rem);
}

.home-main-balanced .home-main-panel .home-hero-text {
    max-width: 740px;
}

.home-main-balanced .home-info-panel {
    align-self: center;
    padding: clamp(1.1rem, 2.2vw, 1.55rem);
    border-radius: 24px;
    background:
        radial-gradient(circle at 100% 0%, rgba(47, 100, 115, 0.11), transparent 38%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 250, 250, 0.98));
}

.home-main-balanced .home-info-kicker {
    margin-bottom: 0.75rem;
    background: rgba(47, 100, 115, 0.08);
}

.home-main-balanced .home-info-panel h2 {
    margin-bottom: 0.55rem;
    font-size: clamp(1.35rem, 1.9vw, 1.72rem);
}

.home-main-balanced .home-info-panel > p {
    line-height: 1.45;
    font-size: 0.93rem;
}

.home-main-balanced .home-info-list {
    margin-top: 0.9rem;
    gap: 0.65rem;
}

.home-main-balanced .home-info-item {
    position: relative;
    padding: 0.8rem;
    border-radius: 17px;
    background: rgba(255, 255, 255, 0.9);
}

.home-main-balanced .home-info-item::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.home-main-balanced .home-info-icon {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
    border-radius: 13px;
    background: rgba(47, 100, 115, 0.1);
}

.home-main-balanced .home-info-item h3 {
    font-size: 0.98rem;
    margin-bottom: 0.12rem;
}

.home-main-balanced .home-info-item p {
    font-size: 0.87rem;
    line-height: 1.36;
}

@media (max-width: 900px) {
    .home-main-balanced .home-top-grid {
        grid-template-columns: 1fr;
    }

    .home-main-balanced .home-main-panel {
        min-height: auto;
    }

    .home-main-balanced .home-info-panel {
        align-self: stretch;
    }
}

@media (max-width: 560px) {
    .home-main-balanced .home-main-panel {
        padding: 1.15rem;
    }

    .home-main-balanced .home-main-panel h2 {
        font-size: clamp(1.9rem, 10vw, 2.55rem);
        margin-bottom: 0.8rem;
    }

    .home-main-balanced .home-main-actions {
        margin-top: 1.15rem;
    }

    .home-main-balanced .home-info-panel {
        padding: 1rem;
    }

    .home-main-balanced .home-info-list {
        gap: 0.55rem;
    }

    .home-main-balanced .home-info-item {
        padding: 0.75rem;
    }
}

/* ACCUEIL - ajustements finaux : kicker principal et contact léger */
.home-main-balanced .home-main-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    width: fit-content;
    margin: 0 0 0.75rem;
    color: var(--primary);
    font-size: 0.86rem;
    font-weight: 900;
    letter-spacing: 0.02em;
}

.home-main-balanced .home-main-kicker::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--primary);
    box-shadow: 0 0 0 4px rgba(47, 100, 115, 0.1);
}

.home-main-balanced .home-main-panel h2 {
    font-size: clamp(2.15rem, 4.65vw, 3.65rem);
    line-height: 1.02;
}

.home-main-balanced .home-info-kicker {
    display: none;
}

.home-contact-strip {
    max-width: var(--max-width);
    margin: 2rem auto 0;
    padding: 1rem 1.2rem;
    border: 1px solid rgba(47, 100, 115, 0.14);
    border-radius: 20px;
    background: rgba(47, 100, 115, 0.06);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    box-shadow: 0 10px 26px rgba(19, 44, 52, 0.045);
}

.home-contact-strip strong {
    display: block;
    color: var(--text);
    font-size: 1rem;
    margin-bottom: 0.18rem;
}

.home-contact-strip p {
    margin: 0;
    color: var(--muted);
    font-size: 0.95rem;
    line-height: 1.45;
}

.home-contact-link {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0.65rem 0.95rem;
    border-radius: 999px;
    color: var(--primary);
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid rgba(47, 100, 115, 0.14);
    font-weight: 900;
    text-decoration: none;
    transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s ease, border-color 0.18s ease;
}

.home-contact-link:hover {
    color: var(--primary-dark);
    background: #fff;
    border-color: rgba(47, 100, 115, 0.28);
    transform: translateY(-1px);
}

@media (max-width: 760px) {
    .home-main-balanced .home-main-kicker {
        margin-bottom: 0.65rem;
        font-size: 0.82rem;
    }

    .home-main-balanced .home-main-panel h2 {
        font-size: clamp(1.82rem, 9.2vw, 2.42rem);
        line-height: 1.06;
    }

    .home-contact-strip {
        margin: 1.5rem 1rem 0;
        padding: 1rem;
        flex-direction: column;
        align-items: flex-start;
        border-radius: 18px;
    }

    .home-contact-link {
        width: 100%;
    }
}


/* ACCUEIL - touche écologique et mini-cartes cliquables */
.home-main-balanced .home-benefit-card.is-eco {
    background:
        radial-gradient(circle at 100% 0%, rgba(74, 163, 104, 0.15), transparent 36%),
        linear-gradient(135deg, rgba(74, 163, 104, 0.10), rgba(255, 255, 255, 0.96));
    border-color: rgba(74, 163, 104, 0.28);
}

.home-main-balanced .home-benefit-card.is-eco .home-benefit-icon {
    background: rgba(74, 163, 104, 0.14);
    color: #2f7d4f;
    box-shadow: 0 10px 24px rgba(74, 163, 104, 0.12);
}

.home-main-balanced .home-benefit-card.is-eco h3 {
    color: #2f7d4f;
}

.home-main-balanced .home-info-link {
    color: inherit;
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

.home-main-balanced .home-info-link:hover {
    transform: translateY(-2px);
    border-color: rgba(47, 100, 115, 0.30);
    background: rgba(47, 100, 115, 0.065);
    box-shadow: 0 14px 28px rgba(19, 44, 52, 0.075);
}

.home-main-balanced .home-info-link:focus-visible {
    outline: 3px solid rgba(47, 100, 115, 0.25);
    outline-offset: 3px;
}

.home-main-balanced .home-info-link:hover .home-info-icon {
    background: rgba(47, 100, 115, 0.16);
}

@media (max-width: 760px) {
    .home-main-balanced .home-info-link {
        min-height: 64px;
    }
}

/* FINALISATION - badge accueil plus écologique, ancre résultats et lien mot de passe oublié */
.home-main-balanced .home-main-kicker.eco-kicker {
    color: #2f7d4f;
    background: rgba(74, 163, 104, 0.09);
    border: 1px solid rgba(74, 163, 104, 0.18);
    padding: 0.35rem 0.68rem;
    border-radius: 999px;
    box-shadow: 0 10px 22px rgba(74, 163, 104, 0.07);
}

.home-main-balanced .home-main-kicker.eco-kicker::before {
    content: none;
}

.eco-kicker-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    line-height: 1;
    filter: saturate(1.08);
}

#resultats-annonces {
    scroll-margin-top: 1.5rem;
}

.auth-forgot-link {
    display: inline-flex;
    width: fit-content;
    margin-top: 0.55rem;
    color: var(--primary);
    font-weight: 800;
    text-decoration: none;
    font-size: 0.95rem;
}

.auth-forgot-link:hover,
.auth-forgot-link:focus-visible {
    color: var(--primary-dark);
    text-decoration: underline;
}

.auth-forgot-link:focus-visible {
    outline: 3px solid rgba(47, 100, 115, 0.22);
    outline-offset: 3px;
    border-radius: 8px;
}

.reset-token-note {
    color: var(--muted);
    font-size: 0.95rem;
    line-height: 1.55;
    margin: 0.2rem 0 1rem;
}

@media (max-width: 760px) {
    .home-main-balanced .home-main-kicker.eco-kicker {
        padding: 0.32rem 0.62rem;
    }

    #resultats-annonces {
        scroll-margin-top: 0.8rem;
    }
}


/* PROFESSIONNALISATION MVP - confiance, responsabilité et résultats */
.home-trust-section {
    max-width: var(--max-width);
    margin: 2.2rem auto 0;
    padding: 1.25rem;
    border: 1px solid rgba(47, 100, 115, 0.12);
    border-radius: 26px;
    background: linear-gradient(135deg, rgba(47, 100, 115, 0.055), rgba(255, 255, 255, 0.96));
    box-shadow: 0 14px 34px rgba(19, 44, 52, 0.055);
}

.home-trust-header {
    max-width: 820px;
    margin-bottom: 1rem;
}

.home-trust-header h2 {
    color: var(--text);
    font-size: clamp(1.45rem, 2.4vw, 2rem);
    line-height: 1.12;
    margin-bottom: 0.45rem;
}

.home-trust-header p {
    color: var(--muted);
    line-height: 1.65;
    margin: 0;
}

.home-trust-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.home-trust-card {
    display: flex;
    gap: 0.8rem;
    align-items: flex-start;
    padding: 1rem;
    border: 1px solid rgba(47, 100, 115, 0.11);
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.78);
}

.home-trust-icon {
    width: 38px;
    height: 38px;
    flex: 0 0 38px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(47, 100, 115, 0.09);
    color: var(--primary);
    font-weight: 900;
}

.home-trust-card h3 {
    margin: 0 0 0.25rem;
    color: var(--text);
    font-size: 1rem;
}

.home-trust-card p {
    margin: 0;
    color: var(--muted);
    font-size: 0.94rem;
    line-height: 1.45;
}

.annonce-help-note {
    margin: 0 0 1rem;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(47, 100, 115, 0.12);
    border-radius: 16px;
    background: rgba(47, 100, 115, 0.055);
    color: var(--muted);
    line-height: 1.5;
    font-size: 0.95rem;
}

.responsibility-check {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin: 1.1rem 0 0;
    padding: 1rem;
    border: 1px solid rgba(47, 100, 115, 0.14);
    border-radius: 18px;
    background: rgba(47, 100, 115, 0.055);
    color: var(--text);
    font-weight: 750;
    line-height: 1.45;
    cursor: pointer;
}

.responsibility-check input {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    margin-top: 0.15rem;
    accent-color: var(--primary);
}

.results-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    text-align: left;
}

.results-count {
    color: var(--text);
    font-weight: 800;
    font-size: 1rem;
}

.results-context {
    color: var(--muted);
    font-size: 0.94rem;
    line-height: 1.45;
    text-align: right;
}

.empty-results {
    border: 1px solid rgba(47, 100, 115, 0.13);
    background: linear-gradient(135deg, rgba(47, 100, 115, 0.055), rgba(255, 255, 255, 0.96));
}

.empty-results h3 {
    color: var(--text);
}

.empty-results-actions {
    margin-top: 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.8rem;
    flex-wrap: wrap;
}

@media (max-width: 760px) {
    .home-trust-section {
        margin: 1.5rem 1rem 0;
        padding: 1rem;
        border-radius: 22px;
    }

    .home-trust-grid {
        grid-template-columns: 1fr;
    }

    .home-trust-card {
        padding: 0.9rem;
    }

    .responsibility-check {
        padding: 0.9rem;
    }

    .results-summary {
        align-items: flex-start;
        flex-direction: column;
        text-align: left;
    }

    .results-context {
        text-align: left;
    }

    .empty-results-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .empty-results-actions .cta-button,
    .empty-results-actions .reset-link {
        width: 100%;
        justify-content: center;
        text-align: center;
    }
}


/* Ajustements ciblés : cartes annonces plus compactes + distance plus moderne */
.annonces-section .annonce-card h3 {
    min-height: auto !important;
    max-height: 2.35em !important;
    margin-bottom: 0.35rem !important;
    line-height: 1.16 !important;
}

.annonces-section .annonce-card .card-topline {
    margin-bottom: 0.55rem !important;
}

.annonces-section .annonce-meta {
    gap: 0.45rem !important;
    margin-top: 0.45rem !important;
}

.annonces-section .annonce-meta li {
    min-height: 48px !important;
    height: 48px !important;
    max-height: 48px !important;
    padding: 0.55rem 0.65rem !important;
}

.annonces-section .annonce-meta li strong {
    margin-bottom: 0.08rem !important;
    font-size: 0.78rem !important;
}

.annonces-section .annonce-meta-value {
    line-height: 1.16 !important;
}

.annonces-section .annonce-card .annonce-description-preview,
.annonces-section .annonce-card > p {
    margin-top: 0.65rem !important;
    min-height: 2.45em !important;
    height: 2.45em !important;
    max-height: 2.45em !important;
    line-height: 1.25 !important;
}

.annonces-section .annonce-card .inline-actions {
    margin-top: 0.75rem !important;
}

.annonces-section .annonce-card .annonce-meta li.annonce-distance {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0.38rem !important;
    min-height: 48px !important;
    height: 48px !important;
    max-height: 48px !important;
    margin-top: 0 !important;
    padding: 0.55rem 0.65rem !important;
    border-left: 0 !important;
    border: 1px solid rgba(47, 100, 115, 0.14) !important;
    border-radius: 12px !important;
    background: rgba(47, 100, 115, 0.045) !important;
    color: var(--muted) !important;
    font-size: 0.92rem !important;
    font-weight: 650 !important;
    line-height: 1.15 !important;
}

.annonces-section .annonce-distance-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    color: var(--primary) !important;
    font-size: 0.95rem !important;
    line-height: 1 !important;
}

.annonces-section .annonce-distance-value {
    min-width: 0 !important;
    color: var(--primary-dark) !important;
    font-size: 0.96rem !important;
    font-weight: 750 !important;
    line-height: 1.15 !important;
    white-space: nowrap !important;
}

.deposit-title-simple {
    padding-bottom: 0.6rem !important;
}

.deposit-title-simple h2 {
    margin-bottom: 0 !important;
}

@media (max-width: 900px) {
    .annonces-section .annonce-meta li,
    .annonces-section .annonce-card .annonce-meta li.annonce-distance {
        min-height: 46px !important;
        height: 46px !important;
        max-height: 46px !important;
    }
}

@media (max-width: 600px) {
    .annonces-section .annonce-card h3 {
        max-height: none !important;
    }

    .annonces-section .annonce-meta {
        gap: 0.4rem !important;
    }

    .annonces-section .annonce-meta li,
    .annonces-section .annonce-card .annonce-meta li.annonce-distance {
        min-height: 44px !important;
        height: auto !important;
        max-height: none !important;
        padding: 0.52rem 0.62rem !important;
    }
}

/* Vérification email - Mat'Local */
.alert-warning {
    border: 1px solid rgba(190, 120, 20, 0.24);
    background: rgba(255, 193, 87, 0.14);
    color: #6f4b0f;
    border-radius: 18px;
    padding: 1rem;
    margin-bottom: 1rem;
}

.account-verification-alert a {
    color: var(--primary);
    font-weight: 800;
    text-decoration: none;
}

.account-verification-alert a:hover,
.account-verification-alert a:focus-visible {
    text-decoration: underline;
}

.account-verification-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-bottom: 1rem;
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
    background: rgba(61, 139, 92, 0.10);
    color: #2f7d4f;
    border: 1px solid rgba(61, 139, 92, 0.18);
    font-size: 0.92rem;
    font-weight: 800;
}

.email-verification-state,
.email-verification-card {
    text-align: left;
}

@media (max-width: 760px) {
    .account-verification-badge {
        width: 100%;
        justify-content: flex-start;
        border-radius: 16px;
    }
}

/* Préparation légale / déploiement */
.legal-page {
    max-width: 1180px;
    margin-inline: auto;
}

.legal-card {
    margin: 1rem auto;
    padding: 1.35rem;
    border: 1px solid var(--border);
    border-radius: 22px;
    background: var(--surface);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.045);
}

.legal-card h3 {
    margin: 0 0 0.75rem;
    color: var(--text);
    font-size: 1.2rem;
}

.legal-card p {
    color: var(--muted);
    line-height: 1.65;
}

.legal-card a {
    color: var(--primary);
    font-weight: 800;
    text-decoration: none;
}

.legal-card a:hover,
.legal-card a:focus-visible {
    text-decoration: underline;
}

.legal-list {
    margin: 0.7rem 0 0;
    padding-left: 1.25rem;
    color: var(--muted);
    line-height: 1.65;
}

.legal-list li + li {
    margin-top: 0.35rem;
}

.legal-warning-card {
    border-color: rgba(61, 139, 92, 0.24);
    background: linear-gradient(135deg, rgba(61, 139, 92, 0.08), rgba(255, 255, 255, 0.96));
}

.legal-help-note {
    border-color: rgba(61, 139, 92, 0.20);
    background: rgba(61, 139, 92, 0.07);
    color: var(--text);
}

.site-footer a {
    color: inherit;
    font-weight: 800;
    text-decoration: none;
}

.site-footer a:hover,
.site-footer a:focus-visible {
    text-decoration: underline;
}

@media (max-width: 760px) {
    .legal-card {
        padding: 1rem;
        border-radius: 18px;
    }

    .legal-card h3 {
        font-size: 1.08rem;
    }
}


/* PATCH ACCUEIL - charte plus vivante, moderne et écologique
   Objectif : ajouter de la couleur sans casser la structure existante. */
:root {
    --accent-green: #3fa66b;
    --accent-green-dark: #2f7d4f;
    --accent-sand: #f0b45a;
    --accent-sand-soft: rgba(240, 180, 90, 0.16);
    --accent-sky: #4da3b3;
    --accent-leaf-soft: rgba(74, 163, 104, 0.12);
}

body {
    background:
        radial-gradient(circle at 12% 8%, rgba(74, 163, 104, 0.10), transparent 28%),
        radial-gradient(circle at 88% 16%, rgba(240, 180, 90, 0.11), transparent 26%),
        linear-gradient(180deg, #f7faf7 0%, var(--bg) 46%, #f5f7f6 100%);
}

.home-main-balanced .home-top-grid {
    position: relative;
}

.home-main-balanced .home-top-grid::before {
    content: "";
    position: absolute;
    inset: -1rem;
    z-index: -1;
    border-radius: 34px;
    background:
        radial-gradient(circle at 20% 20%, rgba(74, 163, 104, 0.16), transparent 32%),
        radial-gradient(circle at 82% 15%, rgba(240, 180, 90, 0.14), transparent 28%);
    filter: blur(2px);
    opacity: 0.85;
}

.home-main-balanced .home-main-panel {
    background:
        radial-gradient(circle at 96% 10%, rgba(240, 180, 90, 0.18), transparent 28%),
        radial-gradient(circle at 6% 95%, rgba(74, 163, 104, 0.16), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,0.98), rgba(248,252,249,0.96));
    border-color: rgba(74, 163, 104, 0.16);
    box-shadow: 0 22px 48px rgba(31, 70, 82, 0.10);
}

.home-main-balanced .home-main-panel h2 {
    color: #253c35;
}

.home-main-balanced .home-main-panel h2::after {
    content: "";
    display: block;
    width: 86px;
    height: 5px;
    margin-top: 0.85rem;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--accent-green), var(--accent-sand));
}

.home-main-balanced .home-hero-text {
    color: #50615c;
}

.home-main-balanced .home-primary-action {
    background: linear-gradient(135deg, var(--primary), var(--accent-green));
    box-shadow: 0 16px 34px rgba(47, 100, 115, 0.20);
}

.home-main-balanced .home-primary-action:hover,
.home-main-balanced .home-primary-action:focus-visible {
    background: linear-gradient(135deg, var(--primary-dark), var(--accent-green-dark));
    box-shadow: 0 18px 38px rgba(47, 100, 115, 0.25);
}

.home-main-balanced .home-main-kicker.eco-kicker {
    color: var(--accent-green-dark);
    background: linear-gradient(135deg, rgba(74, 163, 104, 0.13), rgba(240, 180, 90, 0.10));
    border-color: rgba(74, 163, 104, 0.25);
}

.home-main-balanced .home-info-panel {
    background:
        radial-gradient(circle at 100% 0%, rgba(77, 163, 179, 0.15), transparent 34%),
        radial-gradient(circle at 0% 100%, rgba(240, 180, 90, 0.12), transparent 32%),
        linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,252,251,0.98));
    border-color: rgba(77, 163, 179, 0.18);
    box-shadow: 0 18px 38px rgba(31, 70, 82, 0.08);
}

.home-main-balanced .home-info-panel h2 {
    color: #253c35;
}

.home-main-balanced .home-info-panel > p {
    color: #66746f;
}

.home-main-balanced .home-info-item:nth-child(1) .home-info-icon {
    background: rgba(77, 163, 179, 0.14);
    color: var(--accent-sky);
}

.home-main-balanced .home-info-item:nth-child(2) .home-info-icon {
    background: rgba(74, 163, 104, 0.14);
    color: var(--accent-green-dark);
}

.home-main-balanced .home-info-link:hover:nth-child(1) {
    background: rgba(77, 163, 179, 0.075);
    border-color: rgba(77, 163, 179, 0.26);
}

.home-main-balanced .home-info-link:hover:nth-child(2) {
    background: rgba(74, 163, 104, 0.080);
    border-color: rgba(74, 163, 104, 0.28);
}

.home-main-balanced .home-benefit-card,
.home-main-balanced .home-step-card,
.home-trust-card {
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.home-main-balanced .home-benefit-card:hover,
.home-main-balanced .home-step-card:hover,
.home-trust-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 36px rgba(31, 70, 82, 0.09);
}

.home-main-balanced .home-benefit-card:nth-child(1) .home-benefit-icon,
.home-trust-card:nth-child(1) .home-trust-icon {
    background: rgba(77, 163, 179, 0.12);
    color: var(--accent-sky);
}

.home-main-balanced .home-benefit-card:nth-child(2) .home-benefit-icon {
    background: var(--accent-sand-soft);
    color: #b5741f;
}

.home-main-balanced .home-step-number {
    background: linear-gradient(135deg, var(--primary), var(--accent-green));
    box-shadow: 0 10px 22px rgba(47, 100, 115, 0.16);
}

.home-trust-card:nth-child(2) .home-trust-icon {
    background: var(--accent-sand-soft);
    color: #b5741f;
}

.home-trust-card:nth-child(3) .home-trust-icon {
    background: rgba(74, 163, 104, 0.12);
    color: var(--accent-green-dark);
}

.home-contact-strip {
    background:
        linear-gradient(135deg, rgba(74, 163, 104, 0.08), rgba(240, 180, 90, 0.08));
    border-color: rgba(74, 163, 104, 0.18);
}

@media (max-width: 760px) {
    .home-main-balanced .home-top-grid::before {
        inset: -0.45rem;
        border-radius: 24px;
    }

    .home-main-balanced .home-main-panel h2::after {
        width: 68px;
        height: 4px;
        margin-top: 0.65rem;
    }
}

/* PATCH FINAL - charte plus vivante, sans dégradé vert/jaune
   Objectif : garder un rendu professionnel, plus coloré, mais sans effet cheap. */
:root {
    --accent-green: #3d8b5c;
    --accent-green-dark: #2f7049;
    --accent-sky: #3e9caf;
    --accent-clay: #c96f3d;
    --accent-clay-soft: rgba(201, 111, 61, 0.12);
    --accent-blue-soft: rgba(62, 156, 175, 0.12);
    --accent-green-soft: rgba(61, 139, 92, 0.12);
}

body {
    background:
        radial-gradient(circle at 8% 10%, rgba(62, 156, 175, 0.08), transparent 30%),
        radial-gradient(circle at 92% 14%, rgba(61, 139, 92, 0.08), transparent 28%),
        linear-gradient(180deg, #f7fbfa 0%, var(--bg) 52%, #f5f8f7 100%);
}

.home-main-balanced .home-top-grid::before {
    background:
        radial-gradient(circle at 18% 18%, rgba(62, 156, 175, 0.13), transparent 34%),
        radial-gradient(circle at 84% 16%, rgba(61, 139, 92, 0.12), transparent 32%);
    opacity: 0.75;
}

.home-main-balanced .home-main-panel {
    background:
        radial-gradient(circle at 95% 8%, rgba(62, 156, 175, 0.12), transparent 30%),
        radial-gradient(circle at 8% 96%, rgba(61, 139, 92, 0.12), transparent 34%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(247, 252, 251, 0.98));
    border-color: rgba(47, 100, 115, 0.13);
    box-shadow: 0 22px 48px rgba(31, 70, 82, 0.10);
}

.home-main-balanced .home-main-panel h2::after {
    background: var(--accent-green);
    box-shadow: 24px 0 0 var(--accent-sky), 48px 0 0 rgba(201, 111, 61, 0.75);
    width: 18px;
    height: 5px;
}

.home-main-balanced .home-primary-action {
    background: #2f6473;
    box-shadow: 0 16px 34px rgba(47, 100, 115, 0.22);
}

.home-main-balanced .home-primary-action:hover,
.home-main-balanced .home-primary-action:focus-visible {
    background: #254f5b;
    box-shadow: 0 18px 38px rgba(47, 100, 115, 0.28);
}

.home-main-balanced .home-main-kicker.eco-kicker {
    color: var(--accent-green-dark);
    background: rgba(61, 139, 92, 0.09);
    border-color: rgba(61, 139, 92, 0.18);
}

.home-main-balanced .home-info-panel {
    background:
        radial-gradient(circle at 100% 0%, rgba(62, 156, 175, 0.13), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 251, 250, 0.98));
    border-color: rgba(62, 156, 175, 0.16);
    box-shadow: 0 18px 38px rgba(31, 70, 82, 0.08);
}

.home-main-balanced .home-info-link:hover:nth-child(1) {
    background: rgba(62, 156, 175, 0.075);
    border-color: rgba(62, 156, 175, 0.28);
}

.home-main-balanced .home-info-link:hover:nth-child(2) {
    background: rgba(61, 139, 92, 0.08);
    border-color: rgba(61, 139, 92, 0.30);
}

.home-main-balanced .home-benefit-card:nth-child(2) .home-benefit-icon,
.home-trust-card:nth-child(2) .home-trust-icon {
    background: var(--accent-clay-soft);
    color: var(--accent-clay);
}

.home-main-balanced .home-step-number {
    background: #2f6473;
    box-shadow: 0 10px 22px rgba(47, 100, 115, 0.16);
}

.home-contact-strip {
    background: rgba(47, 100, 115, 0.055);
    border-color: rgba(47, 100, 115, 0.14);
}

.home-main-balanced .home-benefit-card.is-eco,
.home-main-balanced .home-benefit-card.eco,
.home-main-balanced .home-benefit-card:nth-child(3) {
    background:
        radial-gradient(circle at 100% 0%, rgba(61, 139, 92, 0.12), transparent 36%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 252, 249, 0.98));
    border-color: rgba(61, 139, 92, 0.22);
}

.home-main-balanced .home-benefit-card.is-eco .home-benefit-icon,
.home-main-balanced .home-benefit-card.eco .home-benefit-icon,
.home-main-balanced .home-benefit-card:nth-child(3) .home-benefit-icon {
    background: rgba(61, 139, 92, 0.13);
    color: var(--accent-green-dark);
}


/* Patch page Déposer : choix du type en cartes */
.deposit-type-choice {
    margin-bottom: 1rem;
}

.deposit-type-heading {
    margin-bottom: 0.75rem;
}

.deposit-type-heading h4 {
    margin: 0 0 0.25rem;
    color: var(--text);
    font-size: 1.05rem;
    line-height: 1.25;
}

.deposit-type-heading p {
    margin: 0;
    color: var(--muted);
    font-size: 0.95rem;
    line-height: 1.4;
}

.deposit-type-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
    margin: 0.85rem 0 1rem;
}

.deposit-type-card {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    min-height: 104px;
    padding: 1rem 1.05rem;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: var(--surface);
    cursor: pointer;
    transition: border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.deposit-type-card:hover {
    transform: translateY(-1px);
    border-color: rgba(47, 100, 115, 0.35);
    box-shadow: 0 10px 24px rgba(21, 38, 45, 0.08);
}

.deposit-type-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.deposit-type-card.is-selected {
    border-color: var(--primary);
    background:
        radial-gradient(circle at 100% 0%, rgba(61, 139, 92, 0.10), transparent 38%),
        rgba(47, 100, 115, 0.07);
    box-shadow: 0 12px 28px rgba(47, 100, 115, 0.12);
}

.deposit-type-card.is-selected::after {
    content: "✓";
    position: absolute;
    top: 0.8rem;
    right: 0.8rem;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: var(--primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 0.85rem;
}

.deposit-type-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-radius: 15px;
    background: rgba(47, 100, 115, 0.10);
    color: var(--primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 1.25rem;
    line-height: 1;
}

.deposit-type-content {
    display: block;
    min-width: 0;
    padding-right: 1.45rem;
}

.deposit-type-card strong {
    display: block;
    color: var(--text);
    font-size: 1.03rem;
    margin-bottom: 0.25rem;
    line-height: 1.25;
}

.deposit-type-card small {
    display: block;
    color: var(--muted);
    line-height: 1.35;
}

.deposit-responsibility-note {
    margin: 0.75rem 0 0;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(47, 100, 115, 0.12);
    border-radius: 16px;
    background: rgba(47, 100, 115, 0.045);
    color: var(--muted);
    font-size: 0.92rem;
    line-height: 1.45;
}

@media (max-width: 760px) {
    .deposit-type-grid {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }

    .deposit-type-card {
        min-height: auto;
        padding: 0.95rem;
        border-radius: 18px;
    }

    .deposit-type-icon {
        width: 40px;
        height: 40px;
        flex-basis: 40px;
        font-size: 1.1rem;
    }

    .deposit-type-card strong {
        font-size: 1rem;
    }

    .deposit-type-card small,
    .deposit-type-heading p,
    .deposit-responsibility-note {
        font-size: 0.9rem;
    }
}

/* Gestion de compte - Mes annonces */
.account-panel {
    margin: 1.25rem 0 1.5rem;
    padding: 1.15rem;
    border: 1px solid var(--border);
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(47, 100, 115, 0.06), rgba(255, 255, 255, 0.96));
    box-shadow: 0 12px 28px rgba(19, 43, 51, 0.06);
}

.account-panel-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.account-panel-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-bottom: 0.35rem;
    color: var(--primary);
    font-size: 0.85rem;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.account-panel-kicker::before {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: var(--primary);
}

.account-panel h3,
.delete-account-card h2 {
    margin: 0;
    color: var(--text);
}

.account-panel p {
    margin: 0.25rem 0 0;
    color: var(--muted);
}

.account-panel-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.account-info-item {
    padding: 0.85rem;
    border: 1px solid rgba(47, 100, 115, 0.10);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.78);
}

.account-info-item span,
.account-info-item small {
    display: block;
    color: var(--muted);
    font-size: 0.9rem;
    line-height: 1.35;
}

.account-info-item strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--text);
    font-size: 0.98rem;
    overflow-wrap: anywhere;
}

.account-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    flex: 0 0 auto;
}


.account-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0.48rem 0.75rem;
    border-radius: 999px;
    font-size: 0.9rem;
    font-weight: 800;
    line-height: 1.1;
    white-space: nowrap;
}

.account-status-pill.is-verified {
    border: 1px solid rgba(61, 139, 92, 0.18);
    background: rgba(61, 139, 92, 0.10);
    color: #2f7d4f;
}

.account-status-pill.is-pending {
    border: 1px solid rgba(190, 120, 20, 0.22);
    background: rgba(255, 193, 87, 0.14);
    color: #6f4b0f;
}

.account-inline-warning {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin: -0.15rem 0 1rem;
    padding: 0.75rem 0.9rem;
    border: 1px solid rgba(190, 120, 20, 0.18);
    border-radius: 16px;
    background: rgba(255, 193, 87, 0.10);
    color: #6f4b0f;
    font-size: 0.95rem;
    font-weight: 700;
}

.account-inline-warning a {
    color: var(--primary);
    font-weight: 850;
    text-decoration: none;
    white-space: nowrap;
}

.account-inline-warning a:hover,
.account-inline-warning a:focus-visible {
    text-decoration: underline;
}

.account-button {
    min-height: 42px;
}

.account-delete-link {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    color: #a44235;
    font-size: 0.95rem;
    font-weight: 800;
    text-decoration: none;
}

.account-delete-link:hover,
.account-delete-link:focus-visible {
    text-decoration: underline;
}

.account-page-main .form-card,
.delete-account-card {
    max-width: 720px;
    margin-inline: auto;
}

.delete-account-warning {
    margin: 0.75rem 0 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid rgba(164, 66, 53, 0.18);
    border-radius: 16px;
    background: rgba(164, 66, 53, 0.07);
    color: #763126;
    font-weight: 700;
    line-height: 1.45;
}

.account-delete-list {
    margin: 1rem 0;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--text);
}

.account-delete-list ul {
    margin: 0.5rem 0 0;
    padding-left: 1.2rem;
    color: var(--muted);
}

.delete-confirm-check {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    margin: 1rem 0;
    padding: 0.9rem 1rem;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.76);
    color: var(--text);
    font-weight: 700;
    cursor: pointer;
}

.delete-confirm-check input {
    width: 18px;
    height: 18px;
    margin-top: 0.1rem;
    flex: 0 0 18px;
    accent-color: #a44235;
}

.danger-button {
    background: #a44235;
    color: #fff;
    box-shadow: 0 12px 24px rgba(164, 66, 53, 0.18);
}

.danger-button:hover,
.danger-button:focus-visible {
    background: #8f352a;
    box-shadow: 0 14px 28px rgba(164, 66, 53, 0.24);
}

@media (max-width: 900px) {
    .account-panel-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .account-panel {
        padding: 1rem;
        border-radius: 18px;
    }

    .account-panel-heading {
        flex-direction: column;
        align-items: stretch;
    }

    .account-actions {
        justify-content: flex-start;
    }

    .account-inline-warning {
        flex-direction: column;
        align-items: flex-start;
    }

    .account-panel-grid {
        grid-template-columns: 1fr;
    }

    .account-status-pill,
    .account-button,
    .account-delete-link,
    .danger-button {
        width: 100%;
        justify-content: center;
        text-align: center;
    }
}

/* Patch parcours inscription / email confirmé - carte d'attente email */
.email-waiting-section {
    display: flex;
    justify-content: center;
    padding: 1.5rem 0 2.5rem;
}

.email-waiting-card {
    max-width: 680px;
    width: 100%;
    text-align: center;
    padding: 2rem;
}

.email-waiting-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 18px;
    background: rgba(47, 100, 115, 0.10);
    color: var(--primary);
    font-size: 1.6rem;
    margin-bottom: 1rem;
}

.email-waiting-card h2 {
    margin: 0 0 0.65rem;
    color: var(--text);
    font-size: clamp(1.55rem, 4vw, 2rem);
}

.email-waiting-card p {
    color: var(--muted);
    margin-left: auto;
    margin-right: auto;
    max-width: 520px;
}

.email-waiting-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    flex-wrap: wrap;
    margin-top: 1.25rem;
}

.email-waiting-note {
    font-size: 0.92rem;
    margin-top: 1rem;
}

@media (max-width: 760px) {
    .email-waiting-card {
        padding: 1.25rem;
    }

    .email-waiting-icon {
        width: 48px;
        height: 48px;
    }

    .email-waiting-actions {
        align-items: stretch;
    }

    .email-waiting-actions .cta-button,
    .email-waiting-actions .reset-link {
        width: 100%;
        justify-content: center;
        text-align: center;
    }
}
