
/* =========================
   HandyGoan Premium Theme Add-on
   Improves ALL pages (3D, spacing, page heroes, cards)
   ========================= */

:root{
  --hg-shadow: 0 18px 45px rgba(2, 6, 23, .08);
  --hg-shadow2: 0 10px 30px rgba(2, 6, 23, .10);
  --hg-radius: 18px;
  --hg-radius-lg: 26px;
  --hg-glass: rgba(255,255,255,.72);
}

/* =========================
   NAVBAR (Mobile polish)
   Fixes: broken collapse layout, search alignment, spacing
   ========================= */
@media (max-width: 992px){
  /* Bootstrap collapse should control visibility (avoid custom display:none rules) */
  .navbar .navbar-collapse{ width: 100%; }
  .navbar .navbar-collapse.collapse{ display: none; }
  .navbar .navbar-collapse.collapse.show{ display: block; }

  .navbar .navbar-collapse{
    margin-top: 10px;
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 18px;
    padding: 10px;
    box-shadow: var(--hg-shadow2);
  }

  .navbar .navbar-nav{
    width: 100%;
    margin-left: 0 !important;
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    padding: 4px;
  }
  .navbar .navbar-nav .nav-link{
    width: 100%;
    border-radius: 12px;
    padding: 10px 12px !important;
  }
  .navbar .navbar-nav .nav-link:hover{
    background: rgba(2,6,23,.04);
  }

  .navbar .nav-actions{
    width: 100%;
    margin-left: 0 !important;
    padding: 10px 6px 6px;
    gap: 10px;
  }
  .navbar .nav-search{ flex: 1 1 auto; width: auto !important; }
  .navbar .nav-search input{ height: 44px; }
  .navbar .admin-link{ width: 44px; height: 44px; }
}

/* =========================
   BLOG (Read more page)
   Cleaner typography + premium cards + sidebar
   ========================= */
.blog-card{
  border-radius: 22px !important;
  box-shadow: 0 18px 50px rgba(2,6,23,.08);
  border: 1px solid rgba(2,6,23,.06) !important;
}
.blog-card .badge{ border-radius: 999px; padding: .5rem .75rem; font-weight: 700; }
.blog-excerpt{
  display: -webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 4.2em;
}
.blog-readtime{ font-size: .85rem; color: rgba(17,24,39,.55); }
.btn-readmore{ border-radius: 999px; font-weight: 700; }
.btn-readmore span{ display:inline-block; transition: transform .18s ease; }
.btn-readmore:hover span{ transform: translateX(2px); }

.blogPost-card{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 18px;
  box-shadow: var(--hg-shadow);
}
.blogPost-content{
  font-size: 1.02rem;
}
.blogPost-content h2{
  font-size: 1.55rem;
}
.blogPost-content h3{
  font-size: 1.22rem;
}
.blogPost-content p{
  margin-bottom: 14px;
}

.blogSide{
  display: grid;
  gap: 14px;
  position: sticky;
  top: 92px; /* below sticky navbar */
}
.blogSide-card{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(2,6,23,.10);
  border-radius: 20px;
  padding: 16px 16px 16px 18px;
  box-shadow: 0 14px 34px rgba(2,6,23,.08);
  position: relative;
}
.blogSide-card::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width: 4px;
  border-radius: 20px 0 0 20px;
  background: linear-gradient(180deg, rgba(249,115,22,.9), rgba(59,130,246,.7));
  opacity: .65;
  z-index: 0;
}
.blogSide-card > *{ position: relative; z-index: 1; }
.blogSide-title{
  font-weight: 900;
  letter-spacing: -.01em;
  margin-bottom: 10px;
}
.blogSide-list{
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
}
.blogSide-list li{ padding: 8px 0; border-bottom: 1px dashed rgba(0,0,0,.08); }
.blogSide-list li:last-child{ border-bottom: 0; }

.blogSide-actions{
  display: grid;
  gap: 10px;
}
.blogSide-check{ padding-left: 18px; margin: 0; }
.blogSide-check li{ margin: 8px 0; color: rgba(17,24,39,.86); }

.blogSide-links{
  display: grid;
  gap: 10px;
}
.blogSide-links a{
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  text-decoration: none;
  color: rgba(17,24,39,.92);
  background: rgba(2,6,23,.02);
}
.blogSide-links a:hover{ background: rgba(2,6,23,.05); }

@media (max-width: 992px){
  .blogPost-card{ padding: 14px; }
  .blogSide{ position: static; top: auto; }
}

