/* OVERCOMERS Design System */
:root{--bg:#f5f6fa;--card:#fff;--ink:#0a1a24;--muted:#5b6875;--brand:#0b5f57;--brand2:#0ea5a0;--brand-glow:rgba(11,95,87,.08);--danger:#b91c1c;--shadow:0 1px 3px rgba(0,0,0,.04),0 12px 40px rgba(0,0,0,.06);--shadow-hover:0 2px 8px rgba(0,0,0,.06),0 20px 50px rgba(0,0,0,.10);--radius:16px;--ease:0.2s cubic-bezier(.4,0,.2,1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:Inter,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--ink);background:var(--bg);font-size:15px;line-height:1.65}
a{color:inherit;text-decoration:none;transition:color var(--ease)}img{display:block;max-width:100%}p{margin:0}
.container{max-width:1120px;margin:0 auto;padding:0 20px}.section{padding:40px 0}.page{padding:22px 0}
.muted{color:var(--muted)}.small{font-size:13px}.tiny{font-size:12px}
h1,.h1{font-size:42px;letter-spacing:-.03em;line-height:1.1;font-weight:800;margin:0 0 10px}
h2,.h2{font-size:26px;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin:0 0 8px}
h3,.h3{font-size:17px;font-weight:700;line-height:1.35;margin:0 0 6px}
.lead{font-size:17px;color:var(--muted)}

/* ── Topbar ── */
.topbar{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid rgba(0,0,0,.06);transition:box-shadow var(--ease)}
.topbar.scrolled{box-shadow:0 1px 12px rgba(0,0,0,.08)}
.topbar__inner{display:flex;align-items:center;height:64px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.brand__logo{height:40px;width:40px;border-radius:50%;object-fit:cover;transition:transform var(--ease)}.brand:hover .brand__logo{transform:scale(1.05)}
.brand__title{font-weight:800;font-size:15px;letter-spacing:.03em}.brand__subtitle{font-size:11px;color:var(--muted);line-height:1.3}
.nav{display:flex;gap:6px;flex:1;justify-content:center}
.nav a{padding:8px 12px;font-weight:600;font-size:13.5px;color:var(--muted);border-radius:8px;transition:all var(--ease);text-decoration:none}.nav a:hover{color:var(--ink);background:rgba(0,0,0,.04)}
.nav__cta{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:10px;border:1px solid rgba(0,0,0,.10);background:#fff;font-weight:600;font-size:13.5px;cursor:pointer;min-height:40px;transition:all var(--ease);white-space:nowrap;text-decoration:none;color:var(--ink);font-family:inherit}
.btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.08)}.btn:active{transform:translateY(0)}.btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle}
.btn:not(.btn--primary) .spinner{border-color:rgba(0,0,0,.15);border-top-color:var(--ink)}
@keyframes spin{to{transform:rotate(360deg)}}
.nav a:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:8px}
.btn--primary,.btn.primary{background:var(--brand);color:#fff;border-color:transparent}.btn--primary:hover,.btn.primary:hover{background:#094e47;box-shadow:0 4px 16px rgba(11,95,87,.25)}
.btn--ghost,.btn.ghost{background:transparent;border-color:rgba(0,0,0,.10)}
.btn--donate{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;border:none;font-weight:700;letter-spacing:.01em}
.btn--donate:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(11,95,87,.3)}
.btn--sm{padding:7px 14px;font-size:13px;min-height:36px;border-radius:8px}
.btn--lg{padding:14px 24px;font-size:16px;min-height:52px}
.btn--block{width:100%;justify-content:center}
.btn.danger{background:var(--danger);color:#fff;border-color:transparent}

/* ── Trust strip ── */
.trust-strip{background:var(--brand);color:#fff;font-size:12.5px;font-weight:500;padding:7px 0}
.trust-strip__inner{display:flex;justify-content:center;align-items:center;gap:20px;flex-wrap:wrap}
.trust-strip__dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.35);flex-shrink:0}
.trust-strip a{color:rgba(255,255,255,.85);text-decoration:underline;text-underline-offset:2px}.trust-strip a:hover{color:#fff}

/* ── Flash ── */
.flash{margin:14px 0;display:grid;gap:10px}
.flash__item{padding:12px 16px;border-radius:12px;background:#fff;border:1px solid rgba(0,0,0,.08);font-size:14px}
.flash__item--success{border-color:rgba(16,185,129,.35);background:rgba(16,185,129,.04)}
.flash__item--error{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.04)}
.flash__item--info{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.04)}
.flash__item--warning{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.04)}
.flash__item--success,.flash__item--info{animation:flashFade 4s ease-in forwards}
@keyframes flashFade{0%,70%{opacity:1}100%{opacity:0;pointer-events:none}}

/* ── Cards & Grid ── */
.card{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:all .25s ease}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.card--no-hover:hover{transform:none;box-shadow:var(--shadow)}
.card__body,.body{padding:22px;display:flex;flex-direction:column;gap:8px;height:100%}
.card__media img{width:100%;height:190px;object-fit:cover;display:block}
.card--padded{padding:22px}.card--stretch{min-height:260px}
.card--flat{box-shadow:none;border:1px solid rgba(7,25,34,.1);background:rgba(255,255,255,.7)}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;align-items:stretch}
.grid.cards>article.card,.grid.cards>.card{grid-column:span 4}
@media(max-width:960px){.grid.cards>article.card,.grid.cards>.card{grid-column:span 6}}
@media(max-width:600px){.grid.cards>article.card,.grid.cards>.card{grid-column:span 12}}
@media(max-width:640px){.grid>[style*="grid-column"]{grid-column:span 12!important}}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.section-head .actions{margin-left:auto}
@media(max-width:720px){.section-head{align-items:flex-start;flex-direction:column}.section-head .actions{margin-left:0}}
.section-title{font-size:18px;margin:0 0 6px}
.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;padding-top:6px}
.actions-inline{display:flex;gap:10px;flex-wrap:wrap}
.spacer{height:10px}
.link{text-decoration:none;font-weight:700}.link.muted{font-weight:600;color:var(--muted)}

/* ── Hero ── */
.hero{padding:36px 0 28px}
.hero__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:20px;align-items:stretch}
.hero__copy{display:flex;flex-direction:column;justify-content:center;gap:14px}
.hero__title{margin:0;font-size:42px;letter-spacing:-.03em;line-height:1.1}
.hero__lead{font-size:16.5px;color:var(--muted);line-height:1.6;margin:0}
.hero__body{color:rgba(10,26,36,.85);line-height:1.65;margin:0}
.hero__actions{display:flex;gap:10px;flex-wrap:wrap;padding-top:4px}
.hero__fine{font-size:12px;color:var(--muted)}
.hero__sidebar{display:flex;flex-direction:column;gap:16px}
.cta-card{background:linear-gradient(145deg,#0b5f57,#0da89e);color:#fff;border:none;border-radius:var(--radius);padding:26px;flex:1;display:flex;flex-direction:column;justify-content:space-between}
.cta-card__badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);padding:5px 14px;border-radius:20px;font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;width:fit-content}
.cta-card__title{font-size:22px;font-weight:800;color:#fff;margin:12px 0 6px;line-height:1.2}
.cta-card__desc{opacity:.85;font-size:13.5px;line-height:1.55;margin-bottom:16px}
.cta-card__actions{display:flex;gap:8px;flex-wrap:wrap}.cta-card__actions .btn{font-size:13px;padding:8px 16px;min-height:38px;cursor:pointer}
.res-card{padding:22px;display:flex;flex-direction:column;gap:8px}.res-card h3{font-size:16px;font-weight:700;margin:0}.res-card p{color:var(--muted);font-size:13.5px;margin:0}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;display:inline-block;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(74,222,128,.4)}50%{opacity:.7;box-shadow:0 0 0 6px rgba(74,222,128,0)}}

