/* ========================= */
/* GLOBAL RESET */
/* ========================= */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* ========================= */
/* BODY */
/* ========================= */

body {
  font-family: Arial, Helvetica, sans-serif;
  background-color: #f8f9fa;
  color: #212529;
  overflow-x: hidden;
  line-height: 1.6;
}

/* ========================= */
/* LINKS */
/* ========================= */

a {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

/* ========================= */
/* NAVBAR */
/* ========================= */

.navbar {
  padding-top: 2px;
  padding-bottom: 2px;
  min-height: auto;
}

.navbar-brand {
  padding-top: 0;
  padding-bottom: 0;
  margin-right: 1rem;
}

.navbar-logo {
  height: 60px;
  width: auto;
  display: block;
}
.nav-link {
  font-size: 0.95rem;
  font-weight: 600;
  padding-left: 0.55rem !important;
  padding-right: 0.55rem !important;
  transition: 0.3s;
}

.nav-link:hover {
  color: #ffc107 !important;
}

/* Public site pink gradient navbar */
.navbar-pink {
  background: linear-gradient(90deg, #f1a7c1 0%, #e3749d 50%, #c53263 100%);
  box-shadow: 0 2px 16px rgba(197, 50, 99, 0.18);
}

.navbar-pink .navbar-brand,
.navbar-pink .nav-link {
  color: #ffffff !important;
}

.navbar-pink .nav-link:hover,
.navbar-pink .nav-link.active {
  color: #ffe082 !important;
}

/* ========================= */
/* HERO SECTION */
/* ========================= */

.hero-section {
  min-height: 90vh;
  background:
    linear-gradient(
      rgba(0, 0, 0, 0.65),
      rgba(0, 0, 0, 0.65)
    ),
    url("https://images.unsplash.com/photo-1584515933487-779824d29309?q=80&w=1400&auto=format&fit=crop")
    center/cover no-repeat;

  padding-top: 80px;
  padding-bottom: 80px;
}

.hero-tagline {
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
  color: #ffc107;
  font-weight: 600;
}

.hero-title {
  font-size: 2.7rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 20px;
}

.hero-description {
  font-size: 1.05rem;
  max-width: 650px;
  margin-bottom: 30px;
  color: #f1f1f1;
}

/* ========================= */
/* BUTTONS */
/* ========================= */

.btn {
  border-radius: 10px;
  padding: 12px 24px;
  font-weight: 600;
  transition: all 0.3s ease;
}

.btn:hover {
  transform: translateY(-2px);
}

.btn-primary {
  background: linear-gradient(90deg, #e3749d, #c53263);
  border-color: #c53263;
}

.btn-primary:hover {
  background: linear-gradient(90deg, #c53263, #ad2554);
  border-color: #ad2554;
}

/* Keep existing emphasis for these */
.btn-success,
.btn-outline-primary {
  font-weight: 600;
}

/* ========================= */
/* SECTIONS */
/* ========================= */

section {
  overflow: hidden;
}

.section-title {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 12px;
}

.section-description {
  color: #6c757d;
  max-width: 700px;
  margin: auto;
}

/* ========================= */
/* FEATURE CARDS */
/* ========================= */

.feature-card {
  border-radius: 18px;
  transition: 0.3s ease;
}

.feature-card:hover {
  transform: translateY(-6px);
}

.feature-icon {
  width: 80px;
  height: 80px;
  margin: auto;
  border-radius: 50%;
  background: linear-gradient(135deg, #e3749d, #c53263);
  display: flex;
  align-items: center;
  justify-content: center;
}

.feature-icon i {
  font-size: 2rem;
  color: white;
}

/* Doctor page specific icon sizing */
.feature-icon.flex-shrink-0 {
  width: 64px;
  height: 64px;
}

.feature-icon.flex-shrink-0 i {
  font-size: 1.5rem;
}

/* ========================= */
/* NEWS CARDS */
/* ========================= */

.news-card {
  border-radius: 18px;
  transition: 0.3s;
}

.news-card:hover {
  transform: translateY(-5px);
}

/* ========================= */
/* QUICK LINKS */
/* ========================= */

.quick-link-card {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px;
  border-radius: 14px;
  background-color: #f8f9fa;
  transition: 0.3s;
  color: #212529;
  font-weight: 600;
}

.quick-link-card:hover {
  background: linear-gradient(90deg, #e3749d, #c53263);
  color: white;
}

.quick-link-card i {
  font-size: 1.3rem;
}

/* ========================= */
/* FOOTER */
/* ========================= */

footer {
  margin-top: 0;
}

footer h5 {
  margin-bottom: 10px;
}

/* ========================= */
/* UTILITIES */
/* ========================= */

.min-vh-75 {
  min-height: 75vh;
}

/* ===================================== */
/* CARD HOVER EFFECTS */
/* ===================================== */

.card {
  transition: all 0.3s ease;
}

.card:hover {
  transform: translateY(-5px);
}

/* ===================================== */
/* PACKAGE / TEST / DOCTOR CARDS */
/* ===================================== */

.card h4 {
  font-size: 1.2rem;
}

.card p {
  font-size: 0.95rem;
}

/* ===================================== */
/* BADGES */
/* ===================================== */

.badge {
  font-size: 0.8rem;
  padding: 8px 12px;
}

/* ===================================== */
/* PAGE HERO */
/* ===================================== */

.bg-light h1 {
  line-height: 1.3;
}

.bg-light p {
  font-size: 1rem;
}

/* ===================================== */
/* ABOUT PAGE */
/* ===================================== */

.about-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.18), transparent 30%),
    radial-gradient(circle at bottom left, rgba(255, 193, 7, 0.12), transparent 25%),
    linear-gradient(135deg, #69a2f7 0%, #1563ff 100%);
  color: #fff;
}

.about-hero .hero-tagline,
.about-hero .hero-title,
.about-hero .hero-description {
  color: #fff !important;
}

.about-hero .hero-description {
  max-width: 760px;
}

.about-panel {
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.2);
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(10px);
}

.about-panel img {
  width: 100%;
  height: 280px;
  object-fit: cover;
}

.about-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 0.7rem 1rem;
  font-weight: 600;
}

.about-elevated-card {
  border-radius: 22px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.about-elevated-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.08);
}

.about-team-card {
  border-radius: 24px;
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.about-team-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.08);
}