/* =========================
   FOOTER (Premium)
   Cleaner hierarchy, better spacing, premium background
   ========================= */
.footer-premium{
  color: rgba(255,255,255,.9);
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(255,85,0,.22), transparent 55%),
    radial-gradient(900px 500px at 90% 20%, rgba(59,130,246,.22), transparent 55%),
    linear-gradient(180deg, #0b1220 0%, #070b14 100%);
  border-top: 1px solid rgba(255,255,255,.08);
}
.footer-premium .footer-top{ padding: 44px 0 18px; }
.footer-premium .footer-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.75);
  font-size: .95rem;
}
.footer-premium .footer-bottom a{ color: rgba(255,255,255,.78); text-decoration:none; }
.footer-premium .footer-bottom a:hover{ color: #fff; }
.footer-premium .dot{ opacity:.6; }

.footer-premium .footer-bottom .muted{ color: rgba(255,255,255,.62); }

.footer-brand{ display:flex; gap: 12px; align-items:center; margin-bottom: 14px; }
.footer-logo{
  width: 180px;
  height: 46px;
  object-fit: contain;
  background: rgba(255,255,255,.98);
  border-radius: 14px;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 45px rgba(0,0,0,.22);
}
.footer-name{ font-weight: 900; letter-spacing: -.02em; font-size: 1.08rem; }
.footer-tag{ color: rgba(255,255,255,.72); font-size: .92rem; }
.footer-desc{ color: rgba(255,255,255,.72); margin: 0 0 18px; max-width: 44ch; }

.footer-mini{ display:flex; flex-wrap:wrap; gap: 8px; margin-bottom: 18px; }
.footer-mini .pill{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.80);
  font-size: .85rem;
}

