/* ===== Villa EVA — panel admin ===== */
body.admin { background: #f1ede2; min-height: 100vh; }

/* Login */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 1rem;
  background: linear-gradient(160deg, var(--maquis) 0%, #1f3528 100%); }
.login-card { background: var(--blanc); border-radius: 18px; padding: 2.4rem; max-width: 380px; width: 100%; box-shadow: var(--shadow); text-align: center; }
.login-card .brand { color: var(--maquis); font-size: 1.8rem; }
.login-card p { font-size: .9rem; color: #6b756e; margin: .4rem 0 1rem; }

/* Layout */
.admin-shell { display: none; }
.admin-shell.on { display: grid; grid-template-columns: 230px 1fr; min-height: 100vh; }
.sidebar { background: var(--maquis); color: #d8e2d3; padding: 1.6rem 1rem; display: flex; flex-direction: column; gap: .3rem; }
.sidebar .brand { color: #fff; font-size: 1.4rem; margin-bottom: 1.6rem; padding-left: .6rem; }
.sidebar button.navbtn { background: none; border: none; color: #c4d2bf; text-align: left; padding: .65rem .9rem; border-radius: 9px;
  font-family: var(--sans); font-size: .95rem; cursor: pointer; display: flex; gap: .6rem; align-items: center; }
.sidebar button.navbtn:hover { background: rgba(255,255,255,.08); color: #fff; }
.sidebar button.navbtn.active { background: var(--terracotta); color: #fff; }
.sidebar .spacer { flex: 1; }
.sidebar .badge { margin-left: auto; background: var(--terracotta); color: #fff; font-size: .72rem; border-radius: 99px; padding: .05rem .5rem; }
.main { padding: 2rem 2.2rem; overflow-x: auto; }
.main h1 { font-size: 1.9rem; margin-bottom: 1.4rem; }

/* Cards & stats */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; margin-bottom: 1.8rem; }
.stat { background: var(--blanc); border-radius: var(--radius); padding: 1.2rem 1.4rem; box-shadow: var(--shadow); }
.stat .num { font-family: var(--serif); font-size: 2rem; font-weight: 700; color: var(--maquis); }
.stat .lbl { font-size: .82rem; color: #76817a; letter-spacing: .04em; }
.panel { background: var(--blanc); border-radius: var(--radius); padding: 1.5rem; box-shadow: var(--shadow); margin-bottom: 1.4rem; }
.panel h2 { font-size: 1.3rem; margin-bottom: 1rem; }

/* Tables */
table.list { width: 100%; border-collapse: collapse; font-size: .9rem; }
table.list th { text-align: left; padding: .6rem .7rem; color: #76817a; font-weight: 500; font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; border-bottom: 2px solid var(--sable-dark); }
table.list td { padding: .7rem; border-bottom: 1px solid #efe9da; vertical-align: middle; }
table.list tr:hover td { background: #faf6ec; }
.status { display: inline-block; padding: .15rem .7rem; border-radius: 99px; font-size: .76rem; font-weight: 600; white-space: nowrap; }
.status.pending { background: #fdf3d7; color: #8a6d1d; }
.status.awaiting_payment { background: #e3edf2; color: var(--mer); }
.status.confirmed { background: #e2efe0; color: var(--ok); }
.status.rejected, .status.cancelled { background: #f4e4de; color: var(--err); }
.actions { display: flex; gap: .4rem; flex-wrap: wrap; }
.mini { border: none; border-radius: 8px; padding: .35rem .8rem; font-size: .8rem; font-family: var(--sans); cursor: pointer; font-weight: 500; }
.mini.ok { background: #2f4a38; color: #fff; }
.mini.warn { background: #b98a2e; color: #fff; }
.mini.err { background: #b04632; color: #fff; }
.mini.ghost { background: var(--sable); color: var(--encre); }
.mini:hover { opacity: .85; }

/* Settings */
.set-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0 1.4rem; }
.mode-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: .6rem 0 1rem; }
.mode-card { border: 2px solid var(--sable-dark); border-radius: var(--radius); padding: 1.1rem 1.3rem; cursor: pointer; transition: border .2s, background .2s; }
.mode-card.selected { border-color: var(--maquis); background: #eef3ea; }
.mode-card h3 { font-size: 1.1rem; }
.mode-card p { font-size: .85rem; color: #6b756e; }

/* Seasons editor */
.season-row { display: grid; grid-template-columns: 1.5fr 1fr 1fr .7fr .6fr auto; gap: .6rem; align-items: center; margin-bottom: .55rem; }
.season-row input { padding: .5rem .7rem; font-size: .88rem; }
.season-head { font-size: .75rem; text-transform: uppercase; letter-spacing: .06em; color: #76817a; }

/* Calendar admin */
.cal-admin-wrap { display: flex; gap: 2rem; flex-wrap: wrap; }
.cal-admin-wrap .cal-card { flex: 1; min-width: 320px; max-width: 430px; }
.cal-day.blocked { background: #3f3a35; color: #fff; text-decoration: none; }
.cal-day.booked-confirmed { background: #c9ddc5; color: var(--maquis); font-weight: 600; text-decoration: none; cursor: default; }
.cal-day.booked-pending { background: #f3e3bb; color: #8a6d1d; font-weight: 600; text-decoration: none; cursor: default; }

/* Emails */
.email-list { display: flex; flex-direction: column; gap: .6rem; }
.email-item { background: #fbf8f0; border: 1px solid var(--sable-dark); border-radius: 10px; padding: .9rem 1.1rem; cursor: pointer; }
.email-item .eh { display: flex; justify-content: space-between; gap: 1rem; font-size: .85rem; }
.email-item .eh b { color: var(--maquis); }
.email-item .eh .date { color: #919a93; white-space: nowrap; font-size: .78rem; }
.email-item pre { display: none; margin-top: .8rem; white-space: pre-wrap; font-family: var(--sans); font-size: .87rem; color: #414c45; border-top: 1px dashed var(--sable-dark); padding-top: .8rem; }
.email-item.open pre { display: block; }

.toast { position: fixed; bottom: 1.4rem; right: 1.4rem; background: var(--maquis); color: #fff; padding: .8rem 1.3rem; border-radius: 10px; box-shadow: var(--shadow); opacity: 0; transition: opacity .3s; pointer-events: none; z-index: 200; }
.toast.show { opacity: 1; }
.empty { color: #919a93; font-size: .9rem; padding: 1rem 0; }

@media (max-width: 800px) {
  .admin-shell.on { grid-template-columns: 1fr; }
  .sidebar { flex-direction: row; flex-wrap: wrap; align-items: center; }
  .sidebar .brand { margin: 0 1rem 0 0; }
  .season-row { grid-template-columns: 1fr 1fr; }
  .mode-cards { grid-template-columns: 1fr; }
}
