@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 — modern refresh
   Fresh community-sport feel: clean green, white floating cards,
   soft shadows, rounded pills, friendly bold type.
   ============================================================ */

:root{
  --green:#2fb074; --green-bright:#41c081; --green-deep:#239160; --green-tint:#eaf7f0;
  --ink:#151a21; --navy:#232c39; --navy-2:#2d3848;
  --paper:#f3f6f8; --surface:#ffffff;
  --muted:#647281; --muted-dark:#aeb9c6; --line:#e7ecf1;
  --orange:#f2994a; --blue:#3d82f4; --red:#e5574e;
  --shadow:0 16px 38px rgba(22,32,45,.08);
  --shadow-sm:0 6px 18px rgba(22,32,45,.06);
  --radius:20px; --radius-sm:14px; --max:1180px;
  --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{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;overflow-x:hidden;font-family:var(--body);color:var(--ink);
  background:var(--paper);line-height:1.6;letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
a{color:var(--green-deep);text-decoration:none;text-underline-offset:3px;transition:.18s ease}
a:hover{color:var(--green)}
img,svg,video{max-width:100%;height:auto}
.skip{position:absolute;left:-999px;top:10px;background:#fff;color:var(--ink);padding:10px;border-radius:10px;z-index:99}
.skip:focus{left:10px}

/* ---------- Typography ---------- */
h1,h2,h3{margin:0 0 .7rem;color:var(--ink);font-family:var(--display);line-height:1.18;letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,3.4vw,3.1rem);font-weight:700;max-width:18ch}
h2{font-size:clamp(1.5rem,2.4vw,2.1rem);font-weight:700;max-width:24ch}
h3{font-size:clamp(1.1rem,1.4vw,1.28rem);font-weight:600}
p{margin:0 0 1rem}
.lead{font-size:clamp(1.05rem,1.2vw,1.18rem);line-height:1.7;max-width:60ch;color:#3c4654}
.muted{color:var(--muted)}
.small{font-size:.92rem}
.eyebrow{display:inline-flex;gap:.6rem;align-items:center;text-transform:uppercase;letter-spacing:.13em;
  font-size:.72rem;font-weight:700;color:var(--green-deep);margin:0 0 .9rem}
.eyebrow:before{content:"";width:26px;height:3px;border-radius:999px;background:var(--green)}
.kicker{font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--green-deep);margin-bottom:.6rem}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.header-inner{max-width:var(--max);margin:0 auto;min-height:70px;padding:12px 24px;display:flex;align-items:center;
  justify-content:space-between;gap:18px;position:relative}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink);text-decoration:none;min-width:0}
.brand-mark{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--green-bright),var(--green-deep));color:#fff;font-weight:700;
  font-family:var(--display);box-shadow:0 8px 20px rgba(47,176,116,.32)}
.brand-text{display:flex;flex-direction:column;line-height:1.15;min-width:0}
.brand-title{font-family:var(--display);font-weight:600;letter-spacing:-.01em;white-space:nowrap}
.brand-sub{font-size:.76rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav{display:flex;align-items:center;gap:2px}
.nav a{padding:.55rem .8rem;font-size:.9rem;font-weight:500;color:#3f4a57;border-radius:999px;transition:.16s ease}
.nav a:hover{background:var(--green-tint);color:var(--green-deep)}
.nav a.active{background:var(--green-tint);color:var(--green-deep);font-weight:600}
.nav-toggle{display:none;flex:0 0 auto;background:var(--green);color:#fff;border:0;border-radius:999px;
  padding:.6rem .9rem;font-weight:600;font-family:var(--body);cursor:pointer}

/* ---------- Breadcrumb ---------- */
.breadcrumb{max-width:var(--max);margin:22px auto 0;padding:0 24px;color:var(--muted);font-size:.9rem}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--green-deep)}
main{min-width:0}

