:root{
  --green:#0d7633;--orange:#ffa619;--blue:#283891;
  --green-lt:#e8f5ed;--orange-lt:#fff8ee;--blue-lt:#eef0fa;
  --gray:#f5f6f8;--dark:#0d1240;--text:#1a1a2e;--muted:#5c5c7a;
  --sh:0 4px 24px rgba(40,56,145,.10);--sh-lg:0 8px 40px rgba(40,56,145,.18);
  --r:18px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Open Sans',sans-serif;color:var(--text);background:#fff;overflow-x:hidden}
h1,h2,h3,h4,h5{font-family:'Montserrat',sans-serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1140px;margin:0 auto;padding:0 20px}
.mobile-break{display:none}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:999;
  background:rgba(255,255,255,.97);backdrop-filter:blur(16px);
  border-bottom:2px solid var(--blue-lt);
  box-shadow:0 2px 18px rgba(40,56,145,.07);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;padding:0 5%}
.nav-logo img{height:100px;width:auto}
.nav-links{display:flex;gap:1.4rem;align-items:center;list-style:none}
.nav-links a{
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.78rem;
  letter-spacing:.07em;text-transform:uppercase;color:var(--blue);
  padding-bottom:3px;border-bottom:2px solid transparent;transition:.2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--orange);border-color:var(--orange)}
.nav-cta{
  background:var(--orange)!important;color:#fff!important;
  padding:.5rem 1.3rem!important;border-radius:50px!important;border:none!important;
  box-shadow:0 4px 14px rgba(255,166,25,.35);
}
.nav-cta:hover{background:#e8930a!important}
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:40px;height:40px;background:none;border:none;cursor:pointer;padding:4px;
}
.hamburger span{display:block;height:2.5px;background:var(--blue);border-radius:2px;transition:.3s;transform-origin:center}
.hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mobile-menu{
  display:none;position:fixed;top:68px;left:0;right:0;bottom:0;
  background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
  z-index:998;padding:2rem 5%;overflow-y:auto;flex-direction:column;gap:.5rem;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  display:block;font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:1.1rem;color:var(--blue);padding:1rem 0;
  border-bottom:1px solid var(--blue-lt);transition:.2s;
}
.mobile-menu a:hover{color:var(--orange);padding-left:8px}
.mobile-menu .m-cta{
  margin-top:1.5rem;background:var(--orange);color:#fff!important;
  text-align:center;border-radius:50px;padding:1rem!important;border:none;
}

