/* ============================================
   People Info Plugin — Frontend CSS
   ============================================ */
:root {
  --ppi-primary:    #7c3aed;
  --ppi-primary-dk: #6d28d9;
  --ppi-accent:     #f97316;
  --ppi-gold:       #d97706;
  --ppi-text:       #1e293b;
  --ppi-muted:      #64748b;
  --ppi-border:     #e2e8f0;
  --ppi-bg:         #f8fafc;
  --ppi-white:      #ffffff;
  --ppi-radius:     14px;
  --ppi-radius-sm:  8px;
  --ppi-shadow:     0 2px 12px rgba(0,0,0,.08);
  --ppi-shadow-hov: 0 8px 32px rgba(0,0,0,.14);
  --ppi-trans:      all .25s ease;
}

.ppi-container { max-width:1200px; margin:0 auto; padding:0 20px; }

/* Breadcrumb */
.ppi-breadcrumb { background:var(--ppi-bg); border-bottom:1px solid var(--ppi-border); padding:12px 0; font-size:13px; color:var(--ppi-muted); }
.ppi-breadcrumb a { color:var(--ppi-primary); text-decoration:none; }
.ppi-breadcrumb span { margin:0 6px; }
.ppi-section-title { font-size:24px; font-weight:800; margin:36px 0 20px; padding-bottom:10px; border-bottom:3px solid var(--ppi-primary); display:inline-block; }

/* ============================================
   PEOPLE GRID & CARDS
   ============================================ */
.ppi-people-grid { display:grid; gap:20px; margin:20px 0; }
.ppi-people-grid.ppi-cols-3{grid-template-columns:repeat(3,1fr);}
.ppi-people-grid.ppi-cols-4{grid-template-columns:repeat(4,1fr);}
.ppi-people-grid.ppi-cols-5{grid-template-columns:repeat(5,1fr);}

.ppi-person-card { background:var(--ppi-white); border:1px solid var(--ppi-border); border-radius:var(--ppi-radius); overflow:hidden; display:flex; flex-direction:column; transition:var(--ppi-trans); }
.ppi-person-card:hover { box-shadow:var(--ppi-shadow-hov); transform:translateY(-4px); border-color:var(--ppi-primary); }
.ppi-card-featured { border-color:var(--ppi-gold); }

