/* =========================
   EVENTS PAGE SHARED / SELF-CONTAINED
========================= */
.page-shell{
  min-height:100vh;
  min-height:100svh;
  background:
    radial-gradient(1200px 700px at 10% 0%, rgba(210,169,52,.16), transparent 60%),
    linear-gradient(180deg, rgba(15,13,11,1), rgba(18,14,11,1));
}

.page-content{
  width:min(1280px, calc(100% - 2rem));
  margin:0 auto;
  padding:7.5rem 0 3rem;
}

.section-mini-head h1,
.section-mini-head h2{
  margin:.15rem 0 .55rem;
}

.eyebrow{
  margin:0;
  color:rgba(210,169,52,.95);
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:800;
}

.muted-copy,
.muted-card-line{
  color:rgba(243,239,232,.76);
}

.preview-label{
  display:block;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(210,169,52,.90);
  margin-bottom:.2rem;
  font-weight:800;
}

.stack-form{
  display:grid;
  gap:1rem;
}

.stack-form label{
  display:grid;
  gap:.45rem;
}

.stack-form input,
.stack-form textarea,
.stack-form select{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(0,0,0,.22));
  color:var(--text);
  padding:.82rem .92rem;
  font:inherit;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}

.stack-form input::placeholder,
.stack-form textarea::placeholder{
  color:rgba(243,239,232,.42);
}

.stack-form textarea{
  resize:vertical;
}

.stack-form input[type="date"],
.stack-form input[type="time"]{
  color-scheme:dark;
}

.stack-form input[type="checkbox"]{
  width:18px;
  height:18px;
  accent-color:var(--gold);
}

.stack-form input[type="file"]{
  padding:.72rem;
  background:rgba(255,255,255,.04);
  border-style:dashed;
}

.stack-form input[type="file"]::file-selector-button{
  margin-right:.75rem;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(210,169,52,.14);
  color:var(--text);
  padding:.55rem .85rem;
  border-radius:999px;
  cursor:pointer;
}

.form-grid{
  display:grid;
  gap:.75rem;
}

.form-grid.two-col{
  grid-template-columns:repeat(2, minmax(0,1fr));
}

.form-grid label span{
  color:rgba(243,239,232,.84);
  font-size:.82rem;
  font-weight:700;
}

.form-actions{
  display:flex;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
  margin-top:1rem;
}

.form-status{
  min-height:1.2rem;
  margin:0;
  font-weight:700;
  color:rgba(243,239,232,.76);
}

.events-preview-list{
  display:grid;
  gap:.55rem;
}

.event-list-row{
  display:grid;
  grid-template-columns:72px minmax(0, 1fr);
  gap:.6rem;
  align-items:start;
  padding:.65rem .75rem;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.16);
}

.event-list-thumb-wrap{
  width:72px;
  min-width:72px;
}

.event-list-thumb{
  display:flex;
  align-items:center;
  justify-content:center;
  width:72px;
  height:72px;
  border-radius:16px;
  object-fit:cover;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
}

.event-list-thumb-empty{
  color:rgba(243,239,232,.56);
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:800;
}

.event-list-main{
  display:grid;
  gap:.45rem;
  min-width:0;
}

.event-list-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.75rem;
  flex-wrap:wrap;
}

.event-list-title{
  display:block;
  color:rgba(243,239,232,.96);
  font-size:.95rem;
  line-height:1.2;
}

.event-meta{
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
  align-items:center;
}

.event-meta span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:.35rem .8rem;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(243,239,232,.88);
  font-size:.76rem;
  font-weight:700;
}

.compact-thumb-wrap{
  width:56px;
  min-width:56px;
}

.compact-thumb{
  width:56px;
  height:56px;
  border-radius:14px;
}

.compact-event-main{
  display:grid;
  grid-template-rows:auto 1fr;
  gap:.32rem;
  min-width:0;
}

.compact-event-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.6rem;
  flex-wrap:wrap;
}

.manager-modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:80;
}

.manager-modal.is-open{
  display:block;
}

.manager-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.62);
  backdrop-filter:blur(4px);
}

.manager-modal-dialog{
  position:relative;
  z-index:1;
  width:min(960px, calc(100% - 1.25rem));
  margin:3vh auto;
  max-height:94vh;
}

.manager-modal-content{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(28,22,17,.98), rgba(15,11,9,.98));
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}

.manager-modal-header,
.manager-modal-body{
  padding:1.15rem 1.2rem;
}

.manager-modal-header{
  border-bottom:1px solid rgba(255,255,255,.08);
  padding-right:4.5rem;
}

.manager-modal-header.with-action{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}

