/* Knowledge Barbers — Events page + Drawer
 * Matte-black aesthetic matching the KB brand.
 * Inline-ish conservative CSS; no build step.
 */

:root {
  --kb-bg: #ffffff;
  --kb-surface: #fafafa;
  --kb-surface-2: #f3f4f6;
  --kb-border: #e5e7eb;
  --kb-text: #0f172a;
  --kb-text-dim: #6b7280;
  --kb-accent: #215C2E; /* KB logo green */
  --kb-accent-hover: #1a4a25;
  --kb-accent-ink: #ffffff;
  --kb-danger: #dc2626;
  --kb-success: #10b981;
}

/* -------------------- EVENTS PAGE -------------------- */

body.events-page {
  background: var(--kb-bg);
  color: var(--kb-text);
  font-family: 'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  margin: 0;
  -webkit-font-smoothing: antialiased;
}

.ev-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 28px;
  border-bottom: 1px solid var(--kb-border);
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.ev-top a.ev-logo { display: inline-flex; align-items: center; text-decoration: none; }
.ev-top a.ev-logo img { height: 28px; }
.ev-top nav a {
  color: var(--kb-text-dim);
  text-decoration: none;
  margin-left: 22px;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color 0.15s ease;
}
.ev-top nav a:hover { color: var(--kb-text); }

.ev-hero {
  position: relative;
  min-height: 70vh;
  display: flex;
  align-items: flex-end;
  padding: 48px 28px;
  overflow: hidden;
}
.ev-hero-img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.45) saturate(0.85) contrast(1.05);
}
.ev-hero-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,0.0) 0%, rgba(10,10,10,0.35) 55%, rgba(10,10,10,1.0) 100%);
}
.ev-hero-inner {
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
  width: 100%;
}
.ev-hero-eyebrow {
  display: inline-block;
  padding: 6px 12px;
  border: 1px solid var(--kb-accent);
  color: var(--kb-accent);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border-radius: 999px;
  margin-bottom: 18px;
}
.ev-hero h1 {
  font-family: 'Helvetica Neue', 'Montserrat', Arial, sans-serif;
  font-weight: 900;
  font-size: clamp(42px, 8vw, 96px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  margin: 0 0 18px 0;
  text-transform: uppercase;
}
.ev-hero .ev-tagline {
  font-size: 18px;
  color: var(--kb-text-dim);
  max-width: 620px;
  margin: 0 0 28px 0;
}
.ev-hero .ev-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  margin-bottom: 28px;
}
.ev-hero .ev-meta > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ev-hero .ev-meta .lbl {
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--kb-text-dim);
  text-transform: uppercase;
}
.ev-hero .ev-meta .val { font-size: 15px; font-weight: 500; color: var(--kb-text); }
.ev-hero .ev-meta .val a { color: var(--kb-accent); text-decoration: none; }
.ev-hero .ev-meta .val a:hover { text-decoration: underline; }

.ev-cta-row { display: flex; gap: 12px; flex-wrap: wrap; }
.ev-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 26px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: transform 0.12s ease, background 0.2s ease, opacity 0.2s ease;
}
.ev-btn:active { transform: scale(0.98); }
.ev-btn-primary { background: var(--kb-accent); color: var(--kb-accent-ink); }
.ev-btn-primary:hover { background: #f0c67a; }
.ev-btn-ghost {
  background: transparent;
  color: var(--kb-text);
  border: 1px solid var(--kb-border);
}
.ev-btn-ghost:hover { border-color: var(--kb-text); }
.ev-btn[disabled] { opacity: 0.55; cursor: not-allowed; }

/* -------------------- Sections -------------------- */

.ev-section {
  padding: 72px 28px;
  max-width: 1100px;
  margin: 0 auto;
}
.ev-section h2 {
  font-family: 'Helvetica Neue', 'Montserrat', Arial, sans-serif;
  font-size: 36px;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin: 0 0 8px 0;
  text-transform: uppercase;
}
.ev-section .eyebrow {
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--kb-accent);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.ev-section p {
  color: var(--kb-text-dim);
  font-size: 16px;
  line-height: 1.65;
  max-width: 720px;
}

.ev-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
  margin-top: 32px;
}
.ev-gallery img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  border-radius: 4px;
  filter: brightness(0.88) saturate(0.9);
  transition: filter 0.25s ease, transform 0.3s ease;
}
.ev-gallery img:hover { filter: brightness(1) saturate(1); transform: scale(1.01); }

