@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ============================================================
   NZ Club Fundraising — fillable form / template pages (2026)
   Document-editor surface matched to the polished site system.
   ============================================================ */

:root{
  --paper:#fafaf7;
  --paper-2:#ffffff;
  --surface:#ffffff;
  --shade:#f1efe8;

  --ink:#0b0d10;
  --ink-2:#1a1d22;
  --muted:#5b626d;
  --muted-2:#8a8f99;
  --line:rgba(11,13,16,.10);
  --line-strong:rgba(11,13,16,.16);

  --accent:#2546f0;
  --accent-2:#3a5dff;
  --accent-soft:color-mix(in srgb, #2546f0 12%, transparent);
  --accent-tint:color-mix(in srgb, #2546f0 6%, #fafaf7);

  --doc-accent:var(--accent);
  --doc-soft:var(--accent-tint);

  --shadow-xs:0 1px 2px rgba(11,13,16,.04);
  --shadow-sm:0 4px 14px rgba(11,13,16,.05);
  --shadow:0 12px 30px rgba(11,13,16,.06), 0 2px 6px rgba(11,13,16,.04);

  --radius:12px;
  --radius-sm:8px;

  --display:'Inter',ui-sans-serif,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --body:'Inter',ui-sans-serif,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}

@media (prefers-color-scheme: dark){
  :root{
    --paper:#0b0d10;
    --paper-2:#111418;
    --surface:#14181d;
    --shade:#1a1f25;
    --ink:#f5f5f2;
    --ink-2:#e6e7e3;
    --muted:#9aa2ad;
    --muted-2:#6b7280;
    --line:rgba(245,245,242,.10);
    --line-strong:rgba(245,245,242,.18);
    --accent:#7f96ff;
    --accent-2:#a3b5ff;
    --accent-soft:color-mix(in srgb, #7f96ff 18%, transparent);
    --accent-tint:color-mix(in srgb, #7f96ff 8%, #14181d);
    --doc-accent:var(--accent);
    --doc-soft:var(--accent-tint);
  }
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  font-size:16px;line-height:1.55;letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  padding-bottom:env(safe-area-inset-bottom)}
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
img{max-width:100%;display:block}
.page{max-width:960px;margin:0 auto;padding:28px 20px 80px}

/* ---------- Topbar ---------- */
.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:20px}
.brand{display:flex;gap:10px;align-items:center;font-family:var(--display);font-weight:700;color:var(--ink);text-decoration:none}
.mark{width:36px;height:36px;border-radius:10px;background:var(--ink);color:var(--paper);
  display:grid;place-items:center;font-weight:800;font-size:.78rem;letter-spacing:-.02em}
.back{color:var(--muted);font-size:.88rem;text-decoration:none;font-family:var(--mono);letter-spacing:.02em}
.back:hover{color:var(--accent)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:30px 32px;box-shadow:var(--shadow-sm)}
.hero:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);border-radius:4px 0 0 4px}
.hero:after{content:"";position:absolute;right:-100px;top:-120px;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(closest-side, var(--accent-soft), transparent 70%);pointer-events:none}
.hero>*{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--muted);font-family:var(--mono);font-size:.7rem;font-weight:600;margin:0 0 .8rem}
.eyebrow:before{content:"";width:22px;height:1px;background:var(--ink);display:block;opacity:.5}
.hero h1{font-family:var(--display);font-size:clamp(1.7rem,2.8vw,2.25rem);font-weight:800;
  letter-spacing:-.035em;line-height:1.1;margin:0 0 .55rem;color:var(--ink)}
.hero p{color:var(--muted);max-width:62ch;margin:0}

/* ---------- Meta strip ---------- */
.meta{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0}
.meta div{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 16px;box-shadow:var(--shadow-xs);font-size:.92rem}
.meta strong{display:block;font-family:var(--mono);font-size:.66rem;text-transform:uppercase;
  letter-spacing:.08em;color:var(--muted);margin-bottom:5px;font-weight:600}

/* ---------- Toolbar (JS-injected) ---------- */
.form-toolbar{display:flex;justify-content:space-between;gap:14px;align-items:center;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin:18px 0;box-shadow:var(--shadow-xs)}
.toolbar-left,.toolbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.toolbar-note{margin:0;color:var(--muted);font-size:.86rem}
.logo-preview{width:88px;height:54px;border:1.5px dashed var(--line-strong);border-radius:8px;
  display:grid;place-items:center;background:var(--shade);overflow:hidden;color:var(--muted);
  font-family:var(--mono);font-size:.7rem;text-align:center}
