/* ===================== Kureghar — design tokens ===================== */
:root{
  --bg:#FAF6EF; --card:#fff; --text:#3A342B; --text-soft:#5C5342; --text-muted:#7A705C; --text-mute2:#8A8071;
  --border:#EDE4D3; --border-strong:#E2D8C4; --placeholder:#B4A88F;
  --gold:#C9962E; --gold-hover:#B5851F; --gold-bg:#F1E7D2; --gold-text:#9A7B2E;
  --green:#6F8F5E; --green-bg:#E7EDE2; --green-dark:#3F5136; --green-body:#4C5C41;
  --blue:#6B8FAD; --blue-bg:#E4EBF1;
  --dark:#3F3829; --cream:#FFF8EA;
  --wall:#F3EBDC; --roof:#A9714E; --door:#7A5A3A; --window:#CFE0EA;
  --brick1:#C98A63; --brick2:#C27F58; --brick3:#D2946E; --brick4:#BE7F55; --brick-empty-border:#DCCFB6;
  --completed-bg:#F2F5EF; --completed-border:#DCE5D6;
  --radius-pill:99px;
  --font-body:'Nunito Sans','Noto Sans Bengali',sans-serif;
  --font-serif:'Lora','Noto Sans Bengali',serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-body);overflow-x:hidden;min-height:100vh;display:flex;flex-direction:column}
input,textarea,button,select{font-family:inherit}
::placeholder{color:var(--placeholder)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{border:none;background:none;cursor:pointer;color:inherit}
[hidden]{display:none!important}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.35}}
.fade-up{animation:fadeUp .5s ease both}
.fade-up-delay{animation:fadeUp .5s .1s ease both}
.pulse-dot{animation:livePulse 1.6s infinite}

.container{max-width:1200px;margin:0 auto;padding:0 32px}
.container-narrow{max-width:900px;margin:0 auto;padding:0 32px}
.container-md{max-width:960px;margin:0 auto;padding:0 32px}
.container-sm{max-width:860px;margin:0 auto;padding:0 32px}
.container-donors{max-width:1100px;margin:0 auto;padding:0 32px}
.container-narrower{max-width:800px;margin:0 auto;padding:0 32px}