.about-team-img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.about-section-kicker {
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 0.82rem;
  font-weight: 700;
}

.about-muted-box {
  border-radius: 20px;
  background: rgba(13, 110, 253, 0.05);
}

.about-bio {
  min-height: 72px;
}

/* ========================= */
/* ABOUT TEAM AVATARS */
/* ========================= */

.team-avatar {
  width: 170px;
  height: 170px;
  margin: 0 auto 1.25rem;
  border-radius: 50%;
  overflow: hidden;
  background: linear-gradient(135deg, #e8eefc, #dce7ff);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 6px solid #ffffff;
  box-shadow: 0 8px 24px rgba(13, 110, 253, 0.12);
}

.team-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.team-avatar-fallback {
  font-size: 4rem;
  font-weight: 700;
  color: #0d6efd;
  line-height: 1;
}

.team-avatar-preview {
  width: 150px;
  height: 150px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  margin: 0 auto;
}

/* ========================= */
/* FOOTER */
/* ========================= */

.site-footer {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.08), transparent 25%),
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.06), transparent 20%),
    linear-gradient(135deg, #d27b98 0%, #6a193c 45%, #4b0d28 100%);
}

.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, rgba(255,255,255,0.06), transparent 45%),
    linear-gradient(300deg, rgba(255,255,255,0.04), transparent 35%);
  pointer-events: none;
}

.footer-top,
.footer-bottom {
  position: relative;
  z-index: 1;
}

.footer-brand {
  text-decoration: none;
  color: #fff;
}

.footer-brand:hover {
  color: #fff;
}

