/* Project Hoof — /leave/ page. Parchment-themed calendar + leave list.
   Body background + base hero header come from body.subpage in base.css. */

.leave-main {
  position: relative; z-index: 2;
  padding: 88px 24px 64px;
  max-width: 1280px; margin: 0 auto;
}

/* ----- Gate ----- */
.leave-gate {
  text-align: center;
  max-width: 540px; margin: 60px auto;
  padding: 70px 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid rgba(201,162,74,.25);
  border-radius: 14px;
}
.leave-gate h1 {
  font-family: 'Cinzel Decorative', serif;
  font-size: 2rem; margin: 0 0 12px;
  color: #f2cc6a;
}
.leave-gate p {
  font-family: 'EB Garamond', serif;
  font-style: italic; color: #b3a98b;
  margin: 0 0 22px;
  font-size: 1.1rem;
}

/* ----- Header CTA strip (under the shared .subpage-hero block) ----- */
.leave-header-actions {
  margin-top: 18px;
  display: flex; justify-content: center;
}
.leave-cta-new {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Cinzel', serif; font-weight: 700;
  font-size: .9rem; letter-spacing: .12em; text-transform: uppercase;
  padding: 12px 22px; border-radius: 999px;
  background: linear-gradient(180deg, #f2cc6a, #c9a24a);
  color: #2a1f0d; border: 1px solid #8a5d1a;
  cursor: pointer;
}
.leave-cta-new:hover { filter: brightness(1.08); }

/* ============ Calendar ============ */
.leave-calendar {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin-bottom: 28px;
}
@media (max-width: 1100px) { .leave-calendar { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 740px)  { .leave-calendar { grid-template-columns: 1fr; } }

.cal-month {
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(201,162,74,.05), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.01));
  border: 1px solid rgba(201,162,74,.22);
  border-radius: 12px;
  padding: 16px 14px 14px;
}
.cal-month-h {
  font-family: 'IM Fell English SC', serif;
  font-size: .95rem;
  letter-spacing: .22em; text-transform: uppercase;
  color: #f2cc6a;
  text-align: center;
  margin: 0 0 12px;
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 3px;
}
.cal-dow {
  font-family: 'Manrope', sans-serif;
  font-size: .68rem; letter-spacing: .12em;
  color: #888173;
  text-align: center;
  padding-bottom: 4px;
  text-transform: uppercase;
}
.cal-cell {
  aspect-ratio: 1 / 1;
  display: flex; align-items: flex-start; justify-content: flex-end;
  padding: 5px 6px;
  position: relative;
  border-radius: 5px;
  font-family: 'Manrope', sans-serif;
  font-size: .82rem;
  color: #d8cfb6;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(201,162,74,.08);
  cursor: pointer;
  transition: transform .12s, border-color .15s, background .15s;
  user-select: none;
}
.cal-cell.is-empty { visibility: hidden; cursor: default; }
.cal-cell.is-past  { opacity: .45; }
.cal-cell.is-today {
  border-color: #f2cc6a;
  box-shadow: inset 0 0 0 1px #f2cc6a;
  color: #f2cc6a;
  font-weight: 700;
}
.cal-cell:hover:not(.is-empty) { transform: translateY(-1px); border-color: rgba(201,162,74,.45); }
.cal-cell.is-selected {
  background: rgba(140,200,120,.18);
  border-color: rgba(140,200,120,.6);
  color: #e8f2dc;
}
/* Range-pick highlights — first cell clicked (start) + live hover preview. */
.cal-cell.is-pick-start {
  background: rgba(242,204,106,.35) !important;
  border-color: #f2cc6a !important;
  color: #f2cc6a !important;
  font-weight: 700;
  box-shadow: inset 0 0 0 1px #f2cc6a;
}
.cal-cell.is-pick-range {
  background: rgba(242,204,106,.14) !important;
  border-color: rgba(242,204,106,.4) !important;
  color: #f2cc6a !important;
}

