/* ============================================================
   SPIKELAB — Prelaunch Testing Program
   Shared brand styles (survey app + admin dashboard)
   Brand pulled from spikelab.co.nz
   ============================================================ */

:root{
  --bg:#0a0a0a;
  --bg-elev:#121212;
  --bg-card:#181818;
  --bg-card-hi:#1f1f1f;
  --line:rgba(200,168,75,.18);
  --line-soft:rgba(245,239,224,.08);
  --text:#f8f4ea;
  --text-mid:#e7dfd0;
  --text-dim:#b3ab9a;
  --text-faint:#7d7666;
  --gold:#c8a84b;
  --gold-hi:#e6c562;
  --gold-lo:#9a7f33;
  --gold-deep:#7a6328;
  --btn-ink:#0a0a0a;
  --good:#5fae6b;
  --warn:#d6a13f;
  --bad:#cf6a5a;
  --pins:#7fb0d6;   /* PINS accent */
  --bolts:#d68f5a;  /* BOLTS accent */
  --serif:'Bebas Neue',sans-serif;
  --condensed:'Barlow Condensed',sans-serif;
  --logo:'Inter',sans-serif;
  --radius:16px;
  --radius-sm:11px;
  --maxw:640px;
  /* cricket-ground background (matched to spikelab.co.nz) */
  --pb-sky-a:#080706; --pb-sky-b:#110d09;
  --pb-field-a:#1f1a11; --pb-field-b:#15110b; --pb-field-c:#0d0a07;
  --pb-ring:#2c2517;
  --pb-rope:#d8cba0; --pb-rope-sh:#0a0805;
  --pb-line:#f3ecda; --pb-stud:#e8dcae;
  --pb-veil:#0a0a0a;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(200,168,75,.07), transparent 60%),
    var(--bg);
  color:var(--text);
  font-family:var(--condensed);
  font-weight:500;
  letter-spacing:.012em;
  font-size:18px;
  line-height:1.5;
  min-height:100dvh;
  -webkit-font-smoothing:antialiased;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── Cricket-ground background (boundary rope + 30-yard ring + pitch, like the website) ── */
.pitch-bg{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.pitch-bg svg{position:absolute;inset:0;width:100%;height:100%}
a{color:var(--gold-hi);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Layout shell ── */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px 88px}
.app-header{
  position:sticky;top:0;z-index:20;
  background:rgba(10,10,10,.78);
  backdrop-filter:saturate(150%) blur(12px);
  -webkit-backdrop-filter:saturate(150%) blur(12px);
  border-bottom:1px solid var(--line-soft);
}
.app-header .bar{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:13px 18px}

/* ── Wordmark (matched to spikelab.co.nz) ── */
.logo{
  font-family:var(--logo);font-weight:900;font-size:20px;letter-spacing:.04em;
  color:var(--text);text-decoration:none;display:inline-flex;align-items:center;
}
.logo .i-spike{display:inline-block;width:.40em;height:.84em;margin:0 .03em;vertical-align:-.05em;flex-shrink:0}
.logo-tm{align-self:flex-start;font-size:.48em;font-weight:700;letter-spacing:0;margin-left:1.5px;margin-top:.1em;color:var(--text-dim)}
.header-tag{font-family:var(--condensed);font-weight:600;font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);opacity:.85}
.admin-corner{background:none;border:0;cursor:pointer;font-family:var(--condensed);font-weight:600;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);padding:6px 4px;
  transition:color .15s}
.admin-corner:hover{color:var(--gold)}

/* ── Headings ── */
h1,h2,h3{font-family:var(--serif);font-weight:400;letter-spacing:.02em;line-height:1.02;margin:0}
h1{font-size:clamp(34px,9vw,52px)}
h2{font-size:clamp(26px,6.5vw,34px)}
h3{font-size:22px}
.eyebrow{font-family:var(--condensed);font-weight:700;font-size:13px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin:0 0 8px}
.lede{color:var(--text-mid);font-size:18px;font-weight:400;margin:10px 0 0}
.muted{color:var(--text-dim)}
.faint{color:var(--text-faint)}

