/*
 * Payra Enterprise Society Accounts - Frontend UI
 * Login + Member Portal (UI-first)
 */

:root{
  --osa-bg: #f4f7ff;
  --osa-card: rgba(255,255,255,0.86);
  --osa-border: rgba(15,23,42,0.08);
  --osa-text: rgba(15,23,42,0.92);
  --osa-muted: rgba(15,23,42,0.60);
  --osa-blue: #2563eb;
  --osa-blue-2: #1d4ed8;
  --osa-shadow: 0 18px 50px rgba(15,23,42,0.12);
  --osa-radius: 20px;
}

.osa-app, .osa-app *{ box-sizing: border-box; }
.osa-app{ font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }

.osa-logo{
  width: 44px; height: 44px; border-radius: 16px;
  background: linear-gradient(135deg, rgba(37,99,235,1), rgba(99,102,241,1));
  box-shadow: 0 12px 28px rgba(37,99,235,0.25);
}

/* AUTH */
.osa-auth{
  min-height: calc(100vh - 120px);
  display: flex; align-items: center; justify-content: center;
  padding: 26px;
  background:
    radial-gradient(circle at 20% 10%, rgba(37,99,235,0.20), transparent 40%),
    radial-gradient(circle at 80% 30%, rgba(99,102,241,0.18), transparent 45%),
    var(--osa-bg);
}

.osa-auth-card{
  width: min(420px, 92vw);
  border-radius: var(--osa-radius);
  background: var(--osa-card);
  border: 1px solid var(--osa-border);
  box-shadow: var(--osa-shadow);
  overflow: hidden;
}

.osa-auth-top{ padding: 18px; background: rgba(15,23,42,0.02); border-bottom: 1px solid rgba(15,23,42,0.06); }
.osa-brand{ display:flex; gap: 12px; align-items:center; }
.osa-brand-name{ font-weight: 900; color: var(--osa-text); letter-spacing: -0.02em; }
.osa-brand-sub{ color: var(--osa-muted); font-size: 12px; }

.osa-auth-body{ padding: 18px; }
.osa-title{ margin: 0 0 12px; font-size: 22px; letter-spacing: -0.02em; }

.osa-form{ display:flex; flex-direction: column; gap: 12px; }
.osa-field{ display:flex; flex-direction: column; gap: 6px; }
.osa-label{ font-size: 12px; font-weight: 800; color: rgba(15,23,42,0.80); }
.osa-field input{
  height: 44px; border-radius: 14px; border: 1px solid rgba(15,23,42,0.10);
  padding: 0 12px; outline: none; background: rgba(255,255,255,0.90);
}
.osa-field input:focus{ border-color: rgba(37,99,235,0.55); box-shadow: 0 0 0 4px rgba(37,99,235,0.12); }

.osa-check{ display:flex; gap: 10px; align-items:center; font-size: 13px; color: rgba(15,23,42,0.75); }

.osa-btn{
  height: 44px; border-radius: 14px; border: 1px solid transparent;
  display: inline-flex; align-items:center; justify-content:center;
  font-weight: 900; cursor: pointer; text-decoration:none;
}
.osa-btn-primary{ background: var(--osa-blue); color: #fff; box-shadow: 0 14px 26px rgba(37,99,235,0.25); }
.osa-btn-primary:hover{ background: var(--osa-blue-2); }
.osa-btn-ghost{ background: rgba(15,23,42,0.04); color: rgba(15,23,42,0.85); border-color: rgba(15,23,42,0.06); }
.osa-btn-ghost:hover{ background: rgba(15,23,42,0.06); }

.osa-link{ color: rgba(37,99,235,1); text-decoration: none; font-weight: 800; }
.osa-link:hover{ text-decoration: underline; }

.osa-auth-foot{ display:flex; justify-content:center; margin-top: 6px; }

.osa-auth-bottom{ padding: 12px 18px; border-top: 1px solid rgba(15,23,42,0.06); background: rgba(15,23,42,0.02); text-align:center; }
.osa-muted{ color: var(--osa-muted); font-size: 12px; }

.osa-alert{ border-radius: 14px; padding: 10px 12px; font-size: 13px; border: 1px solid; }
.osa-alert-danger{ background: rgba(239,68,68,0.08); border-color: rgba(239,68,68,0.25); color: rgba(127,29,29,1); }
.osa-alert-success{ background: rgba(34,197,94,0.10); border-color: rgba(34,197,94,0.25); color: rgba(22,101,52,1); }

/* PORTAL */
.osa-portal{
  padding: 26px;
  background:
    radial-gradient(circle at 20% 10%, rgba(37,99,235,0.18), transparent 45%),
    radial-gradient(circle at 80% 60%, rgba(99,102,241,0.14), transparent 55%),
    var(--osa-bg);
}

.osa-portal-shell{ max-width: 1150px; margin: 0 auto; }

.osa-portal-header{
  display:flex; align-items:center; justify-content: space-between;
  background: var(--osa-card);
  border: 1px solid var(--osa-border);
  border-radius: var(--osa-radius);
  box-shadow: var(--osa-shadow);
  padding: 16px;
  margin-bottom: 16px;
}

.osa-portal-left{ display:flex; align-items:center; gap: 12px; }
.osa-hello{ font-weight: 900; letter-spacing: -0.02em; color: var(--osa-text); }
.osa-date{ font-size: 12px; color: var(--osa-muted); }

.osa-portal-grid{ display:grid; grid-template-columns: 320px 1fr; gap: 16px; }
@media (max-width: 980px){ .osa-portal-grid{ grid-template-columns: 1fr; } }

.osa-side-card{
  position: sticky; top: 18px;
  background: var(--osa-card);
  border: 1px solid var(--osa-border);
  border-radius: var(--osa-radius);
  box-shadow: 0 20px 50px rgba(15,23,42,0.10);
  padding: 14px;
}

.osa-side-title{ font-weight: 900; margin-bottom: 10px; }
.osa-side-nav{ display:flex; flex-direction: column; gap: 6px; }
.osa-side-nav a{
  display:flex; padding: 10px 12px; border-radius: 14px;
  color: rgba(15,23,42,0.85); text-decoration:none; font-weight: 800;
  background: rgba(15,23,42,0.03);
  border: 1px solid rgba(15,23,42,0.04);
}
.osa-side-nav a:hover{ background: rgba(37,99,235,0.08); border-color: rgba(37,99,235,0.18); }
.osa-side-nav a.is-active{ background: rgba(37,99,235,0.12); border-color: rgba(37,99,235,0.22); }

.osa-kpis{ display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-bottom: 12px; }
@media (max-width: 980px){ .osa-kpis{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 520px){ .osa-kpis{ grid-template-columns: 1fr; } }

.osa-kpi{
  background: var(--osa-card);
  border: 1px solid var(--osa-border);
  border-radius: var(--osa-radius);
  box-shadow: 0 18px 48px rgba(15,23,42,0.10);
  padding: 14px;
}

.osa-kpi-label{ font-size: 12px; color: var(--osa-muted); font-weight: 800; }
.osa-kpi-value{ font-size: 24px; font-weight: 900; margin-top: 6px; letter-spacing: -0.02em; }
.osa-kpi-sub{ margin-top: 6px; font-size: 12px; color: var(--osa-muted); }

.osa-card{
  background: var(--osa-card);
  border: 1px solid var(--osa-border);
  border-radius: var(--osa-radius);
  box-shadow: 0 18px 50px rgba(15,23,42,0.10);
  overflow: hidden;
}

.osa-wide{ margin-bottom: 12px; }

.osa-card-head{ padding: 14px; border-bottom: 1px solid rgba(15,23,42,0.06); display:flex; align-items:flex-start; justify-content: space-between; gap: 12px; }
.osa-card-title{ margin: 0; font-size: 16px; font-weight: 900; letter-spacing: -0.02em; }
.osa-card-desc{ margin: 6px 0 0; font-size: 12px; color: var(--osa-muted); }
.osa-chip{ display:inline-flex; align-items:center; padding: 6px 10px; border-radius: 999px; background: rgba(37,99,235,0.10); border: 1px solid rgba(37,99,235,0.20); font-weight: 900; font-size: 12px; color: rgba(37,99,235,1); }

.osa-card-body{ padding: 14px; }

.osa-chart-skeleton{
  height: 220px; border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(37,99,235,0.10), rgba(37,99,235,0.00)),
    repeating-linear-gradient(0deg, rgba(15,23,42,0.06), rgba(15,23,42,0.06) 1px, transparent 1px, transparent 28px);
  position: relative;
}
.osa-chart-skeleton:after{
  content:'';
  position:absolute; inset: 0;
  background: radial-gradient(circle at 70% 35%, rgba(37,99,235,0.18), transparent 40%);
  border-radius: 16px;
}

.osa-table-wrap{ border: 1px solid rgba(15,23,42,0.06); border-radius: 16px; overflow: hidden; background: rgba(255,255,255,0.70); }
.osa-table{ width:100%; border-collapse: separate; border-spacing:0; }
.osa-table th, .osa-table td{ padding: 12px; border-bottom: 1px solid rgba(15,23,42,0.06); font-size: 13px; }
.osa-table thead th{ background: rgba(15,23,42,0.03); text-align:left; font-weight: 900; }
.osa-table .is-right{ text-align:right; }
.osa-empty{ text-align:center; color: var(--osa-muted); }


/* ==========================================================
   Member Portal UI (UI-first, functional data will be wired later)
   Inspired by the provided clean mobile dashboard layout
   ========================================================== */

.osa-mp{
  --mp-bg:#f5f7fb;
  --mp-card:#ffffff;
  --mp-text:#0f172a;
  --mp-muted:#6b7280;
  --mp-border:rgba(15,23,42,.08);
  --mp-accent:#3b82f6;
  --mp-accent2:#8bd3ff;
  --mp-shadow:0 12px 30px rgba(15,23,42,.08);
  background: linear-gradient(180deg, #eef3ff 0%, var(--mp-bg) 60%, #f7fafc 100%);
  color: var(--mp-text);
  padding: 18px 12px 26px;
}

.osa-mp *{ box-sizing:border-box; }

.osa-mp-shell{
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 18px 18px;
  box-sizing: border-box;
}


.osa-mp-top{
  width: 100%;
  box-sizing: border-box;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  padding: 14px 14px;
  background: rgba(255,255,255,.72);
  border: 1px solid var(--mp-border);
  border-radius: 18px;
  box-shadow: var(--mp-shadow);
  backdrop-filter: blur(8px);
}

.osa-mp-brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 0;
}

.osa-mp-logo{
  width: 46px;
  height: 46px;
  border-radius: 14px;
  object-fit: cover;
  border: 1px solid var(--mp-border);
  background:#fff;
}

.osa-mp-logo--placeholder{
  background: linear-gradient(135deg, rgba(59,130,246,.28), rgba(139,211,255,.35));
}

.osa-mp-brand-meta{ min-width:0; }

.osa-mp-society-name{
  font-weight: 800;
  font-size: 16px;
  line-height: 1.2;
  letter-spacing: .2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.osa-mp-member-line{
  margin-top: 4px;
  font-size: 13px;
  color: var(--mp-muted);
  display:flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items:center;
}

.osa-mp-member-name{ color: var(--mp-text); font-weight: 700; }
.osa-mp-dot{ opacity: .6; }

.osa-mp-actions{
  display:flex;
  align-items:center;
  gap: 10px;
  flex-shrink: 0;
}

.osa-mp-avatar{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  object-fit: cover;
  border: 1px solid var(--mp-border);
  background:#fff;
}

.osa-mp-avatar--placeholder{
  background: radial-gradient(circle at 30% 30%, rgba(59,130,246,.22), rgba(139,211,255,.18));
}

.osa-mp-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid var(--mp-border);
  background:#fff;
  color: var(--mp-text);
  font-weight: 700;
  text-decoration:none;
  transition: transform .12s ease, box-shadow .12s ease;
}

.osa-mp-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(15,23,42,.10);
}

.osa-mp-nav{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  padding: 10px;
  border-radius: 18px;
  background: rgba(255,255,255,.70);
  border: 1px solid var(--mp-border);
  box-shadow: 0 10px 22px rgba(15,23,42,.06);
  backdrop-filter: blur(8px);
}

.osa-mp-navbtn{
  flex: 1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 10px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  font-weight: 800;
  color: var(--mp-muted);
  transition: background .12s ease, color .12s ease, transform .12s ease, border-color .12s ease;
}

.osa-mp-navbtn:hover{ transform: translateY(-1px); }

.osa-mp-navbtn.is-active{
  background: linear-gradient(135deg, rgba(59,130,246,.16), rgba(139,211,255,.22));
  border-color: rgba(59,130,246,.28);
  color: var(--mp-text);
}

.osa-mp-navico{
  width: 28px;
  height: 28px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.8);
  border: 1px solid var(--mp-border);
  font-size: 14px;
}

.osa-mp-main{ margin-top: 14px; }

.osa-mp-panel{ display:none; }
.osa-mp-panel.is-active{ display:block; }

.osa-mp-hero{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.osa-mp-hero-card{
  background: var(--mp-card);
  border: 1px solid var(--mp-border);
  border-radius: 22px;
  box-shadow: var(--mp-shadow);
  padding: 16px;
}

.osa-mp-hero-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
}

.osa-mp-hero-title{
  font-weight: 900;
  font-size: 16px;
}

.osa-mp-hero-sub{
  margin-top: 4px;
  color: var(--mp-muted);
  font-size: 13px;
}

.osa-mp-chip{
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(59,130,246,.10);
  border: 1px solid rgba(59,130,246,.18);
  color: var(--mp-text);
  font-weight: 800;
  font-size: 12px;
  white-space: nowrap;
}

.osa-mp-hero-body{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 220px 1fr;
  gap: 14px;
  align-items:center;
}

.osa-mp-ring{
  width: 210px;
  height: 210px;
  border-radius: 999px;
  background: conic-gradient(var(--mp-accent) 0deg, var(--mp-accent2) 110deg, rgba(15,23,42,.08) 110deg 360deg);
  display:flex;
  align-items:center;
  justify-content:center;
  margin: 0 auto;
  position: relative;
}

.osa-mp-ring::after{
  content:'';
  position:absolute;
  inset: 16px;
  border-radius: 999px;
  background: var(--mp-card);
  border: 1px solid var(--mp-border);
}

.osa-mp-ring-inner{
  position: relative;
  z-index: 2;
  text-align:center;
  padding: 8px 10px;
}

.osa-mp-ring-value{
  font-weight: 900;
  font-size: 30px;
  line-height: 1.1;
}

.osa-mp-ring-label{
  margin-top: 6px;
  font-weight: 800;
  color: var(--mp-muted);
  font-size: 12px;
}

.osa-mp-mini{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.osa-mp-mini-card{
  border-radius: 18px;
  border: 1px solid var(--mp-border);
  background: linear-gradient(135deg, rgba(59,130,246,.10), rgba(139,211,255,.16));
  padding: 14px;
}

.osa-mp-mini-title{
  font-weight: 800;
  color: var(--mp-muted);
  font-size: 12px;
}

.osa-mp-mini-value{
  margin-top: 8px;
  font-weight: 900;
  font-size: 20px;
  color: var(--mp-text);
}

.osa-mp-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.osa-mp-kpi{
  background: var(--mp-card);
  border: 1px solid var(--mp-border);
  border-radius: 18px;
  padding: 14px;
  box-shadow: 0 10px 22px rgba(15,23,42,.06);
}

.osa-mp-kpi-title{
  font-weight: 800;
  color: var(--mp-muted);
  font-size: 12px;
}

.osa-mp-kpi-value{
  margin-top: 8px;
  font-weight: 900;
  font-size: 20px;
  color: var(--mp-text);
}

.osa-mp-card{
  margin-top: 14px;
  background: var(--mp-card);
  border: 1px solid var(--mp-border);
  border-radius: 22px;
  box-shadow: var(--mp-shadow);
}

.osa-mp-card-head{
  padding: 16px 16px 10px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
}

.osa-mp-card-title{
  font-weight: 900;
  font-size: 16px;
}

.osa-mp-card-sub{
  margin-top: 4px;
  color: var(--mp-muted);
  font-size: 13px;
}

.osa-mp-card-body{ padding: 0 16px 16px; }

.osa-mp-empty{
  padding: 16px;
  border-radius: 18px;
  border: 1px dashed rgba(15,23,42,.18);
  background: rgba(15,23,42,.02);
  color: var(--mp-muted);
  font-weight: 700;
}

.osa-mp-project{
  border-radius: 18px;
  border: 1px solid var(--mp-border);
  background: linear-gradient(135deg, rgba(59,130,246,.08), rgba(255,255,255,1));
  padding: 16px;
}

.osa-mp-project-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}

.osa-mp-project-title{
  font-weight: 900;
  font-size: 16px;
}

.osa-mp-pill{
  display:inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  background: rgba(16,185,129,.10);
  border: 1px solid rgba(16,185,129,.18);
}

.osa-mp-project-grid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.osa-mp-stat{
  border-radius: 16px;
  border: 1px solid var(--mp-border);
  background: rgba(255,255,255,.85);
  padding: 12px;
}

.osa-mp-stat-k{
  font-weight: 800;
  font-size: 12px;
  color: var(--mp-muted);
}

.osa-mp-stat-v{
  margin-top: 6px;
  font-weight: 900;
  font-size: 18px;
}

.osa-mp-project-note{
  margin-top: 10px;
  color: var(--mp-muted);
  font-size: 13px;
  font-weight: 700;
}

