/*
Theme Name: ORBIT
Theme URI: https://www.orbit.ngo
Author: ORBIT — Organisation for Relief & Betterment Initiating Trust
Author URI: https://www.orbit.ngo
Description: Official website theme for ORBIT, a national NGO building resilient communities across South Sudan. Installs a complete 9-page site (Home, About, Programmes, Projects, Impact, News, Partners, Get Involved, Contact) with brand colours, typography, interactive map, animated stats and full mobile responsiveness. Edit all content from Appearance → Customize → ORBIT Settings (no page builder required); WPForms-ready contact forms.
Version: 1.4.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: orbit
Tags: nonprofit, ngo, charity, custom-menu, featured-images, full-width-template, translation-ready
*/

/* ============================================================
   ORBIT — Organisation for Relief & Betterment Initiating Trust
   Global design system
   Fonts: Schibsted Grotesk (display) · Public Sans (body)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Brand */
  --green-700:#1E7D3A;   /* primary */
  --green-600:#268a45;
  --green-500:#34a558;
  --green-800:#176032;
  --green-900:#0e3d22;   /* deep, for dark sections */
  --green-50:#eef7f1;
  --green-100:#dcefe3;

  --blue-700:#0B5FA5;    /* secondary */
  --blue-600:#1372bd;
  --navy-900:#0a2845;    /* deep trust — footer / hero overlay */
  --navy-800:#0e3a63;
  --navy-50:#eef4fa;

  --gold:#F5A623;        /* accent */
  --gold-600:#e0930f;
  --gold-50:#fdf3e1;

  --ink:#1F2937;         /* primary text */
  --ink-600:#475467;     /* muted text */
  --ink-400:#7a8699;
  --bg:#F8FAFC;          /* page background tint */
  --surface:#ffffff;
  --line:#e5eaf1;
  --line-strong:#d4dbe6;

  /* Type */
  --font-display:"Schibsted Grotesk",system-ui,sans-serif;
  --font-body:"Public Sans",system-ui,sans-serif;

  /* Radii */
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:32px; --r-pill:999px;

  /* Shadows */
  --shadow-sm:0 1px 2px rgba(16,33,55,.06), 0 1px 3px rgba(16,33,55,.05);
  --shadow-md:0 6px 18px rgba(16,33,55,.08), 0 2px 6px rgba(16,33,55,.05);
  --shadow-lg:0 24px 60px -18px rgba(10,40,69,.30), 0 8px 24px -12px rgba(10,40,69,.18);

  /* Layout */
  --maxw:1240px;
  --gutter:clamp(20px,4vw,48px);
  --nav-h:80px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);
  background:var(--surface);line-height:1.6;font-size:17px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:700;line-height:1.08;
  letter-spacing:-.02em;color:var(--ink);margin:0}
p{margin:0}
ul{margin:0}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.container-wide{max-width:1440px;margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,8vw,120px)}
.section-sm{padding-block:clamp(48px,6vw,80px)}
.bg-tint{background:var(--bg)}
.bg-green-tint{background:var(--green-50)}
.bg-dark{background:var(--navy-900);color:#dbe6f2}
.bg-dark h1,.bg-dark h2,.bg-dark h3,.bg-dark h4{color:#fff}
.center{text-align:center}
.mx-auto{margin-inline:auto}

/* Type scale */
.display{font-size:clamp(2.6rem,6vw,4.6rem);line-height:1.02;letter-spacing:-.03em}
.h1{font-size:clamp(2.2rem,4.6vw,3.4rem)}
.h2{font-size:clamp(1.8rem,3.4vw,2.7rem)}
.h3{font-size:clamp(1.35rem,2.2vw,1.7rem)}
.lead{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink-600);line-height:1.6}
.muted{color:var(--ink-600)}
.measure{max-width:62ch}
.measure-sm{max-width:46ch}

/* Eyebrow / kicker */
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-body);
  font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--green-700)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);border-radius:2px}
.eyebrow.on-dark{color:var(--gold)}
.eyebrow.on-dark::before{background:var(--gold)}
.eyebrow.center-line{justify-content:center}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-body);font-weight:700;font-size:1rem;line-height:1;
  padding:.95rem 1.6rem;border-radius:var(--r-pill);border:2px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--green-700);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--green-800);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#3a2603;box-shadow:var(--shadow-sm)}
.btn-gold:hover{background:var(--gold-600);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.btn-outline{background:transparent;border-color:var(--line-strong);color:var(--ink)}
.btn-outline:hover{border-color:var(--green-700);color:var(--green-700)}
.btn-light{background:#fff;color:var(--navy-900)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-ghost-light{background:rgba(255,255,255,.10);color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost-light:hover{background:rgba(255,255,255,.18);border-color:#fff}
.btn-lg{padding:1.1rem 2rem;font-size:1.08rem}
.btn-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;color:var(--green-700)}
.btn-link svg{width:18px;height:18px;transition:transform .2s ease}
.btn-link:hover svg{transform:translateX(4px)}
.btn-link.on-dark{color:var(--gold)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;
  transition:box-shadow .25s ease, border-color .25s ease}
.site-header.scrolled{box-shadow:var(--shadow-sm);border-color:var(--line)}
.nav{display:flex;align-items:center;gap:1.5rem;height:var(--nav-h)}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:42px;width:auto}
.nav-links{display:flex;align-items:center;gap:.35rem;margin-left:auto}
.nav-links a{position:relative;padding:.6rem .8rem;border-radius:var(--r-sm);
  font-weight:600;font-size:.97rem;color:var(--ink);transition:color .15s,background .15s}
