/* ============================================================
   peq-components.css — Shared component styles for analysis pages
   Includes: gap-table, benchmark-table, data-table, tooltips,
             info-bubble, demo cards, compa-ratio toggles, tags.
   ============================================================ */

/* --- Gap Summary Table (.gap-tbl) --- */
.gap-tbl{width:100%;border-collapse:collapse;margin-bottom:12px;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.08);}
.gap-tbl th,.gap-tbl td{padding:10px 14px;border:1px solid #dde3e8;}
.gap-tbl thead th{font-size:12px;font-weight:700;text-align:center;letter-spacing:.04em;text-transform:uppercase;color:#fff;}
.gap-tbl .th-pay{background:#012169;}
.gap-tbl .th-bon{background:#1b5e20;}
.gap-tbl .th-ben{background:#4a148c;}
.gap-tbl .th-tr{background:#006064;}
.gap-tbl .row-lbl{font-size:12px;font-weight:700;color:#444;background:#f5f6fa;}
.gap-tbl .gap-cell{text-align:center;background:#fff;position:relative;}
.gap-tbl .gc-val{font-size:20px;font-weight:700;line-height:1;margin-bottom:2px;}
.gap-tbl .gc-badge{display:inline-block;font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px;text-transform:uppercase;background:#e8eaf6;color:#3949ab;margin-left:4px;vertical-align:top;}
.gap-tbl .gc-sub{font-size:10px;color:#999;margin-top:2px;}
.info-bubble{cursor:help;color:#5b7dba;font-size:13px;vertical-align:middle;margin-left:2px;}

/* --- Benchmark Summary Table (.bench-tbl) --- */
.bench-tbl{width:100%;table-layout:fixed;border-collapse:collapse;margin-bottom:8px;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.08);}
.bench-tbl col.bl-col{width:15%;}
.bench-tbl col.data-col{width:21.25%;}
.bench-tbl th,.bench-tbl td{padding:10px 14px;border:1px solid #dde3e8;font-size:12px;}
.bench-tbl thead th{font-weight:700;text-align:center;color:#fff;letter-spacing:.03em;text-transform:uppercase;font-size:12px;}
.bench-tbl .bth-pay{background:#012169;}.bench-tbl .bth-bon{background:#1b5e20;}.bench-tbl .bth-ben{background:#4a148c;}.bench-tbl .bth-tr{background:#006064;}
.bench-tbl .bl-lbl{font-weight:700;font-size:12px;color:#444;background:#f5f6fa;text-align:left !important;}
.bench-tbl td{text-align:center;background:#fff;}

/* --- Data Table (generic) --- */
.data-table{width:100%;border-collapse:collapse;font-size:12px;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.08);border-radius:6px;overflow:hidden;}
.data-table th,.data-table td{padding:6px 10px;border:1px solid #dde3e8;}
.data-table thead th{background:#012169;color:#fff;font-weight:700;text-align:center;font-size:11px;letter-spacing:.03em;text-transform:uppercase;}

/* --- Column Header Tooltip --- */
.th-tip{position:relative;display:inline-block;cursor:help;}
.th-tip .tip-icon{display:inline-flex;align-items:center;justify-content:center;
  width:13px;height:13px;border-radius:50%;background:rgba(255,255,255,0.30);
  color:#fff;font-size:9px;font-weight:700;font-style:normal;
  margin-left:4px;vertical-align:middle;line-height:1;}
.th-tip:hover .tip-box,.th-tip:focus-within .tip-box{display:block;}
.tip-box{display:none;position:absolute;top:calc(100% + 8px);right:-20px;
  width:320px;background:#fff;color:#333;font-size:12px;font-weight:400;
  line-height:1.45;padding:10px 14px;border-radius:6px;border:1px solid #ccc;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
  text-align:left;text-transform:none;letter-spacing:0;white-space:normal;z-index:100;}
.tip-box::after{content:"";position:absolute;bottom:100%;right:26px;
  border:5px solid transparent;border-bottom-color:#fff;}
.tip-box::before{content:"";position:absolute;bottom:100%;right:25px;
  border:6px solid transparent;border-bottom-color:#ccc;}

/* --- Demographics Grid & Cards --- */
.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:8px;}
.demo-card{background:#fff;border:1px solid #e1e4e8;border-radius:6px;padding:20px 22px;}
.demo-card h3{font-size:14px;font-weight:600;margin:0 0 12px;color:#000;}
.demo-card .chart-wrap{position:relative;height:220px;}

/* --- Compa-Ratio Toggle --- */
.cr-toggle{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;}
.cr-toggle button{padding:6px 16px;border:1px solid #c5cae9;border-radius:4px;background:#fff;color:#012169;font-size:12px;font-weight:600;cursor:pointer;}
.cr-toggle button.active{background:#012169;color:#fff;border-color:#012169;}

/* --- Tags (EU / National) --- */
.tag{display:inline-block;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;text-transform:uppercase;margin-left:6px;vertical-align:middle;}
.tag-eu{background:#e8eaf6;color:#3949ab;}
.tag-nat{background:#e8f5e9;color:#2e7d32;}

/* --- Legislation table --- */
.legis-wrap{margin-top:8px;}
.legis-table{width:100%;border-collapse:collapse;font-size:13px;line-height:1.6;}
.legis-table th{background:#012169;color:#fff;padding:8px 12px;text-align:left;font-size:12px;font-weight:600;}
.legis-table td{padding:8px 12px;border-bottom:1px solid #e1e4e8;vertical-align:top;}
.legis-table tr:hover{background:#f5f6fa;}

/* --- OB Decomposition threshold colours --- */
.ob-tbl .ob-red{color:#c62828;font-variant-numeric:tabular-nums;}
.ob-tbl .ob-green{color:#2e7d32;font-variant-numeric:tabular-nums;}
.ob-tbl .ob-amber{color:#b8860b;font-variant-numeric:tabular-nums;}
.ob-tbl .ob-neg{color:#c62828;font-variant-numeric:tabular-nums;}
.ob-tbl .ob-pos{color:#2e7d32;font-variant-numeric:tabular-nums;}
.ob-tbl .ob-zero{color:#888;}

/* --- OB Decomposition Table (full) --- */
.ob-tbl{width:100%;table-layout:fixed;border-collapse:collapse;margin-bottom:8px;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.08);}
.ob-tbl th,.ob-tbl td{padding:10px 14px;border:1px solid #dde3e8;font-size:12px;}
.ob-tbl thead th{font-weight:700;text-align:center;color:#fff;letter-spacing:.03em;text-transform:uppercase;}
.ob-tbl td{text-align:center;background:#fff;font-size:20px;font-weight:700;}
.ob-tbl .ob-lbl{font-weight:700;font-size:12px;color:#444;background:#f5f6fa;text-align:left;}
.ob-tbl .ob-sub-lbl{font-weight:400;font-size:10px;color:#666;background:#f5f6fa;text-align:left;padding-left:28px !important;}
.ob-tbl tr.ob-sub td{font-size:14px;font-weight:400;padding:6px 14px;}
.ob-tbl tr.ob-sub td.ob-sub-lbl{font-size:10px;}
.ob-tbl tr.ob-comment td{background:#f8f9ff;font-size:11px;font-weight:400;color:#444;line-height:1.6;padding:12px 14px;font-style:italic;text-align:left;}

/* --- Effect Bar (regression coefficient visualisation) --- */
.effect-bar{display:inline-block;height:10px;border-radius:3px;vertical-align:middle;margin-left:6px;}

/* --- Regression Grid & Card --- */
.reg-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.reg-card{background:#fff;border:1px solid #e1e4e8;border-radius:6px;padding:24px 28px;}
.reg-card h3{font-size:15px;font-weight:600;margin:0 0 16px;color:#000;}

/* --- Chart Wrapper --- */
.chart-wrap{position:relative;height:280px;}

/* --- Sample Data Banner --- */
.sample-banner{background:#fff3e0;border-left:4px solid #f57c00;padding:12px 16px;border-radius:0 4px 4px 0;font-size:13px;color:#5d3a00;margin-bottom:24px;}
.sample-banner a{color:#e65100;}

/* --- No Data Placeholder --- */
.no-data{text-align:center;padding:32px;color:#888;font-style:italic;font-size:14px;}

/* --- Status Bar (server indicator) --- */
.status-bar{display:flex;align-items:center;gap:12px;padding:6px 0;margin-bottom:16px;font-size:12px;color:#666;}
.status-dot{width:8px;height:8px;border-radius:50%;background:#ccc;flex-shrink:0;}
.status-dot.ok{background:#2e7d32;}
.status-dot.err{background:#c62828;}

/* --- Section Note --- */
.section-note{font-size:12px;color:#888;font-style:italic;margin:-12px 0 16px;}

/* --- GPG Report Action Bar --- */
.gpg-report-bar{margin-top:56px;padding:28px 32px;background:#fff;border:1px solid #dde3e8;border-radius:8px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.gpg-report-bar-text h3{margin:0 0 4px;font-size:17px;font-weight:600;color:#012169;}
.gpg-report-bar-text p{margin:0;font-size:13px;color:#666;max-width:560px;}
.gpg-report-btn{background:#012169;color:#fff;border:none;padding:13px 28px;border-radius:5px;font-size:.92rem;font-weight:600;cursor:pointer;letter-spacing:.02em;white-space:nowrap;box-shadow:0 2px 8px rgba(1,33,105,.22);}
.gpg-report-btn:hover{background:#002580;}
.gpg-report-btn:disabled{background:#999;cursor:not-allowed;}
.gpg-report-progress{font-size:13px;color:#666;margin-top:8px;min-height:20px;}

/* --- Responsive --- */
@media(max-width:900px){
  .demo-grid{grid-template-columns:1fr;}
  .reg-grid{grid-template-columns:1fr;}
}
