/* ===========================================================
   QFS — user.css (MINIMAL)
   Purpose: gadget/page-specific styles only.
   Global layout + header/nav have moved to qfs-overrides.css.
   =========================================================== */

*{ box-sizing:border-box; }
body{ font-family: Arial, Helvetica, sans-serif; }

/* ---------- TEMP: Event registration messaging ---------- */
/* Hide confusing "Apply for membership" upsell on event registration */
#FunctionalBlock1_ctl00_eventPageViewBase_ctl00_ctl00_stepTemplate_registrationTopMessage_suggestToApplyMessage_idConfirmWindowStyle,
#FunctionalBlock1_ctl00_eventPageViewBase_ctl00_ctl00_stepTemplate_registrationTopMessage_suggestToApplyMessage_idConfirmWindow,
#FunctionalBlock1_ctl00_eventPageViewBase_ctl00_ctl00_stepTemplate_registrationTopMessage *{
  display:none !important;
}

/* Replace the “Only for certain membership levels.” warning text with clearer copy.
   NOTE: This is CSS-only, so it still appears wherever WA renders that warning. */
.fieldSubContainer .warningLabel{
  position: relative;
  color: transparent !important;          /* hide existing text */
}
.fieldSubContainer .warningLabel::after{
  content: "QFS members only (free admission).";
  color: #333 !important;
  position: relative;
  left: 0;
}
/* Remove the warning triangle background + left padding */
.fieldSubContainer .warningLine{
  background: none !important;
  padding-left: 0 !important;
}

/* ---------- Cards ---------- */
.card-container{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap:20px;
  margin:20px;
  background-color:#fceae8;
  padding:20px;
  border-radius:10px;
  border:1px solid #000;
}
.card{
  background-color:#ffffff !important;
  border:2px solid #000;
  border-radius:10px;
  padding:15px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  text-align:left;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:650px;
}
.poster-container{ display:flex; justify-content:center; margin-bottom:10px; }
.movie-poster{
  max-width:100%;
  height:auto;
  max-height:250px;
  border-radius:10px;
  border:1px solid #000;
}
.title-date-container{ text-align:center; margin-bottom:10px; }
.description-container{ flex:1; font-size:14px; line-height:1.4; margin-bottom:10px; }
.showtimes{ display:flex; justify-content:space-around; gap:10px; margin-top:10px; }
.showtimes a{ flex:1; font-size:14px; padding:10px 15px; }

/* ---------- Visions of Texas ---------- */
.visionsoftexascontent{
  background-color:#b3cefe;
  border-radius:28px;
  border:1px solid #000;
}
.visionsoftexascontent h3{
  font-family:'Ultra', serif;
  font-weight:normal;
  color:#000;
  font-size:18px;
  margin-bottom:5px;
}
.visionsoftexascontent h4{
  font-family:'Ultra', serif;
  font-weight:normal;
  color:#000;
  font-size:16px;
}
.visionsoftexasbutton{
  background-color:#000;
  border-radius:28px;
  border:1px solid #1b0505;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:#fff !important;
  font-family: Arial, sans-serif;
  font-size:14px;
  padding:10px 20px;
  text-decoration:none;
  text-shadow: 0px 1px 0px #fceae8;
  min-height:44px;
  line-height:1.2;
}
.visionsoftexasbutton img{
  height:23px;
  vertical-align:middle;
  margin-left:5px;
}
.visionsoftexasbutton:hover{
  background-color:#fceae8;
  color:#000 !important;
  border-color:#921111;
}
.visionsoftexasbutton:active{ position:relative; top:1px; }

/* Responsive tweaks */
@media (max-width: 480px){
  .card-container{ margin:10px; padding:12px; gap:14px; }
  .card{ min-height:unset; padding:12px; }
  .visionsoftexascontent h3{ font-size:16px; }
  .visionsoftexascontent h4{ font-size:14px; }
  .showtimes{ flex-direction:column; gap:8px; align-items:stretch; }
  .poster-container{ gap:8px; flex-wrap:wrap; }
  .poster-container img{ max-width:100%; height:auto; }
  .poster-container img + img{ width:100%; }
}
@media (max-width: 360px){
  .card-container{ grid-template-columns: 1fr; }
}

/* ---------- Board grid ---------- */
.board-container{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap:20px;
  max-width:1200px;
  margin:0 auto;
  padding:20px;
}
.board-poster-container{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  margin-bottom:10px;
}
.board-name{
  font-size:22px;
  font-weight:bold;
  color:#521011;
  margin-bottom:3px;
}
.board-bio p{
  font-size:18px;
  line-height:1.6;
  margin-bottom:1em;
}
.board-photo{
  width:160px;
  height:225px;
  object-fit:cover;
  border-radius:8px;
  display:block;
  margin:0 auto 10px;
}
.board-title{
  font-style:italic;
  font-size:1rem;
  text-align:center;
  color:#444;
  margin-bottom:5px;
}
.board-profile:hover{
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
  transform: translateY(-2px);
  transition: all 0.2s ease;
}

/* ---------- Seating chart ---------- */
#seating-chart .screen{
  background:#e0c46f;
  color:#000;
  padding:.75em 1em;
  border-radius:0 0 30px 30px;
  margin:0 auto 2em;
  width:60%;
  font-size:1.25rem;
  font-weight:bold;
  letter-spacing:.05em;
  text-align:center;
}
#seating-chart .seating{
  display:flex;
  flex-direction:column;
  gap:.5em;
  justify-content:center;
  margin:auto;
  max-width:750px;
}
#seating-chart .row{
  display:grid;
  grid-template-columns: 2em 48px repeat(8, 48px) 2em;
  align-items:center;
  gap:.5em;
}
#seating-chart .row-label{
  font-weight:bold;
  font-size:.9em;
  text-align:center;
  white-space:nowrap;
  min-width:2em;
}
#seating-chart .spacer{ width:48px; height:48px; }
#seating-chart .seat{
  display:inline-block;
  background:#fff;
  border:2px solid #003366;
  color:#003366;
  font-weight:600;
  border-radius:8px;
  font-size:.9rem;
  text-align:center;
  cursor:pointer;
  transition: background .3s;
  width:48px;
  height:48px;
}
#seating-chart .seat:hover{ background-color:#e6f0ff; }
#seating-chart .seat.unavailable{
  background-color:#ccc;
  color:#666;
  border-color:#999;
  pointer-events:none;
  cursor:not-allowed;
}
#seating-chart .seat.accessible::after{ content:" \267F"; font-size:.8em; }
#seating-chart .seat.selected{
  background-color:#003366;
  color:#fff;
  border-color:#001a33;
}
#seating-chart .seat:focus{
  outline:2px solid #ffcc00;
  outline-offset:2px;
}