.logo-preview img{max-width:100%;max-height:100%;object-fit:contain;display:none}
button,.logo-upload{border:1px solid var(--ink);border-radius:8px;padding:.6rem .95rem;
  background:var(--ink);color:var(--paper);font:inherit;font-family:var(--body);font-weight:600;
  font-size:.88rem;cursor:pointer;transition:.15s ease;min-height:40px}
button:hover,.logo-upload:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px)}
.ghost-btn{background:transparent!important;color:var(--ink)!important;border:1px solid var(--line-strong)!important}
.ghost-btn:hover{background:var(--ink)!important;color:var(--paper)!important;border-color:var(--ink)!important}
.logo-upload input{display:none}
.toolbar-actions button:first-child,.profile-actions button:first-child{background:var(--accent);border-color:var(--accent);color:#fff}
.toolbar-actions button:first-child:hover,.profile-actions button:first-child:hover{background:var(--ink);border-color:var(--ink)}
.toolbar-actions button:last-child,.profile-actions button:last-child{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
.toolbar-actions button:last-child:hover,.profile-actions button:last-child:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---------- Profile panel ---------- */
.profile-panel{display:none;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;margin:0 0 18px;box-shadow:var(--shadow)}
.profile-panel.open{display:block}
.profile-head h2{margin:0 0 4px;font-family:var(--display);font-size:1.15rem;font-weight:700;letter-spacing:-.02em}
.profile-head p{margin:0 0 14px;color:var(--muted)}
.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.profile-grid label{display:flex;flex-direction:column;gap:5px;font-family:var(--mono);font-size:.68rem;
  text-transform:uppercase;letter-spacing:.06em;font-weight:600;color:var(--muted)}
.profile-grid input,.profile-grid textarea{width:100%;border:1px solid var(--line-strong);border-radius:8px;
  padding:.6rem .72rem;font:inherit;font-family:var(--body);text-transform:none;letter-spacing:0;color:var(--ink);
  background:var(--surface);transition:.15s ease;min-height:38px}
.profile-grid input:focus,.profile-grid textarea:focus{outline:0;border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft)}
.profile-grid textarea{min-height:72px;resize:vertical}
.profile-grid .wide{grid-column:1/-1}
.profile-actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}

/* ---------- Print brand (screen hidden until print) ---------- */
.print-brand{display:none;align-items:center;gap:14px;margin:0 0 18px}
.print-brand img{width:80px;max-height:56px;object-fit:contain;display:none}
.print-brand strong{display:block;font-size:1.1rem;font-weight:700;color:var(--ink)}
.print-brand span{color:var(--muted);font-size:.9rem}

/* ---------- Sections ---------- */
.section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;margin:16px 0;box-shadow:var(--shadow-xs)}
h2{font-family:var(--display);font-size:1.22rem;font-weight:700;margin:0 0 14px;
  color:var(--ink);letter-spacing:-.022em}
.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.three{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}

/* ---------- Fillable fields ---------- */
.field{border:1.5px dashed var(--line-strong);border-radius:10px;min-height:46px;
  padding:10px 14px;background:var(--shade);margin:8px 0;transition:.15s ease}
.field:hover{border-color:var(--muted-2);background:var(--surface)}
.field:focus-within{border-style:solid;border-color:var(--accent);background:var(--surface);
  box-shadow:0 0 0 3px var(--accent-soft)}
.field label{display:block;font-family:var(--mono);font-size:.66rem;text-transform:uppercase;
  letter-spacing:.07em;color:var(--muted);font-weight:600;margin-bottom:5px}
.field input{width:100%;border:0;background:transparent;font:inherit;font-family:var(--body);
  color:var(--ink);padding:3px 0;outline:0;font-size:.96rem}
.field input::placeholder{color:var(--muted-2)}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;margin-top:8px}
th,td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top;font-size:.92rem}
th{background:var(--shade);color:var(--ink);font-family:var(--mono);font-size:.68rem;
  text-transform:uppercase;letter-spacing:.05em;font-weight:600}
td[contenteditable="true"]{min-height:20px}
td[contenteditable="true"]:focus{outline:2px solid var(--accent);outline-offset:-1px;background:var(--accent-tint)}

/* ---------- Editable content areas ---------- */
.content[contenteditable="true"],.raw[contenteditable="true"]{min-height:24px;border-radius:8px;
  transition:.15s ease;padding:6px}
.content[contenteditable="true"]:focus,.raw[contenteditable="true"]:focus{outline:2px solid var(--accent);outline-offset:3px;background:var(--accent-tint)}
.content h1,.content h2,.content h3{font-family:var(--display);letter-spacing:-.025em;font-weight:700;color:var(--ink)}
.content h1{font-size:1.45rem;margin:0 0 .6rem}
.content h2{font-size:1.18rem;border-bottom:1px solid var(--line);padding-bottom:8px;margin:1rem 0 .6rem}
.content h3{font-size:1.02rem;margin:.8rem 0 .4rem}
.content ul{padding-left:1.2rem;color:var(--ink-2)}
.content p{color:var(--ink-2)}
.raw{white-space:pre-wrap;background:var(--shade);border:1px solid var(--line);border-radius:10px;
  padding:14px;overflow:auto;font-family:var(--mono);font-size:.88rem;color:var(--ink)}