.nav-links a:hover{color:var(--green-700);background:var(--green-50)}
.nav-links a.active{color:var(--green-700)}
.nav-links a.active::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.2rem;
  height:2px;background:var(--gold);border-radius:2px}
.nav-cta{display:flex;align-items:center;gap:.6rem;margin-left:.5rem}
.nav-toggle{display:none;margin-left:auto;width:46px;height:46px;border:1px solid var(--line-strong);
  background:#fff;border-radius:var(--r-sm);flex-direction:column;justify-content:center;
  align-items:center;gap:5px}
.nav-toggle span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile drawer */
.mobile-menu{position:fixed;inset:var(--nav-h) 0 0 0;background:#fff;z-index:55;
  transform:translateX(100%);transition:transform .3s ease;padding:2rem var(--gutter);
  display:flex;flex-direction:column;gap:.25rem;overflow-y:auto}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{padding:1rem .25rem;font-family:var(--font-display);font-size:1.4rem;
  font-weight:600;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:1.5rem}

/* ---------- Photo placeholders ---------- */
.ph{position:relative;overflow:hidden;background:
    linear-gradient(135deg,var(--green-800),var(--navy-900));
  border-radius:var(--r-lg);display:flex;align-items:flex-end;isolation:isolate}
.ph::before{content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 2px,transparent 2px 11px)}
.ph::after{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(120% 90% at 80% 10%,rgba(245,166,35,.18),transparent 55%)}
.ph .ph-label{margin:0;padding:.55rem .7rem;font-family:"Public Sans",monospace;
  font-size:.72rem;letter-spacing:.02em;color:rgba(255,255,255,.82);
  background:rgba(8,22,38,.42);backdrop-filter:blur(3px);border-radius:8px;margin:.7rem;
  font-weight:600;display:inline-flex;align-items:center;gap:.4rem}
.ph .ph-label::before{content:"▣";color:var(--gold)}
.ph.alt{background:linear-gradient(135deg,var(--blue-700),var(--green-800))}
.ph.gold{background:linear-gradient(135deg,var(--gold-600),var(--green-800))}
.ph-16x9{aspect-ratio:16/9}
.ph-4x3{aspect-ratio:4/3}
.ph-1x1{aspect-ratio:1/1}
.ph-3x4{aspect-ratio:3/4}

/* ---------- Cards ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;transition:transform .22s ease, box-shadow .22s ease, border-color .22s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.card-pad{padding:clamp(1.25rem,2vw,1.75rem)}

/* Grid utilities */
.grid{display:grid;gap:clamp(1.1rem,2vw,1.75rem)}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

/* Chips / tags */
.chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:700;
  padding:.38rem .75rem;border-radius:var(--r-pill);background:var(--green-50);
  color:var(--green-800);letter-spacing:.01em}
.chip.blue{background:var(--navy-50);color:var(--blue-700)}
.chip.gold{background:var(--gold-50);color:var(--gold-600)}

/* Divider */
.rule{height:1px;background:var(--line);border:0}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-900);color:#aebfd2}
.site-footer a{color:#cdd9e8}
.site-footer a:hover{color:#fff}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.4fr;gap:2.5rem;
  padding-block:clamp(48px,6vw,80px)}
.footer-logo{background:#fff;padding:.7rem .9rem;border-radius:var(--r-md);display:inline-flex;
  width:fit-content}
.footer-logo img{height:38px}
.footer-col h4{color:#fff;font-size:1.02rem;margin-bottom:1rem;letter-spacing:0}
.footer-col ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.6rem}
.footer-col a{font-size:.95rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:1.5rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  font-size:.86rem;color:#8ea3bd}
.social{display:flex;gap:.6rem}
.social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);
  display:grid;place-items:center;transition:background .2s,transform .2s}
.social a:hover{background:var(--green-700);transform:translateY(-2px)}
.social svg{width:18px;height:18px;fill:#fff}

/* Newsletter */
.newsletter{display:flex;gap:.6rem;flex-wrap:wrap}
.newsletter input{flex:1;min-width:0;padding:.85rem 1rem;border-radius:var(--r-pill);
  border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;
  font-family:inherit;font-size:.95rem}
.newsletter input::placeholder{color:#8ea3bd}
.newsletter input:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.1)}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),
  transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;background:var(--navy-900);color:#fff;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;opacity:.32;
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 2px,transparent 2px 13px)}
.page-hero::after{content:"";position:absolute;inset:0;
  background:radial-gradient(90% 120% at 85% -10%,rgba(30,125,58,.55),transparent 60%),
             radial-gradient(70% 90% at 0% 110%,rgba(11,95,165,.45),transparent 60%)}
.page-hero .container{position:relative;z-index:1;padding-block:clamp(60px,9vw,120px)}
.page-hero h1,.page-hero h2,.page-hero h3,.page-hero h4{color:#fff}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.86rem;color:#9fb4cd;margin-bottom:1.1rem}
.breadcrumb a:hover{color:#fff}

/* ---------- Stat block ---------- */
.stat-num{font-family:var(--font-display);font-weight:800;line-height:1;
  font-size:clamp(2.4rem,4.5vw,3.4rem);letter-spacing:-.03em}

/* Utility spacing */
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}
.flex{display:flex}.items-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}
.wrap{flex-wrap:wrap}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .g4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:880px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .g3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  body{font-size:16px}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}