/* Agenda */
.ev-agenda {
  margin-top: 32px;
  border-top: 1px solid var(--kb-border);
}
.ev-agenda-row {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 24px;
  padding: 22px 0;
  border-bottom: 1px solid var(--kb-border);
}
.ev-agenda-row .t {
  font-size: 14px;
  color: var(--kb-accent);
  font-weight: 600;
  letter-spacing: 0.06em;
}
.ev-agenda-row .title { font-size: 17px; font-weight: 600; color: var(--kb-text); margin-bottom: 2px; }
.ev-agenda-row .sub { font-size: 14px; color: var(--kb-text-dim); }

/* Tiers */
.ev-tiers {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  margin-top: 36px;
}
.ev-tier {
  background: var(--kb-surface);
  border: 1px solid var(--kb-border);
  border-radius: 10px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: border-color 0.2s ease, transform 0.18s ease;
}
.ev-tier.featured {
  border-color: var(--kb-accent);
  position: relative;
}
.ev-tier.featured::before {
  content: 'Most Popular';
  position: absolute;
  top: -11px;
  left: 24px;
  background: var(--kb-accent);
  color: var(--kb-accent-ink);
  padding: 3px 10px;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  border-radius: 999px;
}
.ev-tier h3 {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.ev-tier .price {
  font-size: 36px;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.ev-tier .price small {
  font-size: 14px;
  font-weight: 500;
  color: var(--kb-text-dim);
  margin-left: 6px;
  letter-spacing: 0;
}
.ev-tier .desc { color: var(--kb-text-dim); font-size: 14px; line-height: 1.5; }
.ev-tier ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.ev-tier ul li {
  font-size: 14px;
  color: var(--kb-text);
  padding-left: 22px;
  position: relative;
  line-height: 1.5;
}
.ev-tier ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 7px;
  width: 12px;
  height: 12px;
  border: 1.5px solid var(--kb-accent);
  border-top: 0;
  border-right: 0;
  transform: rotate(-45deg);
}
.ev-tier .cap {
  font-size: 12px;
  color: var(--kb-text-dim);
  letter-spacing: 0.04em;
}
.ev-tier button { margin-top: auto; }

/* FAQs */
.ev-faqs { margin-top: 32px; }
.ev-faq {
  border-top: 1px solid var(--kb-border);
  padding: 20px 0;
}
.ev-faq .q { font-weight: 600; font-size: 16px; margin-bottom: 6px; }
.ev-faq .a { color: var(--kb-text-dim); font-size: 14px; line-height: 1.6; }

/* Footer */
.ev-footer {
  padding: 40px 28px;
  text-align: center;
  border-top: 1px solid var(--kb-border);
  color: var(--kb-text-dim);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* -------------------- DRAWER -------------------- */

.ev-drawer-scrim {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.ev-drawer-scrim.open { opacity: 1; pointer-events: auto; }

.ev-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(480px, 100vw);
  background: var(--kb-bg);
  border-left: 1px solid var(--kb-border);
  z-index: 1000;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.ev-drawer.open { transform: translateX(0); }

.ev-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid var(--kb-border);
  flex-shrink: 0;
}
.ev-drawer-head .title { font-size: 15px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
.ev-drawer-head .sub { font-size: 12px; color: var(--kb-text-dim); margin-top: 2px; }
.ev-drawer-close {
  background: transparent;
  border: none;
  color: var(--kb-text);
  cursor: pointer;
  padding: 6px;
  font-size: 22px;
  line-height: 1;
}

.ev-drawer-steps {
  display: flex;
  gap: 4px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--kb-border);
  flex-shrink: 0;
}
.ev-step-dot {
  flex: 1;
  height: 3px;
  border-radius: 2px;
  background: var(--kb-border);
  transition: background 0.3s ease;
}
.ev-step-dot.active { background: var(--kb-accent); }
.ev-step-dot.done { background: var(--kb-text-dim); }

.ev-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 24px 22px 100px;
  -webkit-overflow-scrolling: touch;
}
.ev-drawer-body h3 {
  margin: 0 0 6px 0;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.ev-drawer-body .step-sub { color: var(--kb-text-dim); font-size: 14px; margin-bottom: 24px; }

/* Tier radio cards */
.ev-tier-pick {
  display: block;
  border: 1px solid var(--kb-border);
  border-radius: 8px;
  padding: 18px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: border-color 0.18s ease, background 0.18s ease;
  background: var(--kb-surface);
}
.ev-tier-pick:hover { border-color: var(--kb-text-dim); }
.ev-tier-pick.selected { border-color: var(--kb-accent); background: var(--kb-surface-2); }
.ev-tier-pick .row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.ev-tier-pick .n { font-weight: 600; font-size: 15px; }
.ev-tier-pick .p { font-weight: 700; font-size: 18px; color: var(--kb-accent); }
.ev-tier-pick .d { font-size: 13px; color: var(--kb-text-dim); margin-top: 6px; line-height: 1.5; }

/* Quantity */
.ev-qty {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 20px;
}
.ev-qty .label { font-size: 13px; color: var(--kb-text-dim); flex: 1; }
.ev-qty button {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--kb-border);
  background: transparent;
  color: var(--kb-text);
  font-size: 20px;
  cursor: pointer;
  line-height: 1;
  transition: border-color 0.15s ease;
}
.ev-qty button:hover:not(:disabled) { border-color: var(--kb-text); }
.ev-qty button:disabled { opacity: 0.4; cursor: not-allowed; }
.ev-qty .v { min-width: 28px; text-align: center; font-weight: 600; font-size: 16px; }

/* Form fields */
.ev-field { margin-bottom: 16px; }
.ev-field label {
  display: block;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kb-text-dim);
  margin-bottom: 8px;
  font-weight: 600;
}
.ev-field input {
  width: 100%;
  padding: 14px 16px;
  background: var(--kb-surface);
  border: 1px solid var(--kb-border);
  border-radius: 8px;
  color: var(--kb-text);
  font-size: 15px;
  font-family: inherit;
  box-sizing: border-box;
  transition: border-color 0.15s ease;
}
.ev-field input:focus { outline: none; border-color: var(--kb-accent); }

