/* ===========================================================
   The MISSION Nonprofit — site preview styles
   Brand: "Purple House" purple + teal window-trim accent + warm gold CTA
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --purple-900:#34185c;
  --purple-700:#5b2a86;
  --purple-500:#7a4bb0;
  --purple-300:#b692dd;
  --purple-100:#ede3f8;
  --teal:#1aa99a;
  --teal-dark:#138577;
  --gold:#f4a300;
  --gold-dark:#d98c00;
  --ink:#241b33;
  --muted:#6b6478;
  --line:#e7e1f0;
  --bg:#fbf9fe;
  --card:#ffffff;
  --shadow:0 10px 30px rgba(52,24,92,.10);
  --shadow-sm:0 4px 14px rgba(52,24,92,.08);
  --radius:18px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;line-height:1.12;font-weight:600;color:var(--purple-900)}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.6rem)}
h3{font-size:1.3rem}
a{color:var(--purple-700);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1140px;margin:0 auto;padding:0 22px}
.section{padding:74px 0}
.section.tight{padding:50px 0}
.center{text-align:center}
.lead{font-size:1.18rem;color:var(--muted);max-width:680px}
.eyebrow{font-family:'Inter';font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  font-size:.78rem;color:var(--teal-dark);margin-bottom:12px}

/* buttons */
.btn{display:inline-block;font-weight:600;font-family:'Inter';padding:14px 28px;border-radius:999px;
  transition:transform .15s ease,box-shadow .15s ease;cursor:pointer;border:none;font-size:1rem}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#3a2600;box-shadow:0 8px 20px rgba(244,163,0,.35)}
.btn-gold:hover{background:var(--gold-dark)}
.btn-purple{background:var(--purple-700);color:#fff;box-shadow:0 8px 20px rgba(91,42,134,.3)}
.btn-purple:hover{background:var(--purple-900)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7)}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-outline{background:transparent;color:var(--purple-700);border:2px solid var(--purple-300)}
.btn-outline:hover{background:var(--purple-100)}

