/* ══════════════════════════════════════════════════════════════
   imt-events.css — CSS untuk halaman listing IMT portal
   Diekstrak dari native event_pelatihan.php, event_mooc.php,
   event_self_learning.php, event_corpu.php
   Seluruh style persis seperti native tanpa perubahan.
══════════════════════════════════════════════════════════════ */

:root {
  --ec-navy: #1B2C5D;
  --ec-gold: #FFCB05;
  --ec-bg: #F5F7FB;
  --ec-muted: #6B7280;
  --ec-border: #E5E7EB;
  --ec-radius: .875rem;
  --ec-shadow: 0 4px 20px rgba(27,44,93,.10);
  --ec-ease: .25s cubic-bezier(.4,0,.2,1);
}

/* ─── Container ────────────────────────────────────────────── */
.ec-container { max-width:1200px; margin:0 auto; padding:0 20px; }

/* ─── HERO ──────────────────────────────────────────────────── */
.ec-hero {
  background: linear-gradient(135deg, #1B2C5D 0%, #0d1e4a 55%, #162454 100%);
  position: relative; overflow: hidden; padding: 72px 0 56px;
}
.ec-hero::before {
  content:''; position:absolute; width:560px; height:560px; border-radius:50%;
  background:radial-gradient(circle,rgba(255,203,5,.13) 0%,transparent 70%);
  top:-180px; right:-120px; pointer-events:none;
}
.ec-hero::after {
  content:''; position:absolute; width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle,rgba(255,203,5,.08) 0%,transparent 70%);
  bottom:-100px; left:-60px; pointer-events:none;
}
.ec-hero-dots {
  position:absolute; inset:0; pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.055) 1px,transparent 1px);
  background-size:28px 28px;
}
.ec-hero-title {
  font-family:'Lora',serif; font-size:clamp(1.85rem,4.5vw,3rem);
  font-weight:700; color:#fff; line-height:1.2; margin-bottom:16px;
}
.ec-hero-title span { color:var(--ec-gold); }
.ec-hero-subtitle {
  color:#B8C4D8; font-size:1rem; max-width:540px; margin:0 auto 40px; line-height:1.75;
}

