/* Scoped styles */
.gg-programs{--ink:#0f172a;--muted:#6b7280;--bg:#f8fafc;--surface:#ffffff;
  --ring: var(--gg-ring, rgba(14,165,233,.25));
  --primary: var(--gg-primary, #6366f1);
  --chip: var(--gg-chip, #eef2ff);
  --shadow:0 10px 30px rgba(2,6,23,.08);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,"Noto Sans Bengali",Arial;color:var(--ink);
  background:linear-gradient(180deg,#fbfdff,#f4f7fb)
}
.ggp-wrap{max-width:1200px;margin:0 auto;padding:32px 16px}
.ggp-head{text-align:center;margin-bottom:18px}
.ggp-kicker{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--primary);background:var(--chip);padding:6px 10px;border-radius:999px}
.ggp-title{margin:10px 0 8px;font-size:32px;line-height:1.15}
.ggp-sub{color:var(--muted);max-width:720px;margin:0 auto 18px}

.ggp-search{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;margin:18px auto 26px}
.ggp-search input[type="search"]{width:min(680px,90%);padding:12px 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;outline:none;
  box-shadow:0 0 0 0 transparent;transition:box-shadow .15s,border-color .15s}
.ggp-search input[type="search"]:focus{border-color:#93c5fd; box-shadow:0 0 0 4px var(--ring)}
.ggp-btn{padding:12px 16px;border-radius:12px;border:1px solid #dbeafe;background:#e0ecff;font-weight:600;cursor:pointer}
.ggp-btn:hover{filter:brightness(.97)}

.ggp-swiper{padding:8px 6px 34px}
.ggp-controls{display:flex;align-items:center;justify-content:space-between;margin-top:6px;gap:12px}
.ggp-nav{display:flex;gap:8px}
.ggp-nav .nav{width:40px;height:40px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow)}
.ggp-nav .nav:disabled{opacity:.35;cursor:not-allowed}
.ggp-pag{flex:1;text-align:center}

.prog-card{background:var(--surface); border:1px solid #eef2f7; border-radius:16px; overflow:hidden; box-shadow:var(--shadow)}
.prog-media{position:relative;aspect-ratio:16/9;background:#e5e7eb}
.prog-media img{width:100%;height:100%;object-fit:cover}
.badge{position:absolute;right:10px;top:10px;background:#10b981;color:#fff;font-size:12px;font-weight:700;padding:6px 8px;border-radius:999px}
.prog-body{padding:14px}
.prog-title{font-size:16px;line-height:1.25;margin:0 0 6px}
.prog-meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:12px;margin-bottom:10px}
.prog-meta .dot{width:4px;height:4px;display:inline-block;background:#cbd5e1;border-radius:50%}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.tag{background:var(--chip);color:#3730a3;font-size:12px;padding:4px 8px;border-radius:999px}
.prog-foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid #eef2f7;padding:10px 14px}
.price{font-weight:800}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:10px;font-weight:700;font-size:12px;border:1px solid #e5e7eb;background:#fff}
.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}

@media (min-width: 1024px){ .ggp-swiper .swiper-slide{width:360px} }
@media (min-width: 768px) and (max-width: 1023.98px){ .ggp-swiper .swiper-slide{width:300px} }
@media (max-width: 767.98px){ .ggp-swiper .swiper-slide{width:86%} }