/* ── Cards ── */
.card{
  background:linear-gradient(180deg,var(--bg-card),var(--bg-elev));
  border:1px solid var(--line-soft);
  border-radius:var(--radius);
  padding:20px;
  margin:14px 0;
}
.card.glow{border-color:var(--line);box-shadow:0 0 0 1px rgba(200,168,75,.05),0 18px 50px -28px rgba(0,0,0,.9);
  animation:cardin .45s cubic-bezier(.2,.7,.2,1) both}
@keyframes cardin{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}

/* ── Product badge ── */
.pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--condensed);font-weight:700;
  font-size:13px;letter-spacing:.14em;text-transform:uppercase;padding:5px 12px;border-radius:999px;
  border:1px solid var(--line)}
.pill .dot{width:8px;height:8px;border-radius:50%}
.pill.pins{color:var(--pins);border-color:rgba(127,176,214,.4)}
.pill.pins .dot{background:var(--pins)}
.pill.bolts{color:var(--bolts);border-color:rgba(214,143,90,.4)}
.pill.bolts .dot{background:var(--bolts)}

/* ── Stage tracker ── */
.tracker{display:flex;flex-direction:column;gap:10px;margin:8px 0}
.stage-row{
  display:flex;align-items:center;gap:14px;width:100%;text-align:left;
  background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--radius-sm);
  padding:15px 16px;color:var(--text);font-family:var(--condensed);font-size:18px;cursor:pointer;
  transition:border-color .15s,transform .08s,background .15s;
}
.stage-row:active{transform:scale(.992)}
.stage-row.next{border-color:var(--gold);background:linear-gradient(180deg,rgba(200,168,75,.08),var(--bg-card))}
.stage-row.done{cursor:default}
.stage-row.locked{opacity:.5;cursor:not-allowed}
.stage-row .ico{
  flex:none;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  border:1.5px solid var(--line);font-weight:700;font-size:15px;color:var(--text-dim);font-family:var(--condensed)
}
.stage-row.done .ico{background:var(--gold);border-color:var(--gold);color:var(--btn-ink)}
.stage-row.next .ico{border-color:var(--gold);color:var(--gold)}
.stage-row .meta{flex:1;min-width:0}
.stage-row .meta .t{font-weight:600;letter-spacing:.01em}
.stage-row .meta .s{font-size:13px;color:var(--text-dim);letter-spacing:.04em;text-transform:uppercase;font-weight:600}
.stage-row.done .meta .s{color:var(--good)}
.stage-row.next .meta .s{color:var(--gold)}
.stage-row .chev{flex:none;color:var(--text-faint);font-size:22px}

/* progress bar */
.progress{height:7px;background:var(--bg-card);border-radius:999px;overflow:hidden;border:1px solid var(--line-soft)}
.progress > i{display:block;height:100%;background:linear-gradient(90deg,var(--gold-lo),var(--gold-hi));border-radius:999px;transition:width .4s}
.progress-label{display:flex;justify-content:space-between;font-size:13px;color:var(--text-dim);
  text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:7px}

/* ── Questions ── */
.q{margin:0 0 22px;animation:rise .35s ease both}
.q:last-child{margin-bottom:4px}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.q-label{font-family:var(--condensed);font-weight:600;font-size:19px;line-height:1.3;margin:0 0 4px;color:var(--text)}
.q-label .req{color:var(--gold);margin-left:3px}
.q-help{font-size:14.5px;color:var(--text-dim);margin:0 0 12px;line-height:1.4}
.section-head{margin:26px 0 16px;padding-top:8px;border-top:1px solid var(--line-soft)}
.section-head:first-child{border-top:0;padding-top:0}
.section-head .eyebrow{margin-bottom:3px}
.section-head .sh-note{font-size:14.5px;color:var(--text-dim)}

