/* ============================================================
   Dirty Panard — feuille de style « guide de voyage »
   Palette crème + accent prune, typographie serif.
   ============================================================ */

:root {
    --cream:      #efe9e0;
    --cream-deep: #e6ddcf;
    --ink:        #2a2622;
    --ink-soft:   #6b6258;
    --plum:       #7a2f57;
    --plum-soft:  #9a5b7d;
    --line:       #cdbfa9;
    --danger:     #9b3030;
    --ok:         #3f6b3f;
    --serif:      Georgia, "Times New Roman", "Playfair Display", serif;
    --sans:       -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

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

html { -webkit-text-size-adjust: 100%; }

body {
    background: var(--cream);
    color: var(--ink);
    font-family: var(--serif);
    line-height: 1.6;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

a { color: var(--plum); text-decoration: none; }
a:hover { text-decoration: underline; }

/* --- En-tête / navigation ----------------------------------------------- */
.site {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    padding: 18px 24px;
    border-bottom: 1px solid var(--line);
}
.brand {
    font-size: 26px;
    font-weight: 700;
    color: var(--ink);
    letter-spacing: 0.02em;
}
.brand span { color: var(--plum); font-style: italic; }
.brand:hover { text-decoration: none; }

.nav {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 18px;
    font-family: var(--sans);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}
.nav a { color: var(--ink-soft); padding: 4px 0; }
.nav a:hover { color: var(--plum); text-decoration: none; }
.nav a.active { color: var(--plum); border-bottom: 2px solid var(--plum); }
.nav a.adminlink { color: var(--plum-soft); font-style: italic; }

/* --- Conteneur principal ------------------------------------------------ */
.container {
    width: 100%;
    max-width: 820px;
    margin: 0 auto;
    padding: 40px 24px;
    flex: 1;
}

/* --- Couverture d'accueil ----------------------------------------------- */
.cover {
    text-align: center;
    padding: 40px 0 24px;
}
.cover .eyebrow {
    display: inline-block;
    font-family: var(--sans);
    font-size: 13px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--plum);
    border: 1px solid var(--plum-soft);
    padding: 10px 20px;
    margin-bottom: 36px;
}
.cover h1 {
    font-size: clamp(3rem, 13vw, 6rem);
    line-height: 0.95;
    font-weight: 700;
}
.cover h1 .it { display: block; font-style: italic; color: var(--plum); font-weight: 400; }
.cover .lead {
    font-style: italic;
    font-size: clamp(1.1rem, 3.5vw, 1.5rem);
    color: var(--ink-soft);
    max-width: 30ch;
    margin: 28px auto 0;
}
.cover .note {
    font-style: italic;
    color: var(--ink-soft);
    opacity: 0.8;
    max-width: 46ch;
    margin: 44px auto 0;
    font-size: 0.95rem;
}
.cover .cta {
    margin-top: 40px;
    display: flex;
    gap: 14px;
    justify-content: center;
    flex-wrap: wrap;
}

/* --- Titres de section -------------------------------------------------- */
.section-title {
    text-align: center;
    margin-bottom: 8px;
}
.section-title .eyebrow {
    font-family: var(--sans);
    font-size: 12px;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--plum);
}
.section-title h2 {
    font-size: clamp(2rem, 7vw, 3rem);
    font-weight: 700;
}
.section-sub {
    text-align: center;
    font-style: italic;
    color: var(--ink-soft);
    margin-bottom: 36px;
}

/* --- Carte panard (post) ------------------------------------------------ */
.panard {
    background: var(--cream-deep);
    border: 1px solid var(--line);
    margin-bottom: 32px;
    overflow: hidden;
}
.panard img.photo {
    display: block;
    width: 100%;
    height: auto;
    border-bottom: 1px solid var(--line);
}
.panard .body { padding: 22px 24px; }
.panard h3 { font-size: 1.6rem; line-height: 1.2; }
.panard .desc { margin-top: 10px; color: var(--ink); }
.panard .meta {
    margin-top: 16px;
    font-family: var(--sans);
    font-size: 12px;
    letter-spacing: 0.05em;
    color: var(--ink-soft);
    text-transform: uppercase;
}