.footer-title{
  font-weight: 800;
  letter-spacing: -.01em;
  margin-bottom: 12px;
}
.footer-links{ list-style:none; padding:0; margin:0; display:grid; gap: 10px; }
.footer-links a{
  color: rgba(255,255,255,.72);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap: 8px;
}
.footer-links a:hover{ color:#fff; }

.footer-social{ display:flex; gap: 10px; }
.footer-social-btn{
  width: 40px;
  height: 40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 14px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.92);
  text-decoration:none;
}
.footer-social-btn:hover{ background: rgba(255,255,255,.14); color:#fff; }

.footer-contact{ display:grid; gap: 10px; }
.footer-contact a{
  color: rgba(255,255,255,.78);
  text-decoration:none;
  display:flex;
  gap: 10px;
  align-items:center;
}
.footer-contact a:hover{ color:#fff; }
.footer-contact i{ width: 18px; text-align:center; opacity:.9; }
.footer-address{ display:flex; gap: 10px; color: rgba(255,255,255,.72); align-items:flex-start; }
.footer-address i{ width: 18px; margin-top: 2px; opacity:.9; }

.footer-cta{ display:flex; gap: 10px; flex-wrap:wrap; margin: 14px 0 14px; }
/* Map iframe removed for a cleaner, faster footer. */
.footer-map{ display:none; }

@media (max-width: 992px){
  .footer-premium .footer-top{ padding: 44px 0 22px; }
  .footer-premium .footer-bottom{ flex-direction: column; align-items:flex-start; }
}

/* Page hero */
.page-hero{
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(229,231,235,.8);
  background: radial-gradient(900px 450px at 15% 10%, rgba(249,115,22,.18), transparent 55%),
              radial-gradient(700px 400px at 85% 20%, rgba(59,130,246,.14), transparent 55%),
              linear-gradient(180deg, #ffffff, #fbfbfb);
}
.page-hero .container{ position: relative; z-index: 2; }
.page-hero .hero-kicker{
  display:inline-flex; gap:.5rem; align-items:center;
  font-weight:600; color: var(--muted);
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(229,231,235,.9);
  padding: .35rem .65rem;
  border-radius: 999px;
  box-shadow: 0 10px 30px rgba(2,6,23,.05);
}
.page-hero h1{
  font-size: clamp(28px, 4vw, 44px);
  letter-spacing: -0.03em;
}
.page-hero .hero-sub{
  font-size: 1.05rem;
  color: var(--muted);
  max-width: 62ch;
}
.page-hero .hero-bg{
  position:absolute; inset:0;
  background-size: cover;
  background-position: center;
  opacity:.08;
  filter: saturate(1.1) contrast(1.05);
}
.page-hero .hero-orb{
  position:absolute; width:520px; height:520px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(249,115,22,.25), transparent 58%),
              radial-gradient(circle at 70% 70%, rgba(59,130,246,.18), transparent 58%);
  filter: blur(2px);
  opacity: .9;
  transform: translate3d(0,0,0);
}
.page-hero .orb-1{ left:-220px; top:-220px;}
.page-hero .orb-2{ right:-260px; top:-260px; opacity:.75;}

/* Cards */
.hg-card{
  background: #fff;
  border: 1px solid rgba(229,231,235,.9);
  border-radius: var(--hg-radius);
  box-shadow: var(--hg-shadow);
}
.hg-card.soft{ box-shadow: 0 10px 28px rgba(2,6,23,.06); }
.hg-card:hover{
  transform: translateY(-2px);
  transition: transform .18s ease, box-shadow .18s ease;
  box-shadow: 0 22px 55px rgba(2,6,23,.10);
}

.hg-glass{
  background: var(--hg-glass);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(229,231,235,.8);
  border-radius: var(--hg-radius-lg);
  box-shadow: 0 25px 70px rgba(2,6,23,.08);
}

.section-title{
  display:flex; align-items:flex-end; justify-content:space-between; gap:1rem;
  margin-bottom: 1.1rem;
}
.section-title h2{
  letter-spacing: -0.02em;
  font-size: clamp(22px, 2.6vw, 30px);
}
.section-title p{ margin:0; color: var(--muted); }

/* 3D hover (About page) */
.tilt-wrap{ perspective: 900px; }
.tilt-card{
  transform-style: preserve-3d;
  transition: transform .22s ease, box-shadow .22s ease;
}
.tilt-wrap:hover .tilt-card{
  transform: rotateX(3deg) rotateY(-4deg) translateY(-3px);
  box-shadow: 0 28px 80px rgba(2,6,23,.12);
}
.tilt-card .tilt-pop{ transform: translateZ(18px); }

/* Better placeholders */
.thumb-placeholder, .img-placeholder{
  width:100%; height:100%;
  min-height: 170px;
  display:grid; place-items:center;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(249,115,22,.12), rgba(59,130,246,.10));
  border: 1px dashed rgba(148,163,184,.55);
  color: rgba(15,23,42,.55);
}
.img-placeholder.sm{ min-height: 110px; border-radius: 12px; }

/* Floating widgets spacing so buttons don't block submit */
.form-safe-bottom{ padding-bottom: 86px; }

/* Home image slider (horizontal) */
.hg-photo-slider{
  position: relative;
  overflow:hidden;
  border-radius: 22px;
  border: 1px solid rgba(229,231,235,.9);
  box-shadow: var(--hg-shadow2);
}
.hg-photo-track{
  display:flex;
  gap:0;
  width:100%;
  animation: hgSlide 24s linear infinite;
}
.hg-photo{
  flex: 0 0 100%;
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
}
@keyframes hgSlide{
  0%{ transform: translateX(0%); }
  28%{ transform: translateX(0%); }
  33%{ transform: translateX(-100%); }
  61%{ transform: translateX(-100%); }
  66%{ transform: translateX(-200%); }
  94%{ transform: translateX(-200%); }
  100%{ transform: translateX(0%); }
}
@media (prefers-reduced-motion: reduce){
  .hg-photo-track{ animation: none; }
}

/* Footer tidy */
.footer-links{ display:none !important; }

/* Careers opening avatar */
.opening-avatar{
  width:42px; height:42px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(249,115,22,.16), rgba(59,130,246,.12));
  border: 1px solid rgba(229,231,235,.9);
  color: rgba(15,23,42,.75);
  flex: 0 0 auto;
}

/* Make homepage mosaic clickable with real images */
.hg-mosaic a{ display:block; color: inherit; text-decoration:none; }
.hg-mosaic-main, .hg-mosaic-side{
  background-size: cover !important;
  background-position: center !important;
}
.hg-mosaic-main::before, .hg-mosaic-side::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(2,6,23,.12), rgba(2,6,23,.55));
  border-radius: inherit;
}
.hg-mosaic-main > *, .hg-mosaic-side > *{ position:relative; z-index:2; }