/* Payment step */
.ev-pay-summary {
  background: var(--kb-surface);
  border: 1px solid var(--kb-border);
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 20px;
}
.ev-pay-summary .line {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 14px;
  padding: 4px 0;
}
.ev-pay-summary .total {
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--kb-border);
  font-size: 18px;
  font-weight: 700;
}
.ev-pay-summary .total .amt { color: var(--kb-accent); }

#sq-wallet-box, #sq-card-box { margin-top: 14px; }
#sq-apple-pay-btn, #sq-google-pay-btn {
  width: 100%;
  height: 48px;
  border-radius: 8px;
  margin-bottom: 10px;
  cursor: pointer;
}
#sq-card-container {
  background: var(--kb-surface);
  border: 1px solid var(--kb-border);
  border-radius: 8px;
  padding: 14px;
  min-height: 56px;
}
.ev-pay-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 16px 0;
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--kb-text-dim);
  text-transform: uppercase;
}
.ev-pay-divider::before, .ev-pay-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--kb-border);
}

.ev-err {
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.4);
  color: #fca5a5;
  padding: 12px 14px;
  border-radius: 6px;
  font-size: 13px;
  margin-top: 12px;
}

/* Footer CTA */
.ev-drawer-foot {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 16px 22px;
  background: linear-gradient(180deg, rgba(10,10,10,0) 0%, rgba(10,10,10,0.95) 30%, var(--kb-bg) 100%);
  padding-top: 36px;
}
.ev-drawer-foot .ev-btn { width: 100%; }