.osa-mp-tablewrap{
  overflow:auto;
  border-radius: 18px;
  border: 1px solid var(--mp-border);
}

.osa-mp-table{
  width:100%;
  border-collapse: separate;
  border-spacing: 0;
  min-width: 820px;
  background:#fff;
}

.osa-mp-table thead th{
  position: sticky;
  top: 0;
  background: rgba(245,247,251,.92);
  border-bottom: 1px solid var(--mp-border);
  padding: 12px 12px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--mp-muted);
  font-weight: 900;
}

.osa-mp-table td{
  padding: 12px 12px;
  border-bottom: 1px solid rgba(15,23,42,.06);
  color: var(--mp-text);
  font-weight: 700;
  font-size: 13px;
  white-space: nowrap;
}

.osa-mp-table .is-right{ text-align:right; }

.osa-mp-td-empty{
  text-align:center;
  color: var(--mp-muted) !important;
  padding: 26px 12px !important;
  font-weight: 800 !important;
}

/* Responsive */
@media (max-width: 980px){
  .osa-mp-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .osa-mp-hero-body{ grid-template-columns: 1fr; }
  .osa-mp-ring{ width: 200px; height: 200px; }
}

@media (max-width: 560px){
  .osa-mp-top{ flex-direction: column; align-items: stretch; }
  .osa-mp-actions{ justify-content: space-between; }
  .osa-mp-nav{ gap: 8px; padding: 8px; }
  .osa-mp-navico{ display:none; }
  .osa-mp-btn{ width: 100%; }
  .osa-mp-mini{ grid-template-columns: 1fr; }
  .osa-mp-project-grid{ grid-template-columns: 1fr; }
}


/* Member Portal - Statement tools */
.osa-mp-stmt-tools{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.osa-mp-stmt-form{
  display:flex;
  align-items:flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.osa-mp-stmt-field{
  display:flex;
  flex-direction:column;
  gap: 6px;
  font-size: 12px;
  color: var(--mp-muted);
}

.osa-mp-input{
  height: 40px;
  padding: 8px 12px;
  border-radius: 14px;
  border: 1px solid var(--mp-border);
  background: #fff;
  color: var(--mp-text);
  outline: none;
  min-width: 160px;
}

.osa-mp-input:focus{
  box-shadow: 0 0 0 3px rgba(16, 185, 129, .18);
  border-color: rgba(16, 185, 129, .45);
}

.osa-mp-note{
  margin-bottom: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid var(--mp-border);
  background: rgba(255,255,255,.70);
  color: var(--mp-muted);
  font-size: 13px;
}

/* ---- My Investment: details toggle (minimal, consistent with existing UI) ---- */
.osa-mp-project-actions{
  margin-top: 10px;
  display: flex;
  justify-content: flex-end;
}

.osa-mp-project-toggle{
  border: 1px solid var(--mp-border);
  background: rgba(255,255,255,.75);
  color: var(--mp-muted);
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 13px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.osa-mp-project-toggle:hover{
  background: rgba(255,255,255,.92);
}

.osa-mp-chevron{
  display: inline-block;
  transform: translateY(-1px);
}

.osa-mp-project.is-open .osa-mp-chevron{
  transform: rotate(180deg) translateY(1px);
}

.osa-mp-project-details{
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed var(--mp-border);
}

.osa-mp-details-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.osa-mp-detail{
  border: 1px solid var(--mp-border);
  background: rgba(255,255,255,.60);
  border-radius: 14px;
  padding: 10px 12px;
}

.osa-mp-detail-label{
  font-size: 12px;
  color: var(--mp-muted);
  margin-bottom: 4px;
}

.osa-mp-detail-value{
  font-size: 14px;
  color: var(--mp-text);
  font-weight: 600;
}

@media (max-width: 560px){
  .osa-mp-details-grid{
    grid-template-columns: 1fr;
  }
}


/* =========================================================
   Member Portal UI v2 (mobile-first, based on provided UI)
   - Keeps existing HTML content, only restyles + new header card
   ========================================================= */

.osa-mp{
  background: #f4f6fb;
  padding: 18px 12px 84px;
  min-height: 100vh;
}

.osa-mp-shell{
  max-width: 1180px;
  margin: 0 auto;
}

@media (max-width: 720px){
  .osa-mp-shell{ max-width: 430px; }
}

.osa-app-top{
  margin-bottom: 14px;
}

/* Profile card */
.osa-profile-card{
  background: rgba(255,255,255,0.9);
  border: 1px solid var(--osa-border);
  border-radius: 26px;
  padding: 16px 16px 14px;
  box-shadow: 0 16px 30px rgba(15,23,42,0.06);
  backdrop-filter: blur(8px);
}

.osa-toprow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
}

.osa-top-actions{
  display:flex;
  align-items:center;
  gap: 10px;
}

.osa-society{
  display:flex;
  align-items:center;
  gap:10px;
  min-width: 0;
}

.osa-society-logo{
  width: 52px;
  height: 52px;
  border-radius: 18px;
  object-fit: cover;
}

.osa-society-logo--lg{
  width: 76px;
  height: 76px;
  border-radius: 28px;
}

.osa-society-logo--placeholder{
  width: 52px;
  height: 52px;
  border-radius: 18px;
  background: rgba(15,23,42,0.08);
}

.osa-society-logo--placeholder.osa-society-logo--lg{
  width: 76px;
  height: 76px;
  border-radius: 28px;
}

.osa-society-name{
  font-weight: 700;
  font-size: 14px;
  color: var(--osa-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.osa-iconbtn{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1px solid var(--osa-border);
  background: rgba(255,255,255,0.9);
  color: var(--osa-text);
  text-decoration: none;
  box-shadow: 0 10px 18px rgba(15,23,42,0.05);
}
.osa-iconbtn:hover{ filter: brightness(0.98); }
.osa-iconbtn:active{ transform: translateY(1px); }

/* Bell modal */
.osa-bell-modal{
  position: fixed;
  inset: 0;
  z-index: 999999;
  /*
    IMPORTANT: Some themes override the HTML [hidden] attribute (e.g. [hidden]{display:block}).
    To guarantee open/close works everywhere, the modal is hidden/shown via an explicit class.
  */
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 84px 14px 14px;
}
.osa-bell-modal.is-open{
  display: flex;
}
.osa-bell-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,0.45);
  backdrop-filter: blur(2px);
}
.osa-bell-panel{
  position: relative;
  width: min(520px, calc(100% - 28px));
  margin: 0;
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(15,23,42,0.12);
  border-radius: 18px;
  box-shadow: 0 26px 70px rgba(15,23,42,0.22);
  overflow: hidden;
  max-height: calc(100vh - 110px);
  overflow: auto;
}
.osa-bell-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 14px;
  border-bottom: 1px solid rgba(15,23,42,0.10);
}
.osa-bell-title{
  font-weight: 800;
  color: var(--osa-text);
  font-size: 15px;
}
.osa-bell-close{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,0.12);
  background: rgba(255,255,255,0.9);
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  color: var(--osa-text);
}
.osa-bell-body{
  padding: 12px 14px 14px;
}
.osa-bell-line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 10px 10px;
  border: 1px solid rgba(15,23,42,0.10);
  border-radius: 14px;
  background: rgba(244,246,251,0.75);
  margin-bottom: 8px;
}
.osa-bell-k{
  font-size: 12px;
  color: rgba(15,23,42,0.72);
  font-weight: 700;
}
.osa-bell-v{
  font-size: 13px;
  color: rgba(15,23,42,0.92);
  font-weight: 800;
  text-align: right;
}
.osa-bell-updated{
  margin-top: 10px;
  font-size: 11px;
  color: rgba(15,23,42,0.6);
}
@media (max-width: 720px){
  .osa-bell-modal{ padding-top: 64px; }
  .osa-bell-panel{ max-height: calc(100vh - 90px); }
}


.osa-avatar-wrap{
  display:flex;
  justify-content:center;
  margin-top: 12px;
  margin-bottom: 10px;
}

.osa-avatar{
  width: 84px;
  height: 84px;
  border-radius: 999px;
  object-fit: cover;
  border: 6px solid rgba(85,224,57,0.18);
  background: #fff;
}

.osa-avatar--placeholder{
  background: rgba(15,23,42,0.08);
}

.osa-member-name{
  text-align:center;
  font-size: 22px;
  font-weight: 800;
  color: var(--osa-text);
  letter-spacing: -0.02em;
}

.osa-member-sub{
  margin-top: 4px;
  text-align:center;
  font-size: 12px;
  color: rgba(15,23,42,0.65);
  display:flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content:center;
  align-items:center;
}
.osa-dot{ opacity: .6; }

.osa-stats3{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
}

.osa-stat{
  text-align:center;
  padding: 10px 8px;
  border-radius: 16px;
  border: 1px solid var(--osa-border);
  background: rgba(255,255,255,0.75);
}

.osa-stat-value{
  font-weight: 800;
  font-size: 14px;
  color: var(--osa-text);
}

.osa-stat-label{
  margin-top: 2px;
  font-size: 11px;
  color: rgba(15,23,42,0.62);
}

/* Panels area */
.osa-mp-main{
  margin-top: 14px;
}

/* Make existing cards match the new style */
.osa-mp-card,
.osa-mp-hero-card{
  border-radius: 22px !important;
  background: rgba(255,255,255,0.92) !important;
  border: 1px solid var(--osa-border) !important;
  box-shadow: 0 16px 30px rgba(15,23,42,0.06) !important;
}

.osa-mp-hero{
  padding: 0 !important;
  margin-bottom: 14px !important;
}

.osa-mp-hero-head{
  padding: 14px 16px 0 !important;
}

.osa-mp-hero-title{
  font-size: 18px !important;
  font-weight: 800 !important;
}
.osa-mp-hero-sub{
  font-size: 12px !important;
  opacity: 0.75;
}

.osa-mp-mini{
  padding: 12px 16px 16px !important;
  gap: 10px !important;
}
.osa-mp-mini-card{
  border-radius: 18px !important;
}

/* Bottom nav (app-like) */
.osa-mp-nav{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 12px 14px calc(12px + env(safe-area-inset-bottom));
  background: rgba(244,246,251,0.92);
  backdrop-filter: blur(10px);
  border-top: 1px solid rgba(15,23,42,0.06);
  display:flex;
  justify-content:center;
  z-index: 9999;
}

.osa-mp-navbtn{
  flex: 1;
  max-width: 140px;
  border: none;
  background: transparent;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 6px;
  padding: 8px 6px;
  border-radius: 18px;
  color: rgba(15,23,42,0.58);
  cursor: pointer;
}

.osa-mp-navico{
  width: 40px;
  height: 40px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,0.85);
  border: 1px solid rgba(15,23,42,0.08);
  box-shadow: 0 12px 18px rgba(15,23,42,0.05);
  font-size: 18px;
}

