:root{
  /* Paleta z logo: granat #2C4A7C, stalowy szary #9AA4B0, akcent czerwony #D9342B */
  --ink: #1f3559;        /* główny granat (ciemniejszy niż logo dla kontrastu) */
  --ink-2: #2c4a7c;      /* granat z logo */
  --ink-3: #5b6b85;      /* stonowany */
  --paper: #fafaf9;
  --paper-2: #f1f2f4;
  --paper-3: #e3e6ec;
  --rule: rgba(44,74,124,.14);
  --rule-2: rgba(44,74,124,.07);
  --gold: #D9342B;       /* czerwony akcent z logo (zmienna nazywa się 'gold' historycznie) */
  --gold-deep: #b22820;  /* głębszy czerwony do hover/tekstu */
  --steel: #9AA4B0;      /* szary z słupków */
  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;
  --dens: 1;            /* density multiplier */
  --measure: 62ch;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:hidden;max-width:100%}
body{
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01","kern";
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

::selection{ background: var(--gold); color: var(--paper); }

.brand-logo{ height: 40px; width: auto; display:block; }
.footer .brand-logo{ filter: brightness(0) invert(1); height: 36px; opacity: .92; }

/* Layout */
.wrap{ max-width: 1280px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 720px){ .wrap{ padding: 0 20px; } }

.section{ padding: calc(120px * var(--dens)) 0; position:relative; }
.section--tight{ padding: calc(72px * var(--dens)) 0; }
.section--alt{ background: var(--paper-2); }
.section--ink{ background: var(--ink); color: var(--paper); }

.eyebrow{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin: 0 0 24px;
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{
  content:""; display:inline-block; width:24px; height:1px; background: var(--gold);
}
.section--ink .eyebrow{ color: var(--gold); }
.section--ink .eyebrow::before{ background: var(--gold); }

h1,h2,h3,h4{ font-family: var(--serif); font-weight: 500; letter-spacing: -.01em; margin:0; }
.h-display{ font-size: clamp(48px, 6.4vw, 92px); line-height: 1.02; letter-spacing: -.02em; font-weight: 500; }
.h-section{ font-size: clamp(36px, 4.4vw, 60px); line-height: 1.06; letter-spacing: -.015em; font-weight: 500; }
.h-card{ font-size: 24px; line-height: 1.18; font-weight: 600; }
em.italic{ font-style: italic; color: var(--gold-deep); font-weight: 500; }

p.lead{ font-size: 19px; line-height: 1.55; color: var(--ink-2); max-width: var(--measure); }
p{ margin: 0 0 1em; max-width: var(--measure); color: var(--ink-2); }

.hairline{ height:1px; background: var(--rule); border:0; margin: 0; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  height: 48px; padding: 0 22px;
  border-radius: 999px;
  font-weight: 500; font-size: 14px; letter-spacing: .01em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  white-space: nowrap;
}
.btn .arrow{
  display:inline-block; width:14px; height:14px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round' d='M5 12h14M13 6l6 6-6 6'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round' d='M5 12h14M13 6l6 6-6 6'/></svg>") center/contain no-repeat;
  transition: transform .2s ease;
}
.btn:hover .arrow{ transform: translateX(3px); }
.btn--primary{ background: var(--ink); color: var(--paper); }
.btn--primary:hover{ background: var(--ink-2); }
.btn--gold{ background: var(--ink-2); color: var(--paper); position:relative; padding-right: 26px; }
.btn--gold::after{ content:""; position:absolute; left: 22px; right: 36px; bottom: 12px; height: 1px; background: var(--gold); transition: right .2s ease; }
.btn--gold:hover{ background: var(--ink); }
.btn--gold:hover::after{ right: 22px; }
.btn--ghost{ background: transparent; color: var(--ink); border-color: var(--rule); }
.btn--ghost:hover{ border-color: var(--ink); }
.section--ink .btn--ghost{ color: var(--paper); border-color: rgba(255,255,255,.2); }
.section--ink .btn--ghost:hover{ border-color: var(--paper); }

/* Nav */
.nav{
  position: sticky; top: 0; z-index: 100;
  background: rgba(250,250,247,.78);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
          backdrop-filter: blur(18px) saturate(140%);
  border-bottom: 1px solid var(--rule-2);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  height: 76px;
}
.brand{ display:flex; align-items:center; gap:14px; }
.brand-mark{
  width:38px; height:38px; flex:0 0 38px;
  display:grid; place-items:center;
  border:1px solid var(--ink); border-radius: 2px;
  background: var(--ink); color: var(--paper);
}
.brand-mark svg{ width: 22px; height: 22px; }
.brand-text{ display:flex; flex-direction:column; line-height: 1.1; }
.brand-text b{ font-family: var(--serif); font-size: 18px; font-weight: 600; letter-spacing: -.005em; }
.brand-text span{ font-family: var(--mono); font-size: 10px; letter-spacing: .14em; color: var(--ink-3); text-transform: uppercase; }

.nav-links{ display:flex; align-items:center; gap: 4px; }
.nav-links a{
  padding: 8px 14px; font-size: 14px; color: var(--ink-2); border-radius: 999px;
  transition: background .15s, color .15s;
}
.nav-links a:hover{ background: var(--paper-2); color: var(--ink); }
.nav-links a.active{ color: var(--ink); }
.nav-cta{ display:flex; align-items:center; gap: 12px; }

@media (max-width: 960px){
  .nav-links{ display:none; }
}

/* Hero */
.hero{
  padding: clamp(80px, 12vh, 140px) 0 clamp(60px, 8vh, 100px);
  position: relative; overflow: hidden;
}
.hero-grid{
  display:grid; grid-template-columns: 1.3fr 1fr; gap: 80px; align-items: end;
}
.hero-meta{
  display:flex; gap: 28px; align-items:center;
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform:uppercase;
  color: var(--ink-3); margin-bottom: 40px;
}
.hero-meta .dot{ width:6px; height:6px; border-radius:50%; background: var(--gold); }
.hero h1{ margin-bottom: 36px; }
.hero h1 .accent{
  font-style: italic; color: var(--gold-deep); font-weight: 500;
  position: relative;
}
.hero-actions{ display:flex; gap: 14px; margin-top: 40px; flex-wrap:wrap; }
.hero-side{
  border-left: 1px solid var(--rule);
  padding-left: 40px;
  padding-bottom: 12px;
}
.hero-stats{ display:flex; flex-direction:column; gap: 28px; }
.hero-stat{ }
.hero-stat .num{
  font-family: var(--serif); font-size: 56px; line-height: 1; font-weight: 500;
  letter-spacing: -.02em;
}
.hero-stat .num small{ font-size: 22px; color: var(--gold-deep); margin-left: 2px; }
.hero-stat .lbl{
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform:uppercase;
  color: var(--ink-3); margin-top: 8px;
}

@media (max-width: 900px){
  .hero-grid{ grid-template-columns: 1fr; gap: 56px; }
  .hero-side{ border-left: 0; padding-left: 0; border-top: 1px solid var(--rule); padding-top: 32px; }
  .hero-stats{ flex-direction: row; flex-wrap:wrap; gap: 32px; }
}

/* Marquee strip — runs under hero */
.strip{
  border-top: 1px solid var(--rule-2);
  border-bottom: 1px solid var(--rule-2);
  padding: 22px 0;
  overflow: hidden;
  background: var(--paper);
}
.strip-track{
  display:flex; gap: 56px; align-items:center;
  animation: scroll 60s linear infinite;
  white-space: nowrap;
  font-family: var(--serif); font-style: italic; font-size: 22px; color: var(--ink-3);
}
.strip-track .sep{ color: var(--gold); font-style: normal; }
@keyframes scroll{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* About */
.about-grid{
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start;
}
.about-aside h2{ position: sticky; top: 110px; }
.about-body p{ font-size: 17px; }
.values{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 40px;
  margin-top: 64px; padding-top: 56px; border-top: 1px solid var(--rule);
}
.value-num{
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em; color: var(--gold-deep);
  margin-bottom: 14px;
}
.value h4{ font-family: var(--serif); font-size: 22px; font-weight: 600; margin-bottom: 10px; }
.value p{ font-size: 15px; color: var(--ink-3); margin: 0; }

@media (max-width: 900px){
  .about-grid{ grid-template-columns: 1fr; gap: 40px; }
  .about-aside h2{ position: static; }
  .values{ grid-template-columns: 1fr; gap: 28px; }
}

/* Section header */
.sec-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap: 40px;
  margin-bottom: 56px;
}
.sec-head .left{ max-width: 720px; }
.sec-head .right{ font-family: var(--mono); font-size: 11px; letter-spacing: .14em; color: var(--ink-3); text-transform:uppercase; }
@media (max-width: 720px){ .sec-head{ flex-direction:column; align-items:flex-start; gap: 16px; } }

/* Projects */
.projects{ display:flex; flex-direction:column; gap: 0; border-top: 1px solid var(--rule); }
.project{
  display:grid; grid-template-columns: 80px 1fr 1.2fr 180px; gap: 32px;
  padding: 36px 0;
  border-bottom: 1px solid var(--rule);
  align-items: start;
  transition: background .25s ease;
  cursor: pointer;
}
.project:hover{ background: var(--paper-2); }
.project:hover .p-arrow{ transform: translateX(4px); opacity:1; }
.p-num{ font-family: var(--mono); font-size: 12px; color: var(--gold-deep); padding-top: 6px; }
.p-title{ font-family: var(--serif); font-size: 30px; line-height: 1.15; font-weight: 500; padding-top: 0; }
.p-desc{ font-size: 14px; color: var(--ink-3); line-height: 1.55; padding-top: 6px; }
.p-meta{
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em; color: var(--ink-3);
  text-transform: uppercase; padding-top: 10px;
  display:flex; justify-content:space-between; align-items: flex-start; gap: 12px;
}
.p-arrow{
  width: 14px; height: 14px; opacity: .5; transition: transform .25s, opacity .25s;
  background: currentColor; flex-shrink: 0; margin-top: 4px;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round' d='M5 12h14M13 6l6 6-6 6'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='none' stroke='black' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round' d='M5 12h14M13 6l6 6-6 6'/></svg>") center/contain no-repeat;
}
.p-status{
  display:inline-flex; align-items:center; gap: 6px;
  padding: 4px 8px; border-radius: 4px;
  background: var(--paper-3); color: var(--ink-2);
  font-family: var(--mono); font-size: 10px; letter-spacing: .1em;
}
.p-status .live{ width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }
.p-status.done{ background: rgba(10,22,40,.06); }
.p-status.done .live{ background: var(--ink-3); }

@media (max-width: 900px){
  .project{ grid-template-columns: 60px 1fr; gap: 16px; padding: 28px 0; }
  .p-desc, .p-meta{ grid-column: 2; }
  .p-meta{ flex-direction: row; justify-content: flex-start; gap: 16px; }
  .p-arrow{ display:none; }
}

/* Project detail card */
.project-detail{
  margin-top: 80px;
  display:grid; grid-template-columns: 1.2fr 1fr; gap: 0;
  border: 1px solid var(--rule);
  background: var(--paper);
  overflow: hidden;
}
.pd-media{
  background: var(--ink);
  position: relative; min-height: 480px;
  display:flex; align-items:flex-end;
}
.pd-tag{
  position:absolute; top: 24px; left: 24px;
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  color: var(--paper); text-transform: uppercase;
  background: rgba(255,255,255,.08); padding: 6px 10px; border-radius: 4px;
  border: 1px solid rgba(255,255,255,.12);
}
.pd-caption{
  padding: 24px;
  color: var(--paper); position:relative; z-index: 2;
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase;
  border-top: 1px solid rgba(255,255,255,.1);
  background: linear-gradient(0deg, rgba(0,0,0,.4), transparent);
  width:100%;
}
.pd-body{ padding: 56px 48px; }
.pd-body .eyebrow{ margin-bottom: 16px; }
.pd-body h3{ font-family: var(--serif); font-size: 36px; font-weight: 500; margin-bottom: 20px; line-height: 1.1; letter-spacing: -.01em; }
.pd-body p{ font-size: 15px; color: var(--ink-2); }
.pd-data{ margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--rule); display:grid; grid-template-columns: repeat(2, 1fr); gap: 20px 28px; }
.pd-data dt{ font-family: var(--mono); font-size: 10px; letter-spacing: .14em; color: var(--ink-3); text-transform:uppercase; margin-bottom: 4px; }
.pd-data dd{ margin: 0; font-family: var(--serif); font-size: 18px; font-weight: 500; }
@media (max-width: 900px){
  .project-detail{ grid-template-columns: 1fr; }
  .pd-body{ padding: 36px 28px; }
  .pd-media{ min-height: 320px; }
}

/* Gallery / Before-after */
.gallery{ display:grid; grid-template-columns: repeat(12, 1fr); gap: 20px; }
.g-card{
  position: relative; overflow: hidden;
  background: var(--paper-2);
  border: 1px solid var(--rule-2);
  cursor: zoom-in;
  transition: transform .3s ease;
}
.g-card:hover{ transform: translateY(-2px); }
.g-card .g-img{ display:block; width:100%; height:100%; }
.g-card .g-overlay{
  position:absolute; left:0; right:0; bottom:0;
  padding: 16px 18px;
  background: linear-gradient(0deg, rgba(0,0,0,.7), transparent);
  color: #fff;
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform:uppercase;
  display:flex; justify-content: space-between; align-items: flex-end;
}
.g-card .g-overlay strong{ font-weight: 500; font-size: 12px; }
.g-card[data-size="lg"]{ grid-column: span 8; aspect-ratio: 16/10; }
.g-card[data-size="md"]{ grid-column: span 4; aspect-ratio: 4/5; }
.g-card[data-size="sm"]{ grid-column: span 4; aspect-ratio: 1/1; }
.g-card[data-size="wd"]{ grid-column: span 12; aspect-ratio: 24/9; }
@media (max-width: 720px){
  .g-card{ grid-column: span 12 !important; aspect-ratio: 4/3 !important; }
}

/* Before/After slider */
.ba{
  position: relative; overflow: hidden;
  background: var(--ink);
  user-select: none; touch-action: none;
}
.ba-img{
  position: absolute; inset: 0; width: 100%; height: 100%;
}
.ba-after{ clip-path: inset(0 0 0 var(--pos, 50%)); }
.ba-handle{
  position: absolute; top: 0; bottom: 0; left: var(--pos, 50%);
  width: 2px; background: rgba(255,255,255,.85);
  transform: translateX(-1px);
  pointer-events: none;
}
.ba-knob{
  position: absolute; left: 50%; top: 50%; width: 44px; height: 44px;
  transform: translate(-50%, -50%);
  background: #fff; border-radius: 50%;
  display:grid; place-items:center;
  box-shadow: 0 4px 18px rgba(0,0,0,.3);
}
.ba-knob::before{ content: ""; width:14px; height:14px;
  background:
    linear-gradient(to right, transparent 0 4px, var(--ink) 4px 5px, transparent 5px 9px, var(--ink) 9px 10px, transparent 10px 14px);
}
.ba-label{
  position: absolute; top: 18px;
  font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform:uppercase;
  color: #fff; padding: 5px 10px;
  background: rgba(0,0,0,.45); border: 1px solid rgba(255,255,255,.18);
  border-radius: 3px;
}
.ba-label.before{ left: 18px; }
.ba-label.after{ right: 18px; }

/* Lightbox */
.lb{
  position: fixed; inset: 0; z-index: 200;
  background: rgba(8, 14, 26, .96);
  display:flex; align-items:center; justify-content:center;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.lb.open{ opacity: 1; pointer-events: auto; }
.lb-inner{
  width: min(1100px, 92vw);
  max-height: 88vh;
  display: flex; flex-direction: column; gap: 16px;
  position: relative;
}
.lb-canvas{
  flex: 1; min-height: 0;
  background: var(--ink-2);
  display: grid; place-items: center;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
}
.lb-canvas .ph{ width: 100%; height: 100%; }
.lb-meta{
  display:flex; align-items:center; justify-content:space-between;
  color: rgba(255,255,255,.78); font-family: var(--mono); font-size: 11px;
  letter-spacing: .1em; text-transform: uppercase;
}
.lb-close, .lb-nav{
  position: absolute; appearance:none; background: rgba(255,255,255,.06); color:#fff; border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px; width: 44px; height: 44px; display:grid; place-items:center; cursor:pointer;
  transition: background .15s;
}
.lb-close:hover, .lb-nav:hover{ background: rgba(255,255,255,.16); }
.lb-close{ top: -56px; right: 0; }
.lb-nav.prev{ top: 50%; left: -64px; transform: translateY(-50%); }
.lb-nav.next{ top: 50%; right: -64px; transform: translateY(-50%); }
@media (max-width: 900px){
  .lb-nav.prev{ left: 8px; }
  .lb-nav.next{ right: 8px; }
  .lb-close{ top: 8px; right: 8px; }
}

/* Donate / Wesprzyj */
.donate-grid{
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: center;
}
.donate-card{
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.1);
  padding: 40px;
}
.donate-card h3{ font-family: var(--serif); font-size: 28px; font-weight: 500; margin-bottom: 24px; color: var(--paper); }
.donate-amounts{ display:grid; grid-template-columns: repeat(4,1fr); gap: 8px; margin-bottom: 16px; }
@media (max-width: 900px){
  .donate-grid{ grid-template-columns: 1fr; gap: 48px; }
}
@media (max-width: 560px){
  .donate-card{ padding: 28px 22px; }
  .donate-amounts{ grid-template-columns: repeat(2, 1fr); }
  .donate-amount{ padding: 12px 0; font-size: 18px; }
}
.donate-amount{
  appearance:none; background: transparent; color: var(--paper);
  border: 1px solid rgba(255,255,255,.18); padding: 14px 0;
  font-family: var(--serif); font-size: 20px; font-weight: 500;
  cursor: pointer; transition: all .15s;
}
.donate-amount:hover{ border-color: var(--paper); color: var(--paper); }
.donate-amount.active{ background: var(--paper); color: var(--ink); border-color: var(--paper); }
.donate-amount.active::after{ content:""; display:block; width: 18px; height: 1px; background: var(--gold); margin: 6px auto 0; }
.donate-custom{
  display:flex; align-items:center; gap: 0; margin-bottom: 20px;
  border: 1px solid rgba(255,255,255,.18);
}
.donate-custom span{ padding: 0 14px; font-family: var(--mono); color: rgba(255,255,255,.5); font-size: 12px; }
.donate-custom input{
  flex:1; background: transparent; border: 0; padding: 14px 0;
  color: var(--paper); font-family: var(--serif); font-size: 20px; outline: none;
}
.donate-progress{
  margin: 28px 0 12px; height: 4px; background: rgba(255,255,255,.1); position: relative; overflow: hidden;
}
.donate-progress span{ position:absolute; inset: 0 auto 0 0; width: 64%; background: var(--gold); }
.donate-meta{
  display:flex; justify-content:space-between;
  font-family: var(--mono); font-size: 11px; letter-spacing:.1em; text-transform: uppercase;
  color: rgba(255,255,255,.6); margin-bottom: 24px;
}
.donate-meta strong{ color: var(--paper); font-weight: 500; }

/* News */
.news-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.news-card{
  display:flex; flex-direction: column;
  border-top: 1px solid var(--ink);
  padding-top: 24px;
  cursor: pointer;
  transition: transform .25s ease;
}
.news-card:hover{ transform: translateY(-4px); }
.news-img{ aspect-ratio: 4/3; background: var(--paper-3); margin-bottom: 24px; overflow: hidden; }
.news-img .ph{ width: 100%; height: 100%; }
.news-meta{ font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 12px; display:flex; gap: 14px; }
.news-meta .cat{ color: var(--gold-deep); }
.news-card h3{ font-family: var(--serif); font-size: 24px; font-weight: 500; line-height: 1.2; margin-bottom: 12px; }
.news-card p{ font-size: 14px; color: var(--ink-3); margin-bottom: 16px; }
.news-card .read{
  margin-top: auto; font-size: 13px; font-weight: 500;
  display:inline-flex; gap: 8px; align-items:center;
  color: var(--ink);
}
@media (max-width: 900px){ .news-grid{ grid-template-columns: 1fr; } }

/* Partners */
.partners{
  display:grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid var(--rule);
}
.partner{
  aspect-ratio: 16/9;
  display:grid; place-items:center;
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  font-family: var(--serif); font-size: 22px; font-weight: 500;
  color: var(--ink-3);
  padding: 20px; text-align: center;
  transition: background .2s, color .2s;
  cursor: default;
  background: var(--paper);
}
.partner:hover{ background: var(--paper-2); color: var(--ink); }
.partner:nth-child(4n){ border-right: 0; }
.partner:nth-last-child(-n+4){ border-bottom: 0; }
.partner small{ display:block; font-family: var(--mono); font-size: 10px; letter-spacing: .12em; text-transform:uppercase; color: var(--ink-3); margin-top: 6px; }
@media (max-width: 720px){
  .partners{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .partner:nth-child(4n){ border-right: 1px solid var(--rule); }
  .partner:nth-child(2n){ border-right: 0; }
  .partner:nth-last-child(-n+4){ border-bottom: 1px solid var(--rule); }
  .partner:nth-last-child(-n+2){ border-bottom: 0; }
}

/* Contact */
.contact-grid{ display:grid; grid-template-columns: 1fr 1.2fr; gap: 80px; }
.contact-info dl{ margin: 0; display: flex; flex-direction: column; gap: 28px; }
.contact-info dt{ font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px; }
.contact-info dd{ margin: 0; font-family: var(--serif); font-size: 22px; font-weight: 500; line-height: 1.3; }
.contact-info dd a:hover{ color: var(--gold-deep); }

.form{ display:grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form .full{ grid-column: 1 / -1; }
.form label{ display:flex; flex-direction:column; gap: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: .14em; color: var(--ink-3); text-transform: uppercase; }
.form input, .form textarea, .form select{
  font-family: var(--sans); font-size: 16px; color: var(--ink);
  border: 0; border-bottom: 1px solid var(--rule);
  background: transparent; padding: 8px 0 12px; outline: none;
  border-radius: 0;
  transition: border-color .15s;
}
.form input:focus, .form textarea:focus, .form select:focus{ border-color: var(--ink); }
.form textarea{ resize: vertical; min-height: 100px; font-family: var(--sans); }
.form .submit{ display:flex; justify-content:flex-end; align-items:center; gap: 16px; margin-top: 8px; }
.form .submit small{ flex: 1; color: var(--ink-3); font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; }

@media (max-width: 900px){ .contact-grid, .form{ grid-template-columns: 1fr; gap: 40px; } }

/* Footer */
.footer{
  background: var(--ink); color: var(--paper);
  padding: 80px 0 40px;
}
.footer-top{ display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 56px; border-bottom: 1px solid rgba(255,255,255,.1); }
.footer h5{ font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform:uppercase; color: var(--gold); margin-bottom: 18px; font-weight: 500; }
.footer ul{ list-style: none; padding: 0; margin: 0; display:flex; flex-direction: column; gap: 10px; }
.footer ul a{ color: rgba(255,255,255,.7); font-size: 14px; }
.footer ul a:hover{ color: var(--paper); }
.footer .brand-text b{ color: var(--paper); }
.footer .brand-text span{ color: var(--gold); }
.footer .brand-mark{ background: var(--paper); color: var(--ink); border-color: var(--paper); }
.footer p{ color: rgba(255,255,255,.6); font-size: 14px; max-width: 36ch; margin-top: 14px; }
.footer-bot{
  display:flex; justify-content:space-between; align-items:center;
  padding-top: 32px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(255,255,255,.5);
}
@media (max-width: 900px){ .footer-top{ grid-template-columns: 1fr 1fr; gap: 40px; } .footer-bot{ flex-direction: column; gap: 16px; } }

/* --- Mobile (<=600px) --- */
@media (max-width: 600px){
  .section{ padding: 80px 0; }
  .h-display{ font-size: clamp(40px, 11vw, 56px); }
  .h-section{ font-size: clamp(32px, 8vw, 44px); }
  .donate-card h3{ font-size: 22px; margin-bottom: 18px; }
  .footer-top{ grid-template-columns: 1fr; gap: 36px; padding-bottom: 40px; }
  .footer{ padding: 56px 0 32px; }
  .hero-stats{ gap: 24px; }
  .hero-stat .num{ font-size: 36px; }
  .nav-bar{ padding: 14px 0; }
  .cookie{ left: 16px; right: 16px; bottom: 16px; max-width: none; }
  .partners{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .partner{ padding: 22px 14px; text-align:center; }
  .partner div{ font-size: 13px; line-height: 1.3; word-break: break-word; }
}

/* Placeholder image (subtle stripes + label) */
.ph{
  background:
    repeating-linear-gradient(135deg, transparent 0 9px, rgba(44,74,124,.10) 9px 10px),
    linear-gradient(180deg, var(--paper-3), var(--paper-2));
  display:flex; align-items:center; justify-content:center;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .14em; color: var(--ink-3);
  text-transform:uppercase; text-align:center;
  padding: 16px;
}
.ph--dark{
  background:
    repeating-linear-gradient(135deg, transparent 0 9px, rgba(154,164,176,.14) 9px 10px),
    linear-gradient(180deg, #1a2c4a, #14233d);
  color: rgba(255,255,255,.55);
}
.ph small{ display:block; opacity: .6; margin-top: 6px; font-size: 9.5px; letter-spacing: .14em; }

/* Reveal on scroll */
.reveal{ opacity: 0; transform: translateY(16px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in{ opacity: 1; transform: none; }

/* Cookie strip */
.cookie{
  position: fixed; right: 24px; bottom: 24px; z-index: 90;
  max-width: 360px;
  background: var(--paper); border: 1px solid var(--rule);
  box-shadow: 0 12px 40px rgba(10,22,40,.12);
  padding: 18px 20px;
  font-size: 13px; color: var(--ink-2);
  display: flex; flex-direction: column; gap: 12px;
  animation: cookie-in .5s ease 1.2s both;
}
@keyframes cookie-in{ from{transform: translateY(20px); opacity: 0} to{transform: none; opacity: 1} }
.cookie .row{ display:flex; gap: 8px; justify-content: flex-end; }
.cookie button{
  appearance:none; border: 1px solid var(--rule); background: transparent; padding: 8px 14px;
  font-size: 12px; cursor: pointer; border-radius: 999px; font-weight: 500;
}
.cookie button.primary{ background: var(--ink); color: var(--paper); border-color: var(--ink); }
.cookie.hidden{ display: none; }