.manager-modal-body{
  overflow:auto;
  max-height:68vh;
  display:grid;
  gap:1rem;
}

.manager-modal-close{
  position:absolute;
  top:.8rem;
  right:.9rem;
  z-index:5;
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#fff;
  font-size:1.4rem;
  line-height:1;
  cursor:pointer;
}

body.modal-open{
  overflow:hidden;
}

/* =========================
   PUBLIC EVENTS PAGE
========================= */
.events-page-head-spacing{
  margin-top: 0;
}

.events-page-card{
  display:grid;
  gap:1.75rem;
  width:min(1280px, calc(100% - 3rem));
  margin:0 auto;
}

.events-back-link{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.72rem 1rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:rgba(243,239,232,.94);
  text-decoration:none;
  font-weight:700;
  transition:transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease;
}

.events-back-link:hover,
.events-back-link:focus-visible{
  transform:translateY(-1px);
  border-color:rgba(210,169,52,.32);
  background:rgba(255,255,255,.08);
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  outline:none;
}

.events-back-link span[aria-hidden="true"]{
  font-size:1.05rem;
  line-height:1;
}

.events-calendar-section,
.public-events-section,
.public-contact-section{
  display:grid;
  gap:1rem;
  padding:1.4rem;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(8,7,6,.42);
  box-shadow:0 18px 42px rgba(0,0,0,.22);
  backdrop-filter:blur(6px);
}

.calendar-shell{
  display:grid;
  gap:.85rem;
  padding:.92rem;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}

.calendar-head{
  width:100%;
}

.calendar-nav{
  display:grid;
  grid-template-columns:44px 1fr 44px;
  align-items:center;
  width:100%;
  gap:.5rem;
}

.calendar-month-text{
  display:block;
  text-align:center;
  font-size:clamp(1.15rem, 2.3vw, 1.65rem);
  line-height:1.1;
  font-weight:800;
  color:rgba(243,239,232,.96);
}

.calendar-nav-btn{
  display:flex;
  align-items:center;
  padding-bottom:8px;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:rgba(243,239,232,.94);
  font:inherit;
  font-size:1.5rem;
  font-weight:800;
  cursor:pointer;
  transition:
    transform .16s ease,
    border-color .16s ease,
    background .16s ease,
    box-shadow .16s ease,
    opacity .16s ease;
}

.calendar-nav-btn:hover,
.calendar-nav-btn:focus-visible{
  transform:translateY(-1px);
  border-color:rgba(210,169,52,.28);
  background:rgba(255,255,255,.09);
  box-shadow:0 10px 22px rgba(0,0,0,.16);
  outline:none;
}

.calendar-nav-btn:disabled{
  opacity:.38;
  cursor:default;
  transform:none;
  box-shadow:none;
}

.calendar-month{
  margin:0;
  font-size:clamp(1.15rem, 2.3vw, 1.65rem);
  line-height:1.1;
}

.calendar-weekdays{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  gap:.5rem;
}

.calendar-weekdays > div{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:rgba(243,239,232,.68);
  font-size:.74rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.events-calendar-grid{
  display:grid;
  grid-template-columns:repeat(7, minmax(0, 1fr));
  gap:.7rem;
}

.calendar-day{
  min-height:122px;
  padding:.58rem;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.025);
  display:grid;
  grid-template-rows:auto 1fr;
  gap:.45rem;
}

.calendar-day.is-empty{
  visibility:hidden;
  pointer-events:none;
  min-height:122px;
  border-color:transparent;
  background:transparent;
  box-shadow:none;
}

.calendar-day.is-today{
  border-color:rgba(210,169,52,.35);
  box-shadow:inset 0 0 0 1px rgba(210,169,52,.12);
}

.calendar-day-top{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}

.calendar-day-number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:32px;
  height:34px;
  padding:0 .55rem;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(243,239,232,.95);
  font-weight:800;
}

.calendar-day.is-today .calendar-day-number{
  background:rgba(210,169,52,.16);
  border-color:rgba(210,169,52,.28);
  color:rgba(255,240,202,.98);
}

.calendar-day-events{
  display:grid;
  align-content:start;
  gap:.35rem;
  min-width:0;
}

.calendar-event-pill{
  display:grid;
  gap:.12rem;
  padding:.34rem .44rem;
  border-radius:12px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
  min-width:0;
}