h1,h2,h3,h4{font-family:var(--font-serif);font-weight:600;margin:0}
p{margin:0}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(250,246,239,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.nav-inner{padding:14px 32px;display:flex;align-items:center;gap:26px}
.brand{display:flex;align-items:center;gap:10px;cursor:pointer}
.brand-mark{width:38px;height:38px;border-radius:11px;background:var(--gold);display:flex;align-items:center;justify-content:center;flex-direction:column;flex:none}
.brand-mark .roof{width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:8px solid var(--cream)}
.brand-mark .wall{width:13px;height:9px;background:var(--cream);border-radius:0 0 2px 2px;margin-top:1px}
.brand-name{font-family:var(--font-serif);font-weight:700;font-size:21px}
.nav-links{display:flex;justify-content:center;gap:32px;flex:1;flex-wrap:wrap;list-style:none;margin:0;padding:0}
.nav-links a{cursor:pointer;font-size:15.5px;font-weight:800;color:var(--text);padding:4px 0;border-bottom:2px solid transparent;transition:color .15s}
.nav-links a:hover,.nav-links a.active{color:var(--gold-hover)}
.nav-links a.active{border-bottom-color:var(--gold)}
.lang-btn{cursor:pointer;font-size:13px;font-weight:700;color:var(--text-mute2);border:1px solid var(--border-strong);border-radius:var(--radius-pill);padding:6px 13px;background:#fff;transition:.15s}
.lang-btn:hover{color:var(--text);border-color:var(--gold)}
.nav-spacer{height:68px}
.menu-toggle{display:none}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-weight:800;border-radius:14px;padding:13px 24px;font-size:15px;transition:.15s;white-space:nowrap;border:none}
.btn-primary{background:var(--gold);color:var(--cream);box-shadow:0 2px 8px rgba(201,150,46,.3)}
.btn-primary:hover{background:var(--gold-hover)}
.btn-outline{background:#fff;border:1.5px solid var(--border-strong);color:var(--text)}
.btn-outline:hover{border-color:var(--gold)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:#5E7C4E}
.btn-pill{border-radius:var(--radius-pill)}
.btn-sm{padding:10px 18px;font-size:13.5px;border-radius:11px}
.btn-block{width:100%}
.btn:disabled{opacity:.6;cursor:default}

/* ---------- Cards & sections ---------- */
.card{background:#fff;border:1px solid var(--border);border-radius:20px}
.section{padding:60px 32px}
.section-tight{padding:0 32px 70px}
.eyebrow{display:inline-block;background:var(--gold-bg);color:var(--gold-text);font-weight:700;font-size:13px;padding:6px 14px;border-radius:var(--radius-pill)}
.badge-verified{display:inline-block;font-size:12px;font-weight:800;color:var(--green);background:var(--green-bg);padding:5px 13px;border-radius:var(--radius-pill)}
.badge-chip{font-size:11.5px;font-weight:800;padding:3px 10px;border-radius:var(--radius-pill)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden}
.hero .glow-1{position:absolute;top:-120px;right:-100px;width:380px;height:380px;border-radius:99px;background:radial-gradient(circle,#F1E7D2 0%,rgba(241,231,210,0) 70%)}
.hero .glow-2{position:absolute;bottom:-160px;left:-120px;width:420px;height:420px;border-radius:99px;background:radial-gradient(circle,#E7EDE2 0%,rgba(231,237,226,0) 70%)}
.hero-grid{padding:64px 32px 60px;display:grid;grid-template-columns:1.15fr 1fr;gap:56px;align-items:center;position:relative}
.hero-title{font-size:48px;line-height:1.14;text-wrap:pretty}
.hero-sub{font-size:17.5px;line-height:1.65;color:var(--text-muted);margin-top:18px;max-width:540px}
.hero-actions{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.hero-features{display:flex;gap:20px;margin-top:34px;flex-wrap:wrap}
.hero-feature{display:flex;align-items:center;gap:8px}
.feature-check{width:20px;height:20px;border-radius:99px;background:var(--gold-bg);color:var(--gold-text);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;flex:none}
.feature-label{font-size:13.5px;font-weight:700;color:var(--text-soft)}

/* ---------- House / bricks visual ---------- */
.house-card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:26px;box-shadow:0 14px 36px rgba(90,75,50,.1)}
.house-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.house-card-title{font-family:var(--font-serif);font-size:16.5px;font-weight:600}
.live-flag{display:flex;align-items:center;gap:6px}
.live-dot{width:7px;height:7px;border-radius:99px;background:var(--green)}
.live-label{font-size:11px;font-weight:800;letter-spacing:.06em;color:var(--green)}
.house-wrap{display:flex;flex-direction:column;align-items:center}
.house{position:relative;width:230px}
.roof-shape{width:0;height:0;border-left:115px solid transparent;border-right:115px solid transparent;border-bottom:68px solid var(--roof);transition:opacity .6s}
.wall{position:relative;background:var(--wall);border-radius:0 0 10px 10px;padding:8px;display:grid;grid-template-columns:repeat(10,1fr);gap:3px}
.brick{height:13px;border-radius:2px;transition:background .45s,border-color .45s}
.brick.filled{border:1px solid rgba(255,255,255,.3)}
.brick.empty{background:transparent;border:1.5px dashed var(--brick-empty-border)}
.door{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);width:36px;height:52px;background:var(--door);border-radius:18px 18px 0 0;transition:opacity .6s}
.window{position:absolute;top:30px;width:25px;height:25px;background:var(--window);border:2.5px solid var(--door);border-radius:5px;transition:opacity .6s}
.window.left{left:26px}.window.right{right:26px}
.ground{height:8px;background:var(--border);border-radius:99px;margin-top:8px;filter:blur(1px)}
.house-progress{cursor:pointer;margin-top:16px;padding-top:14px;border-top:1px solid var(--border);transition:opacity .15s}
.house-progress:hover{opacity:.85}
.house-progress-head{display:flex;justify-content:space-between;align-items:baseline}
.progress-track{margin-top:9px;height:8px;background:var(--wall);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--gold),#E0AC3E);transition:width .6s ease}
.progress-foot{display:flex;justify-content:space-between;margin-top:8px;font-size:12.5px}

/* larger house (build page) */
.house-lg{position:relative;width:292px}
.house-lg .roof-shape{border-left-width:146px;border-right-width:146px;border-bottom-width:86px}
.house-lg .wall{border-radius:0 0 12px 12px;padding:10px;gap:4px}
.house-lg .brick{height:18px;border-radius:3px}
.house-lg .door{width:46px;height:66px;border-radius:23px 23px 0 0}
.house-lg .window{width:32px;height:32px;top:38px;border-radius:6px}
.house-lg .window.left{left:34px}.house-lg .window.right{right:34px}
.house-lg .ground{height:10px;margin-top:10px}

/* mini bricks (card) */
.bricks-mini{flex:none;background:var(--wall);border-radius:8px;padding:6px;display:grid;grid-template-columns:repeat(10,1fr);gap:2px;width:120px}
.bricks-mini .brick{height:8px}

/* ---------- Two cause cards ---------- */
.causes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.cause-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:16px;transition:transform .2s}
.cause-card:hover{transform:translateY(-4px)}
.cause-head{display:flex;align-items:center;gap:14px}
.cause-icon{width:52px;height:52px;border-radius:15px;display:flex;align-items:center;justify-content:center;flex-direction:column;flex:none}
.cause-icon.gold{background:var(--gold-bg)}
.cause-icon.green{background:var(--green-bg)}
.cause-title{font-family:var(--font-serif);font-size:21px;font-weight:600}
.cause-desc{font-size:13.5px;line-height:1.5;color:var(--text-muted);margin-top:2px}
.cause-stat{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:16px;display:flex;gap:16px;align-items:center}
.cause-actions{display:flex;gap:10px}

/* donut ring */
.donut{position:relative}
.donut-hole{position:absolute;border-radius:99px;background:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column}
.donut-pct{font-weight:800;font-family:var(--font-serif);color:var(--green)}

/* ---------- Trust / stat grids ---------- */
.trust-section{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:38px}
.trust-card{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:22px}
.trust-num{width:34px;height:34px;border-radius:99px;background:var(--gold-bg);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--gold-text);font-size:15px;margin-bottom:12px}
.trust-title{font-weight:800;font-size:15.5px}
.trust-desc{font-size:13.5px;line-height:1.55;color:var(--text-muted);margin-top:6px}

.recent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.recent-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;align-items:center;gap:14px}
.recent-dot{width:44px;height:44px;border-radius:99px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:17px;flex:none}
.recent-name{font-weight:800;font-size:15px}
.recent-sub{font-size:13px;color:var(--text-mute2);margin-top:2px}
.recent-badge{display:inline-block;margin-top:7px}

.cta-band{background:var(--dark);border-radius:24px;padding:52px;text-align:center;position:relative;overflow:hidden}
.cta-band .glow{position:absolute;top:-80px;right:-80px;width:220px;height:220px;border-radius:99px;background:radial-gradient(circle,rgba(201,150,46,.35),rgba(201,150,46,0) 70%)}
.cta-title{font-size:32px;color:var(--bg);position:relative;text-wrap:pretty}

/* ---------- Page headers ---------- */
.page-head{padding:44px 32px 0}
.page-title{font-size:40px;font-weight:600}
.page-sub{font-size:17px;color:var(--text-muted);margin-top:8px;max-width:600px}

/* ---------- Build a home page ---------- */
.build-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:36px;align-items:stretch}
.house-panel{background:#fff;border:1px solid var(--border);border-radius:22px;padding:34px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}
.completed-flag{position:absolute;top:20px;right:20px;background:var(--green);color:#fff;font-weight:800;font-size:13px;padding:7px 16px;border-radius:99px}
.house-pct{font-size:46px;font-weight:800;font-family:var(--font-serif);color:var(--gold)}
.house-sub{font-size:13.5px;color:var(--text-mute2);margin-bottom:22px}
.beneficiary-card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:32px;display:flex;flex-direction:column}
.beneficiary-name{font-family:var(--font-serif);font-size:28px;font-weight:600;margin-top:16px}
.beneficiary-loc{font-size:14.5px;color:var(--text-mute2);margin-top:3px}
.beneficiary-story{font-size:15px;line-height:1.6;color:var(--text-soft);margin-top:14px;flex:1}
.stat-grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px}
.stat-box{background:var(--bg);border-radius:12px;padding:12px}
.stat-label{font-size:12px;color:var(--text-mute2);font-weight:700}
.stat-value{font-weight:800;font-size:17px;margin-top:2px}
.stat-value.green{color:var(--green)}
.stat-value.gold{color:var(--gold)}
.beneficiary-actions{display:flex;gap:12px;margin-top:22px}

.board-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:26px;margin-top:26px}
.board-card{background:#fff;border:1px solid var(--border);border-radius:22px;padding:30px}
.board-title{font-family:var(--font-serif);font-size:23px;font-weight:600;margin-bottom:18px}
.board-list{display:flex;flex-direction:column;gap:10px}
.board-row{display:flex;align-items:center;gap:14px;background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:14px 18px}
.board-row.done{background:var(--completed-bg);border-color:var(--completed-border)}
.row-index{width:34px;height:34px;border-radius:99px;background:var(--gold-bg);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--gold-text);flex:none}
.row-check{width:34px;height:34px;border-radius:99px;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;flex:none}
.row-name{font-weight:800;font-size:15px}
.row-sub{font-size:13px;color:var(--text-mute2)}
.row-badge{font-size:12px;font-weight:800;padding:5px 13px;border-radius:99px}

.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.how-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:22px}
.how-title{font-weight:800;font-size:15.5px}
.how-desc{font-size:13.5px;line-height:1.55;color:var(--text-muted);margin-top:8px}

/* ---------- Funeral page ---------- */
.funeral-head{display:flex;align-items:end;justify-content:space-between;gap:20px;flex-wrap:wrap}
.featured-card{margin-top:30px;background:#fff;border:1px solid var(--border);border-radius:24px;padding:32px;display:grid;grid-template-columns:1fr 1.15fr;gap:30px;align-items:center}
.featured-donut-wrap{display:flex;flex-direction:column;align-items:center}
.featured-route{font-size:14px;color:var(--text-mute2);margin-top:2px}
.featured-story{font-size:14.5px;line-height:1.6;color:var(--text-soft);margin-top:12px}
.verify-box{margin-top:14px;background:var(--bg);border:1px solid var(--border);border-radius:13px;padding:13px 16px;display:flex;align-items:center;gap:12px}
.verify-icon{width:32px;height:32px;border-radius:99px;background:var(--gold-bg);color:var(--gold-text);display:flex;align-items:center;justify-content:center;font-weight:800;flex:none}
.verify-label{font-size:11.5px;font-weight:800;color:var(--gold-text);text-transform:uppercase;letter-spacing:.04em}
.featured-progress{display:flex;justify-content:space-between;margin-top:14px;font-size:13.5px}
.featured-actions{display:flex;gap:10px;margin-top:16px}

.stat-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.stat-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;text-align:center}
.stat-card .num{font-family:var(--font-serif);font-weight:700;font-size:26px;color:var(--green)}
.stat-card .label{font-size:13px;color:var(--text-mute2);font-weight:700;margin-top:4px}

.cases-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.case-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:16px}
.case-top{display:flex;gap:20px}
.case-donut-wrap{flex:none;width:96px;height:96px;position:relative}
.case-body{flex:1;min-width:0}
.case-name-row{display:flex;justify-content:space-between;align-items:start;gap:10px}
.case-name{font-family:var(--font-serif);font-size:19px;font-weight:600}
.case-route{font-size:13px;color:var(--text-mute2);margin-top:3px}
.case-story{font-size:13.5px;line-height:1.55;color:var(--text-soft);margin-top:8px}
.case-verify{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:10px 14px;display:flex;align-items:center;gap:10px}
.case-progress-row{display:flex;justify-content:space-between;font-size:13px}
.case-actions{display:flex;gap:8px;margin-top:12px}