/* ── Steps ── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:6px 0}
.step{text-align:center;padding:20px 14px;background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow);transition:all .25s ease}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);border-color:rgba(11,95,87,.15)}
.step__num{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:var(--brand-glow);color:var(--brand);font-size:20px;font-weight:800;margin:0 auto 10px;transition:all var(--ease)}
.step:hover .step__num{background:var(--brand);color:#fff}
.step h3{font-size:15px;margin-bottom:4px}.step p{font-size:12.5px;color:var(--muted);line-height:1.5;margin:0}
@media(max-width:700px){.steps{grid-template-columns:repeat(2,1fr)}}

/* ── Openings Banner ── */
.openings-banner{border:2px solid rgba(11,95,87,.12);border-radius:var(--radius);overflow:hidden;background:var(--card);transition:all .25s ease}
.openings-banner:hover{border-color:rgba(11,95,87,.22);box-shadow:var(--shadow-hover);transform:none}
.openings-banner__inner{display:flex;align-items:stretch}
.openings-banner__main{flex:1;min-width:300px;padding:30px}
.openings-banner__badge{display:inline-flex;align-items:center;gap:6px;background:var(--brand-glow);padding:5px 14px;border-radius:20px;font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--brand);margin-bottom:14px}
.openings-banner__sidebar{flex:0 0 260px;background:linear-gradient(160deg,rgba(11,95,87,.03),rgba(11,95,87,.07));padding:28px;display:flex;flex-direction:column;justify-content:center;gap:18px;border-left:1px solid rgba(0,0,0,.06)}
.fact-label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:3px}
.fact-value{font-weight:700;font-size:14.5px}.fact-value--green{color:var(--brand)}
@media(max-width:760px){.openings-banner__inner{flex-direction:column}.openings-banner__sidebar{border-left:none;border-top:1px solid rgba(0,0,0,.06);flex:auto;display:grid;grid-template-columns:1fr 1fr;gap:14px}}

/* ── Forms ── */
.form{margin-top:16px}
.grid--form{grid-template-columns:repeat(2,1fr)}.grid__span2{grid-column:span 2}
@media(max-width:640px){.grid--form{grid-template-columns:1fr}.grid__span2{grid-column:span 1}}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}
.label{display:block;font-weight:600;font-size:13px;margin-bottom:4px;color:var(--ink)}
.input,input[type="text"],input[type="email"],input[type="password"],input[type="tel"],select{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.14);background:#fff;font-size:15px;min-height:44px;font-family:inherit;transition:border-color var(--ease)}
.textarea,textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.14);background:#fff;font-size:15px;resize:vertical;min-height:44px;font-family:inherit}
.input:focus,input:focus,textarea:focus,select:focus{outline:2px solid var(--brand);outline-offset:1px;border-color:var(--brand)}
.error{color:var(--danger);font-weight:700;font-size:13px}
.form__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.form-card{max-width:680px;padding:18px}.form-grid{display:grid;grid-template-columns:1fr;gap:0}.form-row{margin-bottom:14px}
.auth-form .field{margin-bottom:14px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:640px){.grid-2{grid-template-columns:1fr}}

