/* mycamer-lite — CSS admin
   Dashboard moderne, animations fluides, compact. */

:root{
	--bg:#f3f4f7;
	--side-bg:#111827;
	--side-bg-2:#1f2937;
	--side-fg:#9ca3af;
	--side-fg-hover:#fff;
	--side-active:#000;
	--accent:#e60023;
	--accent-dark:#b4001c;
	--ok:#10b981;
	--off:#9ca3af;
	--warn:#f59e0b;
	--danger:#dc2626;
	--info:#3b82f6;
	--border:#e5e7eb;
	--border-dark:#d1d5db;
	--text:#111827;
	--text-muted:#6b7280;
	--radius:8px;
	--radius-sm:4px;
	--shadow:0 1px 2px rgba(0,0,0,.04),0 1px 3px rgba(0,0,0,.05);
	--shadow-hover:0 4px 6px rgba(0,0,0,.06),0 10px 15px rgba(0,0,0,.05);
	--trans:all .2s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
body.admin-body{margin:0;font:14px/1.5 system-ui,-apple-system,Segoe UI,sans-serif;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none;transition:var(--trans)}
a:hover{color:var(--accent-dark)}

/* ============ Layout ============ */
body.admin-body{display:flex;min-height:100vh}

.admin-side{width:240px;background:linear-gradient(180deg,var(--side-bg) 0%,var(--side-bg-2) 100%);color:var(--side-fg);padding:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;box-shadow:2px 0 10px rgba(0,0,0,.1)}
.admin-side::-webkit-scrollbar{width:6px}
.admin-side::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
.admin-brand{display:flex;align-items:center;gap:.6rem;padding:1.2rem;color:#fff;font-weight:700;font-size:1.1rem;border-bottom:1px solid rgba(255,255,255,.08);letter-spacing:.3px}
.admin-brand:hover{color:#fff;text-decoration:none}
.admin-brand::before{content:"";width:28px;height:28px;background:var(--accent);border-radius:50%;box-shadow:inset -5px -5px 0 rgba(0,0,0,.15);flex-shrink:0}
.admin-side nav{padding:.8rem 0;flex:1}
.admin-side nav a{display:flex;align-items:center;gap:.7rem;padding:.6rem 1.2rem;color:var(--side-fg);border-left:3px solid transparent;font-size:.9rem;transition:var(--trans);position:relative}
.admin-side nav a:hover{background:rgba(255,255,255,.05);color:var(--side-fg-hover);text-decoration:none;border-left-color:var(--accent);padding-left:1.4rem}
.admin-side nav a.active{background:rgba(230,0,35,.12);color:#fff;border-left-color:var(--accent)}
.admin-side nav a::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.4;flex-shrink:0}
.nav-group{padding:1.2rem 1.2rem .3rem;font-size:.68rem;text-transform:uppercase;letter-spacing:1.2px;color:#6b7280;font-weight:600}
.admin-user{padding:1rem 1.2rem;border-top:1px solid rgba(255,255,255,.08);font-size:.85rem;background:rgba(0,0,0,.25)}
.admin-user strong{display:block;color:#fff;margin-bottom:.1rem}
.admin-user small{display:block;color:#9ca3af;margin-bottom:.4rem;text-transform:capitalize}
.admin-user a{color:var(--accent);font-size:.85rem}

.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}
.admin-topbar{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1rem 2rem;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.admin-topbar h1{margin:0;font-size:1.3rem;font-weight:700}
.admin-topbar a{font-size:.85rem;color:var(--text-muted);display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .8rem;border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--trans)}
.admin-topbar a:hover{background:var(--bg);color:var(--accent);text-decoration:none;border-color:var(--accent)}
.admin-main > *:not(.admin-topbar){padding:1.5rem 2rem}
.admin-main > .flash{margin:1rem 2rem 0;border-radius:var(--radius-sm);padding:.8rem 1rem}

/* ============ Flash ============ */
.flash{padding:.8rem 1rem;border-radius:var(--radius-sm);background:#fef3c7;border:1px solid #fde68a;animation:slideIn .3s}
.flash-ok{background:#d1fae5;border-color:#6ee7b7;color:#065f46}
.flash-error{background:#fee2e2;border-color:#fca5a5;color:#991b1b}
@keyframes slideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ============ Stats cards (big) ============ */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-bottom:1.2rem}
.stat-card{display:flex;align-items:flex-start;gap:1rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;color:inherit;transition:var(--trans);position:relative;overflow:hidden}
.stat-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}
.stat-card.stat-red::before{background:#e60023}
.stat-card.stat-orange::before{background:#f59e0b}
.stat-card.stat-blue::before{background:#3b82f6}
.stat-card.stat-green::before{background:#10b981}
.stat-card:hover{text-decoration:none;box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.stat-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;color:#fff;flex-shrink:0}
.stat-red .stat-icon{background:linear-gradient(135deg,#e60023,#b4001c)}
.stat-orange .stat-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}
.stat-blue .stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}
.stat-green .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}
.stat-body{flex:1;min-width:0}
.stat-num{font-size:1.8rem;font-weight:800;line-height:1;color:var(--text)}
.stat-label{color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.7px;margin-top:.4rem;font-weight:600}
.stat-sub{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.3rem;align-items:center}
@media (max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.stats-grid{grid-template-columns:1fr}}

/* Mini stats row */
.stats-mini{display:grid;grid-template-columns:repeat(6,1fr);gap:.8rem;margin-bottom:1.5rem}
.mini{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.7rem 1rem;display:flex;flex-direction:column;align-items:flex-start}
.mini .n{font-size:1.2rem;font-weight:700;color:var(--text)}
.mini .l{color:var(--text-muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;margin-top:.1rem}
@media (max-width:1100px){.stats-mini{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){.stats-mini{grid-template-columns:repeat(2,1fr)}}

/* ============ Panels (generic card) ============ */
.card-panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem;animation:fadeUp .35s}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.panel-head{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.2rem;border-bottom:1px solid var(--border);background:#fafbfc}
.panel-head h2{margin:0;font-size:1rem;font-weight:700;color:var(--text)}
.panel-head .btn-small{font-size:.8rem;padding:.35rem .8rem;background:transparent;color:var(--accent);border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--trans)}
.panel-head .btn-small:hover{background:var(--accent);color:#fff;text-decoration:none;border-color:var(--accent)}
.panel-head .btn-primary.btn-small{background:var(--accent);color:#fff;border-color:var(--accent)}
.panel-head .btn-primary.btn-small:hover{background:var(--accent-dark)}
.count-badge{display:inline-block;background:var(--warn);color:#fff;font-size:.7rem;padding:.1rem .5rem;border-radius:10px;margin-left:.3rem;font-weight:700}

.dashboard-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media (max-width:1100px){.dashboard-grid-2{grid-template-columns:1fr}}

/* ============ Chart (pure CSS bars) ============ */
.chart{display:flex;align-items:flex-end;gap:.5rem;padding:1.5rem 1.2rem;height:240px;overflow:hidden}
.chart-bar{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;position:relative}
.chart-fill{width:100%;max-width:34px;background:linear-gradient(180deg,var(--accent) 0%,#ff5050 100%);border-radius:3px 3px 0 0;position:relative;transition:var(--trans);min-height:2px}
.chart-bar:hover .chart-fill{background:linear-gradient(180deg,var(--accent-dark) 0%,var(--accent) 100%)}
.chart-val{position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-size:.72rem;font-weight:700;color:var(--text);opacity:0;transition:var(--trans)}
.chart-bar:hover .chart-val{opacity:1;top:-22px}
.chart-lbl{font-size:.68rem;color:var(--text-muted);margin-top:.4rem;white-space:nowrap}

/* ============ Top lists (with progress bars) ============ */
.top-list{list-style:none;padding:.8rem 1.2rem;margin:0}
.top-list li{padding:.6rem 0;border-bottom:1px solid var(--border)}
.top-list li:last-child{border-bottom:0}
.top-list .empty-row{color:var(--text-muted);text-align:center;padding:1rem 0}
.top-row{display:flex;justify-content:space-between;align-items:center;gap:.8rem;margin-bottom:.3rem}
.top-name{color:var(--text);font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top-name:hover{color:var(--accent);text-decoration:none}
.top-val{color:var(--text-muted);font-size:.82rem;white-space:nowrap;font-weight:600}
.progress{height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#ff5050);border-radius:2px;transition:width .5s ease-out}

/* ============ Table ============ */
.admin-actions{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.admin-actions .muted{color:var(--text-muted);font-size:.9rem}
.admin-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.admin-table th,.admin-table td{padding:.7rem 1rem;border-bottom:1px solid var(--border);text-align:left;font-size:.9rem}
.admin-table th{background:#fafbfc;font-weight:600;color:#374151;font-size:.73rem;text-transform:uppercase;letter-spacing:.7px}
.admin-table th.num,.admin-table td.num{text-align:right}
.admin-table td.rank{color:var(--text-muted);font-weight:700;width:40px;text-align:center}
.admin-table tr:last-child td{border-bottom:0}
.admin-table tr:hover td{background:#fafbfc}
.admin-table.compact th,.admin-table.compact td{padding:.6rem 1rem}
.admin-table .actions{display:flex;gap:.5rem;align-items:center;white-space:nowrap}
.admin-table .actions form{display:inline}
.admin-table .actions .link{border:0;background:transparent;color:var(--accent);cursor:pointer;font-size:.85rem;padding:0;transition:var(--trans)}
.admin-table .actions .link:hover{color:var(--accent-dark);text-decoration:underline}
.admin-table .actions .link.danger{color:var(--danger)}
.admin-table .empty-cell{text-align:center;color:#9ca3af;padding:2rem}
.card-panel .admin-table{border:0;border-radius:0}
.row-meta{margin-top:.2rem;display:flex;gap:.3rem;align-items:center;flex-wrap:wrap}
.muted{color:var(--text-muted)}

/* ============ Pills ============ */
.pill{display:inline-flex;align-items:center;font-size:.68rem;padding:.15rem .5rem;border-radius:3px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.pill.ok{background:#d1fae5;color:#065f46}
.pill.off{background:#f3f4f6;color:#6b7280}
.pill.sponsored{background:#fed7aa;color:#9a3412}
.pill.warn{background:#fef3c7;color:#92400e}
.pill.info{background:#dbeafe;color:#1e40af}
a.pill:hover{text-decoration:none;filter:brightness(.95)}

/* ============ Forms (améliorés) ============ */
.admin-form{max-width:980px;background:#fff;padding:1.8rem;border:1px solid var(--border);border-radius:var(--radius);animation:fadeUp .3s}
.admin-form label{display:block;margin-bottom:1rem}
.admin-form label span{display:block;font-weight:600;margin-bottom:.3rem;font-size:.85rem;color:#374151}
.admin-form small{display:block;color:var(--text-muted);margin-top:.3rem;font-size:.8rem}
.admin-form input[type=text],
.admin-form input[type=email],
.admin-form input[type=tel],
.admin-form input[type=password],
.admin-form input[type=url],
.admin-form input[type=number],
.admin-form input[type=datetime-local],
.admin-form input[type=search],
.admin-form select,
.admin-form textarea{
	width:100%;padding:.6rem .8rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;background:#fff;transition:var(--trans)
}
.admin-form input:focus,.admin-form select:focus,.admin-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(230,0,35,.1)}
.admin-form textarea{resize:vertical;min-height:120px}
.admin-form textarea.code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.85rem}
.admin-form .row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}
.admin-form .row label{margin-bottom:0}
.admin-form h2{margin:1.5rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);font-size:1.05rem;font-weight:700;display:flex;align-items:center;gap:.5rem}
.admin-form h2:first-child{margin-top:0}
.checks{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1rem;padding:1rem;background:#fafbfc;border-radius:var(--radius-sm);border:1px solid var(--border)}
.cb{display:flex;align-items:center;gap:.4rem;font-size:.9rem;font-weight:500;cursor:pointer;margin:0;padding:0;user-select:none}
.cb input{width:auto;margin:0;cursor:pointer}
.form-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;gap:.8rem;align-items:center}

/* Fieldset layout pour article form */
.form-section-grid{display:grid;grid-template-columns:1fr 280px;gap:1.5rem;align-items:start}
.form-section-grid .form-main{min-width:0}
.form-section-grid .form-aside{background:#fafbfc;border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem}
.form-section-grid .form-aside label{margin-bottom:.8rem}
@media (max-width:900px){.form-section-grid{grid-template-columns:1fr}}

/* Cover preview thumb */
.cover-preview{display:flex;align-items:center;gap:.7rem;padding:.5rem;background:#fafbfc;border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:.3rem}
.cover-preview img{width:60px;height:60px;object-fit:cover;border-radius:3px;flex-shrink:0}
.cover-preview span{font-size:.8rem;color:var(--text-muted);word-break:break-all}

/* ============ Quill (WYSIWYG) ============ */
.ql-toolbar.ql-snow{border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:#fafbfc;padding:.5rem}
.ql-container.ql-snow{border:1px solid var(--border);border-top:0;border-radius:0 0 var(--radius-sm) var(--radius-sm);font-family:inherit;font-size:1rem;min-height:400px;background:#fff}
.ql-editor{min-height:400px;padding:1rem 1.2rem;line-height:1.7}
.ql-editor p{margin:0 0 1em}
.ql-editor h2,.ql-editor h3,.ql-editor h4{font-weight:700;margin:1em 0 .5em}
.ql-editor blockquote{border-left:4px solid var(--accent);padding-left:1rem;color:var(--text-muted)}

/* ============ Buttons ============ */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;font-weight:500;text-decoration:none;transition:var(--trans)}
.btn:hover{background:#f9fafb;text-decoration:none;border-color:var(--border-dark)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 1px 2px rgba(230,0,35,.2)}
.btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark);color:#fff;transform:translateY(-1px);box-shadow:0 4px 8px rgba(230,0,35,.25)}
.btn-link{background:transparent;border-color:transparent;color:var(--text-muted)}
.btn-link:hover{background:#f3f4f6;color:var(--text)}
.btn-block{display:block;text-align:center;width:100%}
.btn-small{padding:.4rem .75rem;font-size:.82rem}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-danger:hover{background:#b91c1c;border-color:#b91c1c;color:#fff}

/* ============ Pagination ============ */
.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}
.pagination span{color:var(--text-muted)}
.pagination a{padding:.5rem 1rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:600}
.pagination a:hover{background:var(--accent);color:#fff;border-color:var(--accent);text-decoration:none}

/* ============ Login ============ */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--side-bg),#2a1a3a)}
.login-form{background:#fff;padding:2.5rem;border-radius:var(--radius);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:0 20px 40px rgba(0,0,0,.15)}
.login-form .brand-big{text-align:center;font-size:1.5rem;font-weight:800;margin-bottom:.3rem;color:var(--text)}
.login-form .brand-big::before{content:"";display:block;width:48px;height:48px;background:var(--accent);border-radius:50%;margin:0 auto 1rem;box-shadow:inset -8px -8px 0 rgba(0,0,0,.15)}
.login-form .muted{text-align:center;color:var(--text-muted);margin:0 0 1.5rem;font-size:.9rem}
.login-form label{display:block;margin-bottom:1rem}
.login-form label span{display:block;margin-bottom:.3rem;font-weight:600;font-size:.85rem}
.login-form input{width:100%;padding:.7rem .9rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;transition:var(--trans)}
.login-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(230,0,35,.1)}
.back-home{display:block;text-align:center;margin-top:1rem;color:var(--text-muted);font-size:.85rem}

/* ============ Empty ============ */
.empty{text-align:center;padding:3rem;color:var(--text-muted);background:#fff;border-radius:var(--radius);border:1px dashed var(--border)}

/* ============ Responsive sidebar ============ */
@media (max-width:900px){
	body.admin-body{flex-direction:column}
	.admin-side{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;padding:0}
	.admin-side nav{display:flex;flex-wrap:wrap;padding:0;width:100%;order:2}
	.admin-side nav a{padding:.5rem .8rem;border-left:0;border-bottom:3px solid transparent;font-size:.8rem}
	.admin-side nav a:hover{border-left:0;border-bottom-color:var(--accent);padding-left:.8rem}
	.nav-group{display:none}
	.admin-brand{border-bottom:0;padding:1rem 1.2rem}
	.admin-user{width:auto;border-top:0;padding:.8rem 1.2rem;font-size:.8rem}
	.admin-main > *:not(.admin-topbar){padding:1rem}
	.admin-topbar{padding:.8rem 1rem}
}

/* ---- Vue d'un message contact ---- */
.message-view{padding:.5rem 0}
.message-header{background:#fafbfc;border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem 1.2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.message-header a{color:var(--accent);font-weight:600}
.message-body{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:1.2rem 1.5rem;line-height:1.7;white-space:pre-wrap;min-height:120px;font-size:1rem;color:#222}
