/* ============================================================
   Shared Professional Theme (v2 - responsive + filters)
   ============================================================ */
:root{
  --navy:#12233f;
  --navy-light:#1c3660;
  --gold:#b8892f;
  --gold-light:#e7c580;
  --ink:#1f2937;
  --muted:#6b7280;
  --border:#d9dee6;
  --bg:#f3f5f8;
  --card:#ffffff;
  --success:#1c8a4b;
  --danger:#c0392b;
  --radius:10px;
  --shadow:0 2px 10px rgba(18,35,63,0.08);
}

*{box-sizing:border-box;}
body{
  margin:0;
  font-family:'Segoe UI', Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--ink);
}
a{color:inherit;}
img{max-width:100%;}

/* ---------- Layout shells ---------- */
.app-shell{max-width:1200px;margin:0 auto;padding:24px;}
.topbar{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
  background:var(--navy);color:#fff;padding:16px 24px;border-radius:var(--radius);
  margin-bottom:24px;box-shadow:var(--shadow);
}
.topbar h1{font-size:20px;margin:0;font-weight:600;letter-spacing:.3px;}
.topbar .actions{display:flex;flex-wrap:wrap;gap:8px;}
.topbar .actions a, .topbar .actions button{
  background:var(--gold);color:#1a1a1a;border:none;padding:9px 16px;
  border-radius:6px;font-weight:600;cursor:pointer;text-decoration:none;
  font-size:13px;display:inline-block;
}
.topbar .actions a.secondary{background:rgba(255,255,255,0.12);color:#fff;}
.topbar .actions a:hover, .topbar .actions button:hover{background:var(--gold-light);}

.card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;margin-bottom:22px;box-shadow:var(--shadow);
}
.card h2{
  margin:0 0 16px;font-size:16px;color:var(--navy);
  border-bottom:2px solid var(--gold);display:inline-block;padding-bottom:6px;
}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
@media(max-width:800px){.grid-2,.grid-3{grid-template-columns:1fr;}}

