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

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

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

/* ============================================
   COMPANY GRID & CARDS
   ============================================ */
.ci-company-grid { display:grid; gap:20px; margin:20px 0; }
.ci-company-grid.ci-cols-2{grid-template-columns:repeat(2,1fr);}
.ci-company-grid.ci-cols-3{grid-template-columns:repeat(3,1fr);}
.ci-company-grid.ci-cols-4{grid-template-columns:repeat(4,1fr);}

.ci-company-card { background:var(--ci-white); border:1px solid var(--ci-border); border-radius:var(--ci-radius); overflow:hidden; display:flex; flex-direction:column; transition:var(--ci-trans); position:relative; }
.ci-company-card:hover { box-shadow:var(--ci-shadow-hov); transform:translateY(-4px); border-color:var(--ci-primary); }
.ci-card-featured { border-color:var(--ci-gold); }
.ci-card-featured::before { content:'⭐ Nổi bật'; position:absolute; top:0; right:0; background:var(--ci-gold); color:#fff; font-size:11px; font-weight:700; padding:3px 10px; border-radius:0 var(--ci-radius) 0 var(--ci-radius-sm); }

.ci-card-top { display:flex; align-items:center; gap:12px; padding:16px 16px 0; text-decoration:none; }
.ci-card-logo { width:64px; height:50px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.ci-card-logo img { max-width:100%; max-height:100%; object-fit:contain; }
.ci-logo-placeholder { width:52px; height:52px; border-radius:10px; background:linear-gradient(135deg,var(--ci-primary),#3b82f6); color:#fff; display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:800; }
.ci-card-header-info { flex:1; display:flex; flex-wrap:wrap; gap:5px; align-items:center; }
.ci-card-type { font-size:11px; background:#eff6ff; border:1px solid #bfdbfe; color:#1d4ed8; padding:2px 8px; border-radius:20px; }
.ci-card-ticker { font-size:11px; background:#fef3c7; border:1px solid #fde68a; color:#92400e; padding:2px 8px; border-radius:20px; font-weight:700; }
.ci-status-dot { width:8px; height:8px; border-radius:50%; display:inline-block; }

.ci-card-body { padding:12px 16px 16px; flex:1; display:flex; flex-direction:column; }
.ci-card-title { font-size:16px; font-weight:700; margin:0 0 6px; line-height:1.3; }
.ci-card-title a { color:var(--ci-text); text-decoration:none; }
.ci-card-title a:hover { color:var(--ci-primary); }
.ci-card-industry { font-size:12px; color:var(--ci-primary); margin-bottom:8px; display:block; }
.ci-card-meta { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.ci-card-meta span { font-size:12px; color:var(--ci-muted); }
.ci-card-btn { display:block; text-align:center; background:var(--ci-primary); color:#fff; padding:9px; border-radius:var(--ci-radius-sm); text-decoration:none; font-size:13px; font-weight:600; margin-top:auto; transition:var(--ci-trans); }
.ci-card-btn:hover { background:var(--ci-primary-dk); color:#fff; }

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

/* ============================================
   LEADERS GRID
   ============================================ */
.ci-leaders-grid { display:grid; gap:16px; margin:20px 0; }
.ci-leaders-grid.ci-cols-4{grid-template-columns:repeat(4,1fr);}
.ci-leaders-grid.ci-cols-3{grid-template-columns:repeat(3,1fr);}
.ci-leader-card { background:var(--ci-white); border:1px solid var(--ci-border); border-radius:var(--ci-radius); overflow:hidden; text-align:center; padding:20px 16px; transition:var(--ci-trans); }
.ci-leader-card:hover { box-shadow:var(--ci-shadow-hov); border-color:var(--ci-primary); }
.ci-leader-avatar { width:80px; height:80px; border-radius:50%; overflow:hidden; margin:0 auto 12px; border:3px solid var(--ci-border); }
.ci-leader-avatar img { width:100%; height:100%; object-fit:cover; }
.ci-avatar-placeholder { width:80px; height:80px; border-radius:50%; background:linear-gradient(135deg,var(--ci-primary),#3b82f6); color:#fff; display:flex; align-items:center; justify-content:center; font-size:28px; font-weight:700; margin:0 auto 12px; }
.ci-leader-name { font-size:15px; font-weight:700; margin:0 0 4px; }
.ci-leader-name a { color:var(--ci-text); text-decoration:none; }
.ci-leader-name a:hover { color:var(--ci-primary); }
.ci-leader-title  { font-size:12px; color:var(--ci-primary); font-weight:600; display:block; margin-bottom:3px; }
.ci-leader-company{ font-size:12px; color:var(--ci-muted); display:block; margin-bottom:8px; }
.ci-leader-linkedin { display:inline-block; background:#0a66c2; color:#fff; padding:3px 10px; border-radius:4px; font-size:12px; font-weight:700; text-decoration:none; }

/* ============================================
   FILTER & SEARCH
   ============================================ */
.ci-filter-bar { display:flex; gap:10px; flex-wrap:wrap; padding:14px 16px; background:var(--ci-white); border:1px solid var(--ci-border); border-radius:var(--ci-radius); margin-bottom:24px; align-items:center; }
.ci-filter-select { flex:1; min-width:140px; padding:9px 12px; border:1px solid var(--ci-border); border-radius:var(--ci-radius-sm); font-size:13px; background:var(--ci-white); cursor:pointer; }
.ci-filter-reset { padding:9px 16px; border:1px solid var(--ci-border); border-radius:var(--ci-radius-sm); background:var(--ci-bg); font-size:13px; cursor:pointer; color:var(--ci-muted); }
.ci-filter-reset:hover { border-color:var(--ci-primary); color:var(--ci-primary); }

.ci-search-wrap { margin:20px 0; }
.ci-search-inner { display:flex; border:2px solid var(--ci-border); border-radius:50px; overflow:hidden; background:var(--ci-white); transition:var(--ci-trans); }
.ci-search-inner:focus-within { border-color:var(--ci-primary); }
.ci-search-input { flex:1; padding:14px 20px; border:none; outline:none; font-size:15px; background:transparent; }
.ci-search-btn { padding:0 20px; background:var(--ci-primary); border:none; color:#fff; cursor:pointer; display:flex; align-items:center; }
.ci-search-btn:hover { background:var(--ci-primary-dk); }

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

/* ============================================
   SINGLE COMPANY — HERO
   ============================================ */
.ci-single-company { background:var(--ci-bg); min-height:100vh; }
.ci-company-hero { background:linear-gradient(135deg,#0f172a,#1e3a5f); color:#fff; padding:40px 0; }
.ci-hero-inner { display:grid; grid-template-columns:1fr 2fr auto; gap:28px; align-items:start; }
.ci-hero-logo { background:rgba(255,255,255,.12); backdrop-filter:blur(10px); border-radius:var(--ci-radius); padding:20px; width:120px; display:flex; align-items:center; justify-content:center; }
.ci-hero-logo img { max-width:100%; max-height:80px; object-fit:contain; }
.ci-logo-lg { width:80px; height:80px; border-radius:14px; background:var(--ci-primary); color:#fff; display:flex; align-items:center; justify-content:center; font-size:28px; font-weight:800; }
.ci-hero-main { flex:1; }
.ci-hero-tags { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:10px; }
.ci-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; }
.ci-tag-type { background:rgba(59,130,246,.3); border-color:rgba(59,130,246,.5); }
.ci-tag-ticker { background:rgba(245,158,11,.3); border-color:rgba(245,158,11,.5); font-weight:700; }
.ci-hero-title { font-size:32px; font-weight:800; margin:0 0 4px; }
.ci-hero-en { font-size:14px; opacity:.7; margin:0 0 6px; }
.ci-hero-slogan { font-size:14px; font-style:italic; opacity:.8; margin:0 0 14px; }
.ci-hero-quick { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:16px; }
.ci-hero-quick span { font-size:13px; opacity:.85; }
.ci-hero-actions { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px; }
.ci-btn-primary { display:inline-block; padding:10px 20px; background:var(--ci-primary); color:#fff; text-decoration:none; border-radius:var(--ci-radius-sm); font-size:13px; font-weight:600; transition:var(--ci-trans); }
.ci-btn-primary:hover { background:var(--ci-primary-dk); color:#fff; }
.ci-btn-secondary { display:inline-block; padding:9px 18px; background:rgba(255,255,255,.12); color:#fff; text-decoration:none; border-radius:var(--ci-radius-sm); font-size:13px; font-weight:500; border:1px solid rgba(255,255,255,.25); transition:var(--ci-trans); }
.ci-btn-secondary:hover { background:rgba(255,255,255,.22); color:#fff; }
.ci-hero-socials { display:flex; flex-wrap:wrap; gap:7px; }
.ci-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(--ci-trans); }
.ci-social-btn:hover { background:rgba(255,255,255,.2); color:#fff; }

/* Finance sidebar */
.ci-hero-finance { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:var(--ci-radius); padding:18px; min-width:200px; }
.ci-hero-finance h3 { font-size:13px; font-weight:700; margin:0 0 12px; opacity:.9; }
.ci-finance-item { display:flex; justify-content:space-between; align-items:center; padding:7px 0; border-bottom:1px solid rgba(255,255,255,.1); font-size:13px; }
.ci-finance-item:last-child { border:none; }
.ci-finance-item span { opacity:.7; }
.ci-finance-item strong { color:#fff; text-align:right; font-size:12px; max-width:110px; }

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

/* MVV cards */
.ci-mvv-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:24px; }
.ci-mvv-card { background:var(--ci-bg); border:1px solid var(--ci-border); border-radius:var(--ci-radius-sm); padding:20px; }
.ci-mvv-full { grid-column:1/-1; }
.ci-mvv-card h3 { font-size:16px; font-weight:700; margin:0 0 10px; }
.ci-mvv-card p { font-size:14px; color:var(--ci-text); line-height:1.7; margin:0; }

/* Operations */
.ci-ops-block { margin-bottom:22px; }
.ci-ops-block h3 { font-size:16px; font-weight:700; margin:0 0 10px; }
.ci-ops-content { font-size:14px; color:var(--ci-text); line-height:1.7; }

/* Stock */
.ci-stock-hero { display:flex; align-items:center; gap:14px; margin-bottom:20px; padding:16px 20px; background:linear-gradient(135deg,#eff6ff,#dbeafe); border-radius:var(--ci-radius); border:1px solid #bfdbfe; }
.ci-stock-ticker { font-size:32px; font-weight:900; color:#1d4ed8; }
.ci-stock-exchange { font-size:14px; color:#3b82f6; font-weight:600; }
.ci-shareholders { font-size:13px; color:var(--ci-text); line-height:1.8; }

/* Awards */
.ci-awards-list { font-size:14px; line-height:2; color:var(--ci-text); }

/* Social list */
.ci-social-list { display:flex; flex-direction:column; gap:8px; }
.ci-social-item { display:flex; align-items:center; gap:10px; padding:10px 14px; background:var(--ci-bg); border-radius:var(--ci-radius-sm); text-decoration:none; color:var(--ci-text); font-size:14px; transition:var(--ci-trans); border:1px solid var(--ci-border); }
.ci-social-item:hover { border-color:var(--ci-primary); color:var(--ci-primary); }

/* Gallery */
.ci-gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.ci-gallery-item { position:relative; aspect-ratio:16/10; border-radius:var(--ci-radius-sm); overflow:hidden; cursor:pointer; }
.ci-gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.ci-gallery-item:hover img { transform:scale(1.08); }
.ci-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; }
.ci-gallery-item:hover .ci-gallery-overlay { opacity:1; }
.ci-video-wrap { position:relative; padding-bottom:56.25%; height:0; }
.ci-video-wrap iframe { position:absolute; inset:0; width:100%; height:100%; border-radius:var(--ci-radius-sm); }
.ci-desc-content { font-size:15px; line-height:1.8; }

/* Leader detail page */
.ci-leader-detail { display:grid; grid-template-columns:240px 1fr; gap:32px; align-items:start; }
.ci-leader-detail-photo img { width:100%; border-radius:var(--ci-radius); }
.ci-avatar-lg { width:200px; height:200px; border-radius:var(--ci-radius); background:linear-gradient(135deg,var(--ci-primary),#3b82f6); color:#fff; display:flex; align-items:center; justify-content:center; font-size:64px; font-weight:800; }
.ci-leader-detail h1 { font-size:28px; font-weight:800; margin:0 0 6px; }
.ci-leader-pos { font-size:16px; color:var(--ci-primary); font-weight:600; margin:0 0 4px; }
.ci-leader-co  { font-size:14px; color:var(--ci-muted); margin:0 0 16px; }

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

/* Lightbox */
.ci-lightbox-overlay { position:fixed; inset:0; background:rgba(0,0,0,.92); z-index:999999; display:flex; align-items:center; justify-content:center; }
.ci-lb-content { max-width:90vw; max-height:90vh; }
.ci-lb-content img { max-width:90vw; max-height:85vh; object-fit:contain; border-radius:var(--ci-radius); }
.ci-lb-close,.ci-lb-prev,.ci-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; }
.ci-lb-close:hover,.ci-lb-prev:hover,.ci-lb-next:hover { background:rgba(255,255,255,.25); }
.ci-lb-close { top:20px; right:20px; }
.ci-lb-prev { left:20px; top:50%; transform:translateY(-50%); }
.ci-lb-next { right:20px; top:50%; transform:translateY(-50%); }

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

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

/* ---- Responsive ---- */
@media(max-width:1024px){
  .ci-hero-inner { grid-template-columns:1fr 1fr; }
  .ci-hero-finance { grid-column:1/-1; }
  .ci-company-grid.ci-cols-4 { grid-template-columns:repeat(3,1fr); }
  .ci-spec-two-col { grid-template-columns:1fr; }
  .ci-mvv-grid { grid-template-columns:1fr; }
  .ci-meta-grid { grid-template-columns:1fr; }
}
@media(max-width:768px){
  .ci-hero-inner { grid-template-columns:1fr; }
  .ci-company-grid.ci-cols-3,.ci-company-grid.ci-cols-4 { grid-template-columns:repeat(2,1fr); }
  .ci-leaders-grid.ci-cols-4 { grid-template-columns:repeat(2,1fr); }
  .ci-industry-grid.ci-cols-4 { grid-template-columns:repeat(2,1fr); }
  .ci-gallery-grid { grid-template-columns:repeat(2,1fr); }
  .ci-hero-title { font-size:24px; }
  .ci-filter-bar { flex-direction:column; }
  .ci-tabs-nav { overflow-x:auto; }
  .ci-leader-detail { grid-template-columns:1fr; }
}
@media(max-width:480px){
  .ci-company-grid.ci-cols-2,.ci-company-grid.ci-cols-3 { grid-template-columns:1fr; }
  .ci-industry-grid { grid-template-columns:1fr; }
  .ci-leaders-grid.ci-cols-4,.ci-leaders-grid.ci-cols-3 { grid-template-columns:repeat(2,1fr); }
}
