/* =====================================================================
   Andrea's — Espace Gérant (owner panel)
   ===================================================================== */
:root{
  --green-900:#243418;--green-800:#2d4020;--green:#486830;--green-600:#4f7135;--green-300:#93aa73;--green-100:#e4ead9;
  --ink:#20241a;--muted:#6d7162;--cream:#f7f3ea;--paper:#f2efe6;--ivory:#fffdf8;--sand:#efe7d6;
  --line:rgba(72,104,48,.16);--line-strong:rgba(72,104,48,.3);
  --terracotta:#b56a41;--amber:#c68a2e;--red:#b4483f;
  --serif:"Cormorant Garamond",Georgia,serif;--sans:"Jost","Segoe UI",system-ui,sans-serif;
  --sh-sm:0 2px 12px rgba(36,52,24,.07);--sh-md:0 16px 44px -20px rgba(36,52,24,.3);
  --glass:rgba(255,253,248,.7);--glass-border:rgba(255,255,255,.6);--blur:16px;
  --radius:16px;--ease:cubic-bezier(.22,.61,.36,1);
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--sans);font-weight:300;color:var(--ink);line-height:1.6;
  background:
    radial-gradient(60% 60% at 100% 0%,rgba(72,104,48,.10),transparent 60%),
    radial-gradient(50% 50% at 0% 100%,rgba(181,106,65,.08),transparent 55%),
    var(--paper);
  min-height:100vh;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;margin:0;color:var(--green-900);line-height:1.1}
a{color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{display:block;max-width:100%}
:focus-visible{outline:2px solid var(--green-600);outline-offset:2px}

/* ---------- login ---------- */
.login{min-height:100vh;display:grid;place-items:center;padding:1.5rem}
.login__card{width:min(400px,100%);background:var(--glass);-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));
  border:1px solid var(--glass-border);border-radius:22px;box-shadow:var(--sh-md);padding:2.4rem 2rem;text-align:center}
.login__card img{width:150px;margin:0 auto 1.2rem}
.login__card h1{font-size:1.8rem;margin-bottom:.2rem}
.login__card p{color:var(--muted);font-size:.9rem;margin:0 0 1.6rem}
.login__card .field{text-align:left;margin-bottom:1rem}
.login__card label{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green-600);margin-bottom:.4rem;font-weight:500}
.login__card input{width:100%;padding:.85em 1em;border:1px solid var(--line-strong);border-radius:10px;font-family:var(--sans);font-size:1rem;background:rgba(255,255,255,.7)}
.login__card input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(72,104,48,.14)}
.login__hint{font-size:.74rem;color:var(--muted);margin-top:1rem}
.login__hint code{background:var(--cream);padding:.15em .5em;border-radius:6px;color:var(--green-800);font-family:var(--sans)}
.login__err{color:var(--red);font-size:.85rem;min-height:1.1em;margin:.4rem 0}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--sans);font-weight:400;
  font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;padding:.95em 1.6em;border-radius:100px;
  background:var(--green);color:var(--ivory);transition:.35s var(--ease);box-shadow:var(--sh-sm)}
