/* ==========================================================================
   SAVE ME — Design tokens
   Palette: trust blue + hope teal + warm amber accent, on soft mint/white
   Type: Fraunces (display, warm humanist serif) + Inter (body/UI)
   Signature motif: the "ring" — a circle of support, used in stats & funding
   ========================================================================== */

:root{
  --color-bg:            #FFFFFF;
  --color-bg-soft:       #EFF7F6;
  --color-bg-deep:       #0F3D57;
  --color-primary:       #1B5E8C;
  --color-primary-dark:  #124867;
  --color-secondary:     #2FA88A;
  --color-secondary-dark:#1F7A63;
  --color-accent:        #F2A154;
  --color-accent-dark:   #D9822F;
  --color-ink:           #16323E;
  --color-ink-soft:      #4C6B75;
  --color-line:          #DCEAEA;
  --color-white:         #FFFFFF;

  --font-display: "Fraunces", Georgia, serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --radius-sm: 12px;
  --radius-md: 20px;
  --radius-lg: 28px;
  --radius-full: 999px;

  --shadow-sm: 0 2px 10px rgba(22,50,62,0.06);
  --shadow-md: 0 12px 32px rgba(22,50,62,0.10);
  --shadow-lg: 0 24px 60px rgba(22,50,62,0.16);

  --container-w: 1220px;
  --space-section: clamp(64px, 8vw, 120px);

  --font-scale: 1;
}

/* ==========================================================================
   Reset
   ========================================================================== */
*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *, *::before, *::after{ animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
}
body{
  margin:0;
  font-family: var(--font-body);
  color: var(--color-ink);
  background: var(--color-bg);
  font-size: calc(16px * var(--font-scale));
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ color: inherit; }
h1,h2,h3,h4{ font-family: var(--font-display); line-height: 1.15; margin: 0 0 0.5em; color: var(--color-ink); }
p{ margin: 0 0 1em; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family: inherit; cursor:pointer; }
input{ font-family: inherit; }

.container{ max-width: var(--container-w); margin: 0 auto; padding: 0 24px; }

