/* Interface admin — même charte graphique que le planning public */
.admin-main { max-width: 980px; margin: 0 auto; padding: 28px; }
.admin-nav { display: flex; gap: 8px; align-items: center; padding: 10px 28px; background: linear-gradient(90deg, #0a2251, #163d7a); }
.admin-nav a { color: rgba(255,255,255,0.75); font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; text-decoration: none; padding: 6px 12px; border-radius: 6px; transition: background .15s; }
.admin-nav a:hover, .admin-nav a.active { background: rgba(255,255,255,0.12); color: #fff; }
.admin-nav .spacer { flex: 1; }

.panel { background: var(--blanc); border-radius: 10px; box-shadow: 0 2px 10px var(--ombre); padding: 20px; margin-bottom: 22px; }
.panel h2 { font-family: 'Bebas Neue', sans-serif; font-size: 22px; letter-spacing: 2px; color: var(--marine); margin-bottom: 14px; }
.panel h3 { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--bleu-roi); margin: 14px 0 8px; }

.form-grid { display: flex; flex-wrap: wrap; gap: 10px; align-items: flex-end; }
.field { display: flex; flex-direction: column; gap: 4px; }
.field label { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: #88a0ba; }
.field input, .field select, .field textarea { font-family: 'Nunito', sans-serif; font-size: 13px; padding: 8px 10px; border: 1.5px solid var(--gris-clair); border-radius: 7px; background: var(--fond); color: var(--texte); outline: none; transition: border-color .15s; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--bleu-ciel); background: #fff; }
.field textarea { min-height: 56px; resize: vertical; }

.btn { display: inline-flex; align-items: center; gap: 6px; font-family: 'Nunito', sans-serif; font-size: 12px; font-weight: 800; letter-spacing: .5px; padding: 8px 16px; border: none; border-radius: 7px; cursor: pointer; background: var(--bleu-roi); color: #fff; transition: filter .15s, transform .1s; text-decoration: none; }
.btn:hover { filter: brightness(1.12); }
.btn:active { transform: scale(.97); }
.btn.secondary { background: var(--gris-clair); color: var(--marine); }
.btn.danger { background: #c0392b; }
.btn.small { padding: 4px 10px; font-size: 11px; }
.btn.ghost { background: transparent; color: #88a0ba; padding: 4px 6px; }
.btn.ghost:hover { color: var(--bleu-roi); }

.admin-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.admin-table th { text-align: left; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: #88a0ba; padding: 8px 10px; border-bottom: 2px solid var(--gris-clair); }
.admin-table td { padding: 9px 10px; border-bottom: 1px solid var(--gris-clair); vertical-align: middle; }
.admin-table tr:hover td { background: var(--fond); }
.admin-table .actions { display: flex; gap: 6px; justify-content: flex-end; flex-wrap: wrap; }
.admin-table form { display: inline; }

.pill { display: inline-block; padding: 2px 10px; border-radius: 20px; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: #fff; }
.pill.montage { background: var(--montage); }
.pill.exploitation { background: var(--exploitation); }
.pill.demontage { background: var(--demontage); }
.pill.cabane { background: var(--marine); }
.pill.neutre { background: var(--gris-mid); color: var(--marine); }

.flash { padding: 10px 16px; border-radius: 8px; font-size: 13px; font-weight: 700; margin-bottom: 16px; }
.flash.ok { background: rgba(42,175,160,.14); color: #137065; border: 1.5px solid rgba(42,175,160,.4); }
.flash.error { background: rgba(192,57,43,.1); color: #962d22; border: 1.5px solid rgba(192,57,43,.35); }

.login-box { max-width: 380px; margin: 80px auto; }
.crumb { font-size: 12px; color: #88a0ba; margin-bottom: 16px; }
.crumb a { color: var(--bleu-roi); text-decoration: none; font-weight: 700; }
.muted { color: #88a0ba; font-size: 12px; }