/* HERO */
.events-hero{
  padding:130px 0 70px;
  background:linear-gradient(135deg,#0b1845 0%,#1a2a80 45%,#0d4020 100%);
  position:relative;overflow:hidden;
}
.events-hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:36px 36px;
}
.events-hero::after{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:rgba(255,166,25,.05);top:-200px;right:-200px;
}
.hero-inner{position:relative;z-index:2;text-align:center;color:#fff}
.hero-pill{
  display:inline-flex;align-items:center;gap:.6rem;
  background:rgba(255,166,25,.15);border:1px solid rgba(255,166,25,.3);
  color:var(--orange);padding:.45rem 1.2rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.72rem;
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.5rem;
}
.events-hero h1{
  font-size:clamp(2rem,5vw,3.4rem);font-weight:900;
  color:#fff;margin-bottom:1rem;letter-spacing:-.02em;
}
.events-hero h1 span{color:var(--orange)}
.events-hero p{
  font-size:1rem;color:rgba(255,255,255,.75);
  max-width:560px;margin:0 auto 2.5rem;line-height:1.75;
}
.hero-stats-row{
  display:flex;gap:2.5rem;justify-content:center;flex-wrap:wrap;
  padding-top:2rem;border-top:1px solid rgba(255,255,255,.12);
}
.hs{text-align:center}
.hs-n{font-family:'Montserrat',sans-serif;font-size:1.8rem;font-weight:900;color:var(--orange)}
.hs-l{font-size:.72rem;color:rgba(255,255,255,.5);letter-spacing:.06em;text-transform:uppercase;margin-top:.2rem}

/* FILTERS */
.filters-bar{
  background:#fff;padding:1.8rem 0;
  border-bottom:2px solid var(--gray);
  position:sticky;top:68px;z-index:90;
  box-shadow:0 4px 20px rgba(40,56,145,.06);
}
.filters-inner{
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
}
.filter-label{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.75rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
  flex-shrink:0;
}
.filter-btns{display:flex;gap:.5rem;flex-wrap:wrap;flex:1}
.fbtn{
  padding:.5rem 1.1rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.76rem;
  letter-spacing:.04em;cursor:pointer;transition:.2s;
  border:1.5px solid #dde2f0;background:#fff;color:var(--muted);
}
.fbtn:hover{border-color:var(--blue);color:var(--blue)}
.fbtn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.fbtn.upcoming{background:var(--green);color:#fff;border-color:var(--green)}
.fbtn.past{background:var(--muted);color:#fff;border-color:var(--muted)}
.search-box{
  display:flex;align-items:center;gap:.5rem;
  background:var(--gray);border-radius:50px;padding:.5rem 1rem;
  border:1.5px solid transparent;transition:.2s;margin-left:auto;
}
.search-box:focus-within{border-color:var(--blue);background:#fff}
.search-box input{
  border:none;background:transparent;outline:none;
  font-family:'Open Sans',sans-serif;font-size:.85rem;color:var(--text);
  width:180px;
}
.search-box span{color:var(--muted);font-size:.9rem}

/* MAIN LAYOUT */
.events-main{padding:60px 0 100px}

/* SECTION DIVIDERS */
.timeline-section{margin-bottom:4rem}
.ts-header{
  display:flex;align-items:center;gap:1rem;margin-bottom:2rem;
}
.ts-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.45rem 1.1rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.75rem;
  letter-spacing:.1em;text-transform:uppercase;flex-shrink:0;
}
.ts-pill.upcoming{background:var(--green-lt);color:var(--green)}
.ts-pill.upcoming::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green);animation:blink 2s infinite}
.ts-pill.past{background:var(--gray);color:var(--muted)}
.ts-line{flex:1;height:1px;background:var(--gray)}
.ts-count{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.75rem;
  color:var(--muted);flex-shrink:0;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* EVENT CARDS GRID */
.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}

.event-card{
  background:#fff;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--sh);transition:.3s;position:relative;
  display:flex;flex-direction:column;
}
.event-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.event-card.past{opacity:.82}
.event-card.past:hover{opacity:1}

/* poster */
.ec-poster{
  position:relative;overflow:hidden;background:var(--blue-lt);
  aspect-ratio:16/9;
}
.ec-poster img{
  width:100%;height:100%;object-fit:cover;transition:.4s;
}
.event-card:hover .ec-poster img{transform:scale(1.04)}
.ec-poster-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-size:3rem;background:linear-gradient(135deg,var(--blue-lt),var(--green-lt));
}
.ec-status-badge{
  position:absolute;top:10px;left:10px;
  padding:.3rem .8rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.65rem;
  letter-spacing:.08em;text-transform:uppercase;
}
.badge-virtual{background:rgba(40,56,145,.9);color:#fff}
.badge-inperson{background:rgba(13,118,51,.9);color:#fff}
.ec-upcoming-ribbon{
  position:absolute;top:10px;right:10px;
  background:var(--orange);color:#fff;
  padding:.3rem .8rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.65rem;
  letter-spacing:.08em;text-transform:uppercase;
  animation:pulse-badge 2s infinite;
}
@keyframes pulse-badge{0%,100%{box-shadow:0 0 0 0 rgba(255,166,25,.4)}50%{box-shadow:0 0 0 6px rgba(255,166,25,0)}}
.ec-past-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.3);
  display:flex;align-items:center;justify-content:center;
}
.ec-past-label{
  background:rgba(0,0,0,.7);color:rgba(255,255,255,.8);
  padding:.4rem 1rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.7rem;
  letter-spacing:.1em;text-transform:uppercase;
}