.visually-hidden{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.skip-link{
  position:absolute; left:-999px; top:0; background: var(--color-primary); color:#fff;
  padding: 12px 20px; z-index: 1000; border-radius: 0 0 8px 0; font-weight:600;
}
.skip-link:focus{ left:0; }

:focus-visible{
  outline: 3px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ==========================================================================
   Accessibility bar
   ========================================================================== */
.a11y-bar{
  background: var(--color-bg-deep);
  color: #E7F1F5;
  font-size: 13px;
}
.a11y-bar__inner{
  max-width: var(--container-w); margin: 0 auto; padding: 6px 24px;
  display:flex; align-items:center; gap:8px; flex-wrap: wrap;
}
.a11y-bar__label{ opacity:0.7; margin-right:4px; }
.a11y-btn{
  background: rgba(255,255,255,0.08); color:#fff; border:1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius-full); padding: 3px 12px; font-size:12px; font-weight:600;
  transition: background 0.2s ease;
}
.a11y-btn:hover{ background: rgba(255,255,255,0.2); }
.a11y-btn--link{ text-decoration: underline; background:none; border:none; }
.a11y-btn[aria-pressed="true"]{ background: var(--color-accent); border-color: var(--color-accent); color:#1a1200; }

/* ==========================================================================
   High contrast mode
   ========================================================================== */
body.high-contrast{
  --color-bg: #000000;
  --color-bg-soft: #0A0A0A;
  --color-ink: #FFFFFF;
  --color-ink-soft: #F2F2F2;
  --color-line: #666666;
  --color-primary: #5FC2FF;
  --color-secondary: #58E0B3;
  --color-accent: #FFC24D;
}
body.high-contrast h1, body.high-contrast h2, body.high-contrast h3{ color:#fff; }
body.high-contrast img{ filter: grayscale(0.2) contrast(1.1); }
body.high-contrast .hero__scrim{ background: rgba(0,0,0,0.75) !important; }
body.high-contrast .btn{ border: 2px solid currentColor; }

/* ==========================================================================
   Header
   ========================================================================== */
.site-header{
  position: sticky; top:0; z-index: 500;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-line);
}
.site-header__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 24px; gap: 24px;
}
.logo{ display:flex; align-items:center; gap:10px; text-decoration:none; }
.logo__mark{ color: var(--color-primary); display:flex; }
.logo__text{
  font-family: var(--font-display); font-weight:700; font-size:22px; letter-spacing:0.02em;
  color: var(--color-ink);
}
.logo__text em{ font-style:normal; color: var(--color-secondary); }

.main-nav ul{ display:flex; gap:28px; }
.main-nav a{
  text-decoration:none; font-weight:600; font-size:15px; color: var(--color-ink-soft);
  padding: 6px 2px; border-bottom: 2px solid transparent; transition: color .2s, border-color .2s;
}
.main-nav a:hover{ color: var(--color-primary); border-color: var(--color-secondary); }

.site-header__actions{ display:flex; align-items:center; gap:14px; }

.nav-toggle{
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width: 40px; height: 40px; background:none; border:1px solid var(--color-line); border-radius:10px;
}
.nav-toggle span{ display:block; height:2px; width:20px; margin:0 auto; background: var(--color-ink); border-radius:2px; }

.mobile-nav{ display:none; border-top:1px solid var(--color-line); background:#fff; }
.mobile-nav ul{ padding: 12px 24px 20px; display:flex; flex-direction:column; gap:4px; }
.mobile-nav a{ display:block; padding:10px 4px; text-decoration:none; font-weight:600; color:var(--color-ink); border-bottom:1px solid var(--color-line); }
.mobile-nav a.btn{ border-bottom:none; text-align:center; margin-top:10px; }

@media (max-width: 980px){
  .main-nav{ display:none; }
  .nav-toggle{ display:flex; }
  .site-header__actions .btn--sm{ display:none; }
  .mobile-nav[data-open="true"]{ display:block; }
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 13px 26px; border-radius: var(--radius-full); font-weight:700; font-size:15px;
  text-decoration:none; border: 2px solid transparent; transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  white-space: nowrap;
}
.btn:hover{ transform: translateY(-2px); }
.btn:active{ transform: translateY(0); }

.btn--accent{ background: var(--color-accent); color:#402400; box-shadow: var(--shadow-sm); }
.btn--accent:hover{ background: var(--color-accent-dark); box-shadow: var(--shadow-md); }

.btn--primary{ background: var(--color-primary); color:#fff; box-shadow: var(--shadow-sm); }
.btn--primary:hover{ background: var(--color-primary-dark); box-shadow: var(--shadow-md); }

.btn--outline{ border-color: var(--color-primary); color: var(--color-primary); background:transparent; }
.btn--outline:hover{ background: var(--color-primary); color:#fff; }

.btn--outline-light{ border-color: rgba(255,255,255,0.7); color:#fff; background: rgba(255,255,255,0.06); }
.btn--outline-light:hover{ background:#fff; color: var(--color-primary-dark); }

.btn--ghost-light{ color:#fff; background:none; border-color: transparent; text-decoration: underline; text-underline-offset:4px; padding-left:6px; padding-right:6px; }

.btn--sm{ padding: 8px 18px; font-size:13px; }
.btn--lg{ padding: 17px 34px; font-size:17px; }
.btn--block{ width:100%; }

/* ==========================================================================
   Section scaffolding
   ========================================================================== */
section{ padding: var(--space-section) 0; }
.section-head{ max-width: 640px; margin: 0 auto 48px; text-align:center; }
.section-head h2{ font-size: clamp(28px, 3.4vw, 40px); }
.section-head__sub{ color: var(--color-ink-soft); font-size:16px; }
.section-head--light p, .section-head--light h2{ color:#fff; }

.eyebrow{
  display:inline-block; font-family: var(--font-body); font-weight:700; font-size:13px;
  letter-spacing:0.12em; text-transform:uppercase; color: var(--color-accent);
  margin-bottom:14px;
}
.eyebrow--dark{ color: var(--color-secondary-dark); }

.card-link{
  display:inline-flex; align-items:center; gap:6px; font-weight:700; text-decoration:none;
  color: var(--color-primary); font-size:14px;
}
.card-link span{ transition: transform .2s ease; }
.card-link:hover span{ transform: translateX(4px); }

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{ position:relative; min-height: 92vh; display:flex; align-items:flex-end; overflow:hidden; padding:0; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{ width:100%; height:100%; object-fit: cover; }
.hero__scrim{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(15,61,87,0.35) 0%, rgba(15,61,87,0.55) 55%, rgba(9,38,54,0.92) 100%);
}
.hero__content{ position:relative; z-index:1; color:#fff; padding-bottom: 76px; padding-top:140px; }
.hero h1{ font-size: clamp(38px, 6vw, 70px); color:#fff; max-width: 16ch; }
.hero__sub{ font-size: clamp(16px, 1.6vw, 19px); max-width: 46ch; color: rgba(255,255,255,0.92); }
.hero__ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-top: 28px; }

/* ==========================================================================
   Stats + Ring motif
   ========================================================================== */
.stats{ background: var(--color-bg-soft); padding: 56px 0; }
.stats__grid{
  display:grid; grid-template-columns: repeat(5, 1fr); gap: 20px;
}
.stat-card{ text-align:center; display:flex; flex-direction:column; align-items:center; gap:10px; }
.ring{ position:relative; width:64px; height:64px; }
.ring svg{ width:100%; height:100%; transform: rotate(-90deg); }
.ring__track{ fill:none; stroke: var(--color-line); stroke-width:5; }
.ring__fill{
  fill:none; stroke: var(--color-secondary); stroke-width:5; stroke-linecap:round;
  stroke-dasharray: 169.6; stroke-dashoffset: 169.6;
  transition: stroke-dashoffset 1.4s cubic-bezier(.22,1,.36,1);
}
.ring__icon{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:18px; color: var(--color-primary); font-weight:700;
}
.stat-card__num{ font-family: var(--font-display); font-size: clamp(24px,2.6vw,32px); font-weight:700; color: var(--color-primary); }
.stat-card__label{ font-size:14px; color: var(--color-ink-soft); font-weight:600; }

@media (max-width: 900px){
  .stats__grid{ grid-template-columns: repeat(3,1fr); row-gap:32px; }
}
@media (max-width: 560px){
  .stats__grid{ grid-template-columns: repeat(2,1fr); }
}

/* ==========================================================================
   About
   ========================================================================== */
.about__grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items:center; }
.about__media{ position:relative; }
.about__media img{ border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); width:100%; aspect-ratio: 4/3.2; object-fit:cover; }
.about__media-badge{
  position:absolute; bottom:-24px; left:-24px; background:#fff; border-radius: var(--radius-md);
  box-shadow: var(--shadow-md); padding: 18px 22px; display:flex; flex-direction:column; align-items:center;
  border: 1px solid var(--color-line);
}
.about__media-badge strong{ font-family: var(--font-display); font-size:30px; color: var(--color-secondary-dark); line-height:1; }
.about__media-badge span{ font-size:12px; color: var(--color-ink-soft); font-weight:600; }
.about__text h2{ font-size: clamp(28px,3.2vw,38px); }
.about__ctas{ display:flex; gap:14px; margin-top:20px; flex-wrap:wrap; }

@media (max-width: 900px){
  .about__grid{ grid-template-columns: 1fr; gap:56px; }
  .about__media-badge{ left: 16px; }
}

/* ==========================================================================
   Mission
   ========================================================================== */
.mission{ background: var(--color-bg-soft); }
.mission__grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:28px; }
.mission-card{
  background:#fff; border-radius: var(--radius-lg); padding: 36px 30px; box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-line); transition: transform .25s ease, box-shadow .25s ease;
}
.mission-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-md); }
.mission-card__icon{
  display:flex; align-items:center; justify-content:center; width:60px; height:60px;
  border-radius: var(--radius-md); background: var(--color-bg-soft); color: var(--color-primary);
  margin-bottom: 20px;
}
.mission-card__icon svg{ width: 30px; height:30px; }
.mission-card h3{ font-size:21px; }

@media (max-width: 900px){ .mission__grid{ grid-template-columns: 1fr; } }

/* ==========================================================================
   Programs
   ========================================================================== */
.programs__grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:28px; }
.program-card{
  border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-sm); border:1px solid var(--color-line);
  transition: transform .25s ease, box-shadow .25s ease;
}
.program-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-md); }
.program-card__media{ aspect-ratio: 4/2.6; overflow:hidden; }
.program-card__media img{ width:100%; height:100%; object-fit:cover; transition: transform .5s ease; }
.program-card:hover .program-card__media img{ transform: scale(1.06); }
.program-card__body{ padding: 24px 26px 28px; }
.program-card__body h3{ font-size:20px; }

@media (max-width: 980px){ .programs__grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){ .programs__grid{ grid-template-columns: 1fr; } }

/* ==========================================================================
   Success stories (carousel)
   ========================================================================== */
.stories{ background: var(--color-bg-deep); color:#fff; }
.stories__track{
  display:flex; gap:24px; overflow-x:auto; scroll-snap-type:x mandatory; padding: 0 24px 12px;
  scrollbar-width: none;
}
.stories__track::-webkit-scrollbar{ display:none; }
.story-card{
  scroll-snap-align:center; flex: 0 0 min(420px, 84vw); background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14); border-radius: var(--radius-lg); padding: 32px 28px;
}
.story-card__photo{ width:56px; height:56px; border-radius:50%; object-fit:cover; margin-bottom:18px; border:2px solid var(--color-secondary); }
.story-card__quote{ font-family: var(--font-display); font-size:19px; line-height:1.5; color:#fff; }
.story-card__name{ font-weight:700; margin-bottom:2px; }
.story-card__name span{ display:block; font-weight:500; color: rgba(255,255,255,0.6); font-size:13px; }
.story-card__impact{ font-size:13px; color: var(--color-secondary); font-weight:600; margin-top:14px; margin-bottom:0; }

.stories__controls{ display:flex; justify-content:center; gap:14px; margin-top: 28px; }
.story-nav{
  width:44px; height:44px; border-radius:50%; border:1px solid rgba(255,255,255,0.3); background: rgba(255,255,255,0.06);
  color:#fff; font-size:22px; display:flex; align-items:center; justify-content:center; transition: background .2s;
}
.story-nav:hover{ background: var(--color-secondary); }

/* ==========================================================================
   Transparency / donut motif
   ========================================================================== */
.transparency__grid{ display:grid; grid-template-columns: repeat(4,1fr); gap:24px; }
.fund-card{
  text-align:center; background: var(--color-bg-soft); border-radius: var(--radius-lg); padding: 32px 20px;
  border: 1px solid var(--color-line);
}
.donut{ position:relative; width:120px; height:120px; margin:0 auto 18px; }
.donut svg{ width:100%; height:100%; transform: rotate(-90deg); }
.donut__track{ fill:none; stroke: var(--color-line); stroke-width:9; }
.donut__fill{
  fill:none; stroke: var(--color-secondary); stroke-width:9; stroke-linecap:round;
  stroke-dasharray: 263.9; stroke-dashoffset: 263.9;
  transition: stroke-dashoffset 1.4s cubic-bezier(.22,1,.36,1);
}
.donut__pct{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family: var(--font-display); font-weight:700; font-size:22px; color: var(--color-primary);
}
.fund-card h3{ font-size:17px; margin-bottom:2px; }
.fund-card p{ color: var(--color-ink-soft); font-weight:600; margin:0; }
.transparency__cta{ text-align:center; margin-top:40px; }

@media (max-width: 900px){ .transparency__grid{ grid-template-columns: repeat(2,1fr); } }

/* ==========================================================================
   Campaigns
   ========================================================================== */
.campaigns__grid{ display:grid; grid-template-columns: repeat(4,1fr); gap:24px; }
.campaign-card{
  background:#fff; border: 1px solid var(--color-line); border-radius: var(--radius-lg); padding: 28px 24px;
  box-shadow: var(--shadow-sm); display:flex; flex-direction:column;
}
.campaign-card h3{ font-size:19px; }
.campaign-card__amounts{ display:flex; justify-content:space-between; font-size:13px; color: var(--color-ink-soft); margin-bottom:10px; }
.campaign-card__amounts strong{ display:block; color: var(--color-ink); font-size:15px; }
.progress{ height:10px; border-radius: var(--radius-full); background: var(--color-line); overflow:hidden; margin-bottom:8px; }
.progress__fill{ display:block; height:100%; width: var(--pct); background: linear-gradient(90deg, var(--color-secondary), var(--color-primary)); border-radius: var(--radius-full); transition: width 1.2s cubic-bezier(.22,1,.36,1); }
.campaign-card__pct{ font-size:13px; font-weight:700; color: var(--color-secondary-dark); margin-bottom:18px; }
.campaign-card .btn{ margin-top:auto; }

@media (max-width: 980px){ .campaigns__grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .campaigns__grid{ grid-template-columns: 1fr; } }

/* ==========================================================================
   Volunteer
   ========================================================================== */
.volunteer{ position:relative; overflow:hidden; padding: 0; }
.volunteer__media{ position:absolute; inset:0; }
.volunteer__media img{ width:100%; height:100%; object-fit:cover; }
.volunteer__media::after{
  content:""; position:absolute; inset:0; background: linear-gradient(120deg, rgba(15,61,87,0.94) 30%, rgba(31,122,99,0.55) 100%);
}
.volunteer__content{ position:relative; z-index:1; color:#fff; padding: 96px 24px; max-width:640px; }
.volunteer__content h2{ color:#fff; font-size: clamp(28px,3.4vw,42px); }
.volunteer__ctas{ display:flex; gap:14px; flex-wrap:wrap; margin-top:24px; }

/* ==========================================================================
   Events
   ========================================================================== */
.events__grid{ display:grid; grid-template-columns: repeat(4,1fr); gap:24px; }
.event-card{
  display:flex; gap:18px; align-items:flex-start; background: var(--color-bg-soft); border-radius: var(--radius-lg);
  padding: 24px 20px; border:1px solid var(--color-line);
}
.event-card__date{
  flex:0 0 auto; background: var(--color-primary); color:#fff; border-radius: var(--radius-sm);
  width:56px; text-align:center; padding: 10px 0; font-size:12px; font-weight:700; letter-spacing:0.06em;
}
.event-card__date span{ display:block; font-family: var(--font-display); font-size:24px; line-height:1; margin-bottom:4px; }
.event-card__body h3{ font-size:17px; margin-bottom:4px; }
.event-card__body p{ font-size:14px; color: var(--color-ink-soft); margin-bottom:14px; }

@media (max-width: 980px){ .events__grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .events__grid{ grid-template-columns: 1fr; } }

/* ==========================================================================
   Partners marquee
   ========================================================================== */
.partners{ padding: 48px 0; border-top:1px solid var(--color-line); border-bottom:1px solid var(--color-line); }
.partners__label{ text-align:center; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; font-size:13px; color: var(--color-ink-soft); margin-bottom:24px; }
.partners__marquee{ overflow:hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent); mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent); }
.partners__track{ display:flex; gap:64px; width: max-content; animation: marquee 28s linear infinite; }
.partners__track span{ font-family: var(--font-display); font-size: 22px; font-weight:600; color: var(--color-ink-soft); white-space:nowrap; opacity:0.7; }
@keyframes marquee{ from{ transform: translateX(0);} to{ transform: translateX(-50%);} }

/* ==========================================================================
   News
   ========================================================================== */
.news__grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:28px; }
.news-card{ border-radius: var(--radius-lg); overflow:hidden; border:1px solid var(--color-line); box-shadow: var(--shadow-sm); }
.news-card img{ aspect-ratio: 4/2.4; object-fit:cover; width:100%; }
.news-card__body{ padding:22px 24px 26px; }
.news-card__date{ font-size:12px; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color: var(--color-secondary-dark); margin-bottom:8px; }
.news-card__body h3{ font-size:18px; }

@media (max-width: 900px){ .news__grid{ grid-template-columns: 1fr; } }

/* ==========================================================================
   Gallery
   ========================================================================== */
.gallery__masonry{
  columns: 4 220px; column-gap: 16px;
}
.gallery__masonry img{
  width:100%; border-radius: var(--radius-md); margin-bottom:16px; break-inside: avoid;
  transition: transform .3s ease;
}
.gallery__masonry img:hover{ transform: scale(1.02); }
@media (max-width: 900px){ .gallery__masonry{ columns: 2 200px; } }
@media (max-width: 520px){ .gallery__masonry{ columns: 1; } }

/* ==========================================================================
   Donation CTA
   ========================================================================== */
.donate-cta{
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary-dark) 100%);
  color:#fff; text-align:center;
}
.donate-cta__inner{ max-width:680px; margin:0 auto; }
.donate-cta h2{ color:#fff; font-size: clamp(30px,4vw,46px); }
.donate-cta p{ color: rgba(255,255,255,0.9); font-size:17px; }
.donate-cta__ctas{ display:flex; justify-content:center; gap:16px; flex-wrap:wrap; margin-top:24px; }

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{ background: var(--color-bg-deep); color: rgba(255,255,255,0.82); padding-top: 72px; }
.footer__grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:56px; }
.footer__brand p{ font-size:14px; color: rgba(255,255,255,0.65); max-width:32ch; margin-top:14px; }
.logo--footer .logo__text{ color:#fff; }
.footer__social{ display:flex; gap:10px; margin-top:18px; }
.footer__social a{
  display:flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:50%;
  background: rgba(255,255,255,0.08); color:#fff; transition: background .2s;
}
.footer__social a:hover{ background: var(--color-secondary); }
.site-footer h3{ color:#fff; font-family: var(--font-body); font-size:15px; text-transform:uppercase; letter-spacing:0.06em; margin-bottom:18px; }
.footer__links ul, .footer__contact ul{ display:flex; flex-direction:column; gap:10px; font-size:14px; }
.footer__links a, .footer__contact a{ text-decoration:none; color: rgba(255,255,255,0.75); }
.footer__links a:hover, .footer__contact a:hover{ color: var(--color-accent); }
.footer__newsletter p{ font-size:14px; color: rgba(255,255,255,0.7); margin-bottom:16px; }
.newsletter-form{ display:flex; gap:8px; }
.newsletter-form input{
  flex:1; min-width:0; padding: 11px 14px; border-radius: var(--radius-full); border:1px solid rgba(255,255,255,0.25);
  background: rgba(255,255,255,0.08); color:#fff;
}
.newsletter-form input::placeholder{ color: rgba(255,255,255,0.5); }
.newsletter-status{ font-size:13px; margin-top:10px; color: var(--color-accent); min-height:16px; }

.footer__bottom{ border-top:1px solid rgba(255,255,255,0.12); padding: 20px 0; }
.footer__bottom-inner{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:13px; color: rgba(255,255,255,0.55); }
.footer__bottom-inner ul{ display:flex; gap:20px; }
.footer__bottom-inner a{ text-decoration:none; color: inherit; }
.footer__bottom-inner a:hover{ color:#fff; }

@media (max-width: 900px){ .footer__grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .footer__grid{ grid-template-columns: 1fr; } }

/* ==========================================================================
   Back to top
   ========================================================================== */
.back-to-top{
  position:fixed; right:24px; bottom:24px; width:48px; height:48px; border-radius:50%;
  background: var(--color-primary); color:#fff; border:none; font-size:20px; box-shadow: var(--shadow-md);
  opacity:0; pointer-events:none; transform: translateY(10px); transition: opacity .25s, transform .25s;
  z-index: 400;
}
.back-to-top.visible{ opacity:1; pointer-events:auto; transform:translateY(0); }
.back-to-top:hover{ background: var(--color-primary-dark); }

/* ==========================================================================
   Scroll reveal
   ========================================================================== */
.reveal{ opacity:0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}
