/* ===========================================================
   Blue Sky Disaster Relief — NestProtect brand system
   Royal blue hero · white surfaces · cool blue→teal gradient
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,600&display=swap');

:root{
  --royal:#0162e8;
  --royal-dark:#0a4bb0;
  --teal:#00d2bc;
  --purple:#770bda;
  --pink:#ee0c49;
  --yellow:#ffd875;
  --white:#ffffff;
  --border:#E5E7EB;
  --slate:#4B5563;
  --slate-light:#6b7280;
  --soft:#F8F9FA;
  --ink:#0b1f4d;

  --grad-cool:linear-gradient(180deg,#0162e8 0%,#00d2bc 100%);
  --grad-callout:linear-gradient(180deg,#0162e8 0%,#770bda 100%);

  --shadow-card:0 1px 3px rgba(160,168,176,.18),0 4px 16px rgba(160,168,176,.18);
  --shadow-card-hover:0 2px 6px rgba(160,168,176,.22),0 10px 28px rgba(160,168,176,.24);
  --radius:.75rem;
  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Open Sans',Arial,system-ui,sans-serif;
  color:var(--slate);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:var(--royal);text-decoration:none}
a:hover{text-decoration:underline;color:var(--royal-dark)}
h1,h2,h3,h4{color:var(--royal);line-height:1.18;font-weight:700}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.5rem}
.eyebrow{
  font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal);margin-bottom:.6rem;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:inherit;font-size:.95rem;font-weight:700;
  padding:.72rem 1.4rem;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
  text-decoration:none;white-space:nowrap;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--grad-cool);color:#fff;box-shadow:0 4px 14px rgba(1,98,232,.28)}
.btn-primary:hover{color:#fff;box-shadow:0 6px 20px rgba(1,98,232,.36)}
.btn-secondary{background:#fff;color:var(--royal);border-color:var(--royal)}
.btn-secondary:hover{background:rgba(1,98,232,.06);color:var(--royal)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-ghost-light:hover{background:rgba(255,255,255,.14);color:#fff}
.btn-lg{padding:.9rem 1.8rem;font-size:1.02rem}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.6rem}
.brand img{height:46px;width:auto}
.nav-links{display:flex;align-items:center;gap:1.7rem;list-style:none}
.nav-links a{color:var(--ink);font-weight:600;font-size:.96rem}
.nav-links a:hover{color:var(--royal);text-decoration:none}
.nav-actions{display:flex;align-items:center;gap:.7rem}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;color:var(--ink)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:540px;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(1,98,232,.55) 0%,rgba(1,77,176,.42) 45%,rgba(0,210,188,.40) 100%);
}
.hero-inner{position:relative;z-index:2;color:#fff;padding:5.5rem 0;max-width:640px}
.hero h1{color:#fff;font-size:clamp(2.6rem,6vw,4.2rem);font-weight:800;letter-spacing:-.01em;margin-bottom:.6rem;text-shadow:0 2px 18px rgba(8,24,66,.35)}
.hero p.lead{color:#fff;font-size:1.22rem;font-weight:400;max-width:520px;margin-bottom:1.8rem;text-shadow:0 1px 10px rgba(8,24,66,.3)}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}

/* ---------- Sections ---------- */
section{padding:4.5rem 0}
.section-head{max-width:680px;margin-bottom:2.4rem}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head h2{font-size:clamp(1.8rem,3.5vw,2.5rem);margin-bottom:.5rem}
.section-head p{font-size:1.08rem}
.bg-soft{background:var(--soft)}

/* ---------- Stat band ---------- */
.stats{background:var(--soft);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem}
.stat-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-card);padding:1.5rem 1rem;text-align:center;
}
.stat-num{font-size:2.3rem;font-weight:800;color:var(--royal);line-height:1;letter-spacing:-.02em}
.stat-num span{font-size:1.2rem;vertical-align:super}
.stat-label{margin-top:.55rem;font-size:.95rem;font-weight:600;color:var(--slate)}

/* ---------- Story teaser ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split .media img{border-radius:var(--radius);box-shadow:var(--shadow-card);width:100%;aspect-ratio:5/4;object-fit:cover}
.split h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:1rem}
.split p{margin-bottom:1rem}

/* ---------- What we do ---------- */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.feature-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-card);padding:1.8rem;transition:box-shadow .2s,transform .2s;
}
.feature-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}
.feature-card .tag{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--royal);margin-bottom:.7rem}
.dot{width:9px;height:9px;border-radius:50%;background:var(--teal);display:inline-block}
.feature-card h3{font-size:1.2rem;margin-bottom:.6rem}
.feature-card p{font-size:.97rem}