/* rating 1-5 */
.scale{display:flex;gap:8px}
.scale.nps{flex-wrap:wrap;gap:7px}
.scale button{
  flex:1;min-width:0;aspect-ratio:1/1;border-radius:12px;border:1.5px solid var(--line-soft);
  background:var(--bg-card);color:var(--text-mid);font-family:var(--serif);font-size:22px;cursor:pointer;
  transition:all .12s;display:grid;place-items:center;
}
.scale.nps button{aspect-ratio:auto;padding:13px 0;font-size:18px;flex:0 0 calc(18.18% - 6px)}
.scale button:hover{border-color:var(--gold-lo)}
.scale button.sel{background:var(--gold);border-color:var(--gold);color:var(--btn-ink);transform:translateY(-2px)}
.scale-ends{display:flex;justify-content:space-between;font-size:13px;color:var(--text-faint);margin-top:7px;
  text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* choice / segmented */
.choices{display:flex;flex-direction:column;gap:9px}
.choices.inline{flex-direction:row;flex-wrap:wrap}
.choice{
  display:flex;align-items:center;gap:11px;padding:13px 15px;border-radius:12px;
  border:1.5px solid var(--line-soft);background:var(--bg-card);color:var(--text-mid);
  cursor:pointer;font-family:var(--condensed);font-size:17px;font-weight:500;transition:all .12s;
}
.choices.inline .choice{flex:1 1 auto}
.choice:hover{border-color:var(--gold-lo)}
.choice .mark{flex:none;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--text-faint);
  display:grid;place-items:center}
.choice.multi .mark{border-radius:6px}
.choice.sel{border-color:var(--gold);background:linear-gradient(180deg,rgba(200,168,75,.1),var(--bg-card));color:var(--text)}
.choice.sel .mark{border-color:var(--gold);background:var(--gold)}
.choice.sel .mark::after{content:"";width:9px;height:9px;border-radius:inherit;background:var(--btn-ink)}
.choice.multi.sel .mark{border-radius:6px}

/* text inputs */
.field{
  width:100%;background:var(--bg-card);border:1.5px solid var(--line-soft);border-radius:12px;
  color:var(--text);font-family:var(--condensed);font-size:17px;font-weight:500;padding:13px 15px;
  transition:border-color .12s;resize:vertical;
}
.field:focus{outline:none;border-color:var(--gold)}
textarea.field{min-height:92px;line-height:1.45}
.field::placeholder{color:var(--text-faint)}

/* conditional follow-up */
.followup{margin-top:11px;padding-left:14px;border-left:2px solid var(--line);animation:rise .25s ease both}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--condensed);font-weight:700;font-size:17px;letter-spacing:.06em;text-transform:uppercase;
  padding:15px 26px;border-radius:13px;border:1px solid transparent;cursor:pointer;transition:all .14s;
}
.btn-gold{background:linear-gradient(180deg,var(--gold-hi),var(--gold));color:var(--btn-ink);
  box-shadow:0 10px 30px -14px rgba(200,168,75,.7)}
.btn-gold:hover{filter:brightness(1.06)}
.btn-gold:disabled{opacity:.45;cursor:not-allowed;filter:none;box-shadow:none}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text-mid)}
.btn-ghost:hover{border-color:var(--gold-lo);color:var(--text)}
.btn-block{display:flex;width:100%}
.btn-row{display:flex;gap:11px;margin-top:8px}

/* sticky submit footer */
.sticky-foot{
  position:sticky;bottom:0;margin:18px -18px 0;padding:14px 18px calc(14px + env(safe-area-inset-bottom));
  background:linear-gradient(0deg,var(--bg) 60%,transparent);
}

/* ── States / confirmation ── */
.center{text-align:center}
.big-check{width:84px;height:84px;border-radius:50%;margin:6px auto 18px;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 35%,rgba(200,168,75,.22),transparent 70%);border:2px solid var(--gold)}
.big-check svg{width:42px;height:42px;stroke:var(--gold-hi);stroke-width:3;fill:none;
  stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:60;stroke-dashoffset:60;animation:draw .5s .15s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--gold);
  animation:spin .8s linear infinite;margin:30px auto}
@keyframes spin{to{transform:rotate(360deg)}}
.note{font-size:14px;color:var(--text-dim);background:var(--bg-card);border:1px solid var(--line-soft);
  border-radius:11px;padding:13px 15px;line-height:1.5}
.note.gold{border-color:var(--line);background:linear-gradient(180deg,rgba(200,168,75,.07),var(--bg-card))}
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:var(--bg-card-hi);
  border:1px solid var(--line);color:var(--text);padding:12px 20px;border-radius:999px;font-size:15px;
  box-shadow:0 14px 40px -16px #000;z-index:50;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.err{color:var(--bad)}

