/* PMSFlow Frontend v2 — Jost / Premium White */
@import url('https://fonts.googleapis.com/css2?family=Jost:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --pf-g:      #16a34a;
  --pf-g-h:    #15803d;
  --pf-g-d:    #14532d;
  --pf-g-lt:   #f0fdf4;
  --pf-g-md:   #dcfce7;
  --pf-g-bd:   #bbf7d0;
  --pf-red:    #dc2626;
  --pf-red-lt: #fff5f5;
  --pf-amb:    #d97706;
  --pf-amb-lt: #fffbeb;
  --pf-blue:   #2563eb;
  --pf-blue-lt:#eff6ff;
  --pf-ink:    #0a0f1e;
  --pf-ink2:   #334155;
  --pf-ink3:   #64748b;
  --pf-ink4:   #94a3b8;
  --pf-bg:     #f4f6fa;
  --pf-surface:#ffffff;
  --pf-border: #e4e9f0;
  --pf-font:   'Jost', sans-serif;
  --pf-r:      12px;
  --pf-sh:     0 1px 3px rgba(10,15,30,.05), 0 4px 16px rgba(10,15,30,.07);
}

.pmf-portal,
.pmf-announcements-list,
.pmf-payment-form,
.pmf-dues-list {
  font-family: var(--pf-font);
  color: var(--pf-ink);
  max-width: 780px;
}

/* ── Portal header ──────────────────────────────── */
.pmf-portal-header {
  background: linear-gradient(135deg, var(--pf-g) 0%, var(--pf-g-h) 100%);
  border-radius: 16px;
  padding: 24px 28px;
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 18px;
  color: #fff;
  box-shadow: 0 4px 20px rgba(22,163,74,.3);
}
.pmf-portal-avatar {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  font-size: 22px;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  border: 2px solid rgba(255,255,255,.4);
}
.pmf-portal-header h2 { font-size: 20px; font-weight: 800; margin: 0 0 4px; letter-spacing: -.3px; }
.pmf-portal-header p  { font-size: 13.5px; opacity: .85; margin: 0; }

/* ── Portal tabs ────────────────────────────────── */
.pmf-portal-tabs {
  display: flex;
  gap: 3px;
  background: #eef2f7;
  border-radius: 12px;
  padding: 4px;
  width: fit-content;
  margin-bottom: 20px;
  border: 1px solid var(--pf-border);
}
.pmf-portal-tab {
  padding: 8px 20px;
  border-radius: 9px;
  font-family: var(--pf-font);
  font-size: 13.5px;
  font-weight: 600;
  color: var(--pf-ink3);
  background: none;
  border: none;
  cursor: pointer;
  transition: all .14s;
  text-decoration: none;
  display: inline-block;
}
.pmf-portal-tab:hover  { color: var(--pf-ink); }
.pmf-portal-tab.active {
  background: var(--pf-surface);
  color: var(--pf-g);
  box-shadow: 0 1px 4px rgba(10,15,30,.1);
  font-weight: 700;
}

/* ── Public card ────────────────────────────────── */
.pmf-pub-card {
  background: var(--pf-surface);
  border: 1px solid var(--pf-border);
  border-radius: var(--pf-r);
  box-shadow: var(--pf-sh);
  overflow: hidden;
  margin-bottom: 16px;
}
.pmf-pub-card-header {
  padding: 14px 20px;
  border-bottom: 1px solid var(--pf-border);
  background: #fafbfd;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pmf-pub-card-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--pf-ink);
  display: flex;
  align-items: center;
  gap: 7px;
}
.pmf-pub-card-body { padding: 20px; }

/* ── Due row ────────────────────────────────────── */
.pmf-due-list { display: flex; flex-direction: column; gap: 8px; }

