/* The Richest Man in Heaven — wealth-portal styling (blue/white). */
:root{
  --blue:#2563eb; --navy:#1e3a8a; --navy-d:#0b1f4d; --ink:#1f2937;
  --muted:#6b7280; --line:#e5e7eb; --bg:#f5f7fb; --card:#ffffff;
  --ok:#16a34a; --warn:#b45309; --gold:#c79a3a;
  --radius:16px; --shadow:0 6px 24px rgba(16,38,90,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3{color:var(--navy);line-height:1.2}
h2{font-size:1.5rem;margin:6px 0 12px}
h3{font-size:1.1rem;margin:0 0 8px}
a{color:var(--blue);text-decoration:none}
.muted{color:var(--muted)}
.small{font-size:.85rem}
.lead{font-size:1.25rem;color:var(--navy);font-weight:600}
.crown{color:var(--gold)}
.warn-text{color:var(--warn)}

/* buttons */
.btn{background:var(--blue);color:#fff;border:0;border-radius:12px;padding:11px 18px;
  font-size:1rem;font-weight:600;cursor:pointer;transition:filter .15s}
.btn:hover{filter:brightness(1.07)}
.btn:disabled{opacity:.6;cursor:default}
.btn.ghost{background:#eef2fb;color:var(--navy)}
.btn.full{width:100%}
.link{background:none;border:0;color:var(--blue);cursor:pointer;font-size:.92rem;padding:4px 6px}
.row{display:flex;gap:10px;align-items:center}
.row.end{justify-content:flex-end;margin-top:14px}
.row.between{justify-content:space-between}

/* layout chrome */
.app-head{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;
  background:linear-gradient(120deg,var(--navy),var(--navy-d));color:#fff;padding:12px 16px;box-shadow:var(--shadow)}
.brand{font-weight:700;letter-spacing:.2px}
.app-head .brand{color:#fff}
.menu-btn{display:none;background:none;border:0;color:#fff;font-size:1.4rem;cursor:pointer}
.topnav{display:flex;gap:4px;flex-wrap:wrap;margin-left:auto}
.topnav a{color:#cfe0ff;padding:7px 10px;border-radius:9px;font-size:.92rem}
.topnav a:hover{background:rgba(255,255,255,.1)}
.topnav a.active{background:#fff;color:var(--navy);font-weight:600}
.drawer{display:none}
.view{max-width:820px;margin:0 auto;padding:18px 16px 60px}
.app-foot{max-width:820px;margin:0 auto;padding:18px 16px 40px;color:var(--muted);font-size:.85rem;border-top:1px solid var(--line)}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;margin:14px 0;box-shadow:var(--shadow)}
.eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}

/* hero balance */
.hero-card{background:linear-gradient(135deg,var(--navy),var(--navy-d));color:#fff;border:0;
  border-radius:var(--radius);padding:22px;margin:14px 0;box-shadow:var(--shadow)}
.hero-top{display:flex;justify-content:space-between;align-items:center}
.hero-card .eyebrow{color:#aac4ff}
.rate-pill{background:rgba(255,255,255,.16);padding:5px 11px;border-radius:20px;font-size:.8rem;font-weight:600}
.balance{font-size:2.8rem;font-weight:800;margin:6px 0 2px;letter-spacing:-.5px}
.subbal{color:#cfe0ff;font-size:.95rem}
.chart{width:100%;height:200px;display:block;margin-top:10px}
.proj-line{color:#dbe7ff;font-size:.95rem;margin-top:6px}

/* scripture */
.scripture blockquote{font-family:Georgia,serif;font-size:1.18rem;color:var(--navy);margin:8px 0;border:0}
.scripture cite{color:var(--muted);font-style:normal;font-weight:600}
.trey-note{background:#f3f6fd;border-left:3px solid var(--blue);padding:10px 14px;border-radius:8px;margin-top:10px}
.trey-note .sign{color:var(--muted);font-style:italic}
.sign{display:block;margin-top:6px;color:var(--muted);font-style:italic}

/* quick actions */
.quick-row{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0}

/* gift list */
.gift-list{list-style:none;margin:0;padding:0}
.gift-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}
.gift-row:last-child{border-bottom:0}
.g-amt{font-weight:700;color:var(--navy);font-size:1.05rem}
.g-meta{display:block;color:var(--muted);font-size:.85rem}
.tag{background:#eef2fb;color:var(--navy);border-radius:6px;padding:1px 6px;font-size:.75rem}
.g-actions{display:flex;gap:2px}

/* chips & impact */
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{background:#f3f6fd;border-radius:12px;padding:10px 14px;text-align:center;min-width:84px}
.chip b{display:block;font-size:1.4rem;color:var(--navy)}
.chip span{font-size:.8rem;color:var(--muted)}
.impact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.impact-card{background:#f3f6fd;border-radius:12px;padding:16px;text-align:center}
.impact-card b{display:block;font-size:2rem;color:var(--navy)}
.impact-card i{display:block;color:var(--muted);font-size:.78rem;font-style:normal;margin-top:4px}
.impact-card.off b{color:#aab4c8}

/* invite/empty */
.invite{background:linear-gradient(135deg,#eef3ff,#fff);border-color:#d7e2ff}

/* goals */
.progress{background:#eef2fb;border-radius:20px;height:16px;overflow:hidden;margin:6px 0}
.progress .bar{background:var(--blue);height:100%;border-radius:20px;transition:width .4s}
.meter{display:flex;gap:8px;margin:10px 0;flex-wrap:wrap}
.meter .dot{padding:6px 12px;border-radius:20px;background:#eef2fb;color:var(--muted);font-size:.85rem;font-weight:600}
.meter.growing .dot.growing{background:#fde9c8;color:var(--warn)}
.meter.returning .dot.returning{background:#dbeafe;color:var(--navy)}
.meter.generous .dot.generous{background:#dcfce7;color:var(--ok)}
.meter-status{font-size:1.05rem}

/* streaks */
.streak-card{text-align:center}
.streak-num{font-size:3.4rem;font-weight:800;color:var(--blue)}
.streak-label{color:var(--muted);font-weight:600}
.badge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.badge{background:#f3f6fd;border-radius:12px;padding:14px;text-align:center;font-size:.85rem}
.badge .medal{display:block;font-size:1.8rem;margin-bottom:4px}
.badge.locked{opacity:.5}
.badge.earned{background:#fff7e6;border:1px solid #f0d9a8}

/* analytics */
.stat-row{display:flex;justify-content:space-around;flex-wrap:wrap;gap:14px}
.stat{text-align:center}
.stat b{display:block;font-size:1.4rem;color:var(--navy)}
.stat span{color:var(--muted);font-size:.85rem}

/* legacy */
.legacy{background:linear-gradient(135deg,#fff,#f3f6fd)}
.legacy-num{font-size:2.4rem;font-weight:800;color:var(--navy);margin:8px 0 2px}

/* devotional */
.dev.done{border-color:#bfe6c9;background:#f4fbf6}
.dev blockquote{font-family:Georgia,serif;color:var(--navy);margin:8px 0;border:0}

/* desk */
.sec{margin:22px 0 4px;border-bottom:2px solid var(--line);padding-bottom:6px}
.desk-list{list-style:none;margin:0;padding:0}
.desk-list li{padding:12px 0;border-bottom:1px solid var(--line)}
.desk-list li span{display:block;color:var(--muted);font-size:.9rem}
.word .sign{margin-top:8px}

/* forms */
label{display:block;margin:10px 0;font-weight:600;color:var(--ink);font-size:.92rem}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;
  font-size:1rem;font-family:inherit;margin-top:4px;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid var(--blue);border-color:var(--blue)}
.ck{display:flex;align-items:center;gap:8px;font-weight:500}
.ck input{width:auto;margin:0}

/* modal */
.modal-wrap{position:fixed;inset:0;background:rgba(11,31,77,.45);display:flex;align-items:center;
  justify-content:center;z-index:50;padding:16px}
.modal{background:#fff;border-radius:var(--radius);max-width:480px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0}
.modal-head .x{background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--muted);line-height:1}
.modal-body{padding:18px}

/* txn import */
.txn-list{list-style:none;margin:8px 0;padding:0;max-height:300px;overflow:auto}
.txn{padding:10px;border-bottom:1px solid var(--line)}
.txn.is-gift{background:#f4fbf6}
.txn .ck{font-weight:600}

/* admin */
.admin-tabs{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0}
.admin-tabs .tab{background:#eef2fb;border:0;border-radius:9px;padding:8px 12px;cursor:pointer;font-weight:600;color:var(--navy)}
.admin-tabs .tab.active{background:var(--blue);color:#fff}
.adm-list{list-style:none;margin:12px 0;padding:0}
.adm-row{display:flex;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;background:#fff}
.adm-text{color:var(--muted);font-size:.9rem;margin-top:4px}

/* auth */
#auth-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;
  background:linear-gradient(160deg,var(--navy),var(--navy-d));color:#fff}
.auth-head{padding:28px}
.auth-head .brand{font-size:1.2rem}
.auth-main{flex:1;display:flex;align-items:center;justify-content:center;width:100%;padding:16px}
.auth-card{background:#fff;color:var(--ink);border-radius:var(--radius);padding:26px;max-width:380px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.auth-card h2{margin-top:0}
.auth-links{display:flex;justify-content:space-between;margin-top:12px}
.auth-tag{font-family:Georgia,serif;font-style:italic;padding:0 16px 30px;text-align:center;color:#aac4ff;max-width:480px}

/* toast */
#toast-host{position:fixed;bottom:18px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:80;pointer-events:none}
.toast{background:var(--navy);color:#fff;padding:11px 18px;border-radius:12px;box-shadow:var(--shadow);
  opacity:0;transform:translateY(12px);transition:all .3s;max-width:90%}
.toast.show{opacity:1;transform:translateY(0)}
.toast.warn{background:var(--warn)}
.toast.ok{background:var(--ok)}

/* offline */
.offline-banner{background:var(--warn);color:#fff;text-align:center;padding:8px;font-size:.9rem}

/* story / disclosures */
.story p,.disclosures p{margin:10px 0}

/* responsive */
@media (max-width:760px){
  .menu-btn{display:block}
  .topnav{display:none}
  .drawer{display:flex;flex-direction:column;position:fixed;top:54px;left:0;right:0;background:var(--navy-d);
    z-index:19;max-height:0;overflow:hidden;transition:max-height .25s}
  .drawer.open{max-height:80vh;padding:8px 0}
  .drawer a{color:#cfe0ff;padding:13px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
  .drawer a.active{background:rgba(255,255,255,.12);color:#fff;font-weight:600}
  .balance{font-size:2.2rem}
}

/* ============================================================
   LANDING PAGE + DEMO + DASHBOARD POLISH
   ============================================================ */

/* hero */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;justify-content:center;
  overflow:hidden;color:#fff;text-align:center}
.slides{position:absolute;inset:0;z-index:0}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease-in-out}
.slide.active{opacity:1}
.slide img{width:100%;height:100%;object-fit:cover;display:block}
/* elegant wealth-portal gradient fallbacks (show until Higgsfield images load) */
.slide-1{background:radial-gradient(120% 120% at 30% 20%,#1e3a8a 0%,#0b1f4d 60%,#060f2b 100%)}
.slide-2{background:radial-gradient(120% 120% at 70% 30%,#23489f 0%,#0d2350 55%,#070d24 100%)}
.slide-3{background:linear-gradient(135deg,#0b1f4d 0%,#1e3a8a 50%,#2a5298 100%)}
.slide-4{background:radial-gradient(100% 100% at 50% 0%,#2a4ba0 0%,#11265a 55%,#0a1530 100%)}
.slide-1::after,.slide-2::after,.slide-3::after,.slide-4::after{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 50% at 50% 35%,rgba(199,154,58,.22),transparent 70%)}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(7,15,40,.35),rgba(7,15,40,.72))}
.hero-inner{position:relative;z-index:2;max-width:760px;padding:40px 22px}
.wordmark{font-weight:700;letter-spacing:.4px;color:#dbe7ff;margin-bottom:18px;font-size:1.05rem}
.hero h1{color:#fff;font-size:clamp(2.4rem,6vw,4rem);margin:6px 0;letter-spacing:-1px;line-height:1.05}
.hero-sub{color:#dbe7ff;font-size:clamp(1.05rem,2.5vw,1.3rem);max-width:600px;margin:14px auto 22px}
.hero-cta{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}
.hero-cta.center{margin-top:18px}
.hero-foot{color:#aac4ff;font-size:.9rem;margin-top:22px;font-style:italic}
.btn.big{padding:14px 26px;font-size:1.05rem;border-radius:14px}
.btn.ghost-light{background:rgba(255,255,255,.14);color:#fff;backdrop-filter:blur(4px)}
.link.light{color:#dbe7ff}
.btn.small{padding:7px 13px;font-size:.85rem;border-radius:9px}

/* landing sections */
.lp-sec{max-width:920px;margin:0 auto;padding:56px 20px;text-align:center}
.lp-sec.alt{background:#fff;max-width:none}
.lp-sec.alt>*{max-width:920px;margin-left:auto;margin-right:auto}
.lp-sec h2,.lp-cta h2,.lp-band h2{font-size:clamp(1.6rem,4vw,2.2rem);margin-bottom:10px}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:24px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.step .num{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;
  background:var(--blue);color:#fff;font-weight:700;font-size:1.1rem;margin-bottom:10px}
.step h4{color:var(--navy);margin:6px 0}
.step p{color:var(--muted);margin:0}
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin-top:24px;text-align:left}
.feat{background:#f3f6fd;border-radius:14px;padding:20px}
.feat h4{color:var(--navy);margin:0 0 6px}
.feat p{color:var(--muted);margin:0}
.ten-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;
  margin:24px auto 0;padding:0;max-width:760px;text-align:left}
.ten-list li{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 16px;font-weight:600;color:var(--navy)}
.ten-list li::before{content:"✦ ";color:var(--gold)}
.lp-band{background:linear-gradient(135deg,var(--navy),var(--navy-d));color:#fff;text-align:center;padding:60px 20px}
.lp-band h2{color:#fff}
.lp-band p{max-width:680px;margin:10px auto 0;color:#dbe7ff;font-size:1.1rem}
.lp-sec.story .lead{font-family:Georgia,serif;font-size:1.4rem;color:var(--navy)}
.lp-sec.story p{max-width:720px;margin:12px auto;color:var(--ink);text-align:left}
.lp-cta{text-align:center;padding:60px 20px;background:#f3f6fd}
.lp-foot{text-align:center;padding:28px 20px;color:var(--muted);font-size:.9rem;background:#fff;border-top:1px solid var(--line)}
.link.back{display:block;margin-top:14px;color:var(--muted)}

/* demo banner */
.demo-banner{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:center;gap:14px;
  flex-wrap:wrap;background:linear-gradient(90deg,var(--gold),#d9b65a);color:#3a2a00;padding:9px 14px;font-weight:600;font-size:.92rem}
.demo-banner .btn{background:#1e3a8a;color:#fff}

/* dashboard polish — portfolio summary row */
.summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin:14px 0}
.sum{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow)}
.sum b{display:block;font-size:1.35rem;color:var(--navy)}
.sum span{color:var(--muted);font-size:.82rem}
.sum .up{color:var(--ok);font-size:.82rem;font-weight:600}

@media (max-width:760px){
  .hero{min-height:80vh}
  .hero-cta .btn.big{width:100%}
}
@media (prefers-reduced-motion: reduce){
  .slide{transition:none}
}

/* public about/disclosures (logged-out) */
.public-page{max-width:820px;margin:0 auto;padding:28px 18px 60px}

/* ===== Password gate (demo.jeremydudley.com only) ===== */
body.gated{overflow:hidden}
.gate{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,#1e3a8a,#0b1f4d);padding:20px}
.gate-card{background:#fff;color:#1f2937;border-radius:18px;padding:30px 26px;max-width:380px;width:100%;
  text-align:center;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.gate-mark{font-weight:700;color:#1e3a8a;letter-spacing:.3px;margin-bottom:14px}
.gate-card h1{color:#1e3a8a;font-size:1.5rem;margin:6px 0}
.gate-card p{color:#6b7280;margin:6px 0 16px}
.gate-card input{width:100%;padding:12px 14px;border:1px solid #e5e7eb;border-radius:10px;font-size:1rem;margin-bottom:12px}
.gate-card input:focus{outline:2px solid #2563eb;border-color:#2563eb}
.gate-err{color:#b45309;font-size:.9rem;margin-top:10px}