/* ---------- Two ways ---------- */
.ways-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.way-card{
  background:#fff;border:1px solid var(--border);border-top:4px solid var(--royal);
  border-radius:var(--radius);box-shadow:var(--shadow-card);padding:2rem;
  display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s;
}
.way-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}
.way-card.digital{border-top-color:var(--teal)}
.way-pill{
  align-self:flex-start;font-size:.72rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:.32rem .7rem;border-radius:999px;margin-bottom:1rem;
}
.way-pill.phys{background:rgba(1,98,232,.10);color:var(--royal)}
.way-pill.dig{background:rgba(0,210,188,.18);color:#0a6b62}
.way-card h3{font-size:1.5rem;margin-bottom:.45rem}
.way-card>p{margin-bottom:1.1rem}
.way-points{list-style:none;margin-bottom:1.5rem}
.way-points li{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.6rem;font-size:.97rem}
.way-points li::before{content:"";flex:0 0 9px;width:9px;height:9px;border-radius:50%;margin-top:.5rem;background:var(--royal)}
.way-card.digital .way-points li::before{background:var(--teal)}
.way-card .btn{margin-top:auto;align-self:flex-start}

/* ---------- Kits / shop preview ---------- */
.kits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.kit-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-card);overflow:hidden;display:flex;flex-direction:column;
  transition:box-shadow .2s,transform .2s;
}
.kit-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}
.kit-card .kit-img{aspect-ratio:4/3;width:100%;object-fit:cover;background:var(--soft)}
.kit-body{padding:1.4rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.kit-body h3{font-size:1.2rem}
.kit-price{font-size:1.15rem;font-weight:800;color:var(--ink)}
.kit-meta{font-size:.82rem;color:var(--slate-light)}
.kit-body .btn{margin-top:auto;justify-content:center}

/* ---------- NestProtect supporting callout ---------- */
.app-callout{
  display:grid;grid-template-columns:1.05fr 1fr;gap:0;border-radius:1rem;overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--shadow-card);background:#fff;
}
.app-callout .app-copy{padding:2.6rem;display:flex;flex-direction:column;justify-content:center}
.app-callout .app-copy .eyebrow{color:var(--teal)}
.app-callout h2{font-size:clamp(1.6rem,2.6vw,2.1rem);margin-bottom:.8rem}
.app-callout ul{list-style:none;margin:.4rem 0 1.4rem}
.app-callout li{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.55rem;font-size:.98rem}
.app-callout li::before{content:"";flex:0 0 9px;width:9px;height:9px;border-radius:50%;background:var(--teal);margin-top:.5rem}
.app-callout .app-media{background:var(--grad-cool);display:flex;align-items:center;justify-content:center;padding:1.5rem}
.app-callout .app-media img{border-radius:.75rem;width:100%;max-width:380px;box-shadow:0 8px 30px rgba(8,24,66,.25)}

/* ---------- Rebuild / testimonial ---------- */
.rebuild{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.video-thumb{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);cursor:pointer}
.video-thumb img{width:100%;aspect-ratio:16/12;object-fit:cover}
.video-thumb .play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(11,31,77,.05),rgba(11,31,77,.35));
}
.video-thumb .play span{
  width:74px;height:74px;border-radius:50%;background:rgba(255,255,255,.92);
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(8,24,66,.3);
  transition:transform .18s;
}
.video-thumb:hover .play span{transform:scale(1.07)}
.video-thumb .play span::after{content:"";margin-left:5px;border-style:solid;border-width:13px 0 13px 21px;border-color:transparent transparent transparent var(--royal)}
.quote{
  border-left:3px solid var(--royal);background:var(--soft);
  padding:1.2rem 1.4rem;border-radius:0 .5rem .5rem 0;margin-top:1.4rem;
}
.quote p{font-style:italic;color:var(--slate);margin-bottom:.4rem}
.quote cite{font-style:normal;font-weight:700;color:var(--ink);font-size:.92rem}