.pmf-due-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border: 1.5px solid var(--pf-border);
  border-radius: 10px;
  background: var(--pf-surface);
  transition: box-shadow .14s, border-color .14s;
}
.pmf-due-row:hover { box-shadow: var(--pf-sh); }
.pmf-due-row.overdue { border-color: #fca5a5; background: var(--pf-red-lt); }
.pmf-due-row.paid    { border-color: var(--pf-g-bd); background: var(--pf-g-lt); opacity: .85; }

.pmf-due-info strong { display: block; font-size: 14px; font-weight: 700; color: var(--pf-ink); }
.pmf-due-info span   { font-size: 12px; color: var(--pf-ink3); margin-top: 2px; display: block; }
.pmf-due-amount      { font-size: 18px; font-weight: 800; color: var(--pf-ink); font-variant-numeric: tabular-nums; letter-spacing: -.3px; }
.pmf-due-row.overdue .pmf-due-amount { color: var(--pf-red); }
.pmf-due-row.paid    .pmf-due-amount { color: var(--pf-g); }

/* ── Announcement ───────────────────────────────── */
.pmf-ann-card {
  background: var(--pf-surface);
  border: 1px solid var(--pf-border);
  border-radius: var(--pf-r);
  padding: 18px 22px;
  margin-bottom: 12px;
  box-shadow: var(--pf-sh);
  transition: box-shadow .14s;
}
.pmf-ann-card:hover { box-shadow: 0 4px 20px rgba(10,15,30,.1); }
.pmf-ann-card.pinned {
  border-left: 4px solid var(--pf-g);
  border-color: var(--pf-g-bd);
  background: var(--pf-g-lt);
}
.pmf-ann-pin   { font-size: 11px; color: var(--pf-g); font-weight: 700; text-transform: uppercase; letter-spacing: .5px; display: block; margin-bottom: 6px; }
.pmf-ann-title { font-size: 15px; font-weight: 800; color: var(--pf-ink); margin-bottom: 8px; display: block; letter-spacing: -.2px; }
.pmf-ann-body  { font-size: 14px; color: var(--pf-ink2); line-height: 1.7; }
.pmf-ann-time  { font-size: 11.5px; color: var(--pf-ink4); margin-top: 12px; display: block; }

/* ── Badge ──────────────────────────────────────── */
.pmf-pub-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 9px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .2px;
  text-transform: uppercase;
}
.pmf-pub-badge--paid    { background: var(--pf-g-md);  color: var(--pf-g-d); }
.pmf-pub-badge--pending { background: var(--pf-amb-lt); color: var(--pf-amb); border: 1px solid #fde68a; }
.pmf-pub-badge--overdue { background: var(--pf-red-lt); color: var(--pf-red); border: 1px solid #fecaca; }

/* ── Buttons ────────────────────────────────────── */
.pmf-pub-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 20px;
  border-radius: 9px;
  font-family: var(--pf-font);
  font-size: 13.5px;
  font-weight: 700;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: all .14s;
  text-decoration: none;
  letter-spacing: .1px;
}
.pmf-pub-btn--primary {
  background: var(--pf-g); color: #fff;
  box-shadow: 0 2px 8px rgba(22,163,74,.25);
}
.pmf-pub-btn--primary:hover {
  background: var(--pf-g-h); color: #fff;
  box-shadow: 0 4px 14px rgba(22,163,74,.35);
  transform: translateY(-1px);
}
.pmf-pub-btn--outline {
  background: var(--pf-surface);
  color: var(--pf-ink2);
  border-color: var(--pf-border);
}
.pmf-pub-btn--outline:hover { border-color: var(--pf-g); color: var(--pf-g); }

/* ── Notice ─────────────────────────────────────── */
.pmf-pub-notice {
  padding: 13px 16px;
  border-radius: 10px;
  font-size: 13.5px;
  font-family: var(--pf-font);
  border: 1px solid;
  margin-bottom: 16px;
  line-height: 1.5;
}
.pmf-pub-notice--info    { background: var(--pf-blue-lt); border-color: #bfdbfe; color: #1e40af; }
.pmf-pub-notice--warning { background: var(--pf-amb-lt);  border-color: #fde68a; color: #92400e; }
.pmf-pub-notice--success { background: var(--pf-g-lt);    border-color: var(--pf-g-bd); color: var(--pf-g-d); }

/* ── Empty ──────────────────────────────────────── */
.pmf-pub-empty {
  text-align: center;
  padding: 40px 20px;
  color: var(--pf-ink4);
  font-family: var(--pf-font);
}
.pmf-pub-empty span { font-size: 38px; display: block; margin-bottom: 12px; opacity: .5; }
.pmf-pub-empty p    { font-size: 14px; color: var(--pf-ink3); }

/* ── Info table ─────────────────────────────────── */
.pmf-pub-info-row {
  display: flex;
  justify-content: space-between;
  padding: 11px 0;
  border-bottom: 1px solid var(--pf-border);
  font-size: 13.5px;
  font-family: var(--pf-font);
}
.pmf-pub-info-row:last-child { border-bottom: none; }
.pmf-pub-info-key   { color: var(--pf-ink3); font-weight: 500; }
.pmf-pub-info-value { color: var(--pf-ink);  font-weight: 700; }

/* ── Card form ──────────────────────────────────── */
.pmf-field label {
  display: block;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--pf-ink3);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 5px;
}
.pmf-field input {
  width: 100%;
  background: var(--pf-surface);
  border: 1.5px solid var(--pf-border);
  border-radius: 9px;
  padding: 9px 13px;
  font-family: var(--pf-font);
  font-size: 13.5px;
  color: var(--pf-ink);
  outline: none;
  transition: border-color .14s, box-shadow .14s;
}
.pmf-field input:focus {
  border-color: var(--pf-g);
  box-shadow: 0 0 0 3px rgba(22,163,74,.1);
}

/* ── Spinner ─────────────────────────────────────── */
.pmf-pub-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(22,163,74,.2);border-top-color:var(--pf-g);border-radius:50%;animation:pmf-pub-spin .6s linear infinite;vertical-align:middle;}
@keyframes pmf-pub-spin{to{transform:rotate(360deg);}}

/* ── Frontend Modal ──────────────────────────────── */
.pmf-pub-modal-wrap{display:none;}
.pmf-pub-modal-wrap.pmf-pub-modal-open{display:flex;position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center;}
.pmf-pub-modal-backdrop{position:absolute;inset:0;background:rgba(10,15,30,.5);backdrop-filter:blur(4px);}
.pmf-pub-modal{position:relative;background:#fff;border-radius:18px;width:580px;max-width:96vw;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px rgba(10,15,30,.2);animation:pmf-pub-modal-in .22s cubic-bezier(.22,1,.36,1);}
@keyframes pmf-pub-modal-in{from{transform:translateY(16px) scale(.97);opacity:0;}to{transform:translateY(0) scale(1);opacity:1;}}
.pmf-pub-modal-header{padding:20px 24px 16px;border-bottom:1px solid #f0f4f8;display:flex;align-items:center;justify-content:space-between;}
.pmf-pub-modal-header h3{font-family:var(--pf-font);font-size:16px;font-weight:800;color:var(--pf-ink);display:flex;align-items:center;gap:8px;}
.pmf-pub-modal-close{width:30px;height:30px;border-radius:8px;background:#f1f5f9;border:none;cursor:pointer;color:#94a3b8;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .14s;}
.pmf-pub-modal-close:hover{background:#fee2e2;color:#dc2626;}
.pmf-pub-modal-body{padding:22px 24px;}
.pmf-pub-modal-footer{padding:14px 24px;border-top:1px solid #f0f4f8;background:#fafbfd;display:flex;gap:10px;justify-content:flex-end;border-radius:0 0 18px 18px;}

/* ── Frontend form fields ────────────────────────── */
.pmf-pub-form-row{display:grid;gap:14px;margin-bottom:14px;}
.pmf-pub-form-row.c2{grid-template-columns:1fr 1fr;}
.pmf-pub-form-row.c1{grid-template-columns:1fr;}
@media(max-width:600px){.pmf-pub-form-row.c2{grid-template-columns:1fr;}}
.pmf-pub-field{display:flex;flex-direction:column;gap:5px;}
.pmf-pub-field label{font-family:var(--pf-font);font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px;}
.pmf-pub-field input,
.pmf-pub-field select,
.pmf-pub-field textarea{font-family:var(--pf-font);font-size:14px;color:var(--pf-ink);background:#fff;border:1.5px solid #dde3ec;border-radius:10px;padding:10px 13px;width:100%;outline:none;transition:border-color .14s,box-shadow .14s;-webkit-appearance:none;appearance:none;}
.pmf-pub-field input:focus,
.pmf-pub-field select:focus,
.pmf-pub-field textarea:focus{border-color:var(--pf-g);box-shadow:0 0 0 3px rgba(22,163,74,.12);}
.pmf-pub-field input::placeholder{color:#b0bac7;}
.pmf-pub-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2394a3b8'%3E%3Cpath d='M5.23 7.21a.75.75 0 011.06.02L10 11.168l3.71-3.938a.75.75 0 111.08 1.04l-4.25 4.5a.75.75 0 01-1.08 0l-4.25-4.5a.75.75 0 01.02-1.06z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;padding-right:34px;cursor:pointer;}
.pmf-pub-field textarea{resize:vertical;min-height:80px;line-height:1.6;}

/* ── Manager panel ───────────────────────────────── */
.pmf-mgr-wrap{font-family:var(--pf-font);color:var(--pf-ink);}
.pmf-mgr-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px;}
.pmf-mgr-header h2{font-size:20px;font-weight:800;color:var(--pf-ink);display:flex;align-items:center;gap:10px;letter-spacing:-.3px;}
.pmf-mgr-logo{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--pf-g),var(--pf-g-h));color:#fff;font-size:14px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;}

/* Stats */
.pmf-mgr-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px;}
.pmf-mgr-stat{background:#fff;border:1px solid var(--pf-border);border-radius:12px;padding:16px 18px;box-shadow:0 1px 4px rgba(10,15,30,.06);}
.pmf-mgr-stat-icon{font-size:20px;margin-bottom:10px;}
.pmf-mgr-stat-val{font-size:24px;font-weight:800;color:var(--pf-ink);line-height:1;margin-bottom:3px;font-variant-numeric:tabular-nums;}
.pmf-mgr-stat-lbl{font-size:11px;color:var(--pf-ink4);font-weight:600;text-transform:uppercase;letter-spacing:.5px;}

/* Table */
.pmf-mgr-table-wrap{overflow-x:auto;}
.pmf-mgr-table{width:100%;border-collapse:collapse;font-size:13.5px;font-family:var(--pf-font);}
.pmf-mgr-table th{background:#f8fafc;padding:9px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--pf-ink4);border-bottom:1px solid var(--pf-border);}
.pmf-mgr-table td{padding:11px 14px;border-bottom:1px solid #f1f5f9;color:var(--pf-ink2);vertical-align:middle;}
.pmf-mgr-table tr:last-child td{border-bottom:none;}
.pmf-mgr-table tbody tr:hover td{background:#fafbfd;}
.pmf-mgr-strong{color:var(--pf-ink)!important;font-weight:700;}
.pmf-mgr-muted{color:var(--pf-ink3)!important;font-size:12px;}

/* Section card */
.pmf-mgr-card{background:#fff;border:1px solid var(--pf-border);border-radius:14px;overflow:hidden;margin-bottom:18px;box-shadow:0 1px 4px rgba(10,15,30,.06);}
.pmf-mgr-card-header{padding:13px 18px;border-bottom:1px solid var(--pf-border);background:#fafbfd;display:flex;align-items:center;justify-content:space-between;}
.pmf-mgr-card-title{font-size:13.5px;font-weight:700;color:var(--pf-ink);display:flex;align-items:center;gap:7px;}
.pmf-mgr-card-body{padding:18px;}

/* Nav tabs */
.pmf-mgr-tabs{display:flex;gap:3px;background:#f0f4f8;border-radius:10px;padding:4px;width:fit-content;margin-bottom:20px;flex-wrap:wrap;}
.pmf-mgr-tab{padding:7px 16px;border-radius:7px;font-family:var(--pf-font);font-size:13px;font-weight:600;color:var(--pf-ink3);background:none;border:none;cursor:pointer;transition:all .14s;text-decoration:none;display:inline-block;}
.pmf-mgr-tab:hover{color:var(--pf-ink);}
.pmf-mgr-tab.active{background:#fff;color:var(--pf-g);box-shadow:0 1px 4px rgba(10,15,30,.1);font-weight:700;}