.osa-mp-navtxt{
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.osa-mp-navbtn.is-active{
  color: var(--osa-text);
}

.osa-mp-navbtn.is-active .osa-mp-navico{
  border-color: rgba(85,224,57,0.45);
  box-shadow: 0 16px 24px rgba(85,224,57,0.14);
}

/* Make room for fixed nav */
.osa-mp-shell{
  padding-bottom: 84px;
}

/* Statement toolbar polish */
.osa-mp-stmt-tools{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.osa-mp-stmt-tools input[type="date"]{
  border-radius: 14px;
}
.osa-mp-stmt-tools .osa-mp-btn{
  border-radius: 14px;
}

/* Investment cards */
.osa-mp-proj{
  border-radius: 22px !important;
}
.osa-mp-proj-head{
  align-items: center;
}



/* === Portal no-tabs layout (Dashboard -> My Investment -> Statement) === */
.osa-mp-main{padding-bottom:24px;}
.osa-mp-section{margin-top:16px;}
.osa-mp-section-head{
  padding:10px 6px 6px;
}
.osa-mp-section-title{
  font-size:18px;
  font-weight:700;
  letter-spacing:-0.02em;
  color:#0f172a;
}
.osa-mp-section-sub{
  margin-top:4px;
  font-size:12px;
  color:#64748b;
}


/* === Portal theme inspired by provided UI (soft background, white cards, blue accordion headers) === */
.osa-mp{
  background: radial-gradient(1200px 600px at 20% 0%, rgba(64, 141, 255, 0.10), transparent 60%),
              radial-gradient(1000px 500px at 90% 30%, rgba(0, 170, 255, 0.10), transparent 60%),
              #eef3f7;
  min-height: 100vh;
  padding: 26px 16px;
}
.osa-mp-shell{max-width: 1240px; margin: 0 auto; padding: 0 12px;}

@media (max-width: 980px){
  .osa-mp-shell{max-width: 720px; padding: 0 10px;}
  .osa-mp{padding: 18px 10px;}
}
@media (max-width: 720px){
  .osa-mp-shell{max-width: 520px; padding: 0 8px;}
  .osa-society-logo, .osa-society-logo--placeholder{width:88px; height:88px; border-radius:28px;}
  .osa-avatar, .osa-avatar--placeholder{width:72px;height:72px;border-radius:28px;}
}

.osa-mp-top{
  background:#fff;
  border-radius:18px;
  padding:14px 14px;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
  margin-bottom: 14px;
}
.osa-profile-card{padding:0; box-shadow:none; border:none; background:transparent; width:100%;}
.osa-toprow{display:flex; align-items:center; justify-content:space-between; gap:10px;}
.osa-society{display:flex; align-items:center; gap:10px;}
.osa-society-logo, .osa-society-logo--placeholder{width:104px; height:104px; border-radius:32px;}
.osa-society-name{font-size:12px;color:#64748b;font-weight:700;}
.osa-avatar-wrap{display:flex; justify-content:center; margin-top:10px;}
.osa-avatar, .osa-avatar--placeholder{width:84px;height:84px;border-radius:999px; box-shadow: 0 14px 28px rgba(15,23,42,0.10);}
.osa-greet{font-size:12px;color:#94a3b8;margin-top:10px;text-align:center;}
.osa-member-name{font-size:18px;font-weight:900;color:#0f172a;text-align:center; margin-top:4px;}
.osa-member-sub{display:flex; justify-content:center; align-items:center; gap:8px; flex-wrap:wrap; margin-top:6px;}
.osa-member-role{font-size:12px;color:#64748b;font-weight:700;}
.osa-member-meta{font-size:12px;color:#475569;font-weight:800;}
.osa-dot{color:#cbd5e1;}
.osa-iconbtn{
  width:40px;height:40px;border-radius:14px;
  border:1px solid rgba(15,23,42,0.08);
  background:#fff;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
  display:flex;align-items:center;justify-content:center;
}
.osa-iconbtn span{font-size:16px; line-height:1;}
.osa-logout{margin-left:0;}
/* No tabs */
.osa-mp-main{padding-bottom:18px;}

/* Accordion */
.osa-sec{
  border-radius:18px;
  overflow:hidden;
  margin-top: 14px;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}
.osa-sec-head{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  padding: 14px 14px;
  background: linear-gradient(180deg, #1976d2, #0f5fb3);
  border:0;
  cursor:pointer;
  text-align:left;
}
.osa-sec-title{
  color:#fff;
  font-size:14px;
  font-weight:900;
  letter-spacing:-0.01em;
}
.osa-sec-meta{
  margin-left:auto;
  color: rgba(255,255,255,0.86);
  font-size:11px;
  font-weight:700;
  max-width: 420px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.osa-sec-caret{
  color:#fff;
  font-size:16px;
  transform: rotate(-90deg);
  transition: transform .2s ease;
}
.osa-sec--open .osa-sec-caret{transform: rotate(0deg);}
.osa-sec-body{
  background:#fff;
  padding: 12px 12px 14px;
  display:none;
}
.osa-sec--open .osa-sec-body{display:block;}

/* Inner blocks consistent */
.osa-mp-hero-card, .osa-mp-card{
  background:#fff;
  border-radius:16px;
  box-shadow:none;
  border:1px solid rgba(15,23,42,0.06);
}
.osa-mp-hero-card{padding:14px;}
.osa-mp-kpis{display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:10px; margin-top:12px;}
.osa-mp-kpi{
  border-radius:14px; padding:10px;
  background:#f7fafc;
  border:1px solid rgba(15,23,42,0.06);
}
.osa-mp-kpi-title{font-size:11px;color:#64748b;font-weight:800;}
.osa-mp-kpi-value{font-size:14px;font-weight:900;color:#0f172a;margin-top:4px;}
.osa-mp-table-wrap{border-radius:14px; overflow:auto; border:1px solid rgba(15,23,42,0.06);}
.osa-mp-table th{font-size:11px;color:#64748b;font-weight:900;background:#f8fafc;}
.osa-mp-table td{font-size:12px;color:#0f172a;}


/* === Portal-only mode: hide theme chrome, show only portal === */
html.osa-portal-only #wpadminbar{display:none !important;}
html.osa-portal-only{margin-top:0 !important;}
body.osa-portal-only{margin:0 !important; padding:0 !important;}

/* Hide only THEME chrome (top-level), not portal internal header */
body.osa-portal-only > header,
body.osa-portal-only > footer,
body.osa-portal-only > nav,
body.osa-portal-only > .site-header,
body.osa-portal-only > .site-footer,
body.osa-portal-only > #masthead,
body.osa-portal-only > #colophon{display:none !important;}

/* Force portal to cover full viewport */
.osa-portal-only .osa-mp{
  position: fixed;
  inset: 0;
  overflow: auto;
  z-index: 999999;
  padding: 18px 12px;
}
.osa-portal-only .osa-mp-shell{
  max-width: 100%;
}

/* Logout button with label */
.osa-iconbtn.osa-logout{
  width:auto;
  min-width: 44px;
  padding: 10px 12px;
  gap: 8px;
}
.osa-iconbtn.osa-logout .osa-logout-ic{font-size:16px; line-height:1;}
.osa-iconbtn.osa-logout .osa-logout-text{
  font-size:12px;
  font-weight:900;
  color:#0f172a;
}


/* === My Investment cards: match portal UI system === */
.osa-mp-project{
  background:#fff;
  border:1px solid rgba(15,23,42,0.06);
  border-radius:16px;
  padding:14px;
  margin-top:12px;
}
.osa-mp-project-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.osa-mp-project-title{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.osa-mp-avatar, .osa-mp-avatar-img, .osa-mp-avatar-fallback{
  width:44px;
  height:44px;
  border-radius:16px;
}
.osa-mp-avatar-fallback{
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:#0f172a;
  background:#e8f0ff;
  border:1px solid rgba(25,118,210,0.12);
}
.osa-mp-project-name{
  font-size:14px;
  font-weight:900;
  color:#0f172a;
  line-height:1.15;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width: 240px;
}
.osa-mp-project-meta{
  margin-top:4px;
  font-size:12px;
  font-weight:700;
  color:#64748b;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.osa-mp-project-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px;
}
.osa-mp-stat{
  background:#f7fafc;
  border:1px solid rgba(15,23,42,0.06);
  border-radius:14px;
  padding:10px;
}
.osa-mp-stat-label{
  font-size:11px;
  font-weight:800;
  color:#64748b;
}
.osa-mp-stat-val{
  font-size:13px;
  font-weight:900;
  color:#0f172a;
  margin-top:4px;
}
.osa-mp-details{
  margin-top:12px;
  border-top:1px solid rgba(15,23,42,0.06);
  padding-top:12px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
}
.osa-mp-detail{
  border:1px solid rgba(15,23,42,0.06);
  background:#fff;
  border-radius:14px;
  padding:10px;
}
.osa-mp-detail-label{
  font-size:11px;
  font-weight:800;
  color:#64748b;
}
.osa-mp-detail-val{
  font-size:12px;
  font-weight:900;
  color:#0f172a;
  margin-top:4px;
  word-break:break-word;
}
@media (max-width: 460px){
  .osa-mp-project-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .osa-mp-details{ grid-template-columns: 1fr; }
  .osa-mp-project-name{ max-width: 190px; }
}


/* === My Investment cards: row-based layout to match portal UI === */
.osa-mi-card{
  background:#fff;
  border-radius:16px;
  border:1px solid rgba(15,23,42,0.06);
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.osa-mi-photo{
  display:flex;
  justify-content:center;
  align-items:center;
  margin-top:2px;
}
.osa-mi-photo-img{
  width:72px;
  height:72px;
  border-radius:24px;
  object-fit:cover;
  box-shadow: 0 14px 28px rgba(15,23,42,0.10);
}
.osa-mi-photo-fallback{
  width:72px;
  height:72px;
  border-radius:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:#0f172a;
  background:#e2e8f0;
}
.osa-mi-info{
  text-align:center;
}
.osa-mi-code{
  font-size:12px;
  font-weight:900;
  color:#0f5fb3;
}
.osa-mi-name{
  margin-top:4px;
  font-size:14px;
  font-weight:900;
  color:#0f172a;
}
.osa-mi-mobile{
  margin-top:4px;
  font-size:12px;
  font-weight:800;
  color:#475569;
}
.osa-mi-row{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
}
.osa-mi-metric{
  border-radius:14px;
  padding:10px;
  background:#f7fafc;
  border:1px solid rgba(15,23,42,0.06);
}
.osa-mi-label{
  font-size:11px;
  color:#64748b;
  font-weight:800;
}
.osa-mi-value{
  margin-top:4px;
  font-size:14px;
  font-weight:900;
  color:#0f172a;
}
.osa-mi-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.osa-mi-actions .osa-mp-project-toggle{
  border:1px solid rgba(15,23,42,0.08);
  background:#fff;
  border-radius:14px;
  padding:10px 12px;
  font-weight:900;
  color:#0f172a;
}
.osa-mi-actions .osa-mp-chevron{margin-left:6px;}


/* === My Investment card row-2 single-line meta === */
.osa-mi-card .osa-mi-info{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
}
.osa-mi-card .osa-mi-code{
  padding:6px 10px;
  border-radius:999px;
  background:#eef2ff;
  border:1px solid rgba(15,23,42,0.08);
  font-size:11px;
  font-weight:900;
  color:#1e293b;
  flex:0 0 auto;
}
.osa-mi-card .osa-mi-name{
  font-size:13px;
  font-weight:900;
  color:#0f172a;
  flex:1 1 auto;
  min-width:140px;
}
.osa-mi-card .osa-mi-mobile{
  font-size:12px;
  font-weight:800;
  color:#475569;
  flex:0 0 auto;
}
/* Row-5 status badge (colorful like before) */
.osa-mi-card .osa-mi-status{
  padding:6px 10px;
  border-radius:999px;
  background: linear-gradient(180deg, #22c55e, #16a34a);
  color:#fff;
  font-size:11px;
  font-weight:900;
  box-shadow: 0 10px 18px rgba(34,197,94,0.18);
}

.osa-mi-status--history{
  background: linear-gradient(180deg, rgba(15,23,42,.65), rgba(15,23,42,.85));
  box-shadow: 0 10px 18px rgba(15,23,42,0.18);
}
/* View details button in card */
.osa-mi-card .osa-mp-project-toggle{
  border:0;
  background:transparent;
  padding:8px 10px;
  border-radius:12px;
  font-weight:900;
  font-size:12px;
  color:#0f172a;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:8px;
}
.osa-mi-card .osa-mp-project-toggle:hover{
  background:#f1f5f9;
}
.osa-mi-card .osa-mp-project-details{
  margin-top:10px;
  border-top:1px solid rgba(15,23,42,0.06);
  padding-top:12px;
}

.osa-mp-stmt-actions{display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap;}


/* Prevent background scroll when modal open */
html.osa-modal-open, body.osa-modal-open{overflow:hidden;}

/* v1.1.31: Member Portal UI matched with Payra admin light UI */
html.osa-portal-only,
body.osa-portal-only{
  background:#f3f6fb!important;
}
.osa-portal-only .osa-mp,
.osa-mp{
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif!important;
  color:#0f172a!important;
  background:#f3f6fb!important;
  padding:18px!important;
  min-height:100vh!important;
}
.osa-portal-only .osa-mp{
  position:fixed!important;
  inset:0!important;
  overflow:auto!important;
  z-index:999999!important;
}
.osa-mp *,
.osa-mp *:before,
.osa-mp *:after{box-sizing:border-box!important;}
.osa-mp-shell{
  width:100%!important;
  max-width:1180px!important;
  margin:0 auto!important;
  padding:0!important;
}
.osa-mp-top{
  margin:0 0 14px 0!important;
  padding:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.osa-profile-card{
  position:relative!important;
  width:100%!important;
  padding:16px!important;
  border-radius:16px!important;
  border:1px solid rgba(15,23,42,.06)!important;
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,255,255,.86))!important;
  box-shadow:0 18px 60px rgba(15,23,42,.06)!important;
  overflow:hidden!important;
}
.osa-profile-card:before{
  content:""!important;
  position:absolute!important;
  inset:0 0 auto 0!important;
  height:3px!important;
  background:linear-gradient(90deg,rgba(85,224,57,.85),rgba(37,99,235,.85))!important;
}
.osa-toprow{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
  margin-bottom:10px!important;
}
.osa-society-logo,
.osa-society-logo--placeholder,
.osa-society-logo--lg,
.osa-society-logo--placeholder.osa-society-logo--lg{
  width:46px!important;
  height:46px!important;
  border-radius:14px!important;
  object-fit:cover!important;
  border:1px solid rgba(15,23,42,.06)!important;
  background:#fff!important;
  box-shadow:0 10px 30px rgba(15,23,42,.08)!important;
}
.osa-society-logo--placeholder,
.osa-society-logo--placeholder.osa-society-logo--lg{
  background:radial-gradient(circle at 30% 30%,rgba(85,224,57,.35),rgba(85,224,57,0) 62%),linear-gradient(135deg,rgba(37,99,235,.18),rgba(37,99,235,0) 55%),#0f172a!important;
}
.osa-top-actions{display:flex!important;align-items:center!important;gap:8px!important;}
.osa-iconbtn,
.osa-iconbtn.osa-logout{
  width:38px!important;
  height:38px!important;
  min-width:38px!important;
  padding:0!important;
  border-radius:12px!important;
  border:1px solid rgba(15,23,42,.10)!important;
  background:#fff!important;
  color:#0f172a!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-decoration:none!important;
  box-shadow:0 10px 30px rgba(15,23,42,.06)!important;
}
.osa-avatar-wrap{margin:4px 0 8px!important;}
.osa-avatar,
.osa-avatar--placeholder{
  width:78px!important;
  height:78px!important;
  border-radius:24px!important;
  object-fit:cover!important;
  border:5px solid rgba(85,224,57,.14)!important;
  background:#fff!important;
  box-shadow:0 16px 36px rgba(15,23,42,.10)!important;
}
.osa-greet{margin-top:0!important;text-align:center!important;font-size:12px!important;font-weight:700!important;color:rgba(15,23,42,.55)!important;}
.osa-member-name{margin-top:3px!important;text-align:center!important;font-size:20px!important;line-height:1.2!important;font-weight:800!important;color:#0f172a!important;letter-spacing:-.3px!important;}
.osa-member-sub{margin-top:6px!important;text-align:center!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-wrap:wrap!important;gap:6px!important;color:rgba(15,23,42,.65)!important;font-size:12px!important;}
.osa-member-role,
.osa-member-meta{font-size:12px!important;font-weight:700!important;color:rgba(15,23,42,.66)!important;}
.osa-stats3{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:10px!important;
  margin-top:14px!important;
}
.osa-stat{
  padding:12px 10px!important;
  border-radius:16px!important;
  border:1px solid rgba(15,23,42,.06)!important;
  background:rgba(255,255,255,.78)!important;
  box-shadow:none!important;
}
.osa-stat-value{font-size:15px!important;font-weight:800!important;color:#0f172a!important;letter-spacing:-.2px!important;}
.osa-stat-label{margin-top:4px!important;font-size:11px!important;font-weight:700!important;color:rgba(15,23,42,.58)!important;}
.osa-mp-main{margin-top:14px!important;padding-bottom:18px!important;}
.osa-sec{
  margin-top:14px!important;
  border-radius:16px!important;
  border:1px solid rgba(15,23,42,.06)!important;
  background:rgba(255,255,255,.92)!important;
  box-shadow:0 18px 60px rgba(15,23,42,.06)!important;
  overflow:hidden!important;
}
.osa-sec-head{
  width:100%!important;
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  min-height:54px!important;
  padding:14px 16px!important;
  border:0!important;
  border-bottom:1px solid rgba(15,23,42,.06)!important;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.92))!important;
  color:#0f172a!important;
  cursor:pointer!important;
  text-align:left!important;
}
.osa-sec--open .osa-sec-head{background:linear-gradient(180deg,rgba(37,99,235,.08),rgba(255,255,255,.98))!important;}
.osa-sec-title{color:#0f172a!important;font-size:13px!important;font-weight:800!important;letter-spacing:0!important;}
.osa-sec-meta{margin-left:auto!important;max-width:520px!important;color:rgba(15,23,42,.58)!important;font-size:12px!important;font-weight:600!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;}
.osa-sec-caret{color:#2563eb!important;font-size:16px!important;line-height:1!important;margin-left:4px!important;}
.osa-sec-body{display:none!important;padding:14px 16px 16px!important;background:#fff!important;}
.osa-sec--open .osa-sec-body{display:block!important;}
.osa-mp-hero-card,
.osa-mp-card{
  margin:0!important;
  border-radius:16px!important;
  border:1px solid rgba(15,23,42,.06)!important;
  background:rgba(255,255,255,.94)!important;
  box-shadow:none!important;
  overflow:hidden!important;
}
.osa-mp-hero{margin:0 0 14px 0!important;padding:0!important;}
.osa-mp-hero-card{padding:0!important;}
.osa-mp-hero-body{display:grid!important;grid-template-columns:260px 1fr!important;gap:14px!important;align-items:center!important;padding:16px!important;margin:0!important;}
.osa-mp-ring{width:210px!important;height:210px!important;background:conic-gradient(#2563eb 0deg,#55e039 120deg,rgba(15,23,42,.08) 120deg 360deg)!important;}
.osa-mp-ring:after{background:#fff!important;inset:15px!important;border:1px solid rgba(15,23,42,.06)!important;}
.osa-mp-ring-value{font-size:26px!important;font-weight:900!important;color:#0f172a!important;}
.osa-mp-ring-label{font-size:12px!important;font-weight:700!important;color:rgba(15,23,42,.56)!important;}
.osa-mp-mini{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;padding:0!important;}
.osa-mp-mini-card,
.osa-mp-kpi,
.osa-mi-metric,
.osa-mp-detail{
  border-radius:14px!important;
  border:1px solid rgba(15,23,42,.06)!important;
  background:#f8fafc!important;
  box-shadow:none!important;
}
.osa-mp-mini-card{padding:14px!important;}
.osa-mp-mini-title,
.osa-mp-kpi-title,
.osa-mi-label,
.osa-mp-detail-label{font-size:11.5px!important;font-weight:700!important;color:rgba(15,23,42,.58)!important;}
.osa-mp-mini-value,
.osa-mp-kpi-value,
.osa-mi-value,
.osa-mp-detail-value{font-size:16px!important;font-weight:800!important;color:#0f172a!important;}
.osa-mp-grid{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:12px!important;margin-top:14px!important;}
.osa-mp-kpi{padding:14px!important;}
.osa-mp-card-head{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:12px!important;padding:16px 16px 12px!important;border-bottom:1px solid rgba(15,23,42,.06)!important;background:rgba(248,250,252,.70)!important;}
.osa-mp-card-title{font-size:14px!important;font-weight:800!important;color:#0f172a!important;}
.osa-mp-card-sub{font-size:12px!important;font-weight:500!important;color:rgba(15,23,42,.55)!important;}
.osa-mp-card-body{padding:16px!important;}
.osa-mi-card,
.osa-mp-project{
  margin:0 0 12px 0!important;
  border-radius:16px!important;
  border:1px solid rgba(15,23,42,.06)!important;
  background:#fff!important;
  box-shadow:0 8px 24px rgba(15,23,42,.04)!important;
  padding:14px!important;
}
.osa-mi-card:last-child{margin-bottom:0!important;}
.osa-mi-photo-img,
.osa-mi-photo-fallback{width:64px!important;height:64px!important;border-radius:18px!important;}
.osa-mi-card .osa-mi-info{display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;flex-wrap:wrap!important;margin:2px 0 0!important;text-align:center!important;}
.osa-mi-card .osa-mi-code{background:rgba(37,99,235,.08)!important;border-color:rgba(37,99,235,.16)!important;color:#0f172a!important;}
.osa-mi-card .osa-mi-status{background:rgba(85,224,57,.18)!important;color:#0f172a!important;border:1px solid rgba(85,224,57,.28)!important;box-shadow:none!important;}
.osa-mi-status--history{background:rgba(15,23,42,.08)!important;color:#0f172a!important;border-color:rgba(15,23,42,.10)!important;}
.osa-mi-actions .osa-mp-project-toggle,
.osa-mp-btn{
  border:1px solid rgba(15,23,42,.10)!important;
  background:#fff!important;
  color:#0f172a!important;
  border-radius:12px!important;
  padding:9px 12px!important;
  font-size:12px!important;
  font-weight:700!important;
  text-decoration:none!important;
  box-shadow:none!important;
}
.osa-mi-actions .osa-mp-project-toggle:hover,
.osa-mp-btn:hover{box-shadow:0 10px 30px rgba(15,23,42,.08)!important;filter:brightness(.99)!important;}
.osa-mp-tablewrap,
.osa-mp-table-wrap{border-radius:14px!important;border:1px solid rgba(15,23,42,.06)!important;background:#fff!important;overflow:auto!important;}
.osa-mp-table{width:100%!important;min-width:760px!important;border-collapse:separate!important;border-spacing:0!important;background:#fff!important;}
.osa-mp-table thead th{background:#f8fafc!important;color:rgba(15,23,42,.66)!important;font-size:11.5px!important;font-weight:800!important;text-transform:none!important;letter-spacing:0!important;padding:12px!important;border-bottom:1px solid rgba(15,23,42,.06)!important;}
.osa-mp-table td{padding:12px!important;border-bottom:1px solid rgba(15,23,42,.06)!important;color:#0f172a!important;font-size:12.5px!important;font-weight:600!important;}
.osa-mp-table tbody tr:last-child td{border-bottom:0!important;}
.osa-mp-empty,
.osa-mp-note,
.osa-mp-td-empty{border-radius:14px!important;background:#f8fafc!important;border:1px dashed rgba(15,23,42,.14)!important;color:rgba(15,23,42,.58)!important;font-weight:700!important;}
.osa-bell-panel{border-radius:16px!important;border:1px solid rgba(15,23,42,.08)!important;box-shadow:0 26px 70px rgba(15,23,42,.18)!important;}
.osa-bell-line{background:#f8fafc!important;border-color:rgba(15,23,42,.06)!important;}
@media (max-width:980px){
  .osa-mp{padding:12px!important;}
  .osa-mp-hero-body{grid-template-columns:1fr!important;}
  .osa-mp-ring{width:190px!important;height:190px!important;}
  .osa-mp-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .osa-sec-meta{display:none!important;}
}
@media (max-width:640px){
  .osa-mp-shell{max-width:100%!important;}
  .osa-profile-card{padding:14px!important;}
  .osa-stats3{grid-template-columns:1fr!important;}
  .osa-mp-mini{grid-template-columns:1fr!important;}
  .osa-mp-grid{grid-template-columns:1fr!important;}
  .osa-mi-row{grid-template-columns:1fr!important;}
  .osa-mp-card-head{flex-direction:column!important;align-items:flex-start!important;}
  .osa-mp-stmt-actions{justify-content:flex-start!important;}
}

/* v1.1.33: Member Portal KPI cards must match Accounts > Members backend columns. */
.osa-stats6{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:10px!important;
  width:100%!important;
}
.osa-stats6 .osa-stat{
  min-height:68px!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
}
@media (min-width:1180px){
  .osa-stats6{grid-template-columns:repeat(6,minmax(0,1fr))!important;}
  .osa-stats6 .osa-stat-value{font-size:14px!important;}
  .osa-stats6 .osa-stat-label{font-size:10.5px!important;}
}
@media (max-width:760px){
  .osa-stats6{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
}
@media (max-width:420px){
  .osa-stats6{grid-template-columns:1fr!important;}
}

/* v1.1.34: Member portal Society Dashboard - match admin Dashboard Overview cards, static/non-clickable. */
.osa-mp .osa-grid{display:grid;gap:14px;}
.osa-mp .osa-grid-4{grid-template-columns:repeat(4,minmax(0,1fr));}
@media (max-width:1200px){.osa-mp .osa-grid-4{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width:640px){.osa-mp .osa-grid-4{grid-template-columns:1fr;}}
.osa-mp .osa-dashboard-overview{margin-top:0;}
.osa-mp .osa-dashboard-overview > .osa-card-body{padding:16px!important;}
.osa-mp .osa-dashboard-grid{gap:16px!important;}
.osa-mp .osa-dashboard-grid > .osa-card{
  min-height:124px;
  box-shadow:none!important;
  border:1px solid rgba(15,23,42,.07)!important;
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(248,250,252,.92))!important;
  cursor:default!important;
  transform:none!important;
}
.osa-mp .osa-dashboard-grid > .osa-card:hover{transform:none!important;box-shadow:none!important;}
.osa-mp .osa-dashboard-grid > .osa-card .osa-card-head{padding:16px 16px 0 16px!important;align-items:center!important;border-bottom:0!important;}
.osa-mp .osa-dashboard-grid > .osa-card .osa-card-body{padding:14px 16px 18px 16px!important;}
.osa-mp .osa-dashboard-grid .osa-card-title{font-size:16px!important;font-weight:900!important;color:#0f172a!important;line-height:1.25!important;}
.osa-mp .osa-dashboard-grid .osa-metric{font-size:25px!important;line-height:1.15!important;letter-spacing:-.5px!important;font-weight:900!important;color:#0f172a!important;}
.osa-mp .osa-icon{width:38px;height:38px;border-radius:14px;display:inline-block;border:1px solid rgba(15,23,42,.06);}
.osa-mp .osa-i-blue{background:rgba(37,99,235,.12);}
.osa-mp .osa-i-green{background:rgba(85,224,57,.18);}
.osa-mp .osa-i-amber{background:rgba(245,158,11,.18);}
.osa-mp .osa-i-rose{background:rgba(244,63,94,.14);}
.osa-mp .osa-i-indigo{background:rgba(99,102,241,.16);}
.osa-mp .osa-i-violet{background:rgba(139,92,246,.16);}
.osa-mp .osa-i-teal{background:rgba(20,184,166,.16);}
.osa-mp .osa-i-sky{background:rgba(14,165,233,.16);}
.osa-mp .osa-card-accent-green{border-top:3px solid rgba(85,224,57,.85)!important;}
.osa-mp .osa-card-accent-blue{border-top:3px solid rgba(37,99,235,.85)!important;}
.osa-mp .osa-card-accent-amber{border-top:3px solid rgba(245,158,11,.85)!important;}
.osa-mp .osa-card-accent-rose{border-top:3px solid rgba(244,63,94,.85)!important;}
.osa-mp .osa-card-accent-indigo{border-top:3px solid rgba(99,102,241,.85)!important;}
.osa-mp .osa-card-accent-teal{border-top:3px solid rgba(20,184,166,.85)!important;}
.osa-mp .osa-card-accent-violet{border-top:3px solid rgba(139,92,246,.85)!important;}
.osa-mp .osa-card-accent-sky{border-top:3px solid rgba(14,165,233,.85)!important;}


/* v1.0.0 Final frontend polish: login, member portal, and frontend admin UI alignment. */
.osa-card-desc,.osa-sec-meta{display:none!important;}
.osa-auth{min-height:100vh!important;padding:24px 12px!important;background:linear-gradient(180deg,#eef3ff 0%,#f3f6fb 55%,#f8fafc 100%)!important;}
.osa-auth-card{width:min(520px,94vw)!important;border-radius:22px!important;background:rgba(255,255,255,.94)!important;border:1px solid rgba(15,23,42,.08)!important;box-shadow:0 24px 80px rgba(15,23,42,.10)!important;}
.osa-auth-top{padding:22px 22px 16px!important;background:linear-gradient(180deg,#fff,#f8fbff)!important;border-bottom:1px solid rgba(15,23,42,.06)!important;}
.osa-auth-body{padding:22px!important;}
.osa-title{font-size:24px!important;font-weight:900!important;color:#0f172a!important;margin-bottom:16px!important;text-align:left!important;}
.osa-login-modes{display:grid!important;grid-template-columns:1fr 1fr!important;gap:10px!important;margin-bottom:4px!important;}
.osa-radio{display:flex!important;align-items:center!important;gap:8px!important;padding:12px!important;border:1px solid rgba(15,23,42,.08)!important;border-radius:14px!important;background:#f8fafc!important;font-weight:800!important;color:rgba(15,23,42,.75)!important;}
.osa-radio:has(input:checked){background:rgba(37,99,235,.08)!important;border-color:rgba(37,99,235,.30)!important;color:#0f172a!important;}
.osa-field span,.osa-label,.osa-mi-status-label{font-size:12px!important;font-weight:800!important;color:rgba(15,23,42,.72)!important;}
.osa-field input{height:48px!important;border-radius:15px!important;background:#fff!important;border:1px solid rgba(15,23,42,.10)!important;font-size:14px!important;}
.osa-auth .osa-btn-primary{height:48px!important;border-radius:15px!important;background:linear-gradient(135deg,#2563EB,#3B82F6)!important;color:#fff!important;box-shadow:0 14px 30px rgba(37,99,235,.22)!important;}
.osa-auth-bottom{background:#fff!important;color:rgba(15,23,42,.52)!important;}
.osa-brand-sub{display:none!important;}
.osa-mp{background:linear-gradient(180deg,#eef3ff 0%,#f3f6fb 58%,#f8fafc 100%)!important;}
.osa-mp .osa-sec-head{min-height:56px!important;}
.osa-mp .osa-sec-body{background:#fff!important;}
.osa-mp .osa-stats6{grid-template-columns:repeat(6,minmax(0,1fr))!important;}
@media (max-width:1100px){.osa-mp .osa-stats6{grid-template-columns:repeat(3,minmax(0,1fr))!important;}}
@media (max-width:640px){.osa-login-modes{grid-template-columns:1fr!important}.osa-mp .osa-stats6{grid-template-columns:repeat(2,minmax(0,1fr))!important;}}
body.osa-blank .osa-admin-frontend-wrap .osa-card-desc,body.osa-blank .osa-admin-frontend-wrap .osa-sub{display:none!important;}
/* v1.0.0: Frontend admin accounts toolbar alignment. */
body.osa-blank .osa-admin-frontend-wrap .osa-accounts-controlbar{grid-template-columns:minmax(280px,520px) minmax(360px,1fr)!important;}
body.osa-blank .osa-admin-frontend-wrap .osa-accounts-controlbar .osa-live-search{max-width:520px!important;}
@media (max-width:1280px){body.osa-blank .osa-admin-frontend-wrap .osa-accounts-controlbar{grid-template-columns:1fr!important;}body.osa-blank .osa-admin-frontend-wrap .osa-accounts-controlbar .osa-live-search{max-width:none!important;}}


/* v1.0.1 Mobile responsive final pass: login, member portal, and frontend admin portal. */
html,body{max-width:100%;}
.osa-app,.osa-auth,.osa-mp,.osa-admin-frontend-wrap{max-width:100%;overflow-x:hidden;}
.osa-auth-card,.osa-mp-shell,.osa-profile-card,.osa-sec,.osa-mp-card,.osa-mp-hero-card,.osa-mi-card{max-width:100%;box-sizing:border-box;}
.osa-auth input,.osa-auth select,.osa-auth textarea,.osa-mp input,.osa-mp select,.osa-mp textarea{max-width:100%;box-sizing:border-box;}
.osa-mp-tablewrap,.osa-mp-table-wrap{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;}
.osa-mp-table{min-width:720px;}
.osa-mp .osa-table-wrap{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;}
.osa-mp .osa-table{min-width:720px!important;}
.osa-mp .osa-card-desc,.osa-mp .osa-sec-meta{display:none!important;}

@media (max-width:900px){
  .osa-auth{padding:18px 10px!important;align-items:flex-start!important;}
  .osa-auth-card{width:100%!important;max-width:520px!important;margin:0 auto!important;border-radius:18px!important;}
  .osa-auth-top,.osa-auth-body{padding:16px!important;}
  .osa-login-modes{grid-template-columns:1fr!important;}
  .osa-auth .osa-title{font-size:20px!important;}
  .osa-brand{min-width:0!important;}
  .osa-brand-name{font-size:14px!important;word-break:break-word!important;}
  .osa-field input{width:100%!important;}
  .osa-auth .osa-btn{width:100%!important;}

  .osa-mp{position:relative!important;inset:auto!important;padding:12px!important;overflow-x:hidden!important;}
  .osa-portal-only .osa-mp{position:fixed!important;inset:0!important;overflow:auto!important;padding:12px!important;}
  .osa-mp-shell{width:100%!important;max-width:100%!important;padding:0!important;}
  .osa-profile-card{padding:14px!important;border-radius:16px!important;}
  .osa-toprow{flex-wrap:wrap!important;align-items:flex-start!important;}
  .osa-society{max-width:calc(100% - 100px)!important;min-width:0!important;}
  .osa-society-name{white-space:normal!important;line-height:1.25!important;}
  .osa-top-actions{margin-left:auto!important;}
  .osa-member-name{font-size:18px!important;word-break:break-word!important;}
  .osa-member-sub{font-size:12px!important;}
  .osa-stats6{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;}
  .osa-stats6 .osa-stat{min-height:72px!important;padding:10px 8px!important;}
  .osa-stat-value{font-size:14px!important;word-break:break-word!important;}
  .osa-stat-label{font-size:10.5px!important;}
  .osa-sec{border-radius:15px!important;margin-top:12px!important;}
  .osa-sec-head{padding:12px!important;min-height:50px!important;}
  .osa-sec-title{font-size:13px!important;}
  .osa-sec-body{padding:12px!important;}
  .osa-mp-hero-body{grid-template-columns:1fr!important;padding:12px!important;}
  .osa-mp-ring{width:174px!important;height:174px!important;}
  .osa-mp-mini,.osa-mp-grid,.osa-mp .osa-grid-4,.osa-mp .osa-dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;}
  .osa-mp-mini-card,.osa-mp-kpi,.osa-mi-metric{padding:10px!important;}
  .osa-mp-project-grid,.osa-mi-row{grid-template-columns:1fr!important;}
  .osa-mp-details,.osa-mp-details-grid{grid-template-columns:1fr!important;}
  .osa-mi-card .osa-mi-info{justify-content:flex-start!important;text-align:left!important;}
  .osa-mi-card .osa-mi-name{min-width:0!important;flex-basis:100%!important;}
  .osa-mi-actions{flex-direction:column!important;align-items:stretch!important;}
  .osa-mi-actions .osa-mp-project-toggle,.osa-mp-btn{width:100%!important;}
  .osa-mp-card-head{flex-direction:column!important;align-items:stretch!important;gap:8px!important;}
  .osa-mp-stmt-actions,.osa-mp-stmt-tools,.osa-mp-stmt-form{width:100%!important;justify-content:flex-start!important;align-items:stretch!important;}
  .osa-mp-stmt-field,.osa-mp-input,.osa-mp-stmt-actions .osa-mp-btn,.osa-mp-stmt-form .osa-mp-btn{width:100%!important;min-width:0!important;}
}

@media (max-width:520px){
  .osa-auth{padding:12px 8px!important;}
  .osa-auth-card{border-radius:16px!important;}
  .osa-auth-top,.osa-auth-body,.osa-auth-bottom{padding:14px!important;}
  .osa-logo{width:38px!important;height:38px!important;border-radius:13px!important;}
  .osa-mp{padding:10px!important;}
  .osa-portal-only .osa-mp{padding:10px!important;}
  .osa-profile-card{padding:12px!important;}
  .osa-society-logo,.osa-society-logo--placeholder,.osa-society-logo--lg,.osa-society-logo--placeholder.osa-society-logo--lg{width:42px!important;height:42px!important;border-radius:14px!important;}
  .osa-avatar,.osa-avatar--placeholder{width:66px!important;height:66px!important;border-radius:20px!important;}
  .osa-iconbtn,.osa-iconbtn.osa-logout{width:36px!important;height:36px!important;min-width:36px!important;}
  .osa-iconbtn.osa-logout .osa-logout-text{display:none!important;}
  .osa-stats6,.osa-stats3,.osa-mp-mini,.osa-mp-grid,.osa-mp .osa-grid-4,.osa-mp .osa-dashboard-grid{grid-template-columns:1fr!important;}
  .osa-stat{min-height:auto!important;}
  .osa-mp-ring{width:156px!important;height:156px!important;}
  .osa-mp-ring-value{font-size:20px!important;}
  .osa-mp-table,.osa-mp .osa-table{min-width:650px!important;}
  .osa-bell-modal{padding:54px 8px 8px!important;}
  .osa-bell-panel{width:calc(100vw - 16px)!important;max-height:calc(100dvh - 72px)!important;}
  .osa-bell-line{flex-direction:column!important;align-items:flex-start!important;}
  .osa-bell-v{text-align:left!important;}
}

/* Frontend admin portal responsive override. This appears after earlier portal styles and wins on mobile. */
@media (max-width:900px){
  body.osa-blank .osa-admin-frontend-wrap{padding:10px!important;overflow-x:hidden!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-admin-shell{padding:10px!important;border-radius:14px!important;width:100%!important;max-width:100%!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-admin-top{flex-direction:column!important;align-items:stretch!important;gap:12px!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-top-left{min-width:0!important;width:100%!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-h1{font-size:16px!important;word-break:break-word!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-top-actions{width:100%!important;justify-content:flex-start!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-pill{flex:1 1 calc(50% - 8px)!important;justify-content:center!important;text-align:center!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-admin-tabs{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;padding:8px!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-admin-tabs .osa-tab{font-size:11px!important;min-height:42px!important;padding:9px 6px!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-grid-4,
  body.osa-blank .osa-admin-frontend-wrap .osa-dashboard-grid,
  body.osa-blank .osa-admin-frontend-wrap .osa-grid-2,
  body.osa-blank .osa-admin-frontend-wrap .osa-kpi-mini-grid,
  body.osa-blank .osa-admin-frontend-wrap .osa-audit-summary-grid{grid-template-columns:1fr!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-card-head,
  body.osa-blank .osa-admin-frontend-wrap .osa-card-head-split{flex-direction:column!important;align-items:stretch!important;padding:14px!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-toolbar,
  body.osa-blank .osa-admin-frontend-wrap .osa-actions{width:100%!important;justify-content:flex-start!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-search,
  body.osa-blank .osa-admin-frontend-wrap .osa-live-search{width:100%!important;min-width:0!important;max-width:none!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-accounts-controlbar{display:grid!important;grid-template-columns:1fr!important;gap:12px!important;padding:12px 14px!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-inner-tabbar{padding:0!important;justify-content:flex-start!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-inner-tabbar .osa-tabs,
  body.osa-blank .osa-admin-frontend-wrap .osa-card-head .osa-toolbar .osa-tabs{width:100%!important;display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-inner-tabbar .osa-tabs .osa-tab,
  body.osa-blank .osa-admin-frontend-wrap .osa-card-head .osa-toolbar .osa-tabs .osa-tab{width:100%!important;min-width:0!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-form-grid,
  body.osa-blank .osa-admin-frontend-wrap .osa-project-two-col,
  body.osa-blank .osa-admin-frontend-wrap .osa-admin-access-layout,
  body.osa-blank .osa-admin-frontend-wrap .osa-settings-grid{grid-template-columns:1fr!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-table-wrap{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-table{min-width:720px!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-drawer-panel{width:100vw!important;max-width:100vw!important;height:100dvh!important;border-left:0!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-drawer-body{padding:12px!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-drawer-footer{position:sticky!important;bottom:0!important;flex-direction:column!important;align-items:stretch!important;padding:10px 12px calc(10px + env(safe-area-inset-bottom))!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-drawer-footer-left,
  body.osa-blank .osa-admin-frontend-wrap .osa-drawer-footer-right{width:100%!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-drawer-footer .osa-btn{width:100%!important;}
}
@media (max-width:480px){
  body.osa-blank .osa-admin-frontend-wrap .osa-admin-tabs{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-inner-tabbar .osa-tabs,
  body.osa-blank .osa-admin-frontend-wrap .osa-card-head .osa-toolbar .osa-tabs{grid-template-columns:1fr!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-top-actions .osa-pill{flex-basis:100%!important;}
  body.osa-blank .osa-admin-frontend-wrap .osa-btn{width:100%!important;}
}

/* v1.0.1 login/member portal final polish */
.osa-auth .osa-btn.osa-btn-primary,
.osa-auth button[type="submit"]{
  width:100%;
  min-height:48px;
  border-radius:14px;
  background:linear-gradient(135deg,#55E039,#22C55E) !important;
  color:#101210 !important;
  border:0 !important;
  font-weight:800;
  letter-spacing:.01em;
  box-shadow:0 14px 28px rgba(34,197,94,.20);
}
.osa-auth .osa-btn.osa-btn-primary:hover,
.osa-auth button[type="submit"]:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 34px rgba(34,197,94,.26);
}
.osa-auth .osa-alert-danger{
  border:1px solid rgba(220,38,38,.16);
  background:#fff1f2;
  color:#9f1239;
  border-radius:14px;
  padding:12px 14px;
  line-height:1.55;
}
.osa-avatar.osa-avatar--placeholder{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-weight:900 !important;
  letter-spacing:.02em !important;
  color:#101210 !important;
  background:linear-gradient(135deg,rgba(85,224,57,.22),rgba(34,197,94,.42)) !important;
}
@media (max-width: 782px){
  .osa-auth{padding:12px !important;}
  .osa-auth-card{width:100% !important;max-width:100% !important;border-radius:18px !important;}
  .osa-login-modes{display:grid !important;grid-template-columns:1fr 1fr !important;gap:8px !important;}
  .osa-login-modes .osa-radio{width:100% !important;justify-content:center !important;}
  .osa-member-portal .osa-tabs,
  .osa-portal-tabs{display:grid !important;grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:8px !important;}
}

/* v1.0.1 frontend admin mobile share-transfer fallback */
@media (max-width: 782px){
  body.osa-blank #osaShareTransferPage .osa-share-transfer-actions,
  body.osa-blank #osaShareTransferPage .osa-st-add-row{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
    align-items:stretch !important;
  }
  body.osa-blank #osaShareTransferPage #osaShareExecute,
  body.osa-blank #osaShareTransferPage #osaShareLoad,
  body.osa-blank #osaShareTransferPage .osa-st-add{
    width:100% !important;
    min-height:46px !important;
    touch-action:manipulation !important;
  }
  body.osa-blank #osaShareTransferPage .osa-table-wrap{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
  }
}

/* ==========================================================
   v1.0.1 Backend UI Parity Pass
   Purpose: make frontend admin + member portal visually match the backend UI system.
   ========================================================== */
body.osa-blank,
.osa-auth,
.osa-mp,
.osa-portal,
.osa-admin-frontend-wrap{
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif!important;
  background:#f3f6fb!important;
  color:#0f172a!important;
}

/* Frontend admin portal should not hide backend helper text. */
body.osa-blank .osa-admin-frontend-wrap .osa-sub,
body.osa-blank .osa-admin-frontend-wrap .osa-card-desc,
body.osa-blank .osa-admin-frontend-wrap .osa-card-head .osa-card-desc{
  display:block!important;
  visibility:visible!important;
}
body.osa-blank .osa-admin-frontend-wrap .osa-admin-shell{
  background:#f3f6fb!important;
  border:1px solid rgba(15,23,42,.06)!important;
  border-radius:16px!important;
  padding:18px!important;
  max-width:1480px!important;
  margin:0 auto!important;
}
body.osa-blank .osa-admin-frontend-wrap .osa-card,
body.osa-blank .osa-admin-frontend-wrap .osa-modal-card,
body.osa-blank .osa-admin-frontend-wrap .osa-drawer-panel{
  background:rgba(255,255,255,.92)!important;
  border:1px solid rgba(15,23,42,.06)!important;
  border-radius:16px!important;
  box-shadow:0 18px 60px rgba(15,23,42,.06)!important;
}
body.osa-blank .osa-admin-frontend-wrap .osa-btn,
body.osa-blank .osa-admin-frontend-wrap button.osa-btn,
body.osa-blank .osa-admin-frontend-wrap input[type="submit"].osa-btn{
  min-height:38px!important;
  border-radius:12px!important;
  padding:9px 12px!important;
  font-size:12px!important;
  font-weight:700!important;
  line-height:1.2!important;
  text-decoration:none!important;
}
body.osa-blank .osa-admin-frontend-wrap .osa-btn-primary{
  background:linear-gradient(135deg,rgba(37,99,235,.95),rgba(59,130,246,.88))!important;
  border-color:rgba(37,99,235,.30)!important;
  color:#fff!important;
  box-shadow:none!important;
}
body.osa-blank .osa-admin-frontend-wrap .osa-table-wrap{
  border:1px solid rgba(15,23,42,.06)!important;
  border-radius:16px!important;
  overflow:auto!important;
  background:rgba(255,255,255,.70)!important;
}
body.osa-blank .osa-admin-frontend-wrap table.osa-table th,
body.osa-blank .osa-admin-frontend-wrap table.osa-table td{
  padding:12px!important;
  border-bottom:1px solid rgba(15,23,42,.06)!important;
  font-size:13px!important;
  vertical-align:middle!important;
}

/* Member portal: same backend shell, cards, buttons and tables. */
.osa-mp{
  min-height:100vh!important;
  padding:18px!important;
  background:#f3f6fb!important;
}
.osa-mp-shell{
  width:100%!important;
  max-width:1480px!important;
  margin:0 auto!important;
  padding:18px!important;
  background:#f3f6fb!important;
  border:1px solid rgba(15,23,42,.06)!important;
  border-radius:16px!important;
  box-shadow:none!important;
}
.osa-profile-card,
.osa-mp-top,
.osa-portal-header{
  background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(255,255,255,.80))!important;
  border:1px solid rgba(15,23,42,.06)!important;
  border-radius:14px!important;
  box-shadow:none!important;
  padding:12px!important;
}
.osa-toprow,
.osa-mp-top,
.osa-portal-header{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:16px!important;
}
.osa-society,
.osa-mp-brand,
.osa-portal-left{
  display:flex!important;
  align-items:center!important;
  gap:12px!important;
  min-width:0!important;
}
.osa-society-logo,
.osa-society-logo--placeholder,
.osa-society-logo--lg,
.osa-society-logo--placeholder.osa-society-logo--lg,
.osa-mp-logo,
.osa-logo{
  width:42px!important;
  height:42px!important;
  min-width:42px!important;
  border-radius:12px!important;
  object-fit:cover!important;
  border:1px solid rgba(15,23,42,.06)!important;
  background:radial-gradient(circle at 30% 30%,rgba(85,224,57,.35),rgba(85,224,57,0) 60%),linear-gradient(135deg,rgba(37,99,235,.18),rgba(37,99,235,0) 55%),#0f172a!important;
  box-shadow:0 10px 30px rgba(15,23,42,.14)!important;
}
.osa-society-name,
.osa-mp-society-name,
.osa-brand-name,
.osa-hello{
  margin:0!important;
  font-size:18px!important;
  line-height:1.2!important;
  letter-spacing:-.2px!important;
  font-weight:800!important;
  color:#0f172a!important;
}
.osa-member-sub,
.osa-date,
.osa-brand-sub{
  display:block!important;
  color:rgba(15,23,42,.65)!important;
  font-size:12px!important;
  margin-top:2px!important;
}
.osa-avatar,
.osa-avatar--placeholder{
  width:54px!important;
  height:54px!important;
  border-radius:14px!important;
  border:1px solid rgba(15,23,42,.06)!important;
  box-shadow:0 12px 28px rgba(15,23,42,.08)!important;
}
.osa-iconbtn,
.osa-iconbtn.osa-logout{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  min-height:38px!important;
  width:auto!important;
  min-width:38px!important;
  padding:8px 12px!important;
  border-radius:12px!important;
  border:1px solid rgba(15,23,42,.10)!important;
  background:#fff!important;
  color:#0f172a!important;
  font-weight:700!important;
  text-decoration:none!important;
}
.osa-mp-main{margin-top:14px!important;}
.osa-stats6,
.osa-stats3,
.osa-kpis,
.osa-mp-mini,
.osa-mp-grid{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:14px!important;
  margin:14px 0!important;
}
.osa-stat,
.osa-mp-kpi,
.osa-mp-mini-card,
.osa-mi-metric{
  background:rgba(255,255,255,.92)!important;
  border:1px solid rgba(15,23,42,.06)!important;
  border-top:3px solid rgba(37,99,235,.85)!important;
  border-radius:16px!important;
  box-shadow:0 18px 60px rgba(15,23,42,.06)!important;
  padding:14px 16px!important;
  min-height:96px!important;
}
.osa-stat:nth-child(1){border-top-color:rgba(85,224,57,.85)!important;}
.osa-stat:nth-child(2){border-top-color:rgba(37,99,235,.85)!important;}
.osa-stat:nth-child(3){border-top-color:rgba(245,158,11,.85)!important;}
.osa-stat:nth-child(4){border-top-color:rgba(244,63,94,.85)!important;}
.osa-stat:nth-child(5){border-top-color:rgba(99,102,241,.85)!important;}
.osa-stat:nth-child(6){border-top-color:rgba(20,184,166,.85)!important;}
.osa-stat-value,
.osa-mp-kpi-value,
.osa-mi-metric-value{
  font-size:22px!important;
  font-weight:800!important;
  letter-spacing:-.4px!important;
  color:#0f172a!important;
  line-height:1.2!important;
  margin-top:6px!important;
}
.osa-stat-label,
.osa-mp-kpi-label,
.osa-mi-metric-label{
  font-size:12px!important;
  color:rgba(15,23,42,.55)!important;
  font-weight:700!important;
}
.osa-sec,
.osa-mp-card,
.osa-mp-hero-card,
.osa-mi-card,
.osa-card{
  background:rgba(255,255,255,.92)!important;
  border:1px solid rgba(15,23,42,.06)!important;
  border-radius:16px!important;
  box-shadow:0 18px 60px rgba(15,23,42,.06)!important;
  overflow:hidden!important;
}
.osa-sec{margin-top:14px!important;}
.osa-sec-head,
.osa-mp-card-head,
.osa-card-head{
  width:100%!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:10px!important;
  padding:16px 16px 12px!important;
  background:#fff!important;
  border:0!important;
  border-bottom:1px solid rgba(15,23,42,.06)!important;
  color:#0f172a!important;
  text-align:left!important;
}
.osa-sec-title,
.osa-mp-card-title,
.osa-card-title{
  font-size:13px!important;
  font-weight:800!important;
  color:#0f172a!important;
  line-height:1.25!important;
}
.osa-sec-meta,
.osa-mp-card-sub,
.osa-card-desc{
  display:block!important;
  margin-top:4px!important;
  font-size:12px!important;
  color:rgba(15,23,42,.62)!important;
  font-weight:500!important;
}
.osa-sec-body,
.osa-mp-card-body,
.osa-card-body{
  padding:14px 16px 16px!important;
  background:#fff!important;
}
.osa-sec--open .osa-sec-head,
.osa-sec-head:hover{
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,251,255,.96))!important;
}
.osa-mp-btn,
.osa-btn,
.osa-auth .osa-btn,
.osa-auth button[type="submit"]{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  min-height:38px!important;
  height:auto!important;
  padding:9px 12px!important;
  border-radius:12px!important;
  border:1px solid rgba(15,23,42,.10)!important;
  text-decoration:none!important;
  background:#fff!important;
  color:#0f172a!important;
  font-weight:700!important;
  font-size:12px!important;
  cursor:pointer!important;
  box-shadow:none!important;
}
.osa-btn-primary,
.osa-auth .osa-btn-primary,
.osa-auth button[type="submit"]{
  background:linear-gradient(135deg,rgba(37,99,235,.95),rgba(59,130,246,.88))!important;
  border-color:rgba(37,99,235,.30)!important;
  color:#fff!important;
}
.osa-mp-btn:hover,
.osa-btn:hover,
.osa-iconbtn:hover{filter:brightness(.99)!important;box-shadow:0 10px 30px rgba(15,23,42,.08)!important;}
.osa-mp-tablewrap,
.osa-mp-table-wrap,
.osa-table-wrap{
  border:1px solid rgba(15,23,42,.06)!important;
  border-radius:16px!important;
  overflow:auto!important;
  background:rgba(255,255,255,.70)!important;
  -webkit-overflow-scrolling:touch!important;
}
.osa-mp-table,
.osa-table{
  width:100%!important;
  border-collapse:separate!important;
  border-spacing:0!important;
  background:#fff!important;
}
.osa-mp-table th,
.osa-mp-table td,
.osa-table th,
.osa-table td{
  padding:12px!important;
  border-bottom:1px solid rgba(15,23,42,.06)!important;
  font-size:13px!important;
  vertical-align:middle!important;
}
.osa-mp-table thead th,
.osa-table thead th{
  background:rgba(15,23,42,.03)!important;
  text-align:left!important;
  font-weight:900!important;
  color:#0f172a!important;
}
.osa-mp-table .is-right,
.osa-table .is-right{text-align:right!important;}
.osa-mp-project-toggle,
.osa-sec-head{
  cursor:pointer!important;
}

/* Auth page: backend-style compact card, not a separate app design. */
.osa-auth{
  min-height:100vh!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:24px 12px!important;
}
.osa-auth-card{
  width:min(520px,94vw)!important;
  border-radius:16px!important;
  background:rgba(255,255,255,.92)!important;
  border:1px solid rgba(15,23,42,.06)!important;
  box-shadow:0 18px 60px rgba(15,23,42,.06)!important;
}
.osa-auth-top{background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(255,255,255,.80))!important;border-bottom:1px solid rgba(15,23,42,.06)!important;padding:16px!important;}
.osa-auth-body{padding:16px!important;}
.osa-title{font-size:18px!important;font-weight:800!important;color:#0f172a!important;margin:0 0 14px!important;}
.osa-login-modes{display:grid!important;grid-template-columns:1fr 1fr!important;gap:8px!important;}
.osa-radio{border-radius:12px!important;border:1px solid rgba(15,23,42,.08)!important;background:#fff!important;padding:10px 12px!important;}
.osa-radio:has(input:checked){background:rgba(37,99,235,.08)!important;border-color:rgba(37,99,235,.22)!important;}
.osa-field input{
  height:42px!important;
  border-radius:12px!important;
  border:1px solid rgba(15,23,42,.10)!important;
  background:#fff!important;
  padding:0 12px!important;
}
.osa-field input:focus{border-color:rgba(37,99,235,.55)!important;box-shadow:0 0 0 4px rgba(37,99,235,.12)!important;}

@media (max-width:1200px){
  .osa-stats6,.osa-stats3,.osa-kpis,.osa-mp-mini,.osa-mp-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
}
@media (max-width:782px){
  .osa-mp{padding:10px!important;}
  .osa-mp-shell{padding:10px!important;border-radius:14px!important;}
  .osa-toprow,.osa-mp-top,.osa-portal-header,.osa-sec-head,.osa-mp-card-head,.osa-card-head{flex-direction:column!important;align-items:stretch!important;}
  .osa-society{max-width:100%!important;}
  .osa-society-name,.osa-mp-society-name,.osa-brand-name,.osa-hello{font-size:16px!important;}
  .osa-stats6,.osa-stats3,.osa-kpis,.osa-mp-mini,.osa-mp-grid,.osa-mp .osa-grid-4,.osa-mp .osa-dashboard-grid{grid-template-columns:1fr!important;}
  .osa-stat,.osa-mp-kpi,.osa-mp-mini-card,.osa-mi-metric{min-height:auto!important;}
  .osa-mp-table,.osa-table{min-width:720px!important;}
  .osa-mp-btn,.osa-btn,.osa-auth .osa-btn,.osa-auth button[type="submit"]{width:100%!important;}
  .osa-login-modes{grid-template-columns:1fr!important;}
}

/* ==========================================================
   v1.0.1 Member Portal App UI
   Inspired by provided mobile flight app reference:
   dark green hero, floating white summary cards, rounded ticket-style cards,
   and bottom app navigation. Scoped to member portal only.
   ========================================================== */
html.osa-portal-only,
body.osa-portal-only{
  background:#dfe3e9!important;
}
.osa-mp{
  --app-bg:#f6f7f1;
  --app-card:#ffffff;
  --app-text:#171916;
  --app-muted:#6f746b;
  --app-line:rgba(23,25,22,.09);
  --app-green:#234c16;
  --app-green-2:#17300f;
  --app-green-3:#4b6730;
  --app-soft:#f1f3ea;
  --app-shadow:0 18px 42px rgba(17,24,39,.12);
  min-height:100vh!important;
  padding:22px 12px!important;
  background:#dfe3e9!important;
  color:var(--app-text)!important;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif!important;
}
.osa-portal-only .osa-mp{
  position:fixed!important;
  inset:0!important;
  overflow:auto!important;
  z-index:999999!important;
}
.osa-mp *, .osa-mp *::before, .osa-mp *::after{box-sizing:border-box!important;}
.osa-mp-shell{
  width:100%!important;
  max-width:470px!important;
  min-height:calc(100vh - 44px)!important;
  margin:0 auto!important;
  padding:0 18px 104px!important;
  background:var(--app-bg)!important;
  border:1px solid rgba(255,255,255,.84)!important;
  border-radius:32px!important;
  overflow:hidden!important;
  box-shadow:0 26px 70px rgba(15,23,42,.18)!important;
  position:relative!important;
}
.osa-mp-top{
  margin:0 -18px 14px!important;
  padding:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.osa-profile-card{
  position:relative!important;
  min-height:365px!important;
  padding:28px 20px 18px!important;
  border:0!important;
  border-radius:0 0 36px 36px!important;
  background:
    radial-gradient(circle at 70% 0%, rgba(255,255,255,.18), transparent 34%),
    radial-gradient(circle at 20% 8%, rgba(132,179,80,.22), transparent 38%),
    linear-gradient(135deg,var(--app-green-2) 0%, var(--app-green) 58%, var(--app-green-3) 100%)!important;
  box-shadow:none!important;
  overflow:visible!important;
  color:#fff!important;
}
.osa-profile-card::before{display:none!important;}
.osa-toprow{
  position:relative!important;
  z-index:3!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
  min-height:42px!important;
  margin:0 0 22px!important;
}
.osa-society{
  min-width:0!important;
  flex:1 1 auto!important;
}
.osa-society-logo,
.osa-society-logo--placeholder,
.osa-society-logo--lg,
.osa-society-logo--placeholder.osa-society-logo--lg{
  display:none!important;
}
.osa-society::before{
  content:"সদস্য পোর্টাল"!important;
  display:inline-flex!important;
  align-items:center!important;
  min-height:34px!important;
  padding:8px 12px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.12)!important;
  border:1px solid rgba(255,255,255,.12)!important;
  color:#fff!important;
  font-size:12px!important;
  font-weight:800!important;
  letter-spacing:.01em!important;
  backdrop-filter:blur(8px)!important;
}
.osa-top-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
}
.osa-iconbtn,
.osa-iconbtn.osa-logout{
  width:44px!important;
  min-width:44px!important;
  height:44px!important;
  min-height:44px!important;
  padding:0!important;
  border-radius:999px!important;
  border:1px solid rgba(255,255,255,.10)!important;
  background:rgba(255,255,255,.14)!important;
  color:#fff!important;
  box-shadow:none!important;
  backdrop-filter:blur(10px)!important;
}
.osa-iconbtn:hover{background:rgba(255,255,255,.22)!important;filter:none!important;box-shadow:none!important;}
.osa-iconbtn.osa-logout span{color:#fff!important;}
.osa-avatar-wrap{
  position:absolute!important;
  left:20px!important;
  top:86px!important;
  z-index:4!important;
  margin:0!important;
  display:block!important;
}
.osa-avatar,
.osa-avatar--placeholder{
  width:54px!important;
  height:54px!important;
  border-radius:999px!important;
  object-fit:cover!important;
  border:3px solid rgba(255,255,255,.32)!important;
  background:#fff!important;
  color:var(--app-green)!important;
  box-shadow:0 16px 36px rgba(0,0,0,.18)!important;
}
.osa-greet,
.osa-member-name,
.osa-member-sub{
  position:relative!important;
  z-index:4!important;
  text-align:left!important;
  margin-left:66px!important;
  padding:0!important;
}
.osa-greet{
  margin-top:4px!important;
  color:#fff!important;
  font-size:18px!important;
  line-height:1.2!important;
  font-weight:900!important;
  letter-spacing:-.02em!important;
}
.osa-member-name{
  margin-top:2px!important;
  color:rgba(255,255,255,.84)!important;
  font-size:12.5px!important;
  line-height:1.35!important;
  font-weight:700!important;
  letter-spacing:0!important;
}
.osa-member-sub{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  flex-wrap:wrap!important;
  gap:6px!important;
  margin-top:6px!important;
  color:rgba(255,255,255,.78)!important;
  font-size:11px!important;
}
.osa-member-meta{
  color:rgba(255,255,255,.78)!important;
  font-size:11px!important;
  font-weight:700!important;
}
.osa-stats3,
.osa-stats6{
  position:relative!important;
  z-index:5!important;
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:10px!important;
  margin:72px 0 -84px!important;
  padding:14px!important;
  border:1px solid rgba(255,255,255,.75)!important;
  border-radius:24px!important;
  background:rgba(255,255,255,.96)!important;
  box-shadow:0 20px 38px rgba(15,23,42,.16)!important;
  backdrop-filter:blur(10px)!important;
}
.osa-stat{
  min-height:78px!important;
  padding:12px 10px!important;
  border:1px solid rgba(23,25,22,.08)!important;
  border-radius:16px!important;
  border-top:1px solid rgba(23,25,22,.08)!important;
  background:#fafbf6!important;
  box-shadow:none!important;
  text-align:left!important;
}
.osa-stat:nth-child(1), .osa-stat:nth-child(2), .osa-stat:nth-child(3),
.osa-stat:nth-child(4), .osa-stat:nth-child(5), .osa-stat:nth-child(6){border-top-color:rgba(23,25,22,.08)!important;}
.osa-stat-value{
  margin:0!important;
  font-size:16px!important;
  line-height:1.2!important;
  font-weight:900!important;
  color:var(--app-text)!important;
  letter-spacing:-.02em!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
}
.osa-stat-label{
  margin-top:6px!important;
  color:var(--app-muted)!important;
  font-size:11px!important;
  line-height:1.25!important;
  font-weight:800!important;
}
.osa-mp-main{
  margin-top:102px!important;
  padding:0!important;
}
.osa-sec{
  margin:14px 0!important;
  background:transparent!important;
  border:0!important;
  border-radius:0!important;
  box-shadow:none!important;
  overflow:visible!important;
  scroll-margin-top:18px!important;
}
.osa-sec-head{
  min-height:auto!important;
  width:100%!important;
  display:grid!important;
  grid-template-columns:1fr auto!important;
  align-items:center!important;
  gap:8px!important;
  padding:0 2px 10px!important;
  border:0!important;
  background:transparent!important;
  color:var(--app-text)!important;
  cursor:pointer!important;
  text-align:left!important;
}
.osa-sec-head:hover,
.osa-sec--open .osa-sec-head{background:transparent!important;}
.osa-sec-title{
  color:var(--app-text)!important;
  font-size:19px!important;
  line-height:1.2!important;
  font-weight:900!important;
  letter-spacing:-.03em!important;
}
.osa-sec-meta{
  grid-column:1 / -1!important;
  margin:0!important;
  max-width:none!important;
  color:var(--app-muted)!important;
  font-size:12px!important;
  font-weight:700!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
}
.osa-sec-caret{
  width:32px!important;
  height:32px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:999px!important;
  background:#fff!important;
  border:1px solid var(--app-line)!important;
  color:var(--app-green)!important;
  transform:rotate(-90deg)!important;
  box-shadow:0 8px 16px rgba(15,23,42,.06)!important;
}
.osa-sec--open .osa-sec-caret{transform:rotate(0deg)!important;}
.osa-sec-body{
  display:none!important;
  padding:0!important;
  background:transparent!important;
}
.osa-sec--open .osa-sec-body{display:block!important;}
.osa-mp-card,
.osa-mp-hero-card,
.osa-card{
  margin:0!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
  overflow:visible!important;
}
.osa-mp-card-head,
.osa-card-head{
  display:none!important;
}
.osa-mp-card-body,
.osa-card-body{
  padding:0!important;
  background:transparent!important;
}
.osa-mi-card,
.osa-mp-project{
  position:relative!important;
  display:flex!important;
  flex-direction:column!important;
  gap:12px!important;
  margin:0 0 12px!important;
  padding:16px!important;
  border-radius:22px!important;
  border:1px solid rgba(23,25,22,.08)!important;
  background:#fff!important;
  box-shadow:0 14px 28px rgba(15,23,42,.07)!important;
  overflow:hidden!important;
}
.osa-mi-card::before,
.osa-mi-card::after{
  content:""!important;
  position:absolute!important;
  top:52%!important;
  width:16px!important;
  height:28px!important;
  background:var(--app-bg)!important;
  border:1px solid rgba(23,25,22,.05)!important;
  z-index:2!important;
}
.osa-mi-card::before{left:-9px!important;border-radius:0 999px 999px 0!important;border-left:0!important;}
.osa-mi-card::after{right:-9px!important;border-radius:999px 0 0 999px!important;border-right:0!important;}
.osa-mi-photo{
  justify-content:flex-start!important;
  margin:0!important;
}
.osa-mi-photo-img,
.osa-mi-photo-fallback{
  width:48px!important;
  height:48px!important;
  border-radius:999px!important;
  object-fit:cover!important;
  background:#eef3e8!important;
  color:var(--app-green)!important;
  border:1px solid rgba(35,76,22,.10)!important;
  box-shadow:none!important;
  font-size:14px!important;
}
.osa-mi-info{
  margin-top:-58px!important;
  padding-left:62px!important;
  min-height:58px!important;
  display:block!important;
  text-align:left!important;
}
.osa-mi-card .osa-mi-info{display:block!important;text-align:left!important;margin-top:-58px!important;}
.osa-mi-card .osa-mi-code{
  display:inline-flex!important;
  align-items:center!important;
  padding:4px 9px!important;
  border-radius:999px!important;
  background:#f0f3e9!important;
  border:1px solid rgba(35,76,22,.10)!important;
  color:var(--app-green)!important;
  font-size:10.5px!important;
  font-weight:900!important;
}
.osa-mi-card .osa-mi-name{
  margin:5px 0 0!important;
  font-size:14.5px!important;
  line-height:1.24!important;
  color:var(--app-text)!important;
  font-weight:900!important;
  white-space:normal!important;
}
.osa-mi-card .osa-mi-mobile{
  margin:3px 0 0!important;
  color:var(--app-muted)!important;
  font-size:11.5px!important;
  font-weight:700!important;
}
.osa-mi-row{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:0!important;
  border:1px solid rgba(35,76,22,.08)!important;
  background:#f2f4eb!important;
  border-radius:16px!important;
  overflow:hidden!important;
}
.osa-mi-metric{
  min-height:auto!important;
  padding:12px 10px!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.osa-mi-metric + .osa-mi-metric{border-left:1px solid rgba(35,76,22,.10)!important;}
.osa-mi-label{
  color:var(--app-muted)!important;
  font-size:10.5px!important;
  font-weight:800!important;
  letter-spacing:.02em!important;
}
.osa-mi-value{
  margin-top:5px!important;
  color:var(--app-text)!important;
  font-size:13.5px!important;
  line-height:1.2!important;
  font-weight:900!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
}
.osa-mi-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:10px!important;
  padding-top:2px!important;
}
.osa-mi-card .osa-mi-status,
.osa-mi-status--history{
  display:inline-flex!important;
  align-items:center!important;
  min-height:30px!important;
  padding:7px 11px!important;
  border-radius:999px!important;
  background:#f0f3e9!important;
  border:1px solid rgba(35,76,22,.12)!important;
  color:var(--app-green)!important;
  box-shadow:none!important;
  font-size:11px!important;
  font-weight:900!important;
}
.osa-mi-card .osa-mp-project-toggle,
.osa-mi-actions .osa-mp-project-toggle{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:6px!important;
  min-height:34px!important;
  padding:8px 12px!important;
  border:0!important;
  border-radius:999px!important;
  background:var(--app-green)!important;
  color:#fff!important;
  font-size:11px!important;
  font-weight:900!important;
  cursor:pointer!important;
  box-shadow:0 10px 18px rgba(35,76,22,.18)!important;
}
.osa-mp-project-details{
  margin-top:0!important;
  padding-top:12px!important;
  border-top:1px dashed rgba(23,25,22,.12)!important;
}
.osa-mp-details-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:8px!important;
}
.osa-mp-detail{
  padding:10px!important;
  border-radius:14px!important;
  border:1px solid var(--app-line)!important;
  background:#fafbf6!important;
}
.osa-mp-detail-label{
  color:var(--app-muted)!important;
  font-size:10.5px!important;
  font-weight:800!important;
}
.osa-mp-detail-value{
  margin-top:5px!important;
  color:var(--app-text)!important;
  font-size:12.5px!important;
  line-height:1.3!important;
  font-weight:900!important;
}
.osa-mp-empty,
.osa-mp-note,
.osa-mp-td-empty{
  border-radius:18px!important;
  background:#fff!important;
  border:1px dashed rgba(23,25,22,.18)!important;
  color:var(--app-muted)!important;
  box-shadow:0 12px 24px rgba(15,23,42,.05)!important;
  padding:18px!important;
}
.osa-mp-tablewrap,
.osa-mp-table-wrap{
  border:1px solid var(--app-line)!important;
  border-radius:20px!important;
  background:#fff!important;
  box-shadow:0 14px 28px rgba(15,23,42,.07)!important;
  overflow:auto!important;
  -webkit-overflow-scrolling:touch!important;
}
.osa-mp-table{
  width:100%!important;
  min-width:700px!important;
  border-collapse:separate!important;
  border-spacing:0!important;
  background:#fff!important;
}
.osa-mp-table thead th{
  background:#f5f6ef!important;
  color:var(--app-muted)!important;
  font-size:11px!important;
  font-weight:900!important;
  padding:12px!important;
  border-bottom:1px solid var(--app-line)!important;
  text-transform:none!important;
  letter-spacing:0!important;
}
.osa-mp-table td{
  padding:12px!important;
  border-bottom:1px solid rgba(23,25,22,.07)!important;
  color:var(--app-text)!important;
  font-size:12px!important;
  font-weight:700!important;
  white-space:nowrap!important;
}
.osa-mp-stmt-actions,
.osa-mp-stmt-tools{width:100%!important;display:flex!important;justify-content:stretch!important;gap:8px!important;}
.osa-mp-btn{
  width:100%!important;
  min-height:48px!important;
  border-radius:999px!important;
  border:0!important;
  background:var(--app-green)!important;
  color:#fff!important;
  font-size:13px!important;
  font-weight:900!important;
  box-shadow:0 12px 22px rgba(35,76,22,.18)!important;
}
.osa-member-society-dashboard .osa-dashboard-grid,
.osa-member-society-dashboard .osa-grid,
.osa-member-society-dashboard .osa-grid-4{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:10px!important;
}
.osa-member-society-dashboard .osa-card{
  border-radius:18px!important;
  border:1px solid var(--app-line)!important;
  background:#fff!important;
  box-shadow:0 14px 26px rgba(15,23,42,.06)!important;
  padding:0!important;
  overflow:hidden!important;
}
.osa-member-society-dashboard .osa-card-head{
  display:block!important;
  padding:12px 12px 0!important;
  border:0!important;
  background:#fff!important;
}
.osa-member-society-dashboard .osa-card-title{
  font-size:11px!important;
  color:var(--app-muted)!important;
  font-weight:800!important;
}
.osa-member-society-dashboard .osa-card-body{
  padding:8px 12px 12px!important;
  background:#fff!important;
}
.osa-member-society-dashboard .osa-metric{
  font-size:15px!important;
  line-height:1.2!important;
  font-weight:900!important;
  color:var(--app-text)!important;
  word-break:break-word!important;
}
.osa-bell-panel{
  width:min(430px,calc(100% - 28px))!important;
  border:1px solid rgba(255,255,255,.78)!important;
  border-radius:24px!important;
  background:#fff!important;
  box-shadow:0 26px 70px rgba(15,23,42,.22)!important;
}
.osa-bell-head{background:#f6f7f1!important;border-bottom:1px solid var(--app-line)!important;}
.osa-bell-close{border-radius:999px!important;background:#fff!important;}
.osa-bell-line{background:#fafbf6!important;border-color:var(--app-line)!important;border-radius:16px!important;}
.osa-app-bottom-nav{
  position:fixed!important;
  left:50%!important;
  bottom:18px!important;
  transform:translateX(-50%)!important;
  width:min(330px,calc(100vw - 48px))!important;
  min-height:66px!important;
  padding:8px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.92)!important;
  border:1px solid rgba(255,255,255,.76)!important;
  box-shadow:0 18px 42px rgba(15,23,42,.16)!important;
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:8px!important;
  z-index:1000000!important;
  backdrop-filter:blur(12px)!important;
}
.osa-app-bottom-nav a{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:4px!important;
  min-height:50px!important;
  border-radius:999px!important;
  color:var(--app-muted)!important;
  text-decoration:none!important;
  font-size:10px!important;
  font-weight:900!important;
}
.osa-app-bottom-nav a.is-active,
.osa-app-bottom-nav a:hover{
  background:var(--app-green)!important;
  color:#fff!important;
}
.osa-app-nav-ico{font-size:16px!important;line-height:1!important;}
.osa-app-nav-label{font-size:10px!important;line-height:1!important;}
@media (max-width:520px){
  .osa-mp{padding:0!important;background:var(--app-bg)!important;}
  .osa-mp-shell{
    max-width:none!important;
    min-height:100dvh!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
  }
  .osa-profile-card{border-radius:0 0 34px 34px!important;}
  .osa-app-bottom-nav{bottom:12px!important;width:min(330px,calc(100vw - 36px))!important;}
}
@media (max-width:390px){
  .osa-mp-shell{padding-left:14px!important;padding-right:14px!important;}
  .osa-mp-top{margin-left:-14px!important;margin-right:-14px!important;}
  .osa-profile-card{padding-left:16px!important;padding-right:16px!important;}
  .osa-stats3,.osa-stats6{grid-template-columns:1fr!important;margin-bottom:-92px!important;}
  .osa-mp-main{margin-top:112px!important;}
  .osa-mp-details-grid,
  .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-member-society-dashboard .osa-grid,
  .osa-member-society-dashboard .osa-grid-4{grid-template-columns:1fr!important;}
}

/* ==========================================================
   v1.0.1 Member Portal App UI - Responsive refinement
   Goal: keep the same app-style UI, but make desktop/tablet/mobile
   use different responsive layouts instead of the same narrow phone frame.
   ========================================================== */
.osa-mp .osa-sec-meta{
  display:block!important;
  margin-top:4px!important;
  color:rgba(111,116,107,.92)!important;
  font-size:12px!important;
  line-height:1.55!important;
  font-weight:700!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
}
.osa-mp .osa-sec-head{
  align-items:flex-start!important;
}
.osa-mp .osa-sec-title{
  display:block!important;
}
.osa-mp .osa-mp-empty-title{
  font-size:14px!important;
  line-height:1.35!important;
  font-weight:900!important;
  color:var(--app-text)!important;
}
.osa-mp .osa-mp-empty-sub{
  margin-top:6px!important;
  font-size:12px!important;
  line-height:1.55!important;
  color:var(--app-muted)!important;
  font-weight:700!important;
}
.osa-mp .osa-mi-name,
.osa-mp .osa-mi-mobile,
.osa-mp .osa-mi-code,
.osa-mp .osa-mi-label,
.osa-mp .osa-mi-value,
.osa-mp .osa-mp-detail-label,
.osa-mp .osa-mp-detail-value,
.osa-mp .osa-stat-label,
.osa-mp .osa-stat-value{
  -webkit-font-smoothing:antialiased!important;
  text-rendering:geometricPrecision!important;
}
.osa-mp .osa-mi-row,
.osa-mp .osa-mp-details-grid{
  width:100%!important;
}
.osa-mp .osa-mp-tablewrap::after,
.osa-mp .osa-mp-table-wrap::after{
  content:"টেবিলটি ডানে-বামে স্ক্রল করা যাবে"!important;
  display:none!important;
  padding:8px 10px!important;
  font-size:11px!important;
  color:var(--app-muted)!important;
  background:#fafbf6!important;
  border-top:1px solid var(--app-line)!important;
}

@media (min-width:900px){
  html.osa-portal-only,
  body.osa-portal-only{background:#dfe3e9!important;}
  .osa-mp{
    padding:28px!important;
    background:#dfe3e9!important;
  }
  .osa-mp-shell{
    max-width:1180px!important;
    min-height:calc(100vh - 56px)!important;
    padding:0 28px 118px!important;
    border-radius:34px!important;
    background:var(--app-bg)!important;
    box-shadow:0 28px 78px rgba(15,23,42,.16)!important;
    overflow:hidden!important;
  }
  .osa-mp-top{
    margin:0 -28px 18px!important;
  }
  .osa-profile-card{
    min-height:304px!important;
    padding:30px 36px 92px!important;
    border-radius:0 0 42px 42px!important;
  }
  .osa-society::before{
    min-height:38px!important;
    padding:9px 14px!important;
    font-size:12.5px!important;
  }
  .osa-toprow{
    margin-bottom:26px!important;
  }
  .osa-avatar-wrap{
    left:36px!important;
    top:96px!important;
  }
  .osa-avatar,
  .osa-avatar--placeholder{
    width:64px!important;
    height:64px!important;
  }
  .osa-greet,
  .osa-member-name,
  .osa-member-sub{
    margin-left:82px!important;
  }
  .osa-greet{
    font-size:25px!important;
    line-height:1.15!important;
  }
  .osa-member-name{
    max-width:620px!important;
    font-size:15px!important;
    line-height:1.45!important;
  }
  .osa-member-sub{
    max-width:720px!important;
    font-size:12px!important;
  }
  .osa-stats3,
  .osa-stats6{
    grid-template-columns:repeat(6,minmax(0,1fr))!important;
    gap:12px!important;
    margin:54px 0 -64px!important;
    padding:14px!important;
    border-radius:26px!important;
  }
  .osa-stat{
    min-height:86px!important;
    padding:13px 12px!important;
  }
  .osa-stat-value{
    font-size:15.5px!important;
  }
  .osa-stat-label{
    font-size:10.5px!important;
    line-height:1.35!important;
  }
  .osa-mp-main{
    margin-top:86px!important;
    display:grid!important;
    grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr)!important;
    align-items:start!important;
    gap:20px!important;
  }
  .osa-mp-main > .osa-sec{
    margin:0!important;
  }
  #osa-member-investments{grid-column:1!important;grid-row:auto!important;}
  #osa-member-history{grid-column:2!important;grid-row:auto!important;}
  #osa-member-statement{grid-column:1!important;grid-row:auto!important;margin-top:0!important;}
  #osa-member-society{grid-column:2!important;grid-row:auto!important;margin-top:0!important;}
  .osa-sec{
    border-radius:24px!important;
  }
  .osa-sec-head{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    padding:0 4px 12px!important;
  }
  .osa-sec-title{
    font-size:20px!important;
    line-height:1.18!important;
  }
  .osa-sec-meta{
    max-width:100%!important;
    font-size:12.5px!important;
  }
  .osa-sec-caret{
    margin-top:0!important;
  }
  .osa-mi-card,
  .osa-mp-project{
    border-radius:24px!important;
    padding:18px!important;
    margin-bottom:14px!important;
  }
  .osa-mi-photo-img,
  .osa-mi-photo-fallback{
    width:54px!important;
    height:54px!important;
  }
  .osa-mi-info,
  .osa-mi-card .osa-mi-info{
    margin-top:-64px!important;
    padding-left:68px!important;
    min-height:64px!important;
  }
  .osa-mi-card .osa-mi-name{
    font-size:15px!important;
  }
  .osa-mi-row{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .osa-mi-value{
    font-size:14px!important;
  }
  .osa-mp-details-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .osa-mp-tablewrap::after,
  .osa-mp-table-wrap::after{display:none!important;}
  .osa-mp-table{min-width:760px!important;}
  .osa-mp-stmt-actions,
  .osa-mp-stmt-tools{
    justify-content:flex-end!important;
  }
  .osa-mp-btn{
    width:auto!important;
    min-width:170px!important;
  }
  .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-member-society-dashboard .osa-grid,
  .osa-member-society-dashboard .osa-grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:12px!important;
  }
  .osa-member-society-dashboard .osa-card{
    min-height:108px!important;
  }
  .osa-app-bottom-nav{
    bottom:24px!important;
    width:420px!important;
    max-width:calc(100vw - 64px)!important;
  }
}

@media (min-width:1280px){
  .osa-mp-shell{max-width:1280px!important;}
  .osa-mp-main{
    grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr)!important;
    gap:22px!important;
  }
  .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-member-society-dashboard .osa-grid,
  .osa-member-society-dashboard .osa-grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}

@media (min-width:1530px){
  .osa-mp-shell{max-width:1360px!important;}
  .osa-mp-main{grid-template-columns:1fr 1fr!important;}
}

@media (min-width:721px) and (max-width:899px){
  .osa-mp{padding:18px!important;}
  .osa-mp-shell{
    max-width:760px!important;
    padding:0 22px 112px!important;
    border-radius:32px!important;
  }
  .osa-mp-top{margin:0 -22px 16px!important;}
  .osa-profile-card{
    min-height:330px!important;
    padding:26px 26px 84px!important;
  }
  .osa-stats3,
  .osa-stats6{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    margin:66px 0 -78px!important;
  }
  .osa-mp-main{margin-top:98px!important;}
  .osa-sec-title{font-size:19px!important;}
  .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-member-society-dashboard .osa-grid,
  .osa-member-society-dashboard .osa-grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}

@media (max-width:720px){
  .osa-mp{padding:0!important;background:var(--app-bg)!important;}
  .osa-mp-shell{
    width:100%!important;
    max-width:none!important;
    min-height:100dvh!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    padding:0 16px 104px!important;
  }
  .osa-mp-top{margin:0 -16px 14px!important;}
  .osa-profile-card{
    min-height:356px!important;
    padding:24px 18px 18px!important;
  }
  .osa-avatar-wrap{left:18px!important;top:82px!important;}
  .osa-greet,.osa-member-name,.osa-member-sub{margin-left:64px!important;}
  .osa-greet{font-size:17px!important;}
  .osa-member-name{font-size:12.5px!important;}
  .osa-stats3,
  .osa-stats6{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    margin:70px 0 -84px!important;
    padding:12px!important;
  }
  .osa-mp-main{margin-top:100px!important;}
  .osa-sec-title{font-size:18px!important;}
  .osa-sec-meta{font-size:11.5px!important;line-height:1.5!important;}
  .osa-mi-row{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .osa-mp-details-grid{grid-template-columns:1fr!important;}
  .osa-mp-tablewrap::after,
  .osa-mp-table-wrap::after{display:block!important;}
  .osa-app-bottom-nav{bottom:12px!important;width:min(330px,calc(100vw - 34px))!important;}
}

@media (max-width:390px){
  .osa-mp-shell{padding-left:12px!important;padding-right:12px!important;}
  .osa-mp-top{margin-left:-12px!important;margin-right:-12px!important;}
  .osa-profile-card{min-height:372px!important;padding-left:16px!important;padding-right:16px!important;}
  .osa-stats3,
  .osa-stats6{
    grid-template-columns:1fr!important;
    margin-bottom:-92px!important;
  }
  .osa-mp-main{margin-top:112px!important;}
  .osa-mi-row{grid-template-columns:1fr!important;}
  .osa-mi-metric + .osa-mi-metric{border-left:0!important;border-top:1px solid rgba(35,76,22,.10)!important;}
  .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-member-society-dashboard .osa-grid,
  .osa-member-society-dashboard .osa-grid-4{grid-template-columns:1fr!important;}
}

/* ==========================================================
   v1.0.1 Member Portal App UI - section separation polish
   - Centers the deep-green header content.
   - Smooths card/section roundness.
   - Shows the four lower portal areas as clearly separate cards.
   ========================================================== */
.osa-mp .osa-profile-card{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:flex-start!important;
  text-align:center!important;
  min-height:auto!important;
  padding:28px 20px 0!important;
  border-radius:0 0 34px 34px!important;
  overflow:visible!important;
}
.osa-mp .osa-toprow{
  width:100%!important;
  margin:0 0 18px!important;
  align-self:stretch!important;
}
.osa-mp .osa-avatar-wrap{
  position:relative!important;
  left:auto!important;
  top:auto!important;
  margin:2px auto 10px!important;
  display:flex!important;
  justify-content:center!important;
  align-items:center!important;
}
.osa-mp .osa-avatar,
.osa-mp .osa-avatar--placeholder{
  width:66px!important;
  height:66px!important;
  border-width:3px!important;
}
.osa-mp .osa-greet,
.osa-mp .osa-member-name,
.osa-mp .osa-member-sub{
  margin-left:0!important;
  text-align:center!important;
  justify-content:center!important;
  max-width:100%!important;
}
.osa-mp .osa-greet{
  margin-top:0!important;
  font-size:22px!important;
  line-height:1.15!important;
}
.osa-mp .osa-member-name{
  color:rgba(255,255,255,.9)!important;
  font-size:14px!important;
  line-height:1.35!important;
}
.osa-mp .osa-member-sub{
  color:rgba(255,255,255,.82)!important;
  gap:8px!important;
}
.osa-mp .osa-member-meta{
  color:rgba(255,255,255,.82)!important;
}
.osa-mp .osa-stats3,
.osa-mp .osa-stats6{
  width:100%!important;
  max-width:100%!important;
  margin:24px auto -78px!important;
  border-radius:26px!important;
}
.osa-mp .osa-mp-main{
  margin-top:98px!important;
  gap:18px!important;
}
.osa-mp .osa-sec{
  margin:0 0 16px!important;
  padding:16px!important;
  background:#fff!important;
  border:1px solid rgba(23,25,22,.08)!important;
  border-radius:28px!important;
  box-shadow:0 18px 38px rgba(15,23,42,.07)!important;
  overflow:hidden!important;
}
.osa-mp .osa-sec-head{
  padding:0!important;
  min-height:52px!important;
  border-radius:20px!important;
}
.osa-mp .osa-sec--open .osa-sec-head{
  padding-bottom:14px!important;
  border-bottom:1px solid rgba(23,25,22,.07)!important;
  border-radius:0!important;
}
.osa-mp .osa-sec-title{
  font-size:18px!important;
  line-height:1.25!important;
}
.osa-mp .osa-sec-meta{
  font-size:12px!important;
  line-height:1.55!important;
  color:rgba(111,116,107,.92)!important;
}
.osa-mp .osa-sec-caret{
  width:36px!important;
  height:36px!important;
  border-radius:50%!important;
  align-self:center!important;
}
.osa-mp .osa-sec-body{
  padding-top:14px!important;
}
.osa-mp .osa-sec--open .osa-sec-body{
  display:block!important;
}
.osa-mp .osa-mi-card,
.osa-mp .osa-mp-project,
.osa-mp .osa-mp-tablewrap,
.osa-mp .osa-mp-table-wrap,
.osa-mp .osa-mp-empty,
.osa-mp .osa-mp-note,
.osa-mp .osa-mp-td-empty,
.osa-mp .osa-member-society-dashboard .osa-card{
  border-radius:22px!important;
}
.osa-mp .osa-mi-card::before,
.osa-mp .osa-mi-card::after{
  display:none!important;
}
.osa-mp .osa-mi-card,
.osa-mp .osa-mp-project{
  border-color:rgba(35,76,22,.10)!important;
  box-shadow:0 12px 26px rgba(15,23,42,.06)!important;
}
.osa-mp .osa-mi-row{
  border-radius:18px!important;
}
.osa-mp .osa-mp-detail{
  border-radius:16px!important;
}
.osa-mp .osa-member-society-dashboard .osa-card{
  background:#fafbf6!important;
  box-shadow:none!important;
}
.osa-mp .osa-member-society-dashboard .osa-card-head,
.osa-mp .osa-member-society-dashboard .osa-card-body{
  background:#fafbf6!important;
}
.osa-mp .osa-app-bottom-nav{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  width:min(430px,calc(100vw - 42px))!important;
  border-radius:28px!important;
}
.osa-mp .osa-app-bottom-nav a{
  border-radius:22px!important;
  padding:5px 3px!important;
}
.osa-mp .osa-app-nav-label{
  font-size:9.5px!important;
}

@media (min-width:900px){
  .osa-mp .osa-profile-card{
    padding:30px 36px 0!important;
    border-radius:0 0 42px 42px!important;
  }
  .osa-mp .osa-avatar,
  .osa-mp .osa-avatar--placeholder{
    width:76px!important;
    height:76px!important;
  }
  .osa-mp .osa-greet{font-size:28px!important;}
  .osa-mp .osa-member-name{font-size:15px!important;}
  .osa-mp .osa-stats3,
  .osa-mp .osa-stats6{
    margin:26px auto -70px!important;
    max-width:1040px!important;
    border-radius:28px!important;
  }
  .osa-mp .osa-mp-main{
    margin-top:92px!important;
    gap:22px!important;
  }
  .osa-mp .osa-sec{
    margin:0!important;
    min-height:136px!important;
    border-radius:30px!important;
    padding:18px!important;
  }
  .osa-mp .osa-sec-title{font-size:19px!important;}
  .osa-mp .osa-sec-meta{font-size:12.5px!important;}
  .osa-mp .osa-app-bottom-nav{
    width:500px!important;
    max-width:calc(100vw - 72px)!important;
    border-radius:30px!important;
  }
}

@media (min-width:721px) and (max-width:899px){
  .osa-mp .osa-profile-card{padding:26px 26px 0!important;}
  .osa-mp .osa-stats3,
  .osa-mp .osa-stats6{margin:24px auto -76px!important;}
  .osa-mp .osa-mp-main{margin-top:98px!important;}
}

@media (max-width:720px){
  .osa-mp .osa-profile-card{
    padding:24px 18px 0!important;
    border-radius:0 0 32px 32px!important;
  }
  .osa-mp .osa-avatar,
  .osa-mp .osa-avatar--placeholder{
    width:62px!important;
    height:62px!important;
  }
  .osa-mp .osa-greet{font-size:20px!important;}
  .osa-mp .osa-member-name{font-size:13px!important;}
  .osa-mp .osa-stats3,
  .osa-mp .osa-stats6{margin:22px auto -82px!important;}
  .osa-mp .osa-mp-main{margin-top:102px!important;}
  .osa-mp .osa-sec{
    margin:0 0 14px!important;
    padding:14px!important;
    border-radius:24px!important;
  }
  .osa-mp .osa-sec-head{
    min-height:48px!important;
  }
  .osa-mp .osa-app-bottom-nav{
    width:min(390px,calc(100vw - 24px))!important;
    min-height:64px!important;
    padding:7px!important;
    gap:5px!important;
  }
  .osa-mp .osa-app-bottom-nav a{min-height:48px!important;}
  .osa-mp .osa-app-nav-label{font-size:8.8px!important;}
}

@media (max-width:390px){
  .osa-mp .osa-profile-card{padding-left:14px!important;padding-right:14px!important;}
  .osa-mp .osa-stats3,
  .osa-mp .osa-stats6{margin-bottom:-90px!important;}
  .osa-mp .osa-mp-main{margin-top:112px!important;}
  .osa-mp .osa-sec{padding:12px!important;border-radius:22px!important;}
}


/* ==========================================================
   v1.0.1 Member Portal UI hotfix
   - Full-width centered green header on desktop/mobile.
   - Portal label changed to Payra Enterprise Society.
   - Mobile top icons placed on opposite sides.
   - Bottom nav click behavior stabilized by JS companion update.
   ========================================================== */
.osa-mp .osa-mp-top{
  display:block!important;
  width:auto!important;
  max-width:none!important;
  flex:none!important;
}
.osa-mp .osa-profile-card{
  width:100%!important;
  max-width:none!important;
  flex:0 0 auto!important;
  margin:0!important;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.16), transparent 35%),
    radial-gradient(circle at 18% 10%, rgba(132,179,80,.20), transparent 38%),
    linear-gradient(135deg,var(--app-green-2) 0%, var(--app-green) 56%, var(--app-green-3) 100%)!important;
}
.osa-mp .osa-society::before{
  content:"পায়রা এন্টারপ্রাইজ সোসাইটি"!important;
  max-width:100%!important;
  white-space:nowrap!important;
}
.osa-mp .osa-toprow{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
}
.osa-mp .osa-top-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
}
.osa-mp .osa-greet,
.osa-mp .osa-member-name,
.osa-mp .osa-member-sub{
  width:100%!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.osa-mp .osa-stats3,
.osa-mp .osa-stats6{
  position:relative!important;
  left:50%!important;
  transform:translateX(-50%)!important;
}
.osa-mp .osa-app-bottom-nav a{
  touch-action:manipulation!important;
  -webkit-tap-highlight-color:transparent!important;
}
@media (min-width:900px){
  .osa-mp .osa-profile-card{
    min-height:330px!important;
    padding-bottom:0!important;
  }
  .osa-mp .osa-society::before{
    font-size:13px!important;
    padding-inline:18px!important;
  }
  .osa-mp .osa-toprow{
    min-height:52px!important;
  }
}
@media (max-width:720px){
  .osa-mp .osa-profile-card{
    min-height:auto!important;
    padding:18px 16px 0!important;
    border-radius:0 0 30px 30px!important;
  }
  .osa-mp .osa-toprow{
    display:grid!important;
    grid-template-columns:46px minmax(0,1fr) 46px!important;
    gap:8px!important;
    align-items:center!important;
    margin:0 0 16px!important;
    min-height:48px!important;
  }
  .osa-mp .osa-society{
    grid-column:2!important;
    grid-row:1!important;
    justify-self:center!important;
    justify-content:center!important;
    min-width:0!important;
    width:100%!important;
    text-align:center!important;
  }
  .osa-mp .osa-society::before{
    min-height:34px!important;
    max-width:100%!important;
    padding:8px 10px!important;
    font-size:10.5px!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    justify-content:center!important;
  }
  .osa-mp .osa-top-actions{
    display:contents!important;
  }
  .osa-mp .osa-top-actions .osa-bell{
    grid-column:1!important;
    grid-row:1!important;
    justify-self:start!important;
  }
  .osa-mp .osa-top-actions .osa-logout{
    grid-column:3!important;
    grid-row:1!important;
    justify-self:end!important;
  }
  .osa-mp .osa-iconbtn,
  .osa-mp .osa-iconbtn.osa-logout{
    width:42px!important;
    min-width:42px!important;
    height:42px!important;
    min-height:42px!important;
  }
  .osa-mp .osa-avatar-wrap{
    margin-top:0!important;
  }
  .osa-mp .osa-greet{
    font-size:20px!important;
    line-height:1.18!important;
  }
  .osa-mp .osa-member-name{
    font-size:13px!important;
  }
  .osa-mp .osa-member-sub{
    font-size:10.8px!important;
    line-height:1.45!important;
  }
  .osa-mp .osa-stats3,
  .osa-mp .osa-stats6{
    left:50%!important;
    transform:translateX(-50%)!important;
    width:calc(100% - 2px)!important;
    margin-top:20px!important;
    margin-bottom:-80px!important;
  }
  .osa-mp .osa-app-bottom-nav{
    transform:translate3d(-50%,0,0)!important;
    will-change:transform!important;
  }
}
@media (max-width:390px){
  .osa-mp .osa-society::before{
    font-size:10px!important;
    padding-inline:8px!important;
  }
  .osa-mp .osa-toprow{
    grid-template-columns:42px minmax(0,1fr) 42px!important;
    gap:6px!important;
  }
  .osa-mp .osa-iconbtn,
  .osa-mp .osa-iconbtn.osa-logout{
    width:40px!important;
    min-width:40px!important;
    height:40px!important;
    min-height:40px!important;
  }
}

/* ==========================================================
   v1.0.1 Member Portal Profile Update
   - Members can update photo/password from portal.
   - Uses the same member table as backend profiles.
   ========================================================== */
.osa-mp .osa-profile-update-card{
  overflow:hidden!important;
}
.osa-mp .osa-profile-notice{
  margin:0 0 16px!important;
  padding:12px 14px!important;
  border-radius:16px!important;
  font-size:13px!important;
  font-weight:800!important;
  line-height:1.45!important;
  border:1px solid transparent!important;
}
.osa-mp .osa-profile-notice--success{
  background:#eef9e9!important;
  border-color:rgba(35,76,22,.16)!important;
  color:#234c16!important;
}
.osa-mp .osa-profile-notice--error{
  background:#fff1f0!important;
  border-color:rgba(185,28,28,.16)!important;
  color:#9f1d1d!important;
}
.osa-mp .osa-profile-notice--info{
  background:#f6f7f1!important;
  border-color:rgba(35,76,22,.10)!important;
  color:#6b7065!important;
}
.osa-mp .osa-profile-form{
  margin:0!important;
}
.osa-mp .osa-profile-form-grid{
  display:grid!important;
  grid-template-columns:220px minmax(0,1fr)!important;
  gap:22px!important;
  align-items:start!important;
}
.osa-mp .osa-profile-photo-box{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  gap:12px!important;
  padding:18px!important;
  border-radius:24px!important;
  background:#fafbf6!important;
  border:1px solid rgba(35,76,22,.10)!important;
}
.osa-mp .osa-profile-photo-preview{
  width:112px!important;
  height:112px!important;
  border-radius:32px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  background:linear-gradient(135deg,#234c16,#5d7d45)!important;
  color:#fff!important;
  font-size:30px!important;
  font-weight:900!important;
  border:4px solid #fff!important;
  box-shadow:0 16px 32px rgba(15,23,42,.14)!important;
}
.osa-mp .osa-profile-photo-preview img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
}
.osa-mp .osa-profile-upload-btn{
  width:100%!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:44px!important;
  border-radius:999px!important;
  background:#234c16!important;
  color:#fff!important;
  cursor:pointer!important;
  font-size:13px!important;
  font-weight:900!important;
  box-shadow:0 12px 22px rgba(35,76,22,.18)!important;
}
.osa-mp .osa-profile-upload-btn input{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  opacity:0!important;
  pointer-events:none!important;
}
.osa-mp .osa-profile-help,
.osa-mp .osa-profile-action-note{
  color:#6f746b!important;
  font-size:12px!important;
  font-weight:700!important;
  line-height:1.45!important;
  text-align:center!important;
}
.osa-mp .osa-profile-fields{
  min-width:0!important;
}
.osa-mp .osa-profile-readonly-row{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
  margin-bottom:14px!important;
}
.osa-mp .osa-profile-readonly-row>div{
  padding:14px!important;
  border-radius:18px!important;
  background:#fafbf6!important;
  border:1px solid rgba(35,76,22,.10)!important;
  min-width:0!important;
}
.osa-mp .osa-profile-readonly-row span,
.osa-mp .osa-profile-password-grid label>span{
  display:block!important;
  margin-bottom:6px!important;
  color:#6f746b!important;
  font-size:12px!important;
  font-weight:900!important;
}
.osa-mp .osa-profile-readonly-row strong{
  display:block!important;
  color:#1b1f1b!important;
  font-size:15px!important;
  font-weight:900!important;
  overflow-wrap:anywhere!important;
}
.osa-mp .osa-profile-password-grid{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:12px!important;
}
.osa-mp .osa-profile-password-grid label{
  display:block!important;
  margin:0!important;
  min-width:0!important;
}
.osa-mp .osa-profile-password-grid input{
  width:100%!important;
  min-height:46px!important;
  border:1px solid rgba(35,76,22,.14)!important;
  border-radius:16px!important;
  background:#fff!important;
  color:#1b1f1b!important;
  padding:10px 12px!important;
  font-size:14px!important;
  font-weight:700!important;
  outline:none!important;
  box-shadow:none!important;
}
.osa-mp .osa-profile-password-grid input:focus{
  border-color:rgba(35,76,22,.45)!important;
  box-shadow:0 0 0 4px rgba(35,76,22,.08)!important;
}
.osa-mp .osa-profile-actions{
  display:flex!important;
  align-items:center!important;
  gap:12px!important;
  margin-top:16px!important;
  flex-wrap:wrap!important;
}
.osa-mp .osa-profile-save-btn{
  min-height:46px!important;
  border:0!important;
  border-radius:999px!important;
  background:#234c16!important;
  color:#fff!important;
  padding:0 20px!important;
  font-size:14px!important;
  font-weight:900!important;
  cursor:pointer!important;
  box-shadow:0 14px 26px rgba(35,76,22,.20)!important;
}
.osa-mp .osa-profile-save-btn:hover{
  filter:brightness(.96)!important;
}
.osa-mp .osa-app-bottom-nav{
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
  width:min(520px,calc(100vw - 42px))!important;
}
.osa-mp .osa-app-bottom-nav a{
  min-width:0!important;
}
@media (min-width:900px){
  .osa-mp .osa-app-bottom-nav{width:570px!important;}
}
@media (max-width:820px){
  .osa-mp .osa-profile-form-grid{
    grid-template-columns:1fr!important;
    gap:16px!important;
  }
  .osa-mp .osa-profile-photo-box{
    flex-direction:row!important;
    justify-content:flex-start!important;
    align-items:center!important;
    text-align:left!important;
  }
  .osa-mp .osa-profile-photo-preview{
    width:88px!important;
    height:88px!important;
    border-radius:26px!important;
    flex:0 0 auto!important;
  }
  .osa-mp .osa-profile-upload-btn{
    width:auto!important;
    padding-inline:16px!important;
  }
  .osa-mp .osa-profile-help{text-align:left!important;}
}
@media (max-width:720px){
  .osa-mp .osa-profile-readonly-row,
  .osa-mp .osa-profile-password-grid{
    grid-template-columns:1fr!important;
  }
  .osa-mp .osa-profile-actions{
    flex-direction:column!important;
    align-items:stretch!important;
  }
  .osa-mp .osa-profile-save-btn{
    width:100%!important;
  }
  .osa-mp .osa-profile-action-note{text-align:center!important;}
  .osa-mp .osa-app-bottom-nav{
    width:min(430px,calc(100vw - 18px))!important;
    gap:4px!important;
  }
  .osa-mp .osa-app-bottom-nav a{
    padding:5px 2px!important;
  }
  .osa-mp .osa-app-nav-label{font-size:8px!important;}
  .osa-mp .osa-app-nav-ico{font-size:14px!important;}
}
@media (max-width:430px){
  .osa-mp .osa-profile-photo-box{
    flex-direction:column!important;
    text-align:center!important;
  }
  .osa-mp .osa-profile-upload-btn{
    width:100%!important;
  }
  .osa-mp .osa-profile-help{text-align:center!important;}
}

/* ==========================================================
   v1.0.1 Member Portal Society Dashboard UI Polish
   Scope: Member portal only (.osa-mp #osa-member-society).
   Keeps backend dashboard and frontend admin portal untouched.
   ========================================================== */
.osa-mp #osa-member-society{
  background:#fff!important;
  border-color:rgba(35,76,22,.10)!important;
}
.osa-mp #osa-member-society .osa-sec-head{
  background:transparent!important;
}
.osa-mp #osa-member-society .osa-sec-title{
  color:#101510!important;
  letter-spacing:-.25px!important;
}
.osa-mp #osa-member-society .osa-sec-meta{
  color:#73796f!important;
  max-width:640px!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard{
  padding:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
  overflow:visible!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard > .osa-card-head{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
  margin:0 0 14px!important;
  padding:14px 16px!important;
  border:1px solid rgba(35,76,22,.10)!important;
  border-radius:22px!important;
  background:linear-gradient(135deg,#f8faf2 0%,#eef4e8 100%)!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard > .osa-card-head::after{
  content:""!important;
  width:42px!important;
  height:42px!important;
  flex:0 0 42px!important;
  border-radius:16px!important;
  background:
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.80) 0 2px, transparent 3px),
    linear-gradient(135deg,#2b5c1b,#17380f)!important;
  box-shadow:0 12px 22px rgba(35,76,22,.20)!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard > .osa-card-head .osa-card-title{
  margin:0!important;
  color:#1f3f15!important;
  font-size:15px!important;
  line-height:1.25!important;
  font-weight:950!important;
  letter-spacing:-.15px!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard > .osa-card-body{
  padding:0!important;
  background:transparent!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid,
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid,
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid-4{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card{
  position:relative!important;
  min-height:124px!important;
  padding:14px!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:space-between!important;
  border:1px solid rgba(35,76,22,.10)!important;
  border-radius:24px!important;
  background:
    radial-gradient(circle at 96% 0%, rgba(35,76,22,.08), transparent 34%),
    linear-gradient(180deg,#ffffff 0%,#fbfcf7 100%)!important;
  box-shadow:0 14px 30px rgba(15,23,42,.06)!important;
  overflow:hidden!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card::before{
  content:""!important;
  position:absolute!important;
  inset:auto 14px 0 14px!important;
  height:4px!important;
  border-radius:999px 999px 0 0!important;
  background:#234c16!important;
  opacity:.14!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-card-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:10px!important;
  padding:0!important;
  margin:0!important;
  border:0!important;
  background:transparent!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-card-title{
  max-width:calc(100% - 48px)!important;
  color:#6f746b!important;
  font-size:11.5px!important;
  line-height:1.35!important;
  font-weight:900!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-icon{
  width:38px!important;
  height:38px!important;
  min-width:38px!important;
  border-radius:15px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:#eef4e8!important;
  color:#234c16!important;
  box-shadow:inset 0 0 0 1px rgba(35,76,22,.08)!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-icon::before{
  content:""!important;
  width:14px!important;
  height:14px!important;
  border-radius:5px!important;
  background:currentColor!important;
  opacity:.86!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-card-body{
  padding:12px 0 4px!important;
  margin:0!important;
  background:transparent!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-metric{
  color:#141814!important;
  font-size:clamp(15px,2.2vw,20px)!important;
  line-height:1.18!important;
  font-weight:950!important;
  letter-spacing:-.35px!important;
  word-break:break-word!important;
  overflow-wrap:anywhere!important;
}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-green .osa-icon{background:#eef9e9!important;color:#2b5c1b!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-blue .osa-icon{background:#eef6ff!important;color:#2563eb!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-amber .osa-icon{background:#fff7e7!important;color:#b45309!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-rose .osa-icon{background:#fff0f2!important;color:#be123c!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-indigo .osa-icon{background:#eef2ff!important;color:#4f46e5!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-teal .osa-icon{background:#ecfdf5!important;color:#0f766e!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-violet .osa-icon{background:#f5f3ff!important;color:#7c3aed!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-sky .osa-icon{background:#f0f9ff!important;color:#0284c7!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-green::before{background:#2b5c1b!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-blue::before{background:#2563eb!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-amber::before{background:#b45309!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-rose::before{background:#be123c!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-indigo::before{background:#4f46e5!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-teal::before{background:#0f766e!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-violet::before{background:#7c3aed!important;}
.osa-mp #osa-member-society .osa-member-society-dashboard .osa-card-accent-sky::before{background:#0284c7!important;}

@media (min-width:1180px){
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid,
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}
@media (min-width:721px) and (max-width:899px){
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid,
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}
@media (max-width:720px){
  .osa-mp #osa-member-society .osa-member-society-dashboard > .osa-card-head{
    border-radius:20px!important;
    padding:12px 13px!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard > .osa-card-head::after{
    width:38px!important;
    height:38px!important;
    flex-basis:38px!important;
    border-radius:14px!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard > .osa-card-head .osa-card-title{
    font-size:14px!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid,
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card{
    min-height:112px!important;
    border-radius:20px!important;
    padding:12px!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-card-title{
    max-width:100%!important;
    font-size:10.5px!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-icon{
    width:32px!important;
    height:32px!important;
    min-width:32px!important;
    border-radius:12px!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-metric{
    font-size:14px!important;
  }
}
@media (max-width:390px){
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid,
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid,
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-grid-4{
    grid-template-columns:1fr!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card{
    min-height:96px!important;
  }
  .osa-mp #osa-member-society .osa-member-society-dashboard .osa-dashboard-grid > .osa-card .osa-metric{
    font-size:16px!important;
  }
}