.queue-row{display:flex;align-items:center;gap:14px;background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:13px 17px}
.queue-icon{width:30px;height:30px;border-radius:99px;background:#EFE9DC;display:flex;align-items:center;justify-content:center;color:var(--text-mute2);flex:none}
.queue-status{font-size:11.5px;font-weight:800;color:var(--text-mute2);background:#EFE9DC;padding:5px 12px;border-radius:99px}
.done-row{display:flex;align-items:center;gap:14px;background:var(--completed-bg);border:1px solid var(--completed-border);border-radius:14px;padding:13px 17px}
.done-badge{font-size:11px;font-weight:800;color:var(--green);background:#fff;padding:5px 11px;border-radius:99px;border:1px solid var(--completed-border);white-space:nowrap}

/* ---------- Donors page ---------- */
.inspire-band{margin-top:28px;background:var(--gold-bg);border-radius:20px;padding:26px 30px;text-align:center}
.inspire-title{font-family:var(--font-serif);font-size:22px;font-weight:600;color:#5C4A22}
.tiers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tier-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:24px;text-align:center}
.tier-icon{width:56px;height:56px;border-radius:99px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;margin:0 auto 12px}
.tier-title{font-family:var(--font-serif);font-size:18.5px;font-weight:600}
.tier-range{font-size:12.5px;font-weight:800;margin-top:4px}
.tier-desc{font-size:13.5px;line-height:1.55;color:var(--text-muted);margin-top:10px}

.freq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:680px}
.freq-card{background:#fff;border:1.5px solid var(--border);border-radius:18px;padding:24px;text-align:center;display:flex;flex-direction:column;transition:border-color .2s;cursor:pointer}
.freq-icon{width:44px;height:44px;border-radius:99px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;margin:0 auto 12px}
.freq-title{font-family:var(--font-serif);font-size:17px;font-weight:600}
.freq-desc{font-size:13px;line-height:1.5;color:var(--text-muted);margin-top:8px}

.quotes-band{margin-top:44px;background:var(--gold-bg);border-radius:22px;padding:34px}
.quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.quote-card{background:rgba(255,255,255,.55);border-radius:16px;padding:20px}
.quote-text{font-size:14.5px;line-height:1.6;color:#5C4A22;font-style:italic}
.quote-src{font-size:12px;font-weight:800;color:var(--gold-text);margin-top:10px}

.note-band{background:var(--gold-bg);border-radius:18px;padding:22px 26px;margin-top:28px;display:flex;align-items:center;gap:16px}
.note-icon{width:40px;height:40px;border-radius:99px;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;flex:none}
.note-text{font-size:14.5px;line-height:1.55;color:var(--text-soft)}

.filter-row{display:flex;gap:10px;flex-wrap:wrap}
.filter-chip{cursor:pointer;font-size:13.5px;font-weight:800;padding:9px 20px;border-radius:99px;border:1.5px solid var(--border-strong);background:#fff;color:var(--text-soft);transition:.15s}
.filter-chip:hover{border-color:var(--gold)}
.filter-chip.active{background:var(--dark);color:var(--bg);border-color:var(--dark)}

.donors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:20px}
.donor-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:22px;text-align:center}
.avatar-dark{width:56px;height:56px;border-radius:99px;background:var(--dark);color:var(--gold-bg);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;margin:0 auto 12px}
.donor-name{font-weight:800;font-size:15px}
.donor-tier{font-size:12.5px;font-weight:700;margin-top:3px}
.donor-desc{font-size:12.5px;color:var(--text-mute2);line-height:1.5;margin-top:8px}

/* ---------- Volunteers page ---------- */
.vol-inspire{margin-top:28px;background:var(--green-bg);border-radius:20px;padding:28px 32px;display:flex;gap:20px;align-items:center}
.vol-inspire-icon{width:52px;height:52px;border-radius:99px;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px;flex:none}
.vol-inspire-title{font-family:var(--font-serif);font-size:19px;font-weight:600;color:var(--green-dark)}
.vol-inspire-body{font-size:14.5px;line-height:1.6;color:var(--green-body);margin-top:6px}

.vol-grid-top{display:grid;grid-template-columns:1fr 1.2fr;gap:26px;margin-top:32px;align-items:start}
.roles-list{display:flex;flex-direction:column;gap:10px}
.role-row{display:flex;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:13px 16px}
.role-dot{width:9px;height:9px;border-radius:99px;background:var(--gold);flex:none}
.role-label{font-weight:700;font-size:14.5px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-field{display:flex;flex-direction:column}
.form-field.full{grid-column:1/-1}
.form-label{font-size:13px;font-weight:800;margin-bottom:6px}
.form-input{width:100%;border:1.5px solid var(--border-strong);border-radius:11px;padding:11px 14px;font-size:14px;background:var(--bg);outline:none;transition:border-color .15s}
.form-input:focus{border-color:var(--gold)}
textarea.form-input{resize:vertical}
.form-success{text-align:center;padding:50px 20px}
.success-check{width:56px;height:56px;border-radius:99px;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px;margin:0 auto 18px}
.form-error{color:#B3452D;font-size:13px;margin-top:10px;text-align:center}

.vols-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.vol-card{cursor:pointer;background:#fff;border:1px solid var(--border);border-radius:18px;padding:22px;text-align:center;transition:transform .15s}
.vol-card:hover{transform:translateY(-3px)}
.vol-avatar{width:58px;height:58px;border-radius:99px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:19px;margin:0 auto 12px}
.vol-name{font-weight:800;font-size:15px}
.vol-role{font-size:12.5px;color:var(--gold-text);font-weight:700;margin-top:3px}
.vol-city{font-size:12.5px;color:var(--text-mute2);margin-top:2px}
.vol-badges{display:flex;gap:5px;justify-content:center;margin-top:10px;flex-wrap:wrap}
.vol-badge-chip{font-size:10px;font-weight:800;color:var(--gold-text);background:var(--gold-bg);padding:3px 8px;border-radius:99px}

/* ---------- About page ---------- */
.about-hero{text-align:center;position:relative}
.about-glow{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:280px;height:280px;border-radius:99px;background:radial-gradient(circle,#F1E7D2,rgba(241,231,210,0) 70%);z-index:0}
.about-mark{width:60px;height:60px;border-radius:17px;background:var(--gold);display:inline-flex;align-items:center;justify-content:center;flex-direction:column}
.about-p{font-size:17px;line-height:1.75;color:var(--text-soft);margin-top:18px;text-wrap:pretty}
.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:32px}
.photo-card{border-radius:18px;overflow:hidden;border:1px solid var(--border)}
.photo-placeholder{height:150px;display:flex;align-items:center;justify-content:center;font-family:ui-monospace,monospace;font-size:11px;color:#9A8E74}
.photo-placeholder.italy{background:repeating-linear-gradient(45deg,#F1E7D2,#F1E7D2 10px,#F6F0E4 10px,#F6F0E4 20px)}
.photo-placeholder.bd{background:repeating-linear-gradient(45deg,#E7EDE2,#E7EDE2 10px,#EEF2E9 10px,#EEF2E9 20px);color:#8A9A80}
.photo-caption{padding:14px 16px;background:#fff}

.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:38px}
.about-stat{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;text-align:center}
.about-stat .num{font-family:var(--font-serif);font-weight:700;font-size:24px;color:var(--gold)}
.about-stat .label{font-size:12px;color:var(--text-mute2);font-weight:700;margin-top:4px}

.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:38px}
.mv-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:28px}
.mv-icon{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.mv-icon.gold{background:var(--gold-bg)}
.mv-icon.blue{background:var(--blue-bg)}
.mv-body{font-size:14.5px;line-height:1.65;color:var(--text-soft);margin-top:10px}

.advisors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.advisor-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:22px;text-align:center}
.advisor-title{font-size:12.5px;color:var(--gold-text);font-weight:700;margin-top:3px}
.advisor-bio{font-size:12.5px;color:var(--text-mute2);line-height:1.5;margin-top:8px}

.badges-row{display:flex;gap:10px;flex-wrap:wrap}
.badge-pill{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:99px;padding:9px 18px}
.badge-dot{width:8px;height:8px;border-radius:99px}

/* ---------- Transparency / Policy ---------- */
.verify-steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.verify-step-card{background:#fff;border:1px solid var(--border);border-radius:18px;padding:24px}
.verify-num{width:38px;height:38px;border-radius:99px;background:var(--gold-bg);color:var(--gold-text);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;margin-bottom:12px}
.legal-p{font-size:15px;line-height:1.75;color:var(--text-soft);margin-top:16px;text-wrap:pretty}

/* ---------- Contact page ---------- */
.contact-hero{text-align:center;position:relative}
.contact-glow{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:260px;height:260px;border-radius:99px;background:radial-gradient(circle,#F1E7D2,rgba(241,231,210,0) 70%);z-index:0}
.contact-mark{width:56px;height:56px;border-radius:16px;background:var(--gold);display:inline-flex;align-items:center;justify-content:center;color:var(--cream);font-weight:800;font-size:22px}
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:38px}
.contact-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px}
.contact-icon{width:34px;height:34px;border-radius:99px;display:flex;align-items:center;justify-content:center;font-weight:800;margin-bottom:10px}
.contact-label{font-size:12px;font-weight:800;color:var(--gold-text);text-transform:uppercase;letter-spacing:.04em}
.contact-value{font-weight:700;font-size:15px;margin-top:6px}
.contact-form-card{margin-top:32px;background:#fff;border:1px solid var(--border);border-radius:22px;padding:32px}
.contact-cta{margin-top:24px;background:var(--dark);border-radius:18px;padding:26px 30px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.contact-cta-text{color:var(--bg);font-size:15px;line-height:1.55;max-width:480px}

/* ---------- Case detail ---------- */
.detail-back{cursor:pointer;font-weight:800;font-size:14px;color:var(--gold-text);margin-bottom:24px;display:inline-block}
.detail-back:hover{color:var(--text)}
.detail-card{background:#fff;border:1px solid var(--border);border-radius:24px;padding:36px}
.detail-top{display:flex;gap:26px;align-items:start;flex-wrap:wrap}
.detail-photo{width:150px;height:150px;border-radius:20px;background:repeating-linear-gradient(45deg,#EDE4D3,#EDE4D3 8px,#F6F0E4 8px,#F6F0E4 16px);display:flex;align-items:center;justify-content:center;font-family:ui-monospace,monospace;font-size:11px;color:#9A8E74;flex:none}
.detail-name{font-family:var(--font-serif);font-size:32px;font-weight:600;margin-top:12px}
.detail-loc{font-size:14.5px;color:var(--text-mute2);margin-top:4px}
.detail-story{font-size:15px;line-height:1.65;color:var(--text-soft);margin-top:14px;text-wrap:pretty}
.detail-track{margin-top:26px;height:12px;background:var(--wall);border-radius:99px;overflow:hidden}
.detail-track .progress-fill{background:var(--gold)}
.detail-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px}
.detail-actions{display:flex;gap:12px;margin-top:22px}
.donor-row{display:flex;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:12px 16px}
.donor-row-avatar{width:30px;height:30px;border-radius:99px;background:var(--gold-bg);color:var(--gold-text);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;flex:none}

/* ---------- Footer ---------- */
.footer{background:var(--dark);margin-top:auto}
.footer-grid{padding:56px 32px 30px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px}
.footer-brand{display:flex;align-items:center;gap:10px}
.footer-brand-mark{width:36px;height:36px;border-radius:10px;background:var(--gold);display:flex;align-items:center;justify-content:center;flex-direction:column}
.footer-brand-name{font-family:var(--font-serif);font-weight:700;font-size:19px;color:var(--bg)}
.footer-desc{font-size:13.5px;color:#B8AE99;margin-top:14px;line-height:1.6;max-width:320px}
.footer-tagline{font-size:13px;font-weight:700;color:#D8B876;margin-top:10px;font-style:italic}
.footer-socials{display:flex;gap:10px;margin-top:18px}
.social-btn{width:34px;height:34px;border-radius:99px;background:rgba(250,246,239,.08);color:#E4D9C2;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;cursor:pointer;transition:.15s}
.social-btn:hover{background:var(--gold);color:var(--cream)}
.footer-heading{font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#8F8571;margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:10px;list-style:none;margin:0;padding:0}
.footer-links a{cursor:pointer;font-size:14px;color:#D8CEB8;transition:.15s}
.footer-links a:hover{color:var(--bg)}
.footer-bottom{border-top:1px solid rgba(250,246,239,.1)}
.footer-bottom-inner{padding:20px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-note{font-size:12.5px;color:#8F8571}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(46,40,28,.5);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-box{background:#fff;border-radius:24px;padding:34px;width:440px;max-width:100%;max-height:90vh;overflow:auto;box-shadow:0 24px 60px rgba(40,32,16,.3)}
.modal-title{font-family:var(--font-serif);font-size:25px;font-weight:600}
.modal-meta{font-size:14px;color:var(--text-mute2);margin-top:5px}
.modal-meta b{font-weight:800;color:var(--text)}
.modal-section-label{font-size:13px;font-weight:800;margin:20px 0 9px}
.amount-presets{display:flex;gap:9px;flex-wrap:wrap}
.amount-btn{flex:1;min-width:70px;text-align:center;cursor:pointer;font-weight:800;font-size:15px;padding:11px 0;border-radius:12px;background:var(--bg);color:var(--text-soft);border:1.5px solid var(--border-strong);transition:.15s}
.amount-btn:hover{border-color:var(--gold)}
.amount-btn.active{background:var(--gold);color:var(--cream);border-color:var(--gold)}
.freq-tabs{display:flex;gap:8px;margin-top:8px}
.freq-tab{flex:1;text-align:center;cursor:pointer;font-weight:700;font-size:13px;padding:9px 0;border-radius:10px;background:var(--bg);border:1.5px solid var(--border-strong);color:var(--text-soft)}
.freq-tab.active{background:var(--dark);color:var(--bg);border-color:var(--dark)}
.checkbox-row{display:flex;align-items:center;gap:10px;cursor:pointer;margin-top:12px}
.checkbox-box{width:20px;height:20px;border-radius:6px;border:2px solid var(--border-strong);background:#fff;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:800;transition:background .2s}
.checkbox-box.checked{border-color:var(--gold);background:var(--gold)}
.modal-done{text-align:center;padding:22px 8px}
.modal-done .check{width:62px;height:62px;border-radius:99px;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:26px;margin:0 auto 18px}
.modal-close-btn{cursor:pointer;display:inline-block;border:1.5px solid var(--border-strong);font-weight:800;font-size:14px;padding:11px 30px;border-radius:12px;margin-top:20px}
.modal-close-btn:hover{border-color:var(--gold)}
.stripe-note{font-size:11.5px;color:var(--text-mute2);text-align:center;margin-top:12px}

.vol-modal-head{display:flex;align-items:center;gap:16px}
.vol-modal-avatar{width:64px;height:64px;border-radius:99px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:22px;flex:none}

/* ---------- Share sheet ---------- */
.share-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}
.share-option{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;padding:14px 8px;border-radius:14px;border:1px solid var(--border);background:#fff;transition:.15s}
.share-option:hover{border-color:var(--gold);transform:translateY(-2px)}
.share-icon{width:44px;height:44px;border-radius:99px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:16px}
.share-label{font-size:12.5px;font-weight:700;color:var(--text-soft)}
.share-link-row{display:flex;gap:8px;margin-top:18px;align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:10px 12px}
.share-link-text{flex:1;font-size:13px;color:var(--text-mute2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);background:var(--dark);color:var(--cream);font-weight:700;font-size:14px;padding:12px 22px;border-radius:99px;box-shadow:0 10px 30px rgba(0,0,0,.25);z-index:200;opacity:0;pointer-events:none;transition:opacity .25s}
.toast.show{opacity:1}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero-grid,.build-grid,.causes-grid,.mv-grid,.board-grid,.featured-card,.photo-grid,.vol-grid-top{grid-template-columns:1fr}
  .trust-grid,.how-grid,.advisors-grid,.donors-grid,.vols-grid,.tiers-grid,.freq-grid,.quotes-grid,.about-stats,.stat-strip,.cases-grid,.contact-cards{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .nav-inner{gap:14px}
  .nav-links{display:none}
  .menu-toggle{display:flex}
  .hero-title{font-size:34px}
  .page-title{font-size:30px}
  .trust-grid,.how-grid,.advisors-grid,.donors-grid,.vols-grid,.tiers-grid,.freq-grid,.quotes-grid,.about-stats,.stat-strip,.cases-grid,.contact-cards,.stat-grid4{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .container,.container-narrow,.container-md,.container-sm,.container-donors,.container-narrower{padding:0 18px}
  .section{padding:40px 18px}
}
