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

/* ============================================================
   NZ Club Fundraising — fillable form / template pages
   Clean modern document editor. Per-form accent via --doc-accent.
   ============================================================ */

:root{
  --ink:#151a21; --navy:#232c39; --paper:#f3f6f8; --surface:#fff;
  --muted:#647281; --line:#e7ecf1;
  --doc-accent:#2fb074; --doc-soft:#eaf7f0;
  --shadow:0 16px 38px rgba(22,32,45,.08); --shadow-sm:0 6px 18px rgba(22,32,45,.06);
  --radius:18px; --radius-sm:12px;
  --display:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{overflow-x:hidden}
body{margin:0;overflow-x:hidden;font-family:var(--body);color:var(--ink);
  background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
.page{max-width:940px;margin:0 auto;padding:28px 20px 64px}

/* ---------- Topbar ---------- */
.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px}
.brand{display:flex;gap:10px;align-items:center;font-family:var(--display);font-weight:600}
.mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(150deg,var(--doc-accent),color-mix(in srgb,var(--doc-accent) 60%,#000));
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:.86rem}
.back{color:var(--muted);font-size:.9rem;text-decoration:none}
.back:hover{color:var(--doc-accent)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--line);
  border-left:6px solid var(--doc-accent);border-radius:var(--radius);padding:30px 30px;box-shadow:var(--shadow-sm)}
.hero:after{content:"";position:absolute;right:-70px;top:-90px;width:220px;height:220px;border-radius:50%;
  background:var(--doc-soft)}
.hero>*{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;text-transform:uppercase;letter-spacing:.12em;
  color:color-mix(in srgb,var(--doc-accent) 78%,#000);font-size:.72rem;font-weight:700;margin:0 0 .7rem}
.eyebrow:before{content:"";width:24px;height:3px;border-radius:999px;background:var(--doc-accent)}
.hero h1{position:relative;z-index:1;font-family:var(--display);font-size:clamp(1.7rem,3vw,2.3rem);font-weight:700;
  letter-spacing:-.01em;line-height:1.2;margin:0 0 .55rem;color:var(--ink)}
.hero p{position:relative;z-index:1;color:#3c4654;max-width:60ch;margin:0}

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

/* ---------- Toolbar (JS-injected) ---------- */
.form-toolbar{display:flex;justify-content:space-between;gap:14px;align-items:center;background:#fff;
  border:1px solid var(--line);border-radius:16px;padding:14px 16px;margin:0 0 18px;box-shadow:var(--shadow-sm)}
.toolbar-left,.toolbar-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.toolbar-note{margin:0;color:var(--muted);font-size:.86rem}
.logo-preview{width:92px;height:56px;border:1.5px dashed #c2cdd9;border-radius:12px;display:grid;place-items:center;
  background:#f8fafc;overflow:hidden;color:var(--muted);font-size:.74rem;text-align:center}
.logo-preview img{max-width:100%;max-height:100%;object-fit:contain;display:none}
button,.logo-upload{border:0;border-radius:999px;padding:.66rem .95rem;background:var(--ink);color:#fff;
  font:inherit;font-family:var(--body);font-weight:600;cursor:pointer;transition:.16s ease}
button:hover,.logo-upload:hover{filter:brightness(1.08)}
.ghost-btn{background:#eef2f6!important;color:var(--ink)!important}
.ghost-btn:hover{background:#e3e9ef!important}
.logo-upload input{display:none}
.toolbar-actions button:first-child,.profile-actions button:first-child{background:var(--doc-accent);color:#fff}
.toolbar-actions button:last-child,.profile-actions button:last-child{background:#eef2f6;color:var(--ink)}

/* ---------- Profile panel ---------- */
.profile-panel{display:none;background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;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}
.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-size:.7rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--muted)}
.profile-grid input,.profile-grid textarea{width:100%;border:1.5px solid #d4dde6;border-radius:10px;padding:.66rem .72rem;
  font:inherit;font-family:var(--body);text-transform:none;letter-spacing:0;color:var(--ink);background:#fbfdff;transition:.16s ease}
.profile-grid input:focus,.profile-grid textarea:focus{outline:0;border-color:var(--doc-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--doc-accent) 22%,transparent)}
.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:600}
.print-brand span{color:var(--muted);font-size:.9rem}

/* ---------- Sections ---------- */
.section{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin:16px 0;box-shadow:var(--shadow-sm)}
h2{font-family:var(--display);font-size:1.25rem;font-weight:700;margin:0 0 12px;color:var(--ink);letter-spacing:-.005em}
.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 #c2cdd9;border-radius:12px;min-height:46px;padding:10px 14px;background:#fbfdff;margin:8px 0;transition:.16s ease}
.field:focus-within{border-style:solid;border-color:var(--doc-accent);background:#fff;box-shadow:0 0 0 3px color-mix(in srgb,var(--doc-accent) 16%,transparent)}
.field label{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700;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}

/* ---------- 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}
th{background:var(--doc-accent);color:#fff;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
td[contenteditable="true"]{min-height:20px}
td[contenteditable="true"]:focus{outline:2px solid color-mix(in srgb,var(--doc-accent) 45%,transparent);outline-offset:-1px}

/* ---------- Editable content areas ---------- */
.content[contenteditable="true"],.raw[contenteditable="true"]{min-height:24px;border-radius:10px;transition:.16s ease}
.content[contenteditable="true"]:focus,.raw[contenteditable="true"]:focus{outline:2px solid color-mix(in srgb,var(--doc-accent) 42%,transparent);outline-offset:3px}
.content h1,.content h2,.content h3{font-family:var(--display);letter-spacing:-.005em;font-weight:600}
.content h1{font-size:1.45rem}
.content h2{font-size:1.2rem;border-bottom:1px solid var(--line);padding-bottom:8px}
.content h3{font-size:1.02rem}
.content ul{padding-left:1.2rem}
.raw{white-space:pre-wrap;background:#f6f9fc;border:1px solid var(--line);border-radius:12px;padding:14px;overflow:auto}

/* ---------- Note ---------- */
.note{background:var(--doc-soft);border-left:5px solid var(--doc-accent);padding:14px 16px;border-radius:12px;color:#28333f}

/* ---------- 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-left:0!important;border-radius:0!important;
  border-bottom:2px solid var(--doc-accent);padding:18px 0 12px!important;margin:0 0 14px!important}
.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:#232c39!important;color:#fff!important}
.pdf-export th,.pdf-export td{font-size:10.5px;padding:6px}
.pdf-export .note{background:#fff;border-left:3px solid var(--doc-accent);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 46px}
  .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}}

@media print{
  body{background:#fff}
  .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 #e5e7eb}
  .hero{border-radius:0;border-left:4px solid var(--doc-accent)}
  .field{min-height:40px}
  .field input{color:#000}
  .note{background:#fff}
}