/* ---------- NAV (applied to all pages) ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(251,249,254,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:0 22px;max-width:1140px;margin:0 auto}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:46px;width:auto;display:block}
.brand-icon{height:76px;width:auto;display:block;flex:none}
.brand-words{display:flex;flex-direction:column;line-height:1.02}
.bw-top{font-family:'Fraunces',serif;font-weight:700;font-size:1.5rem;color:var(--purple-900);letter-spacing:.01em}
.bw-the{font-size:.62em;font-weight:600;color:var(--muted);font-family:'Inter',sans-serif}
.bw-np{font-family:'Inter',sans-serif;font-weight:700;letter-spacing:.34em;text-transform:uppercase;
  font-size:.66rem;color:var(--teal-dark);margin-top:3px}
.brand-tag{font-family:'Inter';font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  font-size:.72rem;color:var(--teal-dark);align-self:center}
.brand-mark{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--purple-700),var(--teal));
  display:grid;place-items:center;color:#fff;font-family:'Fraunces';font-weight:700;font-size:1.25rem;flex:none}
.footer-logo{height:64px;width:auto;margin-bottom:14px;display:block}
.brand-name{font-family:'Fraunces';font-weight:700;color:var(--purple-900);font-size:1.16rem;line-height:1.05}
.brand-name small{display:block;font-family:'Inter';font-weight:500;font-size:.66rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--teal-dark)}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.nav-links a{padding:9px 14px;border-radius:10px;color:var(--ink);font-weight:500;font-size:.96rem}
.nav-links a:hover{background:var(--purple-100);color:var(--purple-900)}
.nav-links a.active{color:var(--purple-700);font-weight:700}
.nav-cta{margin-left:8px}
.nav-toggle{display:none;background:none;border:none;font-size:1.6rem;color:var(--purple-700);cursor:pointer}

/* ---------- HERO ---------- */
.hero{position:relative;color:#fff;text-align:center;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(52,24,92,.55),rgba(52,24,92,.78))}
.hero-content{position:relative;padding:120px 22px;max-width:860px;margin:0 auto}
.hero h1{color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.25)}
.hero p{font-size:1.25rem;margin:20px auto 32px;max-width:640px;color:rgba(255,255,255,.94)}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.page-hero{background:linear-gradient(135deg,var(--purple-900),var(--purple-700));color:#fff;text-align:center;padding:86px 22px}
.page-hero h1{color:#fff}
.page-hero p{color:rgba(255,255,255,.9);font-size:1.15rem;max-width:640px;margin:16px auto 0}

/* ---------- cards / grids ---------- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;
  border:1px solid var(--line);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-body{padding:22px}
.card h3{margin-bottom:8px}
.card p{color:var(--muted);font-size:.97rem}
.icon-chip{width:50px;height:50px;border-radius:14px;background:var(--purple-100);color:var(--purple-700);
  display:grid;place-items:center;font-size:1.5rem;margin-bottom:14px}

.initiative{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 18px 18px 18px;
  display:flex;gap:12px;align-items:flex-start;box-shadow:var(--shadow-sm)}
.initiative .dot{color:var(--teal);font-size:1.2rem;flex:none;margin-top:2px}
.initiative b{display:block;color:var(--purple-900);font-family:'Fraunces'}

/* media row */
.media-row{display:grid;grid-template-columns:1.15fr 1fr;gap:40px;align-items:center}
.media-row img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:100%;object-fit:cover;max-height:420px}

/* testimony */
.quote{background:linear-gradient(135deg,var(--purple-100),#fff);border-left:5px solid var(--teal);
  border-radius:14px;padding:26px 28px;box-shadow:var(--shadow-sm)}
.quote p{font-family:'Fraunces';font-size:1.18rem;font-style:italic;color:var(--purple-900);margin-bottom:10px}
.quote span{font-weight:600;color:var(--muted);font-size:.92rem}

/* bands */
.band{background:linear-gradient(135deg,var(--purple-700),var(--teal-dark));color:#fff;text-align:center;padding:64px 22px}
.band h2{color:#fff}
.band p{color:rgba(255,255,255,.92);max-width:620px;margin:14px auto 26px;font-size:1.12rem}
.band-gold{background:linear-gradient(135deg,#fff6e3,#fff);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* stat / meter */
.meter-box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.meter{height:26px;border-radius:999px;background:var(--purple-100);overflow:hidden;margin:16px 0 8px}
.meter > span{display:block;height:100%;width:62%;background:linear-gradient(90deg,var(--teal),var(--gold));border-radius:999px}
.meter-num{font-family:'Fraunces';font-size:2rem;color:var(--purple-900);font-weight:700}

/* donor lists */
.donor-cat{margin-bottom:8px;color:var(--teal-dark);font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.82rem}
.donor-list{list-style:none}
.donor-list li{padding:10px 0;border-bottom:1px dashed var(--line);font-weight:500}
.donor-list li:last-child{border-bottom:none}

/* timeline */
.timeline{position:relative;max-width:780px;margin:0 auto;padding-left:34px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:3px;
  background:linear-gradient(var(--purple-300),var(--teal))}
.tl-item{position:relative;margin-bottom:34px}
.tl-item::before{content:"";position:absolute;left:-34px;top:4px;width:20px;height:20px;border-radius:50%;
  background:#fff;border:4px solid var(--teal)}
.tl-year{font-family:'Fraunces';font-weight:700;color:var(--purple-700);font-size:1.15rem}
.tl-item p{color:var(--muted);margin-top:4px}

/* TEMPLATE placeholder styling */
.tpl{border:2px dashed var(--purple-300);background:repeating-linear-gradient(45deg,#faf5ff,#faf5ff 12px,#f3ebfd 12px,#f3ebfd 24px);
  border-radius:var(--radius);position:relative}
.tpl::after{content:"TEMPLATE — add your content";position:absolute;top:10px;right:14px;
  background:var(--purple-700);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.08em;
  padding:4px 10px;border-radius:999px;text-transform:uppercase}
.tpl-note{color:var(--purple-700);font-weight:600;font-size:.92rem}
.placeholder-img{background:var(--purple-100);border-radius:14px;display:grid;place-items:center;
  color:var(--purple-500);min-height:180px;font-weight:600;text-align:center;border:2px dashed var(--purple-300)}
.qr-ph{width:120px;height:120px;border-radius:12px;background:#fff;border:2px dashed var(--purple-300);
  display:grid;place-items:center;color:var(--purple-500);font-size:.8rem;font-weight:600;text-align:center}

/* footer */
.footer{background:var(--purple-900);color:#cdbfe4;padding:54px 22px 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;max-width:1140px;margin:0 auto}
.footer h4{color:#fff;font-size:1.2rem;margin-bottom:10px}
.footer a{color:#e3d7f5}
.footer a:hover{color:#fff}
.footer .muted{color:#a995c9;font-size:.92rem}
.footer ul{list-style:none}
.footer li{margin:7px 0;font-size:.95rem}
.footer-bottom{text-align:center;margin-top:34px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);
  color:#a995c9;font-size:.86rem}
.fb-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);
  padding:8px 14px;border-radius:999px;color:#fff;margin-top:6px}

/* preview banner */
.preview-flag{background:var(--ink);color:#fff;text-align:center;font-size:.82rem;padding:7px 14px;font-weight:500}
.preview-flag b{color:var(--gold)}

@media(max-width:900px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .media-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{display:none;position:absolute;top:70px;left:0;right:0;background:#fff;flex-direction:column;
    padding:14px 22px;box-shadow:var(--shadow);border-bottom:1px solid var(--line)}
  .nav-links.open{display:flex}
  .nav-links a{width:100%}
  .nav-toggle{display:block}
  .grid-3,.grid-4,.grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-content{padding:80px 18px}
}