/* ── Deposit Page ── */
.deposit-page{max-width:680px;margin:0 auto}
.deposit-hero{background:linear-gradient(145deg,#0b5f57,#0da89e);border-radius:var(--radius);padding:32px;color:#fff;margin-bottom:20px;position:relative;overflow:hidden}
.deposit-hero::before{content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none}
.deposit-hero::after{content:'';position:absolute;bottom:-80px;left:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.deposit-hero>*{position:relative}
.deposit-hero__eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.75;margin:0 0 8px}
.deposit-hero__title{font-size:30px;font-weight:800;margin:0 0 8px;color:#fff;line-height:1.15}
.deposit-hero__lead{font-size:15px;opacity:.85;margin:0;line-height:1.6}
.deposit-hero__amount{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);padding:8px 18px;border-radius:12px;margin-top:16px;font-size:24px;font-weight:800}
.deposit-steps{background:rgba(11,95,87,.03);border-radius:14px;padding:18px 20px;margin-bottom:22px}
.deposit-steps__title{font-weight:700;font-size:14px;margin:0 0 12px;color:var(--ink)}
.deposit-step{display:flex;gap:12px;align-items:flex-start;margin-bottom:10px}.deposit-step:last-child{margin-bottom:0}
.deposit-step__num{background:var(--brand);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;margin-top:1px}
.deposit-step__text{color:var(--muted);font-size:14px;line-height:1.5}
.deposit-form .field{margin-bottom:14px}.deposit-form .field:last-of-type{margin-bottom:20px}
.deposit-form .btn--lg{border-radius:12px}
.deposit-secure{text-align:center;margin-top:14px;font-size:12.5px;color:var(--muted);line-height:1.6}
.deposit-secure a{color:var(--brand);font-weight:600}
.deposit-faq{margin-top:16px}
.deposit-faq details{border-bottom:1px solid rgba(0,0,0,.06)}
.deposit-faq details:last-child{border-bottom:none}
.deposit-faq summary{font-weight:600;font-size:14.5px;padding:14px 0;cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px}
.deposit-faq summary::before{content:"\203A";transition:transform .2s;font-size:16px;color:var(--muted)}
.deposit-faq details[open] summary::before{transform:rotate(90deg)}
.deposit-faq summary::-webkit-details-marker{display:none}
.deposit-faq .answer{padding:0 0 14px;color:var(--muted);font-size:14px;line-height:1.65}
.deposit-offline{text-align:center;padding:28px 20px}
.deposit-offline__title{font-size:20px;font-weight:800;margin:0 0 6px}
.deposit-offline__desc{color:var(--muted);margin:0 0 18px}

/* ── Footer ── */
.footer{margin-top:48px;background:#0b1120;color:#d1d5db}.footer a{color:#d1d5db;text-decoration:none;transition:color var(--ease)}.footer a:hover{color:#fff}
.footer__banner{position:relative;padding:28px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.footer__bannerBg{position:absolute;inset:0;background:radial-gradient(800px 280px at 20% 30%,rgba(14,165,160,.2),transparent 60%),radial-gradient(700px 300px at 80% 50%,rgba(125,211,252,.12),transparent 55%)}
.footer__bannerInner{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:760px){.footer__bannerInner{grid-template-columns:1fr}}
.footer__bannerCard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:18px}
.footer__bannerCard strong{color:#e5e7eb}.footer__bannerTitle{font-weight:700;font-size:15px;margin-bottom:8px;color:#e5e7eb}
.footer__bannerBody p{margin:5px 0;font-size:14px;color:#9ca3af}
.footer__inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:20px;padding:28px 0}
@media(max-width:760px){.footer__inner{grid-template-columns:1fr 1fr}}@media(max-width:480px){.footer__inner{grid-template-columns:1fr}}
.footer__brand{font-weight:800;letter-spacing:.03em;color:#e5e7eb;font-size:15px}
.footer__desc{color:#94a3b8;font-size:13px;margin-top:4px}
.footer__fine{color:#64748b;font-size:11.5px;line-height:1.6;margin-top:8px}
.footer__col-title{font-weight:700;font-size:12px;margin-bottom:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em}
.footer__links{display:flex;flex-direction:column;gap:6px}.footer__links a{font-size:13.5px;color:#6b7280}.footer__links a:hover{color:#fff}
.footer__bottom{border-top:1px solid rgba(255,255,255,.06);padding:16px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}.footer__bottom p{color:#4b5563;font-size:11.5px}

/* ── Sticky bar ── */
.sticky-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.08);box-shadow:0 -2px 16px rgba(0,0,0,.06);padding:10px 14px;z-index:90;gap:8px;justify-content:center}
.sticky-bar .btn{font-size:13px;padding:8px 14px;min-height:38px}
@media(max-width:640px){.sticky-bar{display:flex}main{padding-bottom:60px}}

/* ── Mobile ── */
.mobile-toggle{display:none;align-items:center;justify-content:center;background:none;border:1px solid rgba(0,0,0,.10);border-radius:10px;padding:7px 8px;cursor:pointer;color:var(--ink);transition:all var(--ease)}.mobile-toggle:hover{background:rgba(0,0,0,.04)}
@media(max-width:860px){
  .hero__grid{grid-template-columns:1fr}.hero__title{font-size:32px!important}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 8px 24px rgba(0,0,0,.08);flex-direction:column;padding:10px 18px;gap:0;z-index:25;max-height:calc(100vh - 64px);max-height:calc(100dvh - 64px);overflow-y:auto;-webkit-overflow-scrolling:touch}
  .nav.nav--open{display:flex}.nav a{padding:11px 0;border-bottom:1px solid rgba(0,0,0,.04);font-size:15px;margin:0}.nav a:last-child{border-bottom:none}
  .mobile-toggle{display:flex}.nav__mobile-only{display:block!important}
  .nav__mobile-highlight{margin-top:4px!important;padding:12px 16px!important;background:var(--brand)!important;color:#fff!important;border-radius:10px!important;text-align:center;font-weight:700!important;border-bottom:none!important}
  .nav__cta .btn--ghost{display:none}h1,.h1{font-size:28px}
}
@media(min-width:861px){.nav__mobile-only{display:none!important}}
@media(max-width:600px){.nav__cta{display:none}h1,.h1{font-size:26px}h2,.h2{font-size:22px}.login-help-card{display:none}}

/* ── Animations ── */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease;animation:fadeUpFallback .5s ease .8s forwards}
.fade-up.visible{opacity:1;transform:translateY(0);animation:none}
@keyframes fadeUpFallback{to{opacity:1;transform:translateY(0)}}
.fade-up.d1{transition-delay:.06s}.fade-up.d2{transition-delay:.12s}.fade-up.d3{transition-delay:.18s}.fade-up.d4{transition-delay:.24s}

/* ── Existing page styles ── */
.story{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:14px}
.story__media img{width:100%;height:360px;object-fit:cover;border-radius:18px;border:1px solid rgba(0,0,0,.08)}
.story__body{background:#fff;border-radius:18px;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow);padding:18px}
.prose{color:rgba(7,25,34,.92);line-height:1.65}@media(max-width:980px){.story{grid-template-columns:1fr}}
.error-card{background:#fff;border-radius:18px;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow);padding:22px}
.admin-head{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.admin-nav{display:flex;gap:10px;flex-wrap:wrap}
.table{display:grid;gap:8px}.table .row{display:grid;gap:10px;align-items:start;padding:10px 12px;border:1px solid rgba(0,0,0,.06);border-radius:14px;background:#fff}
.table .row.head{background:rgba(11,95,87,.06);border-color:rgba(11,95,87,.12);font-weight:700}
.pill{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:#fff;font-weight:700;font-size:12px}
.jobboard{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;margin-top:16px}
.jobcard{grid-column:span 6;background:rgba(255,255,255,.86);border:1px solid rgba(7,25,34,.10);border-radius:22px;box-shadow:0 10px 26px rgba(2,6,23,.08);overflow:hidden}
.jobcard__body{padding:16px 18px}.jobcard__title{margin:0 0 6px;font-size:1.12rem}
.jobcard__meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}
.jobtag{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(7,25,34,.12);background:rgba(255,255,255,.92);font-weight:700;font-size:.88rem;color:rgba(11,18,32,.78)}
.jobcard ul{margin:0;padding-left:18px;color:rgba(11,18,32,.72)}.jobcard li{margin:8px 0}
@media(max-width:900px){.jobcard{grid-column:span 12}}
.standards-list{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.standards-item{display:flex;gap:14px;align-items:flex-start}
.standards-item__icon{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--brand);color:#fff;font-weight:700;font-size:14px}
.standards-item p{margin:4px 0 0}
.doc-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:rgba(11,95,87,.1);color:var(--brand);margin-bottom:8px}
.doc-badge--ops{background:rgba(14,165,160,.1);color:#087d78}
.impact-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:rgba(11,95,87,.08);color:var(--brand);font-size:22px;margin-bottom:6px}
.menu-wrap{position:relative}.menu-btn{cursor:pointer}
.menu{display:none;position:absolute;right:0;top:100%;min-width:180px;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.1);padding:6px 0;z-index:30}
.menu.open{display:block}
.menu[aria-hidden="false"]{display:block}
.menu__item{display:block;padding:8px 16px;text-decoration:none;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer}.menu__item:hover{background:rgba(0,0,0,.04)}
.menu__item--button{width:100%;text-align:left;background:none;border:none;font:inherit}.menu__form{margin:0}
.accordion{border-bottom:1px solid rgba(0,0,0,.06);padding:0}
.accordion__title{font-weight:700;font-size:15px;padding:14px 0;cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px}
.accordion__title::before{content:"\25B8";transition:transform .2s;font-size:12px;color:var(--muted)}
.accordion[open] .accordion__title::before{transform:rotate(90deg)}
.accordion__title::-webkit-details-marker{display:none}.accordion__body{padding:0 0 14px}
.email-dir{display:flex;flex-direction:column;gap:0}
.email-dir__item{padding:8px 0;border-bottom:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;gap:2px}
.email-dir__item:last-child{border-bottom:none}.email-dir__item strong{font-size:13px}.email-dir__item a{font-size:13px}
.contact-dir{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.contact-dir__item{padding:12px;border:1px solid rgba(0,0,0,.06);border-radius:14px;background:#fff}
.contact-dir__label{font-weight:700;font-size:13px;margin-bottom:2px}
.contact-dir__email{color:var(--brand);text-decoration:none;font-size:14px}.contact-dir__email:hover{text-decoration:underline}
.contact-dir__desc{color:var(--muted);font-size:12px;margin-top:2px}
.photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.photo-strip__item{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:rgba(11,95,87,.06);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;text-align:center;padding:18px}
.photo-strip__item img{width:100%;height:100%;object-fit:cover}@media(max-width:640px){.photo-strip{grid-template-columns:1fr}}
.last-updated{font-size:12px;color:#94a3b8;margin-top:18px;padding-top:12px;border-top:1px solid rgba(0,0,0,.06)}
.donate-hero{background:linear-gradient(135deg,#0b5f57,#0ea5a0);padding:32px 28px;text-align:center;color:#fff;border-radius:var(--radius) var(--radius) 0 0}
.donate-hero__eyebrow{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;opacity:.75;margin:0 0 6px}
.donate-hero__title{font-size:30px;letter-spacing:-.02em;margin:0 0 8px;color:#fff;line-height:1.15}
.donate-hero__lead{font-size:15px;opacity:.85;margin:0;max-width:420px;display:inline-block}
.donate-body{padding:28px}
.donate-label{display:block;font-weight:700;font-size:14px;margin-bottom:10px;color:var(--ink)}
.donate-helper{color:var(--muted);font-size:12px;margin:6px 0 22px}
.donate-input{width:100%;padding:10px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.12);font-size:14px;min-height:44px}
.donate-select{width:100%;padding:12px 14px;border-radius:14px;border:2px solid rgba(0,0,0,.1);font-size:15px;font-weight:600;margin-bottom:24px;background:#fff;color:var(--ink);min-height:48px}
.donate-cta{width:100%;font-size:17px;padding:16px;min-height:56px;border-radius:14px;justify-content:center}
.donate-secure{display:flex;align-items:center;gap:10px;margin-top:14px;justify-content:center}.donate-secure p{color:var(--muted);font-size:12px;margin:0}.donate-secure svg{flex-shrink:0;stroke:var(--muted)}
.amt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.amt-btn{padding:14px;border-radius:14px;border:2px solid rgba(0,0,0,.1);background:#fff;font-size:17px;font-weight:800;cursor:pointer;transition:all .15s;min-height:52px;color:var(--ink);font-family:inherit}
.amt-btn:hover{border-color:var(--brand);color:var(--brand)}
.amt-btn.active{border-color:var(--brand);background:rgba(11,95,87,.06);color:var(--brand);box-shadow:0 0 0 1px var(--brand)}
.amt-custom-wrap{position:relative;display:flex;align-items:center}
.amt-custom-prefix{position:absolute;left:14px;font-weight:700;font-size:15px;color:var(--muted);pointer-events:none}
.amt-custom-input{width:100%;padding:12px 14px 12px 28px;border-radius:14px;border:2px solid rgba(0,0,0,.1);font-size:15px;font-weight:700;text-align:center;min-height:52px;background:#fff}
.amt-custom-input:focus{outline:2px solid var(--brand);outline-offset:1px;border-color:var(--brand)}
.freq-bar{display:flex;gap:0;margin-bottom:22px;border-radius:12px;overflow:hidden;border:2px solid rgba(0,0,0,.1)}
.freq-btn{flex:1;padding:12px;background:#fff;border:none;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;color:var(--muted);font-family:inherit}
.freq-btn:not(:last-child){border-right:1px solid rgba(0,0,0,.08)}.freq-btn.active{background:var(--brand);color:#fff}
.freq-btn:hover:not(.active){background:rgba(11,95,87,.04);color:var(--ink)}
.donate-details{margin-bottom:22px;border:1px solid rgba(0,0,0,.08);border-radius:14px;overflow:hidden}
.donate-details__summary{padding:14px 16px;cursor:pointer;font-weight:600;font-size:14px;list-style:none;display:flex;align-items:center;gap:8px}
.donate-details__summary::-webkit-details-marker{display:none}
.donate-details__optional{margin-left:auto;font-weight:500;font-size:12px;color:var(--muted)}
.donate-details__body{padding:0 16px 16px}
.ded-bar{display:flex;gap:8px;margin-bottom:10px}
.ded-btn{padding:8px 14px;border-radius:10px;border:1px solid rgba(0,0,0,.1);background:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}
.ded-btn.active{border-color:var(--brand);background:rgba(11,95,87,.06);color:var(--brand)}
.donate-impact{margin-top:20px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;text-align:center}
.donate-impact__card{padding:18px}
.donate-impact__amount{font-size:22px;font-weight:800;color:var(--brand);margin:4px 0 2px}
.donate-impact__desc{font-size:12px;color:var(--muted);margin:0}
@media(max-width:640px){.donate-hero{padding:24px 18px}.donate-hero__title{font-size:24px}.donate-body{padding:20px 16px}.amt-grid{grid-template-columns:repeat(3,1fr);gap:8px}.amt-btn{font-size:15px;padding:12px 8px;min-height:46px}.donate-impact{grid-template-columns:1fr 1fr 1fr;gap:8px}.donate-impact__card{padding:12px 8px}.donate-impact__amount{font-size:18px}}

/* ═══ APPLY PAGE ═══ */
.apply-page{max-width:760px;margin:0 auto}
.apply-hero{background:linear-gradient(145deg,#0b5f57,#0da89e);border-radius:var(--radius);padding:32px;color:#fff;margin-bottom:20px;position:relative;overflow:hidden}
.apply-hero::before{content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none}
.apply-hero::after{content:'';position:absolute;bottom:-80px;left:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.apply-hero>*{position:relative}
.apply-hero__eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.75;margin:0 0 8px}
.apply-hero__title{font-size:30px;font-weight:800;margin:0 0 8px;color:#fff;line-height:1.15}
.apply-hero__lead{font-size:15px;opacity:.85;margin:0;line-height:1.6;max-width:520px}
.apply-hero__badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);padding:6px 14px;border-radius:10px;margin-top:16px;font-size:13px;font-weight:600}
.apply-hero__badge svg{opacity:.7}
@media(max-width:600px){.apply-hero{padding:24px 20px}.apply-hero__title{font-size:24px}}

.apply-grid{display:grid;grid-template-columns:1fr 280px;gap:20px;align-items:start}
@media(max-width:800px){.apply-grid{grid-template-columns:1fr}.apply-sidebar{order:-1}}
.apply-sidebar{position:sticky;top:84px}
.apply-sidebar .card__body{gap:0}

.sidebar-step{display:flex;gap:12px;align-items:flex-start;padding:14px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.sidebar-step:last-child{border-bottom:none}
.sidebar-step__num{background:var(--brand-glow);color:var(--brand);width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0;margin-top:1px;transition:all var(--ease)}
.sidebar-step--active .sidebar-step__num{background:var(--brand);color:#fff}
.sidebar-step__text{font-size:13.5px;line-height:1.5}
.sidebar-step__title{font-weight:700;color:var(--ink);margin-bottom:1px}
.sidebar-step__desc{color:var(--muted);font-size:12.5px}

.form-section{margin-bottom:26px}
.form-section__title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--brand);margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--brand-glow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:500px){.form-row{grid-template-columns:1fr}}
.label-hint{font-weight:400;color:var(--muted)}

.reassurance{display:flex;gap:12px;align-items:center;padding:14px 16px;background:rgba(11,95,87,.03);border-radius:12px;margin:4px 0 22px;border:1px solid rgba(11,95,87,.06)}
.reassurance__icon{width:36px;height:36px;border-radius:10px;background:var(--brand-glow);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.reassurance__icon svg{color:var(--brand)}
.reassurance__text{font-size:13px;color:var(--muted);line-height:1.5}
.reassurance__text strong{color:var(--ink)}

.contact-alt{text-align:center;padding:18px;margin-top:16px;border-radius:var(--radius);background:rgba(11,95,87,.02);border:1px dashed rgba(11,95,87,.15)}
.contact-alt__title{font-weight:700;font-size:14px;margin-bottom:4px}
.contact-alt__desc{color:var(--muted);font-size:13px;margin-bottom:10px}
.contact-alt__links{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}

.sidebar-trust{display:flex;flex-direction:column;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid rgba(0,0,0,.06)}
.sidebar-trust__item{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--muted);line-height:1.4}
.sidebar-trust__check{width:18px;height:18px;border-radius:50%;background:var(--brand-glow);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar-trust__check svg{color:var(--brand)}

.form-links{display:flex;justify-content:center;gap:16px;margin-top:12px}
.form-links a{font-size:13px;color:var(--muted);font-weight:600;text-decoration:underline;text-underline-offset:2px;transition:color var(--ease)}
.form-links a:hover{color:var(--brand)}

/* Success confirmation (shown via flash) */
.apply-success{text-align:center;padding:32px 20px}
.apply-success__icon{width:56px;height:56px;border-radius:50%;background:rgba(11,95,87,.08);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.apply-success__title{font-size:22px;font-weight:800;margin:0 0 6px}
.apply-success__desc{color:var(--muted);max-width:380px;margin:0 auto 20px;line-height:1.6}

/* ═══ NOTIFICATION SYSTEM ═══ */
.notif-wrap{position:relative}
.notif-btn{background:none;border:1px solid rgba(0,0,0,.10);border-radius:10px;padding:7px 8px;cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--ease);min-height:40px;min-width:40px}
.notif-btn:hover{background:rgba(0,0,0,.04);color:var(--ink)}
.notif-btn__dot{position:absolute;top:4px;right:4px;width:9px;height:9px;border-radius:50%;background:#4ade80;border:2px solid #fff;display:none;pointer-events:none}
.notif-btn__dot.active{display:block;animation:pulse 2s ease-in-out infinite}
.notif-overlay{display:none;position:fixed;inset:0;z-index:190;background:transparent}
.notif-overlay.open{display:block}
.notif-panel{display:none;position:absolute;right:0;top:calc(100% + 8px);width:340px;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:14px;box-shadow:0 12px 48px rgba(0,0,0,.14);z-index:200;overflow:hidden;transform-origin:top right;animation:notifIn .18s ease}
.notif-panel.open{display:block}
@keyframes notifIn{from{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}
.notif-panel__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid rgba(0,0,0,.06)}
.notif-panel__title{font-weight:700;font-size:14px}
.notif-panel__clear{background:none;border:none;color:var(--brand);font-size:12px;font-weight:600;cursor:pointer;padding:4px 10px;border-radius:6px;transition:all var(--ease);font-family:inherit}
.notif-panel__clear:hover{background:var(--brand-glow)}
.notif-panel__body{max-height:320px;overflow-y:auto;overscroll-behavior:contain}
.notif-item{padding:14px 16px;border-bottom:1px solid rgba(0,0,0,.04);display:flex;gap:10px;align-items:flex-start;transition:background .15s ease,opacity .3s ease;cursor:pointer}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:rgba(0,0,0,.02)}
.notif-item.read{opacity:.55}
.notif-item__icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-item__icon--green{background:rgba(74,222,128,.1);color:#16a34a}
.notif-item__icon--blue{background:rgba(59,130,246,.1);color:#2563eb}
.notif-item__icon--amber{background:rgba(245,158,11,.1);color:#d97706}
.notif-item__dot{width:8px;height:8px;border-radius:50%;background:var(--brand2);flex-shrink:0;margin-top:6px;transition:all .3s ease}
.notif-item.read .notif-item__dot{background:rgba(0,0,0,.1);transform:scale(.7)}
.notif-item__content{flex:1;min-width:0}
.notif-item__text{font-size:13px;line-height:1.5;color:var(--ink)}
.notif-item__text strong{font-weight:700}
.notif-item__time{font-size:11px;color:var(--muted);margin-top:3px}
.notif-item__action{font-size:12px;color:var(--brand);font-weight:600;margin-top:4px;display:inline-block}
.notif-item__action:hover{text-decoration:underline}
.notif-empty{padding:32px 16px;text-align:center}
.notif-empty__icon{width:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.04);display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.notif-empty__text{color:var(--muted);font-size:13px}
@media(max-width:420px){.notif-panel{position:fixed;left:12px;right:12px;top:72px;width:auto}}

/* ═══ PHOTO GALLERY ═══ */
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:200px 200px;gap:6px;border-radius:var(--radius);overflow:hidden;margin-bottom:20px}
.gallery__item{position:relative;overflow:hidden;cursor:pointer}
.gallery__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.gallery__item:hover img{transform:scale(1.04)}
.gallery__item--hero{grid-row:1/3}
.gallery__more{position:absolute;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:700;backdrop-filter:blur(2px);transition:background .2s}
.gallery__item:hover .gallery__more{background:rgba(0,0,0,.55)}
@media(max-width:640px){.gallery{grid-template-columns:1fr 1fr;grid-template-rows:220px 150px 150px}.gallery__item--hero{grid-column:1/3}}

/* ═══ LIGHTBOX ═══ */
.lb{display:none;position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.94);backdrop-filter:blur(10px)}
.lb.open{display:flex;flex-direction:column;align-items:center;justify-content:center}
.lb__close{position:fixed;top:16px;right:16px;background:rgba(255,255,255,.12);border:none;color:#fff;width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:24px;display:flex;align-items:center;justify-content:center;transition:all .15s ease;z-index:1010;line-height:1}
.lb__close:hover{background:rgba(255,255,255,.25);transform:scale(1.08)}
.lb__counter{position:fixed;top:22px;left:20px;color:rgba(255,255,255,.5);font-size:13px;font-weight:600;z-index:1010}
.lb__stage{position:relative;display:flex;align-items:center;justify-content:center;width:100%;flex:1;min-height:0;padding:20px}
.lb__slide{display:none;position:absolute;inset:0;align-items:center;justify-content:center;flex-direction:column;padding:60px 80px 20px}
.lb__slide.active{display:flex}
.lb__slide img{max-width:100%;max-height:calc(100vh - 200px);width:auto;height:auto;object-fit:contain;border-radius:10px;box-shadow:0 8px 40px rgba(0,0,0,.4);display:block;margin:0 auto;-webkit-user-drag:none;user-select:none}
.lb__caption{color:rgba(255,255,255,.6);font-size:14px;margin-top:16px;font-weight:500;text-align:center;flex-shrink:0}
.lb__nav{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:none;color:#fff;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;z-index:1010;backdrop-filter:blur(4px)}
.lb__nav:hover{background:rgba(255,255,255,.22);transform:translateY(-50%) scale(1.06)}
.lb__nav--prev{left:16px}.lb__nav--next{right:16px}
.lb__thumbs{display:flex;gap:6px;padding:12px 20px 20px;justify-content:center;overflow-x:auto;width:100%;max-width:100%;flex-shrink:0;-webkit-overflow-scrolling:touch}
.lb__thumb{width:56px;height:40px;border-radius:6px;overflow:hidden;cursor:pointer;opacity:.35;transition:all .15s ease;flex-shrink:0;border:2px solid transparent}
.lb__thumb.active{opacity:1;border-color:rgba(255,255,255,.8)}
.lb__thumb:hover{opacity:.7}
.lb__thumb img{width:100%;height:100%;object-fit:cover}
@media(max-width:700px){.lb__slide{padding:50px 16px 16px}.lb__slide img{max-height:calc(100vh - 180px);border-radius:8px}.lb__nav{width:40px;height:40px}.lb__nav--prev{left:8px}.lb__nav--next{right:8px}.lb__thumbs{padding:8px 12px 16px;gap:5px}.lb__thumb{width:44px;height:32px;border-radius:5px}}
@media(max-width:480px){.lb__slide{padding:46px 8px 12px}.lb__nav{width:36px;height:36px;background:rgba(0,0,0,.4)}.lb__nav--prev{left:4px}.lb__nav--next{right:4px}.lb__caption{font-size:12px;margin-top:10px}}
@media(min-width:1400px){.lb__slide img{max-width:1000px}}
@media(hover:none){.lb__nav{background:rgba(0,0,0,.35)}}

/* ═══ OPENINGS PAGE ═══ */
.openings-hero{background:linear-gradient(145deg,#0b5f57,#0da89e);border-radius:var(--radius);padding:32px;color:#fff;margin-bottom:24px;position:relative;overflow:hidden}
.openings-hero::before{content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none}
.openings-hero::after{content:'';position:absolute;bottom:-80px;left:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.openings-hero>*{position:relative}
.openings-hero__eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.75;margin:0 0 8px}
.openings-hero__title{font-size:30px;font-weight:800;margin:0 0 8px;color:#fff;line-height:1.15}
.openings-hero__lead{font-size:15px;opacity:.85;margin:0;line-height:1.6;max-width:560px}
.openings-hero__stats{display:flex;gap:28px;margin-top:20px;flex-wrap:wrap}
.openings-hero__stat-value{font-size:22px;font-weight:800;line-height:1;display:flex;align-items:center;gap:6px}
.openings-hero__stat-label{font-size:11px;opacity:.65;margin-top:3px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
@media(max-width:600px){.openings-hero{padding:24px 20px}.openings-hero__title{font-size:24px}}

/* Listing card */
.listing{border-radius:var(--radius);overflow:hidden;background:var(--card);border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow);margin-bottom:16px}
.listing__body{padding:26px;display:flex;flex-direction:column;gap:6px}
.listing__badge{display:inline-flex;align-items:center;gap:6px;background:var(--brand-glow);padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--brand);width:fit-content;margin-bottom:4px}
.listing__title{font-size:20px;font-weight:800;margin:0;line-height:1.25}
.listing__meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:2px 0 8px}
.listing__tag{display:inline-flex;align-items:center;gap:4px;padding:4px 11px;border-radius:6px;font-size:12px;font-weight:600;background:rgba(0,0,0,.04);color:var(--muted)}
.listing__desc{color:var(--muted);line-height:1.6;font-size:14px}
.listing__includes{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 2px}
.listing__incl-item{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--muted)}
.listing__incl-item svg{color:var(--brand);flex-shrink:0}
.listing__price{font-size:13.5px;color:var(--muted);margin-top:8px;padding:12px 0;border-top:1px solid rgba(0,0,0,.06)}
.listing__price strong{color:var(--ink);font-size:15px}
.listing__price-help{color:var(--brand);font-weight:600;font-size:12.5px;margin-left:6px;text-decoration:underline;text-underline-offset:2px}
.listing__actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.btn--accent{border-color:var(--brand);color:var(--brand)}.btn--accent:hover{background:var(--brand-glow)}

/* First week */
.first-week{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;margin-bottom:16px}
.first-week__title{font-size:17px;font-weight:800;margin:0 0 4px}
.first-week__sub{color:var(--muted);font-size:13px;margin-bottom:16px}
.first-week__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.first-week__day{padding:14px;border-radius:12px;background:var(--bg);border:1px solid rgba(0,0,0,.04)}
.first-week__day-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--brand);margin-bottom:4px}
.first-week__day-text{font-size:13px;color:var(--muted);line-height:1.5}

/* Coming soon */
.coming-soon{border:2px dashed rgba(11,95,87,.15);background:rgba(11,95,87,.02);border-radius:var(--radius);padding:28px;text-align:center;margin-bottom:16px;transition:all .25s ease}
.coming-soon:hover{border-color:rgba(11,95,87,.25);background:rgba(11,95,87,.04)}
.coming-soon__badge{display:inline-flex;background:var(--brand);color:#fff;padding:5px 14px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px}
.coming-soon__title{font-size:20px;font-weight:800;margin:0 0 4px}
.coming-soon__meta{color:var(--muted);font-size:14px;margin-bottom:10px}
.coming-soon__desc{color:var(--muted);font-size:14px;max-width:480px;margin:0 auto 16px;line-height:1.6}

/* Helpline bar */
.helpline{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 24px;margin-bottom:16px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.helpline__icon{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#0b5f57,#0ea5a0);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.helpline__icon svg{color:#fff}
.helpline__text{flex:1;min-width:200px}
.helpline__title{font-weight:700;font-size:15px;margin:0 0 2px}
.helpline__desc{color:var(--muted);font-size:13px}
.helpline__actions{display:flex;gap:8px;flex-wrap:wrap}
@media(max-width:520px){.helpline{flex-direction:column;text-align:center}.helpline__actions{justify-content:center}}

/* Crisis resources */
.crisis{margin-bottom:16px}
.crisis__toggle{display:flex;align-items:center;gap:8px;padding:14px 18px;background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;width:100%;text-align:left;font-family:inherit;font-size:14px;font-weight:600;color:var(--muted);transition:all var(--ease)}
.crisis__toggle:hover{color:var(--ink);background:rgba(11,95,87,.02)}
.crisis__toggle svg{flex-shrink:0;transition:transform .2s ease}
.crisis__toggle[aria-expanded="true"] svg:last-child{transform:rotate(180deg)}
.crisis__body{display:none;padding:16px 18px;background:var(--card);border:1px solid rgba(0,0,0,.06);border-top:none;border-radius:0 0 var(--radius) var(--radius);margin-top:-8px}
.crisis__body.open{display:block}
.crisis__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.crisis__item{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:10px;background:var(--bg);text-decoration:none;transition:all var(--ease);min-height:48px}
.crisis__item:hover{background:rgba(11,95,87,.04)}
.crisis__item-icon{width:32px;height:32px;border-radius:8px;background:rgba(11,95,87,.06);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.crisis__item-icon svg{color:var(--brand)}
.crisis__item-text{font-size:13px;font-weight:600;color:var(--ink)}
.crisis__item-sub{font-size:11.5px;color:var(--muted);font-weight:400}

/* Hope message */
.hope{text-align:center;padding:24px 20px;margin-bottom:16px}
.hope__text{font-size:16px;font-weight:600;color:var(--ink);font-style:italic;max-width:480px;margin:0 auto;line-height:1.6}
.hope__line{width:40px;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--brand),var(--brand2));margin:0 auto 12px}

/* Help card */
.help-card{padding:20px;border-radius:var(--radius);background:rgba(11,95,87,.03);border:1px solid rgba(11,95,87,.08);text-align:center;margin-top:8px}
.help-card p{color:var(--muted);font-size:14px}
.help-card a{color:var(--brand);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.input-wrap{position:relative;display:flex;align-items:center}.input-wrap .input{flex:1;padding-right:44px}.pw-toggle{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--muted);padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color var(--ease)}.pw-toggle:hover{color:var(--ink)}.pw-toggle.active{color:var(--brand)}

/* ── Events page ── */
.events-intro{margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid rgba(0,0,0,.06)}
.events-intro__eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
.events-intro h1{font-size:36px;letter-spacing:-.025em;line-height:1.08;margin:0 0 10px;max-width:640px}
.events-intro p{color:var(--muted);font-size:16px;line-height:1.55;max-width:560px;margin:0}

.events-section-title{display:flex;align-items:baseline;gap:10px;margin:32px 0 18px}
.events-section-title h2{font-size:16px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin:0}
.events-section-title__count{font-size:13px;font-weight:500;color:var(--muted)}
.events-section-title__line{flex:1;height:1px;background:rgba(0,0,0,.08);margin-left:6px}

.event-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:720px){.event-grid{grid-template-columns:1fr}}

.event-card{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius);overflow:hidden;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1);position:relative;display:flex;flex-direction:column;text-decoration:none;color:inherit}
.event-card:hover{transform:translateY(-2px);box-shadow:0 2px 8px rgba(0,0,0,.04),0 18px 42px rgba(2,6,23,.08)}
.event-card:hover .event-card__cta{color:var(--brand);gap:10px}

.event-card__hero{position:relative;height:170px;overflow:hidden;background:linear-gradient(135deg,#e8f3f1 0%,#f5faf9 100%)}
.event-card__hero img{width:100%;height:100%;object-fit:cover;display:block}
.event-card__hero--placeholder{display:flex;align-items:center;justify-content:center;background:
  radial-gradient(circle at 80% 20%, rgba(11,95,87,.08) 0%, transparent 50%),
  radial-gradient(circle at 20% 80%, rgba(14,165,160,.06) 0%, transparent 50%),
  linear-gradient(135deg,#ecf5f3 0%,#f8fcfb 100%)}
.event-card__hero-icon{color:var(--brand);opacity:.85;transform:scale(2);transition:transform .3s ease}
.event-card:hover .event-card__hero-icon{transform:scale(2.05)}

.event-card__datestamp{position:absolute;top:14px;left:14px;background:#fff;border-radius:10px;padding:8px 12px;box-shadow:0 2px 8px rgba(0,0,0,.08);text-align:center;min-width:54px;line-height:1}
.event-card__datestamp-month{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);display:block}
.event-card__datestamp-day{font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-.02em;display:block;margin-top:1px}

.event-card__badge{position:absolute;top:14px;right:14px;background:#fff;border-radius:999px;padding:5px 12px 5px 8px;box-shadow:0 2px 6px rgba(0,0,0,.08);display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;color:var(--brand);letter-spacing:.02em}
.event-card__badge svg{width:14px;height:14px}

.event-card__body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.event-card__meta{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--muted);margin-bottom:2px}
.event-card__meta-item{display:inline-flex;align-items:center;gap:5px}
.event-card__meta-item svg{flex-shrink:0;opacity:.8}
.event-card__meta-divider{width:3px;height:3px;border-radius:50%;background:rgba(0,0,0,.15)}

.event-card__title{font-size:18px;font-weight:700;letter-spacing:-.01em;line-height:1.3;color:var(--ink);margin:2px 0 0}
.event-card__summary{font-size:14px;line-height:1.55;color:var(--muted);margin:4px 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.event-card__location{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted);margin-top:auto;padding-top:10px}
.event-card__location svg{flex-shrink:0;opacity:.7}

.event-card__cta{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--muted);margin-top:12px;transition:all .2s ease}
.event-card__cta svg{transition:transform .2s ease}

/* Compact card for past events */
.event-card--past{opacity:.75}
.event-card--past .event-card__hero{height:0;padding:0;border:none}

/* Empty state */
.events-empty{text-align:center;padding:56px 24px;background:var(--card);border:1px dashed rgba(0,0,0,.12);border-radius:var(--radius)}
.events-empty__icon{width:56px;height:56px;margin:0 auto 14px;border-radius:50%;background:rgba(11,95,87,.06);display:flex;align-items:center;justify-content:center;color:var(--brand)}
.events-empty h3{font-size:18px;font-weight:700;margin:0 0 6px}
.events-empty p{color:var(--muted);font-size:14px;max-width:380px;margin:0 auto 16px}

/* Event detail page */
.event-detail{max-width:760px;margin:0 auto}
.event-detail__back{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;color:var(--muted);text-decoration:none;margin-bottom:20px;transition:color .15s}
.event-detail__back:hover{color:var(--brand)}
.event-detail__back svg{transition:transform .15s}
.event-detail__back:hover svg{transform:translateX(-3px)}

.event-detail__hero{border-radius:var(--radius);overflow:hidden;margin-bottom:24px;position:relative;background:linear-gradient(135deg,#ecf5f3 0%,#f8fcfb 100%)}
.event-detail__hero--with-img{height:340px}
.event-detail__hero--with-img img{width:100%;height:100%;object-fit:cover}
.event-detail__hero--placeholder{height:200px;display:flex;align-items:center;justify-content:center;background:
  radial-gradient(circle at 80% 20%, rgba(11,95,87,.1) 0%, transparent 55%),
  radial-gradient(circle at 20% 80%, rgba(14,165,160,.08) 0%, transparent 50%),
  linear-gradient(135deg,#ecf5f3 0%,#f8fcfb 100%)}
.event-detail__hero--placeholder svg{color:var(--brand);opacity:.7;transform:scale(2.8)}

.event-detail__header{display:flex;align-items:flex-start;gap:20px;margin-bottom:20px}
.event-detail__datestamp{background:#fff;border-radius:12px;padding:12px 16px;box-shadow:0 1px 3px rgba(0,0,0,.04),0 4px 12px rgba(0,0,0,.06);text-align:center;min-width:76px;line-height:1;flex-shrink:0}
.event-detail__datestamp-month{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);display:block}
.event-detail__datestamp-day{font-size:32px;font-weight:800;color:var(--ink);letter-spacing:-.025em;display:block;margin-top:2px}
.event-detail__datestamp-year{font-size:11px;font-weight:500;color:var(--muted);display:block;margin-top:2px}

.event-detail__head-text{flex:1;min-width:0}
.event-detail__badge{display:inline-flex;align-items:center;gap:6px;background:rgba(11,95,87,.06);color:var(--brand);padding:5px 12px 5px 9px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.02em;margin-bottom:10px}
.event-detail__title{font-size:32px;font-weight:800;letter-spacing:-.025em;line-height:1.15;margin:0 0 8px}
.event-detail__summary{font-size:17px;line-height:1.55;color:var(--muted);margin:0}

.event-detail__facts{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:24px 0 28px;padding:20px;background:rgba(11,95,87,.03);border-radius:14px;border:1px solid rgba(11,95,87,.06)}
@media(max-width:560px){.event-detail__facts{grid-template-columns:1fr}}
.event-detail__fact{display:flex;gap:12px;align-items:flex-start}
.event-detail__fact-icon{width:36px;height:36px;border-radius:9px;background:rgba(11,95,87,.08);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.event-detail__fact-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 2px}
.event-detail__fact-value{font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.4;margin:0}
.event-detail__fact-sub{font-size:13px;color:var(--muted);line-height:1.4;margin:2px 0 0}

.event-detail__body{font-size:16px;line-height:1.75;color:rgba(7,25,34,.9);margin-bottom:28px;white-space:pre-wrap}

.event-detail__actions{display:flex;gap:10px;flex-wrap:wrap;padding-top:20px;border-top:1px solid rgba(0,0,0,.06)}

@media(max-width:560px){
  .event-detail__header{flex-direction:column;gap:14px}
  .event-detail__title{font-size:26px}
  .events-intro h1{font-size:28px}
}

/* ── Photo uploader (drag-drop) ── */
.photo-uploader{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.photo-uploader__zone{position:relative;border:2px dashed rgba(0,0,0,.18);border-radius:12px;padding:28px 20px;text-align:center;cursor:pointer;background:rgba(0,0,0,.015);transition:all .15s ease;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--muted)}
.photo-uploader__zone:hover{border-color:var(--brand);background:rgba(11,95,87,.03);color:var(--brand)}
.photo-uploader__zone.is-dragging{border-color:var(--brand);background:rgba(11,95,87,.06);color:var(--brand);transform:scale(1.01)}
.photo-uploader__zone-icon{opacity:.6;transition:opacity .15s}
.photo-uploader__zone:hover .photo-uploader__zone-icon{opacity:1}
.photo-uploader__zone-text{font-size:14px;color:var(--ink)}
.photo-uploader__zone-text strong{color:var(--brand);font-weight:700}
.photo-uploader__zone-sub{font-size:12px;color:var(--muted)}
.photo-uploader__thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.photo-uploader__thumb{position:relative;aspect-ratio:1/1;border-radius:10px;overflow:hidden;background:rgba(0,0,0,.04);cursor:move;box-shadow:0 1px 3px rgba(0,0,0,.06);transition:transform .15s ease,box-shadow .15s ease}
.photo-uploader__thumb:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,0,0,.1)}
.photo-uploader__thumb.is-dragging-thumb{opacity:.4;transform:scale(.95)}
.photo-uploader__thumb img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.photo-uploader__thumb-badge{position:absolute;bottom:6px;left:6px;background:var(--brand);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px;letter-spacing:.03em;text-transform:uppercase}
.photo-uploader__thumb-remove{position:absolute;top:5px;right:5px;width:22px;height:22px;padding:0;border:0;background:rgba(0,0,0,.65);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s,background .15s}
.photo-uploader__thumb:hover .photo-uploader__thumb-remove{opacity:1}
.photo-uploader__thumb-remove:hover{background:#b91c1c}
.photo-uploader__thumb-drag{position:absolute;top:5px;left:5px;width:20px;height:20px;color:rgba(255,255,255,.85);background:rgba(0,0,0,.45);border-radius:5px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;pointer-events:none}
.photo-uploader__thumb:hover .photo-uploader__thumb-drag{opacity:1}
.photo-uploader__thumb--uploading{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--muted);cursor:default;background:rgba(11,95,87,.05);border:1px dashed rgba(11,95,87,.2)}
.photo-uploader__thumb--uploading:hover{transform:none;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.photo-uploader__spinner{width:24px;height:24px;border:2.5px solid rgba(11,95,87,.15);border-top-color:var(--brand);border-radius:50%;animation:photo-uploader-spin .7s linear infinite}
.photo-uploader__progress{font-size:11px;font-weight:600;color:var(--brand)}
@keyframes photo-uploader-spin{to{transform:rotate(360deg)}}

/* ── Admin dashboard ── */
.dash-hero{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
@media(max-width:900px){.dash-hero{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.dash-hero{grid-template-columns:1fr}}
.dash-metric{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:18px 20px;display:flex;flex-direction:column;gap:4px;transition:all .15s}
.dash-metric:hover{border-color:rgba(11,95,87,.15);box-shadow:0 2px 8px rgba(0,0,0,.04)}
.dash-metric__label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:2px}
.dash-metric__value{font-size:30px;font-weight:800;letter-spacing:-.025em;color:var(--ink);line-height:1.1;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.dash-metric__delta{font-size:12px;font-weight:700;color:#0b5f57;background:rgba(11,95,87,.1);padding:3px 8px;border-radius:999px;letter-spacing:0}
.dash-metric__delta--warn{color:#c2410c;background:rgba(194,65,12,.1)}
.dash-metric__sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.link-quiet{color:var(--muted);text-decoration:none;transition:color .15s}
.link-quiet:hover{color:var(--brand)}

.dash-grid{display:grid;grid-template-columns:1fr 320px;gap:18px;margin-top:20px}
@media(max-width:900px){.dash-grid{grid-template-columns:1fr}}
.dash-col{display:flex;flex-direction:column;gap:16px;min-width:0}
.dash-col--narrow{gap:14px}

.dash-panel{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:14px;overflow:hidden}
.dash-panel__head{padding:14px 18px;border-bottom:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:center;gap:10px}
.dash-panel__title{font-size:14px;font-weight:700;margin:0;letter-spacing:-.005em;color:var(--ink)}
.dash-panel__body{padding:16px 18px}
.dash-panel__body--compact{padding:10px 14px}
.dash-panel__body--flush{padding:0}

.dash-attn-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(0,0,0,.04)}
.dash-attn-row:last-child{border-bottom:0}
.dash-attn-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dash-attn-dot--applications{background:#0b5f57}
.dash-attn-dot--deposit{background:#16a34a}
.dash-attn-dot--story{background:#7c3aed}
.dash-attn-dot--message{background:#2563eb}
.dash-attn-dot--alert{background:#dc2626}
.dash-attn-label{flex:1;font-size:13.5px;font-weight:500;color:var(--ink)}

.dash-empty{text-align:center;padding:20px 12px;color:var(--muted)}
.dash-empty svg{margin-bottom:10px}
.dash-empty p{margin:0;font-size:13.5px}

.dash-chart{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:6px;height:120px;align-items:end;padding-top:20px}
.dash-chart__bar-wrap{display:flex;flex-direction:column;align-items:center;gap:3px;height:100%;justify-content:flex-end;cursor:default}
.dash-chart__count{font-size:10.5px;font-weight:700;color:var(--brand);min-height:14px;line-height:1}
.dash-chart__bar{width:100%;background:linear-gradient(180deg,var(--brand) 0%,var(--brand2) 100%);border-radius:3px 3px 0 0;min-height:2px;transition:opacity .2s}
.dash-chart__bar-wrap:hover .dash-chart__bar{filter:brightness(1.1)}
.dash-chart__day{font-size:10.5px;color:var(--muted);margin-top:4px}

.dash-feed-row{display:flex;align-items:flex-start;gap:10px;padding:11px 18px;border-bottom:1px solid rgba(0,0,0,.04)}
.dash-feed-row:last-child{border-bottom:0}
.dash-feed-row--warn{background:rgba(245,158,11,.03)}
.dash-feed-row--err{background:rgba(220,38,38,.03)}
.dash-feed-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:6px}
.dash-feed-dot--payment{background:#16a34a}
.dash-feed-dot--auth{background:#2563eb}
.dash-feed-dot--admin_action{background:#7c3aed}
.dash-feed-dot--form_submit{background:var(--brand)}
.dash-feed-dot--misc{background:var(--muted)}
.dash-feed-content{flex:1;min-width:0}
.dash-feed-action{font-size:13px;font-weight:600;color:var(--ink);margin:0;line-height:1.4}
.dash-feed-details{font-size:12px;color:var(--muted);margin:2px 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-feed-time{font-size:11.5px;color:var(--muted);flex-shrink:0;margin-left:8px;padding-top:1px}

.dash-quick{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;text-decoration:none;color:var(--ink);font-size:13.5px;font-weight:500;transition:all .12s}
.dash-quick:hover{background:rgba(11,95,87,.05);transform:translateX(2px)}
.dash-quick__icon{width:30px;height:30px;border-radius:8px;background:rgba(11,95,87,.08);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-quick__arrow{margin-left:auto;color:var(--muted);font-size:14px;opacity:0;transition:opacity .15s,transform .15s}
.dash-quick:hover .dash-quick__arrow{opacity:1;transform:translateX(2px)}

.dash-upcoming-row{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;text-decoration:none;color:inherit;transition:background .12s}
.dash-upcoming-row:hover{background:rgba(11,95,87,.04)}
.dash-upcoming-date{width:46px;text-align:center;background:rgba(11,95,87,.08);padding:6px 4px;border-radius:8px;flex-shrink:0}
.dash-upcoming-month{display:block;font-size:9.5px;font-weight:700;color:var(--brand);letter-spacing:.08em;text-transform:uppercase;line-height:1}
.dash-upcoming-day{display:block;font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1;margin-top:2px}
.dash-upcoming-info{flex:1;min-width:0}
.dash-upcoming-title{font-size:13px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-upcoming-sub{font-size:11.5px;color:var(--muted);margin:2px 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.dash-stat-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;border-bottom:1px solid rgba(0,0,0,.04)}
.dash-stat-row:last-child{border-bottom:0}
.dash-stat-label{color:var(--muted)}
.dash-stat-value{font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.dash-stat-value--warn{color:#dc2626}

/* ─────────────────────────────────────────────────────────────
   Mobile refinement + polish layer (added; no overrides that
   change the desktop look). Targets tap-target size, consistent
   stacking, richer focus states, and smoother card depth.
   ───────────────────────────────────────────────────────────── */

/* Minimum tappable size on controls used throughout the app */
.pw-toggle{min-width:44px;min-height:44px;padding:10px}
.btn{transition:background .18s var(--ease),box-shadow .2s var(--ease),transform .15s var(--ease),border-color .15s var(--ease)}

/* Subtle elevation refinement — same layered feel, a touch more defined */
:root{
  --ring:0 0 0 3px rgba(11,95,87,.18);
  --border-soft:rgba(10,26,36,.08);
  --accent:#f0b429;
}
.card{border-color:var(--border-soft)}
.btn:focus-visible{box-shadow:var(--ring);outline:none}
.input:focus,input:focus,textarea:focus,select:focus{box-shadow:var(--ring);outline:none}

/* Make long-form cards breathe a bit more on phones, and tighten on
   very narrow phones so content doesn't feel crushed. */
@media (max-width:640px){
  .section{padding:32px 0}
  .card__body,.card .body{padding:18px}
  .h1,h1{font-size:28px;line-height:1.2}
  .h2,h2{font-size:22px}
  .h3,h3{font-size:17px}
  .lead{font-size:15.5px}
  /* Action rows stack nicely */
  .actions{display:flex;flex-wrap:wrap;gap:8px}
  .actions .btn{flex:1 1 auto;justify-content:center}
  /* Keep the sticky CTA bar readable */
  .sticky-bar .btn{font-size:12.5px;padding:8px 10px;min-height:36px}
}
@media (max-width:420px){
  .container{padding-left:16px;padding-right:16px}
  .btn{padding:9px 14px;font-size:14px;min-height:40px}
  .btn--sm{padding:6px 12px;font-size:12.5px;min-height:34px}
  /* Hero titles */
  .h1,h1{font-size:24px}
  /* Event detail hero spacing */
  .event-detail__header,.event-detail__facts{gap:14px}
  /* Thread post avatar scales down on ultra-narrow */
  li[id^="post-"] > div[aria-hidden],
  li[id^="opening-post-"] > div[aria-hidden]{
    flex-basis:30px !important;width:30px !important;height:30px !important;font-size:12px !important;
  }
}

/* Admin table polish: already wrapped in overflow-x:auto on the users
   page — harmonise scroll behavior + visual scrollbar on iOS/Android. */
.table,[class*="table"] .row{min-width:max-content}

/* Filter bars across admin pages collapse to single column on phones */
@media (max-width:600px){
  .admin-head .admin-nav{gap:6px}
  .admin-head .admin-nav .btn{padding:6px 10px;font-size:12.5px;min-height:34px}
  form[action*="/admin/activity-log"] .field{flex:1 1 100% !important;min-width:0 !important}
}

/* Event-detail top actions (Join / Leave / Ask) wrap gracefully and
   buttons become full-width on narrow screens. */
@media (max-width:480px){
  .event-detail__actions{gap:8px !important}
  .event-detail__actions > form,
  .event-detail__actions > a.btn,
  .event-detail__actions > .btn{flex:1 1 100% !important}
  .event-detail__actions > form .btn{width:100%}
}

/* Footer columns stack cleanly */
@media (max-width:600px){
  .footer__inner{gap:20px !important}
}

/* Nav cta on small phones — keep Apply/Donate reachable, logout-bell tidy */
@media (max-width:520px){
  .nav__cta{gap:6px}
  .nav__cta .btn{padding:7px 10px;font-size:12.5px;min-height:36px}
}

/* Discussion thread (event + opening) — tighten padding on very narrow phones
   without touching desktop rhythm. */
@media (max-width:520px){
  .event-thread,.opening-thread{margin-top:28px;padding-top:18px}
  li[id^="post-"],li[id^="opening-post-"]{padding:10px 12px !important;gap:10px !important}
}

/* Team page already has its own breakpoints — harmonise small-phone text */
@media (max-width:420px){
  .team-card__name{font-size:17px}
  .team-card__bio{font-size:13.5px}
}

/* Links inside cards pick up brand color cleanly instead of blue default */
.card a:not(.btn){color:var(--brand);text-decoration:none}
.card a:not(.btn):hover{text-decoration:underline}

/* ─────────────────────────────────────────────────────────────
   Accessibility + reading quality
   - Skip link (WCAG 2.4.1 Bypass Blocks)
   - Reduced-motion respect (WCAG 2.3.3)
   - Font smoothing on high-DPI displays
   - Readable measure on long-form prose (~65–75 char line length)
   ───────────────────────────────────────────────────────────── */

/* Skip-to-content link — hidden until focused, jumps over the nav */
.skip-link{
  position:absolute;left:-9999px;top:10px;
  background:var(--brand);color:#fff;
  padding:10px 16px;border-radius:10px;
  font-weight:700;font-size:14px;text-decoration:none;
  box-shadow:var(--shadow-hover);
  z-index:1000;
}
.skip-link:focus{left:10px;outline:3px solid var(--accent);outline-offset:2px}

/* Crisper text on macOS/iOS Retina displays */
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}

/* Reading measure for prose — keeps long lines scannable without changing
   the layout of cards, grids, or hero blocks. */
.lead,.hero__lead,.prose,.event-detail__summary,.event-detail__body{max-width:68ch}

/* Respect users who prefer reduced motion (WCAG 2.3.3) — keep transitions
   that are purely state changes, kill entrance animations. */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
}