/* ---------- Note ---------- */
.note{background:var(--accent-tint);border-left:4px solid var(--accent);
  padding:14px 16px;border-radius:10px;color:var(--ink-2);font-size:.94rem}

/* ---------- PDF export (off-screen render target) ---------- */
.pdf-export{position:fixed;left:-99999px;top:0;width:794px;background:#fff;color:#111;
  font-family:Arial,Helvetica,sans-serif;line-height:1.45;letter-spacing:0;padding:0}
.pdf-export .page{max-width:none;margin:0;padding:0}
.pdf-export .topbar,.pdf-export .form-toolbar,.pdf-export .profile-panel,.pdf-export .back,.pdf-export .eyebrow,
.pdf-export .meta,.pdf-export .print-brand,.pdf-export .content-section>h2{display:none!important}
.pdf-export .hero{background:#fff!important;color:#111!important;border:0!important;
  border-bottom:2px solid #2546f0;padding:18px 0 12px!important;margin:0 0 14px!important}
.pdf-export .hero:before,.pdf-export .hero:after{display:none!important}
.pdf-export .hero h1{font-size:22px!important;line-height:1.2!important;margin:0 0 4px!important;color:#111!important;font-weight:700!important}
.pdf-export .hero p{color:#334155!important;margin:0!important}
.pdf-export .section{background:#fff!important;border:0!important;border-radius:0!important;
  box-shadow:none!important;padding:8px 0 12px!important;margin:0 0 12px!important;break-inside:avoid}
.pdf-export h2{font-size:16px!important;font-weight:700!important;margin:0 0 8px!important;color:#111!important}
.pdf-export .field{border:1px solid #cfd8e3;background:#fff;border-radius:0;min-height:auto;margin:4px 0;padding:7px}
.pdf-export .field label{font-size:9px;color:#5b6777}
.pdf-export .pdf-value{min-height:18px;white-space:pre-wrap}
.pdf-export th{background:#0b0d10!important;color:#fff!important}
.pdf-export th,.pdf-export td{font-size:10.5px;padding:6px;border:1px solid #cfd8e3}
.pdf-export .note{background:#fff;border-left:3px solid #2546f0;font-size:11px}
.pdf-letterhead{border-bottom:1px solid #cfd8e3;margin-bottom:18px;padding-bottom:14px}
.pdf-brand-row{display:flex;gap:18px;align-items:flex-start}
.pdf-logo-box{width:95px;height:75px;border:1px solid #cfd8e3;display:grid;place-items:center;color:#64748b;font-size:11px}
.pdf-logo-box img{max-width:90px;max-height:70px;object-fit:contain}
.pdf-club-block h1{font-size:24px;line-height:1.15;margin:0 0 5px;font-weight:700;color:#111}
.pdf-club-block p{margin:0 0 2px;color:#334155;font-size:11.5px;white-space:pre-wrap}
.pdf-letter-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;margin-top:14px}
.pdf-letter-grid div{border-top:1px solid #e2e8f0;padding-top:6px}
.pdf-letter-grid strong{display:block;font-size:9px;color:#64748b;text-transform:uppercase;letter-spacing:.08em}
.pdf-letter-grid span{display:block;white-space:pre-wrap;font-size:11.5px}

/* ---------- Responsive ---------- */
@media(max-width:720px){
  .meta,.two,.three,.profile-grid{grid-template-columns:1fr}
  .hero{padding:24px 20px}
  .page{padding:18px 14px 60px}
  .form-toolbar{flex-direction:column;align-items:stretch}
  .toolbar-actions button,.logo-upload,.ghost-btn{width:100%}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

@media print{
  body{background:#fff;color:#000}
  .page{max-width:none;padding:0}
  .topbar,.form-toolbar,.profile-panel,.back,.eyebrow,.meta,.content-section>h2{display:none!important}
  .print-brand{display:flex}
  .section,.hero{box-shadow:none;break-inside:avoid;border:1px solid #d4dde6}
  .hero{border-radius:0;border-left:4px solid #2546f0;background:#fff;color:#000}
  .hero h1{color:#000}
  .hero p{color:#334155}
  .field{min-height:40px;background:#fff;border:1px solid #d4dde6}
  .field input{color:#000}
  .note{background:#fff;color:#000;border-left:3px solid #2546f0}
  th{background:#0b0d10;color:#fff}
}