/* ---------- Forms ---------- */
label{display:block;font-size:12.5px;font-weight:600;color:var(--navy);margin-bottom:5px;}
input[type=text], input[type=tel], input[type=number], input[type=date],
input[type=file], input[type=search], textarea, select{
  width:100%;padding:9px 11px;border:1px solid var(--border);border-radius:6px;
  font-size:13.5px;font-family:inherit;background:#fff;color:var(--ink);
}
textarea{resize:vertical;min-height:80px;}
.field{margin-bottom:14px;}
.btn{
  display:inline-block;border:none;padding:10px 18px;border-radius:6px;
  font-weight:600;font-size:13.5px;cursor:pointer;text-decoration:none;
}
.btn-primary{background:var(--navy);color:#fff;}
.btn-primary:hover{background:var(--navy-light);}
.btn-gold{background:var(--gold);color:#1a1a1a;}
.btn-gold:hover{background:var(--gold-light);}
.btn-danger{background:var(--danger);color:#fff;}
.btn-danger:hover{background:#992d21;}
.btn-outline{background:#fff;border:1px solid var(--border);color:var(--ink);}
.btn-sm{padding:6px 12px;font-size:12px;}

.msg{padding:10px 14px;border-radius:6px;margin-bottom:16px;font-size:13.5px;font-weight:600;}
.msg.success{background:#e5f6ec;color:var(--success);border:1px solid #b9e5c9;}
.msg.error{background:#fceeec;color:var(--danger);border:1px solid #f3c9c3;}

/* ---------- Filter bar ---------- */
.filter-bar{
  display:flex;flex-wrap:wrap;align-items:end;gap:14px;margin-bottom:18px;
  background:#f8f9fb;border:1px solid var(--border);border-radius:8px;padding:14px;
}
.filter-bar .field{margin-bottom:0;flex:1 1 160px;min-width:140px;}
.view-toggle{display:flex;gap:6px;flex:0 0 auto;}
.view-toggle button{
  border:1px solid var(--border);background:#fff;padding:9px 14px;border-radius:6px;
  font-size:13px;font-weight:600;cursor:pointer;color:var(--muted);
}
.view-toggle button.active{background:var(--navy);color:#fff;border-color:var(--navy);}

/* ---------- Data table (dashboard listing) ---------- */
table.list{width:100%;border-collapse:collapse;font-size:13px;}
table.list th, table.list td{border:1px solid var(--border);padding:9px 10px;text-align:left;vertical-align:middle;}
table.list th{background:var(--navy);color:#fff;font-weight:600;font-size:12.5px;}
table.list tr:nth-child(even) td{background:#f8f9fb;}
table.list img.thumb{width:42px;height:42px;object-fit:cover;border-radius:50%;border:1px solid var(--border);}
table.list img.biz-thumb{width:26px;height:26px;object-fit:cover;border-radius:4px;border:1px solid var(--border);vertical-align:middle;margin-right:5px;}

.row-actions{display:flex;gap:6px;flex-wrap:wrap;}

/* ---------- Card / Grid view (mobile + tablet default) ---------- */
.member-cards{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(230px, 1fr));
  gap:16px;
}
.member-card{
  border:1px solid var(--border);border-radius:10px;padding:16px;background:#fff;
  display:flex;flex-direction:column;gap:10px;position:relative;
  transition:box-shadow .15s ease;
}
.member-card:hover{box-shadow:var(--shadow);}
.member-card .card-top{display:flex;align-items:center;gap:10px;}
.member-card .photo-wrap{position:relative;flex:0 0 auto;}
.member-card img.thumb{width:56px;height:56px;object-fit:cover;border-radius:50%;border:1px solid var(--border);}
.member-card .biz-badge{
  position:absolute;bottom:-4px;right:-4px;width:22px;height:22px;border-radius:5px;
  border:2px solid #fff;object-fit:cover;background:#fff;
}
.member-card .name{font-weight:700;color:var(--navy);font-size:14.5px;}
.member-card .meta{font-size:12px;color:var(--muted);line-height:1.4;}
.member-card .stats{display:flex;gap:8px;}
.member-card .stat{
  flex:1;text-align:center;background:#f7f9fc;border-radius:6px;padding:6px 4px;
}
.member-card .stat b{display:block;font-size:16px;color:var(--navy);}
.member-card .stat span{font-size:10px;color:var(--muted);text-transform:uppercase;}
.member-card .card-actions{display:flex;gap:6px;}
.member-card .card-actions form{flex:1;}
.member-card .card-actions .btn{width:100%;text-align:center;}

/* View mode switching */
.view-table{display:block;}
.view-grid{display:none;}
body.mode-grid .view-table{display:none;}
body.mode-grid .view-grid{display:grid;}
body.mode-table .view-table{display:block;}
body.mode-table .view-grid{display:none;}

/* Auto default: cards on small screens, table on larger, unless overridden by JS class */
@media(max-width:820px){
  body:not(.mode-table) .view-table{display:none;}
  body:not(.mode-table) .view-grid{display:grid;}
}

/* ---------- Modal ---------- */
.modal-overlay{
  display:none;position:fixed;inset:0;background:rgba(18,35,63,0.55);
  align-items:center;justify-content:center;z-index:999;padding:16px;
}
.modal-overlay.open{display:flex;}
.modal-box{
  background:#fff;border-radius:var(--radius);padding:24px;width:460px;max-width:100%;
  max-height:88vh;overflow-y:auto;box-shadow:0 8px 30px rgba(0,0,0,0.25);
}
.modal-box h3{margin-top:0;color:var(--navy);}
.modal-close{float:right;cursor:pointer;font-size:20px;color:var(--muted);line-height:1;}

/* ---------- Gallery thumbs in dashboard ---------- */
.gallery-thumb-grid{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;}
.gallery-thumb{position:relative;width:110px;}
.gallery-thumb img{width:110px;height:80px;object-fit:cover;border-radius:6px;border:1px solid var(--border);}
.gallery-thumb .tag{font-size:10px;text-transform:uppercase;color:var(--muted);margin-top:3px;text-align:center;}
.gallery-thumb form{position:absolute;top:4px;right:4px;}
.gallery-thumb button{background:rgba(192,57,43,0.9);color:#fff;border:none;border-radius:4px;width:20px;height:20px;font-size:11px;cursor:pointer;line-height:1;}

/* ---------- Responsive tweaks ---------- */
@media(max-width:600px){
  .app-shell{padding:14px;}
  .topbar{padding:14px 16px;flex-direction:column;align-items:flex-start;}
  .card{padding:16px;}
  .filter-bar{flex-direction:column;align-items:stretch;}
  .filter-bar .field{flex:1 1 auto;}
  table.list{font-size:11.5px;}
  table.list th, table.list td{padding:6px;}
}