/* version « du jour » : mise en avant */
.panard.feature { border: 2px solid var(--plum); }

/* grille du guide */
.grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 24px;
}
.grid .panard { margin-bottom: 0; }
.grid .panard h3 { font-size: 1.3rem; }

.empty {
    text-align: center;
    font-style: italic;
    color: var(--ink-soft);
    padding: 60px 0;
}

/* --- Cartes / formulaires ----------------------------------------------- */
.card {
    background: var(--cream-deep);
    border: 1px solid var(--line);
    padding: 26px;
    margin-bottom: 28px;
}
.card h2 { margin-bottom: 16px; font-size: 1.5rem; }

label {
    display: block;
    font-family: var(--sans);
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-soft);
    margin: 14px 0 6px;
}
input[type=text], input[type=password], input[type=url], input[type=file],
textarea, select {
    width: 100%;
    padding: 11px 12px;
    border: 1px solid var(--line);
    background: #fbf8f2;
    font-family: var(--sans);
    font-size: 15px;
    color: var(--ink);
}
textarea { min-height: 110px; resize: vertical; }
input:focus, textarea:focus, select:focus {
    outline: none;
    border-color: var(--plum);
}

.row { display: flex; gap: 16px; flex-wrap: wrap; }
.row > div { flex: 1; min-width: 160px; }

button, .btn {
    display: inline-block;
    font-family: var(--sans);
    font-size: 13px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 11px 22px;
    border: 1px solid var(--plum);
    background: var(--plum);
    color: #fff;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}
button:hover, .btn:hover { background: #66264a; text-decoration: none; }
.btn.ghost, button.secondary {
    background: transparent;
    color: var(--plum);
}
.btn.ghost:hover, button.secondary:hover { background: var(--plum); color: #fff; }
button.danger {
    background: transparent;
    border-color: var(--danger);
    color: var(--danger);
}
button.danger:hover { background: var(--danger); color: #fff; }

/* --- Alertes ------------------------------------------------------------ */
.alert {
    padding: 12px 16px;
    margin-bottom: 20px;
    border: 1px solid;
    font-family: var(--sans);
    font-size: 14px;
}
.alert.ok    { border-color: var(--ok); color: var(--ok); background: #eef3ee; }
.alert.error { border-color: var(--danger); color: var(--danger); background: #f6eded; }

/* --- Tables admin ------------------------------------------------------- */
table { width: 100%; border-collapse: collapse; font-family: var(--sans); font-size: 14px; }
th, td { text-align: left; padding: 10px 8px; border-bottom: 1px solid var(--line); }
th { font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-soft); }

.badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border: 1px solid var(--line);
    color: var(--ink-soft);
}
.badge.admin { border-color: var(--plum); color: var(--plum); }

.submission {
    display: flex;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid var(--line);
    align-items: flex-start;
}
.submission img.thumb {
    width: 96px;
    height: 96px;
    object-fit: cover;
    border: 1px solid var(--line);
    flex: 0 0 auto;
    background: #fbf8f2;
}
.submission .info { flex: 1; min-width: 0; }
.submission .info .who { font-weight: 700; }
.submission .info .msg { color: var(--ink-soft); margin: 4px 0; }
.submission .info .lnk { font-family: var(--sans); font-size: 12px; word-break: break-all; }
.submission .acts { display: flex; flex-direction: column; gap: 8px; flex: 0 0 auto; }

/* --- Pied de page ------------------------------------------------------- */
.site-footer {
    border-top: 1px solid var(--line);
    padding: 28px 24px;
    text-align: center;
}
.site-footer p {
    font-style: italic;
    color: var(--ink-soft);
    max-width: 50ch;
    margin: 0 auto;
    font-size: 0.92rem;
}

@media (max-width: 560px) {
    .submission { flex-wrap: wrap; }
    .submission .acts { flex-direction: row; }
}