/* ---------- Hero (home) ---------- */
.hero{position:relative;overflow:hidden;max-width:var(--max);margin:28px auto 0;border-radius:30px;color:#fff;
  background:linear-gradient(140deg,#3bbd83 0%,#2fb074 46%,#23966a 100%);
  box-shadow:0 28px 60px rgba(35,150,106,.26);
  display:grid;grid-template-columns:minmax(0,1.5fr) minmax(290px,.9fr);gap:36px;align-items:center;padding:60px 48px}
.hero:before{content:"";position:absolute;right:-120px;bottom:-160px;width:380px;height:380px;border-radius:50%;
  background:rgba(255,255,255,.12)}
.hero:after{content:"";position:absolute;left:-90px;top:-120px;width:240px;height:240px;border-radius:50%;
  background:rgba(255,255,255,.08)}
.hero>*{position:relative;z-index:1}
.hero .eyebrow{color:#eafff5}
.hero .eyebrow:before{background:#fff}
.hero h1{color:#fff;font-weight:700;letter-spacing:-.015em;max-width:16ch}
.hero .lead{color:rgba(255,255,255,.94);max-width:46ch}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;overflow:hidden;max-width:var(--max);margin:26px auto 0;border-radius:26px;
  background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);padding:48px 44px;
  border-left:6px solid var(--green)}
.page-hero:before{content:"";position:absolute;right:-90px;top:-110px;width:280px;height:280px;border-radius:50%;
  background:var(--green-tint)}
.page-hero>*{position:relative;z-index:1}
.page-hero h1{color:var(--ink);max-width:20ch}
.page-hero .lead{color:#3c4654}

/* ---------- Hero panel / stats ---------- */
.hero-panel{align-self:start;background:#fff;border-radius:20px;padding:24px;box-shadow:0 20px 44px rgba(20,30,45,.22);color:var(--ink)}
.hero-panel h3{color:var(--ink)}
.hero-panel p{color:#3c4654}
.hero-panel ul{padding-left:0;margin:.8rem 0;list-style:none}
.hero-panel li{position:relative;margin:.65rem 0;padding-left:1.7rem;color:#36404c}
.hero-panel li:before{content:"";position:absolute;left:0;top:.36em;width:14px;height:14px;border-radius:50%;
  background:var(--green-tint);box-shadow:inset 0 0 0 2px var(--green)}
.stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:26px}
.stat{padding:18px;border-radius:16px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22)}
.stat b{display:block;font-family:var(--display);font-size:1.55rem;line-height:1;font-weight:700;color:#fff}
.stat span{font-size:.82rem;color:rgba(255,255,255,.9);font-weight:500}

/* ---------- Buttons ---------- */
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.3rem;border:0;
  border-radius:999px;font-family:var(--body);font-weight:600;font-size:.96rem;text-decoration:none;cursor:pointer;
  background:var(--green);color:#fff;box-shadow:0 12px 24px rgba(47,176,116,.28);transition:.18s ease}
.btn:hover{background:var(--green-deep);color:#fff;transform:translateY(-2px);box-shadow:0 18px 32px rgba(47,176,116,.34)}
.btn.secondary{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line),0 8px 20px rgba(20,30,45,.07)}
.btn.secondary:hover{background:var(--ink);color:#fff;box-shadow:0 12px 26px rgba(20,30,45,.2)}
.btn.light{background:#fff;color:var(--green-deep);box-shadow:0 10px 24px rgba(20,30,45,.16)}
.btn.light:hover{background:#f3fbf7;color:var(--green-deep)}
.hero .btn{background:#fff;color:var(--green-deep);box-shadow:0 12px 26px rgba(20,30,45,.18)}
.hero .btn:hover{background:var(--ink);color:#fff}
.hero .btn.secondary{background:rgba(255,255,255,.16);color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.4)}
.hero .btn.secondary:hover{background:#fff;color:var(--green-deep)}

/* ---------- Sections / bands ---------- */
.section{max-width:var(--max);margin:0 auto;padding:66px 24px}
.section.tight{padding-top:40px}
.border-top{border-top:1px solid var(--line)}
.band{background:linear-gradient(140deg,#2fb074,#23966a);color:#fff;margin:34px 0}
.band .section{padding-top:54px;padding-bottom:54px}
.band h2,.band h3{color:#fff}
.band p{color:rgba(255,255,255,.92)}
.band .muted{color:rgba(255,255,255,.8)}
.band .btn{background:#fff;color:var(--green-deep)}
.band .btn:hover{background:var(--ink);color:#fff}

/* ---------- Grid + cards ---------- */
.grid{display:grid;gap:22px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{min-width:0;position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm);transition:.2s ease}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#d7e6dd}
.card .number{display:inline-grid;place-items:center;width:42px;height:42px;margin-bottom:14px;border-radius:13px;
  font-family:var(--display);font-size:1.1rem;font-weight:700;color:#fff;background:linear-gradient(150deg,var(--green-bright),var(--green-deep))}
.card.compact{padding:18px}
.card.accent{background:linear-gradient(180deg,#fff,var(--green-tint));border-color:#d4ecdf}
.card.dark{background:linear-gradient(150deg,var(--navy),var(--navy-2));color:#fff;border-color:rgba(255,255,255,.1)}
.card.dark:hover{border-color:rgba(255,255,255,.2)}
.card.dark h2,.card.dark h3{color:#fff}
.card.dark p{color:#d3dbe5}
.card.dark a{color:#fff;text-decoration:underline}
.card.dark .muted{color:var(--muted-dark)}

/* ---------- Tables ---------- */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;min-width:700px}
th,td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
th{background:var(--navy);color:#fff;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
tbody tr:hover{background:var(--green-tint)}
tr:last-child td{border-bottom:0}

/* ---------- Forms / filters ---------- */
.filters{display:grid;grid-template-columns:1.3fr repeat(3,1fr);gap:12px;margin:22px 0}
input,select,textarea{width:100%;font:inherit;font-family:var(--body);color:var(--ink);background:#fff;
  border:1.5px solid var(--line);border-radius:12px;padding:.75rem .85rem;transition:.16s ease}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(47,176,116,.18)}
textarea{min-height:120px;resize:vertical}

/* ---------- Funders ---------- */
.funders{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.funders .card{padding:22px}

/* ---------- Notices ---------- */
.notice,.callout,.warning{border-radius:var(--radius);padding:20px 22px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm)}
.notice{border-left:5px solid var(--green)}
.warning{border-left:5px solid var(--orange);background:#fff8ef}
.callout{border-left:5px solid var(--blue);background:#f1f6ff}

/* ---------- Downloads / resources ---------- */
.download-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.download-item{display:flex;justify-content:space-between;gap:14px;align-items:center;min-width:0;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);transition:.18s ease}
.download-item strong{display:block;font-weight:600;color:var(--ink)}
.download-item span{min-width:0;color:var(--muted);font-size:.9rem}
.download-item:hover{transform:translateY(-2px);border-color:var(--green);box-shadow:var(--shadow)}
.resource-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.resource-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);
  padding:22px;display:flex;flex-direction:column;gap:12px;min-width:0;transition:.2s ease}
.resource-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#d7e6dd}
.resource-card h3{font-size:1.08rem;margin:0}
.resource-card p{margin:0;color:var(--muted);font-size:.92rem}
.resource-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:auto}
.resource-actions a{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.6rem .95rem;
  font-weight:600;font-size:.86rem;text-decoration:none;background:var(--green);color:#fff;transition:.16s ease}
.resource-actions a:hover{background:var(--green-deep);color:#fff}


/* Clickability hardening: keep resource buttons above card layers and make cards feel actionable. */
.resource-card{position:relative;cursor:pointer}
.resource-actions a,.download-item,.btn,.copy-btn,.nav-toggle,button{position:relative;z-index:2;pointer-events:auto}
.resource-card:focus-within,.resource-card:focus{outline:3px solid rgba(47,176,116,.25);outline-offset:3px}

/* ---------- Generated / template blocks ---------- */
.template-block,.generated{background:linear-gradient(150deg,var(--navy),var(--navy-2));color:#eef4fb;
  border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:22px;overflow:auto;box-shadow:var(--shadow-sm)}
.template-block pre,.generated{white-space:pre-wrap;margin:0;font-family:"SFMono-Regular",Consolas,monospace;font-size:.9rem}
.copy-row{display:flex;justify-content:space-between;gap:12px;align-items:center;margin:.8rem 0}
.copy-btn{background:var(--green);color:#fff;border:0;border-radius:999px;font-weight:600;padding:.6rem .9rem;cursor:pointer;font-family:var(--body)}
.copy-btn:hover{background:var(--green-deep)}

/* ---------- Calculator ---------- */
.calculator{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.calc-results{background:linear-gradient(150deg,var(--navy),var(--navy-2));color:#fff;padding:26px;
  border-radius:var(--radius);display:grid;gap:14px;box-shadow:var(--shadow)}
.calc-results h2,.calc-results h3{color:#fff}
.result-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.15);padding-bottom:10px}
.result-row strong{font-family:var(--display);font-size:1.2rem;color:var(--green-bright);font-weight:700}
.progress{height:14px;background:rgba(255,255,255,.18);border-radius:999px;overflow:hidden}
.progress>div{height:100%;background:linear-gradient(90deg,var(--green-bright),var(--green));width:0%;transition:width .4s ease}

/* ---------- Checklist / steps ---------- */
.checklist{list-style:none;padding:0;margin:0}
.checklist li{display:grid;grid-template-columns:26px 1fr;gap:10px;align-items:start;margin:.7rem 0}
.checklist li:before{content:"";width:20px;height:20px;margin-top:2px;border-radius:6px;background:var(--green-tint);
  box-shadow:inset 0 0 0 2px var(--green)}
.step-list{counter-reset:steps;list-style:none;padding:0}
.step-list li{counter-increment:steps;position:relative;border:1px solid var(--line);border-radius:var(--radius);
  background:#fff;padding:18px 20px 18px 64px;margin:14px 0;box-shadow:var(--shadow-sm)}
.step-list li:before{content:counter(steps);position:absolute;left:18px;top:18px;display:inline-grid;place-items:center;
  width:34px;height:34px;background:linear-gradient(150deg,var(--green-bright),var(--green-deep));color:#fff;
  font-family:var(--display);font-weight:700;border-radius:11px}

/* ---------- Tool panels ---------- */
.tool-panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:26px;margin-top:20px}
.tool-panel label{display:block;font-weight:600;margin-bottom:14px;color:var(--ink)}
.tool-panel input,.tool-panel select,.tool-panel textarea{margin-top:6px}
.result-box{border:1px solid #cdeadd;background:var(--green-tint);padding:22px;margin-top:18px;border-radius:var(--radius)}
.score-meter{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}
.score-number{font-family:var(--display);font-size:2rem;font-weight:700;color:var(--green-deep)}

/* ---------- Pills / regions / misc ---------- */
.pill-list{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:12px 0;list-style:none}
.pill-list li{padding:.38rem .7rem;background:var(--green-tint);color:var(--green-deep);font-size:.82rem;font-weight:600;border-radius:999px}
.region-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
.region-card details{border-top:1px solid var(--line);padding-top:10px}
.region-card summary{cursor:pointer;font-weight:600;color:var(--ink)}
.mini-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.seo-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.sample{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.page-links{display:flex;flex-wrap:wrap;gap:10px}
.page-links a{border:1px solid var(--line);border-radius:999px;padding:.55rem .9rem;background:#fff;font-weight:600;box-shadow:var(--shadow-sm);transition:.16s ease}
.page-links a:hover{background:var(--green);color:#fff;border-color:var(--green)}
.source-list{columns:2;gap:30px}
.source-list li{break-inside:avoid;margin:.45rem 0}
.empty-state{padding:22px;border:1.5px dashed #c2d2cb;border-radius:var(--radius);background:#fff;color:var(--muted)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#cdd6e1;margin-top:54px}
.footer-inner{max-width:var(--max);margin:0 auto;padding:48px 24px;display:grid;grid-template-columns:1.2fr .8fr;gap:34px}
.site-footer h2{font-family:var(--display);font-size:1.35rem;color:#fff;margin-bottom:.6rem}
.site-footer p{color:#c3cdd9}
.site-footer a{color:#fff}
.site-footer a:hover{color:var(--green-bright)}
.site-footer strong{font-weight:600;color:#fff}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filters{grid-template-columns:1fr 1fr}
  .hero{grid-template-columns:1fr}
}
@media (max-width:860px){
  .hero,.page-hero{width:calc(100% - 24px);margin:14px auto 0;border-radius:22px;padding:34px 22px}
  .hero{gap:22px}
  .stats{grid-template-columns:1fr 1fr 1fr;gap:8px}
  .stat{padding:12px}
  .actions{flex-direction:column}
  .btn{width:100%}
  .grid.two,.grid.three,.funders,.calculator,.footer-inner,.region-grid,.mini-form,.seo-list,.resource-list,.download-list{grid-template-columns:1fr}
  .filters{grid-template-columns:1fr}
  .source-list{columns:1}
  .nav-toggle{display:inline-flex}
  .nav{display:none;position:absolute;left:0;right:0;top:70px;background:#fff;border-bottom:1px solid var(--line);
    box-shadow:0 18px 30px rgba(20,30,45,.1);padding:12px 18px;flex-direction:column;align-items:stretch;gap:4px}
  .nav.open{display:flex}
  .nav a{border-radius:10px;padding:.7rem .8rem}
  .header-inner{padding:12px 16px}
  .section{padding:50px 18px}
  .brand-sub{display:none}
}
@media (max-width:520px){
  .brand-mark{width:40px;height:40px}
  .brand-title{font-size:.98rem}
  .stats{grid-template-columns:1fr}
  .footer-inner{padding:38px 18px}
  .resource-actions a{width:100%}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}

@media print{
  .site-header,.site-footer,.breadcrumb,.nav-toggle,.actions{display:none}
  body{background:#fff}
  .hero,.page-hero,.section{box-shadow:none;max-width:none;margin:0;border-radius:0;color:var(--ink);background:#fff}
  .hero h1,.hero .lead{color:var(--ink)}
  .section{padding:24px 0}
  .card,.notice,.callout,.warning,.tool-panel,.resource-card{box-shadow:none}
}