/* Home readability fixes */
.hg-big-title{ color:#0B1220; }
.hg-p{ color: rgba(30,41,59,.85); }
.hg-outline{ -webkit-text-stroke: 1px rgba(15,23,42,.35); color: transparent; }
.hg-hero{ padding-top: 42px; }



/* Clients logos (placeholders for now) */
.hg-clients-strip{
  padding: 26px 0;
  border-top: 1px solid rgba(229,231,235,.9);
  border-bottom: 1px solid rgba(229,231,235,.9);
  background: linear-gradient(180deg, rgba(249,115,22,.06), rgba(17,24,39,.02));
}
.hg-clients-label{
  text-align:center;
  font-weight: 800;
  color: rgba(17,24,39,.78);
  margin-bottom: 14px;
}
.hg-clients-logos{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  justify-content:center;
  align-items:stretch;
  padding: 0 18px 6px;
}
.hg-logo-card{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(229,231,235,.9);
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  min-width: min(240px, calc(100vw - 60px));
}
.hg-logo-card img{
  width: 44px; height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(229,231,235,.9);
  background:#fff;
  flex: 0 0 auto;
}
.hg-logo-card span{
  font-weight: 800;
  color: rgba(17,24,39,.78);
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}


/* === UI POLISH PACK (Hero / Details / Blogs / Careers) === */
.hg-hero-media{
  display:flex;
  justify-content:flex-end;
  align-items:stretch;
}
.hg-photo-slider{
  width: 100%;
  max-width: 560px;
  border-radius: 26px;
  position: relative;
  isolation: isolate;
  transform: translateZ(0);
}
.hg-photo-slider::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(59,130,246,.55), rgba(249,115,22,.45));
  filter: blur(16px);
  opacity: .45;
  z-index: -2;
}
.hg-photo-slider::after{
  content:"";
  position:absolute; inset:0;
  border-radius: inherit;
  background: radial-gradient(800px 300px at 20% 10%, rgba(255,255,255,.16), transparent 60%),
              radial-gradient(700px 280px at 85% 60%, rgba(249,115,22,.10), transparent 60%);
  pointer-events:none;
  z-index: 2;
}
.hg-photo{
  position: relative;
}
.hg-photo::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(2,6,23,.06), rgba(2,6,23,.32));
}
.hg-photo-slider{ animation: hgFloat 7s ease-in-out infinite; }
@keyframes hgFloat{
  0%,100%{ transform: translateY(0px); }
  50%{ transform: translateY(-8px); }
}

@media (max-width: 991px){
  .hg-hero-grid{ grid-template-columns: 1fr; align-items:start; }
  .hg-hero-media{ justify-content:flex-start; }
  .hg-photo-slider{ max-width: 100%; }
}

/* Solution detail image */
.detail-media{ margin-bottom: 16px; }
.detail-media-frame{
  border-radius: 22px;
  overflow:hidden;
  border: 1px solid rgba(229,231,235,.9);
  background: #F6F8FB;
  box-shadow: 0 18px 55px rgba(0,0,0,.12);
  position: relative;
}
.detail-media-frame img{ width:100%; height:auto; display:block; }
.detail-media-placeholder{ position:relative; }
.detail-media-badge{
  position:absolute;
  left: 14px; bottom: 14px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(229,231,235,.9);
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(10px);
  font-weight: 800;
  color: rgba(17,24,39,.85);
}

/* Top selling card CTA alignment */
.corp-tile .card-body{ min-height: 190px; }
.corp-tile .btn{ border-radius: 14px; }

/* Corp tiles (About - Life at HandyGoan) */
.corp-tile{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 30px rgba(15,23,42,.06);
  height: 100%;
}
.corp-tile img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}
.corp-tile .body{
  padding: 16px 16px 18px;
}
.corp-tile .h{
  font-weight: 800;
  font-size: 1.05rem;
  margin-bottom: 6px;
}
.corp-tile .p{
  color: #475569;
  line-height: 1.55;
  margin: 0;
}
@media (max-width: 991px){
  .corp-tile img{ height: 200px; }
}


/* Blogs */
.blog-hero{
  background:
    radial-gradient(900px 380px at 12% 20%, rgba(59,130,246,.18), transparent 60%),
    radial-gradient(900px 360px at 88% 20%, rgba(249,115,22,.14), transparent 60%),
    linear-gradient(180deg, rgba(248,250,252,1), rgba(255,255,255,1));
  border-bottom: 1px solid rgba(229,231,235,.9);
}
.blog-card{
  border-radius: 20px !important;
  transition: 180ms ease;
}
.blog-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 60px rgba(0,0,0,.10) !important;
}

/* Blog post (read more) polish */
.blogPost-hero{
  background:
    radial-gradient(900px 380px at 10% 10%, rgba(59,130,246,.18), transparent 60%),
    radial-gradient(900px 360px at 90% 10%, rgba(249,115,22,.14), transparent 60%),
    linear-gradient(180deg, rgba(248,250,252,1), rgba(255,255,255,1));
  border-bottom: 1px solid rgba(229,231,235,.9);
}
.blogPost-card{
  border-radius: 22px;
  border: 1px solid rgba(229,231,235,.9);
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 60px rgba(0,0,0,.10);
}