/* Stats */
.ec-stats-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:14px; max-width:800px; margin:0 auto;
}
@media(min-width:768px) { .ec-stats-grid { grid-template-columns:repeat(4,1fr); } }
.ec-stat-card {
  background:rgba(255,255,255,.10); backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,.14);
  border-radius:14px; padding:22px 14px; text-align:center; cursor:default;
  transition:background var(--ec-ease),transform var(--ec-ease);
}
.ec-stat-card:hover { background:rgba(255,255,255,.18); transform:translateY(-4px); }
.ec-stat-icon { font-size:1.3rem; color:rgba(255,203,5,.55); margin-bottom:10px; }
.ec-stat-number {
  font-family:'Lora',serif; font-size:clamp(1.6rem,3.5vw,2.2rem);
  font-weight:700; color:var(--ec-gold); line-height:1; margin-bottom:8px;
}
.ec-stat-label { color:#D1D9E6; font-size:.78rem; font-weight:500; line-height:1.4; }

/* ─── Filter Bar ────────────────────────────────────────────── */
.ec-filter-bar {
  background:#fff; border-bottom:1px solid var(--ec-border);
  padding:14px 0; position:sticky; top:0; z-index:100;
  box-shadow:0 2px 10px rgba(0,0,0,.05);
}
.ec-filter-row { display:flex; flex-wrap:wrap; align-items:center; gap:8px; }
.ec-search-wrap { position:relative; flex:1; min-width:180px; }
.ec-search-icon {
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  color:var(--ec-muted); font-size:.85rem; pointer-events:none;
}
.ec-search-input {
  width:100%; padding:9px 12px 9px 34px;
  border:1.5px solid var(--ec-border); border-radius:9px;
  font-size:.875rem; outline:none; background:#fff; color:#1F2937;
  transition:border-color var(--ec-ease),box-shadow var(--ec-ease);
}
.ec-search-input:focus { border-color:var(--ec-navy); box-shadow:0 0 0 3px rgba(27,44,93,.11); }
.ec-filter-select {
  padding:9px 12px; border:1.5px solid var(--ec-border); border-radius:9px;
  font-size:.85rem; outline:none; background:#fff; color:#374151;
  cursor:pointer; min-width:120px; transition:border-color var(--ec-ease);
}
.ec-filter-select:focus { border-color:var(--ec-navy); }
.ec-btn-reset {
  padding:9px 16px; border:1.5px solid var(--ec-border); border-radius:9px;
  background:#fff; font-size:.85rem; color:var(--ec-muted); cursor:pointer;
  white-space:nowrap; transition:border-color var(--ec-ease),color var(--ec-ease);
}
.ec-btn-reset:hover { border-color:var(--ec-navy); color:var(--ec-navy); }
.ec-view-toggle-group {
  display:flex; gap:3px; background:var(--ec-bg); padding:3px;
  border-radius:9px; border:1px solid var(--ec-border); margin-left:auto;
}
.ec-view-btn {
  padding:6px 10px; border:none; background:transparent; border-radius:6px;
  cursor:pointer; color:var(--ec-muted); font-size:.9rem;
  transition:background var(--ec-ease),color var(--ec-ease);
}
.ec-view-btn.active { background:var(--ec-navy); color:#fff; }
.ec-active-filters { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.ec-filter-tag {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(27,44,93,.07); border:1px solid rgba(27,44,93,.18);
  color:var(--ec-navy); font-size:.75rem; font-weight:600;
  padding:4px 10px; border-radius:999px; cursor:pointer;
  transition:background var(--ec-ease);
}
.ec-filter-tag:hover { background:rgba(27,44,93,.14); }

/* ─── Main Section ──────────────────────────────────────────── */
.ec-main-section { padding:36px 0 60px; background:var(--ec-bg); }
.ec-results-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
.ec-results-count { font-size:.9rem; color:var(--ec-muted); margin:0; }
.ec-results-count strong { color:#1F2937; }

/* ─── Grid ──────────────────────────────────────────────────── */
.ec-events-grid { display:grid; grid-template-columns:1fr; gap:22px; }
@media(min-width:600px) { .ec-events-grid { grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px) { .ec-events-grid { grid-template-columns:repeat(3,1fr); } }

.ec-card {
  background:#fff; border-radius:var(--ec-radius);
  border:1px solid var(--ec-border); box-shadow:var(--ec-shadow);
  overflow:hidden; display:flex; flex-direction:column;
  transition:box-shadow var(--ec-ease),transform var(--ec-ease);
}
.ec-card:hover { box-shadow:0 8px 32px rgba(27,44,93,.16); transform:translateY(-3px); }

.ec-card-img {
  position:relative; height:190px; overflow:hidden; flex-shrink:0;
  background:linear-gradient(135deg,#1B2C5D 0%,#243870 100%);
}
.ec-card-img::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(27,44,93,.45) 0%,transparent 55%);
}
.ec-img-placeholder {
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  font-size:2.5rem; color:rgba(255,203,5,.4); overflow:hidden; position:relative;
}
.ec-img-placeholder img {
  width:100%; height:100%; object-fit:cover; object-position:center;
  position:absolute; top:0; left:0;
}

.ec-status-badge {
  position:absolute; top:12px; right:12px; z-index:2;
  padding:3px 10px; border-radius:999px; font-size:.68rem; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase;
}
.ec-status-upcoming { background:#DBEAFE; color:#1D4ED8; }
.ec-status-ongoing  { background:#D1FAE5; color:#065F46; }
.ec-status-ended    { background:#F3F4F6; color:#6B7280; }

.ec-featured-badge {
  position:absolute; top:12px; left:12px; z-index:2;
  background:var(--ec-gold); color:#1B2C5D;
  font-size:.67rem; font-weight:700; padding:3px 10px;
  border-radius:999px; text-transform:uppercase; letter-spacing:.05em;
}

.ec-card-body { padding:18px; display:flex; flex-direction:column; flex:1; }
.ec-chips { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:9px; }
.ec-chip {
  font-size:.7rem; font-weight:600; padding:3px 8px; border-radius:5px;
  text-decoration:none; transition:opacity var(--ec-ease);
}
.ec-chip:hover { opacity:.72; text-decoration:none; }
.ec-card-title {
  font-family:'Lora',serif; font-size:1rem; font-weight:700; color:#111827;
  line-height:1.35; margin-bottom:8px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden; text-decoration:none; transition:color var(--ec-ease);
}
.ec-card-title:hover { color:var(--ec-navy); text-decoration:none; }
.ec-card-desc {
  font-size:.83rem; color:var(--ec-muted); line-height:1.65; margin-bottom:14px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
  overflow:hidden; flex:1;
}
.ec-meta { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.ec-meta-item { display:flex; align-items:center; gap:7px; font-size:.78rem; color:#4B5563; }
.ec-meta-item i { width:14px; text-align:center; color:var(--ec-navy); flex-shrink:0; font-size:.8rem; }
.ec-card-footer {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:13px; border-top:1px solid var(--ec-border);
}
.ec-participants { display:flex; align-items:center; gap:5px; font-size:.78rem; color:var(--ec-muted); }
.ec-participants i { color:var(--ec-navy); font-size:.8rem; }
.ec-btn-daftar {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--ec-navy); color:#fff !important;
  font-size:.8rem; font-weight:600; padding:7px 14px; border-radius:7px;
  text-decoration:none !important; border:none; cursor:pointer;
  transition:background var(--ec-ease),transform var(--ec-ease);
}
.ec-btn-daftar:hover { background:var(--ec-gold); color:var(--ec-navy) !important; transform:translateY(-1px); text-decoration:none !important; }
.ec-btn-ended { background:#9CA3AF; }
.ec-btn-ended:hover { background:#6B7280; color:#fff !important; }

/* ─── List View ─────────────────────────────────────────────── */
.ec-events-list { flex-direction:column; gap:14px; }
.ec-list-card {
  background:#fff; border-radius:var(--ec-radius); border:1px solid var(--ec-border);
  box-shadow:var(--ec-shadow); display:flex; overflow:hidden;
  transition:box-shadow var(--ec-ease),transform var(--ec-ease);
}
.ec-list-card:hover { box-shadow:0 6px 26px rgba(27,44,93,.14); transform:translateX(3px); }
.ec-list-img {
  width:210px; min-height:150px; flex-shrink:0; position:relative;
  background:linear-gradient(135deg,#1B2C5D 0%,#243870 100%); overflow:hidden;
}
.ec-list-img::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to right,transparent 60%,rgba(27,44,93,.3) 100%);
}
.ec-list-body { padding:18px 22px; display:flex; flex-direction:column; gap:10px; flex:1; }
.ec-list-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.ec-list-desc { font-size:.83rem; color:var(--ec-muted); line-height:1.65; margin:0; }
.ec-list-meta { display:grid; grid-template-columns:repeat(2,1fr); gap:6px; }
@media(min-width:768px) { .ec-list-meta { grid-template-columns:repeat(4,1fr); } }
@media(max-width:600px) {
  .ec-list-card { flex-direction:column; }
  .ec-list-img { width:100%; height:160px; min-height:unset; }
  .ec-list-body { padding:15px; }
}

/* ─── Empty State ───────────────────────────────────────────── */
.ec-empty-state { text-align:center; padding:72px 20px; }
.ec-empty-icon {
  width:72px; height:72px; border-radius:50%; background:rgba(27,44,93,.07);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 18px; font-size:1.8rem; color:var(--ec-navy); opacity:.5;
}
.ec-empty-state h3 { font-family:'Lora',serif; font-size:1.15rem; color:#111827; margin-bottom:8px; }
.ec-empty-state p { color:var(--ec-muted); font-size:.88rem; margin-bottom:18px; }

/* ─── Pagination ────────────────────────────────────────────── */
.ec-pagination { display:flex; align-items:center; justify-content:center; gap:5px; margin-top:40px; flex-wrap:wrap; }
.ec-page-btn {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:36px; height:36px; border-radius:8px; border:1.5px solid var(--ec-border);
  background:#fff; font-size:.85rem; font-weight:500; color:#374151;
  cursor:pointer; text-decoration:none; transition:all var(--ec-ease); padding:0 8px;
}
.ec-page-btn:hover { border-color:var(--ec-navy); color:var(--ec-navy); text-decoration:none; }
.ec-page-btn.active { background:var(--ec-navy); border-color:var(--ec-navy); color:#fff; }
.ec-page-btn.disabled { opacity:.38; pointer-events:none; }

/* ─── Reveal Animation ──────────────────────────────────────── */
.ec-reveal { opacity:0; transform:translateY(18px); transition:opacity .5s ease,transform .5s ease; }
.ec-reveal.visible { opacity:1; transform:translateY(0); }

/* ─── Responsive ────────────────────────────────────────────── */
@media(max-width:768px) {
  .ec-filter-select { min-width:unset; width:100%; }
  .ec-search-wrap { min-width:100%; }
  .ec-view-toggle-group { margin-left:0; }
}