/* ---------- Final CTA ---------- */
.cta-band{background:var(--grad-cool);color:#fff;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.5rem);margin-bottom:.7rem}
.cta-band p{color:#fff;font-size:1.1rem;max-width:560px;margin:0 auto 1.8rem;opacity:.95}
.cta-band .btn-primary{background:#fff;color:var(--royal);box-shadow:0 6px 22px rgba(8,24,66,.25)}
.cta-band .btn-primary:hover{color:var(--royal-dark)}
.cta-band .btn-ghost-light{border-color:#fff}

/* ---------- Footer ---------- */
.grad-strip{height:5px;background:var(--grad-cool)}
.site-footer{background:#fff;border-top:1px solid var(--border);padding:3rem 0 2.2rem}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:2rem;align-items:start}
.site-footer .brand img{height:50px}
.footer-about{margin-top:1rem;font-size:.92rem;max-width:330px}
.footer-col h4{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin-bottom:.9rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.55rem}
.footer-col a{color:var(--slate);font-size:.95rem}
.footer-col a:hover{color:var(--royal)}
.legal{margin-top:2.2rem;padding-top:1.4rem;border-top:1px solid var(--border);font-size:.84rem;color:var(--slate-light);line-height:1.7}
.legal strong{color:var(--slate)}

/* ---------- Sub-page hero ---------- */
.page-hero{background:var(--grad-cool);color:#fff;padding:3.6rem 0}
.page-hero .eyebrow{color:rgba(255,255,255,.9)}
.page-hero h1{color:#fff;font-size:clamp(2.1rem,4.5vw,3.2rem);font-weight:800;letter-spacing:-.01em;margin-bottom:.6rem;max-width:780px}
.page-hero p{color:#fff;font-size:1.15rem;max-width:660px;opacity:.96}
.page-hero .hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.6rem}
.page-hero .btn-primary{background:#fff;color:var(--royal);box-shadow:0 6px 22px rgba(8,24,66,.22)}
.page-hero .btn-primary:hover{color:var(--royal-dark)}
.page-hero .btn-ghost-light{border-color:#fff}

/* ---------- Figures & story ---------- */
.figure{margin:0}
.figure img{width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow-card)}
.figure figcaption{font-size:.85rem;color:var(--slate-light);font-style:italic;margin-top:.7rem;line-height:1.5}
.year-eyebrow{color:var(--teal)}
.split.reverse .media,.split.reverse .figure{order:2}
.split p:last-of-type{margin-bottom:0}
.pullquote{
  text-align:center;max-width:840px;margin:0 auto;padding:.5rem 0;
  font-size:clamp(1.35rem,2.6vw,1.85rem);line-height:1.42;font-weight:700;color:var(--royal);
}
.pullquote cite{display:block;font-style:normal;font-size:.95rem;font-weight:600;color:var(--slate-light);margin-top:1rem}
.nav-links a[aria-current="page"]{color:var(--royal)}

/* ---------- Impact report ---------- */
.reach-band{text-align:center;max-width:680px;margin:1.8rem auto 0;font-size:1.05rem;color:var(--slate)}
.report{max-width:780px;margin:0 auto}
.report h2{font-size:1.6rem;margin-bottom:.7rem}
.report h3{font-size:1.12rem;margin:1.3rem 0 .4rem;color:var(--ink)}
.report p{margin-bottom:1rem}
.report p:last-child{margin-bottom:0}
.report .attrib{font-weight:700;color:var(--ink)}
.report ul.ticks{list-style:none;margin:.3rem 0 1rem}
.report ul.ticks li{position:relative;padding-left:1.6rem;margin-bottom:.6rem}
.report ul.ticks li::before{content:"";position:absolute;left:0;top:.55rem;width:9px;height:9px;border-radius:50%;background:var(--teal)}

.cards-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;max-width:920px;margin:0 auto}

/* financials */
.fin{max-width:860px;margin:0 auto}
.fin-top{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.4rem}
.fin-stat{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.4rem 1.5rem}
.fin-stat .label{font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--slate-light)}
.fin-stat .value{font-size:1.9rem;font-weight:800;color:var(--royal);margin-top:.25rem}
.fin-bars{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.7rem}
.fin-bars h3{margin:0 0 1.1rem;font-size:1.05rem;color:var(--ink)}
.fin-row{margin-bottom:1.1rem}
.fin-row .top{display:flex;justify-content:space-between;font-size:.92rem;font-weight:600;color:var(--slate);margin-bottom:.4rem}
.fin-row .top b{color:var(--ink)}
.track{height:12px;border-radius:999px;background:#eef1f4;overflow:hidden}
.fill{height:100%;border-radius:999px;background:var(--grad-cool)}
.fill.alt{background:var(--teal)}
.efficiency{margin-top:1.4rem;text-align:center;background:var(--grad-cool);color:#fff;border-radius:var(--radius);padding:1.3rem 1.5rem}
.efficiency .big{font-size:2rem;font-weight:800;line-height:1}
.efficiency p{margin:.35rem 0 0;color:#fff;opacity:.95;font-size:.98rem}

/* acknowledgements */
.partners{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;max-width:840px;margin:0 auto}
.partner{background:#fff;border:1px solid var(--border);border-radius:999px;padding:.7rem 1.4rem;font-weight:600;color:var(--ink);box-shadow:var(--shadow-card);font-size:.95rem}

/* ---------- Reveal animation ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(16px);animation:rise .7s ease forwards}
  .reveal.d1{animation-delay:.08s}.reveal.d2{animation-delay:.16s}
  .reveal.d3{animation-delay:.24s}.reveal.d4{animation-delay:.32s}
  @keyframes rise{to{opacity:1;transform:none}}
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .nav-links{display:none}
  .menu-toggle{display:inline-flex}
  .stat-grid{grid-template-columns:repeat(3,1fr)}
  .split,.rebuild,.app-callout,.ways-grid{grid-template-columns:1fr;gap:2rem}
  .app-callout .app-media{order:-1}
  .cards-3,.kits-grid{grid-template-columns:1fr}
  .cards-2,.fin-top{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:1.6rem}
  .hero-inner{padding:4rem 0}
}
@media (max-width:560px){
  .stat-grid{grid-template-columns:1fr 1fr}
  .nav-actions .btn-secondary{display:none}
}