/* Banner shown while the user is mid-range-pick. */
.leave-pick-banner {
  grid-column: 1 / -1;
  display: flex; flex-wrap: wrap; align-items: center; gap: 12px;
  padding: 10px 14px;
  background: rgba(242,204,106,.10);
  border: 1px solid rgba(242,204,106,.4);
  border-radius: 10px;
  font-family: 'EB Garamond', serif;
  font-style: italic;
  color: #f2cc6a;
  margin-bottom: 4px;
}
.leave-pick-banner span { flex: 1; }
.leave-pick-banner .btn-ghost { padding: 6px 14px; font-size: .75rem; }

/* Heat-map colors — light → deep amber → red.
   Tier classes set inline by leave.js. */
.cal-cell[data-heat="1"] { background: rgba(201,162,74,.10); border-color: rgba(201,162,74,.30); }
.cal-cell[data-heat="2"] { background: rgba(201,162,74,.18); border-color: rgba(201,162,74,.45); }
.cal-cell[data-heat="3"] { background: rgba(214,125,60,.22);  border-color: rgba(214,125,60,.6); }
.cal-cell[data-heat="4"] { background: rgba(196, 72, 60,.28); border-color: rgba(196, 72, 60,.65); color: #f7e5d8; }
.cal-cell[data-heat="5"] { background: rgba(170, 50, 50,.40); border-color: rgba(196, 72, 60,.85); color: #fff; }

.cal-cell-badge {
  position: absolute; left: 4px; bottom: 4px;
  font-family: 'Manrope', sans-serif;
  font-size: .68rem; font-weight: 700;
  color: rgba(0,0,0,.55);
  background: rgba(255,255,255,.7);
  border-radius: 999px;
  padding: 0 5px; min-width: 14px; height: 14px;
  display: inline-flex; align-items: center; justify-content: center;
  line-height: 1;
}
.cal-cell[data-heat="4"] .cal-cell-badge,
.cal-cell[data-heat="5"] .cal-cell-badge {
  color: rgba(0,0,0,.7);
  background: rgba(255,255,255,.92);
}

/* ============ Day-detail strip ============ */
.leave-day-detail {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,162,74,.25);
  border-radius: 10px;
  padding: 14px 18px;
  margin-bottom: 28px;
}
.leave-day-detail-h {
  font-family: 'IM Fell English SC', serif;
  font-size: .92rem; letter-spacing: .18em;
  color: #f2cc6a;
  margin: 0 0 10px;
}
.leave-day-detail-items {
  display: flex; flex-wrap: wrap; gap: 8px;
}

/* ============ List of leaves ============ */
.leave-list-section {
  margin-top: 20px;
}
.leave-list-h {
  font-family: 'Cinzel', serif;
  font-weight: 700;
  font-size: 1.4rem; letter-spacing: .04em;
  color: #f2cc6a;
  margin: 0 0 14px;
}
.leave-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.leave-empty {
  font-family: 'EB Garamond', serif;
  font-style: italic;
  color: #888173;
  text-align: center;
  padding: 40px 16px;
}

.leave-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,162,74,.22);
  border-radius: 12px;
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 10px;
  position: relative;
}
.leave-card.is-active { border-color: rgba(140,200,120,.55); }
.leave-card.is-mine   { box-shadow: 0 0 0 1px rgba(242,204,106,.35); cursor: pointer; }
.leave-card.is-mine:hover { background: rgba(255,255,255,.06); }
.leave-card-head {
  display: flex; align-items: center; gap: 10px;
}
.leave-card-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: #1d2a44;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: 'Cinzel', serif;
  font-weight: 700;
  color: #f2cc6a;
  border: 1px solid rgba(201,162,74,.4);
  overflow: hidden;
}
.leave-card-avatar img { width: 100%; height: 100%; object-fit: cover; }
.leave-card-name {
  font-family: 'Cinzel', serif;
  font-weight: 700;
  color: #e8e2d2;
}
.leave-card-role {
  display: inline-block;
  font-family: 'IM Fell English SC', serif;
  font-size: .68rem; letter-spacing: .14em;
  padding: 1px 7px;
  border-radius: 999px;
  text-transform: uppercase;
  margin-left: 6px;
}
.leave-card-role[data-role="r5"]        { background: rgba(242,204,106,.18); color: #f2cc6a; border: 1px solid rgba(242,204,106,.4); }
.leave-card-role[data-role="r4"]        { background: rgba(201,162,74,.12);  color: #c9a24a; border: 1px solid rgba(201,162,74,.3);  }
.leave-card-role[data-role="officer"],
.leave-card-role[data-role="diplomat"],
.leave-card-role[data-role="recruiter"],
.leave-card-role[data-role="scout"]     { background: rgba(140,180,220,.10); color: #9bbedf; border: 1px solid rgba(140,180,220,.3); }
.leave-card-role[data-role="veteran"]   { background: rgba(180,140,90,.10);  color: #c89a6a; border: 1px solid rgba(180,140,90,.3);  }

.leave-card-actions {
  margin-left: auto;
  display: flex; align-items: center; gap: 8px;
  flex-shrink: 0;
}
.leave-card-now {
  font-family: 'IM Fell English SC', serif;
  font-size: .72rem; letter-spacing: .18em;
  color: #a3d39c;
  padding: 2px 8px;
  border: 1px solid rgba(140,200,120,.45);
  border-radius: 999px;
  text-transform: uppercase;
}
.leave-card-range {
  font-family: 'EB Garamond', serif;
  font-size: 1.05rem;
  color: #d6c590;
}
.leave-card-range-days {
  font-style: italic;
  color: #888173;
  font-size: .9rem;
  margin-left: 6px;
}
.leave-card-flags {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.leave-flag-pill {
  font-family: 'Manrope', sans-serif;
  font-size: .72rem;
  background: rgba(140,180,220,.08);
  color: #9bbedf;
  border: 1px solid rgba(140,180,220,.25);
  border-radius: 999px;
  padding: 2px 9px;
}
.leave-flag-pill[data-flag="afk"]    { background: rgba(196, 72, 60,.12); color: #e8a585; border-color: rgba(196,72,60,.35); }
.leave-flag-pill[data-flag="rally"]  { background: rgba(140,200,120,.10); color: #a3d39c; border-color: rgba(140,200,120,.3); }
.leave-card-note {
  font-family: 'EB Garamond', serif;
  font-style: italic;
  color: #b3a98b;
  font-size: .95rem;
  border-left: 2px solid rgba(201,162,74,.35);
  padding-left: 10px;
}
.leave-card-edit {
  background: transparent;
  border: 1px solid rgba(201,162,74,.3);
  color: #c9a24a;
  font-family: 'Manrope', sans-serif;
  font-size: .75rem;
  padding: 2px 9px;
  border-radius: 999px;
  cursor: pointer;
}
.leave-card-edit:hover { background: rgba(201,162,74,.12); border-color: #c9a24a; }

/* ============ Modal ============ */
.leave-modal {
  position: fixed; inset: 0;
  background: rgba(5,8,18,.7);
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  backdrop-filter: blur(6px);
}
.leave-modal[hidden] { display: none; }
.leave-modal-card {
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(201,162,74,.08), transparent 65%),
    linear-gradient(180deg, #131f3a, #0a1326);
  border: 1px solid rgba(201,162,74,.35);
  border-radius: 14px;
  width: 100%;
  max-width: 560px;
  padding: 28px 28px 22px;
  position: relative;
  max-height: 90vh; overflow-y: auto;
}
.leave-modal-close {
  position: absolute; top: 10px; right: 14px;
  background: transparent; border: 0;
  color: #888173;
  font-size: 1.8rem;
  line-height: 1;
  cursor: pointer;
}
.leave-modal-close:hover { color: #f2cc6a; }
.leave-modal-title {
  font-family: 'Cinzel Decorative', serif;
  font-weight: 900;
  font-size: 1.6rem;
  color: #f2cc6a;
  margin: 0 0 4px;
}
.leave-modal-sub {
  font-family: 'EB Garamond', serif;
  font-style: italic;
  color: #b3a98b;
  margin: 0 0 18px;
}
.leave-form-row {
  display: flex; gap: 14px; flex-wrap: wrap; align-items: end;
  margin-bottom: 16px;
}
.leave-form-dates label {
  display: flex; flex-direction: column; gap: 4px;
  font-family: 'IM Fell English SC', serif;
  font-size: .78rem; letter-spacing: .16em;
  color: #c9a24a;
  flex: 1; min-width: 130px;
}
.leave-form-dates input[type="date"] {
  background: rgba(0,0,0,.3);
  border: 1px solid rgba(201,162,74,.3);
  color: #e8e2d2;
  padding: 9px 12px;
  border-radius: 7px;
  font-family: 'Manrope', sans-serif;
  font-size: 1rem;
  /* Force the date-picker icon to be visible on dark bg */
  color-scheme: dark;
}
.leave-form-dates input[type="date"]:focus {
  outline: 0; border-color: #c9a24a;
  box-shadow: 0 0 0 3px rgba(201,162,74,.15);
}
.leave-form-days {
  font-family: 'EB Garamond', serif;
  font-style: italic;
  color: #888173;
  font-size: .95rem;
  align-self: center;
  padding-bottom: 8px;
}

.leave-form-flags {
  border: 1px solid rgba(201,162,74,.22);
  border-radius: 10px;
  padding: 12px 14px 8px;
  margin-bottom: 16px;
}
.leave-form-flags legend {
  font-family: 'IM Fell English SC', serif;
  font-size: .8rem; letter-spacing: .18em;
  color: #c9a24a;
  padding: 0 8px;
}
.leave-flag {
  display: inline-flex; align-items: center; gap: 8px;
  margin: 6px 16px 6px 0;
  font-family: 'EB Garamond', serif;
  color: #d8cfb6;
  cursor: pointer;
}
.leave-flag input[type="checkbox"] {
  width: 16px; height: 16px;
  accent-color: #c9a24a;
}

.leave-form-note {
  display: flex; flex-direction: column; gap: 4px;
  font-family: 'IM Fell English SC', serif;
  font-size: .78rem; letter-spacing: .16em;
  color: #c9a24a;
  margin-bottom: 18px;
}
.leave-form-note textarea {
  background: rgba(0,0,0,.3);
  border: 1px solid rgba(201,162,74,.3);
  color: #e8e2d2;
  padding: 9px 12px;
  border-radius: 7px;
  font-family: 'EB Garamond', serif;
  font-size: 1rem;
  resize: vertical;
}
.leave-form-note textarea:focus {
  outline: 0; border-color: #c9a24a;
  box-shadow: 0 0 0 3px rgba(201,162,74,.15);
}

.leave-form-error {
  background: rgba(196,72,60,.15);
  border: 1px solid rgba(196,72,60,.4);
  color: #e8a585;
  padding: 9px 12px;
  border-radius: 7px;
  font-family: 'Manrope', sans-serif;
  font-size: .9rem;
  margin-bottom: 14px;
}
.leave-form-actions {
  display: flex; gap: 10px; align-items: center;
}
.leave-spacer { flex: 1; }
.btn-ghost {
  background: transparent;
  border: 1px solid rgba(201,162,74,.4);
  color: #d6c590;
  font-family: 'IM Fell English SC', serif;
  letter-spacing: .14em; text-transform: uppercase;
  font-size: .85rem;
  padding: 9px 16px; border-radius: 999px;
  cursor: pointer;
}
.btn-ghost:hover { background: rgba(201,162,74,.1); }
.leave-delete-btn {
  background: transparent;
  border: 1px solid rgba(196,72,60,.5);
  color: #e8a585;
  font-family: 'Manrope', sans-serif;
  font-size: .85rem;
  padding: 8px 14px;
  border-radius: 999px;
  cursor: pointer;
}
.leave-delete-btn:hover { background: rgba(196,72,60,.15); }