.footer-logo {
  height: 120px;
  width: auto;
  display: block;
  object-fit: contain;
}

.footer-title {
  font-weight: 700;
  margin-bottom: 1rem;
  font-size: 1.05rem;
}

.footer-text {
  color: rgba(255, 255, 255, 0.82);
  max-width: 420px;
}

.footer-links li {
  margin-bottom: 0.6rem;
}

.footer-links a {
  color: rgba(255, 255, 255, 0.82);
  transition: 0.25s ease;
}

.footer-links a:hover {
  color: #ffe082;
  padding-left: 4px;
}

.footer-contact-box {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 18px;
  padding: 1rem 1.1rem;
  backdrop-filter: blur(8px);
}

.footer-contact-box p {
  color: rgba(255, 255, 255, 0.88);
}

.footer-contact-box i {
  color: #ffe082;
}

.footer-social {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.14);
  transition: 0.25s ease;
}

.footer-social:hover {
  background: #ffe082;
  color: #3a1022;
  transform: translateY(-3px);
}

.footer-action-btn {
  border-radius: 999px;
  font-weight: 600;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(0, 0, 0, 0.08);
}

.footer-bottom-text {
  color: rgba(255, 255, 255, 0.72);
}

/* Mobile */
@media (max-width: 576px) {
  .footer-logo {
    height: 40px;
  }

  .footer-contact-box {
    padding: 0.9rem;
  }

  .footer-social {
    width: 38px;
    height: 38px;
  }
}

/* ========================= */
/* HOME UPDATE BAR */
/* ========================= */

.cwf-update-bar {
  width: 100%;
  overflow: hidden;
  background: linear-gradient(90deg, #f6edf0 0%, #f9b2cb 50%, #f6edf0 100%);
  border-bottom: 1px solid rgba(197, 50, 99, 0.12);
}

.cwf-update-track {
  display: flex;
  width: max-content;
  white-space: nowrap;
  gap: 2rem;
  padding: 0.7rem 0;
  animation: cwf-scroll-left 22s linear infinite;
  font-weight: 600;
  color: #8b1f45;
}

.cwf-update-track span {
  display: inline-flex;
  align-items: center;
  font-size: 0.95rem;
}

.cwf-update-bar:hover .cwf-update-track {
  animation-play-state: paused;
}

@keyframes cwf-scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* ===================================== */
/* FEEDBACK PAGE */
/* ===================================== */

.rating-stars {
  display: flex;
  gap: 12px;
}

.rating-stars i {
  font-size: 2rem;
  color: #d1d5db;
  cursor: pointer;
  transition: all 0.25s ease;
}

.rating-stars i.active {
  color: #ffc107;
}

.rating-stars i:hover {
  transform: scale(1.15);
}

/* ===================================== */
/* TESTIMONIAL / FEEDBACK SHOWCASE */
/* ===================================== */

.testimonial-container {

  display: flex;
  align-items: center;
  gap: 24px;

  position: relative;
}

/* ===================================== */
/* SLIDER GRID */
/* ===================================== */

.testimonial-grid {

  flex: 1;

  display: grid;
  grid-template-columns: repeat(3, 1fr);

  gap: 28px;

  transition:
    transform 0.7s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.45s ease;

  will-change: transform, opacity;

  min-height: 320px;
}

/* ===================================== */
/* CARD */
/* ===================================== */

.testimonial-card {

  background: #ffffff;

  border-radius: 28px;

  padding: 28px;

  position: relative;

  overflow: hidden;

  opacity: 0.9;

  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.08);

  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    opacity 0.35s ease;
}

/* Top Gradient Bar */

.testimonial-card::before {

  content: "";

  position: absolute;

  top: 0;
  left: 0;

  width: 100%;
  height: 5px;

  background:
    linear-gradient(
      90deg,
      #e08ca8,
      #c53263
    );
}

/* ===================================== */
/* CENTER CARD HIGHLIGHT */
/* ===================================== */