.btn:hover{transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn.block{width:100%}
.btn.ghost{background:transparent;color:var(--green-800);box-shadow:inset 0 0 0 1px var(--line-strong)}
.btn.ghost:hover{background:var(--green);color:var(--ivory)}
.btn.tiny{padding:.5em .9em;font-size:.66rem;letter-spacing:.1em}

/* ---------- app shell ---------- */
.app{display:none;max-width:1200px;margin-inline:auto;padding:1.5rem clamp(1rem,3vw,2rem) 4rem}
.app.on{display:block}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0 1.6rem;flex-wrap:wrap}
.topbar__brand{display:flex;align-items:center;gap:.9rem}
.topbar__brand img{height:40px}
.topbar__brand .sub{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--green-600);font-weight:500}
.topbar__brand h1{font-size:1.5rem}
.topbar__actions{display:flex;align-items:center;gap:.6rem}
.pill-live{display:inline-flex;align-items:center;gap:.45em;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--green-700);background:var(--green-100);border-radius:100px;padding:.4em .8em}
.pill-live::before{content:"";width:7px;height:7px;border-radius:50%;background:#5fa03f;box-shadow:0 0 0 3px rgba(95,160,63,.25)}

/* ---------- stat cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.6rem}
.card{background:var(--glass);-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));
  border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.3rem 1.4rem;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.card .n{font-family:var(--serif);font-size:2.6rem;line-height:1;color:var(--green)}
.card .l{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.4rem}
.card.accent .n{color:var(--terracotta)}
.card.amber .n{color:var(--amber)}
.card .ic{position:absolute;top:1.1rem;right:1.1rem;width:34px;height:34px;opacity:.25}
.card .ic svg{width:100%;height:100%;stroke:var(--green);fill:none;stroke-width:1.4}

/* ---------- toolbar ---------- */
.toolbar{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-bottom:1.2rem;
  background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:.8rem;box-shadow:var(--sh-sm)}
.toolbar input,.toolbar select{font-family:var(--sans);font-size:.9rem;padding:.6em .9em;border:1px solid var(--line-strong);
  border-radius:10px;background:rgba(255,255,255,.7);color:var(--ink);min-width:0;max-width:100%}
.toolbar input:focus,.toolbar select:focus{outline:none;border-color:var(--green)}
.toolbar .search{flex:1;min-width:180px}
.seg{display:flex;background:var(--cream);border-radius:100px;padding:.25rem;box-shadow:inset 0 0 0 1px var(--line)}
.seg button{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;padding:.5em 1em;border-radius:100px;color:var(--muted);transition:.3s}
.seg button.on{background:var(--ivory);color:var(--green-900);box-shadow:var(--sh-sm)}

/* ---------- calendar ---------- */
.cal-card{margin-bottom:1.6rem}
.cal__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.cal__title{font-family:var(--serif);font-size:1.55rem;color:var(--green-900);text-transform:capitalize}
.cal__nav{display:flex;align-items:center;gap:.5rem}
.cal__arrow{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-size:1.3rem;line-height:1;color:var(--green-800);
  background:rgba(255,255,255,.6);box-shadow:inset 0 0 0 1px var(--line-strong);transition:.25s var(--ease)}
.cal__arrow:hover{background:var(--green);color:#fff}
.cal__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal__weekdays span{text-align:center;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal__day{aspect-ratio:1/1;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  background:rgba(255,255,255,.5);box-shadow:inset 0 0 0 1px var(--line);cursor:pointer;transition:.2s var(--ease);position:relative}
.cal__day:hover{box-shadow:inset 0 0 0 1px var(--green-500);transform:translateY(-1px)}
.cal__day.blank{background:transparent;box-shadow:none;cursor:default}
.cal__day.blank:hover{transform:none}
.cal__day.closed{opacity:.4;cursor:default}
.cal__day.closed:hover{transform:none;box-shadow:inset 0 0 0 1px var(--line)}
.cal__day .dn{font-size:.92rem;color:var(--ink);line-height:1}
.cal__day.past .dn{color:var(--muted)}
.cal__day.has{background:var(--green-100)}
.cal__day .cnt{font-size:.56rem;font-weight:500;color:#fff;background:var(--green);border-radius:100px;padding:.05em .4em;min-width:1.5em;text-align:center}
.cal__day.today{box-shadow:inset 0 0 0 2px var(--green)}
.cal__day.sel{background:var(--green);box-shadow:none}
.cal__day.sel .dn{color:#fff}
.cal__day.sel .cnt{background:rgba(255,255,255,.92);color:var(--green-800)}

.listctx{font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--green-800);text-transform:capitalize;margin:0 0 1rem;
  display:flex;align-items:center;gap:.8rem}
.listctx button{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line-strong);
  border-radius:100px;padding:.3em .7em;font-style:normal;font-family:var(--sans);transition:.25s}
.listctx button:hover{background:var(--green);color:#fff;border-color:var(--green)}

/* ---------- reservation list ---------- */
.reslist{display:grid;gap:.8rem}
.res{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;
  background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;padding:1rem 1.2rem;box-shadow:var(--sh-sm);
  transition:box-shadow .3s,transform .3s}
.res:hover{box-shadow:var(--sh-md)}
.res__when{text-align:center;min-width:66px;padding-right:1rem;border-right:1px solid var(--line)}
.res__when .d{font-family:var(--serif);font-size:1.5rem;color:var(--green-800);line-height:1}
.res__when .m{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.res__when .t{font-size:.92rem;color:var(--green);margin-top:.3rem;font-weight:400}
.res__main{min-width:0;overflow-wrap:anywhere}
.res__main .name{font-size:1.1rem;color:var(--green-900);font-weight:400;font-family:var(--serif)}
.res__main .meta{font-size:.82rem;color:var(--muted);display:flex;gap:.8rem;flex-wrap:wrap;margin-top:.15rem}
.res__main .meta b{color:var(--ink-soft,#3a3f30);font-weight:400}
.res__main .notes{font-size:.82rem;color:var(--terracotta);margin-top:.35rem;font-style:italic}
.res__side{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}
.badge{font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;padding:.35em .7em;border-radius:100px;font-weight:500}
.badge.en_attente{background:#f6ecd4;color:#8a6410}
.badge.confirmee{background:var(--green-100);color:var(--green-800)}
.badge.annulee{background:#f3dcd9;color:#9a3b32}
.badge.honoree{background:#e2e8f0;color:#42566b}
.res__actions{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}
.iconbtn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;background:rgba(255,255,255,.6);
  box-shadow:inset 0 0 0 1px var(--line-strong);transition:.25s}
.iconbtn:hover{background:var(--green);}
.iconbtn:hover svg{stroke:#fff}
.iconbtn svg{width:16px;height:16px;stroke:var(--green-800);fill:none;stroke-width:1.7}
.iconbtn.danger:hover{background:var(--red)}
.res.src-local{border-left:3px solid var(--terracotta)}

.empty{text-align:center;padding:3rem 1rem;color:var(--muted)}
.empty img{width:80px;opacity:.4;margin:0 auto 1rem}
.dayhdr{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green-600);margin:1.4rem 0 .3rem;font-weight:500}
.dayhdr:first-child{margin-top:0}

.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;
  background:var(--green-900);color:var(--cream);padding:.8em 1.4em;border-radius:100px;font-size:.85rem;box-shadow:var(--sh-md);
  transition:.4s var(--ease);z-index:50;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media (max-width:820px){
  .cards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .app{padding-top:1rem}
  .topbar{justify-content:center;text-align:center}
  .topbar__brand{justify-content:center}
  .topbar__actions{flex-wrap:wrap;justify-content:center;width:100%}
  .res{grid-template-columns:auto 1fr;grid-template-rows:auto auto}
  .res__side{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:.6rem}
  .res__when{border-right:none}
  .cal__head{flex-direction:column;align-items:stretch;gap:.7rem}
  .cal__nav{justify-content:center}
  .cal__title{text-align:center}
  .cal__grid,.cal__weekdays{gap:4px}
  .cal__day{border-radius:8px}
  .cal__day .dn{font-size:.82rem}
  .listctx{font-size:1.1rem;justify-content:center;text-align:center}
}
@media (max-width:400px){
  .cards{grid-template-columns:1fr 1fr;gap:.7rem}
  .card{padding:1rem}
  .card .n{font-size:2.1rem}
  .cal__day .cnt{font-size:.5rem;padding:.05em .3em}
}