/* Photo */
.ppi-card-photo-link { display:block; }
.ppi-card-photo { position:relative; height:220px; overflow:hidden; background:linear-gradient(135deg,#f3e8ff,#ede9fe); display:flex; align-items:center; justify-content:center; }
.ppi-card-photo img { width:100%; height:100%; object-fit:cover; object-position:top; transition:transform .4s; }
.ppi-person-card:hover .ppi-card-photo img { transform:scale(1.05); }
.ppi-avatar-placeholder { width:100px; height:100px; border-radius:50%; background:linear-gradient(135deg,var(--ppi-primary),#a78bfa); color:#fff; display:flex; align-items:center; justify-content:center; font-size:40px; font-weight:800; }
.ppi-deceased-badge { position:absolute; top:8px; right:8px; background:rgba(0,0,0,.5); color:#fff; font-size:18px; width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.ppi-verified-badge { position:absolute; bottom:8px; right:8px; background:#2563eb; color:#fff; font-size:11px; font-weight:700; padding:2px 8px; border-radius:20px; }

/* Card body */
.ppi-card-body { padding:14px 16px 16px; flex:1; display:flex; flex-direction:column; }
.ppi-card-name { font-size:16px; font-weight:800; margin:0 0 3px; }
.ppi-card-name a { color:var(--ppi-text); text-decoration:none; }
.ppi-card-name a:hover { color:var(--ppi-primary); }
.ppi-card-other { font-size:12px; color:var(--ppi-muted); font-style:italic; display:block; margin-bottom:5px; }
.ppi-card-field { font-size:12px; color:var(--ppi-primary); font-weight:600; display:block; margin-bottom:3px; }
.ppi-card-profession { font-size:12px; color:var(--ppi-muted); display:block; margin-bottom:8px; }
.ppi-card-meta { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:8px; }
.ppi-card-meta span { font-size:11px; color:var(--ppi-muted); }
.ppi-card-summary { font-size:12px; color:var(--ppi-muted); line-height:1.5; margin:0 0 10px; flex:1; }
.ppi-card-btn { display:block; text-align:center; background:var(--ppi-primary); color:#fff; padding:9px; border-radius:var(--ppi-radius-sm); text-decoration:none; font-size:13px; font-weight:600; margin-top:auto; transition:var(--ppi-trans); }
.ppi-card-btn:hover { background:var(--ppi-primary-dk); color:#fff; }

/* ============================================
   FIELDS GRID
   ============================================ */
.ppi-fields-grid { display:grid; gap:14px; margin:20px 0; }
.ppi-fields-grid.ppi-cols-4{grid-template-columns:repeat(4,1fr);}
.ppi-field-card { display:flex; flex-direction:column; align-items:center; gap:8px; padding:22px 14px; background:var(--ppi-white); border:1px solid var(--ppi-border); border-radius:var(--ppi-radius); text-decoration:none; color:var(--ppi-text); text-align:center; transition:var(--ppi-trans); }
.ppi-field-card:hover { border-color:var(--ppi-primary); box-shadow:var(--ppi-shadow-hov); transform:translateY(-3px); }
.ppi-field-icon { font-size:36px; }
.ppi-field-name { font-size:14px; font-weight:700; }
.ppi-field-count { font-size:12px; color:var(--ppi-primary); font-weight:600; }

/* Filter + Search */
.ppi-filter-bar { display:flex; gap:10px; flex-wrap:wrap; padding:14px 16px; background:var(--ppi-white); border:1px solid var(--ppi-border); border-radius:var(--ppi-radius); margin-bottom:24px; align-items:center; }
.ppi-filter-select { flex:1; min-width:140px; padding:9px 12px; border:1px solid var(--ppi-border); border-radius:var(--ppi-radius-sm); font-size:13px; background:var(--ppi-white); cursor:pointer; }
.ppi-filter-reset { padding:9px 16px; border:1px solid var(--ppi-border); border-radius:var(--ppi-radius-sm); background:var(--ppi-bg); font-size:13px; cursor:pointer; color:var(--ppi-muted); }
.ppi-filter-reset:hover { border-color:var(--ppi-primary); color:var(--ppi-primary); }
.ppi-search-wrap { margin:20px 0; }
.ppi-search-inner { display:flex; border:2px solid var(--ppi-border); border-radius:50px; overflow:hidden; background:var(--ppi-white); transition:var(--ppi-trans); }
.ppi-search-inner:focus-within { border-color:var(--ppi-primary); }
.ppi-search-input { flex:1; padding:14px 20px; border:none; outline:none; font-size:15px; background:transparent; }
.ppi-search-btn { padding:0 20px; background:var(--ppi-primary); border:none; color:#fff; cursor:pointer; display:flex; align-items:center; }

/* Pagination */
.ppi-pagination { margin:30px 0; text-align:center; }
.ppi-pagination .page-numbers { display:inline-block; padding:8px 14px; margin:0 3px; border:1px solid var(--ppi-border); border-radius:var(--ppi-radius-sm); color:var(--ppi-text); text-decoration:none; font-size:14px; }
.ppi-pagination .page-numbers.current { background:var(--ppi-primary); color:#fff; border-color:var(--ppi-primary); }
.ppi-pagination .page-numbers:hover:not(.current) { border-color:var(--ppi-primary); color:var(--ppi-primary); }

/* ============================================
   SINGLE PERSON — HERO
   ============================================ */
.ppi-single-person { background:var(--ppi-bg); min-height:100vh; }
.ppi-person-hero { background:linear-gradient(135deg,#2e1065,#4c1d95,#6d28d9); color:#fff; padding:44px 0; }
.ppi-hero-inner { display:grid; grid-template-columns:260px 1fr auto; gap:32px; align-items:start; }

/* Photo */
.ppi-hero-photo { position:relative; }
.ppi-hero-photo img { width:240px; height:300px; object-fit:cover; object-position:top; border-radius:var(--ppi-radius); border:4px solid rgba(255,255,255,.2); display:block; }
.ppi-avatar-lg { width:240px; height:300px; border-radius:var(--ppi-radius); background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,.1)); display:flex; align-items:center; justify-content:center; font-size:80px; font-weight:800; color:#fff; }
.ppi-verified-stamp { position:absolute; bottom:-10px; left:50%; transform:translateX(-50%); background:#2563eb; color:#fff; font-size:11px; font-weight:700; padding:4px 14px; border-radius:20px; white-space:nowrap; }

/* Hero info */
.ppi-hero-tags { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:12px; }
.ppi-tag { padding:4px 12px; border-radius:20px; font-size:12px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); color:#fff; text-decoration:none; }
.ppi-tag-field { background:rgba(167,139,250,.3); border-color:rgba(167,139,250,.5); }
.ppi-tag-featured { background:rgba(217,119,6,.3); border-color:rgba(217,119,6,.5); }
.ppi-hero-name { font-size:36px; font-weight:900; margin:0 0 4px; display:flex; align-items:center; gap:10px; }
.ppi-verified-icon { font-size:20px; background:#2563eb; border-radius:50%; width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0; }
.ppi-hero-other { font-size:14px; opacity:.75; font-style:italic; margin:0 0 4px; }
.ppi-hero-profession { font-size:15px; opacity:.85; margin:0 0 16px; font-weight:500; }
.ppi-hero-quick { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:16px; }
.ppi-qi { display:flex; align-items:center; gap:9px; background:rgba(255,255,255,.08); border-radius:var(--ppi-radius-sm); padding:10px 12px; }
.ppi-qi span { font-size:20px; }
.ppi-qi small { font-size:10px; opacity:.7; display:block; }
.ppi-qi strong { font-size:13px; display:block; }
.ppi-qi-full { grid-column:1/-1; }
.ppi-hero-summary { font-size:14px; opacity:.85; line-height:1.7; margin-bottom:14px; border-left:3px solid rgba(255,255,255,.3); padding-left:12px; }
.ppi-hero-companies { display:flex; flex-wrap:wrap; gap:7px; align-items:center; margin-bottom:12px; }
.ppi-companies-label { font-size:12px; opacity:.7; }
.ppi-company-link { display:inline-block; padding:3px 12px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); border-radius:20px; color:#fff; text-decoration:none; font-size:12px; font-weight:600; transition:var(--ppi-trans); }
.ppi-company-link:hover { background:rgba(255,255,255,.22); color:#fff; }
.ppi-company-plain { opacity:.8; }
.ppi-hero-socials { display:flex; flex-wrap:wrap; gap:7px; }
.ppi-social-btn { display:inline-flex; align-items:center; gap:5px; padding:5px 12px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); color:#fff; text-decoration:none; border-radius:20px; font-size:12px; transition:var(--ppi-trans); }
.ppi-social-btn:hover { background:rgba(255,255,255,.2); color:#fff; }

/* Stats sidebar */
.ppi-hero-stats { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:var(--ppi-radius); padding:18px; min-width:180px; }
.ppi-hero-stats h3 { font-size:13px; font-weight:700; margin:0 0 12px; opacity:.9; }
.ppi-stat-item { padding:8px 0; border-bottom:1px solid rgba(255,255,255,.1); font-size:12px; }
.ppi-stat-item:last-child { border:none; }
.ppi-stat-item span { opacity:.7; display:block; }
.ppi-stat-item strong { color:#fff; font-size:13px; }

/* ============================================
   TABS
   ============================================ */
.ppi-tabs-wrap { margin:36px 0; }
.ppi-tabs-nav { display:flex; gap:2px; border-bottom:2px solid var(--ppi-border); flex-wrap:wrap; }
.ppi-tab-nav { padding:11px 16px; border:none; background:transparent; cursor:pointer; font-size:13px; font-weight:500; color:var(--ppi-muted); border-bottom:3px solid transparent; margin-bottom:-2px; transition:var(--ppi-trans); white-space:nowrap; }
.ppi-tab-nav:hover { color:var(--ppi-primary); }
.ppi-tab-nav.active { color:var(--ppi-primary); border-bottom-color:var(--ppi-primary); }
.ppi-tab-panel { display:none; padding:28px; background:var(--ppi-white); border:1px solid var(--ppi-border); border-top:none; border-radius:0 0 var(--ppi-radius) var(--ppi-radius); }
.ppi-tab-panel.active { display:block; }
.ppi-spec-heading { font-size:17px; font-weight:700; margin:0 0 14px; color:var(--ppi-text); }
.ppi-spec-table { width:100%; border-collapse:collapse; }
.ppi-spec-table th,.ppi-spec-table td { padding:11px 14px; text-align:left; border-bottom:1px solid var(--ppi-border); font-size:14px; }
.ppi-spec-table th { color:var(--ppi-muted); font-weight:500; width:200px; background:var(--ppi-bg); }
.ppi-spec-table td { font-weight:500; color:var(--ppi-text); }
.ppi-spec-table tr:last-child th,.ppi-spec-table tr:last-child td { border-bottom:none; }
.ppi-spec-two-col { display:grid; grid-template-columns:1fr 1fr; gap:28px; }

/* Bio blocks */
.ppi-bio-block { margin-bottom:22px; }
.ppi-bio-block h3 { font-size:16px; font-weight:700; margin:0 0 10px; border-left:3px solid var(--ppi-primary); padding-left:10px; }
.ppi-bio-block div,.ppi-bio-block p { font-size:14px; line-height:1.8; color:var(--ppi-text); margin:0; }
.ppi-desc-content { font-size:15px; line-height:1.8; }

/* Timeline */
.ppi-timeline { margin:24px 0; }
.ppi-timeline h3 { font-size:16px; font-weight:700; margin:0 0 16px; }
.ppi-timeline-list { display:flex; flex-direction:column; gap:0; }
.ppi-timeline-item { display:flex; gap:16px; align-items:flex-start; padding:12px 0; border-bottom:1px solid var(--ppi-border); position:relative; }
.ppi-timeline-item:last-child { border-bottom:none; }
.ppi-timeline-year { font-size:13px; font-weight:800; color:var(--ppi-primary); min-width:60px; flex-shrink:0; padding-top:1px; }
.ppi-timeline-text { font-size:14px; color:var(--ppi-text); line-height:1.5; }
.ppi-timeline-full { font-size:14px; color:var(--ppi-text); }

/* Quotes */
.ppi-quotes { margin:24px 0; }
.ppi-quote { background:linear-gradient(135deg,#faf5ff,#ede9fe); border-left:4px solid var(--ppi-primary); border-radius:0 var(--ppi-radius-sm) var(--ppi-radius-sm) 0; padding:16px 20px; margin:0 0 12px; font-size:15px; font-style:italic; color:var(--ppi-text); line-height:1.7; }

/* Awards & Rankings */
.ppi-awards-list { font-size:14px; line-height:2; color:var(--ppi-text); }
.ppi-rankings-list { display:flex; flex-direction:column; gap:8px; }
.ppi-ranking-item { padding:10px 14px; background:linear-gradient(135deg,#fef3c7,#fffbeb); border:1px solid #fde68a; border-radius:var(--ppi-radius-sm); font-size:13px; font-weight:600; color:#92400e; }

/* Linked companies */
.ppi-linked-companies { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:20px; }
.ppi-linked-co { }
.ppi-co-name { display:block; padding:12px 16px; background:var(--ppi-bg); border:1px solid var(--ppi-border); border-radius:var(--ppi-radius-sm); font-size:14px; font-weight:600; color:var(--ppi-text); text-decoration:none; transition:var(--ppi-trans); }
a.ppi-co-name:hover { border-color:var(--ppi-primary); color:var(--ppi-primary); background:#eff6ff; }
.ppi-co-nolink { opacity:.7; }

/* Gallery */
.ppi-gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.ppi-gallery-item { position:relative; aspect-ratio:1; border-radius:var(--ppi-radius-sm); overflow:hidden; cursor:pointer; }
.ppi-gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.ppi-gallery-item:hover img { transform:scale(1.08); }
.ppi-gallery-overlay { position:absolute; inset:0; background:rgba(0,0,0,.4); display:flex; align-items:center; justify-content:center; font-size:24px; opacity:0; transition:opacity .3s; }
.ppi-gallery-item:hover .ppi-gallery-overlay { opacity:1; }
.ppi-video-wrap { position:relative; padding-bottom:56.25%; height:0; }
.ppi-video-wrap iframe { position:absolute; inset:0; width:100%; height:100%; border-radius:var(--ppi-radius-sm); }
.ppi-no-content { color:var(--ppi-muted); }

/* Archive */
.ppi-archive-header { background:linear-gradient(135deg,#2e1065,#4c1d95,#6d28d9); color:#fff; padding:38px 0; }
.ppi-archive-tax-label { display:inline-block; background:rgba(255,255,255,.15); padding:3px 12px; border-radius:20px; font-size:12px; margin-bottom:8px; }
.ppi-archive-title { font-size:30px; font-weight:800; margin:0 0 8px; }
.ppi-archive-count { font-size:13px; opacity:.7; }

/* Meta grid */
.ppi-meta-grid { display:grid; grid-template-columns:1fr 1fr; gap:0 20px; }
.ppi-meta-grid p { margin:0 0 10px; }
.ppi-meta-grid p.ppi-full { grid-column:1/-1; }

/* Lightbox */
.ppi-lightbox-overlay { position:fixed; inset:0; background:rgba(0,0,0,.92); z-index:999999; display:flex; align-items:center; justify-content:center; }
.ppi-lb-content { max-width:90vw; max-height:90vh; }
.ppi-lb-content img { max-width:90vw; max-height:85vh; object-fit:contain; border-radius:var(--ppi-radius); }
.ppi-lb-close,.ppi-lb-prev,.ppi-lb-next { position:absolute; background:rgba(255,255,255,.12); border:none; color:#fff; font-size:28px; cursor:pointer; width:48px; height:48px; display:flex; align-items:center; justify-content:center; border-radius:50%; transition:background .2s; }
.ppi-lb-close:hover,.ppi-lb-prev:hover,.ppi-lb-next:hover { background:rgba(255,255,255,.25); }
.ppi-lb-close { top:20px; right:20px; }
.ppi-lb-prev { left:20px; top:50%; transform:translateY(-50%); }
.ppi-lb-next { right:20px; top:50%; transform:translateY(-50%); }

/* Misc */
.ppi-no-results { color:var(--ppi-muted); text-align:center; padding:28px; }
.ppi-no-results-large { text-align:center; padding:60px 20px; }
.ppi-related { margin:38px 0; }
.ppi-featured-section { margin:28px 0; }

/* ---- Responsive ---- */
@media(max-width:1024px){
  .ppi-hero-inner { grid-template-columns:200px 1fr; }
  .ppi-hero-stats { grid-column:1/-1; display:flex; flex-wrap:wrap; gap:10px; }
  .ppi-hero-stats h3 { width:100%; }
  .ppi-stat-item { flex:1; min-width:120px; border:1px solid rgba(255,255,255,.1); border-radius:var(--ppi-radius-sm); padding:8px 12px; }
  .ppi-people-grid.ppi-cols-4,.ppi-people-grid.ppi-cols-5 { grid-template-columns:repeat(3,1fr); }
  .ppi-spec-two-col { grid-template-columns:1fr; }
  .ppi-linked-companies { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:768px){
  .ppi-hero-inner { grid-template-columns:1fr; }
  .ppi-hero-photo img,.ppi-avatar-lg { width:160px; height:200px; margin:0 auto; }
  .ppi-people-grid.ppi-cols-3,.ppi-people-grid.ppi-cols-4 { grid-template-columns:repeat(2,1fr); }
  .ppi-fields-grid.ppi-cols-4 { grid-template-columns:repeat(2,1fr); }
  .ppi-hero-quick { grid-template-columns:1fr; }
  .ppi-gallery-grid { grid-template-columns:repeat(2,1fr); }
  .ppi-filter-bar { flex-direction:column; }
  .ppi-tabs-nav { overflow-x:auto; }
  .ppi-meta-grid { grid-template-columns:1fr; }
}
@media(max-width:480px){
  .ppi-people-grid.ppi-cols-2,.ppi-people-grid.ppi-cols-3 { grid-template-columns:1fr; }
  .ppi-linked-companies { grid-template-columns:1fr; }
}