.testimonial-card.active {

  transform: scale(1.08);

  opacity: 1;

  z-index: 2;

  box-shadow:
    0 25px 60px rgba(
      197,
      50,
      99,
      0.22
    );
}

.testimonial-card.inactive {

  opacity: .75;
}

/* ===================================== */
/* HOVER EFFECT */
/* ===================================== */

.testimonial-card:hover {

  transform:
    translateY(-8px)
    scale(1.02);

  box-shadow:
    0 24px 55px rgba(
      0,
      0,
      0,
      0.12
    );
}

/* ===================================== */
/* HEADER */
/* ===================================== */

.testimonial-header {

  display: flex;
  align-items: center;

  gap: 18px;

  margin-bottom: 20px;
}

/* ===================================== */
/* AVATAR */
/* ===================================== */

.testimonial-avatar {

  width: 86px;
  height: 86px;

  border-radius: 50%;

  background:
    linear-gradient(
      135deg,
      #e08ca8,
      #c53263
    );

  color: #ffffff;

  display: flex;
  align-items: center;
  justify-content: center;

  font-size: 2.2rem;
  font-weight: 700;

  flex-shrink: 0;

  box-shadow:
    0 12px 25px rgba(
      197,
      50,
      99,
      0.25
    );
}

/* ===================================== */
/* NAME */
/* ===================================== */

.testimonial-name {

  margin-bottom: 4px;

  font-size: 1.15rem;
  font-weight: 700;

  color: #1f2328;

  text-transform: capitalize;
}

/* ===================================== */
/* SERVICE TAG */
/* ===================================== */

.testimonial-service {

  display: inline-block;

  padding: 5px 12px;

  border-radius: 999px;

  background: #f4f6ff;

  color: #0d6efd;

  font-size: 0.8rem;
  font-weight: 600;

  margin-top: 4px;
}

/* ===================================== */
/* STARS */
/* ===================================== */

.testimonial-stars {

  margin-top: 10px;

  display: flex;
  gap: 2px;
}

.testimonial-stars i {

  color: #ffc107;

  font-size: 1.05rem;
}

/* ===================================== */
/* FEEDBACK TEXT */
/* ===================================== */

.testimonial-text {

  margin-top: 18px;

  color: #495057;

  font-size: 0.96rem;

  line-height: 1.8;

  min-height: 95px;
}

/* ===================================== */
/* QUOTE ICON */
/* ===================================== */

.testimonial-quote {

  position: absolute;

  top: 18px;
  right: 22px;

  font-size: 3rem;

  color: #c53263;

  opacity: 0.08;
}

/* ===================================== */
/* NAVIGATION BUTTONS */
/* ===================================== */

.testimonial-arrow {

  width: 62px;
  height: 62px;

  border: none;

  border-radius: 50%;

  background: #ffffff;

  color: #c53263;

  display: flex;
  align-items: center;
  justify-content: center;

  font-size: 1.4rem;

  flex-shrink: 0;

  box-shadow:
    0 12px 30px rgba(
      0,
      0,
      0,
      0.12
    );

  transition: all 0.3s ease;
}

.testimonial-arrow:hover {

  transform:
    translateY(-3px)
    scale(1.08);

  background:
    linear-gradient(
      135deg,
      #e08ca8,
      #c53263
    );

  color: #ffffff;
}

/* ===================================== */
/* EMPTY STATE */
/* ===================================== */

.testimonial-empty {

  grid-column: 1 / -1;

  background: #ffffff;

  border-radius: 24px;

  padding: 60px 30px;

  text-align: center;

  box-shadow:
    0 12px 35px rgba(
      0,
      0,
      0,
      0.06
    );
}

/* ===================================== */
/* SLIDE ANIMATIONS */
/* ===================================== */

.testimonial-slide-out-left {

  opacity: 0;

  transform:
    translateX(-120px);

  transition:
    transform .55s cubic-bezier(
      .22,
      1,
      .36,
      1
    ),
    opacity .55s ease;
}