.calendar-event-title{
  display:block;
  font-size:.76rem;
  font-weight:800;
  line-height:1.15;
  color:rgba(243,239,232,.94);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.calendar-event-time{
  display:block;
  font-size:.68rem;
  line-height:1.1;
  color:rgba(243,239,232,.65);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}


.calendar-event-pill-summary{
  min-height:56px;
  align-content:center;
  text-align:left;
}

.calendar-event-pill-summary .calendar-event-title{
  white-space:normal;
}

.calendar-no-events{
  display:block;
  min-height:56px;
}

.public-event-modal-body{
  display:grid;
  gap:1rem;
}

.public-event-modal-entry{
  display:grid;
  gap:.9rem;
  padding:1rem;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}

.public-event-modal-entry + .public-event-modal-entry{
  margin-top:.1rem;
}

.public-event-modal-entry-head{
  display:grid;
  gap:.25rem;
}

.public-event-modal-entry-title{
  margin:0;
  font-size:1.1rem;
  line-height:1.2;
}

.public-event-modal-entry-when{
  margin:0;
  color:rgba(243,239,232,.72);
}

.public-event-modal-grid{
  display:grid;
  grid-template-columns:minmax(0, 280px) minmax(0, 1fr);
  gap:1rem;
  align-items:start;
}

.public-event-modal-media{
  width:100%;
  max-width:280px;
  justify-self:start;
}

.public-event-modal-media img{
  display:block;
  width:100%;
  max-width:280px;
  height:200px;
  object-fit:cover;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
}

.public-event-modal-copy{
  min-width:0;
}

.public-event-modal-description{
  margin:0;
  line-height:1.7;
  color:rgba(243,239,232,.86);
  white-space:pre-wrap;
}

.public-events-list{
  gap:.7rem;
  padding-top: 10px;
}

.public-event-row{
  grid-template-columns:56px minmax(0, 1fr);
  gap:.7rem;
  align-items:start;
}

.compact-event-copy{
  display:grid;
  gap:.3rem;
  min-width:0;
}

.compact-event-copy p{
  margin:0;
}

.public-event-row .event-list-title{
  font-size:.98rem;
}

.public-event-row .event-meta span{
  min-height:28px;
  padding:.25rem .65rem;
  font-size:.74rem;
}

.compact-thumb-wrap{
  width:56px;
  min-width:56px;
}

.compact-thumb{
  width:56px;
  height:56px;
  border-radius:14px;
  object-fit:cover;
}

.public-contact-section{
  margin-top:.25rem;
}

.is-locked-field{
  cursor:not-allowed;
  opacity:.82;
  background:rgba(255,255,255,.04) !important;
}

@media (max-width: 980px){
  .events-calendar-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .calendar-weekdays{
    display:none;
  }

  .calendar-day,
  .calendar-day.is-empty{
    min-height:120px;
  }
}

@media (max-width: 900px){
  .form-grid.two-col{
    grid-template-columns:1fr;
  }

  .event-list-row{
    grid-template-columns:60px minmax(0, 1fr);
  }

  .event-list-thumb-wrap,
  .event-list-thumb{
    width:60px;
    min-width:60px;
    height:60px;
  }

  .event-list-top{
    flex-direction:column;
    align-items:flex-start;
  }

  .manager-modal-header.with-action{
    align-items:stretch;
  }
}

@media (max-width: 720px){
  .public-event-modal-grid{
    grid-template-columns:1fr;
  }

  .public-event-modal-media{
    max-width:100%;
  }

  .manager-modal-dialog{
    width:calc(100% - .75rem);
    margin:1vh auto;
    max-height:98vh;
  }

  .manager-modal-header,
  .manager-modal-body{
    padding:1rem;
  }
}

@media (max-width: 640px){
  .page-content{
    width:min(100%, calc(100% - 1rem));
    padding:7rem 0 2rem;
  }

  .events-page-card{
    width:min(100%, calc(100% - 0rem));
    gap:1rem;
  }

  .events-calendar-section,
  .public-events-section,
  .public-contact-section{
    padding:1rem;
    border-radius:22px;
  }

  .events-calendar-grid{
    grid-template-columns:1fr;
  }

  .public-event-row{
    grid-template-columns:48px minmax(0, 1fr);
    gap:.6rem;
  }

  .compact-thumb-wrap{
    width:48px;
    min-width:48px;
  }

  .compact-thumb{
    width:48px;
    height:48px;
    border-radius:12px;
  }

  .calendar-day,
  .calendar-day.is-empty{
    min-height:auto;
  }

  .calendar-nav{
    gap:.55rem;
  }

  .calendar-nav-btn{
    width:38px;
    height:38px;
  }

  .calendar-month-text{
    font-size:1.05rem;
  }

  .manager-modal-content{
    width:100%;
    max-height:94vh;
    border-radius:20px;
  }
}