/* card body */
.ec-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.ec-meta{
  display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;
  margin-bottom:.9rem;
}
.ec-date{
  display:flex;align-items:center;gap:.35rem;
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.73rem;
  color:var(--blue);
}
.ec-date::before{content:'📅';font-size:.8rem}
.ec-venue{
  display:flex;align-items:center;gap:.35rem;
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.73rem;
  color:var(--muted);
}
.ec-venue::before{content:'📍';font-size:.8rem}
.ec-title{
  font-size:1rem;font-weight:800;color:var(--text);
  margin-bottom:.6rem;line-height:1.35;
}
.ec-desc{
  font-size:.82rem;color:var(--muted);line-height:1.6;
  flex:1;margin-bottom:1rem;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.ec-footer{
  padding-top:1rem;border-top:1px solid var(--gray);
  display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap;
}
.ec-fee{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.82rem;
  color:var(--green);
}
.ec-fee.free{color:var(--green)}
.ec-fee.paid{color:var(--blue)}
.ec-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.btn-reg{
  background:var(--orange);color:#fff;
  padding:.5rem 1.1rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.73rem;
  letter-spacing:.04em;transition:.2s;display:inline-flex;align-items:center;gap:.3rem;
  box-shadow:0 3px 12px rgba(255,166,25,.35);white-space:nowrap;
}
.btn-reg:hover{background:#e8930a;transform:translateY(-1px)}
.btn-reg:disabled,.btn-reg.ended{background:var(--muted);box-shadow:none;cursor:not-allowed;transform:none}
.btn-details{
  background:var(--blue-lt);color:var(--blue);
  padding:.5rem 1rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.73rem;
  letter-spacing:.04em;transition:.2s;display:inline-flex;align-items:center;gap:.3rem;
  white-space:nowrap;
}
.btn-details:hover{background:var(--blue);color:#fff}

/* EMPTY STATE */
.empty-state{
  grid-column:1/-1;text-align:center;padding:4rem 2rem;
}
.empty-state .empty-ico{font-size:3rem;margin-bottom:1rem}
.empty-state h3{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.5rem}
.empty-state p{font-size:.88rem;color:var(--muted)}

/* EVENT MODAL */
.modal-overlay{
  position:fixed;inset:0;background:rgba(10,18,62,.7);
  backdrop-filter:blur(6px);z-index:2000;
  display:flex;align-items:center;justify-content:center;padding:1rem;
  opacity:0;pointer-events:none;transition:.3s;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{
  background:#fff;border-radius:24px;width:100%;max-width:680px;
  max-height:90vh;overflow-y:auto;
  transform:scale(.95) translateY(20px);transition:.3s;
  box-shadow:0 20px 60px rgba(10,18,62,.3);
}
.modal-overlay.open .modal{transform:scale(1) translateY(0)}
.modal-poster{
  position:relative;aspect-ratio:16/7;overflow:hidden;background:var(--blue-lt);border-radius:24px 24px 0 0;
}
.modal-poster img{width:100%;height:100%;object-fit:cover}
.modal-poster-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-size:5rem;background:linear-gradient(135deg,var(--blue-lt),var(--green-lt));
}

.registration-overlay{
  position:fixed;inset:0;background:rgba(13,18,64,.72);backdrop-filter:blur(6px);
  z-index:1200;display:none;align-items:flex-start;justify-content:center;padding:86px 18px 28px;
  overflow-y:auto;
}
.registration-overlay.open{display:flex}
.registration-modal{
  width:min(100%,920px);background:#fff;border-radius:16px;box-shadow:var(--sh-lg);
  overflow:hidden;
}
.registration-head{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.2rem 1.4rem;border-bottom:1px solid var(--gray);position:sticky;top:0;background:#fff;z-index:2;
}
.registration-kicker{
  font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:800;letter-spacing:.12em;
  color:var(--orange);text-transform:uppercase;margin-bottom:.25rem;
}
.registration-head h2{font-size:1.08rem;color:var(--blue);margin:0}
.reg-close{position:static;flex-shrink:0}
#eventRegistrationForm{padding:1.35rem}
.form-section-title{
  font-family:'Montserrat',sans-serif;font-size:.76rem;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;color:var(--blue);border-bottom:2px solid var(--blue-lt);
  padding-bottom:.45rem;margin:1.2rem 0 1rem;
}
.form-section-title:first-of-type{margin-top:0}
.reg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.reg-event-row{grid-template-columns:1fr;margin-bottom:1rem}
.reg-grid label{
  display:flex;flex-direction:column;gap:.4rem;
  font-family:'Montserrat',sans-serif;font-size:.74rem;font-weight:800;color:var(--text);
}
.reg-grid input,.reg-grid select{
  width:100%;border:1.5px solid #dde2f0;border-radius:10px;padding:.72rem .8rem;
  font-family:'Open Sans',sans-serif;font-size:.86rem;color:var(--text);background:#fafbff;outline:0;
}
.reg-grid input:focus,.reg-grid select:focus{
  border-color:var(--blue);box-shadow:0 0 0 3px rgba(40,56,145,.08);background:#fff;
}
.reg-grid input[readonly]{background:#f0f2f8;color:var(--blue);font-weight:700}
.phone-row{display:grid;grid-template-columns:128px 1fr;gap:.45rem}
.registration-actions{
  display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.35rem;padding-top:1rem;border-top:1px solid var(--gray);
}
.btn-reg-cancel,.btn-reg-submit{
  border:0;border-radius:50px;padding:.72rem 1.3rem;
  font-family:'Montserrat',sans-serif;font-size:.8rem;font-weight:800;cursor:pointer;transition:.2s;
}
.btn-reg-cancel{background:var(--gray);color:var(--muted)}
.btn-reg-submit{background:var(--green);color:#fff;box-shadow:0 3px 12px rgba(13,118,51,.22)}
.btn-reg-submit:disabled{opacity:.6;cursor:not-allowed}
.reg-message{display:none;margin-top:1rem;border-radius:10px;padding:.8rem 1rem;font-size:.85rem;font-weight:700}
.reg-message.success{display:block;background:var(--green-lt);color:var(--green)}
.reg-message.error{display:block;background:#fef0ef;color:#e74c3c}
.modal-close{
  position:absolute;top:12px;right:12px;
  width:36px;height:36px;border-radius:50%;
  background:rgba(0,0,0,.5);color:#fff;border:none;cursor:pointer;
  font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:.2s;
}
.modal-close:hover{background:rgba(0,0,0,.8)}
.modal-body{padding:2rem}
.modal-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.modal-badge{
  padding:.3rem .8rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.67rem;
  letter-spacing:.08em;text-transform:uppercase;
}
.mb-upcoming{background:var(--green-lt);color:var(--green)}
.mb-past{background:var(--gray);color:var(--muted)}
.mb-virtual{background:var(--blue-lt);color:var(--blue)}
.mb-inperson{background:var(--green-lt);color:var(--green)}
.modal-title{font-size:1.4rem;font-weight:900;color:var(--text);margin-bottom:1.2rem}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:1.5rem}
.mg-item{
  background:var(--gray);border-radius:12px;padding:.9rem 1rem;
}
.mg-label{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.67rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.2rem;
}
.mg-val{font-size:.88rem;font-weight:600;color:var(--text)}
.modal-desc-title{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.8rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem;
}
.modal-desc{font-size:.9rem;color:var(--text);line-height:1.75;margin-bottom:1.5rem}
.modal-actions{display:flex;gap:.8rem;flex-wrap:wrap}
.btn-modal-reg{
  flex:1;background:var(--orange);color:#fff;
  padding:.85rem 1.5rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.88rem;
  text-align:center;transition:.2s;
  box-shadow:0 4px 16px rgba(255,166,25,.4);
  border:0;cursor:pointer;
}
.btn-modal-reg:hover{background:#e8930a;transform:translateY(-2px)}
.btn-modal-reg.ended{background:var(--muted);box-shadow:none;cursor:not-allowed}
.btn-modal-doc{
  background:var(--blue-lt);color:var(--blue);
  padding:.85rem 1.5rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.88rem;
  text-align:center;transition:.2s;white-space:nowrap;
}
.btn-modal-doc:hover{background:var(--blue);color:#fff}

/* FOOTER */
footer{
  background:linear-gradient(135deg,#08122e 0%,#141c5e 100%);
  color:#fff;padding:40px 0 20px;
}
.ft-bottom{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.78rem;color:rgba(255,255,255,.35);flex-wrap:wrap;gap:.5rem;
  padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);
}
.ft-logo{margin-bottom:1rem}
.ft-logo img{height:44px;filter:brightness(1.15)}

/* RESPONSIVE */
@media(max-width:900px){
  .events-grid{grid-template-columns:repeat(2,1fr)}
  .nav-links{display:none}
  .hamburger{display:flex}
}
@media(max-width:560px){
  .mobile-break{display:block}
  .nav-inner{padding:0 6%}
  .nav-logo img{height:52px}
  .events-hero{padding:120px 0 56px}
  .hero-pill{max-width:100%;font-size:.66rem;letter-spacing:.08em;white-space:normal}
  .events-hero h1{font-size:1.48rem;letter-spacing:0;overflow-wrap:anywhere;max-width:calc(100vw - 48px);margin-left:auto;margin-right:auto}
  .events-hero p{font-size:.9rem;width:calc(100vw - 86px);max-width:320px;overflow-wrap:anywhere}
  .hero-stats-row{gap:1.3rem}
  .hs{min-width:86px}
  .events-grid{grid-template-columns:1fr}
  .filters-inner{flex-direction:column;align-items:flex-start}
  .search-box{margin-left:0;width:100%}
  .search-box input{width:100%}
  .modal-grid{grid-template-columns:1fr}
  .modal-actions{flex-direction:column}
  .btn-modal-reg{flex:none}
  .hero-stats-row{gap:1.5rem}
  .registration-overlay{padding:78px 10px 18px}
  .registration-head{padding:1rem}
  #eventRegistrationForm{padding:1rem}
  .reg-grid{grid-template-columns:1fr}
  .phone-row{grid-template-columns:112px 1fr}
  .registration-actions{flex-direction:column-reverse}
  .btn-reg-cancel,.btn-reg-submit{width:100%}
}

/* ── Registration status styles ── */
.reg-window-row{
  display:flex;align-items:center;gap:.5rem;
  font-size:.75rem;font-family:'Montserrat',sans-serif;font-weight:600;
  margin-bottom:.5rem;flex-wrap:wrap;
}
.reg-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.reg-dot-open{background:#0d7633;animation:reg-pulse 2s infinite}
.reg-dot-pending{background:#ffa619}
.reg-dot-closed{background:#e74c3c}
@keyframes reg-pulse{0%,100%{box-shadow:0 0 0 0 rgba(13,118,51,.4)}50%{box-shadow:0 0 0 5px rgba(13,118,51,0)}}
.reg-label-open{color:#0d7633}
.reg-label-pending{color:#b36800}
.reg-label-closed{color:#e74c3c}

.btn-reg-active{
  background:var(--orange);color:#fff;
  padding:.5rem 1.1rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.73rem;
  letter-spacing:.04em;transition:.2s;display:inline-flex;align-items:center;gap:.3rem;
  box-shadow:0 3px 12px rgba(255,166,25,.35);white-space:nowrap;
  border:0;cursor:pointer;
}
.btn-reg-active:hover{background:#e8930a;transform:translateY(-1px)}
.btn-reg-inactive{
  background:#f0f2f8;color:#9999aa;
  padding:.5rem 1.1rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.73rem;
  letter-spacing:.04em;white-space:nowrap;cursor:not-allowed;
  display:inline-flex;align-items:center;gap:.3rem;
}
.btn-reg-ended{
  background:#fdecea;color:#c0392b;
  padding:.5rem 1.1rem;border-radius:50px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.73rem;
  letter-spacing:.04em;white-space:nowrap;
  display:inline-flex;align-items:center;gap:.3rem;
}

/* closed banner inside modal */
.reg-closed-banner{
  background:#fdecea;border:1px solid #f5c6c6;border-radius:12px;
  padding:1rem 1.2rem;margin-bottom:1rem;
  display:flex;align-items:flex-start;gap:.8rem;
}
.reg-closed-banner-ico{font-size:1.4rem;flex-shrink:0}
.reg-closed-banner h4{font-family:'Montserrat',sans-serif;font-weight:700;font-size:.88rem;color:#c0392b;margin-bottom:.2rem}
.reg-closed-banner p{font-size:.8rem;color:#922b21;line-height:1.5}

.reg-opens-banner{
  background:#fff8ee;border:1px solid #ffd98a;border-radius:12px;
  padding:1rem 1.2rem;margin-bottom:1rem;
  display:flex;align-items:flex-start;gap:.8rem;
}
.reg-opens-banner-ico{font-size:1.4rem;flex-shrink:0}
.reg-opens-banner h4{font-family:'Montserrat',sans-serif;font-weight:700;font-size:.88rem;color:#b36800;margin-bottom:.2rem}
.reg-opens-banner p{font-size:.8rem;color:#8a5200;line-height:1.5}

/* modal grid extra row */
.mg-item.mg-full{grid-column:1/-1}
.body-no-scroll{overflow:hidden}
.is-hidden{display:none!important}
.poster-placeholder-hidden{display:none}
.poster-placeholder-visible{display:flex!important}
.modal-badge.reg-status-wrap{
  background:var(--gray);color:var(--muted);display:inline-flex;align-items:center;gap:.35rem;
}
.reg-dot.no-shrink{flex-shrink:0}
.btn-modal-reg.pending-disabled{background:#f0f2f8;color:#9999aa;cursor:not-allowed}
.modal-actions-row{display:flex;gap:.8rem;flex-wrap:wrap}