/* Careers CV upload */
.cv-drop{
  border: 1px dashed rgba(148,163,184,.9);
  border-radius: 16px;
  padding: 12px;
  background: rgba(248,250,252,.9);
}
.cv-help{
  margin-top: 8px;
  font-size: .88rem;
  color: rgba(17,24,39,.6);
}



/* =========================
   Solution Detail (Ultra Premium)
   ========================= */
.sol-hero{
  position: relative;
  padding: 72px 0 42px;
  overflow:hidden;
  border-bottom: 1px solid rgba(229,231,235,.9);
  background: linear-gradient(180deg, rgba(248,250,252,1), rgba(255,255,255,1));
}
.sol-hero-bg{
  position:absolute; inset:0;
  background-size: cover;
  background-position: center;
  filter: saturate(1.1) contrast(1.05);
  opacity:.16;
  transform: scale(1.02);
}
.sol-hero-bg--fallback{
  background:
    radial-gradient(900px 380px at 12% 20%, rgba(59,130,246,.18), transparent 60%),
    radial-gradient(900px 360px at 88% 20%, rgba(249,115,22,.14), transparent 60%),
    linear-gradient(180deg, rgba(248,250,252,1), rgba(255,255,255,1));
  opacity: 1;
}
.sol-hero-card{
  position: relative;
}
.sol-hero-orb{
  position:absolute;
  width:520px; height:520px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(249,115,22,.25), transparent 58%),
              radial-gradient(circle at 70% 70%, rgba(59,130,246,.18), transparent 58%);
  opacity: .9;
  filter: blur(2px);
  animation: hgFloat 7s ease-in-out infinite;
  pointer-events:none;
}
.sol-hero-orb--1{ left:-240px; top:-260px; }
.sol-hero-orb--2{ right:-280px; top:-300px; opacity:.7; animation-delay: .8s; }

.sol-pill{
  border-radius: 999px;
  padding: .42rem .7rem;
  font-weight: 800;
  border: 1px solid rgba(229,231,235,.9);
  background: rgba(255,255,255,.75);
  color: rgba(17,24,39,.78);
}
.sol-pill--soft{
  background: rgba(248,250,252,.85);
  color: rgba(17,24,39,.72);
}

.sol-title{
  font-size: clamp(30px, 4.2vw, 48px);
  letter-spacing: -0.03em;
  margin: 0;
}
.sol-sub{
  color: rgba(17,24,39,.68);
  max-width: 70ch;
  margin-top: 10px;
  font-size: 1.05rem;
}

.sol-media img{
  display:block;
  width:100%;
  height:auto;
}
.sol-tabs .nav-link{
  font-weight: 800;
  color: rgba(17,24,39,.70);
  border: none;
  border-bottom: 2px solid transparent;
  padding: 14px 18px;
}
.sol-tabs .nav-link.active{
  color: rgba(29,78,216,1);
  border-bottom-color: rgba(29,78,216,1);
  background: rgba(248,250,252,.6);
}
.sol-chip{
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(229,231,235,.9);
  background: rgba(248,250,252,.85);
  color: rgba(17,24,39,.74);
  font-weight: 700;
}
.sol-thumb{
  width: 92px; height: 72px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(229,231,235,.9);
  background: rgba(248,250,252,.9);
  flex: 0 0 auto;
}
.sol-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }

.sol-sticky{
  position: sticky;
  top: 110px;
}

.sol-mini{
  display:grid;
  gap: 8px;
}
.sol-mini-item{
  display:flex;
  align-items:center;
  gap: 10px;
  font-weight: 700;
  color: rgba(17,24,39,.72);
}
.sol-mini-item i{
  color: rgba(29,78,216,.9);
}

@media (max-width: 991px){
  .sol-sticky{ position: static; top:auto; }
  .sol-hero{ padding-top: 52px; }
}


/* Shared page banner (same as Blogs hero) */
.page-banner .page-banner-title{ font-size: clamp(2.2rem, 3vw, 3.2rem); }
.page-banner .page-banner-subtitle{ max-width: 62ch; }

/* Footer links visibility safeguard */
.footer-links{ display:grid !important; }
.footer-links li{ display:list-item !important; }
.footer-links a{ opacity:1 !important; visibility:visible !important; }
