/*
 * 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;
  }
}
