/* ============================================================================
 * Console admin Laëti'Bienfaits — styles (responsive, sobre, lisible)
 * Palette alignée sur le site : vert #2b3a26/#5f7d5c, terracotta #c47a5b,
 * crème #f7f3ed/#eef4ea.
 * ========================================================================== */
:root{
  --green:#2b3a26; --green-soft:#5f7d5c; --sage:#7a9b76; --sage-bd:#a9c2a3;
  --terra:#c47a5b; --terra-dk:#a8623f; --cream:#f7f3ed; --cream2:#eef4ea;
  --ink:#2b3a26; --muted:#6f7c69; --line:rgba(122,155,118,.28);
  --radius:14px; --shadow:0 18px 50px -28px rgba(43,58,38,.45);
}
*{box-sizing:border-box;}
html,body{margin:0;height:100%;}
body{font-family:'Open Sans',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;}
a{color:var(--terra-dk);}

/* ---------------- Connexion --------------------------------------------- */
body.login{display:grid;place-items:center;background:#2b3a26 radial-gradient(120% 120% at 50% 0,#33442b 0,#20301a 70%);}
.login-card{width:min(380px,92vw);background:#fff;border-radius:24px;padding:42px 34px;text-align:center;box-shadow:0 30px 80px -20px rgba(0,0,0,.5);}
.login-logo{font-family:'Playfair Display',serif;font-size:30px;font-weight:600;color:var(--green);}
.login-logo span{color:var(--terra);}
.login-sub{margin:4px 0 26px;color:var(--muted);font-size:14px;letter-spacing:.04em;}
#login-form{display:flex;flex-direction:column;gap:14px;}
#pw{padding:14px 16px;font-size:16px;border:1px solid var(--line);border-radius:12px;outline:none;}
#pw:focus{border-color:var(--terra);box-shadow:0 0 0 4px rgba(196,122,91,.18);}
#login-form button{padding:14px;font-size:16px;font-weight:700;color:#fff;background:var(--terra);border:0;border-radius:12px;cursor:pointer;transition:background .15s,transform .1s;}
#login-form button:hover{background:var(--terra-dk);}
#login-form button:active{transform:scale(.99);}
.login-err{color:#c0392b;font-size:14px;min-height:18px;}

/* ---------------- App ---------------------------------------------------- */
.app{display:grid;grid-template-columns:268px 1fr;min-height:100vh;}
.sidebar{background:var(--green);color:rgba(255,255,255,.86);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;}
.side-head{padding:24px 22px 18px;border-bottom:1px solid rgba(255,255,255,.1);}
.side-logo{font-family:'Playfair Display',serif;font-size:23px;font-weight:600;color:#fff;}
.side-logo span{color:var(--terra);}
.side-sub{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--sage-bd);margin-top:3px;}
.side-nav{flex:1;overflow-y:auto;padding:12px 12px;display:flex;flex-direction:column;gap:3px;}
.nav-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:transparent;border:0;color:rgba(255,255,255,.82);
  font-family:inherit;font-size:14.5px;font-weight:500;padding:11px 14px;border-radius:10px;cursor:pointer;transition:background .14s,color .14s;}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff;}
.nav-item.active{background:var(--terra);color:#fff;font-weight:600;}
.nav-ico{flex:none;width:20px;height:20px;display:grid;place-items:center;opacity:.95;}
.nav-ico svg{width:20px;height:20px;}
.side-foot{padding:14px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:4px;}
.side-link{display:block;text-align:left;background:transparent;border:0;color:rgba(255,255,255,.7);font-family:inherit;font-size:14px;padding:9px 12px;border-radius:9px;cursor:pointer;text-decoration:none;}
.side-link:hover{background:rgba(255,255,255,.08);color:#fff;}

.main{display:flex;flex-direction:column;min-width:0;}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;background:rgba(247,243,237,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:14px 26px;}
.burger{display:none;background:#fff;border:1px solid var(--line);width:42px;height:42px;border-radius:10px;font-size:20px;cursor:pointer;}
.topbar-title{flex:1;font-family:'Playfair Display',serif;font-size:clamp(20px,3vw,27px);font-weight:600;color:var(--green);margin:0;}
.topbar-actions{display:flex;align-items:center;gap:14px;}
.save-state{font-size:13px;color:var(--muted);}
.save-state.dirty{color:var(--terra-dk);font-weight:600;}
.btn-save{background:var(--green-soft);color:#fff;border:0;border-radius:11px;padding:12px 20px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s,transform .1s;box-shadow:0 8px 20px -10px rgba(43,58,38,.6);}
.btn-save:hover{background:#4e6a4b;}
.btn-save:active{transform:scale(.98);}
.btn-save:disabled{opacity:.7;cursor:default;}

.content{padding:26px clamp(18px,4vw,42px) 80px;max-width:860px;width:100%;}
.sec-intro{background:var(--cream2);border:1px solid var(--line);border-radius:12px;padding:14px 18px;color:var(--green);font-size:14.5px;line-height:1.5;margin:0 0 24px;}

/* ---------------- Champs ------------------------------------------------- */
.field{margin-bottom:22px;}
.f-label{display:block;font-weight:700;font-size:14.5px;color:var(--green);margin-bottom:7px;}
.f-hint{font-size:12.5px;color:var(--muted);margin-bottom:8px;line-height:1.4;}
.f-input{width:100%;font-family:inherit;font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:11px;padding:12px 14px;outline:none;transition:border-color .15s,box-shadow .15s;}
.f-input:focus{border-color:var(--terra);box-shadow:0 0 0 4px rgba(196,122,91,.15);}
textarea.f-input{resize:vertical;line-height:1.55;min-height:72px;}

/* groupe (sous-section) */
.group{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 20px 4px;margin-bottom:22px;box-shadow:var(--shadow);}
.group-title{font-family:'Playfair Display',serif;font-size:20px;color:var(--green);margin:0 0 16px;font-weight:600;}

/* image */
.img-field{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap;}
.img-prev{width:160px;height:120px;object-fit:cover;border-radius:12px;border:1px solid var(--line);background:#fff;}
.img-prev.empty{display:grid;place-items:center;background:repeating-conic-gradient(#eee 0 25%,#f7f7f7 0 50%) 0/20px 20px;}
.img-ctl{display:flex;flex-direction:column;gap:8px;}
.btn-mini{display:inline-block;background:#fff;border:1px solid var(--terra);color:var(--terra-dk);font-weight:600;font-size:14px;padding:10px 16px;border-radius:10px;cursor:pointer;transition:background .14s;}
.btn-mini:hover{background:#fdf3ee;}
.btn-mini.loading{opacity:.7;pointer-events:none;}
.img-status{font-size:13px;color:var(--green-soft);min-height:16px;}

/* listes */
.list{display:flex;flex-direction:column;gap:14px;}
.list-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px 2px;box-shadow:var(--shadow);}
.list-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.list-title{font-weight:700;color:var(--green-soft);font-size:13px;text-transform:uppercase;letter-spacing:.06em;}
.list-tools{display:flex;gap:6px;}
.btn-icon{width:32px;height:32px;border:1px solid var(--line);background:#fff;border-radius:8px;cursor:pointer;font-size:15px;line-height:1;display:grid;place-items:center;color:var(--green);}
.btn-icon:hover{background:var(--cream2);}
.btn-icon.danger:hover{background:#fdecea;border-color:#e8b4ad;}
.btn-add{align-self:flex-start;background:var(--cream2);border:1px dashed var(--sage-bd);color:var(--green-soft);font-family:inherit;font-weight:600;font-size:14px;padding:11px 18px;border-radius:11px;cursor:pointer;transition:background .14s;}
.btn-add:hover{background:#e3eedd;}

/* galerie : grille de vignettes */
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:14px;}
.gal-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#fff;}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;}
.gal-rm{position:absolute;top:8px;right:8px;width:28px;height:28px;background:rgba(20,28,16,.62);color:#fff;border:0;border-radius:50%;cursor:pointer;display:grid;place-items:center;font-size:13px;line-height:1;opacity:0;transition:opacity .15s,background .15s;}
.gal-item:hover .gal-rm,.gal-item:focus-within .gal-rm{opacity:1;}
.gal-rm:hover{background:#b0392b;}
.gal-mv{position:absolute;left:8px;right:8px;bottom:8px;display:flex;justify-content:space-between;opacity:0;transition:opacity .15s;}
.gal-item:hover .gal-mv,.gal-item:focus-within .gal-mv{opacity:1;}
.gal-mv button{width:28px;height:28px;border:0;border-radius:50%;background:rgba(20,28,16,.62);color:#fff;cursor:pointer;font-size:18px;line-height:1;display:grid;place-items:center;}
.gal-mv button:hover{background:var(--green-soft);}
.gal-add{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:var(--cream2);color:var(--terra-dk);border:2px dashed var(--sage-bd);border-radius:12px;cursor:pointer;text-align:center;font-weight:600;font-size:13px;padding:8px;transition:background .15s;}
.gal-add:hover{background:#e3eedd;}
.gal-add.loading{opacity:.6;pointer-events:none;}
.gal-add-plus{font-size:30px;line-height:1;font-weight:400;}

/* interrupteur (toggle) */
.switch{display:inline-flex;align-items:center;gap:12px;cursor:pointer;user-select:none;}
.switch input{position:absolute;opacity:0;width:0;height:0;}
.switch .slider{position:relative;width:50px;height:28px;border-radius:999px;background:#cdd6c8;transition:background .2s;flex:none;}
.switch .slider::before{content:'';position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.3);}
.switch input:checked + .slider{background:var(--green-soft);}
.switch input:checked + .slider::before{transform:translateX(22px);}
.switch-txt{font-size:14px;color:var(--muted);font-weight:600;}

/* toast + scrim */
.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,20px);background:var(--green);color:#fff;padding:13px 22px;border-radius:12px;font-size:14.5px;font-weight:600;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:60;box-shadow:0 16px 40px -16px rgba(0,0,0,.5);}
.toast.show{opacity:1;transform:translate(-50%,0);}
.toast.err{background:#b0392b;}
.scrim{display:none;position:fixed;inset:0;background:rgba(20,28,16,.5);z-index:25;}
.scrim.show{display:block;}

/* ---------------- Mobile ------------------------------------------------- */
@media(max-width:820px){
  .app{grid-template-columns:1fr;}
  .sidebar{position:fixed;left:0;top:0;z-index:30;width:280px;transform:translateX(-100%);transition:transform .25s;}
  .sidebar.open{transform:translateX(0);box-shadow:0 0 60px rgba(0,0,0,.5);}
  .burger{display:grid;place-items:center;}
  .content{padding:20px 16px 80px;}
  .img-prev{width:130px;height:98px;}
}