.testimonial-slide-out-right {

  opacity: 0;

  transform:
    translateX(120px);

  transition:
    transform .55s cubic-bezier(
      .22,
      1,
      .36,
      1
    ),
    opacity .55s ease;
}

.testimonial-slide-in {

  opacity: 1;

  transform:
    translateX(0);

  transition:
    transform .55s cubic-bezier(
      .22,
      1,
      .36,
      1
    ),
    opacity .55s ease;
}

/* ===================================== */
/* SECTION TITLE ENHANCEMENT */
/* ===================================== */

.testimonial-section .section-title {

  font-size: 3rem;

  font-weight: 800;

  margin-bottom: 15px;
}

.testimonial-section .section-description {

  max-width: 700px;

  margin: 0 auto;

  font-size: 1.15rem;

  color: #6c757d;
}

.package-card-image {

  height:220px;

  object-fit:cover;

  border-radius:
    16px 16px 0 0;
}

.package-market-price {

  text-decoration:line-through;

  color:#6c757d;

  font-size:.95rem;
}

.package-our-price {

  color:#198754;

  font-size:2rem;

  font-weight:700;
}

.package-save {

  color:#dc3545;

  font-weight:600;
}

.package-preview{

  width:100%;

  height:220px;

  overflow:hidden;

  border-radius:12px;

  border:1px solid #dee2e6;
}

.package-preview img{

  width:100%;

  height:100%;

  object-fit:cover;
}

/* ===================================== */
/* HOMEPAGE ADS CAROUSEL */
/* ===================================== */

.ads-carousel-container{

  display:flex;

  align-items:center;

  gap:24px;

  perspective:1400px;
}

.ads-grid{

    align-items:center;

  flex:1;

  display:grid;

  grid-template-columns:
    repeat(3,1fr);

  gap:12px;

  min-height:340px;
}


.ad-card{

  display:flex;

  align-items:center;

  justify-content:center;

  overflow:hidden;

  border-radius:24px;

  background:transparent;

  box-shadow:none;

  height:auto;

  transition:
    transform .35s ease,
    opacity .35s ease;
}

.ad-card img{

  width:100%;

  height:auto;

  object-fit:contain;

  display:block;

  border-radius:24px;

  transition:
    transform .7s cubic-bezier(
      .22,1,.36,1
    ),
    box-shadow .7s ease,
    opacity .7s ease;

  box-shadow:
    0 15px 35px rgba(
      0,0,0,.10
    );
}

.ad-card.active img{

  box-shadow:

    0 35px 90px rgba(
      0,0,0,.20
    ),

    0 15px 45px rgba(
      197,50,99,.18
    );
}

.ad-card.active{

  transform:
    scale(1.18);

  opacity:1;

  z-index:20;
}

.ad-card.inactive{

  transform:scale(.88);

  opacity:.45;

  filter:saturate(.8);

  z-index:1;
}

.ad-card:hover{

  cursor:pointer;
}

.ads-arrow{

  width:62px;
  height:62px;

  border:none;

  border-radius:50%;

  background:#fff;

  color:#c53263;

  font-size:1.4rem;

  display:flex;
  align-items:center;
  justify-content:center;

  box-shadow:
    0 12px 30px rgba(
      0,0,0,.12
    );

  transition:.3s;
}

.ads-arrow:hover{

  background:
    linear-gradient(
      135deg,
      #e08ca8,
      #c53263
    );

  color:#fff;

  transform:
    translateY(-3px)
    scale(1.08);
}

/* ================================= */
/* GOOGLE TRANSLATE CLEANUP */
/* ================================= */

.goog-te-banner-frame,
.skiptranslate,
.goog-te-gadget,
.goog-te-combo,
.goog-te-balloon-frame,
#goog-gt-tt,
.goog-tooltip,
.goog-tooltip:hover {
    display:none !important;
}

body{
    top:0 !important;
}

iframe.skiptranslate{
    display:none !important;
}

.goog-logo-link{
    display:none !important;
}

