/* =====================================================================
   Saudi Future — Public pages (register, workshops, ticket, lookup)
   ===================================================================== */

body.page-public {
  background:
    radial-gradient(ellipse 800px 400px at 100% 0%, rgba(11, 61, 46, 0.05), transparent 70%),
    var(--bg-page);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
body.page-public > main { flex: 1 0 auto; }
body.page-public > .site-footer { flex-shrink: 0; }

.page-public main {
  padding-block: var(--sp-12);
}

/* ====== Form layout ====== */
.form-shell {
  max-width: 720px;
  margin: 0 auto;
  background: var(--white);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-2xl);
  padding: var(--sp-10);
  box-shadow: var(--sh-1);
}
@media (max-width: 600px) { .form-shell { padding: var(--sp-6); } }
.form-shell h1 { font-family: var(--ff-serif); color: var(--green-800); font-size: var(--fs-32); margin-bottom: var(--sp-2); }
.form-shell .lede { color: var(--text-secondary); margin-bottom: var(--sp-6); font-size: var(--fs-16); }

.form-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}
@media (min-width: 700px) { .form-row { grid-template-columns: 1fr 1fr; } }

/* ====== Workshops list ====== */
.workshops-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
@media (min-width: 700px) { .workshops-list { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .workshops-list { grid-template-columns: repeat(3, 1fr); } }

.day-tabs {
  display: flex; gap: var(--sp-2); margin-bottom: var(--sp-6); flex-wrap: wrap;
}
.day-tab {
  padding: var(--sp-3) var(--sp-5);
  background: var(--white);
  border: 1.5px solid var(--border-firm);
  border-radius: var(--r-pill);
  font-weight: 700; font-size: var(--fs-14);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--d-fast) var(--ease-soft);
}
.day-tab:hover { color: var(--green-800); border-color: var(--green-300); }
.day-tab.active { background: var(--green-800); color: var(--cream-50); border-color: var(--green-800); }

/* ====== Ticket ====== */
.ticket-shell {
  max-width: 540px; margin: 0 auto;
}
.ticket {
  position: relative;
  background: var(--white);
  border-radius: var(--r-2xl);
  padding: var(--sp-8) var(--sp-6);
  box-shadow: var(--sh-2);
  text-align: center;
  overflow: hidden;
  border: 1px solid var(--border-soft);
}
.ticket::before {
  content: "";
  position: absolute; inset: 0 0 auto 0;
  height: 12px;
  background: var(--bg-deep-grad);
}
.ticket::after {
  content: "";
  position: absolute; inset: 0;
  background-image: url("../pattren/recolored/1-02-green.png");
  background-position: right top;
  background-repeat: repeat-y;
  background-size: 30px auto;
  opacity: 0.04; pointer-events: none;
}
.ticket > * { position: relative; z-index: 1; }
.ticket__hd {
  display: flex; align-items: center; justify-content: center; gap: var(--sp-3);
  margin-top: var(--sp-3); margin-bottom: var(--sp-4);
}
.ticket__hd img { height: 36px; }
.ticket__hd span { font-family: var(--ff-serif); color: var(--green-800); font-size: var(--fs-18); font-weight: 700; }
.ticket__type {
  display: inline-block;
  padding: var(--sp-1) var(--sp-3);
  background: var(--gold);
  color: var(--green-900);
  border-radius: var(--r-pill);
  font-size: var(--fs-12); font-weight: 800;
  margin-bottom: var(--sp-3);
}
.ticket__name {
  font-family: var(--ff-serif);
  font-size: var(--fs-28); font-weight: 800;
  color: var(--green-800);
  margin-bottom: var(--sp-2);
}
.ticket__meta {
  color: var(--text-secondary); font-size: var(--fs-14); margin-bottom: var(--sp-5);
  display: flex; flex-direction: column; gap: var(--sp-1);
}
.ticket__qr {
  width: 280px; height: 280px;
  margin: 0 auto var(--sp-4);
  background: var(--white);
  padding: var(--sp-3);
  border-radius: var(--r-md);
  border: 1px solid var(--border-soft);
  display: flex; align-items: center; justify-content: center;
}
.ticket__qr canvas, .ticket__qr img { max-width: 100%; height: auto; }
.ticket__ref {
  font-family: var(--ff-mono);
  font-size: var(--fs-20);
  font-weight: 700;
  color: var(--green-800);
  letter-spacing: 0.08em;
  padding: var(--sp-2) var(--sp-4);
  background: var(--cream-100);
  border-radius: var(--r-md);
  display: inline-block;
  margin-bottom: var(--sp-5);
  user-select: all;
}
.ticket__actions { display: flex; gap: var(--sp-2); justify-content: center; flex-wrap: wrap; }
.ticket__hint { font-size: var(--fs-12); color: var(--text-muted); margin-top: var(--sp-5); }

/* Print */
@media print {
  body.page-public { background: var(--white); }
  .site-header, .site-footer, .ticket__actions, .ticket__hint, .lookup-form { display: none !important; }
  .ticket { box-shadow: none; border: 1px solid #000; }
  .ticket::after { display: none; }
}

/* ====== Lookup page ====== */
.lookup-form { max-width: 520px; margin: 0 auto var(--sp-8); }
.bookings-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  max-width: 980px; margin: 0 auto;
}
@media (min-width: 700px) { .bookings-grid { grid-template-columns: 1fr 1fr; } }
.booking-card {
  background: var(--white);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-xl);
  padding: var(--sp-6);
  display: flex; flex-direction: column; gap: var(--sp-3);
}
.booking-card__type { display: inline-block; padding: 2px var(--sp-2); border-radius: var(--r-pill); font-size: var(--fs-12); font-weight: 700; background: var(--green-100); color: var(--green-800); align-self: flex-start; }
.booking-card__title { font-family: var(--ff-serif); font-size: var(--fs-20); color: var(--green-800); font-weight: 700; }
.booking-card__meta { color: var(--text-secondary); font-size: var(--fs-13, 0.81rem); display: flex; flex-direction: column; gap: var(--sp-1); }
.booking-card__ref { font-family: var(--ff-mono); font-size: var(--fs-14); color: var(--ink-700); background: var(--cream-100); padding: var(--sp-1) var(--sp-2); border-radius: var(--r-sm); display: inline-block; align-self: flex-start; }
.booking-card__actions { display: flex; gap: var(--sp-2); margin-top: auto; flex-wrap: wrap; }
.booking-card__qr {
  width: 140px; height: 140px;
  background: var(--white);
  padding: var(--sp-2);
  border-radius: var(--r-md);
  border: 1px solid var(--border-soft);
  display: flex; align-items: center; justify-content: center;
  align-self: center;
}
.booking-card__qr canvas, .booking-card__qr img { max-width: 100%; height: auto; }

/* ====== Conflict warning ====== */
.conflict-warning {
  background: var(--warning-bg);
  border: 1px solid #FDE68A;
  color: #92400E;
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-4);
  font-size: var(--fs-14);
}
.conflict-warning strong { display: block; margin-bottom: var(--sp-1); }

/* ====== Generic site header for inner pages ====== */
.inner-head {
  background: var(--white);
  border-bottom: 1px solid var(--border-soft);
  padding-block: var(--sp-3);
  position: sticky; top: 0; z-index: var(--z-sticky);
}