/* gift / ambassador blocks */
.reward{border:1px solid var(--line);border-radius:var(--radius);padding:18px;
  background:linear-gradient(180deg,rgba(200,168,75,.1),var(--bg-card));margin:14px 0}
.reward .ico{font-size:30px}

/* footer */
.foot{margin-top:34px;padding-top:18px;border-top:1px solid var(--line-soft);
  font-size:13px;color:var(--text-faint);text-align:center;letter-spacing:.04em}

/* ============================================================
   ADMIN DASHBOARD
   ============================================================ */
.admin-wrap{max-width:1100px;margin:0 auto;padding:0 18px 80px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin:16px 0}
.stat{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:var(--radius-sm);padding:16px}
.stat .n{font-family:var(--serif);font-size:38px;line-height:1;color:var(--gold-hi)}
.stat .l{font-size:12.5px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-top:6px}

.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:16px 0}
.toolbar .grow{flex:1;min-width:140px}
.seg{display:inline-flex;border:1px solid var(--line-soft);border-radius:10px;overflow:hidden}
.seg button{background:var(--bg-card);border:0;color:var(--text-dim);font-family:var(--condensed);font-weight:600;
  font-size:14px;padding:9px 14px;cursor:pointer;letter-spacing:.04em}
.seg button.on{background:var(--gold);color:var(--btn-ink)}

.legend{font-size:12.5px;color:var(--text-dim);letter-spacing:.02em;padding:4px 2px 10px}
.legend b{color:var(--gold);font-weight:700}
table.grid tr.rowclick{cursor:pointer}
.tbl-scroll{overflow-x:auto;border:1px solid var(--line-soft);border-radius:var(--radius-sm);background:var(--bg-card)}
table.grid{width:100%;border-collapse:collapse;font-size:15px;min-width:760px}
table.grid th,table.grid td{padding:11px 13px;text-align:left;border-bottom:1px solid var(--line-soft);white-space:nowrap}
table.grid th{font-family:var(--condensed);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-dim);background:var(--bg-elev);position:sticky;top:0}
table.grid tr:last-child td{border-bottom:0}
table.grid tr:hover td{background:var(--bg-card-hi)}
table.grid .name{font-weight:600;color:var(--text)}
.stage-dots{display:inline-flex;gap:5px}
.sd{width:20px;height:20px;border-radius:6px;display:grid;place-items:center;font-size:11px;font-weight:700;
  border:1px solid var(--line-soft);color:var(--text-faint);background:var(--bg-elev)}
.sd.done{background:var(--gold);border-color:var(--gold);color:var(--btn-ink)}
.tag{font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:999px;
  border:1px solid var(--line-soft);color:var(--text-dim)}
.tag.green{color:var(--good);border-color:rgba(95,174,107,.4)}
.tag.gold{color:var(--gold);border-color:var(--line)}
.tag.blue{color:var(--pins);border-color:rgba(127,176,214,.4)}
.tag.orange{color:var(--bolts);border-color:rgba(214,143,90,.4)}
.linkcell{display:inline-flex;align-items:center;gap:6px;cursor:pointer;color:var(--gold-hi)}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.66);backdrop-filter:blur(3px);z-index:60;
  display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal-bg.show{display:flex}
.modal{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);padding:24px;
  max-width:560px;width:100%;animation:rise .25s ease both}
.modal h2{margin-bottom:4px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label.fl{display:block;font-size:13px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;
  font-weight:600;margin:14px 0 6px}
select.field{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-dim) 50%),linear-gradient(135deg,var(--text-dim) 50%,transparent 50%);
  background-position:calc(100% - 18px) 21px,calc(100% - 13px) 21px;background-size:5px 5px;background-repeat:no-repeat}
.resp-block{border:1px solid var(--line-soft);border-radius:11px;padding:14px;margin:12px 0;background:var(--bg-card)}
.resp-block .qa{display:flex;justify-content:space-between;gap:14px;padding:6px 0;border-bottom:1px dashed var(--line-soft);font-size:15px}
.resp-block .qa:last-child{border-bottom:0}
.resp-block .qa .qq{color:var(--text-dim);flex:1}
.resp-block .qa .aa{color:var(--text);font-weight:600;text-align:right;max-width:55%}

@media(max-width:560px){
  .row2{grid-template-columns:1fr}
  body{font-size:17px}
}