#google_translate_element{
    display:none !important;
}
#langToggle{

  border-radius:999px;

  padding:10px 18px;

  font-weight:700;

  min-width:110px;
}

/* ===================================== */
/* BLOG ADMIN */
/* ===================================== */

#blogEditor{

  height:350px;

  background:#ffffff;
}

/* ===================================== */
/* BLOG PAGE */
/* ===================================== */

.blog-card-image{

  height:240px;

  object-fit:cover;

  width:100%;
}

/* ===================================== */
/* BLOG DETAILS PAGE */
/* ===================================== */

.blog-article-container{

  max-width:900px;

  margin:auto;
}

.blog-hero-image{

  width:100%;

  height:500px;

  object-fit:cover;

  border-radius:24px;
}

.blog-title{

  font-size:2.7rem;

  font-weight:700;

  margin-bottom:15px;
}

.blog-meta{

  color:#6c757d;

  margin-bottom:20px;
}

.blog-content{

  font-size:1.05rem;

  line-height:1.9;
}

.blog-content img{

  max-width:100%;

  height:auto;

  border-radius:16px;
}

.blog-content h1,
.blog-content h2,
.blog-content h3{

  margin-top:30px;

  margin-bottom:15px;
}

/* ===================================== */
/* HOMEPAGE BLOGS */
/* ===================================== */

.blog-home-image{

  width:100%;

  height:220px;

  object-fit:cover;
}

.blog-home-card{

  transition:.3s ease;
}

.blog-home-card:hover{

  transform:translateY(-5px);
}

/* ===================================== */
/* VIEW ALL BLOG CARD */
/* ===================================== */

.blog-view-all-card{

  display:block;

  height:100%;

  min-height:100%;

  border-radius:24px;

  background:
    linear-gradient(
      135deg,
      #e3749d,
      #c53263
    );

  color:#fff;

  overflow:hidden;

  transition:.35s ease;

  box-shadow:
    0 15px 40px
    rgba(
      197,
      50,
      99,
      .20
    );
}

.blog-view-all-card:hover{

  transform:
    translateY(-8px);

  color:#fff;

  box-shadow:
    0 25px 60px
    rgba(
      197,
      50,
      99,
      .30
    );
}

.blog-view-all-inner{

  height:100%;

  min-height:420px;

  display:flex;

  flex-direction:column;

  justify-content:center;

  align-items:center;

  text-align:center;

  padding:40px;
}

.blog-view-icon{

  font-size:4rem;

  margin-bottom:20px;

  opacity:.95;
}

.blog-view-all-inner h4{

  margin-bottom:15px;
}

.blog-view-all-inner p{

  color:
    rgba(
      255,
      255,
      255,
      .85
    );

  max-width:220px;
}

#homepageBlogsGrid{

  justify-content:center;
}

.blog-view-all-card{

  max-width:380px;

  margin:auto;
}

/* =====================================
   RESEARCH PAGE
===================================== */

.research-card {

  border-radius: 22px;

  overflow: hidden;

  transition: all .3s ease;

  height: 100%;

}

.research-card:hover {

  transform: translateY(-6px);

}

.research-card-image {

  width: 100%;

  height: 240px;

  object-fit: cover;

}

.research-category {

  display: inline-block;

  padding: 6px 14px;

  border-radius: 999px;

  background: #eef4ff;

  color: #0d6efd;

  font-size: .8rem;

  font-weight: 600;

}

.research-authors {

  color: #6c757d;

  font-size: .95rem;

}

.research-date {

  color: #6c757d;

  font-size: .9rem;

}

.research-abstract {

  color: #495057;

  line-height: 1.7;

}

.research-empty-state {

  text-align: center;

  padding: 60px 20px;

}

.research-empty-state i {

  font-size: 4rem;

  color: #adb5bd;

}

.research-search-box {

  max-width: 500px;

  margin: auto;

}

.research-filter-card {

  border-radius: 18px;

}

.research-view-btn {

  border-radius: 999px;

}

@media (max-width:768px) {

  .research-card-image {

    height: 200px;

  }

}