/* Success screen */
.ev-success {
  text-align: center;
  padding-top: 24px;
}
.ev-success .check {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(16, 185, 129, 0.12);
  border: 2px solid var(--kb-success);
  color: var(--kb-success);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  margin-bottom: 18px;
}
.ev-success h3 { font-size: 26px; margin-bottom: 8px; }
.ev-success .p { color: var(--kb-text-dim); margin-bottom: 20px; }
.ev-ticket {
  background: var(--kb-surface);
  border: 1px solid var(--kb-border);
  border-radius: 10px;
  padding: 22px;
  text-align: left;
  margin-top: 18px;
}
.ev-ticket .row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-size: 14px;
}
.ev-ticket .row .k { color: var(--kb-text-dim); }
.ev-ticket .row .v { color: var(--kb-text); font-weight: 500; }
.ev-ticket .tid {
  font-family: 'SF Mono', 'Monaco', monospace;
  font-size: 13px;
  color: var(--kb-accent);
  letter-spacing: 0.04em;
}
.ev-qr-box {
  display: flex;
  justify-content: center;
  background: white;
  padding: 20px;
  border-radius: 8px;
  margin-top: 18px;
}
.ev-qr-box img, .ev-qr-box canvas { max-width: 180px; height: auto; }

/* -------------------- WHITE+GREEN THEME OVERRIDES -------------------- */
/* Hero text stays white over darkened photo; transitions cleanly to white body. */
.ev-hero h1,
.ev-hero .ev-tagline,
.ev-hero .ev-meta .val { color: #ffffff !important; }
.ev-hero .ev-meta .lbl { color: rgba(255,255,255,0.7) !important; }
.ev-hero-eyebrow { color: #ffffff !important; border-color: #ffffff !important; background: rgba(33,92,46,0.35); }
.ev-hero-img::after { background: linear-gradient(180deg, rgba(33,92,46,0.35) 0%, rgba(0,0,0,0.55) 60%, #ffffff 100%) !important; }

/* Primary button → KB green, white ink */
.ev-btn-primary { background: var(--kb-accent); color: var(--kb-accent-ink); }
.ev-btn-primary:hover { background: var(--kb-accent-hover); }

/* Ghost button on light bg */
.ev-btn-ghost { color: var(--kb-text); border: 1px solid var(--kb-border); }
.ev-btn-ghost:hover { border-color: var(--kb-accent); color: var(--kb-accent); }

/* Tier cards: light, lift on hover */
.ev-tier { background: #ffffff; box-shadow: 0 1px 3px rgba(15,23,42,0.04), 0 1px 2px rgba(15,23,42,0.03); }
.ev-tier:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(33,92,46,0.10); }
.ev-tier.featured { box-shadow: 0 4px 16px rgba(33,92,46,0.12), 0 1px 3px rgba(15,23,42,0.04); }

/* Drawer scrim: lighter on white theme */
.ev-drawer-scrim { background: rgba(15, 23, 42, 0.55); }

/* Drawer step dots */
.ev-step-dot { background: var(--kb-border); }
.ev-step-dot.active { background: var(--kb-accent); }
.ev-step-dot.complete { background: var(--kb-accent); opacity: 0.4; }

/* Gallery images on light bg */
.ev-gallery img { filter: none; box-shadow: 0 1px 3px rgba(15,23,42,0.08); }

/* Apple Pay + Google Pay wallet buttons sit nicely on white */
#sq-apple-pay-btn, #sq-google-pay-btn { min-height: 48px; }

/* Section headers: add a subtle green underline vibe via eyebrow */
.ev-section .eyebrow { color: var(--kb-accent); }

/* Text-dim should still be readable on white */
.ev-agenda-row .sub,
.ev-tier .desc,
.ev-tier .cap,
.ev-faq .a { color: var(--kb-text-dim); }

/* Small screens */
@media (max-width: 520px) {
  .ev-hero { padding: 32px 20px; min-height: 60vh; }
  .ev-hero h1 { font-size: 46px; }
  .ev-section { padding: 48px 20px; }
  .ev-top { padding: 14px 20px; }
  .ev-top nav a { display: none; }
  .ev-gallery img { height: 180px; }
  .ev-agenda-row { grid-template-columns: 90px 1fr; gap: 16px; }
}
