@font-face{
  font-family:"GFL";
  src:url("/public/fonts/GFL-Medium.woff2") format("woff2");
  font-weight:500;
  font-style:normal;
  font-display:swap;
}

@font-face{
  font-family:"GFL";
  src:url("/public/fonts/GFL-MediumItalic.woff2") format("woff2");
  font-weight:500;
  font-style:italic;
  font-display:swap;
}

@font-face{
  font-family:"GFL";
  src:url("/public/fonts/GFL-Black.woff2") format("woff2");
  font-weight:900;
  font-style:normal;
  font-display:swap;
}

@font-face{
  font-family:"GFL";
  src:url("/public/fonts/GFL-BlackItalic.woff2") format("woff2");
  font-weight:900;
  font-style:italic;
  font-display:swap;
}

@font-face{
  font-family:"Space Grotesk";
  src:url("/public/fonts/SpaceGrotesk-Regular.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

@font-face{
  font-family:"Space Grotesk";
  src:url("/public/fonts/SpaceGrotesk-Bold.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:swap;
}

:root{
  --bg: #f4f6f8;
  --surface: #ffffff;
  --fg: #111827;
  --muted: #6b7280;
  --card: #ffffff;
  --border: rgba(17,24,39,.12);
  --border-strong: rgba(17,24,39,.2);
  --shadow-sm: 0 1px 2px rgba(17,24,39,.06), 0 6px 18px rgba(17,24,39,.04);
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --font-heading: "GFL", "Arial Narrow", "Helvetica Neue", Arial, sans-serif;
  --font-body: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  --focus-ring: 0 0 0 3px rgba(37, 99, 235, .2);
  --alert-info-bg: #eef4ff;
  --alert-info-fg: #1e3a8a;
  --alert-success-bg: #ecfdf5;
  --alert-success-fg: #065f46;
  --alert-error-bg: #fef2f2;
  --alert-error-fg: #991b1b;
  --status-gray-bg: #f3f4f6;
  --status-gray-fg: #374151;
  --status-green-bg: #ecfdf5;
  --status-green-fg: #065f46;
  --status-amber-bg: #fffbeb;
  --status-amber-fg: #92400e;
  --status-red-bg: #fef2f2;
  --status-red-fg: #991b1b;
  --status-blue-bg: #eff6ff;
  --status-blue-fg: #1d4ed8;
}

*,
*::before,
*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--fg);line-height:1.45}
h1,h2,h3,h4{font-family:var(--font-heading)}
a{color:inherit}
img,svg{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
table{border-collapse:collapse}

.container{max-width:960px;margin:0 auto;padding:var(--space-4)}
.header{border-bottom:1px solid var(--border);background:rgba(255,255,255,.92);backdrop-filter:saturate(140%) blur(8px);position:sticky;top:0;z-index:20}
.header .container{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}
.brand{font-family:var(--font-heading);font-weight:900;letter-spacing:.02em}
.nav{display:flex;gap:var(--space-2);flex-wrap:wrap}
.nav a{margin-right:0;color:inherit;text-decoration:none;padding:8px 10px;border-radius:999px}
.nav a:hover{background:rgba(17,24,39,.04)}

.stack > * + *{margin-top:var(--space-4)}
.stack-tight > * + *{margin-top:var(--space-3)}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);margin:var(--space-4) 0;box-shadow:var(--shadow-sm)}
.card h1,.card h2,.card h3,.card h4{margin-top:0}
.card > :last-child{margin-bottom:0}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;border-radius:10px;padding:10px 14px;cursor:pointer;text-decoration:none;font-weight:700;line-height:1.1}
.btn:hover{filter:brightness(.98)}
.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}
.btn-primary{background:var(--color-primary-1, #1f6feb);color:white}
.btn-secondary{background:#fff;color:var(--fg);border-color:var(--border-strong)}
.btn-sm{padding:6px 10px;font-size:12px;border-radius:8px}

.field{display:flex;flex-direction:column;gap:6px;margin:10px 0}
.field label{font-weight:700;font-size:14px}
.choice-list{display:flex;flex-direction:column;gap:8px}
.choice-row{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14px}
.choice-row input[type="radio"]{margin:0;flex:0 0 auto}
input,select,textarea,
.input,.select,.textarea{
  width:100%;
  min-width:0;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid var(--border-strong);
  background:#fff;
  color:var(--fg);
  font-size:14px;
}
input[type="checkbox"]{width:auto}
input[type="radio"]{width:auto}
textarea{min-height:100px;resize:vertical}
input:focus,select:focus,textarea:focus,
.input:focus,.select:focus,.textarea:focus{
  outline:none;
  border-color:rgba(37,99,235,.45);
  box-shadow:var(--focus-ring);
}

.small{color:var(--muted);font-size:13px}

.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 8px;border-radius:999px;background:var(--status-gray-bg);
  color:var(--status-gray-fg);border:1px solid var(--border);font-size:12px;font-weight:700;
}
.badge.badge-paid,.badge.badge-claimed,.badge.badge-accepted,.badge.badge-active,.badge.badge-sent{background:var(--status-green-bg);color:var(--status-green-fg)}
.badge.badge-unpaid,.badge.badge-offered,.badge.badge-in_queue,.badge.badge-paused{background:var(--status-amber-bg);color:var(--status-amber-fg)}
.badge.badge-declined,.badge.badge-expired,.badge.badge-failed,.badge.badge-inactive{background:var(--status-red-bg);color:var(--status-red-fg)}
.badge.badge-info{background:var(--status-blue-bg);color:var(--status-blue-fg)}

.alert{
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  margin:10px 0;
}
.alert.alert-info{background:var(--alert-info-bg);color:var(--alert-info-fg)}
.alert.alert-success{background:var(--alert-success-bg);color:var(--alert-success-fg)}
.alert.alert-error{background:var(--alert-error-bg);color:var(--alert-error-fg)}

.row-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.participant-row{background:#fff}
.participant-row-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}
.participant-row-header h3{margin:0;font-size:16px}
.participant-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px 12px}
.participant-grid .field{margin:4px 0}
.participant-remove[disabled]{opacity:.5;cursor:not-allowed}
.noscript-warning{padding:10px;border:1px solid var(--border);border-radius:10px;background:#fff7d6}

.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:12px;background:#fff}
.table{width:100%;min-width:640px;background:#fff}
.table th,.table td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.table thead th{position:sticky;top:0;background:#f9fafb;z-index:1;font-size:13px}
.table tbody tr:nth-child(even){background:#fafafa}
.table tbody tr:hover{background:#f5f8ff}
.table td .btn{padding:7px 10px}
.table input,.table select,.table textarea{padding:6px 8px;font-size:13px;border-radius:8px}
.table textarea{min-height:56px}
.table .cell-edit{min-width:110px}
.table .cell-edit.cell-edit-sm{min-width:72px;max-width:96px}
.table .cell-edit.cell-edit-md{min-width:140px}
.table .cell-edit.cell-edit-lg{min-width:220px}
.table .cell-edit{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.table td[data-inline-cell]{position:relative}
.table td[data-inline-cell] .cell-edit{padding-right:14px}
.cell-status{
  position:absolute;top:4px;right:6px;z-index:2;
  display:inline-flex;align-items:center;justify-content:center;
  max-width:56px;padding:1px 5px;border-radius:999px;
  font-size:10px;line-height:1.1;color:var(--muted);
  background:rgba(255,255,255,.92);border:1px solid transparent;
  min-height:0;margin-top:0;pointer-events:none;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.cell-status:empty{display:none}
.cell-status[data-state="saved"]{color:var(--status-green-fg)}
.cell-status[data-state="saving"]{color:var(--status-blue-fg)}
.cell-status[data-state="error"]{color:var(--status-red-fg);font-weight:700}

.table.table-dense{min-width:820px;font-size:13px;line-height:1.2}
.table.table-dense th,
.table.table-dense td{padding:6px 8px;white-space:nowrap}
.table.table-dense th{font-size:12px}
.table.table-dense td{vertical-align:middle}
.table.table-dense td .btn{padding:5px 8px;font-size:12px}
.table.table-dense input,
.table.table-dense select,
.table.table-dense textarea{
  height:28px;min-height:28px;
  padding:3px 6px;
  font-size:12px;
  line-height:1.15;
  border-radius:7px;
}
.table.table-dense textarea{
  height:28px;resize:none;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
}
.table.table-dense .cell-edit{min-width:88px}
.table.table-dense .cell-edit.cell-edit-sm{min-width:78px;max-width:110px}
.table.table-dense .cell-edit.cell-edit-md{min-width:110px;max-width:150px}
.table.table-dense .cell-edit.cell-edit-lg{min-width:140px;max-width:190px}
.table.table-dense td[data-inline-cell] .cell-edit{padding-right:12px}
.table.table-dense td[data-inline-cell] select.cell-edit{padding-right:22px}
.table.table-dense .cell-status{top:3px;right:4px;max-width:44px;padding:1px 4px;font-size:9px}
.table.table-dense code{padding:1px 4px;font-size:11px}
.table.table-dense .small{font-size:11px;line-height:1.15}
.table.table-dense .truncate{display:block;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.table.table-dense .truncate-sm{display:block;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Optional sticky first columns on dense admin grids for side-scroll readability */
.table.table-dense .sticky-col{
  position:sticky;left:0;z-index:1;background:inherit;
}
.table.table-dense thead .sticky-col{z-index:3;background:#f9fafb}

.admin-chrome{margin-bottom:var(--space-4)}
.admin-nav{
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap;
  padding:12px 14px;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:var(--shadow-sm);
}
.admin-nav-links{display:flex;gap:8px;flex-wrap:wrap}
.admin-nav-links a{
  text-decoration:none;padding:8px 10px;border-radius:999px;border:1px solid transparent;color:var(--fg);font-weight:700;font-size:14px;
}
.admin-nav-links a:hover{background:#f3f4f6;border-color:var(--border)}
.admin-nav-actions{display:flex;align-items:center;gap:8px}
.admin-nav-actions form{margin:0}

.section-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}

code{background:#f3f4f6;padding:2px 6px;border-radius:6px}
.payment-total-line{
  margin:4px 0 10px 0;
  font-family:var(--font-heading);
  font-size:clamp(28px, 6vw, 42px);
  line-height:1;
}
.gfl-stepper{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-bottom:14px;
}
.gfl-step{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
}
.gfl-step-index{
  width:28px;
  height:28px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  border:1px solid var(--border-strong);
  background:#fff;
  flex:0 0 auto;
}
.gfl-step-title{
  font-weight:700;
  line-height:1.1;
}
.gfl-step.is-active{
  border-color:rgba(37,99,235,.35);
  background:#eef4ff;
}
.gfl-step.is-active .gfl-step-index{
  background:var(--color-primary-1, #1f6feb);
  color:#fff;
  border-color:transparent;
}
.gfl-step.is-complete{
  background:#ecfdf5;
  border-color:rgba(6,95,70,.22);
}
.gfl-step.is-complete .gfl-step-index{
  background:#065f46;
  color:#fff;
  border-color:transparent;
}
.gfl-step.is-inactive{
  opacity:.8;
}
.payment-step-card{
  background:linear-gradient(180deg, #fff 0%, #fbfdff 100%);
}
.payment-qr-wrap{
  max-width:320px;
}
.payment-qr-image{
  width:100%;
  height:auto;
  border:1px solid #ddd;
  border-radius:8px;
  background:#fff;
  padding:8px;
}

@media (max-width: 640px){
  .gfl-stepper{grid-template-columns:1fr}
}
